From 4f2c8ee38607730ed7561cd814e26b91c6dd53f5 Mon Sep 17 00:00:00 2001
From: spring <2396852758@qq.com>
Date: 星期二, 17 六月 2025 09:07:19 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev' into dev

---
 src/views/basicData/supplierManage/index.vue |   72 +++++++++++++++++++++++++++++++++---
 1 files changed, 66 insertions(+), 6 deletions(-)

diff --git a/src/views/basicData/supplierManage/index.vue b/src/views/basicData/supplierManage/index.vue
index ce4dac7..6270639 100644
--- a/src/views/basicData/supplierManage/index.vue
+++ b/src/views/basicData/supplierManage/index.vue
@@ -16,6 +16,7 @@
       <div>
         <el-button type="primary" @click="openForm('add')">鏂板渚涘簲鍟�</el-button>
         <el-button @click="handleOut">瀵煎嚭</el-button>
+        <el-button type="info" plain icon="Upload" @click="handleImport">瀵煎叆</el-button>
         <el-button type="danger" plain @click="handleDelete">鍒犻櫎</el-button>
       </div>
     </div>
@@ -76,7 +77,7 @@
         <el-row :gutter="30">
           <el-col :span="12">
             <el-form-item label="缁存姢浜猴細" prop="maintainUserId">
-              <el-select v-model="form.maintainUserId" placeholder="璇烽�夋嫨" clearable>
+              <el-select v-model="form.maintainUserId" placeholder="璇烽�夋嫨" clearable disabled>
                 <el-option v-for="item in userList" :key="item.nickName" :label="item.nickName" :value="item.userId"/>
               </el-select>
             </el-form-item>
@@ -91,6 +92,7 @@
                   type="date"
                   placeholder="璇烽�夋嫨"
                   clearable
+                  disabled
               />
             </el-form-item>
           </el-col>
@@ -100,6 +102,26 @@
         <div class="dialog-footer">
           <el-button type="primary" @click="submitForm">纭</el-button>
           <el-button @click="closeDia">鍙栨秷</el-button>
+        </div>
+      </template>
+    </el-dialog>
+
+    <!-- 渚涘簲鍟嗗鍏ュ璇濇 -->
+    <el-dialog :title="upload.title" v-model="upload.open" width="400px" append-to-body>
+      <el-upload ref="uploadRef" :limit="1" accept=".xlsx, .xls" :headers="upload.headers" :action="upload.url + '?updateSupport=' + upload.updateSupport" :disabled="upload.isUploading" :on-progress="handleFileUploadProgress" :on-success="handleFileSuccess" :auto-upload="false" drag>
+        <el-icon class="el-icon--upload"><upload-filled /></el-icon>
+        <div class="el-upload__text">灏嗘枃浠舵嫋鍒版澶勶紝鎴�<em>鐐瑰嚮涓婁紶</em></div>
+        <template #tip>
+          <div class="el-upload__tip text-center">
+            <span>浠呭厑璁稿鍏ls銆亁lsx鏍煎紡鏂囦欢銆�</span>
+            <el-link type="primary" :underline="false" style="font-size: 12px; vertical-align: baseline" @click="importTemplate">涓嬭浇妯℃澘</el-link>
+          </div>
+        </template>
+      </el-upload>
+      <template #footer>
+        <div class="dialog-footer">
+          <el-button type="primary" @click="submitFileForm">纭� 瀹�</el-button>
+          <el-button @click="upload.open = false">鍙� 娑�</el-button>
         </div>
       </template>
     </el-dialog>
@@ -113,16 +135,21 @@
 import {ElMessageBox } from "element-plus";
 import {userListNoPage} from "@/api/system/user.js";
 import {addSupplier,getSupplier,listSupplier,updateSupplier} from "@/api/basicData/supplierManageFile.js";
+import useUserStore from "@/store/modules/user"
+import {getToken} from "@/utils/auth.js";
 const { proxy } = getCurrentInstance()
+const userStore = useUserStore()
 
 const tableColumn = ref([
   {
     label: '渚涘簲鍟嗗悕绉�',
     prop: 'supplierName',
+    width: 250,
   },
   {
     label: '鍏徃鍦板潃',
-    prop: 'companyAddress'
+    prop: 'companyAddress',
+    width: 220,
   },
   {
     label: '鑱旂郴鏂瑰紡',
@@ -218,18 +245,39 @@
   page.current = 1
   getList()
 }
-const pagination = ({ current, limit }) => {
-  page.current = current;
-  page.size = limit;
+const pagination = (obj) => {
+  page.current = obj.page;
+  page.size = obj.limit;
   getList()
+}
+/** 鎻愪氦涓婁紶鏂囦欢 */
+function submitFileForm() {
+  proxy.$refs["uploadRef"].submit()
 }
 const getList = () => {
   tableLoading.value = true
   listSupplier({...searchForm.value, ...page}).then(res => {
     tableLoading.value = false
     tableData.value = res.data.records
-    total.value = res.total
+    total.value = res.data.total
   })
+}
+const upload = reactive({
+  // 鏄惁鏄剧ず寮瑰嚭灞傦紙渚涘簲鍟嗗鍏ワ級
+  open: false,
+  // 寮瑰嚭灞傛爣棰橈紙渚涘簲鍟嗗鍏ワ級
+  title: "",
+  // 鏄惁绂佺敤涓婁紶
+  isUploading: false,
+  // 璁剧疆涓婁紶鐨勮姹傚ご閮�
+  headers: { Authorization: "Bearer " + getToken() },
+  // 涓婁紶鐨勫湴鍧�
+  url: import.meta.env.VITE_APP_BASE_API + "/system/supplier/import"
+})
+/** 瀵煎叆鎸夐挳鎿嶄綔 */
+function handleImport() {
+  upload.title = "渚涘簲鍟嗗鍏�"
+  upload.open = true
 }
 // 琛ㄦ牸閫夋嫨鏁版嵁
 const handleSelectionChange = (selection) => {
@@ -239,6 +287,8 @@
 const openForm = (type, row) => {
   operationType.value = type
   form.value = {}
+  form.value.maintainUserId = userStore.id
+  form.value.maintainTime = getCurrentDate();
   userListNoPage().then(res => {
     userList.value = res.data
   })
@@ -325,6 +375,16 @@
     proxy.$modal.msg("宸插彇娑�")
   })
 }
+
+// 鑾峰彇褰撳墠鏃ユ湡骞舵牸寮忓寲涓� YYYY-MM-DD
+function getCurrentDate() {
+  const today = new Date();
+  const year = today.getFullYear();
+  const month = String(today.getMonth() + 1).padStart(2, '0'); // 鏈堜唤浠�0寮�濮�
+  const day = String(today.getDate()).padStart(2, '0');
+  return `${year}-${month}-${day}`;
+}
+
 getList()
 </script>
 

--
Gitblit v1.9.3