From 02aa50f23d4858798a951bef1cfe2bc23031a4b1 Mon Sep 17 00:00:00 2001 From: 龚焕茏 <2842157468@qq.com> Date: 星期五, 26 四月 2024 16:11:46 +0800 Subject: [PATCH] 合同导入新增金额规则 --- src/views/system/contract/index.vue | 153 ++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 122 insertions(+), 31 deletions(-) diff --git a/src/views/system/contract/index.vue b/src/views/system/contract/index.vue index 0521346..d495071 100644 --- a/src/views/system/contract/index.vue +++ b/src/views/system/contract/index.vue @@ -2,7 +2,7 @@ <div class="app-container"> <el-row> - <el-col :span="8" v-for="(item) in contractList" :key="item" style="margin: 10px;width: 30%;"> + <el-col :span="8" v-for="(item, index) in contractList" :key="index" 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']" @@ -30,7 +30,7 @@ <!-- 鍚堝悓璇︽儏 --> <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 v-model="activeNames"> <el-collapse-item v-for="(item, index) in ruleData" :key="index" :title="item.ruleName" :name="index"> <div class="inline-input-container" v-for="(item, index) in item.children" :key="index"> <b>{{ item.ruleDesc }}</b> <br v-if="item.ruleDesc"/> @@ -52,35 +52,70 @@ </el-dialog> <!-- 鍚堝悓瀵煎叆瀵硅瘽妗� --> - <el-dialog :title="upload.title" :visible.sync="upload.open" width="550px" append-to-body> + <el-dialog :title="upload.title" :visible.sync="upload.open" width="1000px" append-to-body> <el-form ref="form" :model="upload" :rules="rules" label-width="80px"> - <el-form-item label="鍚堝悓鍚嶇О" prop="name"> - <el-input v-model="upload.name" /> - </el-form-item> - <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 + '&name=' + upload.name" - :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> + <el-divider content-position="left">鍚堝悓淇℃伅</el-divider> + <div class="row-warp"> + <div class="row"> + <div class="row-left"> + <div class="block"> + <el-form-item label="鍚堝悓鍚嶇О" prop="name"> + <el-input v-model="upload.name" /> + </el-form-item> + <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> + </div> + </div> + <div class="row-right" style="margin-left: 80px;"> + <div class="margin-5"> + <el-upload ref="upload" :limit="1" accept=".xlsx, .xls" :headers="upload.headers" + :action="upload.url + '?unitId=' + upload.unitId + '&startTime=' + upload.startTime + '&endTime=' + upload.endTime + '&name=' + upload.name" + :disabled="upload.isUploading" :on-progress="handleFileUploadProgress" :on-success="handleFileSuccess" + :file-list="upload.fileList" + :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> + </div> + </div> + </div> </div> - </el-upload> + <el-divider content-position="left">鑰冩牳缁撴灉搴旂敤瑙勫垯</el-divider> + <div class="row-warp"> + <div class="row" v-for="(item, index) in upload.ruleList" :key="index"> + <div class="row-left" style="flex: 0.7;"> + <div class="block"> + <el-form-item label="鑰冩牳鏉′欢" prop="ruleList"> + <el-input v-model="item.scoreCondition" style="width: 250px;" /> + </el-form-item> + </div> + </div> + <div class="row-right"> + <div class="margin-5"> + <el-form-item label="瑙勫垯鎻忚堪" prop="ruleList"> + <el-input type="textarea" v-model="item.description" style="width: 300px;" /> + <el-button style="margin-left: 50px;" type="danger" icon="el-icon-delete" circle @click="deleteRule(index)"></el-button> + </el-form-item> + </div> + </div> + </div> + </div> + <el-button style="margin-left: 50px;" type="success" icon="el-icon-plus" circle @click="addRule"></el-button> </el-form> <div slot="footer" class="dialog-footer"> @@ -93,7 +128,7 @@ </template> <script> -import { listContract, getContract, updateContract } from "@/api/platform/contract"; +import { listContract, getContract, updateContract, addContract } from "@/api/platform/contract"; import { getRuleListByContractId } from "../../../api/platform/calculate-rule"; import { unitSelect } from "../../../api/platform/unit"; import { deptSelect } from "../../../api/system/dept"; @@ -116,6 +151,8 @@ headers: { Authorization: "Bearer " + getToken() }, // 涓婁紶鐨勫湴鍧� url: process.env.VUE_APP_BASE_API + "/system/contract/importData", + ruleList: [], + fileList: [], unitId: '', startTime: '', endTime: '' @@ -167,6 +204,9 @@ ], timezone: [ { type: "array", required: true, message: "鍚堝悓鏃堕棿涓嶈兘涓虹┖", trigger: "change" } + ], + ruleList: [ + { type: "array", required: true, message: "鑰冩牳缁撴灉搴旂敤瑙勫垯涓嶈兘涓虹┖", trigger: "submit" } ] } }; @@ -177,6 +217,15 @@ this.selectDept(); }, methods: { + addRule() { + this.upload.ruleList.push({ + scoreCondition: '', + description: '' + }); + }, + deleteRule(index) { + this.upload.ruleList.splice(index, 1); + }, submitForm() { updateContract(this.form).then(response => { this.detail = false; @@ -218,7 +267,14 @@ let that = this; this.$refs["form"].validate(valid => { if (valid) { - that.$refs.upload.submit(); + addContract(this.upload).then (response => { + if (response.code != 200) { + this.$message.error("鎿嶄綔澶辫触"); + } else { + this.$message.success("鎿嶄綔鎴愬姛"); + } + }); + // that.$refs.upload.submit(); } }) }, @@ -346,3 +402,38 @@ margin-top: 10px; } </style> +<style scoped> +.margin-5 { + margin-left: 5px; +} +.row-warp { + display: flex; + flex-direction: column; +} +.row { + display: flex; + flex-direction: row; + align-items: center; + justify-content: center; + margin: 5px 0; +} +.row-left { + flex: 1; + display: flex; + flex-direction: row; +} +.row-right { + flex: 1; + display: flex; + flex-direction: row; +} +</style> +<style> +.el-cascader-node { + max-width: 300px; +} +.el-divider--horizontal { + margin-top: 50px; + margin-bottom: 50px; +} +</style> -- Gitblit v1.8.0