From fd4b0088dc54e56c64c1995d6554f12d218c8473 Mon Sep 17 00:00:00 2001 From: lb Date: Mon, 18 Dec 2023 14:25:08 +0800 Subject: [PATCH] =?UTF-8?q?update=20=E7=89=B9=E6=AE=8A=E8=AE=BE=E5=A4=87?= =?UTF-8?q?=E4=BF=9D=E5=85=BB?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../specialEquipment/maintain/Record--add.vue | 350 ++++++++++++------ .../specialEquipment/maintain/Record.vue | 31 +- 2 files changed, 264 insertions(+), 117 deletions(-) diff --git a/src/views/specialEquipment/maintain/Record--add.vue b/src/views/specialEquipment/maintain/Record--add.vue index 72b53ee6..8843b623 100644 --- a/src/views/specialEquipment/maintain/Record--add.vue +++ b/src/views/specialEquipment/maintain/Record--add.vue @@ -9,12 +9,59 @@ - + + + + + + + + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + @@ -209,11 +217,7 @@ icon="el-icon-upload2" :disabled="disabled" :before-upload="beforeUpload" - :on-success=" - (response, file, fileList) => { - handleUploadSuccess(response, file, col.prop); - } - "> + :on-success="handleUploadSuccess">
+ @input="handleEditorInput" />
@@ -269,6 +275,68 @@ import { getAccessToken } from '@/utils/auth'; import Editor from '@/components/Editor'; +import tupleImg from '@/assets/images/tuple.png'; +const uploadedFile = { + name: 'UploadedFile', + props: ['file', 'disabled'], + data() { + return {}; + }, + methods: { + handleDelete() { + this.$emit('delete', this.file); + }, + async handleDownload() { + const data = await this.$axios({ + url: this.file.fileUrl, + method: 'get', + responseType: 'blob', + }); + + await this.$message.success('开始下载'); + // create download link + const url = window.URL.createObjectURL(data); + const link = document.createElement('a'); + link.href = url; + link.download = this.file.fileName; + document.body.appendChild(link); + link.click(); + document.body.removeChild(link); + }, + }, + mounted() {}, + render: function (h) { + return ( +
+ {this.file.fileName} + {!this.disabled && ( + + )} +
+ ); + }, +}; + export default { name: 'DialogForm', model: { @@ -276,7 +344,7 @@ export default { event: 'update', }, emits: ['update'], - components: { Editor }, + components: { Editor, uploadedFile }, props: { dataForm: { type: Object, @@ -286,6 +354,10 @@ export default { type: Boolean, default: false, }, + labelPosition: { + type: String, + default: 'top', + }, }, data() { return { @@ -301,6 +373,8 @@ export default { { label: '消防设备', value: 2 }, { label: '特种设备', value: 3 }, ], + workerOptions: [], + planOptions: [], uploadHeaders: { Authorization: 'Bearer ' + getAccessToken() }, uploadUrl: process.env.VUE_APP_BASE_API + '/admin-api/infra/file/upload', // 上传有关的headers,url都是固定的 }; @@ -335,7 +409,6 @@ export default { }, mounted() { this.initOptions(); - this.getEquipmentList(); this.getCode('/base/equipment-maintain-plan/getCode'); }, methods: { @@ -361,12 +434,12 @@ export default { this.initPlan(); }, - async initEquipment() { + async initEquipment(type = 'special-equipment') { this.formLoading = true; const response = await this.$axios('/base/core-equipment/listAll'); this.equipmentList = response.data || []; const equipmentOptions = (response.data || []) - .filter((item) => item.special) + .filter((item) => (type == 'special-equipment' ? item.special : true)) .map((item) => ({ label: item.name, value: item.id, @@ -376,9 +449,30 @@ export default { this.formLoading = false; }, - async initWorker() {}, + async initWorker() { + this.formLoading = true; + const response = await this.$axios({ + url: '/base/core-worker/listAll', + }); + this.workerOptions = (response.data || []).map((item) => ({ + label: item.name, + value: item.id, + })); + this.formLoading = false; + }, - async initPlan() {}, + async initPlan() { + this.formLoading = true; + const response = await this.$axios({ + url: '/base/equipment-maintain-plan/page', + params: { pageNo: 1, pageSize: 100, speical: true }, + }); + this.planOptions = (response.data?.list || []).map((item) => ({ + label: item.name, + value: item.id, + })); + this.formLoading = false; + }, // handlers handleEqTypeChange(type) { @@ -396,12 +490,40 @@ export default { // this.$emit('update', this.form) }, + handleEqChange() { + this.$emit('update', this.form); + }, + + // 修改 是否计划保养 时 + handlePlanChange(val) { + console.log('handlePlanChange', val); + this.form.equipmentCategory = null; + this.form.equipmentId = null; + this.$emit('update', { ...this.form, relatePlan: val }); + this.initEquipment(val == 1 ? 'special-equipment' : null); + }, + + handleEditorInput(html) { + this.$emit('update', { + ...this.form, + maintenanceDes: html, + }); + }, + // upload handleFilesOpen() {}, beforeUpload() {}, - handleUploadSuccess() {}, + handleUploadSuccess(response, file) { + this.$modal.msgSuccess('上传成功'); + console.log('file', file); + this.form.files.push({ + fileName: file.name, + fileUrl: response.data, + }); + this.$emit('update', this.form); + }, handleDeleteFile(file) {}, }, @@ -424,7 +546,7 @@ export default { position: relative; overflow: hidden; transition: height 0.3s ease-out; - margin-top: 40px; + // margin-top: 40px; } .upload-in-dialog { @@ -460,4 +582,10 @@ export default { .height-48 { height: 35px !important; } + +:deep(.record-add__editor) { + .ql-picker-label { + display: flex; + } +} diff --git a/src/views/specialEquipment/maintain/Record.vue b/src/views/specialEquipment/maintain/Record.vue index 1d88c4e4..3d18b73e 100644 --- a/src/views/specialEquipment/maintain/Record.vue +++ b/src/views/specialEquipment/maintain/Record.vue @@ -519,7 +519,7 @@ export default { relatePlan: null, maintainPlanId: null, equipmentId: null, - maintainWorker: null, + maintainWorker: [], maintainOrderNumber: null, startTime: null, endTime: null, @@ -582,10 +582,12 @@ export default { if (!valid) { return; } - this.form.maintainWorker = this.form.maintainWorker.join(','); // 修改的提交 if (this.form.id != null) { - this.put(this.form).then((response) => { + this.put({ + ...this.form, + maintainWorker: this.form.maintainWorker.join(','), + }).then((response) => { this.$modal.msgSuccess('修改成功'); this.open = false; this.getList(); @@ -593,10 +595,27 @@ export default { return; } // 添加的提交 - this.post(this.form).then((response) => { + this.post({ + ...this.form, + maintainWorker: this.form.maintainWorker.join(','), + }).then((response) => { this.$modal.msgSuccess('新增成功'); - this.open = false; - this.getList(); + + // 跳转至 备品备件 保养 + const toSparePartsMaintain = () => { + this.open = false; + // 没有备品备件保养模块。。。 + }; + + this.$confirm('是否有备品备件更换?', '提示', { + confirmButtonText: '有', + cancelButtonText: '没有', + }) + .then(toSparePartsMaintain) + .catch(() => { + this.open = false; + this.getList(); + }); }); }); },