From d529e4e9f3b00ce5ff0d9d65670e37e422ec660c Mon Sep 17 00:00:00 2001
From: fei <791364011@qq.com>
Date: 星期一, 22 十二月 2025 20:19:56 +0800
Subject: [PATCH] 修改了代码

---
 src/views/archiveManager/archiveMaterial/index.vue |  229 ++++++++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 186 insertions(+), 43 deletions(-)

diff --git a/src/views/archiveManager/archiveMaterial/index.vue b/src/views/archiveManager/archiveMaterial/index.vue
index 29e4c70..a6c252d 100644
--- a/src/views/archiveManager/archiveMaterial/index.vue
+++ b/src/views/archiveManager/archiveMaterial/index.vue
@@ -1,5 +1,7 @@
 <template>
     <div class="app-container">
+
+      <div v-if="sho">
          <h2 class="title-border">娣诲姞妗堝嵎璇︾粏璁板綍</h2>
  <el-form ref="form" :model="form" :rules="rules" label-width="100px">
 
@@ -15,8 +17,8 @@
     <el-col :span="16">
           <el-form-item label="璐d换鑰�" prop="creator">
             <div class="title-search-wrapper">
-              <el-input 
-                v-model="form.creator" 
+              <el-input
+                v-model="form.creator"
                 placeholder="璇疯緭鍏ヨ矗浠昏��"
                 @input="handleCreatorInput"
                 @focus="showCreatorSuggestions = true"
@@ -87,6 +89,7 @@
           <el-select
             v-model="form.fileStyle"
             placeholder="璇烽�夋嫨鏉愭枡绫诲瀷"
+            @change="handleFileStyleChange"
           >
             <el-option
               v-for="item in fileStyleOptions"
@@ -233,7 +236,7 @@
 
         </div>
 
-
+</div>
 
 <div class="title-border"></div>
 
@@ -254,6 +257,7 @@
         </el-col>
         <el-col :span="1.5">
           <el-button
+          v-if="sho"
             type="success"
             plain
             icon="el-icon-edit"
@@ -262,6 +266,17 @@
             @click="handleUpdate"
             v-hasPermi="['system:materials:edit']"
           >淇敼</el-button>
+        </el-col>
+           <el-col :span="1.5">
+          <el-button
+            type="warning"
+            plain
+            icon="el-icon-download"
+            size="mini"
+            @click="handleExportDir"
+            v-hasPermi="['system:materials:list']"
+
+          >瀵煎嚭鍗峰唴鐩綍</el-button>
         </el-col>
         <el-col :span="1.5">
           <el-button
@@ -272,10 +287,11 @@
             @click="handleExport"
             v-hasPermi="['system:materials:list']"
 
-          >瀵煎嚭</el-button>
+          >瀵煎嚭鐢靛瓙鏂囦欢鐩綍</el-button>
         </el-col>
         <el-col :span="1.5">
           <el-button
+          v-if="sho"
             type="danger"
             plain
             icon="el-icon-delete"
@@ -288,6 +304,7 @@
 
           <el-col :span="1.5">
           <el-button
+          v-if="sho"
             type="success"
             plain
             icon="el-icon-edit"
@@ -344,7 +361,7 @@
               accept=".xlsx,.xls"
 
         >
-          <el-button size="mini"   type="primary"
+          <el-button size="mini"  v-if="sho" type="primary"
                      plain
                      icon="el-icon-top">瀵煎叆</el-button>
 
@@ -355,7 +372,7 @@
 
       <el-table v-loading="loading" :data="materialsList" @selection-change="handleSelectionChange">
         <el-table-column type="selection" width="55" align="center" />
-        <el-table-column label="鎿嶄綔" align="center" width="160" class-name="small-padding ">
+        <el-table-column v-if="sho" label="鎿嶄綔" align="center" width="160" class-name="small-padding ">
               <template slot-scope="scope">
                 <el-button
                   size="mini"
@@ -392,8 +409,8 @@
         </el-table-column>
         <el-table-column label="椤靛彿" sortable align="center" prop="pageNumber"  />
         <el-table-column label="澶囨敞" align="center" prop="remarks" />
-                <el-table-column label="椤垫" sortable align="center" prop="pageOrder"  />
-
+            <!--          <el-table-column label="椤垫" sortable align="center" prop="pageOrder"  />
+--->
         <el-table-column label="鎵�澶勯樁娈�" sortable align="center" width="180" prop="stage" />
         <el-table-column label="鍏紑灞炴��" sortable align="center" width="180" prop="publicity" />
         <el-table-column label="鏄惁涓洪檮鍥惧強闄勪欢" align="center" prop="isAttachment" />
@@ -404,13 +421,13 @@
 
         <el-table-column label="鏄惁娑夊瘑鍙婃晱鎰熶俊鎭�" align="center" prop="isSensitive" />
         <el-table-column label="鏄惁娉ㄩ攢" align="center" prop="isCanceled" />
-        <el-table-column label="鏍煎紡" align="center" prop="format" />
+     <!--   <el-table-column label="鏍煎紡" align="center" prop="format" />
         <el-table-column label="骞呴潰" align="center" prop="sizeType" />
         <el-table-column label="姘村钩鍒嗚鲸鐜�" align="center" prop="horizontalResolution" />
         <el-table-column label="鍨傜洿鍒嗚鲸鐜�" align="center" prop="verticalResolution" />
         <el-table-column label="瀹藉害" align="center" prop="width" />
         <el-table-column label="楂樺害" align="center" prop="height" />
-        <el-table-column label="澶у皬" align="center" prop="fileSize" />
+        <el-table-column label="澶у皬" align="center" prop="fileSize" /> -->
         <el-table-column label="闄勪欢鍙婂巻鍙插彂鏂囧彿" align="center" prop="attachmentHistoryNumbers" />
 
 
@@ -461,9 +478,9 @@
     <el-form-item label="鏉愭枡绫诲瀷" prop="fileStyle">
           <el-select
             v-model="forms.fileStyle"
-
             placeholder="璇烽�夋嫨鏉愭枡绫诲瀷"
             clearable
+            @change="handleFileStyleChange2"
           >
             <el-option
               v-for="item in fileStyleOptions"
@@ -473,7 +490,7 @@
             />
           </el-select>
         </el-form-item>
-     <el-form-item label="椤靛彿" prop="pageNumber">
+     <el-form-item label="椤靛彿" prop="pageNumber" v-if="forms.fileStyle !== '鍏朵粬鏉愭枡'">
         <el-col :span="8">
           <el-input
             v-model.number="forms.pageNumber"
@@ -616,9 +633,11 @@
       <el-form-item label="鏂囦欢棰樺悕" prop="title">
         <el-input
           v-model="queryParams.title"
-          placeholder="璇疯緭鍏ユ枃浠堕鐩�"
+          placeholder="璇疯緭鍏ユ枃浠堕鍚�"
           clearable
           @keyup.enter.native="handleQuery"
+          :validate-event="false"
+          @blur="validateQueryTitle"
         />
       </el-form-item>
       <el-form-item label="鏃ユ湡" prop="date">
@@ -785,7 +804,7 @@
   </template>
 
   <script>
-  import { islegal, listMaterials, enload, getMaterials, delMaterials, addMaterials, updateMaterials } from "@/api/system/materials"
+  import {insertFile, getFileCount,islegal, listMaterials, enload, getMaterials, delMaterials, addMaterials, updateMaterials } from "@/api/system/materials"
 import { getToken } from '@/utils/auth'
 import store from '@/store'
 import { updateStatusById } from "@/api/system/records"
@@ -795,6 +814,9 @@
     name: "Materials",
     data() {
       return {
+        //鏄惁鏄剧ず鐩稿叧鍐呭
+        sho: true,
+        totalPageCount: 0,
         // 璁板綍鍏冪礌鍒濆浣嶇疆鍜岀姸鎬�
   originalOffsetLeft: 0,
         originalWidth: 0,
@@ -920,22 +942,48 @@
         // 琛ㄥ崟鏍¢獙
         rules: {
           creator: [
-           // { required: true, message: "鍒涘缓鑰呬笉鑳戒负绌�", trigger: "blur" }
+           // { required: true, message: "鍒涘缓鑰呬笉鑳戒负绌�", trigger: "blur" },
+            { max: 85, message: "鏈�澶ч暱搴︿负85涓瓧绗�", trigger: "blur" }
           ],
           title: [
-            { required: true, message: "妗堝嵎棰樺悕涓嶈兘涓虹┖", trigger: "blur" }
+            { required: true, message: "妗堝嵎棰樺悕涓嶈兘涓虹┖", trigger: "blur" },
+             { pattern: /^[^\\/:*?"<>涓╙+$/, message: "鏂囦欢鍚嶄笉鑳藉寘鍚� \\\:*?<>涓� 绛夌壒娈婂瓧绗�", trigger: "blur" },
+            { max: 85, message: "鏈�澶ч暱搴︿负85涓瓧绗�", trigger: "blur" }
           ],
           date: [
           //  { required: true, message: "鏃ユ湡涓嶈兘涓虹┖", trigger: "blur" },
-            { pattern: /^\d{4}-\d{2}-\d{2}$/, message: "鏃ユ湡鏍煎紡蹇呴』涓簓yyy-mm-dd", trigger: "blur" }
+            { pattern: /^\d{4}-\d{2}-\d{2}$/, message: "鏃ユ湡鏍煎紡蹇呴』涓簓yyy-mm-dd", trigger: "blur" },
+            { max: 85, message: "鏈�澶ч暱搴︿负85涓瓧绗�", trigger: "blur" }
           ],
           pageNumber: [
             { required: true, message: "椤靛彿涓嶈兘涓虹┖", trigger: "blur" },
             { type: 'number', message: '椤靛彿蹇呴』涓烘暟瀛楃被鍨�', trigger: ['blur', 'change'] },
-            { pattern: /^\d+$/, message: '璇疯緭鍏ユ鏁存暟', trigger: 'blur' }
+            { pattern: /^[1-9]\d*$/, message: '璇疯緭鍏ュぇ浜�0鐨勬鏁存暟', trigger: 'blur' },
+            // { max: 85, message: "鏈�澶ч暱搴︿负85涓瓧绗�", trigger: "blur" }
           ],
           stage: [
-            { required: true, message: "鎵�澶勯樁娈典笉鑳戒负绌�", trigger: "change" }
+            { required: true, message: "鎵�澶勯樁娈典笉鑳戒负绌�", trigger: "change" },
+            { max: 85, message: "鏈�澶ч暱搴︿负85涓瓧绗�", trigger: "blur" }
+          ],
+          fileStyle: [
+            { required: true, message: "鏉愭枡绫诲瀷涓嶈兘涓虹┖", trigger: "change" },
+            { max: 85, message: "鏈�澶ч暱搴︿负85涓瓧绗�", trigger: "blur" }
+          ],
+          isAttachment: [
+            { required: true, message: "鏄惁涓洪檮浠朵笉鑳戒负绌�", trigger: "change" },
+            { max: 85, message: "鏈�澶ч暱搴︿负85涓瓧绗�", trigger: "blur" }
+          ],
+          retentionPeriod: [
+            { required: true, message: "淇濈鏈熼檺涓嶈兘涓虹┖", trigger: "change" },
+            { max: 85, message: "鏈�澶ч暱搴︿负85涓瓧绗�", trigger: "blur" }
+          ],
+          isSensitive: [
+            { required: true, message: "鏄惁鏁忔劅涓嶈兘涓虹┖", trigger: "change" },
+            { max: 85, message: "鏈�澶ч暱搴︿负85涓瓧绗�", trigger: "blur" }
+          ],
+          isCanceled: [
+            { required: true, message: "鏄惁娉ㄩ攢涓嶈兘涓虹┖", trigger: "change" },
+            { max: 85, message: "鏈�澶ч暱搴︿负85涓瓧绗�", trigger: "blur" }
           ]
         }
       }
@@ -963,6 +1011,14 @@
     created() {
       //const roleId = this.$route.params && this.$route.params.roleId
       const recordId = this.$route.params && this.$route.params.recordId
+
+      this.totalPageCount = this.$route.params && this.$route.params.pageCount
+
+      this.sho = this.$route.params && this.$route.params.sho
+      // 灏嗗瓧绗︿覆杞崲涓哄竷灏斿��
+      this.sho = this.sho === true || this.sho === "true"
+
+      //alert(this.totalPageCount)
       //alert(recordId)
       this.recordId = recordId;
       this.uploadUrl = process.env.VUE_APP_BASE_API +'/system/materials/upload/'+this.recordId
@@ -1007,6 +1063,11 @@
     },
        // 鎵撳紑瀵煎叆瀵硅瘽妗�
     handleImport() {
+      //鐢熸垚鏂扮殑璁板綍
+      insertFile(this.recordId, this.totalPageCount).then(response => {
+        console.log(response)
+      //  alert(3245)
+        })
       this.importDialogVisible = true
     },
     // 鏂囦欢绉婚櫎
@@ -1029,26 +1090,31 @@
         this.$modal.msgWarning('璇峰厛閫夋嫨鏂囦欢鍐嶄笂浼�')
         return
       }
-      if(fileCount!==this.total)
-      {
-        this.$modal.msgWarning('璇烽�夋嫨涓庤褰曟暟涓�鑷寸殑鏂囦欢')
-        return
-      }
+     // alert(this.recordId)
+
+
       //鍒ゆ柇椤靛彿涓庝笂浼犱笂浼犵殑鏂囦欢鐨勯〉鍙锋槸涓嶆槸涓�涓�瀵瑰簲鐨�
-     islegal(this.recordId).then(response => {
-       console.log(response.data)
-       var res = response.data
-       if(res)
+     // islegal(this.recordId).then(response => {
+     //   console.log(response.data)
+     //   var res = response.data.res
+     //  console.log(res)
+       //alert(response.data.total)
+       if(fileCount!=this.totalPageCount)
+       {
+         this.$modal.msgWarning('璇烽�夋嫨涓庤褰曟暟涓�鑷寸殑鏂囦欢')
+         return
+       }
+       else
        {
          // 鎵ц涓婁紶
            this.$refs.upload.submit()
            this.getList()
        }
-       else
-       {
-         this.$modal.msgError("椤靛彿涓嶈繛缁紝璇蜂慨鏀逛负杩炵画姝g‘鐨勯〉鍙凤紒")
-       }
-     })
+       // else
+       // {
+       //   this.$modal.msgError("椤靛彿涓嶈繛缁紝璇蜂慨鏀逛负杩炵画姝g‘鐨勯〉鍙凤紒")
+       // }
+     //})
 
     },
     clearFileList() {
@@ -1080,9 +1146,25 @@
       /** 鏌ヨ銆愯濉啓鍔熻兘鍚嶇О銆戝垪琛� */
       getList() {
         this.loading = true
-        listMaterials(this.queryParams).then(response => {
+
+        // 澶勭悊妗f鍙锋悳绱㈤�昏緫锛屽寘鎷寖鍥存悳绱�
+        const queryParams = { ...this.queryParams }
+
+        // 妫�鏌ユ槸鍚﹀寘鍚寖鍥存悳绱㈢鍙�
+        if (queryParams.fileNumber && queryParams.fileNumber.includes('~')) {
+          const rangeParts = queryParams.fileNumber.split('~')
+          if (rangeParts.length === 2) {
+            // 瑙f瀽鑼冨洿鎼滅储鍙傛暟
+            // 淇濈暀鍘熷fileNumber鐢ㄤ簬鍏朵粬澶勭悊
+            queryParams.fileNumberStart = rangeParts[0].trim()
+            queryParams.fileNumberEnd = rangeParts[1].trim()
+          }
+        }
+
+        listMaterials(queryParams).then(response => {
           console.log(response)
-          this.materialsList = response.data.data
+          // 杩囨护鎺塿isible涓�0鐨勮褰�
+          this.materialsList = response.data.data.filter(item => item.visible !== 0)
           this.total = response.data.total
           this.loading = false
         })
@@ -1177,7 +1259,7 @@
         this.form.title = title;
         this.showTitleSuggestions = false;
       },
-      
+
       // 澶勭悊璐d换浜鸿緭鍏ヤ簨浠�
       handleCreatorInput() {
         // 娓呴櫎涔嬪墠鐨勫畾鏃跺櫒锛堥槻鎶栵級
@@ -1231,6 +1313,21 @@
         this.showCreatorSuggestions = false;
       },
 
+      // 澶勭悊鏉愭枡绫诲瀷鍙樺寲锛堟柊澧炶〃鍗曪級
+      handleFileStyleChange(value) {
+        // 褰撻�夋嫨'鍏朵粬鏉愭枡'鏃讹紝灏嗛〉鍙疯缃负0
+        if (value === '鍏朵粬鏉愭枡') {
+          this.forms.pageNumber = null;
+        }
+      },
+      // 澶勭悊鏉愭枡绫诲瀷鍙樺寲锛堜慨鏀硅〃鍗曪級
+      handleFileStyleChange2(value) {
+        // 褰撻�夋嫨'鍏朵粬鏉愭枡'鏃讹紝灏嗛〉鍙疯缃负0
+        if (value === '鍏朵粬鏉愭枡') {
+          this.forms.pageNumber = null;
+        }
+      },
+
       // 琛ㄥ崟閲嶇疆
       reset() {
         this.form = {
@@ -1263,8 +1360,24 @@
         }
         this.resetForm("form")
       },
+
+      // 楠岃瘉鏌ヨ琛ㄥ崟涓殑鏂囦欢棰樺悕
+      validateQueryTitle() {
+        const illegalCharsPattern = /[\\/:*?<>涓╙/;
+        if (this.queryParams.title && illegalCharsPattern.test(this.queryParams.title)) {
+          this.$message.error("鏂囦欢鍚嶄笉鑳藉寘鍚� \\:/:*?<>涓� 绛夌壒娈婂瓧绗�");
+          this.queryParams.title = this.queryParams.title.replace(illegalCharsPattern, '');
+        }
+      },
       /** 鎼滅储鎸夐挳鎿嶄綔 */
       handleQuery() {
+        // 鎼滅储鍓嶆牎楠屾枃浠堕鍚�
+        const illegalCharsPattern = /[\\/:*?<>涓╙/;
+        if (this.queryParams.title && illegalCharsPattern.test(this.queryParams.title)) {
+          this.$message.error("鏂囦欢鍚嶄笉鑳藉寘鍚� \\:/:*?<>涓� 绛夌壒娈婂瓧绗�");
+          this.queryParams.title = this.queryParams.title.replace(illegalCharsPattern, '');
+          return; // 闃绘鎼滅储锛岀洿鍒扮敤鎴蜂慨姝h緭鍏�
+        }
         this.queryParams.pageNum = 1
         this.getList()
       },
@@ -1291,6 +1404,10 @@
         const materialId = row.materialId || this.ids
         getMaterials(materialId).then(response => {
           this.forms = response.data
+          // 濡傛灉鏉愭枡绫诲瀷鏄�"鍏朵粬鏉愭枡"锛屽皢椤靛彿璁剧疆涓�0
+          if (this.forms.fileStyle === '鍏朵粬鏉愭枡') {
+            this.forms.pageNumber = null;
+          }
           this.open = true
           this.title = "淇敼妗堝嵎璇︾粏淇℃伅"
         })
@@ -1381,6 +1498,7 @@
       },
       /** 鎻愪氦鎸夐挳 */
       submitForms() {
+        console.log(this.forms)
         this.$refs["forms"].validate(valid => {
           if (valid) {
             if (this.forms.materialId != null) {
@@ -1409,6 +1527,26 @@
           this.$modal.msgSuccess("鍒犻櫎鎴愬姛")
         }).catch(() => {})
       },
+           /** 瀵煎嚭鎸夐挳鎿嶄綔 - 鏀寔瀵煎嚭閫変腑琛屾垨鍏ㄩ儴鏁版嵁 */
+      handleExportDir() {
+        // 鍒ゆ柇鏄惁鏈夐�変腑鐨勮
+        if (this.ids && this.ids.length > 0) {
+          // 鏄剧ず瀵煎嚭閫変腑琛岀殑鎻愮ず
+          this.$message.info(`姝e湪瀵煎嚭${this.ids.length}鏉¢�変腑鐨勬暟鎹�...`);
+          // 瀵煎嚭閫変腑鐨勮鏁版嵁
+          this.download('system/materials/exportDir', {
+            ids: this.ids.join(','),
+         //   exportType: 'selected'
+          }, `materiaDir_selected_${new Date().getTime()}.xls`)
+        } else {
+          // 鏄剧ず瀵煎嚭鍏ㄩ儴鏁版嵁鐨勬彁绀�
+          this.$message.info('姝e湪瀵煎嚭绗﹀悎褰撳墠鏌ヨ鏉′欢鐨勬墍鏈夋暟鎹�...');
+          // 娌℃湁閫変腑琛屾椂锛屽鍑哄綋鍓嶆煡璇㈡潯浠剁殑鏁版嵁
+          this.download('system/materials/exportDir', {
+            ...this.queryParams
+          }, `materiaDir_${new Date().getTime()}.xls`)
+        }
+      },
       /** 瀵煎嚭鎸夐挳鎿嶄綔 - 鏀寔瀵煎嚭閫変腑琛屾垨鍏ㄩ儴鏁版嵁 */
       handleExport() {
         // 鍒ゆ柇鏄惁鏈夐�変腑鐨勮
@@ -1419,14 +1557,14 @@
           this.download('system/materials/export', {
             ids: this.ids.join(','),
          //   exportType: 'selected'
-          }, `materials_selected_${new Date().getTime()}.xlsx`)
+          }, `materials_selected_${new Date().getTime()}.xls`)
         } else {
           // 鏄剧ず瀵煎嚭鍏ㄩ儴鏁版嵁鐨勬彁绀�
           this.$message.info('姝e湪瀵煎嚭绗﹀悎褰撳墠鏌ヨ鏉′欢鐨勬墍鏈夋暟鎹�...');
           // 娌℃湁閫変腑琛屾椂锛屽鍑哄綋鍓嶆煡璇㈡潯浠剁殑鏁版嵁
           this.download('system/materials/export', {
             ...this.queryParams
-          }, `materials_${new Date().getTime()}.xlsx`)
+          }, `materials_${new Date().getTime()}.xls`)
         }
       },
 
@@ -1435,7 +1573,7 @@
     {
       this.download('/system/materials/model', {
 
-      }, `materials_${new Date().getTime()}.xlsx`)
+      }, `materials_${new Date().getTime()}.xls`)
     },
        /** 瀵煎叆鎿嶄綔*/
     async handleImportData({file}){
@@ -1446,7 +1584,7 @@
   // }
   const formData = new FormData();
   formData.append('file', file);
- // formData.append('recordId', this.recordId)
+  formData.append('recordId', this.recordId)
   // alert(this.recordId)
   console.log(file)
 
@@ -1508,8 +1646,13 @@
       const rect = fixedRow.getBoundingClientRect();
       const parentRect = fixedRow.parentNode.getBoundingClientRect();
 
-      // 妫�鏌ュ厓绱犳槸鍚﹀簲璇ヨ繘鍏ユ偓娴姸鎬�
-      if (rect.top <= 0) {
+      // 璁板綍鍏冪礌鐨勫師濮嬩綅缃紙鐩稿浜庢枃妗i《閮ㄧ殑浣嶇疆锛�
+      if (!this.originalTop) {
+        this.originalTop = rect.top + window.pageYOffset;
+      }
+
+      // 妫�鏌ュ厓绱犳槸鍚﹀簲璇ヨ繘鍏ユ偓娴姸鎬侊紙褰撴粴鍔ㄤ綅缃秴杩囧厓绱犲師濮嬩綅缃椂锛�
+      if (window.pageYOffset >= this.originalTop) {
         // 鍙湪涓嶅湪floating鐘舵�佹椂娣诲姞锛岄伩鍏嶉噸澶嶆搷浣�
         if (!fixedRow.classList.contains('floating')) {
           // 璁板綍鍏冪礌鍘熷鐨勫乏鍋忕Щ閲忥紙鐩稿浜庣埗瀹瑰櫒锛�
@@ -1533,7 +1676,7 @@
           }
         }
       } else {
-        // 褰撳厓绱犲洖鍒拌鍙i《閮ㄤ互涓婃椂锛岀Щ闄ゆ偓娴姸鎬侊紝鎭㈠鍒版枃妗f祦涓�
+        // 褰撴粴鍔ㄤ綅缃洖鍒板厓绱犲師濮嬩綅缃互涓婃椂锛岀Щ闄ゆ偓娴姸鎬侊紝鎭㈠鍒版枃妗f祦涓�
         if (fixedRow.classList.contains('floating')) {
           // 绉婚櫎floating绫�
           fixedRow.classList.remove('floating');

--
Gitblit v1.9.1