From c7262ac9c1ac9f844f79b9193734c96644e3a165 Mon Sep 17 00:00:00 2001 From: yyb <995253665@qq.com> Date: 星期二, 22 七月 2025 15:45:53 +0800 Subject: [PATCH] 报工增加按人员或按组报工 --- pages/product/report/index.vue | 221 ++++++++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 176 insertions(+), 45 deletions(-) diff --git a/pages/product/report/index.vue b/pages/product/report/index.vue index 794a210..6b92297 100644 --- a/pages/product/report/index.vue +++ b/pages/product/report/index.vue @@ -74,20 +74,22 @@ <u-radio name="鎶曟枡">鎶曟枡</u-radio> </u-radio-group> </u-form-item> - <u-form-item label="宸ュ簭"> - <u-checkbox-group> - <u-checkbox - :name="item.name" - v-for="(item, index) in checkboxList" - :key="index" - v-model="item.value" - @change="changeCheckbox" - :disabled="subdisabled || item.disabled" - > - {{ item.name }} - </u-checkbox> - </u-checkbox-group> + <u-form-item label="绠�鍖栫墿鏂欐鏌�" prop="simplifyMaterials"> + <u-radio-group v-model="form.simplifyMaterials" :disabled="subdisabled || simplifyDisabled" @change="radioChange"> + <u-radio name="true">鏄�</u-radio> + <u-radio name="false">鍚�</u-radio> + </u-radio-group> + </u-form-item> + <u-form-item label="鎶ュ伐鏂瑰紡" prop="status"> + <u-radio-group v-model="form.status" :disabled="subdisabled" @change="handleReportTypeChange"> + <u-radio name="false">鎸夌彮缁勬姤宸�</u-radio> + <u-radio name="true">鎸変汉鍛樻姤宸�</u-radio> + </u-radio-group> </u-form-item> + <u-form-item label="浜哄憳鍚嶇О" :border-bottom="false" prop="Persons"> + <u-input v-model="form.Persons" type="select" placeholder="璇烽�夋嫨" + @click="openselectedPersons" :disabled="!canSelectPerson || subdisabled"/> + </u-form-item> <u-form-item label="浜у嚭鍒楄〃" :border-bottom="false"></u-form-item> </u-form> <view class="wrap"> @@ -199,6 +201,19 @@ </view> </view> </u-modal> + <u-modal v-model="personShowModal" title="" :show-cancel-button="true" :show-confirm-button="true" + @confirm="confirmSelection" @cancel="cancelSelection"> + <view class="popup-content"> + <view class="popup-header"> + <checkbox-group @change="checkboxChange"> + <label class="checkbox-item" v-for="(item, index) in selectedPersons" :key="index"> + <checkbox :value="item.staffId" :checked="item.checked" /> + <text class="label">{{ item.staffName }}</text> + </label> + </checkbox-group> + </view> + </view> + </u-modal> <scan></scan> </div> </template> @@ -215,19 +230,21 @@ }, data() { return { - checkboxList: [ - { - name: "宸ュ簭鐨勮嚜鍔ㄦ姤鍛�", - value: false, - disabled: false, - }, - { - name: "绠�鍖栫墿鏂欐鏌�", - value: false, - disabled: false, - }, - ], + simplifyDisabled:false, + // checkboxList: [ + // { + // name: "宸ュ簭鐨勮嚜鍔ㄦ姤鍛�", + // value: false, + // disabled: false, + // }, + // { + // name: "绠�鍖栫墿鏂欐鏌�", + // value: false, + // disabled: false, + // }, + // ], InventoryReceiptList: [], + selectedPersons: [], form: { workstationId: "", work: "", @@ -242,9 +259,15 @@ productType: "dep", receive: "mo", materialCost: "", - autoReport: false, - simplifyMaterials: false, + // autoReport: false, + simplifyMaterials: 'false', + status: 'false', + Persons: '', + productStaffIds: [], + productStaffs:[] }, + personList: [], + canSelectPerson: false, rules: { work: [ { @@ -288,6 +311,20 @@ trigger: ["change"], }, ], + status: [ + { + required: true, + message: "璇烽�夋嫨鎶ュ伐鏂瑰紡", + trigger: ["change"], + }, + ], + Persons: [ + { + required: true, + message: "璇烽�夋嫨浜哄憳", + trigger: ["change"], + }, + ], }, showSave: false, operationTaskId: "", @@ -295,6 +332,8 @@ codeInfoId: "", detailedList: {}, showModal: false, + personShowModal: false, + checkboxList: [], }; }, // 鐐瑰嚮鎻愪氦鎸夐挳鐨勪簨浠跺鐞嗗嚱鏁� @@ -331,8 +370,8 @@ //鎵爜鎴愬姛鍚庣殑鍥炶皟锛屼綘鍙互鍐欒嚜宸辩殑閫昏緫浠g爜鍦ㄨ繖閲� if (data.code) { let codeInfo = JSON.parse(data.code); - that.codeInfoId = codeInfo.id; if (codeInfo.moOn) { + that.codeInfoId = codeInfo.id; // 鎵弿鎶ュ伐鍗曚簩缁寸爜 that.saveForm(codeInfo); that.getHandelList(); @@ -347,11 +386,72 @@ watch: { "form.taskNo": function (newVal, oldVal) { this.subdisabled = false; - this.checkboxList[1].value = false; - this.checkboxList[0].value = false; }, + 'form.status'(newVal) { + this.selectedPersons = this.selectedPersons.map(item => ({ + ...item, + checked: newVal === 'false' + })); + } }, methods: { + // 澶勭悊鎶ュ伐鏂瑰紡鍙樻洿 + handleReportTypeChange() { + // 鍒囨崲鎶ュ伐鏂瑰紡鏃舵竻绌轰汉鍛樺悕绉� + this.form.Persons = ''; + this.form.productStaffs = []; + this.form.productStaffIds = []; + }, + // 浜哄憳鍚嶇О + openselectedPersons() { + this.personShowModal = true; + }, + // 澶嶉�夋鍙樺寲浜嬩欢 + checkboxChange(e) { + console.log('e',e) + const values = e.target.value || []; + if (this.form.status === 'true') { + // 鍗曢�夋ā寮忥紝鍙厑璁搁�夋嫨涓�涓汉 + const previouslySelected = this.selectedPersons.find(item => item.checked); + const newlySelected = values.length > 0 ? values[values.length - 1] : null; + if (previouslySelected && newlySelected && previouslySelected.staffId !== newlySelected) { + // 宸叉湁閫変腑椤逛笖閫夋嫨浜嗘柊鐨勯」锛屾彁绀哄彧鑳介�夋嫨涓�涓汉 + this.$u.toast('鎸変汉鍛樻姤宸ユ椂鍙兘閫夋嫨涓�浣嶄汉鍛�'); + // 淇濇寔鍘熼�夋嫨 + this.selectedPersons = this.selectedPersons.map(item => ({ + ...item, + checked: item.staffId === previouslySelected.staffId + })); + + } else { + // 棣栨閫夋嫨鎴栧彇娑堥�夋嫨 + this.selectedPersons = this.selectedPersons.map(item => ({ + ...item, + checked: newlySelected ? item.staffId === newlySelected : false + })); + + } + } else { + // 澶氶�夋ā寮� + this.selectedPersons = this.selectedPersons.map(item => ({ + ...item, + checked: values.includes(item.staffId) + })); + } + }, + // 纭閫夋嫨 + confirmSelection() { + const selected = this.selectedPersons.filter(item => item.checked); + // 鏍规嵁鎶ュ伐鏂瑰紡璁剧疆浜哄憳鍚嶇О + if (this.form.status === 'true' && selected.length > 0) { + this.form.Persons = selected[0].staffName; + } else { + this.form.Persons = selected.map(item => item.staffName).join(','); + } + this.form.productStaffs = selected.map(item => item.staffNo); + this.form.productStaffIds = selected.map(item => item.staffId); + }, + cancelSelection(){}, // 閾滄潌鎶ュ伐 CopperReportingWork(val) { const copperList = {}; @@ -359,10 +459,14 @@ copperList.partNo = val.PN copperList.weighingClerk = val.WC copperList.executiveStandard = val.ES - copperList.netWeitht = val.NW + copperList.netWeight = val.NW copperList.specificationType = val.ST copperList.grossWeight = val.TR copperList.operationTaskId = this.form.id + copperList.status = this.form.status; + copperList.Persons = this.form.Persons; + copperList.productStaffIds = this.form.productStaffIds; + copperList.productStaffs = this.form.productStaffs; this.form.productOutputList = []; this.form.operationTaskId = this.form.id; this.form.productOutputList.push(copperList); @@ -374,6 +478,29 @@ }); }, // 鐐瑰嚮纭鍚庤幏鍙栧彇娑堟姤宸ヨ褰� + radioChange() { + // 澶勭悊鍗曢�夋鍙樺寲浜嬩欢 + }, + // 鑾峰彇浜哄憳鍒楄〃 + getPersonList(dutyId) { + console.log('111111') + try { + this.$u.api.workReporting.getPersonByDutyRecordId({ id: dutyId }).then((res) => { + this.selectedPersons = res.data.map(item => ({ + ...item, + checked: this.form.status === 'false' + })); + }) + .catch(err => { + console.log(err) + }) + } catch (err) { + console.log(err) + + } + + }, + confirmModle() { console.log("鐐瑰嚮纭鍚庤幏鍙栧彇娑堟姤宸ヨ褰�"); // 澶勭悊纭閫昏緫 @@ -419,14 +546,14 @@ }); }, // 澶氶�夊鐞� - changeCheckbox(val) { - if (val.name === "宸ュ簭鐨勮嚜鍔ㄦ姤鍛�") { - this.form.autoReport = val.value; - } - if (val.name === "绠�鍖栫墿鏂欐鏌�") { - this.form.simplifyMaterials = val.value; - } - }, + // changeCheckbox(val) { + // if (val.name === "宸ュ簭鐨勮嚜鍔ㄦ姤鍛�") { + // this.form.autoReport = val.value; + // } + // if (val.name === "绠�鍖栫墿鏂欐鏌�") { + // this.form.simplifyMaterials = val.value; + // } + // }, handleUpdate() { this.subdisabled = true; this.getHandelList(); @@ -469,15 +596,19 @@ Jianqtyfinished: val.qtyRequired - val.qtyFinished, proposedLocation: val.proposedLocation, productType: "dep", - receive: "mo", // 澶嶉�夋缁勭殑鍊� + receive: "mo", materialCost: val.materialCost, - autoReport: false, - simplifyMaterials: false, + // autoReport: false, + simplifyMaterials: 'false', + status: 'false', + Persons:'', }; - this.checkboxList[1].value = false; - this.checkboxList[0].value = false; if (this.form.materialCost == "鍊掑啿") { - this.checkboxList[1].disabled = true; + this.simplifyDisabled = true; + } + // 濡傛灉鏈塪utyNo锛岃幏鍙栦汉鍛樺垪琛� + if (val.dutyId) { + this.getPersonList(val.dutyId); } }, }, -- Gitblit v1.9.3