You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
663 lines
13 KiB
663 lines
13 KiB
import type { CrudSchema } from '@/hooks/web/useCrudSchemas'
|
|
import { TableColumn } from '@/types/table'
|
|
|
|
import { dateFormatter } from '@/utils/formatTime'
|
|
import * as getRequestsettingApi from '@/api/wms/requestsetting/index'
|
|
|
|
import * as CountPlanMainApi from '@/api/wms/countPlanMain'
|
|
import { CountPlanMain } from '../countPlanMain/countPlanMain.data'
|
|
|
|
const { t } = useI18n() // 国际化
|
|
|
|
// 获取自动提交自动通过自动执行,跳过任务直接删生成记录的默认值
|
|
const queryParams = {
|
|
pageSize:10,
|
|
pageNo:1,
|
|
code:'CountRequest'
|
|
}
|
|
const data = await getRequestsettingApi.getRequestsettingPage(queryParams)
|
|
const requestsettingData =data?.list[0]||{}
|
|
|
|
// 获取当前操作人的部门
|
|
import { useUserStore } from '@/store/modules/user'
|
|
const userStore = useUserStore()
|
|
const userDept = userStore.userSelfInfo.dept
|
|
// id 转str 否则form回显匹配不到
|
|
userDept.id = userDept.id.toString()
|
|
const userDeptArray:any = [userDept]
|
|
|
|
/**
|
|
* @returns {Array} 盘点申请主表
|
|
*/
|
|
export const CountRequestMain = useCrudSchemas(<CrudSchema[]>([
|
|
{
|
|
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
|
|
},
|
|
},
|
|
{
|
|
label: '计划单号',
|
|
field: 'planNumber',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
form: {
|
|
// labelMessage: '信息提示说明!!!',
|
|
componentProps: {
|
|
isSearchList: true, // 开启查询弹窗
|
|
searchListPlaceholder: '请选择计划单号', // 输入框占位文本
|
|
searchField: 'number', // 查询弹窗赋值字段
|
|
searchTitle: '盘点计划', // 查询弹窗标题
|
|
searchAllSchemas: CountPlanMain.allSchemas, // 查询弹窗所需类
|
|
searchPage: CountPlanMainApi.getCountPlanMainPage, // 查询弹窗所需分页方法
|
|
searchCondition: [{
|
|
key: 'available',
|
|
value: 'TRUE',
|
|
isMainValue: false
|
|
}]
|
|
}
|
|
}
|
|
},
|
|
{
|
|
label: '阶段',
|
|
field: 'stage',
|
|
dictType: DICT_TYPE.COUNT_STAGE,
|
|
dictClass: 'string',
|
|
isTable: true,
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
isSearch: true,
|
|
},
|
|
{
|
|
label: '任务拆分方式',
|
|
field: 'countSplitType',
|
|
dictType: DICT_TYPE.COUNT_SPLIT_TYPE,
|
|
dictClass: 'string',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
isTable:true,
|
|
isForm: true,
|
|
form: {
|
|
value: 'locationCode'
|
|
}
|
|
|
|
},
|
|
{
|
|
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',
|
|
}
|
|
},
|
|
isForm: false,
|
|
},
|
|
{
|
|
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: 'businessType',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
form: {
|
|
value: 'Count',
|
|
componentProps: {
|
|
disabled: true
|
|
}
|
|
},
|
|
isForm: false,
|
|
},
|
|
{
|
|
label: '明盘',
|
|
field: 'isOpenCount',
|
|
dictType: DICT_TYPE.TRUE_FALSE,
|
|
dictClass: 'string',
|
|
isTable: true,
|
|
form: {
|
|
component: 'Switch',
|
|
value: 'FALSE',
|
|
componentProps: {
|
|
inactiveValue: 'FALSE',
|
|
activeValue: 'TRUE'
|
|
}
|
|
},
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
},
|
|
{
|
|
label: '部门',
|
|
field: 'departmentCode',
|
|
sort: 'custom',
|
|
isForm: false,
|
|
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: 'remark',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
isTable: false
|
|
},
|
|
{
|
|
label: '自动提交',
|
|
field: 'autoCommit',
|
|
dictType: DICT_TYPE.TRUE_FALSE,
|
|
dictClass: 'string',
|
|
isForm: false,
|
|
isTable: true,
|
|
form: {
|
|
component: 'Switch',
|
|
value: requestsettingData.autoCommit,
|
|
componentProps: {
|
|
inactiveValue: 'FALSE',
|
|
activeValue: 'TRUE',
|
|
disabled: true
|
|
}
|
|
},
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
},
|
|
{
|
|
label: '自动通过',
|
|
field: 'autoAgree',
|
|
dictType: DICT_TYPE.TRUE_FALSE,
|
|
dictClass: 'string',
|
|
isTable: true,
|
|
isForm: false,
|
|
form: {
|
|
component: 'Switch',
|
|
value: requestsettingData.autoAgree,
|
|
componentProps: {
|
|
inactiveValue: 'FALSE',
|
|
activeValue: 'TRUE',
|
|
disabled: true
|
|
}
|
|
},
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
},
|
|
{
|
|
label: '自动执行',
|
|
field: 'autoExecute',
|
|
dictType: DICT_TYPE.TRUE_FALSE,
|
|
dictClass: 'string',
|
|
isTable: true,
|
|
isForm: false,
|
|
form: {
|
|
component: 'Switch',
|
|
value: requestsettingData.autoExecute,
|
|
componentProps: {
|
|
inactiveValue: 'FALSE',
|
|
activeValue: 'TRUE',
|
|
disabled: true
|
|
}
|
|
},
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
},
|
|
{
|
|
label: '直接生成记录',
|
|
field: 'directCreateRecord',
|
|
dictType: DICT_TYPE.TRUE_FALSE,
|
|
dictClass: 'string',
|
|
isForm: false,
|
|
isTable: false,
|
|
form: {
|
|
component: 'Switch',
|
|
value: requestsettingData.directCreateRecord,
|
|
componentProps: {
|
|
inactiveValue: 'FALSE',
|
|
activeValue: 'TRUE',
|
|
disabled: true
|
|
}
|
|
},
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
},
|
|
{
|
|
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',
|
|
}
|
|
},
|
|
isForm: false,
|
|
isSearch: true,
|
|
search: {
|
|
component: 'DatePicker',
|
|
componentProps: {
|
|
valueFormat: 'YYYY-MM-DD HH:mm:ss',
|
|
type: 'daterange',
|
|
defaultTime: [new Date('1 00:00:00'), new Date('1 23:59:59')]
|
|
},
|
|
},
|
|
},
|
|
{
|
|
label: '创建者',
|
|
field: 'creator',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
isForm: false,
|
|
},
|
|
{
|
|
label: '操作',
|
|
field: 'action',
|
|
isDetail: false,
|
|
isForm: false,
|
|
table: {
|
|
width: 300,
|
|
fixed: 'right'
|
|
},
|
|
}
|
|
]))
|
|
|
|
//表单校验
|
|
export const CountRequestMainRules = reactive({
|
|
// requestNumber: [
|
|
// { required: true, message: '请选择申请单号', trigger: 'change' }
|
|
// ],
|
|
stage: [
|
|
{ required: true, message: '请选择阶段', trigger: 'change' }
|
|
],
|
|
warehouseCode: [
|
|
{ required: true, message: '请选择仓库代码', trigger: 'change' }
|
|
],
|
|
departmentCode: [
|
|
{ required: true, message: '请输入部门', trigger: 'blur' }
|
|
],
|
|
status: [
|
|
{ required: true, message: '请选择状态', trigger: 'change' }
|
|
],
|
|
autoCommit: [
|
|
{ required: true, message: '请选择是否自动提交', trigger: 'change' }
|
|
],
|
|
autoAgree: [
|
|
{ required: true, message: '请选择是否自动通过', trigger: 'change' }
|
|
],
|
|
autoExecute: [
|
|
{ required: true, message: '请选择是否自动执行', trigger: 'change' }
|
|
],
|
|
directCreateRecord: [
|
|
{ required: true, message: '请选择是否跳过任务直接生成记录', trigger: 'change' }
|
|
],
|
|
// businessType: [
|
|
// { required: true, message: '请输入业务类型', trigger: 'blur' }
|
|
// ],
|
|
})
|
|
|
|
|
|
/**
|
|
* @returns {Array} 盘点申请子表
|
|
*/
|
|
export const CountRequestDetail = useCrudSchemas(reactive<CrudSchema[]>([
|
|
{
|
|
label: '单据号',
|
|
field: 'number',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 180
|
|
},
|
|
isTableForm: false,
|
|
form: {
|
|
componentProps: {
|
|
disabled: true
|
|
}
|
|
}
|
|
},
|
|
{
|
|
label: '盘点明细号',
|
|
field: 'countDetailNumber',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 180
|
|
},
|
|
},
|
|
{
|
|
label: '物料代码',
|
|
field: 'itemCode',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
},
|
|
{
|
|
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: {
|
|
disabled: true,
|
|
min: 1,
|
|
precision: 6
|
|
}
|
|
},
|
|
tableForm: {
|
|
type: 'InputNumber',
|
|
min: 1,
|
|
precision: 6
|
|
}
|
|
},
|
|
{
|
|
label: '计量单位',
|
|
field: 'uom',
|
|
dictType: DICT_TYPE.UOM,
|
|
dictClass: 'string',
|
|
isTable: true,
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
tableForm: {
|
|
type: 'Select'
|
|
}
|
|
},
|
|
{
|
|
label: '仓库代码',
|
|
field: 'warehouseCode',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
},
|
|
|
|
{
|
|
label: '库区代码',
|
|
field: 'areaCode',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
},{
|
|
label: '库位组代码',
|
|
field: 'locationGroupCode',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
},
|
|
{
|
|
label: '库位代码',
|
|
field: 'locationCode',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
},
|
|
{
|
|
label: '库存状态',
|
|
field: 'inventoryStatus',
|
|
dictType: DICT_TYPE.INVENTORY_STATUS,
|
|
dictClass: 'string',
|
|
isTable: true,
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
tableForm: {
|
|
type: 'Select'
|
|
}
|
|
},
|
|
{
|
|
label: '备注',
|
|
field: 'remark',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
},
|
|
{
|
|
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',
|
|
}
|
|
},
|
|
isTableForm: false,
|
|
isForm: false
|
|
},
|
|
{
|
|
label: '最后更新者',
|
|
field: 'updater',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
isTableForm: false,
|
|
isForm: 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',
|
|
}
|
|
},
|
|
isTableForm: false,
|
|
isForm: false
|
|
},
|
|
{
|
|
label: '创建者',
|
|
field: 'creator',
|
|
sort: 'custom',
|
|
table: {
|
|
width: 150
|
|
},
|
|
isTableForm: false,
|
|
isForm: false
|
|
},
|
|
// {
|
|
// label: '操作',
|
|
// field: 'action',
|
|
// isDetail: false,
|
|
// isForm: false ,
|
|
// table: {
|
|
// width: 150,
|
|
// fixed: 'right'
|
|
// },
|
|
// isTableForm:false,
|
|
// }
|
|
]))
|
|
|
|
//表单校验
|
|
export const CountRequestDetailRules = reactive({
|
|
countDetailNumber: [
|
|
{ required: true, message: '请输入盘点明细号', trigger: 'blur' }
|
|
],
|
|
packingNumber: [
|
|
{ required: true, message: '请选择包装号', trigger: 'change' }
|
|
],
|
|
batch: [
|
|
{ required: true, message: '请输入批次', trigger: 'blur' }
|
|
],
|
|
locationCode: [
|
|
{ required: true, message: '请选择库位代码', trigger: 'change' }
|
|
],
|
|
inventoryStatus: [
|
|
{ required: true, message: '请选择库存状态', trigger: 'change' }
|
|
],
|
|
})
|
|
|