2024-11-18 22:04:59 +08:00
|
|
|
<template>
|
2024-12-05 15:22:46 +08:00
|
|
|
<div>
|
|
|
|
|
<div class="test-dialog">
|
|
|
|
|
<div class="dialog-left">
|
|
|
|
|
<el-steps direction="vertical" :active="activeIndex" :process-status="currentStepStatus"
|
|
|
|
|
finish-status="success">
|
|
|
|
|
<el-step title="开始检测" :description="startTime" />
|
|
|
|
|
<el-step title="GPS完成上送" :description="gpsTime" />
|
|
|
|
|
<el-step title="设备开始上送时刻" :description="devStartTime" />
|
|
|
|
|
<el-step title="设备最晚上送时刻" :description="devEndTime" />
|
|
|
|
|
<el-step title="检测完成" :description="finishTime" />
|
|
|
|
|
</el-steps>
|
2024-12-03 17:13:47 +08:00
|
|
|
<!-- <el-timeline style="max-width: 600px">
|
2024-11-21 23:02:43 +08:00
|
|
|
<el-timeline-item
|
|
|
|
|
v-for="(activity, index) in activities"
|
|
|
|
|
:key="index"
|
|
|
|
|
:icon="activity.icon"
|
|
|
|
|
:type="activity.type"
|
|
|
|
|
:color="activity.color"
|
|
|
|
|
:size="activity.size"
|
|
|
|
|
:hollow="activity.hollow"
|
|
|
|
|
:timestamp="activity.timestamp"
|
|
|
|
|
>
|
|
|
|
|
{{ activity.content }}
|
|
|
|
|
</el-timeline-item>
|
2024-12-03 17:13:47 +08:00
|
|
|
</el-timeline> -->
|
2024-12-05 15:22:46 +08:00
|
|
|
</div>
|
|
|
|
|
<div class="dialog-right">
|
|
|
|
|
<div class="right-title">
|
|
|
|
|
<!-- <div>设备上送时刻表</div> -->
|
|
|
|
|
<span style=" font-size: 18px;font-weight: 600;">
|
|
|
|
|
设备已合格 <span style="color: #67C23A">{{ qualified }}</span> 台/共 <span style="color: green">4</span> 台
|
|
|
|
|
</span>
|
|
|
|
|
<div>
|
|
|
|
|
<!-- <el-button type="primary" loading v-if="activeIndex > 0 && activeIndex < activeTotalNum">设备已合格3台/共4台</el-button>
|
|
|
|
|
<el-button type="primary" disabled="true" v-if="activeIndex === activeTotalNum">设备已合格3台/共4台</el-button> -->
|
|
|
|
|
|
|
|
|
|
</div>
|
2024-11-18 22:04:59 +08:00
|
|
|
</div>
|
|
|
|
|
<div class="right-content">
|
2024-12-05 15:22:46 +08:00
|
|
|
<ProTable ref='proTable' :pagination='false' :toolButton='false' :showCard='false' :columns='columns'
|
|
|
|
|
:data='deviceOperatorData' stripe :header-cell-style="{ textAlign: 'center' }"
|
|
|
|
|
:cell-style="{ textAlign: 'center' }" style="width: 100%; height:435px" border>
|
2024-12-05 13:46:53 +08:00
|
|
|
</ProTable>
|
|
|
|
|
|
2024-12-05 15:22:46 +08:00
|
|
|
<!-- <el-table :data="deviceOperatorData" stripe :header-cell-style="{ textAlign: 'center' } " :cell-style="{ textAlign: 'center' }" style="width: 100%" border>
|
2024-11-18 22:04:59 +08:00
|
|
|
<el-table-column prop="deviceName" label="设备名" />
|
|
|
|
|
<el-table-column prop="updataTime" label="上送时刻" />
|
|
|
|
|
<el-table-column prop="ErrorValue" label="守时误差(ms)" />
|
2024-11-21 23:02:43 +08:00
|
|
|
<el-table-column prop="Result" label="检测结果">
|
|
|
|
|
<template #default="scope">
|
|
|
|
|
<el-tag :type="scope.row.Result === '合格' ? 'success' : 'danger'">{{ scope.row.Result }}</el-tag>
|
|
|
|
|
</template>
|
2024-12-05 15:22:46 +08:00
|
|
|
</el-table-column>
|
|
|
|
|
</el-table> -->
|
2024-11-18 22:04:59 +08:00
|
|
|
</div>
|
2024-12-05 15:22:46 +08:00
|
|
|
</div>
|
2024-11-18 22:04:59 +08:00
|
|
|
</div>
|
2024-12-05 15:22:46 +08:00
|
|
|
</div>
|
2024-11-18 22:04:59 +08:00
|
|
|
|
|
|
|
|
</template>
|
|
|
|
|
<script lang="tsx" setup name="timeTest">
|
|
|
|
|
import { SuccessFilled } from '@element-plus/icons-vue'
|
|
|
|
|
|
|
|
|
|
const activeIndex = ref(0)
|
|
|
|
|
const activeTotalNum = ref(5)
|
2024-12-05 11:21:10 +08:00
|
|
|
const startTime = ref('')
|
|
|
|
|
const gpsTime = ref('')
|
|
|
|
|
const devStartTime = ref('')
|
|
|
|
|
const devEndTime = ref('')
|
|
|
|
|
const finishTime = ref('')
|
2024-11-18 22:04:59 +08:00
|
|
|
|
2024-11-21 23:02:43 +08:00
|
|
|
interface Activity {
|
|
|
|
|
content: string;
|
|
|
|
|
hollow?: boolean;
|
|
|
|
|
timestamp?: string;
|
|
|
|
|
size?: string;
|
|
|
|
|
color?: string;
|
|
|
|
|
icon?: any;
|
|
|
|
|
}
|
2024-12-05 15:22:46 +08:00
|
|
|
const qualified = ref(0)
|
2024-11-21 23:02:43 +08:00
|
|
|
const activities = ref<Activity[]>([
|
2024-11-18 22:04:59 +08:00
|
|
|
{
|
|
|
|
|
content: '开始检测',
|
|
|
|
|
hollow: true,
|
2024-11-21 23:02:43 +08:00
|
|
|
},])
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const deviceOperatorData = ref([
|
2024-12-05 15:22:46 +08:00
|
|
|
{
|
|
|
|
|
deviceName: '240001',
|
|
|
|
|
updataTime: '—',
|
|
|
|
|
ErrorValue: '—',
|
|
|
|
|
Result: '—',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
deviceName: '240002',
|
|
|
|
|
updataTime: '—',
|
|
|
|
|
ErrorValue: '—',
|
|
|
|
|
Result: '—',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
deviceName: '240003',
|
|
|
|
|
updataTime: '—',
|
|
|
|
|
ErrorValue: '—',
|
|
|
|
|
Result: '—',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
deviceName: '240004',
|
|
|
|
|
updataTime: '—',
|
|
|
|
|
ErrorValue: '—',
|
|
|
|
|
Result: '—',
|
|
|
|
|
},
|
|
|
|
|
])
|
2024-11-18 22:04:59 +08:00
|
|
|
|
2024-12-05 15:22:46 +08:00
|
|
|
const deviceData = ref([
|
|
|
|
|
{
|
|
|
|
|
deviceName: '240001',
|
|
|
|
|
updataTime: '2024-12-05 10:30:08.136',
|
|
|
|
|
ErrorValue: '148',
|
|
|
|
|
Result: '合格',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
deviceName: '240002',
|
|
|
|
|
updataTime: '2024-12-05 10:30:08.136',
|
|
|
|
|
ErrorValue: '136',
|
|
|
|
|
Result: '合格',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
deviceName: '240003',
|
|
|
|
|
updataTime: '2024-12-05 10:30:09.006',
|
|
|
|
|
ErrorValue: '1006',
|
|
|
|
|
Result: '不合格',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
deviceName: '240004',
|
|
|
|
|
updataTime: '2024-12-05 10:30:08.736',
|
|
|
|
|
ErrorValue: '736',
|
|
|
|
|
Result: '合格',
|
|
|
|
|
},
|
|
|
|
|
])
|
2024-11-18 22:04:59 +08:00
|
|
|
const currentStepStatus = ref<'error' | 'finish' | 'wait' | 'success' | 'process'>('finish');
|
|
|
|
|
|
2024-12-05 15:22:46 +08:00
|
|
|
const props = defineProps({
|
|
|
|
|
testStatus: {
|
2024-11-18 22:04:59 +08:00
|
|
|
type: String,
|
|
|
|
|
default: 'wait'
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
const testStatus = toRef(props, 'testStatus');
|
|
|
|
|
const ts = ref('');
|
2024-12-05 13:46:53 +08:00
|
|
|
|
|
|
|
|
// 表格配置项
|
|
|
|
|
const columns = reactive([
|
|
|
|
|
{ type: 'index', fixed: 'left', width: 70, label: '序号' },
|
|
|
|
|
{
|
|
|
|
|
prop: 'deviceName',
|
|
|
|
|
label: '设备名称',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
prop: 'updataTime',
|
|
|
|
|
label: '上送时刻',
|
2024-12-06 09:07:16 +08:00
|
|
|
// width: 230,
|
2024-12-05 13:46:53 +08:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
prop: 'ErrorValue',
|
|
|
|
|
label: '守时误差',
|
2024-12-06 09:07:16 +08:00
|
|
|
// width: 100,
|
2024-12-05 13:46:53 +08:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
prop: 'Result',
|
|
|
|
|
label: '检测结果',
|
2024-12-06 09:07:16 +08:00
|
|
|
// width: 100,
|
2024-12-05 13:46:53 +08:00
|
|
|
render: (scope) => {
|
2024-12-05 15:22:46 +08:00
|
|
|
if (scope.row.Result === '不合格') {
|
|
|
|
|
return (
|
|
|
|
|
<el-tag type='danger'>{scope.row.Result}</el-tag>
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
return (
|
|
|
|
|
<span>{scope.row.Result}</span>
|
|
|
|
|
)
|
|
|
|
|
}
|
|
|
|
|
},
|
2024-12-05 13:46:53 +08:00
|
|
|
},
|
|
|
|
|
])
|
2024-11-21 23:02:43 +08:00
|
|
|
//监听testStatus的变化
|
2024-11-18 22:04:59 +08:00
|
|
|
watch(testStatus, function (newValue, oldValue) {
|
|
|
|
|
ts.value = props.testStatus;
|
2024-12-05 15:22:46 +08:00
|
|
|
if (ts.value === 'start') {
|
2024-11-18 22:04:59 +08:00
|
|
|
ts.value = 'process'
|
|
|
|
|
|
|
|
|
|
let timer = setInterval(() => {
|
2024-12-05 15:22:46 +08:00
|
|
|
if (activeIndex.value < activeTotalNum.value - 2)
|
|
|
|
|
activeIndex.value++
|
|
|
|
|
else if (activeIndex.value === activeTotalNum.value - 2) {
|
|
|
|
|
activeIndex.value++
|
|
|
|
|
activeIndex.value++
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
clearInterval(timer)
|
|
|
|
|
ts.value = 'success'
|
|
|
|
|
}
|
|
|
|
|
}, 1000);
|
2024-11-18 22:04:59 +08:00
|
|
|
}
|
|
|
|
|
})
|
2024-12-05 13:46:53 +08:00
|
|
|
|
|
|
|
|
function formatDateTime(date) {
|
|
|
|
|
const year = date.getFullYear();
|
|
|
|
|
const month = String(date.getMonth() + 1).padStart(2, '0');
|
|
|
|
|
const day = String(date.getDate()).padStart(2, '0');
|
|
|
|
|
const hours = String(date.getHours()).padStart(2, '0');
|
|
|
|
|
const minutes = String(date.getMinutes()).padStart(2, '0');
|
|
|
|
|
const seconds = String(date.getSeconds()).padStart(2, '0');
|
|
|
|
|
const milliseconds = String(date.getMilliseconds()).padStart(3, '0');
|
|
|
|
|
|
|
|
|
|
return `${year}-${month}-${day} ${hours}:${minutes}:${seconds}.${milliseconds}`;
|
|
|
|
|
}
|
|
|
|
|
|
2024-11-21 23:02:43 +08:00
|
|
|
watch(activeIndex, function (newValue, oldValue) {
|
|
|
|
|
|
2024-12-05 15:22:46 +08:00
|
|
|
if (activeIndex.value === 1) {
|
|
|
|
|
startTime.value = formatDateTime(new Date());
|
2024-12-05 13:46:53 +08:00
|
|
|
|
2024-12-05 15:22:46 +08:00
|
|
|
// activities.value.length = 0;
|
|
|
|
|
// activities.value.push({
|
|
|
|
|
// content: '开始检测',
|
|
|
|
|
// timestamp: '2018-04-12 20:46',
|
|
|
|
|
// size: 'large',
|
|
|
|
|
// color: '#0bbd87',
|
|
|
|
|
// icon: SuccessFilled,
|
|
|
|
|
// });
|
|
|
|
|
}
|
|
|
|
|
if (activeIndex.value === 2) {
|
|
|
|
|
gpsTime.value = formatDateTime(new Date());
|
|
|
|
|
// activities.value.push({
|
|
|
|
|
// content: 'GPS上送时刻',
|
|
|
|
|
// timestamp: '2018-04-03 20:46',
|
|
|
|
|
// color: '#0bbd87',
|
|
|
|
|
// icon: SuccessFilled,
|
|
|
|
|
// size: 'large',
|
|
|
|
|
// });
|
|
|
|
|
}
|
|
|
|
|
if (activeIndex.value === 3) {
|
|
|
|
|
// activities.value.push({
|
|
|
|
|
// content: '设备最早上送时刻',
|
|
|
|
|
// timestamp: '2018-04-03 20:46',
|
|
|
|
|
// color: '#0bbd87',
|
|
|
|
|
// icon: SuccessFilled,
|
|
|
|
|
// size: 'large',
|
|
|
|
|
// });
|
|
|
|
|
devStartTime.value = formatDateTime(new Date());
|
|
|
|
|
deviceOperatorData.value.length = 0;
|
|
|
|
|
deviceOperatorData.value = deviceData.value;
|
|
|
|
|
qualified.value = 3
|
|
|
|
|
}
|
|
|
|
|
if (activeIndex.value > 3) {
|
|
|
|
|
devEndTime.value = formatDateTime(new Date());
|
|
|
|
|
finishTime.value = formatDateTime(new Date());
|
2024-12-05 13:46:53 +08:00
|
|
|
|
2024-12-05 15:22:46 +08:00
|
|
|
// activities.value.push({
|
|
|
|
|
// content: '设备最晚上送时刻',
|
|
|
|
|
// timestamp: '2018-04-03 20:46',
|
|
|
|
|
// color: '#0bbd87',
|
|
|
|
|
// icon: SuccessFilled,
|
|
|
|
|
// size: 'large',
|
|
|
|
|
// });
|
|
|
|
|
// activities.value.push({
|
|
|
|
|
// content: '检测结束',
|
|
|
|
|
// timestamp: '2018-04-03 20:46',
|
|
|
|
|
// color: '#0bbd87',
|
|
|
|
|
// icon: SuccessFilled,
|
|
|
|
|
// size: 'large',
|
|
|
|
|
// });
|
|
|
|
|
}
|
2024-11-21 23:02:43 +08:00
|
|
|
})
|
2024-11-18 22:04:59 +08:00
|
|
|
const emit = defineEmits(['update:testStatus']);
|
|
|
|
|
//监听sn
|
|
|
|
|
watch(ts, function (newValue, oldValue) {
|
|
|
|
|
//修改父组件
|
2024-12-05 15:22:46 +08:00
|
|
|
emit('update:testStatus', ts.value)
|
2024-11-18 22:04:59 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
|
|
</script>
|
|
|
|
|
<style scoped>
|
2024-12-05 15:22:46 +08:00
|
|
|
.test-dialog {
|
|
|
|
|
display: flex;
|
2024-11-18 22:04:59 +08:00
|
|
|
|
2024-12-05 15:22:46 +08:00
|
|
|
flex-direction: row;
|
|
|
|
|
/* 横向排列 */
|
|
|
|
|
/* margin-top: 20px; */
|
|
|
|
|
/* min-height: 300px; */
|
|
|
|
|
height: 472px;
|
|
|
|
|
/* .dialog-left{
|
2024-11-18 22:04:59 +08:00
|
|
|
margin-right: 20px;
|
|
|
|
|
} */
|
|
|
|
|
}
|
2024-12-05 15:22:46 +08:00
|
|
|
|
|
|
|
|
.dialog-left {
|
|
|
|
|
margin-left: 20px;
|
|
|
|
|
width: 20%;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.dialog-right {
|
|
|
|
|
/* margin-top: 25px;
|
|
|
|
|
margin-left: 20px; */
|
|
|
|
|
width: 80%;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.right-title {
|
|
|
|
|
height: 32px;
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-direction: row;
|
|
|
|
|
/* 横向排列 */
|
|
|
|
|
justify-content: flex-end;
|
|
|
|
|
/* margin-bottom: 10px; */
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* width: 100%;
|
2024-11-18 22:04:59 +08:00
|
|
|
height: auto;
|
|
|
|
|
background: #fff;
|
|
|
|
|
border-radius: 4px;
|
|
|
|
|
display: flex;
|
|
|
|
|
// justify-content: space-around;
|
|
|
|
|
// justify-content: space-evenly;
|
|
|
|
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
margin-bottom: 10px;
|
|
|
|
|
padding: 10px 20px 10px 20px;
|
|
|
|
|
box-sizing: border-box; */
|
|
|
|
|
</style>
|