Showing
18 changed files
with
564 additions
and
1286 deletions
src/api/equipment/ledger.ts
0 → 100644
1 | +import {defHttp} from "/@/utils/http/axios"; | ||
2 | +import {omit} from "lodash-es"; | ||
3 | + | ||
4 | +/** | ||
5 | + * 列表 | ||
6 | + */ | ||
7 | + | ||
8 | +export const getLedgerList = (params) => { | ||
9 | + const { page, pageSize } = params; | ||
10 | + const otherParams = omit(params, ['page', 'pageSize']); | ||
11 | + return defHttp.post<any>({ | ||
12 | + url: `/da/pageData?page=${page}&pageSize=${pageSize}`, | ||
13 | + params: otherParams, | ||
14 | + }); | ||
15 | +}; | ||
16 | + | ||
17 | + | ||
18 | +/** | ||
19 | +*组织 | ||
20 | +*/ | ||
21 | +export const getOrgList = () => { | ||
22 | + return defHttp.get<any>({ | ||
23 | + url: `/organization/me/list`, | ||
24 | + }); | ||
25 | +}; | ||
26 | + | ||
27 | +/** | ||
28 | +*组织 | ||
29 | +*/ | ||
30 | +export const getUserListByOrg = (params) => { | ||
31 | + return defHttp.get<any>({ | ||
32 | + url: `/user/tenant/page`, | ||
33 | + params, | ||
34 | + }); | ||
35 | +}; | ||
36 | + | ||
37 | +/** | ||
38 | + * 新增 | ||
39 | + */ | ||
40 | +export const saveLedger = (params) => { | ||
41 | + return defHttp.post<any>({ | ||
42 | + url: `/da/save`, | ||
43 | + params, | ||
44 | + }); | ||
45 | +}; | ||
46 | + | ||
47 | +/** | ||
48 | + *详情 | ||
49 | + */ | ||
50 | +export const ledgerEditDetailPage = (params) => { | ||
51 | + return defHttp.get<any>({ | ||
52 | + url: `/da/detail`, | ||
53 | + params, | ||
54 | + }); | ||
55 | +}; | ||
56 | +/** | ||
57 | + *删除 | ||
58 | + */ | ||
59 | +export const deleteLedger = (params) => { | ||
60 | + return defHttp.get<any>({ | ||
61 | + url: `/da/delete`, | ||
62 | + params, | ||
63 | + }); | ||
64 | +}; |
@@ -132,6 +132,7 @@ export type ComponentType = | @@ -132,6 +132,7 @@ export type ComponentType = | ||
132 | | 'ControlGroup' | 132 | | 'ControlGroup' |
133 | | 'JSONEditor' | 133 | | 'JSONEditor' |
134 | | 'OrgTreeSelect' | 134 | | 'OrgTreeSelect' |
135 | + | 'CategoryTreeSelect' | ||
135 | | 'CreateSpeed' | 136 | | 'CreateSpeed' |
136 | | 'ExtendDesc' | 137 | | 'ExtendDesc' |
137 | | 'JavaScriptFunctionEditor' | 138 | | 'JavaScriptFunctionEditor' |
@@ -51,6 +51,12 @@ export enum DeviceStatusEnum { | @@ -51,6 +51,12 @@ export enum DeviceStatusEnum { | ||
51 | OFFLINE = 'OFFLINE', | 51 | OFFLINE = 'OFFLINE', |
52 | } | 52 | } |
53 | 53 | ||
54 | +export enum SbStatusEnum { | ||
55 | + FAULT = 'FAULT', | ||
56 | + NORMAL = 'NORMAL', | ||
57 | + SCRAP = 'SCRAP', | ||
58 | +} | ||
59 | + | ||
54 | export enum CommandStatusEnum { | 60 | export enum CommandStatusEnum { |
55 | QUEUED = 'QUEUED', | 61 | QUEUED = 'QUEUED', |
56 | SENT = 'SENT', | 62 | SENT = 'SENT', |
1 | export default { | 1 | export default { |
2 | productText: '产品', | 2 | productText: '产品', |
3 | deviceText: '设备', | 3 | deviceText: '设备', |
4 | + codeText: '设备编码', | ||
5 | + brandText: '设备品牌', | ||
4 | attributeText: '属性', | 6 | attributeText: '属性', |
5 | organizationText: '组织', | 7 | organizationText: '组织', |
6 | tenantText: '租户', | 8 | tenantText: '租户', |
@@ -29,4 +31,5 @@ export default { | @@ -29,4 +31,5 @@ export default { | ||
29 | commandDeliveryText: '命令下发', | 31 | commandDeliveryText: '命令下发', |
30 | serviceText: '服务', | 32 | serviceText: '服务', |
31 | dateRangeText: '时间范围', | 33 | dateRangeText: '时间范围', |
34 | + directorName: '负责人', | ||
32 | }; | 35 | }; |
@@ -85,6 +85,12 @@ export default { | @@ -85,6 +85,12 @@ export default { | ||
85 | ONLINE: '在线', | 85 | ONLINE: '在线', |
86 | OFFLINE: '离线', | 86 | OFFLINE: '离线', |
87 | }, | 87 | }, |
88 | + sbStatus: { | ||
89 | + ALL: '全部', | ||
90 | + FAULT: '故障', | ||
91 | + NORMAL: '正常', | ||
92 | + SCRAP: '报废', | ||
93 | + }, | ||
88 | commandStatus: { | 94 | commandStatus: { |
89 | QUEUED: '队列中', | 95 | QUEUED: '队列中', |
90 | SENT: '已发送', | 96 | SENT: '已发送', |
1 | export default { | 1 | export default { |
2 | ledgerListText: '台账列表', | 2 | ledgerListText: '台账列表', |
3 | + nameCode: '设备编码', | ||
4 | + brandText: '设备编码', | ||
5 | + modelNumText: '型号', | ||
6 | + buyDate: '购买时间', | ||
7 | + productDate: '出厂日期', | ||
8 | + registeDate: '登记日期', | ||
9 | + receiveDate: '验收日期', | ||
10 | + priceText: '价格', | ||
11 | + specificationsText: '规格', | ||
12 | + manufacturerText: '生产厂家', | ||
13 | + description: '备注', | ||
3 | createLedgerText: '创建台账', | 14 | createLedgerText: '创建台账', |
15 | + editLedgerText: '编辑台账', | ||
4 | importLedgerText: '导入台账', | 16 | importLedgerText: '导入台账', |
5 | deviceName: '设备名称', | 17 | deviceName: '设备名称', |
6 | deviceCode: '设备编码', | 18 | deviceCode: '设备编码', |
7 | deviceType: '设备类型', | 19 | deviceType: '设备类型', |
8 | status: '状态', | 20 | status: '状态', |
9 | - description: '负责人', | ||
10 | operationSuccessText: '操作成功', | 21 | operationSuccessText: '操作成功', |
11 | editProductText: '编辑台账', | 22 | editProductText: '编辑台账', |
12 | updateOrganization: '修改组织', | 23 | updateOrganization: '修改组织', |
13 | batchActionText: '批量操作', | 24 | batchActionText: '批量操作', |
25 | + FAULT: '故障', | ||
26 | + NORMAL: '正常', | ||
27 | + SCRAP: '报废', | ||
14 | } | 28 | } |
src/views/common/CategoryTreeSelect/index.ts
0 → 100644
1 | +export { default as CategoryTreeSelect } from './index.vue'; |
1 | +<template> | ||
2 | + <section class="!flex"> | ||
3 | + <ApiTreeSelect v-bind="getBindProps" class="flex-auto" /> | ||
4 | + <Button v-if="getShowCreate" type="link" @click="handleOpenCreate" :disabled="disabled"> | ||
5 | + {{ t('component.orgSelect.createOrganizationText') }} | ||
6 | + </Button> | ||
7 | + <OrganizationDrawer v-if="getShowCreate" @register="registerDrawer" @success="handleReload" /> | ||
8 | + </section> | ||
9 | +</template> | ||
10 | +<script setup lang="ts"> | ||
11 | +import { ApiTreeSelect } from '/@/components/Form'; | ||
12 | +import { Button } from 'ant-design-vue'; | ||
13 | +import {computed, ref, unref} from "vue"; | ||
14 | +import {getAllCategory} from "/@/api/equipment/category"; | ||
15 | +import {useI18n} from "/@/hooks/web/useI18n"; | ||
16 | +const { t } = useI18n(); | ||
17 | +const emit = defineEmits(['change', 'optionsChange']); | ||
18 | + | ||
19 | +const props = withDefaults( | ||
20 | + defineProps<{ | ||
21 | + value?: string | string[]; | ||
22 | + apiTreeSelectProps?: Recordable; | ||
23 | + showCreate?: boolean; | ||
24 | + disabled?: boolean; | ||
25 | + }>(), | ||
26 | + { | ||
27 | + showCreate: true, | ||
28 | + disabled: false, | ||
29 | + } | ||
30 | +); | ||
31 | +const timespan = ref(Date.now()); | ||
32 | +const needReload = ref(true); | ||
33 | +const cateList = ref<Recordable[]>([]); | ||
34 | +const getBindProps = computed<Recordable>(() => { | ||
35 | + const { value, apiTreeSelectProps = {}, disabled } = props; | ||
36 | + const { params = {} } = apiTreeSelectProps; | ||
37 | + return { | ||
38 | + replaceFields: { children: 'children', key: 'id', title: 'name', value: 'id' }, | ||
39 | + getPopupContainer: () => document.body, | ||
40 | + placeholder: t('equipment.category.categoryPlaceholderText'), | ||
41 | + maxLength: 250, | ||
42 | + disabled, | ||
43 | + ...apiTreeSelectProps, | ||
44 | + value, | ||
45 | + dropdownStyle: { maxHeight: '300px' }, | ||
46 | + api: async (params: any) => { | ||
47 | + try { | ||
48 | + if (!unref(needReload)) return unref(cateList); | ||
49 | + const result = ((await getAllCategory(params)) as unknown as Recordable[]) || []; | ||
50 | + cateList.value = result; | ||
51 | + needReload.value = false; | ||
52 | + return result; | ||
53 | + } catch (error) { | ||
54 | + return unref(cateList); | ||
55 | + } | ||
56 | + }, | ||
57 | + params: { | ||
58 | + ...params, | ||
59 | + _t: unref(timespan), | ||
60 | + }, | ||
61 | + onChange: (...args: any[]) => { | ||
62 | + emit('change', ...args); | ||
63 | + }, | ||
64 | + onOptionsChange: (...args: any[]) => emit('optionsChange', ...args), | ||
65 | + }; | ||
66 | +}); | ||
67 | + | ||
68 | +</script> |
@@ -8,11 +8,15 @@ | @@ -8,11 +8,15 @@ | ||
8 | 8 | ||
9 | import { ref } from 'vue'; | 9 | import { ref } from 'vue'; |
10 | import organizationIdTree from '../OrganizationIdTree.vue'; | 10 | import organizationIdTree from '../OrganizationIdTree.vue'; |
11 | -export const useResetOrganizationTree = (searchInfo: Recordable) => { | 11 | +export const useResetOrganizationTree = (searchInfo: Recordable, type?: string) => { |
12 | const organizationIdTreeRef = ref<InstanceType<typeof organizationIdTree>>(); | 12 | const organizationIdTreeRef = ref<InstanceType<typeof organizationIdTree>>(); |
13 | async function resetFn() { | 13 | async function resetFn() { |
14 | organizationIdTreeRef.value.resetOrganization(); | 14 | organizationIdTreeRef.value.resetOrganization(); |
15 | - searchInfo.organizationId = null; | 15 | + if (type === 'equipment') { |
16 | + searchInfo.categoryId = null; | ||
17 | + }else { | ||
18 | + searchInfo.organizationId = null; | ||
19 | + } | ||
16 | } | 20 | } |
17 | return { organizationIdTreeRef, resetFn }; | 21 | return { organizationIdTreeRef, resetFn }; |
18 | }; | 22 | }; |
@@ -25,6 +25,7 @@ | @@ -25,6 +25,7 @@ | ||
25 | import { computed, onMounted, ref, unref, useAttrs } from 'vue'; | 25 | import { computed, onMounted, ref, unref, useAttrs } from 'vue'; |
26 | import { BasicTree, TreeItem } from '/@/components/Tree'; | 26 | import { BasicTree, TreeItem } from '/@/components/Tree'; |
27 | import { getOrganizationList } from '/@/api/system/system'; | 27 | import { getOrganizationList } from '/@/api/system/system'; |
28 | + import { getAllCategory } from '/@/api/equipment/category'; | ||
28 | import { CaretRightOutlined } from '@ant-design/icons-vue'; | 29 | import { CaretRightOutlined } from '@ant-design/icons-vue'; |
29 | import { getBoundingClientRect } from '/@/utils/domUtils'; | 30 | import { getBoundingClientRect } from '/@/utils/domUtils'; |
30 | import { BasicTreePropsType, OrganizationTreeActionType } from './types'; | 31 | import { BasicTreePropsType, OrganizationTreeActionType } from './types'; |
@@ -34,7 +35,6 @@ | @@ -34,7 +35,6 @@ | ||
34 | const props = defineProps<OrganizationTreePropsType>(); | 35 | const props = defineProps<OrganizationTreePropsType>(); |
35 | 36 | ||
36 | const attrs = useAttrs(); | 37 | const attrs = useAttrs(); |
37 | - | ||
38 | const tree = ref<Nullable<HTMLDivElement>>(); | 38 | const tree = ref<Nullable<HTMLDivElement>>(); |
39 | const emit = defineEmits(['select', 'register']); | 39 | const emit = defineEmits(['select', 'register']); |
40 | const treeData = ref<TreeItem[]>([]); | 40 | const treeData = ref<TreeItem[]>([]); |
@@ -75,7 +75,14 @@ | @@ -75,7 +75,14 @@ | ||
75 | }; | 75 | }; |
76 | 76 | ||
77 | onMounted(async () => { | 77 | onMounted(async () => { |
78 | - treeData.value = (await getOrganizationList()) as unknown as TreeItem[]; | 78 | + let api:any; |
79 | + if (attrs?.listType === 'equipment') { | ||
80 | + api = getAllCategory() | ||
81 | + }else { | ||
82 | + api = getOrganizationList() | ||
83 | + } | ||
84 | + | ||
85 | + treeData.value = (await api) as unknown as TreeItem[]; | ||
79 | const getAllIds = findForAllId(treeData.value as any, []); | 86 | const getAllIds = findForAllId(treeData.value as any, []); |
80 | //设置要展开的id | 87 | //设置要展开的id |
81 | treeExpandData.value = getAllIds; | 88 | treeExpandData.value = getAllIds; |
@@ -88,12 +95,11 @@ | @@ -88,12 +95,11 @@ | ||
88 | }); | 95 | }); |
89 | 96 | ||
90 | const getProps = computed<OrganizationTreePropsType>(() => ({ ...props, ...unref(innerProps) })); | 97 | const getProps = computed<OrganizationTreePropsType>(() => ({ ...props, ...unref(innerProps) })); |
91 | - | ||
92 | const { t } = useI18n(); | 98 | const { t } = useI18n(); |
93 | 99 | ||
94 | const getBindData = computed(() => { | 100 | const getBindData = computed(() => { |
95 | return { | 101 | return { |
96 | - title: t('common.organizationList'), | 102 | + title: attrs?.listType === 'equipment' ? t('equipment.category.categoryText') : t('common.organizationList'), |
97 | toolbar: true, | 103 | toolbar: true, |
98 | search: true, | 104 | search: true, |
99 | clickRowToExpand: false, | 105 | clickRowToExpand: false, |
1 | +<template> | ||
2 | + <BasicDrawer | ||
3 | + destroyOnClose | ||
4 | + v-bind="$attrs" | ||
5 | + showFooter | ||
6 | + width="35%" | ||
7 | + :maskClosable="true" | ||
8 | + :title="businessText" | ||
9 | + @register="registerDrawer" | ||
10 | + wrapClassName="report-drawer" | ||
11 | + @ok="handleSubmit" | ||
12 | + @close="handleClose" | ||
13 | + > | ||
14 | + <BasicForm @register="registerForm"> | ||
15 | + | ||
16 | + </BasicForm> | ||
17 | + </BasicDrawer> | ||
18 | +</template> | ||
19 | +<script setup lang="ts"> | ||
20 | +import {nextTick, reactive, ref} from "vue"; | ||
21 | +import { BasicDrawer, useDrawerInner } from '/@/components/Drawer'; | ||
22 | +import { SchemaFiled} from "../../config/enum"; | ||
23 | +import {BasicForm,useForm} from "/@/components/Form"; | ||
24 | +import {formSchema} from "../../config/data"; | ||
25 | +import {useHooks} from "/@/views/report/config/hooks/index.hooks"; | ||
26 | +import {getUserListByOrg,ledgerEditDetailPage,saveLedger } from "/@/api/equipment/ledger" | ||
27 | +import {useUserStore} from "/@/store/modules/user"; | ||
28 | +import {useThrottleFn} from "@vueuse/shared/index"; | ||
29 | +import {useMessage} from "/@/hooks/web/useMessage"; | ||
30 | +import {useI18n} from "/@/hooks/web/useI18n"; | ||
31 | +const { | ||
32 | + setDefaultTime, | ||
33 | + disableCustomWeekly, | ||
34 | + setPropsForModal, | ||
35 | + removeFields, | ||
36 | +} = useHooks(); | ||
37 | +const userInfo = useUserStore(); | ||
38 | +const restData = reactive({ | ||
39 | + data: {}, | ||
40 | +}); | ||
41 | +const { createMessage } = useMessage(); | ||
42 | +const { t } = useI18n(); | ||
43 | +const emits = defineEmits(['success', 'register']); | ||
44 | +const [registerForm, { validate, resetFields, setFieldsValue, updateSchema, setProps }] = useForm( | ||
45 | + { | ||
46 | + labelWidth: 140, | ||
47 | + schemas: formSchema, | ||
48 | + showActionButtonGroup: false, | ||
49 | + fieldMapToTime: [[SchemaFiled.DATE_RANGE, [SchemaFiled.START_TS, SchemaFiled.END_TS]]], | ||
50 | + } | ||
51 | +); | ||
52 | +// 定义人员选项 | ||
53 | +const userOptions = ref<any[]>([]); | ||
54 | + | ||
55 | +// 监听 org 字段的变化 | ||
56 | +const handleOrgChange = async (orgId: string) => { | ||
57 | + if (!orgId) { | ||
58 | + userOptions.value = []; // 清空人员选项 | ||
59 | + updateSchema({ | ||
60 | + field: 'directorId', | ||
61 | + componentProps: { options: [] }, | ||
62 | + }); | ||
63 | + return; | ||
64 | + } | ||
65 | + const _data = { | ||
66 | + page: '1', | ||
67 | + pageSize: '999', | ||
68 | + tenantId: userInfo.getUserInfo.tenantId!, | ||
69 | + organizationId: orgId | ||
70 | + } | ||
71 | + // 调用接口 B 获取人员数据 | ||
72 | + const userList = await getUserListByOrg(_data); | ||
73 | + console.log(userList,'userList') | ||
74 | + userOptions.value = userList?.items.map(user => ({ | ||
75 | + label: user.username, | ||
76 | + value: user.id, | ||
77 | + })); | ||
78 | + | ||
79 | + // 更新 user 字段的选项 | ||
80 | + updateSchema({ | ||
81 | + field: 'directorId', | ||
82 | + componentProps: { options: userOptions.value }, | ||
83 | + }); | ||
84 | +}; | ||
85 | + | ||
86 | + | ||
87 | + | ||
88 | + | ||
89 | +const businessText = ref(''); | ||
90 | +const [registerDrawer, { setDrawerProps, closeDrawer }] = useDrawerInner(async (data) => { | ||
91 | + try { | ||
92 | + await nextTick(); | ||
93 | + handleClose(); | ||
94 | + businessText.value = data.text; | ||
95 | + // 更新 formSchema 中的 org 字段,绑定 change 事件 | ||
96 | + updateSchema({ | ||
97 | + field: 'org', | ||
98 | + componentProps: { | ||
99 | + onChange: handleOrgChange, | ||
100 | + }, | ||
101 | + }); | ||
102 | + setFieldsValue(setDefaultTime()); | ||
103 | + updateSchema(disableCustomWeekly(0)); | ||
104 | + setDrawerProps(setPropsForModal(businessText.value)); | ||
105 | + if (businessText.value === 'add') return; | ||
106 | + const rest = await ledgerEditDetailPage({id: data.record?.id}); | ||
107 | + restData.data = rest ?? {}; | ||
108 | + | ||
109 | + await setFieldsValue({ | ||
110 | + ...restData.data, | ||
111 | + }); | ||
112 | + | ||
113 | + } finally { | ||
114 | + setDrawerProps({ loading: false }); | ||
115 | + } | ||
116 | +}); | ||
117 | +const handleClose = () => { | ||
118 | + resetValue(); | ||
119 | +} | ||
120 | +//重置表单 | ||
121 | +const resetValue = () => { | ||
122 | + resetFields(); | ||
123 | +}; | ||
124 | + | ||
125 | +const handleSubmit = () => { | ||
126 | + useThrottle(); | ||
127 | +}; | ||
128 | + | ||
129 | +const useThrottle = useThrottleFn(() => { | ||
130 | + getValue(); | ||
131 | +}, 2000); | ||
132 | + | ||
133 | +const getValue = async () => { | ||
134 | + try { | ||
135 | + setDrawerProps({ confirmLoading: true }); | ||
136 | + const values = await validate(); | ||
137 | + if (!values) return; | ||
138 | + const data = { | ||
139 | + ...values, | ||
140 | + buyDate: values.buyDate?.format('YYYY-MM-DD hh:mm:ss'), | ||
141 | + productDate: values.productDate?.format('YYYY-MM-DD hh:mm:ss'), | ||
142 | + receiveDate: values.receiveDate?.format('YYYY-MM-DD hh:mm:ss'), | ||
143 | + registeDate: values.registeDate?.format('YYYY-MM-DD hh:mm:ss'), | ||
144 | + }; | ||
145 | + removeFields.forEach((item) => { | ||
146 | + Reflect.deleteProperty(data, item); | ||
147 | + }); | ||
148 | + businessText.value === 'add' | ||
149 | + ? await saveLedger(data) | ||
150 | + : saveLedger({ ...restData.data, ...data }); | ||
151 | + createMessage.success( | ||
152 | + t(businessText.value !== 'add' ? 'common.editSuccessText' : 'common.createSuccessText') | ||
153 | + ); | ||
154 | + closeDrawer(); | ||
155 | + handleClose(); | ||
156 | + setTimeout(() => { | ||
157 | + emits('success'); | ||
158 | + }, 500); | ||
159 | + } finally { | ||
160 | + setDrawerProps({ confirmLoading: false }); | ||
161 | + } | ||
162 | +}; | ||
163 | + | ||
164 | +</script> |
1 | -import { FormSchema, useComponentRegister } from '/@/components/Form'; | ||
2 | -import { findDictItemByCode } from '/@/api/system/dict'; | ||
3 | -import { getGatewayDevice, queryDeviceProfileBy } from '/@/api/device/deviceManager'; | ||
4 | -import { JSONEditor } from '/@/components/CodeEditor'; | ||
5 | -import { DeviceRecord, DeviceTypeEnum } from '/@/api/device/model/deviceModel'; | ||
6 | -import { h } from 'vue'; | ||
7 | -import { TaskTypeEnum } from '/@/views/task/center/config'; | ||
8 | -import { createImgPreview } from '/@/components/Preview'; | ||
9 | -import { uploadThumbnail } from '/@/api/configuration/center/configurationCenter'; | ||
10 | -import LockControlGroup from '/@/components/Form/src/components/LockControlGroup.vue'; | ||
11 | -import { OrgTreeSelect } from '/@/views/common/OrgTreeSelect'; | ||
12 | -import { TCPProtocolTypeEnum, TransportTypeEnum } from '/@/enums/deviceEnum'; | ||
13 | -import { HexInput, InputTypeEnum } from '../../profiles/components/ObjectModelForm/HexInput'; | ||
14 | -import { DeviceProfileDetail } from '/@/api/device/model/deviceConfigModel'; | ||
15 | -import { getDeviceProfileOtaPackages, getOtaPackageInfo } from '/@/api/ota'; | ||
16 | -import { QueryDeviceProfileOtaPackagesType } from '/@/api/ota/model'; | ||
17 | -import { OTAPackageType } from '/@/enums/otaEnum'; | ||
18 | -import { createPickerSearch } from '/@/utils/pickerSearch'; | ||
19 | -import { useI18n } from '/@/hooks/web/useI18n'; | ||
20 | - | ||
21 | -useComponentRegister('JSONEditor', JSONEditor); | ||
22 | -useComponentRegister('LockControlGroup', LockControlGroup); | ||
23 | -useComponentRegister('OrgTreeSelect', OrgTreeSelect); | ||
24 | -useComponentRegister('HexInput', HexInput); | ||
25 | - | 1 | +import {FormSchema as BFormSchema, useComponentRegister} from "../../../../components/Form"; |
2 | +import {useI18n} from "../../../../hooks/web/useI18n"; | ||
26 | const { t } = useI18n(); | 3 | const { t } = useI18n(); |
27 | - | ||
28 | -export enum TypeEnum { | ||
29 | - IS_GATEWAY = 'GATEWAY', | ||
30 | - SENSOR = 'SENSOR', | ||
31 | -} | ||
32 | - | ||
33 | -export const isGateWay = (type: string) => { | ||
34 | - return type === TypeEnum.IS_GATEWAY; | ||
35 | -}; | ||
36 | - | ||
37 | -const updateProductHelpMessage = [ | ||
38 | - t('deviceManagement.device.updateProductHelpMessage.text1'), | ||
39 | - t('deviceManagement.device.updateProductHelpMessage.text2'), | ||
40 | -]; | ||
41 | - | ||
42 | -export const updateOrgHelpMessage = [ | ||
43 | - t('deviceManagement.device.updateOrgHelpMessage.text1'), | ||
44 | - t('deviceManagement.device.updateOrgHelpMessage.text2'), | ||
45 | - t('deviceManagement.device.updateOrgHelpMessage.text3'), | 4 | +import { CategoryTreeSelect } from '../../../common/CategoryTreeSelect'; |
5 | +import { OrgTreeSelect } from '../../../common/OrgTreeSelect'; | ||
6 | +useComponentRegister('OrgTreeSelect', OrgTreeSelect); | ||
7 | +useComponentRegister('CategoryTreeSelect', CategoryTreeSelect); | ||
8 | +const statusOptions = [ | ||
9 | + { label: t('equipment.ledger.NORMAL'), value: 'NORMAL' }, | ||
10 | + { label: t('equipment.ledger.FAULT'), value: 'FAULT' }, | ||
11 | + { label: t('equipment.ledger.SCRAP'), value: 'SCRAP' }, | ||
46 | ]; | 12 | ]; |
47 | -// 第一步的表单 | ||
48 | -export const step1Schemas: FormSchema[] = [ | ||
49 | - { | ||
50 | - field: 'icon', | ||
51 | - label: t('business.deviceImageText'), | ||
52 | - component: 'ApiUpload', | ||
53 | - changeEvent: 'update:fileList', | ||
54 | - valueField: 'fileList', | ||
55 | - componentProps: ({ formModel }) => { | ||
56 | - return { | ||
57 | - listType: 'picture-card', | ||
58 | - maxFileLimit: 1, | ||
59 | - accept: '.png,.jpg,.jpeg,.gif', | ||
60 | - api: async (file: File) => { | ||
61 | - try { | ||
62 | - const formData = new FormData(); | ||
63 | - formData.set('file', file); | ||
64 | - const { fileStaticUri, fileName } = await uploadThumbnail(formData); | ||
65 | - return { | ||
66 | - uid: fileStaticUri, | ||
67 | - name: fileName, | ||
68 | - url: fileStaticUri, | ||
69 | - }; | ||
70 | - } catch (error) { | ||
71 | - return {}; | ||
72 | - } | ||
73 | - }, | ||
74 | - onPreview: (fileList) => { | ||
75 | - createImgPreview({ imageList: [fileList.url!] }); | ||
76 | - }, | ||
77 | - onDelete(url: string) { | ||
78 | - formModel.deleteUrl = url!; | ||
79 | - }, | ||
80 | - }; | ||
81 | - }, | ||
82 | - }, | 13 | +export const formSchema: BFormSchema[] = [ |
83 | { | 14 | { |
84 | - field: 'deleteUrl', | ||
85 | - label: '', | ||
86 | - component: 'Input', | ||
87 | - show: false, | ||
88 | - }, | ||
89 | - { | ||
90 | - field: 'alias', | ||
91 | - label: t('business.aliasText'), | 15 | + field: 'code', |
16 | + label: t('equipment.ledger.nameCode'), | ||
92 | component: 'Input', | 17 | component: 'Input', |
18 | + colProps: { span: 24 }, | ||
19 | + required: true, | ||
93 | componentProps: { | 20 | componentProps: { |
94 | - maxLength: 32, | 21 | + maxLength: 20, |
95 | }, | 22 | }, |
96 | }, | 23 | }, |
97 | { | 24 | { |
98 | field: 'name', | 25 | field: 'name', |
99 | - label: t('business.deviceNameText'), | 26 | + label: t('equipment.ledger.deviceName'), |
100 | component: 'Input', | 27 | component: 'Input', |
28 | + colProps: { span: 24 }, | ||
29 | + required: true, | ||
101 | componentProps: { | 30 | componentProps: { |
102 | - maxLength: 32, | 31 | + maxLength: 20, |
103 | }, | 32 | }, |
104 | - required: true, | ||
105 | - slot: 'snCode', | ||
106 | }, | 33 | }, |
107 | { | 34 | { |
108 | - field: 'transportType', | ||
109 | - label: '类型', | ||
110 | - component: 'Input', | ||
111 | - show: false, | ||
112 | - }, | ||
113 | - { | ||
114 | - field: 'deviceProfileId', | ||
115 | - label: '', | ||
116 | - component: 'Input', | ||
117 | - show: false, | ||
118 | - }, | ||
119 | - { | ||
120 | - field: 'isUpdate', | ||
121 | - label: '编辑模式', | ||
122 | - component: 'Switch', | ||
123 | - show: false, | ||
124 | - }, | ||
125 | - { | ||
126 | - field: 'tcpDeviceProtocol', | ||
127 | - label: 'TCP设备协议类型', | ||
128 | - component: 'Input', | ||
129 | - show: false, | ||
130 | - }, | ||
131 | - | ||
132 | - { | ||
133 | - field: 'profileId', | ||
134 | - label: t('business.affiliatedProductText'), | 35 | + field: 'categoryId', |
36 | + label: t('equipment.category.categoryText'), | ||
37 | + colProps: { span: 24 }, | ||
38 | + component: 'CategoryTreeSelect', | ||
135 | required: true, | 39 | required: true, |
136 | - component: 'LockControlGroup', | ||
137 | - helpMessage: updateProductHelpMessage, | ||
138 | - renderComponentContent: () => ({ | ||
139 | - popconfirmTitle: () => | ||
140 | - updateProductHelpMessage.map((text) => h('div', { style: { maxWidth: '200px' } }, text)), | ||
141 | - }), | ||
142 | - componentProps: ({ formActionType, formModel }) => { | ||
143 | - const { setFieldsValue } = formActionType; | ||
144 | - return { | ||
145 | - component: 'ApiSelect', | ||
146 | - defaultLockStatus: !!formModel?.isUpdate, | ||
147 | - componentProps: { | ||
148 | - api: async () => { | ||
149 | - const options = await queryDeviceProfileBy({ | ||
150 | - deviceType: formModel?.isUpdate ? formModel?.deviceType : null, | ||
151 | - }); | ||
152 | - | ||
153 | - return options; | ||
154 | - }, | ||
155 | - labelField: 'name', | ||
156 | - valueField: 'tbProfileId', | ||
157 | - onChange(_value: string, option: DeviceProfileDetail) { | ||
158 | - const { deviceType, transportType, id } = option; | ||
159 | - setFieldsValue({ | ||
160 | - deviceType: deviceType, | ||
161 | - transportType, | ||
162 | - deviceProfileId: id, | ||
163 | - gatewayId: null, | ||
164 | - code: null, | ||
165 | - addressCode: null, | ||
166 | - tcpDeviceProtocol: option?.profileData?.transportConfiguration?.protocol, | ||
167 | - }); | ||
168 | - }, | ||
169 | - onOptionsChange(options: (DeviceProfileDetail & Record<'value', string>)[]) { | ||
170 | - const { profileId } = formModel; | ||
171 | - if (profileId) { | ||
172 | - const selectRecord = options.find((item) => item.value === profileId); | ||
173 | - selectRecord && | ||
174 | - setFieldsValue({ | ||
175 | - transportType: selectRecord!.transportType, | ||
176 | - tcpDeviceProtocol: selectRecord?.profileData?.transportConfiguration?.protocol, | ||
177 | - }); | ||
178 | - } | ||
179 | - }, | ||
180 | - placeholder: t('deviceManagement.device.productPlaceholderText'), | ||
181 | - ...createPickerSearch(), | ||
182 | - }, | ||
183 | - }; | ||
184 | - }, | ||
185 | }, | 40 | }, |
186 | { | 41 | { |
187 | - field: 'deviceType', | ||
188 | - label: t('business.deviceTypeText'), | 42 | + field: 'status', |
43 | + component: 'Select', | ||
44 | + label: t('equipment.ledger.status'), | ||
189 | required: true, | 45 | required: true, |
190 | - component: 'ApiSelect', | ||
191 | - dynamicDisabled: true, | ||
192 | - helpMessage: t('deviceManagement.device.deviceTypeHelpText'), | 46 | + colProps: { span: 24 }, |
47 | + defaultValue: 'NORMAL', | ||
193 | componentProps: { | 48 | componentProps: { |
194 | - api: findDictItemByCode, | ||
195 | - params: { | ||
196 | - dictCode: 'device_type', | ||
197 | - }, | ||
198 | - labelField: 'itemText', | ||
199 | - valueField: 'itemValue', | ||
200 | - }, | ||
201 | - }, | ||
202 | - { | ||
203 | - field: 'addressType', | ||
204 | - label: '', | ||
205 | - component: 'Input', | ||
206 | - show: false, | ||
207 | - defaultValue: 'HEX', | ||
208 | - }, | ||
209 | - { | ||
210 | - field: 'deviceState', | ||
211 | - label: '', | ||
212 | - component: 'Input', | ||
213 | - show: false, | ||
214 | - }, | ||
215 | - { | ||
216 | - field: 'addressCode', | ||
217 | - label: t('deviceManagement.device.addressCodeText'), | ||
218 | - dynamicDisabled({ values }) { | ||
219 | - return ( | ||
220 | - values.isUpdate && | ||
221 | - values.deviceType === DeviceTypeEnum.SENSOR && | ||
222 | - values.deviceState === 'ONLINE' && | ||
223 | - values.transportType === TransportTypeEnum.TCP | ||
224 | - ); | ||
225 | - }, | ||
226 | - dynamicRules({ values }) { | ||
227 | - return [ | ||
228 | - { | ||
229 | - required: | ||
230 | - values?.transportType === TransportTypeEnum.TCP && | ||
231 | - values?.tcpDeviceProtocol === TCPProtocolTypeEnum.MODBUS_RTU, | ||
232 | - message: t('deviceManagement.device.addressCodeHelpText'), | ||
233 | - pattern: values?.addressType === 'HEX' ? /^[0-9A-Fa-f]{2}$/ : /^[0-9A-Fa-f]{1,2}$/, | ||
234 | - }, | ||
235 | - ]; | ||
236 | - }, | ||
237 | - helpMessage({ values }) { | ||
238 | - return [ | ||
239 | - t('deviceManagement.device.addressCodeHelpText'), | ||
240 | - values.transportType === TransportTypeEnum.TCP && | ||
241 | - values.deviceType === DeviceTypeEnum.SENSOR | ||
242 | - ? t('deviceManagement.device.tcpAddressCodeHelpText') | ||
243 | - : '', | ||
244 | - ]; | ||
245 | - }, | ||
246 | - component: 'HexInput', | ||
247 | - changeEvent: 'update:value', | ||
248 | - valueField: 'value', | ||
249 | - componentProps: ({ formModel }) => { | ||
250 | - return { | ||
251 | - type: InputTypeEnum.HEX, | ||
252 | - maxValue: parseInt('FF', 16), | ||
253 | - onHexChange: (e) => { | ||
254 | - formModel.addressType = e; | ||
255 | - }, | ||
256 | - }; | ||
257 | - }, | ||
258 | - ifShow: ({ values }) => { | ||
259 | - return ( | ||
260 | - values?.transportType === TransportTypeEnum.TCP && | ||
261 | - values?.tcpDeviceProtocol === TCPProtocolTypeEnum.MODBUS_RTU | ||
262 | - ); | ||
263 | - }, | ||
264 | - }, | ||
265 | - { | ||
266 | - field: 'code', | ||
267 | - label: t('deviceManagement.device.codeText'), | ||
268 | - dynamicRules({ values }) { | ||
269 | - return [ | ||
270 | - { | ||
271 | - required: | ||
272 | - values?.transportType === TransportTypeEnum.TCP && | ||
273 | - values.deviceType === DeviceTypeEnum.SENSOR, | ||
274 | - }, | ||
275 | - ]; | ||
276 | - }, | ||
277 | - dynamicDisabled({ values }) { | ||
278 | - return ( | ||
279 | - values.isUpdate && | ||
280 | - values.deviceType === DeviceTypeEnum.SENSOR && | ||
281 | - values.deviceState === 'ONLINE' && | ||
282 | - values.transportType === TransportTypeEnum.TCP | ||
283 | - ); | ||
284 | - }, | ||
285 | - helpMessage({ values }) { | ||
286 | - return ( | ||
287 | - values.transportType === TransportTypeEnum.TCP && | ||
288 | - values.deviceType === DeviceTypeEnum.SENSOR | ||
289 | - ? ['tcp网关子设备在线时,不能修改设备标识或地址码'] | ||
290 | - : false | ||
291 | - ) as any; | ||
292 | - }, | ||
293 | - component: 'Input', | ||
294 | - componentProps: () => { | ||
295 | - return { | ||
296 | - maxLength: 255, | ||
297 | - placeholder: t('deviceManagement.device.codePlaceholderText'), | ||
298 | - }; | ||
299 | - }, | ||
300 | - ifShow: ({ values }) => { | ||
301 | - return ( | ||
302 | - values?.transportType === TransportTypeEnum.TCP && | ||
303 | - values?.tcpDeviceProtocol === TaskTypeEnum.CUSTOM | ||
304 | - ); | 49 | + options: statusOptions, |
305 | }, | 50 | }, |
306 | }, | 51 | }, |
307 | - | ||
308 | { | 52 | { |
309 | - field: 'brand', | ||
310 | - component: 'ApiRadioGroup', | ||
311 | - label: t('deviceManagement.device.brandText'), | 53 | + field: 'org', |
54 | + component: 'OrgTreeSelect', | ||
55 | + label: '负责人组织', | ||
312 | required: true, | 56 | required: true, |
313 | - defaultValue: 'DIY_', | 57 | + colProps: { span: 24 }, |
314 | componentProps: { | 58 | componentProps: { |
315 | - api: findDictItemByCode, | ||
316 | - params: { | ||
317 | - dictCode: 'device_brand_gateway', | 59 | + // 添加 change 事件 |
60 | + onChange: (value: string) => { | ||
61 | + // 这里需要触发加载人员数据的逻辑 | ||
62 | + console.log(value,'value') | ||
318 | }, | 63 | }, |
319 | - labelField: 'itemText', | ||
320 | - valueField: 'itemValue', | ||
321 | - }, | ||
322 | - ifShow: ({ values }) => isGateWay(values.deviceType), | ||
323 | - }, | ||
324 | - { | ||
325 | - field: 'gatewayId', | ||
326 | - label: t('enum.deviceType.GATEWAY'), | ||
327 | - required: true, | ||
328 | - component: 'ApiSelect', | ||
329 | - ifShow: ({ values }) => values.deviceType === 'SENSOR', | ||
330 | - componentProps: ({ formModel, formActionType }) => { | ||
331 | - const { transportType, deviceType, gatewayId } = formModel; | ||
332 | - const { setFieldsValue } = formActionType; | ||
333 | - if (!transportType) return {}; | ||
334 | - return { | ||
335 | - api: async (params: Recordable) => { | ||
336 | - try { | ||
337 | - const result = await getGatewayDevice(params as any); | ||
338 | - return result.map((item) => ({ ...item, alias: item.alias || item.name })); | ||
339 | - } catch (e) { | ||
340 | - return []; | ||
341 | - } | ||
342 | - }, | ||
343 | - params: { | ||
344 | - transportType, | ||
345 | - gatewayId: deviceType === DeviceTypeEnum.SENSOR && gatewayId ? gatewayId : null, | ||
346 | - }, | ||
347 | - valueField: 'tbDeviceId', | ||
348 | - labelField: 'alias', | ||
349 | - onChange: async (_value: string, option: DeviceRecord) => { | ||
350 | - setFieldsValue({ sensorOrganizationId: option?.organizationId, organizationId: null }); | ||
351 | - }, | ||
352 | - onOptionsChange(options: (DeviceRecord & Record<'value', string>)[]) { | ||
353 | - if (formModel?.deviceType === DeviceTypeEnum.SENSOR && formModel?.gatewayId) { | ||
354 | - const result = options.find((item) => item.value === formModel?.gatewayId); | ||
355 | - result && setFieldsValue({ sensorOrganizationId: result?.organizationId }); | ||
356 | - } | ||
357 | - }, | ||
358 | - ...createPickerSearch(), | ||
359 | - }; | ||
360 | - }, | ||
361 | - }, | ||
362 | - { | ||
363 | - field: 'sensorOrganizationId', | ||
364 | - label: '依据网关设备请求的组织数组', | ||
365 | - component: 'Input', | ||
366 | - ifShow: false, | ||
367 | - }, | ||
368 | - { | ||
369 | - field: 'customerId', | ||
370 | - label: '用来判断编辑时禁用组织修改', | ||
371 | - component: 'Input', | ||
372 | - ifShow: false, | ||
373 | - }, | ||
374 | - { | ||
375 | - field: 'organizationId', | ||
376 | - label: t('business.affiliatedOrganizationText'), | ||
377 | - component: 'LockControlGroup', | ||
378 | - required: true, | ||
379 | - helpMessage: updateOrgHelpMessage, | ||
380 | - renderComponentContent: () => ({ | ||
381 | - popconfirmTitle: () => | ||
382 | - updateOrgHelpMessage.map((text) => h('div', { style: { maxWidth: '240px' } }, text)), | ||
383 | - }), | ||
384 | - componentProps: ({ formModel, formActionType }) => { | ||
385 | - return { | ||
386 | - component: 'OrgTreeSelect', | ||
387 | - defaultLockStatus: !!formModel?.isUpdate, | ||
388 | - disabled: !!formModel?.customerId, | ||
389 | - componentProps: { | ||
390 | - apiTreeSelectProps: { | ||
391 | - params: { | ||
392 | - organizationId: formModel?.sensorOrganizationId, | ||
393 | - }, | ||
394 | - }, | ||
395 | - onOptionsChange: (options: Recordable[]) => { | ||
396 | - if (!formModel?.organizationId && formModel?.deviceType === DeviceTypeEnum.SENSOR) { | ||
397 | - const firstItem = options?.[0]; | ||
398 | - | ||
399 | - if (firstItem && firstItem?.id) { | ||
400 | - const { setFieldsValue, clearValidate } = formActionType; | ||
401 | - setFieldsValue({ organizationId: firstItem.id }); | ||
402 | - clearValidate('organizationId'); | ||
403 | - } | ||
404 | - } | ||
405 | - }, | ||
406 | - placeholder: t('deviceManagement.device.organizationPlaceholderText'), | ||
407 | - }, | ||
408 | - }; | ||
409 | }, | 64 | }, |
410 | }, | 65 | }, |
411 | { | 66 | { |
412 | field: 'directorId', | 67 | field: 'directorId', |
413 | - label: t('deviceManagement.device.directorName'), | ||
414 | - component: 'Input', | ||
415 | - componentProps: { | ||
416 | - maxLength: 255, | ||
417 | - }, | ||
418 | - }, | ||
419 | - { | ||
420 | - field: 'label', | ||
421 | - label: t('deviceManagement.device.deviceLabelText'), | ||
422 | - component: 'Input', | ||
423 | - componentProps: { | ||
424 | - maxLength: 255, | ||
425 | - }, | ||
426 | - }, | ||
427 | - { | ||
428 | - field: 'deviceAddress', | ||
429 | - label: t('business.deviceLocationText'), | ||
430 | - component: 'Input', | ||
431 | - slot: 'deviceAddress', | ||
432 | - }, | ||
433 | - | ||
434 | - { | ||
435 | - field: 'firmwareId', | ||
436 | - label: t('deviceManagement.product.assignHardwareText'), | ||
437 | - component: 'ApiSearchSelect', | ||
438 | - ifShow: ({ model }) => model?.isUpdate, | ||
439 | - componentProps: ({ formModel }) => { | ||
440 | - return { | ||
441 | - api: async (params: QueryDeviceProfileOtaPackagesType) => { | ||
442 | - if (!params.deviceProfileId) return []; | ||
443 | - const result = await getDeviceProfileOtaPackages(params); | ||
444 | - return result.data.map((item) => ({ | ||
445 | - label: `${item.title}(${item.version})`, | ||
446 | - value: item.id.id, | ||
447 | - })); | ||
448 | - }, | ||
449 | - params: (textSearch: string) => { | ||
450 | - return { | ||
451 | - textSearch, | ||
452 | - page: 0, | ||
453 | - type: OTAPackageType.FIRMWARE, | ||
454 | - pageSize: 10, | ||
455 | - deviceProfileId: formModel?.profileId, | ||
456 | - }; | ||
457 | - }, | ||
458 | - queryApi: async (id: string) => { | ||
459 | - const result = await getOtaPackageInfo(id); | ||
460 | - return { label: `${result.title}(${result.version})`, value: result.id.id }; | ||
461 | - }, | ||
462 | - }; | ||
463 | - }, | ||
464 | - }, | ||
465 | - { | ||
466 | - field: 'softwareId', | ||
467 | - label: t('deviceManagement.product.assignSoftwareText'), | ||
468 | - component: 'ApiSearchSelect', | ||
469 | - ifShow: ({ model }) => model?.isUpdate, | ||
470 | - componentProps: ({ formModel }) => { | ||
471 | - return { | ||
472 | - api: async (params: QueryDeviceProfileOtaPackagesType) => { | ||
473 | - if (!params.deviceProfileId) return []; | ||
474 | - const result = await getDeviceProfileOtaPackages(params); | ||
475 | - return result.data.map((item) => ({ | ||
476 | - label: `${item.title}(${item.version})`, | ||
477 | - value: item.id.id, | ||
478 | - })); | ||
479 | - }, | ||
480 | - params: (textSearch: string) => { | ||
481 | - return { | ||
482 | - textSearch, | ||
483 | - page: 0, | ||
484 | - type: OTAPackageType.SOFTWARE, | ||
485 | - pageSize: 10, | ||
486 | - deviceProfileId: formModel?.profileId, | ||
487 | - }; | ||
488 | - }, | ||
489 | - queryApi: async (id: string) => { | ||
490 | - const result = await getOtaPackageInfo(id); | ||
491 | - return { label: `${result.title}(${result.version})`, value: result.id.id }; | ||
492 | - }, | ||
493 | - }; | ||
494 | - }, | ||
495 | - }, | ||
496 | - { | ||
497 | - field: 'description', | ||
498 | - label: t('common.remarkText'), | ||
499 | - component: 'InputTextArea', | ||
500 | - componentProps: { | ||
501 | - maxLength: 500, | ||
502 | - }, | ||
503 | - }, | ||
504 | - { | ||
505 | - field: 'id', | ||
506 | - label: 'id', | ||
507 | - component: 'Input', | ||
508 | - show: false, | ||
509 | - componentProps: { | ||
510 | - maxLength: 36, | ||
511 | - placeholder: '请输入id', | ||
512 | - }, | ||
513 | - }, | ||
514 | - { | ||
515 | - field: 'tenantId', | ||
516 | - label: '租户Code', | ||
517 | - component: 'Input', | ||
518 | - show: false, | ||
519 | - componentProps: { | ||
520 | - maxLength: 36, | ||
521 | - placeholder: '请输入租户Code', | ||
522 | - }, | ||
523 | - }, | ||
524 | - { | ||
525 | - field: 'tbDeviceId', | ||
526 | - label: 'tbDeviceId', | ||
527 | - component: 'Input', | ||
528 | - show: false, | 68 | + component: 'Select', |
69 | + label: '负责人', | ||
70 | + required: true, | ||
71 | + colProps: { span: 24 }, | ||
529 | componentProps: { | 72 | componentProps: { |
530 | - maxLength: 36, | ||
531 | - placeholder: '请输入tbDeviceId', | 73 | + // 动态加载的选项 |
74 | + options: [], // 初始为空,后续动态加载 | ||
532 | }, | 75 | }, |
533 | }, | 76 | }, |
534 | -]; | ||
535 | - | ||
536 | -export enum credentialTypeEnum { | ||
537 | - ACCESS_TOKEN = 'ACCESS_TOKEN', | ||
538 | - X_509 = 'X509_CERTIFICATE', | ||
539 | - MQTT_BASIC = 'MQTT_BASIC', | ||
540 | -} | ||
541 | -// 第二步的表单 | ||
542 | -export const step2Schemas: FormSchema[] = [ | ||
543 | - { | ||
544 | - label: '', | ||
545 | - component: 'Checkbox', | ||
546 | - field: 'addAgree', | ||
547 | - slot: 'addAgree', | ||
548 | - }, | ||
549 | { | 77 | { |
550 | - label: t('deviceManagement.device.certificateTypeText'), | 78 | + field: 'isOnline', |
551 | component: 'Select', | 79 | component: 'Select', |
552 | - field: 'credentialType', | 80 | + label: '是否联网', |
553 | required: true, | 81 | required: true, |
554 | - componentProps({ formActionType }) { | ||
555 | - const { updateSchema, setFieldsValue } = formActionType; | ||
556 | - return { | ||
557 | - options: [ | ||
558 | - { | ||
559 | - value: credentialTypeEnum.ACCESS_TOKEN, | ||
560 | - label: 'Access Token', | ||
561 | - }, | ||
562 | - { | ||
563 | - value: credentialTypeEnum.X_509, | ||
564 | - label: 'X.509', | ||
565 | - }, | ||
566 | - { | ||
567 | - value: credentialTypeEnum.MQTT_BASIC, | ||
568 | - label: 'MQTT Basic', | ||
569 | - }, | ||
570 | - ], | ||
571 | - onChange(value) { | ||
572 | - setFieldsValue({ | ||
573 | - publicKey: '', | ||
574 | - credentialsId: '', | ||
575 | - clientId: '', | ||
576 | - username: '', | ||
577 | - password: '', | ||
578 | - }); | ||
579 | - if (value === credentialTypeEnum.ACCESS_TOKEN) { | ||
580 | - updateSchema([ | ||
581 | - { | ||
582 | - field: 'credentialsId', | ||
583 | - ifShow: true, | ||
584 | - }, | ||
585 | - { | ||
586 | - field: 'clientId', | ||
587 | - ifShow: false, | ||
588 | - }, | ||
589 | - { | ||
590 | - field: 'username', | ||
591 | - ifShow: false, | ||
592 | - }, | ||
593 | - { | ||
594 | - field: 'password', | ||
595 | - ifShow: false, | ||
596 | - }, | ||
597 | - { | ||
598 | - field: 'publicKey', | ||
599 | - ifShow: false, | ||
600 | - }, | ||
601 | - ]); | ||
602 | - } else if (value === credentialTypeEnum.X_509) { | ||
603 | - updateSchema([ | ||
604 | - { | ||
605 | - field: 'publicKey', | ||
606 | - ifShow: true, | ||
607 | - }, | ||
608 | - { | ||
609 | - field: 'credentialsId', | ||
610 | - ifShow: false, | ||
611 | - }, | ||
612 | - { | ||
613 | - field: 'clientId', | ||
614 | - ifShow: false, | ||
615 | - }, | ||
616 | - { | ||
617 | - field: 'username', | ||
618 | - ifShow: false, | ||
619 | - }, | ||
620 | - { | ||
621 | - field: 'password', | ||
622 | - ifShow: false, | ||
623 | - }, | ||
624 | - ]); | ||
625 | - } else if (value === credentialTypeEnum.MQTT_BASIC) { | ||
626 | - updateSchema([ | ||
627 | - { | ||
628 | - field: 'clientId', | ||
629 | - ifShow: true, | ||
630 | - }, | ||
631 | - { | ||
632 | - field: 'username', | ||
633 | - ifShow: true, | ||
634 | - }, | ||
635 | - { | ||
636 | - field: 'password', | ||
637 | - ifShow: true, | ||
638 | - }, | ||
639 | - { | ||
640 | - field: 'publicKey', | ||
641 | - ifShow: false, | ||
642 | - }, | ||
643 | - { | ||
644 | - field: 'credentialsId', | ||
645 | - ifShow: false, | ||
646 | - }, | ||
647 | - ]); | ||
648 | - } else { | ||
649 | - updateSchema([ | ||
650 | - { | ||
651 | - field: 'clientId', | ||
652 | - ifShow: false, | ||
653 | - }, | ||
654 | - { | ||
655 | - field: 'username', | ||
656 | - ifShow: false, | ||
657 | - }, | ||
658 | - { | ||
659 | - field: 'password', | ||
660 | - ifShow: false, | ||
661 | - }, | ||
662 | - { | ||
663 | - field: 'publicKey', | ||
664 | - ifShow: false, | ||
665 | - }, | ||
666 | - { | ||
667 | - field: 'credentialsId', | ||
668 | - ifShow: false, | ||
669 | - }, | ||
670 | - ]); | ||
671 | - } | 82 | + colProps: { span: 24 }, |
83 | + componentProps: { | ||
84 | + options: [ | ||
85 | + { | ||
86 | + label: '是', | ||
87 | + value: true, | ||
672 | }, | 88 | }, |
673 | - }; | 89 | + { |
90 | + label: '否', | ||
91 | + value: false, | ||
92 | + } | ||
93 | + ], | ||
674 | }, | 94 | }, |
675 | - ifShow: ({ values }) => values.addAgree, | ||
676 | }, | 95 | }, |
677 | { | 96 | { |
678 | - label: t('deviceManagement.device.accessTokenText'), | 97 | + field: 'brand', |
98 | + label: t('equipment.ledger.brandText'), | ||
679 | component: 'Input', | 99 | component: 'Input', |
680 | - field: 'credentialsId', | ||
681 | - required: true, | ||
682 | - ifShow: false, | ||
683 | - slot: 'credentialsId', | 100 | + colProps: { span: 24 }, |
684 | componentProps: { | 101 | componentProps: { |
685 | - maxLength: 36, | 102 | + maxLength: 20, |
686 | }, | 103 | }, |
687 | }, | 104 | }, |
688 | { | 105 | { |
689 | - label: t('deviceManagement.device.rsaPublicKeyText'), | ||
690 | - component: 'InputTextArea', | ||
691 | - field: 'publicKey', | ||
692 | - required: true, | ||
693 | - ifShow: false, | 106 | + field: 'modelNum', |
107 | + label: t('equipment.ledger.modelNumText'), | ||
108 | + component: 'Input', | ||
109 | + colProps: { span: 24 }, | ||
694 | componentProps: { | 110 | componentProps: { |
695 | - rows: 8, | 111 | + maxLength: 20, |
696 | }, | 112 | }, |
697 | }, | 113 | }, |
698 | { | 114 | { |
699 | - label: t('deviceManagement.device.clientIdText'), | 115 | + field: 'specifications', |
116 | + label: t('equipment.ledger.specificationsText'), | ||
700 | component: 'Input', | 117 | component: 'Input', |
701 | - field: 'clientId', | ||
702 | - ifShow: false, | ||
703 | - slot: 'clientId', | 118 | + colProps: { span: 24 }, |
704 | componentProps: { | 119 | componentProps: { |
705 | - maxLength: 36, | 120 | + maxLength: 20, |
706 | }, | 121 | }, |
707 | }, | 122 | }, |
708 | { | 123 | { |
709 | - label: t('deviceManagement.device.usernameText'), | 124 | + field: 'specifications', |
125 | + label: t('equipment.ledger.manufacturerText'), | ||
710 | component: 'Input', | 126 | component: 'Input', |
711 | - field: 'username', | ||
712 | - required: true, | ||
713 | - ifShow: false, | 127 | + colProps: { span: 24 }, |
714 | componentProps: { | 128 | componentProps: { |
715 | - maxLength: 255, | 129 | + maxLength: 20, |
716 | }, | 130 | }, |
717 | }, | 131 | }, |
718 | { | 132 | { |
719 | - label: t('deviceManagement.device.passwordText'), | ||
720 | - component: 'InputPassword', | ||
721 | - field: 'password', | 133 | + field: 'buyDate', |
134 | + label: t('equipment.ledger.buyDate'), | ||
135 | + component: 'DatePicker', | ||
136 | + colProps: { span: 24 }, | ||
722 | componentProps: { | 137 | componentProps: { |
723 | - maxLength: 36, | ||
724 | - }, | ||
725 | - ifShow: false, | ||
726 | - }, | ||
727 | -]; | ||
728 | - | ||
729 | -// 管理凭证的表单配置项 | ||
730 | -export const TokenSchemas: FormSchema[] = [ | ||
731 | - { | ||
732 | - label: t('deviceManagement.device.certificateTypeText'), | ||
733 | - component: 'Select', | ||
734 | - field: 'credentialType', | ||
735 | - required: true, | ||
736 | - componentProps({ formActionType }) { | ||
737 | - const { updateSchema, setFieldsValue } = formActionType; | ||
738 | - return { | ||
739 | - options: [ | ||
740 | - { | ||
741 | - value: credentialTypeEnum.ACCESS_TOKEN, | ||
742 | - label: 'Access Token', | ||
743 | - }, | ||
744 | - { | ||
745 | - value: credentialTypeEnum.X_509, | ||
746 | - label: 'X.509', | ||
747 | - }, | ||
748 | - { | ||
749 | - value: credentialTypeEnum.MQTT_BASIC, | ||
750 | - label: 'MQTT Basic', | ||
751 | - }, | ||
752 | - ], | ||
753 | - onChange(value) { | ||
754 | - setFieldsValue({ | ||
755 | - publicKey: '', | ||
756 | - credentialsId: '', | ||
757 | - clientId: '', | ||
758 | - username: '', | ||
759 | - password: '', | ||
760 | - }); | ||
761 | - if (value === credentialTypeEnum.ACCESS_TOKEN) { | ||
762 | - updateSchema([ | ||
763 | - { | ||
764 | - field: 'credentialsId', | ||
765 | - ifShow: true, | ||
766 | - }, | ||
767 | - { | ||
768 | - field: 'clientId', | ||
769 | - ifShow: false, | ||
770 | - }, | ||
771 | - { | ||
772 | - field: 'username', | ||
773 | - ifShow: false, | ||
774 | - }, | ||
775 | - { | ||
776 | - field: 'password', | ||
777 | - ifShow: false, | ||
778 | - }, | ||
779 | - { | ||
780 | - field: 'publicKey', | ||
781 | - ifShow: false, | ||
782 | - }, | ||
783 | - ]); | ||
784 | - } else if (value === credentialTypeEnum.X_509) { | ||
785 | - updateSchema([ | ||
786 | - { | ||
787 | - field: 'publicKey', | ||
788 | - ifShow: true, | ||
789 | - }, | ||
790 | - { | ||
791 | - field: 'credentialsId', | ||
792 | - ifShow: false, | ||
793 | - }, | ||
794 | - { | ||
795 | - field: 'clientId', | ||
796 | - ifShow: false, | ||
797 | - }, | ||
798 | - { | ||
799 | - field: 'username', | ||
800 | - ifShow: false, | ||
801 | - }, | ||
802 | - { | ||
803 | - field: 'password', | ||
804 | - ifShow: false, | ||
805 | - }, | ||
806 | - ]); | ||
807 | - } else if (value === credentialTypeEnum.MQTT_BASIC) { | ||
808 | - updateSchema([ | ||
809 | - { | ||
810 | - field: 'clientId', | ||
811 | - ifShow: true, | ||
812 | - }, | ||
813 | - { | ||
814 | - field: 'username', | ||
815 | - ifShow: true, | ||
816 | - }, | ||
817 | - { | ||
818 | - field: 'password', | ||
819 | - ifShow: true, | ||
820 | - }, | ||
821 | - { | ||
822 | - field: 'publicKey', | ||
823 | - ifShow: false, | ||
824 | - }, | ||
825 | - { | ||
826 | - field: 'credentialsId', | ||
827 | - ifShow: false, | ||
828 | - }, | ||
829 | - ]); | ||
830 | - } else { | ||
831 | - updateSchema([ | ||
832 | - { | ||
833 | - field: 'clientId', | ||
834 | - ifShow: false, | ||
835 | - }, | ||
836 | - { | ||
837 | - field: 'username', | ||
838 | - ifShow: false, | ||
839 | - }, | ||
840 | - { | ||
841 | - field: 'password', | ||
842 | - ifShow: false, | ||
843 | - }, | ||
844 | - { | ||
845 | - field: 'publicKey', | ||
846 | - ifShow: false, | ||
847 | - }, | ||
848 | - { | ||
849 | - field: 'credentialsId', | ||
850 | - ifShow: false, | ||
851 | - }, | ||
852 | - ]); | ||
853 | - } | ||
854 | - }, | ||
855 | - }; | 138 | + format: 'YYYY-MM-DD hh:mm:ss', // 设置日期格式 |
139 | + showTime: true, // 显示时间选择器 | ||
856 | }, | 140 | }, |
857 | }, | 141 | }, |
858 | - { | ||
859 | - label: t('deviceManagement.device.accessTokenText'), | ||
860 | - component: 'Input', | ||
861 | - field: 'credentialsId', | ||
862 | - required: true, | ||
863 | - ifShow: false, | ||
864 | - slot: 'credentialsId', | 142 | +{ |
143 | + field: 'price', | ||
144 | + label: t('equipment.ledger.priceText'), | ||
145 | + component: 'InputNumber', | ||
146 | + colProps: { span: 24 }, | ||
865 | componentProps: { | 147 | componentProps: { |
866 | - maxLength: 36, | ||
867 | }, | 148 | }, |
868 | }, | 149 | }, |
869 | { | 150 | { |
870 | - label: t('deviceManagement.device.rsaPublicKeyText'), | ||
871 | - component: 'InputTextArea', | ||
872 | - field: 'publicKey', | ||
873 | - required: true, | ||
874 | - ifShow: false, | 151 | + field: 'productDate', |
152 | + label: t('equipment.ledger.productDate'), | ||
153 | + component: 'DatePicker', | ||
154 | + colProps: { span: 24 }, | ||
875 | componentProps: { | 155 | componentProps: { |
876 | - rows: 8, | 156 | + format: 'YYYY-MM-DD hh:mm:ss', // 设置日期格式 |
157 | + showTime: true, // 显示时间选择器 | ||
877 | }, | 158 | }, |
878 | }, | 159 | }, |
879 | { | 160 | { |
880 | - label: t('deviceManagement.device.clientIdText'), | ||
881 | - component: 'Input', | ||
882 | - field: 'clientId', | ||
883 | - ifShow: false, | ||
884 | - slot: 'clientId', | 161 | + field: 'receiveDate', |
162 | + label: t('equipment.ledger.receiveDate'), | ||
163 | + component: 'DatePicker', | ||
164 | + colProps: { span: 24 }, | ||
885 | componentProps: { | 165 | componentProps: { |
886 | - maxLength: 36, | 166 | + format: 'YYYY-MM-DD hh:mm:ss', // 设置日期格式 |
167 | + showTime: true, // 显示时间选择器 | ||
887 | }, | 168 | }, |
888 | }, | 169 | }, |
889 | { | 170 | { |
890 | - label: t('deviceManagement.device.usernameText'), | ||
891 | - component: 'Input', | ||
892 | - field: 'username', | ||
893 | - required: true, | ||
894 | - ifShow: false, | 171 | + field: 'registeDate', |
172 | + label: t('equipment.ledger.registeDate'), | ||
173 | + component: 'DatePicker', | ||
174 | + colProps: { span: 24 }, | ||
895 | componentProps: { | 175 | componentProps: { |
896 | - maxLength: 255, | 176 | + format: 'YYYY-MM-DD hh:mm:ss', // 设置日期格式 |
177 | + showTime: true, // 显示时间选择器 | ||
897 | }, | 178 | }, |
898 | }, | 179 | }, |
899 | { | 180 | { |
900 | - label: t('deviceManagement.device.passwordText'), | ||
901 | - component: 'InputPassword', | ||
902 | - field: 'password', | ||
903 | - ifShow: false, | 181 | + field: 'supplierId', |
182 | + component: 'OrgTreeSelect', | ||
183 | + label: '供应商', | ||
184 | + colProps: { span: 24 }, | ||
904 | componentProps: { | 185 | componentProps: { |
905 | - maxLength: 36, | ||
906 | - }, | ||
907 | - }, | ||
908 | - { | ||
909 | - label: 'id', | ||
910 | - component: 'Input', | ||
911 | - field: 'id', | ||
912 | - show: false, | ||
913 | - componentProps: { | ||
914 | - maxLength: 36, | ||
915 | - placeholder: '请输入id', | 186 | + // 添加 change 事件 |
187 | + onChange: (value: string) => { | ||
188 | + // 这里需要触发加载人员数据的逻辑 | ||
189 | + console.log(value,'value') | ||
190 | + }, | ||
916 | }, | 191 | }, |
917 | }, | 192 | }, |
918 | { | 193 | { |
919 | - label: 'tbDeviceId', | ||
920 | - component: 'Input', | ||
921 | - field: 'tbDeviceId', | ||
922 | - show: false, | 194 | + field: 'description', |
195 | + label: t('equipment.ledger.description'), | ||
196 | + component: 'InputTextArea', | ||
197 | + colProps: { span: 24 }, | ||
923 | componentProps: { | 198 | componentProps: { |
924 | - maxLength: 36, | ||
925 | - placeholder: '请输入tbDeviceId', | ||
926 | - }, | ||
927 | - dynamicRules: () => { | ||
928 | - return [ | ||
929 | - { | ||
930 | - required: false, | ||
931 | - validator: (_, value) => { | ||
932 | - if (String(value).length > 36) { | ||
933 | - return Promise.reject('字数不超过36个字'); | ||
934 | - } | ||
935 | - return Promise.resolve(); | ||
936 | - }, | ||
937 | - }, | ||
938 | - ]; | 199 | + maxLength: 200, |
939 | }, | 200 | }, |
940 | }, | 201 | }, |
202 | + | ||
941 | ]; | 203 | ]; |
src/views/equipment/ledger/config/enum.ts
0 → 100644
1 | +export enum SchemaFiled { | ||
2 | + WAY = 'queryMode', | ||
3 | + TIME_PERIOD = 'timePeriod', | ||
4 | + KEYS = 'keys', | ||
5 | + DATE_RANGE = 'dataRange', | ||
6 | + START_TS = 'startTs', | ||
7 | + END_TS = 'endTs', | ||
8 | + INTERVAL = 'interval', | ||
9 | + LIMIT = 'limit', | ||
10 | + AGG = 'agg', | ||
11 | + ORDER_BY = 'orderBy', | ||
12 | + DATA_TYPE = 'dataType', | ||
13 | +} |
1 | -import { formatToDate } from '/@/utils/dateUtil'; | ||
2 | import { BasicColumn } from '/@/components/Table'; | 1 | import { BasicColumn } from '/@/components/Table'; |
3 | import { FormSchema } from '/@/components/Table'; | 2 | import { FormSchema } from '/@/components/Table'; |
4 | -import { DeviceRecord } from '/@/api/device/model/deviceModel'; | ||
5 | -// import { deviceProfile } from '/@/api/device/deviceManager'; | ||
6 | import { h } from 'vue'; | 3 | import { h } from 'vue'; |
7 | -import { Tag, Tooltip } from 'ant-design-vue'; | 4 | +import { Tooltip } from 'ant-design-vue'; |
8 | import { handeleCopy } from '../../../device/profiles/step/topic'; | 5 | import { handeleCopy } from '../../../device/profiles/step/topic'; |
9 | import { useI18n } from '/@/hooks/web/useI18n'; | 6 | import { useI18n } from '/@/hooks/web/useI18n'; |
10 | -import { DeviceStatusEnum, DeviceTypeEnum } from '/@/enums/deviceEnum'; | 7 | +import { SbStatusEnum } from '/@/enums/deviceEnum'; |
11 | 8 | ||
12 | const { t } = useI18n(); | 9 | const { t } = useI18n(); |
13 | import edgefornt from '/@/assets/icons/edgefornt.svg'; | 10 | import edgefornt from '/@/assets/icons/edgefornt.svg'; |
@@ -73,16 +70,15 @@ export enum DeviceListAuthEnum { | @@ -73,16 +70,15 @@ export enum DeviceListAuthEnum { | ||
73 | export const columns: BasicColumn[] = [ | 70 | export const columns: BasicColumn[] = [ |
74 | { | 71 | { |
75 | title: t('business.deviceStatusText'), | 72 | title: t('business.deviceStatusText'), |
76 | - dataIndex: 'deviceState', | 73 | + dataIndex: 'status', |
77 | width: 110, | 74 | width: 110, |
78 | className: 'device-status', | 75 | className: 'device-status', |
79 | - slots: { customRender: 'deviceState' }, | 76 | + slots: { customRender: 'status' }, |
80 | }, | 77 | }, |
81 | { | 78 | { |
82 | - title: t('business.deviceImageText'), | ||
83 | - dataIndex: 'deviceInfo.avatar', | ||
84 | - width: 70, | ||
85 | - slots: { customRender: 'img' }, | 79 | + title: t('business.codeText'), |
80 | + dataIndex: 'code', | ||
81 | + width: 100, | ||
86 | }, | 82 | }, |
87 | { | 83 | { |
88 | dataIndex: 'name', | 84 | dataIndex: 'name', |
@@ -142,53 +138,18 @@ export const columns: BasicColumn[] = [ | @@ -142,53 +138,18 @@ export const columns: BasicColumn[] = [ | ||
142 | }, | 138 | }, |
143 | { | 139 | { |
144 | title: t('business.deviceTypeText'), | 140 | title: t('business.deviceTypeText'), |
145 | - dataIndex: 'deviceType', | ||
146 | - width: 130, | ||
147 | - customRender({ text }) { | ||
148 | - return h(Tag, { color: 'success' }, () => t(`enum.deviceType.${text}`)); | ||
149 | - }, | ||
150 | - }, | ||
151 | - { | ||
152 | - title: t('business.affiliatedProductText'), | ||
153 | - dataIndex: 'deviceProfile.name', | ||
154 | - width: 180, | ||
155 | - slots: { customRender: 'deviceProfile' }, | ||
156 | - ellipsis: true, | ||
157 | - }, | ||
158 | - { | ||
159 | - title: t('business.affiliatedOrganizationText'), | ||
160 | - dataIndex: 'organizationDTO.name', | ||
161 | - width: 100, | ||
162 | - }, | ||
163 | - // { | ||
164 | - // title: '客户', | ||
165 | - // dataIndex: 'customerName', | ||
166 | - // width: 100, | ||
167 | - // }, | ||
168 | - { | ||
169 | - title: t('business.publicText'), | ||
170 | - dataIndex: 'public', | ||
171 | - width: 100, | ||
172 | - customRender({ record }: { record: DeviceRecord }) { | ||
173 | - const flag = record?.customerAdditionalInfo?.isPublic; | ||
174 | - return h(Tag, { color: flag ? 'blue' : 'orange' }, () => | ||
175 | - flag ? t('business.publicText') : t('business.privateText') | ||
176 | - ); | ||
177 | - }, | 141 | + dataIndex: 'categoryName', |
142 | + width: 120, | ||
178 | }, | 143 | }, |
179 | { | 144 | { |
180 | - title: t('deviceManagement.device.lastOnlineTimeText'), | ||
181 | - dataIndex: 'lastOnlineTime', | ||
182 | - format: (text) => text && formatToDate(text, 'YYYY-MM-DD HH:mm:ss'), | ||
183 | - width: 160, | 145 | + title: t('business.directorName'), |
146 | + dataIndex: 'directorName', | ||
147 | + width: 120, | ||
184 | }, | 148 | }, |
185 | { | 149 | { |
186 | - title: t('deviceManagement.device.lastOfflineTimeText'), | ||
187 | - dataIndex: 'lastOfflineTime', | ||
188 | - format: (text) => { | ||
189 | - return text ? formatToDate(text, 'YYYY-MM-DD HH:mm:ss') : ''; | ||
190 | - }, | ||
191 | - width: 160, | 150 | + title: t('business.brandText'), |
151 | + dataIndex: 'brand', | ||
152 | + width: 120, | ||
192 | }, | 153 | }, |
193 | ]; | 154 | ]; |
194 | 155 | ||
@@ -204,24 +165,12 @@ export const searchFormSchema: FormSchema[] = [ | @@ -204,24 +165,12 @@ export const searchFormSchema: FormSchema[] = [ | ||
204 | }, | 165 | }, |
205 | }, | 166 | }, |
206 | { | 167 | { |
207 | - field: 'deviceType', | ||
208 | - label: t('equipment.ledger.deviceType'), | ||
209 | - component: 'Select', | ||
210 | - componentProps: { | ||
211 | - options: Object.values(DeviceTypeEnum).map((value) => ({ | ||
212 | - label: t(`enum.deviceType.${value}`), | ||
213 | - value, | ||
214 | - })), | ||
215 | - }, | ||
216 | - colProps: { span: 6 }, | ||
217 | - }, | ||
218 | - { | ||
219 | - field: 'deviceState', | 168 | + field: 'status', |
220 | label: t('business.deviceStatusText'), | 169 | label: t('business.deviceStatusText'), |
221 | component: 'Select', | 170 | component: 'Select', |
222 | componentProps: { | 171 | componentProps: { |
223 | - options: Object.values(DeviceStatusEnum).map((value) => ({ | ||
224 | - label: t(`enum.deviceStatus.${value}`), | 172 | + options: Object.values(SbStatusEnum).map((value) => ({ |
173 | + label: t(`enum.sbStatus.${value}`), | ||
225 | value, | 174 | value, |
226 | })), | 175 | })), |
227 | }, | 176 | }, |
1 | <template> | 1 | <template> |
2 | <div> | 2 | <div> |
3 | <PageWrapper dense contentFullHeight contentClass="flex"> | 3 | <PageWrapper dense contentFullHeight contentClass="flex"> |
4 | - <OrganizationIdTree @select="handleSelect" ref="organizationIdTreeRef" /> | 4 | + <OrganizationIdTree @select="handleSelect" ref="organizationIdTreeRef" listType="equipment"/> |
5 | <BasicTable style="flex: auto" @register="registerTable" class="w-5/6 xl:w-4/5 device-table"> | 5 | <BasicTable style="flex: auto" @register="registerTable" class="w-5/6 xl:w-4/5 device-table"> |
6 | <template #toolbar> | 6 | <template #toolbar> |
7 | <Authority :value="DeviceListAuthEnum.CREATE"> | 7 | <Authority :value="DeviceListAuthEnum.CREATE"> |
8 | - <a-button type="primary" @click="handleCreate" v-if="authBtn(role)"> | 8 | + <a-button type="primary" @click="handleBussinessDrawer('add', null)" v-if="authBtn(role)"> |
9 | {{ t('equipment.ledger.createLedgerText') }} | 9 | {{ t('equipment.ledger.createLedgerText') }} |
10 | </a-button> | 10 | </a-button> |
11 | </Authority> | 11 | </Authority> |
12 | - | ||
13 | - <Authority :value="DeviceListAuthEnum.IMPORT"> | ||
14 | - <Button type="primary" > | ||
15 | - {{ t('equipment.ledger.importLedgerText') }} | ||
16 | - </Button> | ||
17 | - </Authority> | ||
18 | - | ||
19 | - <Authority | ||
20 | - :value="[ | ||
21 | - DeviceListAuthEnum.DELETE, | ||
22 | - DeviceListAuthEnum.ASSIGN, | ||
23 | - DeviceListAuthEnum.UPDATE_PRODUCT, | ||
24 | - ]" | ||
25 | - > | ||
26 | - <AuthDropDown | ||
27 | - v-if="authBtn(role)" | ||
28 | - :disabled="isPublicAndPrivateFlag || !isExistOption" | ||
29 | - :dropMenuList="[ | ||
30 | - { | ||
31 | - text: t('common.delText'), | ||
32 | - auth: DeviceListAuthEnum.DELETE, | ||
33 | - icon: 'ant-design:delete-outlined', | ||
34 | - event: '', | ||
35 | - disabled: !batchPrivateFlag, | ||
36 | - popconfirm: { | ||
37 | - title: t('common.deleteConfirmText'), | ||
38 | - onConfirm: () => handleDelete(), | ||
39 | - }, | ||
40 | - }, | ||
41 | - { | ||
42 | - text: t('equipment.ledger.editProductText'), | ||
43 | - auth: DeviceListAuthEnum.UPDATE_PRODUCT, | ||
44 | - icon: 'clarity:note-edit-line', | ||
45 | - event: '', | ||
46 | - disabled: !batchPrivateFlag || batchUpdateProductFlag, | ||
47 | - onClick: handelOpenBatchUpdateProductModal, | ||
48 | - }, | ||
49 | - { | ||
50 | - text: t('business.publicText'), | ||
51 | - icon: 'ant-design:wallet-outlined', | ||
52 | - event: '', | ||
53 | - disabled: !batchPrivateFlag, | ||
54 | - onClick: handleBatchPublic.bind(null), | ||
55 | - }, | ||
56 | - { | ||
57 | - text: t('business.privateText'), | ||
58 | - icon: 'ant-design:wallet-outlined', | ||
59 | - event: '', | ||
60 | - disabled: batchPrivateFlag, | ||
61 | - onClick: handleBatchPrivate.bind(null), | ||
62 | - }, | ||
63 | - { | ||
64 | - text: t('equipment.ledger.updateOrganization'), | ||
65 | - icon: 'ant-design:wallet-outlined', | ||
66 | - event: '', | ||
67 | - disabled: !batchPrivateFlag || batchSensorFlag || diffBatchSensorFlag, | ||
68 | - onClick: handleBatchOrg.bind(null), | ||
69 | - }, | ||
70 | - ]" | ||
71 | - > | ||
72 | - <Button type="primary" :disabled="isPublicAndPrivateFlag || !isExistOption"> | ||
73 | - {{ t('equipment.ledger.batchActionText') }} | ||
74 | - </Button> | ||
75 | - </AuthDropDown> | ||
76 | - </Authority> | ||
77 | - </template> | ||
78 | - <template #img="{ record }"> | ||
79 | - <TableImg | ||
80 | - :size="30" | ||
81 | - :showBadge="false" | ||
82 | - :simpleShow="true" | ||
83 | - :imgList=" | ||
84 | - typeof record?.deviceInfo?.avatar !== 'undefined' && | ||
85 | - record?.deviceInfo?.avatar !== '' && | ||
86 | - record?.deviceInfo?.avatar != null | ||
87 | - ? [record.deviceInfo.avatar] | ||
88 | - : null | ||
89 | - " | ||
90 | - /> | ||
91 | </template> | 12 | </template> |
92 | - <template #deviceProfile="{ record }"> | ||
93 | - <Button | ||
94 | - @click="!isCustomer ? goDeviceProfile(record.deviceProfile.name) : null" | ||
95 | - type="link" | ||
96 | - > | ||
97 | - {{ record.deviceProfile.name }} | ||
98 | - </Button> | ||
99 | - </template> | ||
100 | - <template #deviceState="{ record }"> | ||
101 | - <div v-if="record.isCollect"> | ||
102 | - <div class="absolute top-0 left-0 device-collect"> </div> | ||
103 | - <Icon | ||
104 | - icon="ph:star-fill" | ||
105 | - class="fill-light-50 absolute top-0.5 left-0.5" | ||
106 | - color="#fff" | ||
107 | - :size="12" | ||
108 | - /> | ||
109 | - </div> | ||
110 | - | 13 | + <template #status="{ record }"> |
111 | <Tag | 14 | <Tag |
112 | :color=" | 15 | :color=" |
113 | - record.deviceState == DeviceState.INACTIVE | 16 | + record.status == SbStatusEnum.SCRAP |
114 | ? 'warning' | 17 | ? 'warning' |
115 | - : record.deviceState == DeviceState.ONLINE | ||
116 | - ? 'success' | ||
117 | - : record.deviceState == DeviceState.ACTIVE | 18 | + : record.status == SbStatusEnum.NORMAL |
118 | ? 'success' | 19 | ? 'success' |
20 | + : record.status == SbStatusEnum.FAULT | ||
21 | + ? 'error' | ||
119 | : 'error' | 22 | : 'error' |
120 | " | 23 | " |
121 | class="ml-2" | 24 | class="ml-2" |
122 | > | 25 | > |
123 | - {{ t(`enum.deviceStatus.${record.deviceState}`) }} | 26 | + {{ t(`enum.sbStatus.${record.status}`) }} |
124 | </Tag> | 27 | </Tag> |
125 | </template> | 28 | </template> |
126 | <template #action="{ record }"> | 29 | <template #action="{ record }"> |
127 | <TableAction | 30 | <TableAction |
128 | :actions="[ | 31 | :actions="[ |
129 | - { | ||
130 | - label: AlarmDetailActionButton({ hasAlarm: !!record.alarmStatus }), | ||
131 | - icon: 'ant-design:eye-outlined', | ||
132 | - auth: DeviceListAuthEnum.DETAIL, | ||
133 | - // onClick: handleDetail.bind(null, record), | ||
134 | - }, | ||
135 | - { | ||
136 | - label: t('common.editText'), | ||
137 | - auth: DeviceListAuthEnum.UPDATE, | ||
138 | - icon: 'clarity:note-edit-line', | ||
139 | - ifShow: authBtn(role), | ||
140 | - // onClick: handleEdit.bind(null, record), | ||
141 | - }, | ||
142 | - ]" | ||
143 | - :dropDownActions="[ | ||
144 | - // record.customerId | ||
145 | - // ? { | ||
146 | - // label: t('deviceManagement.device.cancelAssignText'), | ||
147 | - // icon: 'mdi:account-arrow-left', | ||
148 | - // ifShow: authBtn(role) && !record?.customerAdditionalInfo?.isPublic, | ||
149 | - // auth: DeviceListAuthEnum.ASSIGN, | ||
150 | - // popConfirm: { | ||
151 | - // title: t('deviceManagement.device.cancelAssignConfirmText'), | ||
152 | - // confirm: handleCancelDispatchCustomer.bind(null, record), | ||
153 | - // }, | ||
154 | - // } | ||
155 | - // : { | ||
156 | - // label: t('deviceManagement.device.assignCustomerText'), | ||
157 | - // icon: 'mdi:account-arrow-right', | ||
158 | - // ifShow: authBtn(role), | ||
159 | - // auth: DeviceListAuthEnum.ASSIGN, | ||
160 | - // onClick: handleDispatchCustomer.bind(null, record), | ||
161 | - // }, | ||
162 | - { | ||
163 | - label: record?.customerAdditionalInfo?.isPublic | ||
164 | - ? t('business.privateText') | ||
165 | - : t('business.publicText'), | ||
166 | - auth: DeviceListAuthEnum.PUBLIC, | ||
167 | - icon: record?.customerAdditionalInfo?.isPublic | ||
168 | - ? 'ant-design:lock-outlined' | ||
169 | - : 'ant-design:unlock-outlined', | ||
170 | - // onClick: handlePublicDevice.bind(null, record), | ||
171 | - }, | ||
172 | - { | ||
173 | - label: t('deviceManagement.device.onlineRecordText'), | ||
174 | - auth: DeviceListAuthEnum.ONLINE, | ||
175 | - icon: 'ant-design:rise-outlined', | ||
176 | - // onClick: handleUpAndDownRecord.bind(null, record), | 32 | + { |
33 | + label: t('common.viewText'), | ||
34 | + icon: 'ant-design:eye-outlined', | ||
35 | + onClick: handleBussinessDrawer.bind(null, 'view', record), | ||
36 | + }, | ||
37 | + { | ||
38 | + label: t('common.editText'), | ||
39 | + icon: 'clarity:note-edit-line', | ||
40 | + onClick: handleBussinessDrawer.bind(null, 'edit', record), | ||
41 | + }, | ||
42 | + { | ||
43 | + label: t('common.delText'), | ||
44 | + icon: 'ant-design:delete-outlined', | ||
45 | + color: 'error', | ||
46 | + popConfirm: { | ||
47 | + title: t('common.isDelete'), | ||
48 | + confirm: handleDelete.bind(null, record), | ||
177 | }, | 49 | }, |
178 | - !record.isCollect | ||
179 | - ? { | ||
180 | - label: t('deviceManagement.device.collectText'), | ||
181 | - icon: 'ant-design:heart-outlined', | ||
182 | - // onClick: handelCollect.bind(null, record), | ||
183 | - } | ||
184 | - : { | ||
185 | - label: t('deviceManagement.device.cancelCollectText'), | ||
186 | - icon: 'ant-design:heart-outlined', | ||
187 | - popConfirm: { | ||
188 | - title: t('deviceManagement.device.cancelCollectConfirmText'), | ||
189 | - // confirm: handelCollect.bind(null, record), | ||
190 | - }, | ||
191 | - }, | ||
192 | - { | ||
193 | - label: t('common.delText'), | ||
194 | - auth: DeviceListAuthEnum.DELETE, | ||
195 | - icon: 'ant-design:delete-outlined', | ||
196 | - ifShow: authBtn(role) && record.customerId === undefined, | ||
197 | - color: 'error', | ||
198 | - popConfirm: { | ||
199 | - title: !!record.isEdge | ||
200 | - ? t('common.edgeDeviceOperationConfirm') | ||
201 | - : t('common.deleteConfirmText'), | ||
202 | - confirm: handleDelete.bind(null, record), | ||
203 | - }, | ||
204 | - }, | ||
205 | - ]" | ||
206 | - /> | 50 | + }, |
51 | + ]" | ||
52 | + > | ||
53 | + </TableAction> | ||
207 | </template> | 54 | </template> |
208 | </BasicTable> | 55 | </BasicTable> |
209 | -<!-- <LedgerDetailDrawer--> | ||
210 | -<!-- @register="registerDetailDrawer"--> | ||
211 | -<!-- @open-tb-device-detail="handleOpenTbDeviceDetail"--> | ||
212 | -<!-- @open-gateway-device-detail="handleOpenGatewayDetail"--> | ||
213 | -<!-- />--> | 56 | + <LedgerDrawer @register="registerDrawer" @success="handleSuccess" @reload="handleSuccess" /> |
214 | </PageWrapper> | 57 | </PageWrapper> |
215 | </div> | 58 | </div> |
216 | </template> | 59 | </template> |
217 | <script setup lang="ts"> | 60 | <script setup lang="ts"> |
218 | -import {CSSProperties, h, reactive, ref} from "vue"; | 61 | +import { reactive} from "vue"; |
219 | import { PageWrapper } from '/@/components/Page'; | 62 | import { PageWrapper } from '/@/components/Page'; |
63 | +import { LedgerDrawer } from "./components/modal/index" | ||
220 | const searchInfo = reactive<Recordable>({}); | 64 | const searchInfo = reactive<Recordable>({}); |
221 | -const { organizationIdTreeRef, resetFn } = useResetOrganizationTree(searchInfo); | ||
222 | -import {BasicTable, TableAction, TableImg, useTable} from "/@/components/Table"; | 65 | +const { organizationIdTreeRef, resetFn } = useResetOrganizationTree(searchInfo,'equipment'); |
66 | +import {BasicTable, TableAction, useTable} from "/@/components/Table"; | ||
223 | import {OrganizationIdTree, useResetOrganizationTree} from "/@/views/common/organizationIdTree"; | 67 | import {OrganizationIdTree, useResetOrganizationTree} from "/@/views/common/organizationIdTree"; |
224 | -import { | ||
225 | - deleteDevice, | ||
226 | - devicePage, | ||
227 | - doBatchPrivateDevice, | ||
228 | - doBatchPublicDevice | ||
229 | -} from "/@/api/device/deviceManager"; | 68 | +import { getLedgerList, deleteLedger } from "/@/api/equipment/ledger" |
230 | import { | 69 | import { |
231 | columns, | 70 | columns, |
232 | DeviceListAuthEnum, | 71 | DeviceListAuthEnum, |
233 | searchFormSchema | 72 | searchFormSchema |
234 | } from "/@/views/equipment/ledger/config/ledger.data"; | 73 | } from "/@/views/equipment/ledger/config/ledger.data"; |
235 | -import {DeviceModel, DeviceRecord, DeviceState} from "/@/api/device/model/deviceModel"; | 74 | +import { SbStatusEnum } from '/@/enums/deviceEnum'; |
75 | + | ||
236 | import {useI18n} from "/@/hooks/web/useI18n"; | 76 | import {useI18n} from "/@/hooks/web/useI18n"; |
237 | import {authBtn} from "/@/enums/roleEnum"; | 77 | import {authBtn} from "/@/enums/roleEnum"; |
238 | -import {Badge, Button, Tag} from "ant-design-vue"; | 78 | +import {Button, Tag} from "ant-design-vue"; |
239 | import {Authority} from "/@/components/Authority"; | 79 | import {Authority} from "/@/components/Authority"; |
240 | -import {AuthDropDown} from "/@/components/Widget"; | ||
241 | import {getAuthCache} from "/@/utils/auth"; | 80 | import {getAuthCache} from "/@/utils/auth"; |
242 | import {USER_INFO_KEY} from "/@/enums/cacheEnum"; | 81 | import {USER_INFO_KEY} from "/@/enums/cacheEnum"; |
243 | -import {useBatchOperation} from "/@/utils/useBatchOperation"; | ||
244 | import {useMessage} from "/@/hooks/web/useMessage"; | 82 | import {useMessage} from "/@/hooks/web/useMessage"; |
245 | -import {DataActionModeEnum} from "/@/enums/toolEnum"; | ||
246 | -import { | ||
247 | - BatchUpdateProductModalParamsType | ||
248 | -} from "/@/views/device/list/cpns/modal/BatchUpdateProductModal/index"; | ||
249 | -import {useModal} from "/@/components/Modal"; | ||
250 | -import Icon from "/@/components/Icon"; | ||
251 | -// import LedgerDetailDrawer from "./cpns/modal/LedgerDetailDrawer.vue"; | 83 | + |
84 | +import {useDrawer} from "/@/components/Drawer"; | ||
85 | + | ||
86 | +// 业务弹窗 | ||
87 | +const [registerDrawer, { openDrawer }] = useDrawer(); | ||
252 | const { t } = useI18n(); | 88 | const { t } = useI18n(); |
253 | const userInfo: any = getAuthCache(USER_INFO_KEY); | 89 | const userInfo: any = getAuthCache(USER_INFO_KEY); |
254 | const role: string = userInfo.roles[0]; | 90 | const role: string = userInfo.roles[0]; |
255 | -const isPublicAndPrivateFlag = ref(false); | ||
256 | -const batchPrivateFlag = ref(true); | ||
257 | -const batchUpdateProductFlag = ref(true); | ||
258 | -const batchSensorFlag = ref(false); | ||
259 | -const { createMessage } = useMessage(); | ||
260 | -const diffBatchSensorFlag = ref(false); | ||
261 | -const [registerOrgModal, { openModal: openOrgodal }] = useModal(); | ||
262 | -const [registerBatchUpdateProductModal, { openModal: openBatchUpdateProductModal }] = useModal(); | ||
263 | 91 | ||
264 | -const AlarmDetailActionButton = ({ hasAlarm }: { hasAlarm?: boolean }) => | ||
265 | - h( | ||
266 | - Badge, | ||
267 | - { offset: [0, -5] }, | ||
268 | - { | ||
269 | - default: () => h('span', { style: { color: '#377dff' } }, t('common.detailText')), | ||
270 | - count: () => | ||
271 | - h( | ||
272 | - 'div', | ||
273 | - { | ||
274 | - style: { | ||
275 | - visibility: hasAlarm ? 'visible' : 'hidden', | ||
276 | - width: '14px', | ||
277 | - height: '14px', | ||
278 | - display: 'flex', | ||
279 | - justifyContent: 'center', | ||
280 | - alignItems: 'center', | ||
281 | - border: '1px solid #f46161', | ||
282 | - borderRadius: '50%', | ||
283 | - } as CSSProperties, | ||
284 | - }, | ||
285 | - h(Icon, { icon: 'mdi:bell-warning', color: '#f46161', size: 12 }) | ||
286 | - ), | ||
287 | - } | ||
288 | - ); | 92 | +const { createMessage } = useMessage(); |
289 | 93 | ||
290 | const [ | 94 | const [ |
291 | registerTable, | 95 | registerTable, |
@@ -295,13 +99,13 @@ const [ | @@ -295,13 +99,13 @@ const [ | ||
295 | setSelectedRowKeys, | 99 | setSelectedRowKeys, |
296 | getForm, | 100 | getForm, |
297 | getSelectRowKeys, | 101 | getSelectRowKeys, |
298 | - getSelectRows, | 102 | + setProps, |
299 | getRowSelection, | 103 | getRowSelection, |
300 | clearSelectedRowKeys, | 104 | clearSelectedRowKeys, |
301 | }, | 105 | }, |
302 | ] = useTable({ | 106 | ] = useTable({ |
303 | title: t('equipment.ledger.ledgerListText'), | 107 | title: t('equipment.ledger.ledgerListText'), |
304 | - api: devicePage, | 108 | + api: getLedgerList, |
305 | columns, | 109 | columns, |
306 | beforeFetch: (params) => { | 110 | beforeFetch: (params) => { |
307 | const { deviceProfileId } = params; | 111 | const { deviceProfileId } = params; |
@@ -327,7 +131,7 @@ const [ | @@ -327,7 +131,7 @@ const [ | ||
327 | rowKey: 'id', | 131 | rowKey: 'id', |
328 | searchInfo: searchInfo, | 132 | searchInfo: searchInfo, |
329 | clickToRowSelect: false, | 133 | clickToRowSelect: false, |
330 | - rowClassName: (record) => ((record as DeviceRecord).alarmStatus ? 'device-alarm-badge' : ''), | 134 | + rowClassName: (record) => ((record as any).alarmStatus ? 'device-alarm-badge' : ''), |
331 | actionColumn: { | 135 | actionColumn: { |
332 | width: 200, | 136 | width: 200, |
333 | title: t('common.actionText'), | 137 | title: t('common.actionText'), |
@@ -336,126 +140,27 @@ const [ | @@ -336,126 +140,27 @@ const [ | ||
336 | }, | 140 | }, |
337 | rowSelection: { | 141 | rowSelection: { |
338 | type: 'checkbox', | 142 | type: 'checkbox', |
339 | - getCheckboxProps: (record: DeviceModel) => { | ||
340 | - return { disabled: !!record.customerId && record.customerName !== 'Public' }; | ||
341 | - }, | ||
342 | - onSelect(_record, _selected, selectedRows) { | ||
343 | - const [firstItem] = selectedRows as DeviceRecord[]; | ||
344 | - const { deviceType } = firstItem || {}; | ||
345 | - batchUpdateProductFlag.value = | ||
346 | - !selectedRows.length || | ||
347 | - !selectedRows.every((item) => (item as DeviceRecord).deviceType === deviceType); | ||
348 | - | ||
349 | - batchPrivateFlag.value = selectedRows.some((item: DeviceRecord) => !item?.customerId); | ||
350 | - const filterSensor = selectedRows.map((filterItem: DeviceRecord) => filterItem.deviceType); | ||
351 | - batchSensorFlag.value = | ||
352 | - filterSensor.includes('SENSOR') && | ||
353 | - (filterSensor.includes('DIRECT_CONNECTION') || filterSensor.includes('GATEWAY')); // 网关子和直连设备或者网关设备,则禁用组织修改 | ||
354 | - const filterGatewayId = selectedRows | ||
355 | - .filter((filterItem: DeviceRecord) => filterItem.deviceType === 'SENSOR') | ||
356 | - .map((mapItem: DeviceRecord) => mapItem.gatewayId); | ||
357 | - diffBatchSensorFlag.value = [...new Set(filterGatewayId)].length > 1; // 数组长度大于1,说明选择的网关子设备所属网关为多个,则禁用组织修改 | ||
358 | - isPublicAndPrivateFlag.value = | ||
359 | - selectedRows.some((item: DeviceRecord) => !item?.customerId) && | ||
360 | - selectedRows.some((item: DeviceRecord) => item?.customerAdditionalInfo?.isPublic); | ||
361 | - }, | ||
362 | - onSelectAll(_selected, selectedRows) { | ||
363 | - const [firstItem] = selectedRows as DeviceRecord[]; | ||
364 | - const { deviceType } = firstItem || {}; | ||
365 | - batchUpdateProductFlag.value = | ||
366 | - !selectedRows.length || | ||
367 | - !selectedRows.every((item) => (item as DeviceRecord).deviceType === deviceType); | ||
368 | - | ||
369 | - batchPrivateFlag.value = selectedRows.some((item) => !item?.customerId); | ||
370 | - const filterSensor = selectedRows.map((filterItem) => filterItem.deviceType); | ||
371 | - batchSensorFlag.value = | ||
372 | - filterSensor.includes('SENSOR') && | ||
373 | - (filterSensor.includes('DIRECT_CONNECTION') || filterSensor.includes('GATEWAY')); // 网关子和直连设备或者网关设备,则禁用组织修改 | ||
374 | - const filterGatewayId = selectedRows | ||
375 | - .filter((filterItem: DeviceRecord) => filterItem.deviceType === 'SENSOR') | ||
376 | - .map((mapItem: DeviceRecord) => mapItem.gatewayId); | ||
377 | - diffBatchSensorFlag.value = [...new Set(filterGatewayId)].length > 1; // 数组长度大于1,说明选择的网关子设备所属网关为多个,则禁用组织修改 | ||
378 | - isPublicAndPrivateFlag.value = | ||
379 | - selectedRows.some((item) => !item?.customerId) && | ||
380 | - selectedRows.some((item) => item?.customerAdditionalInfo?.isPublic); | ||
381 | - }, | 143 | + getCheckboxProps: (record: any) => {}, |
382 | }, | 144 | }, |
383 | }); | 145 | }); |
384 | 146 | ||
385 | -const { isExistOption } = useBatchOperation(getRowSelection, setSelectedRowKeys); | ||
386 | -function handleCreate() { | ||
387 | - // openModal(true, { | ||
388 | - // isUpdate: false, | ||
389 | - // }); | ||
390 | -} | ||
391 | 147 | ||
392 | -// 批量公开设备 | ||
393 | -const handleBatchPublic = async () => { | ||
394 | - setLoading(true); | ||
395 | - try { | ||
396 | - const options = getSelectRows(); | ||
397 | - const tbDeviceIdJoinStr = options.map((item) => item.tbDeviceId).join(','); | ||
398 | - const res = await doBatchPublicDevice(tbDeviceIdJoinStr); | ||
399 | - createMessage.success( | ||
400 | - res === '公开成功' ? t('common.publicSuccess') : t('common.publicError') | ||
401 | - ); | ||
402 | - } finally { | ||
403 | - handleReload(); | ||
404 | - setLoading(false); | ||
405 | - } | 148 | +// 业务弹窗 |
149 | +const handleBussinessDrawer = (text, record) => { | ||
150 | + const modalParams = { | ||
151 | + text, | ||
152 | + record, | ||
153 | + }; | ||
154 | + openDrawer(true, modalParams); | ||
406 | }; | 155 | }; |
407 | 156 | ||
408 | -function handleReload() { | ||
409 | - setSelectedRowKeys([]); | ||
410 | - handleSuccess(); | ||
411 | -} | ||
412 | 157 | ||
413 | -// 批量私有设备 | ||
414 | -const handleBatchPrivate = async () => { | ||
415 | - setLoading(true); | ||
416 | - try { | ||
417 | - const options = getSelectRows(); | ||
418 | - const tbDeviceIdJoinStr = options.map((item) => item.tbDeviceId).join(','); | ||
419 | - const res = await doBatchPrivateDevice(tbDeviceIdJoinStr); | ||
420 | - createMessage.success( | ||
421 | - res === '私有成功' ? t('common.privateSuccess') : t('common.privateError') | ||
422 | - ); | ||
423 | - } finally { | ||
424 | - handleReload(); | ||
425 | - setLoading(false); | ||
426 | - } | ||
427 | -}; | 158 | +const handleDelete = async (record?: any) => { |
159 | + let _id: string = record.id; | ||
428 | 160 | ||
429 | -const handleBatchOrg = () => { | ||
430 | - const options = getSelectRows(); | ||
431 | - openOrgodal(true, options); | ||
432 | -}; | ||
433 | - | ||
434 | -const handelOpenBatchUpdateProductModal = () => { | ||
435 | - const rows: DeviceRecord[] = getSelectRows(); | ||
436 | - const [firstItem] = rows; | ||
437 | - | ||
438 | - openBatchUpdateProductModal(true, { | ||
439 | - mode: DataActionModeEnum.UPDATE, | ||
440 | - record: { | ||
441 | - sourceDeviceProfileName: firstItem.deviceProfile.name, | ||
442 | - deviceType: firstItem.deviceType, | ||
443 | - deviceIds: rows.map((item) => item.tbDeviceId), | ||
444 | - deviceProfile: firstItem.deviceProfile, | ||
445 | - }, | ||
446 | - } as BatchUpdateProductModalParamsType); | ||
447 | -}; | ||
448 | - | ||
449 | -const handleDelete = async (record?: DeviceRecord) => { | ||
450 | - let ids: string[] = []; | ||
451 | - if (record) { | ||
452 | - ids.push(record.id); | ||
453 | - } else { | ||
454 | - ids = getSelectRowKeys(); | ||
455 | - } | ||
456 | try { | 161 | try { |
457 | setLoading(true); | 162 | setLoading(true); |
458 | - await deleteDevice(ids); | 163 | + await deleteLedger({id: _id}); |
459 | createMessage.success(t('common.deleteSuccessText')); | 164 | createMessage.success(t('common.deleteSuccessText')); |
460 | handleReload(); | 165 | handleReload(); |
461 | } catch (error) { | 166 | } catch (error) { |
@@ -465,12 +170,19 @@ const handleDelete = async (record?: DeviceRecord) => { | @@ -465,12 +170,19 @@ const handleDelete = async (record?: DeviceRecord) => { | ||
465 | } | 170 | } |
466 | }; | 171 | }; |
467 | 172 | ||
173 | + | ||
174 | +function handleReload() { | ||
175 | + setSelectedRowKeys([]); | ||
176 | + handleSuccess(); | ||
177 | +} | ||
178 | + | ||
179 | + | ||
468 | function handleSuccess() { | 180 | function handleSuccess() { |
469 | reload(); | 181 | reload(); |
470 | } | 182 | } |
471 | 183 | ||
472 | function handleSelect(organization) { | 184 | function handleSelect(organization) { |
473 | - searchInfo.organizationId = organization; | 185 | + searchInfo.categoryId = organization; |
474 | handleSuccess(); | 186 | handleSuccess(); |
475 | } | 187 | } |
476 | 188 |