From 3d2e74a932fe63aad49d06b429c514c458b3d2dc Mon Sep 17 00:00:00 2001
From: huminmin <mac@MacBook-Pro.local>
Date: 星期四, 25 六月 2026 11:05:37 +0800
Subject: [PATCH] 首页待办事项点击更多,显示全部事项;今日生产计划加上滚动条

---
 src/views/index.vue |   73 +++++++++++++++++++++++++++++-------
 1 files changed, 58 insertions(+), 15 deletions(-)

diff --git a/src/views/index.vue b/src/views/index.vue
index 5785cbe..d11eebd 100644
--- a/src/views/index.vue
+++ b/src/views/index.vue
@@ -216,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">
@@ -334,6 +334,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>
@@ -471,6 +483,9 @@
 
 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);
@@ -1273,7 +1288,7 @@
 const refreshTodayProductionPlan = async () => {
   try {
     const res = await todayProductionPlan({
-      limit: 4,
+      limit: 1000,
       planDate: nowDate.value,
     });
     const data = res?.data || {};
@@ -1305,6 +1320,19 @@
 const todoInfoS = async () => {
   const res = await homeTodos();
   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 () => {
@@ -1741,6 +1769,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 {
@@ -2242,25 +2298,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