From f1fc66a06b7f55c03f2a0ab08e86b5fee4156cca Mon Sep 17 00:00:00 2001 From: 龚焕茏 <2842157468@qq.com> Date: 星期二, 23 四月 2024 10:48:22 +0800 Subject: [PATCH] 合同导入模板 --- src/views/system/contract/index.vue | 316 +++++++++++++++++++++++----------------------------- 1 files changed, 141 insertions(+), 175 deletions(-) diff --git a/src/views/system/contract/index.vue b/src/views/system/contract/index.vue index 8df9540..8774b65 100644 --- a/src/views/system/contract/index.vue +++ b/src/views/system/contract/index.vue @@ -2,9 +2,12 @@ <div class="app-container"> <el-row> - <el-col :span="8" v-for="(item) in tableData" :key="o" style="margin: 10px;width: 30%;"> + <el-col :span="8" v-for="(item) in tableData" :key="item" style="margin: 10px;width: 30%;"> <el-card :body-style="{ padding: '0px' }"> - <el-image style="width: 420px;height: 187px;" :preview-src-list="['https://img2.baidu.com/it/u=68398439,1553004927&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=357']" fit="cover" src="https://img2.baidu.com/it/u=68398439,1553004927&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=357" class="image"/> + <el-image style="width: 420px;height: 187px;" + :preview-src-list="['https://img2.baidu.com/it/u=68398439,1553004927&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=357']" + fit="cover" src="https://img2.baidu.com/it/u=68398439,1553004927&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=357" + class="image" /> <div style="padding: 14px;"> <span>{{ item.companyName }}</span> <span class="time" style="margin-left: 10px;">{{ item.deptName }}</span> @@ -19,88 +22,46 @@ <el-row :gutter="10" class="mb8" style="margin-top: 40px;"> <el-col :span="1.5"> - <el-button - type="primary" - plain - icon="el-icon-plus" - size="mini" - v-hasPermi="['system:contract:add']" - @click="handleAdd" - >鏂板</el-button> - </el-col> - <el-col :span="1.5"> - <el-button - type="warning" - plain - icon="el-icon-top" - size="mini" - v-hasPermi="['system:contract:import']" - @click="handleImportPoint" - >瀵煎叆</el-button> + <el-button type="warning" plain icon="el-icon-top" size="mini" v-hasPermi="['system:contract:import']" + @click="handleImport">瀵煎叆</el-button> </el-col> </el-row> - - - <!-- 娣诲姞鎴栦慨鏀广�愯濉啓鍔熻兘鍚嶇О銆戝璇濇 --> - <el-dialog :title="detailName" :visible.sync="open" width="500px" append-to-body> - <el-form ref="form" :model="form" :rules="rules" label-width="80px"> - <el-form-item label="鍏徃鍚�" prop="companyName"> - <el-select v-model="form.companyName" placeholder="璇烽�夋嫨"> - <el-option - v-for="item in unitList" - :key="item.id" - :label="item.value" - :value="item.id"> - </el-option> - </el-select> - </el-form-item> - <el-form-item label="閮ㄩ棬鍚嶇О" prop="deptName"> - <el-select v-model="form.deptName" placeholder="璇烽�夋嫨"> - <el-option - v-for="item in deptList" - :key="item.id" - :label="item.value" - :value="item.id"> - </el-option> - </el-select> - </el-form-item> - <el-form-item label="鍚堝悓鏃堕棿" prop="timezone"> - <el-date-picker - :disabled="title === '淇敼鍚堝悓鏃堕棿'" - @change="dateChange" - v-model="form.timezone" - type="daterange" - align="right" - unlink-panels - range-separator="鑷�" - start-placeholder="寮�濮嬫棩鏈�" - end-placeholder="缁撴潫鏃ユ湡" - > - </el-date-picker> - </el-form-item> - </el-form> - <div slot="footer" class="dialog-footer"> - <el-button type="primary" @click="submitForm">纭� 瀹�</el-button> - <el-button @click="cancel">鍙� 娑�</el-button> - </div> - </el-dialog> <!-- 鍚堝悓璇︽儏 --> <el-dialog :title="detailName" :visible.sync="detail" width="800px" append-to-body> <el-form label-position="left" inline class="table-expand"> <el-collapse v-model="activeNames" @change="handleChange"> <el-collapse-item title="瑙嗛骞冲潎鍦ㄧ嚎鐜�" name="1"> - <div>鈮�98%锛氫笉鎵e垎</div> - <div class="inline-input-container"> - 95%鈮よ棰戝钩鍧囧湪绾跨巼锛�98%锛氭墸0.1鍒� - </div> - <div class="inline-input-container"> - 90%鈮よ棰戝钩鍧囧湪绾跨巼锛�95%锛氭墸0.5鍒� - </div> - <div class="inline-input-container"> - 锛�90%锛� 鎵�1鍒� - 鑻ユ湁杩炵画涓ゆ鐪佸巺鑰冩牳鍦ㄧ嚎鐜囦綆浜�90%锛屾嫑鏍囦汉鏈夋潈瑙i櫎鍚堝悓銆� - </div> + <el-collapse class="nest-collapse" style="margin-top: 10px;"> + <el-collapse-item title="绗笁灞�-1" name="3"> + <div>鈮�98%锛氫笉鎵e垎</div> + <div class="inline-input-container"> + 95%鈮よ棰戝钩鍧囧湪绾跨巼锛�98%锛氭墸0.1鍒� + </div> + <div class="inline-input-container"> + 90%鈮よ棰戝钩鍧囧湪绾跨巼锛�95%锛氭墸0.5鍒� + </div> + <div class="inline-input-container"> + 锛�90%锛� 鎵�1鍒� + 鑻ユ湁杩炵画涓ゆ鐪佸巺鑰冩牳鍦ㄧ嚎鐜囦綆浜�90%锛屾嫑鏍囦汉鏈夋潈瑙i櫎鍚堝悓銆� + </div> + </el-collapse-item> + </el-collapse> + <el-collapse class="nest-collapse" style="margin-top: 10px;"> + <el-collapse-item title="绗笁灞�-2" name="3"> + <div>鈮�98%锛氫笉鎵e垎</div> + <div class="inline-input-container"> + 95%鈮よ棰戝钩鍧囧湪绾跨巼锛�98%锛氭墸0.1鍒� + </div> + <div class="inline-input-container"> + 90%鈮よ棰戝钩鍧囧湪绾跨巼锛�95%锛氭墸0.5鍒� + </div> + <div class="inline-input-container"> + 锛�90%锛� 鎵�1鍒� + 鑻ユ湁杩炵画涓ゆ鐪佸巺鑰冩牳鍦ㄧ嚎鐜囦綆浜�90%锛屾嫑鏍囦汉鏈夋潈瑙i櫎鍚堝悓銆� + </div> + </el-collapse-item> + </el-collapse> </el-collapse-item> <el-collapse-item title="鍓嶇鎰熺煡婧愭不鐞嗗伐浣�" name="2"> <div class="inline-input-container"> @@ -171,20 +132,70 @@ </el-form> </el-dialog> + <!-- 鍚堝悓瀵煎叆瀵硅瘽妗� --> + <el-dialog :title="upload.title" :visible.sync="upload.open" width="550px" append-to-body> + <el-form ref="form" :model="upload" :rules="rules" label-width="80px"> + <el-form-item label="鍏徃鍚�" prop="unitId"> + <el-select v-model="upload.unitId" placeholder="璇烽�夋嫨"> + <el-option v-for="item in unitList" :key="item.id" :label="item.value" :value="item.id"> + </el-option> + </el-select> + </el-form-item> + <el-form-item label="鍚堝悓鏃堕棿" prop="timezone"> + <el-date-picker :disabled="title === '淇敼鍚堝悓鏃堕棿'" @change="dateChange" v-model="upload.timezone" + value-format="yyyy-MM-dd HH:mm:ss" type="datetimerange" align="right" unlink-panels range-separator="鑷�" + start-placeholder="寮�濮嬫椂闂�" end-placeholder="缁撴潫鏃堕棿"> + </el-date-picker> + </el-form-item> + <el-upload ref="upload" :limit="1" accept=".xlsx, .xls" :headers="upload.headers" + :action="upload.url + '?unitId=' + upload.unitId + '&startTime=' + upload.startTime + '&endTime=' + upload.endTime" + :disabled="upload.isUploading" :on-progress="handleFileUploadProgress" :on-success="handleFileSuccess" + :auto-upload="false" drag style="text-align: center;"> + <i class="el-icon-upload"></i> + <div class="el-upload__text">灏嗘枃浠舵嫋鍒版澶勶紝鎴�<em>鐐瑰嚮涓婁紶</em></div> + <div class="el-upload__tip text-center" slot="tip"> + <span>浠呭厑璁稿鍏ls銆亁lsx鏍煎紡鏂囦欢銆�</span> + <el-link type="primary" :underline="false" style="font-size:12px;vertical-align: baseline;" + @click="importTemplate">涓嬭浇妯℃澘</el-link> + </div> + </el-upload> + </el-form> + <div slot="footer" class="dialog-footer"> + <el-button type="primary" @click="submitFileForm">纭� 瀹�</el-button> + <el-button @click="upload.open = false">鍙� 娑�</el-button> + </div> + </el-dialog> </div> </template> <script> -import { listContract, getContract, delContract, addContract, updateContract } from "@/api/platform/contract"; -import {unitSelect} from "../../../api/platform/unit"; -import {deptSelect} from "../../../api/system/dept"; +import { listContract, getContract } from "@/api/platform/contract"; +import { unitSelect } from "../../../api/platform/unit"; +import { deptSelect } from "../../../api/system/dept"; +import { getToken } from "@/utils/auth"; export default { name: "Contract", data() { return { + // 鍚堝悓瀵煎叆鍙傛暟 + upload: { + // 鏄惁鏄剧ず寮瑰嚭灞傦紙鍚堝悓瀵煎叆锛� + open: false, + // 寮瑰嚭灞傛爣棰橈紙鍚堝悓瀵煎叆锛� + title: "", + // 鏄惁绂佺敤涓婁紶 + isUploading: false, + // 璁剧疆涓婁紶鐨勮姹傚ご閮� + headers: { Authorization: "Bearer " + getToken() }, + // 涓婁紶鐨勫湴鍧� + url: process.env.VUE_APP_BASE_API + "/system/contract/importData", + unitId: '', + startTime: '', + endTime: '' + }, dialogImageUrl: '', dialogVisible: false, disabled: false, @@ -218,16 +229,6 @@ open: false, // 鏄惁鏄剧ず璇︽儏 detail: false, - // 鏌ヨ鍙傛暟 - queryParams: { - pageNum: 1, - pageSize: 10, - companyId: null, - companyName: null, - deptId: null, - deptName: null, - detail: null - }, tableData: [{ id: '12987122', companyName: '杩愮淮鍏徃鐢�', @@ -258,9 +259,12 @@ }, // 琛ㄥ崟鏍¢獙 rules: { - companyId: [ - { required: true, message: "鍏徃id涓嶈兘涓虹┖", trigger: "blur" } + unitId: [ + { required: true, message: "杩愮淮鍗曚綅涓嶈兘涓虹┖", trigger: "blur" } ], + timezone: [ + { type: "array", required: true, message: "鍚堝悓鏃堕棿涓嶈兘涓虹┖", trigger: "change" } + ] } }; }, @@ -270,15 +274,48 @@ this.selectDept(); }, methods: { + /** 瀵煎叆鎸夐挳鎿嶄綔 */ + handleImport() { + this.upload.title = "鍚堝悓瀵煎叆"; + this.upload.open = true; + }, + /** 涓嬭浇妯℃澘鎿嶄綔 */ + importTemplate() { + this.download('system/contract/importTemplate', { + }, `鍚堝悓瀵煎叆妯℃澘.xlsx`) + }, + // 鏂囦欢涓婁紶涓鐞� + handleFileUploadProgress(event, file, fileList) { + this.upload.isUploading = true; + }, + // 鏂囦欢涓婁紶鎴愬姛澶勭悊 + handleFileSuccess(response, file, fileList) { + this.upload.open = false; + this.upload.isUploading = false; + this.$refs.upload.clearFiles(); + this.$alert("<div style='overflow: auto;overflow-x: hidden;max-height: 70vh;padding: 10px 20px 0;'>" + response.msg + "</div>", "瀵煎叆缁撴灉", { dangerouslyUseHTMLString: true }); + this.getList(); + }, + // 鎻愪氦涓婁紶鏂囦欢 + submitFileForm() { + let that = this; + this.$refs["form"].validate(valid => { + if (valid) { + that.$refs.upload.submit(); + } + }) + }, + // 鏃堕棿閫夋嫨鍙戠敓鍙樺寲 + dateChange() { + this.upload.startTime = this.upload.timezone[0]; + this.upload.endTime = this.upload.timezone[1]; + }, handleRemove(file) { console.log(file); }, handlePictureCardPreview(file) { this.dialogImageUrl = file.url; this.dialogVisible = true; - }, - handleDownload(file) { - console.log(file); }, // 杩愮淮鍏徃涓嬫媺鏁版嵁 selectUnit() { @@ -292,12 +329,6 @@ this.deptList = res.data; }) }, - submitForm1() { - alert('鎻愪氦鎴愬姛锛�'); - }, - handleChange(val) { - console.log(val); - }, /** 鏌ヨ銆愯濉啓鍔熻兘鍚嶇О銆戝垪琛� */ getList() { this.loading = true; @@ -306,39 +337,6 @@ this.total = response.total; this.loading = false; }); - }, - // 鍙栨秷鎸夐挳 - cancel() { - this.open = false; - this.reset(); - }, - // 琛ㄥ崟閲嶇疆 - reset() { - this.form = { - id: null, - companyId: null, - companyName: null, - deptId: null, - deptName: null, - detail: null - }; - this.resetForm("form"); - }, - /** 鎼滅储鎸夐挳鎿嶄綔 */ - handleQuery() { - this.queryParams.pageNum = 1; - this.getList(); - }, - /** 閲嶇疆鎸夐挳鎿嶄綔 */ - resetQuery() { - this.resetForm("queryForm"); - this.handleQuery(); - }, - // 澶氶�夋閫変腑鏁版嵁 - handleSelectionChange(selection) { - this.ids = selection.map(item => item.id) - this.single = selection.length!==1 - this.multiple = !selection.length }, /** 鏂板鎸夐挳鎿嶄綔 */ handleAdd() { @@ -361,42 +359,6 @@ this.title = "淇敼鍚堝悓"; }); }, - /** 鎻愪氦鎸夐挳 */ - submitForm() { - this.$refs["form"].validate(valid => { - if (valid) { - if (this.form.id != null) { - updateContract(this.form).then(response => { - this.$modal.msgSuccess("淇敼鎴愬姛"); - this.open = false; - this.getList(); - }); - } else { - addContract(this.form).then(response => { - this.$modal.msgSuccess("鏂板鎴愬姛"); - this.open = false; - this.getList(); - }); - } - } - }); - }, - /** 鍒犻櫎鎸夐挳鎿嶄綔 */ - handleDelete(row) { - const ids = row.id || this.ids; - this.$modal.confirm('鏄惁纭鍒犻櫎銆愯濉啓鍔熻兘鍚嶇О銆戠紪鍙蜂负"' + ids + '"鐨勬暟鎹」锛�').then(function() { - return delContract(ids); - }).then(() => { - this.getList(); - this.$modal.msgSuccess("鍒犻櫎鎴愬姛"); - }).catch(() => {}); - }, - /** 瀵煎嚭鎸夐挳鎿嶄綔 */ - handleExport() { - this.download('system/contract/export', { - ...this.queryParams - }, `contract_${new Date().getTime()}.xlsx`) - } } }; </script> @@ -405,13 +367,17 @@ .table-expand { font-size: 0; } -.table-expand { + +.table-expand { width: 100%; color: #99a9bf; } + .inline-input-container { - white-space: nowrap; /* 闃叉鍐呭鍐呴儴鐨勬崲琛� */ - margin-right: 50px; /* 鍙�夌殑锛岀敤浜庡湪鍏冪礌涔嬮棿娣诲姞涓�浜涢棿璺� */ + white-space: nowrap; + /* 闃叉鍐呭鍐呴儴鐨勬崲琛� */ + margin-right: 50px; + /* 鍙�夌殑锛岀敤浜庡湪鍏冪礌涔嬮棿娣诲姞涓�浜涢棿璺� */ width: 7%; } @@ -437,11 +403,11 @@ .clearfix:before, .clearfix:after { - display: table; - content: ""; + display: table; + content: ""; } .clearfix:after { - clear: both + clear: both } </style> -- Gitblit v1.8.0