| | |
| | | dataIndex: 'requestCode' |
| | | }, |
| | | { |
| | | title: 'å·¥åID', |
| | | title: 'ä»»å¡å·', |
| | | align: 'center', |
| | | dataIndex: 'workOrderId' |
| | | dataIndex: 'workOrderId_dictText' |
| | | }, |
| | | { |
| | | title: 'SAPé¢çå·', |
| | | align: 'center', |
| | | dataIndex: 'reservationCode' |
| | | }, |
| | | { |
| | | title: 'ç©æç¼ç ', |
| | | align: 'center', |
| | | dataIndex: 'materialNumber' |
| | | }, |
| | | { |
| | | title: 'ç©æåç§°', |
| | | align: 'center', |
| | | dataIndex: 'materialName' |
| | | }, |
| | | { |
| | | title: 'ç论æå¨æ°é', |
| | | align: 'center', |
| | | dataIndex: 'specifiedQuantity' |
| | | }, |
| | | { |
| | | title: 'å®é
æå¨æ°é', |
| | | align: 'center', |
| | | dataIndex: 'actualQuantity' |
| | | }, |
| | | { |
| | | title: 'åå¸ç¶æ', |
| | |
| | | { |
| | | title: 'ååºåå°', |
| | | align: 'center', |
| | | dataIndex: 'originalWarehouseId' |
| | | dataIndex: 'originalWarehouseId_dictText' |
| | | }, |
| | | { |
| | | title: 'ç®æ åºåå°', |
| | | align: 'center', |
| | | dataIndex: 'targetWarehouseId' |
| | | dataIndex: 'targetWarehouseId_dictText' |
| | | }, |
| | | { |
| | | title: 'ä¼å
çº§ï¼æå¨ç±»åï¼', |
| | | title: 'æå¨ç±»å', |
| | | align: 'center', |
| | | dataIndex: 'priority_dictText' |
| | | dataIndex: 'materialTransferCategory_dictText' |
| | | }, |
| | | { |
| | | title: 'ææé
éæ¶é´', |
| | |
| | | </a-form-model-item> |
| | | </a-col> |
| | | <a-col :span="12"> |
| | | <a-form-model-item label="èµ·å§åºåå°ç¹" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="originalWarehouseId"> |
| | | <j-dict-select-tag type="list" v-model="model.originalWarehouseId" dictCode="original_warehouse_list" placeholder="è¯·éæ©èµ·å§åºåå°ç¹" /> |
| | | <a-form-model-item label="èµ·å§åºåå°ç¹" :labelCol="labelCol" :wrapperCol="wrapperCol" |
| | | prop="originalWarehouseId"> |
| | | <j-dict-select-tag type="list" v-model="model.originalWarehouseId" dictCode="original_warehouse_list" |
| | | placeholder="è¯·éæ©èµ·å§åºåå°ç¹" /> |
| | | </a-form-model-item> |
| | | </a-col> |
| | | <a-col :span="12"> |
| | | <a-form-model-item label="ä»»å¡å·" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="workOrderId"> |
| | | <a-input v-model="model.workOrderId" placeholder="请è¾å
¥å·¥åID" ></a-input> |
| | | <a-form-model-item label="ä»»å¡å·" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="workOrderCode"> |
| | | <work-order-select-modal :workOrder="workOrderObj" :submitDisabled="formDisabled" |
| | | orderStatus="PUBLISHED" @ok="selectConfirm"></work-order-select-modal> |
| | | </a-form-model-item> |
| | | </a-col> |
| | | <a-col :span="12"> |
| | | <a-form-model-item label="ç®æ åºåå°ç¹" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="targetWarehouseId"> |
| | | <a-input v-model="model.targetWarehouseId" placeholder="èªå¨è·å" readOnly ></a-input> |
| | | <a-form-model-item label="ç®æ åºåå°ç¹" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="warehouseName"> |
| | | <a-input v-model="model.warehouseName" placeholder="èªå¨è·å" readOnly></a-input> |
| | | </a-form-model-item> |
| | | </a-col> |
| | | <a-col :span="12"> |
| | | <a-form-model-item label="æå¨ç±»å" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="materialTransferCategory"> |
| | | <j-dict-select-tag type="list" v-model="model.materialTransferCategory" dictCode="material_transfer_category" placeholder="è¯·éæ©æå¨ç±»å" /> |
| | | <a-form-model-item label="æå¨ç±»å" :labelCol="labelCol" :wrapperCol="wrapperCol" |
| | | prop="materialTransferCategory"> |
| | | <j-dict-select-tag type="list" v-model="model.materialTransferCategory" |
| | | dictCode="material_transfer_category" placeholder="è¯·éæ©æå¨ç±»å" /> |
| | | </a-form-model-item> |
| | | </a-col> |
| | | <a-col :span="12"> |
| | | <a-form-model-item label="ææé
éæ¶é´" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="latestDeliveryTime"> |
| | | <j-date placeholder="è¯·éæ©ææé
éæ¶é´" v-model="model.latestDeliveryTime" :show-time="false" date-format="YYYY-MM-DD" style="width: 100%" /> |
| | | <a-form-model-item label="ææé
éæ¶é´" :labelCol="labelCol" :wrapperCol="wrapperCol" |
| | | prop="latestDeliveryTime"> |
| | | <a-date-picker placeholder="è¯·éæ©ææé
éæ¶é´" v-model="model.latestDeliveryTime" |
| | | value-format="YYYY-MM-DD" style="width: 100%" /> |
| | | </a-form-model-item> |
| | | </a-col> |
| | | <a-col :span="12"> |
| | | <a-form-model-item label="æå¨ç©æ" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="materialNumber"> |
| | | <j-dict-select-tag type="list" v-model="model.materialNumber" dictCode="priority" placeholder="è¯·éæ©æå¨ç©æ" /> |
| | | <a-select v-model="model.materialNumber" placeholder="è¯·éæ©æå¨ç©æ" @change="handleMaterialNumberChange"> |
| | | <a-select-option v-for="item in materialList" :value="item.materialNumber" :title="item.materialName" :key="item.materialNumber"> |
| | | {{ item.materialName }} |
| | | </a-select-option> |
| | | </a-select> |
| | | </a-form-model-item> |
| | | </a-col> |
| | | <a-col :span="12"> |
| | |
| | | |
| | | <script> |
| | | |
| | | import { httpAction, getAction } from '@/api/manage' |
| | | import { validateDuplicateValue } from '@/utils/util' |
| | | import { getAction, httpAction } from '@/api/manage' |
| | | import WorkOrderSelectModal from '@/views/mes/modules/WorkOrderSelectModal.vue' |
| | | import moment from 'moment' |
| | | |
| | | export default { |
| | | name: 'MesMaterialTransferRequestForm', |
| | | components: { |
| | | export default { |
| | | name: 'MesMaterialTransferRequestForm', |
| | | components: { |
| | | WorkOrderSelectModal |
| | | }, |
| | | props: { |
| | | //表åç¦ç¨ |
| | | disabled: { |
| | | type: Boolean, |
| | | default: false, |
| | | required: false |
| | | } |
| | | }, |
| | | data() { |
| | | return { |
| | | model: {}, |
| | | labelCol: { |
| | | xs: { span: 24 }, |
| | | sm: { span: 6 } |
| | | }, |
| | | wrapperCol: { |
| | | xs: { span: 24 }, |
| | | sm: { span: 16 } |
| | | }, |
| | | confirmLoading: false, |
| | | validatorRules: { |
| | | originalWarehouseId: [ |
| | | { required: true, message: 'èµ·å§åºåå°ç¹å¿
é', trigger: 'change' } |
| | | ], |
| | | workOrderCode: [ |
| | | { required: true, message: 'ä»»å¡å·å¿
é', trigger: 'change' } |
| | | ], |
| | | materialNumber: [ |
| | | { required: true, message: 'æå¨ç©æå¿
é', trigger: 'change' } |
| | | ], |
| | | specifiedQuantity: [ |
| | | { required: true, message: 'æå¨æ°éå¿
å¡«', trigger: 'change' } |
| | | ], |
| | | materialTransferCategory: [ |
| | | { required: true, message: 'æå¨ç±»åå¿
é', trigger: 'change' } |
| | | ] |
| | | }, |
| | | url: { |
| | | add: '/mes/mesMaterialTransferRequest/add', |
| | | edit: '/mes/mesMaterialTransferRequest/edit', |
| | | queryById: '/mes/mesMaterialTransferRequest/queryById', |
| | | queryByMaterialNumber: '/pms/processBillMaterialsDetail/queryByMaterialNumber', |
| | | queryByFactoryId: '/base/lineSideWarehouse/queryByFactoryId', |
| | | workOrderQuery: '/mes/mesProductionWorkOrder/queryById' |
| | | }, |
| | | materialList: [], //ç©æå表 |
| | | workOrderObj: {}, //å·¥å对象 |
| | | } |
| | | }, |
| | | computed: { |
| | | formDisabled() { |
| | | return this.disabled |
| | | } |
| | | }, |
| | | created() { |
| | | //å¤ä»½modelåå§å¼ |
| | | this.modelDefault = JSON.parse(JSON.stringify(this.model)) |
| | | }, |
| | | methods: { |
| | | add() { |
| | | this.modelDefault.latestDeliveryTime = moment() |
| | | this.edit(this.modelDefault) |
| | | }, |
| | | props: { |
| | | //表åç¦ç¨ |
| | | disabled: { |
| | | type: Boolean, |
| | | default: false, |
| | | required: false |
| | | } |
| | | }, |
| | | data () { |
| | | return { |
| | | model:{ |
| | | }, |
| | | labelCol: { |
| | | xs: { span: 24 }, |
| | | sm: { span: 6 }, |
| | | }, |
| | | wrapperCol: { |
| | | xs: { span: 24 }, |
| | | sm: { span: 16 }, |
| | | }, |
| | | confirmLoading: false, |
| | | validatorRules: { |
| | | originalWarehouseId: [ |
| | | { required: true, message: 'èµ·å§åºåå°ç¹å¿
é', trigger: 'change' } |
| | | ], |
| | | workOrderId: [ |
| | | { required: true, message: 'ä»»å¡å·å¿
é', trigger: 'change' } |
| | | ], |
| | | materialNumber: [ |
| | | { required: true, message: 'æå¨ç©æå¿
é', trigger: 'change' } |
| | | ], |
| | | specifiedQuantity: [ |
| | | { required: true, message: 'æå¨æ°éå¿
å¡«', trigger: 'change' } |
| | | ], |
| | | materialTransferCategory: [ |
| | | { required: true, message: 'æå¨ç±»åå¿
é', trigger: 'change' } |
| | | ], |
| | | }, |
| | | url: { |
| | | add: "/mes/mesMaterialTransferRequest/add", |
| | | edit: "/mes/mesMaterialTransferRequest/edit", |
| | | queryById: "/mes/mesMaterialTransferRequest/queryById" |
| | | async edit(record) { |
| | | this.model = Object.assign({}, record) |
| | | this.model.workOrderCode = this.model.workOrderId_dictText |
| | | this.visible = true |
| | | if (this.model.workOrderId) { |
| | | let workOrderRes = await this.loadProductionWorkOrder(this.model.workOrderId) |
| | | if(!workOrderRes.success || !workOrderRes.result) { |
| | | return; |
| | | } |
| | | //æäº§å·¥åèµå¼ |
| | | this.workOrderObj = Object.assign({}, workOrderRes.result); |
| | | //ç©æå表 |
| | | let materialListRes = await this.loadMaterialList(workOrderRes.result.materialNumber) |
| | | if (materialListRes.success && materialListRes.result && materialListRes.result.length > 0) { |
| | | this.materialList = [...materialListRes.result] |
| | | } else { |
| | | this.materialList = [] |
| | | } |
| | | //ç®æ åºåå° |
| | | let warehouseRes = await this.loadLineWarehouse(workOrderRes.result.factoryId) |
| | | if (warehouseRes.success && warehouseRes.result) { |
| | | this.$set(this.model, 'targetWarehouseId', warehouseRes.result.id) |
| | | this.$set(this.model, 'warehouseName', warehouseRes.result.warehouseName) |
| | | } else { |
| | | this.model.targetWarehouseId = undefined |
| | | this.model.warehouseName = '' |
| | | } |
| | | } |
| | | }, |
| | | computed: { |
| | | formDisabled(){ |
| | | return this.disabled |
| | | }, |
| | | async selectConfirm(rows) { |
| | | if (rows && rows.length > 0) { |
| | | //æ¸
空å
³èæ°æ® |
| | | this.model.materialNumber = undefined; |
| | | this.model.materialName = ''; |
| | | this.model.specifiedQuantity = 0; |
| | | //èµå¼æ°çæ°æ® |
| | | this.model.workOrderId = rows[0].id |
| | | this.model.workOrderCode = rows[0].workOrderCode |
| | | //æäº§å·¥åèµå¼ |
| | | this.workOrderObj = Object.assign({}, rows[0]); |
| | | let materialListRes = await this.loadMaterialList(rows[0].materialNumber) |
| | | if (materialListRes.success && materialListRes.result && materialListRes.result.length > 0) { |
| | | this.materialList = [...materialListRes.result] |
| | | } else { |
| | | this.materialList = [] |
| | | } |
| | | let warehouseRes = await this.loadLineWarehouse(rows[0].factoryId) |
| | | if (warehouseRes.success && warehouseRes.result) { |
| | | this.$set(this.model, 'targetWarehouseId', warehouseRes.result.id) |
| | | this.$set(this.model, 'warehouseName', warehouseRes.result.warehouseName) |
| | | } else { |
| | | this.model.targetWarehouseId = undefined |
| | | this.model.warehouseName = '' |
| | | } |
| | | } else { |
| | | //æ¸
空å
³èæ°æ® |
| | | this.model.materialNumber = undefined; |
| | | this.model.materialName = ''; |
| | | this.model.specifiedQuantity = 0; |
| | | this.materialList = [] |
| | | this.model.targetWarehouseId = undefined |
| | | this.model.warehouseName = '' |
| | | this.workOrderObj = {}; |
| | | } |
| | | }, |
| | | created () { |
| | | //å¤ä»½modelåå§å¼ |
| | | this.modelDefault = JSON.parse(JSON.stringify(this.model)); |
| | | }, |
| | | methods: { |
| | | add () { |
| | | this.edit(this.modelDefault); |
| | | }, |
| | | edit (record) { |
| | | this.model = Object.assign({}, record); |
| | | this.visible = true; |
| | | }, |
| | | submitForm () { |
| | | const that = this; |
| | | // 触å表åéªè¯ |
| | | this.$refs.form.validate(valid => { |
| | | if (valid) { |
| | | that.confirmLoading = true; |
| | | let httpurl = ''; |
| | | let method = ''; |
| | | if(!this.model.id){ |
| | | httpurl+=this.url.add; |
| | | method = 'post'; |
| | | }else{ |
| | | httpurl+=this.url.edit; |
| | | method = 'put'; |
| | | } |
| | | httpAction(httpurl,this.model,method).then((res)=>{ |
| | | if(res.success){ |
| | | that.$message.success(res.message); |
| | | that.$emit('ok'); |
| | | }else{ |
| | | that.$message.warning(res.message); |
| | | } |
| | | }).finally(() => { |
| | | that.confirmLoading = false; |
| | | }) |
| | | submitForm() { |
| | | const that = this |
| | | // 触å表åéªè¯ |
| | | this.$refs.form.validate(valid => { |
| | | if (valid) { |
| | | that.confirmLoading = true |
| | | let httpurl = '' |
| | | let method = '' |
| | | if (!this.model.id) { |
| | | httpurl += this.url.add |
| | | method = 'post' |
| | | } else { |
| | | httpurl += this.url.edit |
| | | method = 'put' |
| | | } |
| | | httpAction(httpurl, this.model, method).then((res) => { |
| | | if (res.success) { |
| | | that.$message.success(res.message) |
| | | that.$emit('ok') |
| | | } else { |
| | | that.$message.warning(res.message) |
| | | } |
| | | }).finally(() => { |
| | | that.confirmLoading = false |
| | | }) |
| | | } |
| | | |
| | | }) |
| | | }, |
| | | }) |
| | | }, |
| | | loadMaterialList(materialNumber) { |
| | | return getAction(this.url.queryByMaterialNumber, { materialNumber: materialNumber }) |
| | | }, |
| | | loadLineWarehouse(factoryId) { |
| | | return getAction(this.url.queryByFactoryId, { factoryId: factoryId }) |
| | | }, |
| | | loadProductionWorkOrder(workOrderId) { |
| | | return getAction(this.url.workOrderQuery, { id: workOrderId }) |
| | | }, |
| | | handleMaterialNumberChange(val) { |
| | | let find = this.materialList.find(item => item.materialNumber === val) |
| | | if (find) { |
| | | this.model.materialName = find.materialName |
| | | } |
| | | this.model.specifiedQuantity = 0 |
| | | } |
| | | } |
| | | } |
| | | </script> |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <template> |
| | | <div> |
| | | <!----> |
| | | <a-input @click="openModal" placeholder="è¯·éæ©ä»»å¡å·" v-model="textVals" readOnly :disabled="submitDisabled"> |
| | | <a-icon slot="prefix" type="cluster" title="æäº§å·¥åéæ©"/> |
| | | <a-icon v-if="storeVals" slot="suffix" type="close-circle" @click="handleEmpty" title="æ¸
空"/> |
| | | </a-input> |
| | | <a-modal |
| | | title="å·¥åéæ©" |
| | | :width="1000" |
| | | :visible="visible" |
| | | :confirmLoading="confirmLoading" |
| | | @ok="handleSubmit" |
| | | @cancel="handleCancel"> |
| | | <a-table |
| | | ref="table" |
| | | bordered |
| | | size="middle" |
| | | rowKey="id" |
| | | :columns="columns" |
| | | :dataSource="dataSource" |
| | | :pagination="ipagination" |
| | | :loading="loading" |
| | | @change="handleTableChange" |
| | | :customRow="customTableRow" |
| | | :rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange, type: 'radio'}"></a-table> |
| | | </a-modal> |
| | | </div> |
| | | |
| | | </template> |
| | | |
| | | <script> |
| | | import { JeecgListMixin } from '@/mixins/JeecgListMixin' |
| | | |
| | | export default { |
| | | name: "WorkOrderSelectModal", |
| | | mixins: [JeecgListMixin], |
| | | props: { |
| | | orderStatus: { |
| | | type: String, |
| | | default: 'null', //å¦ææ²¡æä¼ å¼åæ¥ä¸å°æ°æ® |
| | | }, |
| | | submitDisabled: { |
| | | type: Boolean, |
| | | default: false, |
| | | }, |
| | | workOrder: { |
| | | type: Object, |
| | | default: undefined, |
| | | } |
| | | }, |
| | | watch: { |
| | | workOrder: { |
| | | immediate: true, |
| | | handler(val) { |
| | | this.textVals = val.workOrderCode |
| | | this.storeVals = val |
| | | } |
| | | } |
| | | }, |
| | | data() { |
| | | return { |
| | | title: "æä½", |
| | | visible: false, |
| | | model: {}, |
| | | confirmLoading: false, |
| | | storeVals: undefined, //[key values] |
| | | textVals: this.value, //[label values] |
| | | queryParam: { |
| | | workOrderStatus: this.orderStatus, |
| | | }, |
| | | url: { |
| | | list: "/mes/mesProductionWorkOrder/list" |
| | | }, |
| | | columns: [ |
| | | { |
| | | title: 'ä»»å¡å·', |
| | | align: "center", |
| | | dataIndex: 'workOrderCode', |
| | | fixed: 'left', |
| | | width: 200 |
| | | }, |
| | | { |
| | | title: 'ç©æç¼ç ', |
| | | align: "center", |
| | | dataIndex: 'materialNumber', |
| | | }, |
| | | { |
| | | title: 'ç©æåç§°', |
| | | align: "center", |
| | | dataIndex: 'materialName' |
| | | }, |
| | | { |
| | | title: '计åç产æ°é', |
| | | align: "center", |
| | | dataIndex: 'planQuantity' |
| | | }, |
| | | { |
| | | title: 'å·¥åç¶æ', |
| | | align: "center", |
| | | dataIndex: 'workOrderStatus_dictText' |
| | | }, |
| | | ] |
| | | } |
| | | }, |
| | | created() { |
| | | //å è½½æäº§å·¥åæ°æ® |
| | | this.queryParam.workOrderStatus = this.orderStatus; |
| | | }, |
| | | methods: { |
| | | openModal(){ |
| | | this.visible = true; |
| | | if(this.workOrder){ |
| | | this.textVals = this.workOrder.workOrderCode; |
| | | this.storeVals = this.workOrder; |
| | | this.selectedRowKeys = [this.workOrder.id]; |
| | | this.selectedRows = [this.workOrder] |
| | | }else { |
| | | this.selectedRowKeys = [] |
| | | this.selectedRows = [] |
| | | this.textVals = ''; |
| | | this.storeVals = undefined; |
| | | } |
| | | |
| | | }, |
| | | handleEmpty(){ |
| | | this.textVals = ''; |
| | | this.storeVals = undefined; |
| | | this.selectedRowKeys = [] |
| | | this.selectedRows = [] |
| | | this.$emit('ok', []); |
| | | }, |
| | | close() { |
| | | this.$emit('close'); |
| | | this.visible = false; |
| | | }, |
| | | /** |
| | | * èªå®ä¹è®¾å¤å°è´¦è¡¨æ ¼è¡ |
| | | * @param record è¡¨æ ¼è¡ä¿¡æ¯ |
| | | * @returns {{style: {cursor: string}, on: {click: *}}} æ ·å¼å¯¹è±¡ä¸äºä»¶æ¹æ³ |
| | | */ |
| | | customTableRow(record) { |
| | | return { |
| | | style: { |
| | | cursor: 'pointer' |
| | | }, |
| | | on: { |
| | | click: () => { |
| | | this.onSelectChange([record.id], [record]); |
| | | } |
| | | } |
| | | } |
| | | }, |
| | | handleCancel() { |
| | | this.close() |
| | | }, |
| | | handleSubmit() { |
| | | if(this.selectionRows && this.selectionRows.length === 1){ |
| | | this.textVals = this.selectionRows[0].workOrderCode; |
| | | this.storeVals = this.selectionRows[0]; |
| | | this.$emit('ok', this.selectionRows); |
| | | this.close() |
| | | }else { |
| | | that.$message.warning('è¯·éæ©ä¸æ¡è®°å½ï¼'); |
| | | } |
| | | }, |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <style> |
| | | |
| | | </style> |