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 |   75 +++++++++++++++++++++++++++++--------
 1 files changed, 58 insertions(+), 17 deletions(-)

diff --git a/UI-Project/src/views/Caching/cachingbefore.vue b/UI-Project/src/views/Caching/cachingbefore.vue
index 38b9516..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'
@@ -37,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) => {
@@ -66,8 +70,8 @@
   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: taskStat.value,
       taskType: taskType.value || ''
@@ -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 {
@@ -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>

--
Gitblit v1.8.0