From f7402f582260e475bffbf85ed4acf49a21dec208 Mon Sep 17 00:00:00 2001 From: zhoux Date: Mon, 18 Dec 2023 11:34:28 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E8=B5=84=E6=BA=90=E7=AE=A1=E7=90=86?= =?UTF-8?q?=E8=AE=BE=E5=A4=87=E7=8A=B6=E6=80=81=E9=9D=99=E6=80=81=E5=AE=8C?= =?UTF-8?q?=E6=88=90=EF=BC=8Cfabric=E7=9B=91=E6=8E=A7=E4=BF=A1=E6=81=AF?= =?UTF-8?q?=E5=B1=95=E7=A4=BA=E5=88=9D=E5=A7=8B=E5=8C=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- config/routes.ts | 15 + src/enums/status.ts | 100 +- src/global.css | 9 +- src/global.less | 9 +- src/pages/DCSDevice/DeviceStatus/index.tsx | 62 +- .../Room/components/ColumnDrawer.tsx | 167 ++ src/pages/FabricView/Room/index.tsx | 204 ++ .../components/DeviceStatusCard.tsx | 158 ++ .../Resource/ResourceDeviceStatus/index.tsx | 181 ++ src/testData/fabricGroupRoom.ts | 1644 +++++++++++++++ src/testData/fabricRoomList.ts | 147 ++ src/testData/fabricRoomSvg.ts | 49 + src/testData/fabricWatchIcons.ts | 1825 +++++++++++++++++ 13 files changed, 4503 insertions(+), 67 deletions(-) create mode 100644 src/pages/FabricView/Room/components/ColumnDrawer.tsx create mode 100644 src/pages/FabricView/Room/index.tsx create mode 100644 src/pages/Resource/ResourceDeviceStatus/components/DeviceStatusCard.tsx create mode 100644 src/pages/Resource/ResourceDeviceStatus/index.tsx create mode 100644 src/testData/fabricGroupRoom.ts create mode 100644 src/testData/fabricRoomList.ts create mode 100644 src/testData/fabricRoomSvg.ts create mode 100644 src/testData/fabricWatchIcons.ts diff --git a/config/routes.ts b/config/routes.ts index 5852a18..2f4c003 100644 --- a/config/routes.ts +++ b/config/routes.ts @@ -185,6 +185,11 @@ export default [ 'path': '/resource/model-version-list', 'component': 'Resource/ModelVersionList', 'access': 'canReadMenu' + },{ + 'name': 'resource-device-status', // 2 + 'path': '/resource/resource-device-status', + 'component': 'Resource/ResourceDeviceStatus', + 'access': 'canReadMenu' }] }, { @@ -259,4 +264,14 @@ export default [ layout: false, component: './404', }, + { + name: 'fabricView', + path: '/fabricView', + routes: [{ + 'name': 'fabricView-room', + 'path': '/fabricView/room', + 'component': 'FabricView/Room', + 'access': 'canReadMenu' + }] + }, ]; diff --git a/src/enums/status.ts b/src/enums/status.ts index 2b9e423..af51370 100644 --- a/src/enums/status.ts +++ b/src/enums/status.ts @@ -1,30 +1,72 @@ +export const deviceStatusEnums: Record = { + allStatus: { + miniName: '全部', + value: '0', + color: '', + }, + onlineStatus: { + miniName: '在线', + value: '1', + color: 'success', + }, + outlineStatus: { + miniName: '离线', + value: '2', + color: 'default', + }, + processingStatus: { + miniName: '运行中', + value: '3', + color: 'warning', + }, + errorStatus: { + miniName: '故障', + value: '4', + color: 'error', + }, +}; - - -export const deviceStatusEnums : Record = { - 'allStatus': { - miniName: '全部', - value: '0', - color: '' - }, - 'onlineStatus': { - miniName: '在线', - value: '1', - color: 'success' - }, - 'outlineStatus': { - miniName: '离线', - value: '2', - color: 'default' - }, - 'processingStatus': { - miniName: '运行中', - value: '3', - color: 'warning' - }, - 'errorStatus': { - miniName: '故障', - value: '4', - color: 'error' - } -} \ No newline at end of file +export const resourceDeviceStatusEnums: Record = { + allStatus: { + miniName: '全部异常', + value: '0', + color: '', + renderType: '', + }, + storageWarn: { + miniName: '存储告警', + value: '1', + color: 'error', + renderType: 'progress', + }, + GPUWarn: { + miniName: 'GPU告警', + value: '2', + color: 'success', + renderType: 'progress', + }, + memoryWarn: { + miniName: '内存告警', + value: '3', + color: 'success', + renderType: 'progress', + }, + errorStatus: { + miniName: 'CPU告警', + value: '4', + color: 'warning', + renderType: 'progress', + }, + codeError: { + miniName: '代码出错', + value: '5', + color: 'error', + renderType: 'dot', + }, + serveTimeOut: { + miniName: '服务器超时', + value: '6', + color: 'error', + renderType: 'dot', + }, +}; diff --git a/src/global.css b/src/global.css index ece78f6..b0bcb37 100644 --- a/src/global.css +++ b/src/global.css @@ -116,6 +116,8 @@ a.ant-dropdown-trigger { .ant-menu-light .ant-menu-item-selected, .ant-menu-light > .ant-menu .ant-menu-item-selected { background-color: #e8effb; + border-left: 3px solid #155BD4; + border-radius: 0; } .ant-select-dropdown .ant-select-item-option-active:not(.ant-select-item-option-disabled) { background-color: #e8effb; @@ -131,6 +133,9 @@ a.ant-dropdown-trigger { .ant-steps .ant-steps-item-active > .ant-steps-item-container > .ant-steps-item-content > .ant-steps-item-description { color: #155BD4; } +.ant-layout-sider-children { + background-color: white; +} .ant-btn-link.ant-btn-dangerous, .ant-btn-default.ant-btn-dangerous { color: #E80D0D; @@ -174,7 +179,7 @@ a.ant-dropdown-trigger { border-radius: 8px; } .ant-pro-list .ant-pro-table-list-toolbar-left { - flex: 0.8; + flex: 1; } .ant-popover .ant-popover-content { min-width: 200px; @@ -295,7 +300,7 @@ a.ant-dropdown-trigger { } .gn .proListActionBox .ant-btn.ant-btn-sm { padding: 0; - font-size: 12px; + font-size: 14px; } .gn.fw7 { font-weight: 700; diff --git a/src/global.less b/src/global.less index 269f86e..f4313b2 100644 --- a/src/global.less +++ b/src/global.less @@ -142,6 +142,8 @@ a.ant-dropdown-trigger{ .ant-menu-light .ant-menu-item-selected, .ant-menu-light>.ant-menu .ant-menu-item-selected { background-color: #e8effb; + border-left: 3px solid #155BD4; + border-radius: 0; } .ant-select-dropdown .ant-select-item-option-active:not(.ant-select-item-option-disabled) { @@ -163,6 +165,9 @@ a.ant-dropdown-trigger{ } } +.ant-layout-sider-children{ + background-color: white; +} .ant-btn-link.ant-btn-dangerous, .ant-btn-default.ant-btn-dangerous { color: #E80D0D; @@ -226,7 +231,7 @@ a.ant-dropdown-trigger{ } .ant-pro-table-list-toolbar-left{ - flex: 0.8 + flex: 1 } } @@ -363,7 +368,7 @@ a.ant-dropdown-trigger{ .proListActionBox{ .ant-btn.ant-btn-sm{ padding: 0; - font-size: 12px; + font-size: 14px; } } diff --git a/src/pages/DCSDevice/DeviceStatus/index.tsx b/src/pages/DCSDevice/DeviceStatus/index.tsx index 746b398..64d3c13 100644 --- a/src/pages/DCSDevice/DeviceStatus/index.tsx +++ b/src/pages/DCSDevice/DeviceStatus/index.tsx @@ -1,11 +1,3 @@ -/* - * @Author: zhoux zhouxia@supervision.ltd - * @Date: 2023-12-08 10:11:54 - * @LastEditors: zhoux zhouxia@supervision.ltd - * @LastEditTime: 2023-12-11 17:15:39 - * @FilePath: \general-ai-platform-web\src\pages\DCSDevice\DeviceStatus\index.tsx - * @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE - */ import TableActionCard from '@/components/TableActionCard'; import IsConfirmAction from '@/components/TableActionCard/isConfirmAction'; import { deviceStatusEnums } from '@/enums/status'; @@ -19,9 +11,9 @@ import DeviceStatusCard from './components/DeviceStatusCard'; /** * @交互说明 - * 1、列表选择栏位 - * 2、卡片比照UI效果图 - * 3、详情弹框 + * 1、列表分页展示分布式设备状态(分类查询) + * 2、详情展示基础信息、日志 + * 3、重启设备 */ const tabOptions: Record = { allStatus: 90, @@ -76,24 +68,34 @@ const DeviceStatus: React.FC = () => { } return { content: ( - +
-
+
{record.status} -

控制设备控制设备{index + 1}

+

+ 控制设备控制设备{index + 1} +

{ onClick={() => { handleDetailModal(); setCurrentRow(record); - // doToDetail(record); - // setShowDetail(true); }} > @@ -153,14 +153,7 @@ const DeviceStatus: React.FC = () => { ), }; }); - - const columns: ProColumns>[] = [ - { - title: '123', - dataIndex: 'status', - // hideInSearch: true, - }, - ]; + return ( @@ -190,7 +183,7 @@ const DeviceStatus: React.FC = () => { {Object.keys(deviceStatusEnums).includes(item) ? deviceStatusEnums[item].miniName : ''} - ({tabOptions[item]}) + {"("+tabOptions[item]+ ')'} ); })} @@ -201,8 +194,8 @@ const DeviceStatus: React.FC = () => { bodyStyle: { background: 'white', padding: '8px 16px 16px', - borderRadius: 8 - } + borderRadius: 8, + }, }} pagination={{ ...proTablePaginationOptions, @@ -211,9 +204,10 @@ const DeviceStatus: React.FC = () => { }} showActions="hover" rowSelection={false} - grid={{ gutter: 16, xs: 1, md: 2, lg: 3, xl: 4, xxl: 4 }} + grid={{ gutter: 16, xs: 1, md: 2, lg: 2, xl: 3, xxl: 4 }} metas={{ type: { + // 不展示在筛选项 hideInSearch: true, }, content: { diff --git a/src/pages/FabricView/Room/components/ColumnDrawer.tsx b/src/pages/FabricView/Room/components/ColumnDrawer.tsx new file mode 100644 index 0000000..5b4187f --- /dev/null +++ b/src/pages/FabricView/Room/components/ColumnDrawer.tsx @@ -0,0 +1,167 @@ +/* + * @Author: zhoux zhouxia@supervision.ltd + * @Date: 2023-11-01 13:56:33 + * @LastEditors: zhoux zhouxia@supervision.ltd + * @LastEditTime: 2023-12-15 16:58:50 + * @FilePath: \general-ai-platform-web\src\pages\Resource\ModelCategoryList\components\ColumnDrawer.tsx + * @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE + */ +import { CloseOutlined } from '@ant-design/icons'; +import { ProColumns, ProDescriptions, ProDescriptionsItemProps } from '@ant-design/pro-components'; +import React, { useEffect, useState } from 'react'; + +export type ColumnDrawProps = { + handleDrawer: (id?: any) => void; + isShowDetail: boolean; + columns: ProColumns[]; + currentRow: Record; + clipPathData: Record; +}; + +const ColumnDrawer: React.FC = (props) => { + const [positionStyle, setPositionStyle] = useState({}); + // 生成模型详情卡片位置 + function initPointPosition() { + type Point = { x: number; y: number }; + type Position = 'left' | 'right' | 'top' | 'bottom'; + let currPositionStyle: React.CSSProperties = {}; + const modelInfoPosition: Position[] = ['right']; + const maxX = props.clipPathData?.width; // 画布宽度 + const maxY = props.clipPathData?.height; // 画布高度 + const x = props.currentRow.baseInfo?.left; // 模型x轴位置 + const y = props.currentRow.baseInfo?.top; // 模型y轴位置 + const modelWidth: number = 120; // 模型自身宽度 + const modelHeight: number = 54; // 模型自身高度 + const modelInfoWidth: number = 400; // 模型信息卡片宽度 + const modelInfoHeight: number = 240; // 模型信息卡片高度 + // if (x < 0 || x > maxX || y < 0 || y > maxY) { + // // 模型超过范围 + // } + if (x > maxX / 2) { + modelInfoPosition.push('left'); + // if (x < maxX / 2) { + // modelInfoPosition.push('left'); + // } else { + // modelInfoPosition.push('right'); + // } + } else { + modelInfoPosition.push('right'); + // if (y < maxY / 2) { + // modelInfoPosition.push('top'); + // } else { + // modelInfoPosition.push('bottom'); + // } + } + console.log(props.currentRow, 'currentRow'); + if (modelInfoPosition.includes('left')) { + let topValue = y - modelInfoHeight / 2 + modelHeight / 2 + if(topValue> maxY - modelInfoHeight){ + topValue = maxY - modelInfoHeight + } + if(topValue<0){ + topValue = 0 + } + currPositionStyle = { + top: topValue, + left: x - modelInfoWidth - 10, + }; + } else { + let topValue = y - modelInfoHeight / 2 + modelHeight / 2 + if(topValue> maxY - modelInfoHeight){ + topValue = maxY - modelInfoHeight + } + if(topValue<0){ + topValue = 0 + } + currPositionStyle = { + top: topValue, + left: x + modelWidth + 10, + }; + } + setPositionStyle(currPositionStyle); + } + + useEffect(() => { + if (props.currentRow) { + initPointPosition(); + } + }, [props.currentRow, props.clipPathData]); + return props.isShowDetail ? ( +
+
+ 设备信息 + props.handleDrawer()} /> +
+ []} + > +
+ ) : ( + <> + ); + + // props.handleDrawer()} + // > + + // + // { + // props.handleDrawer(); + // }} + // closable={true} + // > + // {props.currentRow?.id && ( + // + // style={{ + // // paddingLeft: 4, + // // paddingRight: 4 + // }} + // column={2} + // title={props.currentRow?.id} + // request={async () => ({ + // data: props.currentRow || {}, + // })} + // params={{ + // id: props.currentRow?.id, + // }} + // columns={props.columns as ProDescriptionsItemProps[]} + // /> + // )} + // +}; +export { ColumnDrawer }; diff --git a/src/pages/FabricView/Room/index.tsx b/src/pages/FabricView/Room/index.tsx new file mode 100644 index 0000000..a8035df --- /dev/null +++ b/src/pages/FabricView/Room/index.tsx @@ -0,0 +1,204 @@ +/* + * @Author: zhoux zhouxia@supervision.ltd + * @Date: 2023-12-12 10:57:54 + * @LastEditors: zhoux zhouxia@supervision.ltd + * @LastEditTime: 2023-12-15 17:06:36 + * @FilePath: \general-ai-platform-web\src\pages\FabricView\Room\index.tsx + * @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE + */ + +// import { useUuid } from '@/hooks/useUuid'; +import { currJson } from '@/testData/fabricRoomList'; +import { bgImageData } from '@/testData/fabricRoomSvg'; +import { ProCard } from '@ant-design/pro-components'; +import { useIntl } from '@umijs/max'; +import { Button } from 'antd'; +import { fabric } from 'fabric'; +import React, { useEffect, useRef, useState } from 'react'; +import { ColumnDrawer } from './components/ColumnDrawer'; + +export const ModelCategoryColumns = [ + { + title: '设备ID', + dataIndex: 'id', + }, + { + title: '设备名称', + dataIndex: 'deviceName', + }, + { + title: '设备代码', + dataIndex: 'deviceCode', + }, + { + title: '设备位置', + dataIndex: 'deviceLocation', + }, + { + title: '设备代码', + dataIndex: 'deviceCode', + }, + { + title: '设备名称', + dataIndex: 'deviceName', + }, + { + title: '设备代码', + dataIndex: 'deviceCode', + }, + { + title: '设备名称', + dataIndex: 'deviceName', + }, +]; +const FabricViewRoom: React.FC = () => { + const intl = useIntl(); + const canvasRef = useRef(null); + const itemsRef = useRef(null); + const [cvs, setCanvas] = useState(null); + const [descriptors, setDescriptors] = useState>({}); + const [category_fk_id_open, set_category_fk_id_open] = useState(false); + const [currentModelUserProperty, setCurrentModelUserProperty] = useState>({}); + + const [changeId, setChangeId] = useState([]); + const [currentTargetObject, setCurrentTargetObject] = useState(null); + + const [clipPathData, setClipPathData] = useState({ + width: 1200, // 宽 + height: 900, // 高 + }); + const [jsonData, setJsonData] = useState>({}); + + /*test */ + // const { fetchUuid } = useUuid(); + + function changeModelStatus() { + setChangeId(['2', '3']); + } + + const handle_category_fk_id = () => { + if (category_fk_id_open) { + set_category_fk_id_open(false); + } + }; + + function closeSelectedModel(targetCvs?: any) { + let finalCvs = cvs; + if (targetCvs) { + finalCvs = targetCvs; + } + finalCvs.getObjects().forEach((item) => { + // if (changeId.includes(item?.userProperty?.id)) { + const groupObject = item; + // 选中组合对象 + // canvasObject.setActiveObject(groupObject); // 可以改变 selectable 值 + finalCvs.requestRenderAll(); + // 获取组合对象中的子对象 + const objectsInGroup = groupObject.getObjects(); + groupObject.item(0).item(1).set({ + fill: '#DCDCDC', + }); + groupObject.item(1).set({ + fill: 'rgb(0,0,0)', + }) + finalCvs.renderAll(); + // 遍历子对象找到要修改的子对象 + + // } + }); + } + // 初始化加载画布&渲染模型 + useEffect(() => { + const canvasObject = new fabric.Canvas(canvasRef.current); + canvasObject.setBackgroundImage(bgImageData.src, canvasObject.renderAll.bind(canvasObject), { + width: clipPathData.width, + height: clipPathData.height, + originX: 'left', + originY: 'top', + }); + canvasObject.loadFromJSON(JSON.stringify(currJson), () => { + canvasObject.renderAll(); + // const groupObjectList = canvasObject.getObjects() + + // const groupObject = canvasObject.getObjects()[0]; + + // 选中组合对象 + // console.log(groupObject, 'groupObject', canvasObject.getObjects()); + // 注册事件监听器 + canvasObject.on('mouse:down', (event) => { + // 获取事件的目标对象 + const targetObject = event.target; + // set_category_fk_id_open(false); + + // 检查目标对象是否为组合对象 + if (targetObject && targetObject?.userProperty) { + // canvasObject.setActiveObject(targetObject); + setChangeId([targetObject?.userProperty?.id]); + // console.log('mouse:up:', targetObject); + setCurrentModelUserProperty(targetObject.userProperty); + set_category_fk_id_open(true); + } + // 检查目标对象是否为组合对象 + if (targetObject) { + setCurrentTargetObject(targetObject); + closeSelectedModel(canvasObject); + + // console.log('mouse:down:', ); + targetObject.item(0).item(1).set({ + fill: 'blue', + }); + targetObject.item(1).set({ + fill: 'blue', + }) + } + canvasObject.renderAll(); + }); + }); + setCanvas(canvasObject); + return () => { + canvasObject.dispose(); + }; + }, []); + + useEffect(() => { + // TODO_3 需要加个loading效果 + // import('./Descriptors.json').then((descriptors) => { + // setDescriptors(descriptors); + // }); + // console.log(fetchUuid(), 'fetchUuid'); + if (changeId && changeId.length && !category_fk_id_open) { + closeSelectedModel(); + } + }, [changeId, category_fk_id_open]); + + return ( + + + + } + > + {/* + + */} + + + + + + + // 属性预览 + ); +}; + +export default FabricViewRoom; diff --git a/src/pages/Resource/ResourceDeviceStatus/components/DeviceStatusCard.tsx b/src/pages/Resource/ResourceDeviceStatus/components/DeviceStatusCard.tsx new file mode 100644 index 0000000..07874ac --- /dev/null +++ b/src/pages/Resource/ResourceDeviceStatus/components/DeviceStatusCard.tsx @@ -0,0 +1,158 @@ +/* + * @Author: zhoux zhouxia@supervision.ltd + * @Date: 2023-11-06 16:12:17 + * @LastEditors: zhoux zhouxia@supervision.ltd + * @LastEditTime: 2023-12-15 14:00:33 + * @FilePath: \general-ai-platform-web\src\pages\Setting\components\ProjectCardList.tsx + * @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE + */ +import React from 'react'; + +import { Progress } from 'antd'; +// import { postModelVersionGetModelVersionListByIds } from '@/services/resource/ModelVersion'; + +// const [tabs, setTabs] = useState([]); +// const [projectData, setProjectData] = useState({}); +// const [tab, setTab] = useState(''); +// const [modelVersionData, setModelVersionData] = useState([]); + +/**styles */ +const listItemStyle = { + display: 'flex', + fontSize: 14, + color: '#333333', + width: '100%', + alignItems: 'center', + padding: '4px 0 0', +}; + +const listItemLabelStyle = { + display: 'flex', + alignItems: 'center', + fontSize: 12, + color: '#666666', + minWidth: 53 +}; + +const listItemTextStyle = { + fontSize: 14, + margin: 0, +}; +// 卡片 +export type UpdateProjectProps = { + info: Record; + // reload: any; +}; + +type DeviceItemProgress = { + label: string; + percent: number; +}; + +// 进度条 +// TODO 进度条的边框圆角调整为矩形 +const DeviceItemProgress: React.FC = (props) => { + let strokeColor = 'rgb(243,48,5)'; + switch (props.label) { + case '存储告警': + strokeColor = 'rgb(243,48,5)'; + break; + case 'GPU告警': + case '内存告警': + strokeColor = 'rgb(33,169,122)'; + break; + case 'CPU告警': + strokeColor = 'rgb(250,173,20)'; + break; + } + + return ( +
+ {props.label} + +
+ ); +}; + +const DeviceStatusCard: React.FC = ({ + info, +}: { + info: Record; +}) => { + return ( +
+ {/*
+ 苏胜天算法模型 + 经典算法 +
*/} +
    +
  • + + 代码出错 +
  • +
  • + + 服务超时 +
  • +
+
    +
  • + +
  • +
  • + +
  • +
  • + +
  • +
  • + +
  • +
+
+ ); +}; + +export default DeviceStatusCard; diff --git a/src/pages/Resource/ResourceDeviceStatus/index.tsx b/src/pages/Resource/ResourceDeviceStatus/index.tsx new file mode 100644 index 0000000..87f4dae --- /dev/null +++ b/src/pages/Resource/ResourceDeviceStatus/index.tsx @@ -0,0 +1,181 @@ +import TableActionCard from '@/components/TableActionCard'; +import IsConfirmAction from '@/components/TableActionCard/isConfirmAction'; +import { resourceDeviceStatusEnums } from '@/enums/status'; +import { PageContainer, ProCard, ProColumns, ProList } from '@ant-design/pro-components'; +import { FormattedMessage } from '@umijs/max'; +import { Button, Tag } from 'antd'; +import React, { useState } from 'react'; +import { proTableCommonOptions, proTablePaginationOptions } from '../../../../config/defaultTable'; +import DeviceStatusCard from './components/DeviceStatusCard'; + +/** + * @交互说明 + * 1、列表分页展示分布式设备状态(分类查询) + * 2、详情展示基础信息、日志 + * 3、重启设备 + */ +const tabOptions: Record = { + allStatus: 90, + storageWarn: 20, + GPUWarn: 20, + memoryWarn: 10, + errorStatus: 20, + codeError: 10, + serveTimeOut: 20, +}; + +const ResourceDeviceStatus: React.FC = () => { + const [detailModalOpen, setDetailModalOpen] = useState(false); + const [currentRow, setCurrentRow] = useState>({}); + // 动态设置每页数量 + const [currentPageSize, setCurrentPageSize] = useState(15); + + const [activeTabIndex, setActiveTabIndex] = useState(0); + + + const dataTestList = [ + { status: '存储告警' }, + { status: 'GPU告警' }, + { status: '内存告警' }, + { status: 'CPU告警' }, + { status: '代码出错' }, + { status: '服务器超时' }, + { status: '存储告警' }, + { status: '代码出错' }, + { status: '存储告警' }, + { status: 'GPU告警' }, + { status: '内存告警' }, + { status: 'CPU告警' }, + { status: '代码出错' }, + { status: '服务器超时' }, + { status: '存储告警' }, + { status: '代码出错' }, + ].map((record, index) => { + return { + content: ( + +
+ +

+ 控制设备{index + 1} +

+ +
+ {' '} +
+ ), + }; + }); + + return ( + + + className="gn" + ghost={true} + itemCardProps={{ + ghost: true, + bodyStyle: { padding: 0, margin: 0 }, + }} + headerTitle={ + <> + + {Object.keys(tabOptions).map((item, index) => { + // eslint-disable-next-line react/jsx-key + return ( + + ); + })} + + + } + cardProps={{ + bodyStyle: { + background: 'white', + padding: '0px 16px 16px', + borderRadius: 8, + }, + }} + pagination={{ + ...proTablePaginationOptions, + pageSize: currentPageSize, + onChange: (page, pageSize) => setCurrentPageSize(pageSize), + }} + showActions="hover" + rowSelection={false} + grid={{ gutter: 16, xs: 1, md: 3, lg: 4, xl: 5, xxl: 7 }} + metas={{ + type: { + + }, + content: { + }, + actions: { + cardActionProps: 'extra', + } + }} + request={async (params = {}, sort) => { + const { current, ...rest } = params; + const reqParams = { + page: current, + desc: false, + orderKey: '', + ...rest, + }; + if (sort && Object.keys(sort).length) { + reqParams.orderKey = Object.keys(sort)[0]; + let sort_select = sort[reqParams.orderKey]; + reqParams.desc = sort_select === 'descend'; + } + // TODO 联调查询设备状态接口 + // let resps = await postDeviceGroupGetDeviceGroupList({ ...reqParams }); + let resp = { + success: true, + data: { + list: dataTestList, + total: 16, + page: 1, + pageSize: 16, + }, + }; + return { + data: resp.data.list, + success: resp.success, + total: resp.data.total, + current: resp.data.page, + pageSize: resp.data.pageSize, + }; + }} + /> + + ); +}; + +export default ResourceDeviceStatus; diff --git a/src/testData/fabricGroupRoom.ts b/src/testData/fabricGroupRoom.ts new file mode 100644 index 0000000..dd05cf3 --- /dev/null +++ b/src/testData/fabricGroupRoom.ts @@ -0,0 +1,1644 @@ +const modelGroup: Record[] = [ + { + type: 'group', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: 0, + top: 0, + width: 115.6016, + height: 39, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + id: 'b6ca8fad-c240-4659-9952-a90167699ce9', + selectable: false, + hasControls: true, + userProperty: {}, + objects: [ + { + type: 'group', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -57.8008, + top: -19.5, + width: 36, + height: 39, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + objects: [ + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -12.5, + top: -18, + width: 24, + height: 27, + fill: 'white', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'evenodd', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 19.2704, 25.9335], + ['C', 25.3006, 25.299, 30, 20.1983, 30, 14], + ['C', 30, 7.37258, 24.6274, 2, 18, 2], + ['C', 11.3726, 2, 6, 7.37258, 6, 14], + ['C', 6, 19.8172, 10.1393, 24.6677, 15.6332, 25.7667], + ['L', 17.5, 29], + ['L', 19.2704, 25.9335], + ['Z'], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -13.5, + top: -19, + width: 26, + height: 30, + fill: '#DCDCDC', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 19.2704, 25.9335], + ['L', 19.1658, 24.939], + ['L', 18.6591, 24.9924], + ['L', 18.4044, 25.4335], + ['L', 19.2704, 25.9335], + ['Z'], + ['M', 15.6332, 25.7667], + ['L', 16.4993, 25.2667], + ['L', 16.273, 24.8748], + ['L', 15.8294, 24.7861], + ['L', 15.6332, 25.7667], + ['Z'], + ['M', 17.5, 29], + ['L', 16.634, 29.5], + ['L', 17.5, 31], + ['L', 18.366, 29.5], + ['L', 17.5, 29], + ['Z'], + ['M', 29, 14], + ['C', 29, 19.6811, 24.6924, 24.3575, 19.1658, 24.939], + ['L', 19.3751, 26.9281], + ['C', 25.9088, 26.2405, 31, 20.7155, 31, 14], + ['L', 29, 14], + ['Z'], + ['M', 18, 3], + ['C', 24.0751, 3, 29, 7.92487, 29, 14], + ['L', 31, 14], + ['C', 31, 6.8203, 25.1797, 1, 18, 1], + ['L', 18, 3], + ['Z'], + ['M', 7, 14], + ['C', 7, 7.92487, 11.9249, 3, 18, 3], + ['L', 18, 1], + ['C', 10.8203, 1, 5, 6.8203, 5, 14], + ['L', 7, 14], + ['Z'], + ['M', 15.8294, 24.7861], + ['C', 10.7937, 23.7788, 7, 19.3313, 7, 14], + ['L', 5, 14], + ['C', 5, 20.3032, 9.48488, 25.5566, 15.4371, 26.7472], + ['L', 15.8294, 24.7861], + ['Z'], + ['M', 14.7672, 26.2667], + ['L', 16.634, 29.5], + ['L', 18.366, 28.5], + ['L', 16.4993, 25.2667], + ['L', 14.7672, 26.2667], + ['Z'], + ['M', 18.366, 29.5], + ['L', 20.1364, 26.4335], + ['L', 18.4044, 25.4335], + ['L', 16.634, 28.5], + ['L', 18.366, 29.5], + ['Z'], + ], + }, + ], + }, + { + type: 'group', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -47.8008, + top: -13.4177, + width: 16, + height: 16, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + objects: [ + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -6.9333, + top: -6.6, + width: 12.6666, + height: 0, + fill: '', + stroke: '#52C41A', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 14.3334, 2], + ['L', 7.66675, 2], + ['L', 1.66675, 2], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -0.9332, + top: -6.6, + width: 0, + height: 5.6667, + fill: '', + stroke: '#52C41A', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 7.66675, 7.66667], + ['L', 7.66675, 2], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -6.9994, + top: -2.0727, + width: 11.833, + height: 7.0096, + fill: '#52C41A', + stroke: '#52C41A', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 2.80841, 6.52734], + ['L', 13.4336, 9.37438], + ['L', 12.8528, 10.254], + ['L', 11.5187, 12.6573], + ['L', 10.9379, 13.5369], + ['L', 1.60059, 11.035], + ['L', 2.80841, 6.52734], + ['Z'], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: 2.9186, + top: 1.6539, + width: 2.622, + height: 2.9209, + fill: '', + stroke: '#52C41A', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 12.8527, 10.2539], + ['L', 14.1406, 10.599], + ['L', 13.4504, 13.1748], + ['L', 11.5186, 12.6572], + ], + }, + { + type: 'circle', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -5, + top: 0, + width: 2.5, + height: 2.5, + fill: '', + stroke: 'white', + strokeWidth: 0.5, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + radius: 1.25, + startAngle: 0, + endAngle: 360, + selectable: true, + hasControls: true, + }, + ], + }, + { + type: 'textbox', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -19.6724, + top: -13.5967, + width: 400, + height: 90.4, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 0.1932, + scaleY: 0.1932, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + fontFamily: 'arial', + fontWeight: 'normal', + fontSize: 80, + text: '监控设备', + underline: false, + overline: false, + linethrough: false, + textAlign: 'left', + fontStyle: 'normal', + lineHeight: 1.16, + textBackgroundColor: '', + charSpacing: 0, + styles: [], + direction: 'ltr', + path: null, + pathStartOffset: 0, + pathSide: 'left', + pathAlign: 'baseline', + minWidth: 20, + splitByGrapheme: true, + selectable: true, + hasControls: false, + }, + ], + }, +]; + +const currJson0: Record = { + version: '5.3.0', + objects: [ + { + type: 'group', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: 247.0215, + top: 444.5797, + width: 115.6016, + height: 39, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + id: 'b6ca8fad-c240-4659-9952-a90167699ce9', + selectable: false, + hasControls: true, + userProperty: { + modelId: '121', + status: '0', + id: '2', + label: '正常', + des: '卧室B', + + param1: '', + }, + objects: [ + { + type: 'group', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -57.8008, + top: -19.5, + width: 36, + height: 39, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + objects: [ + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -12.5, + top: -18, + width: 24, + height: 27, + fill: 'white', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'evenodd', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 19.2704, 25.9335], + ['C', 25.3006, 25.299, 30, 20.1983, 30, 14], + ['C', 30, 7.37258, 24.6274, 2, 18, 2], + ['C', 11.3726, 2, 6, 7.37258, 6, 14], + ['C', 6, 19.8172, 10.1393, 24.6677, 15.6332, 25.7667], + ['L', 17.5, 29], + ['L', 19.2704, 25.9335], + ['Z'], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -13.5, + top: -19, + width: 26, + height: 30, + fill: '#DCDCDC', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 19.2704, 25.9335], + ['L', 19.1658, 24.939], + ['L', 18.6591, 24.9924], + ['L', 18.4044, 25.4335], + ['L', 19.2704, 25.9335], + ['Z'], + ['M', 15.6332, 25.7667], + ['L', 16.4993, 25.2667], + ['L', 16.273, 24.8748], + ['L', 15.8294, 24.7861], + ['L', 15.6332, 25.7667], + ['Z'], + ['M', 17.5, 29], + ['L', 16.634, 29.5], + ['L', 17.5, 31], + ['L', 18.366, 29.5], + ['L', 17.5, 29], + ['Z'], + ['M', 29, 14], + ['C', 29, 19.6811, 24.6924, 24.3575, 19.1658, 24.939], + ['L', 19.3751, 26.9281], + ['C', 25.9088, 26.2405, 31, 20.7155, 31, 14], + ['L', 29, 14], + ['Z'], + ['M', 18, 3], + ['C', 24.0751, 3, 29, 7.92487, 29, 14], + ['L', 31, 14], + ['C', 31, 6.8203, 25.1797, 1, 18, 1], + ['L', 18, 3], + ['Z'], + ['M', 7, 14], + ['C', 7, 7.92487, 11.9249, 3, 18, 3], + ['L', 18, 1], + ['C', 10.8203, 1, 5, 6.8203, 5, 14], + ['L', 7, 14], + ['Z'], + ['M', 15.8294, 24.7861], + ['C', 10.7937, 23.7788, 7, 19.3313, 7, 14], + ['L', 5, 14], + ['C', 5, 20.3032, 9.48488, 25.5566, 15.4371, 26.7472], + ['L', 15.8294, 24.7861], + ['Z'], + ['M', 14.7672, 26.2667], + ['L', 16.634, 29.5], + ['L', 18.366, 28.5], + ['L', 16.4993, 25.2667], + ['L', 14.7672, 26.2667], + ['Z'], + ['M', 18.366, 29.5], + ['L', 20.1364, 26.4335], + ['L', 18.4044, 25.4335], + ['L', 16.634, 28.5], + ['L', 18.366, 29.5], + ['Z'], + ], + }, + ], + }, + { + type: 'group', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -47.8008, + top: -13.4177, + width: 16, + height: 16, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + objects: [ + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -6.9333, + top: -6.6, + width: 12.6666, + height: 0, + fill: '', + stroke: '#52C41A', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 14.3334, 2], + ['L', 7.66675, 2], + ['L', 1.66675, 2], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -0.9332, + top: -6.6, + width: 0, + height: 5.6667, + fill: '', + stroke: '#52C41A', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 7.66675, 7.66667], + ['L', 7.66675, 2], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -6.9994, + top: -2.0727, + width: 11.833, + height: 7.0096, + fill: '#52C41A', + stroke: '#52C41A', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 2.80841, 6.52734], + ['L', 13.4336, 9.37438], + ['L', 12.8528, 10.254], + ['L', 11.5187, 12.6573], + ['L', 10.9379, 13.5369], + ['L', 1.60059, 11.035], + ['L', 2.80841, 6.52734], + ['Z'], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: 2.9186, + top: 1.6539, + width: 2.622, + height: 2.9209, + fill: '', + stroke: '#52C41A', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 12.8527, 10.2539], + ['L', 14.1406, 10.599], + ['L', 13.4504, 13.1748], + ['L', 11.5186, 12.6572], + ], + }, + { + type: 'circle', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -5, + top: 0, + width: 2.5, + height: 2.5, + fill: '', + stroke: 'white', + strokeWidth: 0.5, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + radius: 1.25, + startAngle: 0, + endAngle: 360, + selectable: true, + hasControls: true, + }, + ], + }, + { + type: 'textbox', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -19.6724, + top: -13.5967, + width: 400, + height: 90.4, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 0.1932, + scaleY: 0.1932, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + fontFamily: 'arial', + fontWeight: 'normal', + fontSize: 80, + text: '监控设备', + underline: false, + overline: false, + linethrough: false, + textAlign: 'left', + fontStyle: 'normal', + lineHeight: 1.16, + textBackgroundColor: '', + charSpacing: 0, + styles: [], + direction: 'ltr', + path: null, + pathStartOffset: 0, + pathSide: 'left', + pathAlign: 'baseline', + minWidth: 20, + splitByGrapheme: true, + selectable: true, + hasControls: false, + }, + ], + }, + { + type: 'group', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: 778.0535, + top: 172.6152, + width: 48.205, + height: 48.205, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + id: 'f772494d-01de-4a9e-b21d-67faed778e60', + selectable: false, + hasControls: true, + userProperty: { + modelId: '121', + status: '0', + id: '2', + label: '正常', + des: '卧室B', + }, + objects: [ + { + type: 'circle', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -24.1025, + top: -24.1025, + width: 300, + height: 300, + fill: 'rgba(44,246,72,0.99)', + stroke: 'rgba(45,240,230,1)', + strokeWidth: 10, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 0.1555, + scaleY: 0.1555, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + radius: 150, + startAngle: 0, + endAngle: 360, + selectable: false, + hasControls: true, + }, + { + type: 'i-text', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -16.7824, + top: -8.9323, + width: 160, + height: 90.4, + fill: 'rgba(255,255,255,1)', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 0.1954, + scaleY: 0.1954, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + fontFamily: 'arial', + fontWeight: 'normal', + fontSize: 80, + text: '正常', + underline: false, + overline: false, + linethrough: false, + textAlign: 'left', + fontStyle: 'normal', + lineHeight: 1.16, + textBackgroundColor: '', + charSpacing: 0, + styles: [], + direction: 'ltr', + path: null, + pathStartOffset: 0, + pathSide: 'left', + pathAlign: 'baseline', + selectable: false, + hasControls: true, + }, + ], + }, + { + type: 'group', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: 384.136, + top: 153.6373, + width: 48.205, + height: 48.205, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + id: '3fea9335-b7a3-4b01-bf7b-7d15b4ca6b62', + selectable: false, + hasControls: true, + userProperty: { + modelId: '120', + status: '1', + id: '1', + label: '异常', + des: '卧室A', + }, + objects: [ + { + type: 'circle', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -24.1025, + top: -24.1025, + width: 300, + height: 300, + fill: 'rgba(248,9,3,0.94)', + stroke: 'rgba(255,243,47,1)', + strokeWidth: 10, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 0.1555, + scaleY: 0.1555, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + radius: 150, + startAngle: 0, + endAngle: 360, + selectable: false, + hasControls: true, + }, + { + type: 'i-text', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -15.8708, + top: -8.9298, + width: 160, + height: 90.4, + fill: 'rgba(255,255,255,1)', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 0.1954, + scaleY: 0.1954, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + fontFamily: 'arial', + fontWeight: 'normal', + fontSize: 80, + text: '警告', + underline: false, + overline: false, + linethrough: false, + textAlign: 'left', + fontStyle: 'normal', + lineHeight: 1.16, + textBackgroundColor: '', + charSpacing: 0, + styles: [], + direction: 'ltr', + path: null, + pathStartOffset: 0, + pathSide: 'left', + pathAlign: 'baseline', + selectable: false, + hasControls: true, + }, + ], + }, + { + type: 'group', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: 409.6953, + top: 437.8391, + width: 48.205, + height: 48.205, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + id: '16c614ab-6172-4d06-b787-75e8ddc33c68', + selectable: false, + hasControls: true, + userProperty: { + modelId: '122', + status: '0', + id: '3', + label: '正常', + des: '客厅1', + }, + objects: [ + { + type: 'circle', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -24.1025, + top: -24.1025, + width: 300, + height: 300, + fill: 'rgba(44,246,72,0.99)', + stroke: 'rgba(45,240,230,1)', + strokeWidth: 10, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 0.1555, + scaleY: 0.1555, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + radius: 150, + startAngle: 0, + endAngle: 360, + selectable: false, + hasControls: true, + }, + { + type: 'i-text', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -16.7824, + top: -8.9323, + width: 160, + height: 90.4, + fill: 'rgba(255,255,255,1)', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 0.1954, + scaleY: 0.1954, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + fontFamily: 'arial', + fontWeight: 'normal', + fontSize: 80, + text: '正常', + underline: false, + overline: false, + linethrough: false, + textAlign: 'left', + fontStyle: 'normal', + lineHeight: 1.16, + textBackgroundColor: '', + charSpacing: 0, + styles: [], + direction: 'ltr', + path: null, + pathStartOffset: 0, + pathSide: 'left', + pathAlign: 'baseline', + selectable: false, + hasControls: true, + }, + ], + }, + { + type: 'group', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: 384.136, + top: 706.1746, + width: 48.205, + height: 48.205, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + id: '6217576c-4b4a-4916-948a-e99fe9f03bbc', + selectable: false, + hasControls: true, + userProperty: { + modelId: '124', + status: '1', + id: '4', + label: '异常', + des: '卧室C', + }, + objects: [ + { + type: 'circle', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -24.1025, + top: -24.1025, + width: 300, + height: 300, + fill: 'rgba(248,9,3,0.94)', + stroke: 'rgba(255,243,47,1)', + strokeWidth: 10, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 0.1555, + scaleY: 0.1555, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + radius: 150, + startAngle: 0, + endAngle: 360, + selectable: false, + hasControls: true, + }, + { + type: 'i-text', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -15.8708, + top: -8.9298, + width: 160, + height: 90.4, + fill: 'rgba(255,255,255,1)', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 0.1954, + scaleY: 0.1954, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + fontFamily: 'arial', + fontWeight: 'normal', + fontSize: 80, + text: '警告', + underline: false, + overline: false, + linethrough: false, + textAlign: 'left', + fontStyle: 'normal', + lineHeight: 1.16, + textBackgroundColor: '', + charSpacing: 0, + styles: [], + direction: 'ltr', + path: null, + pathStartOffset: 0, + pathSide: 'left', + pathAlign: 'baseline', + selectable: false, + hasControls: true, + }, + ], + }, + ], + clipPath: { + type: 'rect', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: 0, + top: 0, + width: 1200, + height: 900, + fill: 'rgba(255,255,255,1)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + rx: 0, + ry: 0, + selectable: false, + hasControls: true, + }, +}; +let currJson00: Record = { + ...currJson0, + // objects: [], +}; + +// 生成100到1100之间的随机整数 +// function generateRandomNumber(minNum, maxNum) { +// // 生成0到1之间的随机小数 +// const randomFraction = Math.random(); + +// // 将随机小数映射到100到1100之间的范围 +// const randomNumber = Math.floor(randomFraction * (maxNum - minNum + 1) + minNum); + +// return randomNumber; +// } +// let startTime = new Date().getTime() +// let endTime = new Date().getTime() + +// for (let i = 0; i < 2; i++) { +// let currObjects = JSON.parse(JSON.stringify(currJson0.objects)) +// currObjects = currObjects.map(item=>{ +// item.left = generateRandomNumber(100, 1100) +// item.top = generateRandomNumber(100, 800) +// return item +// }) +// currJson00.objects = currJson00.objects.concat(currObjects) +// } +// endTime = new Date().getTime() +// console.log(currJson00,'currJson00', endTime-startTime) + +export const currJson1 = currJson00; + +export const modelGroups = modelGroup diff --git a/src/testData/fabricRoomList.ts b/src/testData/fabricRoomList.ts new file mode 100644 index 0000000..b917dda --- /dev/null +++ b/src/testData/fabricRoomList.ts @@ -0,0 +1,147 @@ +/* + * @Author: zhoux zhouxia@supervision.ltd + * @Date: 2023-12-12 15:41:56 + * @LastEditors: zhoux zhouxia@supervision.ltd + * @LastEditTime: 2023-12-15 17:22:03 + * @FilePath: \general-ai-platform-web\src\testData\fabricRoomList.ts + * @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE + */ + +import { fetchWatchGroupObjects } from './fabricWatchIcons'; +// 模型状态 在线 离线 告警 故障 +const startData: Record = { + modelsList: [ + { + deviceType: '1', // 模型类型 1 设备1 2 设备2 + id: '1001', // 模型id + status: 'watchOnline', // + deviceName: '监控设备1', // 模型名称 + deviceCode: 'code1002', + deviceLocation: '客厅', + deviceParams: '设备参数', + deviceCategory: '控制器', + diviceGroup: '组1', + baseInfo: { + left: 527.0215, // 相对x + top: 24.5797, // 相对y + }, + }, + { + deviceType: '1', // 模型类型 1 设备1 2 设备2 + id: '1002', // 模型id + status: 'watchError', // 模型状态 在线 离线 告警 故障 + deviceName: '监控设备2', // 模型名称 + deviceCode: 'code1001', + deviceLocation: '客厅', + deviceParams: '设备参数', + deviceCategory: '控制器', + diviceGroup: '组1', + baseInfo: { + left: 397.0215, // 相对x + top: 444.5797, // 相对y + }, + }, + { + deviceType: '1', // 模型类型 1 设备1 2 设备2 + id: '1003', // 模型id + status: 'watchOutline', // 模型状态 在线 离线 告警 故障 + deviceName: '监控设备2', // 模型名称 + deviceCode: 'code1001', + deviceLocation: '客厅', + deviceParams: '设备参数', + deviceCategory: '控制器', + diviceGroup: '组1', + baseInfo: { + left: 397.0215, // 相对x + top: 144.5797, // 相对y + }, + }, + { + deviceType: '1', // 模型类型 1 设备1 2 设备2 + id: '1004', // 模型id + status: 'watchOutline', // 模型状态 在线 离线 告警 故障 + deviceName: '监控设备2', // 模型名称 + deviceCode: 'code1001', + deviceLocation: '客厅', + deviceParams: '设备参数', + deviceCategory: '控制器', + diviceGroup: '组1', + baseInfo: { + left: 297.0215, // 相对x + top: 644.5797, // 相对y + }, + }, + { + deviceType: '1', // 模型类型 1 设备1 2 设备2 + id: '1005', // 模型id + status: 'watchWarn', // 模型状态 在线 离线 告警 故障 + deviceName: '监控设备2', // 模型名称 + deviceCode: 'code1001', + deviceLocation: '客厅', + deviceParams: '设备参数', + deviceCategory: '控制器', + diviceGroup: '组1', + baseInfo: { + left: 797.0215, // 相对x + top: 844.5797, // 相对y + }, + }, + ], +}; + +const fabricRoomListData: Record[] = []; +startData.modelsList.forEach((item: Record) => { + const { baseInfo, ...restInfo } = item; + fabricRoomListData.push( + JSON.parse( + JSON.stringify({ + ...fetchWatchGroupObjects(item), + ...baseInfo, + userProperty: item, + selectable: false, + }), + ), + ); +}); + +export const currJson = { + version: '5.3.0', + objects: fabricRoomListData, + clipPath: { + type: 'rect', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: 0, + top: 0, + width: 1200, + height: 900, + fill: 'rgba(255,255,255,1)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + rx: 0, + ry: 0, + selectable: false, + hasControls: true, + }, +}; diff --git a/src/testData/fabricRoomSvg.ts b/src/testData/fabricRoomSvg.ts new file mode 100644 index 0000000..0fa87a9 --- /dev/null +++ b/src/testData/fabricRoomSvg.ts @@ -0,0 +1,49 @@ +/* + * @Author: zhoux zhouxia@supervision.ltd + * @Date: 2023-12-12 14:11:22 + * @LastEditors: zhoux zhouxia@supervision.ltd + * @LastEditTime: 2023-12-15 18:00:38 + * @FilePath: \general-ai-platform-web\src\testData\fabricRoomSvg.ts + * @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE + */ +export const bgImageData = { + type: 'image', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: 1.531, + top: 0, + width: 1600, + height: 1200, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + cropX: 0, + cropY: 0, + id: 'a3fccbda-f75a-4c52-9fc0-98a2dde189b9', + selectable: true, + hasControls: true, + src: '', + crossOrigin: null, + filters: [], +}; diff --git a/src/testData/fabricWatchIcons.ts b/src/testData/fabricWatchIcons.ts new file mode 100644 index 0000000..0f09a84 --- /dev/null +++ b/src/testData/fabricWatchIcons.ts @@ -0,0 +1,1825 @@ +export const watchIcon1: Record[] = [ + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -60, + top: -31.5, + width: 119, + height: 54, + fill: 'white', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'evenodd', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 10, 2], + ['C', 7.79086, 2, 6, 3.79086, 6, 6], + ['L', 6, 44], + ['C', 6, 46.2091, 7.79086, 48, 10, 48], + ['L', 58.8, 48], + ['L', 66, 56], + ['L', 73.2, 48], + ['L', 121, 48], + ['C', 123.209, 48, 125, 46.2091, 125, 44], + ['L', 125, 6], + ['C', 125, 3.79086, 123.209, 2, 121, 2], + ['L', 10, 2], + ['Z'], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -61, + top: -32.5, + width: 121, + height: 56.4948, + fill: 'rgba(21,77,221,0.2)', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 58.8, 48], + ['L', 59.5433, 47.331], + ['L', 59.2454, 47], + ['L', 58.8, 47], + ['L', 58.8, 48], + ['Z'], + ['M', 66, 56], + ['L', 65.2567, 56.669], + ['L', 66, 57.4948], + ['L', 66.7433, 56.669], + ['L', 66, 56], + ['Z'], + ['M', 73.2, 48], + ['L', 73.2, 47], + ['L', 72.7546, 47], + ['L', 72.4567, 47.331], + ['L', 73.2, 48], + ['Z'], + ['M', 7, 6], + ['C', 7, 4.34315, 8.34315, 3, 10, 3], + ['L', 10, 1], + ['C', 7.23858, 1, 5, 3.23857, 5, 6], + ['L', 7, 6], + ['Z'], + ['M', 7, 44], + ['L', 7, 6], + ['L', 5, 6], + ['L', 5, 44], + ['L', 7, 44], + ['Z'], + ['M', 10, 47], + ['C', 8.34315, 47, 7, 45.6569, 7, 44], + ['L', 5, 44], + ['C', 5, 46.7614, 7.23858, 49, 10, 49], + ['L', 10, 47], + ['Z'], + ['M', 58.8, 47], + ['L', 10, 47], + ['L', 10, 49], + ['L', 58.8, 49], + ['L', 58.8, 47], + ['Z'], + ['M', 58.0567, 48.669], + ['L', 65.2567, 56.669], + ['L', 66.7433, 55.331], + ['L', 59.5433, 47.331], + ['L', 58.0567, 48.669], + ['Z'], + ['M', 66.7433, 56.669], + ['L', 73.9433, 48.669], + ['L', 72.4567, 47.331], + ['L', 65.2567, 55.331], + ['L', 66.7433, 56.669], + ['Z'], + ['M', 121, 47], + ['L', 73.2, 47], + ['L', 73.2, 49], + ['L', 121, 49], + ['L', 121, 47], + ['Z'], + ['M', 124, 44], + ['C', 124, 45.6569, 122.657, 47, 121, 47], + ['L', 121, 49], + ['C', 123.761, 49, 126, 46.7614, 126, 44], + ['L', 124, 44], + ['Z'], + ['M', 124, 6], + ['L', 124, 44], + ['L', 126, 44], + ['L', 126, 6], + ['L', 124, 6], + ['Z'], + ['M', 121, 3], + ['C', 122.657, 3, 124, 4.34315, 124, 6], + ['L', 126, 6], + ['C', 126, 3.23858, 123.761, 1, 121, 1], + ['L', 121, 3], + ['Z'], + ['M', 10, 3], + ['L', 121, 3], + ['L', 121, 1], + ['L', 10, 1], + ['L', 10, 3], + ['Z'], + ], + }, + { + type: 'rect', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -52, + top: -24.5, + width: 32, + height: 32, + fill: '#E80D0D', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + rx: 2, + ry: 2, + selectable: true, + hasControls: true, + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -45.9945, + top: -17.6, + width: 19.8963, + height: 0, + fill: '', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 40.0018, 16], + ['L', 29.5301, 16], + ['L', 20.1055, 16], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -36.5727, + top: -17.6, + width: 0, + height: 8.8419, + fill: '', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 29.5273, 24.8419], + ['L', 29.5273, 16], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -46.1, + top: -10.5375, + width: 18.5869, + height: 10.9372, + fill: 'white', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 21.8972, 23.0625], + ['L', 38.5869, 27.5048], + ['L', 37.6746, 28.8773], + ['L', 35.579, 32.6272], + ['L', 34.6667, 33.9997], + ['L', 20, 30.0959], + ['L', 21.8972, 23.0625], + ['Z'], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -30.5219, + top: -4.7211, + width: 4.1186, + height: 4.5576, + fill: '', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 37.6737, 28.8789], + ['L', 39.6967, 29.4174], + ['L', 38.6126, 33.4365], + ['L', 35.5781, 32.6288], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -43.3008, + top: -7.6387, + width: 4.2123, + height: 4.181, + fill: '', + stroke: '#E80D0D', + strokeWidth: 0.5, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 26.6615, 27.7018], + ['C', 26.6615, 28.8548, 25.7201, 29.7923, 24.5554, 29.7923], + ['C', 23.3906, 29.7923, 22.4492, 28.8548, 22.4492, 27.7018], + ['C', 22.4492, 26.5488, 23.3906, 25.6113, 24.5554, 25.6113], + ['C', 25.7201, 25.6113, 26.6615, 26.5488, 26.6615, 27.7018], + ['Z'], + ], + }, +]; +export const watchIcon2: Record[] = [ + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -60, + top: -31.5, + width: 119, + height: 54, + fill: 'white', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'evenodd', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 10, 2], + ['C', 7.79086, 2, 6, 3.79086, 6, 6], + ['L', 6, 44], + ['C', 6, 46.2091, 7.79086, 48, 10, 48], + ['L', 58.8, 48], + ['L', 66, 56], + ['L', 73.2, 48], + ['L', 121, 48], + ['C', 123.209, 48, 125, 46.2091, 125, 44], + ['L', 125, 6], + ['C', 125, 3.79086, 123.209, 2, 121, 2], + ['L', 10, 2], + ['Z'], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -61, + top: -32.5, + width: 121, + height: 56.4948, + fill: 'rgba(21,77,221,0.2)', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 58.8, 48], + ['L', 59.5433, 47.331], + ['L', 59.2454, 47], + ['L', 58.8, 47], + ['L', 58.8, 48], + ['Z'], + ['M', 66, 56], + ['L', 65.2567, 56.669], + ['L', 66, 57.4948], + ['L', 66.7433, 56.669], + ['L', 66, 56], + ['Z'], + ['M', 73.2, 48], + ['L', 73.2, 47], + ['L', 72.7546, 47], + ['L', 72.4567, 47.331], + ['L', 73.2, 48], + ['Z'], + ['M', 7, 6], + ['C', 7, 4.34315, 8.34315, 3, 10, 3], + ['L', 10, 1], + ['C', 7.23858, 1, 5, 3.23857, 5, 6], + ['L', 7, 6], + ['Z'], + ['M', 7, 44], + ['L', 7, 6], + ['L', 5, 6], + ['L', 5, 44], + ['L', 7, 44], + ['Z'], + ['M', 10, 47], + ['C', 8.34315, 47, 7, 45.6569, 7, 44], + ['L', 5, 44], + ['C', 5, 46.7614, 7.23858, 49, 10, 49], + ['L', 10, 47], + ['Z'], + ['M', 58.8, 47], + ['L', 10, 47], + ['L', 10, 49], + ['L', 58.8, 49], + ['L', 58.8, 47], + ['Z'], + ['M', 58.0567, 48.669], + ['L', 65.2567, 56.669], + ['L', 66.7433, 55.331], + ['L', 59.5433, 47.331], + ['L', 58.0567, 48.669], + ['Z'], + ['M', 66.7433, 56.669], + ['L', 73.9433, 48.669], + ['L', 72.4567, 47.331], + ['L', 65.2567, 55.331], + ['L', 66.7433, 56.669], + ['Z'], + ['M', 121, 47], + ['L', 73.2, 47], + ['L', 73.2, 49], + ['L', 121, 49], + ['L', 121, 47], + ['Z'], + ['M', 124, 44], + ['C', 124, 45.6569, 122.657, 47, 121, 47], + ['L', 121, 49], + ['C', 123.761, 49, 126, 46.7614, 126, 44], + ['L', 124, 44], + ['Z'], + ['M', 124, 6], + ['L', 124, 44], + ['L', 126, 44], + ['L', 126, 6], + ['L', 124, 6], + ['Z'], + ['M', 121, 3], + ['C', 122.657, 3, 124, 4.34315, 124, 6], + ['L', 126, 6], + ['C', 126, 3.23858, 123.761, 1, 121, 1], + ['L', 121, 3], + ['Z'], + ['M', 10, 3], + ['L', 121, 3], + ['L', 121, 1], + ['L', 10, 1], + ['L', 10, 3], + ['Z'], + ], + }, + { + type: 'rect', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -52, + top: -24.5, + width: 32, + height: 32, + fill: '#52C41A', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + rx: 2, + ry: 2, + selectable: true, + hasControls: true, + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -45.9945, + top: -17.6, + width: 19.8963, + height: 0, + fill: '', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 40.0018, 16], + ['L', 29.5301, 16], + ['L', 20.1055, 16], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -36.5727, + top: -17.6, + width: 0, + height: 8.8419, + fill: '', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 29.5273, 24.8419], + ['L', 29.5273, 16], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -46.1, + top: -10.5375, + width: 18.5869, + height: 10.9372, + fill: 'white', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 21.8972, 23.0625], + ['L', 38.5869, 27.5048], + ['L', 37.6746, 28.8773], + ['L', 35.579, 32.6272], + ['L', 34.6667, 33.9997], + ['L', 20, 30.0959], + ['L', 21.8972, 23.0625], + ['Z'], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -30.5219, + top: -4.7211, + width: 4.1186, + height: 4.5576, + fill: '', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 37.6737, 28.8789], + ['L', 39.6967, 29.4174], + ['L', 38.6126, 33.4365], + ['L', 35.5781, 32.6288], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -43.3008, + top: -7.6387, + width: 4.2123, + height: 4.181, + fill: '', + stroke: '#52C41A', + strokeWidth: 0.5, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 26.6615, 27.7018], + ['C', 26.6615, 28.8548, 25.7201, 29.7923, 24.5554, 29.7923], + ['C', 23.3906, 29.7923, 22.4492, 28.8548, 22.4492, 27.7018], + ['C', 22.4492, 26.5488, 23.3906, 25.6113, 24.5554, 25.6113], + ['C', 25.7201, 25.6113, 26.6615, 26.5488, 26.6615, 27.7018], + ['Z'], + ], + }, +]; +export const watchIcon3: Record[] = [ + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -60, + top: -31.5, + width: 119, + height: 54, + fill: 'white', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'evenodd', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 10, 2], + ['C', 7.79086, 2, 6, 3.79086, 6, 6], + ['L', 6, 44], + ['C', 6, 46.2091, 7.79086, 48, 10, 48], + ['L', 58.8, 48], + ['L', 66, 56], + ['L', 73.2, 48], + ['L', 121, 48], + ['C', 123.209, 48, 125, 46.2091, 125, 44], + ['L', 125, 6], + ['C', 125, 3.79086, 123.209, 2, 121, 2], + ['L', 10, 2], + ['Z'], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -61, + top: -32.5, + width: 121, + height: 56.4948, + fill: 'rgba(21,77,221,0.2)', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 58.8, 48], + ['L', 59.5433, 47.331], + ['L', 59.2454, 47], + ['L', 58.8, 47], + ['L', 58.8, 48], + ['Z'], + ['M', 66, 56], + ['L', 65.2567, 56.669], + ['L', 66, 57.4948], + ['L', 66.7433, 56.669], + ['L', 66, 56], + ['Z'], + ['M', 73.2, 48], + ['L', 73.2, 47], + ['L', 72.7546, 47], + ['L', 72.4567, 47.331], + ['L', 73.2, 48], + ['Z'], + ['M', 7, 6], + ['C', 7, 4.34315, 8.34315, 3, 10, 3], + ['L', 10, 1], + ['C', 7.23858, 1, 5, 3.23857, 5, 6], + ['L', 7, 6], + ['Z'], + ['M', 7, 44], + ['L', 7, 6], + ['L', 5, 6], + ['L', 5, 44], + ['L', 7, 44], + ['Z'], + ['M', 10, 47], + ['C', 8.34315, 47, 7, 45.6569, 7, 44], + ['L', 5, 44], + ['C', 5, 46.7614, 7.23858, 49, 10, 49], + ['L', 10, 47], + ['Z'], + ['M', 58.8, 47], + ['L', 10, 47], + ['L', 10, 49], + ['L', 58.8, 49], + ['L', 58.8, 47], + ['Z'], + ['M', 58.0567, 48.669], + ['L', 65.2567, 56.669], + ['L', 66.7433, 55.331], + ['L', 59.5433, 47.331], + ['L', 58.0567, 48.669], + ['Z'], + ['M', 66.7433, 56.669], + ['L', 73.9433, 48.669], + ['L', 72.4567, 47.331], + ['L', 65.2567, 55.331], + ['L', 66.7433, 56.669], + ['Z'], + ['M', 121, 47], + ['L', 73.2, 47], + ['L', 73.2, 49], + ['L', 121, 49], + ['L', 121, 47], + ['Z'], + ['M', 124, 44], + ['C', 124, 45.6569, 122.657, 47, 121, 47], + ['L', 121, 49], + ['C', 123.761, 49, 126, 46.7614, 126, 44], + ['L', 124, 44], + ['Z'], + ['M', 124, 6], + ['L', 124, 44], + ['L', 126, 44], + ['L', 126, 6], + ['L', 124, 6], + ['Z'], + ['M', 121, 3], + ['C', 122.657, 3, 124, 4.34315, 124, 6], + ['L', 126, 6], + ['C', 126, 3.23858, 123.761, 1, 121, 1], + ['L', 121, 3], + ['Z'], + ['M', 10, 3], + ['L', 121, 3], + ['L', 121, 1], + ['L', 10, 1], + ['L', 10, 3], + ['Z'], + ], + }, + { + type: 'rect', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -52, + top: -24.5, + width: 32, + height: 32, + fill: '#CCCCCC', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + rx: 2, + ry: 2, + selectable: true, + hasControls: true, + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -45.9945, + top: -17.6, + width: 19.8963, + height: 0, + fill: '', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 40.0018, 16], + ['L', 29.5301, 16], + ['L', 20.1055, 16], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -36.5727, + top: -17.6, + width: 0, + height: 8.8419, + fill: '', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 29.5273, 24.8419], + ['L', 29.5273, 16], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -46.1, + top: -10.5375, + width: 18.5869, + height: 10.9372, + fill: 'white', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 21.8972, 23.0625], + ['L', 38.5869, 27.5048], + ['L', 37.6746, 28.8773], + ['L', 35.579, 32.6272], + ['L', 34.6667, 33.9997], + ['L', 20, 30.0959], + ['L', 21.8972, 23.0625], + ['Z'], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -30.5219, + top: -4.7211, + width: 4.1186, + height: 4.5576, + fill: '', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 37.6737, 28.8789], + ['L', 39.6967, 29.4174], + ['L', 38.6126, 33.4365], + ['L', 35.5781, 32.6288], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -43.3008, + top: -7.6387, + width: 4.2123, + height: 4.181, + fill: '', + stroke: '#CCCCCC', + strokeWidth: 0.5, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 26.6615, 27.7018], + ['C', 26.6615, 28.8548, 25.7201, 29.7923, 24.5554, 29.7923], + ['C', 23.3906, 29.7923, 22.4492, 28.8548, 22.4492, 27.7018], + ['C', 22.4492, 26.5488, 23.3906, 25.6113, 24.5554, 25.6113], + ['C', 25.7201, 25.6113, 26.6615, 26.5488, 26.6615, 27.7018], + ['Z'], + ], + }, +]; +export const watchIcon4: Record[] = [ + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -60, + top: -31.5, + width: 119, + height: 54, + fill: 'white', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'evenodd', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 10, 2], + ['C', 7.79086, 2, 6, 3.79086, 6, 6], + ['L', 6, 44], + ['C', 6, 46.2091, 7.79086, 48, 10, 48], + ['L', 58.8, 48], + ['L', 66, 56], + ['L', 73.2, 48], + ['L', 121, 48], + ['C', 123.209, 48, 125, 46.2091, 125, 44], + ['L', 125, 6], + ['C', 125, 3.79086, 123.209, 2, 121, 2], + ['L', 10, 2], + ['Z'], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -61, + top: -32.5, + width: 121, + height: 56.4948, + fill: 'rgba(21,77,221,0.2)', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 58.8, 48], + ['L', 59.5433, 47.331], + ['L', 59.2454, 47], + ['L', 58.8, 47], + ['L', 58.8, 48], + ['Z'], + ['M', 66, 56], + ['L', 65.2567, 56.669], + ['L', 66, 57.4948], + ['L', 66.7433, 56.669], + ['L', 66, 56], + ['Z'], + ['M', 73.2, 48], + ['L', 73.2, 47], + ['L', 72.7546, 47], + ['L', 72.4567, 47.331], + ['L', 73.2, 48], + ['Z'], + ['M', 7, 6], + ['C', 7, 4.34315, 8.34315, 3, 10, 3], + ['L', 10, 1], + ['C', 7.23858, 1, 5, 3.23857, 5, 6], + ['L', 7, 6], + ['Z'], + ['M', 7, 44], + ['L', 7, 6], + ['L', 5, 6], + ['L', 5, 44], + ['L', 7, 44], + ['Z'], + ['M', 10, 47], + ['C', 8.34315, 47, 7, 45.6569, 7, 44], + ['L', 5, 44], + ['C', 5, 46.7614, 7.23858, 49, 10, 49], + ['L', 10, 47], + ['Z'], + ['M', 58.8, 47], + ['L', 10, 47], + ['L', 10, 49], + ['L', 58.8, 49], + ['L', 58.8, 47], + ['Z'], + ['M', 58.0567, 48.669], + ['L', 65.2567, 56.669], + ['L', 66.7433, 55.331], + ['L', 59.5433, 47.331], + ['L', 58.0567, 48.669], + ['Z'], + ['M', 66.7433, 56.669], + ['L', 73.9433, 48.669], + ['L', 72.4567, 47.331], + ['L', 65.2567, 55.331], + ['L', 66.7433, 56.669], + ['Z'], + ['M', 121, 47], + ['L', 73.2, 47], + ['L', 73.2, 49], + ['L', 121, 49], + ['L', 121, 47], + ['Z'], + ['M', 124, 44], + ['C', 124, 45.6569, 122.657, 47, 121, 47], + ['L', 121, 49], + ['C', 123.761, 49, 126, 46.7614, 126, 44], + ['L', 124, 44], + ['Z'], + ['M', 124, 6], + ['L', 124, 44], + ['L', 126, 44], + ['L', 126, 6], + ['L', 124, 6], + ['Z'], + ['M', 121, 3], + ['C', 122.657, 3, 124, 4.34315, 124, 6], + ['L', 126, 6], + ['C', 126, 3.23858, 123.761, 1, 121, 1], + ['L', 121, 3], + ['Z'], + ['M', 10, 3], + ['L', 121, 3], + ['L', 121, 1], + ['L', 10, 1], + ['L', 10, 3], + ['Z'], + ], + }, + { + type: 'rect', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -52, + top: -24.5, + width: 32, + height: 32, + fill: '#FAAD14', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + rx: 2, + ry: 2, + selectable: true, + hasControls: true, + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -45.9945, + top: -17.6, + width: 19.8963, + height: 0, + fill: '', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 40.0018, 16], + ['L', 29.5301, 16], + ['L', 20.1055, 16], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -36.5727, + top: -17.6, + width: 0, + height: 8.8419, + fill: '', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 29.5273, 24.8419], + ['L', 29.5273, 16], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -46.1, + top: -10.5375, + width: 18.5869, + height: 10.9372, + fill: 'white', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 21.8972, 23.0625], + ['L', 38.5869, 27.5048], + ['L', 37.6746, 28.8773], + ['L', 35.579, 32.6272], + ['L', 34.6667, 33.9997], + ['L', 20, 30.0959], + ['L', 21.8972, 23.0625], + ['Z'], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -30.5219, + top: -4.7211, + width: 4.1186, + height: 4.5576, + fill: '', + stroke: 'white', + strokeWidth: 1.2, + strokeDashArray: null, + strokeLineCap: 'round', + strokeDashOffset: 0, + strokeLineJoin: 'round', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 37.6737, 28.8789], + ['L', 39.6967, 29.4174], + ['L', 38.6126, 33.4365], + ['L', 35.5781, 32.6288], + ], + }, + { + type: 'path', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -43.3008, + top: -7.6387, + width: 4.2123, + height: 4.181, + fill: '', + stroke: '#FAAD14', + strokeWidth: 0.5, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + path: [ + ['M', 26.6615, 27.7018], + ['C', 26.6615, 28.8548, 25.7201, 29.7923, 24.5554, 29.7923], + ['C', 23.3906, 29.7923, 22.4492, 28.8548, 22.4492, 27.7018], + ['C', 22.4492, 26.5488, 23.3906, 25.6113, 24.5554, 25.6113], + ['C', 25.7201, 25.6113, 26.6615, 26.5488, 26.6615, 27.7018], + ['Z'], + ], + }, +]; + + +export const fetchWatchGroupObjects: Record = (record: { + status: string; + deviceName: string; +}) => { + const { status, deviceName } = record; + let watchIconObject = watchIcon1; + switch (status) { + case 'watchError': + watchIconObject = watchIcon1; + break; + case 'watchOnline': + watchIconObject = watchIcon2; + break; + case 'watchOutline': + watchIconObject = watchIcon3; + break; + case 'watchWarn': + watchIconObject = watchIcon4; + break; + } + console.log(deviceName, 'deviceName'); + return { + type: 'group', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: 20.9866, + top: 16.4716, + width: 131, + height: 66, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: null, + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + id: '160e5a54-0126-473e-908a-5f74a2a8a14a', + selectable: true, + hasControls: true, + objects: [ + { + type: 'group', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -65.5, + top: -33, + width: 131, + height: 66, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 0, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + selectable: true, + hasControls: true, + objects: watchIconObject, + }, + { + type: 'textbox', + version: '5.3.0', + originX: 'left', + originY: 'top', + left: -15.709, + top: -15.0177, + width: 67.6873, + height: 13.56, + fill: 'rgb(0,0,0)', + stroke: null, + strokeWidth: 1, + strokeDashArray: null, + strokeLineCap: 'butt', + strokeDashOffset: 0, + strokeLineJoin: 'miter', + strokeUniform: false, + strokeMiterLimit: 4, + scaleX: 1, + scaleY: 1, + angle: 0, + flipX: false, + flipY: false, + opacity: 1, + shadow: '', + visible: true, + backgroundColor: '', + fillRule: 'nonzero', + paintFirst: 'fill', + globalCompositeOperation: 'source-over', + skewX: 0, + skewY: 0, + fontFamily: 'arial', + fontWeight: 'normal', + fontSize: 14, + text: deviceName, + underline: false, + overline: false, + linethrough: false, + textAlign: 'left', + fontStyle: 'normal', + lineHeight: 1.16, + textBackgroundColor: '', + charSpacing: 0, + styles: [], + direction: 'ltr', + path: null, + pathStartOffset: 0, + pathSide: 'left', + pathAlign: 'baseline', + minWidth: 20, + splitByGrapheme: true, + selectable: true, + hasControls: true, + }, + ], + }; +};