From d83860d6839daaf7dccda5cbd68e865ba7e679ab Mon Sep 17 00:00:00 2001 From: maven <2163098428@qq.com> Date: 星期二, 08 七月 2025 17:48:56 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/dev' into dev --- src/views/collaborativeApproval/approvalProcess/components/infoFormDia.vue | 261 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 261 insertions(+), 0 deletions(-) diff --git a/src/views/collaborativeApproval/approvalProcess/components/infoFormDia.vue b/src/views/collaborativeApproval/approvalProcess/components/infoFormDia.vue new file mode 100644 index 0000000..94155b6 --- /dev/null +++ b/src/views/collaborativeApproval/approvalProcess/components/infoFormDia.vue @@ -0,0 +1,261 @@ +<template> + <div> + <el-dialog + v-model="dialogFormVisible" + :title="operationType === 'add' ? '鏂板瀹℃壒娴佺▼' : '缂栬緫瀹℃壒娴佺▼'" + width="50%" + @close="closeDia" + > + <el-form :model="form" label-width="140px" label-position="top" :rules="rules" ref="formRef"> + <el-row> + <el-col :span="24"> + <el-form-item label="娴佺▼缂栧彿锛�" prop="supplier"> + <el-input v-model="form.model" placeholder="鑷姩缂栧彿" clearable disabled/> + </el-form-item> + </el-col> + </el-row> + <el-row> + <el-col :span="24"> + <el-form-item label="鐢宠閮ㄩ棬锛�" prop="productId"> + <el-tree-select + v-model="form.productId" + placeholder="璇烽�夋嫨" + clearable + check-strictly + @change="getModels" + :data="productOptions" + :render-after-expand="false" + style="width: 100%" + /> + </el-form-item> + </el-col> + </el-row> + <el-row> + <el-col :span="24"> + <el-form-item label="瀹℃壒浜嬬敱锛�" prop="model"> + <el-input v-model="form.model" placeholder="璇疯緭鍏�" clearable type="textarea" /> + </el-form-item> + </el-col> + </el-row> + <!-- 瀹℃壒浜洪�夋嫨锛堝姩鎬佽妭鐐癸級 --> + <el-row> + <el-col :span="24"> + <el-form-item> + <template #label> + <span>瀹℃壒浜洪�夋嫨锛�</span> + <el-button type="primary" @click="addApproverNode" style="margin-left: 8px;">鏂板鑺傜偣</el-button> + </template> + <div style="display: flex; align-items: flex-end; flex-wrap: wrap;"> + <div + v-for="(node, index) in approverNodes" + :key="node.id" + style="margin-right: 30px; text-align: center; margin-bottom: 10px;" + > + <div>鑺傜偣{{ index + 1 }} 鈫�</div> + <el-select + v-model="node.userId" + placeholder="閫夋嫨浜哄憳" + style="width: 120px; margin-bottom: 8px;" + > + <el-option + v-for="user in userList" + :key="user.id" + :label="user.name" + :value="user.id" + /> + </el-select> + <div> + <el-button + type="danger" + size="small" + @click="removeApproverNode(index)" + v-if="approverNodes.length > 1" + >鍒犻櫎</el-button> + </div> + </div> + </div> + </el-form-item> + </el-col> + </el-row> + <el-row :gutter="30"> + <el-col :span="12"> + <el-form-item label="鐢宠浜猴細" prop="checkName"> + <el-input v-model="form.checkName" placeholder="璇疯緭鍏�" clearable/> + </el-form-item> + </el-col> + <el-col :span="12"> + <el-form-item label="鐢宠鏃ユ湡锛�" prop="checkTime"> + <el-date-picker + v-model="form.checkTime" + type="date" + placeholder="璇烽�夋嫨鏃ユ湡" + value-format="YYYY-MM-DD" + format="YYYY-MM-DD" + clearable + style="width: 100%" + /> + </el-form-item> + </el-col> + </el-row> + </el-form> + <template #footer> + <div class="dialog-footer"> + <el-button type="primary" @click="submitForm">纭</el-button> + <el-button @click="closeDia">鍙栨秷</el-button> + </div> + </template> + </el-dialog> + </div> +</template> + +<script setup> +import {ref, reactive, toRefs, getCurrentInstance} from "vue"; +import {getOptions} from "@/api/procurementManagement/procurementLedger.js"; +import {productTreeList} from "@/api/basicData/product.js"; +import {qualityInspectAdd, qualityInspectUpdate} from "@/api/qualityManagement/rawMaterialInspection.js"; +const { proxy } = getCurrentInstance() +const emit = defineEmits(['close']) + +const dialogFormVisible = ref(false); +const operationType = ref('') +const data = reactive({ + form: { + checkTime: "", + supplier: "", + checkName: "", + productName: "", + productId: "", + model: "", + unit: "", + quantity: "", + checkCompany: "", + checkResult: "", + approverList: [] // 鏂板瀛楁锛屽瓨鍌ㄦ墍鏈夎妭鐐圭殑瀹℃壒浜篿d + }, + rules: { + checkTime: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" },], + supplier: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }], + checkName: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" }], + productId: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }], + model: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" }], + unit: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" }], + quantity: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }], + checkCompany: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" }], + checkResult: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" }], + }, +}); +const { form, rules } = toRefs(data); +const supplierList = ref([]); +const productOptions = ref([]); + +// 瀹℃壒浜鸿妭鐐圭浉鍏� +const approverNodes = ref([ + { id: 1, userId: null } +]) +let nextApproverId = 2 +const userList = ref([ + { id: 1, name: '寮犱笁' }, + { id: 2, name: '鏉庡洓' }, + { id: 3, name: '鐜嬩簲' } +]) +function addApproverNode() { + approverNodes.value.push({ id: nextApproverId++, userId: null }) +} +function removeApproverNode(index) { + approverNodes.value.splice(index, 1) +} + +// 鎵撳紑寮规 +const openDialog = (type, row) => { + operationType.value = type; + dialogFormVisible.value = true; + getOptions().then((res) => { + supplierList.value = res.data; + }); + getProductOptions(); + if (operationType.value === 'edit') { + form.value = {...row} + // 鍥炴樉瀹℃壒浜鸿妭鐐� + if (row.approverList && Array.isArray(row.approverList) && row.approverList.length > 0) { + approverNodes.value = row.approverList.map((userId, idx) => ({ id: idx + 1, userId })) + nextApproverId = row.approverList.length + 1 + } else { + approverNodes.value = [{ id: 1, userId: null }] + nextApproverId = 2 + } + } else { + approverNodes.value = [{ id: 1, userId: null }] + nextApproverId = 2 + } +} +const getProductOptions = () => { + productTreeList().then((res) => { + productOptions.value = convertIdToValue(res); + }); +}; +const getModels = (value) => { + form.value.productName = findNodeById(productOptions.value, value); +}; +const findNodeById = (nodes, productId) => { + for (let i = 0; i < nodes.length; i++) { + if (nodes[i].value === productId) { + return nodes[i].label; // 鎵惧埌鑺傜偣锛岃繑鍥炶鑺傜偣 + } + if (nodes[i].children && nodes[i].children.length > 0) { + const foundNode = findNodeById(nodes[i].children, productId); + if (foundNode) { + return foundNode; // 鍦ㄥ瓙鑺傜偣涓壘鍒帮紝杩斿洖璇ヨ妭鐐� + } + } + } + return null; // 娌℃湁鎵惧埌鑺傜偣锛岃繑鍥瀗ull +}; +function convertIdToValue(data) { + return data.map((item) => { + const { id, children, ...rest } = item; + const newItem = { + ...rest, + value: id, // 灏� id 鏀逛负 value + }; + if (children && children.length > 0) { + newItem.children = convertIdToValue(children); + } + + return newItem; + }); +} +// 鎻愪氦浜у搧琛ㄥ崟 +const submitForm = () => { + // 鏀堕泦鎵�鏈夎妭鐐圭殑瀹℃壒浜篿d + form.value.approverList = approverNodes.value.map(node => node.userId) + proxy.$refs.formRef.validate(valid => { + if (valid) { + form.value.inspectType = 0 + if (operationType.value === "add") { + qualityInspectAdd(form.value).then(res => { + proxy.$modal.msgSuccess("鎻愪氦鎴愬姛"); + closeDia(); + }) + } else { + qualityInspectUpdate(form.value).then(res => { + proxy.$modal.msgSuccess("鎻愪氦鎴愬姛"); + closeDia(); + }) + } + } + }) +} +// 鍏抽棴寮规 +const closeDia = () => { + proxy.resetForm("formRef"); + dialogFormVisible.value = false; + emit('close') +}; +defineExpose({ + openDialog, +}); +</script> + +<style scoped> + +</style> \ No newline at end of file -- Gitblit v1.9.3