From df2328ea56438bf534ad2df79d7f761606cd9cce Mon Sep 17 00:00:00 2001
From: zhangwencui <1064582902@qq.com>
Date: 星期五, 26 六月 2026 17:34:40 +0800
Subject: [PATCH] 已完成状态的生产订单,工艺路线不能修改,新增编辑按钮都不要展示

---
 src/views/index.vue |  181 +++++++++++++++++++++++++++++---------------
 1 files changed, 118 insertions(+), 63 deletions(-)

diff --git a/src/views/index.vue b/src/views/index.vue
index 0d71970..4a03b41 100644
--- a/src/views/index.vue
+++ b/src/views/index.vue
@@ -113,40 +113,42 @@
           <div class="panel-title-row">
             <div class="panel-title">鐢熶骇璁㈠崟杩涘害</div>
             <el-radio-group v-model="orderFilter" size="small">
-              <el-radio-button label="all">鍏ㄩ儴({{ orderProgressMeta.total }})</el-radio-button>
-              <el-radio-button label="waiting">寰呭紑濮�({{ orderProgressMeta.waitingCount }})</el-radio-button>
-              <el-radio-button label="inProgress">杩涜涓�({{ orderProgressMeta.inProgressCount }})</el-radio-button>
-              <el-radio-button label="completed">宸插畬鎴�({{ orderProgressMeta.completedCount }})</el-radio-button>
-              <el-radio-button label="paused">宸叉殏鍋�({{ orderProgressMeta.pausedCount }})</el-radio-button>
+              <el-radio-button :value="'all'">鍏ㄩ儴({{ orderProgressMeta.total }})</el-radio-button>
+              <el-radio-button :value="'waiting'">寰呭紑濮�({{ orderProgressMeta.waitingCount }})</el-radio-button>
+              <el-radio-button :value="'inProgress'">杩涜涓�({{ orderProgressMeta.inProgressCount }})</el-radio-button>
+              <el-radio-button :value="'completed'">宸插畬鎴�({{ orderProgressMeta.completedCount }})</el-radio-button>
+              <el-radio-button :value="'end'">宸茬粨鏉�({{ orderProgressMeta.endCount }})</el-radio-button>
             </el-radio-group>
           </div>
-          <el-table :data="filteredOrders" stripe>
-            <el-table-column prop="orderNo" label="璁㈠崟缂栧彿" min-width="150" />
-            <el-table-column prop="productName" label="浜у搧鍚嶇О" min-width="120" />
-            <el-table-column prop="planQty" label="璁″垝鏁伴噺" min-width="90" />
-            <el-table-column prop="completedQty" label="宸插畬鎴�" min-width="90" />
-            <el-table-column label="瀹屾垚鐜�" min-width="180">
-              <template #default="{ row }">
-                <div class="table-progress">
-                  <el-progress
-                      :stroke-width="8"
-                      :percentage="row.completionRate"
-                      :show-text="false"
-                      status="success"
-                  />
-                  <span>{{ row.completionRate }}%</span>
-                </div>
-              </template>
-            </el-table-column>
-            <el-table-column prop="deliveryDate" label="浜ゆ湡" min-width="110" />
-            <el-table-column label="鐘舵��" min-width="90">
-              <template #default="{ row }">
-                <el-tag :type="getOrderStatusType(row.status)" effect="light">
-                  {{ row.statusLabel || getOrderStatusText(row.status) }}
-                </el-tag>
-              </template>
-            </el-table-column>
-          </el-table>
+          <div class="order-table-wrap">
+            <el-table :data="filteredOrders" stripe max-height="440">
+              <el-table-column prop="orderNo" label="璁㈠崟缂栧彿" min-width="150" />
+              <el-table-column prop="productName" label="浜у搧鍚嶇О" min-width="120" />
+              <el-table-column prop="planQty" label="璁″垝鏁伴噺" min-width="90" />
+              <el-table-column prop="completedQty" label="宸插畬鎴�" min-width="90" />
+              <el-table-column label="瀹屾垚鐜�" min-width="180">
+                <template #default="{ row }">
+                  <div class="table-progress">
+                    <el-progress
+                        :stroke-width="8"
+                        :percentage="row.completionRate"
+                        :show-text="false"
+                        status="success"
+                    />
+                    <span>{{ row.completionRate }}%</span>
+                  </div>
+                </template>
+              </el-table-column>
+              <el-table-column prop="deliveryDate" label="浜ゆ湡" min-width="110" />
+              <el-table-column label="鐘舵��" min-width="90">
+                <template #default="{ row }">
+                  <el-tag :type="getOrderStatusType(row.status)" effect="light">
+                    {{ row.statusLabel || getOrderStatusText(row.status) }}
+                  </el-tag>
+                </template>
+              </el-table-column>
+            </el-table>
+          </div>
         </div>
 
         <div v-if="visiblePanels.contract" class="cockpit-panel contract-panel">
@@ -214,7 +216,7 @@
         <div v-if="visiblePanels.todo" class="cockpit-panel todo-panel">
           <div class="panel-title-row">
             <div class="panel-title">寰呭姙浜嬮」</div>
-            <span class="panel-more">鏇村</span>
+            <span class="panel-more" @click="openTodoDialog">鏇村</span>
           </div>
           <ul class="todo-list" v-if="todoList.length > 0">
             <li v-for="item in todoList" :key="item.id" class="todo-item">
@@ -232,7 +234,6 @@
         <div v-if="visiblePanels.realtime" class="cockpit-panel realtime-panel">
           <div class="panel-title-row">
             <div class="panel-title">鐢熶骇瀹炴椂鐪嬫澘</div>
-            <span class="panel-more">鏇村</span>
           </div>
           <div class="realtime-grid">
             <div class="realtime-item" v-for="item in realtimeBoard" :key="item.key">
@@ -320,7 +321,7 @@
       <div class="process-selection-wrapper">
         <el-checkbox-group v-model="tempProcessIds">
           <div class="process-grid">
-            <el-checkbox v-for="item in processOptions" :key="item.id" :label="item.id" border>
+            <el-checkbox v-for="item in processOptions" :key="item.id" :value="item.id" border>
               {{ item.name }}
             </el-checkbox>
           </div>
@@ -332,6 +333,18 @@
           <el-button type="primary" @click="handleProcessDialogConfirm">纭</el-button>
         </span>
       </template>
+    </el-dialog>
+
+    <el-dialog v-model="todoDialogVisible" title="鍏ㄩ儴寰呭姙浜嬮」" width="900px" append-to-body destroy-on-close>
+      <div v-loading="todoDialogLoading" class="todo-dialog-body">
+        <el-table :data="todoDialogList" stripe max-height="520">
+          <el-table-column prop="approveId" label="寰呭姙缂栧彿" min-width="160" />
+          <el-table-column prop="approveDeptName" label="閮ㄩ棬/妯℃澘" min-width="160" />
+          <el-table-column prop="approveReason" label="浜嬬敱" min-width="240" show-overflow-tooltip />
+          <el-table-column prop="approveUserName" label="鍙戣捣浜�" min-width="120" />
+          <el-table-column prop="approveTime" label="鏃堕棿" min-width="170" />
+        </el-table>
+      </div>
     </el-dialog>
   </div>
 </template>
@@ -464,11 +477,14 @@
   waitingCount: 0,
   inProgressCount: 0,
   completedCount: 0,
-  pausedCount: 0,
+  endCount: 0,
 });
 
 const todayPlanList = ref([]);
 const todayPlanTotal = ref(0);
+const todoDialogVisible = ref(false);
+const todoDialogLoading = ref(false);
+const todoDialogList = ref([]);
 
 const sum = ref(0);
 const yny = ref(0);
@@ -836,12 +852,12 @@
 
 const productionOrders = ref([]);
 
-const orderFilterOptions = ["all", "waiting", "inProgress", "completed", "paused"];
+const orderFilterOptions = ["all", "waiting", "inProgress", "completed", "end"];
 const orderFilterAliasMap = {
   1: "waiting",
   2: "inProgress",
   3: "completed",
-  4: "paused",
+  5: "end",
 };
 const orderFilter = ref("all");
 const filteredOrders = computed(() => productionOrders.value);
@@ -1141,7 +1157,7 @@
     1: "寰呭紑濮�",
     2: "杩涜涓�",
     3: "宸插畬鎴�",
-    4: "宸叉殏鍋�",
+    5: "宸茬粨鏉�",
   };
   return mapping[status] || "鏈煡";
 };
@@ -1232,8 +1248,8 @@
     const res = await productionOrderProgress({
       status: orderFilter.value,
       tab: orderFilter.value,
-      pageNum: 1,
-      pageSize: 10,
+      pageNum: -1,
+      pageSize: -1,
     });
     const data = res?.data || {};
     const statusValue = normalizeOrderFilter(data.status, orderFilter.value);
@@ -1248,7 +1264,7 @@
       waitingCount: resolveProgressCount(data.waitingCount, statusValue, "waiting", total),
       inProgressCount: resolveProgressCount(data.inProgressCount, statusValue, "inProgress", total),
       completedCount: resolveProgressCount(data.completedCount, statusValue, "completed", total),
-      pausedCount: resolveProgressCount(data.pausedCount, statusValue, "paused", total),
+      endCount: resolveProgressCount(data.endCount, statusValue, "end", total),
     };
     productionOrders.value = (data.records || []).map(mapOrderProgressRecord);
   } catch {
@@ -1262,7 +1278,7 @@
       waitingCount: 0,
       inProgressCount: 0,
       completedCount: 0,
-      pausedCount: 0,
+      endCount: 0,
     };
     productionOrders.value = [];
   }
@@ -1271,7 +1287,7 @@
 const refreshTodayProductionPlan = async () => {
   try {
     const res = await todayProductionPlan({
-      limit: 4,
+      limit: 1000,
       planDate: nowDate.value,
     });
     const data = res?.data || {};
@@ -1305,11 +1321,27 @@
   todoList.value = res.data || [];
 };
 
+const openTodoDialog = async () => {
+  todoDialogVisible.value = true;
+  todoDialogLoading.value = true;
+  try {
+    const res = await homeTodos();
+    todoDialogList.value = res.data || [];
+  } catch {
+    todoDialogList.value = [];
+  } finally {
+    todoDialogLoading.value = false;
+  }
+};
+
 const statisticsReceivable = async () => {
   const res = await statisticsReceivablePayable({ type: 1 });
+  const data = res?.data || {};
+  const payableMoney = Number(data.payableMoney ?? 0);
+  const receivableMoney = Number(data.receivableMoney ?? 0);
   barSeries.value[0].data = [
-    { value: res.data.payableMoney, itemStyle: { color: barColors2[0] } },
-    { value: res.data.receivableMoney, itemStyle: { color: barColors2[1] } },
+    { value: payableMoney, itemStyle: { color: barColors2[0] } },
+    { value: receivableMoney, itemStyle: { color: barColors2[1] } },
   ];
 };
 
@@ -1319,15 +1351,16 @@
   barSeries1.value[0].data = [];
   barSeries1.value[1].data = [];
   barSeries1.value[2].data = [];
-  (res.data.item || []).forEach((item) => {
+  const data = res.data || {};
+  (data.item || []).forEach((item) => {
     xAxis1.value[0].data.push(item.date);
     barSeries1.value[0].data.push(item.supplierNum);
     barSeries1.value[1].data.push(item.processNum);
     barSeries1.value[2].data.push(item.factoryNum);
   });
-  qualityStatisticsObject.value.supplierNum = res.data.supplierNum;
-  qualityStatisticsObject.value.processNum = res.data.processNum;
-  qualityStatisticsObject.value.factoryNum = res.data.factoryNum;
+  qualityStatisticsObject.value.supplierNum = data.supplierNum || 0;
+  qualityStatisticsObject.value.processNum = data.processNum || 0;
+  qualityStatisticsObject.value.factoryNum = data.factoryNum || 0;
 };
 
 const getAmountHalfYearNum = async () => {
@@ -1735,6 +1768,34 @@
   font-size: 14px;
   color: #2563eb;
   cursor: pointer;
+}
+
+.todo-dialog-body {
+  min-height: 220px;
+}
+
+.plan-panel {
+  overflow: hidden;
+}
+
+.plan-list {
+  margin: 10px 0 0;
+  padding: 0 4px 0 0;
+  list-style: none;
+  display: flex;
+  flex-direction: column;
+  gap: 8px;
+  max-height: 300px;
+  overflow-y: auto;
+}
+
+.plan-list::-webkit-scrollbar {
+  width: 6px;
+}
+
+.plan-list::-webkit-scrollbar-thumb {
+  border-radius: 999px;
+  background: rgba(37, 99, 235, 0.28);
 }
 
 .todo-list {
@@ -2190,6 +2251,13 @@
 
 .order-panel {
   min-height: 0;
+  display: flex;
+  flex-direction: column;
+}
+
+.order-table-wrap {
+  flex: 1;
+  min-height: 0;
 }
 
 .quick-panel {
@@ -2229,25 +2297,12 @@
   transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
 }
 
-.plan-panel {
-  min-height: 236px;
-}
-
 .quality-panel {
   min-height: 0;
 }
 
 .receipt-panel {
   min-height: 340px;
-}
-
-.plan-list {
-  margin: 10px 0 0;
-  padding: 0;
-  list-style: none;
-  display: flex;
-  flex-direction: column;
-  gap: 8px;
 }
 
 .plan-item {

--
Gitblit v1.9.3