Browse Source

修改出库实发数量

dev
caoyizhong 2 years ago
parent
commit
49c337941d
  1. 6
      src/components/jeecg/CEditableTable.vue
  2. 8
      src/views/activiti/form/ProcessMaterialsDelivery.vue
  3. 96
      src/views/activiti/form/ProcessMaterialsDeliveryForm.vue
  4. 25
      src/views/activiti/form/ProcessUdgetPlanForm.vue
  5. 9
      src/views/activiti/todoManage.vue
  6. 14
      src/views/system/UserList.vue

6
src/components/jeecg/CEditableTable.vue

@ -11,8 +11,8 @@
<a-col> <a-col>
<!-- 操作按钮 --> <!-- 操作按钮 -->
<div v-if="actionButton" class="action-button"> <div v-if="actionButton" class="action-button">
<a-button type="primary" icon="plus" @click="handleClickAdd" :disabled="disabled">新增</a-button> <a-button type="primary" icon="plus" @click="handleClickAdd" v-if="isabled" :disabled="isabled">新增</a-button>
<!-- <a-button type="primary" icon="plus" @click="handleClickAdd" v-else :disabled="!isabled">新增</a-button>--> <a-button type="primary" icon="plus" @click="handleClickAdd" v-else :disabled="isabled">新增</a-button>
<span class="gap"></span> <span class="gap"></span>
<template v-if="selectedRowIds.length>0"> <template v-if="selectedRowIds.length>0">
<a-popconfirm <a-popconfirm
@ -639,7 +639,7 @@
let rowHeight = 61 let rowHeight = 61
export default { export default {
name: 'PEditableTable', name: 'CEditableTable',
components: { JDate, Draggable, JInputPop, JFilePop }, components: { JDate, Draggable, JInputPop, JFilePop },
provide() { provide() {
return { return {

8
src/views/activiti/form/ProcessMaterialsDelivery.vue

@ -3,7 +3,7 @@
<a-tabs style="text-align: center;"> <a-tabs style="text-align: center;">
<a-tab-pane tab="流程正文" key="1" forceRender> <a-tab-pane tab="流程正文" key="1" forceRender>
<process-materials-delivery-form :dianshang="delivery" :isNew="isNew" :hieg="hieg" @delivery="showType" :processData="processData" :disabled="disabled" <process-materials-delivery-form :dianshang="delivery" :isNew="isNew" :hieg="hieg" @delivery="showType" :processData="processData" :disabled="disabled"
@afterSubmit="afterSub" @close="close" :task="task" @passTask="passTask" @afterSubmit="afterSub" @close="close" :task="task" @passTask="passTask" :actualNumber = "actualNumber"
@backTask="backTask" @loadData="loadData" :itemId="itemId"/> @backTask="backTask" @loadData="loadData" :itemId="itemId"/>
</a-tab-pane> </a-tab-pane>
<a-tab-pane tab="流程节点图" key="2" forceRender> <a-tab-pane tab="流程节点图" key="2" forceRender>
@ -59,6 +59,12 @@
default: '', default: '',
required: true required: true
}, },
//
actualNumber: {
type: Boolean,
default: true, //
required: false //
},
disabled: { disabled: {
type: Boolean, type: Boolean,
default: false, default: false,

96
src/views/activiti/form/ProcessMaterialsDeliveryForm.vue

@ -77,8 +77,8 @@
:columns="processMaterialsDeliveryListTable.columns" :columns="processMaterialsDeliveryListTable.columns"
:dataSource="processMaterialsDeliveryListTable.dataSource" :dataSource="processMaterialsDeliveryListTable.dataSource"
:maxHeight="300" :maxHeight="300"
:disabled="this.hiegs"
:verify="this.deliveryType" :verify="this.deliveryType"
:isabled="isabled"
:verify-type="this.accountingAttributesVal" :verify-type="this.accountingAttributesVal"
@valueChange="onSelect" @valueChange="onSelect"
:rowNumber="true" :rowNumber="true"
@ -160,6 +160,7 @@
return { return {
libraryAssociationIdInvisible: '', libraryAssociationIdInvisible: '',
rolePlay: false, rolePlay: false,
// actualNumbers: true, //
jiy: [], jiy: [],
// heid: true, // heid: true,
addId: '', addId: '',
@ -225,7 +226,8 @@
width: '200px', width: '200px',
placeholder: '请输入${title}', placeholder: '请输入${title}',
// defaultValue:'', // defaultValue:'',
options: [] options: [],
disabled: this.disabled,
}, },
{ {
title: 'WBS', title: 'WBS',
@ -234,7 +236,8 @@
dictCode: '', dictCode: '',
width: '200px', width: '200px',
placeholder: '请输入${title}', placeholder: '请输入${title}',
defaultValue: '' defaultValue: '',
disabled: this.disabled,
}, },
{ {
title: '物料名称及规格型号', title: '物料名称及规格型号',
@ -243,7 +246,8 @@
dictCode: '', dictCode: '',
width: '200px', width: '200px',
placeholder: '请输入${title}', placeholder: '请输入${title}',
defaultValue: '' defaultValue: '',
disabled: this.disabled,
}, },
// { // {
// title: '', // title: '',
@ -269,7 +273,8 @@
dictCode: '', dictCode: '',
width: '130px', width: '130px',
placeholder: '请输入${title}', placeholder: '请输入${title}',
defaultValue: '' defaultValue: '',
disabled: this.disabled,
}, },
// { // {
// title: '', // title: '',
@ -285,7 +290,8 @@
type: FormTypes.inputNumber, type: FormTypes.inputNumber,
width: '130px', width: '130px',
placeholder: '请输入${title}', placeholder: '请输入${title}',
defaultValue: '' defaultValue: '',
disabled: this.disabled,
// slotName: 'qing' // slotName: 'qing'
}, },
{ {
@ -294,7 +300,8 @@
type: FormTypes.inputNumber, type: FormTypes.inputNumber,
width: '130px', width: '130px',
placeholder: '请输入${title}', placeholder: '请输入${title}',
defaultValue: '' defaultValue: '',
disabled: this.actualNumber,
}, },
{ {
title: '库存', title: '库存',
@ -303,7 +310,8 @@
width: '80px', width: '80px',
// placeholder: '${title}', // placeholder: '${title}',
// defaultValue: '', // defaultValue: '',
slotName: 'repertory' slotName: 'repertory',
disabled: this.disabled,
// scopedSlots: {customRender: 'fileSlot'} // scopedSlots: {customRender: 'fileSlot'}
}, },
{ {
@ -313,7 +321,8 @@
dictCode: '', dictCode: '',
width: '200px', width: '200px',
placeholder: '请输入${title}', placeholder: '请输入${title}',
defaultValue: '' defaultValue: '',
disabled: this.disabled,
}, },
{ {
title: '单价(元)', title: '单价(元)',
@ -357,6 +366,7 @@
type: FormTypes.input, type: FormTypes.input,
width: '200px', width: '200px',
placeholder: '请输入${title}', placeholder: '请输入${title}',
disabled: this.disabled,
defaultValue: '' defaultValue: ''
} }
// { // {
@ -392,6 +402,7 @@
} }
}, },
btndisabled: false, btndisabled: false,
isabled: true,
describes: '', describes: '',
assignees: '', assignees: '',
deliveryType: '', deliveryType: '',
@ -439,6 +450,12 @@
required: false required: false
}, },
// //
actualNumber: {
type: Boolean,
// default: false, //
required: true //
},
//
hieg: { hieg: {
type: Boolean, type: Boolean,
default: false, default: false,
@ -460,6 +477,10 @@
return true return true
} }
// console.log("============================",this.hiegs=this.hieg); // console.log("============================",this.hiegs=this.hieg);
console.log("2222222222222222",this.actualNumber)
// if(this.disabled){
// this.isabled = false;
// }
this.hiegs = this.hieg this.hiegs = this.hieg
return this.disabled return this.disabled
}, },
@ -532,6 +553,7 @@
if (val !== undefined) { if (val !== undefined) {
this.accountingAttributesVal = val this.accountingAttributesVal = val
this.hiegs = false this.hiegs = false
this.isabled = false
if (this.deliveryType !== 1 ) { if (this.deliveryType !== 1 ) {
// console.log("") // console.log("")
// //
@ -1357,8 +1379,42 @@
this.$emit('close') this.$emit('close')
}, },
/*通过审批*/ /*通过审批*/
passTask() { async passTask() {
this.$emit('passTask') let qing = false;
if(!this.actualNumber){
await this.getAllTable().then(tables => {
return validateFormAndTables(this.form, tables)
}).then(allValues => {
let formData = this.classifyIntoFormData(allValues);
if(formData.processMaterialsDeliveryListList.length > 0){
formData.processMaterialsDeliveryListList.forEach(item => {
if(!item.actualSendNumber){
qing = true;
}
})
if(qing){
console.log("============",qing);
this.$message.warning("请填写实发数!!!")
}else{
let method = 'put'
httpAction(this.url.edit, formData, method).then((res) => {
if (res.success) {
}
}).finally(() => {
})
}
}
console.log('所有数据========', formData)
})
}
if(!qing){
console.log("============",qing);
this.$emit('passTask')
}
}, },
/*驳回审批*/ /*驳回审批*/
backTask() { backTask() {
@ -1417,6 +1473,24 @@
formData.title = this.processData.title formData.title = this.processData.title
formData.processInstanceId = this.processData.id formData.processInstanceId = this.processData.id
} }
if(formData.processMaterialsDeliveryListList.length > 0){
let qing = false;
formData.processMaterialsDeliveryListList.forEach(item => {
if(!!item.equipment){
if(!item.pleaseSendNumber){
qing = true;
}
}else {
this.$message.warning("请填写数据!!!")
}
})
if(qing){
this.$message.warning("请填写请发数!!!")
return
}
}
console.log('提交方法', method) console.log('提交方法', method)
if(this.btndisabled === false){ if(this.btndisabled === false){
this.btndisabled = true this.btndisabled = true

25
src/views/activiti/form/ProcessUdgetPlanForm.vue

@ -64,26 +64,26 @@
</a-col> </a-col>
<a-col :span="8" v-show="isPlanType"> <a-col :span="8" v-show="isPlanType">
<a-form-item label="采购类型" :labelCol="labelCol" :wrapperCol="wrapperCol"> <a-form-item label="采购类型" :labelCol="labelCol" :wrapperCol="wrapperCol">
<j-dict-select-tag type="list" v-decorator="['planType']" <j-dict-select-tag type="list" v-decorator="['planType',validatorRules.planType]"
:trigger-change="true" dictCode="plan_type" :trigger-change="true" dictCode="plan_type"
placeholder="请选择采购类型电商或非电商" @change="selectChangPlanType"/> placeholder="请选择采购类型电商或非电商" @change="selectChangPlanType"/>
</a-form-item> </a-form-item>
</a-col> </a-col>
<a-col :span="8" v-show="isSourceCapital"> <a-col :span="8" v-show="isSourceCapital">
<a-form-item label="资金来源" :labelCol="labelCol" :wrapperCol="wrapperCol"> <a-form-item label="资金来源" :labelCol="labelCol" :wrapperCol="wrapperCol">
<j-dict-select-tag type="list" v-decorator="['sourceCapital']" <j-dict-select-tag type="list" v-decorator="['sourceCapital',validatorRules.sourceCapital]"
:trigger-change="true" dictCode="source_capital" :trigger-change="true" dictCode="source_capital"
placeholder="请选择资金来源"/> placeholder="请选择资金来源"/>
</a-form-item> </a-form-item>
</a-col> </a-col>
<a-col :span="8" v-show="isIfDirect"> <a-col :span="8" v-if="isIfDirect">
<a-form-item label="是否属于直达物资" :labelCol="labelCol" :wrapperCol="wrapperCol"> <a-form-item label="是否属于直达物资" :labelCol="labelCol" :wrapperCol="wrapperCol">
<j-dict-select-tag type="list" v-decorator="['ifDirect',validatorRules.ifDirect]" <j-dict-select-tag type="list" v-decorator="['ifDirect',validatorRules.ifDirect]"
:trigger-change="true" dictCode="if_status" :trigger-change="true" dictCode="if_status"
placeholder="请选择是否属于直达物资" @change="selectChang"/> placeholder="请选择是否属于直达物资" @change="selectChang"/>
</a-form-item> </a-form-item>
</a-col> </a-col>
<a-col :span="8" v-show="isIfInspection"> <a-col :span="8" v-if="isIfInspection">
<a-form-item label="是否需要送检" :labelCol="labelCol" :wrapperCol="wrapperCol"> <a-form-item label="是否需要送检" :labelCol="labelCol" :wrapperCol="wrapperCol">
<j-dict-select-tag type="list" v-decorator="['ifInspection',validatorRules.ifInspection]" <j-dict-select-tag type="list" v-decorator="['ifInspection',validatorRules.ifInspection]"
:trigger-change="true" dictCode="if_status" :trigger-change="true" dictCode="if_status"
@ -593,6 +593,10 @@
// 'blur' // 'blur'
materialType: { rules: [{ required: true, message: '请选择物资类型!' }] }, materialType: { rules: [{ required: true, message: '请选择物资类型!' }] },
needTime: { rules: [{ required: true, message: '请选择需求时间!' }] }, needTime: { rules: [{ required: true, message: '请选择需求时间!' }] },
ifDirect: { rules: [{ required: true, message: '请选择物资到达类型!' }] },
sourceCapital: { rules: [{ required: true, message: '请选择资金来源!' }] },
planType: { rules: [{ required: true, message: '请选择采购类型!' }] },
ifInspection: { rules: [{ required: true, message: '请选择是否送检!' }] },
processPlan: { rules: [{ required: true, message: '请选择流程计划!' }] }, processPlan: { rules: [{ required: true, message: '请选择流程计划!' }] },
sort: { sort: {
rules: [{ required: true, type: 'number', max: 999999999999, message: '请输入序号!(0 ~ 12个数字)' } rules: [{ required: true, type: 'number', max: 999999999999, message: '请输入序号!(0 ~ 12个数字)' }
@ -1686,7 +1690,7 @@
// }, // },
// //
showFlowData() { showFlowData() {
console.log(this.formBpm, '----------****') // console.log(this.formBpm, '----------****')
if (this.formBpm === true) { if (this.formBpm === true) {
let params = { id: this.formData.dataId } let params = { id: this.formData.dataId }
getAction(this.url.queryById, params).then((res) => { getAction(this.url.queryById, params).then((res) => {
@ -1721,7 +1725,7 @@
this.handleSubmit(true) this.handleSubmit(true)
}, },
// handler // handler
handleSubmit(e) { handleSubmit(e) {
this.getAllTable().then(tables => { this.getAllTable().then(tables => {
return validateFormAndTables(this.form, tables) return validateFormAndTables(this.form, tables)
}).then(allValues => { }).then(allValues => {
@ -1762,8 +1766,8 @@
this.$message.error('需求时间不能小于当前流程发起时间') this.$message.error('需求时间不能小于当前流程发起时间')
return return
} }
console.log(formData, '表单数据') // console.log(formData, '')
console.log(this.opinion, '流程说明') // console.log(this.opinion, '')
this.form.validateFields((err, values) => { this.form.validateFields((err, values) => {
if (!err) { if (!err) {
formData.procDefId = this.processData.id formData.procDefId = this.processData.id
@ -1778,7 +1782,7 @@
method = 'put' method = 'put'
} }
if (formData.planType == 1 && formData.materialType != 6) { if (formData.planType == 1 && formData.materialType != 6) {
console.log('格式化后的数据', formData) // console.log('', formData)
if (formData.ifDirect == null && this.routePlanName == '采购员') { if (formData.ifDirect == null && this.routePlanName == '采购员') {
this.$message.error('请选择是否属于直达物资!') this.$message.error('请选择是否属于直达物资!')
return return
@ -1794,6 +1798,9 @@
if (e==true){ if (e==true){
this.passTask() this.passTask()
} }
formData.ifDirect = parseInt(formData.ifDirect);
formData.sourceCapital = parseInt(formData.sourceCapital);
formData.planType = parseInt(formData.planType);
console.log(formData, '格式化的数据') console.log(formData, '格式化的数据')
if (this.btndisabled === false) { if (this.btndisabled === false) {
this.btndisabled = true this.btndisabled = true

9
src/views/activiti/todoManage.vue

@ -156,6 +156,7 @@
:routePlanName="lcModa.routePlanName" :routePlanName="lcModa.routePlanName"
:isTable="lcModa.isTable" :isTable="lcModa.isTable"
:itemId="lcModa.itemId" :itemId="lcModa.itemId"
:actualNumber = "lcModa.actualNumber"
@afterSubmit="afterSub" @afterSubmit="afterSub"
@passTask="()=>passTask(lcModa.processData)" @passTask="()=>passTask(lcModa.processData)"
@backTask="()=>backTask(lcModa.processData)" :procInstId="lcModa.procInstId" @backTask="()=>backTask(lcModa.processData)" :procInstId="lcModa.procInstId"
@ -290,6 +291,7 @@
lcModa: { lcModa: {
title: '', title: '',
disabled: false, disabled: false,
actualNumber: true,
visible: false, visible: false,
formComponent: null, formComponent: null,
isNew: false, isNew: false,
@ -484,6 +486,13 @@
this.form.userId=null; this.form.userId=null;
}, },
async detail(r) { async detail(r) {
// console.log("rrrr==================rrrrrrr",r)
if(r.name === '项目部经理' && r.processName === '物资出库流程'){
// console.log(" ===")
this.lcModa.actualNumber = false;
}else{
this.lcModa.actualNumber = true;
}
if (!r.routeName) { if (!r.routeName) {
this.$message.warning( this.$message.warning(
'该流程信息未配置表单,请联系开发人员!' '该流程信息未配置表单,请联系开发人员!'

14
src/views/system/UserList.vue

@ -92,23 +92,23 @@
<!-- 操作按钮区域 --> <!-- 操作按钮区域 -->
<div class="table-operator" style="border-top: 5px"> <div class="table-operator" style="border-top: 5px">
<a-button @click="handleAdd" type="primary" icon="plus" v-has="'user:add'">添加用户</a-button> <a-button @click="handleAdd" type="primary" icon="plus" v-has="'user:add'">添加用户</a-button>
<a-button type="primary" icon="download" @click="handleExportXls('用户信息')">导出</a-button> <a-button type="primary" icon="download" @click="handleExportXls('用户信息')" v-has="'user:export'">导出</a-button>
<a-button type="primary" icon="download" @click="downloadText('/static/excle/用户信息导入模板.xlsx','用户信息导入模板.xlsx')">用户信息导入模板</a-button> <a-button type="primary" icon="download" @click="downloadText('/static/excle/用户信息导入模板.xlsx','用户信息导入模板.xlsx')" v-has="'user:download'">用户信息导入模板</a-button>
<a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel"> <a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel">
<a-button type="primary" icon="import">导入</a-button> <a-button type="primary" icon="import" v-has="'user:import'">导入</a-button>
</a-upload> </a-upload>
<a-button type="primary" icon="hdd" @click="recycleBinVisible=true">回收站</a-button> <a-button type="primary" icon="hdd" @click="recycleBinVisible=true" v-has="'user:recycle'">回收站</a-button>
<a-dropdown v-if="selectedRowKeys.length > 0"> <a-dropdown v-if="selectedRowKeys.length > 0">
<a-menu slot="overlay" @click="handleMenuClick"> <a-menu slot="overlay" @click="handleMenuClick">
<a-menu-item key="1"> <a-menu-item key="1" v-has="'user:delete'">
<a-icon type="delete" @click="batchDel"/> <a-icon type="delete" @click="batchDel"/>
删除 删除
</a-menu-item> </a-menu-item>
<a-menu-item key="2"> <a-menu-item key="2" v-has="'user:frost'">
<a-icon type="lock" @click="batchFrozen('2')"/> <a-icon type="lock" @click="batchFrozen('2')"/>
冻结 冻结
</a-menu-item> </a-menu-item>
<a-menu-item key="3"> <a-menu-item key="3" v-has="'user:defrost'">
<a-icon type="unlock" @click="batchFrozen('1')"/> <a-icon type="unlock" @click="batchFrozen('1')"/>
解冻 解冻
</a-menu-item> </a-menu-item>

Loading…
Cancel
Save