From 9b36bf37924e7d9c665837c13832a033754974ae Mon Sep 17 00:00:00 2001
From: maven <2163098428@qq.com>
Date: 星期三, 20 八月 2025 13:16:50 +0800
Subject: [PATCH] yys  修改劳保统计表格

---
 src/views/lavorissue/statistics/index.vue |  359 ++++++++++++++++++++++++++++++++++-------------------------
 1 files changed, 205 insertions(+), 154 deletions(-)

diff --git a/src/views/lavorissue/statistics/index.vue b/src/views/lavorissue/statistics/index.vue
index 5c6f286..2c34f67 100644
--- a/src/views/lavorissue/statistics/index.vue
+++ b/src/views/lavorissue/statistics/index.vue
@@ -1,67 +1,141 @@
 <template>
   <div class="app-container">
-    <el-form :model="filters" :inline="true">
-      <el-form-item label="鍙戞斁瀛e害:" prop="season">
+    <div class="search_form">
+      <div>
+        <span class="search_title">鍙戞斁瀛e害锛�</span>
         <el-select
-            :disabled="filters.issueDate ? true : false"
             style="width: 200px;"
-            @change="getList"
-            v-model="filters.season"
+            @change="handleQuery"
+            v-model="searchForm.season"
             placeholder="璇烽�夋嫨"
+            @clear="clearSeason"
             clearable
+            :disabled="searchForm.issueDate ? true : false"
+
         >
-          <el-option :label="item.label" :value="item.value" v-for="(item,index) in jidu" :key="value" />
+          <el-option :label="item.label" :value="item.value" v-for="(item,index) in jidu" :key="item.value" />
         </el-select>
-      </el-form-item>
-      <el-form-item label="鍙戞斁鏈堜唤:" prop="issueDate">
+        <span class="search_title ml10">鍙戞斁鏈堜唤锛�</span>
         <el-date-picker
-            :disabled="filters.season ? true : false"
-            v-model="filters.issueDate"
-            @change="getList"
+            style="width: 200px;"
+            :disabled="searchForm.season ? true : false"
+            v-model="searchForm.issueDate"
+            @change="handleQuery"
+            @clear="clearIssueDaten"
             type="month"
             value-format="YYYY-MM-DD"
             format="YYYY-MM"
             placeholder="璇烽�夋嫨鏈堜唤"
             clearable
-            style="width: 100%"
         />
-      </el-form-item>
-      <el-form-item>
-        <el-button type="primary" @click="getList">鎼滅储</el-button>
-        <el-button @click="resetParams">閲嶇疆</el-button>
-      </el-form-item>
-    </el-form>
+        <el-button type="primary" @click="handleQuery" style="margin-left: 10px"
+        >鎼滅储</el-button
+        >
+        <el-button type="primary" @click="resetHandleQuery" style="margin-left: 10px"
+        >閲嶇疆</el-button
+        >
+      </div>
+      <div>
+        <el-button @click="handleOut" icon="download">瀵煎嚭</el-button>
+      </div>
+    </div>
     <div class="table_list">
       <div class="actions">
-        <div class="head" @click="getList(1)">宸查鍙栧姵淇濇暟閲�:{{statisticsObj.ylqNum}}</div>
-        <div class="head" @click="getList(2)">鏈鍙栧姵淇濇暟閲�: {{ statisticsObj.wlqNum }}</div>
-        <div class="head" @click="getList(3)">瓒呮椂宸查鍙栧姵淇濇暟閲�: {{statisticsObj.csylqNum}}</div>
-        <div class="head" @click="getList(4)">瓒呮椂鏈鍙栧姵淇濇暟閲�: {{statisticsObj.cswlqNum}}</div>
+        <div class="head" @click="handleQuery(1)">宸查鍙栧姵淇濇暟閲�:{{statisticsObj.ylqNum}}</div>
+        <div class="head" @click="handleQuery(2)">鏈鍙栧姵淇濇暟閲�: {{ statisticsObj.wlqNum }}</div>
+        <div class="head" @click="handleQuery(3)">瓒呮椂宸查鍙栧姵淇濇暟閲�: {{statisticsObj.csylqNum}}</div>
+        <div class="head" @click="handleQuery(4)">瓒呮椂鏈鍙栧姵淇濇暟閲�: {{statisticsObj.cswlqNum}}</div>
       </div>
-      <PIMTable
-          rowKey="id"
-          isSelection
-          :column="columns"
-          :tableData="dataList"
-          :page="{
-          current: pagination.currentPage,
-          size: pagination.pageSize,
-          total: pagination.total,
-        }"
+      <el-table
+          ref="tableRef"
+          v-loading="tableLoading"
+          :data="tableData"
+          border
+          height="calc(100vh - 21em)"
+          :header-cell-style="{ background: '#F0F1F5', color: '#333333' }"
+          style="width: 100%"
           @selection-change="handleSelectionChange"
-          @pagination="changePage"
       >
-      </PIMTable>
+        <!-- 閫夋嫨鍒� -->
+        <el-table-column
+            align="center"
+            type="selection"
+            width="55"
+            fixed="left"
+        />
+
+        <!-- 搴忓彿鍒� -->
+        <el-table-column
+            align="center"
+            label="搴忓彿"
+            type="index"
+            width="60"
+            fixed="left"
+        />
+
+        <!-- 鍥哄畾鍒楋細濮撳悕 -->
+        <el-table-column
+            label="濮撳悕"
+            prop="staffName"
+            width="100"
+            show-overflow-tooltip
+            align="center"
+            fixed="left"
+        />
+
+        <!-- 鍥哄畾鍒楋細宸ュ彿 -->
+        <el-table-column
+            label="宸ュ彿"
+            prop="staffNo"
+            width="100"
+            show-overflow-tooltip
+            align="center"
+            fixed="left"
+        />
+
+        <!-- 鍔ㄦ�佸垪锛氭牴鎹瓧鍏告覆鏌� -->
+        <el-table-column
+            v-for="(dictItem, index) in sys_lavor_issue"
+            :key="dictItem.value"
+            :label="dictItem.label"
+            :prop="dictItem.value"
+            show-overflow-tooltip
+        >
+        </el-table-column>
+      </el-table>
     </div>
   </div>
 </template>
 
 <script setup>
-import { usePaginationApi } from "@/hooks/usePaginationApi";
-import {lavorIssueListPage, statistics} from "@/api/lavorissce/ledger";
-import { onMounted } from "vue";
+import { ref, onMounted, reactive, toRefs, nextTick, getCurrentInstance } from 'vue'
+import dayjs from "dayjs";
+import {statisticsList, statistics} from "@/api/lavorissce/ledger.js";
+import {ElMessageBox, ElMessage} from "element-plus";
+const { proxy } = getCurrentInstance();
+import { getCurrentMonth } from "@/utils/util"
 
-// 琛ㄦ牸澶氶�夋閫変腑椤�
+const page = ref({
+  current: 1,
+  size: 100,
+})
+const total = ref(0)
+// 鍝嶅簲寮忔暟鎹�
+const tableRef = ref(null)
+const tableData = ref([])
+const tableLoading = ref(false)
+const { sys_lavor_issue } = proxy.useDict("sys_lavor_issue")
+const data = reactive({
+  searchForm: {
+    season: getCurrentMonth(),
+    issueDate: "",
+    status: 0
+  },
+});
+const { searchForm } = toRefs(data);
+
+const modalRef = ref();
+const filesDia = ref();
 const multipleList = ref([]);
 const jidu = ref([
   {
@@ -81,148 +155,126 @@
     label: '绗洓瀛e害'
   }
 ])
+const clearSeason = () => {
+  console.log("req")
+  searchForm.value.season = ""
+  searchForm.value.issueDate = dayjs().format("YYYY-MM-DD");
+}
 
-const {
-  filters,
-  columns,
-  dataList,
-  pagination,
-  getTableData,
-  resetFilters,
-  onCurrentChange,
-} = usePaginationApi(
-	lavorIssueListPage,
-    {
-      season: '',
-      issueDate: '',
-      status: 0
-    },
-    [
-      {
-        label: "鍔充繚鍗曞彿",
-        align: "center",
-        prop: "orderNo",
-      },
-      {
-        label: "鍛樺伐鍚嶇О",
-        align: "center",
-        prop: "staffName",
-      },
-      {
-        label: "鍛樺伐缂栧彿",
-        align: "center",
-        prop: "staffNo"
-      },
-
-      {
-        label: "鍔充繚绫诲瀷",
-        align: "center",
-        prop: "dictTypeName",
-
-      },
-      {
-        label: "鍔充繚闃插叿",
-        align: "center",
-        prop: "dictName",
-
-      },
-      {
-        label: "鍙戞斁鏁伴噺",
-        align: "center",
-        prop: "num",
-
-      },
-      {
-        label: "杩涘巶鏃ユ湡",
-        align: "center",
-        prop: "factoryDate",
-
-      },
-      {
-        label: "鍙戞斁鏃ユ湡",
-        align: "center",
-        prop: "issueDate",
-
-      },
-      {
-        label: "棰嗙敤鏃ユ湡",
-        align: "center",
-        prop: "adoptedDate",
-
-      }
-    ]
-);
+const clearIssueDaten = () => {
+  searchForm.value.issueDate = ""
+  searchForm.value.season = getCurrentMonth()
+}
 const statisticsObj = ref({
   ylqNum: 0,  // 宸查鍙栨暟閲�
   wlqNum: 0,  // 鏈鍙栨暟閲�
   csylqNum: 0,  // 瓒呮椂宸查鍙栨暟閲�
   cswlqNum: 0  // 瓒呮椂鏈鍙栨暟閲�
 })
-
-const resetParams = () => {
-  resetFilters();
-  getStatistics();
-};
-
-// 澶氶�夊悗鍋氫粈涔�
-const handleSelectionChange = (selectionList) => {
-  multipleList.value = selectionList;
-};
-const getList = (status) => {
-  switch (status){
-    case 1:
-      filters.status = 1
-      break;
-    case 2:
-      filters.status = 2
-      break;
-    case 3:
-      filters.status = 3
-      break;
-    case 4:
-      filters.status = 4
-      break;
-    default:
-      filters.status = 0
-  }
-  console.log(filters)
-  getTableData();
-  getStatistics();
+const resetHandleQuery = () => {
+  searchForm.value.issueDate = "";
+  searchForm.value.season = getCurrentMonth();
+  handleQuery(0)
 };
 
 /** 鎼滅储鎸夐挳鎿嶄綔 */
-const handleQuery = () => {
-	pagination.current = 1;
-  getTableData();
+const handleQuery = (status) => {
+  switch (status){
+    case 1:
+      searchForm.value.status = 1
+      break;
+    case 2:
+      searchForm.value.status = 2
+      break;
+    case 3:
+      searchForm.value.status = 3
+      break;
+    case 4:
+      searchForm.value.status = 4
+      break;
+    default:
+      searchForm.value.status = 0
+  }
+  getList();
+  getStatistics();
 };
-const changePage = ({ page, limit }) => {
-  pagination.currentPage = page;
-  pagination.pageSize = limit;
-  onCurrentChange(page);
-};
+
 const getStatistics = () => {
-  statistics(filters).then(res => {
+  statistics(searchForm.value).then(res => {
     statisticsObj.value.cswlqNum = res.data.cswlqNum
     statisticsObj.value.csylqNum = res.data.csylqNum
     statisticsObj.value.ylqNum = res.data.ylqNum
     statisticsObj.value.wlqNum = res.data.wlqNum
   })
 }
+// 鑾峰彇瀛楀吀鏁版嵁
+const getList = async () => {
+  tableLoading.value = true;
+  const params = { ...searchForm.value};
+  statisticsList(params).then(res => {
+    tableLoading.value = false;
+    tableData.value = res.data;
+  }).catch(err => {
+    tableLoading.value = false;
+  })
+}
+const handleOut = () => {
+  ElMessageBox.confirm("閫変腑鐨勫唴瀹瑰皢琚鍑猴紝鏄惁纭瀵煎嚭锛�", "瀵煎嚭", {
+    confirmButtonText: "纭",
+    cancelButtonText: "鍙栨秷",
+    type: "warning",
+  })
+      .then(() => {
+        proxy.download(`/lavorIssue/exportCopy`, {season: searchForm.value.season,issueDate: searchForm.value.issueDate}, "鍔充繚鍙拌处.xlsx");
+      })
+      .catch(() => {
+        ElMessage.info("宸插彇娑�");
+      });
+};
 
+// 浜嬩欢澶勭悊鍑芥暟
+const handleSelectionChange = (selection) => {
+  multipleList.value = selection;
+}
+
+// 缁勪欢鎸傝浇鏃跺姞杞藉瓧鍏告暟鎹�
 onMounted(() => {
-  getList()
-});
+  handleQuery()
+})
 </script>
 
-<style lang="scss" scoped>
-.table_list {
-  margin-top: unset;
+<style scoped>
+.dynamic-table-container {
+  width: 100%;
+}
+
+.pagination-container {
+  margin-top: 20px;
+  display: flex;
+  justify-content: flex-end;
+}
+
+:deep(.el-table .el-table__header-wrapper th) {
+  background-color: #F0F1F5 !important;
+  color: #333333;
+  font-weight: 600;
+}
+
+:deep(.el-table .el-table__body-wrapper td) {
+  padding: 8px 0;
+}
+
+:deep(.el-select) {
+  width: 100%;
+}
+
+:deep(.el-input) {
+  width: 100%;
 }
 .actions {
   display: flex;
   justify-content: space-around;
   align-items: center;
-  //margin-top: 20px;
   margin-bottom: 30px;
 }
 .head{
@@ -231,4 +283,3 @@
   font-weight: 600;
 }
 </style>
-

--
Gitblit v1.9.3