From 041720f9dd38244907065dadf46dd909190ed576 Mon Sep 17 00:00:00 2001 From: zhaoxuebing <1291173720@qq.com> Date: Tue, 11 Mar 2025 11:16:21 +0800 Subject: [PATCH] =?UTF-8?q?=E7=9B=98=E7=82=B9=E9=85=8D=E7=BD=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/api/wms/countConfig/index.ts | 61 +++++ .../count/countConfig/countConfig.data.ts | 88 +++++++ .../countManage/count/countConfig/index.vue | 244 ++++++++++++++++++ .../countManage/count/countJobMain/index.vue | 18 +- 4 files changed, 403 insertions(+), 8 deletions(-) create mode 100644 src/api/wms/countConfig/index.ts create mode 100644 src/views/wms/countManage/count/countConfig/countConfig.data.ts create mode 100644 src/views/wms/countManage/count/countConfig/index.vue diff --git a/src/api/wms/countConfig/index.ts b/src/api/wms/countConfig/index.ts new file mode 100644 index 000000000..ac56a4e64 --- /dev/null +++ b/src/api/wms/countConfig/index.ts @@ -0,0 +1,61 @@ +import request from '@/config/axios' + +export interface CountConfigVO { + id: number + itemCode: string + itemName: string + desc1: string + uom: string + packUnit: string + packQty: number + countType: string + conversionRate: number + available: string + remark: string + deletionTime: Date + deleterId: string + extraProperties: string + concurrencyStamp: number + siteId: string +} + +// 查询盘点配置列表 +export const getCountConfigPage = async (params) => { + if (params.isSearch) { + delete params.isSearch + const data = {...params} + return await request.post({ url: '/wms/count-config/senior', data }) + } else { + return await request.get({ url: `/wms/count-config/page`, params }) + } +} + +// 查询盘点配置详情 +export const getCountConfig = async (id: number) => { + return await request.get({ url: `/wms/count-config/get?id=` + id }) +} + +// 新增盘点配置 +export const createCountConfig = async (data: CountConfigVO) => { + return await request.post({ url: `/wms/count-config/create`, data }) +} + +// 修改盘点配置 +export const updateCountConfig = async (data: CountConfigVO) => { + return await request.put({ url: `/wms/count-config/update`, data }) +} + +// 删除盘点配置 +export const deleteCountConfig = async (id: number) => { + return await request.delete({ url: `/wms/count-config/delete?id=` + id }) +} + +// 导出盘点配置 Excel +export const exportCountConfig = async (params) => { + return await request.download({ url: `/wms/count-config/export-excel`, params }) +} + +// 下载用户导入模板 +export const importTemplate = () => { + return request.download({ url: '/wms/count-config/get-import-template' }) +} \ No newline at end of file diff --git a/src/views/wms/countManage/count/countConfig/countConfig.data.ts b/src/views/wms/countManage/count/countConfig/countConfig.data.ts new file mode 100644 index 000000000..c51d95cfd --- /dev/null +++ b/src/views/wms/countManage/count/countConfig/countConfig.data.ts @@ -0,0 +1,88 @@ +import type { CrudSchema } from '@/hooks/web/useCrudSchemas' +import { dateFormatter } from '@/utils/formatTime' + +// 表单校验 +export const CountConfigRules = reactive({ + itemCode: [required], + available: [required], + concurrencyStamp: [required], +}) + +export const CountConfig = useCrudSchemas(reactive([ + { + label: '物品代码', + field: 'itemCode', + sort: 'custom', + isSearch: true, + }, + { + label: '物料名称', + field: 'itemName', + sort: 'custom', + }, + { + label: '背番', + field: 'desc1', + sort: 'custom', + }, + { + label: '计量单位', + field: 'uom', + sort: 'custom', + }, + { + label: '包装规格', + field: 'packUnit', + sort: 'custom', + }, + { + label: '包装数量', + field: 'packQty', + sort: 'custom', + }, + { + label: '盘点模式(1:二分之一,2:逐个)', + field: 'countType', + sort: 'custom', + }, + { + label: '转换率', + field: 'conversionRate', + sort: 'custom', + }, + { + label: '是否可用', + field: 'available', + sort: 'custom', + }, + { + label: '备注', + field: 'remark', + sort: 'custom', + }, + { + label: '创建时间', + field: 'createTime', + sort: 'custom', + formatter: dateFormatter, + 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')] + } + }, + isForm: false, + }, + { + label: '操作', + field: 'action', + isForm: false, + table: { + width: 150, + fixed: 'right' + } + } +])) diff --git a/src/views/wms/countManage/count/countConfig/index.vue b/src/views/wms/countManage/count/countConfig/index.vue new file mode 100644 index 000000000..3a71f2d2c --- /dev/null +++ b/src/views/wms/countManage/count/countConfig/index.vue @@ -0,0 +1,244 @@ + + + diff --git a/src/views/wms/countManage/count/countJobMain/index.vue b/src/views/wms/countManage/count/countJobMain/index.vue index cb744daa7..3bb9b999e 100644 --- a/src/views/wms/countManage/count/countJobMain/index.vue +++ b/src/views/wms/countManage/count/countJobMain/index.vue @@ -301,14 +301,16 @@ const buttonTableClick = async (val, row) => { importTemplateData.value.templateTitle = "盘点任务导入模板.xlsx" importTemplateData.value.templateUrl = await CountJobMainApi.importTemplate() handleImport(row.id) - } else if (val == 'lineTypeImport') { - // 线边盘点 - importUrl.value = "/wms/count-job-main/lineTypeImport" - importTitle.value = '线边盘点' - importTemplateData.value.templateTitle = "线边盘点任务导入模板.xlsx" - importTemplateData.value.templateUrl = await CountJobMainApi.lineTypeImportTemplate() - handleImport(row.id) - } else if (val == 'done') { + } + // else if (val == 'lineTypeImport') { + // // 线边盘点 + // importUrl.value = "/wms/count-job-main/lineTypeImport" + // importTitle.value = '线边盘点' + // importTemplateData.value.templateTitle = "线边盘点任务导入模板.xlsx" + // importTemplateData.value.templateUrl = await CountJobMainApi.lineTypeImportTemplate() + // handleImport(row.id) + // } + else if (val == 'done') { // 完成 handleDone(row.id) }