import type { CrudSchema } from '@/hooks/web/useCrudSchemas' import { dateFormatter } from '@/utils/formatTime' import * as getRequestsettingApi from '@/api/wms/requestsetting/index' import * as BalanceApi from '@/api/wms/balance' import { Balance } from '@/views/wms/inventoryManage/balance/balance.data' const { t } = useI18n() // 国际化 // 获取自动提交自动通过自动执行,跳过任务直接删生成记录的默认值 const queryParams = { pageSize:10, pageNo:1, code:'UnplannedDeliverRequest' } const data = await getRequestsettingApi.getRequestsettingPage(queryParams) const requestsettingData =data?.list[0]||{} // 获取当前操作人的部门 import { useUserStore } from '@/store/modules/user' import { TableColumn } from '@/types/table' const userStore = useUserStore() const userDept = userStore.userSelfInfo.dept // id 转str 否则form回显匹配不到 userDept.id = userDept.id.toString() const userDeptArray:any = [userDept] /** * @returns {Array} 计划外出库申请主表 */ export const UnplannedissueRequestMain = useCrudSchemas(reactive([ { label: '单据号', field: 'number', sort: 'custom', table: { width: 180, fixed: 'left' }, isForm: false, isSearch: true, }, { label: '状态', field: 'status', dictType: DICT_TYPE.REQUEST_STATUS, dictClass: 'string', isSearch: true, isTable: true, isForm: false, sort: 'custom', table: { width: 150 }, form: { value: '1', componentProps: { disabled: true } } }, { label: '原因', field: 'reason', dictType: DICT_TYPE.UNPLANNED_ISSUE_REASON, dictClass: 'string', formatter: (_: Recordable, __: TableColumn, cellValue: number) => { return cellValue }, table: { width: 150 }, form: { componentProps: { filterable: true } }, tableForm: { type: 'Select', filterable: true } }, { label: '申请时间', field: 'requestTime', formatter: dateFormatter, detail: { dateFormat: 'YYYY-MM-DD HH:mm:ss' }, sort: 'custom', table: { width: 180 }, form: { component: 'DatePicker', componentProps: { style: {width:'100%'}, type: 'datetime', dateFormat: 'YYYY-MM-DD HH:mm:ss', valueFormat: 'x', } }, }, { label: '截止时间', field: 'dueTime', formatter: dateFormatter, detail: { dateFormat: 'YYYY-MM-DD HH:mm:ss' }, sort: 'custom', table: { width: 180 }, form: { component: 'DatePicker', componentProps: { style: {width:'100%'}, type: 'datetime', dateFormat: 'YYYY-MM-DD HH:mm:ss', valueFormat: 'x', } }, }, { label: '从仓库代码', field: 'fromWarehouseCode', sort: 'custom', table: { width: 150 }, isForm: false, }, { label: '从库区类型范围', field: 'fromAreaTypes', dictType: DICT_TYPE.AREA_TYPE, dictClass: 'string', isTable: true, sort: 'custom', table: { width: 150 }, isSearch: true, isForm: false, }, { label: '从库区代码范围', field: 'fromAreaCodes', sort: 'custom', table: { width: 150 }, isSearch: true, isForm: false, }, { label: '业务类型', field: 'businessType', sort: 'custom', table: { width: 150 }, isTable:false, form: { value: 'UnplannedDeliver', componentProps: { disabled: true } }, isForm: false, }, { label: '部门', field: 'departmentCode', sort: 'custom', isForm: false, sortTableDefault: 1001, table: { width: 150 }, 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: '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', isTable: false, isForm: 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', isForm: false, isTable: false, sort: 'custom', table: { width: 150 }, form: { component: 'Switch', value: requestsettingData.directCreateRecord, componentProps: { inactiveValue: 'FALSE', activeValue: 'TRUE', disabled: true } } }, { label: '备注', field: 'remark', sort: 'custom', table: { width: 150 }, isTable: false, }, { label: '创建时间', field: 'createTime', formatter: dateFormatter, detail: { dateFormat: 'YYYY-MM-DD HH:mm:ss' }, sort: 'custom', table: { width: 180 }, form: { component: 'DatePicker', componentProps: { style: {width:'100%'}, type: 'datetime', dateFormat: 'YYYY-MM-DD HH:mm:ss', valueFormat: 'x', } }, isTable:false, isForm: false, }, { label: '创建者', field: 'creator', sort: 'custom', table: { width: 150 }, isTable:false, isForm: false, }, { label: '最后更新时间', field: 'updateTime', formatter: dateFormatter, detail: { dateFormat: 'YYYY-MM-DD HH:mm:ss' }, sort: 'custom', table: { width: 180 }, form: { component: 'DatePicker', componentProps: { style: {width:'100%'}, type: 'datetime', dateFormat: 'YYYY-MM-DD HH:mm:ss', valueFormat: 'x', } }, isTable:false, isForm: false, }, { label: '最后更新者', field: 'updater', sort: 'custom', table: { width: 150 }, isTable:false, isForm: false, }, { label: '操作', field: 'action', isDetail: false, isForm: false, table: { width: 300, fixed: 'right' }, } ])) //表单校验 export const UnplannedissueRequestMainRules = reactive({ // requestTime: [ // { required: true, message: '请输入申请时间', trigger: 'blur' } // ], // dueTime: [ // { required: true, message: '请输入截止时间', trigger: 'blur' } // ], departmentCode: [ { required: true, message: '请输入部门', trigger: 'blur' } ], autoCommit: [ { required: true, message: '请选择是否自动提交', trigger: 'change' } ], autoAgree: [ { required: true, message: '请选择是否自动通过', trigger: 'change' } ], autoExecute: [ { required: true, message: '请选择是否自动执行', trigger: 'change' } ], directCreateRecord: [ { required: true, message: '请选择是否跳过任务直接生成记录', trigger: 'change' } ], remark: [ { max: 50, message: '不得超过50个字符', trigger: 'blur' } ], }) /** * @returns {Array} 计划外出库申请子表 */ export const UnplannedissueRequestDetail = useCrudSchemas(reactive([ { label: '单据号', field: 'number', sort: 'custom', hiddenInMain:true, table: { width: 180 }, isTableForm: false, form: { componentProps: { disabled: true } } }, { label: '物料代码', field: 'itemCode', sort: 'custom', table: { width: 150 }, tableForm:{ isInpuFocusShow: true, // 开启查询弹窗 searchListPlaceholder: '请选择包装号', searchField: 'packingNumber', searchTitle: '库存余额信息', searchAllSchemas: Balance.allSchemas, searchPage: BalanceApi.getBalanceItemPage }, form: { // labelMessage: '信息提示说明!!!', componentProps: { isSearchList: true, // 开启查询弹窗 searchListPlaceholder: '请选择包装号', searchField: 'packingNumber', searchTitle: '库存余额信息', searchAllSchemas: Balance.allSchemas, searchPage: BalanceApi.getBalanceItemPage } } }, { label: '物料名称', field: 'itemName', sort: 'custom', table: { width: 150 }, isTableForm: false, isForm: false, }, { label: '物料描述1', field: 'itemDesc1', sort: 'custom', table: { width: 150 }, isTableForm: false, isForm: false, }, { label: '物料描述2', field: 'itemDesc2', sort: 'custom', table: { width: 150 }, isTableForm: false, isForm: false, }, { label: '批次', field: 'batch', sort: 'custom', table: { width: 150 }, }, { label: '包装号', field: 'packingNumber', sort: 'custom', table: { width: 150 }, }, { label: '器具号', field: 'containerNumber', sort: 'custom', table: { width: 150 }, }, { label: '数量', field: 'qty', sort: 'custom', table: { width: 150 }, 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 }, tableForm: { type: 'Select' } }, { label: '库存状态', field: 'inventoryStatus', dictType: DICT_TYPE.INVENTORY_STATUS, dictClass: 'string', isTable: true, sort: 'custom', table: { width: 150 }, tableForm: { type: 'Select' } }, { label: '从库位代码', field: 'fromLocationCode', sort: 'custom', table: { width: 150 }, }, { label: '项目代码', field: 'projectCode', sort: 'custom', table: { width: 150 }, isTableForm: false, isForm: false, }, { label: '从货主代码', field: 'fromOwnerCode', sort: 'custom', table: { width: 150 }, isForm: false, isTableForm: false }, { label: '备注', field: 'remark', sort: 'custom', table: { width: 150 }, }, { label: '创建时间', field: 'createTime', formatter: dateFormatter, detail: { dateFormat: 'YYYY-MM-DD HH:mm:ss' }, sort: 'custom', sortTableDefault: 1002, table: { width: 180 }, 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', sortTableDefault: 1003, table: { width: 150 }, isTableForm: false, isForm: false }, { label: '最后更新时间', field: 'updateTime', formatter: dateFormatter, detail: { dateFormat: 'YYYY-MM-DD HH:mm:ss' }, sort: 'custom', table: { width: 180 }, 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 }, hiddenInMain:true, isTableForm: false, isForm: false }, { label: '操作', field: 'action', isDetail: false, isForm: false , table: { width: 150, fixed: 'right' }, isTableForm:false, hiddenInMain:true, } ])) //表单校验 export const UnplannedissueRequestDetailRules = reactive({ packingNumber: [ { required: true, message: '请选择包装号', trigger: 'change' }, { max: 50, message: '不得超过50个字符', trigger: 'blur' } ], batch: [ { required: true, message: '请输入批次', trigger: 'blur' }, { max: 50, message: '不得超过50个字符', trigger: 'blur' } ], containerNumber: [ { max: 50, message: '不得超过50个字符', trigger: 'blur' } ], inventoryStatus: [ { required: true, message: '请选择库存状态', trigger: 'change' } ], fromLocationCode: [ { required: true, message: '请选择从库位代码', trigger: 'change' }, { max: 50, message: '不得超过50个字符', trigger: 'blur' } ], itemCode: [ { required: true, message: '请选择物料代码', trigger: 'change' }, { max: 50, message: '不得超过50个字符', trigger: 'blur' } ], remark: [ { max: 50, message: '不得超过50个字符', trigger: 'blur' } ], })