import type { CrudSchema } from '@/hooks/web/useCrudSchemas' import { dateFormatter } from '@/utils/formatTime' import * as getRequestsettingApi from '@/api/wms/requestsetting/index' import * as ItembasicApi from '@/api/wms/itembasic' import { Itembasic } from '@/views/wms/basicDataManage/itemManage/itembasic/itembasic.data' import * as LocationApi from '@/api/wms/location' import { Location } from '@/views/wms/basicDataManage/factoryModeling/location/location.data' import * as WarehouseApi from '@/api/wms/warehouse' import { Warehouse } from '@/views/wms/basicDataManage/factoryModeling/warehouse/warehouse.data' const { t } = useI18n() // 国际化 // 获取自动提交自动通过自动执行,跳过任务直接删生成记录的默认值 const queryParams = { pageSize:10, pageNo:1, code:'RepleinmentRequest', businessTypeCode: 'Repleinment' } const data = await getRequestsettingApi.getRequestsettingPage(queryParams) const requestsettingData =data?.list[0]||{} // 获取当前操作人的部门 import { useUserStore } from '@/store/modules/user' import { TableColumn } from '@/types/table' import {getLocationPageRepleinsh} from "@/api/wms/location"; const userStore = useUserStore() const userDept = userStore.userSelfInfo.dept // id 转str 否则form回显匹配不到 userDept.id = userDept.id.toString() const userDeptArray:any = [userDept] /** * @returns {Array} 补料申请主表 */ export const RepleinshRequestMain = useCrudSchemas(reactive([ { label: '单据号', field: 'number', sort: 'custom', table: { width: 180, fixed: 'left' }, isForm: false, isSearch: true, sortSearchDefault:1, }, { label: '状态', field: 'status', dictType: DICT_TYPE.REQUEST_STATUS, dictClass: 'string', isForm:false, isTable: true, sort: 'custom', sortTableDefault:1, table: { width: 150 }, form: { value: '1', componentProps: { disabled: true } } }, { label: '从库区类型范围', field: 'fromAreaTypes', dictType: DICT_TYPE.AREA_TYPE, dictClass: 'string', isTable: false, sort: 'custom', table: { width: 150 }, isForm: false, }, { label: '到库区类型范围', field: 'toAreaTypes', dictType: DICT_TYPE.AREA_TYPE, dictClass: 'string', isTable: false, sort: 'custom', table: { width: 150 }, isForm: false, }, { label: '从库区代码范围', field: 'fromAreaCodes', sort: 'custom', table: { width: 150 }, isTable: false, isForm: false, }, { label: '到库区代码范围', field: 'toAreaCodes', sort: 'custom', table: { width: 150 }, isTable: false, isForm: false, }, { label: '申请时间', field: 'requestTime', formatter: dateFormatter, detail: { dateFormat: 'YYYY-MM-DD HH:mm:ss' }, sort: 'custom', table: { width: 180 }, isTable: false, form: { component: 'DatePicker', componentProps: { style: { width:'100%'}, type: 'datetime', dateFormat: 'YYYY-MM-DD HH:mm:ss', valueFormat: 'x', } }, isForm: false, }, { label: '截止时间', field: 'dueTime', formatter: dateFormatter, detail: { dateFormat: 'YYYY-MM-DD HH:mm:ss' }, sort: 'custom', table: { width: 180 }, isTable: false, form: { component: 'DatePicker', componentProps: { style: { width:'100%'}, type: 'datetime', dateFormat: 'YYYY-MM-DD HH:mm:ss', valueFormat: 'x', } }, }, { label: '部门', field: 'departmentCode', sort: 'custom', isForm:false, table: { width: 150 }, isTable: false, formatter: (_: Recordable, __: TableColumn, cellValue: number) => { return userDeptArray.find((account) => account.id == cellValue)?.name }, form: { value: userDept.id, component: 'Select', api: () => userDeptArray, componentProps: { disabled: true, optionsAlias: { labelField: 'name', valueField: 'id' } } } }, { label: '业务类型', field: 'businessType', sort: 'custom', table: { width: 150 }, isTable:false, form: { value: 'Repleinment', componentProps: { disabled: true } }, isForm: false, }, { label: '备注', field: 'remark', sort: 'custom', table: { width: 150 }, isForm: false, isTable: true, isDetail: true }, { label: '到库位代码', field: 'toLocationCode', sort: 'custom', table: { width: 150 }, hiddenInMain:true, sortSearchDefault:1000, isSearch: true, sortTableDefault:1100, // isTableForm: false, form: { // labelMessage: '信息提示说明!!!', componentProps: { enterSearch:true, isSearchList: true, // 开启查询弹窗 searchListPlaceholder: '请选择到库位代码', // 输入框占位文本 searchField: 'code', // 查询弹窗赋值字段 searchTitle: '库位信息', // 查询弹窗标题 searchAllSchemas: Location.allSchemas, // 查询弹窗所需类 searchPage: LocationApi.getLocationPageRepleinsh, // 查询弹窗所需分页方法 searchCondition:[{ key: 'available', value: 'TRUE', isMainValue: false }], verificationParams: [{ key: 'code', action: '==', value: '', isMainValue: false, isSearch: true, isFormModel: true, }], // 失去焦点校验参数 } }, tableForm:{ isInpuFocusShow: true, searchListPlaceholder: '请选择到库位代码', // 输入框占位文本 searchField: 'code', // 查询弹窗赋值字段 searchTitle: '库位信息', // 查询弹窗标题 searchAllSchemas: Location.allSchemas, // 查询弹窗所需类 searchPage: LocationApi.getLocationPageRepleinsh, // 查询弹窗所需分页方法 searchCondition:[{ key: 'available', value: 'TRUE', isMainValue: false }] }, }, // { // label: '从仓库代码', // field: 'fromWarehouseCode', // sort: 'custom', // table: { // width: 150 // }, // isTable: false, // form: { // // labelMessage: '信息提示说明!!!', // componentProps: { // isSearchList: true, // 开启查询弹窗 // searchListPlaceholder: '请选择仓库代码', // 输入框占位文本 // searchField: 'code', // 查询弹窗赋值字段 // searchTitle: '仓库信息', // 查询弹窗标题 // searchAllSchemas: Warehouse.allSchemas, // 查询弹窗所需类 // searchPage: WarehouseApi.getWarehousePage, // 查询弹窗所需分页方法 // searchCondition: [{ // key: 'available', // value: 'TRUE', // isMainValue: false // }] // } // } // }, // { // label: '到仓库代码', // field: 'toWarehouseCode', // sort: 'custom', // table: { // width: 150 // }, // isTable: false, // form: { // componentProps: { // disabled: true // } // } // }, { label: '自动提交', field: 'autoCommit', dictType: DICT_TYPE.TRUE_FALSE, dictClass: 'string', isTable: false, isForm:false, sort: 'custom', table: { width: 150 }, form: { component: 'Switch', value: requestsettingData.autoCommit, componentProps: { inactiveValue: 'FALSE', activeValue: 'TRUE', disabled: true } } }, { label: '自动通过', field: 'autoAgree', dictType: DICT_TYPE.TRUE_FALSE, dictClass: 'string', isForm:false, isTable: false, sort: 'custom', table: { width: 150 }, form: { component: 'Switch', value: requestsettingData.autoAgree, componentProps: { inactiveValue: 'FALSE', activeValue: 'TRUE', disabled: true } } }, { label: '自动执行', field: 'autoExecute', dictType: DICT_TYPE.TRUE_FALSE, dictClass: 'string', isForm:false, isTable: false, sort: 'custom', table: { width: 150 }, form: { component: 'Switch', value: requestsettingData.autoExecute, componentProps: { inactiveValue: 'FALSE', activeValue: 'TRUE', disabled: true } } }, // { // label: '直接生成记录', // field: 'directCreateRecord', // dictType: DICT_TYPE.TRUE_FALSE, // dictClass: 'string', // isTable: true, // sort: 'custom', // table: { // width: 150 // }, // form: { // component: 'Switch', // value: requestsettingData.directCreateRecord, // componentProps: { // inactiveValue: 'FALSE', // activeValue: 'TRUE', // disabled: true // } // } // }, { label: '创建时间', field: 'createTime', formatter: dateFormatter, detail: { dateFormat: 'YYYY-MM-DD HH:mm:ss' }, sort: 'custom', table: { width: 180 }, isTable: true, form: { component: 'DatePicker', componentProps: { type: 'datetime', dateFormat: 'YYYY-MM-DD HH:mm:ss', valueFormat: 'x', } }, isForm: false, }, { label: '创建者', field: 'creator', sort: 'custom', table: { width: 150 }, isTable: true, isForm: false, }, { label: '最后更新时间', field: 'updateTime', formatter: dateFormatter, detail: { dateFormat: 'YYYY-MM-DD HH:mm:ss' }, sort: 'custom', table: { width: 180 }, isDetail: true, hiddenInMain:true, isTable: false, form: { component: 'DatePicker', componentProps: { style: { width:'100%'}, type: 'datetime', dateFormat: 'YYYY-MM-DD HH:mm:ss', valueFormat: 'x', } }, isForm: false, }, { label: '最后更新者', field: 'updater', sort: 'custom', table: { width: 150 }, hiddenInMain:true, isTable: false, isDetail: true, isForm: false, }, { label: '操作', field: 'action', isDetail: false, isForm: false, table: { width: 300, fixed: 'right' }, }, // { // label: '包装规格', // field: 'packUnit', // sort: 'custom', // isForm:false, // table: { // width: 150 // }, // sortTableDefault:7, // }, // { // label: '包装数量', // field: 'packQty', // sort: 'custom', // isForm:false, // table: { // width: 150 // }, // sortTableDefault:8, // }, ])) //表单校验 export const RepleinshRequestMainRules = reactive({ fromWarehouseCode: [ { required: true, message: '请输入从仓库代码', trigger: 'blur' } ], fromAreaTypes: [ { required: true, message: '请选择从库区类型范围', trigger: 'change' } ], toWarehouseCode: [ { required: true, message: '请输入到仓库代码', trigger: 'blur' } ], toAreaTypes: [ { required: true, message: '请选择到库区类型范围', trigger: 'change' } ], departmentCode: [ { required: true, message: '请输入部门', trigger: 'blur' } ], autoCommit: [ { required: true, message: '请选择是否自动提交', trigger: 'change' } ], autoAgree: [ { required: true, message: '请选择是否自动通过', trigger: 'change' } ], autoExecute: [ { required: true, message: '请选择是否自动执行', trigger: 'change' } ], toLocationCode: [ { required: true, message: '请输入到库位代码', trigger: ['change', 'blur']} ], directCreateRecord: [ { required: true, message: '请选择是否跳过任务直接生成记录', trigger: 'change' } ], businessType: [ { required: true, message: '请输入业务类型', trigger: 'blur' } ], remark: [ { max: 50, message: '不得超过50个字符', trigger: 'blur' } ], }) /** * @returns {Array} 补料申请子表 */ export const RepleinshRequestDetail = useCrudSchemas(reactive([ { label: '物料代码', field: 'itemCode', sort: 'custom', table: { width: 150 }, isSearch:true, sortSearchDefault:2, sortTableDefault:3, form: { // labelMessage: '信息提示说明!!!', componentProps: { isSearchList: true, // 开启查询弹窗 searchListPlaceholder: '请选择物料代码', // 输入框占位文本 searchField: 'code', // 查询弹窗赋值字段 searchTitle: '物料基础信息', // 查询弹窗标题 searchAllSchemas: Itembasic.allSchemas, // 查询弹窗所需类 searchPage: ItembasicApi.getItembasicPage, // 查询弹窗所需分页方法 searchCondition:[{ key: 'available', value: 'TRUE', isMainValue: false }] } }, tableForm:{ multiple:true, disabled:true, isShowTableFormSearch: true, // isInpuFocusShow: true, searchListPlaceholder: '请选择物料代码', // 输入框占位文本 searchField: 'code', // 查询弹窗赋值字段 searchTitle: '物料基础信息', // 查询弹窗标题 searchAllSchemas: Itembasic.allSchemas, // 查询弹窗所需类 searchPage: ItembasicApi.getItembasicPage, // 查询弹窗所需分页方法 searchCondition:[{ key: 'available', value: 'TRUE', isMainValue: false },{ key : 'businessTypeCode', value: queryParams.businessTypeCode }] }, }, { label: '物料名称', field: 'itemName', sort: 'custom', sortTableDefault:4, isTableForm: false, isForm: false, }, { label: '物料描述1', field: 'itemDesc1', sort: 'custom', table: { width: 150 }, hiddenInMain:true, isTableForm: false, isForm: false, }, { label: '物料描述2', field: 'itemDesc2', sort: 'custom', table: { width: 150 }, hiddenInMain:true, isTableForm: false, isForm: false, }, { label: '数量', field: 'qty', sort: 'custom', table: { width: 150 }, hiddenInMain:true, form: { component: 'InputNumber', componentProps: { min: 0, precision: 6 } }, tableForm: { type: 'InputNumber', min: 0, precision: 6 } }, { label: '计量单位', field: 'uom', dictType: DICT_TYPE.UOM, dictClass: 'string', isTable: true, sort: 'custom', table: { width: 150 }, sortTableDefault:9, tableForm: { type: 'Select', disabled: true }, form: { componentProps: { disabled: true } } }, { label: '到库位代码', field: 'toLocationCode', sort: 'custom', table: { width: 150 }, hiddenInMain:true, sortSearchDefault:1000, // isSearch: true, sortTableDefault:1100, isTableForm: false, form: { componentProps: { disabled:true, } } }, // { // label: '包装号', // field: 'packingNumber', // sort: 'custom', // table: { // width: 150 // }, // isTableForm: false, // isForm: false, // sortTableDefault:6, // sortSearchDefault:4, // }, // { // label: '批次', // field: 'batch', // sort: 'custom', // table: { // width: 150 // }, // isTableForm: false, // sortTableDefault:5, // sortSearchDefault:3, // }, { label: '库存状态', field: 'inventoryStatus', dictType: DICT_TYPE.INVENTORY_STATUS, dictClass: 'string', isTableForm: false, isTable:false, sort: 'custom', form: { value: 'OK', componentProps: { disabled: true, searchCondition:[{ key: 'available', value: 'TRUE', isMainValue: false }] } }, table: { width: 150 }, isTableForm:false, tableForm: { type: 'Select', default: 'OK', disabled: true } }, { label: '单据号', field: 'number', sort: 'custom', table: { width: 180 }, hiddenInMain:true, isTableForm: false, isTable:false, form: { componentProps: { disabled: true } } }, { label: '备注', field: 'remark', sort: 'custom', isTableForm:false, table: { width: 150 }, isTable:false, hiddenInMain:true, }, { label: '创建时间', field: 'createTime', formatter: dateFormatter, detail: { dateFormat: 'YYYY-MM-DD HH:mm:ss' }, sort: 'custom', table: { width: 180 }, hiddenInMain:true, form: { component: 'DatePicker', componentProps: { style: { width:'100%'}, type: 'datetime', dateFormat: 'YYYY-MM-DD HH:mm:ss', valueFormat: 'x', } }, isTableForm: false, isForm: false }, { label: '创建者', field: 'creator', sort: 'custom', table: { width: 150 }, hiddenInMain:true, isTableForm: false, isForm: false }, { label: '项目代码', field: 'projectCode', sort: 'custom', table: { width: 150 }, hiddenInMain:true, isTableForm: false, isTable:false, isForm: false, }, { label: '采购订单号', field: 'poNumber', sort: 'custom', table: { width: 150 }, hiddenInMain:true, isTableForm: false, sortTableDefault:1, isTable:false, }, { label: '订单行', field: 'poLine', sort: 'custom', table: { width: 150 }, hiddenInMain:true, isTableForm: false, sortTableDefault:2, isTable:false, }, { label: '从货主代码', field: 'fromOwnerCode', sort: 'custom', table: { width: 150 }, isTableForm: false, isForm: false, hiddenInMain:true, isTable:false, }, { label: '到货主代码', field: 'toOwnerCode', sort: 'custom', table: { width: 150 }, isTableForm: false, isForm: false, hiddenInMain:true, isTable:false, }, { label: '最后更新时间', field: 'updateTime', formatter: dateFormatter, detail: { dateFormat: 'YYYY-MM-DD HH:mm:ss' }, sort: 'custom', table: { width: 180 }, isTable:false, form: { component: 'DatePicker', componentProps: { style: { width:'100%'}, type: 'datetime', dateFormat: 'YYYY-MM-DD HH:mm:ss', valueFormat: 'x', } }, hiddenInMain:true, isTableForm: false, isForm: false }, { label: '最后更新者', field: 'updater', sort: 'custom', table: { width: 150 }, isTableForm: false, hiddenInMain:true, isTable:false, isForm: false }, { label: '未执行任务数量', field: 'unexecutedQty', sort: 'custom', table: { width: 150 }, form: { component: 'InputNumber', }, isTableForm:false, hiddenInMain:true, }, { label: '操作', field: 'action', hiddenInMain:true, isDetail: false, isForm: false , table: { width: 150, fixed: 'right' }, isTableForm:false, } ])) //表单校验 export const RepleinshRequestDetailRules = reactive({ // inventoryStatus: [ // { required: true, message: '请选择库存状态', trigger: 'change' } // ], // toLocationCode: [ // { required: true, message: '请输入到库位代码', trigger: 'blur' } // ], itemCode: [ { required: true, message: '请输入物料代码', trigger: 'blur' } ], remark: [ { max: 50, message: '不得超过50个字符', trigger: 'blur' } ], })