From 8114ef9bf2704a2bc05a15a36ab677808195a274 Mon Sep 17 00:00:00 2001
From: zhoushihao <zsh19950802@163.com>
Date: 星期五, 14 三月 2025 10:40:18 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 UI-Project/src/views/Slicecage/slicecage.vue |  237 ++++++++++++++++++++++------------------------------------
 1 files changed, 90 insertions(+), 147 deletions(-)

diff --git a/UI-Project/src/views/Slicecage/slicecage.vue b/UI-Project/src/views/Slicecage/slicecage.vue
index 2927c05..c482539 100644
--- a/UI-Project/src/views/Slicecage/slicecage.vue
+++ b/UI-Project/src/views/Slicecage/slicecage.vue
@@ -6,21 +6,19 @@
 import {onBeforeUnmount, onMounted, onUnmounted, reactive, ref} from "vue";
 import {closeWebSocket, initializeWebSocket} from '@/utils/WebSocketService';
 import {ElMessage, ElMessageBox} from 'element-plus'
-
-const dialogFormVisibleaDownGlasss = ref(false)
 const scanGlass = ref([])
 const {t} = useI18n()
 let language = ref(localStorage.getItem('lang') || 'zh')
+import { inject } from 'vue';
 const router = useRouter()
-const dialogFormVisible = ref(false)
-const dialoglea = ref(false)
+const timeRange = ref([])
 const dialogFormVisiblea = ref(false)
-const dialogFormVisibleb = ref(false)
 const dialogFormVisiblec = ref(false)
 const dialogFormVisibled = ref(false)
 const dialogFormVisiblee = ref(false)
 const dialogFormVisiblef = ref(false)
 const dialogFormVisibles = ref(false)
+const blindb = ref(false)
 const inkageEntity = ref('#911005');
 const requestEntity = ref('#911005');
 const mesReplyEntity = ref('#911005');
@@ -33,18 +31,18 @@
 const tableDatad = ref([])
 const tableDataf = ref([])
 const tableDatae = ref([])
-const tableDatax = ref([])
 const tableDatas = ref([])
 const tableDatass = ref([])
+const tableDatax = ref([]);
 const tableDatalack = ref([])
 const tableDataspecify = ref([])
 const tableDatacagedetails = ref([])
+const selectValuesa = reactive([]);
 const carPosition = ref([])
 const ganghua = ref('')
 const diaodu = ref('')
 const flowCardId = ref('')
 const filmsId = ref('')
-const project = ref([]);
 const adjust = ref([]);
 const adjusta = ref([]);
 const adjustedRects = ref([]);
@@ -57,16 +55,17 @@
 const subRectsCountsc = ref([]);
 const currentRow = reactive({}); // 褰撳墠琛岀殑鏁版嵁 
 const currentPage2 = ref(1)
+const globalDate = inject('globalDate');
 const inputValuesa = reactive({});
 const add = ref(false)
 const gap = ref('');
 const glassId = ref('');
-const glassType = ref('');
-const height = ref('');
-const sequence = ref('');
-const state = ref('');
-const temperingFeedSequence = ref('');
-const temperingLayoutId = ref('');
+const startSlot = ref('');
+const targetSlot = ref('');
+const taskStateList = ref('');
+const taskTypeList = ref('');
+const beginDate = ref('');
+const endDate = ref('');
 const thickness = ref('');
 const width = ref('');
 const cell1=ref(true);
@@ -256,6 +255,12 @@
     console.error('鍙戠敓閿欒:', error);  
   }  
 }; 
+// 鍘嗗彶浠诲姟
+const iframeUrl = ref('');
+const handlehistorical = (row) => {
+  blindb.value = true;
+  iframeUrl.value = `${window.location.origin}/#/Slicecage/slicecagehistory`;
+};
  // 鎷胯蛋
  const brokec = async(row) => {  
   try {
@@ -546,10 +551,6 @@
   } catch (error) {
     console.error('鍙戠敓閿欒:', error);  
   }  
-}; 
-const handlezhiban = () => {
-  dialoglea.value = true;
-  fetchFlowCardId(); 
 };
 const handleganghua = () => {
   dialogFormVisiblec.value = true;
@@ -707,34 +708,6 @@
     console.error(error);
   }
 }
-// 鍊肩彮淇℃伅
-const fetchFlowCardId = async () => {
-  try  {
-    const response = await request.post('/cacheVerticalGlass/work_assignment/selectWorkAssignment',{
-      line: 4001,
-      workingProcedure : '閽㈠寲'
-    })
-    if (response.code == 200) {
-      ElMessage.success(response.message);
-      tableDatax.value = response.data;
-      console.log(tableDatax.value);
-    } else {
-      ElMessage.error(response.message);
-    }
-}
-catch (error) {
-    console.error(error);
-  }
-}
-const handleConfirm = async () => {
-  const response = await request.post("/cacheVerticalGlass/work_assignment/updateWorkAssignment", tableDatax.value)
-  if (response.code === 200) {
-    ElMessage.success(response.message);
-    dialoglea.value = false;
-  } else {
-    ElMessage.error(response.message);
-  }
-};
 function handleRowClick(row) {  
   selectedRow.value = row; // 鏇存柊閫変腑鐨勮鏁版嵁  
 }  
@@ -777,6 +750,30 @@
     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') {
+  const response = await request.post('/cacheVerticalGlass/bigStorageCage/resetCage')
+    if (response.code === 200) {
+      ElMessage.success(response.message);
+      } else {
+      ElMessage.error(response.msg);
+      }  
+    }  
+  } catch (error) { 
+    console.error('鍙戠敓閿欒:', error); 
+  }  
+}; 
 let socket = null;
 const socketUrl = `ws://${WebSocketHost}:${host}/api/cacheVerticalGlass/api/talk/slicecage`;
 const handleMessage = (data) => {
@@ -1013,8 +1010,19 @@
     right,
   };
 };
-onMounted(() => {
+// 鏍煎紡鍖栧悗绔椂闂村苟璁$畻涓�鍛ㄥ墠鐨勬椂闂�
+const defaultTime = ref<[Date, Date]>([new Date(), new Date()]);
+function parseAndSetTime() {
+  const backendTime = new Date(globalDate);
+  const oneWeekAgo = new Date(backendTime.getTime() - 7 * 24 * 60 * 60 * 1000); // 鍑忓幓7澶�
+  console.log(formatTimestamp(oneWeekAgo));
+  console.log(oneWeekAgo);
+  timeRange.value = [formatTimestamp(oneWeekAgo), formatTimestamp(backendTime)];
+  window.localStorage.setItem('startTime', formatTimestamp(oneWeekAgo))
+}
+  onMounted(() => {
   socket = initializeWebSocket(socketUrl, handleMessage);
+  parseAndSetTime();
 });
   onUnmounted(() => {
     if (socket) {
@@ -1093,6 +1101,17 @@
   }
   return '';
 }
+// 鏍煎紡鍖栨椂闂存埑涓哄勾鏈堟棩鏃堕棿瀛楃涓茬殑鍑芥暟
+function formatTimestamp(timestamp) {
+  const date = new Date(timestamp);
+  const year = date.getFullYear();
+  const month = String(date.getMonth() + 1).padStart(2, '0'); // 鏈堜唤浠�0寮�濮嬶紝闇�瑕佸姞1锛屽苟琛ラ浂
+  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'); // 琛ラ浂锛堝鏋滈渶瑕佹樉绀烘椂闂达級
+  return `${year}-${month}-${day} ${hours}:${minutes}:${seconds}`;
+}
 onBeforeUnmount(() => {
   closeWebSocket();
 });
@@ -1100,15 +1119,12 @@
 <template>
   <div style="height: 600px;">
     <el-button style="margin-top: 7px;margin-left: 10px;" id="searchButton" type="primary" @click="handlexiang">{{ $t('searchOrder.cageinformation') }}</el-button>
-    <el-button style="margin-top: 7px;margin-left: 10px;" id="searchButton" type="success" @click="dialogFormVisibleb = true">{{ $t('searchOrder.productionqueue') }}</el-button>
+    <el-button style="margin-top: 7px;margin-left: 10px;" id="searchButton" type="success" @click="handlehistorical">{{ $t('searchOrder.historicaltasks') }}</el-button>
     <el-button style="margin-top: 7px;margin-left: 10px;" id="searchButton" type="warning" @click="handleganghua">{{ $t('searchOrder.temperingqueries') }}</el-button>
-    <el-button style="margin-top: 7px;margin-left: 10px;" id="searchButton" type="info" @click="handlezhiban">{{ $t('searchOrder.dutyinformation') }}</el-button>
     <el-button style="margin-top: 7px;margin-left: 10px;" id="searchButton" type="info" @click="dialogFormVisibles=true;fetchFlows()">{{ $t('searchOrder.searchlayout') }}</el-button>
+    <el-button style="margin-top: 7px;margin-left: 10px;" id="searchButton" type="danger" @click="handleptask()">{{ $t('searchOrder.partask') }}</el-button>
     <el-switch style="margin-top: 7px;margin-left: 10px;" v-model="ganghua" class="mb-2" :inactive-text="$t('searchOrder.temperedswitch')" @change="handleChange" />
     <el-switch style="margin-top: 7px;margin-left: 10px;" v-model="diaodu" class="mb-2" :inactive-text="$t('searchOrder.Schedulingswitch')" @change="handlediaodu" />
-    <el-button style="margin-top: 7px;margin-left: 10px;" id="searchButton" type="primary"
-      @click="dialogFormVisibleaDownGlasss = true">{{ $t('searchOrder.Labelprinting') }}
-    </el-button>
     <div id="dotClass">
         <div>{{ $t('searchOrder.inkageEntity') }}</div>
         <i :style="{ marginTop: '2px', backgroundColor: inkageEntity, width: '18px', height: '18px', borderRadius: '50%', display: 'block' }"></i>
@@ -1141,7 +1157,7 @@
       <el-table height="300px" ref="table" 
         @selection-change="handleSelectionChange"
         :row-class-name="tableRowClassName"
-        :data="tableDatad" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
+        :data="tableDatax" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
           <el-table-column prop="glassId" align="center" :label="$t('searchOrder.intoglassid')" min-width="140" />
           <el-table-column prop="startSlot" align="center" :label="$t('searchOrder.startposition')" min-width="120" />
           <el-table-column prop="targetSlot" align="center" :label="$t('searchOrder.targetlocation')" min-width="120" />
@@ -1245,13 +1261,13 @@
       <div style="width: 100%; height: calc(100% - 35px); overflow-y: auto;max-height: 420px;">
        <el-table height="420px" ref="table" border 
        :data="tableDatass" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
-         <el-table-column prop="engineerId" align="center" :label="$t('Mounting.project')" min-width="140" />
-         <el-table-column prop="countTemp" align="center" :label="$t('searchOrder.totalfurnaces')" min-width="120" />
-         <el-table-column prop="countGlass" align="center" :label="$t('searchOrder.cagesnumber')" min-width="120" />
-         <el-table-column prop="area" align="center" :label="$t('large.are')" min-width="120" />
-         <el-table-column prop="fullTemp" align="center" :label="$t('searchOrder.fullfurnaces')" min-width="120" />
-         <el-table-column prop="countSlot" align="center" :label="$t('searchOrder.slotnumber')" min-width="120" />
-         <el-table-column prop="percent" align="center" :label="$t('searchOrder.progress')" min-width="120" />
+         <el-table-column fixed prop="engineerId" align="center" :label="$t('Mounting.project')" min-width="100" />
+         <el-table-column prop="countTemp" align="center" :label="$t('searchOrder.totalfurnaces')" min-width="68" />
+         <el-table-column prop="countGlass" align="center" :label="$t('searchOrder.cagesnumber')" min-width="82" />
+         <el-table-column prop="area" align="center" :label="$t('large.are')" min-width="70" />
+         <el-table-column prop="fullTemp" align="center" :label="$t('searchOrder.fullfurnaces')" min-width="82" />
+         <el-table-column prop="countSlot" align="center" :label="$t('searchOrder.slotnumber')" min-width="96" />
+         <el-table-column prop="percent" align="center" :label="$t('searchOrder.progress')" min-width="80" />
        </el-table>
        </div>
     </el-card>
@@ -1422,46 +1438,18 @@
     </div>
   </div>
   </el-dialog>
-<el-dialog v-model="dialogFormVisibleb" top="5vh" width="85%" :title="$t('searchOrder.productionqueue')">
-    <el-table  ref="table" style="margin-top: 20px;height: 700px;"
-        :data="tableDatab" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
-          <el-table-column prop="glassId" fixed align="center" :label="$t('searchOrder.glassID')" min-width="150"/>
-          <el-table-column prop="flowCardId" fixed align="center" :label="$t('searchOrder.processcards')" min-width="120" />
-          <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 prop="filmsid" align="center" :label="$t('searchOrder.coatingtypes')" min-width="80" />
-          <el-table-column
-            align="center"
-            :label="$t('searchOrder.acceptshorizontal')"
-            min-width="150"
-            prop="ishorizontal"
-          >
-          <template #default="scope">  
-        <el-tag :type="getStatusTypea(scope.row.ishorizontal)">  
-          {{ getStatusTexta(scope.row.ishorizontal) }}  
-        </el-tag>  
-      </template> 
-          </el-table-column>
-          <el-table-column prop="temperingLayoutId" align="center" :label="$t('searchOrder.layoutID')" min-width="120" />
-          <el-table-column prop="temperingFeedSequence" align="center" :label="$t('searchOrder.picturesequence')" min-width="120" />
-          <el-table-column prop="xCoordinate" align="center" :label="$t('searchOrder.xcoordinates')" min-width="80" />
-          <el-table-column prop="yCoordinate" align="center" :label="$t('searchOrder.ycoordinates')" min-width="80" />
-          <el-table-column prop="angle" align="center" :label="$t('searchOrder.rotationangle')" min-width="150" />
-          <el-table-column
-            align="center"
-            :label="$t('searchOrder.state')"
-            min-width="80"
-            prop="state"
-          >
-          <template #default="scope">  
-        <el-tag :type="getStatusTypeb(scope.row.state)">  
-          {{ getStatusTextb(scope.row.state) }}  
-        </el-tag>  
-      </template> 
-          </el-table-column>
-        </el-table>
-</el-dialog>
+<!-- 鍘嗗彶浠诲姟 -->
+<el-dialog v-model="blindb" top="10vh" width="90%">
+     <iframe 
+     :src="iframeUrl" 
+     marginwidth="2000px"
+     marginheight="2000px"
+     width="100%" 
+     height="750px" 
+     frameborder="0"
+     ></iframe>
+  </el-dialog>
+<!-- 閽㈠寲鏌ヨ -->
 <el-dialog v-model="dialogFormVisiblec" top="5vh" width="85%" :title="$t('searchOrder.temperingqueries')">
   <div style="margin-bottom: 20px">
       <el-form>
@@ -1647,31 +1635,7 @@
           <el-table-column prop="ycoordinate" align="center" :label="$t('searchOrder.ycoordinates')" min-width="80" />
         </el-table>
 </el-dialog>
-<el-dialog v-model="dialoglea" top="15vh" width="70%" :title="$t('searchOrder.dutyinformation')">
-    <el-table  ref="table" style="margin-top: 20px;height: 300px;"
-        :data="tableDatax" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
-          <el-table-column prop="line" fixed align="center" :label="$t('searchOrder.line')"/>
-          <el-table-column prop="workProcesses" fixed align="center" :label="$t('searchOrder.process')" />
-          <el-table-column prop="teamsGroupsName" align="center" :label="$t('searchOrder.team')">
-        <template #default="{ row }">  
-          <el-input v-model="row.teamsGroupsName" autocomplete="off" min-width="150"/>  
-        </template>  
-      </el-table-column>
-          <el-table-column prop="deviceName" align="center" :label="$t('searchOrder.basic')">
-            <template #default="{ row }">  
-          <el-input v-model="row.deviceName" autocomplete="off" min-width="150"/>  
-        </template>
-        </el-table-column>
-        </el-table>
-        <template #footer>
-      <div id="dialog-footer">
-        <el-button type="primary" @click="handleConfirm">
-          {{ $t('searchOrder.makesure') }}
-        </el-button>
-        <el-button @click="dialoglea = false">{{ $t('searchOrder.cancel') }}</el-button>
-      </div>
-    </template>
-</el-dialog>
+<!-- 闈為挗鍖� -->
 <el-dialog v-model="dialogFormVisibles" top="5vh" width="85%" :title="$t('searchOrder.searchlayout')">
   <el-table  ref="table" style="margin-top: 20px;height: 500px;"
         :data="tableDatas" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
@@ -1683,12 +1647,13 @@
           <el-table-column prop="realCount" align="center" :label="$t('searchOrder.numbercages')" min-width="150" />
           <el-table-column prop="lackCount" align="center" :label="$t('searchOrder.missingquantity')" min-width="150" />
           <el-table-column prop="damageCount" align="center" :label="$t('searchOrder.breakquantity')" min-width="150" />
-          <el-table-column fixed="right" :label="$t('searchOrder.operate')" align="center" width="250">
+          <el-table-column fixed="right" :label="$t('searchOrder.operate')" align="center" width="500">
             <template #default="scope">
               <el-button size="mini" type="text" plain @click="brokee(scope.row,1)">{{ $t('searchOrder.specifytempering') }}</el-button>
               <el-button size="mini" type="text" plain @click="brokee(scope.row,0)">{{ $t('searchOrder.specifyout') }}</el-button>
               <el-button size="mini" type="text" plain @click="brokek(scope.row)">{{ $t('searchOrder.specifyengineerid') }}</el-button>
               <el-button size="mini" type="text" plain @click="handlelack(scope.row)">{{ $t('hellow.missingnumber') }}</el-button>
+              <el-button size="mini" type="text" plain @click="handlecagedetails(scope.row)">{{ $t('searchOrder.cagedetails') }}</el-button>
             </template>
         </el-table-column>
         </el-table>
@@ -1704,28 +1669,6 @@
         </el-table-column>
         </el-table> -->
 </el-dialog>
-<el-dialog v-model="dialogFormVisibleaDownGlasss" top="2vh" width="97%" :title="$t('searchOrder.filminformation')">
-          <div style="display:flex;justify-content: space-around;">
-            <el-card
-              style="display: flex; justify-content: center; align-items: center; width: 800px; height: 800px;position: relative;">
-              <div
-                :style="{ width: scanGlass.width + 'px', height: scanGlass.height + 'px', backgroundColor: '#e1f3d8', transform: 'scale(' + 800 / (scanGlass.width > scanGlass.height ? scanGlass.width : scanGlass.height) + ')' }">
-
-              </div>
-              <div style="font-size: 50px; text-align: center;position: absolute;top:0px;left:200px;">
-                <div>{{ $t('searchOrder.currentglassinformation') }}</div>
-                <div>
-                  <el-button type="primary" @click="open1(scanGlass)">{{ $t('searchOrder.printlabels') }}</el-button>
-                </div>
-                <div>{{ scanGlass.flowCardId }}</div>
-                <div>{{ scanGlass.layer }}</div>
-                <div>{{ scanGlass.glassId }}</div>
-                <div>{{ scanGlass.width }}</div>
-                <div>{{ scanGlass.height }}</div>
-              </div>
-            </el-card>
-          </div>
-        </el-dialog>
         <el-dialog id="sizePrintCalrd1" v-model="dialogTableVisible1" destroy-on-close>
     <print-label id="printFlowCard" :printFlowCardId="printFlowCardId" :printLayer="printLayer"
                  :printGlassId="printGlassId" style=""/>

--
Gitblit v1.8.0