light-chaser-pro 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.trae/.ignore +1 -0
- package/LICENSE +21 -0
- package/README.md +99 -0
- package/UI_DESIGN_SPEC.md +130 -0
- package/deploy.bat +98 -0
- package/doc//344/277/256/345/244/215/347/224/273/345/270/203/350/207/252/351/200/202/345/272/224bug/350/203/214/345/220/216/347/232/204/347/220/206/350/256/272/347/237/245/350/257/206.md +291 -0
- package/light-chaser-app/.dockerignore +6 -0
- package/light-chaser-app/.eslintrc.cjs +19 -0
- package/light-chaser-app/Dockerfile +40 -0
- package/light-chaser-app/command.md +23 -0
- package/light-chaser-app/index.html +30 -0
- package/light-chaser-app/nginx.conf +31 -0
- package/light-chaser-app/package.json +74 -0
- package/light-chaser-app/public/favicon.ico +0 -0
- package/light-chaser-app/release.html +38 -0
- package/light-chaser-app/src/api/ReponseHandler.ts +49 -0
- package/light-chaser-app/src/api/RoleApi.ts +28 -0
- package/light-chaser-app/src/api/engineering/AbstractApi.ts +75 -0
- package/light-chaser-app/src/api/engineering/ApiManager.ts +26 -0
- package/light-chaser-app/src/api/engineering/BaseApi.ts +131 -0
- package/light-chaser-app/src/api/engineering/PureShowApi.ts +28 -0
- package/light-chaser-app/src/comps/antd/area-base/AntdBaseAreaConfig.tsx +269 -0
- package/light-chaser-app/src/comps/antd/area-base/AntdBaseAreaDefinition.ts +232 -0
- package/light-chaser-app/src/comps/antd/area-base/base-area.png +0 -0
- package/light-chaser-app/src/comps/antd/area-percent/AntdPercentAreaDefinition.ts +241 -0
- package/light-chaser-app/src/comps/antd/area-percent/percent-area.png +0 -0
- package/light-chaser-app/src/comps/antd/area-stack/AntdStackAreaDefinition.ts +212 -0
- package/light-chaser-app/src/comps/antd/area-stack/stack-area.png +0 -0
- package/light-chaser-app/src/comps/antd/bar-base/AntdBaseBarDefinition.ts +134 -0
- package/light-chaser-app/src/comps/antd/bar-base/base-bar.png +0 -0
- package/light-chaser-app/src/comps/antd/bar-group/AntdGroupBarDefinition.ts +160 -0
- package/light-chaser-app/src/comps/antd/bar-group/group-bar.png +0 -0
- package/light-chaser-app/src/comps/antd/bar-percent/AntdPercentBarController.ts +21 -0
- package/light-chaser-app/src/comps/antd/bar-percent/AntdPercentBarDefinition.ts +167 -0
- package/light-chaser-app/src/comps/antd/bar-percent/percent-bar.png +0 -0
- package/light-chaser-app/src/comps/antd/bar-range/AntdRangeBarDefinition.ts +180 -0
- package/light-chaser-app/src/comps/antd/bar-range/range-bar.png +0 -0
- package/light-chaser-app/src/comps/antd/bar-stack/AntdStackBarDefinition.ts +144 -0
- package/light-chaser-app/src/comps/antd/bar-stack/stack-bar.png +0 -0
- package/light-chaser-app/src/comps/antd/column-base/AntdBaseColumnDefinition.ts +144 -0
- package/light-chaser-app/src/comps/antd/column-base/base-column.png +0 -0
- package/light-chaser-app/src/comps/antd/column-group/AntdGroupColumnDefinition.ts +154 -0
- package/light-chaser-app/src/comps/antd/column-group/group-column.png +0 -0
- package/light-chaser-app/src/comps/antd/column-percent/AntdPercentColumnDefinition.ts +168 -0
- package/light-chaser-app/src/comps/antd/column-percent/percent-column.png +0 -0
- package/light-chaser-app/src/comps/antd/column-range/AntdRangeColumnDefinition.ts +178 -0
- package/light-chaser-app/src/comps/antd/column-range/range-column.png +0 -0
- package/light-chaser-app/src/comps/antd/column-stack/AntdStackColumnDefinition.ts +152 -0
- package/light-chaser-app/src/comps/antd/column-stack/stack-column.png +0 -0
- package/light-chaser-app/src/comps/antd/g2plot-custom/G2PlotCustomConfig.tsx +80 -0
- package/light-chaser-app/src/comps/antd/g2plot-custom/G2PlotCustomController.ts +83 -0
- package/light-chaser-app/src/comps/antd/g2plot-custom/G2PlotCustomDefinition.ts +160 -0
- package/light-chaser-app/src/comps/antd/g2plot-custom/g2-plot-custom.png +0 -0
- package/light-chaser-app/src/comps/antd/gauge/AntdGaugeConfig.tsx +423 -0
- package/light-chaser-app/src/comps/antd/gauge/AntdGaugeController.ts +110 -0
- package/light-chaser-app/src/comps/antd/gauge/AntdGaugeDefinition.ts +162 -0
- package/light-chaser-app/src/comps/antd/gauge/gauge.png +0 -0
- package/light-chaser-app/src/comps/antd/line-base/AntdBaseLineDefinition.ts +147 -0
- package/light-chaser-app/src/comps/antd/line-base/base-line.png +0 -0
- package/light-chaser-app/src/comps/antd/line-multi/AntdMultiLineConfig.tsx +241 -0
- package/light-chaser-app/src/comps/antd/line-multi/AntdMultiLineDefinition.ts +244 -0
- package/light-chaser-app/src/comps/antd/line-multi/multi-line.png +0 -0
- package/light-chaser-app/src/comps/antd/line-step/AntdStepLineDefinition.ts +171 -0
- package/light-chaser-app/src/comps/antd/line-step/step-line.png +0 -0
- package/light-chaser-app/src/comps/antd/liquid/AntdLiquidConfig.tsx +338 -0
- package/light-chaser-app/src/comps/antd/liquid/AntdLiquidController.ts +106 -0
- package/light-chaser-app/src/comps/antd/liquid/AntdLiquidDefinition.ts +152 -0
- package/light-chaser-app/src/comps/antd/liquid/liquid.png +0 -0
- package/light-chaser-app/src/comps/antd/pie/AntdPieController.ts +74 -0
- package/light-chaser-app/src/comps/antd/pie/AntdPieDefinition.ts +165 -0
- package/light-chaser-app/src/comps/antd/pie/AntdPieStyleConfig.tsx +528 -0
- package/light-chaser-app/src/comps/antd/pie/pie.png +0 -0
- package/light-chaser-app/src/comps/antd/radar/AntdRadarController.ts +110 -0
- package/light-chaser-app/src/comps/antd/radar/AntdRadarDefinition.ts +187 -0
- package/light-chaser-app/src/comps/antd/radar/AntdRadarStyleConfig.tsx +270 -0
- package/light-chaser-app/src/comps/antd/radar/radar.png +0 -0
- package/light-chaser-app/src/comps/antd/radial-bar-base/AntdBaseRadialBarController.ts +79 -0
- package/light-chaser-app/src/comps/antd/radial-bar-base/AntdBaseRadialBarDefinition.ts +124 -0
- package/light-chaser-app/src/comps/antd/radial-bar-base/AntdBaseRadialBarStyleConfig.tsx +275 -0
- package/light-chaser-app/src/comps/antd/radial-bar-base/base-radial-bar.png +0 -0
- package/light-chaser-app/src/comps/antd/ring-progress/AntdRingProgressConfig.tsx +334 -0
- package/light-chaser-app/src/comps/antd/ring-progress/AntdRingProgressController.ts +85 -0
- package/light-chaser-app/src/comps/antd/ring-progress/AntdRingProgressDefinition.ts +138 -0
- package/light-chaser-app/src/comps/antd/ring-progress/ring-progress.png +0 -0
- package/light-chaser-app/src/comps/antd/rose-base/AntdBaseRoseDefinition.ts +102 -0
- package/light-chaser-app/src/comps/antd/rose-base/base-rose.png +0 -0
- package/light-chaser-app/src/comps/antd/rose-group/AntdGroupRoseDefinition.ts +127 -0
- package/light-chaser-app/src/comps/antd/rose-group/group-rose.png +0 -0
- package/light-chaser-app/src/comps/antd/rose-stack/AntdStackRoseDefinition.ts +142 -0
- package/light-chaser-app/src/comps/antd/rose-stack/stack-rose.png +0 -0
- package/light-chaser-app/src/comps/antd/scatter-bubble/AntdScatterBubbleDefinition.ts +192 -0
- package/light-chaser-app/src/comps/antd/scatter-bubble/scatter-bubble.png +0 -0
- package/light-chaser-app/src/comps/antd/scatter-point/AntdScatterPointDefinition.ts +143 -0
- package/light-chaser-app/src/comps/antd/scatter-point/scatter-point.png +0 -0
- package/light-chaser-app/src/comps/antd/word-cloud/AntdWordCloudConfig.tsx +167 -0
- package/light-chaser-app/src/comps/antd/word-cloud/AntdWordCloudController.ts +75 -0
- package/light-chaser-app/src/comps/antd/word-cloud/AntdWordCloudDefinition.ts +198 -0
- package/light-chaser-app/src/comps/antd/word-cloud/word-cloud.png +0 -0
- package/light-chaser-app/src/comps/antd-common/AntdBaseDesignerController.ts +96 -0
- package/light-chaser-app/src/comps/antd-common/AntdCommonDefinition.ts +51 -0
- package/light-chaser-app/src/comps/antd-common/AntdCommonUtil.ts +27 -0
- package/light-chaser-app/src/comps/antd-common/area/AbstractAreaDefinition.ts +53 -0
- package/light-chaser-app/src/comps/antd-common/area/AntdAreaCommonConfig.tsx +276 -0
- package/light-chaser-app/src/comps/antd-common/area/AntdCommonAreaController.ts +108 -0
- package/light-chaser-app/src/comps/antd-common/bar/AbstractBarDefinition.ts +52 -0
- package/light-chaser-app/src/comps/antd-common/bar/AntdBarCommonConfig.tsx +177 -0
- package/light-chaser-app/src/comps/antd-common/bar/AntdCommonBarController.ts +98 -0
- package/light-chaser-app/src/comps/antd-common/column/AbstractColumnDefinition.ts +51 -0
- package/light-chaser-app/src/comps/antd-common/column/AntdColumnCommonConfig.tsx +185 -0
- package/light-chaser-app/src/comps/antd-common/column/AntdCommonColumnController.ts +99 -0
- package/light-chaser-app/src/comps/antd-common/config/AntdFragment.tsx +40 -0
- package/light-chaser-app/src/comps/antd-common/config/axis/AxisConfig.tsx +555 -0
- package/light-chaser-app/src/comps/antd-common/config/legend/AntdLegend.tsx +279 -0
- package/light-chaser-app/src/comps/antd-common/config/legend/Legend.less +68 -0
- package/light-chaser-app/src/comps/antd-common/config/tooltip/G2Tooltip.tsx +62 -0
- package/light-chaser-app/src/comps/antd-common/line/AbstractLineDefinition.ts +53 -0
- package/light-chaser-app/src/comps/antd-common/line/AntdCommonLineController.ts +109 -0
- package/light-chaser-app/src/comps/antd-common/line/AntdLineCommonConfig.tsx +229 -0
- package/light-chaser-app/src/comps/antd-common/rose/AbstractRoseDefinition.ts +52 -0
- package/light-chaser-app/src/comps/antd-common/rose/AntdCommonRoseController.ts +67 -0
- package/light-chaser-app/src/comps/antd-common/rose/AntdRoseCommonConfig.tsx +279 -0
- package/light-chaser-app/src/comps/antd-common/scatter/AbstractScatterDefinition.ts +51 -0
- package/light-chaser-app/src/comps/antd-common/scatter/AntdCommonScatterController.ts +96 -0
- package/light-chaser-app/src/comps/antd-common/scatter/AntdScatterCommonConfig.tsx +210 -0
- package/light-chaser-app/src/comps/antd-common/types.ts +82 -0
- package/light-chaser-app/src/comps/antd-common/util/G2ColorUtil.ts +129 -0
- package/light-chaser-app/src/comps/common-component/animation-config/AnimationConfig.less +23 -0
- package/light-chaser-app/src/comps/common-component/animation-config/AnimationConfig.tsx +26 -0
- package/light-chaser-app/src/comps/common-component/base-info/BaseInfo.tsx +238 -0
- package/light-chaser-app/src/comps/common-component/base-info/BaseInfoStore.ts +36 -0
- package/light-chaser-app/src/comps/common-component/config-code/ConfigCode.tsx +62 -0
- package/light-chaser-app/src/comps/common-component/data-config/DataConfig.tsx +130 -0
- package/light-chaser-app/src/comps/common-component/data-source-config/ApiDataConfig.tsx +285 -0
- package/light-chaser-app/src/comps/common-component/data-source-config/CommonApiConfig.tsx +210 -0
- package/light-chaser-app/src/comps/common-component/data-source-config/DataSourceConfig.less +19 -0
- package/light-chaser-app/src/comps/common-component/data-source-config/DataSourceConfig.tsx +151 -0
- package/light-chaser-app/src/comps/common-component/data-source-config/DatabaseConfig.tsx +241 -0
- package/light-chaser-app/src/comps/common-component/data-source-config/GlobalVariableConfig.tsx +178 -0
- package/light-chaser-app/src/comps/common-component/data-source-config/MQTTConfig.tsx +311 -0
- package/light-chaser-app/src/comps/common-component/data-source-config/StaticDataConfig.tsx +156 -0
- package/light-chaser-app/src/comps/common-component/data-source-config/WebSocketConfig.tsx +183 -0
- package/light-chaser-app/src/comps/common-component/filter-config/FilterConfig.less +18 -0
- package/light-chaser-app/src/comps/common-component/filter-config/FilterConfig.tsx +175 -0
- package/light-chaser-app/src/comps/common-component/floating-modal/FloatingModal.less +116 -0
- package/light-chaser-app/src/comps/common-component/floating-modal/FloatingModal.tsx +166 -0
- package/light-chaser-app/src/comps/common-component/schema-fragment/SchemaFragment.ts +137 -0
- package/light-chaser-app/src/comps/common-component/theme-config/ThemeConfig.tsx +57 -0
- package/light-chaser-app/src/comps/common-component/theme-config/theme-editor/ThemeEditor.less +189 -0
- package/light-chaser-app/src/comps/common-component/theme-config/theme-editor/ThemeEditor.tsx +199 -0
- package/light-chaser-app/src/comps/common-component/theme-config/theme-item/ColorPreviewItem.less +16 -0
- package/light-chaser-app/src/comps/common-component/theme-config/theme-item/ColorPreviewItem.tsx +16 -0
- package/light-chaser-app/src/comps/common-component/theme-config/theme-item/ThemeItem.less +82 -0
- package/light-chaser-app/src/comps/common-component/theme-config/theme-item/ThemeItem.tsx +66 -0
- package/light-chaser-app/src/comps/common-component/theme-config/theme-list/ThemeList.tsx +66 -0
- package/light-chaser-app/src/comps/echarts/EChartsConfig.tsx +80 -0
- package/light-chaser-app/src/comps/echarts/EChartsController.ts +121 -0
- package/light-chaser-app/src/comps/echarts/EChartsCustomDataUpdateConfig.tsx +80 -0
- package/light-chaser-app/src/comps/echarts/EChartsDefinition.ts +186 -0
- package/light-chaser-app/src/comps/echarts/echarts.png +0 -0
- package/light-chaser-app/src/comps/group-layer/GroupLayer.tsx +90 -0
- package/light-chaser-app/src/comps/group-layer/GroupLayerController.ts +64 -0
- package/light-chaser-app/src/comps/group-layer/GroupLayerDefinition.ts +95 -0
- package/light-chaser-app/src/comps/lc/base-button/BaseButtonComponent.less +105 -0
- package/light-chaser-app/src/comps/lc/base-button/BaseButtonComponent.tsx +81 -0
- package/light-chaser-app/src/comps/lc/base-button/BaseButtonConfig.tsx +186 -0
- package/light-chaser-app/src/comps/lc/base-button/BaseButtonController.ts +75 -0
- package/light-chaser-app/src/comps/lc/base-button/BaseButtonDefinition.ts +112 -0
- package/light-chaser-app/src/comps/lc/base-button/base-button.png +0 -0
- package/light-chaser-app/src/comps/lc/base-color-block/BaseColorBlockComponent.tsx +65 -0
- package/light-chaser-app/src/comps/lc/base-color-block/BaseColorBlockConfig.tsx +97 -0
- package/light-chaser-app/src/comps/lc/base-color-block/BaseColorBlockController.ts +69 -0
- package/light-chaser-app/src/comps/lc/base-color-block/BaseColorBlockDefinition.ts +95 -0
- package/light-chaser-app/src/comps/lc/base-color-block/base-color-block.png +0 -0
- package/light-chaser-app/src/comps/lc/base-iframe/BaseIframeComponent.tsx +65 -0
- package/light-chaser-app/src/comps/lc/base-iframe/BaseIframeConfig.tsx +45 -0
- package/light-chaser-app/src/comps/lc/base-iframe/BaseIframeController.ts +57 -0
- package/light-chaser-app/src/comps/lc/base-iframe/BaseIframeDefinition.ts +77 -0
- package/light-chaser-app/src/comps/lc/base-iframe/base-iframe.png +0 -0
- package/light-chaser-app/src/comps/lc/base-image/BaseImageComponent.tsx +86 -0
- package/light-chaser-app/src/comps/lc/base-image/BaseImageConfig.tsx +100 -0
- package/light-chaser-app/src/comps/lc/base-image/BaseImageController.ts +72 -0
- package/light-chaser-app/src/comps/lc/base-image/BaseImageDefinition.ts +89 -0
- package/light-chaser-app/src/comps/lc/base-image/baseImage.png +0 -0
- package/light-chaser-app/src/comps/lc/base-input/BaseInputComponent.less +44 -0
- package/light-chaser-app/src/comps/lc/base-input/BaseInputComponent.tsx +92 -0
- package/light-chaser-app/src/comps/lc/base-input/BaseInputConfig.tsx +173 -0
- package/light-chaser-app/src/comps/lc/base-input/BaseInputController.ts +77 -0
- package/light-chaser-app/src/comps/lc/base-input/BaseInputDefinition.ts +114 -0
- package/light-chaser-app/src/comps/lc/base-input/base-input.png +0 -0
- package/light-chaser-app/src/comps/lc/base-select/BaseSelectComponent.less +17 -0
- package/light-chaser-app/src/comps/lc/base-select/BaseSelectComponent.tsx +91 -0
- package/light-chaser-app/src/comps/lc/base-select/BaseSelectConfig.tsx +182 -0
- package/light-chaser-app/src/comps/lc/base-select/BaseSelectController.ts +92 -0
- package/light-chaser-app/src/comps/lc/base-select/BaseSelectDefinition.ts +116 -0
- package/light-chaser-app/src/comps/lc/base-select/base-select.png +0 -0
- package/light-chaser-app/src/comps/lc/base-switch/BaseSwitchComponent.less +9 -0
- package/light-chaser-app/src/comps/lc/base-switch/BaseSwitchComponent.tsx +190 -0
- package/light-chaser-app/src/comps/lc/base-switch/BaseSwitchController.ts +104 -0
- package/light-chaser-app/src/comps/lc/base-switch/BaseSwitchDefinition.ts +134 -0
- package/light-chaser-app/src/comps/lc/base-switch/BaseSwitchStyleConfig.tsx +187 -0
- package/light-chaser-app/src/comps/lc/base-switch/base-switch.png +0 -0
- package/light-chaser-app/src/comps/lc/base-tab/BaseTabComponent.less +90 -0
- package/light-chaser-app/src/comps/lc/base-tab/BaseTabComponent.tsx +240 -0
- package/light-chaser-app/src/comps/lc/base-tab/BaseTabController.ts +112 -0
- package/light-chaser-app/src/comps/lc/base-tab/BaseTabDefinition.ts +137 -0
- package/light-chaser-app/src/comps/lc/base-tab/BaseTabStyleConfig.tsx +278 -0
- package/light-chaser-app/src/comps/lc/base-tab/tab.jpg +0 -0
- package/light-chaser-app/src/comps/lc/base-table/BaseTableComponent.less +55 -0
- package/light-chaser-app/src/comps/lc/base-table/BaseTableComponent.tsx +214 -0
- package/light-chaser-app/src/comps/lc/base-table/BaseTableConfig.tsx +252 -0
- package/light-chaser-app/src/comps/lc/base-table/BaseTableController.ts +72 -0
- package/light-chaser-app/src/comps/lc/base-table/BaseTableDefinition.ts +185 -0
- package/light-chaser-app/src/comps/lc/base-table/base-table.png +0 -0
- package/light-chaser-app/src/comps/lc/base-text/BaseTextComponent.less +57 -0
- package/light-chaser-app/src/comps/lc/base-text/BaseTextComponent.tsx +124 -0
- package/light-chaser-app/src/comps/lc/base-text/BaseTextConfig.tsx +255 -0
- package/light-chaser-app/src/comps/lc/base-text/BaseTextController.ts +79 -0
- package/light-chaser-app/src/comps/lc/base-text/BaseTextDefinition.ts +102 -0
- package/light-chaser-app/src/comps/lc/base-text/base-text.png +0 -0
- package/light-chaser-app/src/comps/lc/base-video/BaseVideoComponent.tsx +64 -0
- package/light-chaser-app/src/comps/lc/base-video/BaseVideoConfig.tsx +43 -0
- package/light-chaser-app/src/comps/lc/base-video/BaseVideoController.ts +68 -0
- package/light-chaser-app/src/comps/lc/base-video/BaseVideoDefinition.ts +86 -0
- package/light-chaser-app/src/comps/lc/base-video/baseVideo.png +0 -0
- package/light-chaser-app/src/comps/lc/carousel/CarouselComponent.less +17 -0
- package/light-chaser-app/src/comps/lc/carousel/CarouselComponent.tsx +80 -0
- package/light-chaser-app/src/comps/lc/carousel/CarouselConfig.tsx +69 -0
- package/light-chaser-app/src/comps/lc/carousel/CarouselController.ts +62 -0
- package/light-chaser-app/src/comps/lc/carousel/CarouselDefinition.ts +91 -0
- package/light-chaser-app/src/comps/lc/carousel/carousel.png +0 -0
- package/light-chaser-app/src/comps/lc/date-time/DateTimeComponent.less +16 -0
- package/light-chaser-app/src/comps/lc/date-time/DateTimeComponent.tsx +106 -0
- package/light-chaser-app/src/comps/lc/date-time/DateTimeConfig.tsx +163 -0
- package/light-chaser-app/src/comps/lc/date-time/DateTimeController.ts +70 -0
- package/light-chaser-app/src/comps/lc/date-time/DateTimeDefinition.ts +93 -0
- package/light-chaser-app/src/comps/lc/date-time/date-time.png +0 -0
- package/light-chaser-app/src/comps/lc/date-time-picker/DateTimePickerComponent.less +15 -0
- package/light-chaser-app/src/comps/lc/date-time-picker/DateTimePickerComponent.tsx +259 -0
- package/light-chaser-app/src/comps/lc/date-time-picker/DateTimePickerConfig.tsx +219 -0
- package/light-chaser-app/src/comps/lc/date-time-picker/DateTimePickerController.ts +114 -0
- package/light-chaser-app/src/comps/lc/date-time-picker/DateTimePickerDefinition.ts +170 -0
- package/light-chaser-app/src/comps/lc/date-time-picker/datetime-picker.jpg +0 -0
- package/light-chaser-app/src/comps/lc/digital-flipper/DigitalFlipperComponent.tsx +106 -0
- package/light-chaser-app/src/comps/lc/digital-flipper/DigitalFlipperConfig.tsx +197 -0
- package/light-chaser-app/src/comps/lc/digital-flipper/DigitalFlipperController.ts +76 -0
- package/light-chaser-app/src/comps/lc/digital-flipper/DigitalFlipperDefinition.ts +99 -0
- package/light-chaser-app/src/comps/lc/digital-flipper/digital-flipper.png +0 -0
- package/light-chaser-app/src/comps/lc/flv-player/FlvPlayerComponent.tsx +89 -0
- package/light-chaser-app/src/comps/lc/flv-player/FlvPlayerConfig.tsx +44 -0
- package/light-chaser-app/src/comps/lc/flv-player/FlvPlayerController.ts +56 -0
- package/light-chaser-app/src/comps/lc/flv-player/FlvPlayerDefinition.ts +89 -0
- package/light-chaser-app/src/comps/lc/flv-player/flv-player.png +0 -0
- package/light-chaser-app/src/comps/lc/four-angle-glow-border/FourAngleGloeBorder.less +64 -0
- package/light-chaser-app/src/comps/lc/four-angle-glow-border/FourAngleGlowBorder.tsx +64 -0
- package/light-chaser-app/src/comps/lc/four-angle-glow-border/FourAngleGlowBorderConfig.tsx +67 -0
- package/light-chaser-app/src/comps/lc/four-angle-glow-border/FourAngleGlowBorderController.ts +71 -0
- package/light-chaser-app/src/comps/lc/four-angle-glow-border/FourAngleGlowBorderDefinition.ts +91 -0
- package/light-chaser-app/src/comps/lc/four-angle-glow-border/four-angle-glow-border.png +0 -0
- package/light-chaser-app/src/comps/lc/hls-player/HlsPlayerComponent.tsx +90 -0
- package/light-chaser-app/src/comps/lc/hls-player/HlsPlayerConfig.tsx +44 -0
- package/light-chaser-app/src/comps/lc/hls-player/HlsPlayerController.ts +51 -0
- package/light-chaser-app/src/comps/lc/hls-player/HlsPlayerDefinition.ts +89 -0
- package/light-chaser-app/src/comps/lc/hls-player/hls-player.png +0 -0
- package/light-chaser-app/src/comps/lc/screen-reference/ScreenReferenceComponent.tsx +144 -0
- package/light-chaser-app/src/comps/lc/screen-reference/ScreenReferenceConfig.tsx +63 -0
- package/light-chaser-app/src/comps/lc/screen-reference/ScreenReferenceController.ts +55 -0
- package/light-chaser-app/src/comps/lc/screen-reference/ScreenReferenceDefinition.ts +89 -0
- package/light-chaser-app/src/comps/lc/screen-reference/screen-reference.png +0 -0
- package/light-chaser-app/src/comps/lc/text-scroller/TextScrollerComponent.less +41 -0
- package/light-chaser-app/src/comps/lc/text-scroller/TextScrollerComponent.tsx +82 -0
- package/light-chaser-app/src/comps/lc/text-scroller/TextScrollerConfig.tsx +115 -0
- package/light-chaser-app/src/comps/lc/text-scroller/TextScrollerController.ts +71 -0
- package/light-chaser-app/src/comps/lc/text-scroller/TextScrollerDefinition.ts +89 -0
- package/light-chaser-app/src/comps/lc/text-scroller/text-scroller.png +0 -0
- package/light-chaser-app/src/comps/loop-container/LoopContainer.less +26 -0
- package/light-chaser-app/src/comps/loop-container/LoopContainer.tsx +69 -0
- package/light-chaser-app/src/comps/loop-container/LoopContainerConfig.tsx +84 -0
- package/light-chaser-app/src/comps/loop-container/LoopContainerController.ts +115 -0
- package/light-chaser-app/src/comps/loop-container/LoopContainerDefinition.ts +127 -0
- package/light-chaser-app/src/comps/map/AMapComponent.less +27 -0
- package/light-chaser-app/src/comps/map/AMapComponent.tsx +79 -0
- package/light-chaser-app/src/comps/map/AMapConfig.tsx +103 -0
- package/light-chaser-app/src/comps/map/AMapController.ts +57 -0
- package/light-chaser-app/src/comps/map/AMapDefinition.ts +104 -0
- package/light-chaser-app/src/comps/map/AMapScaleObserver.ts +44 -0
- package/light-chaser-app/src/comps/map/MapLoader.ts +61 -0
- package/light-chaser-app/src/comps/map/a-map.d.ts +22 -0
- package/light-chaser-app/src/comps/map/a-map.png +0 -0
- package/light-chaser-app/src/constant/GlobalConstant.ts +17 -0
- package/light-chaser-app/src/designer/Designer.tsx +146 -0
- package/light-chaser-app/src/designer/blueprint/BPCanvas.less +24 -0
- package/light-chaser-app/src/designer/blueprint/BPCanvas.tsx +79 -0
- package/light-chaser-app/src/designer/blueprint/BluePrint.tsx +39 -0
- package/light-chaser-app/src/designer/blueprint/IBPTyps.ts +27 -0
- package/light-chaser-app/src/designer/blueprint/bp-context-menu/BpContextMenu.tsx +112 -0
- package/light-chaser-app/src/designer/blueprint/core/BPExecutor.ts +43 -0
- package/light-chaser-app/src/designer/blueprint/core/BPTask.ts +67 -0
- package/light-chaser-app/src/designer/blueprint/drag/BPMovable.tsx +89 -0
- package/light-chaser-app/src/designer/blueprint/drag/BPSelectable.tsx +75 -0
- package/light-chaser-app/src/designer/blueprint/footer/BPFooter.less +268 -0
- package/light-chaser-app/src/designer/blueprint/footer/BPFooter.tsx +172 -0
- package/light-chaser-app/src/designer/blueprint/header/BPHeader.less +41 -0
- package/light-chaser-app/src/designer/blueprint/header/BPHeader.tsx +31 -0
- package/light-chaser-app/src/designer/blueprint/left/BPLeft.less +262 -0
- package/light-chaser-app/src/designer/blueprint/left/BPLeft.tsx +245 -0
- package/light-chaser-app/src/designer/blueprint/left/BPLeftStore.ts +44 -0
- package/light-chaser-app/src/designer/blueprint/line/LineLayer.tsx +301 -0
- package/light-chaser-app/src/designer/blueprint/manager/BluePrintManager.ts +503 -0
- package/light-chaser-app/src/designer/blueprint/manager/BluePrintPageManager.ts +94 -0
- package/light-chaser-app/src/designer/blueprint/node/BPNode.less +154 -0
- package/light-chaser-app/src/designer/blueprint/node/BPNode.tsx +77 -0
- package/light-chaser-app/src/designer/blueprint/node/NodeLayer.tsx +43 -0
- package/light-chaser-app/src/designer/blueprint/node/core/AbstractBPNodeController.ts +48 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/condition/BPConditionNodeController.ts +108 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/condition/ConditionNodeConfig.tsx +39 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/global/BPGlobalNodeController.ts +67 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/global-variable/BPGlobalVariableNodeController.ts +92 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/layer/BPLayerNodeController.ts +95 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/logical-process/BPLogicalProcessNodeController.ts +102 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/logical-process/LogicalProcessNodeConfig.tsx +39 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/mqtt/BPMqttNodeController.ts +165 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/mqtt/MqttNodeConfig.tsx +33 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/popup-box/BPPopupBoxNodeController.ts +79 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/popup-box/ModalRenderUtil.tsx +181 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/popup-box/PopupBoxNodeConfig.tsx +84 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/timer/BPTimerNodeController.ts +73 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/timer/TimerNodeConfig.tsx +51 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/visible/BPVisibleNodeController.ts +93 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/visible/VisibleNodeConfig.tsx +60 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/websocket/BPWebSocketNodeController.ts +129 -0
- package/light-chaser-app/src/designer/blueprint/node/core/impl/websocket/WebSocketNodeConfig.tsx +33 -0
- package/light-chaser-app/src/designer/blueprint/node/core/node-container/BPNodeContainer.less +25 -0
- package/light-chaser-app/src/designer/blueprint/node/core/node-container/BPNodeContainer.tsx +87 -0
- package/light-chaser-app/src/designer/blueprint/right/BPRight.less +181 -0
- package/light-chaser-app/src/designer/blueprint/right/BPRight.tsx +66 -0
- package/light-chaser-app/src/designer/blueprint/right/BPRightStore.ts +34 -0
- package/light-chaser-app/src/designer/blueprint/util/BpCanvasUtil.ts +254 -0
- package/light-chaser-app/src/designer/blueprint/util/EventUtil.ts +60 -0
- package/light-chaser-app/src/designer/canvas/DesignerCanvas.tsx +73 -0
- package/light-chaser-app/src/designer/canvas/DesignerDragScaleContainer.tsx +77 -0
- package/light-chaser-app/src/designer/canvas/DesignerRuler.tsx +164 -0
- package/light-chaser-app/src/designer/event/ContextMenuStore.ts +71 -0
- package/light-chaser-app/src/designer/footer/DesignerFooter.less +110 -0
- package/light-chaser-app/src/designer/footer/DesignerFooter.tsx +125 -0
- package/light-chaser-app/src/designer/footer/FooterStore.ts +56 -0
- package/light-chaser-app/src/designer/footer/auto-save/AutoSaveManager.ts +130 -0
- package/light-chaser-app/src/designer/footer/auto-save/EnhanceFetch.ts +41 -0
- package/light-chaser-app/src/designer/footer/auto-save/RestoreLocalStorage.less +80 -0
- package/light-chaser-app/src/designer/footer/auto-save/RestoreLocalStorage.tsx +158 -0
- package/light-chaser-app/src/designer/footer/cover/CoverConfig.less +131 -0
- package/light-chaser-app/src/designer/footer/cover/CoverConfig.tsx +113 -0
- package/light-chaser-app/src/designer/footer/hotkey-des/HotKeyDes.less +63 -0
- package/light-chaser-app/src/designer/footer/hotkey-des/HotKeyDes.tsx +111 -0
- package/light-chaser-app/src/designer/header/DesignerHeader.less +132 -0
- package/light-chaser-app/src/designer/header/DesignerHeader.tsx +172 -0
- package/light-chaser-app/src/designer/header/DesignerHeaderStore.ts +30 -0
- package/light-chaser-app/src/designer/header/items/blue-print/BluePrintHdImpl.tsx +32 -0
- package/light-chaser-app/src/designer/header/items/canvas/CanvasHdConfigImpl.less +180 -0
- package/light-chaser-app/src/designer/header/items/canvas/CanvasHdConfigImpl.tsx +128 -0
- package/light-chaser-app/src/designer/header/items/canvas/CanvasManager.ts +55 -0
- package/light-chaser-app/src/designer/header/items/global-filter/GlobalFilterConfigImpl.tsx +42 -0
- package/light-chaser-app/src/designer/header/items/project/ProjectHdItemImpl.less +34 -0
- package/light-chaser-app/src/designer/header/items/project/ProjectHdItemImpl.tsx +64 -0
- package/light-chaser-app/src/designer/header/items/project/ProjectManager.ts +56 -0
- package/light-chaser-app/src/designer/header/items/release/ReleaseHdConfigImpl.less +205 -0
- package/light-chaser-app/src/designer/header/items/release/ReleaseHdConfigImpl.tsx +189 -0
- package/light-chaser-app/src/designer/header/items/theme/ThemeHdItem.less +161 -0
- package/light-chaser-app/src/designer/header/items/theme/ThemeHdItemImpl.tsx +76 -0
- package/light-chaser-app/src/designer/header/items/theme/ThemeManager.ts +81 -0
- package/light-chaser-app/src/designer/left/DesignerLeft.less +15 -0
- package/light-chaser-app/src/designer/left/DesignerLeft.tsx +55 -0
- package/light-chaser-app/src/designer/left/DesignerLeftStore.ts +40 -0
- package/light-chaser-app/src/designer/left/compoent-lib/ComponentCategorize.ts +135 -0
- package/light-chaser-app/src/designer/left/compoent-lib/ComponentList.less +129 -0
- package/light-chaser-app/src/designer/left/compoent-lib/ComponentList.tsx +89 -0
- package/light-chaser-app/src/designer/left/compoent-lib/ComponentListStore.ts +64 -0
- package/light-chaser-app/src/designer/left/compoent-lib/list/CompList.less +112 -0
- package/light-chaser-app/src/designer/left/compoent-lib/list/CompList.tsx +155 -0
- package/light-chaser-app/src/designer/left/designer-left-menus/LeftMenus.less +63 -0
- package/light-chaser-app/src/designer/left/designer-left-menus/LeftMenus.tsx +87 -0
- package/light-chaser-app/src/designer/left/filter-lilst/AddFilterDialog.tsx +76 -0
- package/light-chaser-app/src/designer/left/filter-lilst/FilterList.less +105 -0
- package/light-chaser-app/src/designer/left/filter-lilst/FilterList.tsx +65 -0
- package/light-chaser-app/src/designer/left/global-variable/GlobalVariable.less +231 -0
- package/light-chaser-app/src/designer/left/global-variable/GlobalVariable.ts +151 -0
- package/light-chaser-app/src/designer/left/global-variable/GlobalVariableEditPanel.tsx +79 -0
- package/light-chaser-app/src/designer/left/global-variable/GlobalVariableList.tsx +89 -0
- package/light-chaser-app/src/designer/left/global-variable/parse/ComponentDataGvParser.ts +298 -0
- package/light-chaser-app/src/designer/left/layer-list/CanvasRender.ts +69 -0
- package/light-chaser-app/src/designer/left/layer-list/DesignerRender.ts +70 -0
- package/light-chaser-app/src/designer/left/layer-list/LayerList.less +371 -0
- package/light-chaser-app/src/designer/left/layer-list/LayerList.tsx +129 -0
- package/light-chaser-app/src/designer/left/layer-list/LayerListStore.ts +197 -0
- package/light-chaser-app/src/designer/left/layer-list/LayerRender.ts +67 -0
- package/light-chaser-app/src/designer/left/layer-list/item/BaseLayer.tsx +125 -0
- package/light-chaser-app/src/designer/left/layer-list/item/LayerGroupItem.tsx +61 -0
- package/light-chaser-app/src/designer/left/layer-list/item/LayerItem.tsx +48 -0
- package/light-chaser-app/src/designer/left/layer-list/search-layer/SearchLayer.less +121 -0
- package/light-chaser-app/src/designer/left/layer-list/search-layer/SearchLayer.tsx +82 -0
- package/light-chaser-app/src/designer/left/layer-list/util/LayerUtil.ts +370 -0
- package/light-chaser-app/src/designer/left/source-list/SourceList.less +99 -0
- package/light-chaser-app/src/designer/left/source-list/SourceList.tsx +50 -0
- package/light-chaser-app/src/designer/left/source-list/image-source/ImageSource.less +139 -0
- package/light-chaser-app/src/designer/left/source-list/image-source/ImageSource.tsx +155 -0
- package/light-chaser-app/src/designer/left/sub-project/SubProject.less +200 -0
- package/light-chaser-app/src/designer/left/sub-project/SubProject.tsx +231 -0
- package/light-chaser-app/src/designer/left/template-lib/TemplateLib.less +226 -0
- package/light-chaser-app/src/designer/left/template-lib/TemplateLib.tsx +165 -0
- package/light-chaser-app/src/designer/loader/DesignerLoader.ts +334 -0
- package/light-chaser-app/src/designer/loader/EditDesignerLoader.ts +75 -0
- package/light-chaser-app/src/designer/loader/PureReleaseDesignerLoader.ts +123 -0
- package/light-chaser-app/src/designer/loader/ReleaseDesignerLoader.ts +129 -0
- package/light-chaser-app/src/designer/loader/ViewDesignerLoader.ts +57 -0
- package/light-chaser-app/src/designer/manager/DesignerManager.ts +96 -0
- package/light-chaser-app/src/designer/manager/FilterManager.ts +69 -0
- package/light-chaser-app/src/designer/manager/GlobalFilterManger.ts +69 -0
- package/light-chaser-app/src/designer/manager/GlobalVariableManager.ts +148 -0
- package/light-chaser-app/src/designer/manager/LayerManager.ts +170 -0
- package/light-chaser-app/src/designer/manager/ManagerStore.ts +93 -0
- package/light-chaser-app/src/designer/manager/core/AbstractManager.ts +18 -0
- package/light-chaser-app/src/designer/operate-provider/EventOperateStore.ts +150 -0
- package/light-chaser-app/src/designer/operate-provider/canvas-context-menu/CanvasContextMenu.tsx +204 -0
- package/light-chaser-app/src/designer/operate-provider/hot-key/HotKey.tsx +51 -0
- package/light-chaser-app/src/designer/operate-provider/hot-key/HotKeyConfig.ts +226 -0
- package/light-chaser-app/src/designer/operate-provider/hot-key/HotKeyImpl.ts +871 -0
- package/light-chaser-app/src/designer/operate-provider/hot-key/HotKeyType.ts +29 -0
- package/light-chaser-app/src/designer/operate-provider/movable/DesignerMovable.less +19 -0
- package/light-chaser-app/src/designer/operate-provider/movable/DesignerMovable.tsx +461 -0
- package/light-chaser-app/src/designer/operate-provider/movable/DesignerSelectable.tsx +123 -0
- package/light-chaser-app/src/designer/operate-provider/scale/ScaleCore.ts +43 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/HistoryOperator.ts +37 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/HistoryQueue.ts +170 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/HistoryRecordOperateProxy.ts +1740 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/OperateType.ts +183 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/core/AbstractRollback.ts +27 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/core/AddRollbackImpl.ts +89 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/core/DelRollbackImpl.ts +99 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/core/DragRollbackImpl.ts +59 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/core/HideRollbackImpl.ts +61 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/core/LockRollbackImpl.ts +57 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/core/OrderRollbackImpl.ts +34 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/core/ResizeRollbackImpl.ts +59 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/core/RotateRollbackImpl.ts +58 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/core/StyleRollbackImpl.ts +62 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/core/UpdLayerGroupRollbackImpl.ts +62 -0
- package/light-chaser-app/src/designer/operate-provider/undo-redo/core/index.ts +37 -0
- package/light-chaser-app/src/designer/release/DesignerRelease.less +41 -0
- package/light-chaser-app/src/designer/release/DesignerRelease.tsx +91 -0
- package/light-chaser-app/src/designer/right/ConfigContent.tsx +186 -0
- package/light-chaser-app/src/designer/right/DesignerRight.less +325 -0
- package/light-chaser-app/src/designer/right/DesignerRight.tsx +28 -0
- package/light-chaser-app/src/designer/right/MenuList.tsx +70 -0
- package/light-chaser-app/src/designer/right/MenuType.ts +23 -0
- package/light-chaser-app/src/designer/right/RightStore.ts +122 -0
- package/light-chaser-app/src/designer/right/status-list/ComponentStatusList.tsx +73 -0
- package/light-chaser-app/src/designer/right/status-list/StatusListStore.ts +175 -0
- package/light-chaser-app/src/designer/right/util.ts +53 -0
- package/light-chaser-app/src/designer/store/RuntimeStore.ts +32 -0
- package/light-chaser-app/src/designer/style/DesignerGlobalStyle.less +75 -0
- package/light-chaser-app/src/designer/view/DesignerView.less +41 -0
- package/light-chaser-app/src/designer/view/DesignerView.tsx +61 -0
- package/light-chaser-app/src/framework/cache/AbstractCache.ts +38 -0
- package/light-chaser-app/src/framework/cache/ImageSourceCache.ts +23 -0
- package/light-chaser-app/src/framework/cache/LocalCoverCache.ts +29 -0
- package/light-chaser-app/src/framework/context-menu/ContextMenu.less +57 -0
- package/light-chaser-app/src/framework/context-menu/ContextMenu.tsx +76 -0
- package/light-chaser-app/src/framework/convert/AbstractConvert.ts +31 -0
- package/light-chaser-app/src/framework/core/AbstractController.ts +76 -0
- package/light-chaser-app/src/framework/core/AbstractDefinition.ts +77 -0
- package/light-chaser-app/src/framework/core/AbstractDesignerController.ts +129 -0
- package/light-chaser-app/src/framework/core/AbstractDesignerDefinition.ts +136 -0
- package/light-chaser-app/src/framework/core/AbstractScaleObserver.ts +15 -0
- package/light-chaser-app/src/framework/core/ComponentContainer.tsx +130 -0
- package/light-chaser-app/src/framework/core/ScaleAction.ts +33 -0
- package/light-chaser-app/src/framework/core/tools/ComponentDataUpdater.ts +260 -0
- package/light-chaser-app/src/framework/drag-scale/DragAddProvider.ts +45 -0
- package/light-chaser-app/src/framework/drag-scale/DragScaleProvider.tsx +202 -0
- package/light-chaser-app/src/framework/screen-fit/ScreenFit.less +25 -0
- package/light-chaser-app/src/framework/screen-fit/ScreenFit.tsx +177 -0
- package/light-chaser-app/src/global/ExportEditGlobalMember.ts +54 -0
- package/light-chaser-app/src/global/ExportViewGlobalMember.ts +40 -0
- package/light-chaser-app/src/global/GlobalConstants.ts +16 -0
- package/light-chaser-app/src/images/lock.svg +23 -0
- package/light-chaser-app/src/images/login-logo.png +0 -0
- package/light-chaser-app/src/images/logo.png +0 -0
- package/light-chaser-app/src/images/user.svg +23 -0
- package/light-chaser-app/src/index.less +359 -0
- package/light-chaser-app/src/index.tsx +47 -0
- package/light-chaser-app/src/pages/auth-reminder/AuthReminders.less +218 -0
- package/light-chaser-app/src/pages/auth-reminder/AuthReminders.tsx +174 -0
- package/light-chaser-app/src/pages/auth-reminder/AuthRemindersStore.ts +30 -0
- package/light-chaser-app/src/pages/designer/DesignerPage.tsx +18 -0
- package/light-chaser-app/src/pages/home/Home.less +123 -0
- package/light-chaser-app/src/pages/home/Home.tsx +81 -0
- package/light-chaser-app/src/pages/home/api-management/ApiEditPanel.tsx +79 -0
- package/light-chaser-app/src/pages/home/api-management/ApiManagement.module.less +234 -0
- package/light-chaser-app/src/pages/home/api-management/ApiManagement.tsx +152 -0
- package/light-chaser-app/src/pages/home/api-management/ApiManagementStore.ts +187 -0
- package/light-chaser-app/src/pages/home/database/DataBaseList.module.less +369 -0
- package/light-chaser-app/src/pages/home/database/DataBaseList.tsx +264 -0
- package/light-chaser-app/src/pages/home/database/DataBasePanel.less +170 -0
- package/light-chaser-app/src/pages/home/database/DataBasePanel.tsx +172 -0
- package/light-chaser-app/src/pages/home/database/DataBaseStore.ts +220 -0
- package/light-chaser-app/src/pages/home/dynamic-script/DynamicScriptList.module.less +305 -0
- package/light-chaser-app/src/pages/home/dynamic-script/DynamicScriptList.tsx +248 -0
- package/light-chaser-app/src/pages/home/dynamic-script/DynamicScriptManagement.tsx +19 -0
- package/light-chaser-app/src/pages/home/dynamic-script/DynamicScriptManagementStore.ts +192 -0
- package/light-chaser-app/src/pages/home/font-management/FontManagement.module.less +281 -0
- package/light-chaser-app/src/pages/home/font-management/FontManagement.tsx +218 -0
- package/light-chaser-app/src/pages/home/font-management/FontManagementStore.ts +153 -0
- package/light-chaser-app/src/pages/home/image/default-snapshot.jpg +0 -0
- package/light-chaser-app/src/pages/home/menus/HomeMenus.less +175 -0
- package/light-chaser-app/src/pages/home/menus/HomeMenus.tsx +148 -0
- package/light-chaser-app/src/pages/home/more-info/MoreInfo.module.less +154 -0
- package/light-chaser-app/src/pages/home/more-info/MoreInfo.tsx +71 -0
- package/light-chaser-app/src/pages/home/page-container/PageContainer.less +130 -0
- package/light-chaser-app/src/pages/home/page-container/PageContainer.tsx +41 -0
- package/light-chaser-app/src/pages/home/project-list/CloneProjectDialog.tsx +43 -0
- package/light-chaser-app/src/pages/home/project-list/DelProjectDialog.tsx +37 -0
- package/light-chaser-app/src/pages/home/project-list/NewProjectDialog.less +262 -0
- package/light-chaser-app/src/pages/home/project-list/NewProjectDialog.tsx +152 -0
- package/light-chaser-app/src/pages/home/project-list/ProjectItem.less +192 -0
- package/light-chaser-app/src/pages/home/project-list/ProjectItem.tsx +136 -0
- package/light-chaser-app/src/pages/home/project-list/ProjectList.less +137 -0
- package/light-chaser-app/src/pages/home/project-list/ProjectList.tsx +180 -0
- package/light-chaser-app/src/pages/home/project-management/ProjectManagement.tsx +18 -0
- package/light-chaser-app/src/pages/home/project-setting/ProjectSetting.less +39 -0
- package/light-chaser-app/src/pages/home/project-setting/ProjectSetting.tsx +39 -0
- package/light-chaser-app/src/pages/home/release-management/ReleaseEditPanel.tsx +62 -0
- package/light-chaser-app/src/pages/home/release-management/ReleaseManagement.module.less +216 -0
- package/light-chaser-app/src/pages/home/release-management/ReleaseManagement.tsx +213 -0
- package/light-chaser-app/src/pages/home/release-management/ReleaseStore.ts +138 -0
- package/light-chaser-app/src/pages/home/remote-component/RemoteComponentManagement.module.less +290 -0
- package/light-chaser-app/src/pages/home/remote-component/RemoteComponentManagement.tsx +244 -0
- package/light-chaser-app/src/pages/home/remote-component/RemoteComponentStore.ts +143 -0
- package/light-chaser-app/src/pages/home/resource-management/ResourceManagement.tsx +18 -0
- package/light-chaser-app/src/pages/home/server-list/ServerProjectList.tsx +21 -0
- package/light-chaser-app/src/pages/home/setting/Setting.module.less +298 -0
- package/light-chaser-app/src/pages/home/setting/Setting.tsx +123 -0
- package/light-chaser-app/src/pages/home/template-market/TemplateMarket.tsx +22 -0
- package/light-chaser-app/src/pages/home/user-info/UserInfo.less +279 -0
- package/light-chaser-app/src/pages/home/user-info/UserInfo.tsx +186 -0
- package/light-chaser-app/src/pages/home/user-management/UserManagement.module.less +211 -0
- package/light-chaser-app/src/pages/home/user-management/UserManagement.tsx +209 -0
- package/light-chaser-app/src/pages/home/user-management/UserManagementStore.ts +183 -0
- package/light-chaser-app/src/pages/home/user-management/UserPanel.tsx +113 -0
- package/light-chaser-app/src/pages/login/Login.less +282 -0
- package/light-chaser-app/src/pages/login/Login.tsx +77 -0
- package/light-chaser-app/src/pages/login/ServiceTerms.tsx +118 -0
- package/light-chaser-app/src/pages/login/bg.png +0 -0
- package/light-chaser-app/src/pages/preview/DesignerViewPage.tsx +18 -0
- package/light-chaser-app/src/pages/release/DesignerReleasePage.tsx +19 -0
- package/light-chaser-app/src/pages/result/Error.tsx +24 -0
- package/light-chaser-app/src/pages/result/NoAuth.tsx +24 -0
- package/light-chaser-app/src/pages/result/NotFound.tsx +24 -0
- package/light-chaser-app/src/pureRelease/home/PureHome.less +100 -0
- package/light-chaser-app/src/pureRelease/home/PureHome.tsx +90 -0
- package/light-chaser-app/src/pureRelease/index.less +335 -0
- package/light-chaser-app/src/pureRelease/index.tsx +59 -0
- package/light-chaser-app/src/pureRelease/list/PureList.less +173 -0
- package/light-chaser-app/src/pureRelease/list/PureList.tsx +118 -0
- package/light-chaser-app/src/pureRelease/release/PureRelease.less +41 -0
- package/light-chaser-app/src/pureRelease/release/PureRelease.tsx +53 -0
- package/light-chaser-app/src/router/AuthGuard.tsx +48 -0
- package/light-chaser-app/src/router/router.tsx +76 -0
- package/light-chaser-app/src/test/Demo.tsx +22 -0
- package/light-chaser-app/src/test/DemoMain.less +47 -0
- package/light-chaser-app/src/test/DemoStore.ts +51 -0
- package/light-chaser-app/src/test/alone-store-demo/AloneStore.ts +28 -0
- package/light-chaser-app/src/test/alone-store-demo/TestStoreA.tsx +28 -0
- package/light-chaser-app/src/test/alone-store-demo/TestStoreB.tsx +28 -0
- package/light-chaser-app/src/test/canvas-grid-animation/CanvasGridAnimation.tsx +59 -0
- package/light-chaser-app/src/test/drag-demo/LayerDemo.less +35 -0
- package/light-chaser-app/src/test/drag-demo/LayerDemo.tsx +53 -0
- package/light-chaser-app/src/test/drag-demo/LayerDemoStore.ts +33 -0
- package/light-chaser-app/src/test/drag-demo/MovableDemo.tsx +77 -0
- package/light-chaser-app/src/test/drag-demo/SelectableDemo.tsx +75 -0
- package/light-chaser-app/src/test/other-designer/_demo.js +99 -0
- package/light-chaser-app/src/test/test-json-schema/JsonSchemaDemo.tsx +120 -0
- package/light-chaser-app/src/theme/AntdTheme.ts +1285 -0
- package/light-chaser-app/src/theme/default.less +41 -0
- package/light-chaser-app/src/util/AuthFetchUtil.ts +37 -0
- package/light-chaser-app/src/util/BoundsValidatorUtil.ts +27 -0
- package/light-chaser-app/src/util/ControllerUtil.ts +14 -0
- package/light-chaser-app/src/util/CoordinateUtil.ts +105 -0
- package/light-chaser-app/src/util/DataUtil.ts +111 -0
- package/light-chaser-app/src/util/DomUtil.ts +57 -0
- package/light-chaser-app/src/util/EnvUtil.ts +27 -0
- package/light-chaser-app/src/util/FetchUtil.ts +193 -0
- package/light-chaser-app/src/util/HybridCryptoUtil.ts +137 -0
- package/light-chaser-app/src/util/LogoUtil.ts +34 -0
- package/light-chaser-app/src/util/ProjectUtil.ts +209 -0
- package/light-chaser-app/src/util/RequestAnimationFrameUtil.ts +31 -0
- package/light-chaser-app/src/util/TextUtil.ts +63 -0
- package/light-chaser-app/src/util/Tooles.ts +45 -0
- package/light-chaser-app/src/vite-env.d.ts +53 -0
- package/light-chaser-app/tsconfig.json +40 -0
- package/light-chaser-app/tsconfig.node.json +15 -0
- package/light-chaser-app/vite.base.config.ts +23 -0
- package/light-chaser-app/vite.build.config.ts +18 -0
- package/light-chaser-app/vite.dev.config.ts +43 -0
- package/light-chaser-app/vite.pure.release.config.ts +41 -0
- package/light-chaser-cli/bin/index.js +176 -0
- package/light-chaser-cli/config/vite.config.dev.js +24 -0
- package/light-chaser-cli/config/vite.config.prod.js +47 -0
- package/light-chaser-cli/package.json +41 -0
- package/light-chaser-cli/page/index.html +36 -0
- package/light-chaser-cli/pnpm-lock.yaml +494 -0
- package/light-chaser-cli/template/index.html +35 -0
- package/light-chaser-cli/template/package.json +38 -0
- package/light-chaser-cli/template/src/components/remote-button/base-button.png +0 -0
- package/light-chaser-cli/template/src/components/remote-button/component.module.less +105 -0
- package/light-chaser-cli/template/src/components/remote-button/component.tsx +82 -0
- package/light-chaser-cli/template/src/components/remote-button/config.tsx +179 -0
- package/light-chaser-cli/template/src/components/remote-button/controller.ts +108 -0
- package/light-chaser-cli/template/src/components/remote-button/definition.ts +125 -0
- package/light-chaser-cli/template/src/index.module.less +89 -0
- package/light-chaser-cli/template/src/index.tsx +140 -0
- package/light-chaser-cli/template/src/vite-env.d.ts +22 -0
- package/light-chaser-cli/template/tsconfig.json +39 -0
- package/light-chaser-cli/template/tsconfig.node.json +11 -0
- package/light-chaser-interface/README.md +3 -0
- package/light-chaser-interface/lib/AbstractController.ts +69 -0
- package/light-chaser-interface/lib/AbstractDefinition.ts +84 -0
- package/light-chaser-interface/lib/AbstractDesignerController.ts +80 -0
- package/light-chaser-interface/lib/AbstractDesignerDefinition.ts +71 -0
- package/light-chaser-interface/lib/BPExecutor.ts +28 -0
- package/light-chaser-interface/lib/ConfigComponents.tsx +40 -0
- package/light-chaser-interface/lib/main.ts +17 -0
- package/light-chaser-interface/package.json +46 -0
- package/light-chaser-interface/tsconfig-build.json +6 -0
- package/light-chaser-interface/tsconfig.json +40 -0
- package/light-chaser-interface/tsconfig.node.json +15 -0
- package/light-chaser-interface/vite.config.ts +22 -0
- package/light-chaser-types/package.json +38 -0
- package/light-chaser-types/tsconfig-build.json +6 -0
- package/light-chaser-types/tsconfig.json +41 -0
- package/light-chaser-types/tsconfig.node.json +12 -0
- package/light-chaser-types/types/BluePrintTypes.ts +85 -0
- package/light-chaser-types/types/CanvasTypes.ts +33 -0
- package/light-chaser-types/types/ComponentTypes.ts +100 -0
- package/light-chaser-types/types/DataSourceTypes.ts +96 -0
- package/light-chaser-types/types/DesignerToolsTypes.ts +18 -0
- package/light-chaser-types/types/DesignerTypes.ts +136 -0
- package/light-chaser-types/types/FilterTypes.ts +44 -0
- package/light-chaser-types/types/GlobalVariableTypes.ts +43 -0
- package/light-chaser-types/types/LayerTypes.ts +90 -0
- package/light-chaser-types/types/ReleaseTypes.ts +22 -0
- package/light-chaser-types/types/ThemeTypes.ts +34 -0
- package/light-chaser-types/types/main.ts +69 -0
- package/light-chaser-types/vite.config.ts +14 -0
- package/light-chaser-ui/index.html +24 -0
- package/light-chaser-ui/lib/accordion/Accordion.less +158 -0
- package/light-chaser-ui/lib/accordion/Accordion.tsx +43 -0
- package/light-chaser-ui/lib/accordion/IAccordionType.ts +35 -0
- package/light-chaser-ui/lib/accordion/SubAccordion.tsx +44 -0
- package/light-chaser-ui/lib/button/Button.tsx +37 -0
- package/light-chaser-ui/lib/card-panel/CardPanel.less +32 -0
- package/light-chaser-ui/lib/card-panel/CardPanel.tsx +36 -0
- package/light-chaser-ui/lib/checkbox/CheckBox.tsx +42 -0
- package/light-chaser-ui/lib/code-editor/CodeEditor.tsx +55 -0
- package/light-chaser-ui/lib/code-editor/FullEditor.tsx +45 -0
- package/light-chaser-ui/lib/code-editor/MonacoEditor.less +35 -0
- package/light-chaser-ui/lib/code-editor/MonacoEditor.tsx +83 -0
- package/light-chaser-ui/lib/color-mode/ColorMode.less +20 -0
- package/light-chaser-ui/lib/color-mode/ColorMode.tsx +80 -0
- package/light-chaser-ui/lib/color-picker/ColorPicker.less +104 -0
- package/light-chaser-ui/lib/color-picker/ColorPicker.tsx +315 -0
- package/light-chaser-ui/lib/color-picker/RecentColors.ts +46 -0
- package/light-chaser-ui/lib/colors-picker/ColorsPicker.less +77 -0
- package/light-chaser-ui/lib/colors-picker/ColorsPicker.tsx +78 -0
- package/light-chaser-ui/lib/control-group/ControlGroup.less +49 -0
- package/light-chaser-ui/lib/control-group/ControlGroup.tsx +101 -0
- package/light-chaser-ui/lib/frame-layout/FrameLayout.less +47 -0
- package/light-chaser-ui/lib/frame-layout/FrameLayout.tsx +42 -0
- package/light-chaser-ui/lib/grid/Grid.less +20 -0
- package/light-chaser-ui/lib/grid/Grid.tsx +33 -0
- package/light-chaser-ui/lib/group-button/GroupButton.less +52 -0
- package/light-chaser-ui/lib/group-button/GroupButton.tsx +54 -0
- package/light-chaser-ui/lib/gui/GUITheme.ts +547 -0
- package/light-chaser-ui/lib/gui/LCGUI.tsx +186 -0
- package/light-chaser-ui/lib/gui/LCGUIUtil.ts +108 -0
- package/light-chaser-ui/lib/imag-upload/ImageUpload.less +26 -0
- package/light-chaser-ui/lib/imag-upload/ImageUpload.tsx +102 -0
- package/light-chaser-ui/lib/input/Input.tsx +48 -0
- package/light-chaser-ui/lib/input/NumberInput.tsx +52 -0
- package/light-chaser-ui/lib/loading/Loading.less +211 -0
- package/light-chaser-ui/lib/loading/Loading.tsx +38 -0
- package/light-chaser-ui/lib/main.ts +71 -0
- package/light-chaser-ui/lib/message/GlobalMessage.tsx +44 -0
- package/light-chaser-ui/lib/message/GlobalModal.tsx +44 -0
- package/light-chaser-ui/lib/radio/Radio.tsx +53 -0
- package/light-chaser-ui/lib/searchable-select/SearchableSelect.tsx +239 -0
- package/light-chaser-ui/lib/select/Select.tsx +89 -0
- package/light-chaser-ui/lib/slider/Slider.tsx +51 -0
- package/light-chaser-ui/lib/switch/Switch.tsx +42 -0
- package/light-chaser-ui/lib/text-area/TextArea.tsx +49 -0
- package/light-chaser-ui/lib/text-only/TextOnly.tsx +25 -0
- package/light-chaser-ui/lib/types.ts +257 -0
- package/light-chaser-ui/lib/ui-container/UIContainer.less +44 -0
- package/light-chaser-ui/lib/ui-container/UIContainer.tsx +40 -0
- package/light-chaser-ui/lib/ui-map.ts +59 -0
- package/light-chaser-ui/package.json +57 -0
- package/light-chaser-ui/public/favicon.ico +0 -0
- package/light-chaser-ui/src/test.tsx +24 -0
- package/light-chaser-ui/tsconfig-build.json +6 -0
- package/light-chaser-ui/tsconfig.json +42 -0
- package/light-chaser-ui/tsconfig.node.json +12 -0
- package/light-chaser-ui/vite.config.ts +25 -0
- package/light-chaser-util/lib/AuthTools.ts +75 -0
- package/light-chaser-util/lib/Base64Util.ts +31 -0
- package/light-chaser-util/lib/ColorUtil.ts +110 -0
- package/light-chaser-util/lib/ComponentUtil.ts +45 -0
- package/light-chaser-util/lib/FileUtil.ts +49 -0
- package/light-chaser-util/lib/IdGenerate.ts +23 -0
- package/light-chaser-util/lib/ObjectUtil.ts +130 -0
- package/light-chaser-util/lib/SafeEvalUtil.ts +63 -0
- package/light-chaser-util/lib/URLUtil.ts +27 -0
- package/light-chaser-util/lib/main.ts +21 -0
- package/light-chaser-util/package.json +40 -0
- package/light-chaser-util/src/test.ts +12 -0
- package/light-chaser-util/tsconfig-build.json +6 -0
- package/light-chaser-util/tsconfig.json +36 -0
- package/light-chaser-util/vite.config.ts +18 -0
- package/package.json +12 -0
- package/pnpm-workspace.yaml +7 -0
- package/prompt/UI/344/274/230/345/214/226/346/217/220/347/244/272/350/257/215.md +144 -0
- package/prompt//347/273/204/344/273/266/345/274/200/345/217/221/346/217/220/347/244/272/350/257/215.md +1090 -0
- package/prompt//351/200/273/350/276/221/344/274/230/345/214/226/346/217/220/347/244/272/350/257/215.md +98 -0
- package/prompt//351/205/215/347/275/256/351/241/271/347/224/237/346/210/220/345/267/245/344/275/234/346/265/201.md +401 -0
|
@@ -0,0 +1,1740 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright © 2023-2025 puyinzhen
|
|
3
|
+
* All rights reserved.
|
|
4
|
+
*
|
|
5
|
+
* The copyright of this work (or idea/project/document) is owned by puyinzhen. Without explicit written permission, no part of this work may be reproduced, distributed, or modified in any form for commercial purposes.
|
|
6
|
+
*
|
|
7
|
+
* This copyright statement applies to, but is not limited to: concept descriptions, design documents, source code, images, presentation files, and any related content.
|
|
8
|
+
*
|
|
9
|
+
* For permission to use this work or any part of it, please contact 1182810784@qq.com to obtain written authorization.
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
import {IAddOperateData, IDelOperateData, IGraphicalTransform, IHideOperateData, IHistoryRecord, ILockOperateData, IUpdLayerOperateData, IUpdStyleOperateData, OperateType} from "./OperateType";
|
|
13
|
+
import {historyOperator} from "./HistoryOperator";
|
|
14
|
+
import eventOperateStore from "../EventOperateStore";
|
|
15
|
+
import {runInAction} from "mobx";
|
|
16
|
+
import rightStore from "../../right/RightStore";
|
|
17
|
+
import {cloneDeep} from "lodash";
|
|
18
|
+
import {ConfigureObjectFragments} from "light-chaser-util/lib/ObjectUtil.ts";
|
|
19
|
+
import IdGenerate from "../../../../../light-chaser-util/lib/IdGenerate.ts";
|
|
20
|
+
import {Component} from "react";
|
|
21
|
+
import layerListStore from "../../left/layer-list/LayerListStore";
|
|
22
|
+
import LayerUtil from "../../left/layer-list/util/LayerUtil";
|
|
23
|
+
import designerLeftStore from "../../left/DesignerLeftStore";
|
|
24
|
+
import {ILayerItem} from "light-chaser-types/types/LayerTypes.ts";
|
|
25
|
+
import CoordinateUtil from "../../../util/CoordinateUtil.ts";
|
|
26
|
+
import {BaseLayer} from "../../left/layer-list/item/BaseLayer.tsx";
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
class HistoryRecordOperateProxy {
|
|
30
|
+
|
|
31
|
+
public doDrag(latestState: ILayerItem[]): void {
|
|
32
|
+
//构建历史记录数据
|
|
33
|
+
const {layerConfigs, updateLayer} = window.LC_ENV.currentManager.layerManager!;
|
|
34
|
+
|
|
35
|
+
//1. 记录变更前数据
|
|
36
|
+
const prev = latestState.map((item) => {
|
|
37
|
+
const {id, x = 0, y = 0, rotate = 0} = layerConfigs[item.id!];
|
|
38
|
+
return {id, x, y, rotate}
|
|
39
|
+
})
|
|
40
|
+
|
|
41
|
+
//2. 更新布局数据
|
|
42
|
+
updateLayer(latestState, false);
|
|
43
|
+
|
|
44
|
+
//3. 记录变更后数据
|
|
45
|
+
const next = latestState.map((item) => {
|
|
46
|
+
const {id, x = 0, y = 0, rotate = 0} = layerConfigs[item.id!];
|
|
47
|
+
return {id, x, y, rotate}
|
|
48
|
+
})
|
|
49
|
+
|
|
50
|
+
//4. 构建历史记录节点
|
|
51
|
+
const data: IHistoryRecord = {
|
|
52
|
+
type: OperateType.DRAG,
|
|
53
|
+
prev: prev!,
|
|
54
|
+
next: next!
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
//历史记录入队
|
|
58
|
+
historyOperator.put({actions: [data]});
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
public doRotate(latestState: ILayerItem[]): void {
|
|
62
|
+
if (!latestState || latestState.length === 0)
|
|
63
|
+
return;
|
|
64
|
+
const {layerConfigs, updateLayer} = window.LC_ENV.currentManager.layerManager!;
|
|
65
|
+
|
|
66
|
+
//1. 记录变更前数据
|
|
67
|
+
const prev = latestState.map((item) => {
|
|
68
|
+
const {id, x = 0, y = 0, rotate = 0} = layerConfigs[item.id!];
|
|
69
|
+
return {id: id!, x: x!, y: y!, rotate: rotate!}
|
|
70
|
+
})
|
|
71
|
+
|
|
72
|
+
//2. 执行数据变更
|
|
73
|
+
updateLayer(latestState, false);
|
|
74
|
+
|
|
75
|
+
//3. 记录变更后数据
|
|
76
|
+
const next = latestState.map((item) => {
|
|
77
|
+
const {id, x = 0, y = 0, rotate = 0} = layerConfigs[item.id!];
|
|
78
|
+
return {id: id!, x: x!, y: y!, rotate: rotate!}
|
|
79
|
+
})
|
|
80
|
+
|
|
81
|
+
//4. 构建历史记录节点
|
|
82
|
+
const data: IHistoryRecord = {
|
|
83
|
+
type: OperateType.ROTATE,
|
|
84
|
+
prev: prev!,
|
|
85
|
+
next: next!
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
//5. 历史记录入队
|
|
89
|
+
historyOperator.put({actions: [data]});
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
public doResize(latestState: ILayerItem[]): void {
|
|
93
|
+
//构建历史记录数据
|
|
94
|
+
const {layerConfigs, updateLayer} = window.LC_ENV.currentManager.layerManager!;
|
|
95
|
+
|
|
96
|
+
//1. 记录变更前数据
|
|
97
|
+
const prev: IGraphicalTransform[] = latestState.map((item) => {
|
|
98
|
+
const {id, x = 0, y = 0, width = 0, height = 0, rotate = 0} = layerConfigs[item.id!];
|
|
99
|
+
return {id: id!, x, y, width, height, rotate}
|
|
100
|
+
})
|
|
101
|
+
|
|
102
|
+
//2. 更新布局数据
|
|
103
|
+
updateLayer(latestState, true);
|
|
104
|
+
|
|
105
|
+
//3. 记录变更后数据
|
|
106
|
+
const next: IGraphicalTransform[] = latestState.map((item) => {
|
|
107
|
+
const {id, x = 0, y = 0, width = 0, height = 0, rotate = 0} = layerConfigs[item.id!];
|
|
108
|
+
return {id: id!, x, y, width, height, rotate}
|
|
109
|
+
})
|
|
110
|
+
|
|
111
|
+
//4. 构建历史记录节点
|
|
112
|
+
const record: IHistoryRecord = {type: OperateType.RESIZE, prev: prev!, next: next!}
|
|
113
|
+
|
|
114
|
+
//5. 历史记录入队
|
|
115
|
+
historyOperator.put({actions: [record]});
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
public doAdd(layer: ILayerItem): void {
|
|
119
|
+
const addPrev: IAddOperateData[] = [];
|
|
120
|
+
const addNext: IAddOperateData[] = [];
|
|
121
|
+
const updLayerPrev: IUpdLayerOperateData[] = [];
|
|
122
|
+
const updLayerNext: IUpdLayerOperateData[] = [];
|
|
123
|
+
const {layerManager} = window.LC_ENV.currentManager!;
|
|
124
|
+
const {layerConfigs, updateLayer} = layerManager!;
|
|
125
|
+
|
|
126
|
+
//头插法建立双向链表
|
|
127
|
+
if (!layerManager?.layerHeader) {
|
|
128
|
+
//首次插入
|
|
129
|
+
addPrev.push({layerHeader: undefined, layerTail: undefined})
|
|
130
|
+
layerManager!.layerHeader = layer.id;
|
|
131
|
+
layerManager!.layerTail = layer.id;
|
|
132
|
+
} else {
|
|
133
|
+
//非首次插入
|
|
134
|
+
addPrev.push({layerHeader: layerManager.layerHeader})
|
|
135
|
+
const oldHeaderLayer = layerConfigs[layerManager.layerHeader];
|
|
136
|
+
updLayerPrev.push({id: oldHeaderLayer.id, prev: oldHeaderLayer.prev})
|
|
137
|
+
oldHeaderLayer.prev = layer.id;
|
|
138
|
+
layer.next = oldHeaderLayer.id;
|
|
139
|
+
layerManager.layerHeader = layer.id;
|
|
140
|
+
updLayerNext.push({id: oldHeaderLayer.id, prev: layer.id})
|
|
141
|
+
}
|
|
142
|
+
addNext.push({
|
|
143
|
+
id: layer.id,
|
|
144
|
+
layerConfig: cloneDeep(layer),
|
|
145
|
+
layerHeader: layerManager?.layerHeader,
|
|
146
|
+
layerTail: layerManager?.layerTail
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
const {addRecordCompId, setAddRecordCompId} = eventOperateStore;
|
|
150
|
+
/**
|
|
151
|
+
* addRecordCompId为不为null,说明是从组件面板拖拽添加的组件要记录操作日志,反之其他操作导致的组件添加则不记录日志
|
|
152
|
+
*/
|
|
153
|
+
if (addRecordCompId && addRecordCompId === layer.id) {
|
|
154
|
+
historyOperator.put({
|
|
155
|
+
actions: [
|
|
156
|
+
{type: OperateType.ADD, prev: addPrev, next: addNext},
|
|
157
|
+
{type: OperateType.UPDATE_LAYER, prev: updLayerPrev, next: updLayerNext}
|
|
158
|
+
]
|
|
159
|
+
});
|
|
160
|
+
setAddRecordCompId(null);
|
|
161
|
+
}
|
|
162
|
+
runInAction(() => {
|
|
163
|
+
layerConfigs[layer.id + ""] = layer;
|
|
164
|
+
})
|
|
165
|
+
updateLayer(updLayerNext);
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
public doUseTemplate(templateInfo: { configs: Record<string, any>, layers: Record<string, ILayerItem> }): void {
|
|
169
|
+
const {configs, layers: oldLayers} = templateInfo;
|
|
170
|
+
if (!configs || !oldLayers)
|
|
171
|
+
return;
|
|
172
|
+
const addPrev: IAddOperateData[] = [];
|
|
173
|
+
const addNext: IAddOperateData[] = [];
|
|
174
|
+
const updLayerPrev: IUpdLayerOperateData[] = [];
|
|
175
|
+
const updLayerNext: IUpdLayerOperateData[] = [];
|
|
176
|
+
|
|
177
|
+
/** 1. 获取待处理图层列表的分组映射关系 */
|
|
178
|
+
const groupMapping = new Map<string, string[]>();
|
|
179
|
+
const topLevelLayers: Record<string, ILayerItem> = {};
|
|
180
|
+
const layerIds = Object.values(oldLayers).map(layer => layer.id!);
|
|
181
|
+
layerIds.forEach(id => {
|
|
182
|
+
const layer = oldLayers[id];
|
|
183
|
+
if (layer.pid && layerIds.includes(layer.pid)) {
|
|
184
|
+
if (!groupMapping.has(layer.pid))
|
|
185
|
+
groupMapping.set(layer.pid, [layer.id!]);
|
|
186
|
+
else
|
|
187
|
+
groupMapping.get(layer.pid)!.push(layer.id!);
|
|
188
|
+
} else {
|
|
189
|
+
topLevelLayers[layer.id!] = layer;
|
|
190
|
+
layer.pid = undefined;
|
|
191
|
+
}
|
|
192
|
+
})
|
|
193
|
+
|
|
194
|
+
/** 3. 构建主干链表 */
|
|
195
|
+
const {head, tail} = LayerUtil.buildADoublyLinkedListOfLayers(topLevelLayers);
|
|
196
|
+
|
|
197
|
+
/** 4. 构建分支链表 */
|
|
198
|
+
groupMapping.forEach((childIds, pid) => {
|
|
199
|
+
const childLayers = childIds.reduce((acc, id) => {
|
|
200
|
+
acc[id] = oldLayers[id];
|
|
201
|
+
return acc;
|
|
202
|
+
}, {} as Record<string, ILayerItem>);
|
|
203
|
+
const {head, tail} = LayerUtil.buildADoublyLinkedListOfLayers(childLayers);
|
|
204
|
+
const parentLayer = oldLayers[pid];
|
|
205
|
+
parentLayer.childHeader = head!;
|
|
206
|
+
parentLayer.childTail = tail!;
|
|
207
|
+
})
|
|
208
|
+
|
|
209
|
+
const newConfigs = cloneDeep(Object.values(configs));
|
|
210
|
+
const newLayers = cloneDeep(Object.values(oldLayers));
|
|
211
|
+
const idNewToOld: Record<string, string> = {};
|
|
212
|
+
const idOldToNew: Record<string, string> = {};
|
|
213
|
+
|
|
214
|
+
//设置新id并复位关联关系
|
|
215
|
+
newLayers.forEach((layer) => {
|
|
216
|
+
const oldId = layer.id;
|
|
217
|
+
const newId = IdGenerate.generateId();
|
|
218
|
+
idNewToOld[newId] = oldId!;
|
|
219
|
+
idOldToNew[oldId!] = newId;
|
|
220
|
+
const config = newConfigs.find(config => config.base['id'] === oldId)
|
|
221
|
+
if (config && config.base)
|
|
222
|
+
config && (config.base['id'] = newId);
|
|
223
|
+
layer.id = newId;
|
|
224
|
+
layer.pid = undefined;
|
|
225
|
+
layer.childHeader = undefined;
|
|
226
|
+
layer.childTail = undefined;
|
|
227
|
+
layer.prev = undefined;
|
|
228
|
+
layer.next = undefined;
|
|
229
|
+
})
|
|
230
|
+
//恢复config
|
|
231
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
232
|
+
const {elemConfigs, layerConfigs} = layerManager!;
|
|
233
|
+
newConfigs.forEach(config => {
|
|
234
|
+
elemConfigs![config.base['id']] = config;
|
|
235
|
+
})
|
|
236
|
+
|
|
237
|
+
runInAction(() => {
|
|
238
|
+
//恢复layer
|
|
239
|
+
newLayers.forEach(newLayer => {
|
|
240
|
+
const oldLayer = oldLayers[idNewToOld[newLayer.id!]];
|
|
241
|
+
if (oldLayer.pid && oldLayer.pid in oldLayers)
|
|
242
|
+
newLayer.pid = idOldToNew[oldLayer.pid];
|
|
243
|
+
if (oldLayer.prev && oldLayer.prev in oldLayers)
|
|
244
|
+
newLayer.prev = idOldToNew[oldLayer.prev];
|
|
245
|
+
if (oldLayer.next && oldLayer.next in oldLayers)
|
|
246
|
+
newLayer.next = idOldToNew[oldLayer.next];
|
|
247
|
+
if (newLayer.type === 'group') {
|
|
248
|
+
if (oldLayer.childTail)
|
|
249
|
+
newLayer.childTail = idOldToNew[oldLayer.childTail];
|
|
250
|
+
if (oldLayer.childHeader)
|
|
251
|
+
newLayer.childHeader = idOldToNew[oldLayer.childHeader];
|
|
252
|
+
}
|
|
253
|
+
layerConfigs[newLayer.id!] = newLayer;
|
|
254
|
+
})
|
|
255
|
+
|
|
256
|
+
//获取新队列的头尾指针
|
|
257
|
+
const queueHead = idOldToNew[head!];
|
|
258
|
+
const queueTail = idOldToNew[tail!];
|
|
259
|
+
const queueTailLayer = newLayers.find(layer => layer.id === queueTail)!;
|
|
260
|
+
|
|
261
|
+
//头插法建立双向链表
|
|
262
|
+
if (!layerManager?.layerHeader) {
|
|
263
|
+
//首次插入
|
|
264
|
+
addPrev.push({layerHeader: undefined, layerTail: undefined})
|
|
265
|
+
layerManager!.layerHeader = queueHead!;
|
|
266
|
+
layerManager!.layerTail = queueTail!;
|
|
267
|
+
} else {
|
|
268
|
+
//非首次插入
|
|
269
|
+
addPrev.push({layerHeader: layerManager.layerHeader})
|
|
270
|
+
const oldHeaderLayer = layerConfigs[layerManager.layerHeader];
|
|
271
|
+
updLayerPrev.push({id: oldHeaderLayer.id, prev: oldHeaderLayer.prev})
|
|
272
|
+
oldHeaderLayer.prev = queueTail!;
|
|
273
|
+
queueTailLayer.next = oldHeaderLayer.id;
|
|
274
|
+
layerManager.layerHeader = queueHead!;
|
|
275
|
+
updLayerNext.push({id: oldHeaderLayer.id, prev: queueTail!})
|
|
276
|
+
}
|
|
277
|
+
})
|
|
278
|
+
|
|
279
|
+
newLayers.forEach(layer => {
|
|
280
|
+
addNext.push({
|
|
281
|
+
id: layer.id,
|
|
282
|
+
layerConfig: cloneDeep(layer),
|
|
283
|
+
elemConfig: elemConfigs![layer.id!],
|
|
284
|
+
layerHeader: layerManager.layerHeader,
|
|
285
|
+
layerTail: layerManager.layerTail
|
|
286
|
+
})
|
|
287
|
+
})
|
|
288
|
+
|
|
289
|
+
historyOperator.put({
|
|
290
|
+
actions: [
|
|
291
|
+
{type: OperateType.ADD, prev: addPrev, next: addNext},
|
|
292
|
+
{type: OperateType.UPDATE_LAYER, prev: updLayerPrev, next: updLayerNext}
|
|
293
|
+
]
|
|
294
|
+
})
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
public doDelete(targetIds: string[]): void {
|
|
298
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
299
|
+
const {delItem, layerConfigs, controllers} = layerManager;
|
|
300
|
+
const {setTargetIds} = eventOperateStore;
|
|
301
|
+
if (targetIds.length === 0)
|
|
302
|
+
return;
|
|
303
|
+
|
|
304
|
+
const allHideLayer = Object.values(layerConfigs).filter(layer => layer.hide);
|
|
305
|
+
const hideParentSet = new Set();
|
|
306
|
+
allHideLayer.forEach(layer => {
|
|
307
|
+
const parentChain = LayerUtil.findLayerGroupChain(layer.id!)
|
|
308
|
+
parentChain.forEach(id => hideParentSet.add(id))
|
|
309
|
+
})
|
|
310
|
+
targetIds = targetIds.filter(id => !hideParentSet.has(id))
|
|
311
|
+
|
|
312
|
+
const {setContentVisible, activeConfig, activeElem} = rightStore;
|
|
313
|
+
//若被删除元素处于配置项的激活状态,则取消激活状态(关闭右侧配置项)
|
|
314
|
+
if (targetIds.includes(activeElem.id!)) {
|
|
315
|
+
setContentVisible(false);
|
|
316
|
+
activeConfig(null, "");
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
const delPrev: IDelOperateData[] = [];
|
|
320
|
+
const delNext: IDelOperateData[] = [];
|
|
321
|
+
const updPrev: IUpdLayerOperateData[] = [];
|
|
322
|
+
const updNext: IUpdLayerOperateData[] = [];
|
|
323
|
+
|
|
324
|
+
//计算本次操作所涉及到的所有图层id
|
|
325
|
+
const relatedLayerIds: Set<string> = new Set();
|
|
326
|
+
targetIds.forEach((id) => {
|
|
327
|
+
const layer = layerConfigs[id];
|
|
328
|
+
relatedLayerIds.add(id);
|
|
329
|
+
if (layer.next)
|
|
330
|
+
relatedLayerIds.add(layer.next);
|
|
331
|
+
if (layer.prev)
|
|
332
|
+
relatedLayerIds.add(layer.prev);
|
|
333
|
+
if (layer.pid) {
|
|
334
|
+
const parentLayer = layerConfigs[layer.pid];
|
|
335
|
+
if (parentLayer.childHeader === id)
|
|
336
|
+
relatedLayerIds.add(parentLayer.id!);
|
|
337
|
+
if (parentLayer.childTail === id)
|
|
338
|
+
relatedLayerIds.add(parentLayer.id!);
|
|
339
|
+
}
|
|
340
|
+
});
|
|
341
|
+
|
|
342
|
+
const toBeUpd = Array.from(relatedLayerIds).filter((id) => !targetIds.includes(id));
|
|
343
|
+
|
|
344
|
+
//记录删除前状态
|
|
345
|
+
targetIds.forEach((id) => {
|
|
346
|
+
const layer = layerConfigs[id];
|
|
347
|
+
const elemConfig = controllers[id] && controllers[id].getConfig();
|
|
348
|
+
delPrev.push({id, layerConfig: cloneDeep(layer), elemConfig: elemConfig})
|
|
349
|
+
});
|
|
350
|
+
updPrev.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail})
|
|
351
|
+
toBeUpd.forEach((id) => {
|
|
352
|
+
const layer = layerConfigs[id];
|
|
353
|
+
const {next, prev, childHeader, childTail, pid} = layer;
|
|
354
|
+
updPrev.push({id, next, prev, childHeader, childTail, pid});
|
|
355
|
+
})
|
|
356
|
+
|
|
357
|
+
//修改数据
|
|
358
|
+
runInAction(() => {
|
|
359
|
+
targetIds.forEach((id) => {
|
|
360
|
+
const layer = layerConfigs[id];
|
|
361
|
+
const prevLayer = layerConfigs[layer.prev!];
|
|
362
|
+
const nextLayer = layerConfigs[layer.next!];
|
|
363
|
+
|
|
364
|
+
if (layer.id === layerManager.layerHeader)
|
|
365
|
+
layerManager.layerHeader = layer.next;
|
|
366
|
+
if (layer.id === layerManager.layerTail)
|
|
367
|
+
layerManager.layerTail = layer.prev;
|
|
368
|
+
|
|
369
|
+
prevLayer && (prevLayer.next = layer?.next);
|
|
370
|
+
nextLayer && (nextLayer.prev = layer?.prev);
|
|
371
|
+
if (layer.pid) {
|
|
372
|
+
const parentLayer = layerConfigs[layer.pid];
|
|
373
|
+
if (parentLayer.childHeader === id)
|
|
374
|
+
parentLayer.childHeader = layer?.next;
|
|
375
|
+
if (parentLayer.childTail === id)
|
|
376
|
+
parentLayer.childTail = layer?.prev;
|
|
377
|
+
}
|
|
378
|
+
});
|
|
379
|
+
delItem(targetIds);
|
|
380
|
+
});
|
|
381
|
+
|
|
382
|
+
//记录删除后状态
|
|
383
|
+
toBeUpd.forEach((id) => {
|
|
384
|
+
const layer = layerConfigs[id];
|
|
385
|
+
const {next, prev, childHeader, childTail, pid} = layer;
|
|
386
|
+
updNext.push({id, next, prev, childHeader, childTail, pid});
|
|
387
|
+
});
|
|
388
|
+
delNext.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail})
|
|
389
|
+
|
|
390
|
+
historyOperator.put({
|
|
391
|
+
actions: [
|
|
392
|
+
{type: OperateType.DEL, prev: delPrev, next: delNext},
|
|
393
|
+
{type: OperateType.UPDATE_LAYER, prev: updPrev, next: updNext}
|
|
394
|
+
]
|
|
395
|
+
});
|
|
396
|
+
|
|
397
|
+
setTargetIds([]);
|
|
398
|
+
//删除组件后,重新聚焦鼠标指针到容器上,避免鼠标失去焦点导致其他快捷键失效。
|
|
399
|
+
eventOperateStore?.focusDesignerCanvas();
|
|
400
|
+
}
|
|
401
|
+
|
|
402
|
+
/**
|
|
403
|
+
* @see https://picss.sunbangyan.cn/2023/12/04/6d352450af32841a97f4784d2252eeb8.jpeg
|
|
404
|
+
* 被克隆的图层可以同时包含普通图层、分组图层和分组图层的子图层。
|
|
405
|
+
* 1.普通图层和没有包含分组图层的子图层,则直接克隆。
|
|
406
|
+
* 2.对于分组图层和其下的子图层,克隆时需要创建克隆前后的映射关系,克隆完毕后根据映射关系恢复新图层之前的层级关系。
|
|
407
|
+
* @param ids
|
|
408
|
+
*/
|
|
409
|
+
public doClone(ids: string[]): string[] {
|
|
410
|
+
if (ids.length === 0)
|
|
411
|
+
return [];
|
|
412
|
+
|
|
413
|
+
const addPrev: IAddOperateData[] = [];
|
|
414
|
+
const addNext: IAddOperateData[] = [];
|
|
415
|
+
const updPrev: IUpdLayerOperateData[] = [];
|
|
416
|
+
const updNext: IUpdLayerOperateData[] = [];
|
|
417
|
+
const layerIdOldToNew: Record<string, string> = {};
|
|
418
|
+
const newLayouts: ILayerItem[] = [];
|
|
419
|
+
const newIds: string[] = [];
|
|
420
|
+
|
|
421
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
422
|
+
//计算复制操作所涉及的所有图层
|
|
423
|
+
const relatedLayerIds: Set<string> = new Set();
|
|
424
|
+
ids.forEach((id) => {
|
|
425
|
+
const layer = layerManager.layerConfigs[id];
|
|
426
|
+
relatedLayerIds.add(id)
|
|
427
|
+
if (layer.prev)
|
|
428
|
+
relatedLayerIds.add(layer.prev);
|
|
429
|
+
if (layer.pid) {
|
|
430
|
+
const parentLayer = layerManager.layerConfigs[layer.pid];
|
|
431
|
+
if (parentLayer) {
|
|
432
|
+
relatedLayerIds.add(parentLayer.id!);
|
|
433
|
+
relatedLayerIds.add(parentLayer.childHeader!);
|
|
434
|
+
}
|
|
435
|
+
}
|
|
436
|
+
});
|
|
437
|
+
|
|
438
|
+
//记录操作前状态
|
|
439
|
+
updPrev.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail})
|
|
440
|
+
relatedLayerIds.forEach((id) => {
|
|
441
|
+
const layer = layerManager.layerConfigs[id];
|
|
442
|
+
const {prev, next, childHeader, childTail, pid} = layer;
|
|
443
|
+
updPrev.push({id, prev, next, childHeader, childTail, pid})
|
|
444
|
+
})
|
|
445
|
+
|
|
446
|
+
//执行复制操作
|
|
447
|
+
runInAction(() => {
|
|
448
|
+
const {layerConfigs, controllers, elemConfigs} = layerManager;
|
|
449
|
+
const oldLayerList = ids.map((id) => layerConfigs[id]);
|
|
450
|
+
|
|
451
|
+
//复制数据
|
|
452
|
+
ids.forEach((oldLayerId) => {
|
|
453
|
+
const oldLayer = layerConfigs[oldLayerId];
|
|
454
|
+
const newLayer = cloneDeep(oldLayer);
|
|
455
|
+
newLayer.id = IdGenerate.generateId();
|
|
456
|
+
newLayer.name = oldLayer.name + "-副本";
|
|
457
|
+
newLayer.prev = undefined;
|
|
458
|
+
newLayer.next = undefined;
|
|
459
|
+
if (newLayer.type !== 'group') {
|
|
460
|
+
newLayer.x = newLayer.x! + 10;
|
|
461
|
+
newLayer.y = newLayer.y! + 10;
|
|
462
|
+
}
|
|
463
|
+
layerConfigs[newLayer.id] = newLayer;
|
|
464
|
+
layerIdOldToNew[oldLayerId] = newLayer.id!;
|
|
465
|
+
|
|
466
|
+
//生成新组件配置项数据
|
|
467
|
+
const oldCompController = controllers[oldLayer.id!];
|
|
468
|
+
if (oldCompController) {
|
|
469
|
+
const newConfig = cloneDeep(oldCompController.getConfig());
|
|
470
|
+
newConfig.base.id = newLayer.id;
|
|
471
|
+
elemConfigs![newLayer.id] = newConfig;
|
|
472
|
+
}
|
|
473
|
+
newIds.push(newLayer.id);
|
|
474
|
+
newLayouts.push(newLayer);
|
|
475
|
+
});
|
|
476
|
+
|
|
477
|
+
//更新复制后的图层层级关系
|
|
478
|
+
ids.forEach((oldLayerId) => {
|
|
479
|
+
const oldLayer = layerConfigs[oldLayerId];
|
|
480
|
+
const newLayer = layerConfigs[layerIdOldToNew[oldLayerId]];
|
|
481
|
+
|
|
482
|
+
if (oldLayer.type === 'group') {
|
|
483
|
+
newLayer.childHeader = layerIdOldToNew[LayerUtil.findTopLayerInGroup(oldLayer?.id ?? '', oldLayerList)!];
|
|
484
|
+
newLayer.childTail = layerIdOldToNew[LayerUtil.findBottomLayerInGroup(oldLayer?.id ?? '', oldLayerList)!];
|
|
485
|
+
}
|
|
486
|
+
|
|
487
|
+
//不在分组内的图层
|
|
488
|
+
if (!oldLayer.pid) {
|
|
489
|
+
const oldPrevLayer = layerConfigs[oldLayer.prev!];
|
|
490
|
+
newLayer.prev = oldPrevLayer?.id;
|
|
491
|
+
newLayer.next = oldLayer?.id;
|
|
492
|
+
oldLayer && (oldLayer.prev = newLayer.id);
|
|
493
|
+
oldPrevLayer && (oldPrevLayer.next = newLayer.id);
|
|
494
|
+
if (oldLayer.id === layerManager.layerHeader)
|
|
495
|
+
layerManager.layerHeader = newLayer.id;
|
|
496
|
+
} else {
|
|
497
|
+
//在分组内的图层,且整个分组都需要复制
|
|
498
|
+
if (oldLayer.pid && ids.includes(oldLayer.pid)) {
|
|
499
|
+
newLayer.prev = layerIdOldToNew[oldLayer.prev!];
|
|
500
|
+
newLayer.next = layerIdOldToNew[oldLayer.next!];
|
|
501
|
+
newLayer.pid = layerIdOldToNew[oldLayer.pid!];
|
|
502
|
+
} else { //在分组内,但仅分组内的单个图层复制
|
|
503
|
+
const oldChildPrevLayer = layerConfigs[oldLayer.prev!];
|
|
504
|
+
newLayer.prev = oldChildPrevLayer?.id;
|
|
505
|
+
newLayer.next = oldLayer?.id;
|
|
506
|
+
oldLayer && (oldLayer.prev = newLayer.id);
|
|
507
|
+
oldChildPrevLayer && (oldChildPrevLayer.next = newLayer.id);
|
|
508
|
+
|
|
509
|
+
const parentLayer = layerConfigs[oldLayer.pid!];
|
|
510
|
+
if (parentLayer.childHeader === oldLayer.id)
|
|
511
|
+
parentLayer.childHeader = newLayer.id;
|
|
512
|
+
}
|
|
513
|
+
}
|
|
514
|
+
});
|
|
515
|
+
});
|
|
516
|
+
|
|
517
|
+
//记录操作后数据
|
|
518
|
+
updNext.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail})
|
|
519
|
+
relatedLayerIds.forEach((id) => {
|
|
520
|
+
const layer = layerManager.layerConfigs[id];
|
|
521
|
+
const {prev, next, childHeader, childTail, pid} = layer;
|
|
522
|
+
updNext.push({id, prev, next, childHeader, childTail, pid})
|
|
523
|
+
})
|
|
524
|
+
newIds.forEach((id) => {
|
|
525
|
+
const newLayer = layerManager.layerConfigs[id];
|
|
526
|
+
const newConfig = layerManager.elemConfigs![id];
|
|
527
|
+
if (newLayer.type === 'group')
|
|
528
|
+
addNext.push({id: id, layerConfig: cloneDeep(newLayer)})
|
|
529
|
+
else
|
|
530
|
+
addNext.push({id: id, layerConfig: cloneDeep(newLayer), elemConfig: newConfig})
|
|
531
|
+
})
|
|
532
|
+
|
|
533
|
+
historyOperator.put({
|
|
534
|
+
actions: [
|
|
535
|
+
{type: OperateType.ADD, prev: addPrev, next: addNext},
|
|
536
|
+
{type: OperateType.UPDATE_LAYER, prev: updPrev, next: updNext},
|
|
537
|
+
]
|
|
538
|
+
})
|
|
539
|
+
//多个组件同时复制时,需要计算多选框的新位置
|
|
540
|
+
if (newLayouts.length > 1) {
|
|
541
|
+
const {groupCoordinate, setGroupCoordinate} = eventOperateStore;
|
|
542
|
+
setGroupCoordinate({minX: groupCoordinate.minX! + 10, minY: groupCoordinate.minY! + 10})
|
|
543
|
+
}
|
|
544
|
+
return newIds;
|
|
545
|
+
}
|
|
546
|
+
|
|
547
|
+
public doHideUpd(ids: string[], hide: boolean): void {
|
|
548
|
+
//真实隐藏的数据结构列表
|
|
549
|
+
const realHideList = LayerUtil.combineCalculationsActiveLayers(ids).map(id => ({id, hide}));
|
|
550
|
+
|
|
551
|
+
const prev: IHideOperateData[] = [];
|
|
552
|
+
const next: IHideOperateData[] = [];
|
|
553
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
554
|
+
const {layerConfigs, updateLayer, controllers} = layerManager;
|
|
555
|
+
realHideList.forEach((item) => {
|
|
556
|
+
const {id} = item;
|
|
557
|
+
const oldHideData = layerConfigs[id!];
|
|
558
|
+
prev.push({id, hide: oldHideData.hide!});
|
|
559
|
+
next.push({id, hide});
|
|
560
|
+
})
|
|
561
|
+
const data: IHistoryRecord = {type: OperateType.HIDE, prev, next}
|
|
562
|
+
historyOperator.put({actions: [data]});
|
|
563
|
+
//更新隐藏状态
|
|
564
|
+
updateLayer(realHideList);
|
|
565
|
+
//取消所有选中状态
|
|
566
|
+
eventOperateStore.setTargetIds([]);
|
|
567
|
+
|
|
568
|
+
const {layerInstances} = layerListStore;
|
|
569
|
+
const {menu} = designerLeftStore;
|
|
570
|
+
realHideList && realHideList.forEach((item) => {
|
|
571
|
+
const controller = controllers[item.id!];
|
|
572
|
+
if (controller)
|
|
573
|
+
controller.setVisible(!item.hide);
|
|
574
|
+
if (menu === 'layer-list')
|
|
575
|
+
(layerInstances[item.id!] as BaseLayer)?.changeHide(item.hide);
|
|
576
|
+
})
|
|
577
|
+
}
|
|
578
|
+
|
|
579
|
+
public doLockUpd(items: ILayerItem[]): void {
|
|
580
|
+
const prev: ILockOperateData[] = [];
|
|
581
|
+
const next: ILockOperateData[] = [];
|
|
582
|
+
const {layerConfigs, updateLayer} = window.LC_ENV.currentManager.layerManager!;
|
|
583
|
+
items.forEach((item) => {
|
|
584
|
+
const {id, lock} = item;
|
|
585
|
+
next.push({id: id!, lock: lock!});
|
|
586
|
+
const oldLockData = layerConfigs[id!];
|
|
587
|
+
prev.push({id: id!, lock: oldLockData.lock!});
|
|
588
|
+
})
|
|
589
|
+
const data: IHistoryRecord = {type: OperateType.LOCK, prev, next}
|
|
590
|
+
historyOperator.put({actions: [data]});
|
|
591
|
+
updateLayer(items);
|
|
592
|
+
const {layerInstances} = layerListStore;
|
|
593
|
+
const {menu} = designerLeftStore;
|
|
594
|
+
if (menu === 'layer-list') {
|
|
595
|
+
//更新图层列表
|
|
596
|
+
items.forEach((item) => {
|
|
597
|
+
(layerInstances[item.id!] as Component)?.setState({lock: item.lock})
|
|
598
|
+
})
|
|
599
|
+
}
|
|
600
|
+
}
|
|
601
|
+
|
|
602
|
+
/**
|
|
603
|
+
* 判断是否可以上移图层
|
|
604
|
+
* @param targetIds
|
|
605
|
+
* @private
|
|
606
|
+
*/
|
|
607
|
+
private canMoveUp(targetIds: string[]): boolean {
|
|
608
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
609
|
+
const {layerConfigs} = layerManager;
|
|
610
|
+
const layerHeaderMap: Record<string, string[]> = {};
|
|
611
|
+
|
|
612
|
+
targetIds.forEach((id) => {
|
|
613
|
+
const layer = layerConfigs[id];
|
|
614
|
+
if (layer.pid) {
|
|
615
|
+
const parentLayer = layerConfigs[layer.pid]
|
|
616
|
+
if (parentLayer.childHeader) {
|
|
617
|
+
if (!layerHeaderMap[parentLayer.childHeader])
|
|
618
|
+
layerHeaderMap[parentLayer.childHeader] = [id];
|
|
619
|
+
else
|
|
620
|
+
layerHeaderMap[parentLayer.childHeader].push(id);
|
|
621
|
+
}
|
|
622
|
+
} else {
|
|
623
|
+
if (!layerHeaderMap[layerManager.layerHeader!])
|
|
624
|
+
layerHeaderMap[layerManager.layerHeader!] = [id];
|
|
625
|
+
else
|
|
626
|
+
layerHeaderMap[layerManager.layerHeader!].push(id);
|
|
627
|
+
}
|
|
628
|
+
})
|
|
629
|
+
|
|
630
|
+
for (const [header, layerIds] of Object.entries(layerHeaderMap)) {
|
|
631
|
+
if (layerIds.includes(header!)) {
|
|
632
|
+
let count = 1;
|
|
633
|
+
let layer = layerConfigs[header]
|
|
634
|
+
while (layer.next) {
|
|
635
|
+
layer = layerConfigs[layer.next];
|
|
636
|
+
if (targetIds.includes(layer.id!))
|
|
637
|
+
count++;
|
|
638
|
+
else
|
|
639
|
+
break;
|
|
640
|
+
}
|
|
641
|
+
if (count >= layerIds.length)
|
|
642
|
+
targetIds = targetIds.filter(id => !layerIds.includes(id))
|
|
643
|
+
}
|
|
644
|
+
}
|
|
645
|
+
|
|
646
|
+
return targetIds.length !== 0;
|
|
647
|
+
}
|
|
648
|
+
|
|
649
|
+
/**
|
|
650
|
+
* 判断图层是否可以下移
|
|
651
|
+
* @param targetIds
|
|
652
|
+
* @private
|
|
653
|
+
*/
|
|
654
|
+
private canMoveDown(targetIds: string[]): boolean {
|
|
655
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
656
|
+
const {layerConfigs} = layerManager;
|
|
657
|
+
const layerTailMap: Record<string, string[]> = {};
|
|
658
|
+
|
|
659
|
+
targetIds.forEach((id) => {
|
|
660
|
+
const layer = layerConfigs[id];
|
|
661
|
+
if (layer.pid) {
|
|
662
|
+
const parentLayer = layerConfigs[layer.pid]
|
|
663
|
+
if (parentLayer.childTail) {
|
|
664
|
+
if (!layerTailMap[parentLayer.childTail])
|
|
665
|
+
layerTailMap[parentLayer.childTail] = [id];
|
|
666
|
+
else
|
|
667
|
+
layerTailMap[parentLayer.childTail].push(id);
|
|
668
|
+
}
|
|
669
|
+
} else {
|
|
670
|
+
if (!layerTailMap[layerManager.layerTail!])
|
|
671
|
+
layerTailMap[layerManager.layerTail!] = [id];
|
|
672
|
+
else
|
|
673
|
+
layerTailMap[layerManager.layerTail!].push(id);
|
|
674
|
+
}
|
|
675
|
+
})
|
|
676
|
+
|
|
677
|
+
|
|
678
|
+
for (const [tail, layerIds] of Object.entries(layerTailMap)) {
|
|
679
|
+
if (layerIds.includes(tail!)) {
|
|
680
|
+
let count = 1;
|
|
681
|
+
let layer = layerConfigs[tail]
|
|
682
|
+
while (layer.prev) {
|
|
683
|
+
layer = layerConfigs[layer.prev];
|
|
684
|
+
if (targetIds.includes(layer.id!))
|
|
685
|
+
count++;
|
|
686
|
+
else
|
|
687
|
+
break;
|
|
688
|
+
}
|
|
689
|
+
if (count >= layerIds.length)
|
|
690
|
+
targetIds = targetIds.filter(id => !layerIds.includes(id))
|
|
691
|
+
}
|
|
692
|
+
}
|
|
693
|
+
|
|
694
|
+
return targetIds.length !== 0;
|
|
695
|
+
}
|
|
696
|
+
|
|
697
|
+
public doLayerToTop(): void {
|
|
698
|
+
const {targetIds} = eventOperateStore;
|
|
699
|
+
if (targetIds.length === 0)
|
|
700
|
+
return;
|
|
701
|
+
|
|
702
|
+
if (!this.canMoveUp(targetIds))
|
|
703
|
+
return;
|
|
704
|
+
|
|
705
|
+
const {layerManager} = window.LC_ENV.currentManager!;
|
|
706
|
+
const {layerConfigs} = layerManager!;
|
|
707
|
+
const updPrev: IUpdLayerOperateData[] = [];
|
|
708
|
+
const updNext: IUpdLayerOperateData[] = [];
|
|
709
|
+
|
|
710
|
+
let finalTargetIds = targetIds.filter((id) => {
|
|
711
|
+
const layer = layerConfigs[id];
|
|
712
|
+
return !layer.pid || (layer.pid && !targetIds.includes(layer.pid));
|
|
713
|
+
})
|
|
714
|
+
|
|
715
|
+
//计算相关的图层id
|
|
716
|
+
const relatedLayerIds: Set<string> = new Set();
|
|
717
|
+
relatedLayerIds.add(layerManager?.layerHeader ?? '');
|
|
718
|
+
finalTargetIds.forEach((id) => {
|
|
719
|
+
const layer = layerConfigs[id];
|
|
720
|
+
relatedLayerIds.add(id);
|
|
721
|
+
layer.next && relatedLayerIds.add(layer.next);
|
|
722
|
+
layer.prev && relatedLayerIds.add(layer.prev);
|
|
723
|
+
layer.pid && relatedLayerIds.add(layer.pid);
|
|
724
|
+
});
|
|
725
|
+
|
|
726
|
+
//记录数据修改前状态
|
|
727
|
+
updPrev.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail})
|
|
728
|
+
relatedLayerIds.forEach((id) => {
|
|
729
|
+
const {prev, next, childHeader, childTail} = layerConfigs[id];
|
|
730
|
+
updPrev.push({id, prev, next, childHeader, childTail})
|
|
731
|
+
});
|
|
732
|
+
|
|
733
|
+
//将被操作图层排序
|
|
734
|
+
finalTargetIds = finalTargetIds.sort((prev, next) => {
|
|
735
|
+
const prevLayer = layerConfigs[prev];
|
|
736
|
+
const nextLayer = layerConfigs[next];
|
|
737
|
+
return prevLayer.order! - nextLayer.order!;
|
|
738
|
+
});
|
|
739
|
+
|
|
740
|
+
//修改数据
|
|
741
|
+
runInAction(() => {
|
|
742
|
+
for (let i = 0; i < finalTargetIds.length; i++) {
|
|
743
|
+
const id = finalTargetIds[i];
|
|
744
|
+
const layer = layerConfigs[id];
|
|
745
|
+
const prevLayer = layerConfigs[layer.prev!];
|
|
746
|
+
const nextLayer = layerConfigs[layer.next!];
|
|
747
|
+
if (layer.pid) {
|
|
748
|
+
//组内元素
|
|
749
|
+
const parentLayer = layerConfigs[layer.pid!];
|
|
750
|
+
if (parentLayer.childHeader === id)
|
|
751
|
+
continue;
|
|
752
|
+
const oldHeaderChildLayer = layerConfigs[parentLayer.childHeader!];
|
|
753
|
+
layer.prev = undefined;
|
|
754
|
+
layer.next = parentLayer?.childHeader;
|
|
755
|
+
prevLayer && (prevLayer.next = nextLayer?.id);
|
|
756
|
+
nextLayer && (nextLayer.prev = prevLayer?.id);
|
|
757
|
+
oldHeaderChildLayer && (oldHeaderChildLayer.prev = id);
|
|
758
|
+
parentLayer.childHeader = id;
|
|
759
|
+
if (id === parentLayer.childTail)
|
|
760
|
+
parentLayer.childTail = prevLayer?.id;
|
|
761
|
+
} else {
|
|
762
|
+
//组外元素
|
|
763
|
+
if (layerManager.layerHeader === id)
|
|
764
|
+
continue;
|
|
765
|
+
layer.prev = undefined;
|
|
766
|
+
layer.next = layerManager.layerHeader;
|
|
767
|
+
prevLayer && (prevLayer.next = nextLayer?.id);
|
|
768
|
+
nextLayer && (nextLayer.prev = prevLayer?.id);
|
|
769
|
+
const oldHeaderLayer = layerConfigs[layerManager.layerHeader!];
|
|
770
|
+
oldHeaderLayer && (oldHeaderLayer.prev = id);
|
|
771
|
+
layerManager.layerHeader = id;
|
|
772
|
+
if (id === layerManager.layerTail)
|
|
773
|
+
layerManager.layerTail = prevLayer?.id;
|
|
774
|
+
}
|
|
775
|
+
}
|
|
776
|
+
})
|
|
777
|
+
|
|
778
|
+
//记录数据修改后状态
|
|
779
|
+
updNext.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail})
|
|
780
|
+
relatedLayerIds.forEach((id) => {
|
|
781
|
+
const {prev, next, childHeader, childTail} = layerConfigs[id];
|
|
782
|
+
updNext.push({id, prev, next, childHeader, childTail})
|
|
783
|
+
});
|
|
784
|
+
|
|
785
|
+
historyOperator.put({actions: [{type: OperateType.UPDATE_LAYER, prev: updPrev, next: updNext}]});
|
|
786
|
+
layerManager.reRenderLayer();
|
|
787
|
+
}
|
|
788
|
+
|
|
789
|
+
public doLayerToBottom(): void {
|
|
790
|
+
const {targetIds} = eventOperateStore;
|
|
791
|
+
if (targetIds.length === 0 || !this.canMoveDown(targetIds))
|
|
792
|
+
return;
|
|
793
|
+
|
|
794
|
+
const updPrev: IUpdLayerOperateData[] = [];
|
|
795
|
+
const updNext: IUpdLayerOperateData[] = [];
|
|
796
|
+
const {layerManager} = window.LC_ENV.currentManager!;
|
|
797
|
+
const {layerConfigs} = layerManager;
|
|
798
|
+
|
|
799
|
+
let finalTargetIds = targetIds.filter((id) => {
|
|
800
|
+
const layer = layerConfigs[id];
|
|
801
|
+
return !layer.pid || (layer.pid && !targetIds.includes(layer.pid));
|
|
802
|
+
})
|
|
803
|
+
|
|
804
|
+
//计算相关的图层id
|
|
805
|
+
const relatedLayerIds: Set<string> = new Set();
|
|
806
|
+
relatedLayerIds.add(layerManager.layerTail!)
|
|
807
|
+
finalTargetIds.forEach((id) => {
|
|
808
|
+
const layer = layerConfigs[id];
|
|
809
|
+
relatedLayerIds.add(id);
|
|
810
|
+
layer.next && relatedLayerIds.add(layer.next);
|
|
811
|
+
layer.prev && relatedLayerIds.add(layer.prev);
|
|
812
|
+
layer.pid && relatedLayerIds.add(layer.pid);
|
|
813
|
+
});
|
|
814
|
+
|
|
815
|
+
//记录数据修改前状态
|
|
816
|
+
updPrev.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail})
|
|
817
|
+
relatedLayerIds.forEach((id) => {
|
|
818
|
+
const {prev, next, childHeader, childTail} = layerConfigs[id];
|
|
819
|
+
updPrev.push({id, prev, next, childHeader, childTail})
|
|
820
|
+
});
|
|
821
|
+
|
|
822
|
+
//将被操作图层排序
|
|
823
|
+
finalTargetIds = finalTargetIds.sort((prev, next) => {
|
|
824
|
+
const prevLayer = layerConfigs[prev];
|
|
825
|
+
const nextLayer = layerConfigs[next];
|
|
826
|
+
return nextLayer.order! - prevLayer.order!;
|
|
827
|
+
});
|
|
828
|
+
|
|
829
|
+
//修改数据
|
|
830
|
+
runInAction(() => {
|
|
831
|
+
for (let i = 0; i < finalTargetIds.length; i++) {
|
|
832
|
+
const id = finalTargetIds[i];
|
|
833
|
+
const layer = layerConfigs[id];
|
|
834
|
+
const prevLayer = layerConfigs[layer.prev!];
|
|
835
|
+
const nextLayer = layerConfigs[layer.next!];
|
|
836
|
+
if (layer.pid) {
|
|
837
|
+
//组内元素
|
|
838
|
+
const parentLayer = layerConfigs[layer.pid!];
|
|
839
|
+
if (id === parentLayer.childTail)
|
|
840
|
+
continue;
|
|
841
|
+
const oldTailChildLayer = layerConfigs[parentLayer.childTail!];
|
|
842
|
+
layer.prev = parentLayer.childTail;
|
|
843
|
+
layer.next = undefined;
|
|
844
|
+
prevLayer && (prevLayer.next = nextLayer?.id);
|
|
845
|
+
nextLayer && (nextLayer.prev = prevLayer?.id);
|
|
846
|
+
oldTailChildLayer && (oldTailChildLayer.next = id);
|
|
847
|
+
parentLayer.childTail = id;
|
|
848
|
+
if (id === parentLayer.childHeader)
|
|
849
|
+
parentLayer.childHeader = nextLayer?.id;
|
|
850
|
+
} else {
|
|
851
|
+
//组外元素
|
|
852
|
+
if (layerManager.layerTail === id)
|
|
853
|
+
continue;
|
|
854
|
+
layer.prev = layerManager.layerTail;
|
|
855
|
+
layer.next = undefined;
|
|
856
|
+
prevLayer && (prevLayer.next = nextLayer?.id);
|
|
857
|
+
nextLayer && (nextLayer.prev = prevLayer?.id);
|
|
858
|
+
const oldTailLayer = layerConfigs[layerManager.layerTail!];
|
|
859
|
+
oldTailLayer && (oldTailLayer.next = id);
|
|
860
|
+
layerManager.layerTail = id;
|
|
861
|
+
if (id === layerManager.layerHeader)
|
|
862
|
+
layerManager.layerHeader = nextLayer?.id;
|
|
863
|
+
}
|
|
864
|
+
}
|
|
865
|
+
})
|
|
866
|
+
|
|
867
|
+
//记录数据修改后状态
|
|
868
|
+
updNext.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail})
|
|
869
|
+
relatedLayerIds.forEach((id) => {
|
|
870
|
+
const {prev, next, childHeader, childTail} = layerConfigs[id];
|
|
871
|
+
updNext.push({id, prev, next, childHeader, childTail})
|
|
872
|
+
});
|
|
873
|
+
|
|
874
|
+
historyOperator.put({actions: [{type: OperateType.UPDATE_LAYER, prev: updPrev, next: updNext}]});
|
|
875
|
+
layerManager.reRenderLayer();
|
|
876
|
+
}
|
|
877
|
+
|
|
878
|
+
public doLayerMoveUp(): void {
|
|
879
|
+
let {targetIds} = eventOperateStore;
|
|
880
|
+
if (targetIds.length === 0)
|
|
881
|
+
return;
|
|
882
|
+
|
|
883
|
+
if (!this.canMoveUp(targetIds))
|
|
884
|
+
return;
|
|
885
|
+
|
|
886
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
887
|
+
const {layerConfigs} = layerManager;
|
|
888
|
+
const prev: IUpdLayerOperateData[] = [];
|
|
889
|
+
const next: IUpdLayerOperateData[] = [];
|
|
890
|
+
|
|
891
|
+
//收集相关的图层id
|
|
892
|
+
const relatedLayerIds: Set<string> = new Set();
|
|
893
|
+
targetIds.forEach((id) => {
|
|
894
|
+
const layer = layerConfigs[id];
|
|
895
|
+
const prevLayer = layerConfigs[layer.prev!];
|
|
896
|
+
relatedLayerIds.add(id);
|
|
897
|
+
if (layer && layer.next)
|
|
898
|
+
relatedLayerIds.add(layer.next);
|
|
899
|
+
if (layer && layer.prev)
|
|
900
|
+
relatedLayerIds.add(layer.prev);
|
|
901
|
+
if (prevLayer && prevLayer.prev)
|
|
902
|
+
relatedLayerIds.add(prevLayer.prev!);
|
|
903
|
+
});
|
|
904
|
+
|
|
905
|
+
//将被操作图层排序
|
|
906
|
+
targetIds = targetIds.sort((prev, next) => {
|
|
907
|
+
const prevLayer = layerConfigs[prev];
|
|
908
|
+
const nextLayer = layerConfigs[next];
|
|
909
|
+
return nextLayer.order! - prevLayer.order!;
|
|
910
|
+
});
|
|
911
|
+
|
|
912
|
+
//记录数据变更前状态
|
|
913
|
+
prev.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail})
|
|
914
|
+
relatedLayerIds.forEach((id) => {
|
|
915
|
+
const layer = layerConfigs[id];
|
|
916
|
+
const {childTail, childHeader} = layer;
|
|
917
|
+
prev.push({id, prev: layer.prev, next: layer.next, childHeader, childTail})
|
|
918
|
+
});
|
|
919
|
+
|
|
920
|
+
//变更数据
|
|
921
|
+
runInAction(() => {
|
|
922
|
+
targetIds.forEach((id) => {
|
|
923
|
+
const layer = layerConfigs[id];
|
|
924
|
+
const prevLayer = layerConfigs[layer.prev!];
|
|
925
|
+
const prevPrevLayer = layerConfigs[prevLayer?.prev ?? ''];
|
|
926
|
+
const nextLayer = layerConfigs[layer.next!];
|
|
927
|
+
if (layer.pid) {
|
|
928
|
+
//在分组内
|
|
929
|
+
const parent = layerConfigs[layer.pid];
|
|
930
|
+
if (id !== parent.childHeader) {
|
|
931
|
+
if (layer.prev === parent.childHeader)
|
|
932
|
+
parent.childHeader = id;
|
|
933
|
+
if (id === parent.childTail)
|
|
934
|
+
parent.childTail = layer.prev!;
|
|
935
|
+
layer.prev = prevPrevLayer?.id;
|
|
936
|
+
layer.next = prevLayer?.id;
|
|
937
|
+
if (prevLayer) {
|
|
938
|
+
prevLayer.prev = layer.id
|
|
939
|
+
prevLayer.next = nextLayer?.id
|
|
940
|
+
}
|
|
941
|
+
prevPrevLayer && (prevPrevLayer.next = layer.id)
|
|
942
|
+
nextLayer && (nextLayer.prev = prevLayer?.id)
|
|
943
|
+
}
|
|
944
|
+
} else {
|
|
945
|
+
//不再分组内
|
|
946
|
+
if (id !== layerManager.layerHeader) {
|
|
947
|
+
if (layer.prev === layerManager.layerHeader)
|
|
948
|
+
layerManager.layerHeader = id;
|
|
949
|
+
if (id === layerManager.layerTail)
|
|
950
|
+
layerManager.layerTail = layer.prev!;
|
|
951
|
+
layer.prev = prevPrevLayer?.id;
|
|
952
|
+
layer.next = prevLayer?.id;
|
|
953
|
+
if (prevLayer) {
|
|
954
|
+
prevLayer.prev = layer.id
|
|
955
|
+
prevLayer.next = nextLayer?.id
|
|
956
|
+
}
|
|
957
|
+
prevPrevLayer && (prevPrevLayer.next = layer.id)
|
|
958
|
+
nextLayer && (nextLayer.prev = prevLayer?.id)
|
|
959
|
+
}
|
|
960
|
+
}
|
|
961
|
+
})
|
|
962
|
+
})
|
|
963
|
+
|
|
964
|
+
//记录数据变更后状态
|
|
965
|
+
next.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail})
|
|
966
|
+
relatedLayerIds.forEach((id) => {
|
|
967
|
+
const layer = layerConfigs[id];
|
|
968
|
+
const {childTail, childHeader} = layer;
|
|
969
|
+
next.push({id, prev: layer.prev, next: layer.next, childHeader, childTail})
|
|
970
|
+
});
|
|
971
|
+
historyOperator.put({actions: [{type: OperateType.UPDATE_LAYER, prev, next}]});
|
|
972
|
+
layerManager.reRenderLayer();
|
|
973
|
+
}
|
|
974
|
+
|
|
975
|
+
public doLayerMoveDown(): void {
|
|
976
|
+
let {targetIds} = eventOperateStore;
|
|
977
|
+
if (targetIds.length === 0 || !this.canMoveDown(targetIds))
|
|
978
|
+
return;
|
|
979
|
+
|
|
980
|
+
const {layerManager} = window.LC_ENV.currentManager!;
|
|
981
|
+
const {layerConfigs} = layerManager;
|
|
982
|
+
const prev: IUpdLayerOperateData[] = [];
|
|
983
|
+
const next: IUpdLayerOperateData[] = [];
|
|
984
|
+
|
|
985
|
+
//收集相关的图层id
|
|
986
|
+
const relatedLayerIds: Set<string> = new Set();
|
|
987
|
+
targetIds.forEach((id) => {
|
|
988
|
+
const layer = layerConfigs[id];
|
|
989
|
+
const nextLayer = layerConfigs[layer.next!];
|
|
990
|
+
relatedLayerIds.add(id);
|
|
991
|
+
if (layer && layer.next)
|
|
992
|
+
relatedLayerIds.add(layer.next);
|
|
993
|
+
if (layer && layer.prev)
|
|
994
|
+
relatedLayerIds.add(layer.prev);
|
|
995
|
+
if (nextLayer && nextLayer.next)
|
|
996
|
+
relatedLayerIds.add(nextLayer.next!);
|
|
997
|
+
});
|
|
998
|
+
|
|
999
|
+
//将被操作图层排序
|
|
1000
|
+
targetIds = targetIds.sort((prev, next) => {
|
|
1001
|
+
const prevLayer = layerConfigs[prev];
|
|
1002
|
+
const nextLayer = layerConfigs[next];
|
|
1003
|
+
return prevLayer.order! - nextLayer.order!;
|
|
1004
|
+
});
|
|
1005
|
+
|
|
1006
|
+
//记录数据变更前状态
|
|
1007
|
+
prev.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail})
|
|
1008
|
+
relatedLayerIds.forEach((id) => {
|
|
1009
|
+
const layer = layerConfigs[id];
|
|
1010
|
+
const {childTail, childHeader} = layer;
|
|
1011
|
+
prev.push({id, prev: layer.prev, next: layer.next, childHeader, childTail})
|
|
1012
|
+
});
|
|
1013
|
+
|
|
1014
|
+
//变更数据
|
|
1015
|
+
runInAction(() => {
|
|
1016
|
+
targetIds.forEach((id) => {
|
|
1017
|
+
const layer = layerConfigs[id];
|
|
1018
|
+
const prevLayer = layerConfigs[layer.prev!];
|
|
1019
|
+
const nextLayer = layerConfigs[layer.next!];
|
|
1020
|
+
const nextNextLayer = layerConfigs[nextLayer?.next ?? ''];
|
|
1021
|
+
if (layer.pid) {
|
|
1022
|
+
//在分组内
|
|
1023
|
+
const parent = layerConfigs[layer.pid];
|
|
1024
|
+
if (id !== parent.childTail) {
|
|
1025
|
+
if (layer.next === parent.childTail)
|
|
1026
|
+
parent.childTail = id;
|
|
1027
|
+
if (id === parent.childHeader)
|
|
1028
|
+
parent.childHeader = layer.next!;
|
|
1029
|
+
layer.prev = nextLayer?.id;
|
|
1030
|
+
layer.next = nextNextLayer?.id;
|
|
1031
|
+
if (nextLayer) {
|
|
1032
|
+
nextLayer.prev = prevLayer?.id
|
|
1033
|
+
nextLayer.next = layer.id
|
|
1034
|
+
}
|
|
1035
|
+
prevLayer && (prevLayer.next = nextLayer?.id)
|
|
1036
|
+
nextNextLayer && (nextNextLayer.prev = layer?.id)
|
|
1037
|
+
}
|
|
1038
|
+
} else {
|
|
1039
|
+
//不再分组内
|
|
1040
|
+
if (id !== layerManager.layerTail) {
|
|
1041
|
+
if (layer.next === layerManager.layerTail)
|
|
1042
|
+
layerManager.layerTail = id;
|
|
1043
|
+
if (id === layerManager.layerHeader)
|
|
1044
|
+
layerManager.layerHeader = layer.next!;
|
|
1045
|
+
layer.prev = nextLayer?.id;
|
|
1046
|
+
layer.next = nextNextLayer?.id;
|
|
1047
|
+
if (nextLayer) {
|
|
1048
|
+
nextLayer.prev = prevLayer?.id
|
|
1049
|
+
nextLayer.next = layer.id
|
|
1050
|
+
}
|
|
1051
|
+
prevLayer && (prevLayer.next = nextLayer?.id)
|
|
1052
|
+
nextNextLayer && (nextNextLayer.prev = layer?.id)
|
|
1053
|
+
}
|
|
1054
|
+
}
|
|
1055
|
+
})
|
|
1056
|
+
})
|
|
1057
|
+
|
|
1058
|
+
//记录数据变更后状态
|
|
1059
|
+
next.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail})
|
|
1060
|
+
relatedLayerIds.forEach((id) => {
|
|
1061
|
+
const layer = layerConfigs[id];
|
|
1062
|
+
const {childTail, childHeader} = layer;
|
|
1063
|
+
next.push({id, prev: layer.prev, next: layer.next, childHeader, childTail})
|
|
1064
|
+
});
|
|
1065
|
+
historyOperator.put({actions: [{type: OperateType.UPDATE_LAYER, prev, next}]});
|
|
1066
|
+
layerManager.reRenderLayer();
|
|
1067
|
+
}
|
|
1068
|
+
|
|
1069
|
+
/**
|
|
1070
|
+
* 记录组件配置更新
|
|
1071
|
+
* @param newData
|
|
1072
|
+
* @param oldData
|
|
1073
|
+
*/
|
|
1074
|
+
public doStyleUpd(newData: ConfigureObjectFragments, oldData: ConfigureObjectFragments): void {
|
|
1075
|
+
const {activeElem: {id}} = rightStore;
|
|
1076
|
+
const record: IHistoryRecord = {
|
|
1077
|
+
type: OperateType.UPD_STYLE,
|
|
1078
|
+
prev: {id, data: oldData} as IUpdStyleOperateData,
|
|
1079
|
+
next: {id, data: newData} as IUpdStyleOperateData
|
|
1080
|
+
}
|
|
1081
|
+
historyOperator.put({actions: [record]});
|
|
1082
|
+
}
|
|
1083
|
+
|
|
1084
|
+
/**
|
|
1085
|
+
* 图层编组
|
|
1086
|
+
*/
|
|
1087
|
+
public doGrouping() {
|
|
1088
|
+
let {directSelectedIds: beGroupIds} = eventOperateStore;
|
|
1089
|
+
if (!beGroupIds || beGroupIds.length <= 1)
|
|
1090
|
+
return;
|
|
1091
|
+
//获取编组的基准图层。(以最上层的分组图层优先,最上层的非分组图层次之)
|
|
1092
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
1093
|
+
const {layerConfigs, addItem} = layerManager;
|
|
1094
|
+
const topLayerId = beGroupIds.reduce((prev, next) => {
|
|
1095
|
+
return layerConfigs[prev].order! > layerConfigs[next].order! ? prev : next;
|
|
1096
|
+
}, beGroupIds[0]);
|
|
1097
|
+
const topPrevLayer = layerConfigs[layerConfigs[topLayerId].prev ?? ''];
|
|
1098
|
+
let topNextLayerId = layerConfigs[topLayerId].next ?? '';
|
|
1099
|
+
while (beGroupIds.includes(topNextLayerId)) {
|
|
1100
|
+
topNextLayerId = layerConfigs[topNextLayerId].next!;
|
|
1101
|
+
}
|
|
1102
|
+
const topNextLayer = layerConfigs[topNextLayerId];
|
|
1103
|
+
const originalPid = layerConfigs[topLayerId].pid; //原始pid,如果topLayerId是分组图层,则最终生成的分组和原始图层所在的分组相同。若没有分组,则pid为undefined
|
|
1104
|
+
|
|
1105
|
+
|
|
1106
|
+
//构建新的分组数据
|
|
1107
|
+
const groupId = IdGenerate.generateId();
|
|
1108
|
+
//计算新分组的锁定状态
|
|
1109
|
+
const allLock = beGroupIds.every((id) => layerConfigs[id].lock);
|
|
1110
|
+
//构建新的分组数据
|
|
1111
|
+
const groupItem: ILayerItem = {
|
|
1112
|
+
id: groupId,
|
|
1113
|
+
type: 'group',
|
|
1114
|
+
name: '新建分组',
|
|
1115
|
+
hide: false,
|
|
1116
|
+
lock: allLock,
|
|
1117
|
+
};
|
|
1118
|
+
|
|
1119
|
+
//计算相关图层
|
|
1120
|
+
const relatedLayerIds: Set<string> = new Set();
|
|
1121
|
+
relatedLayerIds.add(layerManager.layerHeader!);
|
|
1122
|
+
beGroupIds.forEach((id) => {
|
|
1123
|
+
const layer = layerConfigs[id];
|
|
1124
|
+
relatedLayerIds.add(id);
|
|
1125
|
+
if (layer.next)
|
|
1126
|
+
relatedLayerIds.add(layer.next);
|
|
1127
|
+
if (layer.prev)
|
|
1128
|
+
relatedLayerIds.add(layer.prev);
|
|
1129
|
+
if (layer.pid)
|
|
1130
|
+
relatedLayerIds.add(layer.pid);
|
|
1131
|
+
});
|
|
1132
|
+
if (layerConfigs[topLayerId].type === 'group')
|
|
1133
|
+
relatedLayerIds.add(layerConfigs[topLayerId].childHeader!);
|
|
1134
|
+
|
|
1135
|
+
//构建操作记录
|
|
1136
|
+
const updPrev: IUpdLayerOperateData[] = [];
|
|
1137
|
+
const updNext: IUpdLayerOperateData[] = [];
|
|
1138
|
+
const addNext: IAddOperateData[] = [];
|
|
1139
|
+
|
|
1140
|
+
//记录操作前状态
|
|
1141
|
+
updPrev.push({layerHeader: layerManager.layerHeader});
|
|
1142
|
+
relatedLayerIds.forEach((id) => {
|
|
1143
|
+
const layer = layerConfigs[id];
|
|
1144
|
+
if (layer.type === 'group')
|
|
1145
|
+
updPrev.push({
|
|
1146
|
+
id,
|
|
1147
|
+
pid: layer.pid,
|
|
1148
|
+
prev: layer.prev,
|
|
1149
|
+
next: layer.next,
|
|
1150
|
+
childHeader: layer.childHeader,
|
|
1151
|
+
childTail: layer.childTail
|
|
1152
|
+
});
|
|
1153
|
+
else
|
|
1154
|
+
updPrev.push({id, pid: layer.pid, prev: layer.prev, next: layer.next});
|
|
1155
|
+
});
|
|
1156
|
+
|
|
1157
|
+
let chileHeader = "";
|
|
1158
|
+
let chileTail = "";
|
|
1159
|
+
//修改数据
|
|
1160
|
+
runInAction(() => {
|
|
1161
|
+
//对目标图层排序
|
|
1162
|
+
beGroupIds = beGroupIds.sort((prev, next) => {
|
|
1163
|
+
const prevLayer = layerConfigs[prev];
|
|
1164
|
+
const nextLayer = layerConfigs[next];
|
|
1165
|
+
return prevLayer.order! - nextLayer.order!;
|
|
1166
|
+
});
|
|
1167
|
+
beGroupIds.forEach((id) => {
|
|
1168
|
+
const layer = layerConfigs[id];
|
|
1169
|
+
const prevLayer = layerConfigs[layer.prev!];
|
|
1170
|
+
const nextLayer = layerConfigs[layer.next!];
|
|
1171
|
+
const parentLayer = layerConfigs[layer.pid!];
|
|
1172
|
+
|
|
1173
|
+
if (layerManager.layerHeader === id)
|
|
1174
|
+
layerManager.layerHeader = groupItem.id;
|
|
1175
|
+
if (layerManager.layerTail === id) {
|
|
1176
|
+
//如果当前图层加入分组前layer.prev指向为undefined,则说明所有图层都加入了分组,则最新的layerManager.layerTail指向本次分组的id
|
|
1177
|
+
layerManager.layerTail = layer.prev || groupItem.id;
|
|
1178
|
+
}
|
|
1179
|
+
const topIsHeader = parentLayer?.childHeader === id;
|
|
1180
|
+
const topIsTail = parentLayer?.childTail === id;
|
|
1181
|
+
if (parentLayer?.childHeader === id)
|
|
1182
|
+
parentLayer.childHeader = layer.next!;
|
|
1183
|
+
if (parentLayer?.childTail === id)
|
|
1184
|
+
parentLayer.childTail = layer.prev!;
|
|
1185
|
+
if (topIsHeader && topLayerId === id)
|
|
1186
|
+
parentLayer.childHeader = groupId;
|
|
1187
|
+
if (topIsTail && topLayerId === id)
|
|
1188
|
+
parentLayer.childTail = groupId;
|
|
1189
|
+
|
|
1190
|
+
layer.pid = groupId;
|
|
1191
|
+
//prev图层和next图层建立联系
|
|
1192
|
+
prevLayer && (prevLayer.next = layer.next);
|
|
1193
|
+
nextLayer && (nextLayer.prev = layer.prev);
|
|
1194
|
+
//清空原有图层的prev和next指针
|
|
1195
|
+
layer.prev = undefined;
|
|
1196
|
+
layer.next = undefined;
|
|
1197
|
+
|
|
1198
|
+
//头插法建立子双向链表
|
|
1199
|
+
if (chileHeader) {
|
|
1200
|
+
const oldChildHeader = layerConfigs[chileHeader];
|
|
1201
|
+
oldChildHeader.prev = id;
|
|
1202
|
+
layer.next = chileHeader;
|
|
1203
|
+
} else {
|
|
1204
|
+
chileTail = id;
|
|
1205
|
+
}
|
|
1206
|
+
chileHeader = id;
|
|
1207
|
+
});
|
|
1208
|
+
groupItem.childHeader = chileHeader;
|
|
1209
|
+
groupItem.childTail = chileTail;
|
|
1210
|
+
groupItem.pid = originalPid;
|
|
1211
|
+
//将新生成的分组加入到topPreLayer之后
|
|
1212
|
+
groupItem.prev = topPrevLayer?.id;
|
|
1213
|
+
topPrevLayer && (topPrevLayer.next = groupId);
|
|
1214
|
+
groupItem.next = topNextLayer?.id;
|
|
1215
|
+
topNextLayer && (topNextLayer.prev = groupId);
|
|
1216
|
+
|
|
1217
|
+
if (!groupItem.next && !groupItem.pid) {
|
|
1218
|
+
//如果分组加入图层队列链表后后继节点及父节点都为空,则说明分组加入图层队列链表后为最后一个图层。则将layerManager.layerTail指向此分组
|
|
1219
|
+
layerManager.layerTail = groupId;
|
|
1220
|
+
}
|
|
1221
|
+
});
|
|
1222
|
+
addItem(groupItem);
|
|
1223
|
+
//记录操作后状态
|
|
1224
|
+
updNext.push({layerHeader: layerManager.layerHeader});
|
|
1225
|
+
relatedLayerIds.forEach((id) => {
|
|
1226
|
+
const layer = layerConfigs[id];
|
|
1227
|
+
if (layer.type === 'group')
|
|
1228
|
+
updNext.push({
|
|
1229
|
+
id,
|
|
1230
|
+
pid: layer.pid,
|
|
1231
|
+
prev: layer.prev,
|
|
1232
|
+
next: layer.next,
|
|
1233
|
+
childHeader: layer.childHeader,
|
|
1234
|
+
childTail: layer.childTail
|
|
1235
|
+
});
|
|
1236
|
+
else
|
|
1237
|
+
updNext.push({id, pid: layer.pid, prev: layer.prev, next: layer.next});
|
|
1238
|
+
});
|
|
1239
|
+
addNext.push({id: groupId, layerConfig: groupItem});
|
|
1240
|
+
historyOperator.put({
|
|
1241
|
+
actions: [
|
|
1242
|
+
{type: OperateType.ADD, prev: null, next: addNext},
|
|
1243
|
+
{type: OperateType.UPDATE_LAYER, prev: updPrev, next: updNext}
|
|
1244
|
+
]
|
|
1245
|
+
});
|
|
1246
|
+
eventOperateStore.setTargetIds([]);
|
|
1247
|
+
//特殊场景处理,如果编组时,所有的子图层都处于锁定状态,则编组后,编组图层也处于锁定状态
|
|
1248
|
+
if (allLock) {
|
|
1249
|
+
const {layerInstances} = layerListStore;
|
|
1250
|
+
const groupTimer = setTimeout(() => {
|
|
1251
|
+
(layerInstances[groupId] as Component).setState({lock: true});
|
|
1252
|
+
clearTimeout(groupTimer);
|
|
1253
|
+
}, 10);
|
|
1254
|
+
}
|
|
1255
|
+
}
|
|
1256
|
+
|
|
1257
|
+
public doUnGrouping() {
|
|
1258
|
+
//如果蓝图中使用了分组图层节点,则需要先删除蓝图中的组件和连线,且蓝图中的删除操作目前无法回退
|
|
1259
|
+
const {directSelectedIds, setTargetIds} = eventOperateStore;
|
|
1260
|
+
if (directSelectedIds.length === 0)
|
|
1261
|
+
return;
|
|
1262
|
+
const {bluePrintManager, layerManager} = window.LC_ENV.currentManager;
|
|
1263
|
+
const {layerConfigs, delLayout} = layerManager;
|
|
1264
|
+
const groupIds = directSelectedIds.filter((id: string) => layerConfigs[id].type === 'group');
|
|
1265
|
+
if (directSelectedIds && directSelectedIds.length > 0) {
|
|
1266
|
+
const {delNode, currentPageManager} = bluePrintManager;
|
|
1267
|
+
const {bpNodeLayoutMap} = currentPageManager!;
|
|
1268
|
+
const preDelNodeIds: string[] = [];
|
|
1269
|
+
groupIds.forEach((id: string) => {
|
|
1270
|
+
if (bpNodeLayoutMap[id])
|
|
1271
|
+
preDelNodeIds.push(id);
|
|
1272
|
+
});
|
|
1273
|
+
if (preDelNodeIds.length > 0)
|
|
1274
|
+
delNode(preDelNodeIds);
|
|
1275
|
+
}
|
|
1276
|
+
|
|
1277
|
+
//对每个分组图层进行解组
|
|
1278
|
+
const updPrev: IUpdLayerOperateData[] = [];
|
|
1279
|
+
const updNext: IUpdLayerOperateData[] = [];
|
|
1280
|
+
const delPrev: IDelOperateData[] = [];
|
|
1281
|
+
|
|
1282
|
+
const relatedLayerIds: Set<string> = new Set();
|
|
1283
|
+
groupIds.forEach((id) => {
|
|
1284
|
+
const groupLayer = layerConfigs[id];
|
|
1285
|
+
if (groupLayer.next)
|
|
1286
|
+
relatedLayerIds.add(groupLayer.next);
|
|
1287
|
+
if (groupLayer.prev)
|
|
1288
|
+
relatedLayerIds.add(groupLayer.prev);
|
|
1289
|
+
if (groupLayer.childHeader) {
|
|
1290
|
+
let childLayer = layerConfigs[groupLayer.childHeader];
|
|
1291
|
+
if (childLayer)
|
|
1292
|
+
relatedLayerIds.add(childLayer.id!)
|
|
1293
|
+
while (childLayer?.next) {
|
|
1294
|
+
childLayer = layerConfigs[childLayer.next];
|
|
1295
|
+
if (childLayer)
|
|
1296
|
+
relatedLayerIds.add(childLayer.id!)
|
|
1297
|
+
}
|
|
1298
|
+
}
|
|
1299
|
+
});
|
|
1300
|
+
|
|
1301
|
+
//记录操作前状态
|
|
1302
|
+
updPrev.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail});
|
|
1303
|
+
relatedLayerIds.forEach((id) => {
|
|
1304
|
+
const layer = layerConfigs[id];
|
|
1305
|
+
if (layer) {
|
|
1306
|
+
const {prev, next, pid, childHeader, childTail} = layer;
|
|
1307
|
+
updPrev.push({id, prev, next, pid, childHeader, childTail});
|
|
1308
|
+
}
|
|
1309
|
+
});
|
|
1310
|
+
groupIds.forEach((id) => {
|
|
1311
|
+
delPrev.push({id, layerConfig: cloneDeep(layerConfigs[id])})
|
|
1312
|
+
})
|
|
1313
|
+
|
|
1314
|
+
//修改数据
|
|
1315
|
+
runInAction(() => {
|
|
1316
|
+
groupIds.forEach((groupId: string) => {
|
|
1317
|
+
const layer = layerConfigs[groupId];
|
|
1318
|
+
const prevLayer = layerConfigs[layer.prev!];
|
|
1319
|
+
const nextLayer = layerConfigs[layer.next!];
|
|
1320
|
+
const childHeaderLayer = layerConfigs[layer.childHeader!];
|
|
1321
|
+
const childTailLayer = layerConfigs[layer.childTail!];
|
|
1322
|
+
//分组下是否有子图层
|
|
1323
|
+
const hasChild = childHeaderLayer && childTailLayer;
|
|
1324
|
+
if (hasChild) {
|
|
1325
|
+
childHeaderLayer && (childHeaderLayer.prev = prevLayer?.id)
|
|
1326
|
+
childTailLayer && (childTailLayer.next = nextLayer?.id)
|
|
1327
|
+
prevLayer && (prevLayer.next = childHeaderLayer?.id)
|
|
1328
|
+
nextLayer && (nextLayer.prev = childTailLayer?.id)
|
|
1329
|
+
|
|
1330
|
+
let childNext = layer.childHeader;
|
|
1331
|
+
while (childNext) {
|
|
1332
|
+
const childLayer = layerConfigs[childNext];
|
|
1333
|
+
childLayer && (childLayer.pid = layer.pid)
|
|
1334
|
+
childNext = childLayer?.next;
|
|
1335
|
+
}
|
|
1336
|
+
|
|
1337
|
+
if (groupId === layerManager.layerHeader)
|
|
1338
|
+
layerManager.layerHeader = layer.childHeader;
|
|
1339
|
+
if (groupId === layerManager.layerTail)
|
|
1340
|
+
layerManager.layerTail = layer.childTail;
|
|
1341
|
+
} else {
|
|
1342
|
+
prevLayer && (prevLayer.next = nextLayer?.id)
|
|
1343
|
+
nextLayer && (nextLayer.prev = prevLayer?.id)
|
|
1344
|
+
if (groupId === layerManager.layerHeader)
|
|
1345
|
+
layerManager.layerHeader = nextLayer?.id;
|
|
1346
|
+
if (groupId === layerManager.layerTail)
|
|
1347
|
+
layerManager.layerTail = prevLayer?.id;
|
|
1348
|
+
}
|
|
1349
|
+
});
|
|
1350
|
+
});
|
|
1351
|
+
|
|
1352
|
+
//记录操作后数据
|
|
1353
|
+
updNext.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail});
|
|
1354
|
+
relatedLayerIds.forEach((id) => {
|
|
1355
|
+
const layer = layerConfigs[id];
|
|
1356
|
+
const {prev, next, pid, childHeader, childTail} = layer;
|
|
1357
|
+
updNext.push({id, prev, next, pid, childHeader, childTail});
|
|
1358
|
+
});
|
|
1359
|
+
|
|
1360
|
+
delLayout(groupIds);
|
|
1361
|
+
|
|
1362
|
+
const actions: IHistoryRecord[] = [
|
|
1363
|
+
{type: OperateType.UPDATE_LAYER, prev: updPrev, next: updNext},
|
|
1364
|
+
{type: OperateType.DEL, prev: delPrev, next: null}
|
|
1365
|
+
];
|
|
1366
|
+
historyOperator.put({actions});
|
|
1367
|
+
//清空组件选中状态
|
|
1368
|
+
setTargetIds([]);
|
|
1369
|
+
//处理右侧设置项,如果为当前选中的分组图层,则卸载该设置项(因为分组图层已经被删除)
|
|
1370
|
+
const {activeElem, activeConfig, setContentVisible} = rightStore;
|
|
1371
|
+
if (activeElem && groupIds.includes(activeElem.id!)) {
|
|
1372
|
+
setContentVisible(false);
|
|
1373
|
+
activeConfig(null, "");
|
|
1374
|
+
}
|
|
1375
|
+
}
|
|
1376
|
+
|
|
1377
|
+
public doRemoveFromGroup() {
|
|
1378
|
+
const {targetIds} = eventOperateStore;
|
|
1379
|
+
if (targetIds.length === 0)
|
|
1380
|
+
return;
|
|
1381
|
+
//筛选出目标图层
|
|
1382
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
1383
|
+
const {layerConfigs} = layerManager;
|
|
1384
|
+
const finalTargetIds = targetIds.filter(id => {
|
|
1385
|
+
const layer = layerConfigs[id];
|
|
1386
|
+
return layer.pid && !targetIds.includes(layer.pid)
|
|
1387
|
+
})
|
|
1388
|
+
|
|
1389
|
+
const updPrev: IUpdLayerOperateData[] = [];
|
|
1390
|
+
const updNext: IUpdLayerOperateData[] = [];
|
|
1391
|
+
|
|
1392
|
+
//计算关联图层id
|
|
1393
|
+
const relateIds = new Set<string>();
|
|
1394
|
+
relateIds.add(layerManager.layerHeader!);
|
|
1395
|
+
finalTargetIds.forEach(id => {
|
|
1396
|
+
const layer = layerConfigs[id];
|
|
1397
|
+
const parent = layerConfigs[layer.pid!];
|
|
1398
|
+
relateIds.add(layer.id!)
|
|
1399
|
+
if (layer.prev)
|
|
1400
|
+
relateIds.add(layer.prev)
|
|
1401
|
+
if (layer.next)
|
|
1402
|
+
relateIds.add(layer.next)
|
|
1403
|
+
if (parent.childHeader === id || parent.childTail === id)
|
|
1404
|
+
relateIds.add(parent.id!)
|
|
1405
|
+
})
|
|
1406
|
+
|
|
1407
|
+
//记录数据变更前状态
|
|
1408
|
+
updPrev.push({layerHeader: layerManager.layerHeader!, layerTail: layerManager.layerTail!})
|
|
1409
|
+
relateIds.forEach((id) => {
|
|
1410
|
+
const layer = layerConfigs[id];
|
|
1411
|
+
const {prev, next, pid, childHeader, childTail} = layer;
|
|
1412
|
+
updPrev.push({id, prev, next, pid, childHeader, childTail});
|
|
1413
|
+
});
|
|
1414
|
+
|
|
1415
|
+
//修改数据
|
|
1416
|
+
runInAction(() => {
|
|
1417
|
+
finalTargetIds.forEach(id => {
|
|
1418
|
+
const layer = layerConfigs[id];
|
|
1419
|
+
const prevLayer = layerConfigs[layer.prev!];
|
|
1420
|
+
const nextLayer = layerConfigs[layer.next!];
|
|
1421
|
+
const parentLayer = layerConfigs[layer.pid!];
|
|
1422
|
+
const oldHeaderLayer = layerConfigs[layerManager.layerHeader!];
|
|
1423
|
+
|
|
1424
|
+
if (parentLayer.childHeader === id)
|
|
1425
|
+
parentLayer.childHeader = nextLayer?.id;
|
|
1426
|
+
if (parentLayer.childTail === id)
|
|
1427
|
+
parentLayer.childTail = prevLayer?.id;
|
|
1428
|
+
|
|
1429
|
+
layer.pid = undefined;
|
|
1430
|
+
layer.prev = undefined;
|
|
1431
|
+
layer.next = layerManager.layerHeader;
|
|
1432
|
+
oldHeaderLayer.prev = layer.id;
|
|
1433
|
+
layerManager.layerHeader = layer.id;
|
|
1434
|
+
|
|
1435
|
+
prevLayer && (prevLayer.next = nextLayer?.id)
|
|
1436
|
+
nextLayer && (nextLayer.prev = prevLayer?.id)
|
|
1437
|
+
})
|
|
1438
|
+
})
|
|
1439
|
+
|
|
1440
|
+
//记录数据变更后状态
|
|
1441
|
+
updNext.push({layerHeader: layerManager.layerHeader!, layerTail: layerManager.layerTail!})
|
|
1442
|
+
relateIds.forEach((id) => {
|
|
1443
|
+
const layer = layerConfigs[id];
|
|
1444
|
+
const {prev, next, pid, childHeader, childTail} = layer;
|
|
1445
|
+
updNext.push({id, prev, next, pid, childHeader, childTail});
|
|
1446
|
+
});
|
|
1447
|
+
|
|
1448
|
+
historyOperator.put({actions: [{type: OperateType.UPDATE_LAYER, prev: updPrev, next: updNext}]});
|
|
1449
|
+
layerManager.reRenderLayer();
|
|
1450
|
+
}
|
|
1451
|
+
|
|
1452
|
+
/**
|
|
1453
|
+
* 将source图层移动到target图层上方
|
|
1454
|
+
* @param sourceId
|
|
1455
|
+
* @param targetId
|
|
1456
|
+
*/
|
|
1457
|
+
public layerDragMove(sourceId: string, targetId: string) {
|
|
1458
|
+
if (!sourceId || !targetId || sourceId === targetId)
|
|
1459
|
+
return;
|
|
1460
|
+
if (LayerUtil.isTargetChild(targetId, sourceId))
|
|
1461
|
+
return;
|
|
1462
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
1463
|
+
const {layerConfigs} = layerManager;
|
|
1464
|
+
const sourceLayer = layerConfigs[sourceId];
|
|
1465
|
+
const sourcePrevLayer = layerConfigs[sourceLayer.prev!];
|
|
1466
|
+
const sourceNextLayer = layerConfigs[sourceLayer.next!];
|
|
1467
|
+
const targetLayer = layerConfigs[targetId];
|
|
1468
|
+
const targetPrevLayer = layerConfigs[targetLayer.prev!];
|
|
1469
|
+
if (!sourceLayer || !targetLayer || targetLayer.id === sourceLayer.next)
|
|
1470
|
+
return;
|
|
1471
|
+
|
|
1472
|
+
//对每个分组图层进行解组
|
|
1473
|
+
const updPrev: IUpdLayerOperateData[] = [];
|
|
1474
|
+
const updNext: IUpdLayerOperateData[] = [];
|
|
1475
|
+
|
|
1476
|
+
const relatedLayerIds: Set<string> = new Set([sourceId, targetId]);
|
|
1477
|
+
[sourceId, targetId].forEach((id) => {
|
|
1478
|
+
const layer = layerConfigs[id];
|
|
1479
|
+
layer.next && relatedLayerIds.add(layer.next);
|
|
1480
|
+
layer.prev && relatedLayerIds.add(layer.prev);
|
|
1481
|
+
layer.pid && relatedLayerIds.add(layer.pid);
|
|
1482
|
+
});
|
|
1483
|
+
|
|
1484
|
+
//记录操作前状态
|
|
1485
|
+
updPrev.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail});
|
|
1486
|
+
relatedLayerIds.forEach((id) => {
|
|
1487
|
+
const layer = layerConfigs[id];
|
|
1488
|
+
const {prev, next, pid, childHeader, childTail} = layer;
|
|
1489
|
+
updPrev.push({id, prev, next, pid, childHeader, childTail});
|
|
1490
|
+
});
|
|
1491
|
+
|
|
1492
|
+
runInAction(() => {
|
|
1493
|
+
//如果被过拽的图层恰好是整个图层的末尾元素
|
|
1494
|
+
if (layerManager.layerTail === sourceId)
|
|
1495
|
+
layerManager.layerTail = sourcePrevLayer?.id;
|
|
1496
|
+
|
|
1497
|
+
sourcePrevLayer && (sourcePrevLayer.next = sourceNextLayer?.id);
|
|
1498
|
+
sourceNextLayer && (sourceNextLayer.prev = sourcePrevLayer?.id);
|
|
1499
|
+
|
|
1500
|
+
sourceLayer.prev = targetPrevLayer?.id;
|
|
1501
|
+
sourceLayer.next = targetLayer.id;
|
|
1502
|
+
targetPrevLayer && (targetPrevLayer.next = sourceLayer.id);
|
|
1503
|
+
targetLayer.prev = sourceLayer.id;
|
|
1504
|
+
|
|
1505
|
+
if (layerManager.layerHeader === sourceLayer.id)
|
|
1506
|
+
layerManager.layerHeader = sourceNextLayer.id;
|
|
1507
|
+
if (layerManager.layerHeader === targetLayer.id)
|
|
1508
|
+
layerManager.layerHeader = sourceLayer.id;
|
|
1509
|
+
|
|
1510
|
+
//原图层在分组内
|
|
1511
|
+
if (sourceLayer.pid) {
|
|
1512
|
+
const sourceParentLayer = layerConfigs[sourceLayer.pid!];
|
|
1513
|
+
if (sourceParentLayer) {
|
|
1514
|
+
if (sourceParentLayer.childHeader === sourceLayer.id)
|
|
1515
|
+
sourceParentLayer.childHeader = sourceNextLayer?.id;
|
|
1516
|
+
if (sourceParentLayer.childTail === sourceLayer.id)
|
|
1517
|
+
sourceParentLayer.childTail = sourcePrevLayer?.id;
|
|
1518
|
+
}
|
|
1519
|
+
sourceLayer.pid = undefined;
|
|
1520
|
+
}
|
|
1521
|
+
|
|
1522
|
+
//目标图层在分组内
|
|
1523
|
+
if (targetLayer.pid) {
|
|
1524
|
+
const targetParentLayer = layerConfigs[targetLayer.pid!];
|
|
1525
|
+
if (targetParentLayer) {
|
|
1526
|
+
sourceLayer.pid = targetParentLayer.id
|
|
1527
|
+
if (targetParentLayer.childHeader === targetLayer.id)
|
|
1528
|
+
targetParentLayer.childHeader = sourceLayer.id;
|
|
1529
|
+
}
|
|
1530
|
+
}
|
|
1531
|
+
})
|
|
1532
|
+
|
|
1533
|
+
//记录操作后数据
|
|
1534
|
+
updNext.push({layerHeader: layerManager.layerHeader, layerTail: layerManager.layerTail});
|
|
1535
|
+
relatedLayerIds.forEach((id) => {
|
|
1536
|
+
const layer = layerConfigs[id];
|
|
1537
|
+
const {prev, next, pid, childHeader, childTail} = layer;
|
|
1538
|
+
updNext.push({id, prev, next, pid, childHeader, childTail});
|
|
1539
|
+
});
|
|
1540
|
+
const actions: IHistoryRecord[] = [{type: OperateType.UPDATE_LAYER, prev: updPrev, next: updNext}];
|
|
1541
|
+
historyOperator.put({actions});
|
|
1542
|
+
|
|
1543
|
+
layerManager.reRenderLayer();
|
|
1544
|
+
}
|
|
1545
|
+
|
|
1546
|
+
/**
|
|
1547
|
+
* 组内上对其
|
|
1548
|
+
*/
|
|
1549
|
+
public groupTopAligned() {
|
|
1550
|
+
//日志记录
|
|
1551
|
+
const updPrev: IUpdLayerOperateData[] = [];
|
|
1552
|
+
const updNext: IUpdLayerOperateData[] = [];
|
|
1553
|
+
|
|
1554
|
+
const {targetIds, setTargetIds} = eventOperateStore;
|
|
1555
|
+
|
|
1556
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
1557
|
+
//记录变更前数据
|
|
1558
|
+
targetIds.forEach(id => {
|
|
1559
|
+
const layer = layerManager.layerConfigs[id];
|
|
1560
|
+
updPrev.push({id, y: layer.y});
|
|
1561
|
+
});
|
|
1562
|
+
|
|
1563
|
+
//变更数据
|
|
1564
|
+
const coordinate = CoordinateUtil.calculateGroupRect(targetIds, layerManager.layerConfigs);
|
|
1565
|
+
targetIds.forEach(id => {
|
|
1566
|
+
const layer = layerManager.layerConfigs[id];
|
|
1567
|
+
layer.y = coordinate.minY;
|
|
1568
|
+
});
|
|
1569
|
+
|
|
1570
|
+
//记录变更后的数据
|
|
1571
|
+
targetIds.forEach(id => {
|
|
1572
|
+
const layer = layerManager.layerConfigs[id];
|
|
1573
|
+
updNext.push({id, y: layer.y});
|
|
1574
|
+
});
|
|
1575
|
+
|
|
1576
|
+
//写入日志
|
|
1577
|
+
historyOperator.put({actions: [{type: OperateType.UPDATE_LAYER, prev: updPrev, next: updNext}]});
|
|
1578
|
+
|
|
1579
|
+
//重新选中最新位置的包围盒
|
|
1580
|
+
setTargetIds([]);
|
|
1581
|
+
Promise.resolve().then(() => setTargetIds(targetIds));
|
|
1582
|
+
layerManager.reRenderLayer();
|
|
1583
|
+
}
|
|
1584
|
+
|
|
1585
|
+
/**
|
|
1586
|
+
* 组内下对齐
|
|
1587
|
+
*/
|
|
1588
|
+
public groupBottomAligned() {
|
|
1589
|
+
//日志记录
|
|
1590
|
+
const updPrev: IUpdLayerOperateData[] = [];
|
|
1591
|
+
const updNext: IUpdLayerOperateData[] = [];
|
|
1592
|
+
|
|
1593
|
+
const {targetIds, setTargetIds} = eventOperateStore;
|
|
1594
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
1595
|
+
//记录变更前数据
|
|
1596
|
+
targetIds.forEach(id => {
|
|
1597
|
+
const layer = layerManager.layerConfigs[id];
|
|
1598
|
+
updPrev.push({id, y: layer.y});
|
|
1599
|
+
});
|
|
1600
|
+
|
|
1601
|
+
const coordinate = CoordinateUtil.calculateGroupRectLT(targetIds, layerManager.layerConfigs);
|
|
1602
|
+
targetIds.forEach(id => {
|
|
1603
|
+
const layer = layerManager.layerConfigs[id];
|
|
1604
|
+
layer.y = coordinate.maxY;
|
|
1605
|
+
});
|
|
1606
|
+
|
|
1607
|
+
//记录变更后的数据
|
|
1608
|
+
targetIds.forEach(id => {
|
|
1609
|
+
const layer = layerManager.layerConfigs[id];
|
|
1610
|
+
updNext.push({id, y: layer.y});
|
|
1611
|
+
});
|
|
1612
|
+
|
|
1613
|
+
//写入日志
|
|
1614
|
+
historyOperator.put({actions: [{type: OperateType.UPDATE_LAYER, prev: updPrev, next: updNext}]});
|
|
1615
|
+
|
|
1616
|
+
//重新选中最新位置的包围盒
|
|
1617
|
+
setTargetIds([]);
|
|
1618
|
+
Promise.resolve().then(() => setTargetIds(targetIds));
|
|
1619
|
+
layerManager.reRenderLayer();
|
|
1620
|
+
}
|
|
1621
|
+
|
|
1622
|
+
/**
|
|
1623
|
+
* 组内左对齐
|
|
1624
|
+
*/
|
|
1625
|
+
public groupLeftAligned() {
|
|
1626
|
+
//日志记录
|
|
1627
|
+
const updPrev: IUpdLayerOperateData[] = [];
|
|
1628
|
+
const updNext: IUpdLayerOperateData[] = [];
|
|
1629
|
+
|
|
1630
|
+
const {targetIds, setTargetIds} = eventOperateStore;
|
|
1631
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
1632
|
+
//记录变更前数据
|
|
1633
|
+
targetIds.forEach(id => {
|
|
1634
|
+
const layer = layerManager.layerConfigs[id];
|
|
1635
|
+
updPrev.push({id, x: layer.x});
|
|
1636
|
+
});
|
|
1637
|
+
|
|
1638
|
+
const coordinate = CoordinateUtil.calculateGroupRect(targetIds, layerManager.layerConfigs);
|
|
1639
|
+
targetIds.forEach(id => {
|
|
1640
|
+
const layer = layerManager.layerConfigs[id];
|
|
1641
|
+
layer.x = coordinate.minX;
|
|
1642
|
+
});
|
|
1643
|
+
|
|
1644
|
+
//记录变更后的数据
|
|
1645
|
+
targetIds.forEach(id => {
|
|
1646
|
+
const layer = layerManager.layerConfigs[id];
|
|
1647
|
+
updNext.push({id, x: layer.x});
|
|
1648
|
+
});
|
|
1649
|
+
|
|
1650
|
+
//写入日志
|
|
1651
|
+
historyOperator.put({actions: [{type: OperateType.UPDATE_LAYER, prev: updPrev, next: updNext}]});
|
|
1652
|
+
|
|
1653
|
+
//重新选中最新位置的包围盒
|
|
1654
|
+
setTargetIds([]);
|
|
1655
|
+
Promise.resolve().then(() => setTargetIds(targetIds));
|
|
1656
|
+
layerManager.reRenderLayer();
|
|
1657
|
+
}
|
|
1658
|
+
|
|
1659
|
+
/**
|
|
1660
|
+
* 组内右对齐
|
|
1661
|
+
*/
|
|
1662
|
+
public groupRightAligned() {
|
|
1663
|
+
//日志记录
|
|
1664
|
+
const updPrev: IUpdLayerOperateData[] = [];
|
|
1665
|
+
const updNext: IUpdLayerOperateData[] = [];
|
|
1666
|
+
|
|
1667
|
+
const {targetIds, setTargetIds} = eventOperateStore;
|
|
1668
|
+
const {layerManager} = window.LC_ENV.currentManager;
|
|
1669
|
+
//记录变更前数据
|
|
1670
|
+
targetIds.forEach(id => {
|
|
1671
|
+
const layer = layerManager.layerConfigs[id];
|
|
1672
|
+
updPrev.push({id, x: layer.x});
|
|
1673
|
+
});
|
|
1674
|
+
|
|
1675
|
+
const coordinate = CoordinateUtil.calculateGroupRectLT(targetIds, layerManager.layerConfigs);
|
|
1676
|
+
targetIds.forEach(id => {
|
|
1677
|
+
const layer = layerManager.layerConfigs[id];
|
|
1678
|
+
layer.x = coordinate.maxX;
|
|
1679
|
+
});
|
|
1680
|
+
|
|
1681
|
+
//记录变更后的数据
|
|
1682
|
+
targetIds.forEach(id => {
|
|
1683
|
+
const layer = layerManager.layerConfigs[id];
|
|
1684
|
+
updNext.push({id, x: layer.x});
|
|
1685
|
+
});
|
|
1686
|
+
|
|
1687
|
+
//写入日志
|
|
1688
|
+
historyOperator.put({actions: [{type: OperateType.UPDATE_LAYER, prev: updPrev, next: updNext}]});
|
|
1689
|
+
|
|
1690
|
+
//重新选中最新位置的包围盒
|
|
1691
|
+
setTargetIds([]);
|
|
1692
|
+
Promise.resolve().then(() => setTargetIds(targetIds));
|
|
1693
|
+
layerManager.reRenderLayer();
|
|
1694
|
+
}
|
|
1695
|
+
|
|
1696
|
+
/**
|
|
1697
|
+
* 创建循环容器
|
|
1698
|
+
*/
|
|
1699
|
+
public createLoopContainer() {
|
|
1700
|
+
const {layerManager, canvasManager: {canvasConfig: {width = 0, height = 0}}} = window.LC_ENV.currentManager;
|
|
1701
|
+
const {layerConfigs, elemConfigs, layerHeader} = layerManager;
|
|
1702
|
+
const {setTargetIds} = eventOperateStore;
|
|
1703
|
+
const loopId = IdGenerate.generateId();
|
|
1704
|
+
const definition = window.LC_ENV.definitions!['LoopContainer'];
|
|
1705
|
+
if (!definition)
|
|
1706
|
+
return;
|
|
1707
|
+
const initConfig = definition.getInitConfig();
|
|
1708
|
+
initConfig.base.id = loopId;
|
|
1709
|
+
const w = 640, h = 400;
|
|
1710
|
+
const x = width / 2 - w / 2, y = height / 2 - h / 2;
|
|
1711
|
+
const loopLayer: ILayerItem = {
|
|
1712
|
+
id: loopId,
|
|
1713
|
+
type: 'LoopContainer',
|
|
1714
|
+
name: '循环容器',
|
|
1715
|
+
hide: false,
|
|
1716
|
+
lock: false,
|
|
1717
|
+
x,
|
|
1718
|
+
y,
|
|
1719
|
+
width: w,
|
|
1720
|
+
height: h,
|
|
1721
|
+
rotate: 0
|
|
1722
|
+
};
|
|
1723
|
+
|
|
1724
|
+
runInAction(() => {
|
|
1725
|
+
const oldHeaderLayer = layerConfigs[layerHeader!];
|
|
1726
|
+
oldHeaderLayer && (oldHeaderLayer.prev = loopId);
|
|
1727
|
+
loopLayer.next = oldHeaderLayer?.id;
|
|
1728
|
+
layerManager.layerHeader = loopId;
|
|
1729
|
+
if (!oldHeaderLayer)
|
|
1730
|
+
layerManager.layerTail = loopId;
|
|
1731
|
+
layerConfigs[loopId] = loopLayer;
|
|
1732
|
+
elemConfigs![loopId] = initConfig;
|
|
1733
|
+
});
|
|
1734
|
+
Promise.resolve().then(() => setTargetIds([loopId]));
|
|
1735
|
+
}
|
|
1736
|
+
|
|
1737
|
+
}
|
|
1738
|
+
|
|
1739
|
+
const historyRecordOperateProxy = new HistoryRecordOperateProxy();
|
|
1740
|
+
export default historyRecordOperateProxy;
|