计划班组功能悠 1.7

zhc4dev
zhc077 2 years ago
parent 7fb4946dfe
commit 206438c0ad
  1. 42
      ant-design-vue-jeecg/src/views/productplan/ZyPlanProcessDataList.vue
  2. 816
      ant-design-vue-jeecg/src/views/productplan/ZyPlanProcessDataList_back1223.vue
  3. 329
      ant-design-vue-jeecg/src/views/productplan/ZyPlanTeamDataList.vue
  4. 6
      jeecg-boot/jeecg-boot-module-system/src/main/java/org/jeecg/modules/productplan/entity/ZyPlanProcess.java
  5. 7
      jeecg-boot/jeecg-boot-module-system/src/main/java/org/jeecg/modules/productplan/entity/vo/ProcessDataVo.java
  6. 88
      jeecg-boot/jeecg-boot-module-system/src/main/java/org/jeecg/modules/productplan/service/impl/ZyPlanProcessServiceImpl.java
  7. 2
      jeecg-boot/jeecg-boot-module-system/src/main/java/org/jeecg/modules/team/entity/GroupxMember.java
  8. 16
      jeecg-boot/jeecg-boot-module-system/src/main/java/org/jeecg/modules/team/vo/GroupxMemeberVo.java
  9. 16
      jeecg-boot/jeecg-boot-module-system/src/main/java/org/jeecg/modules/team/vo/GroupxVo.java

@ -76,7 +76,8 @@ export default {
width: '200px', width: '200px',
options: [], options: [],
placeholder: '请选择${title}', placeholder: '请选择${title}',
}, { },
{
title: '设备列表', title: '设备列表',
key: 'machineIds', key: 'machineIds',
type: JVXETypes.selectMultiple, type: JVXETypes.selectMultiple,
@ -91,14 +92,43 @@ export default {
options: [], options: [],
placeholder: '请选择${title}', placeholder: '请选择${title}',
}, },
// {
// title: 'JPopup',
// key: 'popup',
// type: JVXETypes.popup,
// width: '180px',
// popupCode: 'demo',
// field: 'name,sex,age',
// orgFields: 'name,sex,age',
// destFields: 'popup,popup_sex,popup_age'
// },
{ {
key: 'proProcess',
title: '前导工序', title: '前导工序',
dictCode: 'zy_process,process_name,id,id in(select process_id from zy_product_process where product_id="1")', key: 'proProcess',
width: '150', type: JVXETypes.popup,
type: JVXETypes.select width: '180px',
popupCode: 'zy_process',
field: 'id,process_code,process_name,process_describe',
orgFields: 'id,process_code,process_name,process_describe',
destFields: 'popup,id,popup_process_name,popup_process_describe',
},
// {
// key: 'proProcess',
// title: '',
// dictCode: 'zy_process,process_name,id,id in(select process_id from zy_product_process where product_id="1")',
// width: '150',
// type: JVXETypes.select
// },
{
title: '后导工序',
key: 'postProcess',
type: JVXETypes.popup,
width: '180px',
popupCode: 'zy_process',
field: 'id,process_code,process_name,process_describe',
orgFields: 'id,process_code,process_name,process_describe',
destFields: 'popup,id,popup_process_name,popup_process_describe',
}, },
{key: 'postProcess', title: '后导工序', width: '150', type: JVXETypes.select},
{key: 'inputProduct', title: '输入产品', width: '150', type: JVXETypes.input}, {key: 'inputProduct', title: '输入产品', width: '150', type: JVXETypes.input},
{key: 'semiProduct', title: '成品/半成品', width: '150', type: JVXETypes.input}, {key: 'semiProduct', title: '成品/半成品', width: '150', type: JVXETypes.input},
], ],

@ -1,422 +1,422 @@
<template> <!--<template>-->
<a-card :bordered="false"> <!-- <a-card :bordered="false">-->
<div class="table-operator"> <!-- <div class="table-operator">-->
<a-button type="primary" icon="download" @click="handleExportXls('计划工序')">导出</a-button> <!-- <a-button type="primary" icon="download" @click="handleExportXls('计划工序')">导出</a-button>-->
<a-button type="primary" @click="fanHui()">保存</a-button> <!-- <a-button type="primary" @click="fanHui()">保存</a-button>-->
<a-button type="primary" @click="fanHui()">返回</a-button> <!-- <a-button type="primary" @click="fanHui()">返回</a-button>-->
</div> <!-- </div>-->
<!-- table区域-begin --> <!-- &lt;!&ndash; table区域-begin &ndash;&gt;-->
<div> <!-- <div>-->
<a-table <!-- <a-table-->
ref="table" <!-- ref="table"-->
size="middle" <!-- size="middle"-->
:scroll="{x:true}" <!-- :scroll="{x:true}"-->
bordered <!-- bordered-->
rowKey="id" <!-- rowKey="id"-->
:columns="columns" <!-- :columns="columns"-->
:dataSource="dataSource" <!-- :dataSource="dataSource"-->
:pagination="ipagination" <!-- :pagination="ipagination"-->
:loading="loading" <!-- :loading="loading"-->
:rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}" <!-- :rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}"-->
class="j-table-force-nowrap" <!-- class="j-table-force-nowrap"-->
@change="handleTableChange"> <!-- @change="handleTableChange">-->
<span slot="stationList" slot-scope="stationList"> <!-- <span slot="stationList" slot-scope="stationList">-->
<a-select @change="getToolAndMachine" style="width: 180px" placeholder="请选择"> <!-- <a-select @change="getToolAndMachine" style="width: 180px" placeholder="请选择">-->
<a-select-option v-for="item in stationList" :value="item.id"> <!-- <a-select-option v-for="item in stationList" :value="item.id">-->
{{ item.stationName }} <!-- {{ item.stationName }}-->
</a-select-option> <!-- </a-select-option>-->
</a-select> <!-- </a-select>-->
</span> <!-- </span>-->
<span slot="toolsList" slot-scope="toolsList"> <!-- <span slot="toolsList" slot-scope="toolsList">-->
<a-select style="width: 180px" placeholder="请选择"> <!-- <a-select style="width: 180px" placeholder="请选择">-->
<a-select-option v-for="item in toolsList" :value="item.id"> <!-- <a-select-option v-for="item in toolsList" :value="item.id">-->
{{ item.name }} <!-- {{ item.name }}-->
</a-select-option> <!-- </a-select-option>-->
</a-select> <!-- </a-select>-->
</span> <!-- </span>-->
<span slot="machineList" slot-scope="machineList"> <!-- <span slot="machineList" slot-scope="machineList">-->
<a-select style="width: 180px" placeholder="请选择"> <!-- <a-select style="width: 180px" placeholder="请选择">-->
<a-select-option v-for="item in machineList" :value="item.id"> <!-- <a-select-option v-for="item in machineList" :value="item.id">-->
{{ item.name }} <!-- {{ item.name }}-->
</a-select-option> <!-- </a-select-option>-->
</a-select> <!-- </a-select>-->
</span> <!-- </span>-->
<span slot="proProcess" slot-scope="proProcess"> <!-- <span slot="proProcess" slot-scope="proProcess">-->
<j-search-select-tag type="list" dict="zy_process,process_name,id,id in(select process_id from zy_product_process where product_id='1')" pidField="pid" <!-- <j-search-select-tag type="list" dict="zy_process,process_name,id,id in(select process_id from zy_product_process where product_id='1')" pidField="pid"-->
pidValue="" placeholder="前导工序"/> <!-- pidValue="" placeholder="前导工序"/>-->
</span> <!-- </span>-->
<span slot="postProcess" slot-scope="postProcess"> <!-- <span slot="postProcess" slot-scope="postProcess">-->
<j-search-select-tag type="list" dict="zy_process,process_name,id,id in(select process_id from zy_product_process where product_id='1')" pidField="pid" <!-- <j-search-select-tag type="list" dict="zy_process,process_name,id,id in(select process_id from zy_product_process where product_id='1')" pidField="pid"-->
pidValue="" placeholder="后导工序"/> <!-- pidValue="" placeholder="后导工序"/>-->
</span> <!-- </span>-->
<span slot="inputProduct" slot-scope="inputProduct"> <!-- <span slot="inputProduct" slot-scope="inputProduct">-->
<a-input v-model="processIds" placeholder="请输入产品"></a-input> <!-- <a-input v-model="processIds" placeholder="请输入产品"></a-input>-->
</span> <!-- </span>-->
<span slot="semiProduct" slot-scope="semiProduct"> <!-- <span slot="semiProduct" slot-scope="semiProduct">-->
<a-input v-model="semiProduct" placeholder="请输入成品/半成品"></a-input> <!-- <a-input v-model="semiProduct" placeholder="请输入成品/半成品"></a-input>-->
</span> <!-- </span>-->
<!-- <template <!-- &lt;!&ndash; <template-->
v-for="col in columns" <!-- v-for="col in columns"-->
:slot="col" <!-- :slot="col"-->
slot-scope="text, record, index" <!-- slot-scope="text, record, index"-->
> <!-- >-->
<div :key="col"> <!-- <div :key="col">-->
<a-input <!-- <a-input-->
v-if="record.editable" <!-- v-if="record.editable"-->
style="margin: -5px 0" <!-- style="margin: -5px 0"-->
:value="text" <!-- :value="text"-->
@change="e => handleChange(e.target.value, record.key, col)" <!-- @change="e => handleChange(e.target.value, record.key, col)"-->
/> <!-- />-->
<template v-else> <!-- <template v-else>-->
{{ text }} <!-- {{ text }}-->
</template> <!-- </template>-->
</div> <!-- </div>-->
</template> <!-- </template>-->
<template slot="operation" slot-scope="text, record, index"> <!-- <template slot="operation" slot-scope="text, record, index">-->
<div class="editable-row-operations"> <!-- <div class="editable-row-operations">-->
<span v-if="record.editable"> <!-- <span v-if="record.editable">-->
<a @click="() => save(record)">Save</a> <!-- <a @click="() => save(record)">Save</a>-->
<a-popconfirm title="Sure to cancel?" @confirm="() => cancel(record)"> <!-- <a-popconfirm title="Sure to cancel?" @confirm="() => cancel(record)">-->
<a>Cancel</a> <!-- <a>Cancel</a>-->
</a-popconfirm> <!-- </a-popconfirm>-->
</span> <!-- </span>-->
<span> <!-- <span>-->
<a :disabled="editingKey !== ''" @click="() => edit(index)">Edit66</a> <!-- <a :disabled="editingKey !== ''" @click="() => edit(index)">Edit66</a>-->
</span> b <!-- </span> b-->
</div> <!-- </div>-->
</template>--> <!-- </template>&ndash;&gt;-->
</a-table> <!-- </a-table>-->
</div> <!-- </div>-->
<div class="table-operator" style="text-align: right"> <!-- <div class="table-operator" style="text-align: right">-->
<a-button type="primary" @click="fanHui()">提交</a-button> <!-- <a-button type="primary" @click="fanHui()">提交</a-button>-->
</div> <!-- </div>-->
<!-- <zy-plan-process-modal @valueChange="valueChange" ref="modalForm" @ok="modalFormOk"></zy-plan-process-modal>--> <!-- &lt;!&ndash; <zy-plan-process-modal @valueChange="valueChange" ref="modalForm" @ok="modalFormOk"></zy-plan-process-modal>&ndash;&gt;-->
</a-card> <!-- </a-card>-->
</template> <!--</template>-->
<script> <!--<script>-->
import '@/assets/less/TableExpand.less' <!--import '@/assets/less/TableExpand.less'-->
import {mixinDevice} from '@/utils/mixin' <!--import {mixinDevice} from '@/utils/mixin'-->
import {JeecgListMixin} from '@/mixins/JeecgListMixin' <!--import {JeecgListMixin} from '@/mixins/JeecgListMixin'-->
import ZyPlanProcessModal from './modules/ZyPlanProcessModal2' <!--import ZyPlanProcessModal from './modules/ZyPlanProcessModal2'-->
import {getAction} from "@api/manage"; <!--import {getAction} from "@api/manage";-->
import {filterObj} from "@/utils/util"; <!--import {filterObj} from "@/utils/util";-->
export default { <!--export default {-->
name: 'ZyPlanProcessList', <!-- name: 'ZyPlanProcessList',-->
mixins: [JeecgListMixin, mixinDevice], <!-- mixins: [JeecgListMixin, mixinDevice],-->
components: { <!-- components: {-->
ZyPlanProcessModal <!-- ZyPlanProcessModal-->
}, <!-- },-->
data() { <!-- data() {-->
// this.cacheData = this.dataSource.map(item => ({ ...item })); <!-- // this.cacheData = this.dataSource.map(item => ({ ...item }));-->
this.cacheData = []; <!-- this.cacheData = [];-->
return { <!-- return {-->
description: '生产计划工序管理页面', <!-- description: '生产计划工序管理页面',-->
// columns, <!-- // columns,-->
// <!-- // -->
columns: [ <!-- columns: [-->
{ <!-- {-->
title: '#', <!-- title: '#',-->
dataIndex: 'productProcessId', <!-- dataIndex: 'productProcessId',-->
key: 'rowIndex', <!-- key: 'rowIndex',-->
width: 60, <!-- width: 60,-->
align: "center", <!-- align: "center",-->
customRender: function (t, r, index) { <!-- customRender: function (t, r, index) {-->
return parseInt(index) + 1; <!-- return parseInt(index) + 1;-->
} <!-- }-->
}, <!-- },-->
/* { <!-- /* {-->
title: '计划id', <!-- title: '计划id',-->
align: "center", <!-- align: "center",-->
dataIndex: 'planId' <!-- dataIndex: 'planId'-->
},*/ <!-- },*/-->
{ <!-- {-->
title: '工单编号', <!-- title: '工单编号',-->
align: "center", <!-- align: "center",-->
dataIndex: 'workOrderId', <!-- dataIndex: 'workOrderId',-->
scopedSlots: {customRender: 'workOrderId'} <!-- scopedSlots: {customRender: 'workOrderId'}-->
}, <!-- },-->
/*{ <!-- /*{-->
title: '产品id', <!-- title: '产品id',-->
align: "center", <!-- align: "center",-->
dataIndex: 'productId' <!-- dataIndex: 'productId'-->
}, <!-- },-->
{ <!-- {-->
title: '工序id', <!-- title: '工序id',-->
align: "center", <!-- align: "center",-->
dataIndex: 'productProcessId' <!-- dataIndex: 'productProcessId'-->
},*/ <!-- },*/-->
{ <!-- {-->
title: '产品', <!-- title: '产品',-->
align: "center", <!-- align: "center",-->
dataIndex: 'productName' <!-- dataIndex: 'productName'-->
}, <!-- },-->
{ <!-- {-->
title: '车间', <!-- title: '车间',-->
align: "center", <!-- align: "center",-->
dataIndex: 'departName' <!-- dataIndex: 'departName'-->
}, <!-- },-->
{ <!-- {-->
title: '工序', <!-- title: '工序',-->
align: "center", <!-- align: "center",-->
dataIndex: 'processName' <!-- dataIndex: 'processName'-->
}, <!-- },-->
{ <!-- {-->
title: '工位列表', <!-- title: '工位列表',-->
align: "center", <!-- align: "center",-->
dataIndex: 'stationList', <!-- dataIndex: 'stationList',-->
width: 150, <!-- width: 150,-->
scopedSlots: {customRender: 'stationList'} <!-- scopedSlots: {customRender: 'stationList'}-->
}, <!-- },-->
{ <!-- {-->
title: '工位工具列表', <!-- title: '工位工具列表',-->
align: "center", <!-- align: "center",-->
dataIndex: 'toolsList', <!-- dataIndex: 'toolsList',-->
width: 150, <!-- width: 150,-->
// scopedSlots: {customRender: this.toolsList} <!-- // scopedSlots: {customRender: this.toolsList}-->
scopedSlots: {customRender: 'toolsList'} <!-- scopedSlots: {customRender: 'toolsList'}-->
}, <!-- },-->
{ <!-- {-->
title: '工具设备列表', <!-- title: '工具设备列表',-->
align: "center", <!-- align: "center",-->
dataIndex: 'machineList', <!-- dataIndex: 'machineList',-->
width: 150, <!-- width: 150,-->
scopedSlots: {customRender: 'machineList'} <!-- scopedSlots: {customRender: 'machineList'}-->
}, <!-- },-->
{ <!-- {-->
title: '前导工序', <!-- title: '前导工序',-->
align: "center", <!-- align: "center",-->
dataIndex: 'proProcess', <!-- dataIndex: 'proProcess',-->
width: 150, <!-- width: 150,-->
scopedSlots: {customRender: 'proProcess'} <!-- scopedSlots: {customRender: 'proProcess'}-->
}, <!-- },-->
{ <!-- {-->
title: '后导工序', <!-- title: '后导工序',-->
align: "center", <!-- align: "center",-->
dataIndex: 'proProcess', <!-- dataIndex: 'proProcess',-->
width: 150, <!-- width: 150,-->
scopedSlots: {customRender: 'postProcess'} <!-- scopedSlots: {customRender: 'postProcess'}-->
}, <!-- },-->
{ <!-- {-->
title: '输入产品', <!-- title: '输入产品',-->
align: "center", <!-- align: "center",-->
dataIndex: 'inputProduct', <!-- dataIndex: 'inputProduct',-->
width: 150, <!-- width: 150,-->
scopedSlots: {customRender: 'inputProduct'} <!-- scopedSlots: {customRender: 'inputProduct'}-->
}, <!-- },-->
{ <!-- {-->
title: '成品/半成品', <!-- title: '成品/半成品',-->
align: "center", <!-- align: "center",-->
dataIndex: 'semiProduct', <!-- dataIndex: 'semiProduct',-->
width: 150, <!-- width: 150,-->
scopedSlots: {customRender: 'semiProduct'} <!-- scopedSlots: {customRender: 'semiProduct'}-->
}, <!-- },-->
// { <!-- // {-->
// title: 'operation', <!-- // title: 'operation',-->
// dataIndex: 'operation', <!-- // dataIndex: 'operation',-->
// scopedSlots: {customRender: 'operation'}, <!-- // scopedSlots: {customRender: 'operation'},-->
// }, <!-- // },-->
// { <!-- // {-->
// title: '', <!-- // title: '',-->
// dataIndex: 'action', <!-- // dataIndex: 'action',-->
// align: "center", <!-- // align: "center",-->
// fixed: "right", <!-- // fixed: "right",-->
// width: 147, <!-- // width: 147,-->
// scopedSlots: {customRender: 'action'} <!-- // scopedSlots: {customRender: 'action'}-->
// } <!-- // }-->
], <!-- ],-->
editingKey: '', <!-- editingKey: '',-->
url: { <!-- url: {-->
list: "/org.jeecg.modules.productplan/zyPlanProcess/getProcessDatalist", <!-- list: "/org.jeecg.modules.productplan/zyPlanProcess/getProcessDatalist",-->
stationToolslist: "/stationTool/list", <!-- stationToolslist: "/stationTool/list",-->
stationMachinelist: "/stationMachine/list", <!-- stationMachinelist: "/stationMachine/list",-->
// productPlanlist: "/org.jeecg.modules.productplan/zyProductPlan/list", <!-- // productPlanlist: "/org.jeecg.modules.productplan/zyProductPlan/list",-->
delete: "/org.jeecg.modules.productplan/zyPlanProcess/delete", <!-- delete: "/org.jeecg.modules.productplan/zyPlanProcess/delete",-->
// deleteBatch: "/org.jeecg.modules.productplan/zyPlanProcess/deleteBatch", <!-- // deleteBatch: "/org.jeecg.modules.productplan/zyPlanProcess/deleteBatch",-->
// exportXlsUrl: "/org.jeecg.modules.productplan/zyPlanProcess/exportXls", <!-- // exportXlsUrl: "/org.jeecg.modules.productplan/zyPlanProcess/exportXls",-->
// importExcelUrl: "org.jeecg.modules.productplan/zyPlanProcess/importExcel", <!-- // importExcelUrl: "org.jeecg.modules.productplan/zyPlanProcess/importExcel",-->
}, <!-- },-->
loadRouteType: false, <!-- loadRouteType: false,-->
planId: "", <!-- planId: "",-->
dictOptions: {}, <!-- dictOptions: {},-->
// superFieldList: [], <!-- // superFieldList: [],-->
toolsList: [], <!-- toolsList: [],-->
machineList: [], <!-- machineList: [],-->
} <!-- }-->
}, <!-- },-->
created() { <!-- created() {-->
this.getSuperFieldList(); <!-- this.getSuperFieldList();-->
}, <!-- },-->
computed: { <!-- computed: {-->
importExcelUrl: function () { <!-- importExcelUrl: function () {-->
return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`; <!-- return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`;-->
}, <!-- },-->
}, <!-- },-->
methods: { <!-- methods: {-->
fanHui() { <!-- fanHui() {-->
this.$router.push({ <!-- this.$router.push({-->
path: '/productplan/ZyPlanProcessList', <!-- path: '/productplan/ZyPlanProcessList',-->
}); <!-- });-->
}, <!-- },-->
getToolAndMachine(stationId) { <!-- getToolAndMachine(stationId) {-->
// alert("stationId=" + stationId); <!-- // alert("stationId=" + stationId);-->
getAction(this.url.stationToolslist, {"stationId": stationId}).then((res) => { <!-- getAction(this.url.stationToolslist, {"stationId": stationId}).then((res) => {-->
if (res.success) { <!-- if (res.success) {-->
this.toolsList = res.result.records || res.result; <!-- this.toolsList = res.result.records || res.result;-->
console.log("toolsList", JSON.stringify(this.toolsList)) <!-- console.log("toolsList", JSON.stringify(this.toolsList))-->
} else { <!-- } else {-->
this.$message.warning(res.message) <!-- this.$message.warning(res.message)-->
} <!-- }-->
}); <!-- });-->
getAction(this.url.stationMachinelist, {"stationId": stationId}).then((res) => { <!-- getAction(this.url.stationMachinelist, {"stationId": stationId}).then((res) => {-->
if (res.success) { <!-- if (res.success) {-->
this.machineList = res.result.records || res.result; <!-- this.machineList = res.result.records || res.result;-->
console.log("machineList", JSON.stringify(this.toolsList)) <!-- console.log("machineList", JSON.stringify(this.toolsList))-->
} else { <!-- } else {-->
this.$message.warning(res.message) <!-- this.$message.warning(res.message)-->
} <!-- }-->
}); <!-- });-->
}, <!-- },-->
// <!-- //-->
loadParameter() { <!-- loadParameter() {-->
if (this.loadRouteType === false) { <!-- if (this.loadRouteType === false) {-->
this.planId = this.$route.query.planId; <!-- this.planId = this.$route.query.planId;-->
// this.biaoTi = this.$route.query.styleNames+""; <!-- // this.biaoTi = this.$route.query.styleNames+"";-->
console.log("*******传递的planId:" + this.planId) <!-- console.log("*******传递的planId:" + this.planId)-->
this.loadRouteType = true; <!-- this.loadRouteType = true;-->
} <!-- }-->
}, <!-- },-->
loadData(arg) { <!-- loadData(arg) {-->
if (!this.url.list) { <!-- if (!this.url.list) {-->
this.$message.error("请设置url.list属性!") <!-- this.$message.error("请设置url.list属性!")-->
return <!-- return-->
} <!-- }-->
// 1 <!-- // 1-->
if (arg === 1) { <!-- if (arg === 1) {-->
this.ipagination.current = 1; <!-- this.ipagination.current = 1;-->
} <!-- }-->
this.loadParameter(); <!-- this.loadParameter();-->
var params = this.getQueryParams();// <!-- var params = this.getQueryParams();//-->
this.loading = true; <!-- this.loading = true;-->
console.log("----------------the params:", params); <!-- console.log("&#45;&#45;&#45;&#45;&#45;&#45;&#45;&#45;&#45;&#45;&#45;&#45;&#45;&#45;&#45;&#45;the params:", params);-->
getAction(this.url.list, params).then((res) => { <!-- getAction(this.url.list, params).then((res) => {-->
if (res.success) { <!-- if (res.success) {-->
this.dataSource = res.result.records || res.result; <!-- this.dataSource = res.result.records || res.result;-->
if (res.result.total) { <!-- if (res.result.total) {-->
this.ipagination.total = res.result.total; <!-- this.ipagination.total = res.result.total;-->
} else { <!-- } else {-->
this.ipagination.total = 0; <!-- this.ipagination.total = 0;-->
} <!-- }-->
} else { <!-- } else {-->
this.$message.warning(res.message) <!-- this.$message.warning(res.message)-->
} <!-- }-->
}).finally(() => { <!-- }).finally(() => {-->
// this.dataSource.forEach(item => { <!-- // this.dataSource.forEach(item => {-->
// item['stationName'] = this.stationName; <!-- // item['stationName'] = this.stationName;-->
// item['stationNum'] = this.stationNum; <!-- // item['stationNum'] = this.stationNum;-->
// }) <!-- // })-->
this.loading = false <!-- this.loading = false-->
}) <!-- })-->
}, <!-- },-->
getQueryParams() { <!-- getQueryParams() {-->
// <!-- //-->
let sqp = {} <!-- let sqp = {}-->
if (this.superQueryParams) { <!-- if (this.superQueryParams) {-->
sqp['superQueryParams'] = encodeURI(this.superQueryParams) <!-- sqp['superQueryParams'] = encodeURI(this.superQueryParams)-->
sqp['superQueryMatchType'] = this.superQueryMatchType <!-- sqp['superQueryMatchType'] = this.superQueryMatchType-->
} <!-- }-->
var param = Object.assign(sqp, this.queryParam, this.isorter, this.filters); <!-- var param = Object.assign(sqp, this.queryParam, this.isorter, this.filters);-->
param.field = this.getQueryField(); <!-- param.field = this.getQueryField();-->
param.pageNo = this.ipagination.current; <!-- param.pageNo = this.ipagination.current;-->
param.pageSize = this.ipagination.pageSize; <!-- param.pageSize = this.ipagination.pageSize;-->
param.planId = this.planId; <!-- param.planId = this.planId;-->
return filterObj(param); <!-- return filterObj(param);-->
}, <!-- },-->
// initDictConfig() { <!-- // initDictConfig() {-->
// }, <!-- // },-->
getSuperFieldList() { <!-- getSuperFieldList() {-->
// let fieldList = []; <!-- // let fieldList = [];-->
// fieldList.push({type: 'string', value: 'id', text: 'id', dictCode: ''}) <!-- // fieldList.push({type: 'string', value: 'id', text: 'id', dictCode: ''})-->
// fieldList.push({type: 'string', value: 'planId', text: 'id', dictCode: ''}) <!-- // fieldList.push({type: 'string', value: 'planId', text: 'id', dictCode: ''})-->
// fieldList.push({type: 'string', value: 'productName', text: 'id', dictCode: ''}) <!-- // fieldList.push({type: 'string', value: 'productName', text: 'id', dictCode: ''})-->
// fieldList.push({type: 'string', value: 'stationId', text: 'id', dictCode: ''}) <!-- // fieldList.push({type: 'string', value: 'stationId', text: 'id', dictCode: ''})-->
// fieldList.push({type: 'string', value: 'machineIds', text: 'id', dictCode: ''}) <!-- // fieldList.push({type: 'string', value: 'machineIds', text: 'id', dictCode: ''})-->
// fieldList.push({type: 'string', value: 'toolsIds', text: 'id', dictCode: ''}) <!-- // fieldList.push({type: 'string', value: 'toolsIds', text: 'id', dictCode: ''})-->
// fieldList.push({type: 'string', value: 'productProcessId', text: 'id', dictCode: ''}) <!-- // fieldList.push({type: 'string', value: 'productProcessId', text: 'id', dictCode: ''})-->
// fieldList.push({type: 'string', value: 'productProcessId', text: 'id', dictCode: ''}) <!-- // fieldList.push({type: 'string', value: 'productProcessId', text: 'id', dictCode: ''})-->
// fieldList.push({type: 'string', value: 'userIds', text: 'id', dictCode: ''}) <!-- // fieldList.push({type: 'string', value: 'userIds', text: 'id', dictCode: ''})-->
// this.superFieldList = fieldList <!-- // this.superFieldList = fieldList-->
}, <!-- },-->
// handleChange(value, key, column) { <!-- // handleChange(value, key, column) {-->
// const newData = [...this.data]; <!-- // const newData = [...this.data];-->
// const target = newData.find(item => key === item.key); <!-- // const target = newData.find(item => key === item.key);-->
// if (target) { <!-- // if (target) {-->
// target[column] = value; <!-- // target[column] = value;-->
// this.data = newData; <!-- // this.data = newData;-->
// } <!-- // }-->
// }, <!-- // },-->
edit(key) { <!-- edit(key) {-->
alert("the edit() record =" + JSON.stringify(key)) <!-- alert("the edit() record =" + JSON.stringify(key))-->
// const newData = [...this.data]; <!-- // const newData = [...this.data];-->
const newData = [...this.dataSource]; <!-- const newData = [...this.dataSource];-->
// const newData = record; <!-- // const newData = record;-->
console.log("the edit() newData =", JSON.stringify(newData)); <!-- console.log("the edit() newData =", JSON.stringify(newData));-->
// this.editingKey = '0'; <!-- // this.editingKey = '0';-->
// record.editable = true; <!-- // record.editable = true;-->
// const target = newData.find(item => key === item.key); <!-- // const target = newData.find(item => key === item.key);-->
const target = newData[0]; <!-- const target = newData[0];-->
console.log("the edit() target =", JSON.stringify(target)); <!-- console.log("the edit() target =", JSON.stringify(target));-->
this.editingKey = key; <!-- this.editingKey = key;-->
console.log("the edit() editingKey =", this.editingKey); <!-- console.log("the edit() editingKey =", this.editingKey);-->
if (target) { <!-- if (target) {-->
// debugger; <!-- // debugger;-->
target.editable = true; <!-- target.editable = true;-->
this.dataSource = newData; <!-- this.dataSource = newData;-->
} <!-- }-->
}, <!-- },-->
save(key) { <!-- save(key) {-->
// const newData = [...this.data]; <!-- // const newData = [...this.data];-->
const newData = this.dataSource; <!-- const newData = this.dataSource;-->
console.log("save() newData=", JSON.stringify(newData)) <!-- console.log("save() newData=", JSON.stringify(newData))-->
const newCacheData = [...this.cacheData]; <!-- const newCacheData = [...this.cacheData];-->
const target = newData.find(item => key === item.key); <!-- const target = newData.find(item => key === item.key);-->
const targetCache = newCacheData.find(item => key === item.key); <!-- const targetCache = newCacheData.find(item => key === item.key);-->
if (target && targetCache) { <!-- if (target && targetCache) {-->
delete target.editable; <!-- delete target.editable;-->
this.dataSource = newData; <!-- this.dataSource = newData;-->
Object.assign(targetCache, target); <!-- Object.assign(targetCache, target);-->
this.cacheData = newCacheData; <!-- this.cacheData = newCacheData;-->
} <!-- }-->
this.editingKey = ''; <!-- this.editingKey = '';-->
}, <!-- },-->
cancel(key) { <!-- cancel(key) {-->
const newData = this.dataSource; <!-- const newData = this.dataSource;-->
const target = newData.find(item => key === item.key); <!-- const target = newData.find(item => key === item.key);-->
this.editingKey = ''; <!-- this.editingKey = '';-->
if (target) { <!-- if (target) {-->
Object.assign(target, this.cacheData.find(item => key === item.key)); <!-- Object.assign(target, this.cacheData.find(item => key === item.key));-->
delete target.editable; <!-- delete target.editable;-->
this.dataSource = newData; <!-- this.dataSource = newData;-->
} <!-- }-->
}, <!-- },-->
}, <!-- },-->
}; <!--};-->
</script> <!--</script>-->
<style scoped> <!--<style scoped>-->
.editable-row-operations a { <!--.editable-row-operations a {-->
margin-right: 8px; <!-- margin-right: 8px;-->
} <!--}-->
</style> <!--</style>-->

@ -1,76 +1,27 @@
<template> <template>
<a-card :bordered="false"> <a-card :bordered="false">
<!-- 查询区域 -->
<div class="table-page-search-wrapper">
<a-form layout="inline" @keyup.enter.native="searchQuery">
<a-row :gutter="24">
</a-row>
</a-form>
</div>
<!-- 查询区域-END -->
<div class="table-operator"> <div class="table-operator">
<!-- <a-button @click="handleAdd" type="primary" icon="plus">新增</a-button>--> <a-button type="primary" icon="download" @click="handleExportXls('计划工序')">导出</a-button>
<!-- <a-button @click="zyStyleFabricHandleAdd(stationId)" type="primary" icon="plus">新增</a-button>--> <!-- <a-button type="primary" @click="handleTableSave($event)">保存</a-button>-->
<a-button type="primary" icon="download" @click="handleExportXls('1')">导出</a-button>
<a-button type="primary" @click="fanHui()">返回</a-button> <a-button type="primary" @click="fanHui()">返回</a-button>
</div> </div>
<!-- table区域-begin --> <!-- table区域-begin -->
<div> <div>
<!-- <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">--> <j-vxe-table
<!-- <i class="anticon anticon-info-circle ant-alert-icon"></i> 已选择 <a--> ref="xTable"
<!-- style="font-weight: 600">{{ selectedRowKeys.length }}</a>--> toolbar
<!-- <a style="margin-left: 24px" @click="onClearSelected">清空</a>--> :toolbarConfig="toolbarConfig"
<!-- </div>--> row-number
row-selection
<a-table keep-source
ref="table" :loading="loading"
size="middle"
:scroll="{x:true}"
bordered
rowKey="id"
:columns="columns" :columns="columns"
@selectRowChange="handleSelectRowChange"
:dataSource="dataSource" :dataSource="dataSource"
:pagination="ipagination" @save="handleTableSave"
:loading="loading" />
:rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}"
class="j-table-force-nowrap"
@change="handleTableChange">
<!-- <span slot="machineIds_dictText" slot-scope="text, record">-->
<span slot="groupMemberList" slot-scope="record,text">
<a-select mode="multiple"
@select="selectData($event,text)"
style="width: 220px"
placeholder="请选择">
<a-select-option v-for="item in record" :value="item.id">
{{ item.userId }}
</a-select-option>
</a-select>
</span>
<!-- <span slot="toolsList" slot-scope="toolsList">-->
<!-- <a-select style="width: 180px" placeholder="请选择">-->
<!-- <a-select-option v-for="item in toolsList" :value="item.id">-->
<!-- {{ item.name }}-->
<!-- </a-select-option>-->
<!-- </a-select>-->
<!-- </span>-->
<!-- <span slot="machineList" slot-scope="machineList">-->
<!-- <a-select style="width: 180px" placeholder="请选择">-->
<!-- <a-select-option v-for="item in machineList" :value="item.id">-->
<!-- {{ item.name }}-->
<!-- </a-select-option>-->
<!-- </a-select>-->
<!-- </span>-->
</a-table>
</div>
<div class="table-operator" style="text-align: right">
<a-button type="primary" @click="saveBatch">提交</a-button>
</div> </div>
<!-- <zy-plan-process-modal @valueChange="valueChange" ref="modalForm" @ok="modalFormOk"></zy-plan-process-modal>-->
</a-card> </a-card>
</template> </template>
@ -79,136 +30,88 @@
import '@/assets/less/TableExpand.less' import '@/assets/less/TableExpand.less'
import {mixinDevice} from '@/utils/mixin' import {mixinDevice} from '@/utils/mixin'
import {JeecgListMixin} from '@/mixins/JeecgListMixin' import {JeecgListMixin} from '@/mixins/JeecgListMixin'
import ZyPlanProcessModal from './modules/ZyPlanProcessModal2' import {getAction, postAction} from "@api/manage";
import {getAction, httpAction, downFile, postAction} from "@api/manage"; import {filterObj, pushIfNotExist, randomNumber, randomUUID} from "@/utils/util";
import {filterObj} from "@/utils/util"; import {JVXETypes} from '@/components/jeecg/JVxeTable'
export default { export default {
name: 'ZyPlanProcessList', name: 'ZyPlanProcessDataList',
mixins: [JeecgListMixin, mixinDevice], mixins: [JeecgListMixin, mixinDevice],
components: {
ZyPlanProcessModal
},
data() { data() {
return { return {
description: '生产计划班组管理页面', toolbarConfig: {
// // add remove clearSelection
btn: ['save']
},
description: '生产计划工序管理页面',
loading: false,
//
// pagination: {
// //
// current: 1,
// //
// pageSize: 10,
// //
// pageSizeOptions: ['10', '20', '30', '50'],
// // 0
// total: 0,
// },
//
// selectedRows: [],
//
dataSource: [],
// columns,
columns: [ columns: [
{ {key: 'workOrderId', title: '工单编号', width: '180px'},
title: '#', {key: 'productName', title: '产品名称', width: '180px'},
dataIndex: '', {key: 'departName', title: '车间名称', width: '180px'},
key: 'rowIndex', {key: 'processName', title: '工序名称', width: '180px'},
width: 60, {key: 'groupName', title: '班组名称', width: '180px'},
align: "center",
customRender: function (t, r, index) {
return parseInt(index) + 1;
}
},
// {
// title: 'id',
// align: "center",
// dataIndex: 'planId'
// },
{
title: '工单编号',
align: "center",
dataIndex: 'workOrderId'
},
{
title: '产品id',
align: "center",
dataIndex: 'productId'
},
{
title: '产品',
align: "center",
dataIndex: 'productName'
},
{
title: '车间',
align: "center",
dataIndex: 'departName'
},
{
title: '工序',
align: "center",
dataIndex: 'processName'
},
{ {
title: '班组成员', title: '班组成员',
align: "center", key: 'userIds',
dataIndex: 'groupMemberList', type: JVXETypes.selectMultiple,
width: 150, width: '200px',
scopedSlots: {customRender: 'groupMemberList'} options: [],
placeholder: '请选择${title}',
}, },
// {
// title: '',
// align: "center",
// dataIndex: 'toolsList',
// width: 150,
// scopedSlots: {customRender: 'toolsList'}
// // scopedSlots: {customRender: this.toolsList}
// },
// {
// title: '',
// align: "center",
// dataIndex: 'machineList',
// width: 150,
// scopedSlots: {customRender: 'machineList'}
// },
{
title: '操作',
dataIndex: 'action',
align: "center",
fixed: "right",
width: 147,
scopedSlots: {customRender: 'action'}
}
], ],
url: { url: {
list: "/org.jeecg.modules.productplan/zyPlanProcess/getTeamDatalist", list: "/org.jeecg.modules.productplan/zyPlanProcess/getTeamDatalist",
// getTeamDatalistByPlanId: "/org.jeecg.modules.productplan/zyPlanProcess/getTeamDatalistByPlanId", // addProcessBatch: "/org.jeecg.modules.productplan/zyPlanProcess/addProcessBatch",
groupMemberlist: "/groupxMember/list", updateTeamBatch: "/org.jeecg.modules.productplan/zyPlanProcess/addTeamBatch",
addTeamBatch: "/org.jeecg.modules.productplan/zyPlanProcess/addTeamBatch",
// stationMachinelist: "/stationMachine/list",
// productPlanlist: "/org.jeecg.modules.productplan/zyProductPlan/list",
delete: "/org.jeecg.modules.productplan/zyPlanProcess/delete",
// deleteBatch: "/org.jeecg.modules.productplan/zyPlanProcess/deleteBatch",
// exportXlsUrl: "/org.jeecg.modules.productplan/zyPlanProcess/exportXls",
// importExcelUrl: "org.jeecg.modules.productplan/zyPlanProcess/importExcel",
}, },
loadRouteType: false, loadRouteType: false,
planId: "", planId: "",
dictOptions: {}, groupMemberList: [],
superFieldList: [], clickTrue: true,
toolsList: [],
machineList: [],
processIds: [],
memberIds: [],
} }
}, },
created() { created() {
this.getSuperFieldList();
// this.model = Object.assign({}, record);
},
computed: {
importExcelUrl: function () {
return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`;
},
}, },
methods: { methods: {
saveBatch() { //
// alert("") handleTableSave({$table, target}) {
postAction(this.url.addTeamBatch, this.processIds).then((res) => { console.log("保存开始-----")
if (res.success) { //
this.$message.success(res.message) $table.validate().then((errMap) => {
this.$emit('ok') //
this.close() if (!errMap) {
} else { //
this.$message.warning(res.message) let tableData = target.getTableData()
console.log('当前保存的数据是:', tableData)
//
this.loading = true
postAction(this.url.updateTeamBatch, tableData).then(res => {
if (res.success) {
this.$message.success(`保存成功!`)
} else {
this.$message.warn(`保存失败:` + res.message)
}
}).finally(() => {
this.loading = false
})
} }
}).finally(() => {
this.confirmLoading = false
}) })
}, },
fanHui() { fanHui() {
@ -216,16 +119,7 @@ export default {
path: '/productplan/ZyPlanTeamList', path: '/productplan/ZyPlanTeamList',
}); });
}, },
//$eventkey
selectData($event, row) {
console.log("group_member key $event=" + $event);
// console.log("group_member key row=" + JSON.stringify(row));
console.log("productProcessId=" + JSON.stringify(row.productProcessId));
this.processIds.push({"processId": row.productProcessId, "userIds": $event});
// for (var i = 0; i < processIds.length; i++) {
console.log("the processIds length:" + this.processIds.length);
},
// //
loadParameter() { loadParameter() {
if (this.loadRouteType === false) { if (this.loadRouteType === false) {
@ -236,14 +130,16 @@ export default {
} }
}, },
loadData(arg) { loadData(arg) {
console.log("the loadData---------开始");
// var that = this;
if (!this.url.list) { if (!this.url.list) {
this.$message.error("请设置url.list属性!") this.$message.error("请设置url.list属性!")
return return
} }
// 1 // 1
if (arg === 1) { // if (arg === 1) {
this.ipagination.current = 1; // this.ipagination.current = 1;
} // }
this.loadParameter(); this.loadParameter();
var params = this.getQueryParams();// var params = this.getQueryParams();//
this.loading = true; this.loading = true;
@ -251,19 +147,12 @@ export default {
getAction(this.url.list, params).then((res) => { getAction(this.url.list, params).then((res) => {
if (res.success) { if (res.success) {
this.dataSource = res.result.records || res.result; this.dataSource = res.result.records || res.result;
if (res.result.total) { this.groupMemberList = this.dataSource[0].groupMemberList;
this.ipagination.total = res.result.total;
} else {
this.ipagination.total = 0;
}
} else { } else {
// this.stationIdCode = "station,station_name,id,depart_id in (select workshop_id from zy_product_plan where id='" + this.planId + "')";
this.$message.warning(res.message) this.$message.warning(res.message)
} }
}).finally(() => { }).finally(() => {
// this.dataSource.forEach(item => {
// item['stationName'] = this.stationName;
// item['stationNum'] = this.stationNum;
// })
this.loading = false this.loading = false
}) })
}, },
@ -281,51 +170,15 @@ export default {
param.planId = this.planId; param.planId = this.planId;
return filterObj(param); return filterObj(param);
}, },
// initDictConfig() {
// },
getSuperFieldList() {
let fieldList = [];
fieldList.push({type: 'string', value: 'planId', text: '生产计划id', dictCode: ''})
fieldList.push({type: 'string', value: 'stationId', text: '工位id', dictCode: ''})
fieldList.push({type: 'string', value: 'machineIds', text: '设备id列表', dictCode: ''})
fieldList.push({type: 'string', value: 'toolsIds', text: '工具id列表', dictCode: ''})
fieldList.push({type: 'string', value: 'processIds', text: '工序id列表', dictCode: ''})
fieldList.push({type: 'string', value: 'userIds', text: '成员id列表', dictCode: ''})
this.superFieldList = fieldList
},
// jumpPage1(record) {
// this.$router.push({
// // path: '/productplan/ZyProductPlanList',
// path: '/productplan/ZyPlanProcessDataList',
//
// // query: { //
// // 'stationId': record.id,
// // 'stationName': record.stationName,
// // },
// });
// },
// pf(record) {
// this.$router.push({
// path: '/productplan/ZyPlanProcessAddList',
// query: { //
// }
// });
// getAction("productPlanlist", {id: record.id}).then((res) => { //
// if (res.success) { handleSelectRowChange(event) {
// this.$router.push({ console.log("handleSelectRowChange-event:", event)
// path: '/src/views/processassessment/assessmentCourse/ClassOpeningTaskList', const {type, row, column, value, target, $table} = event
// query: { // console.log("groupMemberList-----------", JSON.stringify(this.groupMemberList));
// } // target.$refs.vxe.columns[6].dictCode = this.stationIdCode;
// }); target.$refs.vxe.columns[7].options = this.groupMemberList;
// } else { },
// this.$message.error(res.message) },
// } };
// });
// },
}
}
</script> </script>
<style scoped>
@import '~@assets/less/common.less';
</style>

@ -86,7 +86,7 @@ public class ZyPlanProcess implements Serializable {
*/ */
@Excel(name = "设备id列表", width = 15) @Excel(name = "设备id列表", width = 15)
@ApiModelProperty(value = "设备id列表") @ApiModelProperty(value = "设备id列表")
@Dict(dictTable = "zy_devicetype", dicText = "name", dicCode = "id") @Dict(dictTable = "zy_device", dicText = "name", dicCode = "id")
private String machineIds; private String machineIds;
/** /**
* 工具id列表 * 工具id列表
@ -100,7 +100,7 @@ public class ZyPlanProcess implements Serializable {
*/ */
@Excel(name = "成员id列表", width = 15) @Excel(name = "成员id列表", width = 15)
@ApiModelProperty(value = "成员id列表") @ApiModelProperty(value = "成员id列表")
@Dict(dictTable = "groupx_member", dicText = "user_id", dicCode = "id") @Dict(dictTable = "sys_user", dicText = "realname", dicCode = "id")
private String userIds; private String userIds;
/** /**
@ -108,12 +108,14 @@ public class ZyPlanProcess implements Serializable {
*/ */
@Excel(name = "前导工序", width = 15) @Excel(name = "前导工序", width = 15)
@ApiModelProperty(value = "前导工序") @ApiModelProperty(value = "前导工序")
@Dict(dictTable = "zy_process", dicText = "process_name", dicCode = "id")
private String proProcess; private String proProcess;
/** /**
* 后导工序 * 后导工序
*/ */
@Excel(name = "后导工序", width = 15) @Excel(name = "后导工序", width = 15)
@ApiModelProperty(value = "后导工序") @ApiModelProperty(value = "后导工序")
@Dict(dictTable = "zy_process", dicText = "process_name", dicCode = "id")
private String postProcess; private String postProcess;
/** /**
* 输入产品 * 输入产品

@ -4,6 +4,7 @@ import lombok.Data;
import lombok.EqualsAndHashCode; import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors; import lombok.experimental.Accessors;
import org.jeecg.modules.team.entity.GroupxMember; import org.jeecg.modules.team.entity.GroupxMember;
import org.jeecg.modules.team.vo.GroupxMemeberVo;
import org.jeecg.modules.team.vo.StationVo; import org.jeecg.modules.team.vo.StationVo;
import java.io.Serializable; import java.io.Serializable;
@ -16,7 +17,7 @@ public class ProcessDataVo implements Serializable {
private static final long serialVersionUID = 1009888L; private static final long serialVersionUID = 1009888L;
// private String id; // private String id;
//工单id //工单id
private String workOrderId; private String workOrderId;
@ -34,8 +35,10 @@ public class ProcessDataVo implements Serializable {
//工位 //工位
private List<StationVo> stationList; private List<StationVo> stationList;
private String groupName;
//班组成员列表 //班组成员列表
private List<GroupxMember> groupMemberList; private List<GroupxMemeberVo> groupMemberList;
//产品工序id //产品工序id
// @Dict(dictTable ="zy_process",dicText = "process_name",dicCode = "id") // @Dict(dictTable ="zy_process",dicText = "process_name",dicCode = "id")

@ -3,6 +3,7 @@ package org.jeecg.modules.productplan.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.apache.commons.lang3.StringUtils;
import org.jeecg.common.exception.JeecgBootException; import org.jeecg.common.exception.JeecgBootException;
import org.jeecg.modules.demo.base.service.IZyProcessService; import org.jeecg.modules.demo.base.service.IZyProcessService;
import org.jeecg.modules.product.zyproductprocess.entity.ZyProductProcess; import org.jeecg.modules.product.zyproductprocess.entity.ZyProductProcess;
@ -14,11 +15,15 @@ import org.jeecg.modules.productplan.mapper.ZyPlanProcessMapper;
import org.jeecg.modules.productplan.service.IZyPlanProcessService; import org.jeecg.modules.productplan.service.IZyPlanProcessService;
import org.jeecg.modules.productplan.service.IZyProductPlanService; import org.jeecg.modules.productplan.service.IZyProductPlanService;
import org.jeecg.modules.system.entity.SysDepart; import org.jeecg.modules.system.entity.SysDepart;
import org.jeecg.modules.system.entity.SysUser;
import org.jeecg.modules.system.service.ISysDepartService; import org.jeecg.modules.system.service.ISysDepartService;
import org.jeecg.modules.system.service.ISysUserService;
import org.jeecg.modules.team.entity.GroupxMember; import org.jeecg.modules.team.entity.GroupxMember;
import org.jeecg.modules.team.entity.Station; import org.jeecg.modules.team.entity.Station;
import org.jeecg.modules.team.service.IGroupxMemberService; import org.jeecg.modules.team.service.IGroupxMemberService;
import org.jeecg.modules.team.service.IGroupxService;
import org.jeecg.modules.team.service.IStationService; import org.jeecg.modules.team.service.IStationService;
import org.jeecg.modules.team.vo.GroupxMemeberVo;
import org.jeecg.modules.team.vo.StationVo; import org.jeecg.modules.team.vo.StationVo;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
@ -27,6 +32,8 @@ import org.springframework.util.ObjectUtils;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.List; import java.util.List;
import static com.sun.tools.internal.xjc.reader.Ring.add;
/** /**
* @Description: 生产计划工序 * @Description: 生产计划工序
* @Author: jeecg-boot * @Author: jeecg-boot
@ -47,10 +54,15 @@ public class ZyPlanProcessServiceImpl extends ServiceImpl<ZyPlanProcessMapper, Z
@Autowired @Autowired
private ISysDepartService iSysDepartService; private ISysDepartService iSysDepartService;
@Autowired @Autowired
private ISysUserService iSysUserService;
@Autowired
private IZyProcessService iZyProcessService; private IZyProcessService iZyProcessService;
@Autowired @Autowired
private IGroupxMemberService iGroupxMemberService; private IGroupxMemberService iGroupxMemberService;
@Autowired
private IGroupxService iGroupxService;
public List<ProcessDataVo> getProcessDatalist(ZyPlanProcess zyPlanProcess) { public List<ProcessDataVo> getProcessDatalist(ZyPlanProcess zyPlanProcess) {
//生产计划id //生产计划id
@ -59,35 +71,35 @@ public class ZyPlanProcessServiceImpl extends ServiceImpl<ZyPlanProcessMapper, Z
if (ObjectUtils.isEmpty(zyPlanProcess)) { if (ObjectUtils.isEmpty(zyPlanProcess)) {
throw new JeecgBootException("生产计划不存在!"); throw new JeecgBootException("生产计划不存在!");
} }
//工单id //工单id
String productCode = zyProductPlan.getProductCode(); String productCode = zyProductPlan.getProductCode();
String departId = zyProductPlan.getWorkshopId(); String departId = zyProductPlan.getWorkshopId();
// TODO zy_product产品表,根据工单id获取产品id, // TODO zy_product产品表,根据工单id获取产品id,
List<ProcessDataVo> result = new LinkedList<>(); List<ProcessDataVo> result = new LinkedList<>();
//根据产品id获取产品工序列表
// List<ZyProductProcess> productProcessesList = iZyProductProcessService.list(new LambdaQueryWrapper<ZyProductProcess>().eq(ZyProductProcess::getProductId, "产品id"));
List<ZyProductProcess> productProcessesList = iZyProductProcessService.list(new LambdaQueryWrapper<ZyProductProcess>().eq(ZyProductProcess::getProductId, "1"));
if (!ObjectUtils.isEmpty(productProcessesList)) {
SysDepart depart = iSysDepartService.getById(departId);
List<Station> stationList = iStationService.list(new LambdaQueryWrapper<Station>().eq(Station::getDepartId, departId));
List<StationVo> stationVoList = new LinkedList<>();
if (!ObjectUtils.isEmpty(stationList)) {
stationList.forEach(en -> {
StationVo stationVo = new StationVo();
stationVo.setId(en.getId());
stationVo.setValue(en.getId());
stationVo.setText(en.getStationName());
stationVo.setTitle(en.getStationName());
stationVoList.add(stationVo);
});
}
productProcessesList.forEach(e -> { SysDepart depart = iSysDepartService.getById(departId);
List<Station> stationList = iStationService.list(new LambdaQueryWrapper<Station>().eq(Station::getDepartId, departId));
List<StationVo> stationVoList = new LinkedList<>();
if (!ObjectUtils.isEmpty(stationList)) {
stationList.forEach(en -> {
StationVo stationVo = new StationVo();
stationVo.setId(en.getId());
stationVo.setValue(en.getId());
stationVo.setText(en.getStationName());
stationVo.setTitle(en.getStationName());
stationVoList.add(stationVo);
});
}
List<ZyPlanProcess> planProcessList = this.list(new LambdaQueryWrapper<ZyPlanProcess>().eq(ZyPlanProcess::getPlanId, planId));
//TODO暂定有一条数据时,查询产品工序记录,多条时说明已定制计划工序
if (!ObjectUtils.isEmpty(planProcessList) && planProcessList.size() > 1) {
planProcessList.forEach(e -> {
ProcessDataVo vo = new ProcessDataVo(); ProcessDataVo vo = new ProcessDataVo();
vo.setPlanId(planId); vo.setPlanId(planId);
vo.setProcessId(e.getProcessId()); vo.setProcessId(e.getProcessId());
vo.setProcessName(iZyProcessService.getById(e.getProcessId()).getProcessName()); vo.setProcessName(iZyProcessService.getById(e.getProcessId()).getProcessName());
vo.setProductId(e.getProductId());
vo.setProductName("产品名称"); vo.setProductName("产品名称");
vo.setWorkOrderId(productCode); vo.setWorkOrderId(productCode);
vo.setDepartId(departId); vo.setDepartId(departId);
@ -95,6 +107,25 @@ public class ZyPlanProcessServiceImpl extends ServiceImpl<ZyPlanProcessMapper, Z
vo.setStationList(stationVoList); vo.setStationList(stationVoList);
result.add(vo); result.add(vo);
}); });
} else {
//根据产品id获取产品工序列表
// List<ZyProductProcess> productProcessesList = iZyProductProcessService.list(new LambdaQueryWrapper<ZyProductProcess>().eq(ZyProductProcess::getProductId, "产品id"));
List<ZyProductProcess> productProcessesList = iZyProductProcessService.list(new LambdaQueryWrapper<ZyProductProcess>().eq(ZyProductProcess::getProductId, "1"));
if (!ObjectUtils.isEmpty(productProcessesList)) {
productProcessesList.forEach(e -> {
ProcessDataVo vo = new ProcessDataVo();
vo.setPlanId(planId);
vo.setProcessId(e.getProcessId());
vo.setProcessName(iZyProcessService.getById(e.getProcessId()).getProcessName());
vo.setProductId(e.getProductId());
vo.setProductName("产品名称");
vo.setWorkOrderId(productCode);
vo.setDepartId(departId);
vo.setDepartName(depart.getDepartName());
vo.setStationList(stationVoList);
result.add(vo);
});
}
} }
return result; return result;
} }
@ -118,18 +149,31 @@ public class ZyPlanProcessServiceImpl extends ServiceImpl<ZyPlanProcessMapper, Z
if (!ObjectUtils.isEmpty(productProcessesList)) { if (!ObjectUtils.isEmpty(productProcessesList)) {
SysDepart depart = iSysDepartService.getById(departId); SysDepart depart = iSysDepartService.getById(departId);
List<GroupxMember> groupxMemberList = iGroupxMemberService.list(new LambdaQueryWrapper<GroupxMember>().eq(GroupxMember::getGroupxId, zyProductPlan.getTeamId())); List<GroupxMember> groupxMemberList = iGroupxMemberService.list(new LambdaQueryWrapper<GroupxMember>().eq(GroupxMember::getGroupxId, zyProductPlan.getTeamId()));
List<GroupxMemeberVo> groupxMemberVoList = new LinkedList<>();
if (!ObjectUtils.isEmpty(groupxMemberList)) {
groupxMemberList.forEach(en -> {
GroupxMemeberVo memeberVo = new GroupxMemeberVo();
memeberVo.setId(en.getId());
memeberVo.setValue(en.getUserId());
SysUser sysUser = iSysUserService.getById(en.getUserId());
memeberVo.setText(StringUtils.isNotBlank(sysUser.getRealname()) ? sysUser.getRealname() : "");
memeberVo.setTitle(StringUtils.isNotBlank(sysUser.getRealname()) ? sysUser.getRealname() : "");
groupxMemberVoList.add(memeberVo);
});
}
productProcessesList.forEach(e -> { productProcessesList.forEach(e -> {
ProcessDataVo vo = new ProcessDataVo(); ProcessDataVo vo = new ProcessDataVo();
vo.setPlanId(planId); vo.setPlanId(planId);
vo.setProcessId(e.getProcessId()); vo.setProcessId(e.getProcessId());
vo.setProcessName(iZyProcessService.getById(e.getProcessId()).getProcessName()); vo.setProcessName(iZyProcessService.getById(e.getProcessId()).getProcessName());
vo.setProductId(e.getProductId()); vo.setProductId(e.getProductId());
// vo.setProductName("产品名称") vo.setProductName("产品名称");
vo.setWorkOrderId(productCode); vo.setWorkOrderId(productCode);
vo.setDepartId(departId); vo.setDepartId(departId);
vo.setDepartName(depart.getDepartName()); vo.setDepartName(depart.getDepartName());
// vo.setStationList(stationList); vo.setGroupMemberList(groupxMemberVoList);
vo.setGroupMemberList(groupxMemberList); vo.setGroupName(iGroupxService.getById(zyProductPlan.getTeamId()).getGroupName());
result.add(vo); result.add(vo);
}); });
} }

@ -46,7 +46,7 @@ public class GroupxMember {
*/ */
@Excel(name = "用户id FK 用户表", width = 15) @Excel(name = "用户id FK 用户表", width = 15)
@ApiModelProperty(value = "用户id FK 用户表") @ApiModelProperty(value = "用户id FK 用户表")
// @Dict(dictTable = "sys_user", dicText = "realname", dicCode = "id") @Dict(dictTable = "sys_user", dicText = "realname", dicCode = "id")
private String userId; private String userId;
@TableField(exist = false) @TableField(exist = false)

@ -0,0 +1,16 @@
package org.jeecg.modules.team.vo;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class GroupxMemeberVo {
private String id;
private String value;
private String text;
private String title;
}

@ -0,0 +1,16 @@
package org.jeecg.modules.team.vo;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class GroupxVo {
private String id;
private String value;
private String text;
private String title;
}
Loading…
Cancel
Save