From bd21c609d3e0f325f10f20bb1f59ae24a4b35dc2 Mon Sep 17 00:00:00 2001
From: zhoushihao <zsh19950802@163.com>
Date: 星期一, 03 三月 2025 10:29:05 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 UI-Project/src/views/Caching/cachingbefore.vue |   85 +++++++++++++++++++++++++++++++-----------
 1 files changed, 63 insertions(+), 22 deletions(-)

diff --git a/UI-Project/src/views/Caching/cachingbefore.vue b/UI-Project/src/views/Caching/cachingbefore.vue
index 9755b78..d12cadf 100644
--- a/UI-Project/src/views/Caching/cachingbefore.vue
+++ b/UI-Project/src/views/Caching/cachingbefore.vue
@@ -2,6 +2,7 @@
 import {onBeforeUnmount, onMounted, onUnmounted, ref, reactive} from "vue";
 import {useRouter} from "vue-router"
 import {host, WebSocketHost} from '@/utils/constants'
+import dayjs from 'dayjs';
 import request from "@/utils/request"
 import {closeWebSocket, initializeWebSocket} from '@/utils/WebSocketService';
 import {ElMessage, ElMessageBox} from 'element-plus'
@@ -15,6 +16,7 @@
 const selectValuesa = reactive([]);
 const timeRange = ref([])
 const taskState = ref('')
+const taskStat = ref('')
 const taskType = ref('')
 const glassId = ref('')
 const blindb = ref(false)
@@ -36,9 +38,12 @@
   //     id: rect.id * 10,
   //   })); 
 };
-// 鍒濆鍖� WebSocket锛屽苟浼犻�掓秷鎭鐞嗗嚱鏁�
 onMounted(() => {
   socket = initializeWebSocket(socketUrl, handleMessage);
+  const endTime = dayjs().startOf('minute'); // 褰撳墠鏃堕棿锛岀簿纭埌鍒嗛挓
+  const startTime = endTime.subtract(1, 'day').startOf('minute'); // 褰撳墠鏃堕棿鐨勫墠涓�澶╋紝绮剧‘鍒板垎閽�
+  // 璁剧疆鏃堕棿鑼冨洿涓� [寮�濮嬫椂闂�, 缁撴潫鏃堕棿]
+  timeRange.value = [startTime.format('YYYY-MM-DD HH:mm:ss'), endTime.format('YYYY-MM-DD HH:mm:ss')];
 });
 // 鍘嗗彶浠诲姟
 const handlehistorical = (row) => {
@@ -65,13 +70,12 @@
   try { 
     const params = {
       deviceId: 1,
-      startTime: timeRange.value[0] || '',
-      endTime: timeRange.value[1] || '',
+      startTime: (timeRange.value && timeRange.value[0]) || '',
+      endTime: (timeRange.value && timeRange.value[1]) || '',
       glassId: glassId.value || '',
-      taskState: taskState.value || '',
+      taskState: taskStat.value,
       taskType: taskType.value || ''
     };
- 
     // 鏋勫缓鏌ヨ瀛楃涓�
     const queryString = new URLSearchParams(params).toString();
     const url = `/cacheGlass/edgStorageDeviceTaskHistory?${queryString}`;
@@ -145,6 +149,31 @@
     console.error('鍙戠敓閿欒:', error);  
   }  
 }; 
+// 浠诲姟閲嶇疆
+const handleptask = async() => { 
+  try {
+    const confirmResult = await ElMessageBox.confirm(  
+      t('searchOrder.partasks'), 
+      t('workOrder.prompt'),  
+      {  
+        confirmButtonText: t('workOrder.yes'), 
+        cancelButtonText: t('workOrder.cancel'),
+        type: 'warning',  
+      } 
+    );
+ if (confirmResult === 'confirm') {
+  var url="/cacheGlass/edgStorageDeviceTask/resetTask?deviceId="+ 1;
+      const response = await request.post(url) 
+    if (response.code === 200) {
+      ElMessage.success(response.message);
+      } else {
+      ElMessage.error(response.msg);
+      }  
+    }  
+  } catch (error) { 
+    console.error('鍙戠敓閿欒:', error); 
+  }  
+}; 
  // 鍒犻櫎 
  const handledelete = async(row) => {  
   try {
@@ -158,9 +187,7 @@
       } 
     ); 
     if (confirmResult === 'confirm') {
-      const response = await request.post("/cacheGlass/edgStorageCageDetails/removeEdgDetails",{
-        glassId: row.glassId
-      })
+      const response = await request.post("/cacheGlass/edgStorageCageDetails/removeEdgDetails?glassId="+encodeURIComponent(row.glassId))
     if (response.code === 200) {
      ElMessage.success(response.message);
       } else {
@@ -189,7 +216,7 @@
 const optionsa = [
   {
     value: 0,
-    label: t('searchOrder.empty'),
+    label: t('hellow.starttask'),
   },
   {
     value: 1,
@@ -241,7 +268,7 @@
 function getStatusTextb(taskState) {
   switch (taskState) {
     case 0:
-      return t('searchOrder.empty');
+      return t('hellow.starttask');
     case 1:
       return t('searchOrder.endtask');
   }
@@ -255,8 +282,7 @@
   const hours = String(date.getHours()).padStart(2, '0'); // 琛ラ浂锛堝鏋滈渶瑕佹樉绀烘椂闂达級
   const minutes = String(date.getMinutes()).padStart(2, '0'); // 琛ラ浂锛堝鏋滈渶瑕佹樉绀烘椂闂达級
   const seconds = String(date.getSeconds()).padStart(2, '0'); // 琛ラ浂锛堝鏋滈渶瑕佹樉绀烘椂闂达級
-  // 鍙樉绀哄勾鏈堟棩锛屽鏋滈渶瑕佹樉绀烘椂闂达紝鍒欐嫾鎺� hours + ':' + minutes + ':' + seconds
-  return `${year}-${month}-${day}`;
+  return `${year}-${month}-${day} ${hours}:${minutes}:${seconds}`;
 }
   onUnmounted(() => {
     if (socket) {
@@ -272,12 +298,21 @@
   <div style="height: 500px;">
     <el-card style="flex: 1;margin-left: 10px;margin-top: 10px;" v-loading="loading">
     <el-button style="margin-bottom: 15px;margin-left: 20px;" @click="handlehistorical" type="primary">{{ $t('searchOrder.historicaltasks') }}</el-button>
+    <div style="position: relative; width: 100%; height: 100%;"> <!-- 娣诲姞鐩稿瀹氫綅 -->
+  <div style="position: absolute; margin-top: 28px; left: 430px; display: flex; z-index: 10;"> <!-- 娣诲姞缁濆瀹氫綅 -->
+    <div>{{ $t('searchOrder.projectnumber') }}</div>
+    <div style="margin-left: 155px;">{{ $t('hellow.flowCardId') }}</div>
+    <div style="margin-left: 152px;">{{ $t('searchOrder.glassID') }}</div>
+    <div style="margin-left: 165px;">{{ $t('searchOrder.width') }}</div>
+    <div style="margin-left: 185px;">{{ $t('searchOrder.height') }}</div>
+    <div style="margin-left: 172px;">{{ $t('searchOrder.thickness') }}</div>
+    <div style="margin-left: 145px;">{{ $t('hellow.operate') }}</div>
+  </div>
     <div style="width: 98%; height: calc(100% - 35px); overflow-y: auto;">
       <el-table
       ref="table"
       style="margin-top: 20px; height: 360px;"
       :data="tableDataa"
-      :row-class-name="rowClassName"
       :header-cell-style="{ background: '#F2F3F5', color: '#1D2129' }"
       row-key="id"
   >
@@ -300,14 +335,14 @@
     <template #default="props">
       <el-table 
       :header-cell-style="{ background: '#F2F3F5', color: '#1D2129' }"
-      :data="props.row.details" style="width: 100%;height: 200px;">
-        <el-table-column prop="engineerId" align="center" :label="$t('searchOrder.projectnumber')" min-width="80" />
-          <el-table-column prop="flowCardId" align="center" :label="$t('hellow.flowCardId')" min-width="80" />
-          <el-table-column prop="glassId" align="center" :label="$t('searchOrder.glassID')" min-width="80" />
-          <el-table-column prop="width" align="center" :label="$t('searchOrder.width')" min-width="80" />
-          <el-table-column prop="height" align="center" :label="$t('searchOrder.height')" min-width="80" />
-          <el-table-column prop="thickness" align="center" :label="$t('searchOrder.thickness')" min-width="80" />
-    <el-table-column fixed="right" :label="$t('hellow.operate')" align="center" width="150">
+      :data="props.row.details" style="width: 100%;height: 70px;">
+        <el-table-column prop="engineerId" align="center" min-width="80" />
+          <el-table-column prop="flowCardId" align="center" min-width="80" />
+          <el-table-column prop="glassId" align="center" min-width="80" />
+          <el-table-column prop="width" align="center"  min-width="80" />
+          <el-table-column prop="height" align="center" min-width="80" />
+          <el-table-column prop="thickness" align="center" min-width="80" />
+    <el-table-column fixed="right" align="center" width="150">
         <template #default="scope">
           <el-button size="mini" type="text" plain @click="handletake(scope.row)">{{ $t('searchOrder.breakage') }}</el-button>
           <el-button size="mini" type="text" plain @click="handleBindRack(scope.row)">{{ $t('searchOrder.takeout')}} </el-button>
@@ -319,6 +354,7 @@
     </el-table-column>
   </el-table>
  </div>
+</div>
       <div style="width: 98%; height: calc(100% - 35px); overflow-y: auto;margin-top: 15px;">
         <el-table height="90" ref="table" 
         @selection-change="handleSelectionChange"
@@ -353,6 +389,11 @@
           </el-table-column>
           <el-table-column prop="formattedCreateTime" align="center" :label="$t('film.createtime')" min-width="120" />
           <el-table-column prop="formattedupdateTime" align="center" :label="$t('sorter.updateTime')" min-width="120" />
+          <el-table-column fixed="right" :label="$t('hellow.operate')" align="center" width="150">
+        <template #default="scope">
+          <el-button size="mini" type="text" plain @click="handleptask()">{{ $t('searchOrder.partask') }}</el-button>
+        </template>
+      </el-table-column>
         </el-table>
       </div>
     </el-card>
@@ -379,7 +420,7 @@
             :placeholder="$t('searchOrder.taskstatus')"
              clearable
              style="width: 270px;margin-left: 10px;"  
-             v-model="taskState">
+             v-model="taskStat">
                <el-option
                 v-for="item in optionsa"
                 :key="item.value"

--
Gitblit v1.8.0