diff --git a/src/api/wms/mesBarCode/index.ts b/src/api/wms/mesBarCode/index.ts
new file mode 100644
index 000000000..ba37485d6
--- /dev/null
+++ b/src/api/wms/mesBarCode/index.ts
@@ -0,0 +1,65 @@
+import request from '@/config/axios'
+
+export interface MesBarCodeVO {
+ id: number
+ plat: number
+ counter: string
+ sign: string
+ option: string
+ lowerLim: string
+ upperLimit: string
+ itac: string
+ type: string
+ lengthBc: number
+ posMat: string
+ lengthMat: number
+ posRevlv: string
+ partNumber: string
+ packLabel: string
+ oesLabel: string
+ checkRvl: string
+ days: number
+ available: string
+ remark: string
+}
+
+// 查询生产条码清单列表
+export const getMesBarCodePage = async (params) => {
+ if (params.isSearch) {
+ delete params.isSearch
+ const data = {...params}
+ return await request.post({ url: '/wms/mes-bar-code/senior', data })
+ } else {
+ return await request.get({ url: `/wms/mes-bar-code/page`, params })
+ }
+}
+
+// 查询生产条码清单详情
+export const getMesBarCode = async (id: number) => {
+ return await request.get({ url: `/wms/mes-bar-code/get?id=` + id })
+}
+
+// 新增生产条码清单
+export const createMesBarCode = async (data: MesBarCodeVO) => {
+ return await request.post({ url: `/wms/mes-bar-code/create`, data })
+}
+
+// 修改生产条码清单
+export const updateMesBarCode = async (data: MesBarCodeVO) => {
+ return await request.put({ url: `/wms/mes-bar-code/update`, data })
+}
+
+// 删除生产条码清单
+export const deleteMesBarCode = async (id: number) => {
+ return await request.delete({ url: `/wms/mes-bar-code/delete?id=` + id })
+}
+
+// 导出生产条码清单 Excel
+export const exportMesBarCode = async (params) => {
+ return await request.download({ url: `/wms/mes-bar-code/export-excel`, params })
+}
+
+// 下载用户导入模板
+export const importTemplate = () => {
+ return request.download({ url: '/wms/mes-bar-code/get-import-template' })
+}
\ No newline at end of file
diff --git a/src/views/wms/mes/mesBarCode/index.vue b/src/views/wms/mes/mesBarCode/index.vue
new file mode 100644
index 000000000..b24a20fa1
--- /dev/null
+++ b/src/views/wms/mes/mesBarCode/index.vue
@@ -0,0 +1,244 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {{ row.code }}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/views/wms/mes/mesBarCode/mesBarCode.data.ts b/src/views/wms/mes/mesBarCode/mesBarCode.data.ts
new file mode 100644
index 000000000..39b4c5a7a
--- /dev/null
+++ b/src/views/wms/mes/mesBarCode/mesBarCode.data.ts
@@ -0,0 +1,174 @@
+import type { CrudSchema } from '@/hooks/web/useCrudSchemas'
+import { dateFormatter } from '@/utils/formatTime'
+
+// 表单校验
+export const MesBarCodeRules = reactive({
+ available: [required],
+})
+
+export const MesBarCode = useCrudSchemas(reactive([
+ {
+ label: 'id',
+ field: 'id',
+ sort: 'custom',
+ isForm: false,
+ },
+ {
+ label: 'Plnt',
+ field: 'plat',
+ sort: 'custom',
+ isSearch: true,
+ form: {
+ component: 'InputNumber',
+ value: 0
+ },
+ },
+ {
+ label: 'Counter',
+ field: 'counter',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ label: 'SIGN',
+ field: 'sign',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ label: 'Option',
+ field: 'option',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ label: 'Lower Lim.',
+ field: 'lowerLim',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ label: 'UpperLimit',
+ field: 'upperLimit',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ label: 'ITAC',
+ field: 'itac',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ label: 'Type',
+ field: 'type',
+ sort: 'custom',
+ isSearch: true,
+ form: {
+ component: 'SelectV2'
+ },
+ },
+ {
+ label: 'Length BC',
+ field: 'lengthBc',
+ sort: 'custom',
+ isSearch: true,
+ form: {
+ component: 'InputNumber',
+ value: 0
+ },
+ },
+ {
+ label: 'Pos. mat',
+ field: 'posMat',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ label: 'Length mat',
+ field: 'lengthMat',
+ sort: 'custom',
+ isSearch: true,
+ form: {
+ component: 'InputNumber',
+ value: 0
+ },
+ },
+ {
+ label: 'Pos. revlv',
+ field: 'posRevlv',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ label: 'Part number',
+ field: 'partNumber',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ label: 'Pack Label',
+ field: 'packLabel',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ label: 'OES-Label',
+ field: 'oesLabel',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ label: 'Check Rvl',
+ field: 'checkRvl',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ label: 'Days',
+ field: 'days',
+ sort: 'custom',
+ isSearch: true,
+ form: {
+ component: 'InputNumber',
+ value: 0
+ },
+ },
+ {
+ label: '是否可用',
+ field: 'available',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ 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: 'remark',
+ sort: 'custom',
+ isSearch: true,
+ },
+ {
+ label: '操作',
+ field: 'action',
+ isForm: false,
+ table: {
+ width: 150,
+ fixed: 'right'
+ }
+ }
+]))