| | |
| | | * @version: |
| | | * @Date: 2024-06-19 20:34:27 |
| | | * @LastEditors: Ben Lin |
| | | * @LastEditTime: 2024-08-04 01:13:27 |
| | | * @LastEditTime: 2024-09-23 01:57:24 |
| | | */ |
| | | |
| | | import { Ref, h, ref, render, unref } from 'vue'; |
| | |
| | | RouteToCust, |
| | | RouteToProd, |
| | | } from '/@/api/tigerapi/mes/router'; |
| | | import { |
| | | GetEnum, |
| | | SaveEntity, |
| | | convertToTree, |
| | | getEntity, |
| | | } from '/@/api/tigerapi/system'; |
| | | import { GetEnum, SaveEntity, convertToTree, getEntity } from '/@/api/tigerapi/system'; |
| | | import { useLocale } from '/@/locales/useLocale'; |
| | | import { isNullOrEmpty, isNullOrUnDef } from '/@/utils/is'; |
| | | import { useI18n } from '/@/hooks/web/useI18n'; |
| | |
| | | * @return {*} |
| | | */ |
| | | GetHomeUrl: () => { |
| | | return `/V_BAS_PROD/LC/${encodeURI(JSON.stringify({ ID: 'V_BAS_PROD', colSlots: [], crudColSlots: [] }))}`; |
| | | return `/V_BAS_PROD_R/LC/${encodeURI(JSON.stringify({ ID: 'V_BAS_PROD_R', colSlots: [], crudColSlots: [] }))}`; |
| | | }, |
| | | /** |
| | | * @description: 获取树形数据 |
| | |
| | | case 'Node': |
| | | form = nodeFormShema; |
| | | break; |
| | | case 'BAS_PKG_DTL': |
| | | default: |
| | | form = crudForms[type]; |
| | | break; |
| | | break; |
| | | } |
| | | return form; |
| | | }, |
| | |
| | | * @return {*} |
| | | */ |
| | | GetCrudColSlots: () => { |
| | | return ['scanadd', 'assyadd', 'testadd', 'auditadd', 'printadd', 'pkgadd']; |
| | | return [ |
| | | { name: 'scanadd', icon: 'search|svg' }, |
| | | { name: 'assyadd', icon: 'search|svg' }, |
| | | { name: 'testadd', icon: 'search|svg' }, |
| | | { name: 'auditadd', icon: 'search|svg' }, |
| | | { name: 'printadd', icon: 'search|svg' }, |
| | | { name: 'pkgadd', icon: 'search|svg' }, |
| | | { name: 'labeladd', icon: 'search|svg' }, |
| | | ]; |
| | | }, |
| | | /** |
| | | * @description: 切换节点时事件方法 |
| | |
| | | nodeChange: (params: { useForms: Ref<any>; objParams: Ref<any>; selectedNodes: any[] }) => |
| | | new Promise<any>(async (resolve, reject) => { |
| | | // params['useForms'].value = methods.GetUseForm(); |
| | | let result = {}; |
| | | let result = { isShow: {} }; |
| | | let sqlcmd = ' 1=1 '; |
| | | if (!isNullOrEmpty(params['objParams'].value['CODE'])) { |
| | | sqlcmd += `And PROD_CODE = '${params['objParams'].value['CODE']}'`; |
| | |
| | | PROD_CODE: params['objParams'].value['CODE'], |
| | | ACT_TYPE: res.Data.Items[0].ACT_TYPE, |
| | | CUST_CODE: params['selectedNodes'][0].cust, |
| | | OPTION_1: res.Data.Items[0].OPTION_1, |
| | | OPTION_2: res.Data.Items[0].OPTION_2, |
| | | }); |
| | | result['isShow'] = isNullOrEmpty(res.Data.Items[0].PKG_CODE) ? false : true; |
| | | const ents = await getEntity({ |
| | | sqlcmd: `RULE_CODE ='${res.Data.Items[0].PKG_CODE}'`, |
| | | entityName: 'V_BAS_PKG_DTL', |
| | | order: '', |
| | | }); |
| | | result['Table'] = ents.Data.Items; |
| | | /* 如果是包装规则 */ |
| | | if (res.Data.Items[0].ACT_TYPE == 6) { |
| | | result['name'] = 'BAS_PKG_DTL'; |
| | | result['isShow'] = { |
| | | BAS_PKG_DTL: isNullOrEmpty(res.Data.Items[0].PKG_CODE) ? false : true, |
| | | ItemCode: false, |
| | | }; |
| | | const ents = await getEntity({ |
| | | sqlcmd: `RULE_CODE ='${res.Data.Items[0].PKG_CODE}'`, |
| | | entityName: 'V_BAS_PKG_DTL', |
| | | order: '', |
| | | }); |
| | | result['BAS_PKG_DTL'] = isNullOrEmpty(res.Data.Items[0].OPTION_1) |
| | | ? ents.Data.Items |
| | | : JSON.parse(res.Data.Items[0].OPTION_1); |
| | | /* 如果OPTION_1字段为空就把包装信息转JSON存到OPTION_1字段 */ |
| | | res.Data.Items[0].OPTION_1 = isNullOrEmpty(res.Data.Items[0].OPTION_1) |
| | | ? JSON.stringify(ents.Data.Items) |
| | | : res.Data.Items[0].OPTION_1; |
| | | } /* 如果是组装上料 */ |
| | | if (res.Data.Items[0].ACT_TYPE == 2) { |
| | | result['name'] = 'ItemCode'; |
| | | result['ItemCode'] = JSON.parse(res.Data.Items[0].OPTION_1); |
| | | result['isShow'] = { |
| | | BAS_PKG_DTL: false, |
| | | ItemCode: true, |
| | | }; |
| | | } |
| | | result['Action'] = res.Data.Items; |
| | | } |
| | | if (params['selectedNodes'][0].type == 'Node') { |
| | | resetFieldsNode(); |
| | |
| | | PROD_CODE: params['objParams'].value['CODE'], |
| | | CUST_CODE: params['selectedNodes'][0].cust, |
| | | }); |
| | | // result['Node'] = res.Data.Items; |
| | | result['name'] = 'Node'; |
| | | result['isShow'] = { |
| | | BAS_PKG_DTL: false, |
| | | ItemCode: false, |
| | | }; |
| | | } |
| | | resolve(result); |
| | | } catch (e) { |
| | |
| | | value: { |
| | | RULE_CODE: d.values['val'], |
| | | }, |
| | | isShow: false, |
| | | isShow: { BAS_PKG_DTL: false, ItemCode: false }, |
| | | }; |
| | | break; |
| | | case 'assyadd': |
| | | const items = d.values['val'].split(','); |
| | | let data: any[] = []; |
| | | if (!isNullOrEmpty(items) && items.length > 0) { |
| | | items.map((x) => { |
| | | data.push({ |
| | | ITEM_CODE: x, |
| | | RULE_CODE: '', |
| | | IsBatchItem: 'N', |
| | | QTY: 1, |
| | | }); |
| | | }); |
| | | } |
| | | value = { |
| | | value: { |
| | | ITEM_CODE: d.values['val'], |
| | | }, |
| | | isShow: false, |
| | | isShow: { BAS_PKG_DTL: false, ItemCode: true }, |
| | | data: data, |
| | | name: 'ItemCode', |
| | | }; |
| | | break; |
| | | case 'printadd': |
| | |
| | | value: { |
| | | LABEL_CODE: d.values['val'], |
| | | }, |
| | | isShow: false, |
| | | isShow: { BAS_PKG_DTL: false, ItemCode: false }, |
| | | }; |
| | | break; |
| | | case 'pkgadd': |
| | |
| | | value: { |
| | | PKG_CODE: d.values['val'], |
| | | }, |
| | | isShow: true, |
| | | isShow: { BAS_PKG_DTL: true, ItemCode: false }, |
| | | data: ents.Data.Items, |
| | | name: 'BAS_PKG_DTL', |
| | | }; |
| | | break; |
| | | case 'addRoute': |
| | |
| | | }; |
| | | }, |
| | | /** |
| | | * @description: 获取表格use列表 |
| | | * @description: 获取表格use列表,这里跟主页面传过来的OtherTableName: ['BAS_PKG_DTL', 'ItemCode']内的名称是一致的。 |
| | | * @param {string} type |
| | | * @param {array} args |
| | | * @return {*} |
| | |
| | | GetUseTables: (data: Ref<{}>, ...args) => { |
| | | // data.value['Table'] = []; |
| | | return { |
| | | Table: useTable({ |
| | | BAS_PKG_DTL: useTable({ |
| | | title: '列表信息', |
| | | // api: getListByPage, |
| | | // searchInfo: { TABLE_NAME: 'V_BAS_PKG_DTL' }, |
| | | dataSource: data.value['Table'], |
| | | columns: GetBaseColumns('', args[0], data), |
| | | dataSource: data.value['BAS_PKG_DTL'], |
| | | columns: GetBaseColumns('BAS_PKG_DTL', args[0], data), |
| | | maxHeight: 520, |
| | | useSearchForm: false, |
| | | showTableSetting: false, |
| | | bordered: true, |
| | | canResize: true, |
| | | showIndexColumn: false, |
| | | // rowSelection: { |
| | | // type: 'radio', //'checkbox' |
| | | // }, |
| | | actionColumn: { |
| | | width: 100, |
| | | title: '操作', |
| | | dataIndex: 'action', |
| | | slots: { customRender: 'action' }, |
| | | fixed: 'right', |
| | | }, //自定义操作列 |
| | | }), |
| | | ItemCode: useTable({ |
| | | title: '列表信息', |
| | | // api: getListByPage, |
| | | // searchInfo: { TABLE_NAME: 'V_BAS_PKG_DTL' }, |
| | | dataSource: data.value['ItemCode'], |
| | | columns: GetBaseColumns('ItemCode', args[0], data), |
| | | maxHeight: 520, |
| | | useSearchForm: false, |
| | | showTableSetting: false, |
| | |
| | | * @param {string} type |
| | | * @return {*} |
| | | */ |
| | | GetTitle: (type: string) => { |
| | | GetTitle: (type: string, item) => { |
| | | return { |
| | | configTitle: type == 'Action' ? '行为配置' : '工序配置', |
| | | navTitle: type == 'Product' ? '添加工艺路线' : '工艺路线维护', |
| | | tableTitle: type == 'Action' ? '包装层级列表' : '', |
| | | tableTitle: type == 'Action' ? (item == 'ItemCode' ? '上料列表' : '包装层级列表') : '', |
| | | }; |
| | | }, |
| | | /** |
| | |
| | | showNav: false, |
| | | type: selectedNodes.value[0].type, |
| | | nodes: selectedNodes.value, |
| | | showOtherTable: false, |
| | | showOtherTable: { BAS_PKG_DTL: false, ItemCode: false }, |
| | | }; |
| | | if (isNullOrUnDef(selectedNodes.value)) { |
| | | return result; |
| | |
| | | if (selectedNodes.value[0].type == 'Product' || selectedNodes.value[0].type == 'Route') { |
| | | result.showNav = true; |
| | | result.showConfig = false; |
| | | result.showOtherTable = false; |
| | | result.showOtherTable = { BAS_PKG_DTL: false, ItemCode: false }; |
| | | } |
| | | if (selectedNodes.value[0].type == 'Action' || selectedNodes.value[0].type == 'Node') { |
| | | result.showNav = false; |
| | | result.showConfig = true; |
| | | if (selectedNodes.value[0].type == 'Action') { |
| | | result.showOtherTable = true; |
| | | result.showOtherTable = { BAS_PKG_DTL: false, ItemCode: false }; |
| | | } else { |
| | | result.showOtherTable = false; |
| | | result.showOtherTable = { BAS_PKG_DTL: false, ItemCode: false }; |
| | | } |
| | | } |
| | | return result; |
| | |
| | | }); |
| | | break; |
| | | case 'editRoute': |
| | | args[1](true, { rotId: args[2][0].id, slotName: '' }); |
| | | args[1](true, { |
| | | rotId: args[2][0].id, |
| | | slotName: '', |
| | | prodCode: args[3], |
| | | custCode: args[2][0].cust, |
| | | }); |
| | | break; |
| | | } |
| | | }, |
| | |
| | | * @param {array} args |
| | | * @return {*} |
| | | */ |
| | | CustFunc: async (param: CustModalParams, ...args) => { |
| | | if (param.ctype == 'BAS_PKG_DTL') { |
| | | let useTables = args[0]; |
| | | const ents = await getEntity({ |
| | | sqlcmd: `PKG_RULE_ID ='${param.values['PKG_RULE_ID']}'`, |
| | | entityName: 'V_BAS_PKG_DTL', |
| | | order: '', |
| | | }); |
| | | param.data.value['Table'] = ents.Data.Items; |
| | | CustFunc: async (param: CustModalParams) => { |
| | | switch (param['ctype']) { |
| | | case 'BAS_PKG_DTL': |
| | | // const ents = await getEntity({ |
| | | // sqlcmd: `PKG_RULE_ID ='${param.values['PKG_RULE_ID']}'`, |
| | | // entityName: 'V_BAS_PKG_DTL', |
| | | // order: '', |
| | | // }); |
| | | // param.data.value['Table'] = ents.Data.Items; |
| | | param.data.value['BAS_PKG_DTL'].map((x) => { |
| | | if (x.PKG_CODE == param.values['PKG_CODE']) { |
| | | x.LABEL_CODE = param.values['LABEL_CODE']; |
| | | } |
| | | }); |
| | | param.data.value['Action'][0]['OPTION_1'] = JSON.stringify( |
| | | param.data.value['BAS_PKG_DTL'], |
| | | ); |
| | | break; |
| | | case 'ItemCode': |
| | | param.data.value['ItemCode'].map((x) => { |
| | | if (x.ITEM_CODE == param.values['ITEM_CODE']) { |
| | | x.IsBatchItem = param.values['IsBatchItem']; |
| | | x.RULE_CODE = param.values['RULE_CODE']; |
| | | } |
| | | }); |
| | | param.data.value['Action'][0]['OPTION_1'] = JSON.stringify(param.data.value['ItemCode']); |
| | | break; |
| | | } |
| | | }, |
| | | /** |
| | |
| | | * @return {*} |
| | | */ |
| | | function GetBaseColumns(type: string, emit, data: Ref<{}>) { |
| | | columns = [ |
| | | { |
| | | dataIndex: 'PKG_RULE_ID', |
| | | title: '包装规则ID', |
| | | ifShow: false, |
| | | sorter: true, |
| | | resizable: true, |
| | | }, |
| | | { |
| | | dataIndex: 'PKG_CODE', |
| | | title: '包装编码', |
| | | ifShow: false, |
| | | sorter: true, |
| | | resizable: true, |
| | | customRender: () => {}, |
| | | }, |
| | | { |
| | | dataIndex: 'PKG_NAME', |
| | | title: '包装名称', |
| | | ifShow: true, |
| | | sorter: true, |
| | | resizable: true, |
| | | customRender: () => {}, |
| | | }, |
| | | { |
| | | dataIndex: 'PKG_QTY', |
| | | title: '包装数量', |
| | | ifShow: true, |
| | | sorter: true, |
| | | resizable: true, |
| | | customRender: () => {}, |
| | | }, |
| | | { |
| | | dataIndex: 'PKG_LEVEL', |
| | | title: '包装层级', |
| | | ifShow: true, |
| | | sorter: true, |
| | | resizable: true, |
| | | customRender: () => {}, |
| | | }, |
| | | { |
| | | dataIndex: 'LABEL_CODE', |
| | | title: '标签模板编码', |
| | | // edit: true, |
| | | // editRule: true, |
| | | ifShow: true, |
| | | sorter: true, |
| | | resizable: true, |
| | | // editComponent: 'Input', |
| | | // editComponentProps: (column) => { |
| | | // return { |
| | | // onClick: (event) => { |
| | | // console.log(column); |
| | | // }, |
| | | // }; |
| | | // }, |
| | | // customCell: (record, rowIndex) => { |
| | | // return { |
| | | // onClick: (event) => { |
| | | // console.log(record); |
| | | // }, |
| | | // }; |
| | | // }, |
| | | }, |
| | | ]; |
| | | switch (type) { |
| | | case 'BAS_PKG_DTL': |
| | | columns = [ |
| | | { |
| | | dataIndex: 'PKG_RULE_ID', |
| | | title: '包装规则ID', |
| | | ifShow: false, |
| | | sorter: true, |
| | | resizable: true, |
| | | }, |
| | | { |
| | | dataIndex: 'PKG_CODE', |
| | | title: '包装编码', |
| | | ifShow: false, |
| | | sorter: true, |
| | | resizable: true, |
| | | customRender: () => {}, |
| | | }, |
| | | { |
| | | dataIndex: 'PKG_NAME', |
| | | title: '包装名称', |
| | | ifShow: true, |
| | | sorter: true, |
| | | resizable: true, |
| | | customRender: () => {}, |
| | | }, |
| | | { |
| | | dataIndex: 'PKG_QTY', |
| | | title: '包装数量', |
| | | ifShow: true, |
| | | sorter: true, |
| | | resizable: true, |
| | | customRender: () => {}, |
| | | }, |
| | | { |
| | | dataIndex: 'PKG_LEVEL', |
| | | title: '包装层级', |
| | | ifShow: true, |
| | | sorter: true, |
| | | resizable: true, |
| | | customRender: () => {}, |
| | | }, |
| | | { |
| | | dataIndex: 'LABEL_CODE', |
| | | title: '标签模板编码', |
| | | // edit: true, |
| | | // editRule: true, |
| | | ifShow: true, |
| | | sorter: true, |
| | | resizable: true, |
| | | // editComponent: 'Input', |
| | | // editComponentProps: (column) => { |
| | | // return { |
| | | // onClick: (event) => { |
| | | // console.log(column); |
| | | // }, |
| | | // }; |
| | | // }, |
| | | // customCell: (record, rowIndex) => { |
| | | // return { |
| | | // onClick: (event) => { |
| | | // console.log(record); |
| | | // }, |
| | | // }; |
| | | // }, |
| | | }, |
| | | ] as BasicColumn[]; |
| | | break; |
| | | case 'ItemCode': |
| | | /* |
| | | public string ITEM_CODE { get; set; } |
| | | public string RULE_CODE { get; set; } |
| | | /// <summary> |
| | | /// 是否批次物料 |
| | | /// </summary> |
| | | public bool IsBatchItem { get; set; } |
| | | /// <summary> |
| | | /// 上料数量 |
| | | /// </summary> |
| | | public int QTY { get; set; } |
| | | */ |
| | | columns = [ |
| | | { |
| | | dataIndex: 'ITEM_CODE', |
| | | title: '物料编码', |
| | | ifShow: true, |
| | | sorter: true, |
| | | resizable: true, |
| | | }, |
| | | { |
| | | dataIndex: 'RULE_CODE', |
| | | title: '规则编码', |
| | | ifShow: true, |
| | | sorter: true, |
| | | resizable: true, |
| | | customRender: () => {}, |
| | | }, |
| | | { |
| | | dataIndex: 'IsBatchItem', |
| | | title: '是否批次物料', |
| | | ifShow: true, |
| | | sorter: true, |
| | | resizable: true, |
| | | customRender: () => {}, |
| | | }, |
| | | { |
| | | dataIndex: 'QTY', |
| | | title: '上料数量', |
| | | ifShow: true, |
| | | sorter: true, |
| | | resizable: true, |
| | | customRender: () => {}, |
| | | }, |
| | | // { |
| | | // dataIndex: 'LABEL_CODE', |
| | | // title: '标签模板编码', |
| | | // // edit: true, |
| | | // // editRule: true, |
| | | // ifShow: true, |
| | | // sorter: true, |
| | | // resizable: true, |
| | | // // editComponent: 'Input', |
| | | // // editComponentProps: (column) => { |
| | | // // return { |
| | | // // onClick: (event) => { |
| | | // // console.log(column); |
| | | // // }, |
| | | // // }; |
| | | // // }, |
| | | // // customCell: (record, rowIndex) => { |
| | | // // return { |
| | | // // onClick: (event) => { |
| | | // // console.log(record); |
| | | // // }, |
| | | // // }; |
| | | // // }, |
| | | // }, |
| | | ] as BasicColumn[]; |
| | | break; |
| | | } |
| | | return columns; |
| | | } |
| | | |
| | |
| | | colSlot: 'pkgadd', |
| | | }, |
| | | { |
| | | field: 'OPTION_2', |
| | | label: '是否称重', |
| | | required: true, |
| | | component: 'Select', |
| | | colProps: { span: 12 }, |
| | | ifShow: ({ values }) => isPackage(values.ACT_TYPE), |
| | | componentProps: { |
| | | options: [ |
| | | { |
| | | label: '是', |
| | | value: 'Y', |
| | | key: 'Y', |
| | | }, |
| | | { |
| | | label: '否', |
| | | value: 'N', |
| | | key: 'N', |
| | | }, |
| | | ], |
| | | }, |
| | | }, |
| | | { |
| | | field: 'REMARK', |
| | | label: '备注', |
| | | component: 'Input', |
| | | colProps: { span: 12 }, |
| | | }, |
| | | { |
| | | field: 'OPTION_1', |
| | | label: '行为选项1', |
| | | component: 'Input', |
| | | colProps: { span: 12 }, |
| | | show: false, |
| | | }, |
| | | ]; |
| | | |
| | |
| | | colProps: { span: 12 }, |
| | | }, |
| | | ]; |
| | | |
| | | |
| | | const crudForms = { |
| | | BAS_PKG_DTL: [ |
| | | { |
| | |
| | | label: '模板编码', |
| | | component: 'Input', |
| | | show: true, |
| | | required: true, |
| | | // required: true, |
| | | colProps: { |
| | | span: 22, |
| | | }, |
| | |
| | | show: false, |
| | | }, |
| | | ] as FormSchema[], |
| | | ItemCode: [ |
| | | { |
| | | label: '物料编码', |
| | | field: 'ITEM_CODE', |
| | | component: 'Input', |
| | | colProps: { |
| | | span: 24, |
| | | }, |
| | | dynamicDisabled: ({ values }) => { |
| | | return false; |
| | | }, |
| | | }, |
| | | { |
| | | field: 'RULE_CODE', |
| | | label: '规则编码', |
| | | component: 'Input', |
| | | colProps: { |
| | | span: 22, |
| | | }, |
| | | dynamicDisabled: ({ values }) => { |
| | | return false; |
| | | }, |
| | | }, |
| | | { |
| | | field: 'BAS_CODE_RULE1PSelect_0', //按低代码配置的规则,实体名+序号+PSelect_0,序号用来区分多个的时候,PSelect_0这是个固定后缀 |
| | | label: '1', |
| | | defaultValue: 'BAS_CODE_RULE', |
| | | component: 'Input', |
| | | colProps: { span: 2 }, |
| | | colSlot: 'BAS_CODE_RULE1add', //按低代码配置的规则,实体名+序号+add,序号用来区分多个的时候,add这是个固定后缀 |
| | | }, |
| | | { |
| | | label: '是否批次物料', |
| | | field: 'IsBatchItem', |
| | | colProps: { |
| | | span: 24, |
| | | }, |
| | | component: 'Select', |
| | | componentProps: { |
| | | options: [ |
| | | { |
| | | label: '是', |
| | | value: 'Y', |
| | | key: 'Y', |
| | | }, |
| | | { |
| | | label: '否', |
| | | value: 'N', |
| | | key: 'N', |
| | | }, |
| | | ], |
| | | }, |
| | | }, |
| | | { |
| | | label: '上料数量', |
| | | field: 'QTY', |
| | | component: 'Input', |
| | | colProps: { |
| | | span: 24, |
| | | }, |
| | | dynamicDisabled: ({ values }) => { |
| | | return false; |
| | | }, |
| | | }, |
| | | ] as FormSchema[], |
| | | }; |
| | | |
| | | return [methods]; |