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
package/.trae/.ignore
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
../deploy.bat
|
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2024 xiaopujun
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
# Light Chaser Pro 项目文档
|
|
2
|
+
|
|
3
|
+
## 1. 项目概述 (Project Overview)
|
|
4
|
+
|
|
5
|
+
**Light Chaser Pro (LC Pro)** 是一款基于 React 技术的现代化**低代码/无代码数据可视化大屏设计器**。它旨在帮助开发者和业务人员通过图形化界面,快速构建专业级的数据仪表盘、大屏展示和人机交互界面(HMI)。
|
|
6
|
+
|
|
7
|
+
**核心价值:**
|
|
8
|
+
- **所见即所得**:通过拖拽组件、配置属性即可完成页面搭建。
|
|
9
|
+
- **逻辑编排**:内置“蓝图”系统,通过节点连线实现复杂的交互逻辑,无需编写代码。
|
|
10
|
+
- **多数据源**:支持 HTTP、WebSocket、MQTT 等多种数据接入方式。
|
|
11
|
+
|
|
12
|
+
## 2. 技术架构 (Technical Architecture)
|
|
13
|
+
|
|
14
|
+
项目采用现代前端 Monorepo 架构构建:
|
|
15
|
+
|
|
16
|
+
- **包管理器**:**pnpm** (使用 Workspace 管理多包依赖)
|
|
17
|
+
- **核心框架**:React 18 + TypeScript
|
|
18
|
+
- **构建工具**:Vite
|
|
19
|
+
- **状态管理**:MobX (用于管理设计器复杂的全局状态)
|
|
20
|
+
- **UI 组件库**:
|
|
21
|
+
- `antd`: 通用 UI 组件
|
|
22
|
+
- `light-chaser-ui`: 项目自研的专用 UI 组件库
|
|
23
|
+
- **图表渲染**:ECharts, @antv/g2plot
|
|
24
|
+
- **画布交互**:react-moveable, react-selecto
|
|
25
|
+
- **本地存储**:localforage (IndexedDB)
|
|
26
|
+
|
|
27
|
+
## 3. 目录结构与 Workspace (Directory Structure)
|
|
28
|
+
|
|
29
|
+
项目采用 **Monorepo** 结构,核心代码分散在 `packages` 中(根目录配置在 `pnpm-workspace.yaml`):
|
|
30
|
+
|
|
31
|
+
### 3.1 Workspace Packages
|
|
32
|
+
|
|
33
|
+
| 包名 (Package) | 目录 | 说明 |
|
|
34
|
+
| :--- | :--- | :--- |
|
|
35
|
+
| **light-chaser-app** | `/light-chaser-app` | **主应用核心**。包含设计器主体、画布、蓝图系统及运行时逻辑。 |
|
|
36
|
+
| **light-chaser-ui** | `/light-chaser-ui` | **UI 组件库**。提供设计器面板中使用的自定义控件(如属性设置器、颜色选择器等)。 |
|
|
37
|
+
| **light-chaser-util** | `/light-chaser-util` | **工具库**。通用的辅助函数和工具类。 |
|
|
38
|
+
| **light-chaser-interface** | `/light-chaser-interface` | **接口定义**。定义项目通用的 TypeScript 接口和规范。 |
|
|
39
|
+
| **light-chaser-types** | `/light-chaser-types` | **类型定义**。全局类型声明。 |
|
|
40
|
+
| **light-chaser-cli** | `/light-chaser-cli` | **命令行工具**。可能用于脚手架或辅助构建任务。 |
|
|
41
|
+
|
|
42
|
+
### 3.2 核心应用模块 (`light-chaser-app/src`)
|
|
43
|
+
|
|
44
|
+
主应用 (`light-chaser-app`) 是项目的大脑,其 `src` 目录结构如下:
|
|
45
|
+
|
|
46
|
+
- **`src/designer` (设计器核心)**:
|
|
47
|
+
- **Canvas**: 画布区域。
|
|
48
|
+
- **Header**: 顶部工具栏。
|
|
49
|
+
- **Left/Right**: 左右侧面板(组件库、图层、属性配置)。
|
|
50
|
+
- **Blueprint**: 蓝图逻辑编排模块。
|
|
51
|
+
- **`src/comps` (可视化组件库)**:
|
|
52
|
+
- 包含所有可拖拽到画布上的组件(图表、文本、媒体等)。
|
|
53
|
+
- 每个组件包含 Definition (元数据), Controller (逻辑), Component (视图), Config (配置面板)。
|
|
54
|
+
- **`src/designer/blueprint` (蓝图系统)**:
|
|
55
|
+
- 可视化逻辑编辑器,处理组件交互和事件流。
|
|
56
|
+
|
|
57
|
+
## 4. 数据流与状态管理 (Data Flow)
|
|
58
|
+
|
|
59
|
+
### 4.1 状态管理 (MobX)
|
|
60
|
+
- `ProjectManager`: 管理项目整体配置。
|
|
61
|
+
- `DesignerManager`: 管理画布交互状态。
|
|
62
|
+
- `LayerListStore`: 管理组件图层树。
|
|
63
|
+
|
|
64
|
+
### 4.2 数据持久化
|
|
65
|
+
- **自动保存**: 利用 `localforage` 将快照存入 IndexedDB。
|
|
66
|
+
- **项目文件**: 保存为 JSON 格式,包含画布配置、组件树 (Layer) 和蓝图逻辑 (Blueprint)。
|
|
67
|
+
|
|
68
|
+
## 5. 核心功能特性 (Key Features)
|
|
69
|
+
|
|
70
|
+
1. **Monorepo 架构**: 模块解耦,便于维护和复用。
|
|
71
|
+
2. **可视化拖拽**: 自由布局,支持成组、锁定、快捷键操作。
|
|
72
|
+
3. **蓝图交互**: 节点式逻辑编排,支持复杂业务场景。
|
|
73
|
+
4. **多源数据**: 支持静态 JSON、API、WebSocket、MQTT。
|
|
74
|
+
5. **插件化组件**: 组件结构标准化,易于扩展。
|
|
75
|
+
|
|
76
|
+
## 6. 开发指南 (Development Guide)
|
|
77
|
+
|
|
78
|
+
### 环境准备
|
|
79
|
+
- Node.js (推荐 LTS)
|
|
80
|
+
- **pnpm** (必须安装: `npm install -g pnpm`)
|
|
81
|
+
|
|
82
|
+
### 安装与启动
|
|
83
|
+
|
|
84
|
+
1. **安装依赖** (在根目录执行):
|
|
85
|
+
```bash
|
|
86
|
+
pnpm install
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
2. **启动开发环境**:
|
|
90
|
+
由于是 Monorepo,通常需要进入主应用目录或使用 pnpm 过滤器启动。
|
|
91
|
+
```bash
|
|
92
|
+
# 或者在根目录使用 pnpm 过滤 (假设主应用有 dev 脚本)
|
|
93
|
+
pnpm --F light-chaser-app dev
|
|
94
|
+
```
|
|
95
|
+
|
|
96
|
+
3. **构建项目**:
|
|
97
|
+
```bash
|
|
98
|
+
pnpm --F light-chaser-app build
|
|
99
|
+
```
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
# Light Chaser Pro - UI 设计规范文档
|
|
2
|
+
|
|
3
|
+
本文档基于 "Dark Blue Dashboard" 设计风格制定,旨在统一项目的视觉体验与交互规范。后续所有组件开发与页面设计均需严格遵循本规范。
|
|
4
|
+
|
|
5
|
+
## 1. 设计理念 (Design Philosophy)
|
|
6
|
+
|
|
7
|
+
* **沉浸式深色主题 (Immersive Dark Theme)**: 使用深蓝/蓝紫作为主色调,营造科技感与现代感,降低长时间使用的视觉疲劳。
|
|
8
|
+
* **高对比度 (High Contrast)**: 关键数据与操作按钮使用高饱和度的霓虹色(粉、蓝、青),在深色背景下形成鲜明对比。
|
|
9
|
+
* **层级分明 (Clear Hierarchy)**: 通过背景亮度的细微差异(背景色 vs 卡片色)与投影区分内容层级。
|
|
10
|
+
* **卡片式布局 (Card-based Layout)**: 内容被封装在独立的卡片容器中,边界清晰,圆角柔和。
|
|
11
|
+
|
|
12
|
+
---
|
|
13
|
+
|
|
14
|
+
## 2. 颜色系统 (Color System)
|
|
15
|
+
|
|
16
|
+
### 2.1 背景色 (Backgrounds)
|
|
17
|
+
* **应用背景 (App Background)**: `#1E1E2F` (深蓝黑色,用于页面底层)
|
|
18
|
+
* **卡片背景 (Card Background)**: `#27293D` (稍亮的蓝灰色,用于内容容器)
|
|
19
|
+
* **侧边栏/导航栏 (Navigation)**: `#1E1E2F` 或透明度变体
|
|
20
|
+
|
|
21
|
+
### 2.2 品牌色 / 强调色 (Brand & Accent Colors)
|
|
22
|
+
* **主色调 (Primary - Pink/Red)**: `#FD5D93` (用于主要操作按钮如 "Create"、关键高亮)
|
|
23
|
+
* *渐变应用*: `linear-gradient(to bottom left, #fd5d93, #ec250d)`
|
|
24
|
+
* **信息色 (Info - Blue)**: `#1D8CF8` (用于辅助图表、链接、选中状态)
|
|
25
|
+
* *渐变应用*: `linear-gradient(to bottom left, #1d8cf8, #3358f4)`
|
|
26
|
+
* **成功色 (Success - Teal/Green)**: `#00F2C3` (用于增长趋势、完成状态)
|
|
27
|
+
* *渐变应用*: `linear-gradient(to bottom left, #00f2c3, #0098f0)`
|
|
28
|
+
* **警告/其他 (Warning/Purple)**: `#E14ECA` (用于特定图表线条或次要高亮)
|
|
29
|
+
|
|
30
|
+
### 2.3 文本颜色 (Typography Colors)
|
|
31
|
+
* **主要文本 (Heading/Body)**: `#FFFFFF` (纯白,用于标题、数值、正文)
|
|
32
|
+
* **次要文本 (Muted/Label)**: `#9A9A9A` (灰白,用于副标题、图表轴标、辅助说明)
|
|
33
|
+
* **占位符/禁用 (Disabled)**: `rgba(255, 255, 255, 0.3)`
|
|
34
|
+
|
|
35
|
+
---
|
|
36
|
+
|
|
37
|
+
## 3. 排版 (Typography)
|
|
38
|
+
|
|
39
|
+
* **字体家族 (Font Family)**: `"Poppins", "Roboto", "Helvetica Neue", Arial, sans-serif`
|
|
40
|
+
* **字重 (Font Weight)**:
|
|
41
|
+
* Light: 300 (大标题)
|
|
42
|
+
* Regular: 400 (正文)
|
|
43
|
+
* Medium: 500 (导航、小标题)
|
|
44
|
+
* Bold: 700 (关键数值)
|
|
45
|
+
|
|
46
|
+
### 3.1 文字层级规范
|
|
47
|
+
* **H1 / 页面标题**: 24px - 32px, White
|
|
48
|
+
* **H2 / 卡片标题**: 16px - 18px, Muted (`#9A9A9A`),通常位于卡片左上角
|
|
49
|
+
* **H3 / 关键数值**: 24px - 36px, White, Bold (e.g., "9,000")
|
|
50
|
+
* **Body / 正文**: 14px, White/Muted
|
|
51
|
+
* **Small / 辅助文字**: 12px, Muted
|
|
52
|
+
|
|
53
|
+
---
|
|
54
|
+
|
|
55
|
+
## 4. 布局与间距 (Layout & Spacing)
|
|
56
|
+
|
|
57
|
+
### 4.1 栅格系统 (Grid)
|
|
58
|
+
* 采用 12 列栅格系统。
|
|
59
|
+
* **Gutter (槽宽)**: 20px - 30px。
|
|
60
|
+
|
|
61
|
+
### 4.2 尺寸与圆角 (Dimensions & Radius)
|
|
62
|
+
* **卡片圆角 (Card Radius)**: `4px` 或 `6px` (保持微圆角,避免过度圆润)
|
|
63
|
+
* **按钮圆角 (Button Radius)**: `4px` (实心按钮) / `30px` (胶囊型,视具体场景)
|
|
64
|
+
* **内边距 (Padding)**:
|
|
65
|
+
* 卡片内边距: `20px` (标准)
|
|
66
|
+
* 卡片头部与内容间距: `15px`
|
|
67
|
+
|
|
68
|
+
---
|
|
69
|
+
|
|
70
|
+
## 5. 组件样式规范 (Component Styles)
|
|
71
|
+
|
|
72
|
+
### 5.1 卡片 (Cards)
|
|
73
|
+
* **背景**: `#27293D`
|
|
74
|
+
* **阴影**: `0 1px 20px 0px rgba(0, 0, 0, 0.1)` (极其柔和的阴影,主要靠颜色区分层级)
|
|
75
|
+
* **边框**: 无边框 (None)
|
|
76
|
+
|
|
77
|
+
### 5.2 按钮 (Buttons)
|
|
78
|
+
* **主要按钮 (Primary - "Create")**:
|
|
79
|
+
* 背景: `#FD5D93` (或渐变)
|
|
80
|
+
* 文字: White
|
|
81
|
+
* 圆角: `4px`
|
|
82
|
+
* 阴影: `0 4px 6px rgba(50, 50, 93, 0.11), 0 1px 3px rgba(0, 0, 0, 0.08)`
|
|
83
|
+
* 交互: Hover 时亮度提升或阴影加深。
|
|
84
|
+
* **次要/幽灵按钮 (Secondary/Outline - "Add Task")**:
|
|
85
|
+
* 背景: Transparent
|
|
86
|
+
* 边框: `1px solid #FD5D93` (或其他强调色)
|
|
87
|
+
* 文字: White 或 对应强调色
|
|
88
|
+
|
|
89
|
+
### 5.3 图表 (Charts)
|
|
90
|
+
* **线条**: 平滑曲线 (Spline)。
|
|
91
|
+
* **描边宽度**: `3px`。
|
|
92
|
+
* **特效**:
|
|
93
|
+
* 线条发光效果 (Glow/Shadow): `drop-shadow(0px 5px 5px rgba(..., 0.4))`
|
|
94
|
+
* 节点: 实心圆点,白色描边。
|
|
95
|
+
|
|
96
|
+
### 5.4 导航栏 (Navbar)
|
|
97
|
+
* **布局**: 顶部水平布局。
|
|
98
|
+
* **状态**:
|
|
99
|
+
* 激活项: 亮白色文字 + 底部或侧边强调色圆点 (e.g., 蓝色小圆点)。
|
|
100
|
+
* 未激活项: 灰色文字 (`#9A9A9A`)。
|
|
101
|
+
|
|
102
|
+
---
|
|
103
|
+
|
|
104
|
+
## 6. 代码实现参考 (CSS Variables)
|
|
105
|
+
|
|
106
|
+
```css
|
|
107
|
+
:root {
|
|
108
|
+
/* Colors */
|
|
109
|
+
--lc-color-bg-app: #1e1e2f;
|
|
110
|
+
--lc-color-bg-card: #27293d;
|
|
111
|
+
|
|
112
|
+
--lc-color-primary: #fd5d93;
|
|
113
|
+
--lc-color-info: #1d8cf8;
|
|
114
|
+
--lc-color-success: #00f2c3;
|
|
115
|
+
--lc-color-warning: #ff8d72;
|
|
116
|
+
--lc-color-danger: #fd5d93;
|
|
117
|
+
|
|
118
|
+
/* Text */
|
|
119
|
+
--lc-color-text-primary: #ffffff;
|
|
120
|
+
--lc-color-text-secondary: #9a9a9a;
|
|
121
|
+
--lc-color-text-disabled: rgba(255, 255, 255, 0.3);
|
|
122
|
+
|
|
123
|
+
/* Spacing & Radius */
|
|
124
|
+
--lc-radius-base: 4px;
|
|
125
|
+
--lc-padding-card: 20px;
|
|
126
|
+
|
|
127
|
+
/* Typography */
|
|
128
|
+
--lc-font-family: "Poppins", sans-serif;
|
|
129
|
+
}
|
|
130
|
+
```
|
package/deploy.bat
ADDED
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
@echo off
|
|
2
|
+
chcp 65001 >nul
|
|
3
|
+
|
|
4
|
+
setlocal enabledelayedexpansion
|
|
5
|
+
|
|
6
|
+
REM 设置颜色变量
|
|
7
|
+
for /F "tokens=1,2 delims=#" %%a in ('"prompt #$H#$E# & echo on & for %%b in (1) do rem"') do (
|
|
8
|
+
set "DEL=%%a"
|
|
9
|
+
)
|
|
10
|
+
|
|
11
|
+
echo.
|
|
12
|
+
echo ========================================
|
|
13
|
+
echo 开始部署LIGHT CHASER PRO 前端
|
|
14
|
+
echo ========================================
|
|
15
|
+
echo.
|
|
16
|
+
|
|
17
|
+
REM 检查必要的工具是否安装
|
|
18
|
+
|
|
19
|
+
echo [1/6] 检查工具链...
|
|
20
|
+
|
|
21
|
+
where ssh >nul 2>nul
|
|
22
|
+
if errorlevel 1 (
|
|
23
|
+
echo 错误: 未找到ssh命令,请安装OpenSSH或添加ssh到PATH
|
|
24
|
+
pause
|
|
25
|
+
exit /b 1
|
|
26
|
+
)
|
|
27
|
+
|
|
28
|
+
where scp >nul 2>nul
|
|
29
|
+
if errorlevel 1 (
|
|
30
|
+
echo 错误: 未找到scp命令,请安装OpenSSH或添加scp到PATH
|
|
31
|
+
pause
|
|
32
|
+
exit /b 1
|
|
33
|
+
)
|
|
34
|
+
|
|
35
|
+
echo [2/6] 初始化部署环境...
|
|
36
|
+
|
|
37
|
+
set "FRONTEND_DIR=D:\dev_project\light-chaser-pro"
|
|
38
|
+
set "FRONTEND_ZIP=app.zip"
|
|
39
|
+
|
|
40
|
+
set "SERVER_USER=root"
|
|
41
|
+
set "SERVER_HOST=116.198.230.57"
|
|
42
|
+
set "SERVER_PORT=22"
|
|
43
|
+
set "DEPLOY_DIR=/home/dagu/LCP/lib"
|
|
44
|
+
set "APP_ROOT=/home/dagu/LCP"
|
|
45
|
+
set "SERVICE_NAME=your_service_name"
|
|
46
|
+
|
|
47
|
+
echo [3/6] 构建前端项目...
|
|
48
|
+
if errorlevel 1 (
|
|
49
|
+
echo 错误: 前端目录不存在
|
|
50
|
+
pause
|
|
51
|
+
exit /b 1
|
|
52
|
+
)
|
|
53
|
+
|
|
54
|
+
call pnpm install
|
|
55
|
+
if errorlevel 1 (
|
|
56
|
+
echo 错误: pnpm install 失败
|
|
57
|
+
pause
|
|
58
|
+
exit /b 1
|
|
59
|
+
)
|
|
60
|
+
|
|
61
|
+
call pnpm -F light-chaser-app build
|
|
62
|
+
if errorlevel 1 (
|
|
63
|
+
echo 错误: 前端构建失败
|
|
64
|
+
pause
|
|
65
|
+
exit /b 1
|
|
66
|
+
)
|
|
67
|
+
|
|
68
|
+
echo [4/6] 压缩前端文件...
|
|
69
|
+
|
|
70
|
+
cd /d %FRONTEND_DIR%\light-chaser-app\dist
|
|
71
|
+
call tar -a -c -f app.zip *
|
|
72
|
+
|
|
73
|
+
if errorlevel 1 (
|
|
74
|
+
echo 错误: 压缩前端文件失败
|
|
75
|
+
pause
|
|
76
|
+
exit /b 1
|
|
77
|
+
)
|
|
78
|
+
|
|
79
|
+
|
|
80
|
+
echo [5/6] 上传文件到服务器...
|
|
81
|
+
scp -P %SERVER_PORT% "%FRONTEND_DIR%\light-chaser-app\dist\%FRONTEND_ZIP%" "%SERVER_USER%@%SERVER_HOST%:%DEPLOY_DIR%/"
|
|
82
|
+
|
|
83
|
+
|
|
84
|
+
echo [6/6] 在服务器上执行部署操作...
|
|
85
|
+
|
|
86
|
+
ssh -p %SERVER_PORT% %SERVER_USER%@%SERVER_HOST% "cd %DEPLOY_DIR% && rm -rf app && unzip app.zip -d app && rm app.zip && cd %APP_ROOT% && ./stop.sh && ./start.sh"
|
|
87
|
+
|
|
88
|
+
echo 清理临时文件
|
|
89
|
+
|
|
90
|
+
del /f /q "%FRONTEND_DIR%\light-chaser-app\dist\%FRONTEND_ZIP%"
|
|
91
|
+
|
|
92
|
+
echo.
|
|
93
|
+
echo ========================================
|
|
94
|
+
echo LIGHT CHASER PRO 前端部署完毕~
|
|
95
|
+
echo ========================================
|
|
96
|
+
echo.
|
|
97
|
+
|
|
98
|
+
pause
|
|
@@ -0,0 +1,291 @@
|
|
|
1
|
+
# ScreenFit 组件核心原理解析
|
|
2
|
+
|
|
3
|
+
## 一、组件设计目标
|
|
4
|
+
|
|
5
|
+
实现一个**自适应大屏缩放容器**,支持多种缩放模式,在不同浏览器缩放比例和视口尺寸下,都能正确显示内容且不出现布局空白。
|
|
6
|
+
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
## 二、核心概念理解
|
|
10
|
+
|
|
11
|
+
### 2.1 CSS Transform 的本质特性
|
|
12
|
+
|
|
13
|
+
CSS `transform` 属性有一个关键特性:**只改变视觉呈现,不改变布局空间**。
|
|
14
|
+
|
|
15
|
+
#### 示例说明:
|
|
16
|
+
```css
|
|
17
|
+
.element {
|
|
18
|
+
width: 1000px;
|
|
19
|
+
height: 2000px;
|
|
20
|
+
transform: scale(0.5);
|
|
21
|
+
}
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
这个元素会产生两个不同的"高度":
|
|
25
|
+
- **视觉高度(Visual Height)**: 2000px × 0.5 = 1000px(用户眼睛看到的)
|
|
26
|
+
- **布局高度(Layout Height)**: 2000px(浏览器计算文档流、滚动条时使用的)
|
|
27
|
+
|
|
28
|
+
**差值**: 2000 - 1000 = 1000px 的"幽灵空间"
|
|
29
|
+
|
|
30
|
+
这就是空白问题的根源。
|
|
31
|
+
|
|
32
|
+
---
|
|
33
|
+
|
|
34
|
+
### 2.2 浏览器缩放的影响
|
|
35
|
+
|
|
36
|
+
当用户使用 `Ctrl + 滚轮` 或 `Ctrl + +/-` 调整浏览器缩放时:
|
|
37
|
+
- `document.body.clientWidth/Height` 会相应变化
|
|
38
|
+
- 但我们设定的设计稿尺寸(如 1920×6800)不会变
|
|
39
|
+
- 这导致计算出的缩放比例 `widthScale` 会动态变化
|
|
40
|
+
|
|
41
|
+
#### 缩放比例计算:
|
|
42
|
+
```javascript
|
|
43
|
+
const widthScale = currentWidth / designWidth
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
**不同浏览器缩放下的表现:**
|
|
47
|
+
| 浏览器缩放 | 视口宽度 | widthScale | 6800px 缩放后视觉高度 | 布局高度 | 空白 |
|
|
48
|
+
|---------|---------|-----------|---------------------|---------|-----|
|
|
49
|
+
| 100% | 1920px | 1.0 | 6800px | 6800px | 0px ✅ |
|
|
50
|
+
| 60% | 3200px | 1.67 | 11356px | 6800px | -4556px ❌ |
|
|
51
|
+
| 150% | 1280px | 0.67 | 4556px | 6800px | 2244px ❌ |
|
|
52
|
+
|
|
53
|
+
可以看到,除了 100% 缩放,其他情况都会产生视觉高度与布局高度的不匹配。
|
|
54
|
+
|
|
55
|
+
---
|
|
56
|
+
|
|
57
|
+
## 三、解决方案原理
|
|
58
|
+
|
|
59
|
+
### 3.1 核心思路
|
|
60
|
+
|
|
61
|
+
**使用负 margin 抵消多余的布局空间**
|
|
62
|
+
|
|
63
|
+
原理公式:
|
|
64
|
+
```
|
|
65
|
+
实际占用空间 = 布局高度 + marginBottom
|
|
66
|
+
让:实际占用空间 = 视觉高度
|
|
67
|
+
则:marginBottom = 视觉高度 - 布局高度
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
### 3.2 数学推导
|
|
71
|
+
|
|
72
|
+
设:
|
|
73
|
+
- `H` = 原始设计高度(如 6800px)
|
|
74
|
+
- `S` = 缩放比例(widthScale)
|
|
75
|
+
- `H_visual` = 视觉高度 = H × S
|
|
76
|
+
- `H_layout` = 布局高度 = H
|
|
77
|
+
- `H_diff` = 高度差 = H_layout - H_visual = H - H×S = H(1-S)
|
|
78
|
+
|
|
79
|
+
修正方案:
|
|
80
|
+
```text
|
|
81
|
+
marginBottom = -H_diff = -(H - H×S) = H×S - H
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
简化为:
|
|
85
|
+
```javascript
|
|
86
|
+
const scaledHeight = realHeight * widthScale // H×S
|
|
87
|
+
const heightDiff = realHeight - scaledHeight // H - H×S
|
|
88
|
+
marginBottom = -heightDiff // -(H - H×S)
|
|
89
|
+
```
|
|
90
|
+
|
|
91
|
+
### 3.3 代码实现
|
|
92
|
+
|
|
93
|
+
```javascript
|
|
94
|
+
case 'full-x':
|
|
95
|
+
// 1. 等比缩放(保持宽高比,不变形)
|
|
96
|
+
elRef.current!.style.transform = `scale(${widthScale}, ${widthScale})`
|
|
97
|
+
|
|
98
|
+
// 2. 计算视觉高度
|
|
99
|
+
const scaledHeight = +realHeight * widthScale
|
|
100
|
+
|
|
101
|
+
// 3. 计算多余的布局空间
|
|
102
|
+
const heightDiff = +realHeight - scaledHeight
|
|
103
|
+
|
|
104
|
+
// 4. 使用负 margin 抵消多余空间
|
|
105
|
+
if (heightDiff > 0) {
|
|
106
|
+
// 缩小场景:布局高度 > 视觉高度,有多余空间
|
|
107
|
+
elRef.current!.style.marginBottom = `-${heightDiff}px`
|
|
108
|
+
} else {
|
|
109
|
+
// 放大场景:视觉高度 >= 布局高度,不需要调整
|
|
110
|
+
elRef.current!.style.marginBottom = `0px`
|
|
111
|
+
}
|
|
112
|
+
break;
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
---
|
|
116
|
+
|
|
117
|
+
## 四、完整工作流程
|
|
118
|
+
|
|
119
|
+
### 4.1 初始化阶段
|
|
120
|
+
1. 组件挂载,获取设计稿尺寸(width, height)
|
|
121
|
+
2. 设置容器固定尺寸:`width: 1920px; height: 6800px`
|
|
122
|
+
3. 监听窗口 resize 事件
|
|
123
|
+
|
|
124
|
+
### 4.2 缩放计算阶段
|
|
125
|
+
1. **获取视口尺寸**:`currentWidth = document.body.clientWidth`
|
|
126
|
+
2. **计算缩放比例**:`widthScale = currentWidth / 1920`
|
|
127
|
+
3. **应用 transform**:`transform: scale(widthScale, widthScale)`
|
|
128
|
+
4. **计算视觉高度**:`scaledHeight = 6800 × widthScale`
|
|
129
|
+
5. **计算高度差**:`heightDiff = 6800 - scaledHeight`
|
|
130
|
+
6. **修正布局**:`marginBottom = -heightDiff`
|
|
131
|
+
|
|
132
|
+
### 4.3 滚动条行为
|
|
133
|
+
```
|
|
134
|
+
外层容器高度:100vh(固定)
|
|
135
|
+
内层容器占用空间:scaledHeight(动态)
|
|
136
|
+
|
|
137
|
+
if (scaledHeight <= 100vh) {
|
|
138
|
+
// 内容未超出视口,留白显示,无滚动条 ✅
|
|
139
|
+
} else {
|
|
140
|
+
// 内容超出视口,出现滚动条 ✅
|
|
141
|
+
// 滚动范围 = scaledHeight(正好到内容底部,无多余空白)✅
|
|
142
|
+
}
|
|
143
|
+
```
|
|
144
|
+
|
|
145
|
+
---
|
|
146
|
+
|
|
147
|
+
## 五、关键技术点总结
|
|
148
|
+
|
|
149
|
+
### 5.1 为什么用负 margin 而不是其他方案?
|
|
150
|
+
|
|
151
|
+
**方案对比:**
|
|
152
|
+
|
|
153
|
+
| 方案 | 原理 | 缺点 |
|
|
154
|
+
|-----|------|------|
|
|
155
|
+
| 动态改变 height | 直接设置 `height: scaledHeight` | 会影响 transform 的计算基准,导致二次缩放 ❌ |
|
|
156
|
+
| 使用 padding-bottom | 用 padding 撑开空间 | padding 会增加空间,不是减少空间 ❌ |
|
|
157
|
+
| 修改父容器高度 | 调整外层容器 | 破坏了固定视口的设计,滚动条消失 ❌ |
|
|
158
|
+
| **负 margin-bottom** | 减少元素占用空间 | 完美解决,不影响其他布局 ✅ |
|
|
159
|
+
|
|
160
|
+
### 5.2 transform-origin 的作用
|
|
161
|
+
|
|
162
|
+
```javascript
|
|
163
|
+
elRef.current!.style.transformOrigin = 'left top'
|
|
164
|
+
```
|
|
165
|
+
|
|
166
|
+
- **作用**:设置缩放的原点为左上角
|
|
167
|
+
- **效果**:内容从左上角开始缩放,不会产生偏移
|
|
168
|
+
- **如果不设置**:默认是 `center center`,内容会向右下偏移
|
|
169
|
+
|
|
170
|
+
### 5.3 等比缩放的重要性
|
|
171
|
+
|
|
172
|
+
```javascript
|
|
173
|
+
// full-x 模式:X 和 Y 都使用 widthScale
|
|
174
|
+
transform: scale(widthScale, widthScale)
|
|
175
|
+
|
|
176
|
+
// 而不是:
|
|
177
|
+
transform: scale(widthScale, 1) // ❌ 会导致拉伸变形
|
|
178
|
+
```
|
|
179
|
+
|
|
180
|
+
**原因**:
|
|
181
|
+
- 只缩放 X 轴会导致内容横向压缩,纵向不变 → 变形
|
|
182
|
+
- X、Y 使用相同比例 → 保持原始宽高比 → 不变形
|
|
183
|
+
|
|
184
|
+
---
|
|
185
|
+
|
|
186
|
+
## 六、数学验证
|
|
187
|
+
|
|
188
|
+
### 场景:浏览器 60% 缩放
|
|
189
|
+
|
|
190
|
+
**已知条件:**
|
|
191
|
+
- 设计稿:1920 × 6800
|
|
192
|
+
- 视口宽度:3200px(因为缩小到 60%)
|
|
193
|
+
- 视口高度:1800px
|
|
194
|
+
|
|
195
|
+
**计算过程:**
|
|
196
|
+
```
|
|
197
|
+
widthScale = 3200 / 1920 = 1.67
|
|
198
|
+
|
|
199
|
+
应用 transform: scale(1.67, 1.67)
|
|
200
|
+
视觉宽度 = 1920 × 1.67 = 3206px ≈ 3200px ✅ (铺满屏幕)
|
|
201
|
+
视觉高度 = 6800 × 1.67 = 11356px
|
|
202
|
+
|
|
203
|
+
布局高度 = 6800px (transform 不改变)
|
|
204
|
+
高度差 = 6800 - 11356 = -4556px
|
|
205
|
+
|
|
206
|
+
marginBottom = -(-4556) = 4556px ?❌
|
|
207
|
+
|
|
208
|
+
等等,这里是放大场景!
|
|
209
|
+
heightDiff = 6800 - 11356 = -4556 < 0
|
|
210
|
+
所以不需要负 margin,保持 marginBottom = 0
|
|
211
|
+
```
|
|
212
|
+
|
|
213
|
+
**实际效果:**
|
|
214
|
+
- 内容放大到 11356px
|
|
215
|
+
- 超出视口 1800px
|
|
216
|
+
- 出现滚动条,滚动范围正常 ✅
|
|
217
|
+
|
|
218
|
+
### 场景:浏览器 150% 缩放
|
|
219
|
+
|
|
220
|
+
**已知条件:**
|
|
221
|
+
- 视口宽度:1280px(因为放大到 150%)
|
|
222
|
+
|
|
223
|
+
**计算过程:**
|
|
224
|
+
```
|
|
225
|
+
widthScale = 1280 / 1920 = 0.67
|
|
226
|
+
|
|
227
|
+
应用 transform: scale(0.67, 0.67)
|
|
228
|
+
视觉高度 = 6800 × 0.67 = 4556px
|
|
229
|
+
布局高度 = 6800px
|
|
230
|
+
高度差 = 6800 - 4556 = 2244px
|
|
231
|
+
|
|
232
|
+
marginBottom = -2244px
|
|
233
|
+
```
|
|
234
|
+
|
|
235
|
+
**实际效果:**
|
|
236
|
+
- 元素原本占用 6800px
|
|
237
|
+
- 负 margin 减少 2244px
|
|
238
|
+
- 最终占用 = 6800 - 2244 = 4556px
|
|
239
|
+
- 正好等于视觉高度 ✅
|
|
240
|
+
- 滚动到底没有空白 ✅
|
|
241
|
+
|
|
242
|
+
---
|
|
243
|
+
|
|
244
|
+
## 七、设计模式总结
|
|
245
|
+
|
|
246
|
+
这个组件体现了以下设计理念:
|
|
247
|
+
|
|
248
|
+
### 7.1 关注点分离
|
|
249
|
+
- **视觉呈现**:由 `transform: scale()` 处理
|
|
250
|
+
- **布局空间**:由 `margin-bottom` 修正
|
|
251
|
+
- **滚动行为**:由外层容器的 `overflow` 控制
|
|
252
|
+
|
|
253
|
+
### 7.2 响应式适配
|
|
254
|
+
- 监听 `resize` 事件
|
|
255
|
+
- 使用防抖(debounce)优化性能
|
|
256
|
+
- 动态计算并应用样式
|
|
257
|
+
|
|
258
|
+
### 7.3 数学精确性
|
|
259
|
+
- 所有计算基于精确的数学公式
|
|
260
|
+
- 不依赖经验值或魔法数字
|
|
261
|
+
- 适用于任意尺寸和缩放比例
|
|
262
|
+
|
|
263
|
+
---
|
|
264
|
+
|
|
265
|
+
## 八、核心公式总结
|
|
266
|
+
|
|
267
|
+
**full-x 模式(宽度铺满):**
|
|
268
|
+
```
|
|
269
|
+
widthScale = 视口宽度 / 设计稿宽度
|
|
270
|
+
transform: scale(widthScale, widthScale)
|
|
271
|
+
视觉高度 = 设计稿高度 × widthScale
|
|
272
|
+
高度差 = 设计稿高度 - 视觉高度
|
|
273
|
+
marginBottom = -max(高度差, 0)
|
|
274
|
+
```
|
|
275
|
+
|
|
276
|
+
**full-y 模式(高度铺满):**
|
|
277
|
+
```
|
|
278
|
+
heightScale = 视口高度 / 设计稿高度
|
|
279
|
+
transform: scale(heightScale, heightScale)
|
|
280
|
+
视觉宽度 = 设计稿宽度 × heightScale
|
|
281
|
+
宽度差 = 设计稿宽度 - 视觉宽度
|
|
282
|
+
marginRight = -max(宽度差, 0)
|
|
283
|
+
```
|
|
284
|
+
|
|
285
|
+
**关键不等式:**
|
|
286
|
+
```
|
|
287
|
+
当 scale < 1 时(缩小):布局空间 > 视觉空间 → 需要负 margin
|
|
288
|
+
当 scale >= 1 时(放大):视觉空间 >= 布局空间 → 不需要调整
|
|
289
|
+
```
|
|
290
|
+
|
|
291
|
+
这就是整个组件的核心原理!
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
module.exports = {
|
|
2
|
+
root: true,
|
|
3
|
+
env: { browser: true, es2020: true },
|
|
4
|
+
extends: [
|
|
5
|
+
'eslint:recommended',
|
|
6
|
+
'plugin:@typescript-eslint/recommended',
|
|
7
|
+
'plugin:react-hooks/recommended',
|
|
8
|
+
],
|
|
9
|
+
ignorePatterns: ['dist', '.eslintrc.cjs'],
|
|
10
|
+
parser: '@typescript-eslint/parser',
|
|
11
|
+
plugins: ['react-refresh'],
|
|
12
|
+
rules: {
|
|
13
|
+
'react-refresh/only-export-components': [
|
|
14
|
+
'warn',
|
|
15
|
+
{ allowConstantExport: true },
|
|
16
|
+
],
|
|
17
|
+
"@typescript-eslint/no-explicit-any": "off",
|
|
18
|
+
},
|
|
19
|
+
}
|