From 01234763ead69643a1c2835bccaa01e09858eb78 Mon Sep 17 00:00:00 2001 From: ljlong_2630 Date: Wed, 15 May 2024 09:48:52 +0800 Subject: [PATCH] =?UTF-8?q?=E5=88=B6=E9=80=A0=E5=95=86=E4=BE=9B=E5=BA=94?= =?UTF-8?q?=E5=95=86=E4=BB=A3=E7=A0=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/api/eam/equipmentManufacturer/index.ts | 63 +++++ src/api/eam/equipmentSupplier/index.ts | 63 +++++ .../equipmentManufacturer.data.ts | 139 ++++++++++ src/views/eam/equipmentManufacturer/index.vue | 244 ++++++++++++++++++ .../equipmentSupplier.data.ts | 145 +++++++++++ src/views/eam/equipmentSupplier/index.vue | 244 ++++++++++++++++++ .../system/messageSet/messageSet.data.ts | 7 +- .../tableActionRel/tableActionRel.data.ts | 12 +- 8 files changed, 908 insertions(+), 9 deletions(-) create mode 100644 src/api/eam/equipmentManufacturer/index.ts create mode 100644 src/api/eam/equipmentSupplier/index.ts create mode 100644 src/views/eam/equipmentManufacturer/equipmentManufacturer.data.ts create mode 100644 src/views/eam/equipmentManufacturer/index.vue create mode 100644 src/views/eam/equipmentSupplier/equipmentSupplier.data.ts create mode 100644 src/views/eam/equipmentSupplier/index.vue diff --git a/src/api/eam/equipmentManufacturer/index.ts b/src/api/eam/equipmentManufacturer/index.ts new file mode 100644 index 000000000..d735e38e4 --- /dev/null +++ b/src/api/eam/equipmentManufacturer/index.ts @@ -0,0 +1,63 @@ +import request from '@/config/axios' + +export interface EquipmentManufacturerVO { + id: number + number: string + name: string + shortName: string + address: string + country: string + city: string + phone: string + fax: string + postId: string + contacts: string + departmentCode: string + remark: string + siteId: string + available: string + deletionTime: Date + deleterId: byte[] + concurrencyStamp: number +} + +// 查询设备制造商列表 +export const getEquipmentManufacturerPage = async (params) => { + if (params.isSearch) { + delete params.isSearch + const data = {...params} + return await request.post({ url: '/eam/basic/equipment-manufacturer/senior', data }) + } else { + return await request.get({ url: `/eam/basic/equipment-manufacturer/page`, params }) + } +} + +// 查询设备制造商详情 +export const getEquipmentManufacturer = async (id: number) => { + return await request.get({ url: `/eam/basic/equipment-manufacturer/get?id=` + id }) +} + +// 新增设备制造商 +export const createEquipmentManufacturer = async (data: EquipmentManufacturerVO) => { + return await request.post({ url: `/eam/basic/equipment-manufacturer/create`, data }) +} + +// 修改设备制造商 +export const updateEquipmentManufacturer = async (data: EquipmentManufacturerVO) => { + return await request.put({ url: `/eam/basic/equipment-manufacturer/update`, data }) +} + +// 删除设备制造商 +export const deleteEquipmentManufacturer = async (id: number) => { + return await request.delete({ url: `/eam/basic/equipment-manufacturer/delete?id=` + id }) +} + +// 导出设备制造商 Excel +export const exportEquipmentManufacturer = async (params) => { + return await request.download({ url: `/eam/basic/equipment-manufacturer/export-excel`, params }) +} + +// 下载用户导入模板 +export const importTemplate = () => { + return request.download({ url: '/eam/basic/equipment-manufacturer/get-import-template' }) +} \ No newline at end of file diff --git a/src/api/eam/equipmentSupplier/index.ts b/src/api/eam/equipmentSupplier/index.ts new file mode 100644 index 000000000..3026e600c --- /dev/null +++ b/src/api/eam/equipmentSupplier/index.ts @@ -0,0 +1,63 @@ +import request from '@/config/axios' + +export interface EquipmentSupplierVO { + id: number + number: string + name: string + shortName: string + address: string + country: string + city: string + phone: string + fax: string + postId: string + contacts: string + departmentCode: string + remark: string + siteId: string + available: string + deletionTime: Date + deleterId: byte[] + concurrencyStamp: number +} + +// 查询供应商列表 +export const getEquipmentSupplierPage = async (params) => { + if (params.isSearch) { + delete params.isSearch + const data = {...params} + return await request.post({ url: '/eam/basic/equipment-supplier/senior', data }) + } else { + return await request.get({ url: `/eam/basic/equipment-supplier/page`, params }) + } +} + +// 查询供应商详情 +export const getEquipmentSupplier = async (id: number) => { + return await request.get({ url: `/eam/basic/equipment-supplier/get?id=` + id }) +} + +// 新增供应商 +export const createEquipmentSupplier = async (data: EquipmentSupplierVO) => { + return await request.post({ url: `/eam/basic/equipment-supplier/create`, data }) +} + +// 修改供应商 +export const updateEquipmentSupplier = async (data: EquipmentSupplierVO) => { + return await request.put({ url: `/eam/basic/equipment-supplier/update`, data }) +} + +// 删除供应商 +export const deleteEquipmentSupplier = async (id: number) => { + return await request.delete({ url: `/eam/basic/equipment-supplier/delete?id=` + id }) +} + +// 导出供应商 Excel +export const exportEquipmentSupplier = async (params) => { + return await request.download({ url: `/eam/basic/equipment-supplier/export-excel`, params }) +} + +// 下载用户导入模板 +export const importTemplate = () => { + return request.download({ url: '/eam/basic/equipment-supplier/get-import-template' }) +} \ No newline at end of file diff --git a/src/views/eam/equipmentManufacturer/equipmentManufacturer.data.ts b/src/views/eam/equipmentManufacturer/equipmentManufacturer.data.ts new file mode 100644 index 000000000..b2f57cff9 --- /dev/null +++ b/src/views/eam/equipmentManufacturer/equipmentManufacturer.data.ts @@ -0,0 +1,139 @@ +import type { CrudSchema } from '@/hooks/web/useCrudSchemas' +import { dateFormatter } from '@/utils/formatTime' +import { handleTreeToComponentOptions } from '@/utils/tree' +import * as DeptApi from '@/api/system/dept' +const deptList = ref([]) // 树形结构 + +// 加载部门树(默认格式) +deptList.value = handleTreeToComponentOptions(await DeptApi.getSimpleDeptList()) + +// 表单校验 +export const EquipmentManufacturerRules = reactive({ + number: [required], + name: [required], + concurrencyStamp: [required] +}) + +export const EquipmentManufacturer = useCrudSchemas(reactive([ + + { + label: '设备厂商编号', + field: 'number', + sort: 'custom', + isSearch: true, + fixed: 'left', + isForm: false, + }, + { + label: '名称', + field: 'name', + sort: 'custom', + isSearch: true + }, + { + label: '简称', + field: 'shortName', + sort: 'custom', + isSearch: true + }, + { + label: '地址', + field: 'address', + sort: 'custom', + isSearch: true + }, + { + label: '国家', + field: 'country', + sort: 'custom', + isSearch: true + }, + { + label: '城市', + field: 'city', + sort: 'custom', + isSearch: true + }, + { + label: '电话', + field: 'phone', + sort: 'custom', + isSearch: true + }, + { + label: '传真', + field: 'fax', + sort: 'custom', + isSearch: true + }, + { + label: '邮编', + field: 'postId', + sort: 'custom', + isSearch: true + }, + { + label: '联系人', + field: 'contacts', + sort: 'custom', + isSearch: true + }, + { + label: '部门', + field: 'departmentCode', + sort: 'custom', + isSearch: true, + form: { + component: 'TreeSelect', + componentProps: { // 假设deptList是部门数据列表 + data: deptList, + placeholder: "请选择部门", + filterable: true, + // multiple: true, + } + } + }, + { + label: '备注', + field: 'remark', + sort: 'custom', + isSearch: true, + form: { + component: 'Input', + componentProps: { + type: 'textarea' + } + } + }, + { + label: '是否可用', + field: 'available', + sort: 'custom', + dictType: DICT_TYPE.TRUE_FALSE, + dictClass: 'string', // 默认都是字符串类型其他暂不考虑 + isSearch: true, + form: { + component: 'Switch', + value: 'TRUE', + componentProps: { + inactiveValue: 'FALSE', + activeValue: 'TRUE' + } + }, + search: { + component: 'Select', + }, + table: { + width: 110 + } + }, + { + label: '操作', + field: 'action', + isForm: false, + table: { + width: 150, + fixed: 'right' + } + } +])) diff --git a/src/views/eam/equipmentManufacturer/index.vue b/src/views/eam/equipmentManufacturer/index.vue new file mode 100644 index 000000000..3189ad974 --- /dev/null +++ b/src/views/eam/equipmentManufacturer/index.vue @@ -0,0 +1,244 @@ + + + diff --git a/src/views/eam/equipmentSupplier/equipmentSupplier.data.ts b/src/views/eam/equipmentSupplier/equipmentSupplier.data.ts new file mode 100644 index 000000000..2aaf9e1d6 --- /dev/null +++ b/src/views/eam/equipmentSupplier/equipmentSupplier.data.ts @@ -0,0 +1,145 @@ +import type { CrudSchema } from '@/hooks/web/useCrudSchemas' +import { dateFormatter } from '@/utils/formatTime' +import { validateHanset,validateNumDot, validateEmail } from '@/utils/validator' +import { handleTreeToComponentOptions } from '@/utils/tree' +import * as DeptApi from '@/api/system/dept' +const deptList = ref([]) // 树形结构 + +// 加载部门树(默认格式) +deptList.value = handleTreeToComponentOptions(await DeptApi.getSimpleDeptList()) + +// 表单校验 +export const EquipmentSupplierRules = reactive({ + number: [required], + name: [required], + concurrencyStamp: [required], + phone: [ + { validator:validateHanset, message: '手机号格式不正确', trigger: 'blur'} + ], + postId: [ + {validator:validateNumDot, message: '邮编格式不正确', trigger: 'blur'} + ] +}) + +export const EquipmentSupplier = useCrudSchemas(reactive([ + { + label: '供应商编号', + field: 'number', + sort: 'custom', + isSearch: true, + fixed: 'left', + isForm: false, + }, + { + label: '名称', + field: 'name', + sort: 'custom', + isSearch: true + }, + { + label: '简称', + field: 'shortName', + sort: 'custom', + isSearch: true + }, + { + label: '地址', + field: 'address', + sort: 'custom', + isSearch: true + }, + { + label: '国家', + field: 'country', + sort: 'custom', + isSearch: true + }, + { + label: '城市', + field: 'city', + sort: 'custom', + isSearch: true + }, + { + label: '电话', + field: 'phone', + sort: 'custom', + isSearch: true + }, + { + label: '传真', + field: 'fax', + sort: 'custom', + isSearch: true + }, + { + label: '邮编', + field: 'postId', + sort: 'custom', + isSearch: true + }, + { + label: '联系人', + field: 'contacts', + sort: 'custom', + isSearch: true + }, + { + label: '部门', + field: 'departmentCode', + sort: 'custom', + isSearch: true, + form: { + component: 'TreeSelect', + componentProps: { // 假设deptList是部门数据列表 + data: deptList, + placeholder: "请选择部门", + filterable: true, + // multiple: true, + } + } + }, + { + label: '备注', + field: 'remark', + sort: 'custom', + isSearch: true, + form: { + component: 'Input', + componentProps: { + type: 'textarea' + } + } + }, + { + label: '是否可用', + field: 'available', + sort: 'custom', + dictType: DICT_TYPE.TRUE_FALSE, + dictClass: 'string', // 默认都是字符串类型其他暂不考虑 + isSearch: true, + form: { + component: 'Switch', + value: 'TRUE', + componentProps: { + inactiveValue: 'FALSE', + activeValue: 'TRUE' + } + }, + search: { + component: 'Select', + }, + table: { + width: 110 + } + }, + { + label: '操作', + field: 'action', + isForm: false, + table: { + width: 150, + fixed: 'right' + } + } +])) diff --git a/src/views/eam/equipmentSupplier/index.vue b/src/views/eam/equipmentSupplier/index.vue new file mode 100644 index 000000000..3a41de721 --- /dev/null +++ b/src/views/eam/equipmentSupplier/index.vue @@ -0,0 +1,244 @@ + + + diff --git a/src/views/system/messageSet/messageSet.data.ts b/src/views/system/messageSet/messageSet.data.ts index 4b3351b90..dc02dda1c 100644 --- a/src/views/system/messageSet/messageSet.data.ts +++ b/src/views/system/messageSet/messageSet.data.ts @@ -146,7 +146,7 @@ export const MessageSet = useCrudSchemas(reactive([ } }, { - label: '短信模板是否启用', + label: '短信模板启用', field: 'smsTemplateEnabled', sort: 'custom', isSearch: true, @@ -207,7 +207,7 @@ export const MessageSet = useCrudSchemas(reactive([ }, }, { - label: '邮件模板是否启用', + label: '邮件模板启用', field: 'emailTemplateEnabled', sort: 'custom', isSearch: true, @@ -269,10 +269,11 @@ export const MessageSet = useCrudSchemas(reactive([ }, }, { - label: '内部消息模板是否启用', + label: '内部消息模板启用', field: 'internalMessageTemplateEnabled', sort: 'custom', isSearch: true, + width: 200, formatter: (_: Recordable, __: TableColumn, cellValue: boolean) => { return trueFalse.find(item=>cellValue==item.value).label }, diff --git a/src/views/system/tableActionRel/tableActionRel.data.ts b/src/views/system/tableActionRel/tableActionRel.data.ts index 2f5e171a3..2b153078d 100644 --- a/src/views/system/tableActionRel/tableActionRel.data.ts +++ b/src/views/system/tableActionRel/tableActionRel.data.ts @@ -28,13 +28,13 @@ export const TableActionRel = useCrudSchemas(reactive([ dictClass: 'string', // 默认都是字符串类型其他暂不考虑 isSearch: true, form: { - component: 'SelectV2', + component: 'Select', componentProps: { filterable: true, } }, search: { - component: 'SelectV2', + component: 'Select', componentProps: { filterable: true, } @@ -47,15 +47,15 @@ export const TableActionRel = useCrudSchemas(reactive([ isSearch: true, isDetail: false, dictType: DICT_TYPE.NOTICE_ACTION_TYPE, - dictClass: 'string', // 默认都是字符串类型其他暂不考虑 + dictClass: 'number', // 默认都是字符串类型其他暂不考虑 form: { - component: 'SelectV2', + component: 'Select', componentProps: { filterable: true, } }, search: { - component: 'SelectV2', + component: 'Select', componentProps: { filterable: true, } @@ -79,7 +79,7 @@ export const TableActionRel = useCrudSchemas(reactive([ dictType: DICT_TYPE.TRUE_FALSE, dictClass: 'string', // 默认都是字符串类型其他暂不考虑 form: { - component: 'SelectV2', + component: 'Select', } }, {