From f9c7ba194dee021012f366e743164c5a1336f405 Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期五, 21 十一月 2025 13:57:32 +0800
Subject: [PATCH] 1.弘也水泥-报销管理添加报销金额字段

---
 src/views/collaborativeApproval/approvalProcess/index.vue |  226 ++++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 152 insertions(+), 74 deletions(-)

diff --git a/src/views/collaborativeApproval/approvalProcess/index.vue b/src/views/collaborativeApproval/approvalProcess/index.vue
index 9398a1b..4299d22 100644
--- a/src/views/collaborativeApproval/approvalProcess/index.vue
+++ b/src/views/collaborativeApproval/approvalProcess/index.vue
@@ -11,13 +11,21 @@
             clearable
             :prefix-icon="Search"
         />
+        <span class="search_title ml10">瀹℃壒鐘舵�侊細</span>
+				<el-select v-model="searchForm.approveStatus" clearable @change="handleQuery" style="width: 240px">
+					<el-option label="寰呭鏍�" :value="0" />
+					<el-option label="瀹℃牳涓�" :value="1" />
+					<el-option label="瀹℃牳瀹屾垚" :value="2" />
+					<el-option label="瀹℃牳鏈�氳繃" :value="3" />
+					<el-option label="宸查噸鏂版彁浜�" :value="4" />
+				</el-select>
         <el-button type="primary" @click="handleQuery" style="margin-left: 10px"
         >鎼滅储</el-button
         >
       </div>
       <div>
         <el-button type="primary" @click="openForm('add')">鏂板</el-button>
-<!--        <el-button @click="handleOut">瀵煎嚭</el-button>-->
+        <el-button @click="handleOut">瀵煎嚭</el-button>
         <el-button type="danger" plain @click="handleDelete">鍒犻櫎</el-button>
       </div>
     </div>
@@ -34,12 +42,14 @@
           :total="page.total"
       ></PIMTable>
     </div>
-    <info-form-dia ref="infoFormDia" @close="handleQuery"></info-form-dia>
-    <approval-dia ref="approvalDia" @close="handleQuery"></approval-dia>
+    <info-form-dia ref="infoFormDia" @close="handleQuery" :approveType="approveType"></info-form-dia>
+    <approval-dia ref="approvalDia" @close="handleQuery" :approveType="approveType"></approval-dia>
+    <FileList ref="fileListRef" />
   </div>
 </template>
 
 <script setup>
+import FileList from "./fileList.vue";
 import { Search } from "@element-plus/icons-vue";
 import {onMounted, ref} from "vue";
 import {ElMessageBox} from "element-plus";
@@ -47,88 +57,119 @@
 import ApprovalDia from "@/views/collaborativeApproval/approvalProcess/components/approvalDia.vue";
 import {approveProcessDelete, approveProcessListPage} from "@/api/collaborativeApproval/approvalProcess.js";
 import useUserStore from "@/store/modules/user";
+
+// 瀹氫箟缁勪欢鎺ユ敹鐨刾rops
+const props = defineProps({
+  approveType: {
+    type: [Number, String],
+    default: 0
+  }
+});
+
 const userStore = useUserStore();
 
 
 const data = reactive({
   searchForm: {
 		approveId: "",
+		approveStatus: "",
   },
 });
 const { searchForm } = toRefs(data);
-const tableColumn = ref([
-  {
-    label: "瀹℃壒鐘舵��",
-    prop: "approveStatus",
-    dataType: "tag",
-		width: 100,
-    formatData: (params) => {
-      if (params == 0) {
-        return "寰呭鏍�";
-      } else if (params == 1) {
-        return "瀹℃牳涓�";
-      } else if (params == 2) {
-        return "瀹℃牳瀹屾垚";
-      } else if (params == 4) {
-        return "宸查噸鏂版彁浜�";
-      } else {
-        return '涓嶉�氳繃';
-      }
+const tableColumn = computed(() => {
+  const baseColumns = [
+    {
+      label: "瀹℃壒鐘舵��",
+      prop: "approveStatus",
+      dataType: "tag",
+		  width: 100,
+      formatData: (params) => {
+        if (params == 0) {
+          return "寰呭鏍�";
+        } else if (params == 1) {
+          return "瀹℃牳涓�";
+        } else if (params == 2) {
+          return "瀹℃牳瀹屾垚";
+        } else if (params == 4) {
+          return "宸查噸鏂版彁浜�";
+        } else {
+          return '涓嶉�氳繃';
+        }
+      },
+      formatType: (params) => {
+        if (params == 0) {
+          return "warning";
+        } else if (params == 1) {
+          return "primary";
+        } else if (params == 2) {
+          return "success";
+        } else if (params == 4) {
+          return "";
+        } else {
+          return 'danger';
+        }
+      },
     },
-    formatType: (params) => {
-      if (params == 0) {
-        return "warning";
-      } else if (params == 1) {
-        return "primary";
-      } else if (params == 2) {
-        return "success";
-      } else if (params == 4) {
-        return "";
-      } else {
-        return 'danger';
-      }
+    {
+      label: "娴佺▼缂栧彿",
+      prop: "approveId",
+      width: 170
     },
-  },
-  {
-    label: "娴佺▼缂栧彿",
-    prop: "approveId",
-    width: 170
-  },
-  {
-    label: "鐢宠閮ㄩ棬",
-    prop: "approveDeptName",
-		width: 220
-  },
-  {
-    label: "瀹℃壒浜嬬敱",
-    prop: "approveReason",
-		width: 200
-  },
-  {
-    label: "鐢宠浜�",
-    prop: "approveUserName",
-  },
-  {
-    label: "鐢宠鏃ユ湡",
-    prop: "approveTime",
-		width: 120
-  },
-  {
-    label: "缁撴潫鏃ユ湡",
-    prop: "approveOverTime",
-    width: 120
-  },
-  {
-    label: "褰撳墠瀹℃壒浜�",
-    prop: "approveUserCurrentName",
-    width: 120
-  },
-  {
+    {
+      label: "鐢宠閮ㄩ棬",
+      prop: "approveDeptName",
+		  width: 220
+    },
+    {
+      label: "瀹℃壒浜嬬敱",
+      prop: "approveReason",
+		  width: 200
+    },
+    {
+      label: "鐢宠浜�",
+      prop: "approveUserName",
+      width: 120
+    },
+    {
+      label: "鐢宠鏃ユ湡",
+      prop: "approveTime",
+		  width: 200
+    },
+    {
+      label: "缁撴潫鏃ユ湡",
+      prop: "approveOverTime",
+      width: 120
+    },
+    {
+      label: "褰撳墠瀹℃壒浜�",
+      prop: "approveUserCurrentName",
+      width: 120
+    }
+  ];
+
+  // 濡傛灉鏄姤閿�绠$悊瀹℃壒琛紙approveType=4锛夛紝娣诲姞鎶ラ攢閲戦鍒�
+  if (props.approveType == 4) {
+    baseColumns.push({
+      label: "鎶ラ攢閲戦",
+      prop: "price",
+      width: 120,
+      fixed: "right",
+      formatData: (params) => {
+        if (params) {
+          return `楼${Number(params).toFixed(2)}`;
+        }
+        return '-'
+      }
+    });
+  }
+
+  // 娣诲姞鎿嶄綔鍒�
+  baseColumns.push({
     dataType: "action",
     label: "鎿嶄綔",
     align: "center",
     fixed: "right",
-    width: 150,
+    width: 230,
     operation: [
       {
         name: "缂栬緫",
@@ -144,7 +185,7 @@
         clickFun: (row) => {
           openApprovalDia("approval", row);
         },
-				disabled: (row) => row.approveUserCurrentId == null || row.approveStatus == 2 || row.approveStatus == 3 || row.approveStatus == 4 || row.approveUsercurrentId !== userStore.id
+				disabled: (row) => row.approveUserCurrentId == null || row.approveStatus == 2 || row.approveStatus == 3 || row.approveStatus == 4 || row.approveUserCurrentId !== userStore.id
       },
       {
         name: "璇︽儏",
@@ -153,9 +194,18 @@
           openApprovalDia('view', row);
         },
       },
+      {
+        name: "闄勪欢",
+        type: "text",
+        clickFun: (row) => {
+          downLoadFile(row);
+        },
+      },
     ],
-  },
-]);
+  });
+
+  return baseColumns;
+});
 const tableData = ref([]);
 const selectedRows = ref([]);
 const tableLoading = ref(false);
@@ -174,6 +224,11 @@
   page.current = 1;
   getList();
 };
+const fileListRef = ref(null)
+const downLoadFile = (row) => {
+  fileListRef.value.open(row.commonFileList)
+
+}
 const pagination = (obj) => {
   page.current = obj.page;
   page.size = obj.limit;
@@ -181,7 +236,7 @@
 };
 const getList = () => {
   tableLoading.value = true;
-  approveProcessListPage({...page, ...searchForm.value,}).then(res => {
+  approveProcessListPage({...page, ...searchForm.value,approveType:props.approveType}).then(res => {
     tableLoading.value = false;
     tableData.value = res.data.records
     page.total = res.data.total;
@@ -189,6 +244,29 @@
     tableLoading.value = false;
   })
 };
+// 瀵煎嚭
+const handleOut = () => {
+  const type = Number(props.approveType || 0)
+  const urlMap = {
+    0: "/approveProcess/exportZero",
+    1: "/approveProcess/exportOne",
+    2: "/approveProcess/exportTwo",
+    3: "/approveProcess/exportThree",
+    4: "/approveProcess/exportFour",
+    5: "/approveProcess/exportFive",
+  }
+  const url = urlMap[type] || urlMap[0]
+  const nameMap = {
+    0: "鍗忓悓瀹℃壒绠$悊琛�",
+    1: "鍏嚭绠$悊瀹℃壒琛�",
+    2: "璇峰亣绠$悊瀹℃壒琛�",
+    3: "鍑哄樊绠$悊瀹℃壒琛�",
+    4: "鎶ラ攢绠$悊瀹℃壒琛�",
+    5: "閲囪喘鐢宠瀹℃壒琛�",
+  }
+  const fileName = nameMap[type] || nameMap[0]
+  proxy.download(url, {}, `${fileName}.xlsx`)
+}
 // 琛ㄦ牸閫夋嫨鏁版嵁
 const handleSelectionChange = (selection) => {
   selectedRows.value = selection;

--
Gitblit v1.9.3