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,315 @@
|
|
|
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 {ColorPicker as AntdColorPicker, ConfigProvider, InputNumber, Slider} from 'antd';
|
|
13
|
+
import {UIContainer, UIContainerProps} from "../ui-container/UIContainer";
|
|
14
|
+
import './ColorPicker.less';
|
|
15
|
+
import {FocusEvent, ReactNode, useEffect, useRef, useState} from "react";
|
|
16
|
+
import {ColorUtil} from "light-chaser-util";
|
|
17
|
+
import {getRecentColors, updateRecentColor} from "./RecentColors.ts";
|
|
18
|
+
|
|
19
|
+
//对比两个等长度数组的元素变化值,返回变化元素的索引值,比如A = [1,2,3] , B=[1,4,3] 则返回下标1, 如果B=[1,3,3] B=[1,3,4] 则返回2. 如果没有变化则返回-1
|
|
20
|
+
function findChangedIndex<T>(oldArr: T[], newArr: T[]): number {
|
|
21
|
+
const indexLimit = Math.min(oldArr.length, newArr.length);
|
|
22
|
+
for (let i = 0; i < indexLimit; i++) {
|
|
23
|
+
if (oldArr[i] !== newArr[i]) {
|
|
24
|
+
return i;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
if (oldArr.length !== newArr.length)
|
|
28
|
+
return indexLimit;
|
|
29
|
+
else
|
|
30
|
+
return -1
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* 判断一个字符串是否是一个合法的颜色值
|
|
35
|
+
* @param color
|
|
36
|
+
*/
|
|
37
|
+
function isValidColor(color: string) {
|
|
38
|
+
const hexRegex = /^#([0-9A-F]{3}|[0-9A-F]{6,8})$/i;
|
|
39
|
+
const rgbRegex = /^rgb\((\d{1,3}),\s*(\d{1,3}),\s*(\d{1,3})\)$/;
|
|
40
|
+
const rgbaRegex = /^rgba\((\d{1,3}),\s*(\d{1,3}),\s*(\d{1,3}),\s*(0|1|0?\.\d+)\)$/;
|
|
41
|
+
const hslRegex = /^hsl\((\d{1,3}),\s*(\d{1,3})%,\s*(\d{1,3})%\)$/;
|
|
42
|
+
const hslaRegex = /^hsla\((\d{1,3}),\s*(\d{1,3})%,\s*(\d{1,3})%,\s*(0|1|0?\.\d+)\)$/;
|
|
43
|
+
return hexRegex.test(color) || rgbRegex.test(color) || rgbaRegex.test(color) || hslRegex.test(color) || hslaRegex.test(color);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* 判断字符串是否一个合法的径向渐变颜色值
|
|
48
|
+
* @param color
|
|
49
|
+
*/
|
|
50
|
+
function isRadialGradient(color: string) {
|
|
51
|
+
const radialGradientRegex = /^radial-gradient\(\s*((circle|ellipse|closest-side|closest-corner|farthest-side|farthest-corner|),)?\s*(((\s*#[0-9a-fA-F]{3,8}|\s*rgba?\([^)]+\))\s+)\d+%,?)+\)$/;
|
|
52
|
+
return radialGradientRegex.test(color);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* 解析颜色值
|
|
57
|
+
* @param color
|
|
58
|
+
*/
|
|
59
|
+
function parseColorValue(color: string) {
|
|
60
|
+
//判断value是否是一个合法的颜色值,
|
|
61
|
+
if (isValidColor(color)) {
|
|
62
|
+
return {
|
|
63
|
+
mode: 'single',
|
|
64
|
+
rawValue: color
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
//判断value是否是线性渐变
|
|
68
|
+
if (color.startsWith('linear-gradient')) {
|
|
69
|
+
return {
|
|
70
|
+
mode: 'linear',
|
|
71
|
+
...ColorUtil.parseLinerGradient(color)
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
//判断value是否是径向渐变
|
|
75
|
+
if (isRadialGradient(color)) {
|
|
76
|
+
return {
|
|
77
|
+
mode: 'radial',
|
|
78
|
+
...ColorUtil.parseRadialGradient(color)
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
type ColorMode = 'single' | 'linear' | 'radial';
|
|
84
|
+
|
|
85
|
+
export interface ColorPickerProps extends UIContainerProps {
|
|
86
|
+
value?: string;
|
|
87
|
+
defaultValue?: string;
|
|
88
|
+
modes?: Array<ColorMode>
|
|
89
|
+
showText?: boolean;
|
|
90
|
+
disabled?: boolean;
|
|
91
|
+
onChange?: (color: string) => void;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
|
|
95
|
+
interface ColorVal {
|
|
96
|
+
mode?: string;
|
|
97
|
+
angle?: number;
|
|
98
|
+
rawValue?: string;
|
|
99
|
+
posArr: number[];
|
|
100
|
+
colorArr: string[];
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
const colorModes = [
|
|
104
|
+
{
|
|
105
|
+
label: '单色',
|
|
106
|
+
value: 'single'
|
|
107
|
+
},
|
|
108
|
+
{
|
|
109
|
+
label: '线性渐变',
|
|
110
|
+
value: 'linear'
|
|
111
|
+
},
|
|
112
|
+
{
|
|
113
|
+
label: '径向渐变',
|
|
114
|
+
value: 'radial'
|
|
115
|
+
}
|
|
116
|
+
]
|
|
117
|
+
|
|
118
|
+
export default function ColorPicker(props: ColorPickerProps) {
|
|
119
|
+
const {value, defaultValue, modes, showText, disabled, onChange, ...containerProps} = props;
|
|
120
|
+
const controlled = value != undefined && defaultValue == undefined;
|
|
121
|
+
const configRef = useRef<ColorVal>({mode: 'single', angle: 90, posArr: [0, 100], colorArr: ['#fff', '#000'], rawValue: '#fff'});
|
|
122
|
+
const [count, setCount] = useState(0);
|
|
123
|
+
const linerSelectedRef = useRef(0);
|
|
124
|
+
const radialSelectedRef = useRef(0);
|
|
125
|
+
|
|
126
|
+
useEffect(() => {
|
|
127
|
+
const finalValue = value || defaultValue || '#fff';
|
|
128
|
+
configRef.current = {...configRef.current, ...parseColorValue(finalValue)} as ColorVal;
|
|
129
|
+
updateColorValue(undefined, false);
|
|
130
|
+
}, controlled ? [props.value] : [])
|
|
131
|
+
|
|
132
|
+
const updateColorValue = (color?: string, triggerChange: boolean = true) => {
|
|
133
|
+
if (configRef.current.mode === 'single') {
|
|
134
|
+
color && (configRef.current.rawValue = color);
|
|
135
|
+
}
|
|
136
|
+
if (configRef.current.mode === 'linear') {
|
|
137
|
+
color && (configRef.current.colorArr[linerSelectedRef.current] = color);
|
|
138
|
+
configRef.current.rawValue = generateLinerGradient();
|
|
139
|
+
}
|
|
140
|
+
if (configRef.current.mode === 'radial') {
|
|
141
|
+
color && (configRef.current.colorArr[radialSelectedRef.current] = color);
|
|
142
|
+
configRef.current.rawValue = generateRadialGradient();
|
|
143
|
+
}
|
|
144
|
+
setCount(count + 1);
|
|
145
|
+
if (triggerChange)
|
|
146
|
+
onChange && onChange(configRef.current.rawValue!);
|
|
147
|
+
updateRecentColor(configRef.current.rawValue!)
|
|
148
|
+
};
|
|
149
|
+
|
|
150
|
+
const linerSlideChange = (value: number[]) => {
|
|
151
|
+
//查找本次修改颜色的索引
|
|
152
|
+
const index = findChangedIndex(configRef.current.posArr, value);
|
|
153
|
+
if (value.length > configRef.current.posArr.length) {
|
|
154
|
+
//增加新的节点
|
|
155
|
+
configRef.current.colorArr.splice(index, 0, configRef.current.colorArr[index - 1])
|
|
156
|
+
} else if (value.length < configRef.current.posArr.length) {
|
|
157
|
+
//删除节点
|
|
158
|
+
configRef.current.colorArr.splice(index, 1);
|
|
159
|
+
}
|
|
160
|
+
configRef.current.posArr = value;
|
|
161
|
+
updateColorValue();
|
|
162
|
+
}
|
|
163
|
+
const linerSlideFocus = (e: FocusEvent) => {
|
|
164
|
+
//匹配e.target.className中数字并提取数字
|
|
165
|
+
const index = e.target.className.match(/\d+/)?.[0];
|
|
166
|
+
linerSelectedRef.current = Number(index) - 1;
|
|
167
|
+
setCount(count + 1);
|
|
168
|
+
}
|
|
169
|
+
const generateLinerGradient = (): string => {
|
|
170
|
+
let linerGradient = "";
|
|
171
|
+
configRef.current.posArr.forEach((v, i) => {
|
|
172
|
+
linerGradient += ` ${configRef.current.colorArr[i]} ${v}%${i === configRef.current.posArr.length - 1 ? '' : ','}`;
|
|
173
|
+
})
|
|
174
|
+
return `linear-gradient(${configRef.current.angle}deg, ${linerGradient})`;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
|
|
178
|
+
const radialSlideChange = (value: number[]) => {
|
|
179
|
+
//查找本次修改颜色的索引
|
|
180
|
+
const index = findChangedIndex(configRef.current.posArr, value);
|
|
181
|
+
if (value.length > configRef.current.posArr.length) {
|
|
182
|
+
//增加新的节点
|
|
183
|
+
configRef.current.colorArr.splice(index, 0, configRef.current.colorArr[index - 1])
|
|
184
|
+
} else if (value.length < configRef.current.posArr.length) {
|
|
185
|
+
//删除节点
|
|
186
|
+
configRef.current.colorArr.splice(index, 1);
|
|
187
|
+
}
|
|
188
|
+
configRef.current.posArr = value;
|
|
189
|
+
updateColorValue();
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
const radialSlideFocus = (e: FocusEvent) => {
|
|
193
|
+
//匹配e.target.className中数字并提取数字
|
|
194
|
+
const index = e.target.className.match(/\d+/)?.[0];
|
|
195
|
+
radialSelectedRef.current = Number(index) - 1;
|
|
196
|
+
setCount(count + 1);
|
|
197
|
+
}
|
|
198
|
+
const generateRadialGradient = (): string => {
|
|
199
|
+
let radialGradient = "";
|
|
200
|
+
configRef.current.posArr.forEach((v, i) => {
|
|
201
|
+
radialGradient += `${configRef.current.colorArr[i]} ${v}%${i === configRef.current.colorArr.length - 1 ? '' : ','}`;
|
|
202
|
+
})
|
|
203
|
+
return `radial-gradient(${radialGradient})`;
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
|
|
207
|
+
const customRender = (panel: ReactNode): ReactNode => {
|
|
208
|
+
return <div className="versatile-color-picker-panel">
|
|
209
|
+
<div className="picker-toolbar" onClick={(e) => {
|
|
210
|
+
const mode = (e.target as HTMLElement)?.dataset?.mode;
|
|
211
|
+
if (mode) {
|
|
212
|
+
configRef.current.mode = mode;
|
|
213
|
+
if (mode === 'single' && !isValidColor(configRef.current.rawValue!))
|
|
214
|
+
configRef.current.rawValue = '#fff';
|
|
215
|
+
updateColorValue();
|
|
216
|
+
}
|
|
217
|
+
}}>
|
|
218
|
+
{
|
|
219
|
+
colorModes.filter(v => modes?.includes(v.value as ColorMode)).map(v => {
|
|
220
|
+
return <div key={v.value} data-mode={v.value} className={`tool-item ${configRef.current.mode === v.value ? 'mode-active' : ''}`}>{v.label}</div>
|
|
221
|
+
})
|
|
222
|
+
}
|
|
223
|
+
</div>
|
|
224
|
+
{
|
|
225
|
+
configRef.current.mode === 'linear' && <div className="liner-gradient-tool">
|
|
226
|
+
<div className="liner-gradient-slider-container">
|
|
227
|
+
<Slider className='liner-gradient-slider'
|
|
228
|
+
range={{editable: true, minCount: 2, maxCount: 5}}
|
|
229
|
+
tooltip={{open: false}}
|
|
230
|
+
styles={{
|
|
231
|
+
rail: {
|
|
232
|
+
background: generateLinerGradient(),
|
|
233
|
+
height: 8,
|
|
234
|
+
top: 0,
|
|
235
|
+
borderRadius: 7
|
|
236
|
+
},
|
|
237
|
+
handle: {background: '#00000000'}
|
|
238
|
+
}}
|
|
239
|
+
onFocus={linerSlideFocus}
|
|
240
|
+
step={1}
|
|
241
|
+
included={false}
|
|
242
|
+
onChange={linerSlideChange}
|
|
243
|
+
value={configRef.current.posArr}
|
|
244
|
+
/>
|
|
245
|
+
</div>
|
|
246
|
+
<div className="liner-gradient-angle">
|
|
247
|
+
<InputNumber size="small" value={configRef.current.angle ?? 90} onChange={(value) => {
|
|
248
|
+
configRef.current.angle = value!;
|
|
249
|
+
updateColorValue();
|
|
250
|
+
}}/>
|
|
251
|
+
</div>
|
|
252
|
+
</div>
|
|
253
|
+
}
|
|
254
|
+
{
|
|
255
|
+
configRef.current.mode === 'radial' && <div className="radial-gradient-tool">
|
|
256
|
+
<div className="radial-gradient-slider-container">
|
|
257
|
+
<Slider className='radial-gradient-slider'
|
|
258
|
+
range={{editable: true, minCount: 2, maxCount: 5}}
|
|
259
|
+
tooltip={{open: false}}
|
|
260
|
+
styles={{
|
|
261
|
+
rail: {
|
|
262
|
+
background: generateRadialGradient(),
|
|
263
|
+
height: 8,
|
|
264
|
+
top: 1,
|
|
265
|
+
borderRadius: 7
|
|
266
|
+
},
|
|
267
|
+
handle: {background: '#00000000'}
|
|
268
|
+
}}
|
|
269
|
+
onFocus={radialSlideFocus}
|
|
270
|
+
step={1}
|
|
271
|
+
included={false}
|
|
272
|
+
onChange={radialSlideChange}
|
|
273
|
+
value={configRef.current.posArr}
|
|
274
|
+
/>
|
|
275
|
+
</div>
|
|
276
|
+
</div>
|
|
277
|
+
}
|
|
278
|
+
{panel}
|
|
279
|
+
</div>
|
|
280
|
+
}
|
|
281
|
+
const index = configRef.current.mode === 'linear' ? linerSelectedRef.current : configRef.current.mode === 'radial' ? radialSelectedRef.current : undefined;
|
|
282
|
+
const color = index !== undefined ? configRef.current.colorArr[index] : configRef.current.rawValue;
|
|
283
|
+
|
|
284
|
+
return (
|
|
285
|
+
<UIContainer {...containerProps} className={'versatile-color-picker'}>
|
|
286
|
+
<ConfigProvider theme={{
|
|
287
|
+
token: {
|
|
288
|
+
fontSizeSM: 12,
|
|
289
|
+
marginXXS: 5
|
|
290
|
+
}
|
|
291
|
+
}}>
|
|
292
|
+
<AntdColorPicker panelRender={customRender}
|
|
293
|
+
children={
|
|
294
|
+
<div className="color-trigger-container">
|
|
295
|
+
<div className="color-picker-trigger-block" style={{background: configRef.current.rawValue}}></div>
|
|
296
|
+
{configRef.current.mode === 'single' && showText ?
|
|
297
|
+
<div className="color-picker-text">
|
|
298
|
+
{configRef.current.rawValue?.toUpperCase()}
|
|
299
|
+
</div> : ''}
|
|
300
|
+
</div>}
|
|
301
|
+
presets={[
|
|
302
|
+
{label: '最近使用', colors: getRecentColors(), defaultOpen: true},
|
|
303
|
+
{label: '常用颜色', colors: ['#fff', '#000', '#f00', '#0f0', '#00f', '#ff0', '#f0f', '#0ff'], defaultOpen: false}
|
|
304
|
+
]}
|
|
305
|
+
size={'small'}
|
|
306
|
+
format={'hex'}
|
|
307
|
+
disabled={disabled}
|
|
308
|
+
value={color}
|
|
309
|
+
placement={'bottom'}
|
|
310
|
+
arrow={false}
|
|
311
|
+
onChange={(color) => updateColorValue(color.toHexString())}/>
|
|
312
|
+
</ConfigProvider>
|
|
313
|
+
</UIContainer>
|
|
314
|
+
);
|
|
315
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
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
|
+
|
|
13
|
+
import {debounce} from "lodash";
|
|
14
|
+
|
|
15
|
+
const MAX_COLORS = 8;
|
|
16
|
+
const STORAGE_KEY = '__recentColors__';
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* 更新最近使用的颜色
|
|
20
|
+
* @param color 新的颜色值,例如 "#FF0000"
|
|
21
|
+
*/
|
|
22
|
+
export const updateRecentColor = debounce((color: string) => {
|
|
23
|
+
// 获取当前数组
|
|
24
|
+
let recent: string[] = (window as any)[STORAGE_KEY] || [];
|
|
25
|
+
|
|
26
|
+
// 如果已经存在该颜色,先移除
|
|
27
|
+
recent = recent.filter(c => c !== color);
|
|
28
|
+
|
|
29
|
+
// 添加到数组头部
|
|
30
|
+
recent.unshift(color);
|
|
31
|
+
|
|
32
|
+
// 保证长度不超过 MAX_COLORS
|
|
33
|
+
if (recent.length > MAX_COLORS) {
|
|
34
|
+
recent = recent.slice(0, MAX_COLORS);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
// 保存回 window
|
|
38
|
+
(window as any)[STORAGE_KEY] = recent;
|
|
39
|
+
}, 500)
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* 获取最近使用的颜色
|
|
43
|
+
*/
|
|
44
|
+
export const getRecentColors = function () {
|
|
45
|
+
return (window as any)[STORAGE_KEY] || [];
|
|
46
|
+
}
|
|
@@ -0,0 +1,77 @@
|
|
|
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
|
+
.colors-picker {
|
|
13
|
+
flex-wrap: wrap;
|
|
14
|
+
display: flex;
|
|
15
|
+
flex-direction: row;
|
|
16
|
+
align-items: center;
|
|
17
|
+
|
|
18
|
+
.colors-item {
|
|
19
|
+
position: relative;
|
|
20
|
+
margin-right: 3px;
|
|
21
|
+
|
|
22
|
+
span {
|
|
23
|
+
position: absolute;
|
|
24
|
+
top: 0;
|
|
25
|
+
left: 18px;
|
|
26
|
+
width: 10px;
|
|
27
|
+
height: 10px;
|
|
28
|
+
border-radius: 5px;
|
|
29
|
+
text-align: center;
|
|
30
|
+
background-color: #525252;
|
|
31
|
+
|
|
32
|
+
label {
|
|
33
|
+
cursor: pointer;
|
|
34
|
+
color: #d6d6d6;
|
|
35
|
+
position: relative;
|
|
36
|
+
top: -3.3px;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.colors-pick-add-btn {
|
|
42
|
+
border: 1px solid #007984;
|
|
43
|
+
width: 21px;
|
|
44
|
+
height: 21px;
|
|
45
|
+
border-radius: 15px;
|
|
46
|
+
font-size: 20px;
|
|
47
|
+
display: flex;
|
|
48
|
+
|
|
49
|
+
.add-icon {
|
|
50
|
+
color: #007984;
|
|
51
|
+
width: 21px;
|
|
52
|
+
height: 21px;
|
|
53
|
+
text-align: center;
|
|
54
|
+
line-height: 21px;
|
|
55
|
+
position: relative;
|
|
56
|
+
top: -4px;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
.colors-pick-add-btn:hover {
|
|
61
|
+
cursor: pointer;
|
|
62
|
+
border-color: #00cde3;
|
|
63
|
+
|
|
64
|
+
.add-icon {
|
|
65
|
+
color: #00cde3;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
.colors-pick-add-btn:active {
|
|
70
|
+
cursor: pointer;
|
|
71
|
+
border-color: #bef3ff;
|
|
72
|
+
|
|
73
|
+
.add-icon {
|
|
74
|
+
color: #bef3ff;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
@@ -0,0 +1,78 @@
|
|
|
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 {useRef, useState} from 'react';
|
|
13
|
+
import './ColorsPicker.less';
|
|
14
|
+
import {UIContainer, UIContainerProps} from "../ui-container/UIContainer";
|
|
15
|
+
import ColorPicker from "../color-picker/ColorPicker.tsx";
|
|
16
|
+
|
|
17
|
+
export interface ColorsPickerProp extends UIContainerProps {
|
|
18
|
+
value?: string[];
|
|
19
|
+
defaultValue?: string[];
|
|
20
|
+
canAdd?: boolean;
|
|
21
|
+
onChange?: (data: string[]) => void;
|
|
22
|
+
modes?: Array<'single' | 'linear' | 'radial'>
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export default function ColorsPicker(props: ColorsPickerProp) {
|
|
26
|
+
const {value, defaultValue, modes, canAdd, onChange, ...containerProps} = props;
|
|
27
|
+
const controlled = value !== undefined && defaultValue === undefined;
|
|
28
|
+
const [stateValue, setStateValue] = useState(controlled ? value : defaultValue);
|
|
29
|
+
const [stateCanAdd, setStateCanAdd] = useState(!!canAdd);
|
|
30
|
+
const finalValue = controlled ? value : stateValue;
|
|
31
|
+
const maxRef = useRef<number>(5);
|
|
32
|
+
|
|
33
|
+
const _onChange = (color: string, id: number) => {
|
|
34
|
+
const tempValue = [...finalValue!];
|
|
35
|
+
tempValue[id] = color;
|
|
36
|
+
onChange && onChange(tempValue);
|
|
37
|
+
if (!controlled)
|
|
38
|
+
setStateValue(tempValue);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
const addColor = () => {
|
|
42
|
+
const tempValue = [...finalValue!];
|
|
43
|
+
if (tempValue?.length >= maxRef.current)
|
|
44
|
+
return;
|
|
45
|
+
tempValue.push('#a9a9a9');
|
|
46
|
+
if (tempValue.length === maxRef.current)
|
|
47
|
+
setStateCanAdd(false);
|
|
48
|
+
setStateValue(tempValue);
|
|
49
|
+
onChange && onChange(tempValue);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
const delColor = (id: number) => {
|
|
53
|
+
const tempValue = [...finalValue!];
|
|
54
|
+
tempValue.splice(id, 1);
|
|
55
|
+
if (tempValue.length < maxRef.current)
|
|
56
|
+
setStateCanAdd(true);
|
|
57
|
+
setStateValue(tempValue);
|
|
58
|
+
onChange && onChange(tempValue);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
return (
|
|
62
|
+
<UIContainer {...containerProps}>
|
|
63
|
+
<div className={'colors-picker'}>
|
|
64
|
+
{finalValue?.map((item: string, i: number) => {
|
|
65
|
+
return (
|
|
66
|
+
<div className={"colors-item"} key={i + ''}>
|
|
67
|
+
<ColorPicker value={item} modes={modes} onChange={(color) => _onChange(color, i)}/>
|
|
68
|
+
<span onClick={() => delColor(i)}><label>×</label></span>
|
|
69
|
+
</div>
|
|
70
|
+
)
|
|
71
|
+
})}
|
|
72
|
+
{stateCanAdd &&
|
|
73
|
+
<div onClick={addColor} className={'colors-pick-add-btn'}>
|
|
74
|
+
<div className="add-icon">+</div>
|
|
75
|
+
</div>}</div>
|
|
76
|
+
</UIContainer>
|
|
77
|
+
)
|
|
78
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
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
|
+
.control-group {
|
|
13
|
+
width: 100%;
|
|
14
|
+
padding: 10px;
|
|
15
|
+
|
|
16
|
+
.control-group-header {
|
|
17
|
+
color: #e4f4ff;
|
|
18
|
+
width: 100%;
|
|
19
|
+
display: flex;
|
|
20
|
+
justify-content: space-between;
|
|
21
|
+
font-size: 12px;
|
|
22
|
+
|
|
23
|
+
.cgh-operate {
|
|
24
|
+
|
|
25
|
+
.operate-icon {
|
|
26
|
+
cursor: pointer;
|
|
27
|
+
padding: 3px;
|
|
28
|
+
position: relative;
|
|
29
|
+
top: 1px;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
.toggle-icon {
|
|
33
|
+
top: 2px;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
.control-group-body {
|
|
39
|
+
padding: 5px;
|
|
40
|
+
|
|
41
|
+
.lc-accordion {
|
|
42
|
+
|
|
43
|
+
.accordion-header {
|
|
44
|
+
color: #c6c6c6;
|
|
45
|
+
font-size: 12px;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
@@ -0,0 +1,101 @@
|
|
|
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 React, {lazy, Suspense, useRef} from "react";
|
|
13
|
+
import {Control} from "../types";
|
|
14
|
+
import './ControlGroup.less';
|
|
15
|
+
import {FieldChangeData} from "../gui/LCGUI";
|
|
16
|
+
import Loading from "../loading/Loading";
|
|
17
|
+
import LCGUIUtil from "../gui/LCGUIUtil";
|
|
18
|
+
import {cloneDeep} from "lodash";
|
|
19
|
+
import {AddOne, DeleteFive, Down, Right} from "@icon-park/react";
|
|
20
|
+
import {ObjectUtil} from "light-chaser-util";
|
|
21
|
+
|
|
22
|
+
const LCGUI = lazy(() => import("../gui/LCGUI").then((module) => ({default: module.LCGUI})));
|
|
23
|
+
|
|
24
|
+
export interface ControlGroupProps {
|
|
25
|
+
label?: string;
|
|
26
|
+
itemName?: string;
|
|
27
|
+
template?: Control;
|
|
28
|
+
defaultValue?: object[];
|
|
29
|
+
onChange?: (value: unknown) => void;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
const ControlGroup = (props: ControlGroupProps) => {
|
|
33
|
+
const {label, defaultValue = [], template, itemName} = props;
|
|
34
|
+
const [toggle, setToggle] = React.useState<boolean>(false);
|
|
35
|
+
const templateData = LCGUIUtil.parseSchemaData(template!);
|
|
36
|
+
const initSchema: Control = {children: []};
|
|
37
|
+
defaultValue.forEach((data, index) => {
|
|
38
|
+
initSchema.children?.push({
|
|
39
|
+
type: 'accordion',
|
|
40
|
+
key: index + '',
|
|
41
|
+
label: (itemName || '系列') + (index + 1),
|
|
42
|
+
children: [{...LCGUIUtil.schemaStructureAssignment(data, cloneDeep(template!))}]
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
const dataRef = useRef(defaultValue);
|
|
46
|
+
const [schema, setSchema] = React.useState<Control>(initSchema);
|
|
47
|
+
|
|
48
|
+
const addNewGroup = () => {
|
|
49
|
+
const {template} = props;
|
|
50
|
+
if (!template) return;
|
|
51
|
+
schema.children?.push({
|
|
52
|
+
type: 'accordion',
|
|
53
|
+
key: dataRef.current.length + '',
|
|
54
|
+
label: (itemName || '系列') + (dataRef.current.length + 1),
|
|
55
|
+
children: [template]
|
|
56
|
+
});
|
|
57
|
+
setSchema({...schema});
|
|
58
|
+
dataRef.current = [...dataRef.current, {...templateData}];
|
|
59
|
+
const {onChange} = props;
|
|
60
|
+
onChange && onChange(dataRef.current);
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
const delGroup = () => {
|
|
64
|
+
schema.children?.pop();
|
|
65
|
+
setSchema({...schema});
|
|
66
|
+
dataRef.current.pop();
|
|
67
|
+
const {onChange} = props;
|
|
68
|
+
onChange && onChange(dataRef.current);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
const onFieldChange = (fieldChangeData: FieldChangeData) => {
|
|
72
|
+
const {dataFragment} = fieldChangeData;
|
|
73
|
+
const index = Number(Object.keys(dataFragment)[0]);
|
|
74
|
+
dataRef.current[index] = ObjectUtil.merge(dataRef.current[index], dataFragment[index as keyof object]);
|
|
75
|
+
const {onChange} = props;
|
|
76
|
+
onChange && onChange(dataRef.current);
|
|
77
|
+
}
|
|
78
|
+
return (
|
|
79
|
+
<div className="control-group">
|
|
80
|
+
<div className={'control-group-header'}>
|
|
81
|
+
<div className={'cgh-label'}><span>{label}</span></div>
|
|
82
|
+
<div className={'cgh-operate'}>
|
|
83
|
+
<span className={'operate-icon'} onClick={delGroup}><DeleteFive/></span>
|
|
84
|
+
<span className={'operate-icon'} onClick={addNewGroup}><AddOne/></span>
|
|
85
|
+
<span className={'operate-icon toggle-icon'} onClick={() => setToggle(!toggle)}>
|
|
86
|
+
{toggle ?
|
|
87
|
+
<Down size={16}/> :
|
|
88
|
+
<Right size={16}/>}
|
|
89
|
+
</span>
|
|
90
|
+
</div>
|
|
91
|
+
</div>
|
|
92
|
+
{toggle && <div className={'control-group-body'} style={{display: toggle ? 'block' : 'none'}}>
|
|
93
|
+
<Suspense fallback={<Loading/>}>
|
|
94
|
+
<LCGUI schema={schema} onFieldChange={onFieldChange}/>
|
|
95
|
+
</Suspense>
|
|
96
|
+
</div>}
|
|
97
|
+
</div>
|
|
98
|
+
)
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
export default ControlGroup;
|