@ecan-bi/datav 1.1.24 → 1.1.25
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/dist/index.es.js +428 -427
- package/dist/index.es.js.map +1 -1
- package/dist/index.umd.js +6 -6
- package/dist/index.umd.js.map +1 -1
- package/dist/style.css +2 -3
- package/package.json +2 -2
- package/es/_virtual/_plugin-vue_export-helper.js +0 -11
- package/es/_virtual/_plugin-vue_export-helper.js.map +0 -1
- package/es/assets/border-title-decoration-left.png.js +0 -5
- package/es/assets/border-title-decoration-left.png.js.map +0 -1
- package/es/assets/border-title-decoration-right.png.js +0 -5
- package/es/assets/border-title-decoration-right.png.js.map +0 -1
- package/es/assets/go-down.png.js +0 -5
- package/es/assets/go-down.png.js.map +0 -1
- package/es/assets/go-up.png.js +0 -5
- package/es/assets/go-up.png.js.map +0 -1
- package/es/common/echarts/Echarts.js +0 -200
- package/es/common/echarts/Echarts.js.map +0 -1
- package/es/common/echarts/composables/api.js +0 -43
- package/es/common/echarts/composables/api.js.map +0 -1
- package/es/common/echarts/composables/autoresize.js +0 -27
- package/es/common/echarts/composables/autoresize.js.map +0 -1
- package/es/common/echarts/composables/loading.js +0 -30
- package/es/common/echarts/composables/loading.js.map +0 -1
- package/es/common/echarts/index.js +0 -5
- package/es/common/echarts/index.js.map +0 -1
- package/es/common/echarts/style.css.js +0 -5
- package/es/common/echarts/style.css.js.map +0 -1
- package/es/common/echarts/utils.js +0 -16
- package/es/common/echarts/utils.js.map +0 -1
- package/es/common/skeleton/Skeleton.vue.js +0 -20
- package/es/common/skeleton/Skeleton.vue.js.map +0 -1
- package/es/common/skeleton/Skeleton.vue2.js +0 -20
- package/es/common/skeleton/Skeleton.vue2.js.map +0 -1
- package/es/common/skeleton/index.js +0 -5
- package/es/common/skeleton/index.js.map +0 -1
- package/es/common/spin/Spin.vue.js +0 -32
- package/es/common/spin/Spin.vue.js.map +0 -1
- package/es/common/spin/Spin.vue2.js +0 -5
- package/es/common/spin/Spin.vue2.js.map +0 -1
- package/es/common/spin/Spin.vue3.js +0 -22
- package/es/common/spin/Spin.vue3.js.map +0 -1
- package/es/common/spin/index.js +0 -5
- package/es/common/spin/index.js.map +0 -1
- package/es/components.js +0 -153
- package/es/components.js.map +0 -1
- package/es/container/border/Border.vue.js +0 -78
- package/es/container/border/Border.vue.js.map +0 -1
- package/es/container/border/Border.vue2.js +0 -65
- package/es/container/border/Border.vue2.js.map +0 -1
- package/es/container/border/Border.vue3.js +0 -5
- package/es/container/border/Border.vue3.js.map +0 -1
- package/es/container/border/index.js +0 -12
- package/es/container/border/index.js.map +0 -1
- package/es/container/border/props.js +0 -31
- package/es/container/border/props.js.map +0 -1
- package/es/container/modal/Modal.vue.js +0 -59
- package/es/container/modal/Modal.vue.js.map +0 -1
- package/es/container/modal/Modal.vue2.js +0 -113
- package/es/container/modal/Modal.vue2.js.map +0 -1
- package/es/container/modal/Modal.vue3.js +0 -5
- package/es/container/modal/Modal.vue3.js.map +0 -1
- package/es/container/modal/Modal.vue4.js +0 -5
- package/es/container/modal/Modal.vue4.js.map +0 -1
- package/es/container/modal/index.js +0 -12
- package/es/container/modal/index.js.map +0 -1
- package/es/container/modal/props.js +0 -28
- package/es/container/modal/props.js.map +0 -1
- package/es/container/tabs/Tabs.vue.js +0 -49
- package/es/container/tabs/Tabs.vue.js.map +0 -1
- package/es/container/tabs/Tabs.vue2.js +0 -72
- package/es/container/tabs/Tabs.vue2.js.map +0 -1
- package/es/container/tabs/Tabs.vue3.js +0 -5
- package/es/container/tabs/Tabs.vue3.js.map +0 -1
- package/es/container/tabs/index.js +0 -12
- package/es/container/tabs/index.js.map +0 -1
- package/es/container/tabs/props.js +0 -43
- package/es/container/tabs/props.js.map +0 -1
- package/es/control/button/Button.vue.js +0 -36
- package/es/control/button/Button.vue.js.map +0 -1
- package/es/control/button/Button.vue2.js +0 -59
- package/es/control/button/Button.vue2.js.map +0 -1
- package/es/control/button/Button.vue3.js +0 -5
- package/es/control/button/Button.vue3.js.map +0 -1
- package/es/control/button/index.js +0 -12
- package/es/control/button/index.js.map +0 -1
- package/es/control/button/props.js +0 -24
- package/es/control/button/props.js.map +0 -1
- package/es/control/checkbox/Checkbox.vue.js +0 -23
- package/es/control/checkbox/Checkbox.vue.js.map +0 -1
- package/es/control/checkbox/Checkbox.vue2.js +0 -97
- package/es/control/checkbox/Checkbox.vue2.js.map +0 -1
- package/es/control/checkbox/Checkbox.vue3.js +0 -5
- package/es/control/checkbox/Checkbox.vue3.js.map +0 -1
- package/es/control/checkbox/index.js +0 -12
- package/es/control/checkbox/index.js.map +0 -1
- package/es/control/checkbox/props.js +0 -26
- package/es/control/checkbox/props.js.map +0 -1
- package/es/control/date-picker/DatePicker.vue.js +0 -29
- package/es/control/date-picker/DatePicker.vue.js.map +0 -1
- package/es/control/date-picker/DatePicker.vue2.js +0 -68
- package/es/control/date-picker/DatePicker.vue2.js.map +0 -1
- package/es/control/date-picker/DatePicker.vue3.js +0 -5
- package/es/control/date-picker/DatePicker.vue3.js.map +0 -1
- package/es/control/date-picker/index.js +0 -12
- package/es/control/date-picker/index.js.map +0 -1
- package/es/control/date-picker/props.js +0 -26
- package/es/control/date-picker/props.js.map +0 -1
- package/es/control/input/Input.vue.js +0 -25
- package/es/control/input/Input.vue.js.map +0 -1
- package/es/control/input/Input.vue2.js +0 -63
- package/es/control/input/Input.vue2.js.map +0 -1
- package/es/control/input/Input.vue3.js +0 -5
- package/es/control/input/Input.vue3.js.map +0 -1
- package/es/control/input/index.js +0 -12
- package/es/control/input/index.js.map +0 -1
- package/es/control/input/props.js +0 -22
- package/es/control/input/props.js.map +0 -1
- package/es/control/range-picker/RangePicker.vue.js +0 -29
- package/es/control/range-picker/RangePicker.vue.js.map +0 -1
- package/es/control/range-picker/RangePicker.vue2.js +0 -77
- package/es/control/range-picker/RangePicker.vue2.js.map +0 -1
- package/es/control/range-picker/RangePicker.vue3.js +0 -5
- package/es/control/range-picker/RangePicker.vue3.js.map +0 -1
- package/es/control/range-picker/RangePicker.vue4.js +0 -5
- package/es/control/range-picker/RangePicker.vue4.js.map +0 -1
- package/es/control/range-picker/index.js +0 -12
- package/es/control/range-picker/index.js.map +0 -1
- package/es/control/range-picker/props.js +0 -25
- package/es/control/range-picker/props.js.map +0 -1
- package/es/control/select/Select.vue.js +0 -32
- package/es/control/select/Select.vue.js.map +0 -1
- package/es/control/select/Select.vue2.js +0 -109
- package/es/control/select/Select.vue2.js.map +0 -1
- package/es/control/select/Select.vue3.js +0 -5
- package/es/control/select/Select.vue3.js.map +0 -1
- package/es/control/select/Select.vue4.js +0 -5
- package/es/control/select/Select.vue4.js.map +0 -1
- package/es/control/select/index.js +0 -12
- package/es/control/select/index.js.map +0 -1
- package/es/control/select/props.js +0 -26
- package/es/control/select/props.js.map +0 -1
- package/es/graph/bar/Bar.vue.js +0 -51
- package/es/graph/bar/Bar.vue.js.map +0 -1
- package/es/graph/bar/Bar.vue2.js +0 -368
- package/es/graph/bar/Bar.vue2.js.map +0 -1
- package/es/graph/bar/Bar.vue3.js +0 -5
- package/es/graph/bar/Bar.vue3.js.map +0 -1
- package/es/graph/bar/index.js +0 -12
- package/es/graph/bar/index.js.map +0 -1
- package/es/graph/bar/props.js +0 -101
- package/es/graph/bar/props.js.map +0 -1
- package/es/graph/combo-graph/ComboGraph.vue.js +0 -51
- package/es/graph/combo-graph/ComboGraph.vue.js.map +0 -1
- package/es/graph/combo-graph/ComboGraph.vue2.js +0 -376
- package/es/graph/combo-graph/ComboGraph.vue2.js.map +0 -1
- package/es/graph/combo-graph/ComboGraph.vue3.js +0 -5
- package/es/graph/combo-graph/ComboGraph.vue3.js.map +0 -1
- package/es/graph/combo-graph/index.js +0 -12
- package/es/graph/combo-graph/index.js.map +0 -1
- package/es/graph/combo-graph/props.js +0 -112
- package/es/graph/combo-graph/props.js.map +0 -1
- package/es/graph/custom-graph/CustomGraph.vue.js +0 -20
- package/es/graph/custom-graph/CustomGraph.vue.js.map +0 -1
- package/es/graph/custom-graph/CustomGraph.vue2.js +0 -42
- package/es/graph/custom-graph/CustomGraph.vue2.js.map +0 -1
- package/es/graph/custom-graph/index.js +0 -11
- package/es/graph/custom-graph/index.js.map +0 -1
- package/es/graph/custom-graph/props.js +0 -18
- package/es/graph/custom-graph/props.js.map +0 -1
- package/es/graph/line/Line.vue.js +0 -49
- package/es/graph/line/Line.vue.js.map +0 -1
- package/es/graph/line/Line.vue2.js +0 -362
- package/es/graph/line/Line.vue2.js.map +0 -1
- package/es/graph/line/Line.vue3.js +0 -5
- package/es/graph/line/Line.vue3.js.map +0 -1
- package/es/graph/line/index.js +0 -12
- package/es/graph/line/index.js.map +0 -1
- package/es/graph/line/props.js +0 -71
- package/es/graph/line/props.js.map +0 -1
- package/es/graph/pie/Pie.vue.js +0 -49
- package/es/graph/pie/Pie.vue.js.map +0 -1
- package/es/graph/pie/Pie.vue2.js +0 -303
- package/es/graph/pie/Pie.vue2.js.map +0 -1
- package/es/graph/pie/Pie.vue3.js +0 -5
- package/es/graph/pie/Pie.vue3.js.map +0 -1
- package/es/graph/pie/index.js +0 -12
- package/es/graph/pie/index.js.map +0 -1
- package/es/graph/pie/props.js +0 -71
- package/es/graph/pie/props.js.map +0 -1
- package/es/graph/scatter/Scatter.vue.js +0 -49
- package/es/graph/scatter/Scatter.vue.js.map +0 -1
- package/es/graph/scatter/Scatter.vue2.js +0 -256
- package/es/graph/scatter/Scatter.vue2.js.map +0 -1
- package/es/graph/scatter/Scatter.vue3.js +0 -5
- package/es/graph/scatter/Scatter.vue3.js.map +0 -1
- package/es/graph/scatter/index.js +0 -12
- package/es/graph/scatter/index.js.map +0 -1
- package/es/graph/scatter/props.js +0 -64
- package/es/graph/scatter/props.js.map +0 -1
- package/es/hooks/useDownloadFile.js +0 -24
- package/es/hooks/useDownloadFile.js.map +0 -1
- package/es/hooks/useEmitEvent.js +0 -39
- package/es/hooks/useEmitEvent.js.map +0 -1
- package/es/hooks/useHrefParamsToGlobalVariables.js +0 -21
- package/es/hooks/useHrefParamsToGlobalVariables.js.map +0 -1
- package/es/hooks/useImagePath.js +0 -20
- package/es/hooks/useImagePath.js.map +0 -1
- package/es/hooks/useIndicatorData.js +0 -213
- package/es/hooks/useIndicatorData.js.map +0 -1
- package/es/hooks/useOnEvent.js +0 -24
- package/es/hooks/useOnEvent.js.map +0 -1
- package/es/hooks/usePageUrl.js +0 -11
- package/es/hooks/usePageUrl.js.map +0 -1
- package/es/hooks/usePickComponentStyle.js +0 -38
- package/es/hooks/usePickComponentStyle.js.map +0 -1
- package/es/hooks/useRequestData.js +0 -115
- package/es/hooks/useRequestData.js.map +0 -1
- package/es/hooks/useRequestDiagramData.js +0 -346
- package/es/hooks/useRequestDiagramData.js.map +0 -1
- package/es/hooks/useTransformChartDataByAttrKey.js +0 -56
- package/es/hooks/useTransformChartDataByAttrKey.js.map +0 -1
- package/es/hooks/useTransformChartDataByAttrValue.js +0 -41
- package/es/hooks/useTransformChartDataByAttrValue.js.map +0 -1
- package/es/hooks/useValueFormatter.js +0 -33
- package/es/hooks/useValueFormatter.js.map +0 -1
- package/es/hooks/useVariablesInText.js +0 -40
- package/es/hooks/useVariablesInText.js.map +0 -1
- package/es/index.js +0 -162
- package/es/index.js.map +0 -1
- package/es/map/map/Map.vue.js +0 -30
- package/es/map/map/Map.vue.js.map +0 -1
- package/es/map/map/Map.vue2.js +0 -171
- package/es/map/map/Map.vue2.js.map +0 -1
- package/es/map/map/Map.vue3.js +0 -5
- package/es/map/map/Map.vue3.js.map +0 -1
- package/es/map/map/index.js +0 -11
- package/es/map/map/index.js.map +0 -1
- package/es/map/map/props.js +0 -49
- package/es/map/map/props.js.map +0 -1
- package/es/media/iframe/Iframe.vue.js +0 -21
- package/es/media/iframe/Iframe.vue.js.map +0 -1
- package/es/media/iframe/Iframe.vue2.js +0 -43
- package/es/media/iframe/Iframe.vue2.js.map +0 -1
- package/es/media/iframe/Iframe.vue3.js +0 -5
- package/es/media/iframe/Iframe.vue3.js.map +0 -1
- package/es/media/iframe/index.js +0 -11
- package/es/media/iframe/index.js.map +0 -1
- package/es/media/iframe/props.js +0 -17
- package/es/media/iframe/props.js.map +0 -1
- package/es/media/image/Image.vue.js +0 -22
- package/es/media/image/Image.vue.js.map +0 -1
- package/es/media/image/Image.vue2.js +0 -53
- package/es/media/image/Image.vue2.js.map +0 -1
- package/es/media/image/Image.vue3.js +0 -5
- package/es/media/image/Image.vue3.js.map +0 -1
- package/es/media/image/index.js +0 -11
- package/es/media/image/index.js.map +0 -1
- package/es/media/image/props.js +0 -19
- package/es/media/image/props.js.map +0 -1
- package/es/node_modules/@ant-design/colors/dist/index.esm.js +0 -176
- package/es/node_modules/@ant-design/colors/dist/index.esm.js.map +0 -1
- package/es/node_modules/@ant-design/icons-svg/es/asn/LoadingOutlined.js +0 -6
- package/es/node_modules/@ant-design/icons-svg/es/asn/LoadingOutlined.js.map +0 -1
- package/es/node_modules/@ant-design/icons-vue/es/components/AntdIcon.js +0 -166
- package/es/node_modules/@ant-design/icons-vue/es/components/AntdIcon.js.map +0 -1
- package/es/node_modules/@ant-design/icons-vue/es/components/IconBase.js +0 -114
- package/es/node_modules/@ant-design/icons-vue/es/components/IconBase.js.map +0 -1
- package/es/node_modules/@ant-design/icons-vue/es/components/twoTonePrimaryColor.js +0 -80
- package/es/node_modules/@ant-design/icons-vue/es/components/twoTonePrimaryColor.js.map +0 -1
- package/es/node_modules/@ant-design/icons-vue/es/icons/LoadingOutlined.js +0 -39
- package/es/node_modules/@ant-design/icons-vue/es/icons/LoadingOutlined.js.map +0 -1
- package/es/node_modules/@ant-design/icons-vue/es/insert-css.js +0 -45
- package/es/node_modules/@ant-design/icons-vue/es/insert-css.js.map +0 -1
- package/es/node_modules/@ant-design/icons-vue/es/utils.js +0 -86
- package/es/node_modules/@ant-design/icons-vue/es/utils.js.map +0 -1
- package/es/node_modules/@babel/runtime/helpers/esm/extends.js +0 -18
- package/es/node_modules/@babel/runtime/helpers/esm/extends.js.map +0 -1
- package/es/node_modules/@ctrl/tinycolor/dist/module/conversion.js +0 -116
- package/es/node_modules/@ctrl/tinycolor/dist/module/conversion.js.map +0 -1
- package/es/node_modules/@ctrl/tinycolor/dist/module/css-color-names.js +0 -154
- package/es/node_modules/@ctrl/tinycolor/dist/module/css-color-names.js.map +0 -1
- package/es/node_modules/@ctrl/tinycolor/dist/module/format-input.js +0 -149
- package/es/node_modules/@ctrl/tinycolor/dist/module/format-input.js.map +0 -1
- package/es/node_modules/@ctrl/tinycolor/dist/module/util.js +0 -50
- package/es/node_modules/@ctrl/tinycolor/dist/module/util.js.map +0 -1
- package/es/node_modules/@vue/shared/dist/shared.esm-bundler.js +0 -3
- package/es/node_modules/@vue/shared/dist/shared.esm-bundler.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/button/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/button/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/checkbox/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/checkbox/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/date-picker/locale/zh_CN.js +0 -24
- package/es/node_modules/ant-design-vue/es/date-picker/locale/zh_CN.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/date-picker/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/date-picker/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/dropdown/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/dropdown/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/empty/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/empty/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/input/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/input/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/modal/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/modal/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/pagination/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/pagination/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/progress/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/progress/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/radio/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/radio/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/select/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/select/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/skeleton/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/skeleton/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/spin/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/spin/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/style/default.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/style/default.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/table/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/table/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/tag/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/tag/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/time-picker/locale/zh_CN.js +0 -9
- package/es/node_modules/ant-design-vue/es/time-picker/locale/zh_CN.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/tooltip/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/tooltip/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/tree/style/index.less.js +0 -5
- package/es/node_modules/ant-design-vue/es/tree/style/index.less.js.map +0 -1
- package/es/node_modules/ant-design-vue/es/vc-picker/locale/zh_CN.js +0 -33
- package/es/node_modules/ant-design-vue/es/vc-picker/locale/zh_CN.js.map +0 -1
- package/es/node_modules/echarts/lib/action/roamHelper.js +0 -38
- package/es/node_modules/echarts/lib/action/roamHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/animation/basicTrasition.js +0 -149
- package/es/node_modules/echarts/lib/animation/basicTrasition.js.map +0 -1
- package/es/node_modules/echarts/lib/animation/customGraphicKeyframeAnimation.js +0 -92
- package/es/node_modules/echarts/lib/animation/customGraphicKeyframeAnimation.js.map +0 -1
- package/es/node_modules/echarts/lib/animation/customGraphicTransition.js +0 -389
- package/es/node_modules/echarts/lib/animation/customGraphicTransition.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/bar/BarSeries.js +0 -68
- package/es/node_modules/echarts/lib/chart/bar/BarSeries.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/bar/BarView.js +0 -784
- package/es/node_modules/echarts/lib/chart/bar/BarView.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/bar/BaseBarSeries.js +0 -57
- package/es/node_modules/echarts/lib/chart/bar/BaseBarSeries.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/bar/install.js +0 -31
- package/es/node_modules/echarts/lib/chart/bar/install.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/helper/LargeSymbolDraw.js +0 -255
- package/es/node_modules/echarts/lib/chart/helper/LargeSymbolDraw.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/helper/Symbol.js +0 -252
- package/es/node_modules/echarts/lib/chart/helper/Symbol.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/helper/SymbolDraw.js +0 -158
- package/es/node_modules/echarts/lib/chart/helper/SymbolDraw.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/helper/createClipPathFromCoordSys.js +0 -102
- package/es/node_modules/echarts/lib/chart/helper/createClipPathFromCoordSys.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/helper/createRenderPlanner.js +0 -17
- package/es/node_modules/echarts/lib/chart/helper/createRenderPlanner.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/helper/createSeriesData.js +0 -118
- package/es/node_modules/echarts/lib/chart/helper/createSeriesData.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/helper/createSeriesDataSimply.js +0 -19
- package/es/node_modules/echarts/lib/chart/helper/createSeriesDataSimply.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/helper/labelHelper.js +0 -35
- package/es/node_modules/echarts/lib/chart/helper/labelHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/helper/pieHelper.js +0 -23
- package/es/node_modules/echarts/lib/chart/helper/pieHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/line/LineSeries.js +0 -116
- package/es/node_modules/echarts/lib/chart/line/LineSeries.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/line/LineView.js +0 -977
- package/es/node_modules/echarts/lib/chart/line/LineView.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/line/helper.js +0 -81
- package/es/node_modules/echarts/lib/chart/line/helper.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/line/install.js +0 -25
- package/es/node_modules/echarts/lib/chart/line/install.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/line/lineAnimationDiff.js +0 -113
- package/es/node_modules/echarts/lib/chart/line/lineAnimationDiff.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/line/poly.js +0 -304
- package/es/node_modules/echarts/lib/chart/line/poly.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/map/MapSeries.js +0 -185
- package/es/node_modules/echarts/lib/chart/map/MapSeries.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/map/MapView.js +0 -121
- package/es/node_modules/echarts/lib/chart/map/MapView.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/map/install.js +0 -19
- package/es/node_modules/echarts/lib/chart/map/install.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/map/mapDataStatistic.js +0 -62
- package/es/node_modules/echarts/lib/chart/map/mapDataStatistic.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/map/mapSymbolLayout.js +0 -43
- package/es/node_modules/echarts/lib/chart/map/mapSymbolLayout.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/pie/PieSeries.js +0 -153
- package/es/node_modules/echarts/lib/chart/pie/PieSeries.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/pie/PieView.js +0 -230
- package/es/node_modules/echarts/lib/chart/pie/PieView.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/pie/install.js +0 -19
- package/es/node_modules/echarts/lib/chart/pie/install.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/pie/labelLayout.js +0 -391
- package/es/node_modules/echarts/lib/chart/pie/labelLayout.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/pie/pieLayout.js +0 -133
- package/es/node_modules/echarts/lib/chart/pie/pieLayout.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/scatter/ScatterSeries.js +0 -79
- package/es/node_modules/echarts/lib/chart/scatter/ScatterSeries.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/scatter/ScatterView.js +0 -93
- package/es/node_modules/echarts/lib/chart/scatter/ScatterView.js.map +0 -1
- package/es/node_modules/echarts/lib/chart/scatter/install.js +0 -15
- package/es/node_modules/echarts/lib/chart/scatter/install.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axis/AxisBuilder.js +0 -490
- package/es/node_modules/echarts/lib/component/axis/AxisBuilder.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axis/AxisView.js +0 -61
- package/es/node_modules/echarts/lib/component/axis/AxisView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axis/CartesianAxisView.js +0 -193
- package/es/node_modules/echarts/lib/component/axis/CartesianAxisView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axis/axisSplitHelper.js +0 -83
- package/es/node_modules/echarts/lib/component/axis/axisSplitHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axisPointer/AxisPointerModel.js +0 -75
- package/es/node_modules/echarts/lib/component/axisPointer/AxisPointerModel.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axisPointer/AxisPointerView.js +0 -41
- package/es/node_modules/echarts/lib/component/axisPointer/AxisPointerView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axisPointer/BaseAxisPointer.js +0 -288
- package/es/node_modules/echarts/lib/component/axisPointer/BaseAxisPointer.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axisPointer/CartesianAxisPointer.js +0 -107
- package/es/node_modules/echarts/lib/component/axisPointer/CartesianAxisPointer.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axisPointer/axisTrigger.js +0 -293
- package/es/node_modules/echarts/lib/component/axisPointer/axisTrigger.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axisPointer/findPointFromSeries.js +0 -53
- package/es/node_modules/echarts/lib/component/axisPointer/findPointFromSeries.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axisPointer/globalListener.js +0 -87
- package/es/node_modules/echarts/lib/component/axisPointer/globalListener.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axisPointer/install.js +0 -33
- package/es/node_modules/echarts/lib/component/axisPointer/install.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axisPointer/modelHelper.js +0 -202
- package/es/node_modules/echarts/lib/component/axisPointer/modelHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/component/axisPointer/viewHelper.js +0 -144
- package/es/node_modules/echarts/lib/component/axisPointer/viewHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/component/dataZoom/AxisProxy.js +0 -211
- package/es/node_modules/echarts/lib/component/dataZoom/AxisProxy.js.map +0 -1
- package/es/node_modules/echarts/lib/component/dataZoom/DataZoomModel.js +0 -301
- package/es/node_modules/echarts/lib/component/dataZoom/DataZoomModel.js.map +0 -1
- package/es/node_modules/echarts/lib/component/dataZoom/DataZoomView.js +0 -25
- package/es/node_modules/echarts/lib/component/dataZoom/DataZoomView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/dataZoom/SelectZoomModel.js +0 -20
- package/es/node_modules/echarts/lib/component/dataZoom/SelectZoomModel.js.map +0 -1
- package/es/node_modules/echarts/lib/component/dataZoom/SelectZoomView.js +0 -20
- package/es/node_modules/echarts/lib/component/dataZoom/SelectZoomView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/dataZoom/dataZoomAction.js +0 -19
- package/es/node_modules/echarts/lib/component/dataZoom/dataZoomAction.js.map +0 -1
- package/es/node_modules/echarts/lib/component/dataZoom/dataZoomProcessor.js +0 -66
- package/es/node_modules/echarts/lib/component/dataZoom/dataZoomProcessor.js.map +0 -1
- package/es/node_modules/echarts/lib/component/dataZoom/helper.js +0 -65
- package/es/node_modules/echarts/lib/component/dataZoom/helper.js.map +0 -1
- package/es/node_modules/echarts/lib/component/dataZoom/history.js +0 -68
- package/es/node_modules/echarts/lib/component/dataZoom/history.js.map +0 -1
- package/es/node_modules/echarts/lib/component/dataZoom/installCommon.js +0 -18
- package/es/node_modules/echarts/lib/component/dataZoom/installCommon.js.map +0 -1
- package/es/node_modules/echarts/lib/component/dataZoom/installDataZoomSelect.js +0 -12
- package/es/node_modules/echarts/lib/component/dataZoom/installDataZoomSelect.js.map +0 -1
- package/es/node_modules/echarts/lib/component/dataset/install.js +0 -58
- package/es/node_modules/echarts/lib/component/dataset/install.js.map +0 -1
- package/es/node_modules/echarts/lib/component/geo/GeoView.js +0 -73
- package/es/node_modules/echarts/lib/component/geo/GeoView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/geo/install.js +0 -90
- package/es/node_modules/echarts/lib/component/geo/install.js.map +0 -1
- package/es/node_modules/echarts/lib/component/graphic/GraphicModel.js +0 -169
- package/es/node_modules/echarts/lib/component/graphic/GraphicModel.js.map +0 -1
- package/es/node_modules/echarts/lib/component/graphic/GraphicView.js +0 -317
- package/es/node_modules/echarts/lib/component/graphic/GraphicView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/graphic/install.js +0 -27
- package/es/node_modules/echarts/lib/component/graphic/install.js.map +0 -1
- package/es/node_modules/echarts/lib/component/grid/installSimple.js +0 -59
- package/es/node_modules/echarts/lib/component/grid/installSimple.js.map +0 -1
- package/es/node_modules/echarts/lib/component/helper/BrushController.js +0 -656
- package/es/node_modules/echarts/lib/component/helper/BrushController.js.map +0 -1
- package/es/node_modules/echarts/lib/component/helper/BrushTargetManager.js +0 -270
- package/es/node_modules/echarts/lib/component/helper/BrushTargetManager.js.map +0 -1
- package/es/node_modules/echarts/lib/component/helper/MapDraw.js +0 -515
- package/es/node_modules/echarts/lib/component/helper/MapDraw.js.map +0 -1
- package/es/node_modules/echarts/lib/component/helper/RoamController.js +0 -165
- package/es/node_modules/echarts/lib/component/helper/RoamController.js.map +0 -1
- package/es/node_modules/echarts/lib/component/helper/brushHelper.js +0 -33
- package/es/node_modules/echarts/lib/component/helper/brushHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/component/helper/cursorHelper.js +0 -14
- package/es/node_modules/echarts/lib/component/helper/cursorHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/component/helper/interactionMutex.js +0 -31
- package/es/node_modules/echarts/lib/component/helper/interactionMutex.js.map +0 -1
- package/es/node_modules/echarts/lib/component/helper/listComponent.js +0 -37
- package/es/node_modules/echarts/lib/component/helper/listComponent.js.map +0 -1
- package/es/node_modules/echarts/lib/component/helper/roamHelper.js +0 -29
- package/es/node_modules/echarts/lib/component/helper/roamHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/component/helper/sliderMove.js +0 -48
- package/es/node_modules/echarts/lib/component/helper/sliderMove.js.map +0 -1
- package/es/node_modules/echarts/lib/component/legend/LegendModel.js +0 -256
- package/es/node_modules/echarts/lib/component/legend/LegendModel.js.map +0 -1
- package/es/node_modules/echarts/lib/component/legend/LegendView.js +0 -402
- package/es/node_modules/echarts/lib/component/legend/LegendView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/legend/ScrollableLegendModel.js +0 -61
- package/es/node_modules/echarts/lib/component/legend/ScrollableLegendModel.js.map +0 -1
- package/es/node_modules/echarts/lib/component/legend/ScrollableLegendView.js +0 -312
- package/es/node_modules/echarts/lib/component/legend/ScrollableLegendView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/legend/install.js +0 -11
- package/es/node_modules/echarts/lib/component/legend/install.js.map +0 -1
- package/es/node_modules/echarts/lib/component/legend/installLegendPlain.js +0 -17
- package/es/node_modules/echarts/lib/component/legend/installLegendPlain.js.map +0 -1
- package/es/node_modules/echarts/lib/component/legend/installLegendScroll.js +0 -15
- package/es/node_modules/echarts/lib/component/legend/installLegendScroll.js.map +0 -1
- package/es/node_modules/echarts/lib/component/legend/legendAction.js +0 -46
- package/es/node_modules/echarts/lib/component/legend/legendAction.js.map +0 -1
- package/es/node_modules/echarts/lib/component/legend/legendFilter.js +0 -19
- package/es/node_modules/echarts/lib/component/legend/legendFilter.js.map +0 -1
- package/es/node_modules/echarts/lib/component/legend/scrollableLegendAction.js +0 -16
- package/es/node_modules/echarts/lib/component/legend/scrollableLegendAction.js.map +0 -1
- package/es/node_modules/echarts/lib/component/title/install.js +0 -184
- package/es/node_modules/echarts/lib/component/title/install.js.map +0 -1
- package/es/node_modules/echarts/lib/component/toolbox/ToolboxModel.js +0 -72
- package/es/node_modules/echarts/lib/component/toolbox/ToolboxModel.js.map +0 -1
- package/es/node_modules/echarts/lib/component/toolbox/ToolboxView.js +0 -224
- package/es/node_modules/echarts/lib/component/toolbox/ToolboxView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/toolbox/feature/DataView.js +0 -369
- package/es/node_modules/echarts/lib/component/toolbox/feature/DataView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/toolbox/feature/DataZoom.js +0 -206
- package/es/node_modules/echarts/lib/component/toolbox/feature/DataZoom.js.map +0 -1
- package/es/node_modules/echarts/lib/component/toolbox/feature/MagicType.js +0 -163
- package/es/node_modules/echarts/lib/component/toolbox/feature/MagicType.js.map +0 -1
- package/es/node_modules/echarts/lib/component/toolbox/feature/Restore.js +0 -42
- package/es/node_modules/echarts/lib/component/toolbox/feature/Restore.js.map +0 -1
- package/es/node_modules/echarts/lib/component/toolbox/feature/SaveAsImage.js +0 -97
- package/es/node_modules/echarts/lib/component/toolbox/feature/SaveAsImage.js.map +0 -1
- package/es/node_modules/echarts/lib/component/toolbox/featureManager.js +0 -21
- package/es/node_modules/echarts/lib/component/toolbox/featureManager.js.map +0 -1
- package/es/node_modules/echarts/lib/component/toolbox/install.js +0 -24
- package/es/node_modules/echarts/lib/component/toolbox/install.js.map +0 -1
- package/es/node_modules/echarts/lib/component/tooltip/TooltipHTMLContent.js +0 -291
- package/es/node_modules/echarts/lib/component/tooltip/TooltipHTMLContent.js.map +0 -1
- package/es/node_modules/echarts/lib/component/tooltip/TooltipModel.js +0 -88
- package/es/node_modules/echarts/lib/component/tooltip/TooltipModel.js.map +0 -1
- package/es/node_modules/echarts/lib/component/tooltip/TooltipRichContent.js +0 -153
- package/es/node_modules/echarts/lib/component/tooltip/TooltipRichContent.js.map +0 -1
- package/es/node_modules/echarts/lib/component/tooltip/TooltipView.js +0 -684
- package/es/node_modules/echarts/lib/component/tooltip/TooltipView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/tooltip/helper.js +0 -40
- package/es/node_modules/echarts/lib/component/tooltip/helper.js.map +0 -1
- package/es/node_modules/echarts/lib/component/tooltip/install.js +0 -24
- package/es/node_modules/echarts/lib/component/tooltip/install.js.map +0 -1
- package/es/node_modules/echarts/lib/component/tooltip/seriesFormatTooltip.js +0 -95
- package/es/node_modules/echarts/lib/component/tooltip/seriesFormatTooltip.js.map +0 -1
- package/es/node_modules/echarts/lib/component/tooltip/tooltipMarkup.js +0 -245
- package/es/node_modules/echarts/lib/component/tooltip/tooltipMarkup.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/ContinuousModel.js +0 -178
- package/es/node_modules/echarts/lib/component/visualMap/ContinuousModel.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/ContinuousView.js +0 -590
- package/es/node_modules/echarts/lib/component/visualMap/ContinuousView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/PiecewiseModel.js +0 -335
- package/es/node_modules/echarts/lib/component/visualMap/PiecewiseModel.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/PiecewiseView.js +0 -172
- package/es/node_modules/echarts/lib/component/visualMap/PiecewiseView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/VisualMapModel.js +0 -269
- package/es/node_modules/echarts/lib/component/visualMap/VisualMapModel.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/VisualMapView.js +0 -103
- package/es/node_modules/echarts/lib/component/visualMap/VisualMapView.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/helper.js +0 -40
- package/es/node_modules/echarts/lib/component/visualMap/helper.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/install.js +0 -11
- package/es/node_modules/echarts/lib/component/visualMap/install.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/installCommon.js +0 -23
- package/es/node_modules/echarts/lib/component/visualMap/installCommon.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/installVisualMapContinuous.js +0 -12
- package/es/node_modules/echarts/lib/component/visualMap/installVisualMapContinuous.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/installVisualMapPiecewise.js +0 -12
- package/es/node_modules/echarts/lib/component/visualMap/installVisualMapPiecewise.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/preprocessor.js +0 -37
- package/es/node_modules/echarts/lib/component/visualMap/preprocessor.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/visualEncoding.js +0 -66
- package/es/node_modules/echarts/lib/component/visualMap/visualEncoding.js.map +0 -1
- package/es/node_modules/echarts/lib/component/visualMap/visualMapAction.js +0 -19
- package/es/node_modules/echarts/lib/component/visualMap/visualMapAction.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/Axis.js +0 -176
- package/es/node_modules/echarts/lib/coord/Axis.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/CoordinateSystem.js +0 -7
- package/es/node_modules/echarts/lib/coord/CoordinateSystem.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/View.js +0 -166
- package/es/node_modules/echarts/lib/coord/View.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/axisAlignTicks.js +0 -87
- package/es/node_modules/echarts/lib/coord/axisAlignTicks.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/axisCommonTypes.js +0 -10
- package/es/node_modules/echarts/lib/coord/axisCommonTypes.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/axisDefault.js +0 -163
- package/es/node_modules/echarts/lib/coord/axisDefault.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/axisHelper.js +0 -233
- package/es/node_modules/echarts/lib/coord/axisHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/axisModelCommonMixin.js +0 -19
- package/es/node_modules/echarts/lib/coord/axisModelCommonMixin.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/axisModelCreator.js +0 -63
- package/es/node_modules/echarts/lib/coord/axisModelCreator.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/axisTickLabelBuilder.js +0 -225
- package/es/node_modules/echarts/lib/coord/axisTickLabelBuilder.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/cartesian/Axis2D.js +0 -42
- package/es/node_modules/echarts/lib/coord/cartesian/Axis2D.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/cartesian/AxisModel.js +0 -25
- package/es/node_modules/echarts/lib/coord/cartesian/AxisModel.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/cartesian/Cartesian.js +0 -37
- package/es/node_modules/echarts/lib/coord/cartesian/Cartesian.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/cartesian/Cartesian2D.js +0 -116
- package/es/node_modules/echarts/lib/coord/cartesian/Cartesian2D.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/cartesian/Grid.js +0 -384
- package/es/node_modules/echarts/lib/coord/cartesian/Grid.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/cartesian/GridModel.js +0 -36
- package/es/node_modules/echarts/lib/coord/cartesian/GridModel.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/cartesian/cartesianAxisHelper.js +0 -73
- package/es/node_modules/echarts/lib/coord/cartesian/cartesianAxisHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/geo/Geo.js +0 -151
- package/es/node_modules/echarts/lib/coord/geo/Geo.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/geo/GeoJSONResource.js +0 -93
- package/es/node_modules/echarts/lib/coord/geo/GeoJSONResource.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/geo/GeoModel.js +0 -164
- package/es/node_modules/echarts/lib/coord/geo/GeoModel.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/geo/GeoSVGResource.js +0 -174
- package/es/node_modules/echarts/lib/coord/geo/GeoSVGResource.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/geo/Region.js +0 -237
- package/es/node_modules/echarts/lib/coord/geo/Region.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/geo/fix/diaoyuIsland.js +0 -13
- package/es/node_modules/echarts/lib/coord/geo/fix/diaoyuIsland.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/geo/fix/nanhai.js +0 -32
- package/es/node_modules/echarts/lib/coord/geo/fix/nanhai.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/geo/fix/textCoord.js +0 -24
- package/es/node_modules/echarts/lib/coord/geo/fix/textCoord.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/geo/geoCreator.js +0 -177
- package/es/node_modules/echarts/lib/coord/geo/geoCreator.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/geo/geoSourceManager.js +0 -76
- package/es/node_modules/echarts/lib/coord/geo/geoSourceManager.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/geo/parseGeoJson.js +0 -95
- package/es/node_modules/echarts/lib/coord/geo/parseGeoJson.js.map +0 -1
- package/es/node_modules/echarts/lib/coord/scaleRawExtentInfo.js +0 -140
- package/es/node_modules/echarts/lib/coord/scaleRawExtentInfo.js.map +0 -1
- package/es/node_modules/echarts/lib/core/CoordinateSystem.js +0 -38
- package/es/node_modules/echarts/lib/core/CoordinateSystem.js.map +0 -1
- package/es/node_modules/echarts/lib/core/ExtensionAPI.js +0 -37
- package/es/node_modules/echarts/lib/core/ExtensionAPI.js.map +0 -1
- package/es/node_modules/echarts/lib/core/Scheduler.js +0 -358
- package/es/node_modules/echarts/lib/core/Scheduler.js.map +0 -1
- package/es/node_modules/echarts/lib/core/echarts.js +0 -1784
- package/es/node_modules/echarts/lib/core/echarts.js.map +0 -1
- package/es/node_modules/echarts/lib/core/impl.js +0 -23
- package/es/node_modules/echarts/lib/core/impl.js.map +0 -1
- package/es/node_modules/echarts/lib/core/lifecycle.js +0 -7
- package/es/node_modules/echarts/lib/core/lifecycle.js.map +0 -1
- package/es/node_modules/echarts/lib/core/locale.js +0 -50
- package/es/node_modules/echarts/lib/core/locale.js.map +0 -1
- package/es/node_modules/echarts/lib/core/task.js +0 -184
- package/es/node_modules/echarts/lib/core/task.js.map +0 -1
- package/es/node_modules/echarts/lib/data/DataDiffer.js +0 -155
- package/es/node_modules/echarts/lib/data/DataDiffer.js.map +0 -1
- package/es/node_modules/echarts/lib/data/DataStore.js +0 -788
- package/es/node_modules/echarts/lib/data/DataStore.js.map +0 -1
- package/es/node_modules/echarts/lib/data/OrdinalMeta.js +0 -67
- package/es/node_modules/echarts/lib/data/OrdinalMeta.js.map +0 -1
- package/es/node_modules/echarts/lib/data/SeriesData.js +0 -666
- package/es/node_modules/echarts/lib/data/SeriesData.js.map +0 -1
- package/es/node_modules/echarts/lib/data/SeriesDimensionDefine.js +0 -18
- package/es/node_modules/echarts/lib/data/SeriesDimensionDefine.js.map +0 -1
- package/es/node_modules/echarts/lib/data/Source.js +0 -220
- package/es/node_modules/echarts/lib/data/Source.js.map +0 -1
- package/es/node_modules/echarts/lib/data/helper/SeriesDataSchema.js +0 -145
- package/es/node_modules/echarts/lib/data/helper/SeriesDataSchema.js.map +0 -1
- package/es/node_modules/echarts/lib/data/helper/createDimensions.js +0 -213
- package/es/node_modules/echarts/lib/data/helper/createDimensions.js.map +0 -1
- package/es/node_modules/echarts/lib/data/helper/dataProvider.js +0 -257
- package/es/node_modules/echarts/lib/data/helper/dataProvider.js.map +0 -1
- package/es/node_modules/echarts/lib/data/helper/dataStackHelper.js +0 -108
- package/es/node_modules/echarts/lib/data/helper/dataStackHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/data/helper/dataValueHelper.js +0 -65
- package/es/node_modules/echarts/lib/data/helper/dataValueHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/data/helper/dimensionHelper.js +0 -104
- package/es/node_modules/echarts/lib/data/helper/dimensionHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/data/helper/sourceHelper.js +0 -243
- package/es/node_modules/echarts/lib/data/helper/sourceHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/data/helper/sourceManager.js +0 -236
- package/es/node_modules/echarts/lib/data/helper/sourceManager.js.map +0 -1
- package/es/node_modules/echarts/lib/data/helper/transform.js +0 -296
- package/es/node_modules/echarts/lib/data/helper/transform.js.map +0 -1
- package/es/node_modules/echarts/lib/extension.js +0 -70
- package/es/node_modules/echarts/lib/extension.js.map +0 -1
- package/es/node_modules/echarts/lib/i18n/langEN.js +0 -113
- package/es/node_modules/echarts/lib/i18n/langEN.js.map +0 -1
- package/es/node_modules/echarts/lib/i18n/langZH.js +0 -113
- package/es/node_modules/echarts/lib/i18n/langZH.js.map +0 -1
- package/es/node_modules/echarts/lib/label/labelGuideHelper.js +0 -218
- package/es/node_modules/echarts/lib/label/labelGuideHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/label/labelLayoutHelper.js +0 -222
- package/es/node_modules/echarts/lib/label/labelLayoutHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/label/labelStyle.js +0 -352
- package/es/node_modules/echarts/lib/label/labelStyle.js.map +0 -1
- package/es/node_modules/echarts/lib/label/sectorLabel.js +0 -153
- package/es/node_modules/echarts/lib/label/sectorLabel.js.map +0 -1
- package/es/node_modules/echarts/lib/layout/barGrid.js +0 -368
- package/es/node_modules/echarts/lib/layout/barGrid.js.map +0 -1
- package/es/node_modules/echarts/lib/layout/points.js +0 -63
- package/es/node_modules/echarts/lib/layout/points.js.map +0 -1
- package/es/node_modules/echarts/lib/legacy/dataSelectAction.js +0 -76
- package/es/node_modules/echarts/lib/legacy/dataSelectAction.js.map +0 -1
- package/es/node_modules/echarts/lib/loading/default.js +0 -109
- package/es/node_modules/echarts/lib/loading/default.js.map +0 -1
- package/es/node_modules/echarts/lib/model/Component.js +0 -120
- package/es/node_modules/echarts/lib/model/Component.js.map +0 -1
- package/es/node_modules/echarts/lib/model/Global.js +0 -572
- package/es/node_modules/echarts/lib/model/Global.js.map +0 -1
- package/es/node_modules/echarts/lib/model/Model.js +0 -104
- package/es/node_modules/echarts/lib/model/Model.js.map +0 -1
- package/es/node_modules/echarts/lib/model/OptionManager.js +0 -191
- package/es/node_modules/echarts/lib/model/OptionManager.js.map +0 -1
- package/es/node_modules/echarts/lib/model/Series.js +0 -380
- package/es/node_modules/echarts/lib/model/Series.js.map +0 -1
- package/es/node_modules/echarts/lib/model/globalDefault.js +0 -90
- package/es/node_modules/echarts/lib/model/globalDefault.js.map +0 -1
- package/es/node_modules/echarts/lib/model/internalComponentCreator.js +0 -28
- package/es/node_modules/echarts/lib/model/internalComponentCreator.js.map +0 -1
- package/es/node_modules/echarts/lib/model/mixin/areaStyle.js +0 -28
- package/es/node_modules/echarts/lib/model/mixin/areaStyle.js.map +0 -1
- package/es/node_modules/echarts/lib/model/mixin/dataFormat.js +0 -119
- package/es/node_modules/echarts/lib/model/mixin/dataFormat.js.map +0 -1
- package/es/node_modules/echarts/lib/model/mixin/itemStyle.js +0 -35
- package/es/node_modules/echarts/lib/model/mixin/itemStyle.js.map +0 -1
- package/es/node_modules/echarts/lib/model/mixin/lineStyle.js +0 -34
- package/es/node_modules/echarts/lib/model/mixin/lineStyle.js.map +0 -1
- package/es/node_modules/echarts/lib/model/mixin/makeStyleMapper.js +0 -27
- package/es/node_modules/echarts/lib/model/mixin/makeStyleMapper.js.map +0 -1
- package/es/node_modules/echarts/lib/model/mixin/palette.js +0 -56
- package/es/node_modules/echarts/lib/model/mixin/palette.js.map +0 -1
- package/es/node_modules/echarts/lib/model/mixin/textStyle.js +0 -42
- package/es/node_modules/echarts/lib/model/mixin/textStyle.js.map +0 -1
- package/es/node_modules/echarts/lib/model/referHelper.js +0 -112
- package/es/node_modules/echarts/lib/model/referHelper.js.map +0 -1
- package/es/node_modules/echarts/lib/preprocessor/backwardCompat.js +0 -213
- package/es/node_modules/echarts/lib/preprocessor/backwardCompat.js.map +0 -1
- package/es/node_modules/echarts/lib/preprocessor/helper/compatStyle.js +0 -269
- package/es/node_modules/echarts/lib/preprocessor/helper/compatStyle.js.map +0 -1
- package/es/node_modules/echarts/lib/processor/dataFilter.js +0 -27
- package/es/node_modules/echarts/lib/processor/dataFilter.js.map +0 -1
- package/es/node_modules/echarts/lib/processor/dataSample.js +0 -82
- package/es/node_modules/echarts/lib/processor/dataSample.js.map +0 -1
- package/es/node_modules/echarts/lib/processor/dataStack.js +0 -74
- package/es/node_modules/echarts/lib/processor/dataStack.js.map +0 -1
- package/es/node_modules/echarts/lib/processor/negativeDataFilter.js +0 -21
- package/es/node_modules/echarts/lib/processor/negativeDataFilter.js.map +0 -1
- package/es/node_modules/echarts/lib/renderer/installCanvasRenderer.js +0 -8
- package/es/node_modules/echarts/lib/renderer/installCanvasRenderer.js.map +0 -1
- package/es/node_modules/echarts/lib/scale/Interval.js +0 -193
- package/es/node_modules/echarts/lib/scale/Interval.js.map +0 -1
- package/es/node_modules/echarts/lib/scale/Log.js +0 -122
- package/es/node_modules/echarts/lib/scale/Log.js.map +0 -1
- package/es/node_modules/echarts/lib/scale/Ordinal.js +0 -126
- package/es/node_modules/echarts/lib/scale/Ordinal.js.map +0 -1
- package/es/node_modules/echarts/lib/scale/Scale.js +0 -49
- package/es/node_modules/echarts/lib/scale/Scale.js.map +0 -1
- package/es/node_modules/echarts/lib/scale/Time.js +0 -380
- package/es/node_modules/echarts/lib/scale/Time.js.map +0 -1
- package/es/node_modules/echarts/lib/scale/helper.js +0 -77
- package/es/node_modules/echarts/lib/scale/helper.js.map +0 -1
- package/es/node_modules/echarts/lib/theme/dark.js +0 -183
- package/es/node_modules/echarts/lib/theme/dark.js.map +0 -1
- package/es/node_modules/echarts/lib/theme/light.js +0 -9
- package/es/node_modules/echarts/lib/theme/light.js.map +0 -1
- package/es/node_modules/echarts/lib/util/ECEventProcessor.js +0 -80
- package/es/node_modules/echarts/lib/util/ECEventProcessor.js.map +0 -1
- package/es/node_modules/echarts/lib/util/clazz.js +0 -165
- package/es/node_modules/echarts/lib/util/clazz.js.map +0 -1
- package/es/node_modules/echarts/lib/util/component.js +0 -117
- package/es/node_modules/echarts/lib/util/component.js.map +0 -1
- package/es/node_modules/echarts/lib/util/decal.js +0 -292
- package/es/node_modules/echarts/lib/util/decal.js.map +0 -1
- package/es/node_modules/echarts/lib/util/event.js +0 -17
- package/es/node_modules/echarts/lib/util/event.js.map +0 -1
- package/es/node_modules/echarts/lib/util/format.js +0 -140
- package/es/node_modules/echarts/lib/util/format.js.map +0 -1
- package/es/node_modules/echarts/lib/util/graphic.js +0 -376
- package/es/node_modules/echarts/lib/util/graphic.js.map +0 -1
- package/es/node_modules/echarts/lib/util/innerStore.js +0 -23
- package/es/node_modules/echarts/lib/util/innerStore.js.map +0 -1
- package/es/node_modules/echarts/lib/util/layout.js +0 -249
- package/es/node_modules/echarts/lib/util/layout.js.map +0 -1
- package/es/node_modules/echarts/lib/util/log.js +0 -81
- package/es/node_modules/echarts/lib/util/log.js.map +0 -1
- package/es/node_modules/echarts/lib/util/model.js +0 -464
- package/es/node_modules/echarts/lib/util/model.js.map +0 -1
- package/es/node_modules/echarts/lib/util/number.js +0 -306
- package/es/node_modules/echarts/lib/util/number.js.map +0 -1
- package/es/node_modules/echarts/lib/util/shape/sausage.js +0 -69
- package/es/node_modules/echarts/lib/util/shape/sausage.js.map +0 -1
- package/es/node_modules/echarts/lib/util/states.js +0 -598
- package/es/node_modules/echarts/lib/util/states.js.map +0 -1
- package/es/node_modules/echarts/lib/util/styleCompat.js +0 -78
- package/es/node_modules/echarts/lib/util/styleCompat.js.map +0 -1
- package/es/node_modules/echarts/lib/util/symbol.js +0 -267
- package/es/node_modules/echarts/lib/util/symbol.js.map +0 -1
- package/es/node_modules/echarts/lib/util/throttle.js +0 -85
- package/es/node_modules/echarts/lib/util/throttle.js.map +0 -1
- package/es/node_modules/echarts/lib/util/time.js +0 -253
- package/es/node_modules/echarts/lib/util/time.js.map +0 -1
- package/es/node_modules/echarts/lib/util/types.js +0 -22
- package/es/node_modules/echarts/lib/util/types.js.map +0 -1
- package/es/node_modules/echarts/lib/util/vendor.js +0 -13
- package/es/node_modules/echarts/lib/util/vendor.js.map +0 -1
- package/es/node_modules/echarts/lib/view/Chart.js +0 -139
- package/es/node_modules/echarts/lib/view/Chart.js.map +0 -1
- package/es/node_modules/echarts/lib/view/Component.js +0 -40
- package/es/node_modules/echarts/lib/view/Component.js.map +0 -1
- package/es/node_modules/echarts/lib/visual/LegendVisualProvider.js +0 -31
- package/es/node_modules/echarts/lib/visual/LegendVisualProvider.js.map +0 -1
- package/es/node_modules/echarts/lib/visual/VisualMapping.js +0 -369
- package/es/node_modules/echarts/lib/visual/VisualMapping.js.map +0 -1
- package/es/node_modules/echarts/lib/visual/decal.js +0 -27
- package/es/node_modules/echarts/lib/visual/decal.js.map +0 -1
- package/es/node_modules/echarts/lib/visual/helper.js +0 -61
- package/es/node_modules/echarts/lib/visual/helper.js.map +0 -1
- package/es/node_modules/echarts/lib/visual/style.js +0 -160
- package/es/node_modules/echarts/lib/visual/style.js.map +0 -1
- package/es/node_modules/echarts/lib/visual/symbol.js +0 -82
- package/es/node_modules/echarts/lib/visual/symbol.js.map +0 -1
- package/es/node_modules/echarts/lib/visual/visualDefault.js +0 -49
- package/es/node_modules/echarts/lib/visual/visualDefault.js.map +0 -1
- package/es/node_modules/echarts/lib/visual/visualSolution.js +0 -101
- package/es/node_modules/echarts/lib/visual/visualSolution.js.map +0 -1
- package/es/node_modules/echarts/node_modules/tslib/tslib.es6.js +0 -37
- package/es/node_modules/echarts/node_modules/tslib/tslib.es6.js.map +0 -1
- package/es/node_modules/zrender/lib/Element.js +0 -994
- package/es/node_modules/zrender/lib/Element.js.map +0 -1
- package/es/node_modules/zrender/lib/Handler.js +0 -257
- package/es/node_modules/zrender/lib/Handler.js.map +0 -1
- package/es/node_modules/zrender/lib/Storage.js +0 -158
- package/es/node_modules/zrender/lib/Storage.js.map +0 -1
- package/es/node_modules/zrender/lib/animation/Animation.js +0 -148
- package/es/node_modules/zrender/lib/animation/Animation.js.map +0 -1
- package/es/node_modules/zrender/lib/animation/Animator.js +0 -702
- package/es/node_modules/zrender/lib/animation/Animator.js.map +0 -1
- package/es/node_modules/zrender/lib/animation/Clip.js +0 -65
- package/es/node_modules/zrender/lib/animation/Clip.js.map +0 -1
- package/es/node_modules/zrender/lib/animation/cubicEasing.js +0 -24
- package/es/node_modules/zrender/lib/animation/cubicEasing.js.map +0 -1
- package/es/node_modules/zrender/lib/animation/easing.js +0 -189
- package/es/node_modules/zrender/lib/animation/easing.js.map +0 -1
- package/es/node_modules/zrender/lib/animation/requestAnimationFrame.js +0 -10
- package/es/node_modules/zrender/lib/animation/requestAnimationFrame.js.map +0 -1
- package/es/node_modules/zrender/lib/canvas/Layer.js +0 -283
- package/es/node_modules/zrender/lib/canvas/Layer.js.map +0 -1
- package/es/node_modules/zrender/lib/canvas/Painter.js +0 -618
- package/es/node_modules/zrender/lib/canvas/Painter.js.map +0 -1
- package/es/node_modules/zrender/lib/canvas/dashStyle.js +0 -27
- package/es/node_modules/zrender/lib/canvas/dashStyle.js.map +0 -1
- package/es/node_modules/zrender/lib/canvas/graphic.js +0 -522
- package/es/node_modules/zrender/lib/canvas/graphic.js.map +0 -1
- package/es/node_modules/zrender/lib/canvas/helper.js +0 -83
- package/es/node_modules/zrender/lib/canvas/helper.js.map +0 -1
- package/es/node_modules/zrender/lib/config.js +0 -18
- package/es/node_modules/zrender/lib/config.js.map +0 -1
- package/es/node_modules/zrender/lib/contain/arc.js +0 -37
- package/es/node_modules/zrender/lib/contain/arc.js.map +0 -1
- package/es/node_modules/zrender/lib/contain/cubic.js +0 -16
- package/es/node_modules/zrender/lib/contain/cubic.js.map +0 -1
- package/es/node_modules/zrender/lib/contain/line.js +0 -24
- package/es/node_modules/zrender/lib/contain/line.js.map +0 -1
- package/es/node_modules/zrender/lib/contain/path.js +0 -290
- package/es/node_modules/zrender/lib/contain/path.js.map +0 -1
- package/es/node_modules/zrender/lib/contain/polygon.js +0 -26
- package/es/node_modules/zrender/lib/contain/polygon.js.map +0 -1
- package/es/node_modules/zrender/lib/contain/quadratic.js +0 -16
- package/es/node_modules/zrender/lib/contain/quadratic.js.map +0 -1
- package/es/node_modules/zrender/lib/contain/text.js +0 -174
- package/es/node_modules/zrender/lib/contain/text.js.map +0 -1
- package/es/node_modules/zrender/lib/contain/util.js +0 -12
- package/es/node_modules/zrender/lib/contain/util.js.map +0 -1
- package/es/node_modules/zrender/lib/contain/windingLine.js +0 -19
- package/es/node_modules/zrender/lib/contain/windingLine.js.map +0 -1
- package/es/node_modules/zrender/lib/core/BoundingRect.js +0 -205
- package/es/node_modules/zrender/lib/core/BoundingRect.js.map +0 -1
- package/es/node_modules/zrender/lib/core/Eventful.js +0 -155
- package/es/node_modules/zrender/lib/core/Eventful.js.map +0 -1
- package/es/node_modules/zrender/lib/core/GestureMgr.js +0 -82
- package/es/node_modules/zrender/lib/core/GestureMgr.js.map +0 -1
- package/es/node_modules/zrender/lib/core/LRU.js +0 -110
- package/es/node_modules/zrender/lib/core/LRU.js.map +0 -1
- package/es/node_modules/zrender/lib/core/OrientedBoundingRect.js +0 -121
- package/es/node_modules/zrender/lib/core/OrientedBoundingRect.js.map +0 -1
- package/es/node_modules/zrender/lib/core/PathProxy.js +0 -697
- package/es/node_modules/zrender/lib/core/PathProxy.js.map +0 -1
- package/es/node_modules/zrender/lib/core/Point.js +0 -133
- package/es/node_modules/zrender/lib/core/Point.js.map +0 -1
- package/es/node_modules/zrender/lib/core/Transformable.js +0 -233
- package/es/node_modules/zrender/lib/core/Transformable.js.map +0 -1
- package/es/node_modules/zrender/lib/core/WeakMap.js +0 -45
- package/es/node_modules/zrender/lib/core/WeakMap.js.map +0 -1
- package/es/node_modules/zrender/lib/core/bbox.js +0 -109
- package/es/node_modules/zrender/lib/core/bbox.js.map +0 -1
- package/es/node_modules/zrender/lib/core/curve.js +0 -345
- package/es/node_modules/zrender/lib/core/curve.js.map +0 -1
- package/es/node_modules/zrender/lib/core/dom.js +0 -79
- package/es/node_modules/zrender/lib/core/dom.js.map +0 -1
- package/es/node_modules/zrender/lib/core/env.js +0 -73
- package/es/node_modules/zrender/lib/core/env.js.map +0 -1
- package/es/node_modules/zrender/lib/core/event.js +0 -101
- package/es/node_modules/zrender/lib/core/event.js.map +0 -1
- package/es/node_modules/zrender/lib/core/fourPointsTransform.js +0 -60
- package/es/node_modules/zrender/lib/core/fourPointsTransform.js.map +0 -1
- package/es/node_modules/zrender/lib/core/matrix.js +0 -104
- package/es/node_modules/zrender/lib/core/matrix.js.map +0 -1
- package/es/node_modules/zrender/lib/core/platform.js +0 -70
- package/es/node_modules/zrender/lib/core/platform.js.map +0 -1
- package/es/node_modules/zrender/lib/core/timsort.js +0 -512
- package/es/node_modules/zrender/lib/core/timsort.js.map +0 -1
- package/es/node_modules/zrender/lib/core/util.js +0 -508
- package/es/node_modules/zrender/lib/core/util.js.map +0 -1
- package/es/node_modules/zrender/lib/core/vector.js +0 -99
- package/es/node_modules/zrender/lib/core/vector.js.map +0 -1
- package/es/node_modules/zrender/lib/dom/HandlerProxy.js +0 -302
- package/es/node_modules/zrender/lib/dom/HandlerProxy.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/CompoundPath.js +0 -53
- package/es/node_modules/zrender/lib/graphic/CompoundPath.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/Displayable.js +0 -316
- package/es/node_modules/zrender/lib/graphic/Displayable.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/Gradient.js +0 -17
- package/es/node_modules/zrender/lib/graphic/Gradient.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/Group.js +0 -181
- package/es/node_modules/zrender/lib/graphic/Group.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/Image.js +0 -75
- package/es/node_modules/zrender/lib/graphic/Image.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/IncrementalDisplayable.js +0 -115
- package/es/node_modules/zrender/lib/graphic/IncrementalDisplayable.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/LinearGradient.js +0 -21
- package/es/node_modules/zrender/lib/graphic/LinearGradient.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/Path.js +0 -395
- package/es/node_modules/zrender/lib/graphic/Path.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/RadialGradient.js +0 -20
- package/es/node_modules/zrender/lib/graphic/RadialGradient.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/TSpan.js +0 -68
- package/es/node_modules/zrender/lib/graphic/TSpan.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/Text.js +0 -506
- package/es/node_modules/zrender/lib/graphic/Text.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/constants.js +0 -9
- package/es/node_modules/zrender/lib/graphic/constants.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/helper/image.js +0 -56
- package/es/node_modules/zrender/lib/graphic/helper/image.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/helper/parseText.js +0 -447
- package/es/node_modules/zrender/lib/graphic/helper/parseText.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/helper/poly.js +0 -28
- package/es/node_modules/zrender/lib/graphic/helper/poly.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/helper/roundRect.js +0 -74
- package/es/node_modules/zrender/lib/graphic/helper/roundRect.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/helper/roundSector.js +0 -219
- package/es/node_modules/zrender/lib/graphic/helper/roundSector.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/helper/smoothBezier.js +0 -65
- package/es/node_modules/zrender/lib/graphic/helper/smoothBezier.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/helper/subPixelOptimize.js +0 -60
- package/es/node_modules/zrender/lib/graphic/helper/subPixelOptimize.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/shape/Arc.js +0 -48
- package/es/node_modules/zrender/lib/graphic/shape/Arc.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/shape/BezierCurve.js +0 -100
- package/es/node_modules/zrender/lib/graphic/shape/BezierCurve.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/shape/Circle.js +0 -31
- package/es/node_modules/zrender/lib/graphic/shape/Circle.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/shape/Ellipse.js +0 -43
- package/es/node_modules/zrender/lib/graphic/shape/Ellipse.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/shape/Line.js +0 -72
- package/es/node_modules/zrender/lib/graphic/shape/Line.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/shape/Polygon.js +0 -31
- package/es/node_modules/zrender/lib/graphic/shape/Polygon.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/shape/Polyline.js +0 -38
- package/es/node_modules/zrender/lib/graphic/shape/Polyline.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/shape/Rect.js +0 -59
- package/es/node_modules/zrender/lib/graphic/shape/Rect.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/shape/Ring.js +0 -37
- package/es/node_modules/zrender/lib/graphic/shape/Ring.js.map +0 -1
- package/es/node_modules/zrender/lib/graphic/shape/Sector.js +0 -39
- package/es/node_modules/zrender/lib/graphic/shape/Sector.js.map +0 -1
- package/es/node_modules/zrender/lib/mixin/Draggable.js +0 -70
- package/es/node_modules/zrender/lib/mixin/Draggable.js.map +0 -1
- package/es/node_modules/zrender/lib/svg/helper.js +0 -31
- package/es/node_modules/zrender/lib/svg/helper.js.map +0 -1
- package/es/node_modules/zrender/lib/tool/color.js +0 -459
- package/es/node_modules/zrender/lib/tool/color.js.map +0 -1
- package/es/node_modules/zrender/lib/tool/parseSVG.js +0 -633
- package/es/node_modules/zrender/lib/tool/parseSVG.js.map +0 -1
- package/es/node_modules/zrender/lib/tool/parseXML.js +0 -19
- package/es/node_modules/zrender/lib/tool/parseXML.js.map +0 -1
- package/es/node_modules/zrender/lib/tool/path.js +0 -339
- package/es/node_modules/zrender/lib/tool/path.js.map +0 -1
- package/es/node_modules/zrender/lib/tool/transformPath.js +0 -85
- package/es/node_modules/zrender/lib/tool/transformPath.js.map +0 -1
- package/es/node_modules/zrender/lib/zrender.js +0 -238
- package/es/node_modules/zrender/lib/zrender.js.map +0 -1
- package/es/node_modules/zrender/node_modules/tslib/tslib.es6.js +0 -37
- package/es/node_modules/zrender/node_modules/tslib/tslib.es6.js.map +0 -1
- package/es/setting/page-config/PageConfig.vue.js +0 -24
- package/es/setting/page-config/PageConfig.vue.js.map +0 -1
- package/es/setting/page-config/PageConfig.vue2.js +0 -109
- package/es/setting/page-config/PageConfig.vue2.js.map +0 -1
- package/es/setting/page-config/PageConfig.vue3.js +0 -5
- package/es/setting/page-config/PageConfig.vue3.js.map +0 -1
- package/es/setting/page-config/index.js +0 -11
- package/es/setting/page-config/index.js.map +0 -1
- package/es/setting/page-config/props.js +0 -16
- package/es/setting/page-config/props.js.map +0 -1
- package/es/setting/provider-config/ProviderConfig.vue.js +0 -17
- package/es/setting/provider-config/ProviderConfig.vue.js.map +0 -1
- package/es/setting/provider-config/ProviderConfig.vue2.js +0 -177
- package/es/setting/provider-config/ProviderConfig.vue2.js.map +0 -1
- package/es/setting/provider-config/index.js +0 -11
- package/es/setting/provider-config/index.js.map +0 -1
- package/es/setting/provider-config/props.js +0 -13
- package/es/setting/provider-config/props.js.map +0 -1
- package/es/table/table/Table.vue.js +0 -164
- package/es/table/table/Table.vue.js.map +0 -1
- package/es/table/table/Table.vue2.js +0 -547
- package/es/table/table/Table.vue2.js.map +0 -1
- package/es/table/table/Table.vue3.js +0 -5
- package/es/table/table/Table.vue3.js.map +0 -1
- package/es/table/table/Table.vue4.js +0 -5
- package/es/table/table/Table.vue4.js.map +0 -1
- package/es/table/table/index.js +0 -12
- package/es/table/table/index.js.map +0 -1
- package/es/table/table/props.js +0 -78
- package/es/table/table/props.js.map +0 -1
- package/es/text/list/List.vue.js +0 -112
- package/es/text/list/List.vue.js.map +0 -1
- package/es/text/list/List.vue2.js +0 -107
- package/es/text/list/List.vue2.js.map +0 -1
- package/es/text/list/List.vue3.js +0 -5
- package/es/text/list/List.vue3.js.map +0 -1
- package/es/text/list/List.vue4.js +0 -5
- package/es/text/list/List.vue4.js.map +0 -1
- package/es/text/list/index.js +0 -12
- package/es/text/list/index.js.map +0 -1
- package/es/text/list/props.js +0 -43
- package/es/text/list/props.js.map +0 -1
- package/es/text/proportion/Proportion.vue.js +0 -48
- package/es/text/proportion/Proportion.vue.js.map +0 -1
- package/es/text/proportion/Proportion.vue2.js +0 -163
- package/es/text/proportion/Proportion.vue2.js.map +0 -1
- package/es/text/proportion/Proportion.vue3.js +0 -5
- package/es/text/proportion/Proportion.vue3.js.map +0 -1
- package/es/text/proportion/index.js +0 -12
- package/es/text/proportion/index.js.map +0 -1
- package/es/text/proportion/props.js +0 -33
- package/es/text/proportion/props.js.map +0 -1
- package/es/text/scroll-text/ScrollText.vue.js +0 -13
- package/es/text/scroll-text/ScrollText.vue.js.map +0 -1
- package/es/text/scroll-text/ScrollText.vue2.js +0 -14
- package/es/text/scroll-text/ScrollText.vue2.js.map +0 -1
- package/es/text/scroll-text/ScrollText.vue3.js +0 -5
- package/es/text/scroll-text/ScrollText.vue3.js.map +0 -1
- package/es/text/scroll-text/index.js +0 -8
- package/es/text/scroll-text/index.js.map +0 -1
- package/es/text/text/Text.vue.js +0 -26
- package/es/text/text/Text.vue.js.map +0 -1
- package/es/text/text/Text.vue2.js +0 -153
- package/es/text/text/Text.vue2.js.map +0 -1
- package/es/text/text/Text.vue3.js +0 -5
- package/es/text/text/Text.vue3.js.map +0 -1
- package/es/text/text/index.js +0 -12
- package/es/text/text/index.js.map +0 -1
- package/es/text/text/props.js +0 -33
- package/es/text/text/props.js.map +0 -1
- package/es/text/time-display/TimeDisplay.vue.js +0 -15
- package/es/text/time-display/TimeDisplay.vue.js.map +0 -1
- package/es/text/time-display/TimeDisplay.vue2.js +0 -46
- package/es/text/time-display/TimeDisplay.vue2.js.map +0 -1
- package/es/text/time-display/TimeDisplay.vue3.js +0 -5
- package/es/text/time-display/TimeDisplay.vue3.js.map +0 -1
- package/es/text/time-display/index.js +0 -11
- package/es/text/time-display/index.js.map +0 -1
- package/es/text/time-display/props.js +0 -23
- package/es/text/time-display/props.js.map +0 -1
- package/es/utils/constant.js +0 -23
- package/es/utils/constant.js.map +0 -1
- package/es/utils/props.js +0 -40
- package/es/utils/props.js.map +0 -1
- package/es/utils/request.js +0 -47
- package/es/utils/request.js.map +0 -1
- package/es/utils/util.js +0 -31
- package/es/utils/util.js.map +0 -1
- package/es/utils/withInstall.js +0 -19
- package/es/utils/withInstall.js.map +0 -1
- package/lib/_virtual/_plugin-vue_export-helper.js +0 -11
- package/lib/_virtual/_plugin-vue_export-helper.js.map +0 -1
- package/lib/assets/border-title-decoration-left.png.js +0 -5
- package/lib/assets/border-title-decoration-left.png.js.map +0 -1
- package/lib/assets/border-title-decoration-right.png.js +0 -5
- package/lib/assets/border-title-decoration-right.png.js.map +0 -1
- package/lib/assets/go-down.png.js +0 -5
- package/lib/assets/go-down.png.js.map +0 -1
- package/lib/assets/go-up.png.js +0 -5
- package/lib/assets/go-up.png.js.map +0 -1
- package/lib/common/echarts/Echarts.js +0 -199
- package/lib/common/echarts/Echarts.js.map +0 -1
- package/lib/common/echarts/composables/api.js +0 -43
- package/lib/common/echarts/composables/api.js.map +0 -1
- package/lib/common/echarts/composables/autoresize.js +0 -27
- package/lib/common/echarts/composables/autoresize.js.map +0 -1
- package/lib/common/echarts/composables/loading.js +0 -30
- package/lib/common/echarts/composables/loading.js.map +0 -1
- package/lib/common/echarts/index.js +0 -5
- package/lib/common/echarts/index.js.map +0 -1
- package/lib/common/echarts/style.css.js +0 -5
- package/lib/common/echarts/style.css.js.map +0 -1
- package/lib/common/echarts/utils.js +0 -16
- package/lib/common/echarts/utils.js.map +0 -1
- package/lib/common/skeleton/Skeleton.vue.js +0 -20
- package/lib/common/skeleton/Skeleton.vue.js.map +0 -1
- package/lib/common/skeleton/Skeleton.vue2.js +0 -20
- package/lib/common/skeleton/Skeleton.vue2.js.map +0 -1
- package/lib/common/skeleton/index.js +0 -5
- package/lib/common/skeleton/index.js.map +0 -1
- package/lib/common/spin/Spin.vue.js +0 -32
- package/lib/common/spin/Spin.vue.js.map +0 -1
- package/lib/common/spin/Spin.vue2.js +0 -5
- package/lib/common/spin/Spin.vue2.js.map +0 -1
- package/lib/common/spin/Spin.vue3.js +0 -22
- package/lib/common/spin/Spin.vue3.js.map +0 -1
- package/lib/common/spin/index.js +0 -5
- package/lib/common/spin/index.js.map +0 -1
- package/lib/components.js +0 -153
- package/lib/components.js.map +0 -1
- package/lib/container/border/Border.vue.js +0 -78
- package/lib/container/border/Border.vue.js.map +0 -1
- package/lib/container/border/Border.vue2.js +0 -65
- package/lib/container/border/Border.vue2.js.map +0 -1
- package/lib/container/border/Border.vue3.js +0 -5
- package/lib/container/border/Border.vue3.js.map +0 -1
- package/lib/container/border/index.js +0 -12
- package/lib/container/border/index.js.map +0 -1
- package/lib/container/border/props.js +0 -31
- package/lib/container/border/props.js.map +0 -1
- package/lib/container/modal/Modal.vue.js +0 -59
- package/lib/container/modal/Modal.vue.js.map +0 -1
- package/lib/container/modal/Modal.vue2.js +0 -113
- package/lib/container/modal/Modal.vue2.js.map +0 -1
- package/lib/container/modal/Modal.vue3.js +0 -5
- package/lib/container/modal/Modal.vue3.js.map +0 -1
- package/lib/container/modal/Modal.vue4.js +0 -5
- package/lib/container/modal/Modal.vue4.js.map +0 -1
- package/lib/container/modal/index.js +0 -12
- package/lib/container/modal/index.js.map +0 -1
- package/lib/container/modal/props.js +0 -28
- package/lib/container/modal/props.js.map +0 -1
- package/lib/container/tabs/Tabs.vue.js +0 -49
- package/lib/container/tabs/Tabs.vue.js.map +0 -1
- package/lib/container/tabs/Tabs.vue2.js +0 -72
- package/lib/container/tabs/Tabs.vue2.js.map +0 -1
- package/lib/container/tabs/Tabs.vue3.js +0 -5
- package/lib/container/tabs/Tabs.vue3.js.map +0 -1
- package/lib/container/tabs/index.js +0 -12
- package/lib/container/tabs/index.js.map +0 -1
- package/lib/container/tabs/props.js +0 -43
- package/lib/container/tabs/props.js.map +0 -1
- package/lib/control/button/Button.vue.js +0 -36
- package/lib/control/button/Button.vue.js.map +0 -1
- package/lib/control/button/Button.vue2.js +0 -59
- package/lib/control/button/Button.vue2.js.map +0 -1
- package/lib/control/button/Button.vue3.js +0 -5
- package/lib/control/button/Button.vue3.js.map +0 -1
- package/lib/control/button/index.js +0 -12
- package/lib/control/button/index.js.map +0 -1
- package/lib/control/button/props.js +0 -24
- package/lib/control/button/props.js.map +0 -1
- package/lib/control/checkbox/Checkbox.vue.js +0 -23
- package/lib/control/checkbox/Checkbox.vue.js.map +0 -1
- package/lib/control/checkbox/Checkbox.vue2.js +0 -97
- package/lib/control/checkbox/Checkbox.vue2.js.map +0 -1
- package/lib/control/checkbox/Checkbox.vue3.js +0 -5
- package/lib/control/checkbox/Checkbox.vue3.js.map +0 -1
- package/lib/control/checkbox/index.js +0 -12
- package/lib/control/checkbox/index.js.map +0 -1
- package/lib/control/checkbox/props.js +0 -26
- package/lib/control/checkbox/props.js.map +0 -1
- package/lib/control/date-picker/DatePicker.vue.js +0 -29
- package/lib/control/date-picker/DatePicker.vue.js.map +0 -1
- package/lib/control/date-picker/DatePicker.vue2.js +0 -68
- package/lib/control/date-picker/DatePicker.vue2.js.map +0 -1
- package/lib/control/date-picker/DatePicker.vue3.js +0 -5
- package/lib/control/date-picker/DatePicker.vue3.js.map +0 -1
- package/lib/control/date-picker/index.js +0 -12
- package/lib/control/date-picker/index.js.map +0 -1
- package/lib/control/date-picker/props.js +0 -26
- package/lib/control/date-picker/props.js.map +0 -1
- package/lib/control/input/Input.vue.js +0 -25
- package/lib/control/input/Input.vue.js.map +0 -1
- package/lib/control/input/Input.vue2.js +0 -63
- package/lib/control/input/Input.vue2.js.map +0 -1
- package/lib/control/input/Input.vue3.js +0 -5
- package/lib/control/input/Input.vue3.js.map +0 -1
- package/lib/control/input/index.js +0 -12
- package/lib/control/input/index.js.map +0 -1
- package/lib/control/input/props.js +0 -22
- package/lib/control/input/props.js.map +0 -1
- package/lib/control/range-picker/RangePicker.vue.js +0 -29
- package/lib/control/range-picker/RangePicker.vue.js.map +0 -1
- package/lib/control/range-picker/RangePicker.vue2.js +0 -77
- package/lib/control/range-picker/RangePicker.vue2.js.map +0 -1
- package/lib/control/range-picker/RangePicker.vue3.js +0 -5
- package/lib/control/range-picker/RangePicker.vue3.js.map +0 -1
- package/lib/control/range-picker/RangePicker.vue4.js +0 -5
- package/lib/control/range-picker/RangePicker.vue4.js.map +0 -1
- package/lib/control/range-picker/index.js +0 -12
- package/lib/control/range-picker/index.js.map +0 -1
- package/lib/control/range-picker/props.js +0 -25
- package/lib/control/range-picker/props.js.map +0 -1
- package/lib/control/select/Select.vue.js +0 -32
- package/lib/control/select/Select.vue.js.map +0 -1
- package/lib/control/select/Select.vue2.js +0 -109
- package/lib/control/select/Select.vue2.js.map +0 -1
- package/lib/control/select/Select.vue3.js +0 -5
- package/lib/control/select/Select.vue3.js.map +0 -1
- package/lib/control/select/Select.vue4.js +0 -5
- package/lib/control/select/Select.vue4.js.map +0 -1
- package/lib/control/select/index.js +0 -12
- package/lib/control/select/index.js.map +0 -1
- package/lib/control/select/props.js +0 -26
- package/lib/control/select/props.js.map +0 -1
- package/lib/graph/bar/Bar.vue.js +0 -51
- package/lib/graph/bar/Bar.vue.js.map +0 -1
- package/lib/graph/bar/Bar.vue2.js +0 -368
- package/lib/graph/bar/Bar.vue2.js.map +0 -1
- package/lib/graph/bar/Bar.vue3.js +0 -5
- package/lib/graph/bar/Bar.vue3.js.map +0 -1
- package/lib/graph/bar/index.js +0 -12
- package/lib/graph/bar/index.js.map +0 -1
- package/lib/graph/bar/props.js +0 -101
- package/lib/graph/bar/props.js.map +0 -1
- package/lib/graph/combo-graph/ComboGraph.vue.js +0 -51
- package/lib/graph/combo-graph/ComboGraph.vue.js.map +0 -1
- package/lib/graph/combo-graph/ComboGraph.vue2.js +0 -376
- package/lib/graph/combo-graph/ComboGraph.vue2.js.map +0 -1
- package/lib/graph/combo-graph/ComboGraph.vue3.js +0 -5
- package/lib/graph/combo-graph/ComboGraph.vue3.js.map +0 -1
- package/lib/graph/combo-graph/index.js +0 -12
- package/lib/graph/combo-graph/index.js.map +0 -1
- package/lib/graph/combo-graph/props.js +0 -112
- package/lib/graph/combo-graph/props.js.map +0 -1
- package/lib/graph/custom-graph/CustomGraph.vue.js +0 -20
- package/lib/graph/custom-graph/CustomGraph.vue.js.map +0 -1
- package/lib/graph/custom-graph/CustomGraph.vue2.js +0 -59
- package/lib/graph/custom-graph/CustomGraph.vue2.js.map +0 -1
- package/lib/graph/custom-graph/index.js +0 -11
- package/lib/graph/custom-graph/index.js.map +0 -1
- package/lib/graph/custom-graph/props.js +0 -18
- package/lib/graph/custom-graph/props.js.map +0 -1
- package/lib/graph/line/Line.vue.js +0 -49
- package/lib/graph/line/Line.vue.js.map +0 -1
- package/lib/graph/line/Line.vue2.js +0 -362
- package/lib/graph/line/Line.vue2.js.map +0 -1
- package/lib/graph/line/Line.vue3.js +0 -5
- package/lib/graph/line/Line.vue3.js.map +0 -1
- package/lib/graph/line/index.js +0 -12
- package/lib/graph/line/index.js.map +0 -1
- package/lib/graph/line/props.js +0 -71
- package/lib/graph/line/props.js.map +0 -1
- package/lib/graph/pie/Pie.vue.js +0 -49
- package/lib/graph/pie/Pie.vue.js.map +0 -1
- package/lib/graph/pie/Pie.vue2.js +0 -303
- package/lib/graph/pie/Pie.vue2.js.map +0 -1
- package/lib/graph/pie/Pie.vue3.js +0 -5
- package/lib/graph/pie/Pie.vue3.js.map +0 -1
- package/lib/graph/pie/index.js +0 -12
- package/lib/graph/pie/index.js.map +0 -1
- package/lib/graph/pie/props.js +0 -71
- package/lib/graph/pie/props.js.map +0 -1
- package/lib/graph/scatter/Scatter.vue.js +0 -49
- package/lib/graph/scatter/Scatter.vue.js.map +0 -1
- package/lib/graph/scatter/Scatter.vue2.js +0 -256
- package/lib/graph/scatter/Scatter.vue2.js.map +0 -1
- package/lib/graph/scatter/Scatter.vue3.js +0 -5
- package/lib/graph/scatter/Scatter.vue3.js.map +0 -1
- package/lib/graph/scatter/index.js +0 -12
- package/lib/graph/scatter/index.js.map +0 -1
- package/lib/graph/scatter/props.js +0 -64
- package/lib/graph/scatter/props.js.map +0 -1
- package/lib/hooks/useDownloadFile.js +0 -24
- package/lib/hooks/useDownloadFile.js.map +0 -1
- package/lib/hooks/useEmitEvent.js +0 -39
- package/lib/hooks/useEmitEvent.js.map +0 -1
- package/lib/hooks/useHrefParamsToGlobalVariables.js +0 -21
- package/lib/hooks/useHrefParamsToGlobalVariables.js.map +0 -1
- package/lib/hooks/useImagePath.js +0 -20
- package/lib/hooks/useImagePath.js.map +0 -1
- package/lib/hooks/useIndicatorData.js +0 -213
- package/lib/hooks/useIndicatorData.js.map +0 -1
- package/lib/hooks/useOnEvent.js +0 -24
- package/lib/hooks/useOnEvent.js.map +0 -1
- package/lib/hooks/usePageUrl.js +0 -11
- package/lib/hooks/usePageUrl.js.map +0 -1
- package/lib/hooks/usePickComponentStyle.js +0 -38
- package/lib/hooks/usePickComponentStyle.js.map +0 -1
- package/lib/hooks/useRequestData.js +0 -115
- package/lib/hooks/useRequestData.js.map +0 -1
- package/lib/hooks/useRequestDiagramData.js +0 -346
- package/lib/hooks/useRequestDiagramData.js.map +0 -1
- package/lib/hooks/useTransformChartDataByAttrKey.js +0 -56
- package/lib/hooks/useTransformChartDataByAttrKey.js.map +0 -1
- package/lib/hooks/useTransformChartDataByAttrValue.js +0 -41
- package/lib/hooks/useTransformChartDataByAttrValue.js.map +0 -1
- package/lib/hooks/useValueFormatter.js +0 -33
- package/lib/hooks/useValueFormatter.js.map +0 -1
- package/lib/hooks/useVariablesInText.js +0 -40
- package/lib/hooks/useVariablesInText.js.map +0 -1
- package/lib/index.js +0 -162
- package/lib/index.js.map +0 -1
- package/lib/map/map/Map.vue.js +0 -30
- package/lib/map/map/Map.vue.js.map +0 -1
- package/lib/map/map/Map.vue2.js +0 -171
- package/lib/map/map/Map.vue2.js.map +0 -1
- package/lib/map/map/Map.vue3.js +0 -5
- package/lib/map/map/Map.vue3.js.map +0 -1
- package/lib/map/map/index.js +0 -11
- package/lib/map/map/index.js.map +0 -1
- package/lib/map/map/props.js +0 -49
- package/lib/map/map/props.js.map +0 -1
- package/lib/media/iframe/Iframe.vue.js +0 -21
- package/lib/media/iframe/Iframe.vue.js.map +0 -1
- package/lib/media/iframe/Iframe.vue2.js +0 -43
- package/lib/media/iframe/Iframe.vue2.js.map +0 -1
- package/lib/media/iframe/Iframe.vue3.js +0 -5
- package/lib/media/iframe/Iframe.vue3.js.map +0 -1
- package/lib/media/iframe/index.js +0 -11
- package/lib/media/iframe/index.js.map +0 -1
- package/lib/media/iframe/props.js +0 -17
- package/lib/media/iframe/props.js.map +0 -1
- package/lib/media/image/Image.vue.js +0 -22
- package/lib/media/image/Image.vue.js.map +0 -1
- package/lib/media/image/Image.vue2.js +0 -53
- package/lib/media/image/Image.vue2.js.map +0 -1
- package/lib/media/image/Image.vue3.js +0 -5
- package/lib/media/image/Image.vue3.js.map +0 -1
- package/lib/media/image/index.js +0 -11
- package/lib/media/image/index.js.map +0 -1
- package/lib/media/image/props.js +0 -19
- package/lib/media/image/props.js.map +0 -1
- package/lib/node_modules/@ant-design/colors/dist/index.esm.js +0 -176
- package/lib/node_modules/@ant-design/colors/dist/index.esm.js.map +0 -1
- package/lib/node_modules/@ant-design/icons-svg/es/asn/LoadingOutlined.js +0 -6
- package/lib/node_modules/@ant-design/icons-svg/es/asn/LoadingOutlined.js.map +0 -1
- package/lib/node_modules/@ant-design/icons-vue/es/components/AntdIcon.js +0 -166
- package/lib/node_modules/@ant-design/icons-vue/es/components/AntdIcon.js.map +0 -1
- package/lib/node_modules/@ant-design/icons-vue/es/components/IconBase.js +0 -114
- package/lib/node_modules/@ant-design/icons-vue/es/components/IconBase.js.map +0 -1
- package/lib/node_modules/@ant-design/icons-vue/es/components/twoTonePrimaryColor.js +0 -80
- package/lib/node_modules/@ant-design/icons-vue/es/components/twoTonePrimaryColor.js.map +0 -1
- package/lib/node_modules/@ant-design/icons-vue/es/icons/LoadingOutlined.js +0 -39
- package/lib/node_modules/@ant-design/icons-vue/es/icons/LoadingOutlined.js.map +0 -1
- package/lib/node_modules/@ant-design/icons-vue/es/insert-css.js +0 -45
- package/lib/node_modules/@ant-design/icons-vue/es/insert-css.js.map +0 -1
- package/lib/node_modules/@ant-design/icons-vue/es/utils.js +0 -86
- package/lib/node_modules/@ant-design/icons-vue/es/utils.js.map +0 -1
- package/lib/node_modules/@babel/runtime/helpers/esm/extends.js +0 -18
- package/lib/node_modules/@babel/runtime/helpers/esm/extends.js.map +0 -1
- package/lib/node_modules/@ctrl/tinycolor/dist/module/conversion.js +0 -116
- package/lib/node_modules/@ctrl/tinycolor/dist/module/conversion.js.map +0 -1
- package/lib/node_modules/@ctrl/tinycolor/dist/module/css-color-names.js +0 -154
- package/lib/node_modules/@ctrl/tinycolor/dist/module/css-color-names.js.map +0 -1
- package/lib/node_modules/@ctrl/tinycolor/dist/module/format-input.js +0 -149
- package/lib/node_modules/@ctrl/tinycolor/dist/module/format-input.js.map +0 -1
- package/lib/node_modules/@ctrl/tinycolor/dist/module/util.js +0 -50
- package/lib/node_modules/@ctrl/tinycolor/dist/module/util.js.map +0 -1
- package/lib/node_modules/@vue/shared/dist/shared.esm-bundler.js +0 -4
- package/lib/node_modules/@vue/shared/dist/shared.esm-bundler.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/button/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/button/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/checkbox/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/checkbox/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/date-picker/locale/zh_CN.js +0 -24
- package/lib/node_modules/ant-design-vue/es/date-picker/locale/zh_CN.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/date-picker/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/date-picker/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/dropdown/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/dropdown/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/empty/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/empty/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/input/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/input/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/modal/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/modal/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/pagination/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/pagination/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/progress/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/progress/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/radio/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/radio/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/select/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/select/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/skeleton/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/skeleton/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/spin/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/spin/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/style/default.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/style/default.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/table/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/table/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/tag/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/tag/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/time-picker/locale/zh_CN.js +0 -9
- package/lib/node_modules/ant-design-vue/es/time-picker/locale/zh_CN.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/tooltip/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/tooltip/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/tree/style/index.less.js +0 -5
- package/lib/node_modules/ant-design-vue/es/tree/style/index.less.js.map +0 -1
- package/lib/node_modules/ant-design-vue/es/vc-picker/locale/zh_CN.js +0 -33
- package/lib/node_modules/ant-design-vue/es/vc-picker/locale/zh_CN.js.map +0 -1
- package/lib/node_modules/echarts/lib/action/roamHelper.js +0 -38
- package/lib/node_modules/echarts/lib/action/roamHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/animation/basicTrasition.js +0 -149
- package/lib/node_modules/echarts/lib/animation/basicTrasition.js.map +0 -1
- package/lib/node_modules/echarts/lib/animation/customGraphicKeyframeAnimation.js +0 -92
- package/lib/node_modules/echarts/lib/animation/customGraphicKeyframeAnimation.js.map +0 -1
- package/lib/node_modules/echarts/lib/animation/customGraphicTransition.js +0 -389
- package/lib/node_modules/echarts/lib/animation/customGraphicTransition.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/bar/BarSeries.js +0 -68
- package/lib/node_modules/echarts/lib/chart/bar/BarSeries.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/bar/BarView.js +0 -784
- package/lib/node_modules/echarts/lib/chart/bar/BarView.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/bar/BaseBarSeries.js +0 -57
- package/lib/node_modules/echarts/lib/chart/bar/BaseBarSeries.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/bar/install.js +0 -31
- package/lib/node_modules/echarts/lib/chart/bar/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/helper/LargeSymbolDraw.js +0 -255
- package/lib/node_modules/echarts/lib/chart/helper/LargeSymbolDraw.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/helper/Symbol.js +0 -252
- package/lib/node_modules/echarts/lib/chart/helper/Symbol.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/helper/SymbolDraw.js +0 -158
- package/lib/node_modules/echarts/lib/chart/helper/SymbolDraw.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/helper/createClipPathFromCoordSys.js +0 -102
- package/lib/node_modules/echarts/lib/chart/helper/createClipPathFromCoordSys.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/helper/createRenderPlanner.js +0 -17
- package/lib/node_modules/echarts/lib/chart/helper/createRenderPlanner.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/helper/createSeriesData.js +0 -118
- package/lib/node_modules/echarts/lib/chart/helper/createSeriesData.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/helper/createSeriesDataSimply.js +0 -19
- package/lib/node_modules/echarts/lib/chart/helper/createSeriesDataSimply.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/helper/labelHelper.js +0 -35
- package/lib/node_modules/echarts/lib/chart/helper/labelHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/helper/pieHelper.js +0 -23
- package/lib/node_modules/echarts/lib/chart/helper/pieHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/line/LineSeries.js +0 -116
- package/lib/node_modules/echarts/lib/chart/line/LineSeries.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/line/LineView.js +0 -977
- package/lib/node_modules/echarts/lib/chart/line/LineView.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/line/helper.js +0 -81
- package/lib/node_modules/echarts/lib/chart/line/helper.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/line/install.js +0 -25
- package/lib/node_modules/echarts/lib/chart/line/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/line/lineAnimationDiff.js +0 -113
- package/lib/node_modules/echarts/lib/chart/line/lineAnimationDiff.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/line/poly.js +0 -304
- package/lib/node_modules/echarts/lib/chart/line/poly.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/map/MapSeries.js +0 -185
- package/lib/node_modules/echarts/lib/chart/map/MapSeries.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/map/MapView.js +0 -121
- package/lib/node_modules/echarts/lib/chart/map/MapView.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/map/install.js +0 -19
- package/lib/node_modules/echarts/lib/chart/map/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/map/mapDataStatistic.js +0 -62
- package/lib/node_modules/echarts/lib/chart/map/mapDataStatistic.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/map/mapSymbolLayout.js +0 -43
- package/lib/node_modules/echarts/lib/chart/map/mapSymbolLayout.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/pie/PieSeries.js +0 -153
- package/lib/node_modules/echarts/lib/chart/pie/PieSeries.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/pie/PieView.js +0 -230
- package/lib/node_modules/echarts/lib/chart/pie/PieView.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/pie/install.js +0 -19
- package/lib/node_modules/echarts/lib/chart/pie/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/pie/labelLayout.js +0 -391
- package/lib/node_modules/echarts/lib/chart/pie/labelLayout.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/pie/pieLayout.js +0 -133
- package/lib/node_modules/echarts/lib/chart/pie/pieLayout.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/scatter/ScatterSeries.js +0 -79
- package/lib/node_modules/echarts/lib/chart/scatter/ScatterSeries.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/scatter/ScatterView.js +0 -93
- package/lib/node_modules/echarts/lib/chart/scatter/ScatterView.js.map +0 -1
- package/lib/node_modules/echarts/lib/chart/scatter/install.js +0 -15
- package/lib/node_modules/echarts/lib/chart/scatter/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axis/AxisBuilder.js +0 -490
- package/lib/node_modules/echarts/lib/component/axis/AxisBuilder.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axis/AxisView.js +0 -61
- package/lib/node_modules/echarts/lib/component/axis/AxisView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axis/CartesianAxisView.js +0 -193
- package/lib/node_modules/echarts/lib/component/axis/CartesianAxisView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axis/axisSplitHelper.js +0 -83
- package/lib/node_modules/echarts/lib/component/axis/axisSplitHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axisPointer/AxisPointerModel.js +0 -75
- package/lib/node_modules/echarts/lib/component/axisPointer/AxisPointerModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axisPointer/AxisPointerView.js +0 -41
- package/lib/node_modules/echarts/lib/component/axisPointer/AxisPointerView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axisPointer/BaseAxisPointer.js +0 -287
- package/lib/node_modules/echarts/lib/component/axisPointer/BaseAxisPointer.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axisPointer/CartesianAxisPointer.js +0 -107
- package/lib/node_modules/echarts/lib/component/axisPointer/CartesianAxisPointer.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axisPointer/axisTrigger.js +0 -293
- package/lib/node_modules/echarts/lib/component/axisPointer/axisTrigger.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axisPointer/findPointFromSeries.js +0 -53
- package/lib/node_modules/echarts/lib/component/axisPointer/findPointFromSeries.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axisPointer/globalListener.js +0 -87
- package/lib/node_modules/echarts/lib/component/axisPointer/globalListener.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axisPointer/install.js +0 -33
- package/lib/node_modules/echarts/lib/component/axisPointer/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axisPointer/modelHelper.js +0 -202
- package/lib/node_modules/echarts/lib/component/axisPointer/modelHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/axisPointer/viewHelper.js +0 -144
- package/lib/node_modules/echarts/lib/component/axisPointer/viewHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/dataZoom/AxisProxy.js +0 -211
- package/lib/node_modules/echarts/lib/component/dataZoom/AxisProxy.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/dataZoom/DataZoomModel.js +0 -301
- package/lib/node_modules/echarts/lib/component/dataZoom/DataZoomModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/dataZoom/DataZoomView.js +0 -25
- package/lib/node_modules/echarts/lib/component/dataZoom/DataZoomView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/dataZoom/SelectZoomModel.js +0 -20
- package/lib/node_modules/echarts/lib/component/dataZoom/SelectZoomModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/dataZoom/SelectZoomView.js +0 -20
- package/lib/node_modules/echarts/lib/component/dataZoom/SelectZoomView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/dataZoom/dataZoomAction.js +0 -19
- package/lib/node_modules/echarts/lib/component/dataZoom/dataZoomAction.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/dataZoom/dataZoomProcessor.js +0 -66
- package/lib/node_modules/echarts/lib/component/dataZoom/dataZoomProcessor.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/dataZoom/helper.js +0 -65
- package/lib/node_modules/echarts/lib/component/dataZoom/helper.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/dataZoom/history.js +0 -68
- package/lib/node_modules/echarts/lib/component/dataZoom/history.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/dataZoom/installCommon.js +0 -18
- package/lib/node_modules/echarts/lib/component/dataZoom/installCommon.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/dataZoom/installDataZoomSelect.js +0 -12
- package/lib/node_modules/echarts/lib/component/dataZoom/installDataZoomSelect.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/dataset/install.js +0 -58
- package/lib/node_modules/echarts/lib/component/dataset/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/geo/GeoView.js +0 -73
- package/lib/node_modules/echarts/lib/component/geo/GeoView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/geo/install.js +0 -90
- package/lib/node_modules/echarts/lib/component/geo/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/graphic/GraphicModel.js +0 -169
- package/lib/node_modules/echarts/lib/component/graphic/GraphicModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/graphic/GraphicView.js +0 -317
- package/lib/node_modules/echarts/lib/component/graphic/GraphicView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/graphic/install.js +0 -27
- package/lib/node_modules/echarts/lib/component/graphic/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/grid/installSimple.js +0 -59
- package/lib/node_modules/echarts/lib/component/grid/installSimple.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/helper/BrushController.js +0 -656
- package/lib/node_modules/echarts/lib/component/helper/BrushController.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/helper/BrushTargetManager.js +0 -270
- package/lib/node_modules/echarts/lib/component/helper/BrushTargetManager.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/helper/MapDraw.js +0 -515
- package/lib/node_modules/echarts/lib/component/helper/MapDraw.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/helper/RoamController.js +0 -165
- package/lib/node_modules/echarts/lib/component/helper/RoamController.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/helper/brushHelper.js +0 -33
- package/lib/node_modules/echarts/lib/component/helper/brushHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/helper/cursorHelper.js +0 -14
- package/lib/node_modules/echarts/lib/component/helper/cursorHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/helper/interactionMutex.js +0 -31
- package/lib/node_modules/echarts/lib/component/helper/interactionMutex.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/helper/listComponent.js +0 -37
- package/lib/node_modules/echarts/lib/component/helper/listComponent.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/helper/roamHelper.js +0 -29
- package/lib/node_modules/echarts/lib/component/helper/roamHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/helper/sliderMove.js +0 -48
- package/lib/node_modules/echarts/lib/component/helper/sliderMove.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/legend/LegendModel.js +0 -256
- package/lib/node_modules/echarts/lib/component/legend/LegendModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/legend/LegendView.js +0 -402
- package/lib/node_modules/echarts/lib/component/legend/LegendView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/legend/ScrollableLegendModel.js +0 -61
- package/lib/node_modules/echarts/lib/component/legend/ScrollableLegendModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/legend/ScrollableLegendView.js +0 -312
- package/lib/node_modules/echarts/lib/component/legend/ScrollableLegendView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/legend/install.js +0 -11
- package/lib/node_modules/echarts/lib/component/legend/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/legend/installLegendPlain.js +0 -17
- package/lib/node_modules/echarts/lib/component/legend/installLegendPlain.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/legend/installLegendScroll.js +0 -15
- package/lib/node_modules/echarts/lib/component/legend/installLegendScroll.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/legend/legendAction.js +0 -46
- package/lib/node_modules/echarts/lib/component/legend/legendAction.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/legend/legendFilter.js +0 -19
- package/lib/node_modules/echarts/lib/component/legend/legendFilter.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/legend/scrollableLegendAction.js +0 -16
- package/lib/node_modules/echarts/lib/component/legend/scrollableLegendAction.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/title/install.js +0 -184
- package/lib/node_modules/echarts/lib/component/title/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/toolbox/ToolboxModel.js +0 -72
- package/lib/node_modules/echarts/lib/component/toolbox/ToolboxModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/toolbox/ToolboxView.js +0 -224
- package/lib/node_modules/echarts/lib/component/toolbox/ToolboxView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/toolbox/feature/DataView.js +0 -369
- package/lib/node_modules/echarts/lib/component/toolbox/feature/DataView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/toolbox/feature/DataZoom.js +0 -206
- package/lib/node_modules/echarts/lib/component/toolbox/feature/DataZoom.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/toolbox/feature/MagicType.js +0 -163
- package/lib/node_modules/echarts/lib/component/toolbox/feature/MagicType.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/toolbox/feature/Restore.js +0 -42
- package/lib/node_modules/echarts/lib/component/toolbox/feature/Restore.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/toolbox/feature/SaveAsImage.js +0 -97
- package/lib/node_modules/echarts/lib/component/toolbox/feature/SaveAsImage.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/toolbox/featureManager.js +0 -21
- package/lib/node_modules/echarts/lib/component/toolbox/featureManager.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/toolbox/install.js +0 -24
- package/lib/node_modules/echarts/lib/component/toolbox/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/tooltip/TooltipHTMLContent.js +0 -291
- package/lib/node_modules/echarts/lib/component/tooltip/TooltipHTMLContent.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/tooltip/TooltipModel.js +0 -88
- package/lib/node_modules/echarts/lib/component/tooltip/TooltipModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/tooltip/TooltipRichContent.js +0 -153
- package/lib/node_modules/echarts/lib/component/tooltip/TooltipRichContent.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/tooltip/TooltipView.js +0 -684
- package/lib/node_modules/echarts/lib/component/tooltip/TooltipView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/tooltip/helper.js +0 -40
- package/lib/node_modules/echarts/lib/component/tooltip/helper.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/tooltip/install.js +0 -24
- package/lib/node_modules/echarts/lib/component/tooltip/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/tooltip/seriesFormatTooltip.js +0 -95
- package/lib/node_modules/echarts/lib/component/tooltip/seriesFormatTooltip.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/tooltip/tooltipMarkup.js +0 -245
- package/lib/node_modules/echarts/lib/component/tooltip/tooltipMarkup.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/ContinuousModel.js +0 -178
- package/lib/node_modules/echarts/lib/component/visualMap/ContinuousModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/ContinuousView.js +0 -590
- package/lib/node_modules/echarts/lib/component/visualMap/ContinuousView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/PiecewiseModel.js +0 -335
- package/lib/node_modules/echarts/lib/component/visualMap/PiecewiseModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/PiecewiseView.js +0 -172
- package/lib/node_modules/echarts/lib/component/visualMap/PiecewiseView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/VisualMapModel.js +0 -269
- package/lib/node_modules/echarts/lib/component/visualMap/VisualMapModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/VisualMapView.js +0 -103
- package/lib/node_modules/echarts/lib/component/visualMap/VisualMapView.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/helper.js +0 -40
- package/lib/node_modules/echarts/lib/component/visualMap/helper.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/install.js +0 -11
- package/lib/node_modules/echarts/lib/component/visualMap/install.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/installCommon.js +0 -23
- package/lib/node_modules/echarts/lib/component/visualMap/installCommon.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/installVisualMapContinuous.js +0 -12
- package/lib/node_modules/echarts/lib/component/visualMap/installVisualMapContinuous.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/installVisualMapPiecewise.js +0 -12
- package/lib/node_modules/echarts/lib/component/visualMap/installVisualMapPiecewise.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/preprocessor.js +0 -37
- package/lib/node_modules/echarts/lib/component/visualMap/preprocessor.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/visualEncoding.js +0 -66
- package/lib/node_modules/echarts/lib/component/visualMap/visualEncoding.js.map +0 -1
- package/lib/node_modules/echarts/lib/component/visualMap/visualMapAction.js +0 -19
- package/lib/node_modules/echarts/lib/component/visualMap/visualMapAction.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/Axis.js +0 -176
- package/lib/node_modules/echarts/lib/coord/Axis.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/CoordinateSystem.js +0 -7
- package/lib/node_modules/echarts/lib/coord/CoordinateSystem.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/View.js +0 -166
- package/lib/node_modules/echarts/lib/coord/View.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/axisAlignTicks.js +0 -87
- package/lib/node_modules/echarts/lib/coord/axisAlignTicks.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/axisCommonTypes.js +0 -10
- package/lib/node_modules/echarts/lib/coord/axisCommonTypes.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/axisDefault.js +0 -163
- package/lib/node_modules/echarts/lib/coord/axisDefault.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/axisHelper.js +0 -233
- package/lib/node_modules/echarts/lib/coord/axisHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/axisModelCommonMixin.js +0 -19
- package/lib/node_modules/echarts/lib/coord/axisModelCommonMixin.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/axisModelCreator.js +0 -63
- package/lib/node_modules/echarts/lib/coord/axisModelCreator.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/axisTickLabelBuilder.js +0 -225
- package/lib/node_modules/echarts/lib/coord/axisTickLabelBuilder.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/cartesian/Axis2D.js +0 -42
- package/lib/node_modules/echarts/lib/coord/cartesian/Axis2D.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/cartesian/AxisModel.js +0 -25
- package/lib/node_modules/echarts/lib/coord/cartesian/AxisModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/cartesian/Cartesian.js +0 -37
- package/lib/node_modules/echarts/lib/coord/cartesian/Cartesian.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/cartesian/Cartesian2D.js +0 -116
- package/lib/node_modules/echarts/lib/coord/cartesian/Cartesian2D.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/cartesian/Grid.js +0 -384
- package/lib/node_modules/echarts/lib/coord/cartesian/Grid.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/cartesian/GridModel.js +0 -36
- package/lib/node_modules/echarts/lib/coord/cartesian/GridModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/cartesian/cartesianAxisHelper.js +0 -73
- package/lib/node_modules/echarts/lib/coord/cartesian/cartesianAxisHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/geo/Geo.js +0 -151
- package/lib/node_modules/echarts/lib/coord/geo/Geo.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/geo/GeoJSONResource.js +0 -93
- package/lib/node_modules/echarts/lib/coord/geo/GeoJSONResource.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/geo/GeoModel.js +0 -164
- package/lib/node_modules/echarts/lib/coord/geo/GeoModel.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/geo/GeoSVGResource.js +0 -174
- package/lib/node_modules/echarts/lib/coord/geo/GeoSVGResource.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/geo/Region.js +0 -237
- package/lib/node_modules/echarts/lib/coord/geo/Region.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/geo/fix/diaoyuIsland.js +0 -13
- package/lib/node_modules/echarts/lib/coord/geo/fix/diaoyuIsland.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/geo/fix/nanhai.js +0 -32
- package/lib/node_modules/echarts/lib/coord/geo/fix/nanhai.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/geo/fix/textCoord.js +0 -24
- package/lib/node_modules/echarts/lib/coord/geo/fix/textCoord.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/geo/geoCreator.js +0 -177
- package/lib/node_modules/echarts/lib/coord/geo/geoCreator.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/geo/geoSourceManager.js +0 -76
- package/lib/node_modules/echarts/lib/coord/geo/geoSourceManager.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/geo/parseGeoJson.js +0 -95
- package/lib/node_modules/echarts/lib/coord/geo/parseGeoJson.js.map +0 -1
- package/lib/node_modules/echarts/lib/coord/scaleRawExtentInfo.js +0 -140
- package/lib/node_modules/echarts/lib/coord/scaleRawExtentInfo.js.map +0 -1
- package/lib/node_modules/echarts/lib/core/CoordinateSystem.js +0 -38
- package/lib/node_modules/echarts/lib/core/CoordinateSystem.js.map +0 -1
- package/lib/node_modules/echarts/lib/core/ExtensionAPI.js +0 -37
- package/lib/node_modules/echarts/lib/core/ExtensionAPI.js.map +0 -1
- package/lib/node_modules/echarts/lib/core/Scheduler.js +0 -358
- package/lib/node_modules/echarts/lib/core/Scheduler.js.map +0 -1
- package/lib/node_modules/echarts/lib/core/echarts.js +0 -1783
- package/lib/node_modules/echarts/lib/core/echarts.js.map +0 -1
- package/lib/node_modules/echarts/lib/core/impl.js +0 -23
- package/lib/node_modules/echarts/lib/core/impl.js.map +0 -1
- package/lib/node_modules/echarts/lib/core/lifecycle.js +0 -7
- package/lib/node_modules/echarts/lib/core/lifecycle.js.map +0 -1
- package/lib/node_modules/echarts/lib/core/locale.js +0 -50
- package/lib/node_modules/echarts/lib/core/locale.js.map +0 -1
- package/lib/node_modules/echarts/lib/core/task.js +0 -184
- package/lib/node_modules/echarts/lib/core/task.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/DataDiffer.js +0 -155
- package/lib/node_modules/echarts/lib/data/DataDiffer.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/DataStore.js +0 -788
- package/lib/node_modules/echarts/lib/data/DataStore.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/OrdinalMeta.js +0 -67
- package/lib/node_modules/echarts/lib/data/OrdinalMeta.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/SeriesData.js +0 -666
- package/lib/node_modules/echarts/lib/data/SeriesData.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/SeriesDimensionDefine.js +0 -18
- package/lib/node_modules/echarts/lib/data/SeriesDimensionDefine.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/Source.js +0 -220
- package/lib/node_modules/echarts/lib/data/Source.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/helper/SeriesDataSchema.js +0 -145
- package/lib/node_modules/echarts/lib/data/helper/SeriesDataSchema.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/helper/createDimensions.js +0 -213
- package/lib/node_modules/echarts/lib/data/helper/createDimensions.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/helper/dataProvider.js +0 -257
- package/lib/node_modules/echarts/lib/data/helper/dataProvider.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/helper/dataStackHelper.js +0 -108
- package/lib/node_modules/echarts/lib/data/helper/dataStackHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/helper/dataValueHelper.js +0 -65
- package/lib/node_modules/echarts/lib/data/helper/dataValueHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/helper/dimensionHelper.js +0 -104
- package/lib/node_modules/echarts/lib/data/helper/dimensionHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/helper/sourceHelper.js +0 -243
- package/lib/node_modules/echarts/lib/data/helper/sourceHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/helper/sourceManager.js +0 -236
- package/lib/node_modules/echarts/lib/data/helper/sourceManager.js.map +0 -1
- package/lib/node_modules/echarts/lib/data/helper/transform.js +0 -296
- package/lib/node_modules/echarts/lib/data/helper/transform.js.map +0 -1
- package/lib/node_modules/echarts/lib/extension.js +0 -70
- package/lib/node_modules/echarts/lib/extension.js.map +0 -1
- package/lib/node_modules/echarts/lib/i18n/langEN.js +0 -113
- package/lib/node_modules/echarts/lib/i18n/langEN.js.map +0 -1
- package/lib/node_modules/echarts/lib/i18n/langZH.js +0 -113
- package/lib/node_modules/echarts/lib/i18n/langZH.js.map +0 -1
- package/lib/node_modules/echarts/lib/label/labelGuideHelper.js +0 -218
- package/lib/node_modules/echarts/lib/label/labelGuideHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/label/labelLayoutHelper.js +0 -222
- package/lib/node_modules/echarts/lib/label/labelLayoutHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/label/labelStyle.js +0 -352
- package/lib/node_modules/echarts/lib/label/labelStyle.js.map +0 -1
- package/lib/node_modules/echarts/lib/label/sectorLabel.js +0 -153
- package/lib/node_modules/echarts/lib/label/sectorLabel.js.map +0 -1
- package/lib/node_modules/echarts/lib/layout/barGrid.js +0 -368
- package/lib/node_modules/echarts/lib/layout/barGrid.js.map +0 -1
- package/lib/node_modules/echarts/lib/layout/points.js +0 -63
- package/lib/node_modules/echarts/lib/layout/points.js.map +0 -1
- package/lib/node_modules/echarts/lib/legacy/dataSelectAction.js +0 -76
- package/lib/node_modules/echarts/lib/legacy/dataSelectAction.js.map +0 -1
- package/lib/node_modules/echarts/lib/loading/default.js +0 -109
- package/lib/node_modules/echarts/lib/loading/default.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/Component.js +0 -120
- package/lib/node_modules/echarts/lib/model/Component.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/Global.js +0 -572
- package/lib/node_modules/echarts/lib/model/Global.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/Model.js +0 -104
- package/lib/node_modules/echarts/lib/model/Model.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/OptionManager.js +0 -191
- package/lib/node_modules/echarts/lib/model/OptionManager.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/Series.js +0 -380
- package/lib/node_modules/echarts/lib/model/Series.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/globalDefault.js +0 -90
- package/lib/node_modules/echarts/lib/model/globalDefault.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/internalComponentCreator.js +0 -28
- package/lib/node_modules/echarts/lib/model/internalComponentCreator.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/mixin/areaStyle.js +0 -28
- package/lib/node_modules/echarts/lib/model/mixin/areaStyle.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/mixin/dataFormat.js +0 -119
- package/lib/node_modules/echarts/lib/model/mixin/dataFormat.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/mixin/itemStyle.js +0 -35
- package/lib/node_modules/echarts/lib/model/mixin/itemStyle.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/mixin/lineStyle.js +0 -34
- package/lib/node_modules/echarts/lib/model/mixin/lineStyle.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/mixin/makeStyleMapper.js +0 -27
- package/lib/node_modules/echarts/lib/model/mixin/makeStyleMapper.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/mixin/palette.js +0 -56
- package/lib/node_modules/echarts/lib/model/mixin/palette.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/mixin/textStyle.js +0 -42
- package/lib/node_modules/echarts/lib/model/mixin/textStyle.js.map +0 -1
- package/lib/node_modules/echarts/lib/model/referHelper.js +0 -112
- package/lib/node_modules/echarts/lib/model/referHelper.js.map +0 -1
- package/lib/node_modules/echarts/lib/preprocessor/backwardCompat.js +0 -213
- package/lib/node_modules/echarts/lib/preprocessor/backwardCompat.js.map +0 -1
- package/lib/node_modules/echarts/lib/preprocessor/helper/compatStyle.js +0 -269
- package/lib/node_modules/echarts/lib/preprocessor/helper/compatStyle.js.map +0 -1
- package/lib/node_modules/echarts/lib/processor/dataFilter.js +0 -27
- package/lib/node_modules/echarts/lib/processor/dataFilter.js.map +0 -1
- package/lib/node_modules/echarts/lib/processor/dataSample.js +0 -82
- package/lib/node_modules/echarts/lib/processor/dataSample.js.map +0 -1
- package/lib/node_modules/echarts/lib/processor/dataStack.js +0 -74
- package/lib/node_modules/echarts/lib/processor/dataStack.js.map +0 -1
- package/lib/node_modules/echarts/lib/processor/negativeDataFilter.js +0 -21
- package/lib/node_modules/echarts/lib/processor/negativeDataFilter.js.map +0 -1
- package/lib/node_modules/echarts/lib/renderer/installCanvasRenderer.js +0 -8
- package/lib/node_modules/echarts/lib/renderer/installCanvasRenderer.js.map +0 -1
- package/lib/node_modules/echarts/lib/scale/Interval.js +0 -193
- package/lib/node_modules/echarts/lib/scale/Interval.js.map +0 -1
- package/lib/node_modules/echarts/lib/scale/Log.js +0 -122
- package/lib/node_modules/echarts/lib/scale/Log.js.map +0 -1
- package/lib/node_modules/echarts/lib/scale/Ordinal.js +0 -126
- package/lib/node_modules/echarts/lib/scale/Ordinal.js.map +0 -1
- package/lib/node_modules/echarts/lib/scale/Scale.js +0 -49
- package/lib/node_modules/echarts/lib/scale/Scale.js.map +0 -1
- package/lib/node_modules/echarts/lib/scale/Time.js +0 -380
- package/lib/node_modules/echarts/lib/scale/Time.js.map +0 -1
- package/lib/node_modules/echarts/lib/scale/helper.js +0 -77
- package/lib/node_modules/echarts/lib/scale/helper.js.map +0 -1
- package/lib/node_modules/echarts/lib/theme/dark.js +0 -183
- package/lib/node_modules/echarts/lib/theme/dark.js.map +0 -1
- package/lib/node_modules/echarts/lib/theme/light.js +0 -9
- package/lib/node_modules/echarts/lib/theme/light.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/ECEventProcessor.js +0 -80
- package/lib/node_modules/echarts/lib/util/ECEventProcessor.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/clazz.js +0 -165
- package/lib/node_modules/echarts/lib/util/clazz.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/component.js +0 -117
- package/lib/node_modules/echarts/lib/util/component.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/decal.js +0 -292
- package/lib/node_modules/echarts/lib/util/decal.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/event.js +0 -17
- package/lib/node_modules/echarts/lib/util/event.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/format.js +0 -140
- package/lib/node_modules/echarts/lib/util/format.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/graphic.js +0 -375
- package/lib/node_modules/echarts/lib/util/graphic.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/innerStore.js +0 -23
- package/lib/node_modules/echarts/lib/util/innerStore.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/layout.js +0 -249
- package/lib/node_modules/echarts/lib/util/layout.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/log.js +0 -81
- package/lib/node_modules/echarts/lib/util/log.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/model.js +0 -464
- package/lib/node_modules/echarts/lib/util/model.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/number.js +0 -306
- package/lib/node_modules/echarts/lib/util/number.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/shape/sausage.js +0 -69
- package/lib/node_modules/echarts/lib/util/shape/sausage.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/states.js +0 -598
- package/lib/node_modules/echarts/lib/util/states.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/styleCompat.js +0 -78
- package/lib/node_modules/echarts/lib/util/styleCompat.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/symbol.js +0 -267
- package/lib/node_modules/echarts/lib/util/symbol.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/throttle.js +0 -85
- package/lib/node_modules/echarts/lib/util/throttle.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/time.js +0 -253
- package/lib/node_modules/echarts/lib/util/time.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/types.js +0 -22
- package/lib/node_modules/echarts/lib/util/types.js.map +0 -1
- package/lib/node_modules/echarts/lib/util/vendor.js +0 -13
- package/lib/node_modules/echarts/lib/util/vendor.js.map +0 -1
- package/lib/node_modules/echarts/lib/view/Chart.js +0 -139
- package/lib/node_modules/echarts/lib/view/Chart.js.map +0 -1
- package/lib/node_modules/echarts/lib/view/Component.js +0 -40
- package/lib/node_modules/echarts/lib/view/Component.js.map +0 -1
- package/lib/node_modules/echarts/lib/visual/LegendVisualProvider.js +0 -31
- package/lib/node_modules/echarts/lib/visual/LegendVisualProvider.js.map +0 -1
- package/lib/node_modules/echarts/lib/visual/VisualMapping.js +0 -369
- package/lib/node_modules/echarts/lib/visual/VisualMapping.js.map +0 -1
- package/lib/node_modules/echarts/lib/visual/decal.js +0 -27
- package/lib/node_modules/echarts/lib/visual/decal.js.map +0 -1
- package/lib/node_modules/echarts/lib/visual/helper.js +0 -61
- package/lib/node_modules/echarts/lib/visual/helper.js.map +0 -1
- package/lib/node_modules/echarts/lib/visual/style.js +0 -160
- package/lib/node_modules/echarts/lib/visual/style.js.map +0 -1
- package/lib/node_modules/echarts/lib/visual/symbol.js +0 -82
- package/lib/node_modules/echarts/lib/visual/symbol.js.map +0 -1
- package/lib/node_modules/echarts/lib/visual/visualDefault.js +0 -49
- package/lib/node_modules/echarts/lib/visual/visualDefault.js.map +0 -1
- package/lib/node_modules/echarts/lib/visual/visualSolution.js +0 -101
- package/lib/node_modules/echarts/lib/visual/visualSolution.js.map +0 -1
- package/lib/node_modules/echarts/node_modules/tslib/tslib.es6.js +0 -37
- package/lib/node_modules/echarts/node_modules/tslib/tslib.es6.js.map +0 -1
- package/lib/node_modules/zrender/lib/Element.js +0 -994
- package/lib/node_modules/zrender/lib/Element.js.map +0 -1
- package/lib/node_modules/zrender/lib/Handler.js +0 -257
- package/lib/node_modules/zrender/lib/Handler.js.map +0 -1
- package/lib/node_modules/zrender/lib/Storage.js +0 -158
- package/lib/node_modules/zrender/lib/Storage.js.map +0 -1
- package/lib/node_modules/zrender/lib/animation/Animation.js +0 -148
- package/lib/node_modules/zrender/lib/animation/Animation.js.map +0 -1
- package/lib/node_modules/zrender/lib/animation/Animator.js +0 -702
- package/lib/node_modules/zrender/lib/animation/Animator.js.map +0 -1
- package/lib/node_modules/zrender/lib/animation/Clip.js +0 -65
- package/lib/node_modules/zrender/lib/animation/Clip.js.map +0 -1
- package/lib/node_modules/zrender/lib/animation/cubicEasing.js +0 -24
- package/lib/node_modules/zrender/lib/animation/cubicEasing.js.map +0 -1
- package/lib/node_modules/zrender/lib/animation/easing.js +0 -189
- package/lib/node_modules/zrender/lib/animation/easing.js.map +0 -1
- package/lib/node_modules/zrender/lib/animation/requestAnimationFrame.js +0 -10
- package/lib/node_modules/zrender/lib/animation/requestAnimationFrame.js.map +0 -1
- package/lib/node_modules/zrender/lib/canvas/Layer.js +0 -283
- package/lib/node_modules/zrender/lib/canvas/Layer.js.map +0 -1
- package/lib/node_modules/zrender/lib/canvas/Painter.js +0 -618
- package/lib/node_modules/zrender/lib/canvas/Painter.js.map +0 -1
- package/lib/node_modules/zrender/lib/canvas/dashStyle.js +0 -27
- package/lib/node_modules/zrender/lib/canvas/dashStyle.js.map +0 -1
- package/lib/node_modules/zrender/lib/canvas/graphic.js +0 -522
- package/lib/node_modules/zrender/lib/canvas/graphic.js.map +0 -1
- package/lib/node_modules/zrender/lib/canvas/helper.js +0 -83
- package/lib/node_modules/zrender/lib/canvas/helper.js.map +0 -1
- package/lib/node_modules/zrender/lib/config.js +0 -18
- package/lib/node_modules/zrender/lib/config.js.map +0 -1
- package/lib/node_modules/zrender/lib/contain/arc.js +0 -37
- package/lib/node_modules/zrender/lib/contain/arc.js.map +0 -1
- package/lib/node_modules/zrender/lib/contain/cubic.js +0 -16
- package/lib/node_modules/zrender/lib/contain/cubic.js.map +0 -1
- package/lib/node_modules/zrender/lib/contain/line.js +0 -24
- package/lib/node_modules/zrender/lib/contain/line.js.map +0 -1
- package/lib/node_modules/zrender/lib/contain/path.js +0 -290
- package/lib/node_modules/zrender/lib/contain/path.js.map +0 -1
- package/lib/node_modules/zrender/lib/contain/polygon.js +0 -26
- package/lib/node_modules/zrender/lib/contain/polygon.js.map +0 -1
- package/lib/node_modules/zrender/lib/contain/quadratic.js +0 -16
- package/lib/node_modules/zrender/lib/contain/quadratic.js.map +0 -1
- package/lib/node_modules/zrender/lib/contain/text.js +0 -174
- package/lib/node_modules/zrender/lib/contain/text.js.map +0 -1
- package/lib/node_modules/zrender/lib/contain/util.js +0 -12
- package/lib/node_modules/zrender/lib/contain/util.js.map +0 -1
- package/lib/node_modules/zrender/lib/contain/windingLine.js +0 -19
- package/lib/node_modules/zrender/lib/contain/windingLine.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/BoundingRect.js +0 -205
- package/lib/node_modules/zrender/lib/core/BoundingRect.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/Eventful.js +0 -155
- package/lib/node_modules/zrender/lib/core/Eventful.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/GestureMgr.js +0 -82
- package/lib/node_modules/zrender/lib/core/GestureMgr.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/LRU.js +0 -110
- package/lib/node_modules/zrender/lib/core/LRU.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/OrientedBoundingRect.js +0 -121
- package/lib/node_modules/zrender/lib/core/OrientedBoundingRect.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/PathProxy.js +0 -697
- package/lib/node_modules/zrender/lib/core/PathProxy.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/Point.js +0 -133
- package/lib/node_modules/zrender/lib/core/Point.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/Transformable.js +0 -233
- package/lib/node_modules/zrender/lib/core/Transformable.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/WeakMap.js +0 -45
- package/lib/node_modules/zrender/lib/core/WeakMap.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/bbox.js +0 -109
- package/lib/node_modules/zrender/lib/core/bbox.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/curve.js +0 -345
- package/lib/node_modules/zrender/lib/core/curve.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/dom.js +0 -79
- package/lib/node_modules/zrender/lib/core/dom.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/env.js +0 -73
- package/lib/node_modules/zrender/lib/core/env.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/event.js +0 -101
- package/lib/node_modules/zrender/lib/core/event.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/fourPointsTransform.js +0 -60
- package/lib/node_modules/zrender/lib/core/fourPointsTransform.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/matrix.js +0 -104
- package/lib/node_modules/zrender/lib/core/matrix.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/platform.js +0 -70
- package/lib/node_modules/zrender/lib/core/platform.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/timsort.js +0 -512
- package/lib/node_modules/zrender/lib/core/timsort.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/util.js +0 -508
- package/lib/node_modules/zrender/lib/core/util.js.map +0 -1
- package/lib/node_modules/zrender/lib/core/vector.js +0 -99
- package/lib/node_modules/zrender/lib/core/vector.js.map +0 -1
- package/lib/node_modules/zrender/lib/dom/HandlerProxy.js +0 -302
- package/lib/node_modules/zrender/lib/dom/HandlerProxy.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/CompoundPath.js +0 -53
- package/lib/node_modules/zrender/lib/graphic/CompoundPath.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/Displayable.js +0 -316
- package/lib/node_modules/zrender/lib/graphic/Displayable.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/Gradient.js +0 -17
- package/lib/node_modules/zrender/lib/graphic/Gradient.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/Group.js +0 -181
- package/lib/node_modules/zrender/lib/graphic/Group.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/Image.js +0 -75
- package/lib/node_modules/zrender/lib/graphic/Image.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/IncrementalDisplayable.js +0 -115
- package/lib/node_modules/zrender/lib/graphic/IncrementalDisplayable.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/LinearGradient.js +0 -21
- package/lib/node_modules/zrender/lib/graphic/LinearGradient.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/Path.js +0 -395
- package/lib/node_modules/zrender/lib/graphic/Path.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/RadialGradient.js +0 -20
- package/lib/node_modules/zrender/lib/graphic/RadialGradient.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/TSpan.js +0 -68
- package/lib/node_modules/zrender/lib/graphic/TSpan.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/Text.js +0 -506
- package/lib/node_modules/zrender/lib/graphic/Text.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/constants.js +0 -9
- package/lib/node_modules/zrender/lib/graphic/constants.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/helper/image.js +0 -56
- package/lib/node_modules/zrender/lib/graphic/helper/image.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/helper/parseText.js +0 -447
- package/lib/node_modules/zrender/lib/graphic/helper/parseText.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/helper/poly.js +0 -28
- package/lib/node_modules/zrender/lib/graphic/helper/poly.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/helper/roundRect.js +0 -74
- package/lib/node_modules/zrender/lib/graphic/helper/roundRect.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/helper/roundSector.js +0 -219
- package/lib/node_modules/zrender/lib/graphic/helper/roundSector.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/helper/smoothBezier.js +0 -65
- package/lib/node_modules/zrender/lib/graphic/helper/smoothBezier.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/helper/subPixelOptimize.js +0 -60
- package/lib/node_modules/zrender/lib/graphic/helper/subPixelOptimize.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/shape/Arc.js +0 -48
- package/lib/node_modules/zrender/lib/graphic/shape/Arc.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/shape/BezierCurve.js +0 -100
- package/lib/node_modules/zrender/lib/graphic/shape/BezierCurve.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/shape/Circle.js +0 -31
- package/lib/node_modules/zrender/lib/graphic/shape/Circle.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/shape/Ellipse.js +0 -43
- package/lib/node_modules/zrender/lib/graphic/shape/Ellipse.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/shape/Line.js +0 -72
- package/lib/node_modules/zrender/lib/graphic/shape/Line.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/shape/Polygon.js +0 -31
- package/lib/node_modules/zrender/lib/graphic/shape/Polygon.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/shape/Polyline.js +0 -38
- package/lib/node_modules/zrender/lib/graphic/shape/Polyline.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/shape/Rect.js +0 -59
- package/lib/node_modules/zrender/lib/graphic/shape/Rect.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/shape/Ring.js +0 -37
- package/lib/node_modules/zrender/lib/graphic/shape/Ring.js.map +0 -1
- package/lib/node_modules/zrender/lib/graphic/shape/Sector.js +0 -39
- package/lib/node_modules/zrender/lib/graphic/shape/Sector.js.map +0 -1
- package/lib/node_modules/zrender/lib/mixin/Draggable.js +0 -70
- package/lib/node_modules/zrender/lib/mixin/Draggable.js.map +0 -1
- package/lib/node_modules/zrender/lib/svg/helper.js +0 -31
- package/lib/node_modules/zrender/lib/svg/helper.js.map +0 -1
- package/lib/node_modules/zrender/lib/tool/color.js +0 -459
- package/lib/node_modules/zrender/lib/tool/color.js.map +0 -1
- package/lib/node_modules/zrender/lib/tool/parseSVG.js +0 -633
- package/lib/node_modules/zrender/lib/tool/parseSVG.js.map +0 -1
- package/lib/node_modules/zrender/lib/tool/parseXML.js +0 -19
- package/lib/node_modules/zrender/lib/tool/parseXML.js.map +0 -1
- package/lib/node_modules/zrender/lib/tool/path.js +0 -339
- package/lib/node_modules/zrender/lib/tool/path.js.map +0 -1
- package/lib/node_modules/zrender/lib/tool/transformPath.js +0 -85
- package/lib/node_modules/zrender/lib/tool/transformPath.js.map +0 -1
- package/lib/node_modules/zrender/lib/zrender.js +0 -238
- package/lib/node_modules/zrender/lib/zrender.js.map +0 -1
- package/lib/node_modules/zrender/node_modules/tslib/tslib.es6.js +0 -37
- package/lib/node_modules/zrender/node_modules/tslib/tslib.es6.js.map +0 -1
- package/lib/setting/page-config/PageConfig.vue.js +0 -24
- package/lib/setting/page-config/PageConfig.vue.js.map +0 -1
- package/lib/setting/page-config/PageConfig.vue2.js +0 -109
- package/lib/setting/page-config/PageConfig.vue2.js.map +0 -1
- package/lib/setting/page-config/PageConfig.vue3.js +0 -5
- package/lib/setting/page-config/PageConfig.vue3.js.map +0 -1
- package/lib/setting/page-config/index.js +0 -11
- package/lib/setting/page-config/index.js.map +0 -1
- package/lib/setting/page-config/props.js +0 -16
- package/lib/setting/page-config/props.js.map +0 -1
- package/lib/setting/provider-config/ProviderConfig.vue.js +0 -17
- package/lib/setting/provider-config/ProviderConfig.vue.js.map +0 -1
- package/lib/setting/provider-config/ProviderConfig.vue2.js +0 -177
- package/lib/setting/provider-config/ProviderConfig.vue2.js.map +0 -1
- package/lib/setting/provider-config/index.js +0 -11
- package/lib/setting/provider-config/index.js.map +0 -1
- package/lib/setting/provider-config/props.js +0 -13
- package/lib/setting/provider-config/props.js.map +0 -1
- package/lib/style.css +0 -11218
- package/lib/table/table/Table.vue.js +0 -164
- package/lib/table/table/Table.vue.js.map +0 -1
- package/lib/table/table/Table.vue2.js +0 -547
- package/lib/table/table/Table.vue2.js.map +0 -1
- package/lib/table/table/Table.vue3.js +0 -5
- package/lib/table/table/Table.vue3.js.map +0 -1
- package/lib/table/table/Table.vue4.js +0 -5
- package/lib/table/table/Table.vue4.js.map +0 -1
- package/lib/table/table/index.js +0 -12
- package/lib/table/table/index.js.map +0 -1
- package/lib/table/table/props.js +0 -78
- package/lib/table/table/props.js.map +0 -1
- package/lib/text/list/List.vue.js +0 -112
- package/lib/text/list/List.vue.js.map +0 -1
- package/lib/text/list/List.vue2.js +0 -107
- package/lib/text/list/List.vue2.js.map +0 -1
- package/lib/text/list/List.vue3.js +0 -5
- package/lib/text/list/List.vue3.js.map +0 -1
- package/lib/text/list/List.vue4.js +0 -5
- package/lib/text/list/List.vue4.js.map +0 -1
- package/lib/text/list/index.js +0 -12
- package/lib/text/list/index.js.map +0 -1
- package/lib/text/list/props.js +0 -43
- package/lib/text/list/props.js.map +0 -1
- package/lib/text/proportion/Proportion.vue.js +0 -48
- package/lib/text/proportion/Proportion.vue.js.map +0 -1
- package/lib/text/proportion/Proportion.vue2.js +0 -163
- package/lib/text/proportion/Proportion.vue2.js.map +0 -1
- package/lib/text/proportion/Proportion.vue3.js +0 -5
- package/lib/text/proportion/Proportion.vue3.js.map +0 -1
- package/lib/text/proportion/index.js +0 -12
- package/lib/text/proportion/index.js.map +0 -1
- package/lib/text/proportion/props.js +0 -33
- package/lib/text/proportion/props.js.map +0 -1
- package/lib/text/scroll-text/ScrollText.vue.js +0 -13
- package/lib/text/scroll-text/ScrollText.vue.js.map +0 -1
- package/lib/text/scroll-text/ScrollText.vue2.js +0 -14
- package/lib/text/scroll-text/ScrollText.vue2.js.map +0 -1
- package/lib/text/scroll-text/ScrollText.vue3.js +0 -5
- package/lib/text/scroll-text/ScrollText.vue3.js.map +0 -1
- package/lib/text/scroll-text/index.js +0 -8
- package/lib/text/scroll-text/index.js.map +0 -1
- package/lib/text/text/Text.vue.js +0 -26
- package/lib/text/text/Text.vue.js.map +0 -1
- package/lib/text/text/Text.vue2.js +0 -153
- package/lib/text/text/Text.vue2.js.map +0 -1
- package/lib/text/text/Text.vue3.js +0 -5
- package/lib/text/text/Text.vue3.js.map +0 -1
- package/lib/text/text/index.js +0 -12
- package/lib/text/text/index.js.map +0 -1
- package/lib/text/text/props.js +0 -33
- package/lib/text/text/props.js.map +0 -1
- package/lib/text/time-display/TimeDisplay.vue.js +0 -15
- package/lib/text/time-display/TimeDisplay.vue.js.map +0 -1
- package/lib/text/time-display/TimeDisplay.vue2.js +0 -46
- package/lib/text/time-display/TimeDisplay.vue2.js.map +0 -1
- package/lib/text/time-display/TimeDisplay.vue3.js +0 -5
- package/lib/text/time-display/TimeDisplay.vue3.js.map +0 -1
- package/lib/text/time-display/index.js +0 -11
- package/lib/text/time-display/index.js.map +0 -1
- package/lib/text/time-display/props.js +0 -23
- package/lib/text/time-display/props.js.map +0 -1
- package/lib/utils/constant.js +0 -23
- package/lib/utils/constant.js.map +0 -1
- package/lib/utils/props.js +0 -40
- package/lib/utils/props.js.map +0 -1
- package/lib/utils/request.js +0 -47
- package/lib/utils/request.js.map +0 -1
- package/lib/utils/util.js +0 -31
- package/lib/utils/util.js.map +0 -1
- package/lib/utils/withInstall.js +0 -19
- package/lib/utils/withInstall.js.map +0 -1
package/dist/index.umd.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.umd.js","sources":["../src/common/echarts/composables/api.ts","../src/common/echarts/composables/autoresize.ts","../src/common/echarts/composables/loading.ts","../src/common/echarts/utils.ts","../src/common/echarts/Echarts.ts","../node_modules/@ctrl/tinycolor/dist/module/util.js","../node_modules/@ctrl/tinycolor/dist/module/conversion.js","../node_modules/@ctrl/tinycolor/dist/module/css-color-names.js","../node_modules/@ctrl/tinycolor/dist/module/format-input.js","../node_modules/@ant-design/colors/dist/index.esm.js","../node_modules/@ant-design/icons-vue/es/insert-css.js","../node_modules/@ant-design/icons-vue/es/utils.js","../node_modules/@ant-design/icons-vue/es/components/IconBase.js","../node_modules/@ant-design/icons-vue/es/components/twoTonePrimaryColor.js","../node_modules/@ant-design/icons-vue/es/components/AntdIcon.js","../node_modules/@ant-design/icons-svg/es/asn/LoadingOutlined.js","../node_modules/@ant-design/icons-vue/es/icons/LoadingOutlined.js","../src/common/spin/Spin.vue","../src/common/skeleton/Skeleton.vue","../node_modules/@vue/shared/dist/shared.esm-bundler.js","../src/utils/withInstall.ts","../src/utils/props.ts","../src/setting/page-config/props.ts","../src/hooks/usePickComponentStyle.ts","../src/utils/constant.ts","../src/hooks/useOnEvent.ts","../src/hooks/useEmitEvent.ts","../src/hooks/useTransformChartDataByAttrValue.ts","../src/utils/util.ts","../src/hooks/useVariablesInText.ts","../src/hooks/useRequestData.ts","../src/hooks/useTransformChartDataByAttrKey.ts","../src/hooks/useImagePath.ts","../src/hooks/usePageUrl.ts","../src/utils/request.ts","../src/hooks/useRequestDiagramData.ts","../src/hooks/useValueFormatter.ts","../src/hooks/useIndicatorData.ts","../src/hooks/useHrefParamsToGlobalVariables.ts","../src/setting/page-config/PageConfig.vue","../src/setting/page-config/index.ts","../src/setting/provider-config/props.ts","../src/setting/provider-config/ProviderConfig.vue","../src/setting/provider-config/index.ts","../src/text/text/props.ts","../src/assets/go-up.png","../src/assets/go-down.png","../src/text/text/Text.vue","../src/text/text/index.ts","../src/text/scroll-text/ScrollText.vue","../src/text/scroll-text/index.ts","../src/text/time-display/props.ts","../src/text/time-display/TimeDisplay.vue","../src/text/time-display/index.ts","../src/text/list/props.ts","../src/text/list/List.vue","../src/text/list/index.ts","../src/text/proportion/props.ts","../src/text/proportion/Proportion.vue","../src/text/proportion/index.ts","../src/control/input/props.ts","../src/control/input/Input.vue","../src/control/input/index.ts","../src/control/date-picker/props.ts","../src/control/date-picker/DatePicker.vue","../src/control/date-picker/index.ts","../src/control/select/props.ts","../src/control/select/Select.vue","../src/control/select/index.ts","../src/control/range-picker/props.ts","../src/control/range-picker/RangePicker.vue","../src/control/range-picker/index.ts","../src/control/button/props.ts","../src/control/button/Button.vue","../src/control/button/index.ts","../src/control/checkbox/props.ts","../src/control/checkbox/Checkbox.vue","../src/control/checkbox/index.ts","../src/graph/pie/props.ts","../src/hooks/useDownloadFile.ts","../src/graph/pie/Pie.vue","../src/graph/pie/index.ts","../src/graph/line/props.ts","../src/graph/line/Line.vue","../src/graph/line/index.ts","../src/graph/bar/props.ts","../src/graph/bar/Bar.vue","../src/graph/bar/index.ts","../src/graph/scatter/props.ts","../src/graph/scatter/Scatter.vue","../src/graph/scatter/index.ts","../src/graph/custom-graph/props.ts","../src/graph/custom-graph/CustomGraph.vue","../src/graph/custom-graph/index.ts","../src/graph/combo-graph/props.ts","../src/graph/combo-graph/ComboGraph.vue","../src/graph/combo-graph/index.ts","../src/container/border/props.ts","../src/container/border/Border.vue","../src/assets/border-title-decoration-left.png","../src/assets/border-title-decoration-right.png","../src/container/border/index.ts","../src/container/modal/props.ts","../src/container/modal/Modal.vue","../src/container/modal/index.ts","../src/container/tabs/props.ts","../src/container/tabs/Tabs.vue","../src/container/tabs/index.ts","../src/media/image/props.ts","../src/media/image/Image.vue","../src/media/image/index.ts","../src/media/iframe/props.ts","../src/media/iframe/Iframe.vue","../src/media/iframe/index.ts","../src/table/table/props.ts","../src/table/table/Table.vue","../src/table/table/index.ts","../src/map/map/props.ts","../src/map/map/Map.vue","../src/map/map/index.ts","../src/index.ts"],"sourcesContent":["import { Ref } from 'vue'\nimport { EChartsType, Option } from '../types'\n\nconst METHOD_NAMES = [\n 'getWidth',\n 'getHeight',\n 'getDom',\n 'getOption',\n 'resize',\n 'dispatchAction',\n 'convertToPixel',\n 'convertFromPixel',\n 'containPixel',\n 'getDataURL',\n 'getConnectedDataURL',\n 'appendData',\n 'clear',\n 'isDisposed',\n 'dispose'\n] as const\ntype MethodName = typeof METHOD_NAMES[number];\n\ntype PublicMethods = Pick<EChartsType, MethodName>;\n\nexport function usePublicAPI (\n chart: Ref<EChartsType | undefined>,\n init: (option?: Option) => void\n): PublicMethods {\n function makePublicMethod<T extends MethodName> (\n name: T\n ): (...args: Parameters<EChartsType[T]>) => ReturnType<EChartsType[T]> {\n return (...args) => {\n if (!chart.value) {\n init()\n }\n\n if (!chart.value) {\n throw new Error('ECharts is not initialized yet.')\n }\n return (chart.value[name] as any).apply(chart.value, args)\n }\n }\n\n function makePublicMethods (): PublicMethods {\n const methods = Object.create(null)\n METHOD_NAMES.forEach(name => {\n methods[name] = makePublicMethod(name)\n })\n\n return methods as PublicMethods\n }\n\n return makePublicMethods()\n}\n","import { Ref, watch } from 'vue'\nimport { throttle } from 'echarts/core'\nimport { addListener, removeListener, ResizeCallback } from 'resize-detector'\nimport { EChartsType } from '../types'\n\nexport function useAutoresize (\n chart: Ref<EChartsType | undefined>,\n autoresize: Ref<boolean>,\n root: Ref<HTMLElement | undefined>\n): void {\n let resizeListener: ResizeCallback | null = null\n\n watch([root, chart, autoresize], ([root, chart, autoresize], _, cleanup) => {\n if (root && chart && autoresize) {\n resizeListener = throttle(() => {\n chart.resize()\n }, 100)\n\n addListener(root, resizeListener)\n }\n\n cleanup(() => {\n if (resizeListener && root) {\n removeListener(root, resizeListener)\n }\n })\n })\n}\n\nexport const autoresizeProps = {\n autoresize: Boolean\n}\n","import { inject, unref, computed, Ref, watchEffect } from 'vue'\nimport { EChartsType } from '../types'\n\nexport const LOADING_OPTIONS_KEY = 'ecLoadingOptions'\n\ntype UnknownRecord = Record<string, unknown>;\n\nexport function useLoading (\n chart: Ref<EChartsType | undefined>,\n loading: Ref<boolean>,\n loadingOptions: Ref<UnknownRecord | undefined>\n): void {\n const defaultLoadingOptions = inject(LOADING_OPTIONS_KEY, {}) as\n | UnknownRecord\n | Ref<UnknownRecord>\n const realLoadingOptions = computed(() => ({\n ...unref(defaultLoadingOptions),\n ...loadingOptions?.value\n }))\n\n watchEffect(() => {\n const instance = chart.value\n if (!instance) {\n return\n }\n\n if (loading.value) {\n instance.showLoading(realLoadingOptions.value)\n } else {\n instance.hideLoading()\n }\n })\n}\n\nexport const loadingProps = {\n loading: Boolean,\n loadingOptions: Object\n}\n","type Attrs = {\n [key: string]: any\n}\n\n// Copied from\n// https://github.com/vuejs/vue-next/blob/5a7a1b8293822219283d6e267496bec02234b0bc/packages/shared/src/index.ts#L40-L41\nconst onRE = /^on[^a-z]/\nexport const isOn = (key: string): boolean => onRE.test(key)\n\nexport function omitOn (attrs: Attrs): Attrs {\n const result: Attrs = {}\n for (const key in attrs) {\n if (!isOn(key)) {\n result[key] = attrs[key]\n }\n }\n\n return result\n}\n","// 此组件为 vue-echarts\n// 文档:https://github.com/ecomfe/vue-echarts/blob/main/README.zh-Hans.md\nimport {\n defineComponent,\n unref,\n shallowRef,\n toRefs,\n watch,\n computed,\n inject,\n onMounted,\n onUnmounted,\n h,\n nextTick,\n PropType,\n watchEffect\n} from 'vue'\nimport { init as initChart } from 'echarts/core'\nimport {\n EChartsType,\n Option,\n Theme,\n ThemeInjection,\n InitOptions,\n InitOptionsInjection,\n UpdateOptions,\n UpdateOptionsInjection\n} from './types'\nimport {\n usePublicAPI,\n useAutoresize,\n autoresizeProps,\n useLoading,\n loadingProps\n} from './composables'\nimport './style.css'\nimport { omitOn } from './utils'\n\nconst TAG_NAME = 'x-vue-echarts'\nexport const THEME_KEY = 'ecTheme'\nexport const INIT_OPTIONS_KEY = 'ecInitOptions'\nexport const UPDATE_OPTIONS_KEY = 'ecUpdateOptions'\nexport { LOADING_OPTIONS_KEY } from './composables'\n\n// @ts-ignore\nexport default defineComponent({\n name: 'echarts',\n props: {\n option: Object as PropType<Option>,\n theme: {\n type: [Object, String] as PropType<Theme>\n },\n initOptions: Object as PropType<InitOptions>,\n updateOptions: Object as PropType<UpdateOptions>,\n group: String,\n manualUpdate: Boolean,\n ...autoresizeProps,\n ...loadingProps\n },\n inheritAttrs: false,\n // @ts-expect-error listeners for Vue 2 compatibility\n setup (props, { attrs, listeners }) {\n const root = shallowRef<HTMLElement>()\n const chart = shallowRef<EChartsType>()\n const manualOption = shallowRef<Option>()\n const defaultTheme = inject(THEME_KEY, null) as ThemeInjection\n const defaultInitOptions = inject(\n INIT_OPTIONS_KEY,\n null\n ) as InitOptionsInjection\n const defaultUpdateOptions = inject(\n UPDATE_OPTIONS_KEY,\n null\n ) as UpdateOptionsInjection\n\n const { autoresize, manualUpdate, loading, loadingOptions } = toRefs(props)\n\n const realOption = computed(\n () => manualOption.value || props.option || Object.create(null)\n )\n const realTheme = computed(() => props.theme || unref(defaultTheme) || {})\n const realInitOptions = computed(\n () => props.initOptions || unref(defaultInitOptions) || {}\n )\n const realUpdateOptions = computed(\n () => props.updateOptions || unref(defaultUpdateOptions) || {}\n )\n const nonEventAttrs = computed(() => omitOn(attrs))\n\n function init (option?: Option) {\n if (chart.value || !root.value) {\n return\n }\n\n const instance = (chart.value = initChart(\n root.value,\n realTheme.value,\n realInitOptions.value\n ))\n\n if (props.group) {\n instance.group = props.group\n }\n\n let realListeners = listeners\n if (!realListeners) {\n realListeners = {}\n\n Object.keys(attrs)\n .filter(key => key.indexOf('on') === 0 && key.length > 2)\n .forEach(key => {\n // onClick -> c + lick\n // onZr:click -> z + r:click\n const event = key.charAt(2).toLowerCase() + key.slice(3)\n realListeners[event] = attrs[key]\n })\n }\n\n Object.keys(realListeners).forEach(key => {\n const handler = realListeners[key] as any\n\n if (!handler) {\n return\n }\n\n if (key.indexOf('zr:') === 0) {\n instance.getZr().on(key.slice(3).toLowerCase(), handler)\n } else {\n instance.on(key.toLowerCase(), handler)\n }\n })\n\n function resize () {\n if (instance && !instance.isDisposed()) {\n // temporarily suppress errors caused by https://github.com/apache/echarts/issues/14846\n try {\n instance.resize()\n } catch (e) {\n if (e.message === \"Cannot read property 'get' of undefined\") {\n return\n }\n\n throw e\n }\n }\n }\n\n function commit () {\n instance.setOption(option || realOption.value, realUpdateOptions.value)\n }\n\n if (autoresize.value) {\n // Try to make chart fit to container in case container size\n // is changed synchronously or in already queued microtasks\n nextTick(() => {\n resize()\n commit()\n })\n } else {\n commit()\n }\n }\n\n function setOption (option: Option, updateOptions?: UpdateOptions) {\n if (props.manualUpdate) {\n manualOption.value = option\n }\n\n if (!chart.value) {\n init(option)\n } else {\n chart.value.setOption(option, updateOptions || {})\n }\n }\n\n function cleanup () {\n if (chart.value) {\n chart.value.dispose()\n chart.value = undefined\n }\n }\n\n let unwatchOption: (() => void) | null = null\n watch(\n manualUpdate,\n manualUpdate => {\n if (typeof unwatchOption === 'function') {\n unwatchOption()\n unwatchOption = null\n }\n\n if (!manualUpdate) {\n unwatchOption = watch(\n () => props.option,\n option => {\n if (!option) {\n return\n }\n if (!chart.value) {\n init()\n } else {\n chart.value.setOption(option, realUpdateOptions.value)\n }\n },\n { deep: true }\n )\n }\n },\n {\n immediate: true\n }\n )\n\n watch(\n [realTheme, realInitOptions],\n () => {\n cleanup()\n init()\n },\n {\n deep: true\n }\n )\n\n watchEffect(() => {\n if (props.group && chart.value) {\n chart.value.group = props.group\n }\n })\n\n const publicApi = usePublicAPI(chart, init)\n\n useLoading(chart, loading, loadingOptions)\n\n useAutoresize(chart, autoresize, root)\n\n onMounted(() => {\n if (props.option) {\n init()\n }\n })\n\n onUnmounted(cleanup)\n\n return {\n chart,\n root,\n setOption,\n nonEventAttrs,\n ...publicApi\n }\n },\n render () {\n const attrs = { ...this.nonEventAttrs }\n attrs.ref = 'root'\n attrs.class = attrs.class ? ['echarts'].concat(attrs.class) : 'echarts'\n return h(TAG_NAME, attrs)\n }\n})\n","/**\n * Take input from [0, n] and return it as [0, 1]\n * @hidden\n */\nexport function bound01(n, max) {\n if (isOnePointZero(n)) {\n n = '100%';\n }\n var isPercent = isPercentage(n);\n n = max === 360 ? n : Math.min(max, Math.max(0, parseFloat(n)));\n // Automatically convert percentage into number\n if (isPercent) {\n n = parseInt(String(n * max), 10) / 100;\n }\n // Handle floating point rounding errors\n if (Math.abs(n - max) < 0.000001) {\n return 1;\n }\n // Convert into [0, 1] range if it isn't already\n if (max === 360) {\n // If n is a hue given in degrees,\n // wrap around out-of-range values into [0, 360] range\n // then convert into [0, 1].\n n = (n < 0 ? (n % max) + max : n % max) / parseFloat(String(max));\n }\n else {\n // If n not a hue given in degrees\n // Convert into [0, 1] range if it isn't already.\n n = (n % max) / parseFloat(String(max));\n }\n return n;\n}\n/**\n * Force a number between 0 and 1\n * @hidden\n */\nexport function clamp01(val) {\n return Math.min(1, Math.max(0, val));\n}\n/**\n * Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1\n * <http://stackoverflow.com/questions/7422072/javascript-how-to-detect-number-as-a-decimal-including-1-0>\n * @hidden\n */\nexport function isOnePointZero(n) {\n return typeof n === 'string' && n.indexOf('.') !== -1 && parseFloat(n) === 1;\n}\n/**\n * Check to see if string passed in is a percentage\n * @hidden\n */\nexport function isPercentage(n) {\n return typeof n === 'string' && n.indexOf('%') !== -1;\n}\n/**\n * Return a valid alpha value [0,1] with all invalid values being set to 1\n * @hidden\n */\nexport function boundAlpha(a) {\n a = parseFloat(a);\n if (isNaN(a) || a < 0 || a > 1) {\n a = 1;\n }\n return a;\n}\n/**\n * Replace a decimal with it's percentage value\n * @hidden\n */\nexport function convertToPercentage(n) {\n if (n <= 1) {\n return \"\".concat(Number(n) * 100, \"%\");\n }\n return n;\n}\n/**\n * Force a hex value to have 2 characters\n * @hidden\n */\nexport function pad2(c) {\n return c.length === 1 ? '0' + c : String(c);\n}\n","import { bound01, pad2 } from './util';\n// `rgbToHsl`, `rgbToHsv`, `hslToRgb`, `hsvToRgb` modified from:\n// <http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript>\n/**\n * Handle bounds / percentage checking to conform to CSS color spec\n * <http://www.w3.org/TR/css3-color/>\n * *Assumes:* r, g, b in [0, 255] or [0, 1]\n * *Returns:* { r, g, b } in [0, 255]\n */\nexport function rgbToRgb(r, g, b) {\n return {\n r: bound01(r, 255) * 255,\n g: bound01(g, 255) * 255,\n b: bound01(b, 255) * 255,\n };\n}\n/**\n * Converts an RGB color value to HSL.\n * *Assumes:* r, g, and b are contained in [0, 255] or [0, 1]\n * *Returns:* { h, s, l } in [0,1]\n */\nexport function rgbToHsl(r, g, b) {\n r = bound01(r, 255);\n g = bound01(g, 255);\n b = bound01(b, 255);\n var max = Math.max(r, g, b);\n var min = Math.min(r, g, b);\n var h = 0;\n var s = 0;\n var l = (max + min) / 2;\n if (max === min) {\n s = 0;\n h = 0; // achromatic\n }\n else {\n var d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n switch (max) {\n case r:\n h = (g - b) / d + (g < b ? 6 : 0);\n break;\n case g:\n h = (b - r) / d + 2;\n break;\n case b:\n h = (r - g) / d + 4;\n break;\n default:\n break;\n }\n h /= 6;\n }\n return { h: h, s: s, l: l };\n}\nfunction hue2rgb(p, q, t) {\n if (t < 0) {\n t += 1;\n }\n if (t > 1) {\n t -= 1;\n }\n if (t < 1 / 6) {\n return p + (q - p) * (6 * t);\n }\n if (t < 1 / 2) {\n return q;\n }\n if (t < 2 / 3) {\n return p + (q - p) * (2 / 3 - t) * 6;\n }\n return p;\n}\n/**\n * Converts an HSL color value to RGB.\n *\n * *Assumes:* h is contained in [0, 1] or [0, 360] and s and l are contained [0, 1] or [0, 100]\n * *Returns:* { r, g, b } in the set [0, 255]\n */\nexport function hslToRgb(h, s, l) {\n var r;\n var g;\n var b;\n h = bound01(h, 360);\n s = bound01(s, 100);\n l = bound01(l, 100);\n if (s === 0) {\n // achromatic\n g = l;\n b = l;\n r = l;\n }\n else {\n var q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n var p = 2 * l - q;\n r = hue2rgb(p, q, h + 1 / 3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1 / 3);\n }\n return { r: r * 255, g: g * 255, b: b * 255 };\n}\n/**\n * Converts an RGB color value to HSV\n *\n * *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1]\n * *Returns:* { h, s, v } in [0,1]\n */\nexport function rgbToHsv(r, g, b) {\n r = bound01(r, 255);\n g = bound01(g, 255);\n b = bound01(b, 255);\n var max = Math.max(r, g, b);\n var min = Math.min(r, g, b);\n var h = 0;\n var v = max;\n var d = max - min;\n var s = max === 0 ? 0 : d / max;\n if (max === min) {\n h = 0; // achromatic\n }\n else {\n switch (max) {\n case r:\n h = (g - b) / d + (g < b ? 6 : 0);\n break;\n case g:\n h = (b - r) / d + 2;\n break;\n case b:\n h = (r - g) / d + 4;\n break;\n default:\n break;\n }\n h /= 6;\n }\n return { h: h, s: s, v: v };\n}\n/**\n * Converts an HSV color value to RGB.\n *\n * *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100]\n * *Returns:* { r, g, b } in the set [0, 255]\n */\nexport function hsvToRgb(h, s, v) {\n h = bound01(h, 360) * 6;\n s = bound01(s, 100);\n v = bound01(v, 100);\n var i = Math.floor(h);\n var f = h - i;\n var p = v * (1 - s);\n var q = v * (1 - f * s);\n var t = v * (1 - (1 - f) * s);\n var mod = i % 6;\n var r = [v, q, p, p, t, v][mod];\n var g = [t, v, v, q, p, p][mod];\n var b = [p, p, t, v, v, q][mod];\n return { r: r * 255, g: g * 255, b: b * 255 };\n}\n/**\n * Converts an RGB color to hex\n *\n * Assumes r, g, and b are contained in the set [0, 255]\n * Returns a 3 or 6 character hex\n */\nexport function rgbToHex(r, g, b, allow3Char) {\n var hex = [\n pad2(Math.round(r).toString(16)),\n pad2(Math.round(g).toString(16)),\n pad2(Math.round(b).toString(16)),\n ];\n // Return a 3 character hex if possible\n if (allow3Char &&\n hex[0].startsWith(hex[0].charAt(1)) &&\n hex[1].startsWith(hex[1].charAt(1)) &&\n hex[2].startsWith(hex[2].charAt(1))) {\n return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0);\n }\n return hex.join('');\n}\n/**\n * Converts an RGBA color plus alpha transparency to hex\n *\n * Assumes r, g, b are contained in the set [0, 255] and\n * a in [0, 1]. Returns a 4 or 8 character rgba hex\n */\n// eslint-disable-next-line max-params\nexport function rgbaToHex(r, g, b, a, allow4Char) {\n var hex = [\n pad2(Math.round(r).toString(16)),\n pad2(Math.round(g).toString(16)),\n pad2(Math.round(b).toString(16)),\n pad2(convertDecimalToHex(a)),\n ];\n // Return a 4 character hex if possible\n if (allow4Char &&\n hex[0].startsWith(hex[0].charAt(1)) &&\n hex[1].startsWith(hex[1].charAt(1)) &&\n hex[2].startsWith(hex[2].charAt(1)) &&\n hex[3].startsWith(hex[3].charAt(1))) {\n return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0) + hex[3].charAt(0);\n }\n return hex.join('');\n}\n/**\n * Converts an RGBA color to an ARGB Hex8 string\n * Rarely used, but required for \"toFilter()\"\n */\nexport function rgbaToArgbHex(r, g, b, a) {\n var hex = [\n pad2(convertDecimalToHex(a)),\n pad2(Math.round(r).toString(16)),\n pad2(Math.round(g).toString(16)),\n pad2(Math.round(b).toString(16)),\n ];\n return hex.join('');\n}\n/** Converts a decimal to a hex value */\nexport function convertDecimalToHex(d) {\n return Math.round(parseFloat(d) * 255).toString(16);\n}\n/** Converts a hex value to a decimal */\nexport function convertHexToDecimal(h) {\n return parseIntFromHex(h) / 255;\n}\n/** Parse a base-16 hex value into a base-10 integer */\nexport function parseIntFromHex(val) {\n return parseInt(val, 16);\n}\nexport function numberInputToObject(color) {\n return {\n r: color >> 16,\n g: (color & 0xff00) >> 8,\n b: color & 0xff,\n };\n}\n","// https://github.com/bahamas10/css-color-names/blob/master/css-color-names.json\n/**\n * @hidden\n */\nexport var names = {\n aliceblue: '#f0f8ff',\n antiquewhite: '#faebd7',\n aqua: '#00ffff',\n aquamarine: '#7fffd4',\n azure: '#f0ffff',\n beige: '#f5f5dc',\n bisque: '#ffe4c4',\n black: '#000000',\n blanchedalmond: '#ffebcd',\n blue: '#0000ff',\n blueviolet: '#8a2be2',\n brown: '#a52a2a',\n burlywood: '#deb887',\n cadetblue: '#5f9ea0',\n chartreuse: '#7fff00',\n chocolate: '#d2691e',\n coral: '#ff7f50',\n cornflowerblue: '#6495ed',\n cornsilk: '#fff8dc',\n crimson: '#dc143c',\n cyan: '#00ffff',\n darkblue: '#00008b',\n darkcyan: '#008b8b',\n darkgoldenrod: '#b8860b',\n darkgray: '#a9a9a9',\n darkgreen: '#006400',\n darkgrey: '#a9a9a9',\n darkkhaki: '#bdb76b',\n darkmagenta: '#8b008b',\n darkolivegreen: '#556b2f',\n darkorange: '#ff8c00',\n darkorchid: '#9932cc',\n darkred: '#8b0000',\n darksalmon: '#e9967a',\n darkseagreen: '#8fbc8f',\n darkslateblue: '#483d8b',\n darkslategray: '#2f4f4f',\n darkslategrey: '#2f4f4f',\n darkturquoise: '#00ced1',\n darkviolet: '#9400d3',\n deeppink: '#ff1493',\n deepskyblue: '#00bfff',\n dimgray: '#696969',\n dimgrey: '#696969',\n dodgerblue: '#1e90ff',\n firebrick: '#b22222',\n floralwhite: '#fffaf0',\n forestgreen: '#228b22',\n fuchsia: '#ff00ff',\n gainsboro: '#dcdcdc',\n ghostwhite: '#f8f8ff',\n goldenrod: '#daa520',\n gold: '#ffd700',\n gray: '#808080',\n green: '#008000',\n greenyellow: '#adff2f',\n grey: '#808080',\n honeydew: '#f0fff0',\n hotpink: '#ff69b4',\n indianred: '#cd5c5c',\n indigo: '#4b0082',\n ivory: '#fffff0',\n khaki: '#f0e68c',\n lavenderblush: '#fff0f5',\n lavender: '#e6e6fa',\n lawngreen: '#7cfc00',\n lemonchiffon: '#fffacd',\n lightblue: '#add8e6',\n lightcoral: '#f08080',\n lightcyan: '#e0ffff',\n lightgoldenrodyellow: '#fafad2',\n lightgray: '#d3d3d3',\n lightgreen: '#90ee90',\n lightgrey: '#d3d3d3',\n lightpink: '#ffb6c1',\n lightsalmon: '#ffa07a',\n lightseagreen: '#20b2aa',\n lightskyblue: '#87cefa',\n lightslategray: '#778899',\n lightslategrey: '#778899',\n lightsteelblue: '#b0c4de',\n lightyellow: '#ffffe0',\n lime: '#00ff00',\n limegreen: '#32cd32',\n linen: '#faf0e6',\n magenta: '#ff00ff',\n maroon: '#800000',\n mediumaquamarine: '#66cdaa',\n mediumblue: '#0000cd',\n mediumorchid: '#ba55d3',\n mediumpurple: '#9370db',\n mediumseagreen: '#3cb371',\n mediumslateblue: '#7b68ee',\n mediumspringgreen: '#00fa9a',\n mediumturquoise: '#48d1cc',\n mediumvioletred: '#c71585',\n midnightblue: '#191970',\n mintcream: '#f5fffa',\n mistyrose: '#ffe4e1',\n moccasin: '#ffe4b5',\n navajowhite: '#ffdead',\n navy: '#000080',\n oldlace: '#fdf5e6',\n olive: '#808000',\n olivedrab: '#6b8e23',\n orange: '#ffa500',\n orangered: '#ff4500',\n orchid: '#da70d6',\n palegoldenrod: '#eee8aa',\n palegreen: '#98fb98',\n paleturquoise: '#afeeee',\n palevioletred: '#db7093',\n papayawhip: '#ffefd5',\n peachpuff: '#ffdab9',\n peru: '#cd853f',\n pink: '#ffc0cb',\n plum: '#dda0dd',\n powderblue: '#b0e0e6',\n purple: '#800080',\n rebeccapurple: '#663399',\n red: '#ff0000',\n rosybrown: '#bc8f8f',\n royalblue: '#4169e1',\n saddlebrown: '#8b4513',\n salmon: '#fa8072',\n sandybrown: '#f4a460',\n seagreen: '#2e8b57',\n seashell: '#fff5ee',\n sienna: '#a0522d',\n silver: '#c0c0c0',\n skyblue: '#87ceeb',\n slateblue: '#6a5acd',\n slategray: '#708090',\n slategrey: '#708090',\n snow: '#fffafa',\n springgreen: '#00ff7f',\n steelblue: '#4682b4',\n tan: '#d2b48c',\n teal: '#008080',\n thistle: '#d8bfd8',\n tomato: '#ff6347',\n turquoise: '#40e0d0',\n violet: '#ee82ee',\n wheat: '#f5deb3',\n white: '#ffffff',\n whitesmoke: '#f5f5f5',\n yellow: '#ffff00',\n yellowgreen: '#9acd32',\n};\n","import { convertHexToDecimal, hslToRgb, hsvToRgb, parseIntFromHex, rgbToRgb } from './conversion';\nimport { names } from './css-color-names';\nimport { boundAlpha, convertToPercentage } from './util';\n/**\n * Given a string or object, convert that input to RGB\n *\n * Possible string inputs:\n * ```\n * \"red\"\n * \"#f00\" or \"f00\"\n * \"#ff0000\" or \"ff0000\"\n * \"#ff000000\" or \"ff000000\"\n * \"rgb 255 0 0\" or \"rgb (255, 0, 0)\"\n * \"rgb 1.0 0 0\" or \"rgb (1, 0, 0)\"\n * \"rgba (255, 0, 0, 1)\" or \"rgba 255, 0, 0, 1\"\n * \"rgba (1.0, 0, 0, 1)\" or \"rgba 1.0, 0, 0, 1\"\n * \"hsl(0, 100%, 50%)\" or \"hsl 0 100% 50%\"\n * \"hsla(0, 100%, 50%, 1)\" or \"hsla 0 100% 50%, 1\"\n * \"hsv(0, 100%, 100%)\" or \"hsv 0 100% 100%\"\n * ```\n */\nexport function inputToRGB(color) {\n var rgb = { r: 0, g: 0, b: 0 };\n var a = 1;\n var s = null;\n var v = null;\n var l = null;\n var ok = false;\n var format = false;\n if (typeof color === 'string') {\n color = stringInputToObject(color);\n }\n if (typeof color === 'object') {\n if (isValidCSSUnit(color.r) && isValidCSSUnit(color.g) && isValidCSSUnit(color.b)) {\n rgb = rgbToRgb(color.r, color.g, color.b);\n ok = true;\n format = String(color.r).substr(-1) === '%' ? 'prgb' : 'rgb';\n }\n else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.v)) {\n s = convertToPercentage(color.s);\n v = convertToPercentage(color.v);\n rgb = hsvToRgb(color.h, s, v);\n ok = true;\n format = 'hsv';\n }\n else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.l)) {\n s = convertToPercentage(color.s);\n l = convertToPercentage(color.l);\n rgb = hslToRgb(color.h, s, l);\n ok = true;\n format = 'hsl';\n }\n if (Object.prototype.hasOwnProperty.call(color, 'a')) {\n a = color.a;\n }\n }\n a = boundAlpha(a);\n return {\n ok: ok,\n format: color.format || format,\n r: Math.min(255, Math.max(rgb.r, 0)),\n g: Math.min(255, Math.max(rgb.g, 0)),\n b: Math.min(255, Math.max(rgb.b, 0)),\n a: a,\n };\n}\n// <http://www.w3.org/TR/css3-values/#integers>\nvar CSS_INTEGER = '[-\\\\+]?\\\\d+%?';\n// <http://www.w3.org/TR/css3-values/#number-value>\nvar CSS_NUMBER = '[-\\\\+]?\\\\d*\\\\.\\\\d+%?';\n// Allow positive/negative integer/number. Don't capture the either/or, just the entire outcome.\nvar CSS_UNIT = \"(?:\".concat(CSS_NUMBER, \")|(?:\").concat(CSS_INTEGER, \")\");\n// Actual matching.\n// Parentheses and commas are optional, but not required.\n// Whitespace can take the place of commas or opening paren\nvar PERMISSIVE_MATCH3 = \"[\\\\s|\\\\(]+(\".concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")\\\\s*\\\\)?\");\nvar PERMISSIVE_MATCH4 = \"[\\\\s|\\\\(]+(\".concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")\\\\s*\\\\)?\");\nvar matchers = {\n CSS_UNIT: new RegExp(CSS_UNIT),\n rgb: new RegExp('rgb' + PERMISSIVE_MATCH3),\n rgba: new RegExp('rgba' + PERMISSIVE_MATCH4),\n hsl: new RegExp('hsl' + PERMISSIVE_MATCH3),\n hsla: new RegExp('hsla' + PERMISSIVE_MATCH4),\n hsv: new RegExp('hsv' + PERMISSIVE_MATCH3),\n hsva: new RegExp('hsva' + PERMISSIVE_MATCH4),\n hex3: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex6: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,\n hex4: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex8: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,\n};\n/**\n * Permissive string parsing. Take in a number of formats, and output an object\n * based on detected format. Returns `{ r, g, b }` or `{ h, s, l }` or `{ h, s, v}`\n */\nexport function stringInputToObject(color) {\n color = color.trim().toLowerCase();\n if (color.length === 0) {\n return false;\n }\n var named = false;\n if (names[color]) {\n color = names[color];\n named = true;\n }\n else if (color === 'transparent') {\n return { r: 0, g: 0, b: 0, a: 0, format: 'name' };\n }\n // Try to match string input using regular expressions.\n // Keep most of the number bounding out of this function - don't worry about [0,1] or [0,100] or [0,360]\n // Just return an object and let the conversion functions handle that.\n // This way the result will be the same whether the tinycolor is initialized with string or object.\n var match = matchers.rgb.exec(color);\n if (match) {\n return { r: match[1], g: match[2], b: match[3] };\n }\n match = matchers.rgba.exec(color);\n if (match) {\n return { r: match[1], g: match[2], b: match[3], a: match[4] };\n }\n match = matchers.hsl.exec(color);\n if (match) {\n return { h: match[1], s: match[2], l: match[3] };\n }\n match = matchers.hsla.exec(color);\n if (match) {\n return { h: match[1], s: match[2], l: match[3], a: match[4] };\n }\n match = matchers.hsv.exec(color);\n if (match) {\n return { h: match[1], s: match[2], v: match[3] };\n }\n match = matchers.hsva.exec(color);\n if (match) {\n return { h: match[1], s: match[2], v: match[3], a: match[4] };\n }\n match = matchers.hex8.exec(color);\n if (match) {\n return {\n r: parseIntFromHex(match[1]),\n g: parseIntFromHex(match[2]),\n b: parseIntFromHex(match[3]),\n a: convertHexToDecimal(match[4]),\n format: named ? 'name' : 'hex8',\n };\n }\n match = matchers.hex6.exec(color);\n if (match) {\n return {\n r: parseIntFromHex(match[1]),\n g: parseIntFromHex(match[2]),\n b: parseIntFromHex(match[3]),\n format: named ? 'name' : 'hex',\n };\n }\n match = matchers.hex4.exec(color);\n if (match) {\n return {\n r: parseIntFromHex(match[1] + match[1]),\n g: parseIntFromHex(match[2] + match[2]),\n b: parseIntFromHex(match[3] + match[3]),\n a: convertHexToDecimal(match[4] + match[4]),\n format: named ? 'name' : 'hex8',\n };\n }\n match = matchers.hex3.exec(color);\n if (match) {\n return {\n r: parseIntFromHex(match[1] + match[1]),\n g: parseIntFromHex(match[2] + match[2]),\n b: parseIntFromHex(match[3] + match[3]),\n format: named ? 'name' : 'hex',\n };\n }\n return false;\n}\n/**\n * Check to see if it looks like a CSS unit\n * (see `matchers` above for definition).\n */\nexport function isValidCSSUnit(color) {\n return Boolean(matchers.CSS_UNIT.exec(String(color)));\n}\n","import { inputToRGB, rgbToHex, rgbToHsv } from '@ctrl/tinycolor';\n\nvar hueStep = 2; // 色相阶梯\n\nvar saturationStep = 0.16; // 饱和度阶梯,浅色部分\n\nvar saturationStep2 = 0.05; // 饱和度阶梯,深色部分\n\nvar brightnessStep1 = 0.05; // 亮度阶梯,浅色部分\n\nvar brightnessStep2 = 0.15; // 亮度阶梯,深色部分\n\nvar lightColorCount = 5; // 浅色数量,主色上\n\nvar darkColorCount = 4; // 深色数量,主色下\n// 暗色主题颜色映射关系表\n\nvar darkColorMap = [{\n index: 7,\n opacity: 0.15\n}, {\n index: 6,\n opacity: 0.25\n}, {\n index: 5,\n opacity: 0.3\n}, {\n index: 5,\n opacity: 0.45\n}, {\n index: 5,\n opacity: 0.65\n}, {\n index: 5,\n opacity: 0.85\n}, {\n index: 4,\n opacity: 0.9\n}, {\n index: 3,\n opacity: 0.95\n}, {\n index: 2,\n opacity: 0.97\n}, {\n index: 1,\n opacity: 0.98\n}]; // Wrapper function ported from TinyColor.prototype.toHsv\n// Keep it here because of `hsv.h * 360`\n\nfunction toHsv(_ref) {\n var r = _ref.r,\n g = _ref.g,\n b = _ref.b;\n var hsv = rgbToHsv(r, g, b);\n return {\n h: hsv.h * 360,\n s: hsv.s,\n v: hsv.v\n };\n} // Wrapper function ported from TinyColor.prototype.toHexString\n// Keep it here because of the prefix `#`\n\n\nfunction toHex(_ref2) {\n var r = _ref2.r,\n g = _ref2.g,\n b = _ref2.b;\n return \"#\".concat(rgbToHex(r, g, b, false));\n} // Wrapper function ported from TinyColor.prototype.mix, not treeshakable.\n// Amount in range [0, 1]\n// Assume color1 & color2 has no alpha, since the following src code did so.\n\n\nfunction mix(rgb1, rgb2, amount) {\n var p = amount / 100;\n var rgb = {\n r: (rgb2.r - rgb1.r) * p + rgb1.r,\n g: (rgb2.g - rgb1.g) * p + rgb1.g,\n b: (rgb2.b - rgb1.b) * p + rgb1.b\n };\n return rgb;\n}\n\nfunction getHue(hsv, i, light) {\n var hue; // 根据色相不同,色相转向不同\n\n if (Math.round(hsv.h) >= 60 && Math.round(hsv.h) <= 240) {\n hue = light ? Math.round(hsv.h) - hueStep * i : Math.round(hsv.h) + hueStep * i;\n } else {\n hue = light ? Math.round(hsv.h) + hueStep * i : Math.round(hsv.h) - hueStep * i;\n }\n\n if (hue < 0) {\n hue += 360;\n } else if (hue >= 360) {\n hue -= 360;\n }\n\n return hue;\n}\n\nfunction getSaturation(hsv, i, light) {\n // grey color don't change saturation\n if (hsv.h === 0 && hsv.s === 0) {\n return hsv.s;\n }\n\n var saturation;\n\n if (light) {\n saturation = hsv.s - saturationStep * i;\n } else if (i === darkColorCount) {\n saturation = hsv.s + saturationStep;\n } else {\n saturation = hsv.s + saturationStep2 * i;\n } // 边界值修正\n\n\n if (saturation > 1) {\n saturation = 1;\n } // 第一格的 s 限制在 0.06-0.1 之间\n\n\n if (light && i === lightColorCount && saturation > 0.1) {\n saturation = 0.1;\n }\n\n if (saturation < 0.06) {\n saturation = 0.06;\n }\n\n return Number(saturation.toFixed(2));\n}\n\nfunction getValue(hsv, i, light) {\n var value;\n\n if (light) {\n value = hsv.v + brightnessStep1 * i;\n } else {\n value = hsv.v - brightnessStep2 * i;\n }\n\n if (value > 1) {\n value = 1;\n }\n\n return Number(value.toFixed(2));\n}\n\nfunction generate(color) {\n var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var patterns = [];\n var pColor = inputToRGB(color);\n\n for (var i = lightColorCount; i > 0; i -= 1) {\n var hsv = toHsv(pColor);\n var colorString = toHex(inputToRGB({\n h: getHue(hsv, i, true),\n s: getSaturation(hsv, i, true),\n v: getValue(hsv, i, true)\n }));\n patterns.push(colorString);\n }\n\n patterns.push(toHex(pColor));\n\n for (var _i = 1; _i <= darkColorCount; _i += 1) {\n var _hsv = toHsv(pColor);\n\n var _colorString = toHex(inputToRGB({\n h: getHue(_hsv, _i),\n s: getSaturation(_hsv, _i),\n v: getValue(_hsv, _i)\n }));\n\n patterns.push(_colorString);\n } // dark theme patterns\n\n\n if (opts.theme === 'dark') {\n return darkColorMap.map(function (_ref3) {\n var index = _ref3.index,\n opacity = _ref3.opacity;\n var darkColorString = toHex(mix(inputToRGB(opts.backgroundColor || '#141414'), inputToRGB(patterns[index]), opacity * 100));\n return darkColorString;\n });\n }\n\n return patterns;\n}\n\nvar presetPrimaryColors = {\n red: '#F5222D',\n volcano: '#FA541C',\n orange: '#FA8C16',\n gold: '#FAAD14',\n yellow: '#FADB14',\n lime: '#A0D911',\n green: '#52C41A',\n cyan: '#13C2C2',\n blue: '#1890FF',\n geekblue: '#2F54EB',\n purple: '#722ED1',\n magenta: '#EB2F96',\n grey: '#666666'\n};\nvar presetPalettes = {};\nvar presetDarkPalettes = {};\nObject.keys(presetPrimaryColors).forEach(function (key) {\n presetPalettes[key] = generate(presetPrimaryColors[key]);\n presetPalettes[key].primary = presetPalettes[key][5]; // dark presetPalettes\n\n presetDarkPalettes[key] = generate(presetPrimaryColors[key], {\n theme: 'dark',\n backgroundColor: '#141414'\n });\n presetDarkPalettes[key].primary = presetDarkPalettes[key][5];\n});\nvar red = presetPalettes.red;\nvar volcano = presetPalettes.volcano;\nvar gold = presetPalettes.gold;\nvar orange = presetPalettes.orange;\nvar yellow = presetPalettes.yellow;\nvar lime = presetPalettes.lime;\nvar green = presetPalettes.green;\nvar cyan = presetPalettes.cyan;\nvar blue = presetPalettes.blue;\nvar geekblue = presetPalettes.geekblue;\nvar purple = presetPalettes.purple;\nvar magenta = presetPalettes.magenta;\nvar grey = presetPalettes.grey;\n\nexport { blue, cyan, geekblue, generate, gold, green, grey, lime, magenta, orange, presetDarkPalettes, presetPalettes, presetPrimaryColors, purple, red, volcano, yellow };\n","// https://github.com/substack/insert-css\nvar containers = []; // will store container HTMLElement references\n\nvar styleElements = []; // will store {prepend: HTMLElement, append: HTMLElement}\n\nvar usage = 'insert-css: You need to provide a CSS string. Usage: insertCss(cssString[, options]).';\n\nfunction createStyleElement() {\n var styleElement = document.createElement('style');\n styleElement.setAttribute('type', 'text/css');\n return styleElement;\n} // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n\n\nfunction insertCss(css, options) {\n options = options || {};\n\n if (css === undefined) {\n throw new Error(usage);\n }\n\n var position = options.prepend === true ? 'prepend' : 'append';\n var container = options.container !== undefined ? options.container : document.querySelector('head');\n var containerId = containers.indexOf(container); // first time we see this container, create the necessary entries\n\n if (containerId === -1) {\n containerId = containers.push(container) - 1;\n styleElements[containerId] = {};\n } // try to get the correponding container + position styleElement, create it otherwise\n\n\n var styleElement;\n\n if (styleElements[containerId] !== undefined && styleElements[containerId][position] !== undefined) {\n styleElement = styleElements[containerId][position];\n } else {\n styleElement = styleElements[containerId][position] = createStyleElement();\n\n if (position === 'prepend') {\n container.insertBefore(styleElement, container.childNodes[0]);\n } else {\n container.appendChild(styleElement);\n }\n } // strip potential UTF-8 BOM if css was read from a file\n\n\n if (css.charCodeAt(0) === 0xfeff) {\n css = css.substr(1, css.length);\n } // actually add the stylesheet\n\n\n if (styleElement.styleSheet) {\n styleElement.styleSheet.cssText += css;\n } else {\n styleElement.textContent += css;\n }\n\n return styleElement;\n}\n\nexport default insertCss;","function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? Object(arguments[i]) : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { nextTick, h } from 'vue';\nimport { generate as generateColor } from '@ant-design/colors';\nimport insertCss from './insert-css';\nexport function warn(valid, message) {\n // Support uglify\n if (process.env.NODE_ENV !== 'production' && !valid && console !== undefined) {\n console.error(\"Warning: \".concat(message));\n }\n}\nexport function warning(valid, message) {\n warn(valid, \"[@ant-design/icons-vue] \".concat(message));\n} // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n\nexport function isIconDefinition(target) {\n return typeof target === 'object' && typeof target.name === 'string' && typeof target.theme === 'string' && (typeof target.icon === 'object' || typeof target.icon === 'function');\n}\nexport function normalizeAttrs() {\n var attrs = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n return Object.keys(attrs).reduce(function (acc, key) {\n var val = attrs[key];\n\n switch (key) {\n case 'class':\n acc.className = val;\n delete acc[\"class\"];\n break;\n\n default:\n acc[key] = val;\n }\n\n return acc;\n }, {});\n}\nexport function generate(node, key, rootProps) {\n if (!rootProps) {\n return h(node.tag, _objectSpread({\n key: key\n }, node.attrs), (node.children || []).map(function (child, index) {\n return generate(child, \"\".concat(key, \"-\").concat(node.tag, \"-\").concat(index));\n }));\n }\n\n return h(node.tag, _objectSpread({\n key: key\n }, rootProps, node.attrs), (node.children || []).map(function (child, index) {\n return generate(child, \"\".concat(key, \"-\").concat(node.tag, \"-\").concat(index));\n }));\n}\nexport function getSecondaryColor(primaryColor) {\n // choose the second color\n return generateColor(primaryColor)[0];\n}\nexport function normalizeTwoToneColors(twoToneColor) {\n if (!twoToneColor) {\n return [];\n }\n\n return Array.isArray(twoToneColor) ? twoToneColor : [twoToneColor];\n} // These props make sure that the SVG behaviours like general text.\n// Reference: https://blog.prototypr.io/align-svg-icons-to-text-and-say-goodbye-to-font-icons-d44b3d7b26b4\n\nexport var svgBaseProps = {\n width: '1em',\n height: '1em',\n fill: 'currentColor',\n 'aria-hidden': 'true',\n focusable: 'false'\n};\nexport var iconStyles = \"\\n.anticon {\\n display: inline-block;\\n color: inherit;\\n font-style: normal;\\n line-height: 0;\\n text-align: center;\\n text-transform: none;\\n vertical-align: -0.125em;\\n text-rendering: optimizeLegibility;\\n -webkit-font-smoothing: antialiased;\\n -moz-osx-font-smoothing: grayscale;\\n}\\n\\n.anticon > * {\\n line-height: 1;\\n}\\n\\n.anticon svg {\\n display: inline-block;\\n}\\n\\n.anticon::before {\\n display: none;\\n}\\n\\n.anticon .anticon-icon {\\n display: block;\\n}\\n\\n.anticon[tabindex] {\\n cursor: pointer;\\n}\\n\\n.anticon-spin::before,\\n.anticon-spin {\\n display: inline-block;\\n -webkit-animation: loadingCircle 1s infinite linear;\\n animation: loadingCircle 1s infinite linear;\\n}\\n\\n@-webkit-keyframes loadingCircle {\\n 100% {\\n -webkit-transform: rotate(360deg);\\n transform: rotate(360deg);\\n }\\n}\\n\\n@keyframes loadingCircle {\\n 100% {\\n -webkit-transform: rotate(360deg);\\n transform: rotate(360deg);\\n }\\n}\\n\";\nvar cssInjectedFlag = false;\nexport var useInsertStyles = function useInsertStyles() {\n var styleStr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : iconStyles;\n nextTick(function () {\n if (!cssInjectedFlag) {\n if (typeof window !== 'undefined' && window.document && window.document.documentElement) {\n insertCss(styleStr, {\n prepend: true\n });\n }\n\n cssInjectedFlag = true;\n }\n });\n};","var _excluded = [\"icon\", \"primaryColor\", \"secondaryColor\"];\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? Object(arguments[i]) : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { generate, getSecondaryColor, isIconDefinition, warning, useInsertStyles } from '../utils';\nvar twoToneColorPalette = {\n primaryColor: '#333',\n secondaryColor: '#E6E6E6',\n calculated: false\n};\n\nfunction setTwoToneColors(_ref) {\n var primaryColor = _ref.primaryColor,\n secondaryColor = _ref.secondaryColor;\n twoToneColorPalette.primaryColor = primaryColor;\n twoToneColorPalette.secondaryColor = secondaryColor || getSecondaryColor(primaryColor);\n twoToneColorPalette.calculated = !!secondaryColor;\n}\n\nfunction getTwoToneColors() {\n return _objectSpread({}, twoToneColorPalette);\n}\n\nvar IconBase = function IconBase(props, context) {\n var _props$context$attrs = _objectSpread({}, props, context.attrs),\n icon = _props$context$attrs.icon,\n primaryColor = _props$context$attrs.primaryColor,\n secondaryColor = _props$context$attrs.secondaryColor,\n restProps = _objectWithoutProperties(_props$context$attrs, _excluded);\n\n var colors = twoToneColorPalette;\n\n if (primaryColor) {\n colors = {\n primaryColor: primaryColor,\n secondaryColor: secondaryColor || getSecondaryColor(primaryColor)\n };\n }\n\n useInsertStyles();\n warning(isIconDefinition(icon), \"icon should be icon definiton, but got \".concat(icon));\n\n if (!isIconDefinition(icon)) {\n return null;\n }\n\n var target = icon;\n\n if (target && typeof target.icon === 'function') {\n target = _objectSpread({}, target, {\n icon: target.icon(colors.primaryColor, colors.secondaryColor)\n });\n }\n\n return generate(target.icon, \"svg-\".concat(target.name), _objectSpread({}, restProps, {\n 'data-icon': target.name,\n width: '1em',\n height: '1em',\n fill: 'currentColor',\n 'aria-hidden': 'true'\n })); // },\n};\n\nIconBase.props = {\n icon: Object,\n primaryColor: String,\n secondaryColor: String,\n focusable: String\n};\nIconBase.inheritAttrs = false;\nIconBase.displayName = 'IconBase';\nIconBase.getTwoToneColors = getTwoToneColors;\nIconBase.setTwoToneColors = setTwoToneColors;\nexport default IconBase;","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\nimport VueIcon from './IconBase';\nimport { normalizeTwoToneColors } from '../utils';\nexport function setTwoToneColor(twoToneColor) {\n var _normalizeTwoToneColo = normalizeTwoToneColors(twoToneColor),\n _normalizeTwoToneColo2 = _slicedToArray(_normalizeTwoToneColo, 2),\n primaryColor = _normalizeTwoToneColo2[0],\n secondaryColor = _normalizeTwoToneColo2[1];\n\n return VueIcon.setTwoToneColors({\n primaryColor: primaryColor,\n secondaryColor: secondaryColor\n });\n}\nexport function getTwoToneColor() {\n var colors = VueIcon.getTwoToneColors();\n\n if (!colors.calculated) {\n return colors.primaryColor;\n }\n\n return [colors.primaryColor, colors.secondaryColor];\n}","var _excluded = [\"class\", \"icon\", \"spin\", \"rotate\", \"tabindex\", \"twoToneColor\", \"onClick\"];\nimport { createVNode as _createVNode } from \"vue\";\n\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? Object(arguments[i]) : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport VueIcon from './IconBase';\nimport { getTwoToneColor, setTwoToneColor } from './twoTonePrimaryColor';\nimport { normalizeTwoToneColors } from '../utils'; // Initial setting\n\nsetTwoToneColor('#1890ff');\n\nvar Icon = function Icon(props, context) {\n var _classObj;\n\n var _props$context$attrs = _objectSpread({}, props, context.attrs),\n cls = _props$context$attrs[\"class\"],\n icon = _props$context$attrs.icon,\n spin = _props$context$attrs.spin,\n rotate = _props$context$attrs.rotate,\n tabindex = _props$context$attrs.tabindex,\n twoToneColor = _props$context$attrs.twoToneColor,\n onClick = _props$context$attrs.onClick,\n restProps = _objectWithoutProperties(_props$context$attrs, _excluded);\n\n var classObj = (_classObj = {\n anticon: true\n }, _defineProperty(_classObj, \"anticon-\".concat(icon.name), Boolean(icon.name)), _defineProperty(_classObj, cls, cls), _classObj);\n var svgClassString = spin === '' || !!spin || icon.name === 'loading' ? 'anticon-spin' : '';\n var iconTabIndex = tabindex;\n\n if (iconTabIndex === undefined && onClick) {\n iconTabIndex = -1;\n restProps.tabindex = iconTabIndex;\n }\n\n var svgStyle = rotate ? {\n msTransform: \"rotate(\".concat(rotate, \"deg)\"),\n transform: \"rotate(\".concat(rotate, \"deg)\")\n } : undefined;\n\n var _normalizeTwoToneColo = normalizeTwoToneColors(twoToneColor),\n _normalizeTwoToneColo2 = _slicedToArray(_normalizeTwoToneColo, 2),\n primaryColor = _normalizeTwoToneColo2[0],\n secondaryColor = _normalizeTwoToneColo2[1];\n\n return _createVNode(\"span\", _objectSpread({\n \"role\": \"img\",\n \"aria-label\": icon.name\n }, restProps, {\n \"onClick\": onClick,\n \"class\": classObj\n }), [_createVNode(VueIcon, {\n \"class\": svgClassString,\n \"icon\": icon,\n \"primaryColor\": primaryColor,\n \"secondaryColor\": secondaryColor,\n \"style\": svgStyle\n }, null)]);\n};\n\nIcon.props = {\n spin: Boolean,\n rotate: Number,\n icon: Object,\n twoToneColor: String\n};\nIcon.displayName = 'AntdIcon';\nIcon.inheritAttrs = false;\nIcon.getTwoToneColor = getTwoToneColor;\nIcon.setTwoToneColor = setTwoToneColor;\nexport default Icon;","// This icon file is generated automatically.\nvar LoadingOutlined = { \"icon\": { \"tag\": \"svg\", \"attrs\": { \"viewBox\": \"0 0 1024 1024\", \"focusable\": \"false\" }, \"children\": [{ \"tag\": \"path\", \"attrs\": { \"d\": \"M988 548c-19.9 0-36-16.1-36-36 0-59.4-11.6-117-34.6-171.3a440.45 440.45 0 00-94.3-139.9 437.71 437.71 0 00-139.9-94.3C629 83.6 571.4 72 512 72c-19.9 0-36-16.1-36-36s16.1-36 36-36c69.1 0 136.2 13.5 199.3 40.3C772.3 66 827 103 874 150c47 47 83.9 101.8 109.7 162.7 26.7 63.1 40.2 130.2 40.2 199.3.1 19.9-16 36-35.9 36z\" } }] }, \"name\": \"loading\", \"theme\": \"outlined\" };\nexport default LoadingOutlined;\n","import { createVNode as _createVNode } from \"vue\";\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? Object(arguments[i]) : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n// GENERATE BY ./scripts/generate.ts\n// DON NOT EDIT IT MANUALLY\nimport LoadingOutlinedSvg from \"@ant-design/icons-svg/es/asn/LoadingOutlined\";\nimport AntdIcon from '../components/AntdIcon';\n\nvar LoadingOutlined = function LoadingOutlined(props, context) {\n var p = _objectSpread({}, props, context.attrs);\n\n return _createVNode(AntdIcon, _objectSpread({}, p, {\n \"icon\": LoadingOutlinedSvg\n }), null);\n};\n\nLoadingOutlined.displayName = 'LoadingOutlined';\nLoadingOutlined.inheritAttrs = false;\nexport default LoadingOutlined;","<template>\n <div class=\"spin-wrapper\">\n <a-spin\n class=\"spin\"\n :spinning=\"spinning\"\n v-if=\"spinning\"\n :indicator=\"indicator\"\n tip=\"加载中...\"\n >\n </a-spin>\n <slot v-else></slot>\n </div>\n</template>\n<script lang=\"ts\">\nimport { Spin as ASpin } from 'ant-design-vue'\nimport { LoadingOutlined } from '@ant-design/icons-vue'\nimport { defineComponent, h } from 'vue'\nimport 'ant-design-vue/es/spin/style'\nexport default defineComponent({\n props: {\n spinning: {\n type: Boolean,\n default: false\n }\n },\n components: {\n ASpin\n },\n setup () {\n const indicator = h(LoadingOutlined, {\n style: {\n fontSize: '24px',\n color: '#1890ff'\n },\n spin: true\n })\n return {\n indicator\n }\n }\n})\n</script>\n\n<style>\n.spin-wrapper {\n position: relative;\n width: 100%;\n height: 100%;\n}\n.spin {\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n}\n</style>\n","<template>\n <a-skeleton active :loading=\"loading\">\n <slot></slot>\n </a-skeleton>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent } from 'vue'\nimport { Skeleton as ASkeleton } from 'ant-design-vue'\nimport 'ant-design-vue/es/skeleton/style'\nexport default defineComponent({\n name: 'Skeleton',\n props: {\n loading: {\n type: Boolean,\n default: false\n }\n },\n components: {\n ASkeleton\n }\n})\n</script>\n\n<style scoped>\n\n</style>\n","/**\r\n * Make a map and return a function for checking if a key\r\n * is in that map.\r\n * IMPORTANT: all calls of this function must be prefixed with\r\n * \\/\\*#\\_\\_PURE\\_\\_\\*\\/\r\n * So that rollup can tree-shake them if necessary.\r\n */\r\nfunction makeMap(str, expectsLowerCase) {\r\n const map = Object.create(null);\r\n const list = str.split(',');\r\n for (let i = 0; i < list.length; i++) {\r\n map[list[i]] = true;\r\n }\r\n return expectsLowerCase ? val => !!map[val.toLowerCase()] : val => !!map[val];\r\n}\n\n/**\r\n * dev only flag -> name mapping\r\n */\r\nconst PatchFlagNames = {\r\n [1 /* TEXT */]: `TEXT`,\r\n [2 /* CLASS */]: `CLASS`,\r\n [4 /* STYLE */]: `STYLE`,\r\n [8 /* PROPS */]: `PROPS`,\r\n [16 /* FULL_PROPS */]: `FULL_PROPS`,\r\n [32 /* HYDRATE_EVENTS */]: `HYDRATE_EVENTS`,\r\n [64 /* STABLE_FRAGMENT */]: `STABLE_FRAGMENT`,\r\n [128 /* KEYED_FRAGMENT */]: `KEYED_FRAGMENT`,\r\n [256 /* UNKEYED_FRAGMENT */]: `UNKEYED_FRAGMENT`,\r\n [512 /* NEED_PATCH */]: `NEED_PATCH`,\r\n [1024 /* DYNAMIC_SLOTS */]: `DYNAMIC_SLOTS`,\r\n [2048 /* DEV_ROOT_FRAGMENT */]: `DEV_ROOT_FRAGMENT`,\r\n [-1 /* HOISTED */]: `HOISTED`,\r\n [-2 /* BAIL */]: `BAIL`\r\n};\n\n/**\r\n * Dev only\r\n */\r\nconst slotFlagsText = {\r\n [1 /* STABLE */]: 'STABLE',\r\n [2 /* DYNAMIC */]: 'DYNAMIC',\r\n [3 /* FORWARDED */]: 'FORWARDED'\r\n};\n\nconst GLOBALS_WHITE_LISTED = 'Infinity,undefined,NaN,isFinite,isNaN,parseFloat,parseInt,decodeURI,' +\r\n 'decodeURIComponent,encodeURI,encodeURIComponent,Math,Number,Date,Array,' +\r\n 'Object,Boolean,String,RegExp,Map,Set,JSON,Intl,BigInt';\r\nconst isGloballyWhitelisted = /*#__PURE__*/ makeMap(GLOBALS_WHITE_LISTED);\n\nconst range = 2;\r\nfunction generateCodeFrame(source, start = 0, end = source.length) {\r\n // Split the content into individual lines but capture the newline sequence\r\n // that separated each line. This is important because the actual sequence is\r\n // needed to properly take into account the full line length for offset\r\n // comparison\r\n let lines = source.split(/(\\r?\\n)/);\r\n // Separate the lines and newline sequences into separate arrays for easier referencing\r\n const newlineSequences = lines.filter((_, idx) => idx % 2 === 1);\r\n lines = lines.filter((_, idx) => idx % 2 === 0);\r\n let count = 0;\r\n const res = [];\r\n for (let i = 0; i < lines.length; i++) {\r\n count +=\r\n lines[i].length +\r\n ((newlineSequences[i] && newlineSequences[i].length) || 0);\r\n if (count >= start) {\r\n for (let j = i - range; j <= i + range || end > count; j++) {\r\n if (j < 0 || j >= lines.length)\r\n continue;\r\n const line = j + 1;\r\n res.push(`${line}${' '.repeat(Math.max(3 - String(line).length, 0))}| ${lines[j]}`);\r\n const lineLength = lines[j].length;\r\n const newLineSeqLength = (newlineSequences[j] && newlineSequences[j].length) || 0;\r\n if (j === i) {\r\n // push underline\r\n const pad = start - (count - (lineLength + newLineSeqLength));\r\n const length = Math.max(1, end > count ? lineLength - pad : end - start);\r\n res.push(` | ` + ' '.repeat(pad) + '^'.repeat(length));\r\n }\r\n else if (j > i) {\r\n if (end > count) {\r\n const length = Math.max(Math.min(end - count, lineLength), 1);\r\n res.push(` | ` + '^'.repeat(length));\r\n }\r\n count += lineLength + newLineSeqLength;\r\n }\r\n }\r\n break;\r\n }\r\n }\r\n return res.join('\\n');\r\n}\n\n/**\r\n * On the client we only need to offer special cases for boolean attributes that\r\n * have different names from their corresponding dom properties:\r\n * - itemscope -> N/A\r\n * - allowfullscreen -> allowFullscreen\r\n * - formnovalidate -> formNoValidate\r\n * - ismap -> isMap\r\n * - nomodule -> noModule\r\n * - novalidate -> noValidate\r\n * - readonly -> readOnly\r\n */\r\nconst specialBooleanAttrs = `itemscope,allowfullscreen,formnovalidate,ismap,nomodule,novalidate,readonly`;\r\nconst isSpecialBooleanAttr = /*#__PURE__*/ makeMap(specialBooleanAttrs);\r\n/**\r\n * The full list is needed during SSR to produce the correct initial markup.\r\n */\r\nconst isBooleanAttr = /*#__PURE__*/ makeMap(specialBooleanAttrs +\r\n `,async,autofocus,autoplay,controls,default,defer,disabled,hidden,` +\r\n `loop,open,required,reversed,scoped,seamless,` +\r\n `checked,muted,multiple,selected`);\r\n/**\r\n * Boolean attributes should be included if the value is truthy or ''.\r\n * e.g. `<select multiple>` compiles to `{ multiple: '' }`\r\n */\r\nfunction includeBooleanAttr(value) {\r\n return !!value || value === '';\r\n}\r\nconst unsafeAttrCharRE = /[>/=\"'\\u0009\\u000a\\u000c\\u0020]/;\r\nconst attrValidationCache = {};\r\nfunction isSSRSafeAttrName(name) {\r\n if (attrValidationCache.hasOwnProperty(name)) {\r\n return attrValidationCache[name];\r\n }\r\n const isUnsafe = unsafeAttrCharRE.test(name);\r\n if (isUnsafe) {\r\n console.error(`unsafe attribute name: ${name}`);\r\n }\r\n return (attrValidationCache[name] = !isUnsafe);\r\n}\r\nconst propsToAttrMap = {\r\n acceptCharset: 'accept-charset',\r\n className: 'class',\r\n htmlFor: 'for',\r\n httpEquiv: 'http-equiv'\r\n};\r\n/**\r\n * CSS properties that accept plain numbers\r\n */\r\nconst isNoUnitNumericStyleProp = /*#__PURE__*/ makeMap(`animation-iteration-count,border-image-outset,border-image-slice,` +\r\n `border-image-width,box-flex,box-flex-group,box-ordinal-group,column-count,` +\r\n `columns,flex,flex-grow,flex-positive,flex-shrink,flex-negative,flex-order,` +\r\n `grid-row,grid-row-end,grid-row-span,grid-row-start,grid-column,` +\r\n `grid-column-end,grid-column-span,grid-column-start,font-weight,line-clamp,` +\r\n `line-height,opacity,order,orphans,tab-size,widows,z-index,zoom,` +\r\n // SVG\r\n `fill-opacity,flood-opacity,stop-opacity,stroke-dasharray,stroke-dashoffset,` +\r\n `stroke-miterlimit,stroke-opacity,stroke-width`);\r\n/**\r\n * Known attributes, this is used for stringification of runtime static nodes\r\n * so that we don't stringify bindings that cannot be set from HTML.\r\n * Don't also forget to allow `data-*` and `aria-*`!\r\n * Generated from https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes\r\n */\r\nconst isKnownHtmlAttr = /*#__PURE__*/ makeMap(`accept,accept-charset,accesskey,action,align,allow,alt,async,` +\r\n `autocapitalize,autocomplete,autofocus,autoplay,background,bgcolor,` +\r\n `border,buffered,capture,challenge,charset,checked,cite,class,code,` +\r\n `codebase,color,cols,colspan,content,contenteditable,contextmenu,controls,` +\r\n `coords,crossorigin,csp,data,datetime,decoding,default,defer,dir,dirname,` +\r\n `disabled,download,draggable,dropzone,enctype,enterkeyhint,for,form,` +\r\n `formaction,formenctype,formmethod,formnovalidate,formtarget,headers,` +\r\n `height,hidden,high,href,hreflang,http-equiv,icon,id,importance,integrity,` +\r\n `ismap,itemprop,keytype,kind,label,lang,language,loading,list,loop,low,` +\r\n `manifest,max,maxlength,minlength,media,min,multiple,muted,name,novalidate,` +\r\n `open,optimum,pattern,ping,placeholder,poster,preload,radiogroup,readonly,` +\r\n `referrerpolicy,rel,required,reversed,rows,rowspan,sandbox,scope,scoped,` +\r\n `selected,shape,size,sizes,slot,span,spellcheck,src,srcdoc,srclang,srcset,` +\r\n `start,step,style,summary,tabindex,target,title,translate,type,usemap,` +\r\n `value,width,wrap`);\r\n/**\r\n * Generated from https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute\r\n */\r\nconst isKnownSvgAttr = /*#__PURE__*/ makeMap(`xmlns,accent-height,accumulate,additive,alignment-baseline,alphabetic,amplitude,` +\r\n `arabic-form,ascent,attributeName,attributeType,azimuth,baseFrequency,` +\r\n `baseline-shift,baseProfile,bbox,begin,bias,by,calcMode,cap-height,class,` +\r\n `clip,clipPathUnits,clip-path,clip-rule,color,color-interpolation,` +\r\n `color-interpolation-filters,color-profile,color-rendering,` +\r\n `contentScriptType,contentStyleType,crossorigin,cursor,cx,cy,d,decelerate,` +\r\n `descent,diffuseConstant,direction,display,divisor,dominant-baseline,dur,dx,` +\r\n `dy,edgeMode,elevation,enable-background,end,exponent,fill,fill-opacity,` +\r\n `fill-rule,filter,filterRes,filterUnits,flood-color,flood-opacity,` +\r\n `font-family,font-size,font-size-adjust,font-stretch,font-style,` +\r\n `font-variant,font-weight,format,from,fr,fx,fy,g1,g2,glyph-name,` +\r\n `glyph-orientation-horizontal,glyph-orientation-vertical,glyphRef,` +\r\n `gradientTransform,gradientUnits,hanging,height,href,hreflang,horiz-adv-x,` +\r\n `horiz-origin-x,id,ideographic,image-rendering,in,in2,intercept,k,k1,k2,k3,` +\r\n `k4,kernelMatrix,kernelUnitLength,kerning,keyPoints,keySplines,keyTimes,` +\r\n `lang,lengthAdjust,letter-spacing,lighting-color,limitingConeAngle,local,` +\r\n `marker-end,marker-mid,marker-start,markerHeight,markerUnits,markerWidth,` +\r\n `mask,maskContentUnits,maskUnits,mathematical,max,media,method,min,mode,` +\r\n `name,numOctaves,offset,opacity,operator,order,orient,orientation,origin,` +\r\n `overflow,overline-position,overline-thickness,panose-1,paint-order,path,` +\r\n `pathLength,patternContentUnits,patternTransform,patternUnits,ping,` +\r\n `pointer-events,points,pointsAtX,pointsAtY,pointsAtZ,preserveAlpha,` +\r\n `preserveAspectRatio,primitiveUnits,r,radius,referrerPolicy,refX,refY,rel,` +\r\n `rendering-intent,repeatCount,repeatDur,requiredExtensions,requiredFeatures,` +\r\n `restart,result,rotate,rx,ry,scale,seed,shape-rendering,slope,spacing,` +\r\n `specularConstant,specularExponent,speed,spreadMethod,startOffset,` +\r\n `stdDeviation,stemh,stemv,stitchTiles,stop-color,stop-opacity,` +\r\n `strikethrough-position,strikethrough-thickness,string,stroke,` +\r\n `stroke-dasharray,stroke-dashoffset,stroke-linecap,stroke-linejoin,` +\r\n `stroke-miterlimit,stroke-opacity,stroke-width,style,surfaceScale,` +\r\n `systemLanguage,tabindex,tableValues,target,targetX,targetY,text-anchor,` +\r\n `text-decoration,text-rendering,textLength,to,transform,transform-origin,` +\r\n `type,u1,u2,underline-position,underline-thickness,unicode,unicode-bidi,` +\r\n `unicode-range,units-per-em,v-alphabetic,v-hanging,v-ideographic,` +\r\n `v-mathematical,values,vector-effect,version,vert-adv-y,vert-origin-x,` +\r\n `vert-origin-y,viewBox,viewTarget,visibility,width,widths,word-spacing,` +\r\n `writing-mode,x,x-height,x1,x2,xChannelSelector,xlink:actuate,xlink:arcrole,` +\r\n `xlink:href,xlink:role,xlink:show,xlink:title,xlink:type,xml:base,xml:lang,` +\r\n `xml:space,y,y1,y2,yChannelSelector,z,zoomAndPan`);\n\nfunction normalizeStyle(value) {\r\n if (isArray(value)) {\r\n const res = {};\r\n for (let i = 0; i < value.length; i++) {\r\n const item = value[i];\r\n const normalized = isString(item)\r\n ? parseStringStyle(item)\r\n : normalizeStyle(item);\r\n if (normalized) {\r\n for (const key in normalized) {\r\n res[key] = normalized[key];\r\n }\r\n }\r\n }\r\n return res;\r\n }\r\n else if (isString(value)) {\r\n return value;\r\n }\r\n else if (isObject(value)) {\r\n return value;\r\n }\r\n}\r\nconst listDelimiterRE = /;(?![^(]*\\))/g;\r\nconst propertyDelimiterRE = /:(.+)/;\r\nfunction parseStringStyle(cssText) {\r\n const ret = {};\r\n cssText.split(listDelimiterRE).forEach(item => {\r\n if (item) {\r\n const tmp = item.split(propertyDelimiterRE);\r\n tmp.length > 1 && (ret[tmp[0].trim()] = tmp[1].trim());\r\n }\r\n });\r\n return ret;\r\n}\r\nfunction stringifyStyle(styles) {\r\n let ret = '';\r\n if (!styles || isString(styles)) {\r\n return ret;\r\n }\r\n for (const key in styles) {\r\n const value = styles[key];\r\n const normalizedKey = key.startsWith(`--`) ? key : hyphenate(key);\r\n if (isString(value) ||\r\n (typeof value === 'number' && isNoUnitNumericStyleProp(normalizedKey))) {\r\n // only render valid values\r\n ret += `${normalizedKey}:${value};`;\r\n }\r\n }\r\n return ret;\r\n}\r\nfunction normalizeClass(value) {\r\n let res = '';\r\n if (isString(value)) {\r\n res = value;\r\n }\r\n else if (isArray(value)) {\r\n for (let i = 0; i < value.length; i++) {\r\n const normalized = normalizeClass(value[i]);\r\n if (normalized) {\r\n res += normalized + ' ';\r\n }\r\n }\r\n }\r\n else if (isObject(value)) {\r\n for (const name in value) {\r\n if (value[name]) {\r\n res += name + ' ';\r\n }\r\n }\r\n }\r\n return res.trim();\r\n}\r\nfunction normalizeProps(props) {\r\n if (!props)\r\n return null;\r\n let { class: klass, style } = props;\r\n if (klass && !isString(klass)) {\r\n props.class = normalizeClass(klass);\r\n }\r\n if (style) {\r\n props.style = normalizeStyle(style);\r\n }\r\n return props;\r\n}\n\n// These tag configs are shared between compiler-dom and runtime-dom, so they\r\n// https://developer.mozilla.org/en-US/docs/Web/HTML/Element\r\nconst HTML_TAGS = 'html,body,base,head,link,meta,style,title,address,article,aside,footer,' +\r\n 'header,h1,h2,h3,h4,h5,h6,nav,section,div,dd,dl,dt,figcaption,' +\r\n 'figure,picture,hr,img,li,main,ol,p,pre,ul,a,b,abbr,bdi,bdo,br,cite,code,' +\r\n 'data,dfn,em,i,kbd,mark,q,rp,rt,ruby,s,samp,small,span,strong,sub,sup,' +\r\n 'time,u,var,wbr,area,audio,map,track,video,embed,object,param,source,' +\r\n 'canvas,script,noscript,del,ins,caption,col,colgroup,table,thead,tbody,td,' +\r\n 'th,tr,button,datalist,fieldset,form,input,label,legend,meter,optgroup,' +\r\n 'option,output,progress,select,textarea,details,dialog,menu,' +\r\n 'summary,template,blockquote,iframe,tfoot';\r\n// https://developer.mozilla.org/en-US/docs/Web/SVG/Element\r\nconst SVG_TAGS = 'svg,animate,animateMotion,animateTransform,circle,clipPath,color-profile,' +\r\n 'defs,desc,discard,ellipse,feBlend,feColorMatrix,feComponentTransfer,' +\r\n 'feComposite,feConvolveMatrix,feDiffuseLighting,feDisplacementMap,' +\r\n 'feDistanceLight,feDropShadow,feFlood,feFuncA,feFuncB,feFuncG,feFuncR,' +\r\n 'feGaussianBlur,feImage,feMerge,feMergeNode,feMorphology,feOffset,' +\r\n 'fePointLight,feSpecularLighting,feSpotLight,feTile,feTurbulence,filter,' +\r\n 'foreignObject,g,hatch,hatchpath,image,line,linearGradient,marker,mask,' +\r\n 'mesh,meshgradient,meshpatch,meshrow,metadata,mpath,path,pattern,' +\r\n 'polygon,polyline,radialGradient,rect,set,solidcolor,stop,switch,symbol,' +\r\n 'text,textPath,title,tspan,unknown,use,view';\r\nconst VOID_TAGS = 'area,base,br,col,embed,hr,img,input,link,meta,param,source,track,wbr';\r\nconst isHTMLTag = /*#__PURE__*/ makeMap(HTML_TAGS);\r\nconst isSVGTag = /*#__PURE__*/ makeMap(SVG_TAGS);\r\nconst isVoidTag = /*#__PURE__*/ makeMap(VOID_TAGS);\n\nconst escapeRE = /[\"'&<>]/;\r\nfunction escapeHtml(string) {\r\n const str = '' + string;\r\n const match = escapeRE.exec(str);\r\n if (!match) {\r\n return str;\r\n }\r\n let html = '';\r\n let escaped;\r\n let index;\r\n let lastIndex = 0;\r\n for (index = match.index; index < str.length; index++) {\r\n switch (str.charCodeAt(index)) {\r\n case 34: // \"\r\n escaped = '"';\r\n break;\r\n case 38: // &\r\n escaped = '&';\r\n break;\r\n case 39: // '\r\n escaped = ''';\r\n break;\r\n case 60: // <\r\n escaped = '<';\r\n break;\r\n case 62: // >\r\n escaped = '>';\r\n break;\r\n default:\r\n continue;\r\n }\r\n if (lastIndex !== index) {\r\n html += str.slice(lastIndex, index);\r\n }\r\n lastIndex = index + 1;\r\n html += escaped;\r\n }\r\n return lastIndex !== index ? html + str.slice(lastIndex, index) : html;\r\n}\r\n// https://www.w3.org/TR/html52/syntax.html#comments\r\nconst commentStripRE = /^-?>|<!--|-->|--!>|<!-$/g;\r\nfunction escapeHtmlComment(src) {\r\n return src.replace(commentStripRE, '');\r\n}\n\nfunction looseCompareArrays(a, b) {\r\n if (a.length !== b.length)\r\n return false;\r\n let equal = true;\r\n for (let i = 0; equal && i < a.length; i++) {\r\n equal = looseEqual(a[i], b[i]);\r\n }\r\n return equal;\r\n}\r\nfunction looseEqual(a, b) {\r\n if (a === b)\r\n return true;\r\n let aValidType = isDate(a);\r\n let bValidType = isDate(b);\r\n if (aValidType || bValidType) {\r\n return aValidType && bValidType ? a.getTime() === b.getTime() : false;\r\n }\r\n aValidType = isArray(a);\r\n bValidType = isArray(b);\r\n if (aValidType || bValidType) {\r\n return aValidType && bValidType ? looseCompareArrays(a, b) : false;\r\n }\r\n aValidType = isObject(a);\r\n bValidType = isObject(b);\r\n if (aValidType || bValidType) {\r\n /* istanbul ignore if: this if will probably never be called */\r\n if (!aValidType || !bValidType) {\r\n return false;\r\n }\r\n const aKeysCount = Object.keys(a).length;\r\n const bKeysCount = Object.keys(b).length;\r\n if (aKeysCount !== bKeysCount) {\r\n return false;\r\n }\r\n for (const key in a) {\r\n const aHasKey = a.hasOwnProperty(key);\r\n const bHasKey = b.hasOwnProperty(key);\r\n if ((aHasKey && !bHasKey) ||\r\n (!aHasKey && bHasKey) ||\r\n !looseEqual(a[key], b[key])) {\r\n return false;\r\n }\r\n }\r\n }\r\n return String(a) === String(b);\r\n}\r\nfunction looseIndexOf(arr, val) {\r\n return arr.findIndex(item => looseEqual(item, val));\r\n}\n\n/**\r\n * For converting {{ interpolation }} values to displayed strings.\r\n * @private\r\n */\r\nconst toDisplayString = (val) => {\r\n return val == null\r\n ? ''\r\n : isArray(val) ||\r\n (isObject(val) &&\r\n (val.toString === objectToString || !isFunction(val.toString)))\r\n ? JSON.stringify(val, replacer, 2)\r\n : String(val);\r\n};\r\nconst replacer = (_key, val) => {\r\n // can't use isRef here since @vue/shared has no deps\r\n if (val && val.__v_isRef) {\r\n return replacer(_key, val.value);\r\n }\r\n else if (isMap(val)) {\r\n return {\r\n [`Map(${val.size})`]: [...val.entries()].reduce((entries, [key, val]) => {\r\n entries[`${key} =>`] = val;\r\n return entries;\r\n }, {})\r\n };\r\n }\r\n else if (isSet(val)) {\r\n return {\r\n [`Set(${val.size})`]: [...val.values()]\r\n };\r\n }\r\n else if (isObject(val) && !isArray(val) && !isPlainObject(val)) {\r\n return String(val);\r\n }\r\n return val;\r\n};\n\nconst EMPTY_OBJ = (process.env.NODE_ENV !== 'production')\r\n ? Object.freeze({})\r\n : {};\r\nconst EMPTY_ARR = (process.env.NODE_ENV !== 'production') ? Object.freeze([]) : [];\r\nconst NOOP = () => { };\r\n/**\r\n * Always return false.\r\n */\r\nconst NO = () => false;\r\nconst onRE = /^on[^a-z]/;\r\nconst isOn = (key) => onRE.test(key);\r\nconst isModelListener = (key) => key.startsWith('onUpdate:');\r\nconst extend = Object.assign;\r\nconst remove = (arr, el) => {\r\n const i = arr.indexOf(el);\r\n if (i > -1) {\r\n arr.splice(i, 1);\r\n }\r\n};\r\nconst hasOwnProperty = Object.prototype.hasOwnProperty;\r\nconst hasOwn = (val, key) => hasOwnProperty.call(val, key);\r\nconst isArray = Array.isArray;\r\nconst isMap = (val) => toTypeString(val) === '[object Map]';\r\nconst isSet = (val) => toTypeString(val) === '[object Set]';\r\nconst isDate = (val) => val instanceof Date;\r\nconst isFunction = (val) => typeof val === 'function';\r\nconst isString = (val) => typeof val === 'string';\r\nconst isSymbol = (val) => typeof val === 'symbol';\r\nconst isObject = (val) => val !== null && typeof val === 'object';\r\nconst isPromise = (val) => {\r\n return isObject(val) && isFunction(val.then) && isFunction(val.catch);\r\n};\r\nconst objectToString = Object.prototype.toString;\r\nconst toTypeString = (value) => objectToString.call(value);\r\nconst toRawType = (value) => {\r\n // extract \"RawType\" from strings like \"[object RawType]\"\r\n return toTypeString(value).slice(8, -1);\r\n};\r\nconst isPlainObject = (val) => toTypeString(val) === '[object Object]';\r\nconst isIntegerKey = (key) => isString(key) &&\r\n key !== 'NaN' &&\r\n key[0] !== '-' &&\r\n '' + parseInt(key, 10) === key;\r\nconst isReservedProp = /*#__PURE__*/ makeMap(\r\n// the leading comma is intentional so empty string \"\" is also included\r\n',key,ref,ref_for,ref_key,' +\r\n 'onVnodeBeforeMount,onVnodeMounted,' +\r\n 'onVnodeBeforeUpdate,onVnodeUpdated,' +\r\n 'onVnodeBeforeUnmount,onVnodeUnmounted');\r\nconst cacheStringFunction = (fn) => {\r\n const cache = Object.create(null);\r\n return ((str) => {\r\n const hit = cache[str];\r\n return hit || (cache[str] = fn(str));\r\n });\r\n};\r\nconst camelizeRE = /-(\\w)/g;\r\n/**\r\n * @private\r\n */\r\nconst camelize = cacheStringFunction((str) => {\r\n return str.replace(camelizeRE, (_, c) => (c ? c.toUpperCase() : ''));\r\n});\r\nconst hyphenateRE = /\\B([A-Z])/g;\r\n/**\r\n * @private\r\n */\r\nconst hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, '-$1').toLowerCase());\r\n/**\r\n * @private\r\n */\r\nconst capitalize = cacheStringFunction((str) => str.charAt(0).toUpperCase() + str.slice(1));\r\n/**\r\n * @private\r\n */\r\nconst toHandlerKey = cacheStringFunction((str) => str ? `on${capitalize(str)}` : ``);\r\n// compare whether a value has changed, accounting for NaN.\r\nconst hasChanged = (value, oldValue) => !Object.is(value, oldValue);\r\nconst invokeArrayFns = (fns, arg) => {\r\n for (let i = 0; i < fns.length; i++) {\r\n fns[i](arg);\r\n }\r\n};\r\nconst def = (obj, key, value) => {\r\n Object.defineProperty(obj, key, {\r\n configurable: true,\r\n enumerable: false,\r\n value\r\n });\r\n};\r\nconst toNumber = (val) => {\r\n const n = parseFloat(val);\r\n return isNaN(n) ? val : n;\r\n};\r\nlet _globalThis;\r\nconst getGlobalThis = () => {\r\n return (_globalThis ||\r\n (_globalThis =\r\n typeof globalThis !== 'undefined'\r\n ? globalThis\r\n : typeof self !== 'undefined'\r\n ? self\r\n : typeof window !== 'undefined'\r\n ? window\r\n : typeof global !== 'undefined'\r\n ? global\r\n : {}));\r\n};\n\nexport { EMPTY_ARR, EMPTY_OBJ, NO, NOOP, PatchFlagNames, camelize, capitalize, def, escapeHtml, escapeHtmlComment, extend, generateCodeFrame, getGlobalThis, hasChanged, hasOwn, hyphenate, includeBooleanAttr, invokeArrayFns, isArray, isBooleanAttr, isDate, isFunction, isGloballyWhitelisted, isHTMLTag, isIntegerKey, isKnownHtmlAttr, isKnownSvgAttr, isMap, isModelListener, isNoUnitNumericStyleProp, isObject, isOn, isPlainObject, isPromise, isReservedProp, isSSRSafeAttrName, isSVGTag, isSet, isSpecialBooleanAttr, isString, isSymbol, isVoidTag, looseEqual, looseIndexOf, makeMap, normalizeClass, normalizeProps, normalizeStyle, objectToString, parseStringStyle, propsToAttrMap, remove, slotFlagsText, stringifyStyle, toDisplayString, toHandlerKey, toNumber, toRawType, toTypeString };\n","import { NOOP } from '@vue/shared'\nimport { Plugin } from 'vue'\n\nexport type SFCWithInstall<T> = T & Plugin\n\nexport const withInstall = <T, E extends Record<string, any>>(\n main: T,\n extra?: E\n) => {\n (main as SFCWithInstall<T>).install = (app): void => {\n for (const comp of [main, ...Object.values(extra ?? {})]) {\n app.component(comp.name, comp)\n }\n }\n\n if (extra) {\n for (const [key, comp] of Object.entries(extra)) {\n (main as any)[key] = comp\n }\n }\n return main as SFCWithInstall<T> & E\n}\n\nexport const withInstallFunction = <T>(fn: T, name: string) => {\n (fn as SFCWithInstall<T>).install = (app) => {\n app.config.globalProperties[name] = fn\n }\n\n return fn as SFCWithInstall<T>\n}\n\nexport const withNoopInstall = <T>(component: T) => {\n (component as SFCWithInstall<T>).install = NOOP\n\n return component as SFCWithInstall<T>\n}\n","import { mapValues } from 'lodash-es'\n\ninterface Event {\n // 当前组件触发什么事件类型后执行\n on: string\n // 被触发的组件id\n target: string\n // 被触发的组件:想要触发事件的类型\n emit: string\n}\n\nexport type Events = Event []\n\nexport type RequestMethod = 'get' | 'post' | 'put' | 'delete' | 'head'\n\nexport interface RequestParam {\n key: string,\n value: any\n}\n\nexport type RequestParams = RequestParam []\n\nexport interface Props {\n id: string // 组件Id,使用UUID\n name: string // 组件名称\n keyName: string // 控件\n type: string // 组件类型\n width: string // 组件宽度\n height: string // 组件高度\n position: string // 定位\n top: string // 组件左上定点x轴位置(相对于画布)\n left: string // 组件左上定点y轴位置(相对于画布)\n zIndex: number // 组件层级\n rotate: string // 旋转角度\n isShow: boolean // 是否展示\n isRender: boolean // 是否渲染\n events: Events\n requestUrl: string // 请求地址\n requestMethod: RequestMethod // 请求方式\n requestHeaders: { [key: string]: any } // 请求头部\n isOpenRequestTimer: boolean // 开启请求定时器\n requestInterval: number // 请求间隔\n requestParams: RequestParams // 请求参数\n requestSort: number, // 请求初始化优先级,越大越优先\n dataType: 'static' | 'request' | 'indicator'\n}\n\nexport const props: Props = {\n id: '',\n name: '',\n keyName: '',\n type: '',\n width: '100px',\n height: '40px',\n position: 'absolute',\n top: '0px',\n left: '0px',\n zIndex: 1,\n rotate: '0deg',\n isShow: true,\n isRender: true,\n requestUrl: '',\n requestMethod: 'get',\n requestHeaders: {},\n isOpenRequestTimer: false,\n requestInterval: 1,\n requestSort: 0,\n requestParams: [{ key: null, value: { } }],\n events: [],\n dataType: 'static'\n}\n\nexport const transformToComponentProps = <T extends {}>(props: T) => {\n // mapValues方法: 第一参数是要遍历的对象, 第二个参数是每次迭代时调用的函数\n return mapValues(props, (value) => {\n if (value == null) return {}\n return {\n type: (value as any).constructor,\n default: value\n }\n })\n}\n\nexport interface EventsProp {\n events: Events\n}\n\ninterface DataItem {\n name: string | number\n value: string | number\n type?: string\n}\n\nexport type Data = DataItem []\n\n// 数据转化映射格式\n\nexport interface KeyTypeDataFieldNames {\n name: string\n types: {\n label: string\n value: string\n } []\n}\n\nexport interface ValueTypeDataFieldNames {\n name: string\n value: string\n type: string\n}\n","import { transformToComponentProps } from '@/utils/props'\n\nexport interface PageConfig{\n width: string\n height: string\n backgroundColor: string\n backgroundImage: string\n backgroundSize: string\n contextRequestUrl: string\n mode: 'normal' | 'preview'\n}\n\n// 页面组件默认配置\nexport const pageConfig:PageConfig = {\n width: '1920px',\n height: '1080px',\n backgroundColor: '#ffffff',\n backgroundImage: '',\n backgroundSize: '100% 100%',\n contextRequestUrl: '',\n mode: 'normal'\n}\n\n// 转化默认属性\nexport const pageConfigComponentProps = transformToComponentProps(pageConfig)\n","import { computed, HTMLAttributes } from 'vue'\nimport { pick, without } from 'lodash-es'\n// 需要添加组件的 style 属性\nconst styleList = [\n 'width',\n 'height',\n 'color',\n 'position',\n 'top',\n 'left',\n 'rotate',\n 'fontSize',\n 'fontFamily',\n 'fontWeight',\n 'textDecoration',\n 'textAlign',\n 'verticalAlign',\n 'overflow',\n 'backgroundColor',\n 'backgroundImage',\n 'backgroundSize',\n 'borderWidth',\n 'borderStyle',\n 'borderRadius',\n 'borderColor',\n 'textShadow',\n 'justifyContent',\n 'alignItems',\n 'zIndex'\n]\n/**\n * 过滤不是 style 属性的组件属性\n * @param props 组件属性\n * @param excludeStyleList 剔除组件的属性\n * @returns style属性\n */\nexport const usePickComponentStyle = <T>(props: Readonly<Partial<T>>, excludeStyleList: string [] = []) => {\n // 再选择需要的组件属性\n const finalStyleList = without(styleList, ...excludeStyleList)\n return computed<HTMLAttributes>(() => pick(props, finalStyleList))\n}\n\nexport default usePickComponentStyle\n","export const EVENT_BUS = 'EVENT_BUS'\nexport const GLOBAL_CONFIG = 'GLOBAL_CONFIG'\nexport const GLOBAL_MODEL = 'GLOBAL_MODEL'\nexport const REQUEST_MODEL = 'REQUEST_MODEL'\nexport const GLOBAL_TOKEN = 'GLOBAL_TOKEN'\nexport const REFRESH_PAGE = 'REFRESH_PAGE'\n// @ts-ignore\nexport const INDICATOR_URL = window?.config?.indicatorURL\n// @ts-ignore\nexport const UPLOAD_PATH = window?.config?.uploadPath || '/api'\n// @ts-ignore\nexport const BASE_URL = window?.config?.routerBaseURL || './'\n// @ts-ignore\nexport const ERD_URL = window?.config?.erdURL || ''\n","import { watch, inject } from 'vue'\nimport { EVENT_BUS } from '@/utils/constant'\nexport const useOnEvent = <T extends { [id: string]: any}>(props: Readonly<Partial<T>>, events: { [key: string]: any }) => {\n watch(() => props.id, (id, oldId) => {\n const eventBus = inject(EVENT_BUS, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n onEvent: (i: string, e: { [key: string]: any }) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n offEvent: (i: string) => void 0\n })\n if (id != null && id !== '') {\n eventBus.onEvent(id, events)\n }\n }, {\n immediate: true\n })\n}\n\nexport default useOnEvent\n","import { inject, ref } from 'vue'\nimport { Events } from '@/utils/props'\nimport { EVENT_BUS, GLOBAL_CONFIG } from '@/utils/constant'\n/**\n * 触发事件\n * @param props 事件数据\n */\nexport const useEmitEvent = (props: { [key:string]: any }) => {\n const events = props.events as Events\n const id = props.id\n const eventBus = inject(EVENT_BUS, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n emitEvent: (id:string, type: string) => void 0\n })\n\n const { touchEventId } = inject(GLOBAL_CONFIG, {\n touchEventId: ref('')\n })\n /**\n * @param on 触发事件\n * @param callback 回调函数\n */\n return (on: string, callback: Function = () => {}) => {\n return function () {\n // 透传\n callback.call(this, ...arguments)\n if (eventBus) {\n const { emitEvent } = eventBus\n events.forEach(event => {\n if (on === event.on) {\n try {\n touchEventId.value = id\n emitEvent(event.target, event.emit)\n } catch (e) {\n console.error(e)\n }\n }\n })\n }\n }\n }\n}\n\nexport default useEmitEvent\n","import { Data, ValueTypeDataFieldNames } from '@/utils/props'\n\n/**\n * 图形转化数据\n * @param data 数据\n * @param dataFieldNames 字段映射\n */\nexport const useTransformChartDataByAttrValue = (data: Data, dataFieldNames?: ValueTypeDataFieldNames) => {\n let { name = 'name', value = 'value', type = 'type' } = dataFieldNames || {}\n // 处去字符串\n name = name?.trim()\n value = value?.trim()\n type = type?.trim()\n const set = new Set()\n const map = new Map()\n const len = data.length\n for (let i = 0; i < len; i++) {\n const item = data[i]\n // x轴\n const x = item[name] || ''\n // y轴\n const y = item[value] || ''\n // 系列(类型)\n const t = item[type] || ''\n set.add(x)\n if (map.has(t)) {\n const arr = map.get(t)\n arr.push({ name: x, value: y, ...item })\n map.set(t, arr)\n } else {\n map.set(t, [{ name: x, value: y, ...item }])\n }\n }\n const dimensions = Array.from(set)\n const dataset: { [key:string]:any } [] = []\n for (const [name, data] of map) {\n dataset.push({\n name,\n data\n })\n }\n return {\n dimensions,\n dataset\n }\n}\nexport default useTransformChartDataByAttrValue\n","export const handleAxisLabelFormatter = (formatter: string) => {\n return formatter.replace(/\\\\n/g, '\\n')\n}\n/**\n * 处理图表format, 目前只做 \\\\n => \\n 转化\n * @param formatter 格式化字符串\n */\nexport const handleFormatter = (formatter: string) => {\n return formatter.replace(/\\\\n/g, '\\n')\n}\n\n/**\n * 格式化金额\n * @param value 数值\n * @param decimalPlaces 格式化位数\n */\nexport const formatMoney = (value: string | number, decimalPlaces:number = 2) => {\n const _value = parseFloat(value + '')\n if (isNaN(_value) || _value < 0) return value\n return _value.toFixed(decimalPlaces).replace(/(\\d)(?=(\\d{3})+\\.)/g, '$1,')\n}\n\nexport const formatPercentage = (value: string | number, decimalPlaces:number = 2) => {\n const strValue = value + ''\n if (strValue.includes('%')) return value\n const _value = parseFloat(strValue)\n if (isNaN(_value)) return value\n return `${(_value * 100).toFixed(decimalPlaces)}%`\n}\n\n/**\n * 字符串1 中是否包含 字符串2 (会全部转成小写)\n * @param v1 字符串1\n * @param v2 字符串2\n * @constructor\n */\nexport const lowerCaseIncludes = (v1:any, v2:any): boolean => {\n if (typeof v1 === 'string' && typeof v2 === 'string') {\n return v1.toLocaleLowerCase().includes(v2.toLocaleLowerCase())\n }\n return false\n}\n","export const useVariablesInText = (\n formatter: string = '',\n data: { [key: string]:any } = {},\n { useNewline = false, useSpace = false } = {}\n) => {\n // 引入全局变量\n // @ts-ignore\n const config = window.config || {}\n data = { ...config, ...data }\n const variables = (formatter).match(/\\{(.+?)\\}/g)\n if (variables == null || variables.length === 0) {\n return formatter\n }\n for (let i = 0; i < variables.length; i++) {\n const variable = variables[i]\n let statement = variable.slice(1, -1)\n const reg = /[\\u4e00-\\u9fa5a-z-_A-Z]+[0-9]*/g\n const textVariables = statement.match(reg)\n for (let j = 0; j < textVariables.length; j++) {\n const textVariable = textVariables[j]\n const usedVariable = data[textVariable]\n if (usedVariable != null) {\n // 使用的变量\n statement = statement.replace(textVariable, usedVariable)\n }\n // else {\n // 过滤未使用的变量\n // statement = statement.replace(textVariable, '')\n // }\n }\n try {\n // 匹配加减乘除\n // eslint-disable-next-line no-eval\n const eval2 = eval\n statement = eval2(statement)\n } catch (e) {\n console.error(e)\n }\n formatter = formatter.replace(variable, statement)\n }\n // 替换换行\n if (useNewline) {\n formatter = formatter?.replace(/\\n|\\\\n/g, '<br/>')\n }\n // 替换空格\n if (useSpace) {\n formatter = formatter?.replace(/\\s{2,}?/g, ' ')\n }\n return formatter\n}\n\nexport default useVariablesInText\n","import { inject, onUnmounted, unref } from 'vue'\nimport axios from 'axios'\nimport { GLOBAL_MODEL, GLOBAL_CONFIG } from '@/utils/constant'\nimport { lowerCaseIncludes } from '@/utils/util'\nimport useVariablesInText from './useVariablesInText'\n// import dayjs from 'dayjs'\n\nexport const useRequestData = (props: { [key:string]: any }, callBack: Function = () => {}) => {\n const {\n requestUrl,\n requestMethod: method,\n requestHeaders: headers,\n requestParams,\n requestInterval,\n isOpenRequestTimer\n } = props\n const { contextRequestUrl, pageMode, touchEventId } = inject(GLOBAL_CONFIG, {\n contextRequestUrl: '',\n pageMode: 'normal',\n touchEventId: ''\n })\n const { getGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0\n })\n const url = useVariablesInText(requestUrl)\n const requestData = async (params: { [key: string]: any } = {}) => {\n if (!url || !method || !headers || unref(pageMode) === 'design') return\n let _params = {} as { [key: string]: any }\n requestParams.forEach((param) => {\n const { key, value } = param\n if ((typeof value === 'object' && value.id)) {\n // 传入数据可能是这样\n // {\n // key: 'record',\n // value: {\n // id: 'T7hid3K4kg7UR9Q-44u1-',\n // prop: 'record',\n // propKey: 'id'\n // }\n // }\n // 获取到组件数据\n let record = {} as { [key:string]: any }\n const { id, prop, propKey, operate } = value\n if (id === 'THIS') {\n // THIS 使用当前触发事件组件的ID\n record = getGlobalModel(unref(touchEventId)) || {}\n } else {\n record = getGlobalModel(id) || {}\n }\n const p = unref(record[prop])\n // 如果传入响应式数据优取响应式\n let v = null\n // 需要格式日期的组件\n const isNeedFormat = ['date', 'range'].some((item) => lowerCaseIncludes(record?.type, item))\n if (isNeedFormat) {\n // 操作时间\n const { value, type, mode } = operate || {}\n if (value && type && mode) {\n switch (type) {\n case 'add':\n v = unref(p).add(value, mode)\n break\n case 'minus':\n v = unref(p).subtract(value, mode)\n break\n }\n }\n if (v == null) {\n v = unref(p)\n }\n // 此时 v 是 dayjs 对象\n // 此时 propKey 是格式化值\n // 格式化时间\n v = v?.format(propKey?.trim() || record.format) || ''\n } else {\n // 因为 model[prop] 可能为 ref\n // 判断他是不是对象\n if (Object.prototype.toString.call(p) === '[object Object]') {\n v = p[propKey || 'value']\n } else {\n v = p\n }\n // v = p != null && typeof p === 'object' ? p[propKey || 'value'] : p\n }\n _params[key] = v\n } else if (typeof value === 'string') {\n _params[key] = useVariablesInText(value)\n }\n })\n // @ts-ignore\n _params = { ...window.config.requestParams, ...params, ..._params }\n let urlParams = ''\n const keys = Object.keys(_params)\n const last = keys.length - 1\n const keysLen = keys.length\n keys.forEach((key, index) => {\n if (index === 0) {\n if (keysLen !== 1) {\n urlParams += `?${key}=${_params[key]}&`\n } else {\n urlParams += `?${key}=${_params[key]}`\n }\n } else if (index === last) {\n urlParams += `${key}=${_params[key]}`\n } else {\n urlParams += `${key}=${_params[key]}&`\n }\n })\n try {\n const isSetUrlParams = ['get', 'head'].includes(method)\n const res = await axios({\n baseURL: unref(contextRequestUrl),\n url: isSetUrlParams ? url + urlParams : url,\n method,\n headers,\n data: isSetUrlParams ? {} : _params\n })\n callBack(res)\n return res\n } catch (e) {\n console.error(e)\n }\n }\n\n const requestDataTimer = isOpenRequestTimer && setInterval(requestData, requestInterval * 1000)\n\n onUnmounted(() => {\n clearInterval(requestDataTimer)\n })\n\n return requestData\n}\n\nexport default useRequestData\n","import { Data, KeyTypeDataFieldNames } from '@/utils/props'\n\n/**\n * 图形转化数据\n * @param data 数据\n * @param dataFieldNames 字段映射\n */\nexport const useTransformChartDataByAttrKey = (data: Data = [], dataFieldNames: KeyTypeDataFieldNames) => {\n let { name = 'name', types = [] } = dataFieldNames || {}\n name = name?.trim() || name\n const set = new Set()\n const map = new Map<string, any []>()\n const dataLen = data.length\n const typesLen = types.length\n // 只有一条记录\n if (dataLen === 1) {\n const vs = []\n // data 为一个值取第一个\n for (let i = 0; i < typesLen; i++) {\n const type = types[i]\n const { label, value } = type\n const v = { ...data[0], value: data[0][value] }\n set.add(label)\n // 值列表\n vs.push(v)\n }\n const n = data[0][name] || ''\n map.set(n, vs)\n } else {\n for (let i = 0; i < dataLen; i++) {\n const item = data[i]\n const x = item[name]\n set.add(x)\n for (let j = 0; j < typesLen; j++) {\n const type = types[j]\n const { label, value } = type\n const v = { ...item, value: item[value] }\n if (map.has(label)) {\n const m = map.get(label)\n m.push(v)\n map.set(label, m)\n } else {\n map.set(label, [v])\n }\n }\n }\n }\n\n const dimensions = Array.from(set)\n const dataset: { [key:string]:any } [] = []\n for (const [name, data] of map) {\n dataset.push({\n name,\n data\n })\n }\n return {\n dimensions,\n dataset\n }\n}\n\nexport default useTransformChartDataByAttrKey\n","export const useImagePath = (path:string, isFormat: boolean = false) => {\n if (!path) return path\n let imagePath: string = ''\n if (path?.includes('://')) {\n imagePath = path\n } else {\n // @ts-ignore\n imagePath = window?.config?.uploadPath + path\n }\n if (isFormat) {\n imagePath = `url(${imagePath})`\n }\n return imagePath\n}\n\nexport default useImagePath\n","import { BASE_URL } from '@/utils/constant'\nexport const usePageUrl = (pageMode: string, pageId: string) => {\n const envPageUrl = `${BASE_URL}/preview?pageId=${pageId}`\n const proPageUrl = `${BASE_URL}/${pageId}`\n return pageMode === 'preview' ? envPageUrl : proPageUrl\n}\n\nexport default usePageUrl\n","import axios from 'axios'\nimport { message } from 'ant-design-vue'\n\nexport const request = axios.create({\n // timeout: 1000 * 15\n})\nrequest.interceptors.request.use((config) => {\n return config\n}, (error) => {\n return Promise.reject(error)\n})\n\nrequest.interceptors.response.use((config) => {\n if (+config?.data?.code === 500) {\n message.error({\n content: config?.data?.msg || config?.data?.message || '服务器异常',\n key: 'SERVER_ERROR'\n })\n }\n return config\n}, (error) => {\n if (error.message.includes('timeout')) {\n message.error({\n content: '网络连接超时,请重试!',\n key: 'TIMEOUT'\n })\n } else {\n const { status } = error.response\n if (status >= 400 && status < 500) {\n message.error({\n content: '请求异常',\n key: 'REQUEST_ERROR'\n })\n }\n\n if (status >= 500) {\n message.error({\n content: '服务器异常',\n key: 'REQUEST_ERROR'\n })\n }\n }\n return Promise.reject(error)\n})\n\nexport default request\n","import { INDICATOR_URL, GLOBAL_MODEL } from '@/utils/constant'\r\nimport { inject, unref } from 'vue'\r\nimport request from '@/utils/request'\r\nimport { message } from 'ant-design-vue'\r\n\r\n/**\r\n * 请求图表数据接口\r\n * @returns {{requestDiagram: () => Promise<AxiosResponse<any>>}}\r\n */\r\nexport const useRequestDiagramData = (props) => {\r\n // 获取到组件数据\r\n const { getGlobalModel } = inject(GLOBAL_MODEL, {\r\n // @ts-ignore\r\n // eslint-disable-next-line no-void\r\n getGlobalModel: (key: string) => void 0\r\n })\r\n const getIndicatorList = (graphicConfig) => {\r\n const indicatorList = []\r\n // 左值轴、指标\r\n graphicConfig?.leftAxisList.forEach(leftAxis => {\r\n if (leftAxis) {\r\n let show = false\r\n if (graphicConfig.leftAxis.includes(leftAxis.name)) {\r\n show = true\r\n }\r\n let indicator: any = {\r\n label: leftAxis.name,\r\n columnName: leftAxis.label,\r\n aggregate: leftAxis.calcValue ? leftAxis.calcValue : 'SUM',\r\n order: null,\r\n location: 'LEFT',\r\n show: show\r\n }\r\n if (graphicConfig.source === 'INDICATOR_LIB') {\r\n indicator.hrpIndexCode = leftAxis.indexCode\r\n }\r\n indicator = getCalculationAxis(leftAxis, indicator)\r\n indicatorList.push(indicator)\r\n }\r\n })\r\n // 右值轴\r\n graphicConfig.rightAxisList.forEach(it => {\r\n let show = false\r\n if (graphicConfig.rightAxis.includes(it.name)) {\r\n show = true\r\n }\r\n let indicator: any = {\r\n label: it.name,\r\n columnName: it.label,\r\n aggregate: 'SUM',\r\n order: null,\r\n location: 'LEFT',\r\n show: show\r\n }\r\n indicator = getCalculationAxis(it, indicator)\r\n if (graphicConfig.source === 'INDICATOR_LIB') {\r\n indicator.hrpIndexCode = it.indexCode\r\n }\r\n indicatorList.push(indicator)\r\n })\r\n\r\n return indicatorList\r\n }\r\n\r\n /**\r\n * 获取计算指标\r\n * @param item\r\n * @param indicator\r\n */\r\n const getCalculationAxis = <T> (item, indicator: T): T => {\r\n const newIndicator: any = { ...indicator }\r\n if (item.calcMethod) { // 来源:新增计算指标\r\n if (item.calcMethod === 'FORMULA') { // 公式\r\n if (item.formulafuc) {\r\n newIndicator.formula = item.formulafuc\r\n }\r\n newIndicator.calcType = 'FORMULA'\r\n } else {\r\n newIndicator.builtInFormula = item.calculmethod\r\n newIndicator.calcType = 'BUILT_IN'\r\n if (item.comeFrom) {\r\n newIndicator.builtInValueSource = item.comeFrom\r\n }\r\n if (item.accessPrinciple) {\r\n newIndicator.builtInCalcWay = item.accessPrinciple\r\n }\r\n }\r\n } else { // 来源:视图拖拽\r\n // @ts-ignore\r\n newIndicator.calcType = 'COLUMN'\r\n }\r\n\r\n return newIndicator\r\n }\r\n\r\n /**\r\n * 获取查询条件\r\n * TODO 检查除日期外的特殊逻辑\r\n * @param relativeList\r\n * @returns {any[]}\r\n */\r\n const getSqlCondition = (relativeList = []) => {\r\n // 关联\r\n const list = []\r\n for (let i = 0; i < relativeList.length; i++) {\r\n const { keyName, searchName, searchType, variateName, id } = relativeList[i]\r\n const item: any = {\r\n alias: keyName,\r\n fieldName: searchName,\r\n rule: searchType || 'NONE',\r\n fieldValue: '',\r\n valueType: '',\r\n variateName\r\n }\r\n const watchItem = getGlobalModel(id) || {}\r\n if (searchName === 'the_date') {\r\n item.valueType = 'DATE'\r\n } else if (['hbdwbh', 'hbdwbh_name'].includes(searchName)) {\r\n item.valueType = 'TEXT'\r\n }\r\n if (watchItem.type === 'ecanDatePicker') {\r\n item.dateFormat = watchItem.format\r\n const formatter = unref(watchItem)?.value.format\r\n if (typeof formatter === 'function') {\r\n item.fieldValue = formatter(watchItem?.format)\r\n }\r\n }\r\n list.push(item)\r\n }\r\n return list\r\n }\r\n\r\n const getSortParams = (classification, list) => {\r\n // 分类项中的排序\r\n const classifyItem = list.find(item => {\r\n return item.name === classification.label\r\n })\r\n if (classifyItem.sort.type) {\r\n if (classifyItem.sort.type !== 'CUSTOM') {\r\n classification.sort = {\r\n label: classifyItem.sort.label,\r\n columnName: classifyItem.sort.columnName,\r\n type: 'NORMAL',\r\n order: classifyItem.sort.type\r\n }\r\n } else {\r\n classification.sort = {\r\n label: classifyItem.label,\r\n columnName: classifyItem.columnName,\r\n type: 'CUSTOM',\r\n customOrderColumns: classifyItem.sort.customOrderColumns\r\n }\r\n }\r\n }\r\n if (classifyItem.customGroup) {\r\n if (classifyItem.customGroup.groupList.length > 1) { // 0或1表示未分组\r\n classification.customGroup = {\r\n groupInfoMap: {},\r\n otherGroupName: ''\r\n }\r\n classifyItem.customGroup.groupList.forEach((row, rowIndex) => {\r\n if (rowIndex !== 0) {\r\n classification.customGroup.groupInfoMap[row.key] = row.value\r\n }\r\n })\r\n classification.customGroup.otherGroupName = classifyItem.customGroup.otherName || ''\r\n }\r\n }\r\n classification.rangeIndexTypeGuid = classifyItem.typeGuid\r\n classification.customFilterSqlPart = classifyItem.filterSql || ''\r\n }\r\n\r\n const handlerFilterParam = (parent, conditions) => {\r\n for (let i = 0; i < parent.children.length; i++) {\r\n if (parent.children[i].children.length > 0) {\r\n let join = ''\r\n if (parent.type === 'and') {\r\n join = '&&'\r\n } else {\r\n join = '||'\r\n }\r\n conditions.push({ conditions: [], join: join })\r\n handlerFilterParam(parent.children[i], conditions[conditions.length - 1].conditions)\r\n } else {\r\n if (parent.children[i].fieldName) {\r\n let fieldValue = ''\r\n const item: any = {\r\n fieldName: parent.children[i].fieldName,\r\n fieldType: parent.children[i].itemType,\r\n rule: parent.children[i].rule,\r\n fieldValue: '',\r\n label: parent.children[i].label,\r\n version: parent.children[i].version ? parent.children[i].version : 100, // 兼容图形化配置时传显示的label,之前的传字段就是100的,label版本为101\r\n targetSource: parent.children[i].targetSource ? parent.children[i].targetSource : ''\r\n }\r\n fieldValue = JSON.parse(JSON.stringify(parent.children[i].fieldValue))\r\n if (parent.children[i].itemType === 'DATE') {\r\n item.dateFormat = parent.children[i].format\r\n item.dateCalcTypes = parent.children[i].dateCalcTypes\r\n item.calcWays = parent.children[i].calcWays\r\n if (parent.children[i].selectType === 'time') { // 自定义时间\r\n if (parent.children[i].absoluteBool) { // 相对时间\r\n fieldValue = '#######'\r\n item.calcWays = parent.children[i].calcWays\r\n } else { // 取配置值\r\n // TODO\r\n // fieldValue = moment(fieldValue).format(parent.children[i].format)\r\n }\r\n } else if (parent.children[i].selectType === 'component') { // 关联控件\r\n fieldValue = '${' + parent.children[i].relateCompent + '}'\r\n }\r\n item.dateFormat = parent.children[i].format\r\n item.dateCalcTypes = parent.children[i].dateCalcTypes\r\n item.calcWays = parent.children[i].calcWays\r\n } else {\r\n if (Object.prototype.toString.call(fieldValue) === '[object Array]') { // 选中后台查询值\r\n const fieldList: any = []\r\n for (let n = 0; n < fieldValue.length; n++) {\r\n if (fieldValue[n] !== '全选') {\r\n fieldList.push(fieldValue[n])\r\n }\r\n }\r\n fieldValue = fieldList.join(',')\r\n }\r\n }\r\n item.fieldValue = fieldValue\r\n if (parent.children.length > 1 && i !== parent.children.length - 1) {\r\n if (parent.type === 'and') {\r\n item.join = '&&'\r\n } else {\r\n item.join = '||'\r\n }\r\n }\r\n conditions.push(item)\r\n }\r\n }\r\n }\r\n }\r\n\r\n // 筛选变量处理\r\n const getFilterParams = (type, list, graphicConfig) => {\r\n if (!type) {\r\n return\r\n }\r\n const classifyItem = graphicConfig[list].find(item => {\r\n return item.name === type.label\r\n })\r\n if (!classifyItem) {\r\n return\r\n }\r\n const conditions = []\r\n const filterList = classifyItem.filterList\r\n if (filterList) {\r\n for (let i = 0; i < filterList.length; i++) {\r\n if (filterList[i].children.length > 0) {\r\n handlerFilterParam(filterList[i], conditions)\r\n }\r\n }\r\n }\r\n return conditions\r\n }\r\n\r\n return async function () {\r\n const componentType = props.type\r\n let graphicConfig = props.graphicConfig\r\n if (!graphicConfig || Object.keys(graphicConfig).length === 0) {\r\n graphicConfig = {\r\n classify: [],\r\n classifyList: [],\r\n series: [],\r\n seriesList: [],\r\n leftAxis: [],\r\n leftAxisList: [],\r\n rightAxis: [],\r\n rightAxisList: [],\r\n relativeList: []\r\n }\r\n }\r\n const xAxisValue = graphicConfig.classify\r\n const yAxisValue = [...graphicConfig.leftAxis, ...graphicConfig.rightAxis]\r\n if (yAxisValue.length === 0) {\r\n message.error('当前y轴无配置信息')\r\n return\r\n }\r\n\r\n // 获取值轴参数\r\n const indicatorList = getIndicatorList(graphicConfig)\r\n // 获取系列值\r\n let series\r\n if (Array.isArray(graphicConfig.series) && graphicConfig.series.length > 0) {\r\n const seriesItem = graphicConfig.seriesList?.find(item => {\r\n const firstSeries = graphicConfig.series[0]\r\n return item.name === firstSeries || item.nameBak === firstSeries\r\n })\r\n if (seriesItem != null) {\r\n series = {\r\n label: seriesItem.name,\r\n columnName: seriesItem.label\r\n }\r\n }\r\n }\r\n // 获取分类\r\n let classification\r\n if (xAxisValue.length > 0) {\r\n classification = {\r\n label: xAxisValue[0],\r\n columnName: xAxisValue[0]\r\n }\r\n const classify = graphicConfig.classifyList?.find(item => {\r\n return item?.name === xAxisValue[0] || item?.nameBak === xAxisValue[0]\r\n }) || {}\r\n classification.columnName = classify.label\r\n // 获取排序信息\r\n getSortParams(classification, graphicConfig.classifyList)\r\n classification.conditions = getFilterParams(classification, 'classifyList', graphicConfig) || []\r\n }\r\n if (series) {\r\n // 获取排序信息\r\n getSortParams(series, graphicConfig.seriesList)\r\n series.conditions = getFilterParams(series, 'seriesList', graphicConfig) || []\r\n }\r\n\r\n for (let t = 0; t < indicatorList.length; t++) {\r\n if (indicatorList[t].location === 'RIGHT') {\r\n indicatorList[t].conditions = getFilterParams(indicatorList[t], 'rightAxisList', graphicConfig)\r\n } else {\r\n indicatorList[t].conditions = getFilterParams(indicatorList[t], 'leftAxisList', graphicConfig)\r\n }\r\n }\r\n\r\n let sqlConditions\r\n if (graphicConfig?.pageMode === 'design') {\r\n // relativeList 在设计模式下,由于联动无法直接获取,已经处理好数据直接获取\r\n sqlConditions = graphicConfig.sqlConditions ?? []\r\n } else {\r\n sqlConditions = getSqlCondition(graphicConfig?.relativeList)\r\n }\r\n let source = 'SQL_VIEW'\r\n let fixedDimSql = ''\r\n let dataSourceId = ''\r\n let idxLibMode = ''\r\n if (graphicConfig.source === 'INDICATOR_LIB') {\r\n source = 'INDICATOR_LIB'\r\n fixedDimSql = graphicConfig.fixedDimSql\r\n dataSourceId = graphicConfig.dataSourceId\r\n idxLibMode = graphicConfig.idxLibMode\r\n }\r\n\r\n const map = {\r\n ecanBar: 'bar',\r\n ecanLine: 'line',\r\n ecanPie: 'pie',\r\n ecanScatter: 'scatter'\r\n }\r\n\r\n try {\r\n const res = await request.get(`${INDICATOR_URL}/user/anonymous?username=admin`, {\r\n headers: {\r\n systemCode: 'F72FC50A3D97372514A6AC33333D28FD',\r\n current_context: 'ygt'\r\n }\r\n })\r\n\r\n return request.post(`${INDICATOR_URL}/diagram`, {\r\n dataViewId: graphicConfig.dataViewId,\r\n plugin: '1',\r\n layer: '2',\r\n chartType: map[componentType],\r\n classification,\r\n indicatorList,\r\n series,\r\n sqlConditions,\r\n source,\r\n fixedDimSql,\r\n dataSourceId,\r\n idxLibMode\r\n }, {\r\n headers: { Authentication: res.data.data.token }\r\n })\r\n } catch (e) {\r\n console.error(e)\r\n }\r\n }\r\n}\r\n\r\nexport default useRequestDiagramData\r\n","export const useValueFormatter = (formatter: string, value:string) => {\n if (formatter == null) return value\n const variables = (formatter).match(/\\{.*\\}/g)\n if (variables == null || variables.length === 0) {\n return value\n }\n const len = variables.length\n for (let i = 0; i < len; i++) {\n const variable = variables[i]\n if (variable == null || variable === '') break\n let statement = variable.slice(1, -1)\n statement = statement?.replace(/value/g, value)\n try {\n // 匹配加减乘除\n let result = statement\n if ((/[+\\-*/%]+/g).test(statement)) {\n // eslint-disable-next-line no-eval\n const eval2 = eval\n result = eval2(statement)\n }\n formatter = formatter.replace(variable, result)\n } catch (e) {\n formatter = formatter.replace(variable, statement)\n console.warn(e)\n }\n }\n return formatter\n}\n\nexport default useValueFormatter\n","import { GLOBAL_MODEL, INDICATOR_URL, GLOBAL_TOKEN } from '@/utils/constant'\nimport { lowerCaseIncludes } from '@/utils/util'\nimport request from '@/utils/request'\nimport { inject, unref } from 'vue'\n\nexport const useIndicatorData = (props: { [key:string]: any } = {}) => {\n const { requestToken } = inject(GLOBAL_TOKEN, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n requestToken: () => void 0\n })\n // 指标库模式才会发\n if (props.dataType === 'indicator') {\n // 只要调用,计数 + 1,计数大于0才会请求\n requestToken()\n }\n\n const handleQueryColumn = (queryColumn: { [key:string]: any } = {}) => {\n const { label, name, location, show, indexCode } = queryColumn\n return {\n label,\n columnName: name,\n location,\n show,\n calcType: 'COLUMN',\n hrpIndexCode: indexCode\n }\n }\n\n const handleIndicator = (indicator: { [key:string]: any } = {}) => {\n const {\n label,\n name,\n location,\n show,\n indexCode,\n calcType = 'COLUMN',\n builtInFormula,\n builtInValueSource,\n builtInCalcWay,\n formula,\n conditions\n } = indicator\n return {\n label,\n columnName: name,\n location,\n show,\n calcType,\n hrpIndexCode: indexCode,\n aggregate: 'SUM',\n builtInFormula,\n builtInValueSource,\n builtInCalcWay,\n formula,\n conditions\n }\n }\n\n const { getGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0\n })\n const handleSqlConditions = (controlList: { [key:string]: any } [] = []) => {\n const len = controlList.length\n const sqlConditions = [] as { [key:string]: any } []\n for (let i = 0; i < len; i++) {\n const control = controlList[i]\n const {\n id,\n conditionLabel,\n conditionKey,\n conditionValueType\n } = control\n const sqlCondition: { [key:string]: any } = {\n rule: 'NONE',\n label: conditionLabel,\n fieldName: conditionKey,\n fieldValue: '', // 在关联控件中取\n valueType: conditionValueType\n }\n // 获取组件属性\n const model = getGlobalModel(id) || {}\n if (lowerCaseIncludes(model.type, 'date')) {\n const { value, format } = model || {}\n sqlCondition.fieldValue = unref(value)?.format(format)\n sqlCondition.dateFormat = format\n }\n sqlConditions.push(sqlCondition)\n }\n return sqlConditions\n }\n return async () => {\n const { graphicConfig } = props\n const {\n source,\n dataViewId,\n plugin,\n layer,\n chartType,\n classificationList = [],\n seriesList = [],\n leftAxisList = [],\n rightAxisList = [],\n queryColumnList = [],\n indicators = [],\n controlList = [],\n dataSourceId,\n idxLibMode,\n preview = false\n } = graphicConfig || {}\n // console.log('classificationList', classificationList)\n // console.log('seriesList', seriesList)\n // console.log('leftAxisList', leftAxisList)\n // console.log('rightAxisList', rightAxisList)\n // console.log('indicators', indicators)\n // console.log('controlList', controlList)\n // 重点处理 classificationList、seriesList、leftAxisList、rightAxisList、indicators\n // classificationList (取第一项) => classification\n let classification\n if (Array.isArray(classificationList) && classificationList.length > 0) {\n const len = classificationList.length\n for (let i = 0; i < len; i++) {\n const item = classificationList[i] || {}\n const { label = '', name = '', show = false, sort, customGroup, conditions } = item\n // 如果是 show 直接提取 classification,停止遍历\n if (show || len === 1) {\n classification = {\n label,\n columnName: name,\n show,\n sort,\n customGroup,\n conditions\n }\n break\n }\n }\n }\n // seriesList (取第一项) => series\n let series\n if (Array.isArray(seriesList) && seriesList.length > 0) {\n const len = seriesList.length\n for (let i = 0; i < len; i++) {\n const item = seriesList[i] || {}\n const { label = '', name = '', show = false, sort, customGroup, conditions } = item\n // 如果是 show 直接提取 seriesList,停止遍历\n if (show || len === 1) {\n series = {\n label,\n columnName: name,\n show,\n sort,\n customGroup,\n conditions\n }\n break\n }\n }\n }\n // queryColumnList => queryColumns\n const queryColumns = []\n queryColumnList?.forEach((queryColumn: { [key:string]: any }) => {\n queryColumns.push(handleQueryColumn(queryColumn))\n })\n\n // leftAxisList + rightAxisList + indicators => indicatorList\n const indicatorList = []\n leftAxisList?.forEach((leftAxis: { [key:string]: any }) => {\n leftAxis.location = 'LEFT'\n indicatorList.push(handleIndicator(leftAxis))\n })\n rightAxisList?.forEach((rightAxis: { [key:string]: any }) => {\n rightAxis.location = 'RIGHT'\n indicatorList.push(handleIndicator(rightAxis))\n })\n indicators?.forEach((indicator: { [key:string]: any }) => {\n indicator.location = 'LEFT'\n indicatorList.push(handleIndicator(indicator))\n })\n if (layer === '1' && queryColumns.length === 0) {\n return\n } else if (layer === '2' && indicatorList.length === 0) {\n return\n }\n let sqlConditions\n if (graphicConfig?.pageMode === 'design') {\n // relativeList 在设计模式下,由于联动无法直接获取,已经处理好数据直接获取\n sqlConditions = graphicConfig.sqlConditions ?? []\n } else {\n sqlConditions = handleSqlConditions(controlList)\n }\n try {\n const res = await request.post(`${INDICATOR_URL}/diagram`, {\n source,\n dataViewId,\n plugin,\n layer,\n chartType,\n classification,\n series,\n indicatorList,\n queryColumns,\n pageFlag: true,\n sqlConditions,\n // fixedDimSql: '',\n dataSourceId,\n idxLibMode,\n preview\n },\n {\n headers: {\n // @ts-ignore\n Authentication: window?.config?.indicatorToken,\n operateContext: 'ygt'\n }\n })\n return res\n } catch (e) {\n console.error(e)\n }\n }\n}\n\nexport default useIndicatorData\n","export const useHrefParamsToGlobalVariables = () => {\n const search = window.location.search\n const params = search.slice(1).split('&')\n const len = params.length\n for (let i = 0; i < len; i++) {\n const param = params[i]\n if (param == null || param === '') continue\n const keyAndValue = param.split('=')\n if (Array.isArray(keyAndValue)) {\n const key = keyAndValue[0]\n const value = keyAndValue[1] as string\n (window as any).config[key] = value\n }\n }\n}\n\nexport default useHrefParamsToGlobalVariables\n","<template>\n <div id=\"container\" ref=\"container\">\n <template v-if=\"ready\">\n <div\n class=\"page-config\"\n :style=\"style\"\n >\n <slot></slot>\n </div>\n </template>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, nextTick, computed, ref, onMounted, onUnmounted } from 'vue'\nimport { debounce } from 'lodash-es'\nimport { pageConfigComponentProps } from './props'\nimport { useImagePath } from '@/hooks'\nexport default defineComponent({\n name: 'EcanPageConfig',\n inheritAttrs: false,\n props: {\n ...pageConfigComponentProps\n },\n setup (props) {\n // 大屏设计容器\n const style = computed(() => ({\n width: props.width,\n height: props.height,\n backgroundColor: props.backgroundColor,\n backgroundImage: useImagePath(props.backgroundImage as string, true),\n backgroundSize: props.backgroundSize\n }))\n const width = ref(0)\n const height = ref(0)\n const originalWidth = ref(0)\n const originalHeight = ref(0)\n const ready = ref(false)\n const container = ref()\n let observer: MutationObserver | null\n const initSize = () => {\n return new Promise<void>((resolve) => {\n nextTick(() => {\n // 获取大屏的真实尺寸\n if (props.width && props.height) {\n width.value = parseFloat(props.width)\n height.value = parseFloat(props.height)\n } else {\n width.value = container.value.clientWidth\n height.value = container.value.clientHeight\n }\n // 获取画布尺寸\n if (!originalWidth.value || !originalHeight.value) {\n originalWidth.value = window.screen.width\n originalHeight.value = window.screen.height\n }\n resolve()\n })\n })\n }\n const updateSize = () => {\n if (width.value && height.value) {\n container.value.style.width = `${width.value}px`\n container.value.style.height = `${height.value}px`\n } else {\n container.value.style.width = `${originalWidth.value}px`\n container.value.style.height = `${originalHeight.value}px`\n }\n }\n const updateScale = () => {\n // 获取真实的视口尺寸\n const currentWidth = document.body.clientWidth\n const currentHeight = document.body.clientHeight\n // 获取大屏最终的宽高\n const realWidth = width.value || originalWidth.value\n const realHeight = height.value || originalHeight.value\n const widthScale = currentWidth / realWidth\n const heightScale = currentHeight / realHeight\n container.value && (container.value.style.transform = `scale(${widthScale}, ${heightScale})`)\n }\n const onResize = async () => {\n await initSize()\n updateScale()\n }\n const initMutationObserver = () => {\n const MutationObserver = window.MutationObserver\n observer = new MutationObserver(onResize)\n observer.observe(container.value, {\n attributes: true,\n attributeFilter: ['style'],\n attributeOldValue: true\n })\n }\n const removeMutationObserver = () => {\n if (observer) {\n observer.disconnect()\n observer.takeRecords()\n observer = null\n }\n }\n onMounted(async () => {\n ready.value = false\n await initSize()\n updateSize()\n updateScale()\n window.addEventListener('resize', debounce(onResize, 100))\n initMutationObserver()\n ready.value = true\n })\n onUnmounted(() => {\n window.removeEventListener('resize', onResize)\n removeMutationObserver()\n })\n return {\n style,\n container,\n ready\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n#container {\n position: fixed;\n top: 0;\n left: 0;\n overflow: hidden;\n transform-origin: left top;\n z-index: 999;\n}\n.page-config {\n position: relative;\n overflow: hidden;\n background-size: cover;\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport PageConfig from './PageConfig.vue'\nexport const EcanPageConfig = withInstall(PageConfig)\nexport default EcanPageConfig\nexport * from './props'\n","import { transformToComponentProps } from '@/utils/props'\n\nexport interface ProviderConfig {\n contextRequestUrl: string // 请求头\n pageMode: 'normal' | 'preview' | 'design' // 普通、预览、设计模式\n theme: 'light' | 'darkBlue'\n containerMap: { [key:string]: any }\n}\n\nexport const providerConfig: ProviderConfig = {\n contextRequestUrl: '',\n pageMode: 'normal',\n theme: 'light',\n containerMap: {}\n}\n\n// 转化默认属性\nexport const providerConfigComponentProps = transformToComponentProps(providerConfig)\n","<template>\n <!-- 请勿去除属性id -->\n <div id=\"ProviderConfig\" ref=\"providerConfig\">\n <slot></slot>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, provide, ref, onMounted, watch, computed, unref, onBeforeUnmount } from 'vue'\nimport mitt from 'mitt'\nimport { EVENT_BUS, GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL, INDICATOR_URL, GLOBAL_TOKEN, REFRESH_PAGE } from '@/utils/constant'\nimport { providerConfigComponentProps } from './props'\nimport { useVariablesInText, useHrefParamsToGlobalVariables } from '@/hooks'\nimport axios from 'axios'\nimport { RequestModalParam } from '@/utils/types'\n\nexport default defineComponent({\n name: 'EcanProviderConfig',\n inheritAttrs: false,\n props: {\n ...providerConfigComponentProps\n },\n setup (props, { expose }) {\n useHrefParamsToGlobalVariables()\n\n const providerConfig = ref<HTMLElement>()\n const setTheme = () => {\n providerConfig.value.setAttribute('datav-theme', props.theme as string)\n }\n watch(() => props.theme, () => {\n setTheme()\n })\n onMounted(() => {\n setTheme()\n })\n const contextRequestUrl = computed(() => {\n return useVariablesInText(props.contextRequestUrl as string)\n })\n const pageMode = computed(() => props.pageMode)\n const theme = computed(() => props.theme)\n // 当前组件主动触发ID\n const touchEventId = ref<string>('')\n // 提供全局设置\n provide(GLOBAL_CONFIG, {\n // 请求地址\n contextRequestUrl,\n // 模式(设计、预览、正常):目前主要配置初始化是否发起请求\n pageMode,\n // 主题\n theme,\n touchEventId\n })\n\n // 提供全局变量\n const globalModel = new Map()\n const getGlobalModel = (key: string) => {\n return globalModel.get(key)\n }\n const setGlobalModel = (key: string, value: any) => {\n globalModel.set(key, value)\n }\n provide(GLOBAL_MODEL, {\n getGlobalModel,\n setGlobalModel\n })\n\n // 提供事件\n const eventBus = mitt()\n const eventBusKeySet = new Set()\n const onEvent = (key: string, events: { [key:string]: any }) => {\n if (eventBusKeySet.has(key)) {\n eventBus.off(key)\n }\n eventBus.on(key, (k: string) => {\n eventBusKeySet.add(key)\n return Object.prototype.toString.call(events[k]) === '[object Function]' && events[k]()\n })\n onBeforeUnmount(() => {\n eventBus.off(key)\n })\n }\n const offEvent = (key) => {\n eventBus.off(key)\n }\n const emitEvent = (key: string, eventName: string) => {\n eventBus.emit(key, eventName)\n }\n provide(EVENT_BUS, {\n onEvent,\n offEvent,\n emitEvent\n })\n\n // 设置是否请求 token\n const tokenNum = ref(0)\n const requestToken = () => {\n tokenNum.value = unref(tokenNum) + 1\n }\n provide(GLOBAL_TOKEN, {\n requestToken\n })\n // 请求排序\n const requestModel = new Map()\n const requestMap = new Map()\n const setRequest = ({ requestFn = () => {}, sortNum = 0, id = '' }: RequestModalParam) => {\n if (requestModel.has(sortNum)) {\n const requestFnList = requestModel.get(sortNum)\n requestFnList?.push(requestFn)\n } else {\n requestModel.set(sortNum, [requestFn])\n }\n requestMap.set(id, requestFn)\n }\n const handleRequestFnList = (requestFnList: Array<Function>) => {\n return new Promise((resolve, reject) => {\n const resultList = requestFnList.map(requestFn => requestFn())\n Promise.all(resultList)\n .then(list => {\n resolve(list)\n })\n .catch(err => {\n reject(err)\n })\n })\n }\n // 指标库模块请求 token\n const queryUserToken = async () => {\n const res = await axios.get(`${INDICATOR_URL}/user/anonymous?username=admin`, {\n headers: {\n systemCode: 'F72FC50A3D97372514A6AC33333D28FD',\n current_context: 'ygt'\n }\n })\n // 设置 token 挂载在 window.config 上\n // @ts-ignore\n // eslint-disable-next-line\n config.indicatorToken = res.data.data?.token\n }\n const touchRequest = async (id: undefined | string) => {\n // 传空默认触发全部\n if (!id) {\n const requestModelArr = Array.from(requestModel)\n // 排序\n requestModelArr.sort((a, b) => b[0] - a[0])\n const len = requestModelArr.length\n try {\n // 指标库模块需要 token\n // 页面不为design 请求次数 token 不为0\n if (props.pageMode !== 'design' && unref(tokenNum) > 0) {\n await queryUserToken()\n }\n for (let i = 0; i < len; i++) {\n const requestFnList = requestModelArr[i][1]\n await handleRequestFnList(requestFnList)\n }\n } catch (e) {\n console.error(e)\n } finally {\n // 执行完直接清空\n requestModel.clear()\n }\n } else if (typeof id === 'string') {\n const requestFn = requestMap.get(id)\n if (typeof requestFn === 'function') {\n requestFn()\n }\n }\n }\n\n provide(REQUEST_MODEL, {\n setRequest,\n touchRequest\n })\n\n const emitRefreshPage = () => {\n eventBus.emit(REFRESH_PAGE)\n }\n provide(REFRESH_PAGE, {\n emitRefreshPage\n })\n // const notRenderSet = ref(new Set())\n // const refreshEventBus = mitt()\n const onRefreshPage = (callBack: Function) => {\n eventBus.on(REFRESH_PAGE, () => callBack())\n onMounted(() => {\n eventBus.off(REFRESH_PAGE)\n })\n }\n\n onBeforeUnmount(() => {\n requestModel?.clear()\n requestMap?.clear()\n })\n\n expose({\n touchRequest,\n getGlobalModel,\n onRefreshPage\n })\n\n return {\n providerConfig\n }\n }\n})\n</script>\n\n<style scoped>\n\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport ProviderConfig from './ProviderConfig.vue'\nexport const EcanProviderConfig = withInstall(ProviderConfig)\nexport default EcanProviderConfig\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface TextProps extends Props {\n text: string // 文本内容\n color: string // 颜色\n fontSize: string // 字体大小\n fontFamily: string // 字体\n fontWeight: number // 字体的粗细程度\n justifyContent: 'flex-start' | 'center' | 'end' // 水平位置\n alignItems: 'flex-start' | 'center' | 'end' // 垂直位置\n textShadow: string // 文字阴影\n data: { [key:string]: any }\n variableColor: string\n variableFontSize: string\n variableDefaultValue: string\n format: '' | 'percentage'\n href: string\n target: 'self' | 'blank' | 'event' // 打开方式\n linkPage: string // 传入pageId\n}\nexport const textProps:TextProps = {\n ...props,\n name: '文本',\n keyName: '文本',\n type: 'ecanText',\n width: '100px',\n height: '40px',\n text: '文字',\n color: '#333',\n variableColor: '#f00',\n fontSize: '14px',\n fontFamily: '',\n fontWeight: 400,\n textShadow: '',\n justifyContent: 'center',\n alignItems: 'center',\n variableFontSize: '14px',\n data: {},\n variableDefaultValue: '0',\n format: '',\n target: 'self',\n href: '',\n linkPage: ''\n}\n\n// 转化默认属性\nexport const textComponentProps = transformToComponentProps(textProps)\n\nexport const textEvents = ['refreshData', 'click']\n","export default \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAMAAADXqc3KAAAAV1BMVEUAAAD/WzT/WjP/WDD/WzT/WzP/WzT/WzT/WzT/WjT/WzT/WDT/YED/WzT/WzT/WjT/YED/WzT/WzT/WzT/XDT/WzT/WjX/WjP/XDT/XDT/WTL/Tif/WzReH8z5AAAAHHRSTlMA8RgS9W9YHbePZyME5sVjCP7bzcCxgndOQC4GFJJgKwAAAIJJREFUKM+Nkd0OgyAMRjvqcLA53fzXvv9zaokmxq8mnsue5ACFDjiy+XyjLZ7yyK35OxN5mSFZKa2QojEIKRhrZKM0QnsMQxirmJ0kBubTIZvAtUyiFAT4JFoUIYmIotZ5xjDPfyoCAV16nMPdFir8xZ16nM//tePtXw2ODOJY0V0WqQwM2rgKrU0AAAAASUVORK5CYII=\"","export default \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAACXBIWXMAAAsTAAALEwEAmpwYAAAFHGlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4gPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmUgWE1QIENvcmUgNS42LWMxNDUgNzkuMTYzNDk5LCAyMDE4LzA4LzEzLTE2OjQwOjIyICAgICAgICAiPiA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIgeG1sbnM6cGhvdG9zaG9wPSJodHRwOi8vbnMuYWRvYmUuY29tL3Bob3Rvc2hvcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgQ0MgMjAxOSAoV2luZG93cykiIHhtcDpDcmVhdGVEYXRlPSIyMDIyLTA3LTIyVDA5OjM1OjE5KzA4OjAwIiB4bXA6TW9kaWZ5RGF0ZT0iMjAyMi0wNy0yMlQwOTozNTozNyswODowMCIgeG1wOk1ldGFkYXRhRGF0ZT0iMjAyMi0wNy0yMlQwOTozNTozNyswODowMCIgZGM6Zm9ybWF0PSJpbWFnZS9wbmciIHBob3Rvc2hvcDpDb2xvck1vZGU9IjMiIHBob3Rvc2hvcDpJQ0NQcm9maWxlPSJzUkdCIElFQzYxOTY2LTIuMSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDozNmRlNzg2MS1kNzhmLTQyNGYtYTNjOS01ZTk0MjkwY2RjZjEiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MzZkZTc4NjEtZDc4Zi00MjRmLWEzYzktNWU5NDI5MGNkY2YxIiB4bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ9InhtcC5kaWQ6MzZkZTc4NjEtZDc4Zi00MjRmLWEzYzktNWU5NDI5MGNkY2YxIj4gPHhtcE1NOkhpc3Rvcnk+IDxyZGY6U2VxPiA8cmRmOmxpIHN0RXZ0OmFjdGlvbj0iY3JlYXRlZCIgc3RFdnQ6aW5zdGFuY2VJRD0ieG1wLmlpZDozNmRlNzg2MS1kNzhmLTQyNGYtYTNjOS01ZTk0MjkwY2RjZjEiIHN0RXZ0OndoZW49IjIwMjItMDctMjJUMDk6MzU6MTkrMDg6MDAiIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkFkb2JlIFBob3Rvc2hvcCBDQyAyMDE5IChXaW5kb3dzKSIvPiA8L3JkZjpTZXE+IDwveG1wTU06SGlzdG9yeT4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1ldGE+IDw/eHBhY2tldCBlbmQ9InIiPz6VDI+BAAABUUlEQVRIia3WPyhGURgG8B8pi0xisStKMioZLQaLiaQMBoxiVBImCwaLf6MssloUk8Gmb7GgJFKSUvIZ7qe+bvd89+A+03uf989z3nPPPe+tK5fLqtF3tSESzRjFAJ4vemams4IaYqulCq9gEo34QGco+LcCg9hHaxW3jpsiBIZxmMp5kXQTRH1k8S4cZCxoE6//FaiXbEtThm87JjkPI+jN4E9xW4TAQoA/isjNFehCT8B3VoTAUID/xHURAn0B/g5fRQh0B/j7mOJkf2gTaKvY7YG8FsxXPe/hIVbgCTs5C+vAasU+xlooMGuLTrCVI/CDR0zVCgi9gzmUIgQmBbYmT+AdY5LjGMKWpNuaqHWKLrEY8JUkXeYi75iu4DzFfUi6ey9C4AvjeKviliTdRSHmsrvBbMU+lzNg0oidaLvox7LIK+IHdem/iqIROzL/jG+NrT1BRsXKNQAAAABJRU5ErkJggg==\"","<template>\n <div class=\"skeleton-wrapper\" :style=\"style\" v-if=\"loading\">\n <skeleton :loading=\"loading\"/>\n </div>\n <div class=\"ecan-text\" :style=\"style\" v-html=\"myText\" @click=\"click\" v-else/>\n</template>\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, ref, unref, watch } from 'vue'\nimport { textComponentProps } from './props'\nimport {\n usePickComponentStyle,\n useRequestData,\n useOnEvent,\n useEmitEvent,\n usePageUrl,\n useVariablesInText\n} from '@/hooks'\nimport { GLOBAL_CONFIG, REQUEST_MODEL } from '@/utils/constant'\nimport Skeleton from '@/common/skeleton/Skeleton.vue'\nimport goUp from '@/assets/go-up.png'\nimport goDown from '@/assets/go-down.png'\nimport { RequestModalParam } from '@/utils/types'\nimport { formatMoney } from '@/utils/util'\n\nexport default defineComponent({\n name: 'EcanText',\n components: { Skeleton },\n props: {\n ...textComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const myData = ref({} as { [key:string]:any })\n watch(() => [props.data, props.dataType], ([data, dataType]) => {\n if (dataType === 'static') {\n myData.value = data as { [key: string]: any }\n }\n }, {\n immediate: true\n })\n const myText = computed(() => {\n const data = unref(myData)\n let text = props.text as string\n text = text?.replace(/\\n|\\\\n/g, '<br/>')\n text = text?.replace(/\\s/g, ' ')\n const variables = (text).match(/\\{\\s*[\\w\\u4e00-\\u9fa5]*\\s*\\}/g)\n if (variables == null || variables.length === 0) return text\n for (let i = 0; i < variables.length; i++) {\n const variable = variables[i]\n const v = variable?.slice(1, variable.length - 1)?.trim()\n let usedVariable = data[v]\n // 能取到变量值\n if (usedVariable != null) {\n // 涨跌幅\n const format = props.format\n if (format === 'percentage') {\n // 判断是数字类型\n usedVariable = +usedVariable\n if (!isNaN(usedVariable)) {\n usedVariable = (usedVariable * 100).toFixed(2)\n // 如果大于等于 0\n if (usedVariable >= 0) {\n text = text.replace(variable, `<span style=\"color:#ED6643;font-size:${props.variableFontSize}\"><img style=\"width: ${props.variableFontSize}\" src=\"${goUp}\"/>${usedVariable}%</span>`)\n } else {\n // 如果小于 0\n text = text.replace(variable, `<span style=\"color: #6ACB97;font-size:${props.variableFontSize}\"><img style=\"width: ${props.variableFontSize}\" src=\"${goDown}\"/>${Math.abs(usedVariable)}%</span>`)\n }\n } else {\n // 判断不是数字类型\n text = text.replace(variable, `<span style=\"color:${props.variableColor};font-size:${props.variableFontSize}\">${0.00}%</span>`)\n }\n } else if (format === 'percent') {\n // 百分数\n // 判断是数字类型\n usedVariable = +usedVariable\n if (!isNaN(usedVariable)) {\n usedVariable = (usedVariable * 100).toFixed(2)\n text = text.replace(variable, `<span style=\"color:${props.variableColor};font-size:${props.variableFontSize}\">${usedVariable}%</span>`)\n }\n } else if (props.format === 'money') {\n // 金额格式化\n usedVariable = +usedVariable\n if (!isNaN(usedVariable)) {\n usedVariable = formatMoney(usedVariable)\n text = text.replace(variable, `<span style=\"color:${props.variableColor};font-size:${props.variableFontSize}\">${usedVariable}</span>`)\n }\n } else {\n /// 没有使用百分格式化\n text = text.replace(variable, `<span style=\"color:${props.variableColor};font-size:${props.variableFontSize}\">${usedVariable}</span>`)\n }\n } else {\n // 不能取到变量值\n text = text.replace(variable, props.variableDefaultValue as string)\n }\n }\n return `<span>${text}</span>`\n })\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n const requestData = useRequestData(props)\n const loading = ref(false)\n const handleRequestData = async () => {\n if (unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestData()\n myData.value = res?.data?.data || {}\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n const refreshData = () => {\n if (props.dataType === 'static') return\n handleRequestData()\n }\n\n useOnEvent(props, {\n refreshData\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n\n setRequest({\n id: props.id as string,\n requestFn: refreshData,\n sortNum: props.requestSort as number\n })\n useOnEvent(props, {\n refreshData\n })\n\n const emitEvent = useEmitEvent(props)\n\n const click = emitEvent('click', () => {\n // 空链接、空页面直接 return\n if (!props.linkPage && !props.href) return\n const linkPage = (props.linkPage || '') as string\n const pageUrl = usePageUrl(unref(pageMode), linkPage)\n // 优先使用外部链接,再使用url\n const href = props.href as string\n let url = href || pageUrl\n url = useVariablesInText(url)\n const target = props.target\n if (target == null || target === '') return\n if (target !== 'event') {\n window.open(url, '_' + (target as string))\n } else {\n window.parent.postMessage({\n type: 'openPage',\n url: href\n }, '*')\n }\n })\n\n return {\n style,\n myText,\n loading,\n click\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n@import \"./style\";\n//.skeleton-wrapper {\n// overflow: hidden;\n//}\n//\n//.ecan-text {\n// overflow: hidden;\n// display: flex;\n//}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport Text from './Text.vue'\nexport const EcanText = withInstall(Text)\nexport default EcanText\nexport * from './props'\n","<template>\n <div class=\"red\">\n {{ text }}\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, ref } from 'vue'\nexport default defineComponent({\n name: 'EcanScrollText',\n setup () {\n const text = ref('基础文本')\n return {\n text\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.red {\n color: red;\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport ScrollText from './ScrollText.vue'\nexport const EcanScrollText = withInstall(ScrollText)\nexport default EcanScrollText\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface TimeDisplayProps extends Props {\n color: string\n format: string\n fontSize: string\n fontFamily: string // 字体\n fontWeight: number // 字体的粗细程度\n textShadow: string // 文字阴影\n textAlign: string // 水平\n verticalAlign: string // 垂直\n}\n\nexport const timeDisplayProps: TimeDisplayProps = {\n ...props,\n name: '时间展示',\n keyName: '时间展示',\n type: 'ecanTimeDisplay',\n format: 'YYYY-MM-DD dddd HH:mm:ss',\n fontSize: '16px',\n color: '#333',\n width: '240px',\n height: '40px',\n textAlign: 'center',\n fontFamily: '',\n fontWeight: 400,\n textShadow: '',\n verticalAlign: 'middle'\n}\n\nexport const timeDisplayComponentProps = transformToComponentProps(timeDisplayProps)\n","<template>\n <div class=\"time-display\" :style=\"style\">\n {{ time }}\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, onMounted, onUnmounted, ref } from 'vue'\nimport { timeDisplayComponentProps } from './props'\nimport dayjs from 'dayjs'\nimport { usePickComponentStyle } from '../../hooks'\nexport default defineComponent({\n name: 'EcanTimeDisplay',\n props: {\n ...timeDisplayComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const time = ref(dayjs().format(props.format as string))\n let timer = null\n const clearTimer = () => {\n clearInterval(timer)\n timer = null\n }\n const setTimer = () => {\n if (timer) {\n clearTimer()\n }\n timer = setInterval(() => {\n time.value = dayjs().add(1, 's').format(props.format as string)\n }, 1000)\n }\n onMounted(() => {\n setTimer()\n })\n onUnmounted(() => {\n clearTimer()\n })\n return {\n style,\n time\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.time-display {\n overflow: hidden;\n display: table-cell;\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport TimeDisplay from './TimeDisplay.vue'\nexport const EcanTimeDisplay = withInstall(TimeDisplay)\nexport default EcanTimeDisplay\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface ListProps extends Props {\n data: { [key: string]: any } []\n columns: { [key: string]: any } []\n sliceCount: number,\n backgroundColor: string\n useRanking: boolean\n useTitle: boolean\n columnCount: number\n itemHeight: string\n itemColSpan: string\n itemRowSpan: string\n}\n\nexport const listProps:ListProps = {\n ...props,\n type: 'ecanList',\n name: '列表',\n keyName: '列表',\n width: '330px',\n height: '80px',\n backgroundColor: '#0d215e',\n itemColSpan: '10px',\n itemRowSpan: '10px',\n useRanking: true,\n useTitle: false,\n sliceCount: 6,\n columnCount: 1,\n itemHeight: '32px',\n data: [\n {\n name: 'a',\n age: 12\n },\n {\n name: 'b',\n age: 14\n }\n ],\n columns: [\n {\n key: 'name'\n },\n {\n key: 'age'\n }\n ]\n}\n\nexport const listComponentProps = transformToComponentProps(listProps)\n\nexport interface ListEvents {\n refreshData: () => void\n click: () => void\n}\n\nexport const listEvents: Array<keyof ListEvents> = ['refreshData', 'click']\n","<template>\n <div class=\"ecan-list\" :style=\"style\">\n <skeleton :loading=\"loading\">\n <div\n class=\"title\"\n v-if=\"useTitle\"\n >\n <div\n class=\"title-inner\"\n :style=\"{\n backgroundColor: backgroundColor,\n height: itemHeight,\n width: `calc(100% / ${columnCount} - ${itemColSpan} * ${columnCount - 1}/ ${columnCount})`,\n marginRight: count % columnCount !== 0 ? itemColSpan : ''\n }\"\n v-for=\"count in columnCount\"\n :key=\"count\"\n >\n <div class=\"ranking\" v-if=\"useRanking\" />\n <div\n class=\"column\"\n v-for=\"(column, i) in columns\"\n :key=\"column.key || i\"\n :style=\"{\n color: column.titleColor,\n ...columnStyle\n }\"\n >\n {{ column.title }}\n </div>\n </div>\n </div>\n <div class=\"ecan-list-content\" v-if=\"dataSource.length > 0\">\n <div\n class=\"title-placeholder\"\n :style=\"{\n marginBottom: itemRowSpan\n }\"\n v-if=\"useTitle\"\n />\n <div\n class=\"item\"\n :style=\"{\n backgroundColor: backgroundColor,\n height: itemHeight,\n width: `calc(100% / ${columnCount} - ${itemColSpan} * ${columnCount - 1} / ${columnCount})`,\n marginRight: (i + 1) % columnCount !== 0 ? itemColSpan : '',\n marginBottom: itemRowSpan\n }\"\n v-for=\"(item, i) in dataSource.slice(0, sliceCount)\"\n :key=\"item.id || i\"\n @click=\"click\"\n >\n <div class=\"ranking\" v-if=\"useRanking\">\n <div class=\"icon\"/>\n <div class=\"sort\">\n Top {{ i + 1 }}\n </div>\n </div>\n <div\n :class=\"['column', contrastClass(item[column.key], column.format)]\"\n v-for=\"column in columns\"\n :key=\"column.key\"\n :style=\"{\n fontSize: column.fontSize,\n color: contrastClass(item[column.key], column.format) === '' ? column.color : '',\n fontWeight: column.fontWeight,\n ...columnStyle\n }\"\n >\n {{ (column.format != null || column.format !== '') && formatFn(item[column.key], column.format) }}\n </div>\n </div>\n </div>\n <div class=\"empty\" v-else>\n 暂无数据\n </div>\n </skeleton>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, ref, unref } from 'vue'\nimport { listComponentProps, ListEvents } from './props'\nimport { useEmitEvent, useOnEvent, usePickComponentStyle, useRequestData } from '@/hooks'\nimport { formatMoney, formatPercentage } from '@/utils/util'\nimport { GLOBAL_CONFIG, REQUEST_MODEL } from '@/utils/constant'\nimport { RequestModalParam } from '@/utils/types'\nimport Skeleton from '@/common/skeleton'\nexport default defineComponent({\n name: 'EcanList',\n components: { Skeleton },\n props: {\n ...listComponentProps\n },\n setup (props) {\n const dataSource = ref<{[key:string]: any} []>(props.data as {[key:string]: any} [])\n const style = usePickComponentStyle(props, ['backgroundColor'])\n const columnStyle = computed(() => {\n if (props.useRanking) {\n return {\n textAlign: 'center'\n }\n } else {\n return {\n textAlign: 'left'\n }\n }\n })\n type Format = 'money' | 'percentage' | 'contrast' | ''\n const formatFn = (value: string | number, format?: Format) => {\n if (format == null || format === '') return value\n const map = {\n money: formatMoney,\n percentage: formatPercentage,\n contrast: formatPercentage\n }\n return map[format](value) || ''\n }\n const contrastClass = (value: string | number, format: Format) => {\n const _value = parseFloat(value + '')\n if (format !== 'contrast') {\n return ''\n }\n switch (true) {\n case _value >= 0:\n return 'goUp'\n case _value < 0:\n return 'goDown'\n }\n }\n const requestData = useRequestData(props)\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n const loading = ref(false)\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n\n try {\n loading.value = true\n const res = await requestData()\n dataSource.value = res?.data?.data.rows || []\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const refreshData = () => {\n handleRequestData()\n }\n\n const emitEvent = useEmitEvent(props)\n\n const click = emitEvent('click', () => {})\n\n useOnEvent(props, {\n refreshData\n } as ListEvents)\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n setRequest({\n id: props.id as string,\n requestFn: handleRequestData,\n sortNum: props.requestSort as number\n })\n return {\n style,\n formatFn,\n columnStyle,\n contrastClass,\n dataSource,\n loading,\n click\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n .ecan-list {\n overflow: hidden;\n }\n .ecan-list-content {\n width: 100%;\n height: 100%;\n overflow: auto;\n display: flex;\n align-content: flex-start;\n flex-wrap: wrap;\n }\n .title {\n position: absolute;\n z-index: 9;\n display: flex;\n align-items: center;\n height: 32px;\n width: 100%;\n font-size: 16px;\n color: #ffffff;\n }\n .title-inner {\n padding-left: 28px;\n padding-right: 20px;\n flex: 1;\n display: flex;\n height: 100%;\n }\n .title-placeholder {\n width: 100%;\n height: 32px;\n }\n .item {\n display: flex;\n align-items: center;\n height: 32px;\n padding-left: 28px;\n padding-right: 20px;\n width: 100%;\n font-size: 16px;\n color: #ffffff;\n }\n .column {\n flex: 1;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n .ranking {\n flex: 1;\n display: flex;\n align-items: center;\n flex-shrink: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n .icon {\n width: 12px;\n height: 8px;\n background: #21BEF7;\n margin-right: 17px;\n opacity: .6;\n }\n .item:nth-child(2) .icon {\n opacity: .8;\n }\n .item:first-child .icon{\n opacity: 1;\n }\n .sort {\n font-weight: 600;\n }\n .goUp {\n color: #FF512E;\n display: flex;\n align-items: center;\n &:before {\n content: '';\n display: block;\n background: url(\"../../assets/go-up.png\");\n width: 12px;\n height: 12px;\n background-repeat: no-repeat;\n background-size: cover;\n margin-right: 2px;\n }\n }\n\n .goDown {\n color: #39cf93;\n display: flex;\n align-items: center;\n &:before {\n content: '';\n display: block;\n background: url(\"../../assets/go-down.png\");\n width: 12px;\n height: 12px;\n background-repeat: no-repeat;\n background-size: cover;\n margin-right: 2px;\n }\n }\n .empty {\n text-align: center;\n margin-top: 15%;\n }\n</style>\n\n<style lang=\"less\">\n.ecan-list {\n *::-webkit-scrollbar-track {\n background-color: #fff;\n }\n\n .ant-table-cell-scrollbar {\n box-shadow: 0 1px 0 1px transparent;\n }\n *::-webkit-scrollbar {\n width: 6px;\n height: 6px;\n }\n *::-webkit-scrollbar-thumb {\n border-radius: 6px;\n -webkit-box-shadow:inset 0 0 6px rgba(0,0,0,.3);\n background-color: #c8c9ca;\n }\n}\n[datav-theme='darkBlue'] {\n .ecan-list {\n *::-webkit-scrollbar-thumb {\n background-color: #2f4dac !important;\n }\n *::-webkit-scrollbar-track{\n background-color: #192c70;\n }\n *::-webkit-scrollbar-corner {\n background-color: #192c70 !important;\n }\n .empty {\n color: #ffffff;\n }\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport List from './List.vue'\nexport const EcanList = withInstall(List)\nexport default EcanList\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface ProportionProps extends Props {\n strokeColor: string // 进度条的色彩\n strokeLinecap: 'round' | 'square' // 进度条的样式\n trailColor: string // 未完成的分段的颜色\n strokeType: 'circle' | 'dashboard',\n data: { [key:string]: any }\n text: string\n fontSize: string\n color: string\n strokeWidth: number\n fontWeight: number\n strokeTextWidth: string\n lineHeight: string\n decimalFormat: boolean\n variableDefaultValue: string\n}\n\nexport const proportionProps: ProportionProps = {\n ...props,\n name: '占比图',\n keyName: '占比图',\n type: 'ecanProportion',\n strokeType: 'circle',\n width: '200px',\n height: '200px',\n strokeColor: '#4091f7',\n strokeLinecap: 'round',\n trailColor: '#f5f5f5',\n data: {\n percent: 0.30\n },\n text: '{percent}%',\n fontSize: '26px',\n color: '#4091f7',\n strokeWidth: 6,\n fontWeight: 400,\n strokeTextWidth: '100%',\n lineHeight: '26px',\n decimalFormat: false,\n variableDefaultValue: '0'\n}\n\nexport const proportionComponentProps = transformToComponentProps(proportionProps)\n\nexport const proportionEvents = ['refreshData', 'click']\n","<template>\n <div class=\"ecan-proportion\" :style=\"style\">\n <a-progress\n class=\"progress\"\n :percent=\"myValue\"\n :width=\"myWidth\"\n :type=\"strokeType\"\n :strokeColor=\"strokeColor\"\n :strokeLinecap=\"strokeLinecap\"\n :trailColor=\"trailColor\"\n :strokeWidth=\"strokeWidth\"\n :gapDegree=\"strokeType === 'dashboard' ? 75 : 0\"\n @click=\"click\"\n >\n <template #format>\n <skeleton v-if=\"loading\" :loading=\"loading\"/>\n <div\n v-else\n class=\"format\"\n :style=\"{\n width: strokeTextWidth,\n fontSize,\n color,\n fontWeight,\n lineHeight\n }\">\n {{ text }}\n </div>\n </template>\n </a-progress>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, ref, unref, watch } from 'vue'\nimport 'ant-design-vue/es/progress/style'\nimport { Progress as AProgress } from 'ant-design-vue'\nimport { useEmitEvent, useOnEvent, usePickComponentStyle, useRequestData } from '@/hooks'\nimport { proportionComponentProps } from './props'\nimport { GLOBAL_CONFIG, REQUEST_MODEL } from '@/utils/constant'\nimport Skeleton from '../../common/skeleton'\nimport { RequestModalParam } from '@/utils/types'\nexport default defineComponent({\n name: 'EcanProportion',\n components: {\n AProgress,\n Skeleton\n },\n props: {\n ...proportionComponentProps\n },\n setup (props) {\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n const style = usePickComponentStyle(props)\n const myWidth = computed(() => {\n const width = props.width as string\n return parseFloat(width)\n })\n const myData = ref<{ [key:string]: any }>({})\n watch(() => props.data, () => {\n if (props.dataType === 'static' || unref(pageMode) === 'design') {\n myData.value = props.data as { [key:string]: any }\n }\n }, {\n immediate: true,\n deep: true\n })\n const myValue = computed(() => {\n const data = unref(myData)\n const defaultValue = +(props.variableDefaultValue)\n if (data == null) {\n if (!isNaN(defaultValue)) {\n return defaultValue\n } else {\n return 0\n }\n }\n const variables = (props.text as string).match(/\\{.+\\}/g) || []\n let value\n const valueSet = new Set(Object.keys(data))\n for (let i = 0; i < variables.length; i++) {\n const variable = variables[i]\n const key = variable.slice(1, variable.length - 1)\n if (valueSet.has(key)) {\n value = data[key]\n break\n }\n }\n\n if (typeof value === 'number') {\n value = value * 100\n } else if (typeof value === 'string' && !isNaN(+value)) {\n value = (+value) * 100\n } else if (!isNaN(defaultValue)) {\n value = defaultValue * 100\n } else {\n value = 0\n }\n\n if (props.decimalFormat) {\n value = +value.toFixed(2)\n }\n return value\n })\n const text = computed(() => {\n let text = props.text as string\n if (text === '') return unref(myValue)\n const defaultValue = props.variableDefaultValue as string // 变量默认值\n const data = unref(myData) // { a: 1, b: 2 }\n const variables = (text).match(/\\{.+\\}/g) || []\n for (let i = 0; i < variables.length; i++) {\n const variable = variables[i]\n let statement = variable.slice(1, variable.length - 1) // { a - b} => a - b\n const textVariables = statement.match(/.*/g) // a - b => [a,b]\n for (let j = 0; j < textVariables?.length; j++) { // \"1 - 2\"\n const textVariable = textVariables[i]?.trim()\n if (data[textVariable] != null) {\n statement = statement.replace(textVariable, data[textVariable])\n } else {\n statement = statement.replace(textVariable, defaultValue)\n }\n }\n // 匹配加减乘除\n let usedVariable:number | string = statement\n // 运行表达式\n try {\n if ((/\\w+[+\\-*/%]+\\w+/g).test(statement)) {\n // eslint-disable-next-line no-eval\n const eval2 = eval\n usedVariable = eval2(statement)\n }\n } catch (e) {\n console.error(e)\n }\n if (typeof usedVariable === 'number' || !isNaN(+usedVariable)) {\n usedVariable = (+usedVariable * 100)\n if (props.decimalFormat) {\n usedVariable = usedVariable.toFixed(2)\n }\n }\n text = text.replace(variable, usedVariable + '')\n }\n return text\n })\n const requestData = useRequestData(props)\n const loading = ref(false)\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestData()\n myData.value = res?.data?.data || {}\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n const refreshData = () => {\n handleRequestData()\n }\n useOnEvent(props, {\n refreshData\n })\n\n const emitEvent = useEmitEvent(props)\n\n const click = emitEvent('click', () => {})\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n\n setRequest({\n id: props.id as string,\n requestFn: handleRequestData,\n sortNum: props.requestSort as number\n })\n\n return {\n style,\n myWidth,\n text,\n myValue,\n loading,\n click\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.ecan-proportion {\n overflow: hidden;\n}\n\n.progress {\n width: 100%;\n height: 100%;\n}\n\n.format {\n margin: 0 auto;\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Proportion from './Proportion.vue'\nexport const EcanProportion = withInstall(Proportion)\nexport default EcanProportion\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface InputProps extends Props {\n value: string,\n placeholder: string\n}\n\nexport const inputProps: InputProps = {\n ...props,\n width: '200px',\n id: '',\n left: '0px',\n top: '0px',\n name: '输入框',\n keyName: '输入框',\n rotate: '',\n type: 'ecanInput',\n value: '',\n placeholder: '请输入文字'\n}\n\n// 转化默认属性\nexport const inputComponentProps = transformToComponentProps(inputProps)\n\nexport const inputEvents = ['inputChange', 'inputBlur']\n","<template>\n <div\n class=\"ecan-input\"\n :style=\"style\"\n >\n <a-input\n class=\"input\"\n v-model:value=\"myValue\"\n :placeholder=\"placeholder\"\n @change=\"inputChange\"\n @blur=\"inputBlur\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, inject, ref, watch } from 'vue'\nimport { useEmitEvent, usePickComponentStyle } from '@/hooks'\nimport { Input as AInput } from 'ant-design-vue'\nimport 'ant-design-vue/es/input/style'\nimport { inputComponentProps } from './props'\nimport { GLOBAL_MODEL } from '@/utils/constant'\nimport { debounce } from 'lodash-es'\nexport default defineComponent({\n name: 'EcanInput',\n components: {\n AInput\n },\n props: {\n ...inputComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const myValue = ref<string>('')\n watch(() => props.value, (value: string) => {\n myValue.value = value\n }, {\n immediate: true\n })\n const id = props.id as string\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n // 初始化设置值\n setGlobalModel(props.id as string, {\n type: props.type,\n value: myValue\n })\n const handleSetGlobalModel = () => {\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: myValue })\n }\n // 注册函数触发事件拦截器\n const emitEvent = useEmitEvent(props)\n const inputChange = debounce(emitEvent('inputChange', () => {\n handleSetGlobalModel()\n }), 300)\n const inputBlur = emitEvent('inputBlur', () => {\n })\n return {\n style,\n myValue,\n inputBlur,\n inputChange\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.ecan-input {\n .ant-input {\n width: 100%;\n height: 100%;\n }\n}\n\n[datav-theme='light'] .ecan-input {\n .ant-input{\n color: rgba(0, 0, 0, 0.65);\n background-color: #ffffff;\n border: 1px solid #d9d9d9;\n }\n}\n\n[datav-theme='darkBlue'] .ecan-input {\n .ant-input{\n border: 1px solid #1f63a3;\n background-color: #05164c;\n box-shadow: inset 0 0 10px #005efe;\n color: #ffffff;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Input from './Input.vue'\nexport const EcanInput = withInstall(Input)\nexport default EcanInput\nexport * from './props'\n","import {\n Props,\n EventsProp,\n props,\n transformToComponentProps\n} from '@/utils/props'\nexport interface DatePickerProps extends Props, EventsProp {\n value: string\n picker: 'date' | 'week' | 'month' | 'quarter' | 'year'\n format: string\n showTime: boolean // 增加时间选择功能\n useCurrentTime: boolean\n}\n\nexport const datePickerProps: DatePickerProps = {\n ...props,\n height: '33px',\n width: '130px',\n id: '',\n left: '0px',\n top: '0px',\n name: '日期选择器',\n keyName: '日期选择器',\n rotate: '',\n type: 'ecanDatePicker',\n value: '',\n picker: 'date',\n format: 'YYYY-MM-DD',\n showTime: false,\n useCurrentTime: true\n}\nexport const datePickerComponentProps = transformToComponentProps(datePickerProps)\n\nexport const datePickerEvents = ['dateChange']\n","<template>\n <div\n class=\"ecan-date-picker\"\n :style=\"style\"\n >\n <!-- 宽度style有效,class无效 -->\n <a-date-picker\n class=\"date-picker\"\n dropdownClassName=\"ecan-date-picker-dropdown\"\n v-model:value=\"myValue\"\n :format=\"format\"\n :picker=\"picker\"\n :showTime=\"showTime\"\n :locale=\"locale\"\n @change=\"dateChange\"\n :getPopupContainer=\"getPopupContainer\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, inject, ref, watch } from 'vue'\nimport { datePickerComponentProps } from './props'\nimport { DatePicker as ADatePicker } from 'ant-design-vue'\nimport 'ant-design-vue/es/date-picker/style'\nimport { usePickComponentStyle, useOnEvent, useEmitEvent } from '@/hooks'\nimport locale from 'ant-design-vue/es/date-picker/locale/zh_CN'\nimport dayjs, { Dayjs } from 'dayjs'\nimport { GLOBAL_MODEL } from '@/utils/constant'\nexport default defineComponent({\n name: 'EcanDatePicker',\n props: {\n ...datePickerComponentProps\n },\n components: {\n ADatePicker\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const getPopupContainer = () => document.getElementById('ProviderConfig') || document.body\n const myValue = ref<Dayjs | null>(null)\n watch(() => [props.value, props.useCurrentTime], ([value, useCurrentTime]: [string, boolean]) => {\n let _value: Dayjs = null\n if (value) {\n _value = dayjs(value)\n } else if (useCurrentTime) {\n _value = dayjs()\n }\n myValue.value = _value\n }, {\n immediate: true\n })\n const { setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n // 初始化设置值\n setGlobalModel(props.id as string, {\n type: props.type,\n format: props.format,\n value: myValue\n })\n // 注册函数触发事件拦截器\n const emitEvent = useEmitEvent(props)\n const dateChange = emitEvent('dateChange', () => {\n })\n // TODO 传入需要注册的参数\n useOnEvent(props, {\n dateChange\n })\n return {\n style,\n getPopupContainer,\n myValue,\n locale,\n dateChange\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.ecan-date-picker {\n .date-picker {\n width: 100%;\n height: 100%\n }\n}\n[datav-theme='light'] .ecan-date-picker {\n .ant-picker {\n background-color: #ffffff;\n color: rgba(0, 0, 0, 0.85);\n border: 1px solid #d9d9d9;\n }\n .ant-picker-input > input {\n color: rgba(0, 0, 0, 0.85);\n }\n .anticon-calendar {\n color: #333;\n }\n .anticon-close-circle {\n color: #333;\n }\n\n .ant-picker-input > input::placeholder {\n color: #bfbfbf;\n }\n}\n[datav-theme='darkBlue'] .ecan-date-picker {\n .ant-picker {\n background-color: #05164c;\n border: 1px solid #1f63a3;\n color: #fff;\n box-shadow: inset 0 0 10px #005efe;\n }\n .ant-picker-input > input {\n color: #ffffff;\n }\n .anticon-calendar {\n color: #ffffff;\n }\n .anticon-close-circle {\n color: #333;\n }\n}\n[datav-theme='darkBlue'] .ecan-date-picker-dropdown {\n .ant-picker-panel {\n background: #05174e;\n border-bottom: 1px solid #69befa;\n }\n .ant-picker-header {\n color: #69befa;\n border-bottom: 1px solid #69befa;\n }\n .ant-picker-panel .ant-picker-footer {\n border-top: 1px solid #69befa;\n }\n .ant-picker-header button {\n color: #69befa;\n }\n .ant-picker-content th {\n color: #69befa;\n }\n .ant-picker-content td {\n color: #69befa;\n }\n .ant-picker-today-btn {\n color: #69befa;\n }\n .ant-picker-cell:hover:not(.ant-picker-cell-in-view) .ant-picker-cell-inner, .ant-picker-cell:hover:not(.ant-picker-cell-selected):not(.ant-picker-cell-range-start):not(.ant-picker-cell-range-end):not(.ant-picker-cell-range-hover-start):not(.ant-picker-cell-range-hover-end) .ant-picker-cell-inner {\n background: #1890ff;\n color: #ffffff;\n }\n .ant-picker-time-panel-column > li.ant-picker-time-panel-cell .ant-picker-time-panel-cell-inner {\n color: #69befa;\n }\n .ant-picker-time-panel-column > li.ant-picker-time-panel-cell .ant-picker-time-panel-cell-inner:hover {\n background: #1890ff;\n color: #ffffff;\n }\n\n .ant-picker-time-panel-column > li.ant-picker-time-panel-cell-selected .ant-picker-time-panel-cell-inner {\n background: #1890ff;\n color: #ffffff;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport DatePicker from './DatePicker.vue'\nexport const EcanDatePicker = withInstall(DatePicker)\nexport default EcanDatePicker\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface SelectOption {\n value: any\n label: string\n disabled?: boolean\n key?: string\n title?: string\n}\n\nexport type SelectOptions = SelectOption []\n\nexport interface SelectProps extends Props {\n data: SelectOptions // 同 options\n value: string,\n dataFieldNames: { label: string, value: string }\n mode: 'multiple' | 'tags' | 'combobox' | undefined\n maxTagCount: number | undefined\n}\n\nexport const selectProps: SelectProps = {\n ...props,\n name: '选择器',\n keyName: '选择器',\n width: '120px',\n height: '33px',\n type: 'ecanSelect',\n mode: undefined,\n data: [\n { label: '选项一', value: '1' },\n { label: '选项二', value: '2' },\n { label: '选项三', value: '3' }\n ],\n value: '',\n dataFieldNames: { label: 'label', value: 'value' },\n maxTagCount: undefined\n}\n\nexport const selectComponentProps = transformToComponentProps(selectProps)\n\nexport const selectEvents = ['selectChange']\n","<template>\n <div\n class=\"ecan-select\"\n :style=\"style\"\n >\n <a-select\n class=\"select\"\n v-model:value=\"myValue\"\n :options=\"options\"\n :mode=\"mode\"\n :getPopupContainer=\"getPopupContainer\"\n :field-names=\"dataFieldNames\"\n :maxTagCount=\"maxTagCount\"\n show-search\n :filter-option=\"filterOption\"\n @change=\"selectChange\"\n :loading=\"loading\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, inject, ref, unref } from 'vue'\nimport { Select as ASelect } from 'ant-design-vue'\nimport 'ant-design-vue/es/select/style'\nimport { selectComponentProps, SelectOptions } from './props'\nimport { useEmitEvent, useOnEvent, usePickComponentStyle, useRequestData } from '@/hooks'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport { RequestModalParam } from '@/utils/types'\nexport default defineComponent({\n name: 'EcanSelect',\n components: {\n ASelect\n },\n props: {\n ...selectComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n // 挂在在 ProviderConfig 或者 body 下\n const getPopupContainer = () => document.getElementById('ProviderConfig') || document.body\n const requestData = useRequestData(props)\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n const options = ref(props.data as SelectOptions)\n const myValue = ref(props.value || props.data[0])\n const dataFieldNames = props.dataFieldNames as { label:string, value:string }\n const filterOption = (input: string, option: any) => {\n const labelKey = dataFieldNames.label\n const valueKey = dataFieldNames.value\n let value: string | undefined\n // 没有 label 值才用 value\n // ant-select 组件如果没有传 label 值会使用 value 作为值\n const labelValue = option[labelKey]\n const valueValue = option[valueKey]\n if (labelValue != null) {\n value = labelValue\n } else if (valueValue != null) {\n value = valueValue\n }\n return !!(value?.toLowerCase().indexOf(input?.toLowerCase()) >= 0)\n }\n const loading = ref(false)\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n loading.value = true\n try {\n const res = await requestData()\n options.value = res?.data?.data?.rows || []\n const firstOption = unref(options)[0]\n if (props.value === '' && firstOption != null) {\n myValue.value = firstOption[dataFieldNames.value]\n }\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n // 初始化设置值\n setGlobalModel(props.id as string, {\n type: props.type,\n value: myValue\n })\n // 注册函数触发事件拦截器\n const emitEvent = useEmitEvent(props)\n const selectChange = emitEvent('selectChange', () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: myValue })\n })\n // TODO 传入需要注册的参数\n useOnEvent(props, {\n selectChange\n })\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n setRequest({\n id: props.id as string,\n requestFn: handleRequestData,\n sortNum: props.requestSort as number\n })\n return {\n style,\n getPopupContainer,\n myValue,\n selectChange,\n options,\n filterOption,\n loading\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.select {\n width: 100%;\n height: 100%;\n}\n</style>\n\n<style lang=\"less\">\n.ecan-select {\n .ant-select {\n height: 100% !important;\n width: 100% !important;\n }\n .ant-select-selector {\n height: 100% !important;\n width: 100% !important;\n display: flex;\n align-items: center;\n input {\n height: 100% !important;\n }\n }\n}\n\n[datav-theme='light'] {\n .ant-select:not(.ant-select-customize-input) .ant-select-selector {\n border: 1px solid #d9d9d9;\n }\n .ant-select-dropdown {\n color: rgba(0, 0, 0, 0.85);\n background: #ffffff;\n box-shadow: 0 2px 8px rgb(0 0 0 / 15%);\n }\n .ant-empty-img-simple-g {\n stroke: #d9d9d9;\n }\n .ant-empty-img-simple-ellipse {\n fill: #f5f5f5;\n }\n .ant-empty-img-simple-path {\n fill: #f5f5f5;\n stroke: #d9d9d9;\n }\n .ant-empty-description {\n color: rgba(0, 0, 0, 0.25);\n }\n .anticon-down {\n color: #333;\n }\n}\n\n[datav-theme='darkBlue'] {\n .ant-select:not(.ant-select-customize-input) .ant-select-selector {\n border: 1px solid #1f63a3;\n background-color: #05164c;\n box-shadow: inset 0 0 10px #005efe;\n color: #ffffff;\n }\n .ant-select-dropdown {\n box-shadow: inset 0 0 10px #005efe;\n color: #fff;\n background-color: #05164c;\n }\n .ant-empty-img-simple-g {\n stroke: #69befa;\n }\n .ant-empty-img-simple-ellipse {\n fill-opacity: 0;\n }\n .ant-empty-img-simple-path {\n fill: #69befa;\n stroke: #69befa;\n }\n .ant-empty-description {\n color: #69befa;\n }\n .anticon-down {\n color: #ffffff;\n }\n .ant-select-item {\n color: #ffffff;\n }\n .ant-select-item-option-active {\n background: #1f63a3;\n }\n .ant-select-item-option-selected:not(.ant-select-item-option-disabled) {\n background: #1f63a3;\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport Select from './Select.vue'\nexport const EcanSelect = withInstall(Select)\nexport default EcanSelect\nexport * from './props'\n","import { Props, props, transformToComponentProps } from '@/utils/props'\nimport { ManipulateType } from 'dayjs'\n\nexport interface RangePickerProps extends Props {\n picker: 'date' | 'week' | 'month' | 'quarter' | 'year'\n format: string\n startTime: string // 开始时间\n endTime: string // 结束时间\n useCurrentTime: boolean\n interval: number\n intervalUnit: ManipulateType\n}\n\nexport const rangePickerProps: RangePickerProps = {\n ...props,\n name: '范围选择器',\n keyName: '范围选择器',\n type: 'ecanRangePicker',\n width: '250px',\n height: '35px',\n picker: 'date',\n format: 'YYYY-MM-DD',\n startTime: '',\n endTime: '',\n useCurrentTime: true,\n interval: 1,\n intervalUnit: 'year'\n}\n\nexport const rangePickerComponentProps = transformToComponentProps(rangePickerProps)\n\nexport const rangePickerEvents = ['dateChange']\n","<template>\n <div\n class=\"ecan-range-picker\"\n :style=\"style\"\n >\n <a-range-picker\n class=\"range-picker\"\n dropdownClassName=\"ecan-range-picker-dropdown\"\n v-model:value=\"myValue\"\n :format=\"format\"\n :picker=\"picker\"\n :locale=\"locale\"\n :getPopupContainer=\"getPopupContainer\"\n @change=\"dateChange\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, unref, watch, ref } from 'vue'\nimport { rangePickerComponentProps } from './props'\nimport { useEmitEvent, useOnEvent, usePickComponentStyle } from '@/hooks'\nimport { RangePicker as ARangePicker } from 'ant-design-vue'\nimport locale from 'ant-design-vue/es/date-picker/locale/zh_CN'\n// antdv 中 range-picker 组件与 date-picker 共用一个样式\nimport 'ant-design-vue/es/date-picker/style'\nimport { GLOBAL_MODEL } from '@/utils/constant'\nimport dayjs, { Dayjs, ManipulateType } from 'dayjs'\nexport default defineComponent({\n name: 'EcanRangePicker',\n components: {\n ARangePicker\n },\n props: {\n ...rangePickerComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const getPopupContainer = () => document.getElementById('ProviderConfig') || document.body\n const myValue = ref<[Dayjs, Dayjs]>([null, null])\n watch(() => [props.startTime, props.endTime, props.useCurrentTime, props.interval, props.intervalUnit], ([startTime, endTime, useCurrentTime, interval, intervalUnit]: [string, string, boolean, number, ManipulateType]) => {\n let _startTime: Dayjs = null\n let _endTime: Dayjs = null\n if (useCurrentTime) {\n _startTime = dayjs().subtract(interval, intervalUnit)\n _endTime = dayjs()\n }\n if (startTime) {\n _startTime = dayjs(startTime)\n }\n if (endTime) {\n _endTime = dayjs(endTime)\n }\n myValue.value = [_startTime, _endTime]\n }, {\n immediate: true\n })\n const { setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n const myStartTime = computed(() => unref(myValue)[0])\n const myEndTime = computed(() => unref(myValue)[1])\n // 初始化设置值\n setGlobalModel(props.id as string, {\n type: props.type,\n format: props.format,\n startTime: myStartTime,\n endTime: myEndTime\n })\n // 注册函数触发事件拦截器\n const emitEvent = useEmitEvent(props)\n const dateChange = emitEvent('dateChange', () => {})\n useOnEvent(props, {\n dateChange\n })\n return {\n style,\n getPopupContainer,\n locale,\n dateChange,\n myValue\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.range-picker {\n width: 100%;\n height: 100%;\n}\n</style>\n\n<style lang=\"less\">\n[datav-theme='light'] .ecan-range-picker{\n .ant-picker {\n background-color: #ffffff;\n color: rgba(0, 0, 0, 0.85);\n border: 1px solid #d9d9d9;\n }\n .ant-picker-input > input {\n color: rgba(0, 0, 0, 0.85);\n }\n .anticon-calendar {\n color: #333;\n }\n .anticon-close-circle {\n color: #333;\n }\n .ant-picker-input > input::placeholder {\n color: #bfbfbf;\n }\n .ant-picker-separator .anticon {\n color:#333;\n }\n}\n\n[datav-theme='darkBlue'] .ecan-range-picker {\n .ant-picker {\n background-color: #05164c;\n border: 1px solid #1f63a3;\n color: #fff;\n box-shadow: inset 0 0 10px #005efe;\n }\n .ant-picker-input > input {\n color: #ffffff;\n }\n .anticon-calendar {\n color: #ffffff;\n }\n .anticon-close-circle {\n color: #333;\n }\n .ant-picker-separator .anticon {\n color:#fff;\n }\n}\n\n[datav-theme='darkBlue'] .ecan-range-picker-dropdown {\n .ant-picker-panel {\n background: #05174e;\n border-bottom: 1px solid #69befa;\n }\n .ant-picker-header {\n color: #69befa;\n border-bottom: 1px solid #69befa;\n }\n .ant-picker-panel .ant-picker-footer {\n border-top: 1px solid #69befa;\n }\n .ant-picker-header button {\n color: #69befa;\n }\n .ant-picker-content th {\n color: #69befa;\n }\n .ant-picker-content td {\n color: #69befa;\n }\n .ant-picker-today-btn {\n color: #69befa;\n }\n .ant-picker-cell-disabled .ant-picker-cell-inner {\n color: #999;\n }\n .ant-picker-cell-disabled::before {\n background: #333;\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport RangePicker from './RangePicker.vue'\nexport const EcanRangePicker = withInstall(RangePicker)\nexport default EcanRangePicker\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface ButtonProps extends Props {\n text: string\n mode: 'primary' | 'dashed' | 'link' | 'text' | 'default'\n danger: boolean\n shape: 'default' | 'circle' | 'round'\n href: string\n target: 'self' | 'blank' | 'event'\n fontSize: string\n fontWeight: number\n}\n\nexport const buttonProps: ButtonProps = {\n ...props,\n width: '200px',\n name: '按钮',\n keyName: '按钮',\n type: 'ecanButton',\n text: '按钮',\n mode: 'default',\n danger: false,\n shape: 'default',\n href: '',\n target: 'self',\n fontSize: '14px',\n fontWeight: 400\n}\n\n// 转化默认属性\nexport const buttonComponentProps = transformToComponentProps(buttonProps)\n\nexport const buttonEvents = ['click']\n","<template>\n <div\n class=\"ecan-button\"\n :style=\"style\"\n >\n <a-button\n block\n @click=\"click\"\n :type=\"mode\"\n :danger=\"danger\"\n :shape=\"shape\"\n :href=\"myHref\"\n :target=\"myTarget\"\n >\n <span\n :style=\"{\n fontSize,\n fontWeight\n }\"\n >\n {{ myText }}\n </span>\n </a-button>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, unref } from 'vue'\nimport { usePickComponentStyle, useEmitEvent, useVariablesInText } from '@/hooks'\nimport { Button as AButton } from 'ant-design-vue'\nimport 'ant-design-vue/es/button/style'\nimport { buttonComponentProps } from './props'\nexport default defineComponent({\n name: 'EcanButton',\n components: {\n AButton\n },\n props: {\n ...buttonComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n // 拦截触发事件\n const emitEvent = useEmitEvent(props)\n // click 是 event 名称\n const click = emitEvent('click', () => {\n // 打开链接\n const url = unref(myHref)\n if (url && props.target === 'event') {\n window.parent.postMessage({\n type: 'openPage',\n url\n }, '*')\n }\n })\n\n const myText = computed(() => useVariablesInText(props.text as string))\n // 空字符串会刷新页面\n const myHref = computed(() => useVariablesInText(props.href as string) || null)\n const myTarget = computed(() => {\n const target = props.target as 'self' | 'blank' | 'event'\n if (target === 'event' || unref(myHref) == null) {\n return undefined\n } else {\n const map = {\n self: '_self',\n blank: '_blank'\n }\n return map[target]\n }\n })\n return {\n style,\n click,\n myText,\n myHref,\n myTarget\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.ecan-button {\n .ant-btn {\n width: 100%;\n height: 100%;\n display: flex;\n justify-content: center;\n align-items: center;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Button from './Button.vue'\nexport const EcanButton = withInstall(Button)\nexport default EcanButton\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport type CheckboxOptions = {\n label: string\n value: string\n disabled?: boolean\n checked?: boolean\n indeterminate?: boolean\n} []\n\nexport interface CheckboxProps extends Props {\n value: string | string []\n data: CheckboxOptions\n}\n\nexport const checkboxProps: CheckboxProps = {\n ...props,\n width: '240px',\n id: '',\n left: '0px',\n top: '0px',\n name: '复选框',\n keyName: '复选框',\n rotate: '',\n type: 'ecanCheckbox',\n value: [],\n data: [\n { label: '选项一', value: '1', checked: true },\n { label: '选项二', value: '2', checked: true },\n { label: '选项三', value: '3' }\n ]\n}\n\n// 转化默认属性\nexport const checkboxComponentProps = transformToComponentProps(checkboxProps)\n\nexport const checkboxEvents = ['checkboxChange']\n","<template>\n <div class=\"ecan-checkbox\" :style=\"style\">\n <a-checkbox-group\n :options=\"myOption\"\n v-model:value=\"myValue\"\n @change=\"checkboxChange\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, inject, ref, unref, watch } from 'vue'\nimport { CheckboxGroup as ACheckboxGroup } from 'ant-design-vue'\nimport 'ant-design-vue/es/checkbox/style'\nimport { checkboxComponentProps, CheckboxOptions } from './props'\nimport { useEmitEvent, usePickComponentStyle, useRequestData } from '@/hooks'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport { RequestModalParam } from '@/utils/types'\nexport default defineComponent({\n name: 'EcanCheckbox',\n components: {\n ACheckboxGroup\n },\n props: {\n ...checkboxComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const myOption = ref<CheckboxOptions>([])\n const myValue = ref<string []>([])\n const handleDataAndOption = (data) => {\n const value = props.value\n let _value = [] as string []\n data.forEach((item) => {\n if (item.checked) {\n _value.push(item.value)\n }\n })\n if (typeof value === 'string' && value !== '') {\n _value = _value.concat(value.split(','))\n } else if (Array.isArray(value)) {\n _value = _value.concat(value)\n }\n myOption.value = data\n myValue.value = _value\n }\n watch(() => [props.data, props.value], ([data]: [CheckboxOptions, string | string []]) => {\n handleDataAndOption(data)\n }, {\n immediate: true,\n deep: true\n })\n const requestData = useRequestData(props)\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n const res = await requestData()\n const data = res?.data?.data?.rows || []\n handleDataAndOption(data)\n }\n const id = props.id as string\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n // 初始化设置值\n setGlobalModel(props.id as string, {\n type: props.type,\n value: myValue\n })\n // 注册函数触发事件拦截器\n const emitEvent = useEmitEvent(props)\n const checkboxChange = emitEvent('checkboxChange', () => {\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: myValue })\n })\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n setRequest({\n id: props.id as string,\n requestFn: handleRequestData,\n sortNum: props.requestSort as number\n })\n return {\n myOption,\n style,\n myValue,\n checkboxChange\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.ecan-checkbox {\n .ant-checkbox-group {\n width: 100%;\n height: 100%;\n display: flex;\n justify-content: space-between;\n align-content: space-between;\n flex-wrap: wrap;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Checkbox from './Checkbox.vue'\nexport const EcanCheckbox = withInstall(Checkbox)\nexport default EcanCheckbox\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps,\n Data,\n ValueTypeDataFieldNames\n} from '@/utils/props'\n\nexport interface PieProps extends Props {\n data: Data\n titleText: string\n titleSubtext: string\n titleLeft: string\n colors: string[]\n backgroundColor: string\n tooltipShow: boolean\n tooltipTrigger: 'item' | 'axis' | 'none'\n tooltipTextStyleColor: string\n tooltipFormatter: string\n legendShow: boolean\n legendLeft: 'left' | 'center' | 'right'\n legendTop: 'top' | 'middle' | 'bottom'\n legendOrient: 'vertical' | 'horizontal'\n legendTextStyleColor: string\n innerRadius: string\n outerRadius: string\n centerLeft: string\n centerTop: string\n labelShow: boolean\n labelFormatter: string\n labelFontSize: number\n labelPosition: 'outside' | 'inside' | 'center'\n labelLineShow: boolean\n labelColor: string\n isUseLabelColors: boolean\n labelLineLength: number\n labelLineLength2: number\n roseType: '' | 'radius' | 'area'\n valueTypeDataFieldNames: ValueTypeDataFieldNames,\n dataFieldConfigType: 'key' | 'value',\n gridContainLabel: boolean\n gridTop: string\n gridBottom: string\n gridLeft: string\n gridRight: string\n graphicConfig?: any\n toolboxShow: boolean\n toolboxOrient: 'horizontal' | 'vertical'\n toolboxItemSize: number // 工具栏 icon 的大小。\n toolboxItemGap: number // 工具栏 icon 每项之间的间隔。横向布局时为水平间隔,纵向布局时为纵向间隔。\n toolboxLeft: 'left' | 'center' | 'right'\n toolboxTop: 'top'| 'middle'| 'bottom'\n toolboxIconStyleBorderColor: string\n toolboxDownloadUrl: string\n toolboxInfoText: string\n}\n\nexport const pieProps: PieProps = {\n ...props,\n id: '',\n name: '饼图',\n keyName: '饼图',\n type: 'ecanPie',\n width: '400px',\n height: '400px',\n top: '',\n left: '',\n rotate: '',\n data: [\n { name: '名称一', value: 335 },\n { name: '名称二', value: 310 },\n { name: '名称三', value: 234 }\n ],\n titleText: '',\n titleSubtext: '',\n titleLeft: '',\n colors: ['#5470c6', '#91cc75', '#fac858', '#ee6666', '#73c0de', '#3ba272', '#fc8452', '#9a60b4', '#ea7ccc'],\n backgroundColor: '',\n tooltipShow: true,\n tooltipTextStyleColor: '',\n tooltipTrigger: 'item',\n tooltipFormatter: '{marker} {b} {c} ({d}%)',\n legendShow: true,\n legendTextStyleColor: '#333',\n legendOrient: 'vertical',\n legendTop: 'top',\n legendLeft: 'left',\n innerRadius: '0%',\n outerRadius: '60%',\n centerLeft: '50%',\n centerTop: '50%',\n labelShow: true,\n labelColor: '#333',\n isUseLabelColors: false,\n labelFontSize: 12,\n labelPosition: 'outside',\n labelFormatter: '{b}\\\\n{d}%',\n labelLineShow: true,\n labelLineLength: 10,\n labelLineLength2: 15,\n roseType: '',\n valueTypeDataFieldNames: { name: 'name', value: 'value', type: 'type' },\n dataFieldConfigType: 'value',\n gridContainLabel: true,\n gridTop: '10%',\n gridBottom: '10%',\n gridLeft: '5%',\n gridRight: '5%',\n graphicConfig: {},\n toolboxShow: false,\n toolboxOrient: 'horizontal',\n toolboxItemSize: 16,\n toolboxItemGap: 8,\n toolboxLeft: 'right',\n toolboxTop: 'top',\n toolboxIconStyleBorderColor: '#666',\n toolboxDownloadUrl: '',\n toolboxInfoText: '当前无说明信息'\n}\n// 转化默认属性\nexport const pieComponentProps = transformToComponentProps(pieProps)\n\nexport const pieEvents: Array<string> = ['click', 'refreshData', 'resetRecord']\n","import request from '@/utils/request'\nexport const useDownloadFile = async (downloadFileUrl: string) => {\n const res = await request.post(downloadFileUrl, {}, {\n responseType: 'blob'\n }) as any\n const { data, headers } = res\n const fileName = headers['content-disposition'].replace(/\\w+;filename=(.*)/, '$1')\n const blob = new Blob([data])\n const dom = document.createElement('a')\n const url = window.URL.createObjectURL(blob)\n dom.href = url\n dom.download = decodeURI(fileName)\n dom.style.display = 'none'\n document.body.appendChild(dom)\n dom.click()\n dom.parentNode?.removeChild(dom)\n window.URL.revokeObjectURL(url)\n}\nexport default useDownloadFile\n","<template>\n <div :style=\"style\">\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n autoresize\n @click=\"click\"\n />\n </spin>\n <a-modal\n wrap-class-name=\"full-modal\"\n width=\"100%\"\n :visible=\"visible\"\n :footer=\"null\"\n @cancel=\"hideModal\"\n >\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n />\n </spin>\n </a-modal>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, computed, watch, inject, ref, unref } from 'vue'\nimport {\n useEmitEvent,\n usePickComponentStyle,\n useRequestData,\n useTransformChartDataByAttrValue,\n useOnEvent,\n useRequestDiagramData,\n useVariablesInText\n} from '@/hooks'\nimport Echarts from '@/common/echarts'\nimport { pieComponentProps } from './props'\nimport { use } from 'echarts/core'\nimport { CanvasRenderer } from 'echarts/renderers'\nimport { PieChart } from 'echarts/charts'\nimport { TitleComponent, TooltipComponent, LegendComponent, ToolboxComponent } from 'echarts/components'\nimport { handleFormatter } from '@/utils/util'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport { ValueTypeDataFieldNames } from '@/utils/props'\nimport Spin from '@/common/spin'\nimport { Modal as AModal } from 'ant-design-vue'\nimport useDownloadFile from '@/hooks/useDownloadFile'\nimport { RequestModalParam } from '@/utils/types'\nuse([\n CanvasRenderer,\n PieChart,\n TitleComponent,\n ToolboxComponent,\n TooltipComponent,\n LegendComponent\n])\nexport default defineComponent({\n name: 'EcanPie',\n props: {\n ...pieComponentProps\n },\n components: {\n Spin,\n Echarts,\n AModal\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const dataset = ref<{ [key: string]: any }[]>([])\n const visible = ref(false)\n const hideModal = () => {\n visible.value = false\n }\n const option = computed(() => {\n let { data = [] } = unref(dataset)[0] || {}\n if (Array.isArray(props.colors)) {\n const isUseLabelColors = props.isUseLabelColors\n const colors = props.colors\n data = data.map((item, index) => ({\n label: isUseLabelColors ? { color: colors[index] } : {},\n ...item\n }))\n }\n return {\n toolbox: {\n show: props.toolboxShow,\n left: props.toolboxLeft,\n top: props.toolboxTop,\n itemSize: props.toolboxItemSize,\n itemGap: props.toolboxItemGap,\n feature: {\n myDownload: {\n show: true,\n title: '数据下载',\n icon: 'path://M502.010485 765.939573c3.773953 3.719718 8.686846 5.573949 13.596669 5.573949 0.075725 0 0.151449-0.010233 0.227174-0.011256 0.329505 0.016373 0.654916 0.050142 0.988514 0.050142 0.706081 0 1.400906-0.042979 2.087545-0.116657 4.352121-0.366344 8.607028-2.190899 11.961426-5.496178l335.053985-330.166675c7.619538-7.509021 7.709589-19.773346 0.200568-27.393907s-19.774369-7.711636-27.39493-0.201591L536.193005 706.304358 536.193005 50.019207c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 657.032164-306.881342-302.44838c-7.618515-7.509021-19.883863-7.419993-27.393907 0.199545-7.509021 7.619538-7.419993 19.884886 0.199545 27.393907L502.010485 765.939573z, M867.170139 711.020776c-10.698666 0-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 13.054317-10.620895 23.675212-23.676236 23.675212L205.182103 919.486668c-13.054317 0-23.676236-10.620895-23.676236-23.675212L181.505867 730.391962c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 34.416857 28.000728 62.416562 62.417585 62.416562l618.941638 0c34.417881 0 62.417585-27.999704 62.417585-62.416562L886.540302 730.391962C886.541325 719.693296 877.868805 711.020776 867.170139 711.020776z',\n onclick () {\n useDownloadFile(props.toolboxDownloadUrl as string)\n }\n },\n myDataZoom: {\n show: true,\n title: '放大',\n icon: 'path://M932.42 902.246667L792 761.793333A403.84 403.84 0 0 0 896 490.666667c0-223.86-181.473333-405.333333-405.333333-405.333334S85.333333 266.806667 85.333333 490.666667s181.473333 405.333333 405.333334 405.333333a403.84 403.84 0 0 0 271.126666-104l140.453334 140.453333a21.333333 21.333333 0 0 0 30.173333-30.173333zM128 490.666667c0-200.293333 162.373333-362.666667 362.666667-362.666667s362.666667 162.373333 362.666666 362.666667-162.373333 362.666667-362.666666 362.666666-362.666667-162.373333-362.666667-362.666666z m512 0a21.333333 21.333333 0 0 1-21.333333 21.333333H512v106.666667a21.333333 21.333333 0 0 1-42.666667 0V512H362.666667a21.333333 21.333333 0 0 1 0-42.666667h106.666666V362.666667a21.333333 21.333333 0 0 1 42.666667 0v106.666666h106.666667a21.333333 21.333333 0 0 1 21.333333 21.333334z',\n onclick () {\n visible.value = true\n }\n },\n myInfo: {\n show: true,\n title: '说明信息',\n icon: 'path://M512.50142 958.397886c-119.320573 0-231.499491-46.465265-315.871087-130.837884C112.258737 743.188406 65.792449 631.010511 65.792449 511.688915c0-119.319549 46.466288-231.499491 130.837884-315.871087C281.002952 111.445208 393.180847 64.979944 512.50142 64.979944s231.499491 46.465265 315.871087 130.837884c84.372619 84.372619 130.837884 196.551538 130.837884 315.871087 0 119.321596-46.465265 231.499491-130.837884 315.871087C744.000911 911.932622 631.821993 958.397886 512.50142 958.397886zM512.50142 105.962334c-223.718271 0-405.726581 182.00831-405.726581 405.726581s182.00831 405.726581 405.726581 405.726581c223.718271 0 405.727605-182.00831 405.727605-405.726581S736.220714 105.962334 512.50142 105.962334z M510.150886 775.953647c-18.107403 0-32.745798-14.678304-32.745798-32.785707L477.405087 452.191846c0-18.108426 14.638395-32.785707 32.745798-32.785707 18.107403 0 32.745798 14.678304 32.745798 32.785707l0 290.976094C542.896684 761.275343 528.258289 775.953647 510.150886 775.953647z M511.357364 296.458969m-45.080731 0a44.054 44.054 0 1 0 90.161463 0 44.054 44.054 0 1 0-90.161463 0Z',\n onclick () {\n AModal.info({\n title: '说明信息',\n content: (props.toolboxInfoText as string)\n })\n }\n }\n }\n },\n title: {\n text: props.titleText,\n subtext: props.titleSubtext,\n left: 'center'\n },\n grid: {\n top: props.gridTop,\n bottom: props.gridBottom,\n left: props.gridLeft,\n right: props.gridRight,\n containLabel: props.gridContainLabel\n },\n // 提示\n tooltip: {\n show: props.tooltipShow,\n trigger: props.tooltipTrigger,\n formatter: (params) => {\n const { marker, seriesName, name, value, percent, data } = params || {}\n return useVariablesInText(\n props.tooltipFormatter as string,\n {\n marker,\n name,\n value,\n percent,\n a: seriesName,\n b: name,\n c: value,\n d: percent,\n ...data\n },\n {\n useNewline: true,\n useSpace: true\n }\n )\n },\n textStyle: {\n color: props.tooltipTextStyleColor\n }\n },\n // 图例\n legend: {\n show: props.legendShow,\n orient: props.legendOrient,\n top: props.legendTop,\n left: props.legendLeft,\n textStyle: {\n color: props.legendTextStyleColor\n }\n },\n color: props.colors,\n series: [\n {\n data,\n type: 'pie',\n radius: [props.innerRadius, props.outerRadius],\n center: [props.centerLeft, props.centerTop],\n roseType: props.roseType,\n avoidLabelOverlap: false,\n // data: data.value,\n // data: props.data,\n // dimensions: ['name', 'count'],\n label: {\n show: props.labelPosition !== 'center' && props.labelShow,\n color: props.labelColor,\n fontSize: props.labelFontSize,\n position: props.labelPosition,\n formatter: handleFormatter(props.labelFormatter as string)\n },\n labelLine: {\n show: props.labelLineShow,\n length: props.labelLineLength,\n length2: props.labelLineLength2\n },\n emphasis: {\n itemStyle: {\n shadowBlur: 10,\n shadowOffsetX: 0,\n shadowColor: 'rgba(0, 0, 0, 0.5)'\n },\n label: {\n // show: props.labelPosition === 'center'\n }\n }\n }\n ]\n }\n })\n\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n\n const handleDataset = (data: any = [], dataFieldNames?: ValueTypeDataFieldNames) => {\n const { dataset: d } = useTransformChartDataByAttrValue(data, dataFieldNames)\n dataset.value = d\n }\n\n const handleIndicatorDataset = (data: any = [], dataFieldNames?: ValueTypeDataFieldNames) => {\n const chartData = useTransformChartDataByAttrValue(data, dataFieldNames)\n dataset.value = chartData.dataset\n }\n\n // 静态数据\n watch(() => props.data, (value: any) => {\n if (props.dataType === 'static' || unref(pageMode) === 'design') {\n handleDataset(value)\n }\n }, {\n immediate: true,\n deep: true\n })\n\n const loading = ref(false)\n const requestData = useRequestData(props)\n // 动态数据\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestData()\n handleDataset(res?.data?.data?.rows, props.valueTypeDataFieldNames as ValueTypeDataFieldNames)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const emitEvent = useEmitEvent(props)\n\n const click = emitEvent('click', (e) => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: e?.data })\n })\n\n // 指标库\n const requestDiagram = useRequestDiagramData(props)\n const handleIndicatorData = async () => {\n if (props.dataType !== 'indicator' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestDiagram()\n let newArr = []\n if (res?.data?.data?.columns?.length > 0) {\n const name = res.data.data.columns[0]\n const value = res.data.data.columns[1]\n newArr = res?.data?.data?.rows?.map(item => {\n return {\n name: item[name],\n value: item[value]\n }\n })\n }\n handleIndicatorDataset(newArr)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const chooseRequestOrDiagram = () => {\n if (unref(pageMode) === 'design') return\n handleIndicatorData()\n handleRequestData()\n }\n\n const refreshData = () => {\n chooseRequestOrDiagram()\n }\n\n const resetRecord = () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n setGlobalModel(id, { ...modal, RECORD: '' })\n }\n\n useOnEvent(props, {\n resetRecord,\n refreshData,\n click\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n setRequest({\n id: props.id as string,\n requestFn: chooseRequestOrDiagram,\n sortNum: props.requestSort as number\n })\n return {\n option,\n style,\n click,\n loading,\n visible,\n hideModal\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.full-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n height: calc(100vh);\n }\n .ant-modal-body {\n flex: 1;\n }\n\n .ant-modal-body {\n padding: 45px 30px 0;\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport Pie from './Pie.vue'\nexport const EcanPie = withInstall(Pie)\nexport default EcanPie\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps,\n Data,\n ValueTypeDataFieldNames,\n KeyTypeDataFieldNames\n} from '@/utils/props'\n\nexport interface LineProps extends Props {\n data: Data\n titleText: string\n titleSubtext: string\n titleLeft: string\n colors: string[]\n legendShow: boolean,\n legendLeft: 'left' | 'center' | 'right'\n legendTop: 'top' | 'middle' | 'bottom'\n legendOrient: 'vertical' | 'horizontal' // 标记点大小\n symbolSize: number // 线宽度\n lineStyleWidth: number // 线宽\n smooth: boolean // 光滑\n xAxisSplitLineShow: boolean // x轴展示分割线\n xAxisLabelColor: string // x轴名称颜色\n xAxisLineStyleColor: string // x轴名称颜色\n xAxisSplitLineStyleColor: string // x轴分割线颜色\n xAxisTickShow: boolean // 展示刻度\n xAxisLabelFormatter: string // 格式化\n yAxisSplitLineShow: boolean // y轴展示分割线\n yAxisSplitLineStyleColor: string // y轴分割线颜色\n yAxisLabelColor: string // y轴名称颜色\n yAxisLineStyleColor: string // y轴名称颜色\n yAxisLabelFormatter: string // 格式化\n valueTypeDataFieldNames: ValueTypeDataFieldNames\n keyTypeDataFieldNames: KeyTypeDataFieldNames\n dataFieldConfigType: 'key' | 'value'\n gridContainLabel: boolean\n gridTop: string\n gridBottom: string\n gridLeft: string\n gridRight: string\n graphicConfig?: any\n tooltipFormatter: string\n tooltipShow: boolean\n toolboxShow: boolean\n toolboxOrient: 'horizontal' | 'vertical'\n toolboxItemSize: number // 工具栏 icon 的大小。\n toolboxItemGap: number // 工具栏 icon 每项之间的间隔。横向布局时为水平间隔,纵向布局时为纵向间隔。\n toolboxLeft: 'left' | 'center' | 'right'\n toolboxTop: 'top'| 'middle'| 'bottom'\n toolboxIconStyleBorderColor: string\n toolboxDownloadUrl: string\n toolboxInfoText: string\n areaStyleOpacity: number\n}\n\nexport const lineProps: LineProps = {\n ...props,\n id: '',\n name: '折线图',\n keyName: '折线图',\n type: 'ecanLine',\n width: '400px',\n height: '400px',\n top: '',\n left: '',\n rotate: '',\n data: [\n { name: '名称一', value: 235, type: '类型一' },\n { name: '名称二', value: 280, type: '类型一' },\n { name: '名称三', value: 230, type: '类型一' },\n { name: '名称四', value: 335, type: '类型一' }\n ],\n titleText: '',\n titleSubtext: '',\n titleLeft: '',\n legendShow: true,\n legendOrient: 'horizontal',\n legendTop: 'top',\n legendLeft: 'center',\n colors: ['#5470c6', '#91cc75', '#fac858', '#ee6666', '#73c0de', '#3ba272', '#fc8452', '#9a60b4', '#ea7ccc'],\n symbolSize: 4,\n lineStyleWidth: 2,\n smooth: false,\n xAxisSplitLineShow: true,\n xAxisSplitLineStyleColor: '#333',\n xAxisLabelColor: '#333',\n xAxisLineStyleColor: '#333',\n xAxisTickShow: true,\n xAxisLabelFormatter: '{value}', // 格式化\n yAxisSplitLineShow: true,\n yAxisSplitLineStyleColor: '#333',\n yAxisLabelColor: '#333',\n yAxisLineStyleColor: '#333',\n yAxisLabelFormatter: '{value}',\n gridContainLabel: true,\n gridTop: '10%',\n gridBottom: '10%',\n gridLeft: '5%',\n gridRight: '5%',\n valueTypeDataFieldNames: { name: 'name', value: 'value', type: 'type' },\n keyTypeDataFieldNames: { name: 'name', types: [] },\n dataFieldConfigType: 'value',\n graphicConfig: {},\n tooltipShow: true,\n tooltipFormatter: '{marker} {a} {c}',\n toolboxShow: false,\n toolboxOrient: 'horizontal',\n toolboxItemSize: 16,\n toolboxItemGap: 8,\n toolboxLeft: 'right',\n toolboxTop: 'top',\n toolboxIconStyleBorderColor: '#666',\n toolboxDownloadUrl: '',\n toolboxInfoText: '当前无说明信息',\n areaStyleOpacity: 0\n}\n\n// 转化默认属性\nexport const lineComponentProps = transformToComponentProps(lineProps)\n\nexport const lineEvents = ['click', 'refreshData', 'resetRecord']\n","<template>\n <div :style=\"style\">\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n autoresize\n @click=\"click\"\n />\n </spin>\n <a-modal\n wrap-class-name=\"full-modal\"\n width=\"100%\"\n :visible=\"visible\"\n :footer=\"null\"\n @cancel=\"hideModal\"\n >\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n />\n </spin>\n </a-modal>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, ref, unref, watch } from 'vue'\nimport {\n useValueFormatter,\n useEmitEvent, useOnEvent,\n usePickComponentStyle,\n useRequestData, useRequestDiagramData,\n useTransformChartDataByAttrKey,\n useTransformChartDataByAttrValue, useVariablesInText\n} from '@/hooks'\nimport Echarts from '@/common/echarts'\nimport { lineComponentProps } from './props'\nimport { use } from 'echarts/core'\nimport { CanvasRenderer } from 'echarts/renderers'\nimport { LineChart } from 'echarts/charts'\nimport { TitleComponent, LegendComponent, ToolboxComponent } from 'echarts/components'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport { KeyTypeDataFieldNames, ValueTypeDataFieldNames } from '@/utils/props'\nimport Spin from '@/common/spin/Spin.vue'\nimport useDownloadFile from '@/hooks/useDownloadFile'\nimport { Modal as AModal } from 'ant-design-vue'\nimport { RequestModalParam } from '@/utils/types'\nuse([\n CanvasRenderer,\n LineChart,\n ToolboxComponent,\n TitleComponent,\n LegendComponent\n])\nexport default defineComponent({\n name: 'EcanLine',\n props: {\n ...lineComponentProps\n },\n components: {\n Spin,\n Echarts,\n AModal\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const series = ref<{ [key: string]: any }[]>([])\n const dimensions = ref<{ [key: string]: any }[]>([])\n const visible = ref(false)\n const hideModal = () => {\n visible.value = false\n }\n const option = computed(() => {\n // 这样写为了触发响应式\n // 返回函数中使用无法触发\n const xAxisLabelFormatter = props.xAxisLabelFormatter as string\n const yAxisLabelFormatter = props.yAxisLabelFormatter as string\n return {\n toolbox: {\n show: props.toolboxShow,\n left: props.toolboxLeft,\n top: props.toolboxTop,\n itemSize: props.toolboxItemSize,\n itemGap: props.toolboxItemGap,\n feature: {\n myDownload: {\n show: true,\n title: '数据下载',\n icon: 'path://M502.010485 765.939573c3.773953 3.719718 8.686846 5.573949 13.596669 5.573949 0.075725 0 0.151449-0.010233 0.227174-0.011256 0.329505 0.016373 0.654916 0.050142 0.988514 0.050142 0.706081 0 1.400906-0.042979 2.087545-0.116657 4.352121-0.366344 8.607028-2.190899 11.961426-5.496178l335.053985-330.166675c7.619538-7.509021 7.709589-19.773346 0.200568-27.393907s-19.774369-7.711636-27.39493-0.201591L536.193005 706.304358 536.193005 50.019207c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 657.032164-306.881342-302.44838c-7.618515-7.509021-19.883863-7.419993-27.393907 0.199545-7.509021 7.619538-7.419993 19.884886 0.199545 27.393907L502.010485 765.939573z, M867.170139 711.020776c-10.698666 0-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 13.054317-10.620895 23.675212-23.676236 23.675212L205.182103 919.486668c-13.054317 0-23.676236-10.620895-23.676236-23.675212L181.505867 730.391962c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 34.416857 28.000728 62.416562 62.417585 62.416562l618.941638 0c34.417881 0 62.417585-27.999704 62.417585-62.416562L886.540302 730.391962C886.541325 719.693296 877.868805 711.020776 867.170139 711.020776z',\n onclick () {\n useDownloadFile(props.toolboxDownloadUrl as string)\n }\n },\n myDataZoom: {\n show: true,\n title: '放大',\n icon: 'path://M932.42 902.246667L792 761.793333A403.84 403.84 0 0 0 896 490.666667c0-223.86-181.473333-405.333333-405.333333-405.333334S85.333333 266.806667 85.333333 490.666667s181.473333 405.333333 405.333334 405.333333a403.84 403.84 0 0 0 271.126666-104l140.453334 140.453333a21.333333 21.333333 0 0 0 30.173333-30.173333zM128 490.666667c0-200.293333 162.373333-362.666667 362.666667-362.666667s362.666667 162.373333 362.666666 362.666667-162.373333 362.666667-362.666666 362.666666-362.666667-162.373333-362.666667-362.666666z m512 0a21.333333 21.333333 0 0 1-21.333333 21.333333H512v106.666667a21.333333 21.333333 0 0 1-42.666667 0V512H362.666667a21.333333 21.333333 0 0 1 0-42.666667h106.666666V362.666667a21.333333 21.333333 0 0 1 42.666667 0v106.666666h106.666667a21.333333 21.333333 0 0 1 21.333333 21.333334z',\n onclick () {\n visible.value = true\n }\n },\n myInfo: {\n show: true,\n title: '说明信息',\n icon: 'path://M512.50142 958.397886c-119.320573 0-231.499491-46.465265-315.871087-130.837884C112.258737 743.188406 65.792449 631.010511 65.792449 511.688915c0-119.319549 46.466288-231.499491 130.837884-315.871087C281.002952 111.445208 393.180847 64.979944 512.50142 64.979944s231.499491 46.465265 315.871087 130.837884c84.372619 84.372619 130.837884 196.551538 130.837884 315.871087 0 119.321596-46.465265 231.499491-130.837884 315.871087C744.000911 911.932622 631.821993 958.397886 512.50142 958.397886zM512.50142 105.962334c-223.718271 0-405.726581 182.00831-405.726581 405.726581s182.00831 405.726581 405.726581 405.726581c223.718271 0 405.727605-182.00831 405.727605-405.726581S736.220714 105.962334 512.50142 105.962334z M510.150886 775.953647c-18.107403 0-32.745798-14.678304-32.745798-32.785707L477.405087 452.191846c0-18.108426 14.638395-32.785707 32.745798-32.785707 18.107403 0 32.745798 14.678304 32.745798 32.785707l0 290.976094C542.896684 761.275343 528.258289 775.953647 510.150886 775.953647z M511.357364 296.458969m-45.080731 0a44.054 44.054 0 1 0 90.161463 0 44.054 44.054 0 1 0-90.161463 0Z',\n onclick () {\n AModal.info({\n title: '说明信息',\n content: (props.toolboxInfoText as string)\n })\n }\n }\n }\n },\n title: {\n text: props.titleText,\n subText: props.titleSubtext,\n left: 'center'\n },\n grid: {\n top: props.gridTop,\n bottom: props.gridBottom,\n left: props.gridLeft,\n right: props.gridRight,\n containLabel: props.gridContainLabel\n },\n color: props.colors,\n tooltip: {\n trigger: 'axis',\n show: props.tooltipShow,\n formatter: (params) => {\n const len = params.length\n let formatter = ''\n let tooltipFormatter = props.tooltipFormatter as string\n if (tooltipFormatter === '') {\n tooltipFormatter = '{marker} {a} {c}'\n }\n for (let i = 0; i < len; i++) {\n const { marker, seriesName, name, value, data } = params[i] || {}\n if (i === 0) {\n formatter += `${name}<br/>`\n }\n formatter += useVariablesInText(\n tooltipFormatter,\n {\n marker,\n name,\n value,\n a: seriesName,\n b: name,\n c: value,\n ...data\n },\n {\n useNewline: true,\n useSpace: true\n })\n formatter += '<br/>'\n }\n return formatter\n }\n },\n xAxis: {\n type: 'category',\n data: unref(dimensions),\n splitLine: {\n show: props.xAxisSplitLineShow,\n lineStyle: {\n color: props.xAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.xAxisLabelColor,\n formatter (value: string) {\n return useValueFormatter(xAxisLabelFormatter, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.xAxisLineStyleColor\n }\n },\n axisTick: {\n show: props.xAxisTickShow\n }\n },\n yAxis: {\n type: 'value',\n splitLine: {\n show: props.yAxisSplitLineShow,\n lineStyle: {\n color: props.yAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.yAxisLabelColor,\n formatter (value: string) {\n return useValueFormatter(yAxisLabelFormatter, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.yAxisLineStyleColor\n }\n }\n },\n // 图例\n legend: {\n show: props.legendShow,\n orient: props.legendOrient,\n top: props.legendTop,\n left: props.legendLeft\n },\n series: unref(series)\n }\n })\n\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n\n const handleDataset = (data: any = [], useDataFieldNames: boolean = false) => {\n // dataFieldNames 字段映射\n let chartData\n if (props.dataFieldConfigType === 'key') {\n const dataFieldNames = useDataFieldNames ? props.keyTypeDataFieldNames as KeyTypeDataFieldNames : null\n chartData = useTransformChartDataByAttrKey(data, dataFieldNames)\n } else if (props.dataFieldConfigType === 'value') {\n const dataFieldNames = useDataFieldNames ? props.valueTypeDataFieldNames as ValueTypeDataFieldNames : null\n chartData = useTransformChartDataByAttrValue(data, dataFieldNames)\n }\n dimensions.value = chartData.dimensions\n const dataset = chartData.dataset\n const temp = [] as { [key: string]: any } []\n const len = dataset.length\n for (let i = 0; i < len; i++) {\n temp.push({\n type: 'line',\n ...dataset[i],\n symbolSize: props.symbolSize,\n smooth: props.smooth,\n areaStyle: {\n // color: {\n // type: 'linear',\n // x: 0,\n // y: 0,\n // x2: 0,\n // y2: 1,\n // colorStops: [{\n // offset: 0, color: props.colors[i] // 0% 处的颜色\n // }, {\n // offset: 1, color: '#fff' // 100% 处的颜色\n // }],\n // global: false // 缺省为 false\n // },\n opacity: props.areaStyleOpacity\n },\n lineStyle: {\n width: props.lineStyleWidth\n }\n })\n }\n series.value = temp\n }\n\n const handleIndicatorDataset = (data: any = [], keyTypeDataFieldNames: KeyTypeDataFieldNames, useDataFieldNames: boolean = false) => {\n const dataFieldNames = useDataFieldNames ? keyTypeDataFieldNames : null\n const chartData = useTransformChartDataByAttrKey(data, dataFieldNames)\n dimensions.value = chartData.dimensions\n const dataset = chartData.dataset\n const temp = [] as { [key: string]: any } []\n const len = dataset.length\n for (let i = 0; i < len; i++) {\n temp.push({\n type: 'line',\n ...dataset[i],\n symbolSize: props.symbolSize,\n smooth: props.smooth,\n lineStyle: {\n width: props.lineStyleWidth\n }\n })\n }\n series.value = temp\n }\n\n // 静态数据\n watch(() => [props.data, props.symbolSize, props.smooth, props.lineStyleWidth, props.areaStyleOpacity], ([data]) => {\n if (props.dataType === 'static' || unref(pageMode) === 'design') {\n handleDataset(data as { [key: string]: any }[])\n }\n }, {\n immediate: true,\n deep: true\n })\n\n const loading = ref(false)\n const requestData = useRequestData(props)\n // 动态数据\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestData()\n handleDataset(res?.data?.data?.rows, true)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const emitEvent = useEmitEvent(props)\n\n const click = emitEvent('click', (e) => {\n // TODO 设置是否保存钻取数据\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: e?.data })\n })\n\n // 指标库\n const requestDiagram = useRequestDiagramData(props)\n const handleIndicatorData = async () => {\n if (props.dataType !== 'indicator' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestDiagram()\n let a\n if (res?.data?.data?.columns?.length > 0) {\n a = {\n name: res.data.data.columns[0],\n types: res.data.data.columns.slice(1).map(it => {\n return { label: it, value: it }\n })\n }\n }\n handleIndicatorDataset(res?.data?.data?.rows, a, true)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const chooseRequestOrDiagram = () => {\n if (unref(pageMode) === 'design') return\n handleIndicatorData()\n handleRequestData()\n }\n\n const refreshData = () => {\n chooseRequestOrDiagram()\n }\n\n const resetRecord = () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n setGlobalModel(id, { ...modal, RECORD: '' })\n }\n\n useOnEvent(props, {\n refreshData,\n resetRecord,\n click\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n\n setRequest({\n id: props.id as string,\n requestFn: chooseRequestOrDiagram,\n sortNum: props.requestSort as number\n })\n\n return {\n option,\n style,\n click,\n loading,\n visible,\n hideModal\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.full-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n height: calc(100vh);\n }\n .ant-modal-body {\n flex: 1;\n }\n\n .ant-modal-body {\n padding: 45px 30px 0;\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport Line from './Line.vue'\nexport const EcanLine = withInstall(Line)\nexport default EcanLine\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps,\n Data,\n KeyTypeDataFieldNames,\n ValueTypeDataFieldNames\n} from '@/utils/props'\n\nexport interface BarProps extends Props {\n data: Data\n titleText: string\n titleSubtext: string\n colors: string []\n legendShow: boolean\n legendTextStyleColor: string\n legendLeft: 'left' | 'center' | 'right'\n legendTop: 'top' | 'middle' | 'bottom'\n legendOrient: 'vertical' | 'horizontal'\n xAxisSplitLineShow: boolean // x轴展示分割线\n xAxisLabelColor: string // x轴名称颜色\n xAxisLabelWidth: number | undefined // x轴名称宽度\n xAxisLabelOverflow: 'none' | 'truncate' | 'break' | 'breakAll' // x轴名称溢出操作\n xAxisLabelRotate: number // x轴名称旋转\n xAxisLineStyleColor: string // x轴名称颜色\n xAxisTickShow: boolean // 展示刻度\n xAxisLabelFormatter: string\n yAxisLabelWidth: number | undefined // y轴名称宽度\n yAxisLabelOverflow: 'none' | 'truncate' | 'break' | 'breakAll' // y轴名称溢出操作\n yAxisLabelRotate: number // y轴名称旋转\n yAxisSplitLineShow: boolean // y轴展示分割线\n xAxisSplitLineStyleColor: string // x轴分割线颜色\n yAxisSplitLineStyleColor: string // y轴分割线颜色\n yAxisLabelColor: string // y轴名称颜色\n yAxisLineStyleColor: string // y轴名称颜色\n yAxisLabelFormatter: string\n valueTypeDataFieldNames: ValueTypeDataFieldNames\n keyTypeDataFieldNames: KeyTypeDataFieldNames\n dataFieldConfigType: 'key' | 'value'\n tooltipShow: boolean\n tooltipTextStyleColor: string\n tooltipFormatter: string,\n gridContainLabel: boolean\n gridTop: string\n gridBottom: string\n gridLeft: string\n gridRight: string\n barWidth: string\n graphicConfig: {\n [key:string]: any,\n // 全部属性, 为了属性可拓展,所以在设计器中自由添加\n // classification: { [key:string]: any }\n // series: { [key:string]: any }\n // indicatorList: { [key:string]: any } []\n // sqlConditions: { [key:string]: any } []\n // idxLibMode: string\n // source: string\n // dataViewId: string\n chartType: 'bar' // 图表类型,后台接口\n plugin: '1' // 插件类型,后台接口\n layer: '2' // 图类型, 后台接口\n }\n toolboxShow: boolean\n toolboxOrient: 'horizontal' | 'vertical'\n toolboxItemSize: number // 工具栏 icon 的大小。\n toolboxItemGap: number // 工具栏 icon 每项之间的间隔。横向布局时为水平间隔,纵向布局时为纵向间隔。\n toolboxLeft: 'left' | 'center' | 'right'\n toolboxTop: 'top'| 'middle'| 'bottom'\n toolboxIconStyleBorderColor: string\n toolboxDownloadUrl: string\n toolboxInfoText: string\n isUseHorizontalAxis: boolean\n axisInverse: boolean\n xAxisInverse: boolean\n yAxisInverse: boolean\n isStack: boolean\n labelShow: boolean\n labelFontSize: string\n labelPosition: 'inside' | 'top' | 'bottom' | 'right' | 'left'\n labelColor: string\n}\n\nexport const barProps: BarProps = {\n ...props,\n id: '',\n name: '柱状图',\n keyName: '柱状图',\n type: 'ecanBar',\n width: '400px',\n height: '400px',\n top: '',\n left: '',\n rotate: '',\n xAxisLabelFormatter: '{value}',\n yAxisLabelFormatter: '{value}',\n data: [\n {\n name: '名称一',\n value: 335,\n type: '类型一'\n },\n {\n name: '名称二',\n value: 310,\n type: '类型一'\n },\n {\n name: '名称三',\n value: 310,\n type: '类型一'\n }\n ],\n titleText: '',\n titleSubtext: '',\n colors: ['#5470c6', '#91cc75', '#fac858', '#ee6666', '#73c0de', '#3ba272', '#fc8452', '#9a60b4', '#ea7ccc'],\n legendShow: true,\n legendTextStyleColor: '#333',\n legendOrient: 'horizontal',\n legendTop: 'top',\n legendLeft: 'center',\n tooltipShow: true,\n tooltipTextStyleColor: '',\n tooltipFormatter: '{marker} {a} {c}',\n xAxisSplitLineShow: true,\n xAxisSplitLineStyleColor: '#333',\n xAxisLabelColor: '#333',\n xAxisLabelWidth: undefined,\n xAxisLabelRotate: 0,\n xAxisLabelOverflow: 'none',\n xAxisLineStyleColor: '#333',\n xAxisTickShow: true,\n yAxisLabelWidth: undefined,\n yAxisLabelRotate: 0,\n yAxisLabelOverflow: 'none',\n yAxisSplitLineShow: true,\n yAxisSplitLineStyleColor: '#333',\n yAxisLabelColor: '#333',\n yAxisLineStyleColor: '#333',\n valueTypeDataFieldNames: { name: 'name', value: 'value', type: 'type' },\n keyTypeDataFieldNames: { name: 'name', types: [] },\n dataFieldConfigType: 'value',\n barWidth: '40%',\n gridContainLabel: true,\n gridTop: '10%',\n gridBottom: '10%',\n gridLeft: '5%',\n gridRight: '5%',\n graphicConfig: {\n chartType: 'bar', // 图表类型,后台接口\n plugin: '1', // 插件类型,后台接口\n layer: '2' // 图类型, 后台接口\n },\n toolboxShow: false,\n toolboxOrient: 'horizontal',\n toolboxItemSize: 16,\n toolboxItemGap: 8,\n toolboxLeft: 'right',\n toolboxTop: 'top',\n toolboxIconStyleBorderColor: '#666',\n toolboxDownloadUrl: '',\n toolboxInfoText: '当前无说明信息',\n isUseHorizontalAxis: false,\n axisInverse: false,\n xAxisInverse: false,\n yAxisInverse: false,\n isStack: false,\n labelShow: false,\n labelFontSize: '12px',\n labelPosition: 'inside',\n labelColor: ''\n}\n\n// 转化默认属性\nexport const barComponentProps = transformToComponentProps(barProps)\n\nexport const barEvents: string [] = ['refreshData', 'click', 'resetRecord']\n","<template>\n <div class=\"ecan-bar\" :style=\"style\">\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n @click=\"click\"\n />\n </spin>\n <a-modal\n wrap-class-name=\"full-modal\"\n width=\"100%\"\n :visible=\"visible\"\n :footer=\"null\"\n @cancel=\"hideModal\"\n >\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n />\n </spin>\n </a-modal>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, computed, ref, watch, inject, unref } from 'vue'\nimport {\n usePickComponentStyle,\n useOnEvent,\n useTransformChartDataByAttrValue,\n useTransformChartDataByAttrKey,\n useEmitEvent,\n useRequestData,\n useIndicatorData,\n useValueFormatter,\n useVariablesInText\n} from '@/hooks'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport { ValueTypeDataFieldNames, KeyTypeDataFieldNames, Data } from '@/utils/props'\nimport Echarts from '@/common/echarts'\nimport { barComponentProps } from './props'\nimport { use } from 'echarts/core'\nimport { CanvasRenderer } from 'echarts/renderers'\nimport { BarChart } from 'echarts/charts'\nimport Spin from '@/common/spin'\nimport { Modal as AModal } from 'ant-design-vue'\nimport {\n TitleComponent,\n LegendComponent,\n DatasetComponent,\n ToolboxComponent\n} from 'echarts/components'\nimport { RequestModalParam } from '@/utils/types'\nimport useDownloadFile from '@/hooks/useDownloadFile'\nuse([\n CanvasRenderer,\n BarChart,\n TitleComponent,\n LegendComponent,\n DatasetComponent,\n ToolboxComponent\n])\nexport default defineComponent({\n name: 'EcanBar',\n props: {\n ...barComponentProps\n },\n components: {\n Spin,\n Echarts,\n AModal\n },\n setup (props, { expose }) {\n const style = usePickComponentStyle(props)\n const dataSource = ref<{ [key: string]: any }[]>([])\n const visible = ref(false)\n const hideModal = () => {\n visible.value = false\n }\n const series = computed(() => {\n const ds = unref(dataSource)\n const len = ds.length\n const series = []\n for (let i = 0; i < len; i++) {\n const item = {\n ...ds[i],\n type: 'bar',\n barWidth: props.barWidth\n } as { [key:string]: any }\n if (props.isStack) {\n item.stack = 'stack'\n }\n item.label = {\n show: props.labelShow,\n fontSize: props.labelFontSize,\n position: props.labelPosition,\n color: props.labelColor\n }\n series.push(item)\n }\n return series\n })\n const dimensions = ref<{ [key: string]: any }[]>([])\n const loading = ref(false)\n const option = computed(() => {\n // 这样写为了触发响应式\n // 返回函数中使用无法触发\n const yAxisLabelFormatter = props.yAxisLabelFormatter as string\n const xAxisLabelFormatter = props.xAxisLabelFormatter as string\n return {\n toolbox: {\n show: props.toolboxShow,\n left: props.toolboxLeft,\n top: props.toolboxTop,\n itemSize: props.toolboxItemSize,\n itemGap: props.toolboxItemGap,\n feature: {\n myDownload: {\n show: true,\n title: '数据下载',\n icon: 'path://M502.010485 765.939573c3.773953 3.719718 8.686846 5.573949 13.596669 5.573949 0.075725 0 0.151449-0.010233 0.227174-0.011256 0.329505 0.016373 0.654916 0.050142 0.988514 0.050142 0.706081 0 1.400906-0.042979 2.087545-0.116657 4.352121-0.366344 8.607028-2.190899 11.961426-5.496178l335.053985-330.166675c7.619538-7.509021 7.709589-19.773346 0.200568-27.393907s-19.774369-7.711636-27.39493-0.201591L536.193005 706.304358 536.193005 50.019207c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 657.032164-306.881342-302.44838c-7.618515-7.509021-19.883863-7.419993-27.393907 0.199545-7.509021 7.619538-7.419993 19.884886 0.199545 27.393907L502.010485 765.939573z, M867.170139 711.020776c-10.698666 0-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 13.054317-10.620895 23.675212-23.676236 23.675212L205.182103 919.486668c-13.054317 0-23.676236-10.620895-23.676236-23.675212L181.505867 730.391962c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 34.416857 28.000728 62.416562 62.417585 62.416562l618.941638 0c34.417881 0 62.417585-27.999704 62.417585-62.416562L886.540302 730.391962C886.541325 719.693296 877.868805 711.020776 867.170139 711.020776z',\n onclick () {\n useDownloadFile(props.toolboxDownloadUrl as string)\n }\n },\n myDataZoom: {\n show: true,\n title: '放大',\n icon: 'path://M932.42 902.246667L792 761.793333A403.84 403.84 0 0 0 896 490.666667c0-223.86-181.473333-405.333333-405.333333-405.333334S85.333333 266.806667 85.333333 490.666667s181.473333 405.333333 405.333334 405.333333a403.84 403.84 0 0 0 271.126666-104l140.453334 140.453333a21.333333 21.333333 0 0 0 30.173333-30.173333zM128 490.666667c0-200.293333 162.373333-362.666667 362.666667-362.666667s362.666667 162.373333 362.666666 362.666667-162.373333 362.666667-362.666666 362.666666-362.666667-162.373333-362.666667-362.666666z m512 0a21.333333 21.333333 0 0 1-21.333333 21.333333H512v106.666667a21.333333 21.333333 0 0 1-42.666667 0V512H362.666667a21.333333 21.333333 0 0 1 0-42.666667h106.666666V362.666667a21.333333 21.333333 0 0 1 42.666667 0v106.666666h106.666667a21.333333 21.333333 0 0 1 21.333333 21.333334z',\n onclick () {\n visible.value = true\n }\n },\n myInfo: {\n show: true,\n title: '说明信息',\n icon: 'path://M512.50142 958.397886c-119.320573 0-231.499491-46.465265-315.871087-130.837884C112.258737 743.188406 65.792449 631.010511 65.792449 511.688915c0-119.319549 46.466288-231.499491 130.837884-315.871087C281.002952 111.445208 393.180847 64.979944 512.50142 64.979944s231.499491 46.465265 315.871087 130.837884c84.372619 84.372619 130.837884 196.551538 130.837884 315.871087 0 119.321596-46.465265 231.499491-130.837884 315.871087C744.000911 911.932622 631.821993 958.397886 512.50142 958.397886zM512.50142 105.962334c-223.718271 0-405.726581 182.00831-405.726581 405.726581s182.00831 405.726581 405.726581 405.726581c223.718271 0 405.727605-182.00831 405.727605-405.726581S736.220714 105.962334 512.50142 105.962334z M510.150886 775.953647c-18.107403 0-32.745798-14.678304-32.745798-32.785707L477.405087 452.191846c0-18.108426 14.638395-32.785707 32.745798-32.785707 18.107403 0 32.745798 14.678304 32.745798 32.785707l0 290.976094C542.896684 761.275343 528.258289 775.953647 510.150886 775.953647z M511.357364 296.458969m-45.080731 0a44.054 44.054 0 1 0 90.161463 0 44.054 44.054 0 1 0-90.161463 0Z',\n onclick () {\n AModal.info({\n title: '说明信息',\n content: (props.toolboxInfoText as string)\n })\n }\n }\n }\n },\n title: {\n text: props.titleText,\n subtext: props.titleSubtext,\n left: 'center'\n },\n grid: {\n top: props.gridTop,\n bottom: props.gridBottom,\n left: props.gridLeft,\n right: props.gridRight,\n containLabel: props.gridContainLabel\n },\n color: props.colors,\n tooltip: {\n trigger: 'axis',\n show: props.tooltipShow,\n formatter: (params) => {\n const len = params.length\n let formatter = ''\n let tooltipFormatter = props.tooltipFormatter as string\n if (tooltipFormatter === '') {\n tooltipFormatter = '{marker} {a} {c}'\n }\n for (let i = 0; i < len; i++) {\n const { marker, seriesName, name, value, data } = params[i] || {}\n if (i === 0) {\n formatter += `${name}<br/>`\n }\n formatter += useVariablesInText(\n tooltipFormatter,\n {\n marker,\n name,\n value,\n a: seriesName,\n b: name,\n c: value,\n ...data\n },\n {\n useNewline: true,\n useSpace: true\n })\n formatter += '<br/>'\n }\n return formatter\n },\n // valueFormatter: (value) => {\n // return useVariablesInText(props.tooltipValueFormatter as string, { value })\n // },\n textStyle: {\n color: props.tooltipTextStyleColor\n }\n },\n legend: {\n show: props.legendShow,\n orient: props.legendOrient,\n top: props.legendTop,\n left: props.legendLeft,\n textStyle: {\n color: props.legendTextStyleColor\n }\n },\n xAxis: {\n type: props.isUseHorizontalAxis ? 'value' : 'category',\n data: props.isUseHorizontalAxis ? null : unref(dimensions),\n inverse: props.isUseHorizontalAxis ? props.xAxisInverse : props.axisInverse,\n splitLine: {\n show: props.xAxisSplitLineShow,\n lineStyle: {\n color: props.xAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.xAxisLabelColor,\n interval: 0,\n rotate: props.xAxisLabelRotate,\n width: props.xAxisLabelWidth,\n overflow: props.xAxisLabelOverflow,\n formatter (value: string) {\n return useValueFormatter(xAxisLabelFormatter, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.xAxisLineStyleColor\n }\n },\n axisTick: {\n show: props.xAxisTickShow\n }\n },\n yAxis: {\n type: props.isUseHorizontalAxis ? 'category' : 'value',\n data: props.isUseHorizontalAxis ? unref(dimensions) : null,\n inverse: props.isUseHorizontalAxis ? props.axisInverse : props.yAxisInverse,\n splitLine: {\n show: props.yAxisSplitLineShow,\n lineStyle: {\n color: props.yAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.yAxisLabelColor,\n rotate: props.yAxisLabelRotate,\n width: props.yAxisLabelWidth,\n overflow: props.yAxisLabelOverflow,\n formatter (value: string) {\n return useValueFormatter(yAxisLabelFormatter, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.yAxisLineStyleColor\n }\n }\n },\n series: unref(series)\n }\n })\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n\n const handleDataset = (data: Data = [], useDataFieldNames: boolean = false) => {\n let chartData = {} as { [key:string]: any }\n if (props.dataFieldConfigType === 'key') {\n const dataFieldNames = useDataFieldNames ? props.keyTypeDataFieldNames as KeyTypeDataFieldNames : null\n chartData = useTransformChartDataByAttrKey(data, dataFieldNames)\n } else if (props.dataFieldConfigType === 'value') {\n const dataFieldNames = useDataFieldNames ? props.valueTypeDataFieldNames as ValueTypeDataFieldNames : null\n chartData = useTransformChartDataByAttrValue(data, dataFieldNames)\n }\n dataSource.value = chartData.dataset\n dimensions.value = chartData.dimensions\n }\n\n const handleIndicatorDataset = (data: any = [], keyTypeDataFieldNames: KeyTypeDataFieldNames, useDataFieldNames: boolean = false) => {\n const dataFieldNames = useDataFieldNames ? keyTypeDataFieldNames : null\n const chartData = useTransformChartDataByAttrKey(data, dataFieldNames)\n dataSource.value = chartData.dataset\n dimensions.value = chartData.dimensions\n }\n\n // 静态数据\n watch(() => props.data, (value: any) => {\n if (props.dataType === 'static' || unref(pageMode) === 'design') {\n handleDataset(value)\n }\n }, {\n immediate: true,\n deep: true\n })\n\n const requestData = useRequestData(props)\n // 动态数据\n const handleRequestData = async () => {\n try {\n loading.value = true\n const res = await requestData()\n handleDataset(res?.data?.data?.rows, true)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n // 指标库\n const indicatorData = useIndicatorData(props)\n const handleIndicatorData = async () => {\n try {\n loading.value = true\n const res = await indicatorData()\n const { columns = [], rows = [] } = res?.data?.data ?? {}\n let fieldNames\n if (columns.length > 0) {\n fieldNames = {\n name: columns[0],\n types: columns.slice(1).map(column => {\n return {\n label: column,\n value: column\n }\n })\n }\n }\n handleIndicatorDataset(rows, fieldNames, true)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const refreshData = () => {\n if (unref(pageMode) === 'design') return\n switch (props.dataType) {\n case 'indicator':\n handleIndicatorData()\n break\n case 'request':\n handleRequestData()\n break\n }\n }\n\n expose({\n refreshData\n })\n\n const emitEvent = useEmitEvent(props)\n\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n const click = emitEvent('click', (e) => {\n // TODO 设置是否保存钻取数据\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: e.data })\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n\n setRequest({\n id: props.id as string,\n requestFn: refreshData,\n sortNum: props.requestSort as number\n })\n\n const resetRecord = () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n setGlobalModel(id, { ...modal, RECORD: '' })\n }\n\n useOnEvent(props, {\n refreshData,\n click,\n resetRecord\n })\n\n return {\n option,\n style,\n refreshData,\n click,\n loading,\n visible,\n hideModal\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.full-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n height: calc(100vh);\n }\n .ant-modal-body {\n flex: 1;\n }\n .ant-modal-body {\n padding: 45px 30px 0;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Bar from './Bar.vue'\nexport const EcanBar = withInstall(Bar)\nexport default EcanBar\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps,\n Data\n} from '@/utils/props'\n\nexport interface ScatterProps extends Props {\n data: Data\n titleText: string\n titleSubtext: string\n colors: string []\n legendShow: boolean,\n tooltipShow: boolean,\n tooltipTrigger: 'item' | 'axis' | 'none'\n tooltipFormatter: string\n legendLeft: 'left' | 'center' | 'right'\n legendTop: 'top' | 'middle' | 'bottom'\n legendOrient: 'vertical' | 'horizontal'\n symbolSize: number // 标记点大小\n xAxisSplitLineShow: boolean // x轴展示分割线\n xAxisLabelColor: string // x轴名称颜色\n xAxisLineStyleColor: string // x轴名称颜色\n xAxisTickShow: boolean // 展示刻度\n xAxisLabelFormatter: string // 格式化\n yAxisSplitLineShow: boolean // y轴展示分割线\n xAxisSplitLineStyleColor: string // x轴分割线颜色\n yAxisSplitLineStyleColor: string // y轴分割线颜色\n yAxisLabelColor: string // y轴名称颜色\n yAxisLineStyleColor: string // y轴名称颜色\n yAxisLabelFormatter: string // 格式化\n gridContainLabel: boolean\n gridTop: string\n gridBottom: string\n gridLeft: string\n gridRight: string\n dataFieldNames: { name: string, value: string }\n graphicConfig?: any\n toolboxShow: boolean\n toolboxOrient: 'horizontal' | 'vertical'\n toolboxItemSize: number // 工具栏 icon 的大小。\n toolboxItemGap: number // 工具栏 icon 每项之间的间隔。横向布局时为水平间隔,纵向布局时为纵向间隔。\n toolboxLeft: 'left' | 'center' | 'right'\n toolboxTop: 'top'| 'middle'| 'bottom'\n toolboxIconStyleBorderColor: string\n toolboxDownloadUrl: string\n toolboxInfoText: string\n}\n\nexport const scatterProps: ScatterProps = {\n ...props,\n id: '',\n name: '散点图',\n keyName: '散点图',\n type: 'ecanScatter',\n width: '400px',\n height: '400px',\n top: '',\n left: '',\n rotate: '',\n data: [\n { name: 233, value: 335 },\n { name: 556, value: 310 },\n { name: 56, value: 234 }\n ],\n titleText: '',\n titleSubtext: '',\n tooltipShow: true,\n tooltipTrigger: 'item',\n tooltipFormatter: '{marker} {b} {c}',\n legendShow: false,\n legendOrient: 'horizontal',\n legendTop: 'top',\n legendLeft: 'center',\n colors: ['#5470c6', '#91cc75', '#fac858', '#ee6666', '#73c0de', '#3ba272', '#fc8452', '#9a60b4', '#ea7ccc'],\n symbolSize: 10,\n xAxisSplitLineShow: true,\n xAxisSplitLineStyleColor: '#333',\n xAxisLabelColor: '#333',\n xAxisLineStyleColor: '#333',\n xAxisTickShow: true,\n xAxisLabelFormatter: '{value}',\n yAxisSplitLineShow: true,\n yAxisSplitLineStyleColor: '#333',\n yAxisLabelColor: '#333',\n yAxisLineStyleColor: '#333',\n yAxisLabelFormatter: '{value}',\n dataFieldNames: { name: 'name', value: 'value' },\n gridContainLabel: true,\n gridTop: '10%',\n gridBottom: '10%',\n gridLeft: '5%',\n gridRight: '5%',\n graphicConfig: undefined,\n toolboxShow: false,\n toolboxOrient: 'horizontal',\n toolboxItemSize: 16,\n toolboxItemGap: 8,\n toolboxLeft: 'right',\n toolboxTop: 'top',\n toolboxIconStyleBorderColor: '#666',\n toolboxDownloadUrl: '',\n toolboxInfoText: '当前无说明信息'\n}\n\n// 转化默认属性\nexport const scatterComponentProps = transformToComponentProps(scatterProps)\n\nexport const scatterEvents = ['click', 'refreshData']\n","<template>\n <div :style=\"style\">\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n autoresize\n @click=\"click\"\n />\n </spin>\n <a-modal\n wrap-class-name=\"full-modal\"\n width=\"100%\"\n :visible=\"visible\"\n :footer=\"null\"\n @cancel=\"hideModal\"\n >\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n />\n </spin>\n </a-modal>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, computed, ref, watch, inject, unref } from 'vue'\nimport {\n useValueFormatter,\n useEmitEvent,\n useOnEvent,\n usePickComponentStyle,\n useRequestData,\n useVariablesInText\n} from '@/hooks'\nimport { RequestModalParam } from '@/utils/types'\nimport Echarts from '@/common/echarts'\nimport { scatterComponentProps } from './props'\nimport { use } from 'echarts/core'\nimport { CanvasRenderer } from 'echarts/renderers'\nimport { ScatterChart } from 'echarts/charts'\nimport { TitleComponent, TooltipComponent, LegendComponent, ToolboxComponent } from 'echarts/components'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport Spin from '@/common/spin/Spin.vue'\nimport useDownloadFile from '@/hooks/useDownloadFile'\nimport { Modal as AModal } from 'ant-design-vue'\nuse([\n CanvasRenderer,\n ScatterChart,\n ToolboxComponent,\n TitleComponent,\n TooltipComponent,\n LegendComponent\n])\nexport default defineComponent({\n name: 'EcanScatter',\n props: {\n ...scatterComponentProps\n },\n components: {\n Spin,\n Echarts,\n AModal\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const dataset = ref<{ [key: string]: any }[]>([])\n const visible = ref(false)\n const hideModal = () => {\n visible.value = false\n }\n const option = computed(() => {\n // 这样写为了触发响应式\n // 返回函数中使用无法触发\n const xAxisLabelFormatter = props.xAxisLabelFormatter as string\n const yAxisLabelFormatter = props.yAxisLabelFormatter as string\n return {\n toolbox: {\n show: props.toolboxShow,\n left: props.toolboxLeft,\n top: props.toolboxTop,\n itemSize: props.toolboxItemSize,\n itemGap: props.toolboxItemGap,\n feature: {\n myDownload: {\n show: true,\n title: '数据下载',\n icon: 'path://M502.010485 765.939573c3.773953 3.719718 8.686846 5.573949 13.596669 5.573949 0.075725 0 0.151449-0.010233 0.227174-0.011256 0.329505 0.016373 0.654916 0.050142 0.988514 0.050142 0.706081 0 1.400906-0.042979 2.087545-0.116657 4.352121-0.366344 8.607028-2.190899 11.961426-5.496178l335.053985-330.166675c7.619538-7.509021 7.709589-19.773346 0.200568-27.393907s-19.774369-7.711636-27.39493-0.201591L536.193005 706.304358 536.193005 50.019207c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 657.032164-306.881342-302.44838c-7.618515-7.509021-19.883863-7.419993-27.393907 0.199545-7.509021 7.619538-7.419993 19.884886 0.199545 27.393907L502.010485 765.939573z, M867.170139 711.020776c-10.698666 0-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 13.054317-10.620895 23.675212-23.676236 23.675212L205.182103 919.486668c-13.054317 0-23.676236-10.620895-23.676236-23.675212L181.505867 730.391962c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 34.416857 28.000728 62.416562 62.417585 62.416562l618.941638 0c34.417881 0 62.417585-27.999704 62.417585-62.416562L886.540302 730.391962C886.541325 719.693296 877.868805 711.020776 867.170139 711.020776z',\n onclick () {\n useDownloadFile(props.toolboxDownloadUrl as string)\n }\n },\n myDataZoom: {\n show: true,\n title: '放大',\n icon: 'path://M932.42 902.246667L792 761.793333A403.84 403.84 0 0 0 896 490.666667c0-223.86-181.473333-405.333333-405.333333-405.333334S85.333333 266.806667 85.333333 490.666667s181.473333 405.333333 405.333334 405.333333a403.84 403.84 0 0 0 271.126666-104l140.453334 140.453333a21.333333 21.333333 0 0 0 30.173333-30.173333zM128 490.666667c0-200.293333 162.373333-362.666667 362.666667-362.666667s362.666667 162.373333 362.666666 362.666667-162.373333 362.666667-362.666666 362.666666-362.666667-162.373333-362.666667-362.666666z m512 0a21.333333 21.333333 0 0 1-21.333333 21.333333H512v106.666667a21.333333 21.333333 0 0 1-42.666667 0V512H362.666667a21.333333 21.333333 0 0 1 0-42.666667h106.666666V362.666667a21.333333 21.333333 0 0 1 42.666667 0v106.666666h106.666667a21.333333 21.333333 0 0 1 21.333333 21.333334z',\n onclick () {\n visible.value = true\n }\n },\n myInfo: {\n show: true,\n title: '说明信息',\n icon: 'path://M512.50142 958.397886c-119.320573 0-231.499491-46.465265-315.871087-130.837884C112.258737 743.188406 65.792449 631.010511 65.792449 511.688915c0-119.319549 46.466288-231.499491 130.837884-315.871087C281.002952 111.445208 393.180847 64.979944 512.50142 64.979944s231.499491 46.465265 315.871087 130.837884c84.372619 84.372619 130.837884 196.551538 130.837884 315.871087 0 119.321596-46.465265 231.499491-130.837884 315.871087C744.000911 911.932622 631.821993 958.397886 512.50142 958.397886zM512.50142 105.962334c-223.718271 0-405.726581 182.00831-405.726581 405.726581s182.00831 405.726581 405.726581 405.726581c223.718271 0 405.727605-182.00831 405.727605-405.726581S736.220714 105.962334 512.50142 105.962334z M510.150886 775.953647c-18.107403 0-32.745798-14.678304-32.745798-32.785707L477.405087 452.191846c0-18.108426 14.638395-32.785707 32.745798-32.785707 18.107403 0 32.745798 14.678304 32.745798 32.785707l0 290.976094C542.896684 761.275343 528.258289 775.953647 510.150886 775.953647z M511.357364 296.458969m-45.080731 0a44.054 44.054 0 1 0 90.161463 0 44.054 44.054 0 1 0-90.161463 0Z',\n onclick () {\n AModal.info({\n title: '说明信息',\n content: (props.toolboxInfoText as string)\n })\n }\n }\n }\n },\n title: {\n text: props.titleText,\n subtext: props.titleSubtext,\n left: 'center'\n },\n grid: {\n top: props.gridTop,\n bottom: props.gridBottom,\n left: props.gridLeft,\n right: props.gridRight,\n containLabel: props.gridContainLabel\n },\n color: props.colors,\n xAxis: {\n // type: 'value'\n splitLine: {\n show: props.xAxisSplitLineShow,\n lineStyle: {\n color: props.xAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.xAxisLabelColor,\n formatter (value: string) {\n return useValueFormatter(xAxisLabelFormatter, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.xAxisLineStyleColor\n }\n },\n axisTick: {\n show: props.xAxisTickShow\n }\n },\n yAxis: {\n splitLine: {\n show: props.yAxisSplitLineShow,\n lineStyle: {\n color: props.yAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.yAxisLabelColor,\n formatter (value: string) {\n return useValueFormatter(yAxisLabelFormatter, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.yAxisLineStyleColor\n }\n }\n },\n // 提示\n tooltip: {\n show: props.tooltipShow,\n trigger: props.tooltipTrigger,\n formatter: function (params) {\n const { marker, seriesName } = params\n const record = params?.data?.record ?? {}\n const { name, value } = record\n return useVariablesInText(props.tooltipFormatter as string, {\n marker,\n seriesName,\n a: seriesName,\n b: name,\n c: value,\n ...record\n })\n },\n axisPointer: {\n type: 'cross'\n }\n },\n // 图例\n legend: {\n show: props.legendShow,\n orient: props.legendOrient,\n top: props.legendTop,\n left: props.legendLeft\n },\n series: [\n {\n data: unref(dataset),\n type: 'scatter',\n symbolSize: props.symbolSize\n }\n ]\n }\n })\n\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n\n const handleDataset = (data: any = [], dataFieldNames?: { name: string, value:string }) => {\n const { name: x = 'name', value: y = 'value' } = dataFieldNames || {}\n dataset.value = data.map(item => ({ value: [item[x], item[y]], record: item }))\n }\n\n // 静态数据\n watch(() => props.data, (value: any) => {\n if (props.dataType === 'static' || unref(pageMode) === 'design') {\n handleDataset(value)\n }\n }, {\n immediate: true,\n deep: true\n })\n\n const loading = ref(false)\n\n const requestData = useRequestData(props)\n // 动态数据\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n loading.value = true\n try {\n const res = await requestData()\n handleDataset(res?.data?.data?.rows, props.dataFieldNames as { name: string, value:string })\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const emitEvent = useEmitEvent(props)\n\n const click = emitEvent('click', (e) => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: e?.data })\n })\n\n const refreshData = () => {\n handleRequestData()\n }\n\n useOnEvent(props, {\n refreshData,\n click\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n setRequest({\n id: props.id as string,\n requestFn: handleRequestData,\n sortNum: props.requestSort as number\n })\n\n return {\n option,\n style,\n click,\n loading,\n visible,\n hideModal\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.full-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n height: calc(100vh);\n }\n .ant-modal-body {\n flex: 1;\n }\n\n .ant-modal-body {\n padding: 45px 30px 0;\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport Scatter from './Scatter.vue'\nexport const EcanScatter = withInstall(Scatter)\nexport default EcanScatter\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface CustomGraphProps extends Props {\n option: { [key:string]: any }\n optionCode: string\n}\n\nexport const customGraphProps: CustomGraphProps = {\n ...props,\n id: '',\n name: '自定义图表',\n keyName: '自定义图表',\n type: 'ecanCustomGraph',\n width: '400px',\n height: '400px',\n option: {},\n optionCode: ''\n}\n\n// 转化默认属性\nexport const customGraphComponentProps = transformToComponentProps(customGraphProps)\n","<template>\n <div :style=\"style\">\n <echarts\n :option=\"myOption\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, watch, ref } from 'vue'\nimport Echarts from '../../common/echarts'\nimport { customGraphComponentProps } from './props'\nimport { usePickComponentStyle } from '../../hooks'\nimport * as echarts from 'echarts'\n// import 'echarts/components'\nexport default defineComponent({\n name: 'EcanCustomGraph',\n props: {\n ...customGraphComponentProps\n },\n components: {\n Echarts\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const myOption = ref()\n watch(() => props.optionCode, (optionCode: string) => {\n /* // eslint-disable-next-line\n let option = {}\n // eslint-disable-next-line\n eval(props.optionCode as string)\n myOption.value = option */\n try {\n // eslint-disable-next-line\n const evalCopy = eval\n myOption.value = evalCopy(optionCode)\n } catch (e) {\n console.error(e)\n }\n }, {\n immediate: true\n })\n return {\n style,\n myOption,\n echarts\n }\n }\n})\n</script>\n","import { withInstall } from '../../utils/withInstall'\nimport CustomGraph from './CustomGraph.vue'\nexport const EcanCustomGraph = withInstall(CustomGraph)\nexport default EcanCustomGraph\nexport * from './props'\n","import {\n Data,\n Props,\n props,\n transformToComponentProps,\n ValueTypeDataFieldNames,\n KeyTypeDataFieldNames\n} from '@/utils/props'\n\nexport interface ComboGraphProps extends Props {\n data: Data,\n titleText: string\n titleSubtext: string\n colors: string []\n legendShow: boolean\n legendTextStyleColor: string\n legendLeft: 'left' | 'center' | 'right'\n legendTop: 'top' | 'middle' | 'bottom'\n legendOrient: 'vertical' | 'horizontal'\n xAxisSplitLineShow: boolean // x轴展示分割线\n xAxisLabelColor: string // x轴名称颜色\n xAxisLineStyleColor: string // x轴名称颜色\n xAxisTickShow: boolean // 展示刻度\n yAxisSplitLineShow: boolean // y轴展示分割线\n xAxisSplitLineStyleColor: string // x轴分割线颜色\n yAxisSplitLineStyleColor: string // y轴分割线颜色\n yAxisLabelColor: string // y轴名称颜色\n yAxisLineStyleColor: string // y轴名称颜色\n valueTypeDataFieldNames: ValueTypeDataFieldNames\n keyTypeDataFieldNames: KeyTypeDataFieldNames\n tooltipShow: boolean\n tooltipTrigger: 'item' | 'axis' | 'none'\n tooltipTextStyleColor: string\n tooltipFormatter: string\n seriesTypes: { [key: string]: any } []\n dataFieldConfigType: 'key' | 'value',\n yAxis: { [key: string]: any } [],\n graphicConfig?: any\n gridContainLabel: boolean\n gridTop: string\n gridBottom: string\n gridLeft: string\n gridRight: string\n toolboxShow: boolean\n toolboxOrient: 'horizontal' | 'vertical'\n toolboxItemSize: number // 工具栏 icon 的大小。\n toolboxItemGap: number // 工具栏 icon 每项之间的间隔。横向布局时为水平间隔,纵向布局时为纵向间隔。\n toolboxLeft: 'left' | 'center' | 'right'\n toolboxTop: 'top'| 'middle'| 'bottom'\n toolboxIconStyleBorderColor: string\n toolboxDownloadUrl: string\n toolboxInfoText: string\n symbolSize: number // 线宽度\n lineStyleWidth: number // 线宽\n smooth: boolean // 光滑\n areaStyleOpacity: number\n barWidth: string\n}\n\nexport const comboGraphProps: ComboGraphProps = {\n ...props,\n id: '',\n name: '组合图表',\n keyName: '组合图表',\n type: 'ecanComboGraph',\n width: '400px',\n height: '400px',\n data: [\n {\n name: '名称一',\n value: 335,\n type: '类型一'\n },\n {\n name: '名称二',\n value: 410,\n type: '类型一'\n },\n {\n name: '名称三',\n value: 210,\n type: '类型一'\n },\n {\n name: '名称一',\n value: 510,\n type: '类型二'\n },\n {\n name: '名称二',\n value: 731,\n type: '类型二'\n },\n {\n name: '名称三',\n value: 910,\n type: '类型二'\n }\n ],\n titleText: '',\n titleSubtext: '',\n colors: ['#5470c6', '#91cc75', '#fac858', '#ee6666', '#73c0de', '#3ba272', '#fc8452', '#9a60b4', '#ea7ccc'],\n legendShow: true,\n legendTextStyleColor: '#333',\n legendOrient: 'horizontal',\n legendTop: 'top',\n legendLeft: 'center',\n tooltipShow: true,\n tooltipTextStyleColor: '',\n tooltipTrigger: 'item',\n tooltipFormatter: '{marker} {a} {c}',\n xAxisSplitLineShow: true,\n xAxisSplitLineStyleColor: '#333',\n xAxisLabelColor: '#333',\n xAxisLineStyleColor: '#333',\n xAxisTickShow: true,\n yAxisSplitLineShow: true,\n yAxisSplitLineStyleColor: '#333',\n yAxisLabelColor: '#333',\n yAxisLineStyleColor: '#333',\n valueTypeDataFieldNames: { name: 'name', value: 'value', type: 'type' },\n keyTypeDataFieldNames: { name: 'name', types: [] },\n dataFieldConfigType: 'value',\n seriesTypes: [\n {\n type: 'bar',\n axisIndex: 0\n },\n {\n type: 'line',\n axisIndex: 0\n }\n ],\n yAxis: [\n {\n axisLabelFormatter: '{value}'\n },\n {\n axisLabelFormatter: '{value}'\n }\n ],\n gridContainLabel: true,\n gridTop: '10%',\n gridBottom: '10%',\n gridLeft: '5%',\n gridRight: '5%',\n graphicConfig: {},\n toolboxShow: false,\n toolboxOrient: 'horizontal',\n toolboxItemSize: 16,\n toolboxItemGap: 8,\n toolboxLeft: 'right',\n toolboxTop: 'top',\n toolboxIconStyleBorderColor: '#666',\n toolboxDownloadUrl: '',\n toolboxInfoText: '当前无说明信息',\n areaStyleOpacity: 0,\n symbolSize: 4,\n lineStyleWidth: 2,\n smooth: false,\n barWidth: '40%'\n}\n\n// 转化默认属性\nexport const comboGraphComponentProps = transformToComponentProps(comboGraphProps)\n\nexport const comboGraphEvents = ['refreshData', 'click', 'resetRecord']\n","<template>\n <div :style=\"style\">\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n @click=\"click\"\n />\n </spin>\n <a-modal\n wrap-class-name=\"full-modal\"\n width=\"100%\"\n :visible=\"visible\"\n :footer=\"null\"\n @cancel=\"hideModal\">\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n @click=\"click\"\n />\n </spin>\n </a-modal>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, ref, unref, watch } from 'vue'\nimport {\n useEmitEvent,\n useOnEvent,\n usePickComponentStyle,\n useRequestData, useTransformChartDataByAttrKey,\n useTransformChartDataByAttrValue,\n useValueFormatter,\n useRequestDiagramData, useVariablesInText\n // useTooltipFormatter\n} from '@/hooks'\nimport { comboGraphComponentProps } from './props'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport { KeyTypeDataFieldNames, ValueTypeDataFieldNames } from '@/utils/props'\nimport { use } from 'echarts/core'\nimport { CanvasRenderer } from 'echarts/renderers'\nimport { BarChart, LineChart } from 'echarts/charts'\nimport { DatasetComponent, LegendComponent, TitleComponent, ToolboxComponent } from 'echarts/components'\nimport Echarts from '@/common/echarts'\nimport Spin from '@/common/spin/'\nimport useDownloadFile from '@/hooks/useDownloadFile'\nimport { Modal as AModal } from 'ant-design-vue'\nimport { RequestModalParam } from '@/utils/types'\nuse([\n CanvasRenderer,\n BarChart,\n LineChart,\n TitleComponent,\n LegendComponent,\n DatasetComponent,\n ToolboxComponent\n])\nexport default defineComponent({\n name: 'EcanComboGraph',\n props: {\n ...comboGraphComponentProps\n },\n components: {\n Spin,\n Echarts,\n AModal\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const series = ref<{ [key: string]: any }[]>([])\n const dimensions = ref<{ [key: string]: any }[]>([])\n const visible = ref(false)\n const hideModal = () => {\n visible.value = false\n }\n const option = computed(() => ({\n title: {\n text: props.titleText,\n subtext: props.titleSubtext,\n left: 'center'\n },\n toolbox: {\n show: props.toolboxShow,\n left: props.toolboxLeft,\n top: props.toolboxTop,\n itemSize: props.toolboxItemSize,\n itemGap: props.toolboxItemGap,\n feature: {\n myDownload: {\n show: true,\n title: '数据下载',\n icon: 'path://M502.010485 765.939573c3.773953 3.719718 8.686846 5.573949 13.596669 5.573949 0.075725 0 0.151449-0.010233 0.227174-0.011256 0.329505 0.016373 0.654916 0.050142 0.988514 0.050142 0.706081 0 1.400906-0.042979 2.087545-0.116657 4.352121-0.366344 8.607028-2.190899 11.961426-5.496178l335.053985-330.166675c7.619538-7.509021 7.709589-19.773346 0.200568-27.393907s-19.774369-7.711636-27.39493-0.201591L536.193005 706.304358 536.193005 50.019207c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 657.032164-306.881342-302.44838c-7.618515-7.509021-19.883863-7.419993-27.393907 0.199545-7.509021 7.619538-7.419993 19.884886 0.199545 27.393907L502.010485 765.939573z, M867.170139 711.020776c-10.698666 0-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 13.054317-10.620895 23.675212-23.676236 23.675212L205.182103 919.486668c-13.054317 0-23.676236-10.620895-23.676236-23.675212L181.505867 730.391962c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 34.416857 28.000728 62.416562 62.417585 62.416562l618.941638 0c34.417881 0 62.417585-27.999704 62.417585-62.416562L886.540302 730.391962C886.541325 719.693296 877.868805 711.020776 867.170139 711.020776z',\n onclick () {\n useDownloadFile(props.toolboxDownloadUrl as string)\n }\n },\n myDataZoom: {\n show: true,\n title: '放大',\n icon: 'path://M932.42 902.246667L792 761.793333A403.84 403.84 0 0 0 896 490.666667c0-223.86-181.473333-405.333333-405.333333-405.333334S85.333333 266.806667 85.333333 490.666667s181.473333 405.333333 405.333334 405.333333a403.84 403.84 0 0 0 271.126666-104l140.453334 140.453333a21.333333 21.333333 0 0 0 30.173333-30.173333zM128 490.666667c0-200.293333 162.373333-362.666667 362.666667-362.666667s362.666667 162.373333 362.666666 362.666667-162.373333 362.666667-362.666666 362.666666-362.666667-162.373333-362.666667-362.666666z m512 0a21.333333 21.333333 0 0 1-21.333333 21.333333H512v106.666667a21.333333 21.333333 0 0 1-42.666667 0V512H362.666667a21.333333 21.333333 0 0 1 0-42.666667h106.666666V362.666667a21.333333 21.333333 0 0 1 42.666667 0v106.666666h106.666667a21.333333 21.333333 0 0 1 21.333333 21.333334z',\n onclick () {\n visible.value = true\n }\n },\n myInfo: {\n show: true,\n title: '说明信息',\n icon: 'path://M512.50142 958.397886c-119.320573 0-231.499491-46.465265-315.871087-130.837884C112.258737 743.188406 65.792449 631.010511 65.792449 511.688915c0-119.319549 46.466288-231.499491 130.837884-315.871087C281.002952 111.445208 393.180847 64.979944 512.50142 64.979944s231.499491 46.465265 315.871087 130.837884c84.372619 84.372619 130.837884 196.551538 130.837884 315.871087 0 119.321596-46.465265 231.499491-130.837884 315.871087C744.000911 911.932622 631.821993 958.397886 512.50142 958.397886zM512.50142 105.962334c-223.718271 0-405.726581 182.00831-405.726581 405.726581s182.00831 405.726581 405.726581 405.726581c223.718271 0 405.727605-182.00831 405.727605-405.726581S736.220714 105.962334 512.50142 105.962334z M510.150886 775.953647c-18.107403 0-32.745798-14.678304-32.745798-32.785707L477.405087 452.191846c0-18.108426 14.638395-32.785707 32.745798-32.785707 18.107403 0 32.745798 14.678304 32.745798 32.785707l0 290.976094C542.896684 761.275343 528.258289 775.953647 510.150886 775.953647z M511.357364 296.458969m-45.080731 0a44.054 44.054 0 1 0 90.161463 0 44.054 44.054 0 1 0-90.161463 0Z',\n onclick () {\n AModal.info({\n title: '说明信息',\n content: (props.toolboxInfoText as string)\n })\n }\n }\n }\n },\n grid: {\n top: props.gridTop,\n bottom: props.gridBottom,\n left: props.gridLeft,\n right: props.gridRight,\n containLabel: props.gridContainLabel\n },\n color: props.colors,\n legend: {\n show: props.legendShow,\n orient: props.legendOrient,\n top: props.legendTop,\n left: props.legendLeft,\n textStyle: {\n color: props.legendTextStyleColor\n }\n },\n tooltip: {\n trigger: 'axis',\n show: props.tooltipShow,\n formatter: (params) => {\n const len = params.length\n let formatter = ''\n let tooltipFormatter = props.tooltipFormatter as string\n if (tooltipFormatter === '') {\n tooltipFormatter = '{marker} {a} {c}'\n }\n const seriesTypes = props.seriesTypes as { [key: string]: any } []\n for (let i = 0; i < len; i++) {\n const seriesType = seriesTypes[i]\n const { tooltipFormatter: _tooltipFormatter } = seriesType || {}\n const { marker, seriesName, name, value, data } = params[i] || {}\n if (i === 0) {\n formatter += `${name}<br/>`\n }\n formatter += useVariablesInText(\n // 如果系列有提示框组件就使用自定义,没有就用默认的\n _tooltipFormatter || tooltipFormatter,\n {\n marker,\n name,\n value,\n seriesName,\n a: seriesName,\n b: name,\n c: value,\n ...data\n },\n {\n useNewline: true,\n useSpace: true\n })\n formatter += '<br/>'\n }\n return formatter\n },\n textStyle: {\n color: props.tooltipTextStyleColor\n }\n },\n xAxis: {\n type: 'category',\n data: unref(dimensions),\n splitLine: {\n show: props.xAxisSplitLineShow,\n lineStyle: {\n color: props.xAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.xAxisLabelColor\n },\n axisLine: {\n lineStyle: {\n color: props.xAxisLineStyleColor\n }\n },\n axisTick: {\n show: props.xAxisTickShow\n }\n },\n yAxis: unref(yAxis),\n series: unref(series)\n }))\n\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n\n const handleDataset = (data: any = [], useDataFieldNames: boolean = false) => {\n // dataFieldNames 字段映射\n let chartData\n if (props.dataFieldConfigType === 'key') {\n const dataFieldNames = useDataFieldNames ? props.keyTypeDataFieldNames as KeyTypeDataFieldNames : null\n chartData = useTransformChartDataByAttrKey(data, dataFieldNames)\n } else if (props.dataFieldConfigType === 'value') {\n const dataFieldNames = useDataFieldNames ? props.valueTypeDataFieldNames as ValueTypeDataFieldNames : null\n chartData = useTransformChartDataByAttrValue(data, dataFieldNames)\n }\n // dataFieldNames 字段映射\n dimensions.value = chartData.dimensions\n const dataset = chartData.dataset\n const temp = [] as { [key: string]: any } []\n const len = dataset.length\n const seriesTypes = props.seriesTypes as { [key: string]: any } []\n for (let i = 0; i < len; i++) {\n const seriesType = seriesTypes[i]\n const { type, axisIndex } = seriesType || {}\n let series = {\n type: type,\n yAxisIndex: axisIndex,\n ...dataset[i]\n } as { [key:string]: any }\n if (type === 'line') {\n series = {\n ...series,\n symbolSize: props.symbolSize,\n smooth: props.smooth,\n areaStyle: {\n opacity: props.areaStyleOpacity\n },\n lineStyle: {\n width: props.lineStyleWidth\n }\n }\n }\n if (type === 'bar') {\n series = {\n ...series,\n barWidth: props.barWidth\n }\n }\n temp.push(series)\n }\n series.value = temp\n }\n\n const handleIndicatorDataset = (data: any = [], keyTypeDataFieldNames: KeyTypeDataFieldNames, useDataFieldNames: boolean = false) => {\n const dataFieldNames = useDataFieldNames ? keyTypeDataFieldNames : null\n const chartData = useTransformChartDataByAttrKey(data, dataFieldNames)\n // dataFieldNames 字段映射\n dimensions.value = chartData.dimensions\n const dataset = chartData.dataset\n const temp = [] as { [key: string]: any } []\n const len = dataset.length\n const seriesTypes = props.seriesTypes as { [key: string]: any } []\n for (let i = 0; i < len; i++) {\n const seriesType = seriesTypes[i]\n temp.push({\n type: seriesType?.type,\n yAxisIndex: seriesType?.axisIndex,\n ...dataset[i]\n })\n }\n series.value = temp\n }\n\n // 静态数据\n watch(() => [props.data, props.seriesTypes, props.symbolSize, props.smooth, props.areaStyleOpacity, props.lineStyleWidth, props.barWidth], ([value]) => {\n if (props.dataType === 'static' || unref(pageMode) === 'design') {\n handleDataset(value)\n }\n }, {\n immediate: true,\n deep: true\n })\n\n const yAxis = computed(() => {\n const yAxis = props.yAxis as { [key: string]: any } []\n return yAxis?.map((axis) => {\n return {\n type: 'value',\n splitLine: {\n show: props.yAxisSplitLineShow,\n lineStyle: {\n color: props.yAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.yAxisLabelColor,\n formatter (value: string) {\n return useValueFormatter(axis.axisLabelFormatter as string, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.yAxisLineStyleColor\n }\n }\n }\n })\n })\n\n const loading = ref(false)\n\n const requestData = useRequestData(props)\n\n // 动态数据\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestData()\n handleDataset(res?.data?.data?.rows, true)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n // 指标库\n const requestDiagram = useRequestDiagramData(props)\n const handleIndicatorData = async () => {\n if (props.dataType !== 'indicator' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestDiagram()\n let a\n if (res?.data?.data?.columns?.length > 0) {\n a = {\n name: res.data.data.columns[0],\n types: res.data.data.columns.slice(1).map(it => {\n return { label: it, value: it }\n })\n }\n }\n handleIndicatorDataset(res?.data?.data?.rows, a, true)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const chooseRequestOrDiagram = () => {\n if (unref(pageMode) === 'design') return\n handleIndicatorData()\n handleRequestData()\n }\n\n const refreshData = () => {\n chooseRequestOrDiagram()\n }\n\n const emitEvent = useEmitEvent(props)\n\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n const click = emitEvent('click', (e) => {\n // TODO 设置是否保存钻取数据\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: e?.data })\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n\n setRequest({\n id: props.id as string,\n requestFn: chooseRequestOrDiagram,\n sortNum: props.requestSort as number\n })\n\n const resetRecord = () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n setGlobalModel(id, { ...modal, RECORD: '' })\n }\n\n useOnEvent(props, {\n resetRecord,\n refreshData,\n click\n })\n\n return {\n style,\n option,\n click,\n loading,\n visible,\n hideModal\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.full-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n height: calc(100vh);\n }\n .ant-modal-body {\n flex: 1;\n }\n .ant-modal-body {\n padding: 45px 30px 0;\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport ComboGraph from './ComboGraph.vue'\nexport const EcanComboGraph = withInstall(ComboGraph)\nexport default EcanComboGraph\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface BorderProps extends Props {\n fontSize: string // 字体大小\n fontFamily: string // 字体\n fontWeight: number // 字体的粗细程度\n title: string\n mode: 'top-title' | 'no-title' | 'left-top'\n borderColor: string\n borderRadius: string\n borderStyle: string\n borderWidth: string\n backgroundColor: string\n useBorderModify: boolean\n textShadow: string\n data: { [key:string]: any }\n}\n\nexport const borderProps: BorderProps = {\n ...props,\n name: '边框',\n keyName: '边框',\n type: 'ecanBorder',\n width: '300px',\n height: '300px',\n zIndex: 0,\n fontSize: '16px',\n fontFamily: '',\n fontWeight: 700,\n title: '标题',\n mode: 'no-title',\n borderColor: '#eee',\n borderRadius: '5px',\n borderStyle: 'solid',\n borderWidth: '2px',\n backgroundColor: '#ffffff',\n useBorderModify: false,\n textShadow: '',\n data: {}\n}\n\nexport const borderComponentProps = transformToComponentProps(borderProps)\n\nexport const borderEvents = ['click']\n","<template>\n <div class=\"ecan-border\" :style=\"style\" @click=\"click\">\n <div\n class=\"no-title\"\n :style=\"borderStyle\"\n v-if=\"mode === 'no-title'\"\n >\n <template v-if=\"useBorderModify\">\n <div class=\"top-left border-item\"/>\n <div class=\"top-right border-item\"/>\n <div class=\"bottom-left border-item\"/>\n <div class=\"bottom-right border-item\"/>\n </template>\n </div>\n <div class=\"top-title\" :style=\"borderStyle\" v-if=\"mode === 'top-title'\">\n <div class=\"title-item-wrapper\">\n <div class=\"title-item\">\n <img\n class=\"title-decoration-left\"\n src=\"../../assets/border-title-decoration-left.png\"\n >\n <div class=\"title\">{{ title }}</div>\n <img\n class=\"title-decoration-right\"\n src=\"../../assets/border-title-decoration-right.png\"\n >\n </div>\n </div>\n <div class=\"top-left border-item\"/>\n <div class=\"top-right border-item\"/>\n <div class=\"bottom-left border-item\"/>\n <div class=\"bottom-right border-item\"/>\n </div>\n <div class=\"left-title\" v-if=\"mode === 'left-title'\">\n <div class=\"title\">\n <span>{{ title }}</span>\n </div>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, ref, watch } from 'vue'\nimport { borderComponentProps } from './props'\nimport { useEmitEvent, useOnEvent, usePickComponentStyle } from '@/hooks'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL } from '@/utils/constant'\nexport default defineComponent({\n name: 'EcanBorder',\n props: {\n ...borderComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props, ['background'])\n const { theme } = inject(GLOBAL_CONFIG, {\n theme: 'light'\n })\n const borderStyle = computed(() => {\n return {\n // borderWidth: props.borderWidth,\n // borderStyle: props.borderStyle,\n // borderRadius: props.borderRadius,\n // borderColor: props.borderColor,\n // backgroundColor: props.backgroundColor,\n width: '100%',\n height: '100%'\n }\n })\n const emitEvent = useEmitEvent(props)\n const click = emitEvent('click', () => {})\n const myData = ref<{ [key:string]: any } []>([])\n watch(() => props.data, (data: { [key:string]: any } []) => {\n myData.value = data\n }, {\n immediate: true,\n deep: true\n })\n useOnEvent(props, {\n click\n })\n const { setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n // 初始化设置值\n setGlobalModel(props.id as string, {\n type: props.type,\n value: myData\n })\n return {\n style,\n click,\n borderStyle,\n theme\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.top-title, .no-title {\n position: relative;\n box-sizing: border-box;\n width: 100%;\n height: 100%;\n .border-item {\n position: absolute;\n z-index: 2;\n border-color: #50FCFC;\n border-style: solid;\n width: 13px;\n height: 11px;\n }\n .top-left {\n top: 0;\n left: 0;\n border-top-width: 1px;\n border-right-width: 0;\n border-bottom-width: 0;\n border-left-width: 1px;\n }\n .top-right {\n top: 0;\n right: -2px;\n border-top-width: 1px;\n border-right-width: 1px;\n border-bottom-width: 0;\n border-left-width: 0;\n }\n .bottom-left {\n bottom: -2px;\n left: 0;\n border-top-width: 0;\n border-right-width: 0;\n border-bottom-width: 1px;\n border-left-width: 1px;\n }\n .bottom-right {\n bottom: -2px;\n right: -2px;\n border-top-width: 0;\n border-right-width: 1px;\n border-bottom-width: 1px;\n border-left-width: 0;\n }\n .title-item-wrapper {\n width: 100%;\n padding: 5px 0;\n background-image: url(\"../../assets/border-title-background.png\");\n background-size: cover;\n display: grid;\n place-content: center;\n }\n .title-item {\n display: flex;\n align-items: center;\n }\n .title {\n padding: 0 17px;\n color: #d5fdfd;\n background: linear-gradient(0deg,#01aaff,#00eaff);\n -webkit-background-clip: text;\n -webkit-text-fill-color: transparent;\n }\n .title-decoration-left {\n width: 58px;\n height: 14px;\n }\n .title-decoration-right {\n width: 58px;\n height: 14px;\n }\n}\n\n.left-title {\n position: relative;\n width: 100%;\n height: 100%;\n border: 2px solid #375A8899;\n border-radius: 0;\n .title {\n position: absolute;\n left: -33px;\n top: -14px;\n width: 33px;\n min-height: 194px;\n padding-top: 33px;\n padding-bottom: 31px;\n background-image: url(\"../../assets/border-left-title.png\");\n background-repeat: no-repeat;\n background-size: 100% 100%;\n color: #fff;\n font-weight: 500;\n text-align: center;\n span {\n writing-mode: vertical-lr;\n }\n }\n}\n</style>\n","export default \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHQAAAAcCAMAAACH42siAAAAZlBMVEUAAABBltJCldJCldFEk89BltJCltFBldI/lMBKndtmb9pCltNDldFAkclAldNBldJBltM/lM5AltNCldJBldJBlNJBltVBldJBlNJBlNI/lNNBldJBldNAldJBldJBldJBldNBldIiNK7WAAAAInRSTlMAM4BNGmaz5gQGbiAPCV1WQxUpOCY9EmxQSC2jdoacqZK8uPo7tAAAAZ9JREFUSMe90NmOwjAMheGka0J3SulCy/L+Lzk4I+HYhckEKs7dr1x8kQVM5YJMZ7SLiXVHOw817Z72cSns3BmziY7EnGRGjDqUpKt4pEZQKruvyaJt85YmBUebKLJVNUlpq6oOQ1tVVRzbqu6DwFb1NUlsVd3SNL0UDM0jqkaSqoeQqjKmahtQNUzuC1AtU1sF9KHmnmrtrSK6idqBWqE6GFVxFdGvqDGoJ01Qt7rfTEV0e7V6qSK6VjNPtTaqoOq8Ugnqr7aeav+rAuqrTh+qZw3o1urAVcFVQD3U6ZnaYY9MLZk6G5WhDaDFI9UeUPyE7gCNsAdAD9gxoBJ7ARRPUVwALXdu8/h/s3xmjtwUu0/M0M/UJzBjAei3TUTdpmKmcpkBmOHKBNTPzJi59zYJys3DO2aL78YcmNkLgrrM9m9TucwzmoBy08xlju+bgL42G4c5OcxqZSLqbwqXOVNTGXMWFD0ak6KN1ZKaojYmbribndW9MXELNQEFFUyiNqQlmEQ1JqpgErUifUUTUVEIupx1wzpjvWfdsh4FQX8ANe4nnpsb9NEAAAAASUVORK5CYII=\"","export default \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHQAAAAcCAMAAACH42siAAAAaVBMVEUAAABElM9BltJCldJCldFBltJBldJCltFNmrNCmNNFldNAldJBldNBldRBldNBldNBldJCoNFBldJBltNBldJBldJAldJAltJBldJBldJBldNAlNFAldJBlNJAldJBldNBldJBldJBldLfIVowAAAAI3RSTlMAGjJNgGbmswMSCScgDTs/ZAVRK0eYj2s3r3AWveHEhXjeXb5rzlgAAAFqSURBVEjH1dbJVsJAEIXhHjJ05tlEooK8/0NKsbDrFjmHiBD0Lvqcf9PfthRM7xvoZMQuLHZaOejGYLtcdEItzI9oaLg5xIHj5hgcG262oXXcrGzJ23Umg5717C7NKBrAjOMDM8YgCI5ghmEPprUTmMZkrBOtdbJgfpZovho0gwzNOkfTam9k5jSGkKlTMOezWT3VLH5qlg8wQzSbO5jJ28l8Z+YLmZMwuz9lupvNXpjlFTMTZv7vzFSatTDtGnNeYdpNzZTMSJhx5f84m8Y3mSEzJzTVolko3J7Qve+a0J3vntDWffdEaMUQQo1vTWjuuyA0UWvUUarqzuqLUMPt1MD3uKTaTdRwvdrdorpFtfZtH6eyK2F3RS23U3uhlr9VB1TdE1V2h7Vr1O4mdbdera6o+Wq1Vqi2rEktFapGoZopVLVCtVCXag19IBPUiiWpBrojE1QNXZAp1/TYbhKdKVwuWotORKfn9wu/DSc/X9T6qgAAAABJRU5ErkJggg==\"","import { withInstall } from '@/utils/withInstall'\nimport Border from './Border.vue'\nexport const EcanBorder = withInstall(Border)\nexport default EcanBorder\nexport * from './props'\n","import { transformToComponentProps } from '@/utils/props'\n\nexport type ModalPosition = 'default' | 'top' | 'center' | 'bottom'\n\nexport interface ModalProps {\n id: string\n type: string\n width: string\n height: string\n title: string\n titleFontSize: string\n titleColor: string\n backgroundColor: string\n backgroundImage: string\n backgroundSize: string\n keyName: string\n componentList: { [key: string]: any } []\n fullModal: boolean // 是否充满全屏\n originalWidth: string // 设计稿宽\n originalHeight: string // 设计稿长\n destroyOnClose: boolean\n position: ModalPosition\n}\n\nexport const modalProps: ModalProps = {\n id: '',\n type: 'ecanModal',\n title: '',\n titleFontSize: '14px',\n titleColor: '',\n width: '1000px',\n height: '800px',\n originalWidth: '1920px',\n originalHeight: '1080px',\n backgroundColor: '#fff',\n backgroundImage: '',\n backgroundSize: '100% 100%',\n keyName: '弹窗',\n componentList: [],\n fullModal: false,\n destroyOnClose: true,\n position: 'default'\n}\n\nexport const modalComponentProps = transformToComponentProps(modalProps)\n\nexport const modalEvents = ['showModal']\n","<template>\n <!-- centered + style 中的 verticalAlign 调整弹窗位置 -->\n <a-modal\n :getContainer=\"getContainer\"\n :wrapClassName=\"wrapClassName\"\n centered\n :visible=\"visible\"\n :footer=\"null\"\n :width=\"isFullModal || isFullWidth ? '100%' : modalWith\"\n :destroyOnClose=\"destroyOnClose\"\n :style=\"modalStyle\"\n @ok=\"onOk\"\n @cancel=\"onCancel\"\n >\n <template #title v-if=\"title\" >\n <div\n :style=\"{\n fontSize: titleFontSize,\n color: titleColor,\n backgroundColor,\n padding: '16px 24px'\n }\"\n >\n {{ title }}\n </div>\n </template>\n <div class=\"contain\" ref=\"contain\" :style=\"containStyle\">\n <div class=\"content\" :style=\"contentStyle\">\n <component\n v-for=\"(component, index) in componentList\"\n :key=\"(component.id) + index\"\n :is=\"component.type\"\n v-bind=\"component\"\n />\n </div>\n </div>\n </a-modal>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, nextTick, ref, unref } from 'vue'\nimport { modalComponentProps, ModalPosition } from './props'\nimport { Modal as AModal } from 'ant-design-vue'\nimport 'ant-design-vue/es/modal/style'\nimport { useOnEvent, usePickComponentStyle, useImagePath } from '@/hooks'\nimport { REQUEST_MODEL } from '@/utils/constant'\nexport default defineComponent({\n name: 'EcanModal',\n components: {\n AModal\n },\n props: {\n ...modalComponentProps\n },\n setup (props) {\n const getContainer = () => document.getElementById('ProviderConfig') || document.body\n const modalStyle = computed(() => {\n const position = props.position as ModalPosition\n const map = {\n default: '',\n top: 'top',\n center: 'middle',\n bottom: 'bottom'\n }\n return {\n verticalAlign: map[position]\n }\n })\n const width = props.width as string\n const height = props.height as string\n const originalWidth = props.originalWidth as string\n const originalHeight = props.originalHeight as string\n const scaleWidth = computed(() => parseFloat(width) / parseFloat(originalWidth))\n const scaleHeight = computed(() => parseFloat(height) / parseFloat(originalHeight))\n // 弹窗适配\n const modalWith = computed(() => `${unref(scaleWidth) * 100}%`)\n // const modalHeight = computed(() => `${scaleHeight.value * 100}%`)\n const screenWidth = computed(() => document.body.offsetWidth)\n const screenHeight = computed(() => document.body.offsetHeight)\n const containWidth = computed(() => unref(screenWidth) * unref(scaleWidth))\n const containHeight = computed(() => unref(screenHeight) * unref(scaleHeight))\n const containStyle = computed(() => ({\n width: `${unref(containWidth)}px`,\n height: `${unref(containHeight)}px`\n }))\n const style = usePickComponentStyle(props)\n const contentStyle = computed(() => ({\n ...unref(style),\n backgroundImage: useImagePath(props.backgroundImage as string, true),\n transform: `scale(${unref(containWidth) / parseFloat(width)},${unref(containHeight) / parseFloat(height)})`\n }))\n const isFullWidth = computed(() => unref(scaleWidth) >= 1)\n const isFullModal = computed(() => props.fullModal)\n const wrapClassName = computed(() => {\n let className = 'ecan-modal'\n if (unref(isFullWidth)) className += ' ecan-full-width-modal'\n if (unref(isFullModal)) className += ' ecan-full-modal'\n return className\n })\n const visible = ref(false)\n const contain = ref<HTMLElement>()\n const { touchRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n touchRequest: () => void 0\n })\n const showModal = () => {\n visible.value = true\n nextTick(() => {\n touchRequest()\n })\n }\n const hideModal = () => {\n visible.value = false\n }\n const onOk = () => {\n hideModal()\n }\n const onCancel = () => {\n hideModal()\n }\n // 注册\n useOnEvent(props, {\n showModal\n })\n\n return {\n contain,\n containStyle,\n contentStyle,\n getContainer,\n modalStyle,\n modalWith,\n isFullModal,\n style,\n visible,\n showModal,\n onOk,\n onCancel,\n isFullWidth,\n wrapClassName\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.contain {\n position: relative;\n overflow: hidden;\n}\n.content {\n transform-origin: left top;\n z-index: 999;\n}\n</style>\n\n<style lang=\"less\">\n.ecan-modal {\n .ant-modal-body {\n padding: 0;\n }\n .ant-modal-header {\n padding: 0;\n border-bottom: none;\n background: none;\n }\n}\n\n.ecan-full-width-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n }\n .ant-modal-body {\n flex: 1;\n }\n}\n\n.ecan-full-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n height: calc(100vh);\n }\n .ant-modal-body {\n flex: 1;\n }\n}\n\n[datav-theme='darkBlue'] .ecan-modal {\n .anticon-close > svg > path {\n fill: #fff;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Modal from './Modal.vue'\nexport const EcanModal = withInstall(Modal)\nexport default EcanModal\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface TabsProps extends Props {\n data: { [key:string]: any } []\n backgroundColor: string\n tabFontSize: string\n tabColor: string\n activeTabColor: string\n tabBackgroundImage: string\n tabBarGutter: string\n activeTabBackgroundImage\n value: string\n activeKey: number\n tabHorizontalPadding: string\n // 包含组件id\n contains: string []\n tabFontWeight: number\n tabAlignItems: 'flex-start' | 'center' | 'flex-end'\n tabJustifyContent: 'flex-start' | 'center' | 'flex-end',\n tabFlexDirection: 'row' | 'column'\n}\n\nexport const tabsProps: TabsProps = {\n ...props,\n tabHorizontalPadding: '0px',\n type: 'ecanTabs',\n name: '标签页',\n keyName: '标签页',\n width: '500px',\n height: '400px',\n tabFontSize: '14px',\n backgroundColor: '#ffffff',\n activeTabColor: '#1890ff',\n tabBackgroundImage: '',\n activeTabBackgroundImage: '',\n tabColor: '#333',\n tabBarGutter: '24px',\n tabFontWeight: 400,\n value: '',\n activeKey: 0,\n contains: [],\n tabFlexDirection: 'row',\n data: [\n {\n title: '标签1'\n },\n {\n title: '标签2'\n },\n {\n title: '标签3'\n }\n ],\n tabAlignItems: 'flex-start',\n tabJustifyContent: 'flex-start'\n}\n\nexport const tabsComponentProps = transformToComponentProps(tabsProps)\n\nexport const tabsEvents = ['tabChange']\n","<template>\n <div class=\"ecan-tabs\" :style=\"style\">\n <div\n class=\"tabs-header\"\n :style=\"{\n fontSize: tabFontSize,\n alignItems: tabAlignItems,\n justifyContent: tabJustifyContent,\n flexDirection: tabFlexDirection\n }\"\n >\n <div\n class=\"tab\"\n :style=\"{\n padding: `5px ${tabHorizontalPadding}`,\n color: isActive(index) ? activeTabColor : tabColor,\n backgroundImage: isActive(index) ? useImagePath(activeTabBackgroundImage, true) : useImagePath(tabBackgroundImage, true),\n marginRight: tabFlexDirection === 'row' ? tabBarGutter : null,\n marginBottom: tabFlexDirection === 'column' ? tabBarGutter : null,\n fontWeight: tabFontWeight\n }\"\n v-for=\"(tab, index) in myData\"\n :key=\"index\"\n @click.prevent.stop=\"tabChange(tab, index)\"\n >\n <div\n class=\"tab-inner\"\n :style=\"{\n borderBottom: !activeTabBackgroundImage && !tabBackgroundImage ? `1px solid ${isActive(index) ? activeTabColor : 'transparent'}` : ''\n }\"\n >\n {{tab.title}}\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, inject, ref, unref, watch } from 'vue'\nimport { tabsComponentProps } from './props'\nimport { useEmitEvent, useOnEvent, usePickComponentStyle, useImagePath } from '@/hooks'\nimport { GLOBAL_MODEL, REFRESH_PAGE } from '@/utils/constant'\nexport default defineComponent({\n name: 'EcanTabs',\n props: {\n ...tabsComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const activeKey = ref(0)\n watch(() => props.activeKey, (key) => {\n activeKey.value = key\n }, {\n immediate: true\n })\n const myData = ref<{ [key:string]: any } []>([])\n watch(() => props.data, (data: { [key:string]: any } []) => {\n myData.value = data\n }, {\n immediate: true,\n deep: true\n })\n const isActive = (index: number) => activeKey.value === index\n const myValue = ref(props.value || (unref(myData)[0] && unref(myData)[0]?.value) || '')\n // 注册函数触发事件拦截器\n const emitEvent = useEmitEvent(props)\n const { setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n // 初始化设置值\n setGlobalModel(props.id as string, {\n value: myValue,\n activeKey\n })\n\n const { emitRefreshPage } = inject(REFRESH_PAGE, {\n // eslint-disable-next-line no-void\n emitRefreshPage: () => void 0\n })\n\n const tabChange = emitEvent('tabChange', (tab:{ [key:string]:any }, index: number) => {\n if (index !== unref(activeKey)) {\n myValue.value = tab?.value || ''\n activeKey.value = index\n emitRefreshPage()\n }\n })\n useOnEvent(props, {\n tabChange\n })\n return {\n style,\n activeKey,\n isActive,\n tabChange,\n myData,\n useImagePath\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.ecan-tabs {\n display: flex;\n}\n\n.tabs-header {\n width: 100%;\n color: #333333;\n display: flex;\n padding: 0 10px;\n}\n\n.tab {\n background-size: 100% 100%;\n background-repeat: no-repeat;\n cursor: default;\n display: flex;\n justify-content: center;\n align-items: center;\n}\n\n.tab:last-child {\n margin-bottom: 0 !important;\n margin-right: 0 !important;\n}\n\n.tabs-content {\n flex:1;\n}\n</style>\n","import Tabs from './Tabs.vue'\nimport { withInstall } from '../../utils/withInstall'\nexport const EcanTabs = withInstall(Tabs)\nexport default EcanTabs\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface ImageProps extends Props {\n imgUrl: string\n href: string\n target: 'self' | 'blank' | 'event' // 打开方式\n linkPage: string // 传入pageId\n}\n\nexport const imageProps: ImageProps = {\n ...props,\n name: '图片',\n keyName: '图片',\n type: 'ecanImage',\n width: '300px',\n height: '300px',\n imgUrl: '',\n target: 'self',\n href: '',\n linkPage: ''\n}\n\nexport const imageComponentProps = transformToComponentProps(imageProps)\n","<template>\n <img\n :style=\"style\"\n :src=\"myImgUrl\"\n v-if=\"myImgUrl !== ''\"\n @click=\"onClick\"\n />\n <div\n class=\"image-placeholder\"\n :style=\"style\"\n v-else\n >\n 请上传图片\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, unref } from 'vue'\nimport { imageComponentProps } from './props'\nimport { useImagePath, usePickComponentStyle, usePageUrl, useVariablesInText } from '@/hooks'\nimport { GLOBAL_CONFIG } from '@/utils/constant'\nexport default defineComponent({\n name: 'EcanImage',\n props: {\n ...imageComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const myImgUrl = computed(() => useImagePath(props.imgUrl as string))\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n const onClick = () => {\n // 空链接、空页面直接 return\n if (!props.linkPage && !props.href) return\n const linkPage = (props.linkPage || '') as string\n const pageUrl = usePageUrl(unref(pageMode), linkPage)\n // 优先使用外部链接,再使用url\n const href = props.href as string\n let url = href || pageUrl\n url = useVariablesInText(url)\n const target = props.target\n if (target == null || target === '') return\n if (target !== 'event') {\n window.open(url, '_' + (target as string))\n } else {\n window.parent.postMessage({\n type: 'openPage',\n url: href\n }, '*')\n }\n }\n return {\n style,\n myImgUrl,\n onClick\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.image-placeholder {\n display: grid;\n place-content: center;\n border: 1px solid #d9d9d9;\n font-size: 16px;\n color: #333;\n width: 100%;\n overflow: hidden;\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Image from './Image.vue'\nexport const EcanImage = withInstall(Image)\nexport default EcanImage\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface IframeProps extends Props {\n link: string,\n linkType: 'web' | 'erd'\n}\n\nexport const iframeProps: IframeProps = {\n ...props,\n name: '网页',\n keyName: '网页',\n type: 'ecanIframe',\n width: '300px',\n height: '300px',\n link: '',\n linkType: 'web'\n}\n\nexport const iframeComponentProps = transformToComponentProps(iframeProps)\n","<template>\n <iframe\n :src=\"myLink\"\n :style=\"style\"\n v-if=\"myLink\"\n />\n <div\n class=\"iframe-placeholder\"\n :style=\"style\"\n v-else\n >\n 请填写网页链接\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, computed, inject, unref } from 'vue'\nimport { usePickComponentStyle, useVariablesInText } from '@/hooks'\nimport { iframeComponentProps } from '@/media/iframe/props'\nimport { GLOBAL_CONFIG, ERD_URL } from '@/utils/constant'\nexport default defineComponent({\n name: 'EcanIframe',\n props: {\n ...iframeComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const { contextRequestUrl } = inject(GLOBAL_CONFIG, {\n contextRequestUrl: ''\n })\n const myLink = computed(() => {\n let link = useVariablesInText(props.link as string)\n if (props.linkType === 'erd' && link != null) {\n let ctxErdUrl = unref(contextRequestUrl)\n if (ctxErdUrl[ctxErdUrl.length - 1] === '/') {\n ctxErdUrl += 'erdReport'\n } else {\n ctxErdUrl += '/erdReport'\n }\n const erdUrl = ERD_URL || ctxErdUrl\n link = `${erdUrl}?_t=0&uid=${link}`\n }\n return link\n })\n return {\n style,\n myLink\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.iframe-placeholder {\n display: grid;\n place-content: center;\n border: 1px solid #d9d9d9;\n font-size: 16px;\n color: #333;\n width: 100%;\n overflow: hidden;\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Iframe from './Iframe.vue'\nexport const EcanIframe = withInstall(Iframe)\nexport default EcanIframe\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface TableProps extends Props {\n columns: { [key: string]: any } []\n data: { [key: string]: any } []\n bordered: boolean\n size: 'default' | 'middle' | 'small'\n isUseSeq: boolean\n columnsFixedNum: number\n scrollX: number\n paginationShow: boolean\n paginationPosition: 'topLeft' | 'topCenter' | 'topRight' | 'bottomLeft' | 'bottomCenter' | 'bottomRight'\n simple: boolean\n cellBackgroundColor: string\n borderColor: string\n paginationPageSize: number\n isUseAction: boolean // 添加操作列\n actionColumnWidth: number\n actionList: { [key: string]: any } []\n headerFontSize: string\n headerFontWeight: number\n fontSize: string\n fontWeight: number\n isReverse: boolean\n clickHighlight: boolean\n filterDropdownHeight: string\n graphicConfig: {\n [key:string]: any,\n // 全部属性, 为了属性可拓展,所以在设计器中自由添加\n // classification: { [key:string]: any }\n // series: { [key:string]: any }\n // indicatorList: { [key:string]: any } []\n // sqlConditions: { [key:string]: any } []\n // idxLibMode: string\n // source: string\n // dataViewId: string\n chartType: 'table' // 图表类型,后台接口\n plugin: '1' // 插件类型,后台接口\n layer: '1' // 表格类型, 后台接口\n }\n}\n\nexport const tableProps: TableProps = {\n ...props,\n zIndex: 2,\n name: '表格',\n keyName: '表格',\n type: 'ecanTable',\n width: '400px',\n height: '240px',\n bordered: false,\n headerFontSize: '14px',\n fontSize: '14px',\n isUseSeq: false,\n size: 'default',\n headerFontWeight: 400,\n fontWeight: 400,\n columnsFixedNum: 0,\n scrollX: 0,\n paginationShow: true,\n isReverse: false,\n simple: false,\n cellBackgroundColor: '',\n borderColor: '',\n paginationPosition: 'bottomRight',\n paginationPageSize: 10,\n isUseAction: false,\n clickHighlight: false,\n filterDropdownHeight: '200px',\n actionList: [{\n title: '',\n href: '',\n target: '',\n color: ''\n }],\n actionColumnWidth: 100,\n columns: [\n {\n title: '姓名',\n dataIndex: 'name'\n },\n {\n title: '年龄',\n dataIndex: 'age'\n },\n {\n title: '住址',\n dataIndex: 'address'\n }\n ],\n data: [\n {\n name: '小明',\n age: 32,\n address: '福州软件园'\n },\n {\n name: '小红',\n age: 25,\n address: '福州软件园'\n }\n ],\n graphicConfig: {\n chartType: 'table', // 图表类型,后台接口\n plugin: '1', // 插件类型,后台接口\n layer: '1' // 图类型, 后台接口\n }\n}\n\n// 转化默认属性\nexport const tableComponentProps = transformToComponentProps(tableProps)\n\nexport const tableEvents = ['click', 'refreshData', 'resetRecord']\n","<template>\n <div class=\"ecan-table\" :style=\"style\">\n <skeleton :loading=\"loading\">\n <a-table\n class=\"table\"\n :style=\"{\n height: '100%'\n }\"\n :columns=\"tableColumns\"\n :data-source=\"tableDataSource\"\n :bordered=\"bordered\"\n :size=\"size\"\n :customRow=\"customRow\"\n :scroll=\"{ x, y }\"\n :pagination=\"pagination\"\n @change=\"tableChange\"\n >\n <template #customFilterDropdown=\"{ column, selectedKeys, setSelectedKeys, confirm, clearFilters }\">\n <div\n class=\"ecan-table-filter\"\n :style=\"{\n height: filterDropdownHeight\n }\"\n >\n <a-input\n v-model:value=\"column.filterOptionsInputValue\"\n placeholder=\"请输入关键字\"\n :value=\"selectedKeys[0]\"\n class=\"filter-input\"\n @change=\"onSearchFilterOptions\"\n />\n <a-checkbox-group\n v-model:value=\"column.filterCheckboxGroupValue\"\n class=\"filter-checkbox\"\n :options=\"useFilterOptions(column)\"\n @change=\"useSetSelectedKeys(setSelectedKeys, column)\"\n >\n </a-checkbox-group>\n <div>\n <a-button\n type=\"primary\"\n size=\"small\"\n style=\"width: 90px; margin-right: 8px\"\n @click=\"() => confirm()\"\n >\n 搜索\n </a-button>\n <a-button\n size=\"small\"\n style=\"width: 90px\"\n @click=\"onResetFilter(clearFilters, column)\"\n >\n 重置\n </a-button>\n </div>\n </div>\n </template>\n <template #bodyCell=\"{ column, index, text, record }\">\n <template v-if=\"column.dataIndex === 'SEQ'\">\n <span>{{ index + 1 }}</span>\n </template>\n <!-- 操作列配置 -->\n <template v-if=\"column.dataIndex === 'ACTION'\">\n <div class=\"action-list\">\n <div class=\"action\" v-for=\"(action, index) in actionList\" :key=\"index\">\n <a\n :href=\"handleHref(action.href, record)\"\n :target=\"handleHrefTarget(action.target)\"\n :style=\"{\n color: action.color,\n fontSize,\n fontWeight\n }\"\n @click=\"onTouchHrefEvent(action.target, handleHref(action.href, record))\"\n >\n {{ action.title }}\n </a>\n </div>\n </div>\n </template>\n <template v-else>\n <div\n :class=\"[contrastClass(text, column.format)]\"\n :style=\"{\n fontSize,\n fontWeight\n }\"\n >\n {{ column.format != null ? formatFn(text, column.format) : text }}\n </div>\n </template>\n </template>\n <template #summary>\n <a-table-summary v-if=\"summaryList.length > 0\">\n <a-table-summary-row>\n <a-table-summary-cell\n v-for=\"(summary, index) in summaryList\"\n :key=\"index\"\n :index=\"index\"\n :style=\"{\n backgroundColor: cellBackgroundColor,\n textAlign: summary.cellAlign || 'center',\n color: summary.cellColor,\n borderBottomColor: borderColor,\n }\"\n >\n <div\n :class=\"[contrastClass(summary.total, summary.format)]\"\n :style=\"{\n fontSize,\n fontWeight\n }\"\n >\n {{ (summary.format != null || summary.format !== '') && formatFn(summary.total, summary.format) }}\n </div>\n </a-table-summary-cell>\n </a-table-summary-row>\n </a-table-summary>\n </template>\n </a-table>\n </skeleton>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, unref, ref, watch, inject, reactive } from 'vue'\nimport {\n Input as AInput,\n CheckboxGroup as ACheckboxGroup,\n // Checkbox as ACheckbox,\n Table as ATable,\n TableSummary as ATableSummary,\n TableSummaryRow as ATableSummaryRow,\n TableSummaryCell as ATableSummaryCell\n} from 'ant-design-vue'\nimport 'ant-design-vue/es/input/style'\nimport 'ant-design-vue/es/checkbox/style'\nimport 'ant-design-vue/es/table/style'\nimport {\n usePickComponentStyle,\n useEmitEvent,\n useRequestData,\n useOnEvent,\n useIndicatorData,\n useVariablesInText\n} from '@/hooks'\nimport { tableComponentProps } from './props'\nimport { formatMoney, formatPercentage } from '@/utils/util'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport Skeleton from '@/common/skeleton/Skeleton.vue'\nimport { cloneDeep } from 'lodash-es'\nimport { RequestModalParam } from '@/utils/types'\n// import { Big } from 'big.js'\nexport default defineComponent({\n name: 'EcanTable',\n components: {\n Skeleton,\n AInput,\n ACheckboxGroup,\n ATable,\n ATableSummary,\n ATableSummaryRow,\n ATableSummaryCell\n },\n props: {\n ...tableComponentProps\n },\n setup (props, { expose }) {\n const style = usePickComponentStyle(props)\n const splitY = computed(() => {\n if (props.paginationShow) {\n switch (props.size) {\n case 'small':\n return 90\n case 'middle':\n return 100\n default:\n return 120\n }\n } else {\n switch (props.size) {\n case 'small':\n return 40\n case 'middle':\n return 47\n default:\n return 55\n }\n }\n })\n const x = computed(() => props.scrollX)\n const y = computed(() => parseFloat(props.height as string) - unref(splitY))\n const myColumns = ref<{ [key: string]: any } []>([])\n const myDataSource = ref<{ [key: string]: any } []>([])\n const tableColumns = ref<{ [key: string]: any } []>([])\n const tableDataSource = ref<{ [key: string]: any } []>([])\n const total = ref(0)\n const pageNum = ref(1)\n const pageSize = computed(() => props.paginationPageSize as number)\n const filterDataIndexList = reactive([])\n const handleChildrenColumns = (_columns: { [key: string]: any } [] = []) => {\n if (Array.isArray(_columns) && _columns.length > 0) {\n const len = _columns.length\n const columnsFixedNum = props.columnsFixedNum as number\n // 这里的循环为了 props 是引用类型,会造成脏数据(上次修改后,还会存在上次的数据)\n // 如果使用深拷贝会造成性能的浪费,循环来说相对更快\n for (let i = 0; i < len; i++) {\n const column = _columns[i]\n if (i < columnsFixedNum) {\n column.fixed = 'left'\n } else {\n column.fixed = false\n }\n const {\n cellAlign = 'center',\n cellColor,\n dataIndex,\n title,\n tableFilter,\n headerCellAlign,\n headerCellColor\n } = column\n if (tableFilter) {\n filterDataIndexList.push(dataIndex)\n column.filterOptionsInputValue = ''\n column.filterCheckboxGroupValue = []\n column.customFilterDropdown = true\n column.onFilter = (value, record) => record[dataIndex].toString().toLowerCase().includes(value.toLowerCase())\n }\n // 通用配置\n // 头部单元格\n column.customHeaderCell = () => ({\n style: {\n display: 'table-cell',\n verticalAlign: 'middle',\n fontSize: props.headerFontSize,\n fontWeight: props.headerFontWeight,\n textAlign: headerCellAlign || 'center',\n color: headerCellColor,\n borderBottomColor: props.borderColor\n }\n })\n // 表格单元格\n column.customCell = (record, rowIndex) => ({\n style: {\n textAlign: cellAlign,\n color: cellColor,\n backgroundColor: props.cellBackgroundColor,\n borderBottomColor: props.borderColor\n },\n class: {\n highlight: unref(useRowIndex) === rowIndex && props.clickHighlight\n },\n onClick: emitEvent('click', () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n record = {\n dataIndex,\n title,\n ...record\n }\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: record })\n })\n })\n if (Array.isArray(column.children)) {\n handleChildrenColumns(column.children)\n }\n }\n }\n }\n const handleColumns = (columns: { [key: string]: any } [] = []) => {\n // 复制表头数据\n if (props.isUseSeq) {\n // 添加序号\n columns.unshift({\n title: '序号',\n dataIndex: 'SEQ',\n align: 'center'\n })\n }\n // 添加操作列\n if (props.isUseAction) {\n columns.push({\n title: '操作',\n dataIndex: 'ACTION',\n width: props.actionColumnWidth\n })\n }\n handleChildrenColumns(columns)\n return columns\n }\n watch(() => [\n props.columns,\n props.isUseSeq,\n props.isUseAction,\n props.columnsFixedNum,\n props.actionColumnWidth,\n props.cellBackgroundColor,\n props.borderColor\n ], () => {\n myColumns.value = handleColumns(cloneDeep(props.columns as any []))\n }, {\n immediate: true,\n deep: true\n })\n watch(() => [props.data, props.dataType], ([data, dataType]) => {\n if (dataType !== 'static') return\n myDataSource.value = data as { [key:string]:any } []\n }, {\n immediate: true\n })\n const allFilterOptions = ref({})\n const handleFilterCheckboxOptions = (dataSource: { [key:string]: any } []) => {\n if (Array.isArray(dataSource)) {\n const dataLen = dataSource.length\n const keys = filterDataIndexList\n const keysLen = keys.length\n const filterOptionsMap: { [key:string]: Set<string> } = {}\n for (let i = 0; i < dataLen; i++) {\n const record = dataSource[i]\n for (let j = 0; j < keysLen; j++) {\n const key = keys[j]\n if (filterOptionsMap[key]) {\n filterOptionsMap[key].add(record[key])\n } else {\n const set = new Set<string>()\n set.add(record[key])\n filterOptionsMap[key] = set\n }\n }\n }\n const _allFilterOptions: { [key:string]: { label:string, value: string } [] } = {}\n for (const key in filterOptionsMap) {\n if (Object.prototype.hasOwnProperty.call(filterOptionsMap, key)) {\n const optionsSet = filterOptionsMap[key]\n const options = Array.from(optionsSet)\n _allFilterOptions[key] = options.map((option) => ({ label: option, value: option }))\n }\n }\n allFilterOptions.value = _allFilterOptions\n }\n }\n watch(() => [props.isReverse, myColumns.value, myDataSource.value], () => {\n const _columns = unref(myColumns)\n const _dataSource = unref(myDataSource)\n handleFilterCheckboxOptions(_dataSource)\n if (props.isReverse) {\n const { columns, dataSource } = handleReverseTable(cloneDeep(_columns), cloneDeep(_dataSource))\n tableColumns.value = columns\n tableDataSource.value = dataSource\n } else {\n tableColumns.value = _columns\n tableDataSource.value = _dataSource\n }\n }, {\n immediate: true,\n flush: 'post'\n })\n const handleReverseTable = (columns: { [key:string]: any} [], dataSource: { [key:string]: any} []) => {\n const firstColumns = columns[0]\n const _columns = [{\n title: firstColumns.title,\n dataIndex: 'col0',\n key: 'col0',\n align: 'center'\n }] as { [key:string]: any } []\n for (let i = 0; i < dataSource.length; i++) {\n const data = dataSource[i]\n const dataIndex = 'col' + (i + 1)\n _columns.push({\n title: data[firstColumns.dataIndex],\n dataIndex,\n key: dataIndex,\n align: 'center'\n })\n }\n const _dataSource = [] as { [key:string]: any } []\n for (let i = 1; i < columns.length; i++) {\n const column = columns[i]\n const _data = { col0: column.title }\n for (let j = 0; j < dataSource.length; j++) {\n const data = dataSource[j]\n _data[`col${j + 1}`] = data[column.dataIndex]\n }\n _dataSource.push(_data)\n }\n return {\n columns: _columns,\n dataSource: _dataSource\n }\n }\n const orderCondition = ref<string>('')\n const requestData = useRequestData(props)\n const loading = ref(false)\n const handleRequestData = async (isUseLoading: boolean = true) => {\n try {\n if (isUseLoading) loading.value = true\n // 初始参数:排序\n let params = {} as { [key:string]: any }\n if (unref(orderCondition)) {\n params.orderCondition = unref(orderCondition)\n }\n // 分页\n if (props.paginationShow) {\n params = {\n pageNum: unref(pageNum),\n pageSize: unref(pageSize),\n layer: '1',\n ...params\n }\n }\n const res = await requestData(params)\n const { rows = [], total: tableTotal = 0 } = res?.data?.data || {}\n total.value = tableTotal\n if (Array.isArray(rows)) {\n myDataSource.value = rows\n }\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n const tableChange = ({ current }: { current: number }, _filters, sorter) => {\n pageNum.value = current\n if (sorter && Object.keys(sorter).length > 0) {\n const { field, order } = sorter as { field: string | null, order: 'ascend' | 'descend' }\n const map = {\n ascend: 'asc',\n descend: 'desc'\n }\n const fieldOrder = map[order]\n if (field != null && fieldOrder != null) {\n orderCondition.value = field + ' ' + fieldOrder\n pageNum.value = 1\n }\n }\n refreshData(false)\n }\n const pagination = computed(() => {\n const simple = props.simple\n const position = [props.paginationPosition]\n return props.paginationShow && {\n simple,\n position,\n total: unref(total),\n current: unref(pageNum),\n pageSize: unref(pageSize),\n showSizeChanger: false\n }\n })\n const formatBoolean = (value: string | number) => {\n if (+value === 1) return '是'\n if (+value === 0) return '否'\n return value\n }\n type Format = 'money' | 'percentage' | 'contrast' | 'boolean' | ''\n const formatFn = (value: string | number, format?: Format) => {\n if (format == null || format === '') return value\n const map = {\n money: formatMoney,\n percentage: formatPercentage,\n contrast: formatPercentage,\n boolean: formatBoolean\n }\n return map[format](value) || ''\n }\n const contrastClass = (value: string | number, format: Format) => {\n const _value = parseFloat(value + '')\n if (format !== 'contrast') {\n return ''\n }\n switch (true) {\n case _value >= 0:\n return 'goUp'\n case _value < 0:\n return 'goDown'\n }\n }\n\n const emitEvent = useEmitEvent(props)\n\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n\n const handleIndicatorDataset = (dataColumns: any [] = [], dataRows: { [key:string]: any }[] = []) => {\n const _columns = dataColumns.map((column: string) => ({ title: column, dataIndex: column, key: column }))\n myColumns.value = handleColumns(_columns)\n myDataSource.value = dataRows\n }\n\n // 指标库\n const indicatorData = useIndicatorData(props)\n const handleIndicatorData = async () => {\n try {\n loading.value = true\n const res = await indicatorData()\n handleIndicatorDataset(res?.data?.data?.columns, res?.data?.data?.rows)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n //\n // const customHeaderRow = () => ({\n // style: {\n // backgroundColor: props.headerBackgroundColor\n // }\n // })\n const useRowIndex = ref(-1)\n\n const customRow = (record, index) => ({\n onClick: emitEvent('rowClick', () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: record })\n useRowIndex.value = index\n })\n })\n\n const refreshData = (isUseLoading: boolean = true) => {\n if (unref(pageMode) === 'design') return\n switch (props.dataType) {\n case 'request':\n handleRequestData(isUseLoading)\n break\n case 'indicator':\n handleIndicatorData()\n break\n }\n }\n\n const resetRecord = () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n setGlobalModel(id, { ...modal, RECORD: '' })\n }\n\n useOnEvent(props, {\n resetRecord,\n refreshData\n })\n const summaryList = computed(() => {\n const columns = unref(tableColumns)\n const summaryList = [] as { [key: string]: any } []\n let calcTotalCount = 0\n for (let i = 0; i < columns.length; i++) {\n const column = columns[i]\n const { isCalcTotal } = column\n if (props.isUseSeq && i === 0) {\n summaryList.push({\n ...column,\n total: '小计'\n })\n } else if (isCalcTotal) {\n summaryList.push({\n ...column,\n index: i,\n total: 0\n })\n calcTotalCount++\n } else {\n summaryList.push({\n ...column\n })\n }\n }\n // 为空直接返回\n if (calcTotalCount === 0) return []\n let records = unref(tableDataSource)\n if (props.paginationShow) {\n const start = (unref(pageNum) - 1) * unref(pageSize)\n const end = start + unref(pageSize)\n records = records.slice(start, end)\n }\n for (let i = 0; i < summaryList.length; i++) {\n const summary = summaryList[i]\n let total: number = 0\n const { isCalcTotal, dataIndex } = summary\n if (isCalcTotal === true) {\n for (let j = 0; j < records.length; j++) {\n const record = records[j]\n const num = +record[dataIndex]\n total += num\n // console.log(num)\n // if (!isNaN(num)) {\n // total = new Big(total).add(num).toNumber()\n // }\n }\n summary.total = total\n }\n }\n return summaryList\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n\n setRequest({\n id: props.id as string,\n requestFn: refreshData,\n sortNum: props.requestSort as number\n })\n\n expose({\n refreshData\n })\n\n const handleHref = (href: string = '', data: { [key:string]: any }) => {\n return useVariablesInText(href, data)\n }\n\n const handleHrefTarget = (target: 'self' | 'blank' | 'event') => {\n if (target === 'event') {\n return undefined\n } else {\n const map = {\n self: '_self',\n blank: '_blank'\n }\n return map[target]\n }\n }\n\n const onTouchHrefEvent = (target: 'self' | 'blank' | 'event', href: string = '') => {\n if (target === 'event') {\n window.parent.postMessage({\n type: 'openPage',\n url: href\n }, '*')\n }\n }\n\n const useSetSelectedKeys = (setSelectedKeys, column) => {\n setSelectedKeys(column.filterCheckboxGroupValue)\n }\n\n const onResetFilter = (clearFilters, column) => {\n clearFilters({ confirm: true })\n column.filterOptionsInputValue = ''\n column.filterCheckboxGroupValue = []\n }\n const onSearchFilterOptions = () => {}\n const useFilterOptions = (column) => {\n const key = column.dataIndex\n if (typeof key === 'string') {\n let filterOptions = unref(allFilterOptions)[key]\n const _inputValue = unref(column.filterOptionsInputValue).trim()\n if (Array.isArray(filterOptions)) {\n filterOptions = filterOptions.filter((filterOption) => {\n if (typeof filterOption.label === 'string') {\n return filterOption.label.toLowerCase().includes(_inputValue.toLowerCase())\n }\n return true\n })\n return filterOptions\n }\n return []\n }\n return []\n }\n return {\n x,\n y,\n style,\n customRow,\n pagination,\n formatFn,\n contrastClass,\n tableChange,\n summaryList,\n loading,\n onTouchHrefEvent,\n handleHref,\n handleHrefTarget,\n useRowIndex,\n tableColumns,\n tableDataSource,\n useFilterOptions,\n useSetSelectedKeys,\n onResetFilter,\n onSearchFilterOptions\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.table {\n width: 100%;\n}\n\n.goUp {\n color: #FF512E;\n display: flex;\n align-items: center;\n justify-content: center;\n &:before {\n content: '';\n display: block;\n background-image: url(\"../../assets/go-up.png\");\n width: 12px;\n height: 12px;\n background-repeat: no-repeat;\n background-size: cover;\n margin-right: 2px;\n }\n}\n\n.goDown {\n color: #39cf93;\n display: flex;\n align-items: center;\n justify-content: center;\n &:before {\n content: '';\n display: block;\n background-image: url(\"../../assets/go-down.png\");\n width: 12px;\n height: 12px;\n background-repeat: no-repeat;\n background-size: cover;\n margin-right: 2px;\n }\n}\n\n.action-list {\n display: flex;\n width: 100%;\n}\n.action {\n flex: 1;\n}\n\n.filter-input {\n width: 188px;\n margin-bottom: 8px;\n display: block\n}\n\n.filter-checkbox {\n width: 188px;\n margin-bottom: 8px;\n}\n</style>\n\n<style lang=\"less\">\n.ecan-table-filter {\n padding: 8px;\n display: flex;\n flex-direction: column;\n .ant-checkbox-group {\n display: flex;\n flex-direction: column;\n flex: 1;\n overflow-y: auto;\n overflow-x: hidden;\n }\n\n .ant-checkbox-wrapper {\n width: 100%;\n padding: 5px 0;\n font-size: 16px;\n &:hover {\n background-color: #f5f5f5;\n }\n .ant-checkbox + span {\n width: 100%;\n word-break: break-all;\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical\n }\n }\n}\n\n.ecan-table {\n .highlight {\n background: #e6f7ff !important;\n }\n\n *::-webkit-scrollbar {\n //width: 6px;\n //height: 6px;\n }\n\n *::-webkit-scrollbar-thumb {\n border-radius: 3px;\n -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, .3);\n background-color: #c8c9ca !important;\n }\n\n *::-webkit-scrollbar-track {\n background-color: #fff;\n }\n\n .ant-table-cell-scrollbar {\n box-shadow: 0 1px 0 1px transparent;\n }\n\n .ant-table {\n color: rgba(0, 0, 0, .65);\n background: #ffffff;\n }\n\n .ant-table-thead > tr > th {\n color: rgba(0, 0, 0, .85);\n background: #fafafa;\n border-bottom: 1px solid #f0f0f0;\n }\n\n .ant-table-tbody > tr > td {\n border-bottom: 1px solid #f0f0f0;\n }\n\n .ant-table-bordered {\n .ant-table-container {\n border: 1px solid #f0f0f0 !important;\n }\n\n .ant-table-cell {\n border-right: 1px solid #f0f0f0 !important;\n }\n }\n\n .anticon {\n color: #bfbfbf;\n }\n\n}\n\n[datav-theme='darkBlue'] {\n .ecan-table {\n .highlight {\n background: #225b98 !important;\n }\n\n *::-webkit-scrollbar-thumb {\n background-color: #2f4dac !important;\n }\n\n *::-webkit-scrollbar-track {\n background-color: #192c70;\n }\n\n *::-webkit-scrollbar-corner {\n background-color: #192c70 !important;\n }\n .ant-table {\n color: #e8e8e8;\n background: #071655;\n }\n\n .ant-table.ant-table-bordered > .ant-table-container > .ant-table-content > table,\n .ant-table.ant-table-bordered > .ant-table-container > .ant-table-header > table {\n border-top: 1px solid #3e8ee3 !important;\n }\n\n .ant-table-thead > tr > th {\n color: #cdd0f7;\n background: #17338c;\n border-bottom: 1px solid #3e8ee3;\n }\n\n .ant-table-tbody > tr > td {\n border-bottom: 1px solid #3e8ee3;\n }\n\n .ant-table-bordered {\n .ant-table-container {\n border: 1px solid #3e8ee3 !important;\n }\n\n .ant-table-cell {\n border-right: 1px solid #3e8ee3 !important;\n }\n }\n\n .ant-pagination-item-link {\n background: #17338c !important;\n }\n\n .ant-pagination-item {\n background: #17338c !important;\n }\n\n .anticon {\n color: rgba(255, 255, 255, .65) !important;\n }\n\n .ant-table-tbody > tr:hover:not(.ant-table-expanded-row):not(.ant-table-row-selected) > td {\n background: #225b98;\n }\n }\n\n td.ant-table-column-sort {\n background: #225b98;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Table from './Table.vue'\nexport const EcanTable = withInstall(Table)\nexport default EcanTable\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface MapProps extends Props {\n mapJson: { name: string, value: string } | null,\n data: { [key:string]: any } []\n backgroundImage: string\n backgroundImageRepeat: 'repeat' | 'repeat-x' | 'repeat-y' | 'no-repeat',\n symbolImage: string // 图标\n symbolWidth: number\n symbolHeight: number\n geoZoom: number\n geoRoam: boolean\n geoCenter: string\n geoBackgroundImage: string\n geoBackgroundImageRepeat: 'repeat' | 'repeat-x' | 'repeat-y' | 'no-repeat'\n geoLabelShow: boolean\n geoLabelColor: string\n geoLabelFontSize: number\n geoItemStyleAreaColor: string\n geoItemStyleBorderColor: string\n geoItemStyleBorderWidth: number\n geoItemStyleShadowColor: string\n geoItemStyleShadowOffsetX: number\n geoItemStyleShadowOffsetY: number\n geoItemStyleShadowBlur: number\n geoEmphasisDisabled: boolean\n geoEmphasisLabelColor: string\n geoEmphasisItemStyleAreaColor: string\n geoEmphasisItemStyleBorderColor: string\n itemStyleColor: string\n labelFontSize: number\n labelFormatter: string\n labelShow: boolean\n labelColor: string\n tooltipShow: boolean\n tooltipTextStyleColor: string\n tooltipFormatter: string\n}\n\nexport const mapProps: MapProps = {\n ...props,\n mapJson: null,\n data: [],\n name: '地图',\n keyName: '地图',\n type: 'ecanMap',\n width: '400px',\n height: '400px',\n backgroundImage: '',\n backgroundImageRepeat: 'no-repeat',\n geoBackgroundImage: '',\n geoBackgroundImageRepeat: 'no-repeat',\n symbolImage: '',\n symbolWidth: 10,\n symbolHeight: 10,\n itemStyleColor: '#11BFDA',\n labelFontSize: 14,\n labelShow: true,\n geoLabelShow: true,\n geoLabelColor: '#000',\n geoZoom: 1,\n geoRoam: false,\n geoCenter: '',\n geoLabelFontSize: 12,\n labelColor: '',\n labelFormatter: '{b}',\n geoItemStyleAreaColor: '#eee',\n geoItemStyleBorderColor: '#000',\n geoItemStyleBorderWidth: 1,\n geoItemStyleShadowColor: '',\n geoItemStyleShadowOffsetX: 0,\n geoItemStyleShadowOffsetY: 0,\n geoItemStyleShadowBlur: 0,\n geoEmphasisDisabled: false,\n geoEmphasisLabelColor: '#fff',\n geoEmphasisItemStyleAreaColor: '#f00',\n geoEmphasisItemStyleBorderColor: '#000',\n tooltipShow: true,\n tooltipTextStyleColor: '',\n tooltipFormatter: '{b}'\n}\n\nexport const mapComponentProps = transformToComponentProps(mapProps)\n","<template>\n <div class=\"ecan-map\" :style=\"style\">\n <echarts\n v-if=\"isLoadedData\"\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n />\n <img\n ref=\"geoBackgroundImageRef\"\n v-show=\"false\"\n :src=\"myGeoBackgroundImage\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, watch, ref, unref } from 'vue'\nimport { mapComponentProps } from './props'\nimport Echarts from '@/common/echarts'\nimport { use, registerMap } from 'echarts/core'\nimport { CanvasRenderer } from 'echarts/renderers'\nimport { MapChart, ScatterChart } from 'echarts/charts'\nimport { VisualMapComponent, TooltipComponent, GraphicComponent } from 'echarts/components'\nimport request from '@/utils/request'\nimport { usePickComponentStyle, useImagePath } from '../../hooks'\nuse([\n CanvasRenderer,\n MapChart,\n ScatterChart,\n VisualMapComponent,\n TooltipComponent,\n GraphicComponent\n])\nexport default defineComponent({\n name: 'EcanMap',\n components: {\n Echarts\n },\n props: {\n ...mapComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props, ['backgroundImage'])\n const geoBackgroundImageRef = ref()\n const myGeoBackgroundImage = computed(() => useImagePath(props.geoBackgroundImage as string))\n const myBackgroundImage = computed(() => useImagePath(props.backgroundImage as string))\n const areaColor = computed(() => {\n const backgroundImage = props.geoBackgroundImage as string\n if (backgroundImage) {\n return {\n image: unref(geoBackgroundImageRef),\n repeat: props.geoBackgroundImageRepeat\n }\n }\n return props.geoItemStyleAreaColor\n })\n const symbol = computed(() => {\n const symbolImage = props.symbolImage as string\n if (props.symbolImage) {\n return 'image://' + useImagePath(symbolImage)\n }\n return 'circle'\n })\n const option = computed(() => {\n const geoCenter = props.geoCenter\n let center: undefined | Array<any>\n if (typeof geoCenter === 'string' && geoCenter !== '') {\n center = geoCenter.split(',')\n }\n return {\n // backgroundColor: unref(background),\n tooltip: {\n show: true\n },\n graphic: [\n { // 一个图形元素,类型是 image。\n type: 'image',\n style: {\n width: parseFloat(props.width as string),\n height: parseFloat(props.height as string),\n image: unref(myBackgroundImage)\n },\n top: 'center'\n }\n ],\n geo: {\n zoom: props.geoZoom,\n roam: props.geoRoam,\n center,\n map: 'map',\n tooltip: {\n show: false\n },\n label: { // 地图上显示文字属性\n show: props.geoLabelShow,\n color: props.geoLabelColor,\n fontSize: props.geoLabelFontSize\n },\n itemStyle: { // 地图上板块属性\n areaColor: unref(areaColor),\n borderColor: props.geoItemStyleBorderColor,\n borderWidth: props.geoItemStyleBorderWidth,\n shadowColor: props.geoItemStyleShadowColor,\n shadowBlur: props.geoItemStyleShadowBlur,\n shadowOffsetX: props.geoItemStyleShadowOffsetX,\n shadowOffsetY: props.geoItemStyleShadowOffsetY\n },\n emphasis: { // 当鼠标悬停的时候\n disabled: props.geoEmphasisDisabled,\n label: {\n color: props.geoEmphasisLabelColor\n },\n itemStyle: {\n areaColor: props.geoEmphasisItemStyleAreaColor,\n borderColor: props.geoEmphasisItemStyleBorderColor\n }\n }\n },\n series: [\n {\n type: 'scatter',\n coordinateSystem: 'geo',\n itemStyle: {\n color: props.itemStyleColor\n },\n symbol: unref(symbol),\n symbolSize: [props.symbolWidth, props.symbolHeight],\n label: {\n show: props.labelShow,\n fontSize: props.labelFontSize,\n formatter: props.labelFormatter,\n color: props.labelColor\n },\n tooltip: {\n show: props.tooltipShow,\n formatter: props.tooltipFormatter,\n textStyle: {\n color: props.tooltipTextStyleColor\n }\n },\n data: props.data\n }\n ]\n }\n })\n // const echarts = ref()\n const isLoadedData = ref(false)\n const handleRegisterMap = async () => {\n const mapJson = props.mapJson as { name: string, path: string }\n if (mapJson != null && mapJson.path) {\n // @ts-ignore\n const res = await request(window?.config?.uploadPath + mapJson.path)\n registerMap('map', (res?.data || {}) as any)\n }\n isLoadedData.value = true\n }\n watch(() => props.mapJson, () => {\n handleRegisterMap()\n }, {\n immediate: true,\n deep: true\n })\n return {\n option,\n style,\n isLoadedData,\n geoBackgroundImageRef,\n myGeoBackgroundImage\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.ecan-map {\n display: flex;\n justify-content: center;\n align-items: center;\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Map from './Map.vue'\nexport const EcanMap = withInstall(Map)\nexport default EcanMap\nexport * from './props'\n","import { App } from 'vue'\nimport * as components from './components'\nconst install = (app: App) => {\n Object.keys(components).forEach(key => {\n const component = components[key]\n if (component.install) {\n app.use(component)\n }\n })\n}\n\n// 部分导出\nexport * from './components'\n// 全局安装\nexport default {\n install\n}\n"],"names":["METHOD_NAMES","usePublicAPI","chart","init","makePublicMethod","name","args","makePublicMethods","methods","useAutoresize","autoresize","root","resizeListener","watch","_","cleanup","throttle","addListener","removeListener","autoresizeProps","LOADING_OPTIONS_KEY","useLoading","loading","loadingOptions","defaultLoadingOptions","inject","realLoadingOptions","computed","unref","watchEffect","instance","loadingProps","onRE","isOn","key","omitOn","attrs","result","TAG_NAME","THEME_KEY","INIT_OPTIONS_KEY","UPDATE_OPTIONS_KEY","Echarts","defineComponent","props","listeners","shallowRef","manualOption","defaultTheme","defaultInitOptions","defaultUpdateOptions","manualUpdate","toRefs","realOption","realTheme","realInitOptions","realUpdateOptions","nonEventAttrs","option","initChart","realListeners","event","handler","resize","e","commit","nextTick","setOption","updateOptions","unwatchOption","publicApi","onMounted","onUnmounted","h","bound01","n","max","isOnePointZero","isPercent","isPercentage","boundAlpha","a","convertToPercentage","pad2","c","rgbToRgb","r","g","b","hue2rgb","p","q","t","hslToRgb","s","l","rgbToHsv","min","v","d","hsvToRgb","i","f","mod","rgbToHex","allow3Char","hex","convertHexToDecimal","parseIntFromHex","val","names","inputToRGB","color","rgb","ok","format","stringInputToObject","isValidCSSUnit","CSS_INTEGER","CSS_NUMBER","CSS_UNIT","PERMISSIVE_MATCH3","PERMISSIVE_MATCH4","matchers","named","match","hueStep","saturationStep","saturationStep2","brightnessStep1","brightnessStep2","lightColorCount","darkColorCount","darkColorMap","toHsv","_ref","hsv","toHex","_ref2","mix","rgb1","rgb2","amount","getHue","light","hue","getSaturation","saturation","getValue","value","generate","opts","patterns","pColor","colorString","_i","_hsv","_colorString","_ref3","index","opacity","darkColorString","presetPrimaryColors","presetPalettes","presetDarkPalettes","containers","styleElements","usage","createStyleElement","styleElement","insertCss","css","options","position","container","containerId","_objectSpread","target","source","ownKeys","sym","_defineProperty","obj","warn","valid","message","warning","isIconDefinition","node","rootProps","child","getSecondaryColor","primaryColor","generateColor","normalizeTwoToneColors","twoToneColor","iconStyles","cssInjectedFlag","useInsertStyles","styleStr","_excluded","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","sourceSymbolKeys","sourceKeys","twoToneColorPalette","setTwoToneColors","secondaryColor","getTwoToneColors","IconBase","context","_props$context$attrs","icon","restProps","colors","VueIcon","_slicedToArray","arr","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","o","minLen","_arrayLikeToArray","len","arr2","_arr","_n","_d","_s","_e","err","setTwoToneColor","_normalizeTwoToneColo","_normalizeTwoToneColo2","getTwoToneColor","Icon","_classObj","cls","spin","rotate","tabindex","onClick","classObj","svgClassString","iconTabIndex","svgStyle","_createVNode","AntdIcon","LoadingOutlined","LoadingOutlinedSvg","LoadingOutlined$1","_sfc_main$r","ASpin","_component_a_spin","_resolveComponent","_createElementBlock","_hoisted_1","_ctx","_openBlock","_createBlock","_renderSlot","_sfc_main$q","ASkeleton","_component_a_skeleton","withInstall","main","extra","app","comp","transformToComponentProps","mapValues","pageConfig","pageConfigComponentProps","styleList","usePickComponentStyle","excludeStyleList","finalStyleList","without","pick","EVENT_BUS","GLOBAL_CONFIG","GLOBAL_MODEL","REQUEST_MODEL","GLOBAL_TOKEN","REFRESH_PAGE","INDICATOR_URL","_a","_b","BASE_URL","_c","ERD_URL","useOnEvent","events","id","oldId","eventBus","useEmitEvent","type","touchEventId","ref","on","callback","emitEvent","useTransformChartDataByAttrValue","data","dataFieldNames","set","map","item","x","y","dimensions","dataset","handleFormatter","formatter","formatMoney","decimalPlaces","_value","formatPercentage","strValue","lowerCaseIncludes","v1","v2","useVariablesInText","useNewline","useSpace","variables","variable","statement","reg","textVariables","j","textVariable","usedVariable","useRequestData","callBack","requestUrl","method","headers","requestParams","requestInterval","isOpenRequestTimer","contextRequestUrl","pageMode","getGlobalModel","url","requestData","params","_params","param","record","prop","propKey","operate","mode","urlParams","keys","last","keysLen","isSetUrlParams","res","axios","requestDataTimer","useTransformChartDataByAttrKey","types","dataLen","typesLen","vs","label","m","useImagePath","path","isFormat","imagePath","usePageUrl","pageId","envPageUrl","proPageUrl","request","config","error","status","useRequestDiagramData","getIndicatorList","graphicConfig","indicatorList","leftAxis","show","indicator","getCalculationAxis","it","newIndicator","getSqlCondition","relativeList","list","keyName","searchName","searchType","variateName","watchItem","getSortParams","classification","classifyItem","row","rowIndex","handlerFilterParam","parent","conditions","join","fieldValue","fieldList","getFilterParams","filterList","componentType","xAxisValue","series","seriesItem","firstSeries","classify","sqlConditions","fixedDimSql","dataSourceId","idxLibMode","useValueFormatter","useIndicatorData","requestToken","handleQueryColumn","queryColumn","location","indexCode","handleIndicator","calcType","builtInFormula","builtInValueSource","builtInCalcWay","formula","handleSqlConditions","controlList","control","conditionLabel","conditionKey","conditionValueType","sqlCondition","model","dataViewId","plugin","layer","chartType","classificationList","seriesList","leftAxisList","rightAxisList","queryColumnList","indicators","preview","sort","customGroup","queryColumns","rightAxis","useHrefParamsToGlobalVariables","keyAndValue","_sfc_main$p","style","width","height","originalWidth","originalHeight","ready","observer","initSize","resolve","updateSize","updateScale","currentWidth","currentHeight","realWidth","realHeight","widthScale","heightScale","onResize","initMutationObserver","MutationObserver","removeMutationObserver","debounce","_sfc_render","_cache","$props","$setup","$data","$options","_normalizeStyle","EcanPageConfig","providerConfig","providerConfigComponentProps","_sfc_main$o","expose","setTheme","theme","provide","globalModel","setGlobalModel","mitt","eventBusKeySet","onEvent","k","onBeforeUnmount","offEvent","eventName","tokenNum","requestModel","requestMap","setRequest","requestFn","sortNum","requestFnList","handleRequestFnList","reject","resultList","queryUserToken","touchRequest","requestModelArr","emitRefreshPage","onRefreshPage","EcanProviderConfig","textProps","textComponentProps","textEvents","goUp","goDown","_sfc_main$n","Skeleton","myData","dataType","myText","text","handleRequestData","refreshData","click","linkPage","pageUrl","href","_component_skeleton","EcanText","_sfc_main$m","EcanScrollText","timeDisplayProps","timeDisplayComponentProps","_sfc_main$l","time","dayjs","timer","clearTimer","setTimer","EcanTimeDisplay","listProps","listComponentProps","listEvents","_sfc_main$k","dataSource","columnStyle","formatFn","contrastClass","_hoisted_2","_hoisted_3","_hoisted_4","_hoisted_7","_withCtx","_Fragment","_renderList","count","_createCommentVNode","column","_hoisted_5","_normalizeClass","EcanList","proportionProps","proportionComponentProps","proportionEvents","_sfc_main$j","AProgress","myWidth","myValue","defaultValue","valueSet","_component_a_progress","EcanProportion","inputProps","inputComponentProps","inputEvents","_sfc_main$i","AInput","handleSetGlobalModel","modal","inputChange","inputBlur","_component_a_input","$event","EcanInput","datePickerProps","datePickerComponentProps","datePickerEvents","_sfc_main$h","ADatePicker","getPopupContainer","useCurrentTime","dateChange","locale","_component_a_date_picker","EcanDatePicker","selectProps","selectComponentProps","selectEvents","_sfc_main$g","ASelect","filterOption","input","labelKey","valueKey","labelValue","valueValue","firstOption","selectChange","_component_a_select","EcanSelect","rangePickerProps","rangePickerComponentProps","rangePickerEvents","_sfc_main$f","ARangePicker","startTime","endTime","interval","intervalUnit","_startTime","_endTime","myStartTime","myEndTime","_component_a_range_picker","EcanRangePicker","buttonProps","buttonComponentProps","buttonEvents","_sfc_main$e","AButton","myHref","myTarget","_component_a_button","_createElementVNode","EcanButton","checkboxProps","checkboxComponentProps","checkboxEvents","_sfc_main$d","ACheckboxGroup","myOption","handleDataAndOption","checkboxChange","_component_a_checkbox_group","EcanCheckbox","pieProps","pieComponentProps","pieEvents","useDownloadFile","downloadFileUrl","fileName","blob","dom","use","CanvasRenderer","PieChart","TitleComponent","ToolboxComponent","TooltipComponent","LegendComponent","_sfc_main$c","Spin","AModal","visible","hideModal","isUseLabelColors","marker","seriesName","percent","handleDataset","handleIndicatorDataset","chartData","requestDiagram","handleIndicatorData","newArr","_f","chooseRequestOrDiagram","_component_spin","_component_echarts","_component_a_modal","EcanPie","lineProps","lineComponentProps","lineEvents","LineChart","_sfc_main$b","xAxisLabelFormatter","yAxisLabelFormatter","tooltipFormatter","useDataFieldNames","temp","keyTypeDataFieldNames","EcanLine","barProps","barComponentProps","barEvents","BarChart","DatasetComponent","_sfc_main$a","ds","indicatorData","columns","rows","fieldNames","EcanBar","scatterProps","scatterComponentProps","scatterEvents","ScatterChart","_sfc_main$9","EcanScatter","customGraphProps","customGraphComponentProps","_sfc_main$8","optionCode","evalCopy","echarts","EcanCustomGraph","comboGraphProps","comboGraphComponentProps","comboGraphEvents","_sfc_main$7","seriesTypes","seriesType","_tooltipFormatter","yAxis","axisIndex","axis","EcanComboGraph","borderProps","borderComponentProps","borderEvents","_sfc_main$6","borderStyle","_imports_0","_imports_1","_withScopeId","_pushScopeId","_popScopeId","_hoisted_6","_hoisted_8","_hoisted_9","_hoisted_14","_toDisplayString","_hoisted_10","_hoisted_11","_hoisted_12","_hoisted_15","EcanBorder","modalProps","modalComponentProps","modalEvents","_sfc_main$5","getContainer","modalStyle","scaleWidth","scaleHeight","modalWith","screenWidth","screenHeight","containWidth","containHeight","containStyle","contentStyle","isFullWidth","isFullModal","wrapClassName","className","contain","showModal","onOk","onCancel","_createSlots","component","_resolveDynamicComponent","_mergeProps","EcanModal","tabsProps","tabsComponentProps","tabsEvents","_sfc_main$4","activeKey","isActive","tabChange","tab","_withModifiers","EcanTabs","imageProps","imageComponentProps","_sfc_main$3","myImgUrl","EcanImage","iframeProps","iframeComponentProps","_sfc_main$2","myLink","link","ctxErdUrl","EcanIframe","tableProps","tableComponentProps","tableEvents","_sfc_main$1","ATable","ATableSummary","ATableSummaryRow","ATableSummaryCell","splitY","myColumns","myDataSource","tableColumns","tableDataSource","total","pageNum","pageSize","filterDataIndexList","reactive","handleChildrenColumns","_columns","columnsFixedNum","cellAlign","cellColor","dataIndex","title","tableFilter","headerCellAlign","headerCellColor","useRowIndex","handleColumns","cloneDeep","allFilterOptions","handleFilterCheckboxOptions","filterOptionsMap","_allFilterOptions","optionsSet","_dataSource","handleReverseTable","firstColumns","_data","orderCondition","isUseLoading","tableTotal","tableChange","current","_filters","sorter","field","order","fieldOrder","pagination","simple","formatBoolean","dataColumns","dataRows","customRow","summaryList","calcTotalCount","isCalcTotal","records","start","end","summary","num","filterOptions","_inputValue","setSelectedKeys","clearFilters","_component_a_table","selectedKeys","confirm","action","index2","_component_a_table_summary","_component_a_table_summary_row","_component_a_table_summary_cell","EcanTable","mapProps","mapComponentProps","MapChart","VisualMapComponent","GraphicComponent","_sfc_main","geoBackgroundImageRef","myGeoBackgroundImage","myBackgroundImage","areaColor","symbol","symbolImage","geoCenter","center","isLoadedData","handleRegisterMap","mapJson","registerMap","_withDirectives","EcanMap","components"],"mappings":"smEAGMA,GAAe,CACnB,WACA,YACA,SACA,YACA,SACA,iBACA,iBACA,mBACA,eACA,aACA,sBACA,aACA,QACA,aACA,SACF,EAKgB,SAAAC,GACdC,EACAC,EACe,CACf,SAASC,EACPC,EACqE,CACrE,MAAO,IAAIC,IAAS,CAKd,GAJCJ,EAAM,OACJC,IAGH,CAACD,EAAM,MACH,MAAA,IAAI,MAAM,iCAAiC,EAEnD,OAAQA,EAAM,MAAMG,CAAI,EAAU,MAAMH,EAAM,MAAOI,CAAI,CAAA,CAE7D,CAEA,SAASC,GAAoC,CACrC,MAAAC,EAAiB,OAAA,OAAO,IAAI,EAClC,OAAAR,GAAa,QAAgBK,GAAA,CACnBG,EAAAH,CAAI,EAAID,EAAiBC,CAAI,CAAA,CACtC,EAEMG,CACT,CAEA,OAAOD,EAAkB,CAC3B,CChDgB,SAAAE,GACdP,EACAQ,EACAC,EACM,CACN,IAAIC,EAAwC,KAE5CC,EAAAA,MAAM,CAACF,EAAMT,EAAOQ,CAAU,EAAG,CAAC,CAACC,EAAMT,EAAOQ,CAAU,EAAGI,EAAGC,IAAY,CACtEJ,GAAQT,GAASQ,IACnBE,EAAiBI,YAAS,IAAM,CAC9Bd,EAAM,OAAO,GACZ,GAAG,EAENe,eAAYN,EAAMC,CAAc,GAGlCG,EAAQ,IAAM,CACRH,GAAkBD,GACpBO,kBAAeP,EAAMC,CAAc,CACrC,CACD,CAAA,CACF,CACH,CAEO,MAAMO,GAAkB,CAC7B,WAAY,OACd,EC5BaC,GAAsB,mBAInB,SAAAC,GACdnB,EACAoB,EACAC,EACM,CACN,MAAMC,EAAwBC,EAAAA,OAAOL,GAAqB,CAAE,CAAA,EAGtDM,EAAqBC,EAAAA,SAAS,KAAO,CACzC,GAAGC,EAAAA,MAAMJ,CAAqB,EAC9B,GAAGD,GAAA,YAAAA,EAAgB,KACnB,EAAA,EAEFM,EAAAA,YAAY,IAAM,CAChB,MAAMC,EAAW5B,EAAM,MAClB4B,IAIDR,EAAQ,MACDQ,EAAA,YAAYJ,EAAmB,KAAK,EAE7CI,EAAS,YAAY,EACvB,CACD,CACH,CAEO,MAAMC,GAAe,CAC1B,QAAS,QACT,eAAgB,MAClB,QC/BMC,GAAO,YACAC,GAAQC,GAAyBF,GAAK,KAAKE,CAAG,EAEpD,SAASC,GAAQC,EAAqB,CAC3C,MAAMC,EAAgB,CAAA,EACtB,UAAWH,KAAOE,EACXH,GAAKC,CAAG,IACJG,EAAAH,CAAG,EAAIE,EAAMF,CAAG,GAIpB,OAAAG,CACT,CCoBA,MAAMC,GAAW,gBACJC,GAAY,UACZC,GAAmB,gBACnBC,GAAqB,kBAIlCC,GAAeC,kBAAgB,CAC7B,KAAM,UACN,MAAO,CACL,OAAQ,OACR,MAAO,CACL,KAAM,CAAC,OAAQ,MAAM,CACvB,EACA,YAAa,OACb,cAAe,OACf,MAAO,OACP,aAAc,QACd,GAAGxB,GACH,GAAGY,EACL,EACA,aAAc,GAEd,MAAOa,EAAO,CAAE,MAAAR,EAAO,UAAAS,GAAa,CAClC,MAAMlC,EAAOmC,EAAAA,aACP5C,EAAQ4C,EAAAA,aACRC,EAAeD,EAAAA,aACfE,EAAevB,EAAAA,OAAOc,GAAW,IAAI,EACrCU,EAAqBxB,EAAA,OACzBe,GACA,IAAA,EAEIU,EAAuBzB,EAAA,OAC3BgB,GACA,IAAA,EAGI,CAAE,WAAA/B,EAAY,aAAAyC,EAAc,QAAA7B,EAAS,eAAAC,GAAmB6B,EAAAA,OAAOR,CAAK,EAEpES,EAAa1B,EAAA,SACjB,IAAMoB,EAAa,OAASH,EAAM,QAAU,OAAO,OAAO,IAAI,CAAA,EAE1DU,EAAY3B,WAAS,IAAMiB,EAAM,OAAShB,QAAMoB,CAAY,GAAK,CAAA,CAAE,EACnEO,EAAkB5B,EAAA,SACtB,IAAMiB,EAAM,aAAehB,QAAMqB,CAAkB,GAAK,CAAC,CAAA,EAErDO,EAAoB7B,EAAA,SACxB,IAAMiB,EAAM,eAAiBhB,QAAMsB,CAAoB,GAAK,CAAC,CAAA,EAEzDO,EAAgB9B,EAAA,SAAS,IAAMQ,GAAOC,CAAK,CAAC,EAElD,SAASjC,EAAMuD,EAAiB,CAC9B,GAAIxD,EAAM,OAAS,CAACS,EAAK,MACvB,OAGI,MAAAmB,EAAY5B,EAAM,MAAQyD,GAAA,KAC9BhD,EAAK,MACL2C,EAAU,MACVC,EAAgB,KAAA,EAGdX,EAAM,QACRd,EAAS,MAAQc,EAAM,OAGzB,IAAIgB,EAAgBf,EACfe,IACHA,EAAgB,CAAA,EAEhB,OAAO,KAAKxB,CAAK,EACd,UAAcF,EAAI,QAAQ,IAAI,IAAM,GAAKA,EAAI,OAAS,CAAC,EACvD,QAAeA,GAAA,CAGR,MAAA2B,EAAQ3B,EAAI,OAAO,CAAC,EAAE,YAAY,EAAIA,EAAI,MAAM,CAAC,EACzC0B,EAAAC,CAAK,EAAIzB,EAAMF,CAAG,CAAA,CACjC,GAGL,OAAO,KAAK0B,CAAa,EAAE,QAAe1B,GAAA,CAClC,MAAA4B,EAAUF,EAAc1B,CAAG,EAE5B4B,IAID5B,EAAI,QAAQ,KAAK,IAAM,EAChBJ,EAAA,QAAQ,GAAGI,EAAI,MAAM,CAAC,EAAE,cAAe4B,CAAO,EAEvDhC,EAAS,GAAGI,EAAI,YAAY,EAAG4B,CAAO,EACxC,CACD,EAED,SAASC,GAAU,CACjB,GAAIjC,GAAY,CAACA,EAAS,aAEpB,GAAA,CACFA,EAAS,OAAO,QACTkC,GACH,GAAAA,EAAE,UAAY,0CAChB,OAGI,MAAAA,CACR,CAEJ,CAEA,SAASC,GAAU,CACjBnC,EAAS,UAAU4B,GAAUL,EAAW,MAAOG,EAAkB,KAAK,CACxE,CAEI9C,EAAW,MAGbwD,EAAAA,SAAS,IAAM,CACNH,IACAE,GAAA,CACR,EAEMA,GAEX,CAES,SAAAE,EAAWT,EAAgBU,EAA+B,CAC7DxB,EAAM,eACRG,EAAa,MAAQW,GAGlBxD,EAAM,MAGTA,EAAM,MAAM,UAAUwD,EAAQU,GAAiB,CAAE,CAAA,EAFjDjE,EAAKuD,CAAM,CAIf,CAEA,SAAS3C,GAAW,CACdb,EAAM,QACRA,EAAM,MAAM,UACZA,EAAM,MAAQ,OAElB,CAEA,IAAImE,EAAqC,KACzCxD,EAAA,MACEsC,EACAA,GAAgB,CACV,OAAOkB,GAAkB,aACbA,IACEA,EAAA,MAGblB,IACakB,EAAAxD,EAAA,MACd,IAAM+B,EAAM,OACFc,GAAA,CACHA,IAGAxD,EAAM,MAGTA,EAAM,MAAM,UAAUwD,EAAQF,EAAkB,KAAK,EAFhDrD,IAIT,EACA,CAAE,KAAM,EAAK,CAAA,EAGnB,EACA,CACE,UAAW,EACb,CAAA,EAGFU,EAAA,MACE,CAACyC,EAAWC,CAAe,EAC3B,IAAM,CACIxC,IACHZ,GACP,EACA,CACE,KAAM,EACR,CAAA,EAGF0B,EAAAA,YAAY,IAAM,CACZe,EAAM,OAAS1C,EAAM,QACjBA,EAAA,MAAM,MAAQ0C,EAAM,MAC5B,CACD,EAEK,MAAA0B,EAAYrE,GAAaC,EAAOC,CAAI,EAE/B,OAAAkB,GAAAnB,EAAOoB,EAASC,CAAc,EAE3Bd,GAAAP,EAAOQ,EAAYC,CAAI,EAErC4D,EAAAA,UAAU,IAAM,CACV3B,EAAM,QACHzC,GACP,CACD,EAEDqE,EAAA,YAAYzD,CAAO,EAEZ,CACL,MAAAb,EACA,KAAAS,EACA,UAAAwD,EACA,cAAAV,EACA,GAAGa,CAAA,CAEP,EACA,QAAU,CACR,MAAMlC,EAAQ,CAAE,GAAG,KAAK,aAAc,EACtC,OAAAA,EAAM,IAAM,OACNA,EAAA,MAAQA,EAAM,MAAQ,CAAC,SAAS,EAAE,OAAOA,EAAM,KAAK,EAAI,UACvDqC,EAAA,EAAEnC,GAAUF,CAAK,CAC1B,CACF,CAAC,EC9PM,SAASsC,GAAQC,EAAGC,EAAK,CACxBC,GAAeF,CAAC,IAChBA,EAAI,QAER,IAAIG,EAAYC,GAAaJ,CAAC,EAO9B,OANAA,EAAIC,IAAQ,IAAMD,EAAI,KAAK,IAAIC,EAAK,KAAK,IAAI,EAAG,WAAWD,CAAC,CAAC,CAAC,EAE1DG,IACAH,EAAI,SAAS,OAAOA,EAAIC,CAAG,EAAG,EAAE,EAAI,KAGpC,KAAK,IAAID,EAAIC,CAAG,EAAI,KACb,GAGPA,IAAQ,IAIRD,GAAKA,EAAI,EAAKA,EAAIC,EAAOA,EAAMD,EAAIC,GAAO,WAAW,OAAOA,CAAG,CAAC,EAKhED,EAAKA,EAAIC,EAAO,WAAW,OAAOA,CAAG,CAAC,EAEnCD,EACX,CAaO,SAASE,GAAeF,EAAG,CAC9B,OAAO,OAAOA,GAAM,UAAYA,EAAE,QAAQ,GAAG,IAAM,IAAM,WAAWA,CAAC,IAAM,CAC/E,CAKO,SAASI,GAAaJ,EAAG,CAC5B,OAAO,OAAOA,GAAM,UAAYA,EAAE,QAAQ,GAAG,IAAM,EACvD,CAKO,SAASK,GAAWC,EAAG,CAC1B,OAAAA,EAAI,WAAWA,CAAC,GACZ,MAAMA,CAAC,GAAKA,EAAI,GAAKA,EAAI,KACzBA,EAAI,GAEDA,CACX,CAKO,SAASC,GAAoBP,EAAG,CACnC,OAAIA,GAAK,EACE,GAAG,OAAO,OAAOA,CAAC,EAAI,IAAK,GAAG,EAElCA,CACX,CAKO,SAASQ,GAAKC,EAAG,CACpB,OAAOA,EAAE,SAAW,EAAI,IAAMA,EAAI,OAAOA,CAAC,CAC9C,CCxEO,SAASC,GAASC,EAAGC,EAAGC,EAAG,CAC9B,MAAO,CACH,EAAGd,GAAQY,EAAG,GAAG,EAAI,IACrB,EAAGZ,GAAQa,EAAG,GAAG,EAAI,IACrB,EAAGb,GAAQc,EAAG,GAAG,EAAI,GAC7B,CACA,CAuCA,SAASC,GAAQC,EAAGC,EAAGC,EAAG,CAOtB,OANIA,EAAI,IACJA,GAAK,GAELA,EAAI,IACJA,GAAK,GAELA,EAAI,EAAI,EACDF,GAAKC,EAAID,IAAM,EAAIE,GAE1BA,EAAI,EAAI,EACDD,EAEPC,EAAI,EAAI,EACDF,GAAKC,EAAID,IAAM,EAAI,EAAIE,GAAK,EAEhCF,CACX,CAOO,SAASG,GAASpB,EAAGqB,EAAGC,EAAG,CAC9B,IAAIT,EACAC,EACAC,EAIJ,GAHAf,EAAIC,GAAQD,EAAG,GAAG,EAClBqB,EAAIpB,GAAQoB,EAAG,GAAG,EAClBC,EAAIrB,GAAQqB,EAAG,GAAG,EACdD,IAAM,EAENP,EAAIQ,EACJP,EAAIO,EACJT,EAAIS,MAEH,CACD,IAAIJ,EAAII,EAAI,GAAMA,GAAK,EAAID,GAAKC,EAAID,EAAIC,EAAID,EACxCJ,EAAI,EAAIK,EAAIJ,EAChBL,EAAIG,GAAQC,EAAGC,EAAGlB,EAAI,EAAI,CAAC,EAC3Bc,EAAIE,GAAQC,EAAGC,EAAGlB,CAAC,EACnBe,EAAIC,GAAQC,EAAGC,EAAGlB,EAAI,EAAI,CAAC,CAC9B,CACD,MAAO,CAAE,EAAGa,EAAI,IAAK,EAAGC,EAAI,IAAK,EAAGC,EAAI,IAC5C,CAOO,SAASQ,GAASV,EAAGC,EAAGC,EAAG,CAC9BF,EAAIZ,GAAQY,EAAG,GAAG,EAClBC,EAAIb,GAAQa,EAAG,GAAG,EAClBC,EAAId,GAAQc,EAAG,GAAG,EAClB,IAAIZ,EAAM,KAAK,IAAIU,EAAGC,EAAGC,CAAC,EACtBS,EAAM,KAAK,IAAIX,EAAGC,EAAGC,CAAC,EACtBf,EAAI,EACJyB,EAAItB,EACJuB,EAAIvB,EAAMqB,EACVH,EAAIlB,IAAQ,EAAI,EAAIuB,EAAIvB,EAC5B,GAAIA,IAAQqB,EACRxB,EAAI,MAEH,CACD,OAAQG,EAAG,CACP,KAAKU,EACDb,GAAKc,EAAIC,GAAKW,GAAKZ,EAAIC,EAAI,EAAI,GAC/B,MACJ,KAAKD,EACDd,GAAKe,EAAIF,GAAKa,EAAI,EAClB,MACJ,KAAKX,EACDf,GAAKa,EAAIC,GAAKY,EAAI,EAClB,KAGP,CACD1B,GAAK,CACR,CACD,MAAO,CAAE,EAAGA,EAAG,EAAGqB,EAAG,EAAGI,EAC5B,CAOO,SAASE,GAAS3B,EAAGqB,EAAGI,EAAG,CAC9BzB,EAAIC,GAAQD,EAAG,GAAG,EAAI,EACtBqB,EAAIpB,GAAQoB,EAAG,GAAG,EAClBI,EAAIxB,GAAQwB,EAAG,GAAG,EAClB,IAAIG,EAAI,KAAK,MAAM5B,CAAC,EAChB6B,EAAI7B,EAAI4B,EACRX,EAAIQ,GAAK,EAAIJ,GACbH,EAAIO,GAAK,EAAII,EAAIR,GACjBF,EAAIM,GAAK,GAAK,EAAII,GAAKR,GACvBS,EAAMF,EAAI,EACVf,EAAI,CAACY,EAAGP,EAAGD,EAAGA,EAAGE,EAAGM,CAAC,EAAEK,CAAG,EAC1BhB,EAAI,CAACK,EAAGM,EAAGA,EAAGP,EAAGD,EAAGA,CAAC,EAAEa,CAAG,EAC1Bf,EAAI,CAACE,EAAGA,EAAGE,EAAGM,EAAGA,EAAGP,CAAC,EAAEY,CAAG,EAC9B,MAAO,CAAE,EAAGjB,EAAI,IAAK,EAAGC,EAAI,IAAK,EAAGC,EAAI,IAC5C,CAOO,SAASgB,GAASlB,EAAGC,EAAGC,EAAGiB,EAAY,CAC1C,IAAIC,EAAM,CACNvB,GAAK,KAAK,MAAMG,CAAC,EAAE,SAAS,EAAE,CAAC,EAC/BH,GAAK,KAAK,MAAMI,CAAC,EAAE,SAAS,EAAE,CAAC,EAC/BJ,GAAK,KAAK,MAAMK,CAAC,EAAE,SAAS,EAAE,CAAC,CACvC,EAEI,OAAIiB,GACAC,EAAI,CAAC,EAAE,WAAWA,EAAI,CAAC,EAAE,OAAO,CAAC,CAAC,GAClCA,EAAI,CAAC,EAAE,WAAWA,EAAI,CAAC,EAAE,OAAO,CAAC,CAAC,GAClCA,EAAI,CAAC,EAAE,WAAWA,EAAI,CAAC,EAAE,OAAO,CAAC,CAAC,EAC3BA,EAAI,CAAC,EAAE,OAAO,CAAC,EAAIA,EAAI,CAAC,EAAE,OAAO,CAAC,EAAIA,EAAI,CAAC,EAAE,OAAO,CAAC,EAEzDA,EAAI,KAAK,EAAE,CACtB,CA2CO,SAASC,GAAoBlC,EAAG,CACnC,OAAOmC,GAAgBnC,CAAC,EAAI,GAChC,CAEO,SAASmC,GAAgBC,EAAK,CACjC,OAAO,SAASA,EAAK,EAAE,CAC3B,CC/NO,IAAIC,GAAQ,CACf,UAAW,UACX,aAAc,UACd,KAAM,UACN,WAAY,UACZ,MAAO,UACP,MAAO,UACP,OAAQ,UACR,MAAO,UACP,eAAgB,UAChB,KAAM,UACN,WAAY,UACZ,MAAO,UACP,UAAW,UACX,UAAW,UACX,WAAY,UACZ,UAAW,UACX,MAAO,UACP,eAAgB,UAChB,SAAU,UACV,QAAS,UACT,KAAM,UACN,SAAU,UACV,SAAU,UACV,cAAe,UACf,SAAU,UACV,UAAW,UACX,SAAU,UACV,UAAW,UACX,YAAa,UACb,eAAgB,UAChB,WAAY,UACZ,WAAY,UACZ,QAAS,UACT,WAAY,UACZ,aAAc,UACd,cAAe,UACf,cAAe,UACf,cAAe,UACf,cAAe,UACf,WAAY,UACZ,SAAU,UACV,YAAa,UACb,QAAS,UACT,QAAS,UACT,WAAY,UACZ,UAAW,UACX,YAAa,UACb,YAAa,UACb,QAAS,UACT,UAAW,UACX,WAAY,UACZ,UAAW,UACX,KAAM,UACN,KAAM,UACN,MAAO,UACP,YAAa,UACb,KAAM,UACN,SAAU,UACV,QAAS,UACT,UAAW,UACX,OAAQ,UACR,MAAO,UACP,MAAO,UACP,cAAe,UACf,SAAU,UACV,UAAW,UACX,aAAc,UACd,UAAW,UACX,WAAY,UACZ,UAAW,UACX,qBAAsB,UACtB,UAAW,UACX,WAAY,UACZ,UAAW,UACX,UAAW,UACX,YAAa,UACb,cAAe,UACf,aAAc,UACd,eAAgB,UAChB,eAAgB,UAChB,eAAgB,UAChB,YAAa,UACb,KAAM,UACN,UAAW,UACX,MAAO,UACP,QAAS,UACT,OAAQ,UACR,iBAAkB,UAClB,WAAY,UACZ,aAAc,UACd,aAAc,UACd,eAAgB,UAChB,gBAAiB,UACjB,kBAAmB,UACnB,gBAAiB,UACjB,gBAAiB,UACjB,aAAc,UACd,UAAW,UACX,UAAW,UACX,SAAU,UACV,YAAa,UACb,KAAM,UACN,QAAS,UACT,MAAO,UACP,UAAW,UACX,OAAQ,UACR,UAAW,UACX,OAAQ,UACR,cAAe,UACf,UAAW,UACX,cAAe,UACf,cAAe,UACf,WAAY,UACZ,UAAW,UACX,KAAM,UACN,KAAM,UACN,KAAM,UACN,WAAY,UACZ,OAAQ,UACR,cAAe,UACf,IAAK,UACL,UAAW,UACX,UAAW,UACX,YAAa,UACb,OAAQ,UACR,WAAY,UACZ,SAAU,UACV,SAAU,UACV,OAAQ,UACR,OAAQ,UACR,QAAS,UACT,UAAW,UACX,UAAW,UACX,UAAW,UACX,KAAM,UACN,YAAa,UACb,UAAW,UACX,IAAK,UACL,KAAM,UACN,QAAS,UACT,OAAQ,UACR,UAAW,UACX,OAAQ,UACR,MAAO,UACP,MAAO,UACP,WAAY,UACZ,OAAQ,UACR,YAAa,SACjB,ECpIO,SAASC,GAAWC,EAAO,CAC9B,IAAIC,EAAM,CAAE,EAAG,EAAG,EAAG,EAAG,EAAG,GACvBhC,EAAI,EACJa,EAAI,KACJI,EAAI,KACJH,EAAI,KACJmB,EAAK,GACLC,EAAS,GACb,OAAI,OAAOH,GAAU,WACjBA,EAAQI,GAAoBJ,CAAK,GAEjC,OAAOA,GAAU,WACbK,GAAeL,EAAM,CAAC,GAAKK,GAAeL,EAAM,CAAC,GAAKK,GAAeL,EAAM,CAAC,GAC5EC,EAAM5B,GAAS2B,EAAM,EAAGA,EAAM,EAAGA,EAAM,CAAC,EACxCE,EAAK,GACLC,EAAS,OAAOH,EAAM,CAAC,EAAE,OAAO,EAAE,IAAM,IAAM,OAAS,OAElDK,GAAeL,EAAM,CAAC,GAAKK,GAAeL,EAAM,CAAC,GAAKK,GAAeL,EAAM,CAAC,GACjFlB,EAAIZ,GAAoB8B,EAAM,CAAC,EAC/Bd,EAAIhB,GAAoB8B,EAAM,CAAC,EAC/BC,EAAMb,GAASY,EAAM,EAAGlB,EAAGI,CAAC,EAC5BgB,EAAK,GACLC,EAAS,OAEJE,GAAeL,EAAM,CAAC,GAAKK,GAAeL,EAAM,CAAC,GAAKK,GAAeL,EAAM,CAAC,IACjFlB,EAAIZ,GAAoB8B,EAAM,CAAC,EAC/BjB,EAAIb,GAAoB8B,EAAM,CAAC,EAC/BC,EAAMpB,GAASmB,EAAM,EAAGlB,EAAGC,CAAC,EAC5BmB,EAAK,GACLC,EAAS,OAET,OAAO,UAAU,eAAe,KAAKH,EAAO,GAAG,IAC/C/B,EAAI+B,EAAM,IAGlB/B,EAAID,GAAWC,CAAC,EACT,CACH,GAAIiC,EACJ,OAAQF,EAAM,QAAUG,EACxB,EAAG,KAAK,IAAI,IAAK,KAAK,IAAIF,EAAI,EAAG,CAAC,CAAC,EACnC,EAAG,KAAK,IAAI,IAAK,KAAK,IAAIA,EAAI,EAAG,CAAC,CAAC,EACnC,EAAG,KAAK,IAAI,IAAK,KAAK,IAAIA,EAAI,EAAG,CAAC,CAAC,EACnC,EAAGhC,CACX,CACA,CAEA,IAAIqC,GAAc,gBAEdC,GAAa,uBAEbC,GAAW,MAAM,OAAOD,GAAY,OAAO,EAAE,OAAOD,GAAa,GAAG,EAIpEG,GAAoB,cAAc,OAAOD,GAAU,YAAY,EAAE,OAAOA,GAAU,YAAY,EAAE,OAAOA,GAAU,WAAW,EAC5HE,GAAoB,cAAc,OAAOF,GAAU,YAAY,EAAE,OAAOA,GAAU,YAAY,EAAE,OAAOA,GAAU,YAAY,EAAE,OAAOA,GAAU,WAAW,EAC3JG,GAAW,CACX,SAAU,IAAI,OAAOH,EAAQ,EAC7B,IAAK,IAAI,OAAO,MAAQC,EAAiB,EACzC,KAAM,IAAI,OAAO,OAASC,EAAiB,EAC3C,IAAK,IAAI,OAAO,MAAQD,EAAiB,EACzC,KAAM,IAAI,OAAO,OAASC,EAAiB,EAC3C,IAAK,IAAI,OAAO,MAAQD,EAAiB,EACzC,KAAM,IAAI,OAAO,OAASC,EAAiB,EAC3C,KAAM,uDACN,KAAM,uDACN,KAAM,uEACN,KAAM,sEACV,EAKO,SAASN,GAAoBJ,EAAO,CAEvC,GADAA,EAAQA,EAAM,KAAM,EAAC,YAAW,EAC5BA,EAAM,SAAW,EACjB,MAAO,GAEX,IAAIY,EAAQ,GACZ,GAAId,GAAME,CAAK,EACXA,EAAQF,GAAME,CAAK,EACnBY,EAAQ,WAEHZ,IAAU,cACf,MAAO,CAAE,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,OAAQ,MAAM,EAMnD,IAAIa,EAAQF,GAAS,IAAI,KAAKX,CAAK,EACnC,OAAIa,EACO,CAAE,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,CAAC,GAElDA,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CAAE,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,IAE9DA,EAAQF,GAAS,IAAI,KAAKX,CAAK,EAC3Ba,EACO,CAAE,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,CAAC,GAElDA,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CAAE,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,IAE9DA,EAAQF,GAAS,IAAI,KAAKX,CAAK,EAC3Ba,EACO,CAAE,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,CAAC,GAElDA,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CAAE,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,IAE9DA,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CACH,EAAGjB,GAAgBiB,EAAM,CAAC,CAAC,EAC3B,EAAGjB,GAAgBiB,EAAM,CAAC,CAAC,EAC3B,EAAGjB,GAAgBiB,EAAM,CAAC,CAAC,EAC3B,EAAGlB,GAAoBkB,EAAM,CAAC,CAAC,EAC/B,OAAQD,EAAQ,OAAS,MACrC,GAEIC,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CACH,EAAGjB,GAAgBiB,EAAM,CAAC,CAAC,EAC3B,EAAGjB,GAAgBiB,EAAM,CAAC,CAAC,EAC3B,EAAGjB,GAAgBiB,EAAM,CAAC,CAAC,EAC3B,OAAQD,EAAQ,OAAS,KACrC,GAEIC,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CACH,EAAGjB,GAAgBiB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EACtC,EAAGjB,GAAgBiB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EACtC,EAAGjB,GAAgBiB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EACtC,EAAGlB,GAAoBkB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EAC1C,OAAQD,EAAQ,OAAS,MACrC,GAEIC,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CACH,EAAGjB,GAAgBiB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EACtC,EAAGjB,GAAgBiB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EACtC,EAAGjB,GAAgBiB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EACtC,OAAQD,EAAQ,OAAS,KACrC,EAEW,WACX,CAKO,SAASP,GAAeL,EAAO,CAClC,OAAO,QAAQW,GAAS,SAAS,KAAK,OAAOX,CAAK,CAAC,CAAC,CACxD,CCnLA,IAAIc,GAAU,EAEVC,GAAiB,IAEjBC,GAAkB,IAElBC,GAAkB,IAElBC,GAAkB,IAElBC,GAAkB,EAElBC,GAAiB,EAGjBC,GAAe,CAAC,CAClB,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,EACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,EACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,CAAC,EAGD,SAASC,GAAMC,EAAM,CACnB,IAAIjD,EAAIiD,EAAK,EACThD,EAAIgD,EAAK,EACT/C,EAAI+C,EAAK,EACTC,EAAMxC,GAASV,EAAGC,EAAGC,CAAC,EAC1B,MAAO,CACL,EAAGgD,EAAI,EAAI,IACX,EAAGA,EAAI,EACP,EAAGA,EAAI,CACX,CACA,CAIA,SAASC,GAAMC,EAAO,CACpB,IAAIpD,EAAIoD,EAAM,EACVnD,EAAImD,EAAM,EACVlD,EAAIkD,EAAM,EACd,MAAO,IAAI,OAAOlC,GAASlB,EAAGC,EAAGC,EAAG,EAAK,CAAC,CAC5C,CAKA,SAASmD,GAAIC,EAAMC,EAAMC,EAAQ,CAC/B,IAAIpD,EAAIoD,EAAS,IACb7B,EAAM,CACR,GAAI4B,EAAK,EAAID,EAAK,GAAKlD,EAAIkD,EAAK,EAChC,GAAIC,EAAK,EAAID,EAAK,GAAKlD,EAAIkD,EAAK,EAChC,GAAIC,EAAK,EAAID,EAAK,GAAKlD,EAAIkD,EAAK,CACpC,EACE,OAAO3B,CACT,CAEA,SAAS8B,GAAOP,EAAKnC,EAAG2C,EAAO,CAC7B,IAAIC,EAEJ,OAAI,KAAK,MAAMT,EAAI,CAAC,GAAK,IAAM,KAAK,MAAMA,EAAI,CAAC,GAAK,IAClDS,EAAMD,EAAQ,KAAK,MAAMR,EAAI,CAAC,EAAIV,GAAUzB,EAAI,KAAK,MAAMmC,EAAI,CAAC,EAAIV,GAAUzB,EAE9E4C,EAAMD,EAAQ,KAAK,MAAMR,EAAI,CAAC,EAAIV,GAAUzB,EAAI,KAAK,MAAMmC,EAAI,CAAC,EAAIV,GAAUzB,EAG5E4C,EAAM,EACRA,GAAO,IACEA,GAAO,MAChBA,GAAO,KAGFA,CACT,CAEA,SAASC,GAAcV,EAAKnC,EAAG2C,EAAO,CAEpC,GAAIR,EAAI,IAAM,GAAKA,EAAI,IAAM,EAC3B,OAAOA,EAAI,EAGb,IAAIW,EAEJ,OAAIH,EACFG,EAAaX,EAAI,EAAIT,GAAiB1B,EAC7BA,IAAM+B,GACfe,EAAaX,EAAI,EAAIT,GAErBoB,EAAaX,EAAI,EAAIR,GAAkB3B,EAIrC8C,EAAa,IACfA,EAAa,GAIXH,GAAS3C,IAAM8B,IAAmBgB,EAAa,KACjDA,EAAa,IAGXA,EAAa,MACfA,EAAa,KAGR,OAAOA,EAAW,QAAQ,CAAC,CAAC,CACrC,CAEA,SAASC,GAASZ,EAAKnC,EAAG2C,EAAO,CAC/B,IAAIK,EAEJ,OAAIL,EACFK,EAAQb,EAAI,EAAIP,GAAkB5B,EAElCgD,EAAQb,EAAI,EAAIN,GAAkB7B,EAGhCgD,EAAQ,IACVA,EAAQ,GAGH,OAAOA,EAAM,QAAQ,CAAC,CAAC,CAChC,CAEA,SAASC,GAAStC,EAAO,CAKvB,QAJIuC,EAAO,UAAU,OAAS,GAAK,UAAU,CAAC,IAAM,OAAY,UAAU,CAAC,EAAI,CAAA,EAC3EC,EAAW,CAAA,EACXC,EAAS1C,GAAWC,CAAK,EAEpBX,EAAI8B,GAAiB9B,EAAI,EAAGA,GAAK,EAAG,CAC3C,IAAImC,EAAMF,GAAMmB,CAAM,EAClBC,EAAcjB,GAAM1B,GAAW,CACjC,EAAGgC,GAAOP,EAAKnC,EAAG,EAAI,EACtB,EAAG6C,GAAcV,EAAKnC,EAAG,EAAI,EAC7B,EAAG+C,GAASZ,EAAKnC,EAAG,EAAI,CACzB,CAAA,CAAC,EACFmD,EAAS,KAAKE,CAAW,CAC1B,CAEDF,EAAS,KAAKf,GAAMgB,CAAM,CAAC,EAE3B,QAASE,EAAK,EAAGA,GAAMvB,GAAgBuB,GAAM,EAAG,CAC9C,IAAIC,EAAOtB,GAAMmB,CAAM,EAEnBI,EAAepB,GAAM1B,GAAW,CAClC,EAAGgC,GAAOa,EAAMD,CAAE,EAClB,EAAGT,GAAcU,EAAMD,CAAE,EACzB,EAAGP,GAASQ,EAAMD,CAAE,CACrB,CAAA,CAAC,EAEFH,EAAS,KAAKK,CAAY,CAC3B,CAGD,OAAIN,EAAK,QAAU,OACVlB,GAAa,IAAI,SAAUyB,EAAO,CACvC,IAAIC,EAAQD,EAAM,MACdE,EAAUF,EAAM,QAChBG,EAAkBxB,GAAME,GAAI5B,GAAWwC,EAAK,iBAAmB,SAAS,EAAGxC,GAAWyC,EAASO,CAAK,CAAC,EAAGC,EAAU,GAAG,CAAC,EAC1H,OAAOC,CACb,CAAK,EAGIT,CACT,CAEA,IAAIU,GAAsB,CACxB,IAAK,UACL,QAAS,UACT,OAAQ,UACR,KAAM,UACN,OAAQ,UACR,KAAM,UACN,MAAO,UACP,KAAM,UACN,KAAM,UACN,SAAU,UACV,OAAQ,UACR,QAAS,UACT,KAAM,SACR,EACIC,GAAiB,CAAA,EACjBC,GAAqB,CAAA,EACzB,OAAO,KAAKF,EAAmB,EAAE,QAAQ,SAAUhI,EAAK,CACtDiI,GAAejI,CAAG,EAAIoH,GAASY,GAAoBhI,CAAG,CAAC,EACvDiI,GAAejI,CAAG,EAAE,QAAUiI,GAAejI,CAAG,EAAE,CAAC,EAEnDkI,GAAmBlI,CAAG,EAAIoH,GAASY,GAAoBhI,CAAG,EAAG,CAC3D,MAAO,OACP,gBAAiB,SACrB,CAAG,EACDkI,GAAmBlI,CAAG,EAAE,QAAUkI,GAAmBlI,CAAG,EAAE,CAAC,CAC7D,CAAC,EC1ND,IAAImI,GAAa,CAAA,EAEbC,GAAgB,CAAA,EAEhBC,GAAQ,wFAEZ,SAASC,IAAqB,CAC5B,IAAIC,EAAe,SAAS,cAAc,OAAO,EACjD,OAAAA,EAAa,aAAa,OAAQ,UAAU,EACrCA,CACT,CAGA,SAASC,GAAUC,EAAKC,EAAS,CAG/B,GAFAA,EAAUA,GAAW,GAEjBD,IAAQ,OACV,MAAM,IAAI,MAAMJ,EAAK,EAGvB,IAAIM,EAAWD,EAAQ,UAAY,GAAO,UAAY,SAClDE,EAAYF,EAAQ,YAAc,OAAYA,EAAQ,UAAY,SAAS,cAAc,MAAM,EAC/FG,EAAcV,GAAW,QAAQS,CAAS,EAE1CC,IAAgB,KAClBA,EAAcV,GAAW,KAAKS,CAAS,EAAI,EAC3CR,GAAcS,CAAW,EAAI,IAI/B,IAAIN,EAEJ,OAAIH,GAAcS,CAAW,IAAM,QAAaT,GAAcS,CAAW,EAAEF,CAAQ,IAAM,OACvFJ,EAAeH,GAAcS,CAAW,EAAEF,CAAQ,GAElDJ,EAAeH,GAAcS,CAAW,EAAEF,CAAQ,EAAIL,GAAkB,EAEpEK,IAAa,UACfC,EAAU,aAAaL,EAAcK,EAAU,WAAW,CAAC,CAAC,EAE5DA,EAAU,YAAYL,CAAY,GAKlCE,EAAI,WAAW,CAAC,IAAM,QACxBA,EAAMA,EAAI,OAAO,EAAGA,EAAI,MAAM,GAI5BF,EAAa,WACfA,EAAa,WAAW,SAAWE,EAEnCF,EAAa,aAAeE,EAGvBF,CACT,CC1DA,SAASO,GAAcC,EAAQ,CAAE,QAAS5E,EAAI,EAAGA,EAAI,UAAU,OAAQA,IAAK,CAAE,IAAI6E,EAAS,UAAU7E,CAAC,GAAK,KAAO,OAAO,UAAUA,CAAC,CAAC,EAAI,CAAA,EAAQ8E,EAAU,OAAO,KAAKD,CAAM,EAAO,OAAO,OAAO,uBAA0B,aAAcC,EAAUA,EAAQ,OAAO,OAAO,sBAAsBD,CAAM,EAAE,OAAO,SAAUE,EAAK,CAAE,OAAO,OAAO,yBAAyBF,EAAQE,CAAG,EAAE,WAAa,CAAC,GAAKD,EAAQ,QAAQ,SAAUjJ,EAAK,CAAEmJ,GAAgBJ,EAAQ/I,EAAKgJ,EAAOhJ,CAAG,CAAC,CAAE,CAAE,CAAI,CAAC,OAAO+I,CAAS,CAEze,SAASI,GAAgBC,EAAKpJ,EAAKmH,EAAO,CAAE,OAAInH,KAAOoJ,EAAO,OAAO,eAAeA,EAAKpJ,EAAK,CAAE,MAAOmH,EAAO,WAAY,GAAM,aAAc,GAAM,SAAU,EAAM,CAAA,EAAYiC,EAAIpJ,CAAG,EAAImH,EAAgBiC,CAAM,CAK1M,SAASC,GAAKC,EAAOC,EAAS,CAE/B,QAAQ,IAAI,WAAa,cAAgB,CAACD,GAAS,UAAY,QACjE,QAAQ,MAAM,YAAY,OAAOC,CAAO,CAAC,CAE7C,CACO,SAASC,GAAQF,EAAOC,EAAS,CACtCF,GAAKC,EAAO,2BAA2B,OAAOC,CAAO,CAAC,CACxD,CAEO,SAASE,GAAiBV,EAAQ,CACvC,OAAO,OAAOA,GAAW,UAAY,OAAOA,EAAO,MAAS,UAAY,OAAOA,EAAO,OAAU,WAAa,OAAOA,EAAO,MAAS,UAAY,OAAOA,EAAO,MAAS,WACzK,CAmBO,SAAS3B,GAASsC,EAAM1J,EAAK2J,EAAW,CAC7C,OAAKA,EAQEpH,IAAEmH,EAAK,IAAKZ,GAAc,CAC/B,IAAK9I,CACN,EAAE2J,EAAWD,EAAK,KAAK,GAAIA,EAAK,UAAY,IAAI,IAAI,SAAUE,EAAO/B,EAAO,CAC3E,OAAOT,GAASwC,EAAO,GAAG,OAAO5J,EAAK,GAAG,EAAE,OAAO0J,EAAK,IAAK,GAAG,EAAE,OAAO7B,CAAK,CAAC,CAC/E,CAAA,CAAC,EAXOtF,IAAEmH,EAAK,IAAKZ,GAAc,CAC/B,IAAK9I,CACX,EAAO0J,EAAK,KAAK,GAAIA,EAAK,UAAY,CAAA,GAAI,IAAI,SAAUE,EAAO/B,EAAO,CAChE,OAAOT,GAASwC,EAAO,GAAG,OAAO5J,EAAK,GAAG,EAAE,OAAO0J,EAAK,IAAK,GAAG,EAAE,OAAO7B,CAAK,CAAC,CAC/E,CAAA,CAAC,CAQN,CACO,SAASgC,GAAkBC,EAAc,CAE9C,OAAOC,GAAcD,CAAY,EAAE,CAAC,CACtC,CACO,SAASE,GAAuBC,EAAc,CACnD,OAAKA,EAIE,MAAM,QAAQA,CAAY,EAAIA,EAAe,CAACA,CAAY,EAHxD,EAIX,CAUO,IAAIC,GAAa;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EACpBC,GAAkB,GACXC,GAAkB,UAA2B,CACtD,IAAIC,EAAW,UAAU,OAAS,GAAK,UAAU,CAAC,IAAM,OAAY,UAAU,CAAC,EAAIH,GACnFlI,EAAAA,SAAS,UAAY,CACdmI,KACC,OAAO,OAAW,KAAe,OAAO,UAAY,OAAO,SAAS,iBACtE3B,GAAU6B,EAAU,CAClB,QAAS,EACnB,CAAS,EAGHF,GAAkB,GAExB,CAAG,CACH,ECxFIG,GAAY,CAAC,OAAQ,eAAgB,gBAAgB,EAEzD,SAASC,GAAyBvB,EAAQwB,EAAU,CAAE,GAAIxB,GAAU,KAAM,MAAO,GAAI,IAAID,EAAS0B,GAA8BzB,EAAQwB,CAAQ,EAAOxK,EAAKmE,EAAG,GAAI,OAAO,sBAAuB,CAAE,IAAIuG,EAAmB,OAAO,sBAAsB1B,CAAM,EAAG,IAAK7E,EAAI,EAAGA,EAAIuG,EAAiB,OAAQvG,IAAOnE,EAAM0K,EAAiBvG,CAAC,EAAO,EAAAqG,EAAS,QAAQxK,CAAG,GAAK,IAAkB,OAAO,UAAU,qBAAqB,KAAKgJ,EAAQhJ,CAAG,IAAa+I,EAAO/I,CAAG,EAAIgJ,EAAOhJ,CAAG,EAAI,CAAG,OAAO+I,CAAS,CAE5e,SAAS0B,GAA8BzB,EAAQwB,EAAU,CAAE,GAAIxB,GAAU,KAAM,MAAO,CAAE,EAAE,IAAID,EAAS,CAAE,EAAM4B,EAAa,OAAO,KAAK3B,CAAM,EAAOhJ,EAAKmE,EAAG,IAAKA,EAAI,EAAGA,EAAIwG,EAAW,OAAQxG,IAAOnE,EAAM2K,EAAWxG,CAAC,EAAO,EAAAqG,EAAS,QAAQxK,CAAG,GAAK,KAAa+I,EAAO/I,CAAG,EAAIgJ,EAAOhJ,CAAG,GAAK,OAAO+I,CAAS,CAEnT,SAASD,GAAcC,EAAQ,CAAE,QAAS5E,EAAI,EAAGA,EAAI,UAAU,OAAQA,IAAK,CAAE,IAAI6E,EAAS,UAAU7E,CAAC,GAAK,KAAO,OAAO,UAAUA,CAAC,CAAC,EAAI,CAAA,EAAQ8E,EAAU,OAAO,KAAKD,CAAM,EAAO,OAAO,OAAO,uBAA0B,aAAcC,EAAUA,EAAQ,OAAO,OAAO,sBAAsBD,CAAM,EAAE,OAAO,SAAUE,EAAK,CAAE,OAAO,OAAO,yBAAyBF,EAAQE,CAAG,EAAE,WAAa,CAAC,GAAKD,EAAQ,QAAQ,SAAUjJ,EAAK,CAAEmJ,GAAgBJ,EAAQ/I,EAAKgJ,EAAOhJ,CAAG,CAAC,CAAE,CAAE,CAAI,CAAC,OAAO+I,CAAS,CAEze,SAASI,GAAgBC,EAAKpJ,EAAKmH,EAAO,CAAE,OAAInH,KAAOoJ,EAAO,OAAO,eAAeA,EAAKpJ,EAAK,CAAE,MAAOmH,EAAO,WAAY,GAAM,aAAc,GAAM,SAAU,EAAM,CAAA,EAAYiC,EAAIpJ,CAAG,EAAImH,EAAgBiC,CAAM,CAGjN,IAAIwB,GAAsB,CACxB,aAAc,OACd,eAAgB,UAChB,WAAY,EACd,EAEA,SAASC,GAAiBxE,EAAM,CAC9B,IAAIyD,EAAezD,EAAK,aACpByE,EAAiBzE,EAAK,eAC1BuE,GAAoB,aAAed,EACnCc,GAAoB,eAAiBE,GAAkBjB,GAAkBC,CAAY,EACrFc,GAAoB,WAAa,CAAC,CAACE,CACrC,CAEA,SAASC,IAAmB,CAC1B,OAAOjC,GAAc,GAAI8B,EAAmB,CAC9C,CAEA,IAAII,GAAW,SAAkBtK,EAAOuK,EAAS,CAC/C,IAAIC,EAAuBpC,GAAc,CAAA,EAAIpI,EAAOuK,EAAQ,KAAK,EAC7DE,EAAOD,EAAqB,KAC5BpB,EAAeoB,EAAqB,aACpCJ,EAAiBI,EAAqB,eACtCE,EAAYb,GAAyBW,EAAsBZ,EAAS,EAEpEe,EAAST,GAYb,GAVId,IACFuB,EAAS,CACP,aAAcvB,EACd,eAAgBgB,GAAkBjB,GAAkBC,CAAY,CACtE,GAGEM,KACAZ,GAAQC,GAAiB0B,CAAI,EAAG,0CAA0C,OAAOA,CAAI,CAAC,EAElF,CAAC1B,GAAiB0B,CAAI,EACxB,OAAO,KAGT,IAAIpC,EAASoC,EAEb,OAAIpC,GAAU,OAAOA,EAAO,MAAS,aACnCA,EAASD,GAAc,CAAE,EAAEC,EAAQ,CACjC,KAAMA,EAAO,KAAKsC,EAAO,aAAcA,EAAO,cAAc,CAClE,CAAK,GAGIjE,GAAS2B,EAAO,KAAM,OAAO,OAAOA,EAAO,IAAI,EAAGD,GAAc,CAAA,EAAIsC,EAAW,CACpF,YAAarC,EAAO,KACpB,MAAO,MACP,OAAQ,MACR,KAAM,eACN,cAAe,MAChB,CAAA,CAAC,CACJ,EAEAiC,GAAS,MAAQ,CACf,KAAM,OACN,aAAc,OACd,eAAgB,OAChB,UAAW,MACb,EACAA,GAAS,aAAe,GACxBA,GAAS,YAAc,WACvBA,GAAS,iBAAmBD,GAC5BC,GAAS,iBAAmBH,GAC5B,MAAAS,GAAeN,GC/Ef,SAASO,GAAeC,EAAKrH,EAAG,CAAE,OAAOsH,GAAgBD,CAAG,GAAKE,GAAsBF,EAAKrH,CAAC,GAAKwH,GAA4BH,EAAKrH,CAAC,GAAKyH,GAAgB,CAAK,CAE9J,SAASA,IAAmB,CAAE,MAAM,IAAI,UAAU;AAAA,mFAA2I,CAAI,CAEjM,SAASD,GAA4BE,EAAGC,EAAQ,CAAE,GAAKD,EAAW,IAAI,OAAOA,GAAM,SAAU,OAAOE,GAAkBF,EAAGC,CAAM,EAAG,IAAI,EAAI,OAAO,UAAU,SAAS,KAAKD,CAAC,EAAE,MAAM,EAAG,EAAE,EAAgE,GAAzD,IAAM,UAAYA,EAAE,cAAa,EAAIA,EAAE,YAAY,MAAU,IAAM,OAAS,IAAM,MAAO,OAAO,MAAM,KAAKA,CAAC,EAAG,GAAI,IAAM,aAAe,2CAA2C,KAAK,CAAC,EAAG,OAAOE,GAAkBF,EAAGC,CAAM,EAAI,CAEha,SAASC,GAAkBP,EAAKQ,EAAK,EAAMA,GAAO,MAAQA,EAAMR,EAAI,UAAQQ,EAAMR,EAAI,QAAQ,QAASrH,EAAI,EAAG8H,EAAO,IAAI,MAAMD,CAAG,EAAG7H,EAAI6H,EAAK7H,IAAO8H,EAAK9H,CAAC,EAAIqH,EAAIrH,CAAC,EAAK,OAAO8H,CAAO,CAEvL,SAASP,GAAsBF,EAAKrH,EAAG,CAAE,IAAIsD,EAAK+D,GAAO,KAAO,KAAO,OAAO,OAAW,KAAeA,EAAI,OAAO,QAAQ,GAAKA,EAAI,YAAY,EAAG,GAAI/D,GAAM,KAAc,KAAIyE,EAAO,CAAE,EAAMC,EAAK,GAAUC,EAAK,GAAWC,EAAIC,EAAI,GAAI,CAAE,IAAK7E,EAAKA,EAAG,KAAK+D,CAAG,EAAG,EAAEW,GAAME,EAAK5E,EAAG,QAAQ,QAAoByE,EAAK,KAAKG,EAAG,KAAK,EAAO,EAAAlI,GAAK+H,EAAK,SAAW/H,IAA3DgI,EAAK,GAA6B,CAAoC,OAAUI,EAAP,CAAcH,EAAK,GAAME,EAAKC,SAAe,CAAE,GAAI,CAAM,CAACJ,GAAM1E,EAAG,QAAa,MAAMA,EAAG,OAAW,SAAY,CAAE,GAAI2E,EAAI,MAAME,CAAK,CAAA,CAAG,OAAOJ,EAAO,CAEjgB,SAAST,GAAgBD,EAAK,CAAE,GAAI,MAAM,QAAQA,CAAG,EAAG,OAAOA,CAAM,CAI9D,SAASgB,GAAgBvC,EAAc,CAC5C,IAAIwC,EAAwBzC,GAAuBC,CAAY,EAC3DyC,EAAyBnB,GAAekB,EAAuB,CAAC,EAChE3C,EAAe4C,EAAuB,CAAC,EACvC5B,EAAiB4B,EAAuB,CAAC,EAE7C,OAAOpB,GAAQ,iBAAiB,CAC9B,aAAcxB,EACd,eAAgBgB,CACpB,CAAG,CACH,CACO,SAAS6B,IAAkB,CAChC,IAAItB,EAASC,GAAQ,mBAErB,OAAKD,EAAO,WAIL,CAACA,EAAO,aAAcA,EAAO,cAAc,EAHzCA,EAAO,YAIlB,CCjCA,IAAIf,GAAY,CAAC,QAAS,OAAQ,OAAQ,SAAU,WAAY,eAAgB,SAAS,EAGzF,SAASiB,GAAeC,EAAKrH,EAAG,CAAE,OAAOsH,GAAgBD,CAAG,GAAKE,GAAsBF,EAAKrH,CAAC,GAAKwH,GAA4BH,EAAKrH,CAAC,GAAKyH,GAAgB,CAAK,CAE9J,SAASA,IAAmB,CAAE,MAAM,IAAI,UAAU;AAAA,mFAA2I,CAAI,CAEjM,SAASD,GAA4BE,EAAGC,EAAQ,CAAE,GAAKD,EAAW,IAAI,OAAOA,GAAM,SAAU,OAAOE,GAAkBF,EAAGC,CAAM,EAAG,IAAI,EAAI,OAAO,UAAU,SAAS,KAAKD,CAAC,EAAE,MAAM,EAAG,EAAE,EAAgE,GAAzD,IAAM,UAAYA,EAAE,cAAa,EAAIA,EAAE,YAAY,MAAU,IAAM,OAAS,IAAM,MAAO,OAAO,MAAM,KAAKA,CAAC,EAAG,GAAI,IAAM,aAAe,2CAA2C,KAAK,CAAC,EAAG,OAAOE,GAAkBF,EAAGC,CAAM,EAAI,CAEha,SAASC,GAAkBP,EAAKQ,EAAK,EAAMA,GAAO,MAAQA,EAAMR,EAAI,UAAQQ,EAAMR,EAAI,QAAQ,QAASrH,EAAI,EAAG8H,EAAO,IAAI,MAAMD,CAAG,EAAG7H,EAAI6H,EAAK7H,IAAO8H,EAAK9H,CAAC,EAAIqH,EAAIrH,CAAC,EAAK,OAAO8H,CAAO,CAEvL,SAASP,GAAsBF,EAAKrH,EAAG,CAAE,IAAIsD,EAAK+D,GAAO,KAAO,KAAO,OAAO,OAAW,KAAeA,EAAI,OAAO,QAAQ,GAAKA,EAAI,YAAY,EAAG,GAAI/D,GAAM,KAAc,KAAIyE,EAAO,CAAE,EAAMC,EAAK,GAAUC,EAAK,GAAWC,EAAIC,EAAI,GAAI,CAAE,IAAK7E,EAAKA,EAAG,KAAK+D,CAAG,EAAG,EAAEW,GAAME,EAAK5E,EAAG,QAAQ,QAAoByE,EAAK,KAAKG,EAAG,KAAK,EAAO,EAAAlI,GAAK+H,EAAK,SAAW/H,IAA3DgI,EAAK,GAA6B,CAAoC,OAAUI,EAAP,CAAcH,EAAK,GAAME,EAAKC,SAAe,CAAE,GAAI,CAAM,CAACJ,GAAM1E,EAAG,QAAa,MAAMA,EAAG,OAAW,SAAY,CAAE,GAAI2E,EAAI,MAAME,CAAK,CAAA,CAAG,OAAOJ,EAAO,CAEjgB,SAAST,GAAgBD,EAAK,CAAE,GAAI,MAAM,QAAQA,CAAG,EAAG,OAAOA,CAAM,CAErE,SAAS1C,GAAcC,EAAQ,CAAE,QAAS5E,EAAI,EAAGA,EAAI,UAAU,OAAQA,IAAK,CAAE,IAAI6E,EAAS,UAAU7E,CAAC,GAAK,KAAO,OAAO,UAAUA,CAAC,CAAC,EAAI,CAAA,EAAQ8E,EAAU,OAAO,KAAKD,CAAM,EAAO,OAAO,OAAO,uBAA0B,aAAcC,EAAUA,EAAQ,OAAO,OAAO,sBAAsBD,CAAM,EAAE,OAAO,SAAUE,EAAK,CAAE,OAAO,OAAO,yBAAyBF,EAAQE,CAAG,EAAE,WAAa,CAAC,GAAKD,EAAQ,QAAQ,SAAUjJ,EAAK,CAAEmJ,GAAgBJ,EAAQ/I,EAAKgJ,EAAOhJ,CAAG,CAAC,CAAE,CAAE,CAAI,CAAC,OAAO+I,CAAS,CAEze,SAASI,GAAgBC,EAAKpJ,EAAKmH,EAAO,CAAE,OAAInH,KAAOoJ,EAAO,OAAO,eAAeA,EAAKpJ,EAAK,CAAE,MAAOmH,EAAO,WAAY,GAAM,aAAc,GAAM,SAAU,EAAM,CAAA,EAAYiC,EAAIpJ,CAAG,EAAImH,EAAgBiC,CAAM,CAEjN,SAASmB,GAAyBvB,EAAQwB,EAAU,CAAE,GAAIxB,GAAU,KAAM,MAAO,GAAI,IAAID,EAAS0B,GAA8BzB,EAAQwB,CAAQ,EAAOxK,EAAKmE,EAAG,GAAI,OAAO,sBAAuB,CAAE,IAAIuG,EAAmB,OAAO,sBAAsB1B,CAAM,EAAG,IAAK7E,EAAI,EAAGA,EAAIuG,EAAiB,OAAQvG,IAAOnE,EAAM0K,EAAiBvG,CAAC,EAAO,EAAAqG,EAAS,QAAQxK,CAAG,GAAK,IAAkB,OAAO,UAAU,qBAAqB,KAAKgJ,EAAQhJ,CAAG,IAAa+I,EAAO/I,CAAG,EAAIgJ,EAAOhJ,CAAG,EAAI,CAAG,OAAO+I,CAAS,CAE5e,SAAS0B,GAA8BzB,EAAQwB,EAAU,CAAE,GAAIxB,GAAU,KAAM,MAAO,CAAE,EAAE,IAAID,EAAS,CAAE,EAAM4B,EAAa,OAAO,KAAK3B,CAAM,EAAOhJ,EAAKmE,EAAG,IAAKA,EAAI,EAAGA,EAAIwG,EAAW,OAAQxG,IAAOnE,EAAM2K,EAAWxG,CAAC,EAAO,EAAAqG,EAAS,QAAQxK,CAAG,GAAK,KAAa+I,EAAO/I,CAAG,EAAIgJ,EAAOhJ,CAAG,GAAK,OAAO+I,CAAS,CAMnTyD,GAAgB,SAAS,EAEzB,IAAII,GAAO,SAAclM,EAAOuK,EAAS,CACvC,IAAI4B,EAEA3B,EAAuBpC,GAAc,CAAA,EAAIpI,EAAOuK,EAAQ,KAAK,EAC7D6B,EAAM5B,EAAqB,MAC3BC,EAAOD,EAAqB,KAC5B6B,EAAO7B,EAAqB,KAC5B8B,EAAS9B,EAAqB,OAC9B+B,EAAW/B,EAAqB,SAChCjB,EAAeiB,EAAqB,aACpCgC,EAAUhC,EAAqB,QAC/BE,EAAYb,GAAyBW,EAAsBZ,EAAS,EAEpE6C,GAAYN,EAAY,CAC1B,QAAS,EACb,EAAK1D,GAAgB0D,EAAW,WAAW,OAAO1B,EAAK,IAAI,EAAG,QAAQA,EAAK,IAAI,CAAC,EAAGhC,GAAgB0D,EAAWC,EAAKA,CAAG,EAAGD,GACnHO,EAAiBL,IAAS,IAAQA,GAAQ5B,EAAK,OAAS,UAAY,eAAiB,GACrFkC,EAAeJ,EAEfI,IAAiB,QAAaH,IAChCG,EAAe,GACfjC,EAAU,SAAWiC,GAGvB,IAAIC,EAAWN,EAAS,CACtB,YAAa,UAAU,OAAOA,EAAQ,MAAM,EAC5C,UAAW,UAAU,OAAOA,EAAQ,MAAM,CAC3C,EAAG,OAEAP,EAAwBzC,GAAuBC,CAAY,EAC3DyC,EAAyBnB,GAAekB,EAAuB,CAAC,EAChE3C,EAAe4C,EAAuB,CAAC,EACvC5B,EAAiB4B,EAAuB,CAAC,EAE7C,OAAOa,EAAY,YAAC,OAAQzE,GAAc,CACxC,KAAQ,MACR,aAAcqC,EAAK,IACpB,EAAEC,EAAW,CACZ,QAAW8B,EACX,MAASC,CACb,CAAG,EAAG,CAACI,EAAY,YAACjC,GAAS,CACzB,MAAS8B,EACT,KAAQjC,EACR,aAAgBrB,EAChB,eAAkBgB,EAClB,MAASwC,CACb,EAAK,IAAI,CAAC,CAAC,CACX,EAEAV,GAAK,MAAQ,CACX,KAAM,QACN,OAAQ,OACR,KAAM,OACN,aAAc,MAChB,EACAA,GAAK,YAAc,WACnBA,GAAK,aAAe,GACpBA,GAAK,gBAAkBD,GACvBC,GAAK,gBAAkBJ,GACvB,MAAAgB,GAAeZ,GCvFf,IAAIa,GAAkB,CAAE,KAAQ,CAAE,IAAO,MAAO,MAAS,CAAE,QAAW,gBAAiB,UAAa,OAAS,EAAE,SAAY,CAAC,CAAE,IAAO,OAAQ,MAAS,CAAE,EAAK,6TAA6T,EAAI,CAAC,EAAI,KAAQ,UAAW,MAAS,UAAU,EACzgB,MAAAC,GAAeD,GCAf,SAAS3E,GAAcC,EAAQ,CAAE,QAAS5E,EAAI,EAAGA,EAAI,UAAU,OAAQA,IAAK,CAAE,IAAI6E,EAAS,UAAU7E,CAAC,GAAK,KAAO,OAAO,UAAUA,CAAC,CAAC,EAAI,CAAA,EAAQ8E,EAAU,OAAO,KAAKD,CAAM,EAAO,OAAO,OAAO,uBAA0B,aAAcC,EAAUA,EAAQ,OAAO,OAAO,sBAAsBD,CAAM,EAAE,OAAO,SAAUE,EAAK,CAAE,OAAO,OAAO,yBAAyBF,EAAQE,CAAG,EAAE,WAAa,CAAC,GAAKD,EAAQ,QAAQ,SAAUjJ,EAAK,CAAEmJ,GAAgBJ,EAAQ/I,EAAKgJ,EAAOhJ,CAAG,CAAC,CAAE,CAAE,CAAI,CAAC,OAAO+I,CAAS,CAEze,SAASI,GAAgBC,EAAKpJ,EAAKmH,EAAO,CAAE,OAAInH,KAAOoJ,EAAO,OAAO,eAAeA,EAAKpJ,EAAK,CAAE,MAAOmH,EAAO,WAAY,GAAM,aAAc,GAAM,SAAU,EAAM,CAAA,EAAYiC,EAAIpJ,CAAG,EAAImH,EAAgBiC,CAAM,CAOjN,IAAIqE,GAAkB,SAAyB/M,EAAOuK,EAAS,CAC7D,IAAIzH,EAAIsF,GAAc,CAAA,EAAIpI,EAAOuK,EAAQ,KAAK,EAE9C,OAAOsC,EAAY,YAACC,GAAU1E,GAAc,CAAA,EAAItF,EAAG,CACjD,KAAQkK,EACZ,CAAG,EAAG,IAAI,CACV,EAEAD,GAAgB,YAAc,kBAC9BA,GAAgB,aAAe,GAC/B,MAAAE,GAAeF,GCHfG,GAAenN,kBAAgB,CAC7B,MAAO,CACL,SAAU,CACR,KAAM,QACN,QAAS,EACX,CACF,EACA,WAAY,CAAA,MACVoN,EAAA,IACF,EACA,OAAS,CAQA,MAAA,CACL,UARgBtL,IAAEkL,GAAiB,CACnC,MAAO,CACL,SAAU,OACV,MAAO,SACT,EACA,KAAM,EAAA,CACP,CAEC,CAEJ,CACF,CAAC,gIAvCC,MAAAK,EAAAC,mBAUM,QAVN,uBACEC,qBAOS,MAAAC,GAAA,CAAAC,EAAA,UAAAC,EAAAA,YANKC,EAAAA,YAAAN,EAAA,CACX,IAAA,EAEA,MAAA,OACD,SAAII,EAAQ,SAAA,UAAAA,EAAA,UAGd,IAAA,QAAA,EAAA,KAAA,EAAA,CAAA,WAAA,WAAA,CAAA,GAAAG,aAAAH,EAAA,OAAA,UAAA,CAAA,IAAA,CAAA,CAAA,mCCAJI,GAAe7N,kBAAgB,CAC7B,KAAM,WACN,MAAO,CACL,QAAS,CACP,KAAM,QACN,QAAS,EACX,CACF,EACA,WAAY,CAAA,UACV8N,EAAA,QACF,CACF,CAAC,mCApBCR,mBAEa,YAAA,EAFO,OAAAI,EAAA,UAAA,EAAgBC,EAAA,YAAAI,EAAA,CAAA,OAAA,oIC2cnB,QAAQ,IAAI,WAAa,cACtC,OAAO,OAAO,EAAE,EAEH,QAAQ,IAAI,WAAa,cAAgB,OAAO,OAAO,CAAA,CAAE,EC1c/D,MAAAC,EAAc,CACzBC,EACAC,IACG,CAOH,GANCD,EAA2B,QAAWE,GAAc,CACxC,UAAAC,IAAQ,CAACH,EAAM,GAAG,OAAO,OAAOC,GAAS,CAAE,CAAA,CAAC,EACjDC,EAAA,UAAUC,EAAK,KAAMA,CAAI,CAC/B,EAGEF,EACF,SAAW,CAAC3O,EAAK6O,CAAI,IAAK,OAAO,QAAQF,CAAK,EAC3CD,EAAa1O,CAAG,EAAI6O,EAGlB,OAAAH,CACT,EC0BahO,EAAe,CAC1B,GAAI,GACJ,KAAM,GACN,QAAS,GACT,KAAM,GACN,MAAO,QACP,OAAQ,OACR,SAAU,WACV,IAAK,MACL,KAAM,MACN,OAAQ,EACR,OAAQ,OACR,OAAQ,GACR,SAAU,GACV,WAAY,GACZ,cAAe,MACf,eAAgB,CAAC,EACjB,mBAAoB,GACpB,gBAAiB,EACjB,YAAa,EACb,cAAe,CAAC,CAAE,IAAK,KAAM,MAAO,GAAK,EACzC,OAAQ,CAAC,EACT,SAAU,QACZ,EAEaoO,EAA2CpO,GAE/CqO,GAAA,UAAUrO,EAAQyG,GACnBA,GAAS,KAAa,GACnB,CACL,KAAOA,EAAc,YACrB,QAASA,CAAA,CAEZ,ECnEU6H,GAAwB,CACnC,MAAO,SACP,OAAQ,SACR,gBAAiB,UACjB,gBAAiB,GACjB,eAAgB,YAChB,kBAAmB,GACnB,KAAM,QACR,EAGaC,GAA2BH,EAA0BE,EAAU,ECrBtEE,GAAY,CAChB,QACA,SACA,QACA,WACA,MACA,OACA,SACA,WACA,aACA,aACA,iBACA,YACA,gBACA,WACA,kBACA,kBACA,iBACA,cACA,cACA,eACA,cACA,aACA,iBACA,aACA,QACF,EAOaC,EAAwB,CAAIzO,EAA6B0O,EAA8B,KAAO,CAEzG,MAAMC,EAAiBC,GAAA,QAAQJ,GAAW,GAAGE,CAAgB,EAC7D,OAAO3P,EAAyB,SAAA,IAAM8P,GAAAA,KAAK7O,EAAO2O,CAAc,CAAC,CACnE,ECxCaG,GAAY,YACZC,EAAgB,gBAChBC,EAAe,eACfC,GAAgB,gBAChBC,GAAe,eACfC,GAAe,eAEfC,IAAgBC,GAAA,2BAAQ,SAAR,YAAAA,GAAgB,cAElBC,GAAA,2BAAQ,SAAR,MAAAA,GAAgB,WAE9B,MAAAC,KAAWC,GAAA,2BAAQ,SAAR,YAAAA,GAAgB,gBAAiB,KAE5CC,KAAU/D,GAAA,2BAAQ,SAAR,YAAAA,GAAgB,SAAU,GCXpCgE,GAAa,CAAiC1P,EAA6B2P,IAAmC,CACzH1R,EAAAA,MAAM,IAAM+B,EAAM,GAAI,CAAC4P,EAAIC,IAAU,CAC7B,MAAAC,EAAWjR,SAAOiQ,GAAW,CAGjC,QAAS,CAACrL,EAAWrC,IAA8B,GAGnD,SAAWqC,GAAc,EAAA,CAC1B,EACGmM,GAAM,MAAQA,IAAO,IACdE,EAAA,QAAQF,EAAID,CAAM,CAC7B,EACC,CACD,UAAW,EAAA,CACZ,CACH,ECXaI,GAAgB/P,GAAiC,CAC5D,MAAM2P,EAAS3P,EAAM,OACf4P,EAAK5P,EAAM,GACX8P,EAAWjR,SAAOiQ,GAAW,CAGjC,UAAW,CAACc,EAAWI,IAAiB,EAAA,CACzC,EAEK,CAAE,aAAAC,CAAA,EAAiBpR,EAAA,OAAOkQ,EAAe,CAC7C,aAAcmB,MAAI,EAAE,CAAA,CACrB,EAKM,MAAA,CAACC,EAAYC,EAAqB,IAAM,CAAA,IACtC,UAAY,CAGjB,GADSA,EAAA,KAAK,KAAM,GAAG,SAAS,EAC5BN,EAAU,CACN,KAAA,CAAE,UAAAO,CAAc,EAAAP,EACtBH,EAAO,QAAiB1O,GAAA,CAClB,GAAAkP,IAAOlP,EAAM,GACX,GAAA,CACFgP,EAAa,MAAQL,EACXS,EAAApP,EAAM,OAAQA,EAAM,IAAI,QAC3BG,GACP,QAAQ,MAAMA,CAAC,CACjB,CACF,CACD,CACH,CAAA,CAGN,ECnCakP,GAAmC,CAACC,EAAYC,IAA6C,CACpG,GAAA,CAAE,KAAA/S,EAAO,OAAQ,MAAAgJ,EAAQ,QAAS,KAAAuJ,EAAO,MAAA,EAAWQ,GAAkB,GAE1E/S,EAAOA,GAAA,YAAAA,EAAM,OACbgJ,EAAQA,GAAA,YAAAA,EAAO,OACfuJ,EAAOA,GAAA,YAAAA,EAAM,OACP,MAAAS,MAAU,IACVC,MAAU,IACVpF,EAAMiF,EAAK,OACjB,QAAS9M,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAAkN,EAAOJ,EAAK9M,CAAC,EAEbmN,EAAID,EAAKlT,CAAI,GAAK,GAElBoT,EAAIF,EAAKlK,CAAK,GAAK,GAEnBzD,EAAI2N,EAAKX,CAAI,GAAK,GAEpB,GADJS,EAAI,IAAIG,CAAC,EACLF,EAAI,IAAI1N,CAAC,EAAG,CACR,MAAA8H,EAAM4F,EAAI,IAAI1N,CAAC,EACjB8H,EAAA,KAAK,CAAE,KAAM8F,EAAG,MAAOC,EAAG,GAAGF,EAAM,EACnCD,EAAA,IAAI1N,EAAG8H,CAAG,CAAA,MAEV4F,EAAA,IAAI1N,EAAG,CAAC,CAAE,KAAM4N,EAAG,MAAOC,EAAG,GAAGF,CAAK,CAAC,CAAC,CAE/C,CACM,MAAAG,EAAa,MAAM,KAAKL,CAAG,EAC3BM,EAAmC,CAAA,EACzC,SAAW,CAACtT,EAAM8S,CAAI,IAAKG,EACzBK,EAAQ,KAAK,CACX,KAAAtT,EACA,KAAA8S,CAAA,CACD,EAEI,MAAA,CACL,WAAAO,EACA,QAAAC,CAAA,CAEJ,ECtCaC,GAAmBC,GACvBA,EAAU,QAAQ,OAAQ;AAAA,CAAI,EAQ1BC,GAAc,CAACzK,EAAwB0K,EAAuB,IAAM,CACzE,MAAAC,EAAS,WAAW3K,EAAQ,EAAE,EAChC,OAAA,MAAM2K,CAAM,GAAKA,EAAS,EAAU3K,EACjC2K,EAAO,QAAQD,CAAa,EAAE,QAAQ,sBAAuB,KAAK,CAC3E,EAEaE,GAAmB,CAAC5K,EAAwB0K,EAAuB,IAAM,CACpF,MAAMG,EAAW7K,EAAQ,GACrB,GAAA6K,EAAS,SAAS,GAAG,EAAU,OAAA7K,EAC7B,MAAA2K,EAAS,WAAWE,CAAQ,EAClC,OAAI,MAAMF,CAAM,EAAU3K,EACnB,IAAI2K,EAAS,KAAK,QAAQD,CAAa,IAChD,EAQaI,GAAoB,CAACC,EAAQC,IACpC,OAAOD,GAAO,UAAY,OAAOC,GAAO,SACnCD,EAAG,kBAAkB,EAAE,SAASC,EAAG,mBAAmB,EAExD,GCxCIC,GAAqB,CAChCT,EAAoB,GACpBV,EAA8B,CAAC,EAC/B,CAAE,WAAAoB,EAAa,GAAO,SAAAC,EAAW,EAAM,EAAI,CAAA,IACxC,CAIHrB,EAAO,CAAE,GADM,OAAO,QAAU,GACZ,GAAGA,CAAK,EACtB,MAAAsB,EAAaZ,EAAW,MAAM,YAAY,EAChD,GAAIY,GAAa,MAAQA,EAAU,SAAW,EACrC,OAAAZ,EAET,QAASxN,EAAI,EAAGA,EAAIoO,EAAU,OAAQpO,IAAK,CACnC,MAAAqO,EAAWD,EAAUpO,CAAC,EAC5B,IAAIsO,EAAYD,EAAS,MAAM,EAAG,EAAE,EACpC,MAAME,EAAM,kCACNC,EAAgBF,EAAU,MAAMC,CAAG,EACzC,QAASE,EAAI,EAAGA,EAAID,EAAc,OAAQC,IAAK,CACvC,MAAAC,EAAeF,EAAcC,CAAC,EAC9BE,EAAe7B,EAAK4B,CAAY,EAClCC,GAAgB,OAENL,EAAAA,EAAU,QAAQI,EAAcC,CAAY,EAM5D,CACI,GAAA,CAIFL,KADc,MACIA,CAAS,QACpB3Q,GACP,QAAQ,MAAMA,CAAC,CACjB,CACY6P,EAAAA,EAAU,QAAQa,EAAUC,CAAS,CACnD,CAEA,OAAIJ,IACUV,EAAAA,GAAA,YAAAA,EAAW,QAAQ,UAAW,UAGxCW,IACUX,EAAAA,GAAA,YAAAA,EAAW,QAAQ,WAAY,iBAEtCA,CACT,EC1CaoB,GAAiB,CAACrS,EAA8BsS,EAAqB,IAAM,CAAC,IAAM,CACvF,KAAA,CACJ,WAAAC,EACA,cAAeC,EACf,eAAgBC,EAChB,cAAAC,EACA,gBAAAC,EACA,mBAAAC,CACE,EAAA5S,EACE,CAAE,kBAAA6S,EAAmB,SAAAC,EAAU,aAAA7C,CAAa,EAAIpR,EAAAA,OAAOkQ,EAAe,CAC1E,kBAAmB,GACnB,SAAU,SACV,aAAc,EAAA,CACf,EACK,CAAE,eAAAgE,CAAA,EAAmBlU,EAAA,OAAOmQ,EAAc,CAG9C,eAAiB1P,GAAgB,EAAA,CAClC,EACK0T,EAAMtB,GAAmBa,CAAU,EACnCU,EAAc,MAAOC,EAAiC,KAAO,CAC7D,GAAA,CAACF,GAAO,CAACR,GAAU,CAACC,GAAWzT,EAAA,MAAM8T,CAAQ,IAAM,SAAU,OACjE,IAAIK,EAAU,CAAA,EACAT,EAAA,QAASU,GAAU,CACzB,KAAA,CAAE,IAAA9T,EAAK,MAAAmH,CAAU,EAAA2M,EACvB,GAAK,OAAO3M,GAAU,UAAYA,EAAM,GAAK,CAW3C,IAAI4M,EAAS,CAAA,EACb,KAAM,CAAE,GAAAzD,EAAI,KAAA0D,EAAM,QAAAC,EAAS,QAAAC,GAAY/M,EACnCmJ,IAAO,OAETyD,EAASN,EAAe/T,EAAAA,MAAMiR,CAAY,CAAC,GAAK,CAAA,EAEvCoD,EAAAN,EAAenD,CAAE,GAAK,GAEjC,MAAM9M,EAAI9D,EAAA,MAAMqU,EAAOC,CAAI,CAAC,EAE5B,IAAI,EAAI,KAGR,GADqB,CAAC,OAAQ,OAAO,EAAE,KAAM3C,GAASY,GAAkB8B,GAAA,YAAAA,EAAQ,KAAM1C,CAAI,CAAC,EACzE,CAEhB,KAAM,CAAE,MAAAlK,EAAO,KAAAuJ,EAAM,KAAAyD,CAAK,EAAID,GAAW,GACrC/M,GAAAA,GAASuJ,GAAQyD,EACnB,OAAQzD,EAAM,CACZ,IAAK,MACH,EAAIhR,EAAM,MAAA8D,CAAC,EAAE,IAAI2D,EAAOgN,CAAI,EAC5B,MACF,IAAK,QACH,EAAIzU,EAAM,MAAA8D,CAAC,EAAE,SAAS2D,EAAOgN,CAAI,EACjC,KACJ,CAEE,GAAK,OACP,EAAIzU,EAAAA,MAAM8D,CAAC,GAKb,GAAI,iBAAG,QAAOyQ,GAAA,YAAAA,EAAS,SAAUF,EAAO,UAAW,EAAA,MAI/C,OAAO,UAAU,SAAS,KAAKvQ,CAAC,IAAM,kBACpC,EAAAA,EAAEyQ,GAAW,OAAO,EAEpB,EAAAzQ,EAIRqQ,EAAQ7T,CAAG,EAAI,CAAA,MACN,OAAOmH,GAAU,WAClB0M,EAAA7T,CAAG,EAAIoS,GAAmBjL,CAAK,EACzC,CACD,EAES0M,EAAA,CAAE,GAAG,OAAO,OAAO,cAAe,GAAGD,EAAQ,GAAGC,GAC1D,IAAIO,EAAY,GACV,MAAAC,EAAO,OAAO,KAAKR,CAAO,EAC1BS,EAAOD,EAAK,OAAS,EACrBE,EAAUF,EAAK,OAChBA,EAAA,QAAQ,CAACrU,EAAK6H,IAAU,CACvBA,IAAU,EACR0M,IAAY,EACDH,GAAA,IAAIpU,KAAO6T,EAAQ7T,CAAG,KAEtBoU,GAAA,IAAIpU,KAAO6T,EAAQ7T,CAAG,IAE5B6H,IAAUyM,EACNF,GAAA,GAAGpU,KAAO6T,EAAQ7T,CAAG,IAErBoU,GAAA,GAAGpU,KAAO6T,EAAQ7T,CAAG,IACpC,CACD,EACG,GAAA,CACF,MAAMwU,EAAiB,CAAC,MAAO,MAAM,EAAE,SAAStB,CAAM,EAChDuB,EAAM,MAAMC,GAAM,CACtB,QAAShV,QAAM6T,CAAiB,EAChC,IAAKiB,EAAiBd,EAAMU,EAAYV,EACxC,OAAAR,EACA,QAAAC,EACA,KAAMqB,EAAiB,CAAA,EAAKX,CAAA,CAC7B,EACD,OAAAb,EAASyB,CAAG,EACLA,QACA3S,GACP,QAAQ,MAAMA,CAAC,CACjB,CAAA,EAGI6S,EAAmBrB,GAAsB,YAAYK,EAAaN,EAAkB,GAAI,EAE9F/Q,OAAAA,EAAAA,YAAY,IAAM,CAChB,cAAcqS,CAAgB,CAAA,CAC/B,EAEMhB,CACT,EC9HaiB,GAAiC,CAAC3D,EAAa,GAAIC,IAA0C,CACpG,GAAA,CAAE,KAAA/S,EAAO,OAAQ,MAAA0W,EAAQ,CAAA,CAAG,EAAI3D,GAAkB,GAC/C/S,GAAAA,GAAA,YAAAA,EAAM,SAAUA,EACjB,MAAAgT,MAAU,IACVC,MAAU,IACV0D,EAAU7D,EAAK,OACf8D,EAAWF,EAAM,OAEvB,GAAIC,IAAY,EAAG,CACjB,MAAME,EAAK,CAAA,EAEX,QAAS7Q,EAAI,EAAGA,EAAI4Q,EAAU5Q,IAAK,CAC3B,MAAAuM,EAAOmE,EAAM1Q,CAAC,EACd,CAAE,MAAA8Q,EAAO,MAAA9N,CAAU,EAAAuJ,EACnB1M,EAAI,CAAE,GAAGiN,EAAK,CAAC,EAAG,MAAOA,EAAK,CAAC,EAAE9J,CAAK,GAC5CgK,EAAI,IAAI8D,CAAK,EAEbD,EAAG,KAAKhR,CAAC,CACX,CACA,MAAMvB,EAAIwO,EAAK,CAAC,EAAE9S,CAAI,GAAK,GACvBiT,EAAA,IAAI3O,EAAGuS,CAAE,CAAA,KAEb,SAAS7Q,EAAI,EAAGA,EAAI2Q,EAAS3Q,IAAK,CAC1B,MAAAkN,EAAOJ,EAAK9M,CAAC,EACbmN,EAAID,EAAKlT,CAAI,EACnBgT,EAAI,IAAIG,CAAC,EACT,QAASsB,EAAI,EAAGA,EAAImC,EAAUnC,IAAK,CAC3B,MAAAlC,EAAOmE,EAAMjC,CAAC,EACd,CAAE,MAAAqC,EAAO,MAAA9N,CAAU,EAAAuJ,EACnB1M,EAAI,CAAE,GAAGqN,EAAM,MAAOA,EAAKlK,CAAK,GAClC,GAAAiK,EAAI,IAAI6D,CAAK,EAAG,CACZ,MAAAC,EAAI9D,EAAI,IAAI6D,CAAK,EACvBC,EAAE,KAAKlR,CAAC,EACJoN,EAAA,IAAI6D,EAAOC,CAAC,CAAA,MAEhB9D,EAAI,IAAI6D,EAAO,CAACjR,CAAC,CAAC,CAEtB,CACF,CAGI,MAAAwN,EAAa,MAAM,KAAKL,CAAG,EAC3BM,EAAmC,CAAA,EACzC,SAAW,CAACtT,EAAM8S,CAAI,IAAKG,EACzBK,EAAQ,KAAK,CACX,KAAAtT,EACA,KAAA8S,CAAA,CACD,EAEI,MAAA,CACL,WAAAO,EACA,QAAAC,CAAA,CAEJ,EC5Da0D,GAAe,CAACC,EAAaC,EAAoB,KAAU,OACtE,GAAI,CAACD,EAAa,OAAAA,EAClB,IAAIE,EAAoB,GACpB,OAAAF,GAAA,MAAAA,EAAM,SAAS,OACLE,EAAAF,EAGAE,IAAAvF,EAAA,2BAAQ,SAAR,YAAAA,EAAgB,YAAaqF,EAEvCC,IACFC,EAAY,OAAOA,MAEdA,CACT,ECZaC,GAAa,CAAC/B,EAAkBgC,IAAmB,CACxD,MAAAC,EAAa,GAAGxF,qBAA2BuF,IAC3CE,EAAa,GAAGzF,MAAYuF,IAC3B,OAAAhC,IAAa,UAAYiC,EAAaC,CAC/C,ECFaC,GAAUjB,GAAM,OAAO,CAEpC,CAAC,EACDiB,GAAQ,aAAa,QAAQ,IAAKC,GACzBA,EACLC,GACK,QAAQ,OAAOA,CAAK,CAC5B,EAEDF,GAAQ,aAAa,SAAS,IAAKC,GAAW,WAC5C,MAAI,GAAC7F,EAAA6F,GAAA,YAAAA,EAAQ,OAAR,YAAA7F,EAAc,OAAS,KAC1BxG,EAAAA,QAAQ,MAAM,CACZ,UAASyG,EAAA4F,GAAA,YAAAA,EAAQ,OAAR,YAAA5F,EAAc,QAAOE,EAAA0F,GAAA,YAAAA,EAAQ,OAAR,YAAA1F,EAAc,UAAW,QACvD,IAAK,cAAA,CACN,EAEI0F,CACT,EAAIC,GAAU,CACZ,GAAIA,EAAM,QAAQ,SAAS,SAAS,EAClCtM,EAAAA,QAAQ,MAAM,CACZ,QAAS,cACT,IAAK,SAAA,CACN,MACI,CACC,KAAA,CAAE,OAAAuM,CAAO,EAAID,EAAM,SACrBC,GAAU,KAAOA,EAAS,KAC5BvM,EAAAA,QAAQ,MAAM,CACZ,QAAS,OACT,IAAK,eAAA,CACN,EAGCuM,GAAU,KACZvM,EAAAA,QAAQ,MAAM,CACZ,QAAS,QACT,IAAK,eAAA,CACN,CAEL,CACO,OAAA,QAAQ,OAAOsM,CAAK,CAC7B,CAAC,EClCY,MAAAE,GAAyBrV,GAAU,CAE9C,KAAM,CAAE,eAAA+S,CAAA,EAAmBlU,EAAA,OAAOmQ,EAAc,CAG9C,eAAiB1P,GAAgB,EAAA,CAClC,EACKgW,EAAoBC,GAAkB,CAC1C,MAAMC,EAAgB,CAAA,EAEP,OAAAD,GAAA,MAAAA,EAAA,aAAa,QAAoBE,GAAA,CAC9C,GAAIA,EAAU,CACZ,IAAIC,EAAO,GACPH,EAAc,SAAS,SAASE,EAAS,IAAI,IACxCC,EAAA,IAET,IAAIC,EAAiB,CACnB,MAAOF,EAAS,KAChB,WAAYA,EAAS,MACrB,UAAWA,EAAS,UAAYA,EAAS,UAAY,MACrD,MAAO,KACP,SAAU,OACV,KAAAC,CAAA,EAEEH,EAAc,SAAW,kBAC3BI,EAAU,aAAeF,EAAS,WAExBE,EAAAC,EAAmBH,EAAUE,CAAS,EAClDH,EAAc,KAAKG,CAAS,CAC9B,CAAA,GAGYJ,EAAA,cAAc,QAAcM,GAAA,CACxC,IAAIH,EAAO,GACPH,EAAc,UAAU,SAASM,EAAG,IAAI,IACnCH,EAAA,IAET,IAAIC,EAAiB,CACnB,MAAOE,EAAG,KACV,WAAYA,EAAG,MACf,UAAW,MACX,MAAO,KACP,SAAU,OACV,KAAAH,CAAA,EAEUC,EAAAC,EAAmBC,EAAIF,CAAS,EACxCJ,EAAc,SAAW,kBAC3BI,EAAU,aAAeE,EAAG,WAE9BL,EAAc,KAAKG,CAAS,CAAA,CAC7B,EAEMH,CAAA,EAQHI,EAAqB,CAAKjF,EAAMgF,IAAoB,CAClD,MAAAG,EAAoB,CAAE,GAAGH,GAC/B,OAAIhF,EAAK,WACHA,EAAK,aAAe,WAClBA,EAAK,aACPmF,EAAa,QAAUnF,EAAK,YAE9BmF,EAAa,SAAW,YAExBA,EAAa,eAAiBnF,EAAK,aACnCmF,EAAa,SAAW,WACpBnF,EAAK,WACPmF,EAAa,mBAAqBnF,EAAK,UAErCA,EAAK,kBACPmF,EAAa,eAAiBnF,EAAK,kBAKvCmF,EAAa,SAAW,SAGnBA,CAAA,EASHC,EAAkB,CAACC,EAAe,KAAO,OAE7C,MAAMC,EAAO,CAAA,EACb,QAASxS,EAAI,EAAGA,EAAIuS,EAAa,OAAQvS,IAAK,CACtC,KAAA,CAAE,QAAAyS,EAAS,WAAAC,EAAY,WAAAC,EAAY,YAAAC,EAAa,GAAAzG,CAAG,EAAIoG,EAAavS,CAAC,EACrEkN,EAAY,CAChB,MAAOuF,EACP,UAAWC,EACX,KAAMC,GAAc,OACpB,WAAY,GACZ,UAAW,GACX,YAAAC,CAAA,EAEIC,EAAYvD,EAAenD,CAAE,GAAK,CAAA,EAMpC,GALAuG,IAAe,WACjBxF,EAAK,UAAY,OACR,CAAC,SAAU,aAAa,EAAE,SAASwF,CAAU,IACtDxF,EAAK,UAAY,QAEf2F,EAAU,OAAS,iBAAkB,CACvC3F,EAAK,WAAa2F,EAAU,OAC5B,MAAMrF,GAAYjS,EAAAA,EAAA,MAAMsX,CAAS,IAAftX,YAAAA,EAAkB,MAAM,OACtC,OAAOiS,GAAc,aAClBN,EAAA,WAAaM,EAAUqF,GAAA,YAAAA,EAAW,MAAM,EAEjD,CACAL,EAAK,KAAKtF,CAAI,CAChB,CACO,OAAAsF,CAAA,EAGHM,EAAgB,CAACC,EAAgBP,IAAS,CAExC,MAAAQ,EAAeR,EAAK,KAAatF,GAC9BA,EAAK,OAAS6F,EAAe,KACrC,EACGC,EAAa,KAAK,OAChBA,EAAa,KAAK,OAAS,SAC7BD,EAAe,KAAO,CACpB,MAAOC,EAAa,KAAK,MACzB,WAAYA,EAAa,KAAK,WAC9B,KAAM,SACN,MAAOA,EAAa,KAAK,IAAA,EAG3BD,EAAe,KAAO,CACpB,MAAOC,EAAa,MACpB,WAAYA,EAAa,WACzB,KAAM,SACN,mBAAoBA,EAAa,KAAK,kBAAA,GAIxCA,EAAa,aACXA,EAAa,YAAY,UAAU,OAAS,IAC9CD,EAAe,YAAc,CAC3B,aAAc,CAAC,EACf,eAAgB,EAAA,EAElBC,EAAa,YAAY,UAAU,QAAQ,CAACC,EAAKC,IAAa,CACxDA,IAAa,IACfH,EAAe,YAAY,aAAaE,EAAI,GAAG,EAAIA,EAAI,MACzD,CACD,EACDF,EAAe,YAAY,eAAiBC,EAAa,YAAY,WAAa,IAGtFD,EAAe,mBAAqBC,EAAa,SAClCD,EAAA,oBAAsBC,EAAa,WAAa,EAAA,EAG3DG,EAAqB,CAACC,EAAQC,IAAe,CACjD,QAASrT,EAAI,EAAGA,EAAIoT,EAAO,SAAS,OAAQpT,IAC1C,GAAIoT,EAAO,SAASpT,CAAC,EAAE,SAAS,OAAS,EAAG,CAC1C,IAAIsT,EAAO,GACPF,EAAO,OAAS,MACXE,EAAA,KAEAA,EAAA,KAETD,EAAW,KAAK,CAAE,WAAY,CAAA,EAAI,KAAAC,CAAY,CAAA,EAC3BH,EAAAC,EAAO,SAASpT,CAAC,EAAGqT,EAAWA,EAAW,OAAS,CAAC,EAAE,UAAU,CAAA,SAE/ED,EAAO,SAASpT,CAAC,EAAE,UAAW,CAChC,IAAIuT,EAAa,GACjB,MAAMrG,EAAY,CAChB,UAAWkG,EAAO,SAASpT,CAAC,EAAE,UAC9B,UAAWoT,EAAO,SAASpT,CAAC,EAAE,SAC9B,KAAMoT,EAAO,SAASpT,CAAC,EAAE,KACzB,WAAY,GACZ,MAAOoT,EAAO,SAASpT,CAAC,EAAE,MAC1B,QAASoT,EAAO,SAASpT,CAAC,EAAE,QAAUoT,EAAO,SAASpT,CAAC,EAAE,QAAU,IACnE,aAAcoT,EAAO,SAASpT,CAAC,EAAE,aAAeoT,EAAO,SAASpT,CAAC,EAAE,aAAe,EAAA,EAGpF,GADauT,EAAA,KAAK,MAAM,KAAK,UAAUH,EAAO,SAASpT,CAAC,EAAE,UAAU,CAAC,EACjEoT,EAAO,SAASpT,CAAC,EAAE,WAAa,OAClCkN,EAAK,WAAakG,EAAO,SAASpT,CAAC,EAAE,OACrCkN,EAAK,cAAgBkG,EAAO,SAASpT,CAAC,EAAE,cACxCkN,EAAK,SAAWkG,EAAO,SAASpT,CAAC,EAAE,SAC/BoT,EAAO,SAASpT,CAAC,EAAE,aAAe,OAChCoT,EAAO,SAASpT,CAAC,EAAE,eACRuT,EAAA,UACbrG,EAAK,SAAWkG,EAAO,SAASpT,CAAC,EAAE,UAK5BoT,EAAO,SAASpT,CAAC,EAAE,aAAe,cAC3CuT,EAAa,KAAOH,EAAO,SAASpT,CAAC,EAAE,cAAgB,KAEzDkN,EAAK,WAAakG,EAAO,SAASpT,CAAC,EAAE,OACrCkN,EAAK,cAAgBkG,EAAO,SAASpT,CAAC,EAAE,cACxCkN,EAAK,SAAWkG,EAAO,SAASpT,CAAC,EAAE,iBAE/B,OAAO,UAAU,SAAS,KAAKuT,CAAU,IAAM,iBAAkB,CACnE,MAAMC,EAAiB,CAAA,EACvB,QAASlV,EAAI,EAAGA,EAAIiV,EAAW,OAAQjV,IACjCiV,EAAWjV,CAAC,IAAM,MACVkV,EAAA,KAAKD,EAAWjV,CAAC,CAAC,EAGnBiV,EAAAC,EAAU,KAAK,GAAG,CACjC,CAEFtG,EAAK,WAAaqG,EACdH,EAAO,SAAS,OAAS,GAAKpT,IAAMoT,EAAO,SAAS,OAAS,IAC3DA,EAAO,OAAS,MAClBlG,EAAK,KAAO,KAEZA,EAAK,KAAO,MAGhBmG,EAAW,KAAKnG,CAAI,CACtB,CAEJ,EAIIuG,EAAkB,CAAClH,EAAMiG,EAAMV,IAAkB,CACrD,GAAI,CAACvF,EACH,OAEF,MAAMyG,EAAelB,EAAcU,CAAI,EAAE,KAAatF,GAC7CA,EAAK,OAASX,EAAK,KAC3B,EACD,GAAI,CAACyG,EACH,OAEF,MAAMK,EAAa,CAAA,EACbK,EAAaV,EAAa,WAChC,GAAIU,EACF,QAAS1T,EAAI,EAAGA,EAAI0T,EAAW,OAAQ1T,IACjC0T,EAAW1T,CAAC,EAAE,SAAS,OAAS,GACfmT,EAAAO,EAAW1T,CAAC,EAAGqT,CAAU,EAI3C,OAAAA,CAAA,EAGT,OAAO,gBAAkB,SACvB,MAAMM,EAAgBpX,EAAM,KAC5B,IAAIuV,EAAgBvV,EAAM,eACtB,CAACuV,GAAiB,OAAO,KAAKA,CAAa,EAAE,SAAW,KAC1CA,EAAA,CACd,SAAU,CAAC,EACX,aAAc,CAAC,EACf,OAAQ,CAAC,EACT,WAAY,CAAC,EACb,SAAU,CAAC,EACX,aAAc,CAAC,EACf,UAAW,CAAC,EACZ,cAAe,CAAC,EAChB,aAAc,CAAC,CAAA,GAGnB,MAAM8B,EAAa9B,EAAc,SAE7B,GADe,CAAC,GAAGA,EAAc,SAAU,GAAGA,EAAc,SAAS,EAC1D,SAAW,EAAG,CAC3B1M,UAAQ,MAAM,WAAW,EACzB,MACF,CAGM,MAAA2M,EAAgBF,EAAiBC,CAAa,EAEhD,IAAA+B,EACA,GAAA,MAAM,QAAQ/B,EAAc,MAAM,GAAKA,EAAc,OAAO,OAAS,EAAG,CAC1E,MAAMgC,GAAalI,EAAAkG,EAAc,aAAd,YAAAlG,EAA0B,KAAasB,GAAA,CAClD,MAAA6G,EAAcjC,EAAc,OAAO,CAAC,EAC1C,OAAO5E,EAAK,OAAS6G,GAAe7G,EAAK,UAAY6G,CAAA,GAEnDD,GAAc,OACPD,EAAA,CACP,MAAOC,EAAW,KAClB,WAAYA,EAAW,KAAA,EAG7B,CAEI,IAAAf,EACA,GAAAa,EAAW,OAAS,EAAG,CACRb,EAAA,CACf,MAAOa,EAAW,CAAC,EACnB,WAAYA,EAAW,CAAC,CAAA,EAE1B,MAAMI,IAAWnI,EAAAiG,EAAc,eAAd,YAAAjG,EAA4B,KAAaqB,IACjDA,GAAA,YAAAA,EAAM,QAAS0G,EAAW,CAAC,IAAK1G,GAAA,YAAAA,EAAM,WAAY0G,EAAW,CAAC,KACjE,CAAA,EACNb,EAAe,WAAaiB,EAAS,MAEvBlB,EAAAC,EAAgBjB,EAAc,YAAY,EACxDiB,EAAe,WAAaU,EAAgBV,EAAgB,eAAgBjB,CAAa,GAAK,EAChG,CACI+B,IAEYf,EAAAe,EAAQ/B,EAAc,UAAU,EAC9C+B,EAAO,WAAaJ,EAAgBI,EAAQ,aAAc/B,CAAa,GAAK,IAG9E,QAASvS,EAAI,EAAGA,EAAIwS,EAAc,OAAQxS,IACpCwS,EAAcxS,CAAC,EAAE,WAAa,QAClBwS,EAAAxS,CAAC,EAAE,WAAakU,EAAgB1B,EAAcxS,CAAC,EAAG,gBAAiBuS,CAAa,EAEhFC,EAAAxS,CAAC,EAAE,WAAakU,EAAgB1B,EAAcxS,CAAC,EAAG,eAAgBuS,CAAa,EAI7F,IAAAmC,GACAnC,GAAA,YAAAA,EAAe,YAAa,SAEdmC,EAAAnC,EAAc,eAAiB,GAE/BmC,EAAA3B,EAAgBR,GAAA,YAAAA,EAAe,YAAY,EAE7D,IAAIjN,EAAS,WACTqP,EAAc,GACdC,EAAe,GACfC,EAAa,GACbtC,EAAc,SAAW,kBAClBjN,EAAA,gBACTqP,EAAcpC,EAAc,YAC5BqC,EAAerC,EAAc,aAC7BsC,EAAatC,EAAc,YAG7B,MAAM7E,EAAM,CACV,QAAS,MACT,SAAU,OACV,QAAS,MACT,YAAa,SAAA,EAGX,GAAA,CACF,MAAMqD,EAAM,MAAMkB,GAAQ,IAAI,GAAG7F,mCAA+C,CAC9E,QAAS,CACP,WAAY,mCACZ,gBAAiB,KACnB,CAAA,CACD,EAEM,OAAA6F,GAAQ,KAAK,GAAG7F,aAAyB,CAC9C,WAAYmG,EAAc,WAC1B,OAAQ,IACR,MAAO,IACP,UAAW7E,EAAI0G,CAAa,EAC5B,eAAAZ,EACA,cAAAhB,EACA,OAAA8B,EACA,cAAAI,EACA,OAAApP,EACA,YAAAqP,EACA,aAAAC,EACA,WAAAC,CAAA,EACC,CACD,QAAS,CAAE,eAAgB9D,EAAI,KAAK,KAAK,KAAM,CAAA,CAChD,QACM3S,GACP,QAAQ,MAAMA,CAAC,CACjB,CAAA,CAEJ,EC/Xa0W,GAAoB,CAAC7G,EAAmBxK,IAAiB,CACpE,GAAIwK,GAAa,KAAa,OAAAxK,EACxB,MAAAoL,EAAaZ,EAAW,MAAM,SAAS,EAC7C,GAAIY,GAAa,MAAQA,EAAU,SAAW,EACrC,OAAApL,EAET,MAAM6E,EAAMuG,EAAU,OACtB,QAASpO,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAAqO,EAAWD,EAAUpO,CAAC,EACxB,GAAAqO,GAAY,MAAQA,IAAa,GAAI,MACzC,IAAIC,EAAYD,EAAS,MAAM,EAAG,EAAE,EACxBC,EAAAA,GAAA,YAAAA,EAAW,QAAQ,SAAUtL,GACrC,GAAA,CAEF,IAAIhH,EAASsS,EACR,aAAc,KAAKA,CAAS,IAG/BtS,KADc,MACCsS,CAAS,GAEdd,EAAAA,EAAU,QAAQa,EAAUrS,CAAM,QACvC2B,GACK6P,EAAAA,EAAU,QAAQa,EAAUC,CAAS,EACjD,QAAQ,KAAK3Q,CAAC,CAChB,CACF,CACO,OAAA6P,CACT,ECtBa8G,GAAmB,CAAC/X,EAA+B,KAAO,CACrE,KAAM,CAAE,aAAAgY,CAAA,EAAiBnZ,EAAA,OAAOqQ,GAAc,CAG5C,aAAc,IAAM,EAAA,CACrB,EAEGlP,EAAM,WAAa,aAERgY,IAGf,MAAMC,EAAoB,CAACC,EAAqC,KAAO,CACrE,KAAM,CAAE,MAAA3D,EAAO,KAAA9W,EAAM,SAAA0a,EAAU,KAAAzC,EAAM,UAAA0C,CAAc,EAAAF,EAC5C,MAAA,CACL,MAAA3D,EACA,WAAY9W,EACZ,SAAA0a,EACA,KAAAzC,EACA,SAAU,SACV,aAAc0C,CAAA,CAChB,EAGIC,EAAkB,CAAC1C,EAAmC,KAAO,CAC3D,KAAA,CACJ,MAAApB,EACA,KAAA9W,EACA,SAAA0a,EACA,KAAAzC,EACA,UAAA0C,EACA,SAAAE,EAAW,SACX,eAAAC,EACA,mBAAAC,EACA,eAAAC,EACA,QAAAC,EACA,WAAA5B,CACE,EAAAnB,EACG,MAAA,CACL,MAAApB,EACA,WAAY9W,EACZ,SAAA0a,EACA,KAAAzC,EACA,SAAA4C,EACA,aAAcF,EACd,UAAW,MACX,eAAAG,EACA,mBAAAC,EACA,eAAAC,EACA,QAAAC,EACA,WAAA5B,CAAA,CACF,EAGI,CAAE,eAAA/D,CAAA,EAAmBlU,EAAA,OAAOmQ,EAAc,CAG9C,eAAiB1P,GAAgB,EAAA,CAClC,EACKqZ,EAAsB,CAACC,EAAwC,KAAO,OAC1E,MAAMtN,EAAMsN,EAAY,OAClBlB,EAAgB,CAAA,EACtB,QAASjU,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAAoV,EAAUD,EAAYnV,CAAC,EACvB,CACJ,GAAAmM,EACA,eAAAkJ,EACA,aAAAC,EACA,mBAAAC,CACE,EAAAH,EACEI,EAAsC,CAC1C,KAAM,OACN,MAAOH,EACP,UAAWC,EACX,WAAY,GACZ,UAAWC,CAAA,EAGPE,EAAQnG,EAAenD,CAAE,GAAK,CAAA,EACpC,GAAI2B,GAAkB2H,EAAM,KAAM,MAAM,EAAG,CACzC,KAAM,CAAE,MAAAzS,EAAO,OAAAlC,GAAW2U,GAAS,CAAA,EACnCD,EAAa,YAAaja,EAAAA,EAAA,MAAMyH,CAAK,IAAXzH,YAAAA,EAAc,OAAOuF,GAC/C0U,EAAa,WAAa1U,CAC5B,CACAmT,EAAc,KAAKuB,CAAY,CACjC,CACO,OAAAvB,CAAA,EAET,MAAO,UAAY,OACX,KAAA,CAAE,cAAAnC,CAAkB,EAAAvV,EACpB,CACJ,OAAAsI,EACA,WAAA6Q,EACA,OAAAC,EACA,MAAAC,EACA,UAAAC,EACA,mBAAAC,EAAqB,CAAC,EACtB,WAAAC,EAAa,CAAC,EACd,aAAAC,EAAe,CAAC,EAChB,cAAAC,EAAgB,CAAC,EACjB,gBAAAC,EAAkB,CAAC,EACnB,WAAAC,EAAa,CAAC,EACd,YAAAhB,EAAc,CAAC,EACf,aAAAhB,EACA,WAAAC,EACA,QAAAgC,EAAU,EAAA,EACRtE,GAAiB,CAAA,EASjB,IAAAiB,EACJ,GAAI,MAAM,QAAQ+C,CAAkB,GAAKA,EAAmB,OAAS,EAAG,CACtE,MAAMjO,EAAMiO,EAAmB,OAC/B,QAAS9V,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CAC5B,MAAMkN,EAAO4I,EAAmB9V,CAAC,GAAK,CAAA,EAChC,CAAE,MAAA8Q,EAAQ,GAAI,KAAA9W,EAAO,GAAI,KAAAiY,EAAO,GAAO,KAAAoE,EAAM,YAAAC,EAAa,WAAAjD,EAAA,EAAenG,EAE3E,GAAA+E,GAAQpK,IAAQ,EAAG,CACJkL,EAAA,CACf,MAAAjC,EACA,WAAY9W,EACZ,KAAAiY,EACA,KAAAoE,EACA,YAAAC,EACA,WAAAjD,EAAA,EAEF,KACF,CACF,CACF,CAEI,IAAAQ,EACJ,GAAI,MAAM,QAAQkC,CAAU,GAAKA,EAAW,OAAS,EAAG,CACtD,MAAMlO,EAAMkO,EAAW,OACvB,QAAS/V,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CAC5B,MAAMkN,EAAO6I,EAAW/V,CAAC,GAAK,CAAA,EACxB,CAAE,MAAA8Q,EAAQ,GAAI,KAAA9W,EAAO,GAAI,KAAAiY,EAAO,GAAO,KAAAoE,EAAM,YAAAC,EAAa,WAAAjD,EAAA,EAAenG,EAE3E,GAAA+E,GAAQpK,IAAQ,EAAG,CACZgM,EAAA,CACP,MAAA/C,EACA,WAAY9W,EACZ,KAAAiY,EACA,KAAAoE,EACA,YAAAC,EACA,WAAAjD,EAAA,EAEF,KACF,CACF,CACF,CAEA,MAAMkD,EAAe,CAAA,EACJL,GAAA,MAAAA,EAAA,QAASzB,GAAuC,CAClD8B,EAAA,KAAK/B,EAAkBC,CAAW,CAAC,CAAA,GAIlD,MAAM1C,EAAgB,CAAA,EAatB,GAZciE,GAAA,MAAAA,EAAA,QAAShE,GAAoC,CACzDA,EAAS,SAAW,OACND,EAAA,KAAK6C,EAAgB5C,CAAQ,CAAC,CAAA,GAE/BiE,GAAA,MAAAA,EAAA,QAASO,GAAqC,CAC3DA,EAAU,SAAW,QACPzE,EAAA,KAAK6C,EAAgB4B,CAAS,CAAC,CAAA,GAEnCL,GAAA,MAAAA,EAAA,QAASjE,GAAqC,CACxDA,EAAU,SAAW,OACPH,EAAA,KAAK6C,EAAgB1C,CAAS,CAAC,CAAA,GAE3C0D,IAAU,KAAOW,EAAa,SAAW,EAC3C,OACS,GAAAX,IAAU,KAAO7D,EAAc,SAAW,EACnD,OAEE,IAAAkC,GACAnC,GAAA,YAAAA,EAAe,YAAa,SAEdmC,EAAAnC,EAAc,eAAiB,GAE/CmC,EAAgBiB,EAAoBC,CAAW,EAE7C,GAAA,CAyBK,OAxBK,MAAM3D,GAAQ,KAAK,GAAG7F,aAAyB,CACzD,OAAA9G,EACA,WAAA6Q,EACA,OAAAC,EACA,MAAAC,EACA,UAAAC,EACA,eAAA9C,EACA,OAAAc,EACA,cAAA9B,EACA,aAAAwE,EACA,SAAU,GACV,cAAAtC,EAEA,aAAAE,EACA,WAAAC,EACA,QAAAgC,CACF,EACA,CACE,QAAS,CAEP,gBAAgBxK,EAAA,2BAAQ,SAAR,YAAAA,EAAgB,eAChC,eAAgB,KAClB,CACF,CAAA,QAEOjO,GACP,QAAQ,MAAMA,CAAC,CACjB,CAAA,CAEJ,EC/Na8Y,GAAiC,IAAM,CAElD,MAAMhH,EADS,OAAO,SAAS,OACT,MAAM,CAAC,EAAE,MAAM,GAAG,EAClC5H,EAAM4H,EAAO,OACnB,QAASzP,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAA2P,EAAQF,EAAOzP,CAAC,EAClB,GAAA2P,GAAS,MAAQA,IAAU,GAAI,SAC7B,MAAA+G,EAAc/G,EAAM,MAAM,GAAG,EAC/B,GAAA,MAAM,QAAQ+G,CAAW,EAAG,CACxB,MAAA7a,EAAM6a,EAAY,CAAC,EACnB1T,EAAQ0T,EAAY,CAAC,EAC1B,OAAe,OAAO7a,CAAG,EAAImH,CAChC,CACF,CACF,ECIA2T,GAAera,kBAAgB,CAC7B,KAAM,iBACN,aAAc,GACd,MAAO,CACL,GAAGwO,EACL,EACA,MAAOvO,EAAO,CAEN,MAAAqa,EAAQtb,EAAAA,SAAS,KAAO,CAC5B,MAAOiB,EAAM,MACb,OAAQA,EAAM,OACd,gBAAiBA,EAAM,gBACvB,gBAAiByU,GAAazU,EAAM,gBAA2B,EAAI,EACnE,eAAgBA,EAAM,cACtB,EAAA,EACIsa,EAAQpK,MAAI,CAAC,EACbqK,EAASrK,MAAI,CAAC,EACdsK,EAAgBtK,MAAI,CAAC,EACrBuK,EAAiBvK,MAAI,CAAC,EACtBwK,EAAQxK,MAAI,EAAK,EACjBhI,EAAYgI,EAAAA,MACd,IAAAyK,EACJ,MAAMC,EAAW,IACR,IAAI,QAAeC,GAAY,CACpCvZ,EAAAA,SAAS,IAAM,CAETtB,EAAM,OAASA,EAAM,QACjBsa,EAAA,MAAQ,WAAWta,EAAM,KAAK,EAC7Bua,EAAA,MAAQ,WAAWva,EAAM,MAAM,IAEhCsa,EAAA,MAAQpS,EAAU,MAAM,YACvBqS,EAAA,MAAQrS,EAAU,MAAM,eAG7B,CAACsS,EAAc,OAAS,CAACC,EAAe,SAC5BD,EAAA,MAAQ,OAAO,OAAO,MACrBC,EAAA,MAAQ,OAAO,OAAO,QAE/BI,GAAA,CACT,CAAA,CACF,EAEGC,EAAa,IAAM,CACnBR,EAAM,OAASC,EAAO,OACxBrS,EAAU,MAAM,MAAM,MAAQ,GAAGoS,EAAM,UACvCpS,EAAU,MAAM,MAAM,OAAS,GAAGqS,EAAO,YAEzCrS,EAAU,MAAM,MAAM,MAAQ,GAAGsS,EAAc,UAC/CtS,EAAU,MAAM,MAAM,OAAS,GAAGuS,EAAe,UACnD,EAEIM,EAAc,IAAM,CAElB,MAAAC,EAAe,SAAS,KAAK,YAC7BC,EAAgB,SAAS,KAAK,aAE9BC,EAAYZ,EAAM,OAASE,EAAc,MACzCW,EAAaZ,EAAO,OAASE,EAAe,MAC5CW,EAAaJ,EAAeE,EAC5BG,EAAcJ,EAAgBE,EACpCjT,EAAU,QAAUA,EAAU,MAAM,MAAM,UAAY,SAASkT,MAAeC,KAAA,EAE1EC,EAAW,SAAY,CAC3B,MAAMV,EAAS,EACHG,GAAA,EAERQ,EAAuB,IAAM,CACjC,MAAMC,EAAmB,OAAO,iBACrBb,EAAA,IAAIa,EAAiBF,CAAQ,EAC/BX,EAAA,QAAQzS,EAAU,MAAO,CAChC,WAAY,GACZ,gBAAiB,CAAC,OAAO,EACzB,kBAAmB,EAAA,CACpB,CAAA,EAEGuT,EAAyB,IAAM,CAC/Bd,IACFA,EAAS,WAAW,EACpBA,EAAS,YAAY,EACVA,EAAA,KACb,EAEFhZ,OAAAA,EAAAA,UAAU,SAAY,CACpB+Y,EAAM,MAAQ,GACd,MAAME,EAAS,EACJE,IACCC,IACZ,OAAO,iBAAiB,SAAUW,GAAS,SAAAJ,EAAU,GAAG,CAAC,EACpCC,IACrBb,EAAM,MAAQ,EAAA,CACf,EACD9Y,EAAAA,YAAY,IAAM,CACT,OAAA,oBAAoB,SAAU0Z,CAAQ,EACtBG,GAAA,CACxB,EACM,CACL,MAAApB,EACA,UAAAnS,EACA,MAAAwS,CAAA,CAEJ,CACF,CAAC,QAtHwBnN,GAAY,CAAA,GAAA,sCACjBoO,GAAKnO,EAAAoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,sBACnB1O,qBAKM,MAAAC,GAAA,CAAAC,EAAA,OAAAC,EAAAA,YAJeH,EAAAA,mBAAA,MAAA,CAClB,IAAK,EAAA,MAAA,cAEN,MAAa2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,sFCLR,MAAA0O,GAAiBnO,uDAAsB,ECOvCoO,GAAiC,CAC5C,kBAAmB,GACnB,SAAU,SACV,MAAO,QACP,aAAc,CAAC,CACjB,EAGaC,GAA+BhO,EAA0B+N,EAAc,ECDpFE,GAAetc,kBAAgB,CAC7B,KAAM,qBACN,aAAc,GACd,MAAO,CACL,GAAGqc,EACL,EACA,MAAOpc,EAAO,CAAE,OAAAsc,GAAU,CACOpC,KAE/B,MAAMiC,EAAiBjM,EAAAA,MACjBqM,EAAW,IAAM,CACrBJ,EAAe,MAAM,aAAa,cAAenc,EAAM,KAAe,CAAA,EAElE/B,QAAA,IAAM+B,EAAM,MAAO,IAAM,CACpBuc,GAAA,CACV,EACD5a,EAAAA,UAAU,IAAM,CACL4a,GAAA,CACV,EACK,MAAA1J,EAAoB9T,EAAAA,SAAS,IAC1B2S,GAAmB1R,EAAM,iBAA2B,CAC5D,EACK8S,EAAW/T,EAAA,SAAS,IAAMiB,EAAM,QAAQ,EACxCwc,EAAQzd,EAAA,SAAS,IAAMiB,EAAM,KAAK,EAElCiQ,EAAeC,MAAY,EAAE,EAEnCuM,EAAAA,QAAQ1N,EAAe,CAErB,kBAAA8D,EAEA,SAAAC,EAEA,MAAA0J,EACA,aAAAvM,CAAA,CACD,EAGK,MAAAyM,MAAkB,IAClB3J,EAAkBzT,GACfod,EAAY,IAAIpd,CAAG,EAEtBqd,EAAiB,CAACrd,EAAamH,IAAe,CACtCiW,EAAA,IAAIpd,EAAKmH,CAAK,CAAA,EAE5BgW,EAAAA,QAAQzN,EAAc,CACpB,eAAA+D,EACA,eAAA4J,CAAA,CACD,EAGD,MAAM7M,EAAW8M,KACXC,MAAqB,IACrBC,EAAU,CAACxd,EAAaqQ,IAAkC,CAC1DkN,EAAe,IAAIvd,CAAG,GACxBwQ,EAAS,IAAIxQ,CAAG,EAETwQ,EAAA,GAAGxQ,EAAMyd,IAChBF,EAAe,IAAIvd,CAAG,EACf,OAAO,UAAU,SAAS,KAAKqQ,EAAOoN,CAAC,CAAC,IAAM,qBAAuBpN,EAAOoN,CAAC,EAAE,EACvF,EACDC,EAAAA,gBAAgB,IAAM,CACpBlN,EAAS,IAAIxQ,CAAG,CAAA,CACjB,CAAA,EAEG2d,EAAY3d,GAAQ,CACxBwQ,EAAS,IAAIxQ,CAAG,CAAA,EAEZ+Q,EAAY,CAAC/Q,EAAa4d,IAAsB,CAC3CpN,EAAA,KAAKxQ,EAAK4d,CAAS,CAAA,EAE9BT,EAAAA,QAAQ3N,GAAW,CACjB,QAAAgO,EACA,SAAAG,EACA,UAAA5M,CAAA,CACD,EAGK,MAAA8M,EAAWjN,MAAI,CAAC,EAChB8H,EAAe,IAAM,CAChBmF,EAAA,MAAQne,EAAAA,MAAMme,CAAQ,EAAI,CAAA,EAErCV,EAAAA,QAAQvN,GAAc,CACpB,aAAA8I,CAAA,CACD,EAEK,MAAAoF,MAAmB,IACnBC,MAAiB,IACjBC,EAAa,CAAC,CAAE,UAAAC,EAAY,IAAM,CAAI,EAAA,QAAAC,EAAU,EAAG,GAAA5N,EAAK,MAA4B,CACpF,GAAAwN,EAAa,IAAII,CAAO,EAAG,CACvB,MAAAC,EAAgBL,EAAa,IAAII,CAAO,EAC9CC,GAAA,MAAAA,EAAe,KAAKF,EAAS,MAE7BH,EAAa,IAAII,EAAS,CAACD,CAAS,CAAC,EAE5BF,EAAA,IAAIzN,EAAI2N,CAAS,CAAA,EAExBG,EAAuBD,GACpB,IAAI,QAAQ,CAAC5C,EAAS8C,IAAW,CACtC,MAAMC,EAAaH,EAAc,IAAIF,GAAaA,GAAW,EAC7D,QAAQ,IAAIK,CAAU,EACnB,KAAa3H,GAAA,CACZ4E,EAAQ5E,CAAI,CAAA,CACb,EACA,MAAapK,GAAA,CACZ8R,EAAO9R,CAAG,CAAA,CACX,CAAA,CACJ,EAGGgS,EAAiB,SAAY,OACjC,MAAM9J,EAAM,MAAMC,GAAM,IAAI,GAAG5E,mCAA+C,CAC5E,QAAS,CACP,WAAY,mCACZ,gBAAiB,KACnB,CAAA,CACD,EAIM,OAAA,gBAAiBC,EAAA0E,EAAI,KAAK,OAAT,YAAA1E,EAAe,KAAA,EAEnCyO,EAAe,MAAOlO,GAA2B,CAErD,GAAKA,GAqBL,GAAW,OAAOA,GAAO,SAAU,CAC3B,MAAA2N,EAAYF,EAAW,IAAIzN,CAAE,EAC/B,OAAO2N,GAAc,YACbA,GAEd,MA1BS,CACD,MAAAQ,EAAkB,MAAM,KAAKX,CAAY,EAE/BW,EAAA,KAAK,CAAC1b,EAAGO,IAAMA,EAAE,CAAC,EAAIP,EAAE,CAAC,CAAC,EAC1C,MAAMiJ,EAAMyS,EAAgB,OACxB,GAAA,CAGE/d,EAAM,WAAa,UAAYhB,EAAAA,MAAMme,CAAQ,EAAI,GACnD,MAAMU,EAAe,EAEvB,QAASpa,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CAC5B,MAAMga,EAAgBM,EAAgBta,CAAC,EAAE,CAAC,EAC1C,MAAMia,EAAoBD,CAAa,CACzC,QACOrc,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CAEAgc,EAAa,MAAM,CACrB,CAAA,CAMF,EAGFX,EAAAA,QAAQxN,GAAe,CACrB,WAAAqO,EACA,aAAAQ,CAAA,CACD,EAED,MAAME,EAAkB,IAAM,CAC5BlO,EAAS,KAAKX,EAAY,CAAA,EAE5BsN,EAAAA,QAAQtN,GAAc,CACpB,gBAAA6O,CAAA,CACD,EAGK,MAAAC,EAAiB3L,GAAuB,CAC5CxC,EAAS,GAAGX,GAAc,IAAMmD,EAAU,CAAA,EAC1C3Q,EAAAA,UAAU,IAAM,CACdmO,EAAS,IAAIX,EAAY,CAAA,CAC1B,CAAA,EAGH6N,OAAAA,EAAAA,gBAAgB,IAAM,CACpBI,GAAA,MAAAA,EAAc,QACdC,GAAA,MAAAA,EAAY,OAAM,CACnB,EAEMf,EAAA,CACL,aAAAwB,EACA,eAAA/K,EACA,cAAAkL,CAAA,CACD,EAEM,CACL,eAAA9B,CAAA,CAEJ,CACF,CAAC,EA1M6B5O,GAAC,CAAA,GAAA,gDAC3BoO,GAAanO,EAAAoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,4FCDJ,MAAAkC,GAAqBnQ,uBAA0B,ECsB/CoQ,GAAsB,CACjC,GAAGne,EACH,KAAM,KACN,QAAS,KACT,KAAM,WACN,MAAO,QACP,OAAQ,OACR,KAAM,KACN,MAAO,OACP,cAAe,OACf,SAAU,OACV,WAAY,GACZ,WAAY,IACZ,WAAY,GACZ,eAAgB,SAChB,WAAY,SACZ,iBAAkB,OAClB,KAAM,CAAC,EACP,qBAAsB,IACtB,OAAQ,GACR,OAAQ,OACR,KAAM,GACN,SAAU,EACZ,EAGaoe,GAAqBhQ,EAA0B+P,EAAS,EAExDE,GAAa,CAAC,cAAe,OAAO,ECpDlCC,GAAA,6cCAAC,GAAA,qyECwBfC,GAAeze,kBAAgB,CAC7B,KAAM,WACN,WAAY,CAAE,SAAA0e,EAAS,EACvB,MAAO,CACL,GAAGL,EACL,EACA,MAAOpe,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC0e,EAASxO,MAAI,CAAA,CAA0B,EACvCjS,QAAA,IAAM,CAAC+B,EAAM,KAAMA,EAAM,QAAQ,EAAG,CAAC,CAACuQ,EAAMoO,CAAQ,IAAM,CAC1DA,IAAa,WACfD,EAAO,MAAQnO,EACjB,EACC,CACD,UAAW,EAAA,CACZ,EACK,MAAAqO,EAAS7f,EAAAA,SAAS,IAAM,OACtB,MAAAwR,EAAOvR,QAAM0f,CAAM,EACzB,IAAIG,EAAO7e,EAAM,KACV6e,EAAAA,GAAA,YAAAA,EAAM,QAAQ,UAAW,SACzBA,EAAAA,GAAA,YAAAA,EAAM,QAAQ,MAAO,UACtB,MAAAhN,EAAagN,EAAM,MAAM,+BAA+B,EAC1D,GAAAhN,GAAa,MAAQA,EAAU,SAAW,EAAU,OAAAgN,EACxD,QAASpb,EAAI,EAAGA,EAAIoO,EAAU,OAAQpO,IAAK,CACnC,MAAAqO,EAAWD,EAAUpO,CAAC,EACtBH,GAAI+L,EAAAyC,GAAA,YAAAA,EAAU,MAAM,EAAGA,EAAS,OAAS,KAArC,YAAAzC,EAAyC,OAC/C,IAAA+C,EAAe7B,EAAKjN,CAAC,EAEzB,GAAI8O,GAAgB,KAAM,CAExB,MAAM7N,EAASvE,EAAM,OACjBuE,IAAW,cAEb6N,EAAe,CAACA,EACX,MAAMA,CAAY,EAWdyM,EAAAA,EAAK,QAAQ/M,EAAU,sBAAsB9R,EAAM,2BAA2BA,EAAM,qBAAqB,WAAc,GAV9GoS,GAAAA,EAAe,KAAK,QAAQ,CAAC,EAEzCA,GAAgB,EACXyM,EAAAA,EAAK,QAAQ/M,EAAU,wCAAwC9R,EAAM,wCAAwCA,EAAM,0BAA0Bse,QAAUlM,WAAsB,EAGpLyM,EAAOA,EAAK,QAAQ/M,EAAU,yCAAyC9R,EAAM,wCAAwCA,EAAM,0BAA0Bue,QAAY,KAAK,IAAInM,CAAY,WAAW,IAM5L7N,IAAW,WAGpB6N,EAAe,CAACA,EACX,MAAMA,CAAY,IACLA,GAAAA,EAAe,KAAK,QAAQ,CAAC,EACtCyM,EAAAA,EAAK,QAAQ/M,EAAU,sBAAsB9R,EAAM,2BAA2BA,EAAM,qBAAqBoS,WAAsB,IAE/HpS,EAAM,SAAW,SAE1BoS,EAAe,CAACA,EACX,MAAMA,CAAY,IACrBA,EAAelB,GAAYkB,CAAY,EAChCyM,EAAAA,EAAK,QAAQ/M,EAAU,sBAAsB9R,EAAM,2BAA2BA,EAAM,qBAAqBoS,UAAqB,IAIhIyM,EAAAA,EAAK,QAAQ/M,EAAU,sBAAsB9R,EAAM,2BAA2BA,EAAM,qBAAqBoS,UAAqB,CACvI,MAGAyM,EAAOA,EAAK,QAAQ/M,EAAU9R,EAAM,oBAA8B,CAEtE,CACA,MAAO,SAAS6e,UAAA,CACjB,EACK,CAAE,SAAA/L,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EACKkE,EAAcZ,GAAerS,CAAK,EAClCtB,EAAUwR,MAAI,EAAK,EACnB4O,EAAoB,SAAY,OAChC,GAAA9f,EAAA,MAAM8T,CAAQ,IAAM,SACpB,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClByL,EAAO,QAAQrP,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAQ,CAAA,QAC3BjO,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAEIqgB,EAAc,IAAM,CACpB/e,EAAM,WAAa,UACL8e,GAAA,EAGpBpP,GAAW1P,EAAO,CAChB,YAAA+e,CAAA,CACD,EAED,KAAM,CAAE,WAAAzB,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EAEUD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW+e,EACX,QAAS/e,EAAM,WAAA,CAChB,EACD0P,GAAW1P,EAAO,CAChB,YAAA+e,CAAA,CACD,EAIK,MAAAC,EAFYjP,GAAa/P,CAAK,EAEZ,QAAS,IAAM,CAErC,GAAI,CAACA,EAAM,UAAY,CAACA,EAAM,KAAM,OAC9B,MAAAif,EAAYjf,EAAM,UAAY,GAC9Bkf,EAAUrK,GAAW7V,EAAAA,MAAM8T,CAAQ,EAAGmM,CAAQ,EAE9CE,EAAOnf,EAAM,KACnB,IAAIgT,EAAMmM,GAAQD,EAClBlM,EAAMtB,GAAmBsB,CAAG,EAC5B,MAAM3K,EAASrI,EAAM,OACjBqI,GAAU,MAAQA,IAAW,KAC7BA,IAAW,QACN,OAAA,KAAK2K,EAAK,IAAO3K,CAAiB,EAEzC,OAAO,OAAO,YAAY,CACxB,KAAM,WACN,IAAK8W,GACJ,GAAG,EACR,CACD,EAEM,MAAA,CACL,MAAA9E,EACA,OAAAuE,EACA,QAAAlgB,EACA,MAAAsgB,CAAA,CAEJ,CACF,CAAC,kDAvK2D,MAAAI,EAAA/R,mBAAA,UAAA,kCAA7BC,EAAAA,mBAAA,MAAA,CAAE,IAAK,EAAA,MAAA,mBAClC,MAA8B2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAEhC4R,EAA6E,CAAA,QAAA5R,EAAA,OAAA,EAAA,KAAA,EAAA,CAAA,SAAA,CAAA,CAAA,EAAA,CAAA,IAAAC,EAAAA,YAAvDH,EAAAA,mBAAA,MAAA,CAAE,IAAK,EAAS,MAAA,YAAiB,MAAK2O,EAAAA,eAAAzO,EAAA,KAAA,EAAA,UAAAA,EAAA,yECFjD,MAAA6R,GAAWtR,uDAAgB,ECMxCuR,GAAevf,kBAAgB,CAC7B,KAAM,iBACN,OAAS,CAEA,MAAA,CACL,KAFWmQ,MAAI,MAAM,CAErB,CAEJ,CACF,CAAC,kICdY,MAAAqP,GAAiBxR,uDAAsB,ECevCyR,GAAqC,CAChD,GAAGxf,EACH,KAAM,OACN,QAAS,OACT,KAAM,kBACN,OAAQ,2BACR,SAAU,OACV,MAAO,OACP,MAAO,QACP,OAAQ,OACR,UAAW,SACX,WAAY,GACZ,WAAY,IACZ,WAAY,GACZ,cAAe,QACjB,EAEayf,GAA4BrR,EAA0BoR,EAAgB,ECvBnFE,GAAe3f,kBAAgB,CAC7B,KAAM,kBACN,MAAO,CACL,GAAG0f,EACL,EACA,MAAOzf,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC2f,EAAOzP,EAAAA,IAAI0P,GAAA,EAAQ,OAAO5f,EAAM,MAAgB,CAAC,EACvD,IAAI6f,EAAQ,KACZ,MAAMC,EAAa,IAAM,CACvB,cAAcD,CAAK,EACXA,EAAA,IAAA,EAEJE,EAAW,IAAM,CACjBF,GACSC,IAEbD,EAAQ,YAAY,IAAM,CACnBF,EAAA,MAAQC,GAAQ,EAAA,IAAI,EAAG,GAAG,EAAE,OAAO5f,EAAM,MAAgB,GAC7D,GAAI,CAAA,EAET2B,OAAAA,EAAAA,UAAU,IAAM,CACLoe,GAAA,CACV,EACDne,EAAAA,YAAY,IAAM,CACLke,GAAA,CACZ,EACM,CACL,MAAAzF,EACA,KAAAsF,CAAA,CAEJ,CACF,CAAC,QA1CW,SAAAhE,GAACnO,EAAcoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,QAAOvO,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,6ECC5B,MAAA0S,GAAkBjS,uDAAuB,ECiBzCkS,GAAsB,CACjC,GAAGjgB,EACH,KAAM,WACN,KAAM,KACN,QAAS,KACT,MAAO,QACP,OAAQ,OACR,gBAAiB,UACjB,YAAa,OACb,YAAa,OACb,WAAY,GACZ,SAAU,GACV,WAAY,EACZ,YAAa,EACb,WAAY,OACZ,KAAM,CACJ,CACE,KAAM,IACN,IAAK,EACP,EACA,CACE,KAAM,IACN,IAAK,EACP,CACF,EACA,QAAS,CACP,CACE,IAAK,MACP,EACA,CACE,IAAK,KACP,CACF,CACF,EAEakgB,GAAqB9R,EAA0B6R,EAAS,EAOxDE,GAAsC,CAAC,cAAe,OAAO,EC4B1EC,GAAergB,kBAAgB,CAC7B,KAAM,WACN,WAAY,CAAE,SAAA0e,EAAS,EACvB,MAAO,CACL,GAAGyB,EACL,EACA,MAAOlgB,EAAO,CACN,MAAAqgB,EAAanQ,EAAAA,IAA4BlQ,EAAM,IAA8B,EAC7Eqa,EAAQ5L,EAAsBzO,EAAO,CAAC,iBAAiB,CAAC,EACxDsgB,EAAcvhB,EAAAA,SAAS,IACvBiB,EAAM,WACD,CACL,UAAW,QAAA,EAGN,CACL,UAAW,MAAA,CAGhB,EAEKugB,EAAW,CAAC9Z,EAAwBlC,IACpCA,GAAU,MAAQA,IAAW,GAAWkC,EAChC,CACV,MAAOyK,GACP,WAAYG,GACZ,SAAUA,EAAA,EAED9M,CAAM,EAAEkC,CAAK,GAAK,GAEzB+Z,EAAgB,CAAC/Z,EAAwBlC,IAAmB,CAC1D,MAAA6M,EAAS,WAAW3K,EAAQ,EAAE,EACpC,GAAIlC,IAAW,WACN,MAAA,GAET,OAAQ,GAAM,CACZ,KAAK6M,GAAU,EACN,MAAA,OACT,KAAKA,EAAS,EACL,MAAA,QACX,CAAA,EAEI6B,EAAcZ,GAAerS,CAAK,EAClC,CAAE,SAAA8S,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EACKrQ,EAAUwR,MAAI,EAAK,EACnB4O,EAAoB,SAAY,OACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UAEpD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClBoN,EAAW,QAAQhR,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,KAAK,OAAQ,SACpCjO,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAGIqgB,EAAc,IAAM,CACND,GAAA,EAKdE,EAFYjP,GAAa/P,CAAK,EAEZ,QAAS,IAAM,CAAA,CAAE,EAEzC0P,GAAW1P,EAAO,CAChB,YAAA+e,CAAA,CACa,EAEf,KAAM,CAAE,WAAAzB,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EACU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW8e,EACX,QAAS9e,EAAM,WAAA,CAChB,EACM,CACL,MAAAqa,EACA,SAAAkG,EACA,YAAAD,EACA,cAAAE,EACA,WAAAH,EACA,QAAA3hB,EACA,MAAAsgB,CAAA,CAEJ,CACF,CAAC,8EAlLOzR,GAAa,CAAA,IAAA,iBAcNkT,GAAe,CAAA,IAAA,mBAcnBC,GAAM,CAAA,IAAA,6BAqBFC,GAAe,CAAA,IAAA,mGAqBnBC,GAAa,CAAA,IAAA,kDAzEtBvT,mBA6EM,UAAA,SA7EuBI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,YAClC,MA2EW2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAxED4R,EAAQ,CAAA,QAAA5R,EAAA,OAAA,EAAA,CAFhB,QAAAqT,EAAA,QAAA,IAAA,CAAArT,EAAA,UAAAC,EAAA,UAAA,EAAAH,EAAAA,mBAIE,MAuBMC,GAAA,EAAAE,YAtBE,EAAa,EAAAH,EAAAA,mBAAAwT,EAAA,SAAA,KAAAC,EAAAA,WAAAvT,EAAA,YAAAwT,IACbvT,EAAA,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,oBAAwE2O,EAAAA,eAAU,CAAqC,gBAAAzO,EAAA,gBAAiG,OAAAA,EAAA,WAAA,MAAA,eAAAA,EAAA,iBAAAA,EAAA,kBAAAA,EAAA,YAAA,MAAAA,EAAA,2BAOxNwT,EAAKxT,EAAA,cAAA,EAAAA,EAAA,YAAA,EAAA,CAAA,EAEgB,IAAAwT,CAAA,EAAA,CAC3BxT,EAAA,YAAAC,EAAA,UAAA,EAAAH,EAAA,mBAUM,MAVNmT,EAAA,GAAAQ,EAAAA,mBAAA,GAAA,EAAA,GAAAxT,EAAAA,UACQ,EAAQ,EAAAH,EAAA,mBAAAwT,WAAA,KAAAC,EAAA,WAAAvT,EAAA,QAAA,CAAA0T,EAAAzd,KAERgK,EAAA,UAAA,EAAeH,EAAA,mBAAA,MAAA,CACpB,MAAK,SAAyB,IAAM4T,EAAC,KAAUzd,EAAmB,MAAWwY,EAAAA,eAAA,CAAA,MAAAiF,EAAA,iFASpF,GAAAD,EAAAA,mBAAA,GAAA,EAAA,EAMUzT,EAAA,WAAA,OAAQ,sCALhB,MAMEkT,GAAA,CAAAlT,EAAA,UAAAC,EAAAA,YALyBH,EAAAA,mBAAA,MAAA,CACxB,IAAK,EAA8B,MAAA,oBAAA,MAAA2O,EAAAA,eAAA,6BAKtC,EAAA,KAAA,CAAA,GAAAgF,EAAAA,mBAAA,GAAA,EAAA,GAAAxT,EAAA,UACQ,EAAM,EAAAH,EAAAA,mBAAAwT,EAAAA,SAAA,KAAAC,EAAAA,WAAAvT,EAAA,WAAA,MAAA,EAAAA,EAAA,UAAA,EAAA,CAAAmD,EAAA,KACNlD,EAAA,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,aAAsE2O,EAAAA,eAAU,CAAoC,gBAAAzO,EAAA,gBAAA,OAAAA,EAAA,gCAA4KA,EAAW,iBAAAA,EAAA,kBAAAA,EAAA,YAAA,OAAAA,EAAA,eAAA,aAAA,EAAA,GAAAA,EAAA,cAAA,EAAAA,EAAA,YAAA,gBAQ3SA,EAAO,WAAA,CAAA,sBAGcoO,EAAU,CAAA,IAAAA,EAAA,CAAA,EAAA,IAAAle,IAAA8P,EAAA,OAAAA,EAAA,MAAA,GAAA9P,CAAA,EAAA,EAAA,CACnC8P,EAAA,YAAAC,EAAA,UAAA,6BACkBkT,GACZ,CAAAQ,kEAGR,CAAA,GAAAF,EAAAA,mBAAA,GAAA,EAAA,GAAAxT,YACQ,EAAa,EAAAH,EAAAA,mBAAAwT,EAAA,SAAA,KAAaC,EAAAA,WAAYvT,EAAI,QAAgB0T,IAE1DzT,EAAU,UAAA,EAAAH,EAAA,mBAAA,MAAA,CACf,MAAK8T,EAAA,eAAA,CAAA,SAAA5T,EAAA,cAAAmD,EAAAuQ,EAAA,GAAA,EAAAA,EAAA,MAAA,CAAA,CAAA,EAAA,IAA4BA,EAAO,IAAgC,MAAkBjF,EAAAA,eAAA,CAAmF,SAAAiF,EAAA,SAAA,MAAoC1T,EAAW,cAAAmD,EAAAuQ,EAAA,GAAA,EAAAA,EAAA,MAAA,IAAA,GAAAA,EAAA,MAAA,GAAA,WAAAA,EAAA,6NC7D5N,MAAAG,GAAWtT,uDAAgB,ECqB3BuT,GAAmC,CAC9C,GAAGthB,EACH,KAAM,MACN,QAAS,MACT,KAAM,iBACN,WAAY,SACZ,MAAO,QACP,OAAQ,QACR,YAAa,UACb,cAAe,QACf,WAAY,UACZ,KAAM,CACJ,QAAS,EACX,EACA,KAAM,aACN,SAAU,OACV,MAAO,UACP,YAAa,EACb,WAAY,IACZ,gBAAiB,OACjB,WAAY,OACZ,cAAe,GACf,qBAAsB,GACxB,EAEauhB,GAA2BnT,EAA0BkT,EAAe,EAEpEE,GAAmB,CAAC,cAAe,OAAO,ECRvDC,GAAe1hB,kBAAgB,CAC7B,KAAM,iBACN,WAAY,CAAA,UACV2hB,EAAA,SACA,SAAAjD,EACF,EACA,MAAO,CACL,GAAG8C,EACL,EACA,MAAOvhB,EAAO,CACZ,KAAM,CAAE,SAAA8S,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EACKsL,EAAQ5L,EAAsBzO,CAAK,EACnC2hB,EAAU5iB,EAAAA,SAAS,IAAM,CAC7B,MAAMub,EAAQta,EAAM,MACpB,OAAO,WAAWsa,CAAK,CAAA,CACxB,EACKoE,EAASxO,MAA2B,CAAA,CAAE,EACtCjS,QAAA,IAAM+B,EAAM,KAAM,IAAM,EACxBA,EAAM,WAAa,UAAYhB,EAAAA,MAAM8T,CAAQ,IAAM,YACrD4L,EAAO,MAAQ1e,EAAM,KACvB,EACC,CACD,UAAW,GACX,KAAM,EAAA,CACP,EACK,MAAA4hB,EAAU7iB,EAAAA,SAAS,IAAM,CACvB,MAAAwR,EAAOvR,QAAM0f,CAAM,EACnBmD,EAAe,CAAE7hB,EAAM,qBAC7B,GAAIuQ,GAAQ,KACN,OAAC,MAAMsR,CAAY,EAGd,EAFAA,EAKX,MAAMhQ,EAAa7R,EAAM,KAAgB,MAAM,SAAS,GAAK,GACzD,IAAAyG,EACJ,MAAMqb,EAAW,IAAI,IAAI,OAAO,KAAKvR,CAAI,CAAC,EAC1C,QAAS9M,EAAI,EAAGA,EAAIoO,EAAU,OAAQpO,IAAK,CACnC,MAAAqO,EAAWD,EAAUpO,CAAC,EACtBnE,EAAMwS,EAAS,MAAM,EAAGA,EAAS,OAAS,CAAC,EAC7C,GAAAgQ,EAAS,IAAIxiB,CAAG,EAAG,CACrBmH,EAAQ8J,EAAKjR,CAAG,EAChB,KACF,CACF,CAEI,OAAA,OAAOmH,GAAU,SACnBA,EAAQA,EAAQ,IACP,OAAOA,GAAU,UAAY,CAAC,MAAM,CAACA,CAAK,EACnDA,EAAS,CAACA,EAAS,IACT,MAAMob,CAAY,EAGpBpb,EAAA,EAFRA,EAAQob,EAAe,IAKrB7hB,EAAM,gBACAyG,EAAA,CAACA,EAAM,QAAQ,CAAC,GAEnBA,CAAA,CACR,EACKoY,EAAO9f,EAAAA,SAAS,IAAM,OAC1B,IAAI8f,EAAO7e,EAAM,KACjB,GAAI6e,IAAS,GAAI,OAAO7f,EAAAA,MAAM4iB,CAAO,EACrC,MAAMC,EAAe7hB,EAAM,qBACrBuQ,EAAOvR,QAAM0f,CAAM,EACnB7M,EAAagN,EAAM,MAAM,SAAS,GAAK,CAAA,EAC7C,QAASpb,EAAI,EAAGA,EAAIoO,EAAU,OAAQpO,IAAK,CACnC,MAAAqO,EAAWD,EAAUpO,CAAC,EAC5B,IAAIsO,EAAYD,EAAS,MAAM,EAAGA,EAAS,OAAS,CAAC,EAC/C,MAAAG,EAAgBF,EAAU,MAAM,KAAK,EAC3C,QAASG,EAAI,EAAGA,GAAID,GAAA,YAAAA,EAAe,QAAQC,IAAK,CAC9C,MAAMC,GAAe9C,EAAA4C,EAAcxO,CAAC,IAAf,YAAA4L,EAAkB,OACnCkB,EAAK4B,CAAY,GAAK,KACxBJ,EAAYA,EAAU,QAAQI,EAAc5B,EAAK4B,CAAY,CAAC,EAElDJ,EAAAA,EAAU,QAAQI,EAAc0P,CAAY,CAE5D,CAEA,IAAIzP,EAA+BL,EAE/B,GAAA,CACG,mBAAoB,KAAKA,CAAS,IAGrCK,KADc,MACOL,CAAS,SAEzB3Q,GACP,QAAQ,MAAMA,CAAC,CACjB,EACI,OAAOgR,GAAiB,UAAY,CAAC,MAAM,CAACA,CAAY,KAC1DA,EAAgB,CAACA,EAAe,IAC5BpS,EAAM,gBACOoS,EAAAA,EAAa,QAAQ,CAAC,IAGzCyM,EAAOA,EAAK,QAAQ/M,EAAUM,EAAe,EAAE,CACjD,CACOyM,OAAAA,CAAA,CACR,EACK5L,EAAcZ,GAAerS,CAAK,EAClCtB,EAAUwR,MAAI,EAAK,EACnB4O,EAAoB,SAAY,OACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UACpD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClByL,EAAO,QAAQrP,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAQ,CAAA,QAC3BjO,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAKFgR,GAAW1P,EAAO,CAChB,YAJkB,IAAM,CACN8e,GAAA,CAGlB,CACD,EAIK,MAAAE,EAFYjP,GAAa/P,CAAK,EAEZ,QAAS,IAAM,CAAA,CAAE,EAEnC,CAAE,WAAAsd,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EAEU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW8e,EACX,QAAS9e,EAAM,WAAA,CAChB,EAEM,CACL,MAAAqa,EACA,QAAAsH,EACA,KAAA9C,EACA,QAAA+C,EACA,QAAAljB,EACA,MAAAsgB,CAAA,CAEJ,CACF,CAAC,0EA/LC3R,mBA6BM,YAAA,SA7B6BI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,kBACxC,MA2Ba2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAzBDuU,EAAO,CAChB,MAAO,WACP,QAAMvU,EAAA,QACN,MAAWA,EAAA,QACX,KAAAA,EAAA,WACA,YAAYA,EAAA,YACZ,cAAaA,EAAA,cACb,WAAWA,EAAA,WACX,YAAOA,EAAA,YAAA,UAAAA,EAAA,aAAA,YAAA,GAAA,EAEG,QAAMA,EAAA,KAAA,EAAA,CACf,OAAAqT,EAAA,QAAA,IAAA,CAAArT,EAAA,SAAAC,EAAAA,YAA0CC,EAAAA,YAAA0R,EAAA,CAAA,IAAA,EAC1C,QAAA5R,EAAA,OAAA,EAAA,KAAA,EAAA,CAAA,SAAA,CAAA,IAAAC,YAEgB,EAAAH,EAAA,mBAAA,MAAA,CACb,IAAK,EAAuB,MAAA,SAAqC,MAAA2O,EAAAA,eAAA,CAAc,MAAAzO,EAAA,gBAAmB,SAAAA,EAAA,SAAwB,MAAAA,EAAA,MAAA,WAAAA,EAAA,4LCjBxH,MAAAwU,GAAiBjU,uDAAsB,ECSvCkU,GAAyB,CACpC,GAAGjiB,EACH,MAAO,QACP,GAAI,GACJ,KAAM,MACN,IAAK,MACL,KAAM,MACN,QAAS,MACT,OAAQ,GACR,KAAM,YACN,MAAO,GACP,YAAa,OACf,EAGakiB,GAAsB9T,EAA0B6T,EAAU,EAE1DE,GAAc,CAAC,cAAe,WAAW,ECLtDC,GAAeriB,kBAAgB,CAC7B,KAAM,YACN,WAAY,CAAA,OACVsiB,EAAA,KACF,EACA,MAAO,CACL,GAAGH,EACL,EACA,MAAOliB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC4hB,EAAU1R,MAAY,EAAE,EAC9BjS,EAAAA,MAAM,IAAM+B,EAAM,MAAQyG,GAAkB,CAC1Cmb,EAAQ,MAAQnb,CAAA,EACf,CACD,UAAW,EAAA,CACZ,EACD,MAAMmJ,EAAK5P,EAAM,GACX,CAAE,eAAA+S,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEDkW,EAAe3c,EAAM,GAAc,CACjC,KAAMA,EAAM,KACZ,MAAO4hB,CAAA,CACR,EACD,MAAMU,EAAuB,IAAM,CAC3B,MAAAC,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQX,EAAS,CAAA,EAG5CvR,EAAYN,GAAa/P,CAAK,EAC9BwiB,EAAc9G,GAAAA,SAASrL,EAAU,cAAe,IAAM,CACrCiS,GAAA,CACtB,EAAG,GAAG,EACDG,EAAYpS,EAAU,YAAa,IAAM,CAAA,CAC9C,EACM,MAAA,CACL,MAAAgK,EACA,QAAAuH,EACA,UAAAa,EACA,YAAAD,CAAA,CAEJ,CACF,CAAC,yCAvECnV,mBAWM,SAAA,SATEI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,aAEX,MAME2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAJekV,EAAO,CAAA,MAAA,QACrB,MAAWlV,EAAA,QACX,iBAAQoO,EAAW,CAAA,IAAAA,EAAA,CAAA,EAAA+G,GAAAnV,EAAA,QAAAmV,GACnB,YAAMnV,EAAA,YAAA,SAAAA,EAAA,wFCRF,MAAAoV,GAAY7U,uBAAiB,ECY7B8U,GAAmC,CAC9C,GAAG7iB,EACH,OAAQ,OACR,MAAO,QACP,GAAI,GACJ,KAAM,MACN,IAAK,MACL,KAAM,QACN,QAAS,QACT,OAAQ,GACR,KAAM,iBACN,MAAO,GACP,OAAQ,OACR,OAAQ,aACR,SAAU,GACV,eAAgB,EAClB,EACa8iB,GAA2B1U,EAA0ByU,EAAe,EAEpEE,GAAmB,CAAC,YAAY,ECJ7CC,GAAejjB,kBAAgB,CAC7B,KAAM,iBACN,MAAO,CACL,GAAG+iB,EACL,EACA,WAAY,CAAA,YACVG,EAAA,UACF,EACA,MAAOjjB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCkjB,EAAoB,IAAM,SAAS,eAAe,gBAAgB,GAAK,SAAS,KAChFtB,EAAU1R,MAAkB,IAAI,EAChCjS,QAAA,IAAM,CAAC+B,EAAM,MAAOA,EAAM,cAAc,EAAG,CAAC,CAACyG,EAAO0c,CAAc,IAAyB,CAC/F,IAAI/R,EAAgB,KAChB3K,EACF2K,EAASwO,GAAMnZ,CAAK,EACX0c,IACT/R,EAASwO,GAAM,GAEjBgC,EAAQ,MAAQxQ,CAAA,EACf,CACD,UAAW,EAAA,CACZ,EACD,KAAM,CAAE,eAAAuL,CAAA,EAAmB9d,EAAA,OAAOmQ,EAAc,CAG9C,eAAgB,CAAC1P,EAAamH,IAAe,EAAA,CAC9C,EAEDkW,EAAe3c,EAAM,GAAc,CACjC,KAAMA,EAAM,KACZ,OAAQA,EAAM,OACd,MAAO4hB,CAAA,CACR,EAGK,MAAAwB,EADYrT,GAAa/P,CAAK,EACP,aAAc,IAAM,CAAA,CAChD,EAED,OAAA0P,GAAW1P,EAAO,CAChB,WAAAojB,CAAA,CACD,EACM,CACL,MAAA/I,EACA,kBAAA6I,EACA,QAAAtB,EACA,OAAAyB,GACA,WAAAD,CAAA,CAEJ,CACF,CAAC,yCA9EC/V,mBAgBM,eAAA,SAdEI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,mBAGb,MAUE2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eARA8V,EAAkB,CACV,MAAO,cAAA,kBAAA,4BACd,MAAM9V,EAAE,QACR,iBAAQoO,EAAM,CAAA,IAAAA,EAAA,CAAA,EAAA+G,GAAAnV,EAAA,QAAAmV,GACd,OAAQnV,EAAE,OACV,OAAQA,EAAA,OACR,SAAQA,EAAA,SACR,OAAAA,EAAA,OAAA,SAAAA,EAAA,6ICbM,MAAA+V,GAAiBxV,uBAAsB,ECsBvCyV,GAA2B,CACtC,GAAGxjB,EACH,KAAM,MACN,QAAS,MACT,MAAO,QACP,OAAQ,OACR,KAAM,aACN,KAAM,OACN,KAAM,CACJ,CAAE,MAAO,MAAO,MAAO,GAAI,EAC3B,CAAE,MAAO,MAAO,MAAO,GAAI,EAC3B,CAAE,MAAO,MAAO,MAAO,GAAI,CAC7B,EACA,MAAO,GACP,eAAgB,CAAE,MAAO,QAAS,MAAO,OAAQ,EACjD,YAAa,MACf,EAEayjB,GAAuBrV,EAA0BoV,EAAW,EAE5DE,GAAe,CAAC,cAAc,ECf3CC,GAAe5jB,kBAAgB,CAC7B,KAAM,aACN,WAAY,CAAA,QACV6jB,EAAA,MACF,EACA,MAAO,CACL,GAAGH,EACL,EACA,MAAOzjB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EAEnCkjB,EAAoB,IAAM,SAAS,eAAe,gBAAgB,GAAK,SAAS,KAChFjQ,EAAcZ,GAAerS,CAAK,EAClC,CAAE,SAAA8S,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EACK/G,EAAUkI,EAAAA,IAAIlQ,EAAM,IAAqB,EACzC4hB,EAAU1R,EAAI,IAAAlQ,EAAM,OAASA,EAAM,KAAK,CAAC,CAAC,EAC1CwQ,EAAiBxQ,EAAM,eACvB6jB,EAAe,CAACC,EAAehjB,IAAgB,CACnD,MAAMijB,EAAWvT,EAAe,MAC1BwT,EAAWxT,EAAe,MAC5B,IAAA/J,EAGE,MAAAwd,EAAanjB,EAAOijB,CAAQ,EAC5BG,EAAapjB,EAAOkjB,CAAQ,EAClC,OAAIC,GAAc,KACRxd,EAAAwd,EACCC,GAAc,OACfzd,EAAAyd,IAEAzd,GAAA,YAAAA,EAAO,cAAc,QAAQqd,GAAA,YAAAA,EAAO,iBAAkB,CAAA,EAE5DplB,EAAUwR,MAAI,EAAK,EACnB4O,EAAoB,SAAY,SACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UACxD,CAAApU,EAAQ,MAAQ,GACZ,GAAA,CACI,MAAAqV,EAAM,MAAMd,IAClBjL,EAAQ,QAAQsH,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,OAAQ,GACzC,MAAM6U,EAAcnlB,EAAA,MAAMgJ,CAAO,EAAE,CAAC,EAChChI,EAAM,QAAU,IAAMmkB,GAAe,OAC/BvC,EAAA,MAAQuC,EAAY3T,EAAe,KAAK,SAE3CpP,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,EAAA,EAEI,CAAE,eAAAqU,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEDkW,EAAe3c,EAAM,GAAc,CACjC,KAAMA,EAAM,KACZ,MAAO4hB,CAAA,CACR,EAGK,MAAAwC,EADYrU,GAAa/P,CAAK,EACL,eAAgB,IAAM,CACnD,MAAM4P,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQX,EAAS,CAAA,CACjD,EAEDlS,GAAW1P,EAAO,CAChB,aAAAokB,CAAA,CACD,EACD,KAAM,CAAE,WAAA9G,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EACU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW8e,EACX,QAAS9e,EAAM,WAAA,CAChB,EACM,CACL,MAAAqa,EACA,kBAAA6I,EACA,QAAAtB,EACA,aAAAwC,EACA,QAAApc,EACA,aAAA6b,EACA,QAAAnlB,CAAA,CAEJ,CACF,CAAC,+CA5HC2O,mBAiBM,UAAA,SAfEI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,cAEb,MAYE2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAVe6W,EAAO,CAAA,MAAA,SACrB,MAAO7W,EAAE,QACT,iBAAUoO,EAAA,CAAA,IAAAA,EAAA,CAAA,EAAA+G,GAAAnV,EAAA,QAAAmV,GACV,QAAAnV,EAAA,QACA,KAAAA,EAAA,KACA,kBAAaA,EAAA,kBACd,cAAWA,EAAA,eACV,YAAeA,EAAA,YACf,cAAQ,GACR,gBAASA,EAAO,aAAA,SAAAA,EAAA,4JCdV,MAAA8W,GAAavW,uDAAkB,ECW/BwW,GAAqC,CAChD,GAAGvkB,EACH,KAAM,QACN,QAAS,QACT,KAAM,kBACN,MAAO,QACP,OAAQ,OACR,OAAQ,OACR,OAAQ,aACR,UAAW,GACX,QAAS,GACT,eAAgB,GAChB,SAAU,EACV,aAAc,MAChB,EAEawkB,GAA4BpW,EAA0BmW,EAAgB,EAEtEE,GAAoB,CAAC,YAAY,ECH9CC,GAAe3kB,kBAAgB,CAC7B,KAAM,kBACN,WAAY,CAAA,aACV4kB,EAAA,WACF,EACA,MAAO,CACL,GAAGH,EACL,EACA,MAAOxkB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCkjB,EAAoB,IAAM,SAAS,eAAe,gBAAgB,GAAK,SAAS,KAChFtB,EAAU1R,EAAA,IAAoB,CAAC,KAAM,IAAI,CAAC,EAC1CjS,QAAA,IAAM,CAAC+B,EAAM,UAAWA,EAAM,QAASA,EAAM,eAAgBA,EAAM,SAAUA,EAAM,YAAY,EAAG,CAAC,CAAC4kB,EAAWC,EAAS1B,EAAgB2B,EAAUC,CAAY,IAAyD,CAC3N,IAAIC,EAAoB,KACpBC,EAAkB,KAClB9B,IACF6B,EAAapF,GAAM,EAAE,SAASkF,EAAUC,CAAY,EACpDE,EAAWrF,GAAM,GAEfgF,IACFI,EAAapF,GAAMgF,CAAS,GAE1BC,IACFI,EAAWrF,GAAMiF,CAAO,GAElBjD,EAAA,MAAQ,CAACoD,EAAYC,CAAQ,CAAA,EACpC,CACD,UAAW,EAAA,CACZ,EACD,KAAM,CAAE,eAAAtI,CAAA,EAAmB9d,EAAA,OAAOmQ,EAAc,CAG9C,eAAgB,CAAC1P,EAAamH,IAAe,EAAA,CAC9C,EACKye,EAAcnmB,EAAAA,SAAS,IAAMC,EAAAA,MAAM4iB,CAAO,EAAE,CAAC,CAAC,EAC9CuD,EAAYpmB,EAAAA,SAAS,IAAMC,EAAAA,MAAM4iB,CAAO,EAAE,CAAC,CAAC,EAElDjF,EAAe3c,EAAM,GAAc,CACjC,KAAMA,EAAM,KACZ,OAAQA,EAAM,OACd,UAAWklB,EACX,QAASC,CAAA,CACV,EAGK,MAAA/B,EADYrT,GAAa/P,CAAK,EACP,aAAc,IAAM,CAAA,CAAE,EACnD,OAAA0P,GAAW1P,EAAO,CAChB,WAAAojB,CAAA,CACD,EACM,CACL,MAAA/I,EACA,kBAAA6I,EACA,OAAAG,GACA,WAAAD,EACA,QAAAxB,CAAA,CAEJ,CACF,CAAC,+CApFCvU,mBAcM,gBAAA,SAZEI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,oBAEb,MASE2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAPA4X,EAAkB,CACV,MAAO,eAAA,kBAAA,6BACd,MAAM5X,EAAE,QACR,iBAAQoO,EAAM,CAAA,IAAAA,EAAA,CAAA,EAAA+G,GAAAnV,EAAA,QAAAmV,GACd,OAAQnV,EAAA,OACR,OAAAA,EAAA,OACA,OAAMA,EAAE,OAAA,kBAAAA,EAAA,yHCXF,MAAA6X,GAAkBtX,uDAAuB,ECezCuX,GAA2B,CACtC,GAAGtlB,EACH,MAAO,QACP,KAAM,KACN,QAAS,KACT,KAAM,aACN,KAAM,KACN,KAAM,UACN,OAAQ,GACR,MAAO,UACP,KAAM,GACN,OAAQ,OACR,SAAU,OACV,WAAY,GACd,EAGaulB,GAAuBnX,EAA0BkX,EAAW,EAE5DE,GAAe,CAAC,OAAO,ECJpCC,GAAe1lB,kBAAgB,CAC7B,KAAM,aACN,WAAY,CAAA,QACV2lB,EAAA,MACF,EACA,MAAO,CACL,GAAGH,EACL,EACA,MAAOvlB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EAInCgf,EAFYjP,GAAa/P,CAAK,EAEZ,QAAS,IAAM,CAE/B,MAAAgT,EAAMhU,QAAM2mB,CAAM,EACpB3S,GAAOhT,EAAM,SAAW,SAC1B,OAAO,OAAO,YAAY,CACxB,KAAM,WACN,IAAAgT,GACC,GAAG,CACR,CACD,EAEK4L,EAAS7f,EAAAA,SAAS,IAAM2S,GAAmB1R,EAAM,IAAc,CAAC,EAEhE2lB,EAAS5mB,EAAAA,SAAS,IAAM2S,GAAmB1R,EAAM,IAAc,GAAK,IAAI,EACxE4lB,EAAW7mB,EAAAA,SAAS,IAAM,CAC9B,MAAMsJ,EAASrI,EAAM,OACrB,GAAI,EAAAqI,IAAW,SAAWrJ,EAAM,MAAA2mB,CAAM,GAAK,MAOzC,MAJY,CACV,KAAM,QACN,MAAO,QAAA,EAEEtd,CAAM,CACnB,CACD,EACM,MAAA,CACL,MAAAgS,EACA,MAAA2E,EACA,OAAAJ,EACA,OAAA+G,EACA,SAAAC,CAAA,CAEJ,CACF,CAAC,yCA9ECvY,mBAsBM,UAAA,SApBEI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,cAEb,MAiBW2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAfDqY,EAAK,CACZ,MAAM,GACN,QAAQrY,EAAA,MACR,KAAKA,EAAE,KACP,OAAMA,EAAA,OACN,MAAMA,EAAE,MAAA,KAAAA,EAAA,2BAGD,QAAAqT,EAAA,QAAA,IAAA,CAAAiF,EAAAA,mBAAc,OAAQ,CAAY,MAAA7J,EAAAA,eAAA,CAAA,SAAAzO,EAAA,qICbnC,MAAAuY,GAAahY,uBAAkB,ECiB/BiY,GAA+B,CAC1C,GAAGhmB,EACH,MAAO,QACP,GAAI,GACJ,KAAM,MACN,IAAK,MACL,KAAM,MACN,QAAS,MACT,OAAQ,GACR,KAAM,eACN,MAAO,CAAC,EACR,KAAM,CACJ,CAAE,MAAO,MAAO,MAAO,IAAK,QAAS,EAAK,EAC1C,CAAE,MAAO,MAAO,MAAO,IAAK,QAAS,EAAK,EAC1C,CAAE,MAAO,MAAO,MAAO,GAAI,CAC7B,CACF,EAGaimB,GAAyB7X,EAA0B4X,EAAa,EAEhEE,GAAiB,CAAC,gBAAgB,ECtB/CC,GAAepmB,kBAAgB,CAC7B,KAAM,eACN,WAAY,CAAA,eACVqmB,EAAA,aACF,EACA,MAAO,CACL,GAAGH,EACL,EACA,MAAOjmB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCqmB,EAAWnW,MAAqB,CAAA,CAAE,EAClC0R,EAAU1R,MAAe,CAAA,CAAE,EAC3BoW,EAAuB/V,GAAS,CACpC,MAAM9J,EAAQzG,EAAM,MACpB,IAAIoR,EAAS,CAAA,EACRb,EAAA,QAASI,GAAS,CACjBA,EAAK,SACAS,EAAA,KAAKT,EAAK,KAAK,CACxB,CACD,EACG,OAAOlK,GAAU,UAAYA,IAAU,GACzC2K,EAASA,EAAO,OAAO3K,EAAM,MAAM,GAAG,CAAC,EAC9B,MAAM,QAAQA,CAAK,IACnB2K,EAAAA,EAAO,OAAO3K,CAAK,GAE9B4f,EAAS,MAAQ9V,EACjBqR,EAAQ,MAAQxQ,CAAA,EAEZnT,QAAA,IAAM,CAAC+B,EAAM,KAAMA,EAAM,KAAK,EAAG,CAAC,CAACuQ,CAAI,IAA6C,CACxF+V,EAAoB/V,CAAI,CAAA,EACvB,CACD,UAAW,GACX,KAAM,EAAA,CACP,EACK,MAAA0C,EAAcZ,GAAerS,CAAK,EAClC,CAAE,SAAA8S,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EACK+P,EAAoB,SAAY,SACpC,GAAI9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,SAAU,OAC5D,MAAAiB,EAAM,MAAMd,IACZ1C,IAAOjB,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,OAAQ,CAAA,EACtCgX,EAAoB/V,CAAI,CAAA,EAEpBX,EAAK5P,EAAM,GACX,CAAE,eAAA+S,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEDkW,EAAe3c,EAAM,GAAc,CACjC,KAAMA,EAAM,KACZ,MAAO4hB,CAAA,CACR,EAGK,MAAA2E,EADYxW,GAAa/P,CAAK,EACH,iBAAkB,IAAM,CACjD,MAAAuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQX,EAAS,CAAA,CACjD,EACK,CAAE,WAAAtE,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,CAAmC,IAAA,EAAA,CAChE,EACU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW8e,EACX,QAAS9e,EAAM,WAAA,CAChB,EACM,CACL,SAAAqmB,EACA,MAAAhM,EACA,QAAAuH,EACA,eAAA2E,CAAA,CAEJ,CACF,CAAC,yCAnGClZ,mBAMM,kBAAA,SAN2BI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,gBACtC,MAIE2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAFegZ,EAAO,CAAA,QAAAhZ,EAAA,SACrB,MAAQA,EAAA,QAAA,iBAAAoO,EAAA,CAAA,IAAAA,EAAA,CAAA,EAAA+G,GAAAnV,EAAA,QAAAmV,yECHF,MAAA8D,GAAe1Y,uBAAoB,ECuDnC2Y,GAAqB,CAChC,GAAG1mB,EACH,GAAI,GACJ,KAAM,KACN,QAAS,KACT,KAAM,UACN,MAAO,QACP,OAAQ,QACR,IAAK,GACL,KAAM,GACN,OAAQ,GACR,KAAM,CACJ,CAAE,KAAM,MAAO,MAAO,GAAI,EAC1B,CAAE,KAAM,MAAO,MAAO,GAAI,EAC1B,CAAE,KAAM,MAAO,MAAO,GAAI,CAC5B,EACA,UAAW,GACX,aAAc,GACd,UAAW,GACX,OAAQ,CAAC,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,SAAS,EAC1G,gBAAiB,GACjB,YAAa,GACb,sBAAuB,GACvB,eAAgB,OAChB,iBAAkB,4BAClB,WAAY,GACZ,qBAAsB,OACtB,aAAc,WACd,UAAW,MACX,WAAY,OACZ,YAAa,KACb,YAAa,MACb,WAAY,MACZ,UAAW,MACX,UAAW,GACX,WAAY,OACZ,iBAAkB,GAClB,cAAe,GACf,cAAe,UACf,eAAgB,aAChB,cAAe,GACf,gBAAiB,GACjB,iBAAkB,GAClB,SAAU,GACV,wBAAyB,CAAE,KAAM,OAAQ,MAAO,QAAS,KAAM,MAAO,EACtE,oBAAqB,QACrB,iBAAkB,GAClB,QAAS,MACT,WAAY,MACZ,SAAU,KACV,UAAW,KACX,cAAe,CAAC,EAChB,YAAa,GACb,cAAe,aACf,gBAAiB,GACjB,eAAgB,EAChB,YAAa,QACb,WAAY,MACZ,4BAA6B,OAC7B,mBAAoB,GACpB,gBAAiB,SACnB,EAEa2mB,GAAoBvY,EAA0BsY,EAAQ,EAEtDE,GAA2B,CAAC,QAAS,cAAe,aAAa,ECzHjEC,GAAkB,MAAOC,GAA4B,OAChE,MAAM/S,EAAM,MAAMkB,GAAQ,KAAK6R,EAAiB,CAAA,EAAI,CAClD,aAAc,MAAA,CACf,EACK,CAAE,KAAAvW,EAAM,QAAAkC,CAAY,EAAAsB,EACpBgT,EAAWtU,EAAQ,qBAAqB,EAAE,QAAQ,oBAAqB,IAAI,EAC3EuU,EAAO,IAAI,KAAK,CAACzW,CAAI,CAAC,EACtB0W,EAAM,SAAS,cAAc,GAAG,EAChCjU,EAAM,OAAO,IAAI,gBAAgBgU,CAAI,EAC3CC,EAAI,KAAOjU,EACPiU,EAAA,SAAW,UAAUF,CAAQ,EACjCE,EAAI,MAAM,QAAU,OACX,SAAA,KAAK,YAAYA,CAAG,EAC7BA,EAAI,MAAM,GACN5X,EAAA4X,EAAA,aAAA,MAAA5X,EAAY,YAAY4X,GACrB,OAAA,IAAI,gBAAgBjU,CAAG,CAChC,ECkCAkU,GAAAA,IAAI,CACFC,GAAA,eACAC,GAAA,SACAC,EAAA,eACAC,EAAA,iBACAC,EAAA,iBACAC,EAAA,eACF,CAAC,EACD,MAAAC,GAAe1nB,kBAAgB,CAC7B,KAAM,UACN,MAAO,CACL,GAAG4mB,EACL,EACA,WAAY,CACV,KAAAe,GACA,QAAA5nB,GAAA,OACA6nB,EAAA,KACF,EACA,MAAO3nB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC+Q,EAAUb,MAA8B,CAAA,CAAE,EAC1C0X,EAAU1X,MAAI,EAAK,EACnB2X,EAAY,IAAM,CACtBD,EAAQ,MAAQ,EAAA,EAEZ9mB,EAAS/B,EAAAA,SAAS,IAAM,CACxB,GAAA,CAAE,KAAAwR,EAAO,CAAA,GAAOvR,EAAAA,MAAM+R,CAAO,EAAE,CAAC,GAAK,GACzC,GAAI,MAAM,QAAQ/Q,EAAM,MAAM,EAAG,CAC/B,MAAM8nB,EAAmB9nB,EAAM,iBACzB2K,EAAS3K,EAAM,OACrBuQ,EAAOA,EAAK,IAAI,CAACI,EAAMxJ,KAAW,CAChC,MAAO2gB,EAAmB,CAAE,MAAOnd,EAAOxD,CAAK,CAAA,EAAM,CAAC,EACtD,GAAGwJ,CACH,EAAA,CACJ,CACO,MAAA,CACL,QAAS,CACP,KAAM3Q,EAAM,YACZ,KAAMA,EAAM,YACZ,IAAKA,EAAM,WACX,SAAUA,EAAM,gBAChB,QAASA,EAAM,eACf,QAAS,CACP,WAAY,CACV,KAAM,GACN,MAAO,OACP,KAAM,ivCACN,SAAW,CACT6mB,GAAgB7mB,EAAM,kBAA4B,CACpD,CACF,EACA,WAAY,CACV,KAAM,GACN,MAAO,KACP,KAAM,8yBACN,SAAW,CACT4nB,EAAQ,MAAQ,EAClB,CACF,EACA,OAAQ,CACN,KAAM,GACN,MAAO,OACP,KAAM,glCACN,SAAW,CACTD,EAAAA,MAAO,KAAK,CACV,MAAO,OACP,QAAU3nB,EAAM,eAAA,CACjB,CACH,CACF,CACF,CACF,EACA,MAAO,CACL,KAAMA,EAAM,UACZ,QAASA,EAAM,aACf,KAAM,QACR,EACA,KAAM,CACJ,IAAKA,EAAM,QACX,OAAQA,EAAM,WACd,KAAMA,EAAM,SACZ,MAAOA,EAAM,UACb,aAAcA,EAAM,gBACtB,EAEA,QAAS,CACP,KAAMA,EAAM,YACZ,QAASA,EAAM,eACf,UAAYkT,GAAW,CACf,KAAA,CAAE,OAAA6U,EAAQ,WAAAC,EAAY,KAAAvqB,EAAM,MAAAgJ,EAAO,QAAAwhB,EAAS,KAAA1X,CAAAA,EAAS2C,GAAU,GAC9D,OAAAxB,GACL1R,EAAM,iBACN,CACE,OAAA+nB,EACA,KAAAtqB,EACA,MAAAgJ,EACA,QAAAwhB,EACA,EAAGD,EACH,EAAGvqB,EACH,EAAGgJ,EACH,EAAGwhB,EACH,GAAG1X,CACL,EACA,CACE,WAAY,GACZ,SAAU,EACZ,CAAA,CAEJ,EACA,UAAW,CACT,MAAOvQ,EAAM,qBACf,CACF,EAEA,OAAQ,CACN,KAAMA,EAAM,WACZ,OAAQA,EAAM,aACd,IAAKA,EAAM,UACX,KAAMA,EAAM,WACZ,UAAW,CACT,MAAOA,EAAM,oBACf,CACF,EACA,MAAOA,EAAM,OACb,OAAQ,CACN,CACE,KAAAuQ,EACA,KAAM,MACN,OAAQ,CAACvQ,EAAM,YAAaA,EAAM,WAAW,EAC7C,OAAQ,CAACA,EAAM,WAAYA,EAAM,SAAS,EAC1C,SAAUA,EAAM,SAChB,kBAAmB,GAInB,MAAO,CACL,KAAMA,EAAM,gBAAkB,UAAYA,EAAM,UAChD,MAAOA,EAAM,WACb,SAAUA,EAAM,cAChB,SAAUA,EAAM,cAChB,UAAWgR,GAAgBhR,EAAM,cAAwB,CAC3D,EACA,UAAW,CACT,KAAMA,EAAM,cACZ,OAAQA,EAAM,gBACd,QAASA,EAAM,gBACjB,EACA,SAAU,CACR,UAAW,CACT,WAAY,GACZ,cAAe,EACf,YAAa,oBACf,EACA,MAAO,CAEP,CACF,CACF,CACF,CAAA,CACF,CACD,EAEK,CAAE,eAAA+S,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEK,CAAE,SAAAqM,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAEKmZ,EAAgB,CAAC3X,EAAY,CAAA,EAAIC,IAA6C,CAClF,KAAM,CAAE,QAASjN,CAAA,EAAM+M,GAAiCC,EAAMC,CAAc,EAC5EO,EAAQ,MAAQxN,CAAA,EAGZ4kB,EAAyB,CAAC5X,EAAY,CAAA,EAAIC,IAA6C,CACrF,MAAA4X,EAAY9X,GAAiCC,EAAMC,CAAc,EACvEO,EAAQ,MAAQqX,EAAU,OAAA,EAI5BnqB,EAAAA,MAAM,IAAM+B,EAAM,KAAOyG,GAAe,EAClCzG,EAAM,WAAa,UAAYhB,EAAAA,MAAM8T,CAAQ,IAAM,WACrDoV,EAAczhB,CAAK,CACrB,EACC,CACD,UAAW,GACX,KAAM,EAAA,CACP,EAEK,MAAA/H,EAAUwR,MAAI,EAAK,EACnB+C,EAAcZ,GAAerS,CAAK,EAElC8e,EAAoB,SAAY,SACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UACpD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClBiV,GAAc5Y,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,KAAMtP,EAAM,uBAAkD,QACtFoB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAKIsgB,EAFYjP,GAAa/P,CAAK,EAEZ,QAAUoB,GAAM,CACtC,MAAMwO,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQnhB,GAAA,YAAAA,EAAG,KAAM,CAAA,CACjD,EAGKinB,EAAiBhT,GAAsBrV,CAAK,EAC5CsoB,EAAsB,SAAY,iBACtC,GAAI,EAAAtoB,EAAM,WAAa,aAAehB,EAAAA,MAAM8T,CAAQ,IAAM,UACtD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMsU,IAClB,IAAIE,EAAS,CAAA,EACb,KAAI/Y,GAAAF,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,UAAjB,YAAAE,EAA0B,QAAS,EAAG,CACxC,MAAM/R,EAAOsW,EAAI,KAAK,KAAK,QAAQ,CAAC,EAC9BtN,EAAQsN,EAAI,KAAK,KAAK,QAAQ,CAAC,EACrCwU,GAASC,GAAA5c,GAAAF,EAAAqI,GAAA,YAAAA,EAAK,OAAL,YAAArI,EAAW,OAAX,YAAAE,EAAiB,OAAjB,YAAA4c,EAAuB,IAAY7X,IACnC,CACL,KAAMA,EAAKlT,CAAI,EACf,MAAOkT,EAAKlK,CAAK,CAAA,GAGvB,CACA0hB,EAAuBI,CAAM,QACtBnnB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAGI+pB,EAAyB,IAAM,CAC/BzpB,EAAA,MAAM8T,CAAQ,IAAM,WACJwV,IACFxJ,IAAA,EAapBpP,GAAW1P,EAAO,CAChB,YAPkB,IAAM,CACxB,MAAM4P,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAC/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQ,GAAI,CAAA,EAK3C,YAZkB,IAAM,CACDkG,GAAA,EAYvB,MAAAzJ,CAAA,CACD,EAED,KAAM,CAAE,WAAA1B,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EACU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAWyoB,EACX,QAASzoB,EAAM,WAAA,CAChB,EACM,CACL,OAAAc,EACA,MAAAuZ,EACA,MAAA2E,EACA,QAAAtgB,EACA,QAAAkpB,EACA,UAAAC,CAAA,CAEJ,CACF,CAAC,sGAjVCxa,mBAuBM,SAAA,mDAtBJ,MAAA4O,EAAAA,eAMOzO,EANA,KAAA,CAAA,EAAA,eACLkb,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CACLhU,EAAAA,YAAA8b,EAAA,CACT,OAAKnb,EAAE,OAAA,WAAA,mDAGZ,EAAA,CAAA,EACE,EAAA,CAAA,UAAA,CAAA,EAAAX,EAAAA,YACM+b,EAAM,CACX,kBAAS,aACT,MAAM,OACN,QAAMpb,EAAE,QAAA,OAAA,4BAOL,QAAAqT,EAAA,QAAA,IAAA,CAAAhU,EAAAA,YAJF6b,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OAAA,iBAAA,CAAA,SAAA,EAAA,gGClBG,MAAAqb,GAAU9a,uBAAe,ECsDzB+a,GAAuB,CAClC,GAAG9oB,EACH,GAAI,GACJ,KAAM,MACN,QAAS,MACT,KAAM,WACN,MAAO,QACP,OAAQ,QACR,IAAK,GACL,KAAM,GACN,OAAQ,GACR,KAAM,CACJ,CAAE,KAAM,MAAO,MAAO,IAAK,KAAM,KAAM,EACvC,CAAE,KAAM,MAAO,MAAO,IAAK,KAAM,KAAM,EACvC,CAAE,KAAM,MAAO,MAAO,IAAK,KAAM,KAAM,EACvC,CAAE,KAAM,MAAO,MAAO,IAAK,KAAM,KAAM,CACzC,EACA,UAAW,GACX,aAAc,GACd,UAAW,GACX,WAAY,GACZ,aAAc,aACd,UAAW,MACX,WAAY,SACZ,OAAQ,CAAC,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,SAAS,EAC1G,WAAY,EACZ,eAAgB,EAChB,OAAQ,GACR,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,cAAe,GACf,oBAAqB,UACrB,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,oBAAqB,UACrB,iBAAkB,GAClB,QAAS,MACT,WAAY,MACZ,SAAU,KACV,UAAW,KACX,wBAAyB,CAAE,KAAM,OAAQ,MAAO,QAAS,KAAM,MAAO,EACtE,sBAAuB,CAAE,KAAM,OAAQ,MAAO,CAAA,CAAG,EACjD,oBAAqB,QACrB,cAAe,CAAC,EAChB,YAAa,GACb,iBAAkB,sBAClB,YAAa,GACb,cAAe,aACf,gBAAiB,GACjB,eAAgB,EAChB,YAAa,QACb,WAAY,MACZ,4BAA6B,OAC7B,mBAAoB,GACpB,gBAAiB,UACjB,iBAAkB,CACpB,EAGa+oB,GAAqB3a,EAA0B0a,EAAS,EAExDE,GAAa,CAAC,QAAS,cAAe,aAAa,ECxEhE9B,GAAAA,IAAI,CACFC,GAAA,eACA8B,GAAA,UACA3B,EAAA,iBACAD,EAAA,eACAG,EAAA,eACF,CAAC,EACD,MAAA0B,GAAenpB,kBAAgB,CAC7B,KAAM,WACN,MAAO,CACL,GAAGgpB,EACL,EACA,WAAY,CACV,KAAArB,GACA,QAAA5nB,GAAA,OACA6nB,EAAA,KACF,EACA,MAAO3nB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCsX,EAASpH,MAA8B,CAAA,CAAE,EACzCY,EAAaZ,MAA8B,CAAA,CAAE,EAC7C0X,EAAU1X,MAAI,EAAK,EACnB2X,EAAY,IAAM,CACtBD,EAAQ,MAAQ,EAAA,EAEZ9mB,EAAS/B,EAAAA,SAAS,IAAM,CAG5B,MAAMoqB,EAAsBnpB,EAAM,oBAC5BopB,EAAsBppB,EAAM,oBAC3B,MAAA,CACL,QAAS,CACP,KAAMA,EAAM,YACZ,KAAMA,EAAM,YACZ,IAAKA,EAAM,WACX,SAAUA,EAAM,gBAChB,QAASA,EAAM,eACf,QAAS,CACP,WAAY,CACV,KAAM,GACN,MAAO,OACP,KAAM,ivCACN,SAAW,CACT6mB,GAAgB7mB,EAAM,kBAA4B,CACpD,CACF,EACA,WAAY,CACV,KAAM,GACN,MAAO,KACP,KAAM,8yBACN,SAAW,CACT4nB,EAAQ,MAAQ,EAClB,CACF,EACA,OAAQ,CACN,KAAM,GACN,MAAO,OACP,KAAM,glCACN,SAAW,CACTD,EAAAA,MAAO,KAAK,CACV,MAAO,OACP,QAAU3nB,EAAM,eAAA,CACjB,CACH,CACF,CACF,CACF,EACA,MAAO,CACL,KAAMA,EAAM,UACZ,QAASA,EAAM,aACf,KAAM,QACR,EACA,KAAM,CACJ,IAAKA,EAAM,QACX,OAAQA,EAAM,WACd,KAAMA,EAAM,SACZ,MAAOA,EAAM,UACb,aAAcA,EAAM,gBACtB,EACA,MAAOA,EAAM,OACb,QAAS,CACP,QAAS,OACT,KAAMA,EAAM,YACZ,UAAYkT,GAAW,CACrB,MAAM5H,EAAM4H,EAAO,OACnB,IAAIjC,EAAY,GACZoY,EAAmBrpB,EAAM,iBACzBqpB,IAAqB,KACJA,EAAA,uBAErB,QAAS5lB,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,KAAA,CAAE,OAAAskB,EAAQ,WAAAC,EAAY,KAAAvqB,EAAM,MAAAgJ,EAAO,KAAA8J,GAAS2C,EAAOzP,CAAC,GAAK,GAC3DA,IAAM,IACRwN,GAAa,GAAGxT,UAELwT,GAAAS,GACX2X,EACA,CACE,OAAAtB,EACA,KAAAtqB,EACA,MAAAgJ,EACA,EAAGuhB,EACH,EAAGvqB,EACH,EAAGgJ,EACH,GAAG8J,CACL,EACA,CACE,WAAY,GACZ,SAAU,EACZ,CAAA,EACWU,GAAA,OACf,CACO,OAAAA,CACT,CACF,EACA,MAAO,CACL,KAAM,WACN,KAAMjS,QAAM8R,CAAU,EACtB,UAAW,CACT,KAAM9Q,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,UAAWyG,EAAe,CACjB,OAAAqR,GAAkBqR,EAAqB1iB,CAAK,CACrD,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,EACA,SAAU,CACR,KAAMA,EAAM,aACd,CACF,EACA,MAAO,CACL,KAAM,QACN,UAAW,CACT,KAAMA,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,UAAWyG,EAAe,CACjB,OAAAqR,GAAkBsR,EAAqB3iB,CAAK,CACrD,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,CACF,EAEA,OAAQ,CACN,KAAMA,EAAM,WACZ,OAAQA,EAAM,aACd,IAAKA,EAAM,UACX,KAAMA,EAAM,UACd,EACA,OAAQhB,QAAMsY,CAAM,CAAA,CACtB,CACD,EAEK,CAAE,eAAAvE,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEK,CAAE,SAAAqM,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAEKmZ,EAAgB,CAAC3X,EAAY,CAAA,EAAI+Y,EAA6B,KAAU,CAExE,IAAAlB,EACA,GAAApoB,EAAM,sBAAwB,MAAO,CACjC,MAAAwQ,EAAiB8Y,EAAoBtpB,EAAM,sBAAiD,KACtFooB,EAAAlU,GAA+B3D,EAAMC,CAAc,CAAA,SACtDxQ,EAAM,sBAAwB,QAAS,CAC1C,MAAAwQ,EAAiB8Y,EAAoBtpB,EAAM,wBAAqD,KAC1FooB,EAAA9X,GAAiCC,EAAMC,CAAc,CACnE,CACAM,EAAW,MAAQsX,EAAU,WAC7B,MAAMrX,EAAUqX,EAAU,QACpBmB,EAAO,CAAA,EACPje,EAAMyF,EAAQ,OACpB,QAAStN,EAAI,EAAGA,EAAI6H,EAAK7H,IACvB8lB,EAAK,KAAK,CACR,KAAM,OACN,GAAGxY,EAAQtN,CAAC,EACZ,WAAYzD,EAAM,WAClB,OAAQA,EAAM,OACd,UAAW,CAcT,QAASA,EAAM,gBACjB,EACA,UAAW,CACT,MAAOA,EAAM,cACf,CAAA,CACD,EAEHsX,EAAO,MAAQiS,CAAA,EAGXpB,EAAyB,CAAC5X,EAAY,CAAI,EAAAiZ,EAA8CF,EAA6B,KAAU,CAE7H,MAAAlB,EAAYlU,GAA+B3D,EAD1B+Y,EAAoBE,EAAwB,IACE,EACrE1Y,EAAW,MAAQsX,EAAU,WAC7B,MAAMrX,EAAUqX,EAAU,QACpBmB,EAAO,CAAA,EACPje,EAAMyF,EAAQ,OACpB,QAAStN,EAAI,EAAGA,EAAI6H,EAAK7H,IACvB8lB,EAAK,KAAK,CACR,KAAM,OACN,GAAGxY,EAAQtN,CAAC,EACZ,WAAYzD,EAAM,WAClB,OAAQA,EAAM,OACd,UAAW,CACT,MAAOA,EAAM,cACf,CAAA,CACD,EAEHsX,EAAO,MAAQiS,CAAA,EAIjBtrB,EAAA,MAAM,IAAM,CAAC+B,EAAM,KAAMA,EAAM,WAAYA,EAAM,OAAQA,EAAM,eAAgBA,EAAM,gBAAgB,EAAG,CAAC,CAACuQ,CAAI,IAAM,EAC9GvQ,EAAM,WAAa,UAAYhB,EAAAA,MAAM8T,CAAQ,IAAM,WACrDoV,EAAc3X,CAAgC,CAChD,EACC,CACD,UAAW,GACX,KAAM,EAAA,CACP,EAEK,MAAA7R,EAAUwR,MAAI,EAAK,EACnB+C,EAAcZ,GAAerS,CAAK,EAElC8e,EAAoB,SAAY,SACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UACpD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClBiV,GAAc5Y,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,KAAM,EAAI,QAClClO,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAKIsgB,EAFYjP,GAAa/P,CAAK,EAEZ,QAAUoB,GAAM,CAEtC,MAAMwO,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQnhB,GAAA,YAAAA,EAAG,KAAM,CAAA,CACjD,EAGKinB,EAAiBhT,GAAsBrV,CAAK,EAC5CsoB,EAAsB,SAAY,eACtC,GAAI,EAAAtoB,EAAM,WAAa,aAAehB,EAAAA,MAAM8T,CAAQ,IAAM,UACtD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMsU,IACd,IAAAhmB,IACAmN,GAAAF,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,UAAjB,YAAAE,EAA0B,QAAS,IACjCnN,EAAA,CACF,KAAM0R,EAAI,KAAK,KAAK,QAAQ,CAAC,EAC7B,MAAOA,EAAI,KAAK,KAAK,QAAQ,MAAM,CAAC,EAAE,IAAU8B,IACvC,CAAE,MAAOA,EAAI,MAAOA,CAAG,EAC/B,CAAA,GAGLsS,GAAuBvc,GAAAF,EAAAqI,GAAA,YAAAA,EAAK,OAAL,YAAArI,EAAW,OAAX,YAAAE,EAAiB,KAAMvJ,EAAG,EAAI,QAC9CjB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAGI+pB,EAAyB,IAAM,CAC/BzpB,EAAA,MAAM8T,CAAQ,IAAM,WACJwV,IACFxJ,IAAA,EAapBpP,GAAW1P,EAAO,CAChB,YAXkB,IAAM,CACDyoB,GAAA,EAWvB,YARkB,IAAM,CACxB,MAAM7Y,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAC/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQ,GAAI,CAAA,EAM3C,MAAAvD,CAAA,CACD,EAED,KAAM,CAAE,WAAA1B,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EAEU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAWyoB,EACX,QAASzoB,EAAM,WAAA,CAChB,EAEM,CACL,OAAAc,EACA,MAAAuZ,EACA,MAAA2E,EACA,QAAAtgB,EACA,QAAAkpB,EACA,UAAAC,CAAA,CAEJ,CACF,CAAC,sGA/YCxa,mBAuBM,SAAA,mDAtBJ,MAAA4O,EAAAA,eAMOzO,EANA,KAAA,CAAA,EAAA,eACLkb,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CACLhU,EAAAA,YAAA8b,EAAA,CACT,OAAKnb,EAAE,OAAA,WAAA,mDAGZ,EAAA,CAAA,EACE,EAAA,CAAA,UAAA,CAAA,EAAAX,EAAAA,YACM+b,EAAM,CACX,kBAAS,aACT,MAAM,OACN,QAAMpb,EAAE,QAAA,OAAA,4BAOL,QAAAqT,EAAA,QAAA,IAAA,CAAAhU,EAAAA,YAJF6b,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OAAA,iBAAA,CAAA,SAAA,EAAA,gGClBG,MAAAic,GAAW1b,uBAAgB,ECgF3B2b,GAAqB,CAChC,GAAG1pB,EACH,GAAI,GACJ,KAAM,MACN,QAAS,MACT,KAAM,UACN,MAAO,QACP,OAAQ,QACR,IAAK,GACL,KAAM,GACN,OAAQ,GACR,oBAAqB,UACrB,oBAAqB,UACrB,KAAM,CACJ,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,CACF,EACA,UAAW,GACX,aAAc,GACd,OAAQ,CAAC,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,SAAS,EAC1G,WAAY,GACZ,qBAAsB,OACtB,aAAc,aACd,UAAW,MACX,WAAY,SACZ,YAAa,GACb,sBAAuB,GACvB,iBAAkB,sBAClB,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,gBAAiB,OACjB,iBAAkB,EAClB,mBAAoB,OACpB,oBAAqB,OACrB,cAAe,GACf,gBAAiB,OACjB,iBAAkB,EAClB,mBAAoB,OACpB,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,wBAAyB,CAAE,KAAM,OAAQ,MAAO,QAAS,KAAM,MAAO,EACtE,sBAAuB,CAAE,KAAM,OAAQ,MAAO,CAAA,CAAG,EACjD,oBAAqB,QACrB,SAAU,MACV,iBAAkB,GAClB,QAAS,MACT,WAAY,MACZ,SAAU,KACV,UAAW,KACX,cAAe,CACb,UAAW,MACX,OAAQ,IACR,MAAO,GACT,EACA,YAAa,GACb,cAAe,aACf,gBAAiB,GACjB,eAAgB,EAChB,YAAa,QACb,WAAY,MACZ,4BAA6B,OAC7B,mBAAoB,GACpB,gBAAiB,UACjB,oBAAqB,GACrB,YAAa,GACb,aAAc,GACd,aAAc,GACd,QAAS,GACT,UAAW,GACX,cAAe,OACf,cAAe,SACf,WAAY,EACd,EAGa2pB,GAAoBvb,EAA0Bsb,EAAQ,EAEtDE,GAAuB,CAAC,cAAe,QAAS,aAAa,ECrH1E1C,GAAAA,IAAI,CACFC,GAAA,eACA0C,GAAA,SACAxC,EAAA,eACAG,EAAA,gBACAsC,EAAA,iBACAxC,EAAA,gBACF,CAAC,EACD,MAAAyC,GAAehqB,kBAAgB,CAC7B,KAAM,UACN,MAAO,CACL,GAAG4pB,EACL,EACA,WAAY,CACV,KAAAjC,GACA,QAAA5nB,GAAA,OACA6nB,EAAA,KACF,EACA,MAAO3nB,EAAO,CAAE,OAAAsc,GAAU,CAClB,MAAAjC,EAAQ5L,EAAsBzO,CAAK,EACnCqgB,EAAanQ,MAA8B,CAAA,CAAE,EAC7C0X,EAAU1X,MAAI,EAAK,EACnB2X,EAAY,IAAM,CACtBD,EAAQ,MAAQ,EAAA,EAEZtQ,EAASvY,EAAAA,SAAS,IAAM,CACtB,MAAAirB,EAAKhrB,QAAMqhB,CAAU,EACrB/U,EAAM0e,EAAG,OACT1S,EAAS,CAAA,EACf,QAAS7T,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CAC5B,MAAMkN,EAAO,CACX,GAAGqZ,EAAGvmB,CAAC,EACP,KAAM,MACN,SAAUzD,EAAM,QAAA,EAEdA,EAAM,UACR2Q,EAAK,MAAQ,SAEfA,EAAK,MAAQ,CACX,KAAM3Q,EAAM,UACZ,SAAUA,EAAM,cAChB,SAAUA,EAAM,cAChB,MAAOA,EAAM,UAAA,EAEfsX,EAAO,KAAK3G,CAAI,CAClB,CACO2G,OAAAA,CAAA,CACR,EACKxG,EAAaZ,MAA8B,CAAA,CAAE,EAC7CxR,EAAUwR,MAAI,EAAK,EACnBpP,EAAS/B,EAAAA,SAAS,IAAM,CAG5B,MAAMqqB,EAAsBppB,EAAM,oBAC5BmpB,EAAsBnpB,EAAM,oBAC3B,MAAA,CACL,QAAS,CACP,KAAMA,EAAM,YACZ,KAAMA,EAAM,YACZ,IAAKA,EAAM,WACX,SAAUA,EAAM,gBAChB,QAASA,EAAM,eACf,QAAS,CACP,WAAY,CACV,KAAM,GACN,MAAO,OACP,KAAM,ivCACN,SAAW,CACT6mB,GAAgB7mB,EAAM,kBAA4B,CACpD,CACF,EACA,WAAY,CACV,KAAM,GACN,MAAO,KACP,KAAM,8yBACN,SAAW,CACT4nB,EAAQ,MAAQ,EAClB,CACF,EACA,OAAQ,CACN,KAAM,GACN,MAAO,OACP,KAAM,glCACN,SAAW,CACTD,EAAAA,MAAO,KAAK,CACV,MAAO,OACP,QAAU3nB,EAAM,eAAA,CACjB,CACH,CACF,CACF,CACF,EACA,MAAO,CACL,KAAMA,EAAM,UACZ,QAASA,EAAM,aACf,KAAM,QACR,EACA,KAAM,CACJ,IAAKA,EAAM,QACX,OAAQA,EAAM,WACd,KAAMA,EAAM,SACZ,MAAOA,EAAM,UACb,aAAcA,EAAM,gBACtB,EACA,MAAOA,EAAM,OACb,QAAS,CACP,QAAS,OACT,KAAMA,EAAM,YACZ,UAAYkT,GAAW,CACrB,MAAM5H,EAAM4H,EAAO,OACnB,IAAIjC,EAAY,GACZoY,EAAmBrpB,EAAM,iBACzBqpB,IAAqB,KACJA,EAAA,uBAErB,QAAS5lB,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,KAAA,CAAE,OAAAskB,EAAQ,WAAAC,EAAY,KAAAvqB,EAAM,MAAAgJ,EAAO,KAAA8J,GAAS2C,EAAOzP,CAAC,GAAK,GAC3DA,IAAM,IACRwN,GAAa,GAAGxT,UAELwT,GAAAS,GACX2X,EACA,CACE,OAAAtB,EACA,KAAAtqB,EACA,MAAAgJ,EACA,EAAGuhB,EACH,EAAGvqB,EACH,EAAGgJ,EACH,GAAG8J,CACL,EACA,CACE,WAAY,GACZ,SAAU,EACZ,CAAA,EACWU,GAAA,OACf,CACO,OAAAA,CACT,EAIA,UAAW,CACT,MAAOjR,EAAM,qBACf,CACF,EACA,OAAQ,CACN,KAAMA,EAAM,WACZ,OAAQA,EAAM,aACd,IAAKA,EAAM,UACX,KAAMA,EAAM,WACZ,UAAW,CACT,MAAOA,EAAM,oBACf,CACF,EACA,MAAO,CACL,KAAMA,EAAM,oBAAsB,QAAU,WAC5C,KAAMA,EAAM,oBAAsB,KAAOhB,EAAAA,MAAM8R,CAAU,EACzD,QAAS9Q,EAAM,oBAAsBA,EAAM,aAAeA,EAAM,YAChE,UAAW,CACT,KAAMA,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,SAAU,EACV,OAAQA,EAAM,iBACd,MAAOA,EAAM,gBACb,SAAUA,EAAM,mBAChB,UAAWyG,EAAe,CACjB,OAAAqR,GAAkBqR,EAAqB1iB,CAAK,CACrD,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,EACA,SAAU,CACR,KAAMA,EAAM,aACd,CACF,EACA,MAAO,CACL,KAAMA,EAAM,oBAAsB,WAAa,QAC/C,KAAMA,EAAM,oBAAsBhB,EAAAA,MAAM8R,CAAU,EAAI,KACtD,QAAS9Q,EAAM,oBAAsBA,EAAM,YAAcA,EAAM,aAC/D,UAAW,CACT,KAAMA,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,OAAQA,EAAM,iBACd,MAAOA,EAAM,gBACb,SAAUA,EAAM,mBAChB,UAAWyG,EAAe,CACjB,OAAAqR,GAAkBsR,EAAqB3iB,CAAK,CACrD,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,CACF,EACA,OAAQhB,QAAMsY,CAAM,CAAA,CACtB,CACD,EACK,CAAE,SAAAxE,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAEKmZ,EAAgB,CAAC3X,EAAa,CAAA,EAAI+Y,EAA6B,KAAU,CAC7E,IAAIlB,EAAY,CAAA,EACZ,GAAApoB,EAAM,sBAAwB,MAAO,CACjC,MAAAwQ,EAAiB8Y,EAAoBtpB,EAAM,sBAAiD,KACtFooB,EAAAlU,GAA+B3D,EAAMC,CAAc,CAAA,SACtDxQ,EAAM,sBAAwB,QAAS,CAC1C,MAAAwQ,EAAiB8Y,EAAoBtpB,EAAM,wBAAqD,KAC1FooB,EAAA9X,GAAiCC,EAAMC,CAAc,CACnE,CACA6P,EAAW,MAAQ+H,EAAU,QAC7BtX,EAAW,MAAQsX,EAAU,UAAA,EAGzBD,EAAyB,CAAC5X,EAAY,CAAI,EAAAiZ,EAA8CF,EAA6B,KAAU,CAE7H,MAAAlB,EAAYlU,GAA+B3D,EAD1B+Y,EAAoBE,EAAwB,IACE,EACrEnJ,EAAW,MAAQ+H,EAAU,QAC7BtX,EAAW,MAAQsX,EAAU,UAAA,EAI/BnqB,EAAAA,MAAM,IAAM+B,EAAM,KAAOyG,GAAe,EAClCzG,EAAM,WAAa,UAAYhB,EAAAA,MAAM8T,CAAQ,IAAM,WACrDoV,EAAczhB,CAAK,CACrB,EACC,CACD,UAAW,GACX,KAAM,EAAA,CACP,EAEK,MAAAwM,EAAcZ,GAAerS,CAAK,EAElC8e,EAAoB,SAAY,SAChC,GAAA,CACFpgB,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClBiV,GAAc5Y,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,KAAM,EAAI,QAClClO,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAIIurB,EAAgBlS,GAAiB/X,CAAK,EACtCsoB,EAAsB,SAAY,OAClC,GAAA,CACF5pB,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMkW,IACZ,CAAE,QAAAC,EAAU,CAAI,EAAA,KAAAC,EAAO,CAAA,CAAO,IAAA9a,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAQ,GACnD,IAAA+a,EACAF,EAAQ,OAAS,IACNE,EAAA,CACX,KAAMF,EAAQ,CAAC,EACf,MAAOA,EAAQ,MAAM,CAAC,EAAE,IAAchJ,IAC7B,CACL,MAAOA,EACP,MAAOA,CAAA,EAEV,CAAA,GAGkBiH,EAAAgC,EAAMC,EAAY,EAAI,QACtChpB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAGIqgB,EAAc,IAAM,CACpB,GAAA/f,EAAA,MAAM8T,CAAQ,IAAM,SACxB,OAAQ9S,EAAM,SAAU,CACtB,IAAK,YACiBsoB,IACpB,MACF,IAAK,UACexJ,IAClB,KACJ,CAAA,EAGKxC,EAAA,CACL,YAAAyC,CAAA,CACD,EAEK,MAAA1O,EAAYN,GAAa/P,CAAK,EAE9B,CAAE,eAAA+S,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EACKuY,EAAQ3O,EAAU,QAAUjP,GAAM,CAEtC,MAAMwO,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQnhB,EAAE,KAAM,CAAA,CAChD,EAEK,CAAE,WAAAkc,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EAEU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW+e,EACX,QAAS/e,EAAM,WAAA,CAChB,EAQD0P,GAAW1P,EAAO,CAChB,YAAA+e,EACA,MAAAC,EACA,YATkB,IAAM,CACxB,MAAMpP,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAC/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQ,GAAI,CAAA,CAM3C,CACD,EAEM,CACL,OAAAzhB,EACA,MAAAuZ,EACA,YAAA0E,EACA,MAAAC,EACA,QAAAtgB,EACA,QAAAkpB,EACA,UAAAC,CAAA,CAEJ,CACF,CAAC,sGA5ZCxa,mBAwBM,SAAA,SAxBsBI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,WACjC,MAAA2O,EAAAA,eAOOzO,EAPA,KAAA,CAAA,EAAA,eACLkb,EAKE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAJCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OACC,iBAAO,CAAK,SAAA,EAAA,EAAA,WAAA,mDAGjB,EAAA,CAAA,EACE,EAAA,CAAA,UAAA,CAAA,EAAAX,EAAAA,YACM+b,EAAM,CACX,kBAAS,aACT,MAAM,OACN,QAAMpb,EAAE,QAAA,OAAA,4BAOL,QAAAqT,EAAA,QAAA,IAAA,CAAAhU,EAAAA,YAJF6b,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OAAA,iBAAA,CAAA,SAAA,EAAA,gGCnBG,MAAA6c,GAAUtc,uBAAe,EC+CzBuc,GAA6B,CACxC,GAAGtqB,EACH,GAAI,GACJ,KAAM,MACN,QAAS,MACT,KAAM,cACN,MAAO,QACP,OAAQ,QACR,IAAK,GACL,KAAM,GACN,OAAQ,GACR,KAAM,CACJ,CAAE,KAAM,IAAK,MAAO,GAAI,EACxB,CAAE,KAAM,IAAK,MAAO,GAAI,EACxB,CAAE,KAAM,GAAI,MAAO,GAAI,CACzB,EACA,UAAW,GACX,aAAc,GACd,YAAa,GACb,eAAgB,OAChB,iBAAkB,sBAClB,WAAY,GACZ,aAAc,aACd,UAAW,MACX,WAAY,SACZ,OAAQ,CAAC,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,SAAS,EAC1G,WAAY,GACZ,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,cAAe,GACf,oBAAqB,UACrB,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,oBAAqB,UACrB,eAAgB,CAAE,KAAM,OAAQ,MAAO,OAAQ,EAC/C,iBAAkB,GAClB,QAAS,MACT,WAAY,MACZ,SAAU,KACV,UAAW,KACX,cAAe,OACf,YAAa,GACb,cAAe,aACf,gBAAiB,GACjB,eAAgB,EAChB,YAAa,QACb,WAAY,MACZ,4BAA6B,OAC7B,mBAAoB,GACpB,gBAAiB,SACnB,EAGauqB,GAAwBnc,EAA0Bkc,EAAY,EAE9DE,GAAgB,CAAC,QAAS,aAAa,EC5DpDtD,GAAAA,IAAI,CACFC,GAAA,eACAsD,GAAA,aACAnD,EAAA,iBACAD,EAAA,eACAE,EAAA,iBACAC,EAAA,eACF,CAAC,EACD,MAAAkD,GAAe3qB,kBAAgB,CAC7B,KAAM,cACN,MAAO,CACL,GAAGwqB,EACL,EACA,WAAY,CACV,KAAA7C,GACA,QAAA5nB,GAAA,OACA6nB,EAAA,KACF,EACA,MAAO3nB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC+Q,EAAUb,MAA8B,CAAA,CAAE,EAC1C0X,EAAU1X,MAAI,EAAK,EACnB2X,EAAY,IAAM,CACtBD,EAAQ,MAAQ,EAAA,EAEZ9mB,EAAS/B,EAAAA,SAAS,IAAM,CAG5B,MAAMoqB,EAAsBnpB,EAAM,oBAC5BopB,EAAsBppB,EAAM,oBAC3B,MAAA,CACL,QAAS,CACP,KAAMA,EAAM,YACZ,KAAMA,EAAM,YACZ,IAAKA,EAAM,WACX,SAAUA,EAAM,gBAChB,QAASA,EAAM,eACf,QAAS,CACP,WAAY,CACV,KAAM,GACN,MAAO,OACP,KAAM,ivCACN,SAAW,CACT6mB,GAAgB7mB,EAAM,kBAA4B,CACpD,CACF,EACA,WAAY,CACV,KAAM,GACN,MAAO,KACP,KAAM,8yBACN,SAAW,CACT4nB,EAAQ,MAAQ,EAClB,CACF,EACA,OAAQ,CACN,KAAM,GACN,MAAO,OACP,KAAM,glCACN,SAAW,CACTD,EAAAA,MAAO,KAAK,CACV,MAAO,OACP,QAAU3nB,EAAM,eAAA,CACjB,CACH,CACF,CACF,CACF,EACA,MAAO,CACL,KAAMA,EAAM,UACZ,QAASA,EAAM,aACf,KAAM,QACR,EACA,KAAM,CACJ,IAAKA,EAAM,QACX,OAAQA,EAAM,WACd,KAAMA,EAAM,SACZ,MAAOA,EAAM,UACb,aAAcA,EAAM,gBACtB,EACA,MAAOA,EAAM,OACb,MAAO,CAEL,UAAW,CACT,KAAMA,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,UAAWyG,EAAe,CACjB,OAAAqR,GAAkBqR,EAAqB1iB,CAAK,CACrD,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,EACA,SAAU,CACR,KAAMA,EAAM,aACd,CACF,EACA,MAAO,CACL,UAAW,CACT,KAAMA,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,UAAWyG,EAAe,CACjB,OAAAqR,GAAkBsR,EAAqB3iB,CAAK,CACrD,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,CACF,EAEA,QAAS,CACP,KAAMA,EAAM,YACZ,QAASA,EAAM,eACf,UAAW,SAAUkT,EAAQ,OACrB,KAAA,CAAE,OAAA6U,EAAQ,WAAAC,CAAe,EAAA9U,EACzBG,IAAShE,EAAA6D,GAAA,YAAAA,EAAQ,OAAR,YAAA7D,EAAc,SAAU,CAAA,EACjC,CAAE,KAAA5R,EAAM,MAAAgJ,CAAU,EAAA4M,EACjB,OAAA3B,GAAmB1R,EAAM,iBAA4B,CAC1D,OAAA+nB,EACA,WAAAC,EACA,EAAGA,EACH,EAAGvqB,EACH,EAAGgJ,EACH,GAAG4M,CAAA,CACJ,CACH,EACA,YAAa,CACX,KAAM,OACR,CACF,EAEA,OAAQ,CACN,KAAMrT,EAAM,WACZ,OAAQA,EAAM,aACd,IAAKA,EAAM,UACX,KAAMA,EAAM,UACd,EACA,OAAQ,CACN,CACE,KAAMhB,QAAM+R,CAAO,EACnB,KAAM,UACN,WAAY/Q,EAAM,UACpB,CACF,CAAA,CACF,CACD,EAEK,CAAE,eAAA+S,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEK,CAAE,SAAAqM,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAEKmZ,EAAgB,CAAC3X,EAAY,CAAA,EAAIC,IAAoD,CACnF,KAAA,CAAE,KAAMI,EAAI,OAAQ,MAAOC,EAAI,OAAA,EAAYL,GAAkB,GACnEO,EAAQ,MAAQR,EAAK,IAAaI,IAAA,CAAE,MAAO,CAACA,EAAKC,CAAC,EAAGD,EAAKE,CAAC,CAAC,EAAG,OAAQF,CAAO,EAAA,CAAA,EAIhF1S,EAAAA,MAAM,IAAM+B,EAAM,KAAOyG,GAAe,EAClCzG,EAAM,WAAa,UAAYhB,EAAAA,MAAM8T,CAAQ,IAAM,WACrDoV,EAAczhB,CAAK,CACrB,EACC,CACD,UAAW,GACX,KAAM,EAAA,CACP,EAEK,MAAA/H,EAAUwR,MAAI,EAAK,EAEnB+C,EAAcZ,GAAerS,CAAK,EAElC8e,EAAoB,SAAY,SACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UACxD,CAAApU,EAAQ,MAAQ,GACZ,GAAA,CACI,MAAAqV,EAAM,MAAMd,IAClBiV,GAAc5Y,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,KAAMtP,EAAM,cAAgD,QACpFoB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,EAAA,EAKIsgB,EAFYjP,GAAa/P,CAAK,EAEZ,QAAUoB,GAAM,CACtC,MAAMwO,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQnhB,GAAA,YAAAA,EAAG,KAAM,CAAA,CACjD,EAMDsO,GAAW1P,EAAO,CAChB,YALkB,IAAM,CACN8e,GAAA,EAKlB,MAAAE,CAAA,CACD,EAED,KAAM,CAAE,WAAA1B,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EACU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW8e,EACX,QAAS9e,EAAM,WAAA,CAChB,EAEM,CACL,OAAAc,EACA,MAAAuZ,EACA,MAAA2E,EACA,QAAAtgB,EACA,QAAAkpB,EACA,UAAAC,CAAA,CAEJ,CACF,CAAC,sGAlSCxa,mBAuBM,SAAA,mDAtBJ,MAAA4O,EAAAA,eAMOzO,EANA,KAAA,CAAA,EAAA,eACLkb,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CACLhU,EAAAA,YAAA8b,EAAA,CACT,OAAKnb,EAAE,OAAA,WAAA,mDAGZ,EAAA,CAAA,EACE,EAAA,CAAA,UAAA,CAAA,EAAAX,EAAAA,YACM+b,EAAM,CACX,kBAAS,aACT,MAAM,OACN,QAAMpb,EAAE,QAAA,OAAA,4BAOL,QAAAqT,EAAA,QAAA,IAAA,CAAAhU,EAAAA,YAJF6b,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OAAA,iBAAA,CAAA,SAAA,EAAA,gGClBG,MAAAmd,GAAc5c,uBAAmB,ECSjC6c,GAAqC,CAChD,GAAG5qB,EACH,GAAI,GACJ,KAAM,QACN,QAAS,QACT,KAAM,kBACN,MAAO,QACP,OAAQ,QACR,OAAQ,CAAC,EACT,WAAY,EACd,EAGa6qB,GAA4Bzc,EAA0Bwc,EAAgB,ECPnFE,GAAe/qB,kBAAgB,CAC7B,KAAM,kBACN,MAAO,CACL,GAAG8qB,EACL,EACA,WAAY,CACV,QAAA/qB,EACF,EACA,MAAOE,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCqmB,EAAWnW,EAAAA,MACjBjS,OAAAA,EAAAA,MAAM,IAAM+B,EAAM,WAAa+qB,GAAuB,CAMhD,GAAA,CAEF,MAAMC,EAAW,KACR3E,EAAA,MAAQ2E,EAASD,CAAU,QAC7B3pB,GACP,QAAQ,MAAMA,CAAC,CACjB,CAAA,EACC,CACD,UAAW,EAAA,CACZ,EACM,CACL,MAAAiZ,EACA,SAAAgM,EAAA,QACA4E,EAAA,CAEJ,CACF,CAAC,mCAjDC5d,mBAMM,SAAA,mDALJ,MAIE4O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAFCmb,EAAgB,CACjB,OAAAnb,EAAA,SAAA,iBAAA,CAAA,SAAA,EAAA,wCCHO,MAAA0d,GAAkBnd,uBAAuB,ECyDzCod,GAAmC,CAC9C,GAAGnrB,EACH,GAAI,GACJ,KAAM,OACN,QAAS,OACT,KAAM,iBACN,MAAO,QACP,OAAQ,QACR,KAAM,CACJ,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,CACF,EACA,UAAW,GACX,aAAc,GACd,OAAQ,CAAC,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,SAAS,EAC1G,WAAY,GACZ,qBAAsB,OACtB,aAAc,aACd,UAAW,MACX,WAAY,SACZ,YAAa,GACb,sBAAuB,GACvB,eAAgB,OAChB,iBAAkB,sBAClB,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,cAAe,GACf,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,wBAAyB,CAAE,KAAM,OAAQ,MAAO,QAAS,KAAM,MAAO,EACtE,sBAAuB,CAAE,KAAM,OAAQ,MAAO,CAAA,CAAG,EACjD,oBAAqB,QACrB,YAAa,CACX,CACE,KAAM,MACN,UAAW,CACb,EACA,CACE,KAAM,OACN,UAAW,CACb,CACF,EACA,MAAO,CACL,CACE,mBAAoB,SACtB,EACA,CACE,mBAAoB,SACtB,CACF,EACA,iBAAkB,GAClB,QAAS,MACT,WAAY,MACZ,SAAU,KACV,UAAW,KACX,cAAe,CAAC,EAChB,YAAa,GACb,cAAe,aACf,gBAAiB,GACjB,eAAgB,EAChB,YAAa,QACb,WAAY,MACZ,4BAA6B,OAC7B,mBAAoB,GACpB,gBAAiB,UACjB,iBAAkB,EAClB,WAAY,EACZ,eAAgB,EAChB,OAAQ,GACR,SAAU,KACZ,EAGaorB,GAA2Bhd,EAA0B+c,EAAe,EAEpEE,GAAmB,CAAC,cAAe,QAAS,aAAa,EClHtEnE,GAAAA,IAAI,CACFC,GAAA,eACA0C,GAAA,SACAZ,GAAA,UACA5B,EAAA,eACAG,EAAA,gBACAsC,EAAA,iBACAxC,EAAA,gBACF,CAAC,EACD,MAAAgE,GAAevrB,kBAAgB,CAC7B,KAAM,iBACN,MAAO,CACL,GAAGqrB,EACL,EACA,WAAY,CACV,KAAA1D,GACA,QAAA5nB,GAAA,OACA6nB,EAAA,KACF,EACA,MAAO3nB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCsX,EAASpH,MAA8B,CAAA,CAAE,EACzCY,EAAaZ,MAA8B,CAAA,CAAE,EAC7C0X,EAAU1X,MAAI,EAAK,EACnB2X,EAAY,IAAM,CACtBD,EAAQ,MAAQ,EAAA,EAEZ9mB,EAAS/B,EAAAA,SAAS,KAAO,CAC7B,MAAO,CACL,KAAMiB,EAAM,UACZ,QAASA,EAAM,aACf,KAAM,QACR,EACA,QAAS,CACP,KAAMA,EAAM,YACZ,KAAMA,EAAM,YACZ,IAAKA,EAAM,WACX,SAAUA,EAAM,gBAChB,QAASA,EAAM,eACf,QAAS,CACP,WAAY,CACV,KAAM,GACN,MAAO,OACP,KAAM,ivCACN,SAAW,CACT6mB,GAAgB7mB,EAAM,kBAA4B,CACpD,CACF,EACA,WAAY,CACV,KAAM,GACN,MAAO,KACP,KAAM,8yBACN,SAAW,CACT4nB,EAAQ,MAAQ,EAClB,CACF,EACA,OAAQ,CACN,KAAM,GACN,MAAO,OACP,KAAM,glCACN,SAAW,CACTD,EAAAA,MAAO,KAAK,CACV,MAAO,OACP,QAAU3nB,EAAM,eAAA,CACjB,CACH,CACF,CACF,CACF,EACA,KAAM,CACJ,IAAKA,EAAM,QACX,OAAQA,EAAM,WACd,KAAMA,EAAM,SACZ,MAAOA,EAAM,UACb,aAAcA,EAAM,gBACtB,EACA,MAAOA,EAAM,OACb,OAAQ,CACN,KAAMA,EAAM,WACZ,OAAQA,EAAM,aACd,IAAKA,EAAM,UACX,KAAMA,EAAM,WACZ,UAAW,CACT,MAAOA,EAAM,oBACf,CACF,EACA,QAAS,CACP,QAAS,OACT,KAAMA,EAAM,YACZ,UAAYkT,GAAW,CACrB,MAAM5H,EAAM4H,EAAO,OACnB,IAAIjC,EAAY,GACZoY,EAAmBrpB,EAAM,iBACzBqpB,IAAqB,KACJA,EAAA,uBAErB,MAAMkC,EAAcvrB,EAAM,YAC1B,QAASyD,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAA+nB,EAAaD,EAAY9nB,CAAC,EAC1B,CAAE,iBAAkBgoB,GAAsBD,GAAc,CAAA,EACxD,CAAE,OAAAzD,EAAQ,WAAAC,EAAY,KAAAvqB,EAAM,MAAAgJ,EAAO,KAAA8J,IAAS2C,EAAOzP,CAAC,GAAK,GAC3DA,IAAM,IACRwN,GAAa,GAAGxT,UAELwT,GAAAS,GAEX+Z,GAAqBpC,EACrB,CACE,OAAAtB,EACA,KAAAtqB,EACA,MAAAgJ,EACA,WAAAuhB,EACA,EAAGA,EACH,EAAGvqB,EACH,EAAGgJ,EACH,GAAG8J,EACL,EACA,CACE,WAAY,GACZ,SAAU,EACZ,CAAA,EACWU,GAAA,OACf,CACO,OAAAA,CACT,EACA,UAAW,CACT,MAAOjR,EAAM,qBACf,CACF,EACA,MAAO,CACL,KAAM,WACN,KAAMhB,QAAM8R,CAAU,EACtB,UAAW,CACT,KAAM9Q,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,eACf,EACA,SAAU,CACR,UAAW,CACT,MAAOA,EAAM,mBACf,CACF,EACA,SAAU,CACR,KAAMA,EAAM,aACd,CACF,EACA,MAAOhB,QAAM0sB,CAAK,EAClB,OAAQ1sB,QAAMsY,CAAM,CACpB,EAAA,EAEI,CAAE,SAAAxE,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAEKmZ,EAAgB,CAAC3X,EAAY,CAAA,EAAI+Y,EAA6B,KAAU,CAExE,IAAAlB,EACA,GAAApoB,EAAM,sBAAwB,MAAO,CACjC,MAAAwQ,EAAiB8Y,EAAoBtpB,EAAM,sBAAiD,KACtFooB,EAAAlU,GAA+B3D,EAAMC,CAAc,CAAA,SACtDxQ,EAAM,sBAAwB,QAAS,CAC1C,MAAAwQ,EAAiB8Y,EAAoBtpB,EAAM,wBAAqD,KAC1FooB,EAAA9X,GAAiCC,EAAMC,CAAc,CACnE,CAEAM,EAAW,MAAQsX,EAAU,WAC7B,MAAMrX,EAAUqX,EAAU,QACpBmB,EAAO,CAAA,EACPje,EAAMyF,EAAQ,OACdwa,EAAcvrB,EAAM,YAC1B,QAASyD,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAA+nB,EAAaD,EAAY9nB,CAAC,EAC1B,CAAE,KAAAuM,EAAM,UAAA2b,GAAcH,GAAc,CAAA,EAC1C,IAAIlU,EAAS,CACX,KAAAtH,EACA,WAAY2b,EACZ,GAAG5a,EAAQtN,CAAC,CAAA,EAEVuM,IAAS,SACXsH,EAAS,CACP,GAAGA,EACH,WAAYtX,EAAM,WAClB,OAAQA,EAAM,OACd,UAAW,CACT,QAASA,EAAM,gBACjB,EACA,UAAW,CACT,MAAOA,EAAM,cACf,CAAA,GAGAgQ,IAAS,QACXsH,EAAS,CACP,GAAGA,EACH,SAAUtX,EAAM,QAAA,GAGpBupB,EAAK,KAAKjS,CAAM,CAClB,CACAA,EAAO,MAAQiS,CAAA,EAGXpB,EAAyB,CAAC5X,EAAY,CAAI,EAAAiZ,EAA8CF,EAA6B,KAAU,CAE7H,MAAAlB,EAAYlU,GAA+B3D,EAD1B+Y,EAAoBE,EAAwB,IACE,EAErE1Y,EAAW,MAAQsX,EAAU,WAC7B,MAAMrX,EAAUqX,EAAU,QACpBmB,EAAO,CAAA,EACPje,EAAMyF,EAAQ,OACdwa,EAAcvrB,EAAM,YAC1B,QAASyD,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAA+nB,EAAaD,EAAY9nB,CAAC,EAChC8lB,EAAK,KAAK,CACR,KAAMiC,GAAA,YAAAA,EAAY,KAClB,WAAYA,GAAA,YAAAA,EAAY,UACxB,GAAGza,EAAQtN,CAAC,CAAA,CACb,CACH,CACA6T,EAAO,MAAQiS,CAAA,EAIXtrB,QAAA,IAAM,CAAC+B,EAAM,KAAMA,EAAM,YAAaA,EAAM,WAAYA,EAAM,OAAQA,EAAM,iBAAkBA,EAAM,eAAgBA,EAAM,QAAQ,EAAG,CAAC,CAACyG,CAAK,IAAM,EAClJzG,EAAM,WAAa,UAAYhB,EAAAA,MAAM8T,CAAQ,IAAM,WACrDoV,EAAczhB,CAAK,CACrB,EACC,CACD,UAAW,GACX,KAAM,EAAA,CACP,EAEK,MAAAilB,EAAQ3sB,EAAAA,SAAS,IAAM,CAC3B,MAAM2sB,EAAQ1rB,EAAM,MACb0rB,OAAAA,GAAAA,YAAAA,EAAO,IAAKE,IACV,CACL,KAAM,QACN,UAAW,CACT,KAAM5rB,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,UAAWyG,EAAe,CACjB,OAAAqR,GAAkB8T,EAAK,mBAA8BnlB,CAAK,CACnE,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,CAAA,GAEH,CACF,EAEKtB,EAAUwR,MAAI,EAAK,EAEnB+C,EAAcZ,GAAerS,CAAK,EAGlC8e,EAAoB,SAAY,SACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UACpD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClBiV,GAAc5Y,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,KAAM,EAAI,QAClClO,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAII2pB,EAAiBhT,GAAsBrV,CAAK,EAC5CsoB,EAAsB,SAAY,eACtC,GAAI,EAAAtoB,EAAM,WAAa,aAAehB,EAAAA,MAAM8T,CAAQ,IAAM,UACtD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMsU,IACd,IAAAhmB,IACAmN,GAAAF,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,UAAjB,YAAAE,EAA0B,QAAS,IACjCnN,EAAA,CACF,KAAM0R,EAAI,KAAK,KAAK,QAAQ,CAAC,EAC7B,MAAOA,EAAI,KAAK,KAAK,QAAQ,MAAM,CAAC,EAAE,IAAU8B,IACvC,CAAE,MAAOA,EAAI,MAAOA,CAAG,EAC/B,CAAA,GAGLsS,GAAuBvc,GAAAF,EAAAqI,GAAA,YAAAA,EAAK,OAAL,YAAArI,EAAW,OAAX,YAAAE,EAAiB,KAAMvJ,EAAG,EAAI,QAC9CjB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAGI+pB,EAAyB,IAAM,CAC/BzpB,EAAA,MAAM8T,CAAQ,IAAM,WACJwV,IACFxJ,IAAA,EAGdC,EAAc,IAAM,CACD0J,GAAA,EAGnBpY,EAAYN,GAAa/P,CAAK,EAE9B,CAAE,eAAA+S,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EACKuY,EAAQ3O,EAAU,QAAUjP,GAAM,CAEtC,MAAMwO,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQnhB,GAAA,YAAAA,EAAG,KAAM,CAAA,CACjD,EAEK,CAAE,WAAAkc,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EAEU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAWyoB,EACX,QAASzoB,EAAM,WAAA,CAChB,EAQD0P,GAAW1P,EAAO,CAChB,YAPkB,IAAM,CACxB,MAAM4P,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAC/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQ,GAAI,CAAA,EAK3C,YAAAxD,EACA,MAAAC,CAAA,CACD,EAEM,CACL,MAAA3E,EACA,OAAAvZ,EACA,MAAAke,EACA,QAAAtgB,EACA,QAAAkpB,EACA,UAAAC,CAAA,CAEJ,CACF,CAAC,sGAhaCxa,mBAwBM,SAAA,mDAvBJ,MAAA4O,EAAAA,eAOOzO,EAPA,KAAA,CAAA,EAAA,eACLkb,EAKE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAJCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OACC,iBAAO,CAAK,SAAA,EAAA,EAAA,WAAA,mDAGjB,EAAA,CAAA,EACE,EAAA,CAAA,UAAA,CAAA,EAAAX,EAAAA,YACM+b,EAAM,CACX,kBAAS,aACT,MAAM,OACN,QAAMpb,EAAE,QAAA,OAAA,4BAOH,QAAAqT,EAAA,QAAA,IAAA,CAAAhU,EAAAA,YALF6b,EAKE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAJCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OACC,iBAAO,CAAK,SAAA,EAAA,EAAA,WAAA,6GCnBZ,MAAAqe,GAAiB9d,uBAAsB,ECoBvC+d,GAA2B,CACtC,GAAG9rB,EACH,KAAM,KACN,QAAS,KACT,KAAM,aACN,MAAO,QACP,OAAQ,QACR,OAAQ,EACR,SAAU,OACV,WAAY,GACZ,WAAY,IACZ,MAAO,KACP,KAAM,WACN,YAAa,OACb,aAAc,MACd,YAAa,QACb,YAAa,MACb,gBAAiB,UACjB,gBAAiB,GACjB,WAAY,GACZ,KAAM,CAAC,CACT,EAEa+rB,GAAuB3d,EAA0B0d,EAAW,EAE5DE,GAAe,CAAC,OAAO,ECDpCC,GAAelsB,kBAAgB,CAC7B,KAAM,aACN,MAAO,CACL,GAAGgsB,EACL,EACA,MAAO/rB,EAAO,CACZ,MAAMqa,EAAQ5L,EAAsBzO,EAAO,CAAC,YAAY,CAAC,EACnD,CAAE,MAAAwc,CAAA,EAAU3d,EAAA,OAAOkQ,EAAe,CACtC,MAAO,OAAA,CACR,EACKmd,EAAcntB,EAAAA,SAAS,KACpB,CAML,MAAO,OACP,OAAQ,MAAA,EAEX,EAEKigB,EADYjP,GAAa/P,CAAK,EACZ,QAAS,IAAM,CAAA,CAAE,EACnC0e,EAASxO,MAA8B,CAAA,CAAE,EAC/CjS,EAAAA,MAAM,IAAM+B,EAAM,KAAOuQ,GAAmC,CAC1DmO,EAAO,MAAQnO,CAAA,EACd,CACD,UAAW,GACX,KAAM,EAAA,CACP,EACDb,GAAW1P,EAAO,CAChB,MAAAgf,CAAA,CACD,EACD,KAAM,CAAE,eAAArC,CAAA,EAAmB9d,EAAA,OAAOmQ,EAAc,CAG9C,eAAgB,CAAC1P,EAAamH,IAAe,EAAA,CAC9C,EAED,OAAAkW,EAAe3c,EAAM,GAAc,CACjC,KAAMA,EAAM,KACZ,MAAO0e,CAAA,CACR,EACM,CACL,MAAArE,EACA,MAAA2E,EACA,YAAAkN,EACA,MAAA1P,CAAA,CAEJ,CACF,CAAC,EChGc2P,GAAA,q2BCAAC,GAAA,2yBFSPC,GAAAtqB,IAAAuqB,EAAA,YAAA,iBAAA,EAAAvqB,EAAAA,IAAAwqB,EAAAA,aAAAxqB,aACsC+jB,EAAA,mBAAA,MAAA,CAAjC,MAAM,wBAAyB,KAAA,EAAA,CAAA,YACGA,EAAA,mBAAA,MAAA,CAAlC,MAAM,yBAA0B,KAAA,EAAA,CAAA,KAIRuG,GAAA,IAAAvG,EAAA,mBAAA,MAAA,CAAA,MAAA,2BAAA,KAAA,EAAA,CAAA,KACNuG,GAAA,IAAAvG,EAAA,mBAAA,MAAA,CAAA,MAAA,4BAAA,KAAA,EAAA,CAAA,kCAEnB0G,GAAM,CAAuB,MAAA,cACsB5L,GAAAyL,GAAA,IAAAvG,EAAA,mBAAA,MAAA,CAAA,MAAA,0CAInD2G,GAAM,CAAwB,MAAA,SACsBC,GAAAL,GAAA,IAAAvG,EAAA,mBAAA,MAAA,CAAA,MAAA,qDAMpBA,EAAA,mBAAA,MAAA,CAAjC,MAAM,wBAAyB,KAAA,EAAA,CAAA,YACGA,EAAA,mBAAA,MAAA,CAAlC,MAAM,yBAA0B,KAAA,EAAA,CAAA,qKAElC6G,GAAM,CAAA,IAAA,yCAhCH,SAAAhR,GAACnO,EAAaoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,QAAOvO,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAG,MAAK,cAAA,MAAA2O,EAAAA,eAAAzO,EAAA,KAAA,UAIpCoO,EAAI,CAAA,IAAAA,EAAA,CAAA,EAAA,IAAAle,IAAA8P,EAAA,OAAAA,EAAA,MAAA,GAAA9P,CAAA,EAAA,EAAA,oCAFM4P,EAAAA,mBAAA,MAAA,CACf,IAAK,EAAA,MAAA,iBAGU2O,EAAAA,eAAezO,EAAA,WAAA,CAAA,EAAA,GAC7B,iBACoCC,EAAAA,YAAAH,EAAAA,mBAAAwT,EAAAA,SAAA,CAAA,IAAA,GAAA,CACpCvT,GACAkT,GAAAC,uCAGJ,EAAA,CAAA,GAAAO,qBAAA,GAAA,EAAA,EAAAzT,EAAA,OAAA,aAAAC,EAAA,UAAA,EAAsBH,EAAAA,mBAAA,MAAA,CAAE,IAAK,EAAA,MAAA,YAC3B,MAAA2O,EAAAA,eAYMzO,EAZN,WAYM,CAAA,EAAA,CAPDsY,EAAA,mBAAA,MAAA3E,GAAA,CAAA2E,EAAA,mBACD,MAAoC0G,GAAA,CACpC5L,GAAAkF,EAAA,mBAAA,MAAA2G,GAAAG,EAAAA,gBAAApf,EAAA,KAAA,EAAA,CAAA,IAMJ,CAAA,CAAA,CACA,EACAqf,GACAC,GAAAC,KAEF,EAAA,CAAA,GAAA9L,qBAAA,GAAA,EAAA,EACEzT,EAAA,OAAA,cAAAC,EAAAA,iCAC0B,MAAfkf,GAAA,CAAA7G,EAAA,mBAAA,MAAAkH,GAAA,qGGjCJ,MAAAC,GAAalf,uDAAkB,ECsB/Bmf,GAAyB,CACpC,GAAI,GACJ,KAAM,YACN,MAAO,GACP,cAAe,OACf,WAAY,GACZ,MAAO,SACP,OAAQ,QACR,cAAe,SACf,eAAgB,SAChB,gBAAiB,OACjB,gBAAiB,GACjB,eAAgB,YAChB,QAAS,KACT,cAAe,CAAC,EAChB,UAAW,GACX,eAAgB,GAChB,SAAU,SACZ,EAEaC,GAAsB/e,EAA0B8e,EAAU,EAE1DE,GAAc,CAAC,WAAW,ECAvCC,GAAettB,kBAAgB,CAC7B,KAAM,YACN,WAAY,CAAA,OACV4nB,EAAA,KACF,EACA,MAAO,CACL,GAAGwF,EACL,EACA,MAAOntB,EAAO,CACZ,MAAMstB,EAAe,IAAM,SAAS,eAAe,gBAAgB,GAAK,SAAS,KAC3EC,EAAaxuB,EAAAA,SAAS,IAAM,CAChC,MAAMkJ,EAAWjI,EAAM,SAOhB,MAAA,CACL,cAPU,CACV,QAAS,GACT,IAAK,MACL,OAAQ,SACR,OAAQ,QAAA,EAGWiI,CAAQ,CAAA,CAC7B,CACD,EACKqS,EAAQta,EAAM,MACdua,EAASva,EAAM,OACfwa,EAAgBxa,EAAM,cACtBya,EAAiBza,EAAM,eACvBwtB,EAAazuB,WAAS,IAAM,WAAWub,CAAK,EAAI,WAAWE,CAAa,CAAC,EACzEiT,EAAc1uB,WAAS,IAAM,WAAWwb,CAAM,EAAI,WAAWE,CAAc,CAAC,EAE5EiT,EAAY3uB,WAAS,IAAM,GAAGC,EAAAA,MAAMwuB,CAAU,EAAI,MAAM,EAExDG,EAAc5uB,EAAAA,SAAS,IAAM,SAAS,KAAK,WAAW,EACtD6uB,EAAe7uB,EAAAA,SAAS,IAAM,SAAS,KAAK,YAAY,EACxD8uB,EAAe9uB,WAAS,IAAMC,EAAA,MAAM2uB,CAAW,EAAI3uB,EAAA,MAAMwuB,CAAU,CAAC,EACpEM,EAAgB/uB,WAAS,IAAMC,EAAA,MAAM4uB,CAAY,EAAI5uB,EAAA,MAAMyuB,CAAW,CAAC,EACvEM,EAAehvB,EAAAA,SAAS,KAAO,CACnC,MAAO,GAAGC,EAAAA,MAAM6uB,CAAY,MAC5B,OAAQ,GAAG7uB,EAAAA,MAAM8uB,CAAa,KAC9B,EAAA,EACIzT,EAAQ5L,EAAsBzO,CAAK,EACnCguB,EAAejvB,EAAAA,SAAS,KAAO,CACnC,GAAGC,EAAAA,MAAMqb,CAAK,EACd,gBAAiB5F,GAAazU,EAAM,gBAA2B,EAAI,EACnE,UAAW,SAAShB,EAAAA,MAAM6uB,CAAY,EAAI,WAAWvT,CAAK,KAAKtb,EAAAA,MAAM8uB,CAAa,EAAI,WAAWvT,CAAM,IACvG,EAAA,EACI0T,EAAclvB,EAAAA,SAAS,IAAMC,EAAM,MAAAwuB,CAAU,GAAK,CAAC,EACnDU,EAAcnvB,EAAA,SAAS,IAAMiB,EAAM,SAAS,EAC5CmuB,EAAgBpvB,EAAAA,SAAS,IAAM,CACnC,IAAIqvB,EAAY,aAChB,OAAIpvB,EAAAA,MAAMivB,CAAW,IAAgBG,GAAA,0BACjCpvB,EAAAA,MAAMkvB,CAAW,IAAgBE,GAAA,oBAC9BA,CAAA,CACR,EACKxG,EAAU1X,MAAI,EAAK,EACnBme,EAAUne,EAAAA,MACV,CAAE,aAAA4N,CAAA,EAAiBjf,EAAA,OAAOoQ,GAAe,CAG7C,aAAc,IAAM,EAAA,CACrB,EACKqf,EAAY,IAAM,CACtB1G,EAAQ,MAAQ,GAChBtmB,EAAAA,SAAS,IAAM,CACAwc,GAAA,CACd,CAAA,EAEG+J,EAAY,IAAM,CACtBD,EAAQ,MAAQ,EAAA,EAEZ2G,EAAO,IAAM,CACP1G,GAAA,EAEN2G,EAAW,IAAM,CACX3G,GAAA,EAGZ,OAAAnY,GAAW1P,EAAO,CAChB,UAAAsuB,CAAA,CACD,EAEM,CACL,QAAAD,EACA,aAAAN,EACA,aAAAC,EACA,aAAAV,EACA,WAAAC,EACA,UAAAG,EACA,YAAAQ,EACA,MAAA7T,EACA,QAAAuN,EACA,UAAA0G,EACA,KAAAC,EACA,SAAAC,EACA,YAAAP,EACA,cAAAE,CAAA,CAEJ,CACF,CAAC,+CA7IC9gB,mBAkCU,SAAA,EAhCP,OAAAI,EAAA,UAAA,EAA4BC,EAAA,YAAAkb,EAAA,CAC7B,aAAQpb,EAAA,aACP,cAASA,EAAA,cACT,SAAQ,GACR,QAAOA,EAAA,QACP,OAAA,KACA,MAAKA,eAAEA,EAAU,YAAA,OAAAA,EAAA,UACjB,eAAQA,EAAA,eACR,MAAgByO,EAAAA,eAAAzO,EAAA,UAAA,EAAA,KAAAA,EAAA,wBAcjB,EAAAihB,cAAA,CAAA,QAAU5N,UAAC,IAAS,CAAciF,EAAAA,mBAAA,MAAA,CAAE,MAAK,UAAA,IAAA,UACvC,MAOM7J,EAAAA,eAAAzO,EAAA,YAAA,CAAA,EAAA,sBAPqB,MAAE,CAAA,MAAA,iCAC3BA,EAKE,YAAA,CAAA,EAAA,EAHOC,EAAAA,UAAA,EAAA,EAASH,EAAY,mBAAAwT,WAAA,KAAAC,EAAA,WAAAvT,EAAA,cAAA,CAAAkhB,EAAAvnB,KAEpBsG,EAAAA,UAAS,EAAAC,cAAAihB,EAAAA,wBAAAD,EAAA,IAAA,EAAAE,aAAA,CAAA,IAAAF,EAAA,GAAAvnB,iCAlBA,EAAA,CAAA,EAAA,UACrB,KAAA,QAAA,GACG0Z,EAAK,QAAA,IAAA,CAAAiF,EAAAA,mBAAwB,MAAa,CAAA,MAAmB7J,EAAAA,eAAU,CAAA,SAAAzO,EAAA,wOCdnE,MAAAqhB,GAAY9gB,uDAAiB,ECwB7B+gB,GAAuB,CAClC,GAAG9uB,EACH,qBAAsB,MACtB,KAAM,WACN,KAAM,MACN,QAAS,MACT,MAAO,QACP,OAAQ,QACR,YAAa,OACb,gBAAiB,UACjB,eAAgB,UAChB,mBAAoB,GACpB,yBAA0B,GAC1B,SAAU,OACV,aAAc,OACd,cAAe,IACf,MAAO,GACP,UAAW,EACX,SAAU,CAAC,EACX,iBAAkB,MAClB,KAAM,CACJ,CACE,MAAO,KACT,EACA,CACE,MAAO,KACT,EACA,CACE,MAAO,KACT,CACF,EACA,cAAe,aACf,kBAAmB,YACrB,EAEa+uB,GAAqB3gB,EAA0B0gB,EAAS,EAExDE,GAAa,CAAC,WAAW,ECpBtCC,GAAelvB,kBAAgB,CAC7B,KAAM,WACN,MAAO,CACL,GAAGgvB,EACL,EACA,MAAO/uB,EAAO,OACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCkvB,EAAYhf,MAAI,CAAC,EACvBjS,EAAAA,MAAM,IAAM+B,EAAM,UAAYV,GAAQ,CACpC4vB,EAAU,MAAQ5vB,CAAA,EACjB,CACD,UAAW,EAAA,CACZ,EACK,MAAAof,EAASxO,MAA8B,CAAA,CAAE,EAC/CjS,EAAAA,MAAM,IAAM+B,EAAM,KAAOuQ,GAAmC,CAC1DmO,EAAO,MAAQnO,CAAA,EACd,CACD,UAAW,GACX,KAAM,EAAA,CACP,EACD,MAAM4e,EAAYhoB,GAAkB+nB,EAAU,QAAU/nB,EAClDya,EAAU1R,EAAAA,IAAIlQ,EAAM,OAAUhB,EAAAA,MAAM0f,CAAM,EAAE,CAAC,KAAK1f,EAAAA,EAAAA,MAAM0f,CAAM,EAAE,CAAC,IAAf1f,YAAAA,EAAkB,QAAU,EAAE,EAEhFqR,EAAYN,GAAa/P,CAAK,EAC9B,CAAE,eAAA2c,CAAA,EAAmB9d,EAAA,OAAOmQ,EAAc,CAG9C,eAAgB,CAAC1P,EAAamH,IAAe,EAAA,CAC9C,EAEDkW,EAAe3c,EAAM,GAAc,CACjC,MAAO4hB,EACP,UAAAsN,CAAA,CACD,EAED,KAAM,CAAE,gBAAAlR,CAAA,EAAoBnf,EAAA,OAAOsQ,GAAc,CAE/C,gBAAiB,IAAM,EAAA,CACxB,EAEKigB,EAAY/e,EAAU,YAAa,CAACgf,EAA0BloB,IAAkB,CAChFA,IAAUnI,QAAMkwB,CAAS,IACnBtN,EAAA,OAAQyN,GAAA,YAAAA,EAAK,QAAS,GAC9BH,EAAU,MAAQ/nB,EACF6W,IAClB,CACD,EACD,OAAAtO,GAAW1P,EAAO,CAChB,UAAAovB,CAAA,CACD,EACM,CACL,MAAA/U,EACA,UAAA6U,EACA,SAAAC,EACA,UAAAC,EACA,OAAA1Q,EACA,aAAAjK,EAAA,CAEJ,CACF,CAAC,uBArGW,SAAAkH,GAACnO,EAAWoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,QAAOvO,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,YAClC,MAgCM2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,CA9BEsY,EAAAA,mBAAA,MAAA,CAAA,MAAA,cAAuD,MAAA7J,EAAAA,eAAA,CAAA,SAAAzO,EAAA,YAAiF,WAAAA,EAAA,cAAA,eAAAA,EAAA,oEAQtI,EAAK,EAAAF,EAAA,mBAAAwT,WAAA,KAAAC,EAAA,WAAAvT,EAAA,OAAA,CAAA6hB,EAAAloB,KACLsG,EAAA,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,YAAuE2O,EAAAA,eAAS,CAA+D,QAAA,OAAAzO,EAAA,uBAAA,MAAAA,EAAA,SAAgIrG,KAAgB,eAAaqG,EAAA,SAA6C,gBAAAA,EAAA,SAAArG,CAAgB,iBAAgBqG,EAAY,yBAAA,EAAA,EAAAA,EAAA,aAAAA,EAAA,mBAAA,EAAA,EAAA,YAA+BA,EAAa,mBAAA,MAAAA,EAAA,aAAA,KAAA,aAAAA,EAAA,mBAAA,SAAAA,EAAA,aAAA,KAStb,WAAUA,EAAA,aAAA,CAAA,QAGX,QAOM8hB,EAAA,cAAA3M,GAAAnV,EAAA,UAAA6hB,EAAAloB,CAAA,EAAA,CAAA,UAAA,MAAA,CAAA,CAAA,EAAA,CALE2e,EAAAA,mBAAA,MAAA,CAAA,MAAA,oDAIJ,0BAAS,CAAAtY,EAAA,mBAAA,aAAAA,EAAA,SAAArG,CAAA,EAAAqG,EAAA,eAAA,gBAAA,EAAA,CAAA,yDC7BR,MAAA+hB,GAAWxhB,uDAAgB,ECW3ByhB,GAAyB,CACpC,GAAGxvB,EACH,KAAM,KACN,QAAS,KACT,KAAM,YACN,MAAO,QACP,OAAQ,QACR,OAAQ,GACR,OAAQ,OACR,KAAM,GACN,SAAU,EACZ,EAEayvB,GAAsBrhB,EAA0BohB,EAAU,ECLvEE,GAAe3vB,kBAAgB,CAC7B,KAAM,YACN,MAAO,CACL,GAAG0vB,EACL,EACA,MAAOzvB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC2vB,EAAW5wB,EAAAA,SAAS,IAAM0V,GAAazU,EAAM,MAAgB,CAAC,EAC9D,CAAE,SAAA8S,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAqBM,MAAA,CACL,MAAAsL,EACA,SAAAsV,EACA,QAvBc,IAAM,CAEpB,GAAI,CAAC3vB,EAAM,UAAY,CAACA,EAAM,KAAM,OAC9B,MAAAif,EAAYjf,EAAM,UAAY,GAC9Bkf,EAAUrK,GAAW7V,EAAAA,MAAM8T,CAAQ,EAAGmM,CAAQ,EAE9CE,EAAOnf,EAAM,KACnB,IAAIgT,EAAMmM,GAAQD,EAClBlM,EAAMtB,GAAmBsB,CAAG,EAC5B,MAAM3K,EAASrI,EAAM,OACjBqI,GAAU,MAAQA,IAAW,KAC7BA,IAAW,QACN,OAAA,KAAK2K,EAAK,IAAO3K,CAAiB,EAEzC,OAAO,OAAO,YAAY,CACxB,KAAM,WACN,IAAK8W,GACJ,GAAG,EACR,CAKA,CAEJ,CACF,CAAC,+BAzDC3R,EAKEoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,qCAJa,EAAA1O,EAAA,mBAAA,MAAA,CACZ,IAAK,EAEL,MAAK2O,EAAAA,eAAAzO,EAAA,KAAA,EAAA,IAAAA,EAAA,mBAER,CAMM,IAAAoO,EAAA,CAAA,EAAA,IAAAle,IAAA8P,EAAA,SAAAA,EAAA,QAAA,GAAA9P,CAAA,EAAA,EAAA,KAAA,GAAA6P,EAAA,IAAAE,EAAAA,UALqB,EAAAH,EAAA,mBAAA,MAAA,CACxB,IAAK,EAEP,MAAA,oBAAA,MAAA2O,EAAAA,eAAAzO,EAAA,KAAA,iBCTU,MAAAoiB,GAAY7hB,uDAAiB,ECS7B8hB,GAA2B,CACtC,GAAG7vB,EACH,KAAM,KACN,QAAS,KACT,KAAM,aACN,MAAO,QACP,OAAQ,QACR,KAAM,GACN,SAAU,KACZ,EAEa8vB,GAAuB1hB,EAA0ByhB,EAAW,ECFzEE,GAAehwB,kBAAgB,CAC7B,KAAM,aACN,MAAO,CACL,GAAG+vB,EACL,EACA,MAAO9vB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC,CAAE,kBAAA6S,CAAA,EAAsBhU,EAAA,OAAOkQ,EAAe,CAClD,kBAAmB,EAAA,CACpB,EACKihB,EAASjxB,EAAAA,SAAS,IAAM,CACxB,IAAAkxB,EAAOve,GAAmB1R,EAAM,IAAc,EAClD,GAAIA,EAAM,WAAa,OAASiwB,GAAQ,KAAM,CACxC,IAAAC,EAAYlxB,QAAM6T,CAAiB,EACnCqd,EAAUA,EAAU,OAAS,CAAC,IAAM,IACzBA,GAAA,YAEAA,GAAA,aAGfD,EAAO,GADQxgB,IAAWygB,cACGD,GAC/B,CACO,OAAAA,CAAA,CACR,EACM,MAAA,CACL,MAAA5V,EACA,OAAA2V,CAAA,CAEJ,CACF,CAAC,+BAhDCxiB,EAIEoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,gCAHY1O,EAAAA,mBAAA,SAAA,CACX,IAAK,EAAA,IAAAE,EAAA,8BAGRA,EAMM,KAAA,CAAA,EAAA,KAAA,GAAAD,EAAA,IAAAE,EAAAA,UALsB,EAAAH,EAAA,mBAAA,MAAA,CACzB,IAAK,EAEP,MAAA,qBAAA,MAAA2O,EAAAA,eAAAzO,EAAA,KAAA,mBCRU,MAAA2iB,GAAapiB,uDAAkB,EC4C/BqiB,GAAyB,CACpC,GAAGpwB,EACH,OAAQ,EACR,KAAM,KACN,QAAS,KACT,KAAM,YACN,MAAO,QACP,OAAQ,QACR,SAAU,GACV,eAAgB,OAChB,SAAU,OACV,SAAU,GACV,KAAM,UACN,iBAAkB,IAClB,WAAY,IACZ,gBAAiB,EACjB,QAAS,EACT,eAAgB,GAChB,UAAW,GACX,OAAQ,GACR,oBAAqB,GACrB,YAAa,GACb,mBAAoB,cACpB,mBAAoB,GACpB,YAAa,GACb,eAAgB,GAChB,qBAAsB,QACtB,WAAY,CAAC,CACX,MAAO,GACP,KAAM,GACN,OAAQ,GACR,MAAO,EAAA,CACR,EACD,kBAAmB,IACnB,QAAS,CACP,CACE,MAAO,KACP,UAAW,MACb,EACA,CACE,MAAO,KACP,UAAW,KACb,EACA,CACE,MAAO,KACP,UAAW,SACb,CACF,EACA,KAAM,CACJ,CACE,KAAM,KACN,IAAK,GACL,QAAS,OACX,EACA,CACE,KAAM,KACN,IAAK,GACL,QAAS,OACX,CACF,EACA,cAAe,CACb,UAAW,QACX,OAAQ,IACR,MAAO,GACT,CACF,EAGaqwB,GAAsBjiB,EAA0BgiB,EAAU,EAE1DE,GAAc,CAAC,QAAS,cAAe,aAAa,ECqCjEC,GAAexwB,kBAAgB,CAC7B,KAAM,YACN,WAAY,CACV,SAAA0e,GAAA,OACA4D,EAAA,MAAA,eACA+D,EAAA,cAAA,OACAoK,EAAA,MAAA,cACAC,EAAA,aAAA,iBACAC,EAAA,gBAAA,kBACAC,EAAA,gBACF,EACA,MAAO,CACL,GAAGN,EACL,EACA,MAAOrwB,EAAO,CAAE,OAAAsc,GAAU,CAClB,MAAAjC,EAAQ5L,EAAsBzO,CAAK,EACnC4wB,EAAS7xB,EAAAA,SAAS,IAAM,CAC5B,GAAIiB,EAAM,eACR,OAAQA,EAAM,KAAM,CAClB,IAAK,QACI,MAAA,IACT,IAAK,SACI,MAAA,KACT,QACS,MAAA,IACX,KAEA,QAAQA,EAAM,KAAM,CAClB,IAAK,QACI,MAAA,IACT,IAAK,SACI,MAAA,IACT,QACS,MAAA,GACX,CACF,CACD,EACK4Q,EAAI7R,EAAA,SAAS,IAAMiB,EAAM,OAAO,EAChC6Q,EAAI9R,WAAS,IAAM,WAAWiB,EAAM,MAAgB,EAAIhB,EAAAA,MAAM4xB,CAAM,CAAC,EACrEC,EAAY3gB,MAA+B,CAAA,CAAE,EAC7C4gB,EAAe5gB,MAA+B,CAAA,CAAE,EAChD6gB,EAAe7gB,MAA+B,CAAA,CAAE,EAChD8gB,EAAkB9gB,MAA+B,CAAA,CAAE,EACnD+gB,EAAQ/gB,MAAI,CAAC,EACbghB,EAAUhhB,MAAI,CAAC,EACfihB,EAAWpyB,EAAA,SAAS,IAAMiB,EAAM,kBAA4B,EAC5DoxB,EAAsBC,WAAS,CAAA,CAAE,EACjCC,EAAwB,CAACC,EAAsC,KAAO,CAC1E,GAAI,MAAM,QAAQA,CAAQ,GAAKA,EAAS,OAAS,EAAG,CAClD,MAAMjmB,EAAMimB,EAAS,OACfC,EAAkBxxB,EAAM,gBAG9B,QAASyD,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAAyd,EAASqQ,EAAS9tB,CAAC,EACrBA,EAAI+tB,EACNtQ,EAAO,MAAQ,OAEfA,EAAO,MAAQ,GAEX,KAAA,CACJ,UAAAuQ,EAAY,SACZ,UAAAC,EACA,UAAAC,GACA,MAAAC,GACA,YAAAC,GACA,gBAAAC,GACA,gBAAAC,EACE,EAAA7Q,EACA2Q,KACFT,EAAoB,KAAKO,EAAS,EAClCzQ,EAAO,wBAA0B,GACjCA,EAAO,yBAA2B,GAClCA,EAAO,qBAAuB,GAC9BA,EAAO,SAAW,CAACza,GAAO4M,KAAWA,GAAOse,EAAS,EAAE,SAAS,EAAE,YAAY,EAAE,SAASlrB,GAAM,YAAa,CAAA,GAI9Gya,EAAO,iBAAmB,KAAO,CAC/B,MAAO,CACL,QAAS,aACT,cAAe,SACf,SAAUlhB,EAAM,eAChB,WAAYA,EAAM,iBAClB,UAAW8xB,IAAmB,SAC9B,MAAOC,GACP,kBAAmB/xB,EAAM,WAC3B,CAAA,GAGKkhB,EAAA,WAAa,CAAC7N,GAAQsD,MAAc,CACzC,MAAO,CACL,UAAW8a,EACX,MAAOC,EACP,gBAAiB1xB,EAAM,oBACvB,kBAAmBA,EAAM,WAC3B,EACA,MAAO,CACL,UAAWhB,EAAAA,MAAMgzB,CAAW,IAAMrb,IAAY3W,EAAM,cACtD,EACA,QAASqQ,EAAU,QAAS,IAAM,CAChC,MAAMT,GAAK5P,EAAM,GACXuiB,GAAQxP,EAAenD,EAAE,EACtByD,GAAA,CACP,UAAAse,GACA,MAAAC,GACA,GAAGve,EAAA,EAGLsJ,EAAe/M,GAAI,CAAE,GAAG2S,GAAO,OAAQlP,GAAQ,CAAA,CAChD,CAAA,GAEC,MAAM,QAAQ6N,EAAO,QAAQ,GAC/BoQ,EAAsBpQ,EAAO,QAAQ,CAEzC,CACF,CAAA,EAEI+Q,EAAgB,CAAC/H,EAAqC,MAEtDlqB,EAAM,UAERkqB,EAAQ,QAAQ,CACd,MAAO,KACP,UAAW,MACX,MAAO,QAAA,CACR,EAGClqB,EAAM,aACRkqB,EAAQ,KAAK,CACX,MAAO,KACP,UAAW,SACX,MAAOlqB,EAAM,iBAAA,CACd,EAEHsxB,EAAsBpH,CAAO,EACtBA,GAETjsB,EAAAA,MAAM,IAAM,CACV+B,EAAM,QACNA,EAAM,SACNA,EAAM,YACNA,EAAM,gBACNA,EAAM,kBACNA,EAAM,oBACNA,EAAM,WAAA,EACL,IAAM,CACP6wB,EAAU,MAAQoB,EAAcC,GAAU,UAAAlyB,EAAM,OAAiB,CAAC,CAAA,EACjE,CACD,UAAW,GACX,KAAM,EAAA,CACP,EACK/B,QAAA,IAAM,CAAC+B,EAAM,KAAMA,EAAM,QAAQ,EAAG,CAAC,CAACuQ,EAAMoO,CAAQ,IAAM,CAC1DA,IAAa,WACjBmS,EAAa,MAAQvgB,EAAA,EACpB,CACD,UAAW,EAAA,CACZ,EACK,MAAA4hB,EAAmBjiB,MAAI,CAAA,CAAE,EACzBkiB,EAA+B/R,GAAyC,CACxE,GAAA,MAAM,QAAQA,CAAU,EAAG,CAC7B,MAAMjM,EAAUiM,EAAW,OACrB1M,EAAOyd,EACPvd,EAAUF,EAAK,OACf0e,EAAkD,CAAA,EACxD,QAAS5uB,EAAI,EAAGA,EAAI2Q,EAAS3Q,IAAK,CAC1B,MAAA4P,GAASgN,EAAW5c,CAAC,EAC3B,QAASyO,GAAI,EAAGA,GAAI2B,EAAS3B,KAAK,CAC1B,MAAA5S,GAAMqU,EAAKzB,EAAC,EACd,GAAAmgB,EAAiB/yB,EAAG,EACtB+yB,EAAiB/yB,EAAG,EAAE,IAAI+T,GAAO/T,EAAG,CAAC,MAChC,CACC,MAAAmR,OAAU,IACZA,GAAA,IAAI4C,GAAO/T,EAAG,CAAC,EACnB+yB,EAAiB/yB,EAAG,EAAImR,EAC1B,CACF,CACF,CACA,MAAM6hB,EAA0E,CAAA,EAChF,UAAWhzB,KAAO+yB,EAChB,GAAI,OAAO,UAAU,eAAe,KAAKA,EAAkB/yB,CAAG,EAAG,CACzD,MAAAizB,GAAaF,EAAiB/yB,CAAG,EACjC0I,GAAU,MAAM,KAAKuqB,EAAU,EACnBD,EAAAhzB,CAAG,EAAI0I,GAAQ,IAAKlH,KAAY,CAAE,MAAOA,GAAQ,MAAOA,EAAA,EAAS,CACrF,CAEFqxB,EAAiB,MAAQG,CAC3B,CAAA,EAEIr0B,QAAA,IAAM,CAAC+B,EAAM,UAAW6wB,EAAU,MAAOC,EAAa,KAAK,EAAG,IAAM,CAClE,MAAAS,EAAWvyB,QAAM6xB,CAAS,EAC1B2B,EAAcxzB,QAAM8xB,CAAY,EAEtC,GADAsB,EAA4BI,CAAW,EACnCxyB,EAAM,UAAW,CACb,KAAA,CAAE,QAAAkqB,EAAS,WAAA7J,CAAA,EAAeoS,EAAmBP,aAAUX,CAAQ,EAAGW,GAAAA,UAAUM,CAAW,CAAC,EAC9FzB,EAAa,MAAQ7G,EACrB8G,EAAgB,MAAQ3Q,CAAA,MAExB0Q,EAAa,MAAQQ,EACrBP,EAAgB,MAAQwB,CAC1B,EACC,CACD,UAAW,GACX,MAAO,MAAA,CACR,EACK,MAAAC,EAAqB,CAACvI,EAAkC7J,IAAwC,CAC9F,MAAAqS,EAAexI,EAAQ,CAAC,EACxBqH,EAAW,CAAC,CAChB,MAAOmB,EAAa,MACpB,UAAW,OACX,IAAK,OACL,MAAO,QAAA,CACR,EACD,QAASjvB,EAAI,EAAGA,EAAI4c,EAAW,OAAQ5c,IAAK,CACpC,MAAA8M,EAAO8P,EAAW5c,CAAC,EACnBkuB,GAAY,OAASluB,EAAI,GAC/B8tB,EAAS,KAAK,CACZ,MAAOhhB,EAAKmiB,EAAa,SAAS,EAClC,UAAAf,GACA,IAAKA,GACL,MAAO,QAAA,CACR,CACH,CACA,MAAMa,EAAc,CAAA,EACpB,QAAS/uB,EAAI,EAAGA,EAAIymB,EAAQ,OAAQzmB,IAAK,CACjC,MAAAyd,EAASgJ,EAAQzmB,CAAC,EAClBkvB,GAAQ,CAAE,KAAMzR,EAAO,KAAM,EACnC,QAAShP,GAAI,EAAGA,GAAImO,EAAW,OAAQnO,KAAK,CACpC,MAAA3B,GAAO8P,EAAWnO,EAAC,EACzBygB,GAAM,MAAMzgB,GAAI,GAAG,EAAI3B,GAAK2Q,EAAO,SAAS,CAC9C,CACAsR,EAAY,KAAKG,EAAK,CACxB,CACO,MAAA,CACL,QAASpB,EACT,WAAYiB,CAAA,CACd,EAEII,EAAiB1iB,MAAY,EAAE,EAC/B+C,EAAcZ,GAAerS,CAAK,EAClCtB,EAAUwR,MAAI,EAAK,EACnB4O,EAAoB,MAAO+T,EAAwB,KAAS,OAC5D,GAAA,CACEA,IAAcn0B,EAAQ,MAAQ,IAElC,IAAIwU,EAAS,CAAA,EACTlU,EAAAA,MAAM4zB,CAAc,IACf1f,EAAA,eAAiBlU,QAAM4zB,CAAc,GAG1C5yB,EAAM,iBACCkT,EAAA,CACP,QAASlU,QAAMkyB,CAAO,EACtB,SAAUlyB,QAAMmyB,CAAQ,EACxB,MAAO,IACP,GAAGje,CAAA,GAGD,MAAAa,EAAM,MAAMd,EAAYC,CAAM,EAC9B,CAAE,KAAAiX,EAAO,GAAI,MAAO2I,EAAa,CAAM,IAAAzjB,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAQ,GAChE4hB,EAAM,MAAQ6B,EACV,MAAM,QAAQ3I,CAAI,IACpB2G,EAAa,MAAQ3G,SAEhB/oB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAEIq0B,EAAc,CAAC,CAAE,QAAAC,CAAQ,EAAwBC,EAAUC,IAAW,CAE1E,GADAhC,EAAQ,MAAQ8B,EACZE,GAAU,OAAO,KAAKA,CAAM,EAAE,OAAS,EAAG,CACtC,KAAA,CAAE,MAAAC,EAAO,MAAAC,CAAU,EAAAF,EAKnBG,EAJM,CACV,OAAQ,MACR,QAAS,MAAA,EAEYD,CAAK,EACxBD,GAAS,MAAQE,GAAc,OAClBT,EAAA,MAAQO,EAAQ,IAAME,EACrCnC,EAAQ,MAAQ,EAEpB,CACAnS,GAAY,EAAK,CAAA,EAEbuU,EAAav0B,EAAAA,SAAS,IAAM,CAChC,MAAMw0B,EAASvzB,EAAM,OACfiI,EAAW,CAACjI,EAAM,kBAAkB,EAC1C,OAAOA,EAAM,gBAAkB,CAC7B,OAAAuzB,EACA,SAAAtrB,EACA,MAAOjJ,QAAMiyB,CAAK,EAClB,QAASjyB,QAAMkyB,CAAO,EACtB,SAAUlyB,QAAMmyB,CAAQ,EACxB,gBAAiB,EAAA,CACnB,CACD,EACKqC,EAAiB/sB,GACjB,CAACA,GAAU,EAAU,IACrB,CAACA,GAAU,EAAU,IAClBA,EAGH8Z,EAAW,CAAC9Z,EAAwBlC,IACpCA,GAAU,MAAQA,IAAW,GAAWkC,EAChC,CACV,MAAOyK,GACP,WAAYG,GACZ,SAAUA,GACV,QAASmiB,CAAA,EAEAjvB,CAAM,EAAEkC,CAAK,GAAK,GAEzB+Z,EAAgB,CAAC/Z,EAAwBlC,IAAmB,CAC1D,MAAA6M,EAAS,WAAW3K,EAAQ,EAAE,EACpC,GAAIlC,IAAW,WACN,MAAA,GAET,OAAQ,GAAM,CACZ,KAAK6M,GAAU,EACN,MAAA,OACT,KAAKA,EAAS,EACL,MAAA,QACX,CAAA,EAGIf,EAAYN,GAAa/P,CAAK,EAE9B,CAAE,SAAA8S,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAEK,CAAE,eAAAgE,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEK0hB,EAAyB,CAACsL,EAAsB,CAAA,EAAIC,EAAoC,CAAA,IAAO,CACnG,MAAMnC,EAAWkC,EAAY,IAAKvS,IAAoB,CAAE,MAAOA,EAAQ,UAAWA,EAAQ,IAAKA,CAAA,EAAS,EAC9F2P,EAAA,MAAQoB,EAAcV,CAAQ,EACxCT,EAAa,MAAQ4C,CAAA,EAIjBzJ,EAAgBlS,GAAiB/X,CAAK,EACtCsoB,EAAsB,SAAY,aAClC,GAAA,CACF5pB,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMkW,IAClB9B,GAAuB7Y,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,SAAS5D,GAAA8D,EAAAuE,GAAA,YAAAA,EAAK,OAAL,YAAAvE,EAAW,OAAX,YAAA9D,EAAiB,IAAI,QAC/DtK,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAQIszB,EAAc9hB,EAAAA,IAAI,EAAE,EAEpByjB,GAAY,CAACtgB,EAAQlM,KAAW,CACpC,QAASkJ,EAAU,WAAY,IAAM,CACnC,MAAMT,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQlP,EAAQ,EAC/C2e,EAAY,MAAQ7qB,CAAA,CACrB,CAAA,GAGG4X,GAAc,CAAC8T,EAAwB,KAAS,CAChD,GAAA7zB,EAAA,MAAM8T,CAAQ,IAAM,SACxB,OAAQ9S,EAAM,SAAU,CACtB,IAAK,UACH8e,EAAkB+T,CAAY,EAC9B,MACF,IAAK,YACiBvK,IACpB,KACJ,CAAA,EASF5Y,GAAW1P,EAAO,CAChB,YAPkB,IAAM,CACxB,MAAM4P,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAC/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQ,GAAI,CAAA,EAK3C,YAAAxD,EAAA,CACD,EACK,MAAA6U,GAAc70B,EAAAA,SAAS,IAAM,CAC3B,MAAAmrB,EAAUlrB,QAAM+xB,CAAY,EAC5B6C,EAAc,CAAA,EACpB,IAAIC,EAAiB,EACrB,QAASpwB,EAAI,EAAGA,EAAIymB,EAAQ,OAAQzmB,IAAK,CACjC,MAAAyd,EAASgJ,EAAQzmB,CAAC,EAClB,CAAE,YAAAqwB,CAAgB,EAAA5S,EACpBlhB,EAAM,UAAYyD,IAAM,EAC1BmwB,EAAY,KAAK,CACf,GAAG1S,EACH,MAAO,IAAA,CACR,EACQ4S,GACTF,EAAY,KAAK,CACf,GAAG1S,EACH,MAAOzd,EACP,MAAO,CAAA,CACR,EACDowB,KAEAD,EAAY,KAAK,CACf,GAAG1S,CAAA,CACJ,CAEL,CAEA,GAAI2S,IAAmB,EAAG,MAAO,GAC7B,IAAAE,EAAU/0B,QAAMgyB,CAAe,EACnC,GAAIhxB,EAAM,eAAgB,CACxB,MAAMg0B,GAASh1B,QAAMkyB,CAAO,EAAI,GAAKlyB,EAAAA,MAAMmyB,CAAQ,EAC7C8C,EAAMD,EAAQh1B,EAAA,MAAMmyB,CAAQ,EACxB4C,EAAAA,EAAQ,MAAMC,EAAOC,CAAG,CACpC,CACA,QAASxwB,EAAI,EAAGA,EAAImwB,EAAY,OAAQnwB,IAAK,CACrC,MAAAywB,EAAUN,EAAYnwB,CAAC,EAC7B,IAAIwtB,EAAgB,EACd,KAAA,CAAE,YAAA6C,GAAa,UAAAnC,EAAc,EAAAuC,EACnC,GAAIJ,KAAgB,GAAM,CACxB,QAAS5hB,GAAI,EAAGA,GAAI6hB,EAAQ,OAAQ7hB,KAAK,CAEjC,MAAAiiB,GAAM,CADGJ,EAAQ7hB,EAAC,EACJyf,EAAS,EAC7BV,GAASkD,EAKX,CACAD,EAAQ,MAAQjD,CAClB,CACF,CACO2C,OAAAA,CAAA,CACR,EAEK,CAAE,WAAAtW,EAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EAEU,OAAAD,GAAA,CACT,GAAItd,EAAM,GACV,UAAW+e,GACX,QAAS/e,EAAM,WAAA,CAChB,EAEMsc,EAAA,CACL,YAAAyC,EAAA,CACD,EAuDM,CACL,EAAAnO,EACA,EAAAC,EACA,MAAAwJ,EACA,UAAAsZ,GACA,WAAAL,EACA,SAAA/S,EACA,cAAAC,EACA,YAAAuS,EACA,YAAAa,GACA,QAAAl1B,EACA,iBAhDuB,CAAC2J,EAAoC8W,EAAe,KAAO,CAC9E9W,IAAW,SACb,OAAO,OAAO,YAAY,CACxB,KAAM,WACN,IAAK8W,GACJ,GAAG,CACR,EA2CA,WAjEiB,CAACA,EAAe,GAAI5O,IAC9BmB,GAAmByN,EAAM5O,CAAI,EAiEpC,iBA9DwBlI,GAAuC,CAC/D,GAAIA,IAAW,QAOb,MAJY,CACV,KAAM,QACN,MAAO,QAAA,EAEEA,CAAM,CACnB,EAsDA,YAAA2pB,EACA,aAAAjB,EACA,gBAAAC,EACA,iBAnCwB9P,GAAW,CACnC,MAAM5hB,EAAM4hB,EAAO,UACf,GAAA,OAAO5hB,GAAQ,SAAU,CAC3B,IAAI80B,EAAgBp1B,EAAA,MAAMmzB,CAAgB,EAAE7yB,CAAG,EAC/C,MAAM+0B,EAAcr1B,EAAAA,MAAMkiB,EAAO,uBAAuB,EAAE,KAAK,EAC3D,OAAA,MAAM,QAAQkT,CAAa,GACbA,EAAAA,EAAc,OAAQvQ,GAChC,OAAOA,EAAa,OAAU,SACzBA,EAAa,MAAM,YAAA,EAAc,SAASwQ,EAAY,aAAa,EAErE,EACR,EACMD,GAEF,EACT,CACA,MAAO,EAAC,EAoBR,mBA9CyB,CAACE,EAAiBpT,IAAW,CACtDoT,EAAgBpT,EAAO,wBAAwB,CAAA,EA8C/C,cA3CoB,CAACqT,EAAcrT,IAAW,CACjCqT,EAAA,CAAE,QAAS,EAAA,CAAM,EAC9BrT,EAAO,wBAA0B,GACjCA,EAAO,yBAA2B,EAAC,EAyCnC,sBAvC4B,IAAM,CAAA,CAuClC,CAEJ,CACF,CAAC,mFA7nBgBP,GAAM,CAAA,IAAA,kWA9DrBtT,mBAwHM,UAAA,SAxHwBI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,aACnC,MAsHW2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eArHT4R,EAoHU,CAAA,QAAA5R,EAAA,OAAA,EAAA,CAAA,QAnHHqT,EAAQ,QAAA,IAAA,CACLhU,EAAAA,YAAA2nB,EAAA,CAAA,MAAA,QAEP,MAAA,CACA,OAAO,MAAA,EAEP,QAAQhnB,EAAE,aACV,cAAUA,EAAA,gBACV,SAASA,EAAE,SACX,KAAMA,EAAA,KACN,UAAUA,EAAE,UACZ,OAAM,CAAE,EAAWA,EAAA,EAAA,EAAAA,EAAA,CAAA,EAAA,WAAAA,EAAA,WAET,SAAAA,EAAA,WAAA,EAAA,sBAEDqT,EAAAA,QAAmB,CAAA,CAAA,OAAAK,EAAA,aAAAuT,EAAA,gBAAAH,EAAA,QAAAI,EAAA,aAAAH,KAAA,CACnBzO,EAAAA,mBAAA,MAAA,CAAA,MAAA,8EAKWjZ,EAAAA,YAAA6V,EAAA,CACf,MAAYxB,EAAA,wBAEZ,iBAAoByB,GAAAzB,EAAA,wBAAAyB,EACnB,YAAQ,SAAA,MAAA,eAEX,SAMmBnV,EAAA,qBAAA,EALT,KAAO,WAAO,iBAAwB,UAAA,CAAA,EAAxBX,EAAAA,YAAA2Z,EAAA,CACtB,MAAMtF,EAAA,yBACL,oBAAyBA,EAAO,yBAAAyB,EAChC,MAAA,kBAAA,QAAAnV,EAAA,iBAAA0T,CAAA,EAGH,SAgBMyB,GAAAnV,EAAA,mBAAA8mB,EAAApT,CAAA,CAAA,EAfJ,KAOW,EAAA,CAAA,QAAA,iBAAA,UAAA,UAAA,CAAA,EANK4E,EAAA,mBAAA,MAAA,KAAA,CAAAjZ,EAAAA,YACTgZ,EAAO,CACZ,KAAsC,UACrC,KAAA,QAAA,MAAA,CAAA,MAAA,OAAA,eAAA,KAAA,EAGH,QAAA,IAAA6O,EAAA,CAAA,EAAA,6BACA,EAAA,CAAA,EACE,KAAK,CAAO,SAAA,CAAA,EAAA7nB,EAAAA,YACZgZ,EAAmB,CAClB,KAAA,QAAA,MAAA,CAAA,MAAA,MAAA,EAGH,QAAAlD,GAAAnV,EAAA,cAAA+mB,EAAArT,CAAA,CAAA,EAAA,qDAIK,EAAA,CAAA,CAAA,CAAA,uBAEP,OAAAA,EAA4B,MAAA/Z,EAAA,KAAA0X,EAAA,OAAAxL,KAAA,CAGd6N,EAAA,YAAA,OAAAzT,EAAA,UAAA,EAAgBH,EAAAA,mBAC9B,OAAAoT,GAAAkM,EAAA,gBAAAzlB,EAAA,CAAA,EAAA,CAAA,GAAA8Z,EAAA,mBAAA,GAAA,EAAA,EAAAC,EAAA,YAAA,UAAAzT,EAAAA,UAAA,EAAAH,EAAA,mBACE,MAaMqT,GAAA,EAAAlT,EAAAA,UAbK,EAAQ,EAAAH,EAAA,mBAAAwT,WAAA,KAAAC,EAAA,WAAAvT,EAAA,WAAA,CAAAmnB,EAAAC,KAA6CnnB,EAAK,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,SACnE,IAAAsnB,CAAA,EAAA,CAEW9O,EAAAA,mBAAA,IAAA,CACR,KAAKtY,EAAA,WAAAmnB,EAAA,KAAAthB,CAAA,EAAA,OAA+B7F,EAAO,iBAAKmnB,EAAA,MAAA,EAAA,MAAsB1Y,EAAAA,eAAQ,CAAsB,MAAA0Y,EAAA,MAAA,SAAAnnB,EAAA,SAK/F,WAAAA,EAAA,UAAA,CAAA,gIASDF,EAAA,mBAAA,MAAA,CACR,IAAK,EAA4B,MAAA8T,EAAAA,eAAA,CAAA5T,EAAA,cAAAqR,EAAAqC,EAAA,MAAA,CAAA,CAAA,EAAkB,MAAAjF,EAAAA,eAAA,CAAA,SAAAzO,EAAA,kCAS/C,EAAOof,EAyBE,gBAAA1L,EAAA,QAAA,KAAA1T,EAAA,SAAAqR,EAAAqC,EAAA,MAAA,EAAArC,CAAA,EAAA,CAAA,EAAA,CAAA,EAxBlB,QAAAgC,EAAA,QAAA,IAAA,CAAArT,EAAA,YAAA,OAuBwB,iBAAAE,EAAA,YAAAmnB,EAAA,CAAA,IAAA,GAAA,CApBqB,QAAAhU,EAAA,QAAA,IAAA,CAmBlBhU,EAAA,YAAAioB,EAAA,KAAA,CAAA,QAAAjU,EAAA,QAAA,IAAA,cAlBf,EAAK,EAAAvT,EAAA,mBAAAwT,WAAA,KAAAC,EAAA,WAAAvT,EAAA,YAAA,CAAA0mB,EAAA/sB,KACLsG,EAAO,UAAA,EAAAC,EAAA,YAAAqnB,EAAA,CACZ,IAAK5tB,EAAA,MAAAA,QAAyF8U,EAAAA,eAAiB,CAA+C,gBAAAzO,EAAA,oBAAgD,UAAA0mB,EAAA,WAAA,SAAA,MAAAA,EAAA,8CAQvM,QAAArT,EAAA,QAAA,IAAA,CACAiF,EAAAA,mBAAA,MAAA,CAAwB,MAAQ1E,EAAAA,eAAA,CAAA5T,EAAA,cAAA0mB,EAAA,MAAAA,EAAA,MAAA,CAAA,CAAA,EAAsB,MAAUjY,EAAAA,eAAA,CAAA,SAAAzO,EAAA,yUC1G3E,MAAAwnB,GAAYjnB,uDAAiB,ECyC7BknB,GAAqB,CAChC,GAAGj1B,EACH,QAAS,KACT,KAAM,CAAC,EACP,KAAM,KACN,QAAS,KACT,KAAM,UACN,MAAO,QACP,OAAQ,QACR,gBAAiB,GACjB,sBAAuB,YACvB,mBAAoB,GACpB,yBAA0B,YAC1B,YAAa,GACb,YAAa,GACb,aAAc,GACd,eAAgB,UAChB,cAAe,GACf,UAAW,GACX,aAAc,GACd,cAAe,OACf,QAAS,EACT,QAAS,GACT,UAAW,GACX,iBAAkB,GAClB,WAAY,GACZ,eAAgB,MAChB,sBAAuB,OACvB,wBAAyB,OACzB,wBAAyB,EACzB,wBAAyB,GACzB,0BAA2B,EAC3B,0BAA2B,EAC3B,uBAAwB,EACxB,oBAAqB,GACrB,sBAAuB,OACvB,8BAA+B,OAC/B,gCAAiC,OACjC,YAAa,GACb,sBAAuB,GACvB,iBAAkB,KACpB,EAEak1B,GAAoB9mB,EAA0B6mB,EAAQ,EC5DnE/N,GAAAA,IAAI,CACFC,GAAA,eACAgO,GAAA,SACA1K,GAAA,aACA2K,EAAA,mBACA7N,EAAA,iBACA8N,EAAA,gBACF,CAAC,EACD,MAAAC,GAAev1B,kBAAgB,CAC7B,KAAM,UACN,WAAY,CACV,QAAAD,EACF,EACA,MAAO,CACL,GAAGo1B,EACL,EACA,MAAOl1B,EAAO,CACZ,MAAMqa,EAAQ5L,EAAsBzO,EAAO,CAAC,iBAAiB,CAAC,EACxDu1B,EAAwBrlB,EAAAA,MACxBslB,EAAuBz2B,EAAAA,SAAS,IAAM0V,GAAazU,EAAM,kBAA4B,CAAC,EACtFy1B,EAAoB12B,EAAAA,SAAS,IAAM0V,GAAazU,EAAM,eAAyB,CAAC,EAChF01B,EAAY32B,EAAAA,SAAS,IACDiB,EAAM,mBAErB,CACL,MAAOhB,QAAMu2B,CAAqB,EAClC,OAAQv1B,EAAM,wBAAA,EAGXA,EAAM,qBACd,EACK21B,EAAS52B,EAAAA,SAAS,IAAM,CAC5B,MAAM62B,EAAc51B,EAAM,YAC1B,OAAIA,EAAM,YACD,WAAayU,GAAamhB,CAAW,EAEvC,QAAA,CACR,EACK90B,EAAS/B,EAAAA,SAAS,IAAM,CAC5B,MAAM82B,EAAY71B,EAAM,UACpB,IAAA81B,EACJ,OAAI,OAAOD,GAAc,UAAYA,IAAc,KACxCC,EAAAD,EAAU,MAAM,GAAG,GAEvB,CAEL,QAAS,CACP,KAAM,EACR,EACA,QAAS,CACP,CACE,KAAM,QACN,MAAO,CACL,MAAO,WAAW71B,EAAM,KAAe,EACvC,OAAQ,WAAWA,EAAM,MAAgB,EACzC,MAAOhB,QAAMy2B,CAAiB,CAChC,EACA,IAAK,QACP,CACF,EACA,IAAK,CACH,KAAMz1B,EAAM,QACZ,KAAMA,EAAM,QACZ,OAAA81B,EACA,IAAK,MACL,QAAS,CACP,KAAM,EACR,EACA,MAAO,CACL,KAAM91B,EAAM,aACZ,MAAOA,EAAM,cACb,SAAUA,EAAM,gBAClB,EACA,UAAW,CACT,UAAWhB,QAAM02B,CAAS,EAC1B,YAAa11B,EAAM,wBACnB,YAAaA,EAAM,wBACnB,YAAaA,EAAM,wBACnB,WAAYA,EAAM,uBAClB,cAAeA,EAAM,0BACrB,cAAeA,EAAM,yBACvB,EACA,SAAU,CACR,SAAUA,EAAM,oBAChB,MAAO,CACL,MAAOA,EAAM,qBACf,EACA,UAAW,CACT,UAAWA,EAAM,8BACjB,YAAaA,EAAM,+BACrB,CACF,CACF,EACA,OAAQ,CACN,CACE,KAAM,UACN,iBAAkB,MAClB,UAAW,CACT,MAAOA,EAAM,cACf,EACA,OAAQhB,QAAM22B,CAAM,EACpB,WAAY,CAAC31B,EAAM,YAAaA,EAAM,YAAY,EAClD,MAAO,CACL,KAAMA,EAAM,UACZ,SAAUA,EAAM,cAChB,UAAWA,EAAM,eACjB,MAAOA,EAAM,UACf,EACA,QAAS,CACP,KAAMA,EAAM,YACZ,UAAWA,EAAM,iBACjB,UAAW,CACT,MAAOA,EAAM,qBACf,CACF,EACA,KAAMA,EAAM,IACd,CACF,CAAA,CACF,CACD,EAEK+1B,EAAe7lB,MAAI,EAAK,EACxB8lB,EAAoB,SAAY,OACpC,MAAMC,EAAUj2B,EAAM,QAClB,GAAAi2B,GAAW,MAAQA,EAAQ,KAAM,CAEnC,MAAMliB,EAAM,MAAMkB,KAAQ5F,EAAA,2BAAQ,SAAR,YAAAA,EAAgB,YAAa4mB,EAAQ,IAAI,EACnEC,GAAAA,YAAY,OAAQniB,GAAA,YAAAA,EAAK,OAAQ,CAAU,CAAA,CAC7C,CACAgiB,EAAa,MAAQ,EAAA,EAEjB93B,OAAAA,QAAA,IAAM+B,EAAM,QAAS,IAAM,CACbg2B,GAAA,EACjB,CACD,UAAW,GACX,KAAM,EAAA,CACP,EACM,CACL,OAAAl1B,EACA,MAAAuZ,EACA,aAAA0b,EACA,sBAAAR,EACA,qBAAAC,CAAA,CAEJ,CACF,CAAC,oDA1KCnoB,mBAYM,SAAA,SAZsBI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,iBAEzB2O,EAAAA,eAAYzO,EAAA,KAAA,CAAA,EAAA,+BACHE,EAAAA,YAAAib,EAAA,CACd,IAAA,EACD,OAAAnb,EAAA,OAAA,iBAAA,CAAA,SAAA,EAAA,eAEF,EAAA,KAAA,EAAA,CAAA,QAAA,CAAA,GACEyT,qBAAI,GAAuB,EAAA,EAAAkV,EAAA,eAErBrQ,EAAoB,mBAAA,MAAA,CAAA,IAAA,wBADlB,IAAAtY,EAAA,oBAAA,EAAA,KAAA,EAAAD,EAAA,EAAA,oBCRD,MAAA6oB,GAAUroB,uDAAe,uvDCYvB5G,GAAA,CACb,QAbe+G,GAAa,CAC5B,OAAO,KAAKmoB,EAAU,EAAE,QAAe/2B,GAAA,CAC/B,MAAAovB,EAAY2H,GAAW/2B,CAAG,EAC5BovB,EAAU,SACZxgB,EAAI,IAAIwgB,CAAS,CACnB,CACD,CACH,CAOA"}
|
|
1
|
+
{"version":3,"file":"index.umd.js","sources":["../src/common/echarts/composables/api.ts","../src/common/echarts/composables/autoresize.ts","../src/common/echarts/composables/loading.ts","../src/common/echarts/utils.ts","../src/common/echarts/Echarts.ts","../node_modules/@ctrl/tinycolor/dist/module/util.js","../node_modules/@ctrl/tinycolor/dist/module/conversion.js","../node_modules/@ctrl/tinycolor/dist/module/css-color-names.js","../node_modules/@ctrl/tinycolor/dist/module/format-input.js","../node_modules/@ant-design/colors/dist/index.esm.js","../node_modules/@ant-design/icons-vue/es/insert-css.js","../node_modules/@ant-design/icons-vue/es/utils.js","../node_modules/@ant-design/icons-vue/es/components/IconBase.js","../node_modules/@ant-design/icons-vue/es/components/twoTonePrimaryColor.js","../node_modules/@ant-design/icons-vue/es/components/AntdIcon.js","../node_modules/@ant-design/icons-svg/es/asn/LoadingOutlined.js","../node_modules/@ant-design/icons-vue/es/icons/LoadingOutlined.js","../src/common/spin/Spin.vue","../src/common/skeleton/Skeleton.vue","../node_modules/@vue/shared/dist/shared.esm-bundler.js","../src/utils/withInstall.ts","../src/utils/props.ts","../src/setting/page-config/props.ts","../src/hooks/usePickComponentStyle.ts","../src/utils/constant.ts","../src/hooks/useOnEvent.ts","../src/hooks/useEmitEvent.ts","../src/hooks/useTransformChartDataByAttrValue.ts","../src/utils/util.ts","../src/hooks/useVariablesInText.ts","../src/hooks/useRequestData.ts","../src/hooks/useTransformChartDataByAttrKey.ts","../src/hooks/useImagePath.ts","../src/hooks/usePageUrl.ts","../src/utils/request.ts","../src/hooks/useRequestDiagramData.ts","../src/hooks/useValueFormatter.ts","../src/hooks/useIndicatorData.ts","../src/hooks/useHrefParamsToGlobalVariables.ts","../src/setting/page-config/PageConfig.vue","../src/setting/page-config/index.ts","../src/setting/provider-config/props.ts","../src/setting/provider-config/ProviderConfig.vue","../src/setting/provider-config/index.ts","../src/text/text/props.ts","../src/assets/go-up.png","../src/assets/go-down.png","../src/text/text/Text.vue","../src/text/text/index.ts","../src/text/scroll-text/ScrollText.vue","../src/text/scroll-text/index.ts","../src/text/time-display/props.ts","../src/text/time-display/TimeDisplay.vue","../src/text/time-display/index.ts","../src/text/list/props.ts","../src/text/list/List.vue","../src/text/list/index.ts","../src/text/proportion/props.ts","../src/text/proportion/Proportion.vue","../src/text/proportion/index.ts","../src/control/input/props.ts","../src/control/input/Input.vue","../src/control/input/index.ts","../src/control/date-picker/props.ts","../src/control/date-picker/DatePicker.vue","../src/control/date-picker/index.ts","../src/control/select/props.ts","../src/control/select/Select.vue","../src/control/select/index.ts","../src/control/range-picker/props.ts","../src/control/range-picker/RangePicker.vue","../src/control/range-picker/index.ts","../src/control/button/props.ts","../src/control/button/Button.vue","../src/control/button/index.ts","../src/control/checkbox/props.ts","../src/control/checkbox/Checkbox.vue","../src/control/checkbox/index.ts","../src/graph/pie/props.ts","../src/hooks/useDownloadFile.ts","../src/graph/pie/Pie.vue","../src/graph/pie/index.ts","../src/graph/line/props.ts","../src/graph/line/Line.vue","../src/graph/line/index.ts","../src/graph/bar/props.ts","../src/graph/bar/Bar.vue","../src/graph/bar/index.ts","../src/graph/scatter/props.ts","../src/graph/scatter/Scatter.vue","../src/graph/scatter/index.ts","../src/graph/custom-graph/props.ts","../src/graph/custom-graph/CustomGraph.vue","../src/graph/custom-graph/index.ts","../src/graph/combo-graph/props.ts","../src/graph/combo-graph/ComboGraph.vue","../src/graph/combo-graph/index.ts","../src/container/border/props.ts","../src/container/border/Border.vue","../src/assets/border-title-decoration-left.png","../src/assets/border-title-decoration-right.png","../src/container/border/index.ts","../src/container/modal/props.ts","../src/container/modal/Modal.vue","../src/container/modal/index.ts","../src/container/tabs/props.ts","../src/container/tabs/Tabs.vue","../src/container/tabs/index.ts","../src/media/image/props.ts","../src/media/image/Image.vue","../src/media/image/index.ts","../src/media/iframe/props.ts","../src/media/iframe/Iframe.vue","../src/media/iframe/index.ts","../src/table/table/props.ts","../src/table/table/Table.vue","../src/table/table/index.ts","../src/map/map/props.ts","../src/map/map/Map.vue","../src/map/map/index.ts","../src/index.ts"],"sourcesContent":["import { Ref } from 'vue'\nimport { EChartsType, Option } from '../types'\n\nconst METHOD_NAMES = [\n 'getWidth',\n 'getHeight',\n 'getDom',\n 'getOption',\n 'resize',\n 'dispatchAction',\n 'convertToPixel',\n 'convertFromPixel',\n 'containPixel',\n 'getDataURL',\n 'getConnectedDataURL',\n 'appendData',\n 'clear',\n 'isDisposed',\n 'dispose'\n] as const\ntype MethodName = typeof METHOD_NAMES[number];\n\ntype PublicMethods = Pick<EChartsType, MethodName>;\n\nexport function usePublicAPI (\n chart: Ref<EChartsType | undefined>,\n init: (option?: Option) => void\n): PublicMethods {\n function makePublicMethod<T extends MethodName> (\n name: T\n ): (...args: Parameters<EChartsType[T]>) => ReturnType<EChartsType[T]> {\n return (...args) => {\n if (!chart.value) {\n init()\n }\n\n if (!chart.value) {\n throw new Error('ECharts is not initialized yet.')\n }\n return (chart.value[name] as any).apply(chart.value, args)\n }\n }\n\n function makePublicMethods (): PublicMethods {\n const methods = Object.create(null)\n METHOD_NAMES.forEach(name => {\n methods[name] = makePublicMethod(name)\n })\n\n return methods as PublicMethods\n }\n\n return makePublicMethods()\n}\n","import { Ref, watch } from 'vue'\nimport { throttle } from 'echarts/core'\nimport { addListener, removeListener, ResizeCallback } from 'resize-detector'\nimport { EChartsType } from '../types'\n\nexport function useAutoresize (\n chart: Ref<EChartsType | undefined>,\n autoresize: Ref<boolean>,\n root: Ref<HTMLElement | undefined>\n): void {\n let resizeListener: ResizeCallback | null = null\n\n watch([root, chart, autoresize], ([root, chart, autoresize], _, cleanup) => {\n if (root && chart && autoresize) {\n resizeListener = throttle(() => {\n chart.resize()\n }, 100)\n\n addListener(root, resizeListener)\n }\n\n cleanup(() => {\n if (resizeListener && root) {\n removeListener(root, resizeListener)\n }\n })\n })\n}\n\nexport const autoresizeProps = {\n autoresize: Boolean\n}\n","import { inject, unref, computed, Ref, watchEffect } from 'vue'\nimport { EChartsType } from '../types'\n\nexport const LOADING_OPTIONS_KEY = 'ecLoadingOptions'\n\ntype UnknownRecord = Record<string, unknown>;\n\nexport function useLoading (\n chart: Ref<EChartsType | undefined>,\n loading: Ref<boolean>,\n loadingOptions: Ref<UnknownRecord | undefined>\n): void {\n const defaultLoadingOptions = inject(LOADING_OPTIONS_KEY, {}) as\n | UnknownRecord\n | Ref<UnknownRecord>\n const realLoadingOptions = computed(() => ({\n ...unref(defaultLoadingOptions),\n ...loadingOptions?.value\n }))\n\n watchEffect(() => {\n const instance = chart.value\n if (!instance) {\n return\n }\n\n if (loading.value) {\n instance.showLoading(realLoadingOptions.value)\n } else {\n instance.hideLoading()\n }\n })\n}\n\nexport const loadingProps = {\n loading: Boolean,\n loadingOptions: Object\n}\n","type Attrs = {\n [key: string]: any\n}\n\n// Copied from\n// https://github.com/vuejs/vue-next/blob/5a7a1b8293822219283d6e267496bec02234b0bc/packages/shared/src/index.ts#L40-L41\nconst onRE = /^on[^a-z]/\nexport const isOn = (key: string): boolean => onRE.test(key)\n\nexport function omitOn (attrs: Attrs): Attrs {\n const result: Attrs = {}\n for (const key in attrs) {\n if (!isOn(key)) {\n result[key] = attrs[key]\n }\n }\n\n return result\n}\n","// 此组件为 vue-echarts\n// 文档:https://github.com/ecomfe/vue-echarts/blob/main/README.zh-Hans.md\nimport {\n defineComponent,\n unref,\n shallowRef,\n toRefs,\n watch,\n computed,\n inject,\n onMounted,\n onUnmounted,\n h,\n nextTick,\n PropType,\n watchEffect\n} from 'vue'\nimport { init as initChart } from 'echarts/core'\nimport {\n EChartsType,\n Option,\n Theme,\n ThemeInjection,\n InitOptions,\n InitOptionsInjection,\n UpdateOptions,\n UpdateOptionsInjection\n} from './types'\nimport {\n usePublicAPI,\n useAutoresize,\n autoresizeProps,\n useLoading,\n loadingProps\n} from './composables'\nimport './style.css'\nimport { omitOn } from './utils'\n\nconst TAG_NAME = 'x-vue-echarts'\nexport const THEME_KEY = 'ecTheme'\nexport const INIT_OPTIONS_KEY = 'ecInitOptions'\nexport const UPDATE_OPTIONS_KEY = 'ecUpdateOptions'\nexport { LOADING_OPTIONS_KEY } from './composables'\n\n// @ts-ignore\nexport default defineComponent({\n name: 'echarts',\n props: {\n option: Object as PropType<Option>,\n theme: {\n type: [Object, String] as PropType<Theme>\n },\n initOptions: Object as PropType<InitOptions>,\n updateOptions: Object as PropType<UpdateOptions>,\n group: String,\n manualUpdate: Boolean,\n ...autoresizeProps,\n ...loadingProps\n },\n inheritAttrs: false,\n // @ts-expect-error listeners for Vue 2 compatibility\n setup (props, { attrs, listeners }) {\n const root = shallowRef<HTMLElement>()\n const chart = shallowRef<EChartsType>()\n const manualOption = shallowRef<Option>()\n const defaultTheme = inject(THEME_KEY, null) as ThemeInjection\n const defaultInitOptions = inject(\n INIT_OPTIONS_KEY,\n null\n ) as InitOptionsInjection\n const defaultUpdateOptions = inject(\n UPDATE_OPTIONS_KEY,\n null\n ) as UpdateOptionsInjection\n\n const { autoresize, manualUpdate, loading, loadingOptions } = toRefs(props)\n\n const realOption = computed(\n () => manualOption.value || props.option || Object.create(null)\n )\n const realTheme = computed(() => props.theme || unref(defaultTheme) || {})\n const realInitOptions = computed(\n () => props.initOptions || unref(defaultInitOptions) || {}\n )\n const realUpdateOptions = computed(\n () => props.updateOptions || unref(defaultUpdateOptions) || {}\n )\n const nonEventAttrs = computed(() => omitOn(attrs))\n\n function init (option?: Option) {\n if (chart.value || !root.value) {\n return\n }\n\n const instance = (chart.value = initChart(\n root.value,\n realTheme.value,\n realInitOptions.value\n ))\n\n if (props.group) {\n instance.group = props.group\n }\n\n let realListeners = listeners\n if (!realListeners) {\n realListeners = {}\n\n Object.keys(attrs)\n .filter(key => key.indexOf('on') === 0 && key.length > 2)\n .forEach(key => {\n // onClick -> c + lick\n // onZr:click -> z + r:click\n const event = key.charAt(2).toLowerCase() + key.slice(3)\n realListeners[event] = attrs[key]\n })\n }\n\n Object.keys(realListeners).forEach(key => {\n const handler = realListeners[key] as any\n\n if (!handler) {\n return\n }\n\n if (key.indexOf('zr:') === 0) {\n instance.getZr().on(key.slice(3).toLowerCase(), handler)\n } else {\n instance.on(key.toLowerCase(), handler)\n }\n })\n\n function resize () {\n if (instance && !instance.isDisposed()) {\n // temporarily suppress errors caused by https://github.com/apache/echarts/issues/14846\n try {\n instance.resize()\n } catch (e) {\n if (e.message === \"Cannot read property 'get' of undefined\") {\n return\n }\n\n throw e\n }\n }\n }\n\n function commit () {\n instance.setOption(option || realOption.value, realUpdateOptions.value)\n }\n\n if (autoresize.value) {\n // Try to make chart fit to container in case container size\n // is changed synchronously or in already queued microtasks\n nextTick(() => {\n resize()\n commit()\n })\n } else {\n commit()\n }\n }\n\n function setOption (option: Option, updateOptions?: UpdateOptions) {\n if (props.manualUpdate) {\n manualOption.value = option\n }\n\n if (!chart.value) {\n init(option)\n } else {\n chart.value.setOption(option, updateOptions || {})\n }\n }\n\n function cleanup () {\n if (chart.value) {\n chart.value.dispose()\n chart.value = undefined\n }\n }\n\n let unwatchOption: (() => void) | null = null\n watch(\n manualUpdate,\n manualUpdate => {\n if (typeof unwatchOption === 'function') {\n unwatchOption()\n unwatchOption = null\n }\n\n if (!manualUpdate) {\n unwatchOption = watch(\n () => props.option,\n option => {\n if (!option) {\n return\n }\n if (!chart.value) {\n init()\n } else {\n chart.value.setOption(option, realUpdateOptions.value)\n }\n },\n { deep: true }\n )\n }\n },\n {\n immediate: true\n }\n )\n\n watch(\n [realTheme, realInitOptions],\n () => {\n cleanup()\n init()\n },\n {\n deep: true\n }\n )\n\n watchEffect(() => {\n if (props.group && chart.value) {\n chart.value.group = props.group\n }\n })\n\n const publicApi = usePublicAPI(chart, init)\n\n useLoading(chart, loading, loadingOptions)\n\n useAutoresize(chart, autoresize, root)\n\n onMounted(() => {\n if (props.option) {\n init()\n }\n })\n\n onUnmounted(cleanup)\n\n return {\n chart,\n root,\n setOption,\n nonEventAttrs,\n ...publicApi\n }\n },\n render () {\n const attrs = { ...this.nonEventAttrs }\n attrs.ref = 'root'\n attrs.class = attrs.class ? ['echarts'].concat(attrs.class) : 'echarts'\n return h(TAG_NAME, attrs)\n }\n})\n","/**\n * Take input from [0, n] and return it as [0, 1]\n * @hidden\n */\nexport function bound01(n, max) {\n if (isOnePointZero(n)) {\n n = '100%';\n }\n var isPercent = isPercentage(n);\n n = max === 360 ? n : Math.min(max, Math.max(0, parseFloat(n)));\n // Automatically convert percentage into number\n if (isPercent) {\n n = parseInt(String(n * max), 10) / 100;\n }\n // Handle floating point rounding errors\n if (Math.abs(n - max) < 0.000001) {\n return 1;\n }\n // Convert into [0, 1] range if it isn't already\n if (max === 360) {\n // If n is a hue given in degrees,\n // wrap around out-of-range values into [0, 360] range\n // then convert into [0, 1].\n n = (n < 0 ? (n % max) + max : n % max) / parseFloat(String(max));\n }\n else {\n // If n not a hue given in degrees\n // Convert into [0, 1] range if it isn't already.\n n = (n % max) / parseFloat(String(max));\n }\n return n;\n}\n/**\n * Force a number between 0 and 1\n * @hidden\n */\nexport function clamp01(val) {\n return Math.min(1, Math.max(0, val));\n}\n/**\n * Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1\n * <http://stackoverflow.com/questions/7422072/javascript-how-to-detect-number-as-a-decimal-including-1-0>\n * @hidden\n */\nexport function isOnePointZero(n) {\n return typeof n === 'string' && n.indexOf('.') !== -1 && parseFloat(n) === 1;\n}\n/**\n * Check to see if string passed in is a percentage\n * @hidden\n */\nexport function isPercentage(n) {\n return typeof n === 'string' && n.indexOf('%') !== -1;\n}\n/**\n * Return a valid alpha value [0,1] with all invalid values being set to 1\n * @hidden\n */\nexport function boundAlpha(a) {\n a = parseFloat(a);\n if (isNaN(a) || a < 0 || a > 1) {\n a = 1;\n }\n return a;\n}\n/**\n * Replace a decimal with it's percentage value\n * @hidden\n */\nexport function convertToPercentage(n) {\n if (n <= 1) {\n return \"\".concat(Number(n) * 100, \"%\");\n }\n return n;\n}\n/**\n * Force a hex value to have 2 characters\n * @hidden\n */\nexport function pad2(c) {\n return c.length === 1 ? '0' + c : String(c);\n}\n","import { bound01, pad2 } from './util';\n// `rgbToHsl`, `rgbToHsv`, `hslToRgb`, `hsvToRgb` modified from:\n// <http://mjijackson.com/2008/02/rgb-to-hsl-and-rgb-to-hsv-color-model-conversion-algorithms-in-javascript>\n/**\n * Handle bounds / percentage checking to conform to CSS color spec\n * <http://www.w3.org/TR/css3-color/>\n * *Assumes:* r, g, b in [0, 255] or [0, 1]\n * *Returns:* { r, g, b } in [0, 255]\n */\nexport function rgbToRgb(r, g, b) {\n return {\n r: bound01(r, 255) * 255,\n g: bound01(g, 255) * 255,\n b: bound01(b, 255) * 255,\n };\n}\n/**\n * Converts an RGB color value to HSL.\n * *Assumes:* r, g, and b are contained in [0, 255] or [0, 1]\n * *Returns:* { h, s, l } in [0,1]\n */\nexport function rgbToHsl(r, g, b) {\n r = bound01(r, 255);\n g = bound01(g, 255);\n b = bound01(b, 255);\n var max = Math.max(r, g, b);\n var min = Math.min(r, g, b);\n var h = 0;\n var s = 0;\n var l = (max + min) / 2;\n if (max === min) {\n s = 0;\n h = 0; // achromatic\n }\n else {\n var d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n switch (max) {\n case r:\n h = (g - b) / d + (g < b ? 6 : 0);\n break;\n case g:\n h = (b - r) / d + 2;\n break;\n case b:\n h = (r - g) / d + 4;\n break;\n default:\n break;\n }\n h /= 6;\n }\n return { h: h, s: s, l: l };\n}\nfunction hue2rgb(p, q, t) {\n if (t < 0) {\n t += 1;\n }\n if (t > 1) {\n t -= 1;\n }\n if (t < 1 / 6) {\n return p + (q - p) * (6 * t);\n }\n if (t < 1 / 2) {\n return q;\n }\n if (t < 2 / 3) {\n return p + (q - p) * (2 / 3 - t) * 6;\n }\n return p;\n}\n/**\n * Converts an HSL color value to RGB.\n *\n * *Assumes:* h is contained in [0, 1] or [0, 360] and s and l are contained [0, 1] or [0, 100]\n * *Returns:* { r, g, b } in the set [0, 255]\n */\nexport function hslToRgb(h, s, l) {\n var r;\n var g;\n var b;\n h = bound01(h, 360);\n s = bound01(s, 100);\n l = bound01(l, 100);\n if (s === 0) {\n // achromatic\n g = l;\n b = l;\n r = l;\n }\n else {\n var q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n var p = 2 * l - q;\n r = hue2rgb(p, q, h + 1 / 3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1 / 3);\n }\n return { r: r * 255, g: g * 255, b: b * 255 };\n}\n/**\n * Converts an RGB color value to HSV\n *\n * *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1]\n * *Returns:* { h, s, v } in [0,1]\n */\nexport function rgbToHsv(r, g, b) {\n r = bound01(r, 255);\n g = bound01(g, 255);\n b = bound01(b, 255);\n var max = Math.max(r, g, b);\n var min = Math.min(r, g, b);\n var h = 0;\n var v = max;\n var d = max - min;\n var s = max === 0 ? 0 : d / max;\n if (max === min) {\n h = 0; // achromatic\n }\n else {\n switch (max) {\n case r:\n h = (g - b) / d + (g < b ? 6 : 0);\n break;\n case g:\n h = (b - r) / d + 2;\n break;\n case b:\n h = (r - g) / d + 4;\n break;\n default:\n break;\n }\n h /= 6;\n }\n return { h: h, s: s, v: v };\n}\n/**\n * Converts an HSV color value to RGB.\n *\n * *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100]\n * *Returns:* { r, g, b } in the set [0, 255]\n */\nexport function hsvToRgb(h, s, v) {\n h = bound01(h, 360) * 6;\n s = bound01(s, 100);\n v = bound01(v, 100);\n var i = Math.floor(h);\n var f = h - i;\n var p = v * (1 - s);\n var q = v * (1 - f * s);\n var t = v * (1 - (1 - f) * s);\n var mod = i % 6;\n var r = [v, q, p, p, t, v][mod];\n var g = [t, v, v, q, p, p][mod];\n var b = [p, p, t, v, v, q][mod];\n return { r: r * 255, g: g * 255, b: b * 255 };\n}\n/**\n * Converts an RGB color to hex\n *\n * Assumes r, g, and b are contained in the set [0, 255]\n * Returns a 3 or 6 character hex\n */\nexport function rgbToHex(r, g, b, allow3Char) {\n var hex = [\n pad2(Math.round(r).toString(16)),\n pad2(Math.round(g).toString(16)),\n pad2(Math.round(b).toString(16)),\n ];\n // Return a 3 character hex if possible\n if (allow3Char &&\n hex[0].startsWith(hex[0].charAt(1)) &&\n hex[1].startsWith(hex[1].charAt(1)) &&\n hex[2].startsWith(hex[2].charAt(1))) {\n return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0);\n }\n return hex.join('');\n}\n/**\n * Converts an RGBA color plus alpha transparency to hex\n *\n * Assumes r, g, b are contained in the set [0, 255] and\n * a in [0, 1]. Returns a 4 or 8 character rgba hex\n */\n// eslint-disable-next-line max-params\nexport function rgbaToHex(r, g, b, a, allow4Char) {\n var hex = [\n pad2(Math.round(r).toString(16)),\n pad2(Math.round(g).toString(16)),\n pad2(Math.round(b).toString(16)),\n pad2(convertDecimalToHex(a)),\n ];\n // Return a 4 character hex if possible\n if (allow4Char &&\n hex[0].startsWith(hex[0].charAt(1)) &&\n hex[1].startsWith(hex[1].charAt(1)) &&\n hex[2].startsWith(hex[2].charAt(1)) &&\n hex[3].startsWith(hex[3].charAt(1))) {\n return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0) + hex[3].charAt(0);\n }\n return hex.join('');\n}\n/**\n * Converts an RGBA color to an ARGB Hex8 string\n * Rarely used, but required for \"toFilter()\"\n */\nexport function rgbaToArgbHex(r, g, b, a) {\n var hex = [\n pad2(convertDecimalToHex(a)),\n pad2(Math.round(r).toString(16)),\n pad2(Math.round(g).toString(16)),\n pad2(Math.round(b).toString(16)),\n ];\n return hex.join('');\n}\n/** Converts a decimal to a hex value */\nexport function convertDecimalToHex(d) {\n return Math.round(parseFloat(d) * 255).toString(16);\n}\n/** Converts a hex value to a decimal */\nexport function convertHexToDecimal(h) {\n return parseIntFromHex(h) / 255;\n}\n/** Parse a base-16 hex value into a base-10 integer */\nexport function parseIntFromHex(val) {\n return parseInt(val, 16);\n}\nexport function numberInputToObject(color) {\n return {\n r: color >> 16,\n g: (color & 0xff00) >> 8,\n b: color & 0xff,\n };\n}\n","// https://github.com/bahamas10/css-color-names/blob/master/css-color-names.json\n/**\n * @hidden\n */\nexport var names = {\n aliceblue: '#f0f8ff',\n antiquewhite: '#faebd7',\n aqua: '#00ffff',\n aquamarine: '#7fffd4',\n azure: '#f0ffff',\n beige: '#f5f5dc',\n bisque: '#ffe4c4',\n black: '#000000',\n blanchedalmond: '#ffebcd',\n blue: '#0000ff',\n blueviolet: '#8a2be2',\n brown: '#a52a2a',\n burlywood: '#deb887',\n cadetblue: '#5f9ea0',\n chartreuse: '#7fff00',\n chocolate: '#d2691e',\n coral: '#ff7f50',\n cornflowerblue: '#6495ed',\n cornsilk: '#fff8dc',\n crimson: '#dc143c',\n cyan: '#00ffff',\n darkblue: '#00008b',\n darkcyan: '#008b8b',\n darkgoldenrod: '#b8860b',\n darkgray: '#a9a9a9',\n darkgreen: '#006400',\n darkgrey: '#a9a9a9',\n darkkhaki: '#bdb76b',\n darkmagenta: '#8b008b',\n darkolivegreen: '#556b2f',\n darkorange: '#ff8c00',\n darkorchid: '#9932cc',\n darkred: '#8b0000',\n darksalmon: '#e9967a',\n darkseagreen: '#8fbc8f',\n darkslateblue: '#483d8b',\n darkslategray: '#2f4f4f',\n darkslategrey: '#2f4f4f',\n darkturquoise: '#00ced1',\n darkviolet: '#9400d3',\n deeppink: '#ff1493',\n deepskyblue: '#00bfff',\n dimgray: '#696969',\n dimgrey: '#696969',\n dodgerblue: '#1e90ff',\n firebrick: '#b22222',\n floralwhite: '#fffaf0',\n forestgreen: '#228b22',\n fuchsia: '#ff00ff',\n gainsboro: '#dcdcdc',\n ghostwhite: '#f8f8ff',\n goldenrod: '#daa520',\n gold: '#ffd700',\n gray: '#808080',\n green: '#008000',\n greenyellow: '#adff2f',\n grey: '#808080',\n honeydew: '#f0fff0',\n hotpink: '#ff69b4',\n indianred: '#cd5c5c',\n indigo: '#4b0082',\n ivory: '#fffff0',\n khaki: '#f0e68c',\n lavenderblush: '#fff0f5',\n lavender: '#e6e6fa',\n lawngreen: '#7cfc00',\n lemonchiffon: '#fffacd',\n lightblue: '#add8e6',\n lightcoral: '#f08080',\n lightcyan: '#e0ffff',\n lightgoldenrodyellow: '#fafad2',\n lightgray: '#d3d3d3',\n lightgreen: '#90ee90',\n lightgrey: '#d3d3d3',\n lightpink: '#ffb6c1',\n lightsalmon: '#ffa07a',\n lightseagreen: '#20b2aa',\n lightskyblue: '#87cefa',\n lightslategray: '#778899',\n lightslategrey: '#778899',\n lightsteelblue: '#b0c4de',\n lightyellow: '#ffffe0',\n lime: '#00ff00',\n limegreen: '#32cd32',\n linen: '#faf0e6',\n magenta: '#ff00ff',\n maroon: '#800000',\n mediumaquamarine: '#66cdaa',\n mediumblue: '#0000cd',\n mediumorchid: '#ba55d3',\n mediumpurple: '#9370db',\n mediumseagreen: '#3cb371',\n mediumslateblue: '#7b68ee',\n mediumspringgreen: '#00fa9a',\n mediumturquoise: '#48d1cc',\n mediumvioletred: '#c71585',\n midnightblue: '#191970',\n mintcream: '#f5fffa',\n mistyrose: '#ffe4e1',\n moccasin: '#ffe4b5',\n navajowhite: '#ffdead',\n navy: '#000080',\n oldlace: '#fdf5e6',\n olive: '#808000',\n olivedrab: '#6b8e23',\n orange: '#ffa500',\n orangered: '#ff4500',\n orchid: '#da70d6',\n palegoldenrod: '#eee8aa',\n palegreen: '#98fb98',\n paleturquoise: '#afeeee',\n palevioletred: '#db7093',\n papayawhip: '#ffefd5',\n peachpuff: '#ffdab9',\n peru: '#cd853f',\n pink: '#ffc0cb',\n plum: '#dda0dd',\n powderblue: '#b0e0e6',\n purple: '#800080',\n rebeccapurple: '#663399',\n red: '#ff0000',\n rosybrown: '#bc8f8f',\n royalblue: '#4169e1',\n saddlebrown: '#8b4513',\n salmon: '#fa8072',\n sandybrown: '#f4a460',\n seagreen: '#2e8b57',\n seashell: '#fff5ee',\n sienna: '#a0522d',\n silver: '#c0c0c0',\n skyblue: '#87ceeb',\n slateblue: '#6a5acd',\n slategray: '#708090',\n slategrey: '#708090',\n snow: '#fffafa',\n springgreen: '#00ff7f',\n steelblue: '#4682b4',\n tan: '#d2b48c',\n teal: '#008080',\n thistle: '#d8bfd8',\n tomato: '#ff6347',\n turquoise: '#40e0d0',\n violet: '#ee82ee',\n wheat: '#f5deb3',\n white: '#ffffff',\n whitesmoke: '#f5f5f5',\n yellow: '#ffff00',\n yellowgreen: '#9acd32',\n};\n","import { convertHexToDecimal, hslToRgb, hsvToRgb, parseIntFromHex, rgbToRgb } from './conversion';\nimport { names } from './css-color-names';\nimport { boundAlpha, convertToPercentage } from './util';\n/**\n * Given a string or object, convert that input to RGB\n *\n * Possible string inputs:\n * ```\n * \"red\"\n * \"#f00\" or \"f00\"\n * \"#ff0000\" or \"ff0000\"\n * \"#ff000000\" or \"ff000000\"\n * \"rgb 255 0 0\" or \"rgb (255, 0, 0)\"\n * \"rgb 1.0 0 0\" or \"rgb (1, 0, 0)\"\n * \"rgba (255, 0, 0, 1)\" or \"rgba 255, 0, 0, 1\"\n * \"rgba (1.0, 0, 0, 1)\" or \"rgba 1.0, 0, 0, 1\"\n * \"hsl(0, 100%, 50%)\" or \"hsl 0 100% 50%\"\n * \"hsla(0, 100%, 50%, 1)\" or \"hsla 0 100% 50%, 1\"\n * \"hsv(0, 100%, 100%)\" or \"hsv 0 100% 100%\"\n * ```\n */\nexport function inputToRGB(color) {\n var rgb = { r: 0, g: 0, b: 0 };\n var a = 1;\n var s = null;\n var v = null;\n var l = null;\n var ok = false;\n var format = false;\n if (typeof color === 'string') {\n color = stringInputToObject(color);\n }\n if (typeof color === 'object') {\n if (isValidCSSUnit(color.r) && isValidCSSUnit(color.g) && isValidCSSUnit(color.b)) {\n rgb = rgbToRgb(color.r, color.g, color.b);\n ok = true;\n format = String(color.r).substr(-1) === '%' ? 'prgb' : 'rgb';\n }\n else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.v)) {\n s = convertToPercentage(color.s);\n v = convertToPercentage(color.v);\n rgb = hsvToRgb(color.h, s, v);\n ok = true;\n format = 'hsv';\n }\n else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.l)) {\n s = convertToPercentage(color.s);\n l = convertToPercentage(color.l);\n rgb = hslToRgb(color.h, s, l);\n ok = true;\n format = 'hsl';\n }\n if (Object.prototype.hasOwnProperty.call(color, 'a')) {\n a = color.a;\n }\n }\n a = boundAlpha(a);\n return {\n ok: ok,\n format: color.format || format,\n r: Math.min(255, Math.max(rgb.r, 0)),\n g: Math.min(255, Math.max(rgb.g, 0)),\n b: Math.min(255, Math.max(rgb.b, 0)),\n a: a,\n };\n}\n// <http://www.w3.org/TR/css3-values/#integers>\nvar CSS_INTEGER = '[-\\\\+]?\\\\d+%?';\n// <http://www.w3.org/TR/css3-values/#number-value>\nvar CSS_NUMBER = '[-\\\\+]?\\\\d*\\\\.\\\\d+%?';\n// Allow positive/negative integer/number. Don't capture the either/or, just the entire outcome.\nvar CSS_UNIT = \"(?:\".concat(CSS_NUMBER, \")|(?:\").concat(CSS_INTEGER, \")\");\n// Actual matching.\n// Parentheses and commas are optional, but not required.\n// Whitespace can take the place of commas or opening paren\nvar PERMISSIVE_MATCH3 = \"[\\\\s|\\\\(]+(\".concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")\\\\s*\\\\)?\");\nvar PERMISSIVE_MATCH4 = \"[\\\\s|\\\\(]+(\".concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")[,|\\\\s]+(\").concat(CSS_UNIT, \")\\\\s*\\\\)?\");\nvar matchers = {\n CSS_UNIT: new RegExp(CSS_UNIT),\n rgb: new RegExp('rgb' + PERMISSIVE_MATCH3),\n rgba: new RegExp('rgba' + PERMISSIVE_MATCH4),\n hsl: new RegExp('hsl' + PERMISSIVE_MATCH3),\n hsla: new RegExp('hsla' + PERMISSIVE_MATCH4),\n hsv: new RegExp('hsv' + PERMISSIVE_MATCH3),\n hsva: new RegExp('hsva' + PERMISSIVE_MATCH4),\n hex3: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex6: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,\n hex4: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex8: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,\n};\n/**\n * Permissive string parsing. Take in a number of formats, and output an object\n * based on detected format. Returns `{ r, g, b }` or `{ h, s, l }` or `{ h, s, v}`\n */\nexport function stringInputToObject(color) {\n color = color.trim().toLowerCase();\n if (color.length === 0) {\n return false;\n }\n var named = false;\n if (names[color]) {\n color = names[color];\n named = true;\n }\n else if (color === 'transparent') {\n return { r: 0, g: 0, b: 0, a: 0, format: 'name' };\n }\n // Try to match string input using regular expressions.\n // Keep most of the number bounding out of this function - don't worry about [0,1] or [0,100] or [0,360]\n // Just return an object and let the conversion functions handle that.\n // This way the result will be the same whether the tinycolor is initialized with string or object.\n var match = matchers.rgb.exec(color);\n if (match) {\n return { r: match[1], g: match[2], b: match[3] };\n }\n match = matchers.rgba.exec(color);\n if (match) {\n return { r: match[1], g: match[2], b: match[3], a: match[4] };\n }\n match = matchers.hsl.exec(color);\n if (match) {\n return { h: match[1], s: match[2], l: match[3] };\n }\n match = matchers.hsla.exec(color);\n if (match) {\n return { h: match[1], s: match[2], l: match[3], a: match[4] };\n }\n match = matchers.hsv.exec(color);\n if (match) {\n return { h: match[1], s: match[2], v: match[3] };\n }\n match = matchers.hsva.exec(color);\n if (match) {\n return { h: match[1], s: match[2], v: match[3], a: match[4] };\n }\n match = matchers.hex8.exec(color);\n if (match) {\n return {\n r: parseIntFromHex(match[1]),\n g: parseIntFromHex(match[2]),\n b: parseIntFromHex(match[3]),\n a: convertHexToDecimal(match[4]),\n format: named ? 'name' : 'hex8',\n };\n }\n match = matchers.hex6.exec(color);\n if (match) {\n return {\n r: parseIntFromHex(match[1]),\n g: parseIntFromHex(match[2]),\n b: parseIntFromHex(match[3]),\n format: named ? 'name' : 'hex',\n };\n }\n match = matchers.hex4.exec(color);\n if (match) {\n return {\n r: parseIntFromHex(match[1] + match[1]),\n g: parseIntFromHex(match[2] + match[2]),\n b: parseIntFromHex(match[3] + match[3]),\n a: convertHexToDecimal(match[4] + match[4]),\n format: named ? 'name' : 'hex8',\n };\n }\n match = matchers.hex3.exec(color);\n if (match) {\n return {\n r: parseIntFromHex(match[1] + match[1]),\n g: parseIntFromHex(match[2] + match[2]),\n b: parseIntFromHex(match[3] + match[3]),\n format: named ? 'name' : 'hex',\n };\n }\n return false;\n}\n/**\n * Check to see if it looks like a CSS unit\n * (see `matchers` above for definition).\n */\nexport function isValidCSSUnit(color) {\n return Boolean(matchers.CSS_UNIT.exec(String(color)));\n}\n","import { inputToRGB, rgbToHex, rgbToHsv } from '@ctrl/tinycolor';\n\nvar hueStep = 2; // 色相阶梯\n\nvar saturationStep = 0.16; // 饱和度阶梯,浅色部分\n\nvar saturationStep2 = 0.05; // 饱和度阶梯,深色部分\n\nvar brightnessStep1 = 0.05; // 亮度阶梯,浅色部分\n\nvar brightnessStep2 = 0.15; // 亮度阶梯,深色部分\n\nvar lightColorCount = 5; // 浅色数量,主色上\n\nvar darkColorCount = 4; // 深色数量,主色下\n// 暗色主题颜色映射关系表\n\nvar darkColorMap = [{\n index: 7,\n opacity: 0.15\n}, {\n index: 6,\n opacity: 0.25\n}, {\n index: 5,\n opacity: 0.3\n}, {\n index: 5,\n opacity: 0.45\n}, {\n index: 5,\n opacity: 0.65\n}, {\n index: 5,\n opacity: 0.85\n}, {\n index: 4,\n opacity: 0.9\n}, {\n index: 3,\n opacity: 0.95\n}, {\n index: 2,\n opacity: 0.97\n}, {\n index: 1,\n opacity: 0.98\n}]; // Wrapper function ported from TinyColor.prototype.toHsv\n// Keep it here because of `hsv.h * 360`\n\nfunction toHsv(_ref) {\n var r = _ref.r,\n g = _ref.g,\n b = _ref.b;\n var hsv = rgbToHsv(r, g, b);\n return {\n h: hsv.h * 360,\n s: hsv.s,\n v: hsv.v\n };\n} // Wrapper function ported from TinyColor.prototype.toHexString\n// Keep it here because of the prefix `#`\n\n\nfunction toHex(_ref2) {\n var r = _ref2.r,\n g = _ref2.g,\n b = _ref2.b;\n return \"#\".concat(rgbToHex(r, g, b, false));\n} // Wrapper function ported from TinyColor.prototype.mix, not treeshakable.\n// Amount in range [0, 1]\n// Assume color1 & color2 has no alpha, since the following src code did so.\n\n\nfunction mix(rgb1, rgb2, amount) {\n var p = amount / 100;\n var rgb = {\n r: (rgb2.r - rgb1.r) * p + rgb1.r,\n g: (rgb2.g - rgb1.g) * p + rgb1.g,\n b: (rgb2.b - rgb1.b) * p + rgb1.b\n };\n return rgb;\n}\n\nfunction getHue(hsv, i, light) {\n var hue; // 根据色相不同,色相转向不同\n\n if (Math.round(hsv.h) >= 60 && Math.round(hsv.h) <= 240) {\n hue = light ? Math.round(hsv.h) - hueStep * i : Math.round(hsv.h) + hueStep * i;\n } else {\n hue = light ? Math.round(hsv.h) + hueStep * i : Math.round(hsv.h) - hueStep * i;\n }\n\n if (hue < 0) {\n hue += 360;\n } else if (hue >= 360) {\n hue -= 360;\n }\n\n return hue;\n}\n\nfunction getSaturation(hsv, i, light) {\n // grey color don't change saturation\n if (hsv.h === 0 && hsv.s === 0) {\n return hsv.s;\n }\n\n var saturation;\n\n if (light) {\n saturation = hsv.s - saturationStep * i;\n } else if (i === darkColorCount) {\n saturation = hsv.s + saturationStep;\n } else {\n saturation = hsv.s + saturationStep2 * i;\n } // 边界值修正\n\n\n if (saturation > 1) {\n saturation = 1;\n } // 第一格的 s 限制在 0.06-0.1 之间\n\n\n if (light && i === lightColorCount && saturation > 0.1) {\n saturation = 0.1;\n }\n\n if (saturation < 0.06) {\n saturation = 0.06;\n }\n\n return Number(saturation.toFixed(2));\n}\n\nfunction getValue(hsv, i, light) {\n var value;\n\n if (light) {\n value = hsv.v + brightnessStep1 * i;\n } else {\n value = hsv.v - brightnessStep2 * i;\n }\n\n if (value > 1) {\n value = 1;\n }\n\n return Number(value.toFixed(2));\n}\n\nfunction generate(color) {\n var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var patterns = [];\n var pColor = inputToRGB(color);\n\n for (var i = lightColorCount; i > 0; i -= 1) {\n var hsv = toHsv(pColor);\n var colorString = toHex(inputToRGB({\n h: getHue(hsv, i, true),\n s: getSaturation(hsv, i, true),\n v: getValue(hsv, i, true)\n }));\n patterns.push(colorString);\n }\n\n patterns.push(toHex(pColor));\n\n for (var _i = 1; _i <= darkColorCount; _i += 1) {\n var _hsv = toHsv(pColor);\n\n var _colorString = toHex(inputToRGB({\n h: getHue(_hsv, _i),\n s: getSaturation(_hsv, _i),\n v: getValue(_hsv, _i)\n }));\n\n patterns.push(_colorString);\n } // dark theme patterns\n\n\n if (opts.theme === 'dark') {\n return darkColorMap.map(function (_ref3) {\n var index = _ref3.index,\n opacity = _ref3.opacity;\n var darkColorString = toHex(mix(inputToRGB(opts.backgroundColor || '#141414'), inputToRGB(patterns[index]), opacity * 100));\n return darkColorString;\n });\n }\n\n return patterns;\n}\n\nvar presetPrimaryColors = {\n red: '#F5222D',\n volcano: '#FA541C',\n orange: '#FA8C16',\n gold: '#FAAD14',\n yellow: '#FADB14',\n lime: '#A0D911',\n green: '#52C41A',\n cyan: '#13C2C2',\n blue: '#1890FF',\n geekblue: '#2F54EB',\n purple: '#722ED1',\n magenta: '#EB2F96',\n grey: '#666666'\n};\nvar presetPalettes = {};\nvar presetDarkPalettes = {};\nObject.keys(presetPrimaryColors).forEach(function (key) {\n presetPalettes[key] = generate(presetPrimaryColors[key]);\n presetPalettes[key].primary = presetPalettes[key][5]; // dark presetPalettes\n\n presetDarkPalettes[key] = generate(presetPrimaryColors[key], {\n theme: 'dark',\n backgroundColor: '#141414'\n });\n presetDarkPalettes[key].primary = presetDarkPalettes[key][5];\n});\nvar red = presetPalettes.red;\nvar volcano = presetPalettes.volcano;\nvar gold = presetPalettes.gold;\nvar orange = presetPalettes.orange;\nvar yellow = presetPalettes.yellow;\nvar lime = presetPalettes.lime;\nvar green = presetPalettes.green;\nvar cyan = presetPalettes.cyan;\nvar blue = presetPalettes.blue;\nvar geekblue = presetPalettes.geekblue;\nvar purple = presetPalettes.purple;\nvar magenta = presetPalettes.magenta;\nvar grey = presetPalettes.grey;\n\nexport { blue, cyan, geekblue, generate, gold, green, grey, lime, magenta, orange, presetDarkPalettes, presetPalettes, presetPrimaryColors, purple, red, volcano, yellow };\n","// https://github.com/substack/insert-css\nvar containers = []; // will store container HTMLElement references\n\nvar styleElements = []; // will store {prepend: HTMLElement, append: HTMLElement}\n\nvar usage = 'insert-css: You need to provide a CSS string. Usage: insertCss(cssString[, options]).';\n\nfunction createStyleElement() {\n var styleElement = document.createElement('style');\n styleElement.setAttribute('type', 'text/css');\n return styleElement;\n} // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n\n\nfunction insertCss(css, options) {\n options = options || {};\n\n if (css === undefined) {\n throw new Error(usage);\n }\n\n var position = options.prepend === true ? 'prepend' : 'append';\n var container = options.container !== undefined ? options.container : document.querySelector('head');\n var containerId = containers.indexOf(container); // first time we see this container, create the necessary entries\n\n if (containerId === -1) {\n containerId = containers.push(container) - 1;\n styleElements[containerId] = {};\n } // try to get the correponding container + position styleElement, create it otherwise\n\n\n var styleElement;\n\n if (styleElements[containerId] !== undefined && styleElements[containerId][position] !== undefined) {\n styleElement = styleElements[containerId][position];\n } else {\n styleElement = styleElements[containerId][position] = createStyleElement();\n\n if (position === 'prepend') {\n container.insertBefore(styleElement, container.childNodes[0]);\n } else {\n container.appendChild(styleElement);\n }\n } // strip potential UTF-8 BOM if css was read from a file\n\n\n if (css.charCodeAt(0) === 0xfeff) {\n css = css.substr(1, css.length);\n } // actually add the stylesheet\n\n\n if (styleElement.styleSheet) {\n styleElement.styleSheet.cssText += css;\n } else {\n styleElement.textContent += css;\n }\n\n return styleElement;\n}\n\nexport default insertCss;","function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? Object(arguments[i]) : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { nextTick, h } from 'vue';\nimport { generate as generateColor } from '@ant-design/colors';\nimport insertCss from './insert-css';\nexport function warn(valid, message) {\n // Support uglify\n if (process.env.NODE_ENV !== 'production' && !valid && console !== undefined) {\n console.error(\"Warning: \".concat(message));\n }\n}\nexport function warning(valid, message) {\n warn(valid, \"[@ant-design/icons-vue] \".concat(message));\n} // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n\nexport function isIconDefinition(target) {\n return typeof target === 'object' && typeof target.name === 'string' && typeof target.theme === 'string' && (typeof target.icon === 'object' || typeof target.icon === 'function');\n}\nexport function normalizeAttrs() {\n var attrs = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n return Object.keys(attrs).reduce(function (acc, key) {\n var val = attrs[key];\n\n switch (key) {\n case 'class':\n acc.className = val;\n delete acc[\"class\"];\n break;\n\n default:\n acc[key] = val;\n }\n\n return acc;\n }, {});\n}\nexport function generate(node, key, rootProps) {\n if (!rootProps) {\n return h(node.tag, _objectSpread({\n key: key\n }, node.attrs), (node.children || []).map(function (child, index) {\n return generate(child, \"\".concat(key, \"-\").concat(node.tag, \"-\").concat(index));\n }));\n }\n\n return h(node.tag, _objectSpread({\n key: key\n }, rootProps, node.attrs), (node.children || []).map(function (child, index) {\n return generate(child, \"\".concat(key, \"-\").concat(node.tag, \"-\").concat(index));\n }));\n}\nexport function getSecondaryColor(primaryColor) {\n // choose the second color\n return generateColor(primaryColor)[0];\n}\nexport function normalizeTwoToneColors(twoToneColor) {\n if (!twoToneColor) {\n return [];\n }\n\n return Array.isArray(twoToneColor) ? twoToneColor : [twoToneColor];\n} // These props make sure that the SVG behaviours like general text.\n// Reference: https://blog.prototypr.io/align-svg-icons-to-text-and-say-goodbye-to-font-icons-d44b3d7b26b4\n\nexport var svgBaseProps = {\n width: '1em',\n height: '1em',\n fill: 'currentColor',\n 'aria-hidden': 'true',\n focusable: 'false'\n};\nexport var iconStyles = \"\\n.anticon {\\n display: inline-block;\\n color: inherit;\\n font-style: normal;\\n line-height: 0;\\n text-align: center;\\n text-transform: none;\\n vertical-align: -0.125em;\\n text-rendering: optimizeLegibility;\\n -webkit-font-smoothing: antialiased;\\n -moz-osx-font-smoothing: grayscale;\\n}\\n\\n.anticon > * {\\n line-height: 1;\\n}\\n\\n.anticon svg {\\n display: inline-block;\\n}\\n\\n.anticon::before {\\n display: none;\\n}\\n\\n.anticon .anticon-icon {\\n display: block;\\n}\\n\\n.anticon[tabindex] {\\n cursor: pointer;\\n}\\n\\n.anticon-spin::before,\\n.anticon-spin {\\n display: inline-block;\\n -webkit-animation: loadingCircle 1s infinite linear;\\n animation: loadingCircle 1s infinite linear;\\n}\\n\\n@-webkit-keyframes loadingCircle {\\n 100% {\\n -webkit-transform: rotate(360deg);\\n transform: rotate(360deg);\\n }\\n}\\n\\n@keyframes loadingCircle {\\n 100% {\\n -webkit-transform: rotate(360deg);\\n transform: rotate(360deg);\\n }\\n}\\n\";\nvar cssInjectedFlag = false;\nexport var useInsertStyles = function useInsertStyles() {\n var styleStr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : iconStyles;\n nextTick(function () {\n if (!cssInjectedFlag) {\n if (typeof window !== 'undefined' && window.document && window.document.documentElement) {\n insertCss(styleStr, {\n prepend: true\n });\n }\n\n cssInjectedFlag = true;\n }\n });\n};","var _excluded = [\"icon\", \"primaryColor\", \"secondaryColor\"];\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? Object(arguments[i]) : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { generate, getSecondaryColor, isIconDefinition, warning, useInsertStyles } from '../utils';\nvar twoToneColorPalette = {\n primaryColor: '#333',\n secondaryColor: '#E6E6E6',\n calculated: false\n};\n\nfunction setTwoToneColors(_ref) {\n var primaryColor = _ref.primaryColor,\n secondaryColor = _ref.secondaryColor;\n twoToneColorPalette.primaryColor = primaryColor;\n twoToneColorPalette.secondaryColor = secondaryColor || getSecondaryColor(primaryColor);\n twoToneColorPalette.calculated = !!secondaryColor;\n}\n\nfunction getTwoToneColors() {\n return _objectSpread({}, twoToneColorPalette);\n}\n\nvar IconBase = function IconBase(props, context) {\n var _props$context$attrs = _objectSpread({}, props, context.attrs),\n icon = _props$context$attrs.icon,\n primaryColor = _props$context$attrs.primaryColor,\n secondaryColor = _props$context$attrs.secondaryColor,\n restProps = _objectWithoutProperties(_props$context$attrs, _excluded);\n\n var colors = twoToneColorPalette;\n\n if (primaryColor) {\n colors = {\n primaryColor: primaryColor,\n secondaryColor: secondaryColor || getSecondaryColor(primaryColor)\n };\n }\n\n useInsertStyles();\n warning(isIconDefinition(icon), \"icon should be icon definiton, but got \".concat(icon));\n\n if (!isIconDefinition(icon)) {\n return null;\n }\n\n var target = icon;\n\n if (target && typeof target.icon === 'function') {\n target = _objectSpread({}, target, {\n icon: target.icon(colors.primaryColor, colors.secondaryColor)\n });\n }\n\n return generate(target.icon, \"svg-\".concat(target.name), _objectSpread({}, restProps, {\n 'data-icon': target.name,\n width: '1em',\n height: '1em',\n fill: 'currentColor',\n 'aria-hidden': 'true'\n })); // },\n};\n\nIconBase.props = {\n icon: Object,\n primaryColor: String,\n secondaryColor: String,\n focusable: String\n};\nIconBase.inheritAttrs = false;\nIconBase.displayName = 'IconBase';\nIconBase.getTwoToneColors = getTwoToneColors;\nIconBase.setTwoToneColors = setTwoToneColors;\nexport default IconBase;","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\nimport VueIcon from './IconBase';\nimport { normalizeTwoToneColors } from '../utils';\nexport function setTwoToneColor(twoToneColor) {\n var _normalizeTwoToneColo = normalizeTwoToneColors(twoToneColor),\n _normalizeTwoToneColo2 = _slicedToArray(_normalizeTwoToneColo, 2),\n primaryColor = _normalizeTwoToneColo2[0],\n secondaryColor = _normalizeTwoToneColo2[1];\n\n return VueIcon.setTwoToneColors({\n primaryColor: primaryColor,\n secondaryColor: secondaryColor\n });\n}\nexport function getTwoToneColor() {\n var colors = VueIcon.getTwoToneColors();\n\n if (!colors.calculated) {\n return colors.primaryColor;\n }\n\n return [colors.primaryColor, colors.secondaryColor];\n}","var _excluded = [\"class\", \"icon\", \"spin\", \"rotate\", \"tabindex\", \"twoToneColor\", \"onClick\"];\nimport { createVNode as _createVNode } from \"vue\";\n\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? Object(arguments[i]) : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport VueIcon from './IconBase';\nimport { getTwoToneColor, setTwoToneColor } from './twoTonePrimaryColor';\nimport { normalizeTwoToneColors } from '../utils'; // Initial setting\n\nsetTwoToneColor('#1890ff');\n\nvar Icon = function Icon(props, context) {\n var _classObj;\n\n var _props$context$attrs = _objectSpread({}, props, context.attrs),\n cls = _props$context$attrs[\"class\"],\n icon = _props$context$attrs.icon,\n spin = _props$context$attrs.spin,\n rotate = _props$context$attrs.rotate,\n tabindex = _props$context$attrs.tabindex,\n twoToneColor = _props$context$attrs.twoToneColor,\n onClick = _props$context$attrs.onClick,\n restProps = _objectWithoutProperties(_props$context$attrs, _excluded);\n\n var classObj = (_classObj = {\n anticon: true\n }, _defineProperty(_classObj, \"anticon-\".concat(icon.name), Boolean(icon.name)), _defineProperty(_classObj, cls, cls), _classObj);\n var svgClassString = spin === '' || !!spin || icon.name === 'loading' ? 'anticon-spin' : '';\n var iconTabIndex = tabindex;\n\n if (iconTabIndex === undefined && onClick) {\n iconTabIndex = -1;\n restProps.tabindex = iconTabIndex;\n }\n\n var svgStyle = rotate ? {\n msTransform: \"rotate(\".concat(rotate, \"deg)\"),\n transform: \"rotate(\".concat(rotate, \"deg)\")\n } : undefined;\n\n var _normalizeTwoToneColo = normalizeTwoToneColors(twoToneColor),\n _normalizeTwoToneColo2 = _slicedToArray(_normalizeTwoToneColo, 2),\n primaryColor = _normalizeTwoToneColo2[0],\n secondaryColor = _normalizeTwoToneColo2[1];\n\n return _createVNode(\"span\", _objectSpread({\n \"role\": \"img\",\n \"aria-label\": icon.name\n }, restProps, {\n \"onClick\": onClick,\n \"class\": classObj\n }), [_createVNode(VueIcon, {\n \"class\": svgClassString,\n \"icon\": icon,\n \"primaryColor\": primaryColor,\n \"secondaryColor\": secondaryColor,\n \"style\": svgStyle\n }, null)]);\n};\n\nIcon.props = {\n spin: Boolean,\n rotate: Number,\n icon: Object,\n twoToneColor: String\n};\nIcon.displayName = 'AntdIcon';\nIcon.inheritAttrs = false;\nIcon.getTwoToneColor = getTwoToneColor;\nIcon.setTwoToneColor = setTwoToneColor;\nexport default Icon;","// This icon file is generated automatically.\nvar LoadingOutlined = { \"icon\": { \"tag\": \"svg\", \"attrs\": { \"viewBox\": \"0 0 1024 1024\", \"focusable\": \"false\" }, \"children\": [{ \"tag\": \"path\", \"attrs\": { \"d\": \"M988 548c-19.9 0-36-16.1-36-36 0-59.4-11.6-117-34.6-171.3a440.45 440.45 0 00-94.3-139.9 437.71 437.71 0 00-139.9-94.3C629 83.6 571.4 72 512 72c-19.9 0-36-16.1-36-36s16.1-36 36-36c69.1 0 136.2 13.5 199.3 40.3C772.3 66 827 103 874 150c47 47 83.9 101.8 109.7 162.7 26.7 63.1 40.2 130.2 40.2 199.3.1 19.9-16 36-35.9 36z\" } }] }, \"name\": \"loading\", \"theme\": \"outlined\" };\nexport default LoadingOutlined;\n","import { createVNode as _createVNode } from \"vue\";\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? Object(arguments[i]) : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n// GENERATE BY ./scripts/generate.ts\n// DON NOT EDIT IT MANUALLY\nimport LoadingOutlinedSvg from \"@ant-design/icons-svg/es/asn/LoadingOutlined\";\nimport AntdIcon from '../components/AntdIcon';\n\nvar LoadingOutlined = function LoadingOutlined(props, context) {\n var p = _objectSpread({}, props, context.attrs);\n\n return _createVNode(AntdIcon, _objectSpread({}, p, {\n \"icon\": LoadingOutlinedSvg\n }), null);\n};\n\nLoadingOutlined.displayName = 'LoadingOutlined';\nLoadingOutlined.inheritAttrs = false;\nexport default LoadingOutlined;","<template>\n <div class=\"spin-wrapper\">\n <a-spin\n class=\"spin\"\n :spinning=\"spinning\"\n v-if=\"spinning\"\n :indicator=\"indicator\"\n tip=\"加载中...\"\n >\n </a-spin>\n <slot v-else></slot>\n </div>\n</template>\n<script lang=\"ts\">\nimport { Spin as ASpin } from 'ant-design-vue'\nimport { LoadingOutlined } from '@ant-design/icons-vue'\nimport { defineComponent, h } from 'vue'\nimport 'ant-design-vue/es/spin/style'\nexport default defineComponent({\n props: {\n spinning: {\n type: Boolean,\n default: false\n }\n },\n components: {\n ASpin\n },\n setup () {\n const indicator = h(LoadingOutlined, {\n style: {\n fontSize: '24px',\n color: '#1890ff'\n },\n spin: true\n })\n return {\n indicator\n }\n }\n})\n</script>\n\n<style>\n.spin-wrapper {\n position: relative;\n width: 100%;\n height: 100%;\n}\n.spin {\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n}\n</style>\n","<template>\n <a-skeleton active :loading=\"loading\">\n <slot></slot>\n </a-skeleton>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent } from 'vue'\nimport { Skeleton as ASkeleton } from 'ant-design-vue'\nimport 'ant-design-vue/es/skeleton/style'\nexport default defineComponent({\n name: 'Skeleton',\n props: {\n loading: {\n type: Boolean,\n default: false\n }\n },\n components: {\n ASkeleton\n }\n})\n</script>\n\n<style scoped>\n\n</style>\n","/**\r\n * Make a map and return a function for checking if a key\r\n * is in that map.\r\n * IMPORTANT: all calls of this function must be prefixed with\r\n * \\/\\*#\\_\\_PURE\\_\\_\\*\\/\r\n * So that rollup can tree-shake them if necessary.\r\n */\r\nfunction makeMap(str, expectsLowerCase) {\r\n const map = Object.create(null);\r\n const list = str.split(',');\r\n for (let i = 0; i < list.length; i++) {\r\n map[list[i]] = true;\r\n }\r\n return expectsLowerCase ? val => !!map[val.toLowerCase()] : val => !!map[val];\r\n}\n\n/**\r\n * dev only flag -> name mapping\r\n */\r\nconst PatchFlagNames = {\r\n [1 /* TEXT */]: `TEXT`,\r\n [2 /* CLASS */]: `CLASS`,\r\n [4 /* STYLE */]: `STYLE`,\r\n [8 /* PROPS */]: `PROPS`,\r\n [16 /* FULL_PROPS */]: `FULL_PROPS`,\r\n [32 /* HYDRATE_EVENTS */]: `HYDRATE_EVENTS`,\r\n [64 /* STABLE_FRAGMENT */]: `STABLE_FRAGMENT`,\r\n [128 /* KEYED_FRAGMENT */]: `KEYED_FRAGMENT`,\r\n [256 /* UNKEYED_FRAGMENT */]: `UNKEYED_FRAGMENT`,\r\n [512 /* NEED_PATCH */]: `NEED_PATCH`,\r\n [1024 /* DYNAMIC_SLOTS */]: `DYNAMIC_SLOTS`,\r\n [2048 /* DEV_ROOT_FRAGMENT */]: `DEV_ROOT_FRAGMENT`,\r\n [-1 /* HOISTED */]: `HOISTED`,\r\n [-2 /* BAIL */]: `BAIL`\r\n};\n\n/**\r\n * Dev only\r\n */\r\nconst slotFlagsText = {\r\n [1 /* STABLE */]: 'STABLE',\r\n [2 /* DYNAMIC */]: 'DYNAMIC',\r\n [3 /* FORWARDED */]: 'FORWARDED'\r\n};\n\nconst GLOBALS_WHITE_LISTED = 'Infinity,undefined,NaN,isFinite,isNaN,parseFloat,parseInt,decodeURI,' +\r\n 'decodeURIComponent,encodeURI,encodeURIComponent,Math,Number,Date,Array,' +\r\n 'Object,Boolean,String,RegExp,Map,Set,JSON,Intl,BigInt';\r\nconst isGloballyWhitelisted = /*#__PURE__*/ makeMap(GLOBALS_WHITE_LISTED);\n\nconst range = 2;\r\nfunction generateCodeFrame(source, start = 0, end = source.length) {\r\n // Split the content into individual lines but capture the newline sequence\r\n // that separated each line. This is important because the actual sequence is\r\n // needed to properly take into account the full line length for offset\r\n // comparison\r\n let lines = source.split(/(\\r?\\n)/);\r\n // Separate the lines and newline sequences into separate arrays for easier referencing\r\n const newlineSequences = lines.filter((_, idx) => idx % 2 === 1);\r\n lines = lines.filter((_, idx) => idx % 2 === 0);\r\n let count = 0;\r\n const res = [];\r\n for (let i = 0; i < lines.length; i++) {\r\n count +=\r\n lines[i].length +\r\n ((newlineSequences[i] && newlineSequences[i].length) || 0);\r\n if (count >= start) {\r\n for (let j = i - range; j <= i + range || end > count; j++) {\r\n if (j < 0 || j >= lines.length)\r\n continue;\r\n const line = j + 1;\r\n res.push(`${line}${' '.repeat(Math.max(3 - String(line).length, 0))}| ${lines[j]}`);\r\n const lineLength = lines[j].length;\r\n const newLineSeqLength = (newlineSequences[j] && newlineSequences[j].length) || 0;\r\n if (j === i) {\r\n // push underline\r\n const pad = start - (count - (lineLength + newLineSeqLength));\r\n const length = Math.max(1, end > count ? lineLength - pad : end - start);\r\n res.push(` | ` + ' '.repeat(pad) + '^'.repeat(length));\r\n }\r\n else if (j > i) {\r\n if (end > count) {\r\n const length = Math.max(Math.min(end - count, lineLength), 1);\r\n res.push(` | ` + '^'.repeat(length));\r\n }\r\n count += lineLength + newLineSeqLength;\r\n }\r\n }\r\n break;\r\n }\r\n }\r\n return res.join('\\n');\r\n}\n\n/**\r\n * On the client we only need to offer special cases for boolean attributes that\r\n * have different names from their corresponding dom properties:\r\n * - itemscope -> N/A\r\n * - allowfullscreen -> allowFullscreen\r\n * - formnovalidate -> formNoValidate\r\n * - ismap -> isMap\r\n * - nomodule -> noModule\r\n * - novalidate -> noValidate\r\n * - readonly -> readOnly\r\n */\r\nconst specialBooleanAttrs = `itemscope,allowfullscreen,formnovalidate,ismap,nomodule,novalidate,readonly`;\r\nconst isSpecialBooleanAttr = /*#__PURE__*/ makeMap(specialBooleanAttrs);\r\n/**\r\n * The full list is needed during SSR to produce the correct initial markup.\r\n */\r\nconst isBooleanAttr = /*#__PURE__*/ makeMap(specialBooleanAttrs +\r\n `,async,autofocus,autoplay,controls,default,defer,disabled,hidden,` +\r\n `loop,open,required,reversed,scoped,seamless,` +\r\n `checked,muted,multiple,selected`);\r\n/**\r\n * Boolean attributes should be included if the value is truthy or ''.\r\n * e.g. `<select multiple>` compiles to `{ multiple: '' }`\r\n */\r\nfunction includeBooleanAttr(value) {\r\n return !!value || value === '';\r\n}\r\nconst unsafeAttrCharRE = /[>/=\"'\\u0009\\u000a\\u000c\\u0020]/;\r\nconst attrValidationCache = {};\r\nfunction isSSRSafeAttrName(name) {\r\n if (attrValidationCache.hasOwnProperty(name)) {\r\n return attrValidationCache[name];\r\n }\r\n const isUnsafe = unsafeAttrCharRE.test(name);\r\n if (isUnsafe) {\r\n console.error(`unsafe attribute name: ${name}`);\r\n }\r\n return (attrValidationCache[name] = !isUnsafe);\r\n}\r\nconst propsToAttrMap = {\r\n acceptCharset: 'accept-charset',\r\n className: 'class',\r\n htmlFor: 'for',\r\n httpEquiv: 'http-equiv'\r\n};\r\n/**\r\n * CSS properties that accept plain numbers\r\n */\r\nconst isNoUnitNumericStyleProp = /*#__PURE__*/ makeMap(`animation-iteration-count,border-image-outset,border-image-slice,` +\r\n `border-image-width,box-flex,box-flex-group,box-ordinal-group,column-count,` +\r\n `columns,flex,flex-grow,flex-positive,flex-shrink,flex-negative,flex-order,` +\r\n `grid-row,grid-row-end,grid-row-span,grid-row-start,grid-column,` +\r\n `grid-column-end,grid-column-span,grid-column-start,font-weight,line-clamp,` +\r\n `line-height,opacity,order,orphans,tab-size,widows,z-index,zoom,` +\r\n // SVG\r\n `fill-opacity,flood-opacity,stop-opacity,stroke-dasharray,stroke-dashoffset,` +\r\n `stroke-miterlimit,stroke-opacity,stroke-width`);\r\n/**\r\n * Known attributes, this is used for stringification of runtime static nodes\r\n * so that we don't stringify bindings that cannot be set from HTML.\r\n * Don't also forget to allow `data-*` and `aria-*`!\r\n * Generated from https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes\r\n */\r\nconst isKnownHtmlAttr = /*#__PURE__*/ makeMap(`accept,accept-charset,accesskey,action,align,allow,alt,async,` +\r\n `autocapitalize,autocomplete,autofocus,autoplay,background,bgcolor,` +\r\n `border,buffered,capture,challenge,charset,checked,cite,class,code,` +\r\n `codebase,color,cols,colspan,content,contenteditable,contextmenu,controls,` +\r\n `coords,crossorigin,csp,data,datetime,decoding,default,defer,dir,dirname,` +\r\n `disabled,download,draggable,dropzone,enctype,enterkeyhint,for,form,` +\r\n `formaction,formenctype,formmethod,formnovalidate,formtarget,headers,` +\r\n `height,hidden,high,href,hreflang,http-equiv,icon,id,importance,integrity,` +\r\n `ismap,itemprop,keytype,kind,label,lang,language,loading,list,loop,low,` +\r\n `manifest,max,maxlength,minlength,media,min,multiple,muted,name,novalidate,` +\r\n `open,optimum,pattern,ping,placeholder,poster,preload,radiogroup,readonly,` +\r\n `referrerpolicy,rel,required,reversed,rows,rowspan,sandbox,scope,scoped,` +\r\n `selected,shape,size,sizes,slot,span,spellcheck,src,srcdoc,srclang,srcset,` +\r\n `start,step,style,summary,tabindex,target,title,translate,type,usemap,` +\r\n `value,width,wrap`);\r\n/**\r\n * Generated from https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute\r\n */\r\nconst isKnownSvgAttr = /*#__PURE__*/ makeMap(`xmlns,accent-height,accumulate,additive,alignment-baseline,alphabetic,amplitude,` +\r\n `arabic-form,ascent,attributeName,attributeType,azimuth,baseFrequency,` +\r\n `baseline-shift,baseProfile,bbox,begin,bias,by,calcMode,cap-height,class,` +\r\n `clip,clipPathUnits,clip-path,clip-rule,color,color-interpolation,` +\r\n `color-interpolation-filters,color-profile,color-rendering,` +\r\n `contentScriptType,contentStyleType,crossorigin,cursor,cx,cy,d,decelerate,` +\r\n `descent,diffuseConstant,direction,display,divisor,dominant-baseline,dur,dx,` +\r\n `dy,edgeMode,elevation,enable-background,end,exponent,fill,fill-opacity,` +\r\n `fill-rule,filter,filterRes,filterUnits,flood-color,flood-opacity,` +\r\n `font-family,font-size,font-size-adjust,font-stretch,font-style,` +\r\n `font-variant,font-weight,format,from,fr,fx,fy,g1,g2,glyph-name,` +\r\n `glyph-orientation-horizontal,glyph-orientation-vertical,glyphRef,` +\r\n `gradientTransform,gradientUnits,hanging,height,href,hreflang,horiz-adv-x,` +\r\n `horiz-origin-x,id,ideographic,image-rendering,in,in2,intercept,k,k1,k2,k3,` +\r\n `k4,kernelMatrix,kernelUnitLength,kerning,keyPoints,keySplines,keyTimes,` +\r\n `lang,lengthAdjust,letter-spacing,lighting-color,limitingConeAngle,local,` +\r\n `marker-end,marker-mid,marker-start,markerHeight,markerUnits,markerWidth,` +\r\n `mask,maskContentUnits,maskUnits,mathematical,max,media,method,min,mode,` +\r\n `name,numOctaves,offset,opacity,operator,order,orient,orientation,origin,` +\r\n `overflow,overline-position,overline-thickness,panose-1,paint-order,path,` +\r\n `pathLength,patternContentUnits,patternTransform,patternUnits,ping,` +\r\n `pointer-events,points,pointsAtX,pointsAtY,pointsAtZ,preserveAlpha,` +\r\n `preserveAspectRatio,primitiveUnits,r,radius,referrerPolicy,refX,refY,rel,` +\r\n `rendering-intent,repeatCount,repeatDur,requiredExtensions,requiredFeatures,` +\r\n `restart,result,rotate,rx,ry,scale,seed,shape-rendering,slope,spacing,` +\r\n `specularConstant,specularExponent,speed,spreadMethod,startOffset,` +\r\n `stdDeviation,stemh,stemv,stitchTiles,stop-color,stop-opacity,` +\r\n `strikethrough-position,strikethrough-thickness,string,stroke,` +\r\n `stroke-dasharray,stroke-dashoffset,stroke-linecap,stroke-linejoin,` +\r\n `stroke-miterlimit,stroke-opacity,stroke-width,style,surfaceScale,` +\r\n `systemLanguage,tabindex,tableValues,target,targetX,targetY,text-anchor,` +\r\n `text-decoration,text-rendering,textLength,to,transform,transform-origin,` +\r\n `type,u1,u2,underline-position,underline-thickness,unicode,unicode-bidi,` +\r\n `unicode-range,units-per-em,v-alphabetic,v-hanging,v-ideographic,` +\r\n `v-mathematical,values,vector-effect,version,vert-adv-y,vert-origin-x,` +\r\n `vert-origin-y,viewBox,viewTarget,visibility,width,widths,word-spacing,` +\r\n `writing-mode,x,x-height,x1,x2,xChannelSelector,xlink:actuate,xlink:arcrole,` +\r\n `xlink:href,xlink:role,xlink:show,xlink:title,xlink:type,xml:base,xml:lang,` +\r\n `xml:space,y,y1,y2,yChannelSelector,z,zoomAndPan`);\n\nfunction normalizeStyle(value) {\r\n if (isArray(value)) {\r\n const res = {};\r\n for (let i = 0; i < value.length; i++) {\r\n const item = value[i];\r\n const normalized = isString(item)\r\n ? parseStringStyle(item)\r\n : normalizeStyle(item);\r\n if (normalized) {\r\n for (const key in normalized) {\r\n res[key] = normalized[key];\r\n }\r\n }\r\n }\r\n return res;\r\n }\r\n else if (isString(value)) {\r\n return value;\r\n }\r\n else if (isObject(value)) {\r\n return value;\r\n }\r\n}\r\nconst listDelimiterRE = /;(?![^(]*\\))/g;\r\nconst propertyDelimiterRE = /:(.+)/;\r\nfunction parseStringStyle(cssText) {\r\n const ret = {};\r\n cssText.split(listDelimiterRE).forEach(item => {\r\n if (item) {\r\n const tmp = item.split(propertyDelimiterRE);\r\n tmp.length > 1 && (ret[tmp[0].trim()] = tmp[1].trim());\r\n }\r\n });\r\n return ret;\r\n}\r\nfunction stringifyStyle(styles) {\r\n let ret = '';\r\n if (!styles || isString(styles)) {\r\n return ret;\r\n }\r\n for (const key in styles) {\r\n const value = styles[key];\r\n const normalizedKey = key.startsWith(`--`) ? key : hyphenate(key);\r\n if (isString(value) ||\r\n (typeof value === 'number' && isNoUnitNumericStyleProp(normalizedKey))) {\r\n // only render valid values\r\n ret += `${normalizedKey}:${value};`;\r\n }\r\n }\r\n return ret;\r\n}\r\nfunction normalizeClass(value) {\r\n let res = '';\r\n if (isString(value)) {\r\n res = value;\r\n }\r\n else if (isArray(value)) {\r\n for (let i = 0; i < value.length; i++) {\r\n const normalized = normalizeClass(value[i]);\r\n if (normalized) {\r\n res += normalized + ' ';\r\n }\r\n }\r\n }\r\n else if (isObject(value)) {\r\n for (const name in value) {\r\n if (value[name]) {\r\n res += name + ' ';\r\n }\r\n }\r\n }\r\n return res.trim();\r\n}\r\nfunction normalizeProps(props) {\r\n if (!props)\r\n return null;\r\n let { class: klass, style } = props;\r\n if (klass && !isString(klass)) {\r\n props.class = normalizeClass(klass);\r\n }\r\n if (style) {\r\n props.style = normalizeStyle(style);\r\n }\r\n return props;\r\n}\n\n// These tag configs are shared between compiler-dom and runtime-dom, so they\r\n// https://developer.mozilla.org/en-US/docs/Web/HTML/Element\r\nconst HTML_TAGS = 'html,body,base,head,link,meta,style,title,address,article,aside,footer,' +\r\n 'header,h1,h2,h3,h4,h5,h6,nav,section,div,dd,dl,dt,figcaption,' +\r\n 'figure,picture,hr,img,li,main,ol,p,pre,ul,a,b,abbr,bdi,bdo,br,cite,code,' +\r\n 'data,dfn,em,i,kbd,mark,q,rp,rt,ruby,s,samp,small,span,strong,sub,sup,' +\r\n 'time,u,var,wbr,area,audio,map,track,video,embed,object,param,source,' +\r\n 'canvas,script,noscript,del,ins,caption,col,colgroup,table,thead,tbody,td,' +\r\n 'th,tr,button,datalist,fieldset,form,input,label,legend,meter,optgroup,' +\r\n 'option,output,progress,select,textarea,details,dialog,menu,' +\r\n 'summary,template,blockquote,iframe,tfoot';\r\n// https://developer.mozilla.org/en-US/docs/Web/SVG/Element\r\nconst SVG_TAGS = 'svg,animate,animateMotion,animateTransform,circle,clipPath,color-profile,' +\r\n 'defs,desc,discard,ellipse,feBlend,feColorMatrix,feComponentTransfer,' +\r\n 'feComposite,feConvolveMatrix,feDiffuseLighting,feDisplacementMap,' +\r\n 'feDistanceLight,feDropShadow,feFlood,feFuncA,feFuncB,feFuncG,feFuncR,' +\r\n 'feGaussianBlur,feImage,feMerge,feMergeNode,feMorphology,feOffset,' +\r\n 'fePointLight,feSpecularLighting,feSpotLight,feTile,feTurbulence,filter,' +\r\n 'foreignObject,g,hatch,hatchpath,image,line,linearGradient,marker,mask,' +\r\n 'mesh,meshgradient,meshpatch,meshrow,metadata,mpath,path,pattern,' +\r\n 'polygon,polyline,radialGradient,rect,set,solidcolor,stop,switch,symbol,' +\r\n 'text,textPath,title,tspan,unknown,use,view';\r\nconst VOID_TAGS = 'area,base,br,col,embed,hr,img,input,link,meta,param,source,track,wbr';\r\nconst isHTMLTag = /*#__PURE__*/ makeMap(HTML_TAGS);\r\nconst isSVGTag = /*#__PURE__*/ makeMap(SVG_TAGS);\r\nconst isVoidTag = /*#__PURE__*/ makeMap(VOID_TAGS);\n\nconst escapeRE = /[\"'&<>]/;\r\nfunction escapeHtml(string) {\r\n const str = '' + string;\r\n const match = escapeRE.exec(str);\r\n if (!match) {\r\n return str;\r\n }\r\n let html = '';\r\n let escaped;\r\n let index;\r\n let lastIndex = 0;\r\n for (index = match.index; index < str.length; index++) {\r\n switch (str.charCodeAt(index)) {\r\n case 34: // \"\r\n escaped = '"';\r\n break;\r\n case 38: // &\r\n escaped = '&';\r\n break;\r\n case 39: // '\r\n escaped = ''';\r\n break;\r\n case 60: // <\r\n escaped = '<';\r\n break;\r\n case 62: // >\r\n escaped = '>';\r\n break;\r\n default:\r\n continue;\r\n }\r\n if (lastIndex !== index) {\r\n html += str.slice(lastIndex, index);\r\n }\r\n lastIndex = index + 1;\r\n html += escaped;\r\n }\r\n return lastIndex !== index ? html + str.slice(lastIndex, index) : html;\r\n}\r\n// https://www.w3.org/TR/html52/syntax.html#comments\r\nconst commentStripRE = /^-?>|<!--|-->|--!>|<!-$/g;\r\nfunction escapeHtmlComment(src) {\r\n return src.replace(commentStripRE, '');\r\n}\n\nfunction looseCompareArrays(a, b) {\r\n if (a.length !== b.length)\r\n return false;\r\n let equal = true;\r\n for (let i = 0; equal && i < a.length; i++) {\r\n equal = looseEqual(a[i], b[i]);\r\n }\r\n return equal;\r\n}\r\nfunction looseEqual(a, b) {\r\n if (a === b)\r\n return true;\r\n let aValidType = isDate(a);\r\n let bValidType = isDate(b);\r\n if (aValidType || bValidType) {\r\n return aValidType && bValidType ? a.getTime() === b.getTime() : false;\r\n }\r\n aValidType = isArray(a);\r\n bValidType = isArray(b);\r\n if (aValidType || bValidType) {\r\n return aValidType && bValidType ? looseCompareArrays(a, b) : false;\r\n }\r\n aValidType = isObject(a);\r\n bValidType = isObject(b);\r\n if (aValidType || bValidType) {\r\n /* istanbul ignore if: this if will probably never be called */\r\n if (!aValidType || !bValidType) {\r\n return false;\r\n }\r\n const aKeysCount = Object.keys(a).length;\r\n const bKeysCount = Object.keys(b).length;\r\n if (aKeysCount !== bKeysCount) {\r\n return false;\r\n }\r\n for (const key in a) {\r\n const aHasKey = a.hasOwnProperty(key);\r\n const bHasKey = b.hasOwnProperty(key);\r\n if ((aHasKey && !bHasKey) ||\r\n (!aHasKey && bHasKey) ||\r\n !looseEqual(a[key], b[key])) {\r\n return false;\r\n }\r\n }\r\n }\r\n return String(a) === String(b);\r\n}\r\nfunction looseIndexOf(arr, val) {\r\n return arr.findIndex(item => looseEqual(item, val));\r\n}\n\n/**\r\n * For converting {{ interpolation }} values to displayed strings.\r\n * @private\r\n */\r\nconst toDisplayString = (val) => {\r\n return val == null\r\n ? ''\r\n : isArray(val) ||\r\n (isObject(val) &&\r\n (val.toString === objectToString || !isFunction(val.toString)))\r\n ? JSON.stringify(val, replacer, 2)\r\n : String(val);\r\n};\r\nconst replacer = (_key, val) => {\r\n // can't use isRef here since @vue/shared has no deps\r\n if (val && val.__v_isRef) {\r\n return replacer(_key, val.value);\r\n }\r\n else if (isMap(val)) {\r\n return {\r\n [`Map(${val.size})`]: [...val.entries()].reduce((entries, [key, val]) => {\r\n entries[`${key} =>`] = val;\r\n return entries;\r\n }, {})\r\n };\r\n }\r\n else if (isSet(val)) {\r\n return {\r\n [`Set(${val.size})`]: [...val.values()]\r\n };\r\n }\r\n else if (isObject(val) && !isArray(val) && !isPlainObject(val)) {\r\n return String(val);\r\n }\r\n return val;\r\n};\n\nconst EMPTY_OBJ = (process.env.NODE_ENV !== 'production')\r\n ? Object.freeze({})\r\n : {};\r\nconst EMPTY_ARR = (process.env.NODE_ENV !== 'production') ? Object.freeze([]) : [];\r\nconst NOOP = () => { };\r\n/**\r\n * Always return false.\r\n */\r\nconst NO = () => false;\r\nconst onRE = /^on[^a-z]/;\r\nconst isOn = (key) => onRE.test(key);\r\nconst isModelListener = (key) => key.startsWith('onUpdate:');\r\nconst extend = Object.assign;\r\nconst remove = (arr, el) => {\r\n const i = arr.indexOf(el);\r\n if (i > -1) {\r\n arr.splice(i, 1);\r\n }\r\n};\r\nconst hasOwnProperty = Object.prototype.hasOwnProperty;\r\nconst hasOwn = (val, key) => hasOwnProperty.call(val, key);\r\nconst isArray = Array.isArray;\r\nconst isMap = (val) => toTypeString(val) === '[object Map]';\r\nconst isSet = (val) => toTypeString(val) === '[object Set]';\r\nconst isDate = (val) => val instanceof Date;\r\nconst isFunction = (val) => typeof val === 'function';\r\nconst isString = (val) => typeof val === 'string';\r\nconst isSymbol = (val) => typeof val === 'symbol';\r\nconst isObject = (val) => val !== null && typeof val === 'object';\r\nconst isPromise = (val) => {\r\n return isObject(val) && isFunction(val.then) && isFunction(val.catch);\r\n};\r\nconst objectToString = Object.prototype.toString;\r\nconst toTypeString = (value) => objectToString.call(value);\r\nconst toRawType = (value) => {\r\n // extract \"RawType\" from strings like \"[object RawType]\"\r\n return toTypeString(value).slice(8, -1);\r\n};\r\nconst isPlainObject = (val) => toTypeString(val) === '[object Object]';\r\nconst isIntegerKey = (key) => isString(key) &&\r\n key !== 'NaN' &&\r\n key[0] !== '-' &&\r\n '' + parseInt(key, 10) === key;\r\nconst isReservedProp = /*#__PURE__*/ makeMap(\r\n// the leading comma is intentional so empty string \"\" is also included\r\n',key,ref,ref_for,ref_key,' +\r\n 'onVnodeBeforeMount,onVnodeMounted,' +\r\n 'onVnodeBeforeUpdate,onVnodeUpdated,' +\r\n 'onVnodeBeforeUnmount,onVnodeUnmounted');\r\nconst cacheStringFunction = (fn) => {\r\n const cache = Object.create(null);\r\n return ((str) => {\r\n const hit = cache[str];\r\n return hit || (cache[str] = fn(str));\r\n });\r\n};\r\nconst camelizeRE = /-(\\w)/g;\r\n/**\r\n * @private\r\n */\r\nconst camelize = cacheStringFunction((str) => {\r\n return str.replace(camelizeRE, (_, c) => (c ? c.toUpperCase() : ''));\r\n});\r\nconst hyphenateRE = /\\B([A-Z])/g;\r\n/**\r\n * @private\r\n */\r\nconst hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, '-$1').toLowerCase());\r\n/**\r\n * @private\r\n */\r\nconst capitalize = cacheStringFunction((str) => str.charAt(0).toUpperCase() + str.slice(1));\r\n/**\r\n * @private\r\n */\r\nconst toHandlerKey = cacheStringFunction((str) => str ? `on${capitalize(str)}` : ``);\r\n// compare whether a value has changed, accounting for NaN.\r\nconst hasChanged = (value, oldValue) => !Object.is(value, oldValue);\r\nconst invokeArrayFns = (fns, arg) => {\r\n for (let i = 0; i < fns.length; i++) {\r\n fns[i](arg);\r\n }\r\n};\r\nconst def = (obj, key, value) => {\r\n Object.defineProperty(obj, key, {\r\n configurable: true,\r\n enumerable: false,\r\n value\r\n });\r\n};\r\nconst toNumber = (val) => {\r\n const n = parseFloat(val);\r\n return isNaN(n) ? val : n;\r\n};\r\nlet _globalThis;\r\nconst getGlobalThis = () => {\r\n return (_globalThis ||\r\n (_globalThis =\r\n typeof globalThis !== 'undefined'\r\n ? globalThis\r\n : typeof self !== 'undefined'\r\n ? self\r\n : typeof window !== 'undefined'\r\n ? window\r\n : typeof global !== 'undefined'\r\n ? global\r\n : {}));\r\n};\n\nexport { EMPTY_ARR, EMPTY_OBJ, NO, NOOP, PatchFlagNames, camelize, capitalize, def, escapeHtml, escapeHtmlComment, extend, generateCodeFrame, getGlobalThis, hasChanged, hasOwn, hyphenate, includeBooleanAttr, invokeArrayFns, isArray, isBooleanAttr, isDate, isFunction, isGloballyWhitelisted, isHTMLTag, isIntegerKey, isKnownHtmlAttr, isKnownSvgAttr, isMap, isModelListener, isNoUnitNumericStyleProp, isObject, isOn, isPlainObject, isPromise, isReservedProp, isSSRSafeAttrName, isSVGTag, isSet, isSpecialBooleanAttr, isString, isSymbol, isVoidTag, looseEqual, looseIndexOf, makeMap, normalizeClass, normalizeProps, normalizeStyle, objectToString, parseStringStyle, propsToAttrMap, remove, slotFlagsText, stringifyStyle, toDisplayString, toHandlerKey, toNumber, toRawType, toTypeString };\n","import { NOOP } from '@vue/shared'\nimport { Plugin } from 'vue'\n\nexport type SFCWithInstall<T> = T & Plugin\n\nexport const withInstall = <T, E extends Record<string, any>>(\n main: T,\n extra?: E\n) => {\n (main as SFCWithInstall<T>).install = (app): void => {\n for (const comp of [main, ...Object.values(extra ?? {})]) {\n app.component(comp.name, comp)\n }\n }\n\n if (extra) {\n for (const [key, comp] of Object.entries(extra)) {\n (main as any)[key] = comp\n }\n }\n return main as SFCWithInstall<T> & E\n}\n\nexport const withInstallFunction = <T>(fn: T, name: string) => {\n (fn as SFCWithInstall<T>).install = (app) => {\n app.config.globalProperties[name] = fn\n }\n\n return fn as SFCWithInstall<T>\n}\n\nexport const withNoopInstall = <T>(component: T) => {\n (component as SFCWithInstall<T>).install = NOOP\n\n return component as SFCWithInstall<T>\n}\n","import { mapValues } from 'lodash-es'\n\ninterface Event {\n // 当前组件触发什么事件类型后执行\n on: string\n // 被触发的组件id\n target: string\n // 被触发的组件:想要触发事件的类型\n emit: string\n}\n\nexport type Events = Event []\n\nexport type RequestMethod = 'get' | 'post' | 'put' | 'delete' | 'head'\n\nexport interface RequestParam {\n key: string,\n value: any\n}\n\nexport type RequestParams = RequestParam []\n\nexport interface Props {\n id: string // 组件Id,使用UUID\n name: string // 组件名称\n keyName: string // 控件\n type: string // 组件类型\n width: string // 组件宽度\n height: string // 组件高度\n position: string // 定位\n top: string // 组件左上定点x轴位置(相对于画布)\n left: string // 组件左上定点y轴位置(相对于画布)\n zIndex: number // 组件层级\n rotate: string // 旋转角度\n isShow: boolean // 是否展示\n isRender: boolean // 是否渲染\n events: Events\n requestUrl: string // 请求地址\n requestMethod: RequestMethod // 请求方式\n requestHeaders: { [key: string]: any } // 请求头部\n isOpenRequestTimer: boolean // 开启请求定时器\n requestInterval: number // 请求间隔\n requestParams: RequestParams // 请求参数\n requestSort: number, // 请求初始化优先级,越大越优先\n dataType: 'static' | 'request' | 'indicator'\n}\n\nexport const props: Props = {\n id: '',\n name: '',\n keyName: '',\n type: '',\n width: '100px',\n height: '40px',\n position: 'absolute',\n top: '0px',\n left: '0px',\n zIndex: 1,\n rotate: '0deg',\n isShow: true,\n isRender: true,\n requestUrl: '',\n requestMethod: 'get',\n requestHeaders: {},\n isOpenRequestTimer: false,\n requestInterval: 1,\n requestSort: 0,\n requestParams: [{ key: null, value: { } }],\n events: [],\n dataType: 'static'\n}\n\nexport const transformToComponentProps = <T extends {}>(props: T) => {\n // mapValues方法: 第一参数是要遍历的对象, 第二个参数是每次迭代时调用的函数\n return mapValues(props, (value) => {\n if (value == null) return {}\n return {\n type: (value as any).constructor,\n default: value\n }\n })\n}\n\nexport interface EventsProp {\n events: Events\n}\n\ninterface DataItem {\n name: string | number\n value: string | number\n type?: string\n}\n\nexport type Data = DataItem []\n\n// 数据转化映射格式\n\nexport interface KeyTypeDataFieldNames {\n name: string\n types: {\n label: string\n value: string\n } []\n}\n\nexport interface ValueTypeDataFieldNames {\n name: string\n value: string\n type: string\n}\n","import { transformToComponentProps } from '@/utils/props'\n\nexport interface PageConfig{\n width: string\n height: string\n backgroundColor: string\n backgroundImage: string\n backgroundSize: string\n contextRequestUrl: string\n mode: 'normal' | 'preview'\n}\n\n// 页面组件默认配置\nexport const pageConfig:PageConfig = {\n width: '1920px',\n height: '1080px',\n backgroundColor: '#ffffff',\n backgroundImage: '',\n backgroundSize: '100% 100%',\n contextRequestUrl: '',\n mode: 'normal'\n}\n\n// 转化默认属性\nexport const pageConfigComponentProps = transformToComponentProps(pageConfig)\n","import { computed, HTMLAttributes } from 'vue'\nimport { pick, without } from 'lodash-es'\n// 需要添加组件的 style 属性\nconst styleList = [\n 'width',\n 'height',\n 'color',\n 'position',\n 'top',\n 'left',\n 'rotate',\n 'fontSize',\n 'fontFamily',\n 'fontWeight',\n 'textDecoration',\n 'textAlign',\n 'verticalAlign',\n 'overflow',\n 'backgroundColor',\n 'backgroundImage',\n 'backgroundSize',\n 'borderWidth',\n 'borderStyle',\n 'borderRadius',\n 'borderColor',\n 'textShadow',\n 'justifyContent',\n 'alignItems',\n 'zIndex'\n]\n/**\n * 过滤不是 style 属性的组件属性\n * @param props 组件属性\n * @param excludeStyleList 剔除组件的属性\n * @returns style属性\n */\nexport const usePickComponentStyle = <T>(props: Readonly<Partial<T>>, excludeStyleList: string [] = []) => {\n // 再选择需要的组件属性\n const finalStyleList = without(styleList, ...excludeStyleList)\n return computed<HTMLAttributes>(() => pick(props, finalStyleList))\n}\n\nexport default usePickComponentStyle\n","export const EVENT_BUS = 'EVENT_BUS'\nexport const GLOBAL_CONFIG = 'GLOBAL_CONFIG'\nexport const GLOBAL_MODEL = 'GLOBAL_MODEL'\nexport const REQUEST_MODEL = 'REQUEST_MODEL'\nexport const GLOBAL_TOKEN = 'GLOBAL_TOKEN'\nexport const REFRESH_PAGE = 'REFRESH_PAGE'\n// @ts-ignore\nexport const INDICATOR_URL = window?.config?.indicatorURL\n// @ts-ignore\nexport const UPLOAD_PATH = window?.config?.uploadPath || '/api'\n// @ts-ignore\nexport const BASE_URL = window?.config?.routerBaseURL || './'\n// @ts-ignore\nexport const ERD_URL = window?.config?.erdURL || ''\n","import { watch, inject } from 'vue'\nimport { EVENT_BUS } from '@/utils/constant'\nexport const useOnEvent = <T extends { [id: string]: any}>(props: Readonly<Partial<T>>, events: { [key: string]: any }) => {\n watch(() => props.id, (id, oldId) => {\n const eventBus = inject(EVENT_BUS, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n onEvent: (i: string, e: { [key: string]: any }) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n offEvent: (i: string) => void 0\n })\n if (id != null && id !== '') {\n eventBus.onEvent(id, events)\n }\n }, {\n immediate: true\n })\n}\n\nexport default useOnEvent\n","import { inject, ref } from 'vue'\nimport { Events } from '@/utils/props'\nimport { EVENT_BUS, GLOBAL_CONFIG } from '@/utils/constant'\n/**\n * 触发事件\n * @param props 事件数据\n */\nexport const useEmitEvent = (props: { [key:string]: any }) => {\n const events = props.events as Events\n const id = props.id\n const eventBus = inject(EVENT_BUS, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n emitEvent: (id:string, type: string) => void 0\n })\n\n const { touchEventId } = inject(GLOBAL_CONFIG, {\n touchEventId: ref('')\n })\n /**\n * @param on 触发事件\n * @param callback 回调函数\n */\n return (on: string, callback: Function = () => {}) => {\n return function () {\n // 透传\n callback.call(this, ...arguments)\n if (eventBus) {\n const { emitEvent } = eventBus\n events.forEach(event => {\n if (on === event.on) {\n try {\n touchEventId.value = id\n emitEvent(event.target, event.emit)\n } catch (e) {\n console.error(e)\n }\n }\n })\n }\n }\n }\n}\n\nexport default useEmitEvent\n","import { Data, ValueTypeDataFieldNames } from '@/utils/props'\n\n/**\n * 图形转化数据\n * @param data 数据\n * @param dataFieldNames 字段映射\n */\nexport const useTransformChartDataByAttrValue = (data: Data, dataFieldNames?: ValueTypeDataFieldNames) => {\n let { name = 'name', value = 'value', type = 'type' } = dataFieldNames || {}\n // 处去字符串\n name = name?.trim()\n value = value?.trim()\n type = type?.trim()\n const set = new Set()\n const map = new Map()\n const len = data.length\n for (let i = 0; i < len; i++) {\n const item = data[i]\n // x轴\n const x = item[name] || ''\n // y轴\n const y = item[value] || ''\n // 系列(类型)\n const t = item[type] || ''\n set.add(x)\n if (map.has(t)) {\n const arr = map.get(t)\n arr.push({ name: x, value: y, ...item })\n map.set(t, arr)\n } else {\n map.set(t, [{ name: x, value: y, ...item }])\n }\n }\n const dimensions = Array.from(set)\n const dataset: { [key:string]:any } [] = []\n for (const [name, data] of map) {\n dataset.push({\n name,\n data\n })\n }\n return {\n dimensions,\n dataset\n }\n}\nexport default useTransformChartDataByAttrValue\n","export const handleAxisLabelFormatter = (formatter: string) => {\n return formatter.replace(/\\\\n/g, '\\n')\n}\n/**\n * 处理图表format, 目前只做 \\\\n => \\n 转化\n * @param formatter 格式化字符串\n */\nexport const handleFormatter = (formatter: string) => {\n return formatter.replace(/\\\\n/g, '\\n')\n}\n\n/**\n * 格式化金额\n * @param value 数值\n * @param decimalPlaces 格式化位数\n */\nexport const formatMoney = (value: string | number, decimalPlaces:number = 2) => {\n const _value = parseFloat(value + '')\n if (isNaN(_value) || _value < 0) return value\n return _value.toFixed(decimalPlaces).replace(/(\\d)(?=(\\d{3})+\\.)/g, '$1,')\n}\n\nexport const formatPercentage = (value: string | number, decimalPlaces:number = 2) => {\n const strValue = value + ''\n if (strValue.includes('%')) return value\n const _value = parseFloat(strValue)\n if (isNaN(_value)) return value\n return `${(_value * 100).toFixed(decimalPlaces)}%`\n}\n\n/**\n * 字符串1 中是否包含 字符串2 (会全部转成小写)\n * @param v1 字符串1\n * @param v2 字符串2\n * @constructor\n */\nexport const lowerCaseIncludes = (v1:any, v2:any): boolean => {\n if (typeof v1 === 'string' && typeof v2 === 'string') {\n return v1.toLocaleLowerCase().includes(v2.toLocaleLowerCase())\n }\n return false\n}\n","export const useVariablesInText = (\n formatter: string = '',\n data: { [key: string]:any } = {},\n { useNewline = false, useSpace = false } = {}\n) => {\n // 引入全局变量\n // @ts-ignore\n const config = window.config || {}\n data = { ...config, ...data }\n const variables = (formatter).match(/\\{(.+?)\\}/g)\n if (variables == null || variables.length === 0) {\n return formatter\n }\n for (let i = 0; i < variables.length; i++) {\n const variable = variables[i]\n let statement = variable.slice(1, -1)\n const reg = /[\\u4e00-\\u9fa5a-z-_A-Z]+[0-9]*/g\n const textVariables = statement.match(reg)\n for (let j = 0; j < textVariables.length; j++) {\n const textVariable = textVariables[j]\n const usedVariable = data[textVariable]\n if (usedVariable != null) {\n // 使用的变量\n statement = statement.replace(textVariable, usedVariable)\n }\n // else {\n // 过滤未使用的变量\n // statement = statement.replace(textVariable, '')\n // }\n }\n try {\n // 匹配加减乘除\n // eslint-disable-next-line no-eval\n const eval2 = eval\n statement = eval2(statement)\n } catch (e) {\n console.error(e)\n }\n formatter = formatter.replace(variable, statement)\n }\n // 替换换行\n if (useNewline) {\n formatter = formatter?.replace(/\\n|\\\\n/g, '<br/>')\n }\n // 替换空格\n if (useSpace) {\n formatter = formatter?.replace(/\\s{2,}?/g, ' ')\n }\n return formatter\n}\n\nexport default useVariablesInText\n","import { inject, onUnmounted, unref } from 'vue'\nimport axios from 'axios'\nimport { GLOBAL_MODEL, GLOBAL_CONFIG } from '@/utils/constant'\nimport { lowerCaseIncludes } from '@/utils/util'\nimport useVariablesInText from './useVariablesInText'\n// import dayjs from 'dayjs'\n\nexport const useRequestData = (props: { [key:string]: any }, callBack: Function = () => {}) => {\n const {\n requestUrl,\n requestMethod: method,\n requestHeaders: headers,\n requestParams,\n requestInterval,\n isOpenRequestTimer\n } = props\n const { contextRequestUrl, pageMode, touchEventId } = inject(GLOBAL_CONFIG, {\n contextRequestUrl: '',\n pageMode: 'normal',\n touchEventId: ''\n })\n const { getGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0\n })\n const url = useVariablesInText(requestUrl)\n const requestData = async (params: { [key: string]: any } = {}) => {\n if (!url || !method || !headers || unref(pageMode) === 'design') return\n let _params = {} as { [key: string]: any }\n requestParams.forEach((param) => {\n const { key, value } = param\n if ((typeof value === 'object' && value.id)) {\n // 传入数据可能是这样\n // {\n // key: 'record',\n // value: {\n // id: 'T7hid3K4kg7UR9Q-44u1-',\n // prop: 'record',\n // propKey: 'id'\n // }\n // }\n // 获取到组件数据\n let record = {} as { [key:string]: any }\n const { id, prop, propKey, operate } = value\n if (id === 'THIS') {\n // THIS 使用当前触发事件组件的ID\n record = getGlobalModel(unref(touchEventId)) || {}\n } else {\n record = getGlobalModel(id) || {}\n }\n const p = unref(record[prop])\n // 如果传入响应式数据优取响应式\n let v = null\n // 需要格式日期的组件\n const isNeedFormat = ['date', 'range'].some((item) => lowerCaseIncludes(record?.type, item))\n if (isNeedFormat) {\n // 操作时间\n const { value, type, mode } = operate || {}\n if (value && type && mode) {\n switch (type) {\n case 'add':\n v = unref(p).add(value, mode)\n break\n case 'minus':\n v = unref(p).subtract(value, mode)\n break\n }\n }\n if (v == null) {\n v = unref(p)\n }\n // 此时 v 是 dayjs 对象\n // 此时 propKey 是格式化值\n // 格式化时间\n v = v?.format(propKey?.trim() || record.format) || ''\n } else {\n // 因为 model[prop] 可能为 ref\n // 判断他是不是对象\n if (Object.prototype.toString.call(p) === '[object Object]') {\n v = p[propKey || 'value']\n } else {\n v = p\n }\n // v = p != null && typeof p === 'object' ? p[propKey || 'value'] : p\n }\n _params[key] = v\n } else if (typeof value === 'string') {\n _params[key] = useVariablesInText(value)\n }\n })\n // @ts-ignore\n _params = { ...window.config.requestParams, ...params, ..._params }\n let urlParams = ''\n const keys = Object.keys(_params)\n const last = keys.length - 1\n const keysLen = keys.length\n keys.forEach((key, index) => {\n if (index === 0) {\n if (keysLen !== 1) {\n urlParams += `?${key}=${_params[key]}&`\n } else {\n urlParams += `?${key}=${_params[key]}`\n }\n } else if (index === last) {\n urlParams += `${key}=${_params[key]}`\n } else {\n urlParams += `${key}=${_params[key]}&`\n }\n })\n try {\n const isSetUrlParams = ['get', 'head'].includes(method)\n const res = await axios({\n baseURL: unref(contextRequestUrl),\n url: isSetUrlParams ? url + urlParams : url,\n method,\n headers,\n data: isSetUrlParams ? {} : _params\n })\n callBack(res)\n return res\n } catch (e) {\n console.error(e)\n }\n }\n\n const requestDataTimer = isOpenRequestTimer && setInterval(requestData, requestInterval * 1000)\n\n onUnmounted(() => {\n clearInterval(requestDataTimer)\n })\n\n return requestData\n}\n\nexport default useRequestData\n","import { Data, KeyTypeDataFieldNames } from '@/utils/props'\n\n/**\n * 图形转化数据\n * @param data 数据\n * @param dataFieldNames 字段映射\n */\nexport const useTransformChartDataByAttrKey = (data: Data = [], dataFieldNames: KeyTypeDataFieldNames) => {\n let { name = 'name', types = [] } = dataFieldNames || {}\n name = name?.trim() || name\n const set = new Set()\n const map = new Map<string, any []>()\n const dataLen = data.length\n const typesLen = types.length\n // 只有一条记录\n if (dataLen === 1) {\n const vs = []\n // data 为一个值取第一个\n for (let i = 0; i < typesLen; i++) {\n const type = types[i]\n const { label, value } = type\n const v = { ...data[0], value: data[0][value] }\n set.add(label)\n // 值列表\n vs.push(v)\n }\n const n = data[0][name] || ''\n map.set(n, vs)\n } else {\n for (let i = 0; i < dataLen; i++) {\n const item = data[i]\n const x = item[name]\n set.add(x)\n for (let j = 0; j < typesLen; j++) {\n const type = types[j]\n const { label, value } = type\n const v = { ...item, value: item[value] }\n if (map.has(label)) {\n const m = map.get(label)\n m.push(v)\n map.set(label, m)\n } else {\n map.set(label, [v])\n }\n }\n }\n }\n\n const dimensions = Array.from(set)\n const dataset: { [key:string]:any } [] = []\n for (const [name, data] of map) {\n dataset.push({\n name,\n data\n })\n }\n return {\n dimensions,\n dataset\n }\n}\n\nexport default useTransformChartDataByAttrKey\n","export const useImagePath = (path:string, isFormat: boolean = false) => {\n if (!path) return path\n let imagePath: string = ''\n if (path?.includes('://')) {\n imagePath = path\n } else {\n // @ts-ignore\n imagePath = window?.config?.uploadPath + path\n }\n if (isFormat) {\n imagePath = `url(${imagePath})`\n }\n return imagePath\n}\n\nexport default useImagePath\n","import { BASE_URL } from '@/utils/constant'\nexport const usePageUrl = (pageMode: string, pageId: string) => {\n const envPageUrl = `${BASE_URL}/preview?pageId=${pageId}`\n const proPageUrl = `${BASE_URL}/${pageId}`\n return pageMode === 'preview' ? envPageUrl : proPageUrl\n}\n\nexport default usePageUrl\n","import axios from 'axios'\nimport { message } from 'ant-design-vue'\n\nexport const request = axios.create({\n // timeout: 1000 * 15\n})\nrequest.interceptors.request.use((config) => {\n return config\n}, (error) => {\n return Promise.reject(error)\n})\n\nrequest.interceptors.response.use((config) => {\n if (+config?.data?.code === 500) {\n message.error({\n content: config?.data?.msg || config?.data?.message || '服务器异常',\n key: 'SERVER_ERROR'\n })\n }\n return config\n}, (error) => {\n if (error.message.includes('timeout')) {\n message.error({\n content: '网络连接超时,请重试!',\n key: 'TIMEOUT'\n })\n } else {\n const { status } = error.response\n if (status >= 400 && status < 500) {\n message.error({\n content: '请求异常',\n key: 'REQUEST_ERROR'\n })\n }\n\n if (status >= 500) {\n message.error({\n content: '服务器异常',\n key: 'REQUEST_ERROR'\n })\n }\n }\n return Promise.reject(error)\n})\n\nexport default request\n","import { INDICATOR_URL, GLOBAL_MODEL } from '@/utils/constant'\r\nimport { inject, unref } from 'vue'\r\nimport request from '@/utils/request'\r\nimport { message } from 'ant-design-vue'\r\n\r\n/**\r\n * 请求图表数据接口\r\n * @returns {{requestDiagram: () => Promise<AxiosResponse<any>>}}\r\n */\r\nexport const useRequestDiagramData = (props) => {\r\n // 获取到组件数据\r\n const { getGlobalModel } = inject(GLOBAL_MODEL, {\r\n // @ts-ignore\r\n // eslint-disable-next-line no-void\r\n getGlobalModel: (key: string) => void 0\r\n })\r\n const getIndicatorList = (graphicConfig) => {\r\n const indicatorList = []\r\n // 左值轴、指标\r\n graphicConfig?.leftAxisList.forEach(leftAxis => {\r\n if (leftAxis) {\r\n let show = false\r\n if (graphicConfig.leftAxis.includes(leftAxis.name)) {\r\n show = true\r\n }\r\n let indicator: any = {\r\n label: leftAxis.name,\r\n columnName: leftAxis.label,\r\n aggregate: leftAxis.calcValue ? leftAxis.calcValue : 'SUM',\r\n order: null,\r\n location: 'LEFT',\r\n show: show\r\n }\r\n if (graphicConfig.source === 'INDICATOR_LIB') {\r\n indicator.hrpIndexCode = leftAxis.indexCode\r\n }\r\n indicator = getCalculationAxis(leftAxis, indicator)\r\n indicatorList.push(indicator)\r\n }\r\n })\r\n // 右值轴\r\n graphicConfig.rightAxisList.forEach(it => {\r\n let show = false\r\n if (graphicConfig.rightAxis.includes(it.name)) {\r\n show = true\r\n }\r\n let indicator: any = {\r\n label: it.name,\r\n columnName: it.label,\r\n aggregate: 'SUM',\r\n order: null,\r\n location: 'LEFT',\r\n show: show\r\n }\r\n indicator = getCalculationAxis(it, indicator)\r\n if (graphicConfig.source === 'INDICATOR_LIB') {\r\n indicator.hrpIndexCode = it.indexCode\r\n }\r\n indicatorList.push(indicator)\r\n })\r\n\r\n return indicatorList\r\n }\r\n\r\n /**\r\n * 获取计算指标\r\n * @param item\r\n * @param indicator\r\n */\r\n const getCalculationAxis = <T> (item, indicator: T): T => {\r\n const newIndicator: any = { ...indicator }\r\n if (item.calcMethod) { // 来源:新增计算指标\r\n if (item.calcMethod === 'FORMULA') { // 公式\r\n if (item.formulafuc) {\r\n newIndicator.formula = item.formulafuc\r\n }\r\n newIndicator.calcType = 'FORMULA'\r\n } else {\r\n newIndicator.builtInFormula = item.calculmethod\r\n newIndicator.calcType = 'BUILT_IN'\r\n if (item.comeFrom) {\r\n newIndicator.builtInValueSource = item.comeFrom\r\n }\r\n if (item.accessPrinciple) {\r\n newIndicator.builtInCalcWay = item.accessPrinciple\r\n }\r\n }\r\n } else { // 来源:视图拖拽\r\n // @ts-ignore\r\n newIndicator.calcType = 'COLUMN'\r\n }\r\n\r\n return newIndicator\r\n }\r\n\r\n /**\r\n * 获取查询条件\r\n * TODO 检查除日期外的特殊逻辑\r\n * @param relativeList\r\n * @returns {any[]}\r\n */\r\n const getSqlCondition = (relativeList = []) => {\r\n // 关联\r\n const list = []\r\n for (let i = 0; i < relativeList.length; i++) {\r\n const { keyName, searchName, searchType, variateName, id } = relativeList[i]\r\n const item: any = {\r\n alias: keyName,\r\n fieldName: searchName,\r\n rule: searchType || 'NONE',\r\n fieldValue: '',\r\n valueType: '',\r\n variateName\r\n }\r\n const watchItem = getGlobalModel(id) || {}\r\n if (searchName === 'the_date') {\r\n item.valueType = 'DATE'\r\n } else if (['hbdwbh', 'hbdwbh_name'].includes(searchName)) {\r\n item.valueType = 'TEXT'\r\n }\r\n if (watchItem.type === 'ecanDatePicker') {\r\n item.dateFormat = watchItem.format\r\n const formatter = unref(watchItem)?.value.format\r\n if (typeof formatter === 'function') {\r\n item.fieldValue = formatter(watchItem?.format)\r\n }\r\n }\r\n list.push(item)\r\n }\r\n return list\r\n }\r\n\r\n const getSortParams = (classification, list) => {\r\n // 分类项中的排序\r\n const classifyItem = list.find(item => {\r\n return item.name === classification.label\r\n })\r\n if (classifyItem.sort.type) {\r\n if (classifyItem.sort.type !== 'CUSTOM') {\r\n classification.sort = {\r\n label: classifyItem.sort.label,\r\n columnName: classifyItem.sort.columnName,\r\n type: 'NORMAL',\r\n order: classifyItem.sort.type\r\n }\r\n } else {\r\n classification.sort = {\r\n label: classifyItem.label,\r\n columnName: classifyItem.columnName,\r\n type: 'CUSTOM',\r\n customOrderColumns: classifyItem.sort.customOrderColumns\r\n }\r\n }\r\n }\r\n if (classifyItem.customGroup) {\r\n if (classifyItem.customGroup.groupList.length > 1) { // 0或1表示未分组\r\n classification.customGroup = {\r\n groupInfoMap: {},\r\n otherGroupName: ''\r\n }\r\n classifyItem.customGroup.groupList.forEach((row, rowIndex) => {\r\n if (rowIndex !== 0) {\r\n classification.customGroup.groupInfoMap[row.key] = row.value\r\n }\r\n })\r\n classification.customGroup.otherGroupName = classifyItem.customGroup.otherName || ''\r\n }\r\n }\r\n classification.rangeIndexTypeGuid = classifyItem.typeGuid\r\n classification.customFilterSqlPart = classifyItem.filterSql || ''\r\n }\r\n\r\n const handlerFilterParam = (parent, conditions) => {\r\n for (let i = 0; i < parent.children.length; i++) {\r\n if (parent.children[i].children.length > 0) {\r\n let join = ''\r\n if (parent.type === 'and') {\r\n join = '&&'\r\n } else {\r\n join = '||'\r\n }\r\n conditions.push({ conditions: [], join: join })\r\n handlerFilterParam(parent.children[i], conditions[conditions.length - 1].conditions)\r\n } else {\r\n if (parent.children[i].fieldName) {\r\n let fieldValue = ''\r\n const item: any = {\r\n fieldName: parent.children[i].fieldName,\r\n fieldType: parent.children[i].itemType,\r\n rule: parent.children[i].rule,\r\n fieldValue: '',\r\n label: parent.children[i].label,\r\n version: parent.children[i].version ? parent.children[i].version : 100, // 兼容图形化配置时传显示的label,之前的传字段就是100的,label版本为101\r\n targetSource: parent.children[i].targetSource ? parent.children[i].targetSource : ''\r\n }\r\n fieldValue = JSON.parse(JSON.stringify(parent.children[i].fieldValue))\r\n if (parent.children[i].itemType === 'DATE') {\r\n item.dateFormat = parent.children[i].format\r\n item.dateCalcTypes = parent.children[i].dateCalcTypes\r\n item.calcWays = parent.children[i].calcWays\r\n if (parent.children[i].selectType === 'time') { // 自定义时间\r\n if (parent.children[i].absoluteBool) { // 相对时间\r\n fieldValue = '#######'\r\n item.calcWays = parent.children[i].calcWays\r\n } else { // 取配置值\r\n // TODO\r\n // fieldValue = moment(fieldValue).format(parent.children[i].format)\r\n }\r\n } else if (parent.children[i].selectType === 'component') { // 关联控件\r\n fieldValue = '${' + parent.children[i].relateCompent + '}'\r\n }\r\n item.dateFormat = parent.children[i].format\r\n item.dateCalcTypes = parent.children[i].dateCalcTypes\r\n item.calcWays = parent.children[i].calcWays\r\n } else {\r\n if (Object.prototype.toString.call(fieldValue) === '[object Array]') { // 选中后台查询值\r\n const fieldList: any = []\r\n for (let n = 0; n < fieldValue.length; n++) {\r\n if (fieldValue[n] !== '全选') {\r\n fieldList.push(fieldValue[n])\r\n }\r\n }\r\n fieldValue = fieldList.join(',')\r\n }\r\n }\r\n item.fieldValue = fieldValue\r\n if (parent.children.length > 1 && i !== parent.children.length - 1) {\r\n if (parent.type === 'and') {\r\n item.join = '&&'\r\n } else {\r\n item.join = '||'\r\n }\r\n }\r\n conditions.push(item)\r\n }\r\n }\r\n }\r\n }\r\n\r\n // 筛选变量处理\r\n const getFilterParams = (type, list, graphicConfig) => {\r\n if (!type) {\r\n return\r\n }\r\n const classifyItem = graphicConfig[list].find(item => {\r\n return item.name === type.label\r\n })\r\n if (!classifyItem) {\r\n return\r\n }\r\n const conditions = []\r\n const filterList = classifyItem.filterList\r\n if (filterList) {\r\n for (let i = 0; i < filterList.length; i++) {\r\n if (filterList[i].children.length > 0) {\r\n handlerFilterParam(filterList[i], conditions)\r\n }\r\n }\r\n }\r\n return conditions\r\n }\r\n\r\n return async function () {\r\n const componentType = props.type\r\n let graphicConfig = props.graphicConfig\r\n if (!graphicConfig || Object.keys(graphicConfig).length === 0) {\r\n graphicConfig = {\r\n classify: [],\r\n classifyList: [],\r\n series: [],\r\n seriesList: [],\r\n leftAxis: [],\r\n leftAxisList: [],\r\n rightAxis: [],\r\n rightAxisList: [],\r\n relativeList: []\r\n }\r\n }\r\n const xAxisValue = graphicConfig.classify\r\n const yAxisValue = [...graphicConfig.leftAxis, ...graphicConfig.rightAxis]\r\n if (yAxisValue.length === 0) {\r\n message.error('当前y轴无配置信息')\r\n return\r\n }\r\n\r\n // 获取值轴参数\r\n const indicatorList = getIndicatorList(graphicConfig)\r\n // 获取系列值\r\n let series\r\n if (Array.isArray(graphicConfig.series) && graphicConfig.series.length > 0) {\r\n const seriesItem = graphicConfig.seriesList?.find(item => {\r\n const firstSeries = graphicConfig.series[0]\r\n return item.name === firstSeries || item.nameBak === firstSeries\r\n })\r\n if (seriesItem != null) {\r\n series = {\r\n label: seriesItem.name,\r\n columnName: seriesItem.label\r\n }\r\n }\r\n }\r\n // 获取分类\r\n let classification\r\n if (xAxisValue.length > 0) {\r\n classification = {\r\n label: xAxisValue[0],\r\n columnName: xAxisValue[0]\r\n }\r\n const classify = graphicConfig.classifyList?.find(item => {\r\n return item?.name === xAxisValue[0] || item?.nameBak === xAxisValue[0]\r\n }) || {}\r\n classification.columnName = classify.label\r\n // 获取排序信息\r\n getSortParams(classification, graphicConfig.classifyList)\r\n classification.conditions = getFilterParams(classification, 'classifyList', graphicConfig) || []\r\n }\r\n if (series) {\r\n // 获取排序信息\r\n getSortParams(series, graphicConfig.seriesList)\r\n series.conditions = getFilterParams(series, 'seriesList', graphicConfig) || []\r\n }\r\n\r\n for (let t = 0; t < indicatorList.length; t++) {\r\n if (indicatorList[t].location === 'RIGHT') {\r\n indicatorList[t].conditions = getFilterParams(indicatorList[t], 'rightAxisList', graphicConfig)\r\n } else {\r\n indicatorList[t].conditions = getFilterParams(indicatorList[t], 'leftAxisList', graphicConfig)\r\n }\r\n }\r\n\r\n let sqlConditions\r\n if (graphicConfig?.pageMode === 'design') {\r\n // relativeList 在设计模式下,由于联动无法直接获取,已经处理好数据直接获取\r\n sqlConditions = graphicConfig.sqlConditions ?? []\r\n } else {\r\n sqlConditions = getSqlCondition(graphicConfig?.relativeList)\r\n }\r\n let source = 'SQL_VIEW'\r\n let fixedDimSql = ''\r\n let dataSourceId = ''\r\n let idxLibMode = ''\r\n if (graphicConfig.source === 'INDICATOR_LIB') {\r\n source = 'INDICATOR_LIB'\r\n fixedDimSql = graphicConfig.fixedDimSql\r\n dataSourceId = graphicConfig.dataSourceId\r\n idxLibMode = graphicConfig.idxLibMode\r\n }\r\n\r\n const map = {\r\n ecanBar: 'bar',\r\n ecanLine: 'line',\r\n ecanPie: 'pie',\r\n ecanScatter: 'scatter'\r\n }\r\n\r\n try {\r\n const res = await request.get(`${INDICATOR_URL}/user/anonymous?username=admin`, {\r\n headers: {\r\n systemCode: 'F72FC50A3D97372514A6AC33333D28FD',\r\n current_context: 'ygt'\r\n }\r\n })\r\n\r\n return request.post(`${INDICATOR_URL}/diagram`, {\r\n dataViewId: graphicConfig.dataViewId,\r\n plugin: '1',\r\n layer: '2',\r\n chartType: map[componentType],\r\n classification,\r\n indicatorList,\r\n series,\r\n sqlConditions,\r\n source,\r\n fixedDimSql,\r\n dataSourceId,\r\n idxLibMode\r\n }, {\r\n headers: { Authentication: res.data.data.token }\r\n })\r\n } catch (e) {\r\n console.error(e)\r\n }\r\n }\r\n}\r\n\r\nexport default useRequestDiagramData\r\n","export const useValueFormatter = (formatter: string, value:string) => {\n if (formatter == null) return value\n const variables = (formatter).match(/\\{.*\\}/g)\n if (variables == null || variables.length === 0) {\n return value\n }\n const len = variables.length\n for (let i = 0; i < len; i++) {\n const variable = variables[i]\n if (variable == null || variable === '') break\n let statement = variable.slice(1, -1)\n statement = statement?.replace(/value/g, value)\n try {\n // 匹配加减乘除\n let result = statement\n if ((/[+\\-*/%]+/g).test(statement)) {\n // eslint-disable-next-line no-eval\n const eval2 = eval\n result = eval2(statement)\n }\n formatter = formatter.replace(variable, result)\n } catch (e) {\n formatter = formatter.replace(variable, statement)\n console.warn(e)\n }\n }\n return formatter\n}\n\nexport default useValueFormatter\n","import { GLOBAL_MODEL, INDICATOR_URL, GLOBAL_TOKEN } from '@/utils/constant'\nimport { lowerCaseIncludes } from '@/utils/util'\nimport request from '@/utils/request'\nimport { inject, unref } from 'vue'\n\nexport const useIndicatorData = (props: { [key:string]: any } = {}) => {\n const { requestToken } = inject(GLOBAL_TOKEN, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n requestToken: () => void 0\n })\n // 指标库模式才会发\n if (props.dataType === 'indicator') {\n // 只要调用,计数 + 1,计数大于0才会请求\n requestToken()\n }\n\n const handleQueryColumn = (queryColumn: { [key:string]: any } = {}) => {\n const { label, name, location, show, indexCode } = queryColumn\n return {\n label,\n columnName: name,\n location,\n show,\n calcType: 'COLUMN',\n hrpIndexCode: indexCode\n }\n }\n\n const handleIndicator = (indicator: { [key:string]: any } = {}) => {\n const {\n label,\n name,\n location,\n show,\n indexCode,\n calcType = 'COLUMN',\n builtInFormula,\n builtInValueSource,\n builtInCalcWay,\n formula,\n conditions\n } = indicator\n return {\n label,\n columnName: name,\n location,\n show,\n calcType,\n hrpIndexCode: indexCode,\n aggregate: 'SUM',\n builtInFormula,\n builtInValueSource,\n builtInCalcWay,\n formula,\n conditions\n }\n }\n\n const { getGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0\n })\n const handleSqlConditions = (controlList: { [key:string]: any } [] = []) => {\n const len = controlList.length\n const sqlConditions = [] as { [key:string]: any } []\n for (let i = 0; i < len; i++) {\n const control = controlList[i]\n const {\n id,\n conditionLabel,\n conditionKey,\n conditionValueType\n } = control\n const sqlCondition: { [key:string]: any } = {\n rule: 'NONE',\n label: conditionLabel,\n fieldName: conditionKey,\n fieldValue: '', // 在关联控件中取\n valueType: conditionValueType\n }\n // 获取组件属性\n const model = getGlobalModel(id) || {}\n if (lowerCaseIncludes(model.type, 'date')) {\n const { value, format } = model || {}\n sqlCondition.fieldValue = unref(value)?.format(format)\n sqlCondition.dateFormat = format\n }\n sqlConditions.push(sqlCondition)\n }\n return sqlConditions\n }\n return async () => {\n const { graphicConfig } = props\n const {\n source,\n dataViewId,\n plugin,\n layer,\n chartType,\n classificationList = [],\n seriesList = [],\n leftAxisList = [],\n rightAxisList = [],\n queryColumnList = [],\n indicators = [],\n controlList = [],\n dataSourceId,\n idxLibMode,\n preview = false\n } = graphicConfig || {}\n // console.log('classificationList', classificationList)\n // console.log('seriesList', seriesList)\n // console.log('leftAxisList', leftAxisList)\n // console.log('rightAxisList', rightAxisList)\n // console.log('indicators', indicators)\n // console.log('controlList', controlList)\n // 重点处理 classificationList、seriesList、leftAxisList、rightAxisList、indicators\n // classificationList (取第一项) => classification\n let classification\n if (Array.isArray(classificationList) && classificationList.length > 0) {\n const len = classificationList.length\n for (let i = 0; i < len; i++) {\n const item = classificationList[i] || {}\n const { label = '', name = '', show = false, sort, customGroup, conditions } = item\n // 如果是 show 直接提取 classification,停止遍历\n if (show || len === 1) {\n classification = {\n label,\n columnName: name,\n show,\n sort,\n customGroup,\n conditions\n }\n break\n }\n }\n }\n // seriesList (取第一项) => series\n let series\n if (Array.isArray(seriesList) && seriesList.length > 0) {\n const len = seriesList.length\n for (let i = 0; i < len; i++) {\n const item = seriesList[i] || {}\n const { label = '', name = '', show = false, sort, customGroup, conditions } = item\n // 如果是 show 直接提取 seriesList,停止遍历\n if (show || len === 1) {\n series = {\n label,\n columnName: name,\n show,\n sort,\n customGroup,\n conditions\n }\n break\n }\n }\n }\n // queryColumnList => queryColumns\n const queryColumns = []\n queryColumnList?.forEach((queryColumn: { [key:string]: any }) => {\n queryColumns.push(handleQueryColumn(queryColumn))\n })\n\n // leftAxisList + rightAxisList + indicators => indicatorList\n const indicatorList = []\n leftAxisList?.forEach((leftAxis: { [key:string]: any }) => {\n leftAxis.location = 'LEFT'\n indicatorList.push(handleIndicator(leftAxis))\n })\n rightAxisList?.forEach((rightAxis: { [key:string]: any }) => {\n rightAxis.location = 'RIGHT'\n indicatorList.push(handleIndicator(rightAxis))\n })\n indicators?.forEach((indicator: { [key:string]: any }) => {\n indicator.location = 'LEFT'\n indicatorList.push(handleIndicator(indicator))\n })\n if (layer === '1' && queryColumns.length === 0) {\n return\n } else if (layer === '2' && indicatorList.length === 0) {\n return\n }\n let sqlConditions\n if (graphicConfig?.pageMode === 'design') {\n // relativeList 在设计模式下,由于联动无法直接获取,已经处理好数据直接获取\n sqlConditions = graphicConfig.sqlConditions ?? []\n } else {\n sqlConditions = handleSqlConditions(controlList)\n }\n try {\n const res = await request.post(`${INDICATOR_URL}/diagram`, {\n source,\n dataViewId,\n plugin,\n layer,\n chartType,\n classification,\n series,\n indicatorList,\n queryColumns,\n pageFlag: true,\n sqlConditions,\n // fixedDimSql: '',\n dataSourceId,\n idxLibMode,\n preview\n },\n {\n headers: {\n // @ts-ignore\n Authentication: window?.config?.indicatorToken,\n operateContext: 'ygt'\n }\n })\n return res\n } catch (e) {\n console.error(e)\n }\n }\n}\n\nexport default useIndicatorData\n","export const useHrefParamsToGlobalVariables = () => {\n const search = window.location.search\n const params = search.slice(1).split('&')\n const len = params.length\n for (let i = 0; i < len; i++) {\n const param = params[i]\n if (param == null || param === '') continue\n const keyAndValue = param.split('=')\n if (Array.isArray(keyAndValue)) {\n const key = keyAndValue[0]\n const value = keyAndValue[1] as string\n (window as any).config[key] = value\n }\n }\n}\n\nexport default useHrefParamsToGlobalVariables\n","<template>\n <div id=\"container\" ref=\"container\">\n <template v-if=\"ready\">\n <div\n class=\"page-config\"\n :style=\"style\"\n >\n <slot></slot>\n </div>\n </template>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, nextTick, computed, ref, onMounted, onUnmounted } from 'vue'\nimport { debounce } from 'lodash-es'\nimport { pageConfigComponentProps } from './props'\nimport { useImagePath } from '@/hooks'\nexport default defineComponent({\n name: 'EcanPageConfig',\n inheritAttrs: false,\n props: {\n ...pageConfigComponentProps\n },\n setup (props) {\n // 大屏设计容器\n const style = computed(() => ({\n width: props.width,\n height: props.height,\n backgroundColor: props.backgroundColor,\n backgroundImage: useImagePath(props.backgroundImage as string, true),\n backgroundSize: props.backgroundSize\n }))\n const width = ref(0)\n const height = ref(0)\n const originalWidth = ref(0)\n const originalHeight = ref(0)\n const ready = ref(false)\n const container = ref()\n let observer: MutationObserver | null\n const initSize = () => {\n return new Promise<void>((resolve) => {\n nextTick(() => {\n // 获取大屏的真实尺寸\n if (props.width && props.height) {\n width.value = parseFloat(props.width)\n height.value = parseFloat(props.height)\n } else {\n width.value = container.value.clientWidth\n height.value = container.value.clientHeight\n }\n // 获取画布尺寸\n if (!originalWidth.value || !originalHeight.value) {\n originalWidth.value = window.screen.width\n originalHeight.value = window.screen.height\n }\n resolve()\n })\n })\n }\n const updateSize = () => {\n if (width.value && height.value) {\n container.value.style.width = `${width.value}px`\n container.value.style.height = `${height.value}px`\n } else {\n container.value.style.width = `${originalWidth.value}px`\n container.value.style.height = `${originalHeight.value}px`\n }\n }\n const updateScale = () => {\n // 获取真实的视口尺寸\n const currentWidth = document.body.clientWidth\n const currentHeight = document.body.clientHeight\n // 获取大屏最终的宽高\n const realWidth = width.value || originalWidth.value\n const realHeight = height.value || originalHeight.value\n const widthScale = currentWidth / realWidth\n const heightScale = currentHeight / realHeight\n container.value && (container.value.style.transform = `scale(${widthScale}, ${heightScale})`)\n }\n const onResize = async () => {\n await initSize()\n updateScale()\n }\n const initMutationObserver = () => {\n const MutationObserver = window.MutationObserver\n observer = new MutationObserver(onResize)\n observer.observe(container.value, {\n attributes: true,\n attributeFilter: ['style'],\n attributeOldValue: true\n })\n }\n const removeMutationObserver = () => {\n if (observer) {\n observer.disconnect()\n observer.takeRecords()\n observer = null\n }\n }\n onMounted(async () => {\n ready.value = false\n await initSize()\n updateSize()\n updateScale()\n window.addEventListener('resize', debounce(onResize, 100))\n initMutationObserver()\n ready.value = true\n })\n onUnmounted(() => {\n window.removeEventListener('resize', onResize)\n removeMutationObserver()\n })\n return {\n style,\n container,\n ready\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n#container {\n position: fixed;\n top: 0;\n left: 0;\n overflow: hidden;\n transform-origin: left top;\n z-index: 999;\n}\n.page-config {\n position: relative;\n overflow: hidden;\n background-size: cover;\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport PageConfig from './PageConfig.vue'\nexport const EcanPageConfig = withInstall(PageConfig)\nexport default EcanPageConfig\nexport * from './props'\n","import { transformToComponentProps } from '@/utils/props'\n\nexport interface ProviderConfig {\n contextRequestUrl: string // 请求头\n pageMode: 'normal' | 'preview' | 'design' // 普通、预览、设计模式\n theme: 'light' | 'darkBlue'\n containerMap: { [key:string]: any }\n}\n\nexport const providerConfig: ProviderConfig = {\n contextRequestUrl: '',\n pageMode: 'normal',\n theme: 'light',\n containerMap: {}\n}\n\n// 转化默认属性\nexport const providerConfigComponentProps = transformToComponentProps(providerConfig)\n","<template>\n <!-- 请勿去除属性id -->\n <div id=\"ProviderConfig\" ref=\"providerConfig\">\n <slot></slot>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, provide, ref, onMounted, watch, computed, unref, onBeforeUnmount } from 'vue'\nimport mitt from 'mitt'\nimport { EVENT_BUS, GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL, INDICATOR_URL, GLOBAL_TOKEN, REFRESH_PAGE } from '@/utils/constant'\nimport { providerConfigComponentProps } from './props'\nimport { useVariablesInText, useHrefParamsToGlobalVariables } from '@/hooks'\nimport axios from 'axios'\nimport { RequestModalParam } from '@/utils/types'\n\nexport default defineComponent({\n name: 'EcanProviderConfig',\n inheritAttrs: false,\n props: {\n ...providerConfigComponentProps\n },\n setup (props, { expose }) {\n useHrefParamsToGlobalVariables()\n\n const providerConfig = ref<HTMLElement>()\n const setTheme = () => {\n providerConfig.value.setAttribute('datav-theme', props.theme as string)\n }\n watch(() => props.theme, () => {\n setTheme()\n })\n onMounted(() => {\n setTheme()\n })\n const contextRequestUrl = computed(() => {\n return useVariablesInText(props.contextRequestUrl as string)\n })\n const pageMode = computed(() => props.pageMode)\n const theme = computed(() => props.theme)\n // 当前组件主动触发ID\n const touchEventId = ref<string>('')\n // 提供全局设置\n provide(GLOBAL_CONFIG, {\n // 请求地址\n contextRequestUrl,\n // 模式(设计、预览、正常):目前主要配置初始化是否发起请求\n pageMode,\n // 主题\n theme,\n touchEventId\n })\n\n // 提供全局变量\n const globalModel = new Map()\n const getGlobalModel = (key: string) => {\n return globalModel.get(key)\n }\n const setGlobalModel = (key: string, value: any) => {\n globalModel.set(key, value)\n }\n provide(GLOBAL_MODEL, {\n getGlobalModel,\n setGlobalModel\n })\n\n // 提供事件\n const eventBus = mitt()\n const eventBusKeySet = new Set()\n const onEvent = (key: string, events: { [key:string]: any }) => {\n if (eventBusKeySet.has(key)) {\n eventBus.off(key)\n }\n eventBus.on(key, (k: string) => {\n eventBusKeySet.add(key)\n return Object.prototype.toString.call(events[k]) === '[object Function]' && events[k]()\n })\n onBeforeUnmount(() => {\n eventBus.off(key)\n })\n }\n const offEvent = (key) => {\n eventBus.off(key)\n }\n const emitEvent = (key: string, eventName: string) => {\n eventBus.emit(key, eventName)\n }\n provide(EVENT_BUS, {\n onEvent,\n offEvent,\n emitEvent\n })\n\n // 设置是否请求 token\n const tokenNum = ref(0)\n const requestToken = () => {\n tokenNum.value = unref(tokenNum) + 1\n }\n provide(GLOBAL_TOKEN, {\n requestToken\n })\n // 请求排序\n const requestModel = new Map()\n const requestMap = new Map()\n const setRequest = ({ requestFn = () => {}, sortNum = 0, id = '' }: RequestModalParam) => {\n if (requestModel.has(sortNum)) {\n const requestFnList = requestModel.get(sortNum)\n requestFnList?.push(requestFn)\n } else {\n requestModel.set(sortNum, [requestFn])\n }\n requestMap.set(id, requestFn)\n }\n const handleRequestFnList = (requestFnList: Array<Function>) => {\n return new Promise((resolve, reject) => {\n const resultList = requestFnList.map(requestFn => requestFn())\n Promise.all(resultList)\n .then(list => {\n resolve(list)\n })\n .catch(err => {\n reject(err)\n })\n })\n }\n // 指标库模块请求 token\n const queryUserToken = async () => {\n const res = await axios.get(`${INDICATOR_URL}/user/anonymous?username=admin`, {\n headers: {\n systemCode: 'F72FC50A3D97372514A6AC33333D28FD',\n current_context: 'ygt'\n }\n })\n // 设置 token 挂载在 window.config 上\n // @ts-ignore\n // eslint-disable-next-line\n config.indicatorToken = res.data.data?.token\n }\n const touchRequest = async (id: undefined | string) => {\n // 传空默认触发全部\n if (!id) {\n const requestModelArr = Array.from(requestModel)\n // 排序\n requestModelArr.sort((a, b) => b[0] - a[0])\n const len = requestModelArr.length\n try {\n // 指标库模块需要 token\n // 页面不为design 请求次数 token 不为0\n if (props.pageMode !== 'design' && unref(tokenNum) > 0) {\n await queryUserToken()\n }\n for (let i = 0; i < len; i++) {\n const requestFnList = requestModelArr[i][1]\n await handleRequestFnList(requestFnList)\n }\n } catch (e) {\n console.error(e)\n } finally {\n // 执行完直接清空\n requestModel.clear()\n }\n } else if (typeof id === 'string') {\n const requestFn = requestMap.get(id)\n if (typeof requestFn === 'function') {\n requestFn()\n }\n }\n }\n\n provide(REQUEST_MODEL, {\n setRequest,\n touchRequest\n })\n\n const emitRefreshPage = () => {\n eventBus.emit(REFRESH_PAGE)\n }\n provide(REFRESH_PAGE, {\n emitRefreshPage\n })\n // const notRenderSet = ref(new Set())\n // const refreshEventBus = mitt()\n const onRefreshPage = (callBack: Function) => {\n eventBus.on(REFRESH_PAGE, () => callBack())\n onMounted(() => {\n eventBus.off(REFRESH_PAGE)\n })\n }\n\n onBeforeUnmount(() => {\n requestModel?.clear()\n requestMap?.clear()\n })\n\n expose({\n touchRequest,\n getGlobalModel,\n onRefreshPage\n })\n\n return {\n providerConfig\n }\n }\n})\n</script>\n\n<style scoped>\n\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport ProviderConfig from './ProviderConfig.vue'\nexport const EcanProviderConfig = withInstall(ProviderConfig)\nexport default EcanProviderConfig\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface TextProps extends Props {\n text: string // 文本内容\n color: string // 颜色\n fontSize: string // 字体大小\n fontFamily: string // 字体\n fontWeight: number // 字体的粗细程度\n justifyContent: 'flex-start' | 'center' | 'end' // 水平位置\n alignItems: 'flex-start' | 'center' | 'end' // 垂直位置\n textShadow: string // 文字阴影\n data: { [key:string]: any }\n variableColor: string\n variableFontSize: string\n variableDefaultValue: string\n format: '' | 'percentage'\n href: string\n target: 'self' | 'blank' | 'event' // 打开方式\n linkPage: string // 传入pageId\n}\nexport const textProps:TextProps = {\n ...props,\n name: '文本',\n keyName: '文本',\n type: 'ecanText',\n width: '100px',\n height: '40px',\n text: '文字',\n color: '#333',\n variableColor: '#f00',\n fontSize: '14px',\n fontFamily: '',\n fontWeight: 400,\n textShadow: '',\n justifyContent: 'center',\n alignItems: 'center',\n variableFontSize: '14px',\n data: {},\n variableDefaultValue: '0',\n format: '',\n target: 'self',\n href: '',\n linkPage: ''\n}\n\n// 转化默认属性\nexport const textComponentProps = transformToComponentProps(textProps)\n\nexport const textEvents = ['refreshData', 'click']\n","export default \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAMAAADXqc3KAAAAV1BMVEUAAAD/WzT/WjP/WDD/WzT/WzP/WzT/WzT/WzT/WjT/WzT/WDT/YED/WzT/WzT/WjT/YED/WzT/WzT/WzT/XDT/WzT/WjX/WjP/XDT/XDT/WTL/Tif/WzReH8z5AAAAHHRSTlMA8RgS9W9YHbePZyME5sVjCP7bzcCxgndOQC4GFJJgKwAAAIJJREFUKM+Nkd0OgyAMRjvqcLA53fzXvv9zaokmxq8mnsue5ACFDjiy+XyjLZ7yyK35OxN5mSFZKa2QojEIKRhrZKM0QnsMQxirmJ0kBubTIZvAtUyiFAT4JFoUIYmIotZ5xjDPfyoCAV16nMPdFir8xZ16nM//tePtXw2ODOJY0V0WqQwM2rgKrU0AAAAASUVORK5CYII=\"","export default \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAACXBIWXMAAAsTAAALEwEAmpwYAAAFHGlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4gPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmUgWE1QIENvcmUgNS42LWMxNDUgNzkuMTYzNDk5LCAyMDE4LzA4LzEzLTE2OjQwOjIyICAgICAgICAiPiA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIgeG1sbnM6cGhvdG9zaG9wPSJodHRwOi8vbnMuYWRvYmUuY29tL3Bob3Rvc2hvcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgQ0MgMjAxOSAoV2luZG93cykiIHhtcDpDcmVhdGVEYXRlPSIyMDIyLTA3LTIyVDA5OjM1OjE5KzA4OjAwIiB4bXA6TW9kaWZ5RGF0ZT0iMjAyMi0wNy0yMlQwOTozNTozNyswODowMCIgeG1wOk1ldGFkYXRhRGF0ZT0iMjAyMi0wNy0yMlQwOTozNTozNyswODowMCIgZGM6Zm9ybWF0PSJpbWFnZS9wbmciIHBob3Rvc2hvcDpDb2xvck1vZGU9IjMiIHBob3Rvc2hvcDpJQ0NQcm9maWxlPSJzUkdCIElFQzYxOTY2LTIuMSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDozNmRlNzg2MS1kNzhmLTQyNGYtYTNjOS01ZTk0MjkwY2RjZjEiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MzZkZTc4NjEtZDc4Zi00MjRmLWEzYzktNWU5NDI5MGNkY2YxIiB4bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ9InhtcC5kaWQ6MzZkZTc4NjEtZDc4Zi00MjRmLWEzYzktNWU5NDI5MGNkY2YxIj4gPHhtcE1NOkhpc3Rvcnk+IDxyZGY6U2VxPiA8cmRmOmxpIHN0RXZ0OmFjdGlvbj0iY3JlYXRlZCIgc3RFdnQ6aW5zdGFuY2VJRD0ieG1wLmlpZDozNmRlNzg2MS1kNzhmLTQyNGYtYTNjOS01ZTk0MjkwY2RjZjEiIHN0RXZ0OndoZW49IjIwMjItMDctMjJUMDk6MzU6MTkrMDg6MDAiIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkFkb2JlIFBob3Rvc2hvcCBDQyAyMDE5IChXaW5kb3dzKSIvPiA8L3JkZjpTZXE+IDwveG1wTU06SGlzdG9yeT4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1ldGE+IDw/eHBhY2tldCBlbmQ9InIiPz6VDI+BAAABUUlEQVRIia3WPyhGURgG8B8pi0xisStKMioZLQaLiaQMBoxiVBImCwaLf6MssloUk8Gmb7GgJFKSUvIZ7qe+bvd89+A+03uf989z3nPPPe+tK5fLqtF3tSESzRjFAJ4vemams4IaYqulCq9gEo34QGco+LcCg9hHaxW3jpsiBIZxmMp5kXQTRH1k8S4cZCxoE6//FaiXbEtThm87JjkPI+jN4E9xW4TAQoA/isjNFehCT8B3VoTAUID/xHURAn0B/g5fRQh0B/j7mOJkf2gTaKvY7YG8FsxXPe/hIVbgCTs5C+vAasU+xlooMGuLTrCVI/CDR0zVCgi9gzmUIgQmBbYmT+AdY5LjGMKWpNuaqHWKLrEY8JUkXeYi75iu4DzFfUi6ey9C4AvjeKviliTdRSHmsrvBbMU+lzNg0oidaLvox7LIK+IHdem/iqIROzL/jG+NrT1BRsXKNQAAAABJRU5ErkJggg==\"","<template>\n <div class=\"skeleton-wrapper\" :style=\"style\" v-if=\"loading\">\n <skeleton :loading=\"loading\"/>\n </div>\n <div class=\"ecan-text\" :style=\"style\" v-html=\"myText\" @click=\"click\" v-else/>\n</template>\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, ref, unref, watch } from 'vue'\nimport { textComponentProps } from './props'\nimport {\n usePickComponentStyle,\n useRequestData,\n useOnEvent,\n useEmitEvent,\n usePageUrl,\n useVariablesInText\n} from '@/hooks'\nimport { GLOBAL_CONFIG, REQUEST_MODEL } from '@/utils/constant'\nimport Skeleton from '@/common/skeleton/Skeleton.vue'\nimport goUp from '@/assets/go-up.png'\nimport goDown from '@/assets/go-down.png'\nimport { RequestModalParam } from '@/utils/types'\nimport { formatMoney } from '@/utils/util'\n\nexport default defineComponent({\n name: 'EcanText',\n components: { Skeleton },\n props: {\n ...textComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const myData = ref({} as { [key:string]:any })\n watch(() => [props.data, props.dataType], ([data, dataType]) => {\n if (dataType === 'static') {\n myData.value = data as { [key: string]: any }\n }\n }, {\n immediate: true\n })\n const myText = computed(() => {\n const data = unref(myData)\n let text = props.text as string\n text = text?.replace(/\\n|\\\\n/g, '<br/>')\n text = text?.replace(/\\s/g, ' ')\n const variables = (text).match(/\\{\\s*[\\w\\u4e00-\\u9fa5]*\\s*\\}/g)\n if (variables == null || variables.length === 0) return text\n for (let i = 0; i < variables.length; i++) {\n const variable = variables[i]\n const v = variable?.slice(1, variable.length - 1)?.trim()\n let usedVariable = data[v]\n // 能取到变量值\n if (usedVariable != null) {\n // 涨跌幅\n const format = props.format\n if (format === 'percentage') {\n // 判断是数字类型\n usedVariable = +usedVariable\n if (!isNaN(usedVariable)) {\n usedVariable = (usedVariable * 100).toFixed(2)\n // 如果大于等于 0\n if (usedVariable >= 0) {\n text = text.replace(variable, `<span style=\"color:#ED6643;font-size:${props.variableFontSize}\"><img style=\"width: ${props.variableFontSize}\" src=\"${goUp}\"/>${usedVariable}%</span>`)\n } else {\n // 如果小于 0\n text = text.replace(variable, `<span style=\"color: #6ACB97;font-size:${props.variableFontSize}\"><img style=\"width: ${props.variableFontSize}\" src=\"${goDown}\"/>${Math.abs(usedVariable)}%</span>`)\n }\n } else {\n // 判断不是数字类型\n text = text.replace(variable, `<span style=\"color:${props.variableColor};font-size:${props.variableFontSize}\">${0.00}%</span>`)\n }\n } else if (format === 'percent') {\n // 百分数\n // 判断是数字类型\n usedVariable = +usedVariable\n if (!isNaN(usedVariable)) {\n usedVariable = (usedVariable * 100).toFixed(2)\n text = text.replace(variable, `<span style=\"color:${props.variableColor};font-size:${props.variableFontSize}\">${usedVariable}%</span>`)\n }\n } else if (props.format === 'money') {\n // 金额格式化\n usedVariable = +usedVariable\n if (!isNaN(usedVariable)) {\n usedVariable = formatMoney(usedVariable)\n text = text.replace(variable, `<span style=\"color:${props.variableColor};font-size:${props.variableFontSize}\">${usedVariable}</span>`)\n }\n } else {\n /// 没有使用百分格式化\n text = text.replace(variable, `<span style=\"color:${props.variableColor};font-size:${props.variableFontSize}\">${usedVariable}</span>`)\n }\n } else {\n // 不能取到变量值\n text = text.replace(variable, props.variableDefaultValue as string)\n }\n }\n return `<span>${text}</span>`\n })\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n const requestData = useRequestData(props)\n const loading = ref(false)\n const handleRequestData = async () => {\n if (unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestData()\n myData.value = res?.data?.data || {}\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n const refreshData = () => {\n if (props.dataType === 'static') return\n handleRequestData()\n }\n\n useOnEvent(props, {\n refreshData\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n\n setRequest({\n id: props.id as string,\n requestFn: refreshData,\n sortNum: props.requestSort as number\n })\n useOnEvent(props, {\n refreshData\n })\n\n const emitEvent = useEmitEvent(props)\n\n const click = emitEvent('click', () => {\n // 空链接、空页面直接 return\n if (!props.linkPage && !props.href) return\n const linkPage = (props.linkPage || '') as string\n const pageUrl = usePageUrl(unref(pageMode), linkPage)\n // 优先使用外部链接,再使用url\n const href = props.href as string\n let url = href || pageUrl\n url = useVariablesInText(url)\n const target = props.target\n if (target == null || target === '') return\n if (target !== 'event') {\n window.open(url, '_' + (target as string))\n } else {\n window.parent.postMessage({\n type: 'openPage',\n url: href\n }, '*')\n }\n })\n\n return {\n style,\n myText,\n loading,\n click\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n@import \"./style\";\n//.skeleton-wrapper {\n// overflow: hidden;\n//}\n//\n//.ecan-text {\n// overflow: hidden;\n// display: flex;\n//}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport Text from './Text.vue'\nexport const EcanText = withInstall(Text)\nexport default EcanText\nexport * from './props'\n","<template>\n <div class=\"red\">\n {{ text }}\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, ref } from 'vue'\nexport default defineComponent({\n name: 'EcanScrollText',\n setup () {\n const text = ref('基础文本')\n return {\n text\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.red {\n color: red;\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport ScrollText from './ScrollText.vue'\nexport const EcanScrollText = withInstall(ScrollText)\nexport default EcanScrollText\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface TimeDisplayProps extends Props {\n color: string\n format: string\n fontSize: string\n fontFamily: string // 字体\n fontWeight: number // 字体的粗细程度\n textShadow: string // 文字阴影\n textAlign: string // 水平\n verticalAlign: string // 垂直\n}\n\nexport const timeDisplayProps: TimeDisplayProps = {\n ...props,\n name: '时间展示',\n keyName: '时间展示',\n type: 'ecanTimeDisplay',\n format: 'YYYY-MM-DD dddd HH:mm:ss',\n fontSize: '16px',\n color: '#333',\n width: '240px',\n height: '40px',\n textAlign: 'center',\n fontFamily: '',\n fontWeight: 400,\n textShadow: '',\n verticalAlign: 'middle'\n}\n\nexport const timeDisplayComponentProps = transformToComponentProps(timeDisplayProps)\n","<template>\n <div class=\"time-display\" :style=\"style\">\n {{ time }}\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, onMounted, onUnmounted, ref } from 'vue'\nimport { timeDisplayComponentProps } from './props'\nimport dayjs from 'dayjs'\nimport { usePickComponentStyle } from '../../hooks'\nexport default defineComponent({\n name: 'EcanTimeDisplay',\n props: {\n ...timeDisplayComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const time = ref(dayjs().format(props.format as string))\n let timer = null\n const clearTimer = () => {\n clearInterval(timer)\n timer = null\n }\n const setTimer = () => {\n if (timer) {\n clearTimer()\n }\n timer = setInterval(() => {\n time.value = dayjs().add(1, 's').format(props.format as string)\n }, 1000)\n }\n onMounted(() => {\n setTimer()\n })\n onUnmounted(() => {\n clearTimer()\n })\n return {\n style,\n time\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.time-display {\n overflow: hidden;\n display: table-cell;\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport TimeDisplay from './TimeDisplay.vue'\nexport const EcanTimeDisplay = withInstall(TimeDisplay)\nexport default EcanTimeDisplay\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface ListProps extends Props {\n data: { [key: string]: any } []\n columns: { [key: string]: any } []\n sliceCount: number,\n backgroundColor: string\n useRanking: boolean\n useTitle: boolean\n columnCount: number\n itemHeight: string\n itemColSpan: string\n itemRowSpan: string\n}\n\nexport const listProps:ListProps = {\n ...props,\n type: 'ecanList',\n name: '列表',\n keyName: '列表',\n width: '330px',\n height: '80px',\n backgroundColor: '#0d215e',\n itemColSpan: '10px',\n itemRowSpan: '10px',\n useRanking: true,\n useTitle: false,\n sliceCount: 6,\n columnCount: 1,\n itemHeight: '32px',\n data: [\n {\n name: 'a',\n age: 12\n },\n {\n name: 'b',\n age: 14\n }\n ],\n columns: [\n {\n key: 'name'\n },\n {\n key: 'age'\n }\n ]\n}\n\nexport const listComponentProps = transformToComponentProps(listProps)\n\nexport interface ListEvents {\n refreshData: () => void\n click: () => void\n}\n\nexport const listEvents: Array<keyof ListEvents> = ['refreshData', 'click']\n","<template>\n <div class=\"ecan-list\" :style=\"style\">\n <skeleton :loading=\"loading\">\n <div\n class=\"title\"\n v-if=\"useTitle\"\n >\n <div\n class=\"title-inner\"\n :style=\"{\n backgroundColor: backgroundColor,\n height: itemHeight,\n width: `calc(100% / ${columnCount} - ${itemColSpan} * ${columnCount - 1}/ ${columnCount})`,\n marginRight: count % columnCount !== 0 ? itemColSpan : ''\n }\"\n v-for=\"count in columnCount\"\n :key=\"count\"\n >\n <div class=\"ranking\" v-if=\"useRanking\" />\n <div\n class=\"column\"\n v-for=\"(column, i) in columns\"\n :key=\"column.key || i\"\n :style=\"{\n color: column.titleColor,\n ...columnStyle\n }\"\n >\n {{ column.title }}\n </div>\n </div>\n </div>\n <div class=\"ecan-list-content\" v-if=\"dataSource.length > 0\">\n <div\n class=\"title-placeholder\"\n :style=\"{\n marginBottom: itemRowSpan\n }\"\n v-if=\"useTitle\"\n />\n <div\n class=\"item\"\n :style=\"{\n backgroundColor: backgroundColor,\n height: itemHeight,\n width: `calc(100% / ${columnCount} - ${itemColSpan} * ${columnCount - 1} / ${columnCount})`,\n marginRight: (i + 1) % columnCount !== 0 ? itemColSpan : '',\n marginBottom: itemRowSpan\n }\"\n v-for=\"(item, i) in dataSource.slice(0, sliceCount)\"\n :key=\"item.id || i\"\n @click=\"click\"\n >\n <div class=\"ranking\" v-if=\"useRanking\">\n <div class=\"icon\"/>\n <div class=\"sort\">\n Top {{ i + 1 }}\n </div>\n </div>\n <div\n :class=\"['column', contrastClass(item[column.key], column.format)]\"\n v-for=\"column in columns\"\n :key=\"column.key\"\n :style=\"{\n fontSize: column.fontSize,\n color: contrastClass(item[column.key], column.format) === '' ? column.color : '',\n fontWeight: column.fontWeight,\n ...columnStyle\n }\"\n >\n {{ (column.format != null || column.format !== '') && formatFn(item[column.key], column.format) }}\n </div>\n </div>\n </div>\n <div class=\"empty\" v-else>\n 暂无数据\n </div>\n </skeleton>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, ref, unref } from 'vue'\nimport { listComponentProps, ListEvents } from './props'\nimport { useEmitEvent, useOnEvent, usePickComponentStyle, useRequestData } from '@/hooks'\nimport { formatMoney, formatPercentage } from '@/utils/util'\nimport { GLOBAL_CONFIG, REQUEST_MODEL } from '@/utils/constant'\nimport { RequestModalParam } from '@/utils/types'\nimport Skeleton from '@/common/skeleton'\nexport default defineComponent({\n name: 'EcanList',\n components: { Skeleton },\n props: {\n ...listComponentProps\n },\n setup (props) {\n const dataSource = ref<{[key:string]: any} []>(props.data as {[key:string]: any} [])\n const style = usePickComponentStyle(props, ['backgroundColor'])\n const columnStyle = computed(() => {\n if (props.useRanking) {\n return {\n textAlign: 'center'\n }\n } else {\n return {\n textAlign: 'left'\n }\n }\n })\n type Format = 'money' | 'percentage' | 'contrast' | ''\n const formatFn = (value: string | number, format?: Format) => {\n if (format == null || format === '') return value\n const map = {\n money: formatMoney,\n percentage: formatPercentage,\n contrast: formatPercentage\n }\n return map[format](value) || ''\n }\n const contrastClass = (value: string | number, format: Format) => {\n const _value = parseFloat(value + '')\n if (format !== 'contrast') {\n return ''\n }\n switch (true) {\n case _value >= 0:\n return 'goUp'\n case _value < 0:\n return 'goDown'\n }\n }\n const requestData = useRequestData(props)\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n const loading = ref(false)\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n\n try {\n loading.value = true\n const res = await requestData()\n dataSource.value = res?.data?.data.rows || []\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const refreshData = () => {\n handleRequestData()\n }\n\n const emitEvent = useEmitEvent(props)\n\n const click = emitEvent('click', () => {})\n\n useOnEvent(props, {\n refreshData\n } as ListEvents)\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n setRequest({\n id: props.id as string,\n requestFn: handleRequestData,\n sortNum: props.requestSort as number\n })\n return {\n style,\n formatFn,\n columnStyle,\n contrastClass,\n dataSource,\n loading,\n click\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n .ecan-list {\n overflow: hidden;\n }\n .ecan-list-content {\n width: 100%;\n height: 100%;\n overflow: auto;\n display: flex;\n align-content: flex-start;\n flex-wrap: wrap;\n }\n .title {\n position: absolute;\n z-index: 9;\n display: flex;\n align-items: center;\n height: 32px;\n width: 100%;\n font-size: 16px;\n color: #ffffff;\n }\n .title-inner {\n padding-left: 28px;\n padding-right: 20px;\n flex: 1;\n display: flex;\n height: 100%;\n }\n .title-placeholder {\n width: 100%;\n height: 32px;\n }\n .item {\n display: flex;\n align-items: center;\n height: 32px;\n padding-left: 28px;\n padding-right: 20px;\n width: 100%;\n font-size: 16px;\n color: #ffffff;\n }\n .column {\n flex: 1;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n .ranking {\n flex: 1;\n display: flex;\n align-items: center;\n flex-shrink: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n .icon {\n width: 12px;\n height: 8px;\n background: #21BEF7;\n margin-right: 17px;\n opacity: .6;\n }\n .item:nth-child(2) .icon {\n opacity: .8;\n }\n .item:first-child .icon{\n opacity: 1;\n }\n .sort {\n font-weight: 600;\n }\n .goUp {\n color: #FF512E;\n display: flex;\n align-items: center;\n &:before {\n content: '';\n display: block;\n background: url(\"../../assets/go-up.png\");\n width: 12px;\n height: 12px;\n background-repeat: no-repeat;\n background-size: cover;\n margin-right: 2px;\n }\n }\n\n .goDown {\n color: #39cf93;\n display: flex;\n align-items: center;\n &:before {\n content: '';\n display: block;\n background: url(\"../../assets/go-down.png\");\n width: 12px;\n height: 12px;\n background-repeat: no-repeat;\n background-size: cover;\n margin-right: 2px;\n }\n }\n .empty {\n text-align: center;\n margin-top: 15%;\n }\n</style>\n\n<style lang=\"less\">\n.ecan-list {\n *::-webkit-scrollbar-track {\n background-color: #fff;\n }\n\n .ant-table-cell-scrollbar {\n box-shadow: 0 1px 0 1px transparent;\n }\n *::-webkit-scrollbar {\n width: 6px;\n height: 6px;\n }\n *::-webkit-scrollbar-thumb {\n border-radius: 6px;\n -webkit-box-shadow:inset 0 0 6px rgba(0,0,0,.3);\n background-color: #c8c9ca;\n }\n}\n[datav-theme='darkBlue'] {\n .ecan-list {\n *::-webkit-scrollbar-thumb {\n background-color: #2f4dac !important;\n }\n *::-webkit-scrollbar-track{\n background-color: #192c70;\n }\n *::-webkit-scrollbar-corner {\n background-color: #192c70 !important;\n }\n .empty {\n color: #ffffff;\n }\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport List from './List.vue'\nexport const EcanList = withInstall(List)\nexport default EcanList\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface ProportionProps extends Props {\n strokeColor: string // 进度条的色彩\n strokeLinecap: 'round' | 'square' // 进度条的样式\n trailColor: string // 未完成的分段的颜色\n strokeType: 'circle' | 'dashboard',\n data: { [key:string]: any }\n text: string\n fontSize: string\n color: string\n strokeWidth: number\n fontWeight: number\n strokeTextWidth: string\n lineHeight: string\n decimalFormat: boolean\n variableDefaultValue: string\n}\n\nexport const proportionProps: ProportionProps = {\n ...props,\n name: '占比图',\n keyName: '占比图',\n type: 'ecanProportion',\n strokeType: 'circle',\n width: '200px',\n height: '200px',\n strokeColor: '#4091f7',\n strokeLinecap: 'round',\n trailColor: '#f5f5f5',\n data: {\n percent: 0.30\n },\n text: '{percent}%',\n fontSize: '26px',\n color: '#4091f7',\n strokeWidth: 6,\n fontWeight: 400,\n strokeTextWidth: '100%',\n lineHeight: '26px',\n decimalFormat: false,\n variableDefaultValue: '0'\n}\n\nexport const proportionComponentProps = transformToComponentProps(proportionProps)\n\nexport const proportionEvents = ['refreshData', 'click']\n","<template>\n <div class=\"ecan-proportion\" :style=\"style\">\n <a-progress\n class=\"progress\"\n :percent=\"myValue\"\n :width=\"myWidth\"\n :type=\"strokeType\"\n :strokeColor=\"strokeColor\"\n :strokeLinecap=\"strokeLinecap\"\n :trailColor=\"trailColor\"\n :strokeWidth=\"strokeWidth\"\n :gapDegree=\"strokeType === 'dashboard' ? 75 : 0\"\n @click=\"click\"\n >\n <template #format>\n <skeleton v-if=\"loading\" :loading=\"loading\"/>\n <div\n v-else\n class=\"format\"\n :style=\"{\n width: strokeTextWidth,\n fontSize,\n color,\n fontWeight,\n lineHeight\n }\">\n {{ text }}\n </div>\n </template>\n </a-progress>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, ref, unref, watch } from 'vue'\nimport 'ant-design-vue/es/progress/style'\nimport { Progress as AProgress } from 'ant-design-vue'\nimport { useEmitEvent, useOnEvent, usePickComponentStyle, useRequestData } from '@/hooks'\nimport { proportionComponentProps } from './props'\nimport { GLOBAL_CONFIG, REQUEST_MODEL } from '@/utils/constant'\nimport Skeleton from '../../common/skeleton'\nimport { RequestModalParam } from '@/utils/types'\nexport default defineComponent({\n name: 'EcanProportion',\n components: {\n AProgress,\n Skeleton\n },\n props: {\n ...proportionComponentProps\n },\n setup (props) {\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n const style = usePickComponentStyle(props)\n const myWidth = computed(() => {\n const width = props.width as string\n return parseFloat(width)\n })\n const myData = ref<{ [key:string]: any }>({})\n watch(() => props.data, () => {\n if (props.dataType === 'static' || unref(pageMode) === 'design') {\n myData.value = props.data as { [key:string]: any }\n }\n }, {\n immediate: true,\n deep: true\n })\n const myValue = computed(() => {\n const data = unref(myData)\n const defaultValue = +(props.variableDefaultValue)\n if (data == null) {\n if (!isNaN(defaultValue)) {\n return defaultValue\n } else {\n return 0\n }\n }\n const variables = (props.text as string).match(/\\{.+\\}/g) || []\n let value\n const valueSet = new Set(Object.keys(data))\n for (let i = 0; i < variables.length; i++) {\n const variable = variables[i]\n const key = variable.slice(1, variable.length - 1)\n if (valueSet.has(key)) {\n value = data[key]\n break\n }\n }\n\n if (typeof value === 'number') {\n value = value * 100\n } else if (typeof value === 'string' && !isNaN(+value)) {\n value = (+value) * 100\n } else if (!isNaN(defaultValue)) {\n value = defaultValue * 100\n } else {\n value = 0\n }\n\n if (props.decimalFormat) {\n value = +value.toFixed(2)\n }\n return value\n })\n const text = computed(() => {\n let text = props.text as string\n if (text === '') return unref(myValue)\n const defaultValue = props.variableDefaultValue as string // 变量默认值\n const data = unref(myData) // { a: 1, b: 2 }\n const variables = (text).match(/\\{.+\\}/g) || []\n for (let i = 0; i < variables.length; i++) {\n const variable = variables[i]\n let statement = variable.slice(1, variable.length - 1) // { a - b} => a - b\n const textVariables = statement.match(/.*/g) // a - b => [a,b]\n for (let j = 0; j < textVariables?.length; j++) { // \"1 - 2\"\n const textVariable = textVariables[i]?.trim()\n if (data[textVariable] != null) {\n statement = statement.replace(textVariable, data[textVariable])\n } else {\n statement = statement.replace(textVariable, defaultValue)\n }\n }\n // 匹配加减乘除\n let usedVariable:number | string = statement\n // 运行表达式\n try {\n if ((/\\w+[+\\-*/%]+\\w+/g).test(statement)) {\n // eslint-disable-next-line no-eval\n const eval2 = eval\n usedVariable = eval2(statement)\n }\n } catch (e) {\n console.error(e)\n }\n if (typeof usedVariable === 'number' || !isNaN(+usedVariable)) {\n usedVariable = (+usedVariable * 100)\n if (props.decimalFormat) {\n usedVariable = usedVariable.toFixed(2)\n }\n }\n text = text.replace(variable, usedVariable + '')\n }\n return text\n })\n const requestData = useRequestData(props)\n const loading = ref(false)\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestData()\n myData.value = res?.data?.data || {}\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n const refreshData = () => {\n handleRequestData()\n }\n useOnEvent(props, {\n refreshData\n })\n\n const emitEvent = useEmitEvent(props)\n\n const click = emitEvent('click', () => {})\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n\n setRequest({\n id: props.id as string,\n requestFn: handleRequestData,\n sortNum: props.requestSort as number\n })\n\n return {\n style,\n myWidth,\n text,\n myValue,\n loading,\n click\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.ecan-proportion {\n overflow: hidden;\n}\n\n.progress {\n width: 100%;\n height: 100%;\n}\n\n.format {\n margin: 0 auto;\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Proportion from './Proportion.vue'\nexport const EcanProportion = withInstall(Proportion)\nexport default EcanProportion\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface InputProps extends Props {\n value: string,\n placeholder: string\n}\n\nexport const inputProps: InputProps = {\n ...props,\n width: '200px',\n id: '',\n left: '0px',\n top: '0px',\n name: '输入框',\n keyName: '输入框',\n rotate: '',\n type: 'ecanInput',\n value: '',\n placeholder: '请输入文字'\n}\n\n// 转化默认属性\nexport const inputComponentProps = transformToComponentProps(inputProps)\n\nexport const inputEvents = ['inputChange', 'inputBlur']\n","<template>\n <div\n class=\"ecan-input\"\n :style=\"style\"\n >\n <a-input\n class=\"input\"\n v-model:value=\"myValue\"\n :placeholder=\"placeholder\"\n @change=\"inputChange\"\n @blur=\"inputBlur\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, inject, ref, watch } from 'vue'\nimport { useEmitEvent, usePickComponentStyle } from '@/hooks'\nimport { Input as AInput } from 'ant-design-vue'\nimport 'ant-design-vue/es/input/style'\nimport { inputComponentProps } from './props'\nimport { GLOBAL_MODEL } from '@/utils/constant'\nimport { debounce } from 'lodash-es'\nexport default defineComponent({\n name: 'EcanInput',\n components: {\n AInput\n },\n props: {\n ...inputComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const myValue = ref<string>('')\n watch(() => props.value, (value: string) => {\n myValue.value = value\n }, {\n immediate: true\n })\n const id = props.id as string\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n // 初始化设置值\n setGlobalModel(props.id as string, {\n type: props.type,\n value: myValue\n })\n const handleSetGlobalModel = () => {\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: myValue })\n }\n // 注册函数触发事件拦截器\n const emitEvent = useEmitEvent(props)\n const inputChange = debounce(emitEvent('inputChange', () => {\n handleSetGlobalModel()\n }), 300)\n const inputBlur = emitEvent('inputBlur', () => {\n })\n return {\n style,\n myValue,\n inputBlur,\n inputChange\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.ecan-input {\n .ant-input {\n width: 100%;\n height: 100%;\n }\n}\n\n[datav-theme='light'] .ecan-input {\n .ant-input{\n color: rgba(0, 0, 0, 0.65);\n background-color: #ffffff;\n border: 1px solid #d9d9d9;\n }\n}\n\n[datav-theme='darkBlue'] .ecan-input {\n .ant-input{\n border: 1px solid #1f63a3;\n background-color: #05164c;\n box-shadow: inset 0 0 10px #005efe;\n color: #ffffff;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Input from './Input.vue'\nexport const EcanInput = withInstall(Input)\nexport default EcanInput\nexport * from './props'\n","import {\n Props,\n EventsProp,\n props,\n transformToComponentProps\n} from '@/utils/props'\nexport interface DatePickerProps extends Props, EventsProp {\n value: string\n picker: 'date' | 'week' | 'month' | 'quarter' | 'year'\n format: string\n showTime: boolean // 增加时间选择功能\n useCurrentTime: boolean\n}\n\nexport const datePickerProps: DatePickerProps = {\n ...props,\n height: '33px',\n width: '130px',\n id: '',\n left: '0px',\n top: '0px',\n name: '日期选择器',\n keyName: '日期选择器',\n rotate: '',\n type: 'ecanDatePicker',\n value: '',\n picker: 'date',\n format: 'YYYY-MM-DD',\n showTime: false,\n useCurrentTime: true\n}\nexport const datePickerComponentProps = transformToComponentProps(datePickerProps)\n\nexport const datePickerEvents = ['dateChange']\n","<template>\n <div\n class=\"ecan-date-picker\"\n :style=\"style\"\n >\n <!-- 宽度style有效,class无效 -->\n <a-date-picker\n class=\"date-picker\"\n dropdownClassName=\"ecan-date-picker-dropdown\"\n v-model:value=\"myValue\"\n :format=\"format\"\n :picker=\"picker\"\n :showTime=\"showTime\"\n :locale=\"locale\"\n @change=\"dateChange\"\n :getPopupContainer=\"getPopupContainer\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, inject, ref, watch } from 'vue'\nimport { datePickerComponentProps } from './props'\nimport { DatePicker as ADatePicker } from 'ant-design-vue'\nimport 'ant-design-vue/es/date-picker/style'\nimport { usePickComponentStyle, useOnEvent, useEmitEvent } from '@/hooks'\nimport locale from 'ant-design-vue/es/date-picker/locale/zh_CN'\nimport dayjs, { Dayjs } from 'dayjs'\nimport { GLOBAL_MODEL } from '@/utils/constant'\nexport default defineComponent({\n name: 'EcanDatePicker',\n props: {\n ...datePickerComponentProps\n },\n components: {\n ADatePicker\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const getPopupContainer = () => document.getElementById('ProviderConfig') || document.body\n const myValue = ref<Dayjs | null>(null)\n watch(() => [props.value, props.useCurrentTime], ([value, useCurrentTime]: [string, boolean]) => {\n let _value: Dayjs = null\n if (value) {\n _value = dayjs(value)\n } else if (useCurrentTime) {\n _value = dayjs()\n }\n myValue.value = _value\n }, {\n immediate: true\n })\n const { setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n // 初始化设置值\n setGlobalModel(props.id as string, {\n type: props.type,\n format: props.format,\n value: myValue\n })\n // 注册函数触发事件拦截器\n const emitEvent = useEmitEvent(props)\n const dateChange = emitEvent('dateChange', () => {\n })\n // TODO 传入需要注册的参数\n useOnEvent(props, {\n dateChange\n })\n return {\n style,\n getPopupContainer,\n myValue,\n locale,\n dateChange\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.ecan-date-picker {\n .date-picker {\n width: 100%;\n height: 100%\n }\n}\n[datav-theme='light'] .ecan-date-picker {\n .ant-picker {\n background-color: #ffffff;\n color: rgba(0, 0, 0, 0.85);\n border: 1px solid #d9d9d9;\n }\n .ant-picker-input > input {\n color: rgba(0, 0, 0, 0.85);\n }\n .anticon-calendar {\n color: #333;\n }\n .anticon-close-circle {\n color: #333;\n }\n\n .ant-picker-input > input::placeholder {\n color: #bfbfbf;\n }\n}\n[datav-theme='darkBlue'] .ecan-date-picker {\n .ant-picker {\n background-color: #05164c;\n border: 1px solid #1f63a3;\n color: #fff;\n box-shadow: inset 0 0 10px #005efe;\n }\n .ant-picker-input > input {\n color: #ffffff;\n }\n .anticon-calendar {\n color: #ffffff;\n }\n .anticon-close-circle {\n color: #333;\n }\n}\n[datav-theme='darkBlue'] .ecan-date-picker-dropdown {\n .ant-picker-panel {\n background: #05174e;\n border-bottom: 1px solid #69befa;\n }\n .ant-picker-header {\n color: #69befa;\n border-bottom: 1px solid #69befa;\n }\n .ant-picker-panel .ant-picker-footer {\n border-top: 1px solid #69befa;\n }\n .ant-picker-header button {\n color: #69befa;\n }\n .ant-picker-content th {\n color: #69befa;\n }\n .ant-picker-content td {\n color: #69befa;\n }\n .ant-picker-today-btn {\n color: #69befa;\n }\n .ant-picker-cell:hover:not(.ant-picker-cell-in-view) .ant-picker-cell-inner, .ant-picker-cell:hover:not(.ant-picker-cell-selected):not(.ant-picker-cell-range-start):not(.ant-picker-cell-range-end):not(.ant-picker-cell-range-hover-start):not(.ant-picker-cell-range-hover-end) .ant-picker-cell-inner {\n background: #1890ff;\n color: #ffffff;\n }\n .ant-picker-time-panel-column > li.ant-picker-time-panel-cell .ant-picker-time-panel-cell-inner {\n color: #69befa;\n }\n .ant-picker-time-panel-column > li.ant-picker-time-panel-cell .ant-picker-time-panel-cell-inner:hover {\n background: #1890ff;\n color: #ffffff;\n }\n\n .ant-picker-time-panel-column > li.ant-picker-time-panel-cell-selected .ant-picker-time-panel-cell-inner {\n background: #1890ff;\n color: #ffffff;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport DatePicker from './DatePicker.vue'\nexport const EcanDatePicker = withInstall(DatePicker)\nexport default EcanDatePicker\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface SelectOption {\n value: any\n label: string\n disabled?: boolean\n key?: string\n title?: string\n}\n\nexport type SelectOptions = SelectOption []\n\nexport interface SelectProps extends Props {\n data: SelectOptions // 同 options\n value: string,\n dataFieldNames: { label: string, value: string }\n mode: 'multiple' | 'tags' | 'combobox' | undefined\n maxTagCount: number | undefined\n}\n\nexport const selectProps: SelectProps = {\n ...props,\n name: '选择器',\n keyName: '选择器',\n width: '120px',\n height: '33px',\n type: 'ecanSelect',\n mode: undefined,\n data: [\n { label: '选项一', value: '1' },\n { label: '选项二', value: '2' },\n { label: '选项三', value: '3' }\n ],\n value: '',\n dataFieldNames: { label: 'label', value: 'value' },\n maxTagCount: undefined\n}\n\nexport const selectComponentProps = transformToComponentProps(selectProps)\n\nexport const selectEvents = ['selectChange']\n","<template>\n <div\n class=\"ecan-select\"\n :style=\"style\"\n >\n <a-select\n class=\"select\"\n v-model:value=\"myValue\"\n :options=\"options\"\n :mode=\"mode\"\n :getPopupContainer=\"getPopupContainer\"\n :field-names=\"dataFieldNames\"\n :maxTagCount=\"maxTagCount\"\n show-search\n :filter-option=\"filterOption\"\n @change=\"selectChange\"\n :loading=\"loading\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, inject, ref, unref } from 'vue'\nimport { Select as ASelect } from 'ant-design-vue'\nimport 'ant-design-vue/es/select/style'\nimport { selectComponentProps, SelectOptions } from './props'\nimport { useEmitEvent, useOnEvent, usePickComponentStyle, useRequestData } from '@/hooks'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport { RequestModalParam } from '@/utils/types'\nexport default defineComponent({\n name: 'EcanSelect',\n components: {\n ASelect\n },\n props: {\n ...selectComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n // 挂在在 ProviderConfig 或者 body 下\n const getPopupContainer = () => document.getElementById('ProviderConfig') || document.body\n const requestData = useRequestData(props)\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n const options = ref(props.data as SelectOptions)\n const myValue = ref(props.value || props.data[0])\n const dataFieldNames = props.dataFieldNames as { label:string, value:string }\n const filterOption = (input: string, option: any) => {\n const labelKey = dataFieldNames.label\n const valueKey = dataFieldNames.value\n let value: string | undefined\n // 没有 label 值才用 value\n // ant-select 组件如果没有传 label 值会使用 value 作为值\n const labelValue = option[labelKey]\n const valueValue = option[valueKey]\n if (labelValue != null) {\n value = labelValue\n } else if (valueValue != null) {\n value = valueValue\n }\n return !!(value?.toLowerCase().indexOf(input?.toLowerCase()) >= 0)\n }\n const loading = ref(false)\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n loading.value = true\n try {\n const res = await requestData()\n options.value = res?.data?.data?.rows || []\n const firstOption = unref(options)[0]\n if (props.value === '' && firstOption != null) {\n myValue.value = firstOption[dataFieldNames.value]\n }\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n // 初始化设置值\n setGlobalModel(props.id as string, {\n type: props.type,\n value: myValue\n })\n // 注册函数触发事件拦截器\n const emitEvent = useEmitEvent(props)\n const selectChange = emitEvent('selectChange', () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: myValue })\n })\n // TODO 传入需要注册的参数\n useOnEvent(props, {\n selectChange\n })\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n setRequest({\n id: props.id as string,\n requestFn: handleRequestData,\n sortNum: props.requestSort as number\n })\n return {\n style,\n getPopupContainer,\n myValue,\n selectChange,\n options,\n filterOption,\n loading\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.select {\n width: 100%;\n height: 100%;\n}\n</style>\n\n<style lang=\"less\">\n.ecan-select {\n .ant-select {\n height: 100% !important;\n width: 100% !important;\n }\n .ant-select-selector {\n height: 100% !important;\n width: 100% !important;\n display: flex;\n align-items: center;\n input {\n height: 100% !important;\n }\n }\n}\n\n[datav-theme='light'] {\n .ant-select:not(.ant-select-customize-input) .ant-select-selector {\n border: 1px solid #d9d9d9;\n }\n .ant-select-dropdown {\n color: rgba(0, 0, 0, 0.85);\n background: #ffffff;\n box-shadow: 0 2px 8px rgb(0 0 0 / 15%);\n }\n .ant-empty-img-simple-g {\n stroke: #d9d9d9;\n }\n .ant-empty-img-simple-ellipse {\n fill: #f5f5f5;\n }\n .ant-empty-img-simple-path {\n fill: #f5f5f5;\n stroke: #d9d9d9;\n }\n .ant-empty-description {\n color: rgba(0, 0, 0, 0.25);\n }\n .anticon-down {\n color: #333;\n }\n}\n\n[datav-theme='darkBlue'] {\n .ant-select:not(.ant-select-customize-input) .ant-select-selector {\n border: 1px solid #1f63a3;\n background-color: #05164c;\n box-shadow: inset 0 0 10px #005efe;\n color: #ffffff;\n }\n .ant-select-dropdown {\n box-shadow: inset 0 0 10px #005efe;\n color: #fff;\n background-color: #05164c;\n }\n .ant-empty-img-simple-g {\n stroke: #69befa;\n }\n .ant-empty-img-simple-ellipse {\n fill-opacity: 0;\n }\n .ant-empty-img-simple-path {\n fill: #69befa;\n stroke: #69befa;\n }\n .ant-empty-description {\n color: #69befa;\n }\n .anticon-down {\n color: #ffffff;\n }\n .ant-select-item {\n color: #ffffff;\n }\n .ant-select-item-option-active {\n background: #1f63a3;\n }\n .ant-select-item-option-selected:not(.ant-select-item-option-disabled) {\n background: #1f63a3;\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport Select from './Select.vue'\nexport const EcanSelect = withInstall(Select)\nexport default EcanSelect\nexport * from './props'\n","import { Props, props, transformToComponentProps } from '@/utils/props'\nimport { ManipulateType } from 'dayjs'\n\nexport interface RangePickerProps extends Props {\n picker: 'date' | 'week' | 'month' | 'quarter' | 'year'\n format: string\n startTime: string // 开始时间\n endTime: string // 结束时间\n useCurrentTime: boolean\n interval: number\n intervalUnit: ManipulateType\n}\n\nexport const rangePickerProps: RangePickerProps = {\n ...props,\n name: '范围选择器',\n keyName: '范围选择器',\n type: 'ecanRangePicker',\n width: '250px',\n height: '35px',\n picker: 'date',\n format: 'YYYY-MM-DD',\n startTime: '',\n endTime: '',\n useCurrentTime: true,\n interval: 1,\n intervalUnit: 'year'\n}\n\nexport const rangePickerComponentProps = transformToComponentProps(rangePickerProps)\n\nexport const rangePickerEvents = ['dateChange']\n","<template>\n <div\n class=\"ecan-range-picker\"\n :style=\"style\"\n >\n <a-range-picker\n class=\"range-picker\"\n dropdownClassName=\"ecan-range-picker-dropdown\"\n v-model:value=\"myValue\"\n :format=\"format\"\n :picker=\"picker\"\n :locale=\"locale\"\n :getPopupContainer=\"getPopupContainer\"\n @change=\"dateChange\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, unref, watch, ref } from 'vue'\nimport { rangePickerComponentProps } from './props'\nimport { useEmitEvent, useOnEvent, usePickComponentStyle } from '@/hooks'\nimport { RangePicker as ARangePicker } from 'ant-design-vue'\nimport locale from 'ant-design-vue/es/date-picker/locale/zh_CN'\n// antdv 中 range-picker 组件与 date-picker 共用一个样式\nimport 'ant-design-vue/es/date-picker/style'\nimport { GLOBAL_MODEL } from '@/utils/constant'\nimport dayjs, { Dayjs, ManipulateType } from 'dayjs'\nexport default defineComponent({\n name: 'EcanRangePicker',\n components: {\n ARangePicker\n },\n props: {\n ...rangePickerComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const getPopupContainer = () => document.getElementById('ProviderConfig') || document.body\n const myValue = ref<[Dayjs, Dayjs]>([null, null])\n watch(() => [props.startTime, props.endTime, props.useCurrentTime, props.interval, props.intervalUnit], ([startTime, endTime, useCurrentTime, interval, intervalUnit]: [string, string, boolean, number, ManipulateType]) => {\n let _startTime: Dayjs = null\n let _endTime: Dayjs = null\n if (useCurrentTime) {\n _startTime = dayjs().subtract(interval, intervalUnit)\n _endTime = dayjs()\n }\n if (startTime) {\n _startTime = dayjs(startTime)\n }\n if (endTime) {\n _endTime = dayjs(endTime)\n }\n myValue.value = [_startTime, _endTime]\n }, {\n immediate: true\n })\n const { setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n const myStartTime = computed(() => unref(myValue)[0])\n const myEndTime = computed(() => unref(myValue)[1])\n // 初始化设置值\n setGlobalModel(props.id as string, {\n type: props.type,\n format: props.format,\n startTime: myStartTime,\n endTime: myEndTime\n })\n // 注册函数触发事件拦截器\n const emitEvent = useEmitEvent(props)\n const dateChange = emitEvent('dateChange', () => {})\n useOnEvent(props, {\n dateChange\n })\n return {\n style,\n getPopupContainer,\n locale,\n dateChange,\n myValue\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.range-picker {\n width: 100%;\n height: 100%;\n}\n</style>\n\n<style lang=\"less\">\n[datav-theme='light'] .ecan-range-picker{\n .ant-picker {\n background-color: #ffffff;\n color: rgba(0, 0, 0, 0.85);\n border: 1px solid #d9d9d9;\n }\n .ant-picker-input > input {\n color: rgba(0, 0, 0, 0.85);\n }\n .anticon-calendar {\n color: #333;\n }\n .anticon-close-circle {\n color: #333;\n }\n .ant-picker-input > input::placeholder {\n color: #bfbfbf;\n }\n .ant-picker-separator .anticon {\n color:#333;\n }\n}\n\n[datav-theme='darkBlue'] .ecan-range-picker {\n .ant-picker {\n background-color: #05164c;\n border: 1px solid #1f63a3;\n color: #fff;\n box-shadow: inset 0 0 10px #005efe;\n }\n .ant-picker-input > input {\n color: #ffffff;\n }\n .anticon-calendar {\n color: #ffffff;\n }\n .anticon-close-circle {\n color: #333;\n }\n .ant-picker-separator .anticon {\n color:#fff;\n }\n}\n\n[datav-theme='darkBlue'] .ecan-range-picker-dropdown {\n .ant-picker-panel {\n background: #05174e;\n border-bottom: 1px solid #69befa;\n }\n .ant-picker-header {\n color: #69befa;\n border-bottom: 1px solid #69befa;\n }\n .ant-picker-panel .ant-picker-footer {\n border-top: 1px solid #69befa;\n }\n .ant-picker-header button {\n color: #69befa;\n }\n .ant-picker-content th {\n color: #69befa;\n }\n .ant-picker-content td {\n color: #69befa;\n }\n .ant-picker-today-btn {\n color: #69befa;\n }\n .ant-picker-cell-disabled .ant-picker-cell-inner {\n color: #999;\n }\n .ant-picker-cell-disabled::before {\n background: #333;\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport RangePicker from './RangePicker.vue'\nexport const EcanRangePicker = withInstall(RangePicker)\nexport default EcanRangePicker\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface ButtonProps extends Props {\n text: string\n mode: 'primary' | 'dashed' | 'link' | 'text' | 'default'\n danger: boolean\n shape: 'default' | 'circle' | 'round'\n href: string\n target: 'self' | 'blank' | 'event'\n fontSize: string\n fontWeight: number\n}\n\nexport const buttonProps: ButtonProps = {\n ...props,\n width: '200px',\n name: '按钮',\n keyName: '按钮',\n type: 'ecanButton',\n text: '按钮',\n mode: 'default',\n danger: false,\n shape: 'default',\n href: '',\n target: 'self',\n fontSize: '14px',\n fontWeight: 400\n}\n\n// 转化默认属性\nexport const buttonComponentProps = transformToComponentProps(buttonProps)\n\nexport const buttonEvents = ['click']\n","<template>\n <div\n class=\"ecan-button\"\n :style=\"style\"\n >\n <a-button\n block\n @click=\"click\"\n :type=\"mode\"\n :danger=\"danger\"\n :shape=\"shape\"\n :href=\"myHref\"\n :target=\"myTarget\"\n >\n <span\n :style=\"{\n fontSize,\n fontWeight\n }\"\n >\n {{ myText }}\n </span>\n </a-button>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, unref } from 'vue'\nimport { usePickComponentStyle, useEmitEvent, useVariablesInText } from '@/hooks'\nimport { Button as AButton } from 'ant-design-vue'\nimport 'ant-design-vue/es/button/style'\nimport { buttonComponentProps } from './props'\nexport default defineComponent({\n name: 'EcanButton',\n components: {\n AButton\n },\n props: {\n ...buttonComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n // 拦截触发事件\n const emitEvent = useEmitEvent(props)\n // click 是 event 名称\n const click = emitEvent('click', () => {\n // 打开链接\n const url = unref(myHref)\n if (url && props.target === 'event') {\n window.parent.postMessage({\n type: 'openPage',\n url\n }, '*')\n }\n })\n\n const myText = computed(() => useVariablesInText(props.text as string))\n // 空字符串会刷新页面\n const myHref = computed(() => useVariablesInText(props.href as string) || null)\n const myTarget = computed(() => {\n const target = props.target as 'self' | 'blank' | 'event'\n if (target === 'event' || unref(myHref) == null) {\n return undefined\n } else {\n const map = {\n self: '_self',\n blank: '_blank'\n }\n return map[target]\n }\n })\n return {\n style,\n click,\n myText,\n myHref,\n myTarget\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.ecan-button {\n .ant-btn {\n width: 100%;\n height: 100%;\n display: flex;\n justify-content: center;\n align-items: center;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Button from './Button.vue'\nexport const EcanButton = withInstall(Button)\nexport default EcanButton\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport type CheckboxOptions = {\n label: string\n value: string\n disabled?: boolean\n checked?: boolean\n indeterminate?: boolean\n} []\n\nexport interface CheckboxProps extends Props {\n value: string | string []\n data: CheckboxOptions\n}\n\nexport const checkboxProps: CheckboxProps = {\n ...props,\n width: '240px',\n id: '',\n left: '0px',\n top: '0px',\n name: '复选框',\n keyName: '复选框',\n rotate: '',\n type: 'ecanCheckbox',\n value: [],\n data: [\n { label: '选项一', value: '1', checked: true },\n { label: '选项二', value: '2', checked: true },\n { label: '选项三', value: '3' }\n ]\n}\n\n// 转化默认属性\nexport const checkboxComponentProps = transformToComponentProps(checkboxProps)\n\nexport const checkboxEvents = ['checkboxChange']\n","<template>\n <div class=\"ecan-checkbox\" :style=\"style\">\n <a-checkbox-group\n :options=\"myOption\"\n v-model:value=\"myValue\"\n @change=\"checkboxChange\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, inject, ref, unref, watch } from 'vue'\nimport { CheckboxGroup as ACheckboxGroup } from 'ant-design-vue'\nimport 'ant-design-vue/es/checkbox/style'\nimport { checkboxComponentProps, CheckboxOptions } from './props'\nimport { useEmitEvent, usePickComponentStyle, useRequestData } from '@/hooks'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport { RequestModalParam } from '@/utils/types'\nexport default defineComponent({\n name: 'EcanCheckbox',\n components: {\n ACheckboxGroup\n },\n props: {\n ...checkboxComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const myOption = ref<CheckboxOptions>([])\n const myValue = ref<string []>([])\n const handleDataAndOption = (data) => {\n const value = props.value\n let _value = [] as string []\n data.forEach((item) => {\n if (item.checked) {\n _value.push(item.value)\n }\n })\n if (typeof value === 'string' && value !== '') {\n _value = _value.concat(value.split(','))\n } else if (Array.isArray(value)) {\n _value = _value.concat(value)\n }\n myOption.value = data\n myValue.value = _value\n }\n watch(() => [props.data, props.value], ([data]: [CheckboxOptions, string | string []]) => {\n handleDataAndOption(data)\n }, {\n immediate: true,\n deep: true\n })\n const requestData = useRequestData(props)\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n const res = await requestData()\n const data = res?.data?.data?.rows || []\n handleDataAndOption(data)\n }\n const id = props.id as string\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n // 初始化设置值\n setGlobalModel(props.id as string, {\n type: props.type,\n value: myValue\n })\n // 注册函数触发事件拦截器\n const emitEvent = useEmitEvent(props)\n const checkboxChange = emitEvent('checkboxChange', () => {\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: myValue })\n })\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n setRequest({\n id: props.id as string,\n requestFn: handleRequestData,\n sortNum: props.requestSort as number\n })\n return {\n myOption,\n style,\n myValue,\n checkboxChange\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.ecan-checkbox {\n .ant-checkbox-group {\n width: 100%;\n height: 100%;\n display: flex;\n justify-content: space-between;\n align-content: space-between;\n flex-wrap: wrap;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Checkbox from './Checkbox.vue'\nexport const EcanCheckbox = withInstall(Checkbox)\nexport default EcanCheckbox\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps,\n Data,\n ValueTypeDataFieldNames\n} from '@/utils/props'\n\nexport interface PieProps extends Props {\n data: Data\n titleText: string\n titleSubtext: string\n titleLeft: string\n colors: string[]\n backgroundColor: string\n tooltipShow: boolean\n tooltipTrigger: 'item' | 'axis' | 'none'\n tooltipTextStyleColor: string\n tooltipFormatter: string\n legendShow: boolean\n legendLeft: 'left' | 'center' | 'right'\n legendTop: 'top' | 'middle' | 'bottom'\n legendOrient: 'vertical' | 'horizontal'\n legendTextStyleColor: string\n innerRadius: string\n outerRadius: string\n centerLeft: string\n centerTop: string\n labelShow: boolean\n labelFormatter: string\n labelFontSize: number\n labelPosition: 'outside' | 'inside' | 'center'\n labelLineShow: boolean\n labelColor: string\n isUseLabelColors: boolean\n labelLineLength: number\n labelLineLength2: number\n roseType: '' | 'radius' | 'area'\n valueTypeDataFieldNames: ValueTypeDataFieldNames,\n dataFieldConfigType: 'key' | 'value',\n gridContainLabel: boolean\n gridTop: string\n gridBottom: string\n gridLeft: string\n gridRight: string\n graphicConfig?: any\n toolboxShow: boolean\n toolboxOrient: 'horizontal' | 'vertical'\n toolboxItemSize: number // 工具栏 icon 的大小。\n toolboxItemGap: number // 工具栏 icon 每项之间的间隔。横向布局时为水平间隔,纵向布局时为纵向间隔。\n toolboxLeft: 'left' | 'center' | 'right'\n toolboxTop: 'top'| 'middle'| 'bottom'\n toolboxIconStyleBorderColor: string\n toolboxDownloadUrl: string\n toolboxInfoText: string\n}\n\nexport const pieProps: PieProps = {\n ...props,\n id: '',\n name: '饼图',\n keyName: '饼图',\n type: 'ecanPie',\n width: '400px',\n height: '400px',\n top: '',\n left: '',\n rotate: '',\n data: [\n { name: '名称一', value: 335 },\n { name: '名称二', value: 310 },\n { name: '名称三', value: 234 }\n ],\n titleText: '',\n titleSubtext: '',\n titleLeft: '',\n colors: ['#5470c6', '#91cc75', '#fac858', '#ee6666', '#73c0de', '#3ba272', '#fc8452', '#9a60b4', '#ea7ccc'],\n backgroundColor: '',\n tooltipShow: true,\n tooltipTextStyleColor: '',\n tooltipTrigger: 'item',\n tooltipFormatter: '{marker} {b} {c} ({d}%)',\n legendShow: true,\n legendTextStyleColor: '#333',\n legendOrient: 'vertical',\n legendTop: 'top',\n legendLeft: 'left',\n innerRadius: '0%',\n outerRadius: '60%',\n centerLeft: '50%',\n centerTop: '50%',\n labelShow: true,\n labelColor: '#333',\n isUseLabelColors: false,\n labelFontSize: 12,\n labelPosition: 'outside',\n labelFormatter: '{b}\\\\n{d}%',\n labelLineShow: true,\n labelLineLength: 10,\n labelLineLength2: 15,\n roseType: '',\n valueTypeDataFieldNames: { name: 'name', value: 'value', type: 'type' },\n dataFieldConfigType: 'value',\n gridContainLabel: true,\n gridTop: '10%',\n gridBottom: '10%',\n gridLeft: '5%',\n gridRight: '5%',\n graphicConfig: {},\n toolboxShow: false,\n toolboxOrient: 'horizontal',\n toolboxItemSize: 16,\n toolboxItemGap: 8,\n toolboxLeft: 'right',\n toolboxTop: 'top',\n toolboxIconStyleBorderColor: '#666',\n toolboxDownloadUrl: '',\n toolboxInfoText: '当前无说明信息'\n}\n// 转化默认属性\nexport const pieComponentProps = transformToComponentProps(pieProps)\n\nexport const pieEvents: Array<string> = ['click', 'refreshData', 'resetRecord']\n","import request from '@/utils/request'\nexport const useDownloadFile = async (downloadFileUrl: string) => {\n const res = await request.post(downloadFileUrl, {}, {\n responseType: 'blob'\n }) as any\n const { data, headers } = res\n const fileName = headers['content-disposition'].replace(/\\w+;filename=(.*)/, '$1')\n const blob = new Blob([data])\n const dom = document.createElement('a')\n const url = window.URL.createObjectURL(blob)\n dom.href = url\n dom.download = decodeURI(fileName)\n dom.style.display = 'none'\n document.body.appendChild(dom)\n dom.click()\n dom.parentNode?.removeChild(dom)\n window.URL.revokeObjectURL(url)\n}\nexport default useDownloadFile\n","<template>\n <div :style=\"style\">\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n autoresize\n @click=\"click\"\n />\n </spin>\n <a-modal\n wrap-class-name=\"full-modal\"\n width=\"100%\"\n :visible=\"visible\"\n :footer=\"null\"\n @cancel=\"hideModal\"\n >\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n />\n </spin>\n </a-modal>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, computed, watch, inject, ref, unref } from 'vue'\nimport {\n useEmitEvent,\n usePickComponentStyle,\n useRequestData,\n useTransformChartDataByAttrValue,\n useOnEvent,\n useRequestDiagramData,\n useVariablesInText\n} from '@/hooks'\nimport Echarts from '@/common/echarts'\nimport { pieComponentProps } from './props'\nimport { use } from 'echarts/core'\nimport { CanvasRenderer } from 'echarts/renderers'\nimport { PieChart } from 'echarts/charts'\nimport { TitleComponent, TooltipComponent, LegendComponent, ToolboxComponent } from 'echarts/components'\nimport { handleFormatter } from '@/utils/util'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport { ValueTypeDataFieldNames } from '@/utils/props'\nimport Spin from '@/common/spin'\nimport { Modal as AModal } from 'ant-design-vue'\nimport useDownloadFile from '@/hooks/useDownloadFile'\nimport { RequestModalParam } from '@/utils/types'\nuse([\n CanvasRenderer,\n PieChart,\n TitleComponent,\n ToolboxComponent,\n TooltipComponent,\n LegendComponent\n])\nexport default defineComponent({\n name: 'EcanPie',\n props: {\n ...pieComponentProps\n },\n components: {\n Spin,\n Echarts,\n AModal\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const dataset = ref<{ [key: string]: any }[]>([])\n const visible = ref(false)\n const hideModal = () => {\n visible.value = false\n }\n const option = computed(() => {\n let { data = [] } = unref(dataset)[0] || {}\n if (Array.isArray(props.colors)) {\n const isUseLabelColors = props.isUseLabelColors\n const colors = props.colors\n data = data.map((item, index) => ({\n label: isUseLabelColors ? { color: colors[index] } : {},\n ...item\n }))\n }\n return {\n toolbox: {\n show: props.toolboxShow,\n left: props.toolboxLeft,\n top: props.toolboxTop,\n itemSize: props.toolboxItemSize,\n itemGap: props.toolboxItemGap,\n feature: {\n myDownload: {\n show: true,\n title: '数据下载',\n icon: 'path://M502.010485 765.939573c3.773953 3.719718 8.686846 5.573949 13.596669 5.573949 0.075725 0 0.151449-0.010233 0.227174-0.011256 0.329505 0.016373 0.654916 0.050142 0.988514 0.050142 0.706081 0 1.400906-0.042979 2.087545-0.116657 4.352121-0.366344 8.607028-2.190899 11.961426-5.496178l335.053985-330.166675c7.619538-7.509021 7.709589-19.773346 0.200568-27.393907s-19.774369-7.711636-27.39493-0.201591L536.193005 706.304358 536.193005 50.019207c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 657.032164-306.881342-302.44838c-7.618515-7.509021-19.883863-7.419993-27.393907 0.199545-7.509021 7.619538-7.419993 19.884886 0.199545 27.393907L502.010485 765.939573z, M867.170139 711.020776c-10.698666 0-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 13.054317-10.620895 23.675212-23.676236 23.675212L205.182103 919.486668c-13.054317 0-23.676236-10.620895-23.676236-23.675212L181.505867 730.391962c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 34.416857 28.000728 62.416562 62.417585 62.416562l618.941638 0c34.417881 0 62.417585-27.999704 62.417585-62.416562L886.540302 730.391962C886.541325 719.693296 877.868805 711.020776 867.170139 711.020776z',\n onclick () {\n useDownloadFile(props.toolboxDownloadUrl as string)\n }\n },\n myDataZoom: {\n show: true,\n title: '放大',\n icon: 'path://M932.42 902.246667L792 761.793333A403.84 403.84 0 0 0 896 490.666667c0-223.86-181.473333-405.333333-405.333333-405.333334S85.333333 266.806667 85.333333 490.666667s181.473333 405.333333 405.333334 405.333333a403.84 403.84 0 0 0 271.126666-104l140.453334 140.453333a21.333333 21.333333 0 0 0 30.173333-30.173333zM128 490.666667c0-200.293333 162.373333-362.666667 362.666667-362.666667s362.666667 162.373333 362.666666 362.666667-162.373333 362.666667-362.666666 362.666666-362.666667-162.373333-362.666667-362.666666z m512 0a21.333333 21.333333 0 0 1-21.333333 21.333333H512v106.666667a21.333333 21.333333 0 0 1-42.666667 0V512H362.666667a21.333333 21.333333 0 0 1 0-42.666667h106.666666V362.666667a21.333333 21.333333 0 0 1 42.666667 0v106.666666h106.666667a21.333333 21.333333 0 0 1 21.333333 21.333334z',\n onclick () {\n visible.value = true\n }\n },\n myInfo: {\n show: true,\n title: '说明信息',\n icon: 'path://M512.50142 958.397886c-119.320573 0-231.499491-46.465265-315.871087-130.837884C112.258737 743.188406 65.792449 631.010511 65.792449 511.688915c0-119.319549 46.466288-231.499491 130.837884-315.871087C281.002952 111.445208 393.180847 64.979944 512.50142 64.979944s231.499491 46.465265 315.871087 130.837884c84.372619 84.372619 130.837884 196.551538 130.837884 315.871087 0 119.321596-46.465265 231.499491-130.837884 315.871087C744.000911 911.932622 631.821993 958.397886 512.50142 958.397886zM512.50142 105.962334c-223.718271 0-405.726581 182.00831-405.726581 405.726581s182.00831 405.726581 405.726581 405.726581c223.718271 0 405.727605-182.00831 405.727605-405.726581S736.220714 105.962334 512.50142 105.962334z M510.150886 775.953647c-18.107403 0-32.745798-14.678304-32.745798-32.785707L477.405087 452.191846c0-18.108426 14.638395-32.785707 32.745798-32.785707 18.107403 0 32.745798 14.678304 32.745798 32.785707l0 290.976094C542.896684 761.275343 528.258289 775.953647 510.150886 775.953647z M511.357364 296.458969m-45.080731 0a44.054 44.054 0 1 0 90.161463 0 44.054 44.054 0 1 0-90.161463 0Z',\n onclick () {\n AModal.info({\n title: '说明信息',\n content: (props.toolboxInfoText as string)\n })\n }\n }\n }\n },\n title: {\n text: props.titleText,\n subtext: props.titleSubtext,\n left: 'center'\n },\n grid: {\n top: props.gridTop,\n bottom: props.gridBottom,\n left: props.gridLeft,\n right: props.gridRight,\n containLabel: props.gridContainLabel\n },\n // 提示\n tooltip: {\n show: props.tooltipShow,\n trigger: props.tooltipTrigger,\n formatter: (params) => {\n const { marker, seriesName, name, value, percent, data } = params || {}\n return useVariablesInText(\n props.tooltipFormatter as string,\n {\n marker,\n name,\n value,\n percent,\n a: seriesName,\n b: name,\n c: value,\n d: percent,\n ...data\n },\n {\n useNewline: true,\n useSpace: true\n }\n )\n },\n textStyle: {\n color: props.tooltipTextStyleColor\n }\n },\n // 图例\n legend: {\n show: props.legendShow,\n orient: props.legendOrient,\n top: props.legendTop,\n left: props.legendLeft,\n textStyle: {\n color: props.legendTextStyleColor\n }\n },\n color: props.colors,\n series: [\n {\n data,\n type: 'pie',\n radius: [props.innerRadius, props.outerRadius],\n center: [props.centerLeft, props.centerTop],\n roseType: props.roseType,\n avoidLabelOverlap: false,\n // data: data.value,\n // data: props.data,\n // dimensions: ['name', 'count'],\n label: {\n show: props.labelPosition !== 'center' && props.labelShow,\n color: props.labelColor,\n fontSize: props.labelFontSize,\n position: props.labelPosition,\n formatter: handleFormatter(props.labelFormatter as string)\n },\n labelLine: {\n show: props.labelLineShow,\n length: props.labelLineLength,\n length2: props.labelLineLength2\n },\n emphasis: {\n itemStyle: {\n shadowBlur: 10,\n shadowOffsetX: 0,\n shadowColor: 'rgba(0, 0, 0, 0.5)'\n },\n label: {\n // show: props.labelPosition === 'center'\n }\n }\n }\n ]\n }\n })\n\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n\n const handleDataset = (data: any = [], dataFieldNames?: ValueTypeDataFieldNames) => {\n const { dataset: d } = useTransformChartDataByAttrValue(data, dataFieldNames)\n dataset.value = d\n }\n\n const handleIndicatorDataset = (data: any = [], dataFieldNames?: ValueTypeDataFieldNames) => {\n const chartData = useTransformChartDataByAttrValue(data, dataFieldNames)\n dataset.value = chartData.dataset\n }\n\n // 静态数据\n watch(() => props.data, (value: any) => {\n if (props.dataType === 'static' || unref(pageMode) === 'design') {\n handleDataset(value)\n }\n }, {\n immediate: true,\n deep: true\n })\n\n const loading = ref(false)\n const requestData = useRequestData(props)\n // 动态数据\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestData()\n handleDataset(res?.data?.data?.rows, props.valueTypeDataFieldNames as ValueTypeDataFieldNames)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const emitEvent = useEmitEvent(props)\n\n const click = emitEvent('click', (e) => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: e?.data })\n })\n\n // 指标库\n const requestDiagram = useRequestDiagramData(props)\n const handleIndicatorData = async () => {\n if (props.dataType !== 'indicator' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestDiagram()\n let newArr = []\n if (res?.data?.data?.columns?.length > 0) {\n const name = res.data.data.columns[0]\n const value = res.data.data.columns[1]\n newArr = res?.data?.data?.rows?.map(item => {\n return {\n name: item[name],\n value: item[value]\n }\n })\n }\n handleIndicatorDataset(newArr)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const chooseRequestOrDiagram = () => {\n if (unref(pageMode) === 'design') return\n handleIndicatorData()\n handleRequestData()\n }\n\n const refreshData = () => {\n chooseRequestOrDiagram()\n }\n\n const resetRecord = () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n setGlobalModel(id, { ...modal, RECORD: '' })\n }\n\n useOnEvent(props, {\n resetRecord,\n refreshData,\n click\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n setRequest({\n id: props.id as string,\n requestFn: chooseRequestOrDiagram,\n sortNum: props.requestSort as number\n })\n return {\n option,\n style,\n click,\n loading,\n visible,\n hideModal\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.full-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n height: calc(100vh);\n }\n .ant-modal-body {\n flex: 1;\n }\n\n .ant-modal-body {\n padding: 45px 30px 0;\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport Pie from './Pie.vue'\nexport const EcanPie = withInstall(Pie)\nexport default EcanPie\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps,\n Data,\n ValueTypeDataFieldNames,\n KeyTypeDataFieldNames\n} from '@/utils/props'\n\nexport interface LineProps extends Props {\n data: Data\n titleText: string\n titleSubtext: string\n titleLeft: string\n colors: string[]\n legendShow: boolean,\n legendLeft: 'left' | 'center' | 'right'\n legendTop: 'top' | 'middle' | 'bottom'\n legendOrient: 'vertical' | 'horizontal' // 标记点大小\n symbolSize: number // 线宽度\n lineStyleWidth: number // 线宽\n smooth: boolean // 光滑\n xAxisSplitLineShow: boolean // x轴展示分割线\n xAxisLabelColor: string // x轴名称颜色\n xAxisLineStyleColor: string // x轴名称颜色\n xAxisSplitLineStyleColor: string // x轴分割线颜色\n xAxisTickShow: boolean // 展示刻度\n xAxisLabelFormatter: string // 格式化\n yAxisSplitLineShow: boolean // y轴展示分割线\n yAxisSplitLineStyleColor: string // y轴分割线颜色\n yAxisLabelColor: string // y轴名称颜色\n yAxisLineStyleColor: string // y轴名称颜色\n yAxisLabelFormatter: string // 格式化\n valueTypeDataFieldNames: ValueTypeDataFieldNames\n keyTypeDataFieldNames: KeyTypeDataFieldNames\n dataFieldConfigType: 'key' | 'value'\n gridContainLabel: boolean\n gridTop: string\n gridBottom: string\n gridLeft: string\n gridRight: string\n graphicConfig?: any\n tooltipFormatter: string\n tooltipShow: boolean\n toolboxShow: boolean\n toolboxOrient: 'horizontal' | 'vertical'\n toolboxItemSize: number // 工具栏 icon 的大小。\n toolboxItemGap: number // 工具栏 icon 每项之间的间隔。横向布局时为水平间隔,纵向布局时为纵向间隔。\n toolboxLeft: 'left' | 'center' | 'right'\n toolboxTop: 'top'| 'middle'| 'bottom'\n toolboxIconStyleBorderColor: string\n toolboxDownloadUrl: string\n toolboxInfoText: string\n areaStyleOpacity: number\n}\n\nexport const lineProps: LineProps = {\n ...props,\n id: '',\n name: '折线图',\n keyName: '折线图',\n type: 'ecanLine',\n width: '400px',\n height: '400px',\n top: '',\n left: '',\n rotate: '',\n data: [\n { name: '名称一', value: 235, type: '类型一' },\n { name: '名称二', value: 280, type: '类型一' },\n { name: '名称三', value: 230, type: '类型一' },\n { name: '名称四', value: 335, type: '类型一' }\n ],\n titleText: '',\n titleSubtext: '',\n titleLeft: '',\n legendShow: true,\n legendOrient: 'horizontal',\n legendTop: 'top',\n legendLeft: 'center',\n colors: ['#5470c6', '#91cc75', '#fac858', '#ee6666', '#73c0de', '#3ba272', '#fc8452', '#9a60b4', '#ea7ccc'],\n symbolSize: 4,\n lineStyleWidth: 2,\n smooth: false,\n xAxisSplitLineShow: true,\n xAxisSplitLineStyleColor: '#333',\n xAxisLabelColor: '#333',\n xAxisLineStyleColor: '#333',\n xAxisTickShow: true,\n xAxisLabelFormatter: '{value}', // 格式化\n yAxisSplitLineShow: true,\n yAxisSplitLineStyleColor: '#333',\n yAxisLabelColor: '#333',\n yAxisLineStyleColor: '#333',\n yAxisLabelFormatter: '{value}',\n gridContainLabel: true,\n gridTop: '10%',\n gridBottom: '10%',\n gridLeft: '5%',\n gridRight: '5%',\n valueTypeDataFieldNames: { name: 'name', value: 'value', type: 'type' },\n keyTypeDataFieldNames: { name: 'name', types: [] },\n dataFieldConfigType: 'value',\n graphicConfig: {},\n tooltipShow: true,\n tooltipFormatter: '{marker} {a} {c}',\n toolboxShow: false,\n toolboxOrient: 'horizontal',\n toolboxItemSize: 16,\n toolboxItemGap: 8,\n toolboxLeft: 'right',\n toolboxTop: 'top',\n toolboxIconStyleBorderColor: '#666',\n toolboxDownloadUrl: '',\n toolboxInfoText: '当前无说明信息',\n areaStyleOpacity: 0\n}\n\n// 转化默认属性\nexport const lineComponentProps = transformToComponentProps(lineProps)\n\nexport const lineEvents = ['click', 'refreshData', 'resetRecord']\n","<template>\n <div :style=\"style\">\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n autoresize\n @click=\"click\"\n />\n </spin>\n <a-modal\n wrap-class-name=\"full-modal\"\n width=\"100%\"\n :visible=\"visible\"\n :footer=\"null\"\n @cancel=\"hideModal\"\n >\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n />\n </spin>\n </a-modal>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, ref, unref, watch } from 'vue'\nimport {\n useValueFormatter,\n useEmitEvent, useOnEvent,\n usePickComponentStyle,\n useRequestData, useRequestDiagramData,\n useTransformChartDataByAttrKey,\n useTransformChartDataByAttrValue, useVariablesInText\n} from '@/hooks'\nimport Echarts from '@/common/echarts'\nimport { lineComponentProps } from './props'\nimport { use } from 'echarts/core'\nimport { CanvasRenderer } from 'echarts/renderers'\nimport { LineChart } from 'echarts/charts'\nimport { TitleComponent, LegendComponent, ToolboxComponent } from 'echarts/components'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport { KeyTypeDataFieldNames, ValueTypeDataFieldNames } from '@/utils/props'\nimport Spin from '@/common/spin/Spin.vue'\nimport useDownloadFile from '@/hooks/useDownloadFile'\nimport { Modal as AModal } from 'ant-design-vue'\nimport { RequestModalParam } from '@/utils/types'\nuse([\n CanvasRenderer,\n LineChart,\n ToolboxComponent,\n TitleComponent,\n LegendComponent\n])\nexport default defineComponent({\n name: 'EcanLine',\n props: {\n ...lineComponentProps\n },\n components: {\n Spin,\n Echarts,\n AModal\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const series = ref<{ [key: string]: any }[]>([])\n const dimensions = ref<{ [key: string]: any }[]>([])\n const visible = ref(false)\n const hideModal = () => {\n visible.value = false\n }\n const option = computed(() => {\n // 这样写为了触发响应式\n // 返回函数中使用无法触发\n const xAxisLabelFormatter = props.xAxisLabelFormatter as string\n const yAxisLabelFormatter = props.yAxisLabelFormatter as string\n return {\n toolbox: {\n show: props.toolboxShow,\n left: props.toolboxLeft,\n top: props.toolboxTop,\n itemSize: props.toolboxItemSize,\n itemGap: props.toolboxItemGap,\n feature: {\n myDownload: {\n show: true,\n title: '数据下载',\n icon: 'path://M502.010485 765.939573c3.773953 3.719718 8.686846 5.573949 13.596669 5.573949 0.075725 0 0.151449-0.010233 0.227174-0.011256 0.329505 0.016373 0.654916 0.050142 0.988514 0.050142 0.706081 0 1.400906-0.042979 2.087545-0.116657 4.352121-0.366344 8.607028-2.190899 11.961426-5.496178l335.053985-330.166675c7.619538-7.509021 7.709589-19.773346 0.200568-27.393907s-19.774369-7.711636-27.39493-0.201591L536.193005 706.304358 536.193005 50.019207c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 657.032164-306.881342-302.44838c-7.618515-7.509021-19.883863-7.419993-27.393907 0.199545-7.509021 7.619538-7.419993 19.884886 0.199545 27.393907L502.010485 765.939573z, M867.170139 711.020776c-10.698666 0-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 13.054317-10.620895 23.675212-23.676236 23.675212L205.182103 919.486668c-13.054317 0-23.676236-10.620895-23.676236-23.675212L181.505867 730.391962c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 34.416857 28.000728 62.416562 62.417585 62.416562l618.941638 0c34.417881 0 62.417585-27.999704 62.417585-62.416562L886.540302 730.391962C886.541325 719.693296 877.868805 711.020776 867.170139 711.020776z',\n onclick () {\n useDownloadFile(props.toolboxDownloadUrl as string)\n }\n },\n myDataZoom: {\n show: true,\n title: '放大',\n icon: 'path://M932.42 902.246667L792 761.793333A403.84 403.84 0 0 0 896 490.666667c0-223.86-181.473333-405.333333-405.333333-405.333334S85.333333 266.806667 85.333333 490.666667s181.473333 405.333333 405.333334 405.333333a403.84 403.84 0 0 0 271.126666-104l140.453334 140.453333a21.333333 21.333333 0 0 0 30.173333-30.173333zM128 490.666667c0-200.293333 162.373333-362.666667 362.666667-362.666667s362.666667 162.373333 362.666666 362.666667-162.373333 362.666667-362.666666 362.666666-362.666667-162.373333-362.666667-362.666666z m512 0a21.333333 21.333333 0 0 1-21.333333 21.333333H512v106.666667a21.333333 21.333333 0 0 1-42.666667 0V512H362.666667a21.333333 21.333333 0 0 1 0-42.666667h106.666666V362.666667a21.333333 21.333333 0 0 1 42.666667 0v106.666666h106.666667a21.333333 21.333333 0 0 1 21.333333 21.333334z',\n onclick () {\n visible.value = true\n }\n },\n myInfo: {\n show: true,\n title: '说明信息',\n icon: 'path://M512.50142 958.397886c-119.320573 0-231.499491-46.465265-315.871087-130.837884C112.258737 743.188406 65.792449 631.010511 65.792449 511.688915c0-119.319549 46.466288-231.499491 130.837884-315.871087C281.002952 111.445208 393.180847 64.979944 512.50142 64.979944s231.499491 46.465265 315.871087 130.837884c84.372619 84.372619 130.837884 196.551538 130.837884 315.871087 0 119.321596-46.465265 231.499491-130.837884 315.871087C744.000911 911.932622 631.821993 958.397886 512.50142 958.397886zM512.50142 105.962334c-223.718271 0-405.726581 182.00831-405.726581 405.726581s182.00831 405.726581 405.726581 405.726581c223.718271 0 405.727605-182.00831 405.727605-405.726581S736.220714 105.962334 512.50142 105.962334z M510.150886 775.953647c-18.107403 0-32.745798-14.678304-32.745798-32.785707L477.405087 452.191846c0-18.108426 14.638395-32.785707 32.745798-32.785707 18.107403 0 32.745798 14.678304 32.745798 32.785707l0 290.976094C542.896684 761.275343 528.258289 775.953647 510.150886 775.953647z M511.357364 296.458969m-45.080731 0a44.054 44.054 0 1 0 90.161463 0 44.054 44.054 0 1 0-90.161463 0Z',\n onclick () {\n AModal.info({\n title: '说明信息',\n content: (props.toolboxInfoText as string)\n })\n }\n }\n }\n },\n title: {\n text: props.titleText,\n subText: props.titleSubtext,\n left: 'center'\n },\n grid: {\n top: props.gridTop,\n bottom: props.gridBottom,\n left: props.gridLeft,\n right: props.gridRight,\n containLabel: props.gridContainLabel\n },\n color: props.colors,\n tooltip: {\n trigger: 'axis',\n show: props.tooltipShow,\n formatter: (params) => {\n const len = params.length\n let formatter = ''\n let tooltipFormatter = props.tooltipFormatter as string\n if (tooltipFormatter === '') {\n tooltipFormatter = '{marker} {a} {c}'\n }\n for (let i = 0; i < len; i++) {\n const { marker, seriesName, name, value, data } = params[i] || {}\n if (i === 0) {\n formatter += `${name}<br/>`\n }\n formatter += useVariablesInText(\n tooltipFormatter,\n {\n marker,\n name,\n value,\n a: seriesName,\n b: name,\n c: value,\n ...data\n },\n {\n useNewline: true,\n useSpace: true\n })\n formatter += '<br/>'\n }\n return formatter\n }\n },\n xAxis: {\n type: 'category',\n data: unref(dimensions),\n splitLine: {\n show: props.xAxisSplitLineShow,\n lineStyle: {\n color: props.xAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.xAxisLabelColor,\n formatter (value: string) {\n return useValueFormatter(xAxisLabelFormatter, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.xAxisLineStyleColor\n }\n },\n axisTick: {\n show: props.xAxisTickShow\n }\n },\n yAxis: {\n type: 'value',\n splitLine: {\n show: props.yAxisSplitLineShow,\n lineStyle: {\n color: props.yAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.yAxisLabelColor,\n formatter (value: string) {\n return useValueFormatter(yAxisLabelFormatter, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.yAxisLineStyleColor\n }\n }\n },\n // 图例\n legend: {\n show: props.legendShow,\n orient: props.legendOrient,\n top: props.legendTop,\n left: props.legendLeft\n },\n series: unref(series)\n }\n })\n\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n\n const handleDataset = (data: any = [], useDataFieldNames: boolean = false) => {\n // dataFieldNames 字段映射\n let chartData\n if (props.dataFieldConfigType === 'key') {\n const dataFieldNames = useDataFieldNames ? props.keyTypeDataFieldNames as KeyTypeDataFieldNames : null\n chartData = useTransformChartDataByAttrKey(data, dataFieldNames)\n } else if (props.dataFieldConfigType === 'value') {\n const dataFieldNames = useDataFieldNames ? props.valueTypeDataFieldNames as ValueTypeDataFieldNames : null\n chartData = useTransformChartDataByAttrValue(data, dataFieldNames)\n }\n dimensions.value = chartData.dimensions\n const dataset = chartData.dataset\n const temp = [] as { [key: string]: any } []\n const len = dataset.length\n for (let i = 0; i < len; i++) {\n temp.push({\n type: 'line',\n ...dataset[i],\n symbolSize: props.symbolSize,\n smooth: props.smooth,\n areaStyle: {\n // color: {\n // type: 'linear',\n // x: 0,\n // y: 0,\n // x2: 0,\n // y2: 1,\n // colorStops: [{\n // offset: 0, color: props.colors[i] // 0% 处的颜色\n // }, {\n // offset: 1, color: '#fff' // 100% 处的颜色\n // }],\n // global: false // 缺省为 false\n // },\n opacity: props.areaStyleOpacity\n },\n lineStyle: {\n width: props.lineStyleWidth\n }\n })\n }\n series.value = temp\n }\n\n const handleIndicatorDataset = (data: any = [], keyTypeDataFieldNames: KeyTypeDataFieldNames, useDataFieldNames: boolean = false) => {\n const dataFieldNames = useDataFieldNames ? keyTypeDataFieldNames : null\n const chartData = useTransformChartDataByAttrKey(data, dataFieldNames)\n dimensions.value = chartData.dimensions\n const dataset = chartData.dataset\n const temp = [] as { [key: string]: any } []\n const len = dataset.length\n for (let i = 0; i < len; i++) {\n temp.push({\n type: 'line',\n ...dataset[i],\n symbolSize: props.symbolSize,\n smooth: props.smooth,\n lineStyle: {\n width: props.lineStyleWidth\n }\n })\n }\n series.value = temp\n }\n\n // 静态数据\n watch(() => [props.data, props.symbolSize, props.smooth, props.lineStyleWidth, props.areaStyleOpacity], ([data]) => {\n if (props.dataType === 'static' || unref(pageMode) === 'design') {\n handleDataset(data as { [key: string]: any }[])\n }\n }, {\n immediate: true,\n deep: true\n })\n\n const loading = ref(false)\n const requestData = useRequestData(props)\n // 动态数据\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestData()\n handleDataset(res?.data?.data?.rows, true)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const emitEvent = useEmitEvent(props)\n\n const click = emitEvent('click', (e) => {\n // TODO 设置是否保存钻取数据\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: e?.data })\n })\n\n // 指标库\n const requestDiagram = useRequestDiagramData(props)\n const handleIndicatorData = async () => {\n if (props.dataType !== 'indicator' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestDiagram()\n let a\n if (res?.data?.data?.columns?.length > 0) {\n a = {\n name: res.data.data.columns[0],\n types: res.data.data.columns.slice(1).map(it => {\n return { label: it, value: it }\n })\n }\n }\n handleIndicatorDataset(res?.data?.data?.rows, a, true)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const chooseRequestOrDiagram = () => {\n if (unref(pageMode) === 'design') return\n handleIndicatorData()\n handleRequestData()\n }\n\n const refreshData = () => {\n chooseRequestOrDiagram()\n }\n\n const resetRecord = () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n setGlobalModel(id, { ...modal, RECORD: '' })\n }\n\n useOnEvent(props, {\n refreshData,\n resetRecord,\n click\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n\n setRequest({\n id: props.id as string,\n requestFn: chooseRequestOrDiagram,\n sortNum: props.requestSort as number\n })\n\n return {\n option,\n style,\n click,\n loading,\n visible,\n hideModal\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.full-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n height: calc(100vh);\n }\n .ant-modal-body {\n flex: 1;\n }\n\n .ant-modal-body {\n padding: 45px 30px 0;\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport Line from './Line.vue'\nexport const EcanLine = withInstall(Line)\nexport default EcanLine\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps,\n Data,\n KeyTypeDataFieldNames,\n ValueTypeDataFieldNames\n} from '@/utils/props'\n\nexport interface BarProps extends Props {\n data: Data\n titleText: string\n titleSubtext: string\n colors: string []\n legendShow: boolean\n legendTextStyleColor: string\n legendLeft: 'left' | 'center' | 'right'\n legendTop: 'top' | 'middle' | 'bottom'\n legendOrient: 'vertical' | 'horizontal'\n xAxisSplitLineShow: boolean // x轴展示分割线\n xAxisLabelColor: string // x轴名称颜色\n xAxisLabelWidth: number | undefined // x轴名称宽度\n xAxisLabelOverflow: 'none' | 'truncate' | 'break' | 'breakAll' // x轴名称溢出操作\n xAxisLabelRotate: number // x轴名称旋转\n xAxisLineStyleColor: string // x轴名称颜色\n xAxisTickShow: boolean // 展示刻度\n xAxisLabelFormatter: string\n yAxisLabelWidth: number | undefined // y轴名称宽度\n yAxisLabelOverflow: 'none' | 'truncate' | 'break' | 'breakAll' // y轴名称溢出操作\n yAxisLabelRotate: number // y轴名称旋转\n yAxisSplitLineShow: boolean // y轴展示分割线\n xAxisSplitLineStyleColor: string // x轴分割线颜色\n yAxisSplitLineStyleColor: string // y轴分割线颜色\n yAxisLabelColor: string // y轴名称颜色\n yAxisLineStyleColor: string // y轴名称颜色\n yAxisLabelFormatter: string\n valueTypeDataFieldNames: ValueTypeDataFieldNames\n keyTypeDataFieldNames: KeyTypeDataFieldNames\n dataFieldConfigType: 'key' | 'value'\n tooltipShow: boolean\n tooltipTextStyleColor: string\n tooltipFormatter: string,\n gridContainLabel: boolean\n gridTop: string\n gridBottom: string\n gridLeft: string\n gridRight: string\n barWidth: string\n graphicConfig: {\n [key:string]: any,\n // 全部属性, 为了属性可拓展,所以在设计器中自由添加\n // classification: { [key:string]: any }\n // series: { [key:string]: any }\n // indicatorList: { [key:string]: any } []\n // sqlConditions: { [key:string]: any } []\n // idxLibMode: string\n // source: string\n // dataViewId: string\n chartType: 'bar' // 图表类型,后台接口\n plugin: '1' // 插件类型,后台接口\n layer: '2' // 图类型, 后台接口\n }\n toolboxShow: boolean\n toolboxOrient: 'horizontal' | 'vertical'\n toolboxItemSize: number // 工具栏 icon 的大小。\n toolboxItemGap: number // 工具栏 icon 每项之间的间隔。横向布局时为水平间隔,纵向布局时为纵向间隔。\n toolboxLeft: 'left' | 'center' | 'right'\n toolboxTop: 'top'| 'middle'| 'bottom'\n toolboxIconStyleBorderColor: string\n toolboxDownloadUrl: string\n toolboxInfoText: string\n isUseHorizontalAxis: boolean\n axisInverse: boolean\n xAxisInverse: boolean\n yAxisInverse: boolean\n isStack: boolean\n labelShow: boolean\n labelFontSize: string\n labelPosition: 'inside' | 'top' | 'bottom' | 'right' | 'left'\n labelColor: string\n}\n\nexport const barProps: BarProps = {\n ...props,\n id: '',\n name: '柱状图',\n keyName: '柱状图',\n type: 'ecanBar',\n width: '400px',\n height: '400px',\n top: '',\n left: '',\n rotate: '',\n xAxisLabelFormatter: '{value}',\n yAxisLabelFormatter: '{value}',\n data: [\n {\n name: '名称一',\n value: 335,\n type: '类型一'\n },\n {\n name: '名称二',\n value: 310,\n type: '类型一'\n },\n {\n name: '名称三',\n value: 310,\n type: '类型一'\n }\n ],\n titleText: '',\n titleSubtext: '',\n colors: ['#5470c6', '#91cc75', '#fac858', '#ee6666', '#73c0de', '#3ba272', '#fc8452', '#9a60b4', '#ea7ccc'],\n legendShow: true,\n legendTextStyleColor: '#333',\n legendOrient: 'horizontal',\n legendTop: 'top',\n legendLeft: 'center',\n tooltipShow: true,\n tooltipTextStyleColor: '',\n tooltipFormatter: '{marker} {a} {c}',\n xAxisSplitLineShow: true,\n xAxisSplitLineStyleColor: '#333',\n xAxisLabelColor: '#333',\n xAxisLabelWidth: undefined,\n xAxisLabelRotate: 0,\n xAxisLabelOverflow: 'none',\n xAxisLineStyleColor: '#333',\n xAxisTickShow: true,\n yAxisLabelWidth: undefined,\n yAxisLabelRotate: 0,\n yAxisLabelOverflow: 'none',\n yAxisSplitLineShow: true,\n yAxisSplitLineStyleColor: '#333',\n yAxisLabelColor: '#333',\n yAxisLineStyleColor: '#333',\n valueTypeDataFieldNames: { name: 'name', value: 'value', type: 'type' },\n keyTypeDataFieldNames: { name: 'name', types: [] },\n dataFieldConfigType: 'value',\n barWidth: '40%',\n gridContainLabel: true,\n gridTop: '10%',\n gridBottom: '10%',\n gridLeft: '5%',\n gridRight: '5%',\n graphicConfig: {\n chartType: 'bar', // 图表类型,后台接口\n plugin: '1', // 插件类型,后台接口\n layer: '2' // 图类型, 后台接口\n },\n toolboxShow: false,\n toolboxOrient: 'horizontal',\n toolboxItemSize: 16,\n toolboxItemGap: 8,\n toolboxLeft: 'right',\n toolboxTop: 'top',\n toolboxIconStyleBorderColor: '#666',\n toolboxDownloadUrl: '',\n toolboxInfoText: '当前无说明信息',\n isUseHorizontalAxis: false,\n axisInverse: false,\n xAxisInverse: false,\n yAxisInverse: false,\n isStack: false,\n labelShow: false,\n labelFontSize: '12px',\n labelPosition: 'inside',\n labelColor: ''\n}\n\n// 转化默认属性\nexport const barComponentProps = transformToComponentProps(barProps)\n\nexport const barEvents: string [] = ['refreshData', 'click', 'resetRecord']\n","<template>\n <div class=\"ecan-bar\" :style=\"style\">\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n @click=\"click\"\n />\n </spin>\n <a-modal\n wrap-class-name=\"full-modal\"\n width=\"100%\"\n :visible=\"visible\"\n :footer=\"null\"\n @cancel=\"hideModal\"\n >\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n />\n </spin>\n </a-modal>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, computed, ref, watch, inject, unref } from 'vue'\nimport {\n usePickComponentStyle,\n useOnEvent,\n useTransformChartDataByAttrValue,\n useTransformChartDataByAttrKey,\n useEmitEvent,\n useRequestData,\n useIndicatorData,\n useValueFormatter,\n useVariablesInText\n} from '@/hooks'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport { ValueTypeDataFieldNames, KeyTypeDataFieldNames, Data } from '@/utils/props'\nimport Echarts from '@/common/echarts'\nimport { barComponentProps } from './props'\nimport { use } from 'echarts/core'\nimport { CanvasRenderer } from 'echarts/renderers'\nimport { BarChart } from 'echarts/charts'\nimport Spin from '@/common/spin'\nimport { Modal as AModal } from 'ant-design-vue'\nimport {\n TitleComponent,\n LegendComponent,\n DatasetComponent,\n ToolboxComponent\n} from 'echarts/components'\nimport { RequestModalParam } from '@/utils/types'\nimport useDownloadFile from '@/hooks/useDownloadFile'\nuse([\n CanvasRenderer,\n BarChart,\n TitleComponent,\n LegendComponent,\n DatasetComponent,\n ToolboxComponent\n])\nexport default defineComponent({\n name: 'EcanBar',\n props: {\n ...barComponentProps\n },\n components: {\n Spin,\n Echarts,\n AModal\n },\n setup (props, { expose }) {\n const style = usePickComponentStyle(props)\n const dataSource = ref<{ [key: string]: any }[]>([])\n const visible = ref(false)\n const hideModal = () => {\n visible.value = false\n }\n const series = computed(() => {\n const ds = unref(dataSource)\n const len = ds.length\n const series = []\n for (let i = 0; i < len; i++) {\n const item = {\n ...ds[i],\n type: 'bar',\n barWidth: props.barWidth\n } as { [key:string]: any }\n if (props.isStack) {\n item.stack = 'stack'\n }\n item.label = {\n show: props.labelShow,\n fontSize: props.labelFontSize,\n position: props.labelPosition,\n color: props.labelColor\n }\n series.push(item)\n }\n return series\n })\n const dimensions = ref<{ [key: string]: any }[]>([])\n const loading = ref(false)\n const option = computed(() => {\n // 这样写为了触发响应式\n // 返回函数中使用无法触发\n const yAxisLabelFormatter = props.yAxisLabelFormatter as string\n const xAxisLabelFormatter = props.xAxisLabelFormatter as string\n return {\n toolbox: {\n show: props.toolboxShow,\n left: props.toolboxLeft,\n top: props.toolboxTop,\n itemSize: props.toolboxItemSize,\n itemGap: props.toolboxItemGap,\n feature: {\n myDownload: {\n show: true,\n title: '数据下载',\n icon: 'path://M502.010485 765.939573c3.773953 3.719718 8.686846 5.573949 13.596669 5.573949 0.075725 0 0.151449-0.010233 0.227174-0.011256 0.329505 0.016373 0.654916 0.050142 0.988514 0.050142 0.706081 0 1.400906-0.042979 2.087545-0.116657 4.352121-0.366344 8.607028-2.190899 11.961426-5.496178l335.053985-330.166675c7.619538-7.509021 7.709589-19.773346 0.200568-27.393907s-19.774369-7.711636-27.39493-0.201591L536.193005 706.304358 536.193005 50.019207c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 657.032164-306.881342-302.44838c-7.618515-7.509021-19.883863-7.419993-27.393907 0.199545-7.509021 7.619538-7.419993 19.884886 0.199545 27.393907L502.010485 765.939573z, M867.170139 711.020776c-10.698666 0-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 13.054317-10.620895 23.675212-23.676236 23.675212L205.182103 919.486668c-13.054317 0-23.676236-10.620895-23.676236-23.675212L181.505867 730.391962c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 34.416857 28.000728 62.416562 62.417585 62.416562l618.941638 0c34.417881 0 62.417585-27.999704 62.417585-62.416562L886.540302 730.391962C886.541325 719.693296 877.868805 711.020776 867.170139 711.020776z',\n onclick () {\n useDownloadFile(props.toolboxDownloadUrl as string)\n }\n },\n myDataZoom: {\n show: true,\n title: '放大',\n icon: 'path://M932.42 902.246667L792 761.793333A403.84 403.84 0 0 0 896 490.666667c0-223.86-181.473333-405.333333-405.333333-405.333334S85.333333 266.806667 85.333333 490.666667s181.473333 405.333333 405.333334 405.333333a403.84 403.84 0 0 0 271.126666-104l140.453334 140.453333a21.333333 21.333333 0 0 0 30.173333-30.173333zM128 490.666667c0-200.293333 162.373333-362.666667 362.666667-362.666667s362.666667 162.373333 362.666666 362.666667-162.373333 362.666667-362.666666 362.666666-362.666667-162.373333-362.666667-362.666666z m512 0a21.333333 21.333333 0 0 1-21.333333 21.333333H512v106.666667a21.333333 21.333333 0 0 1-42.666667 0V512H362.666667a21.333333 21.333333 0 0 1 0-42.666667h106.666666V362.666667a21.333333 21.333333 0 0 1 42.666667 0v106.666666h106.666667a21.333333 21.333333 0 0 1 21.333333 21.333334z',\n onclick () {\n visible.value = true\n }\n },\n myInfo: {\n show: true,\n title: '说明信息',\n icon: 'path://M512.50142 958.397886c-119.320573 0-231.499491-46.465265-315.871087-130.837884C112.258737 743.188406 65.792449 631.010511 65.792449 511.688915c0-119.319549 46.466288-231.499491 130.837884-315.871087C281.002952 111.445208 393.180847 64.979944 512.50142 64.979944s231.499491 46.465265 315.871087 130.837884c84.372619 84.372619 130.837884 196.551538 130.837884 315.871087 0 119.321596-46.465265 231.499491-130.837884 315.871087C744.000911 911.932622 631.821993 958.397886 512.50142 958.397886zM512.50142 105.962334c-223.718271 0-405.726581 182.00831-405.726581 405.726581s182.00831 405.726581 405.726581 405.726581c223.718271 0 405.727605-182.00831 405.727605-405.726581S736.220714 105.962334 512.50142 105.962334z M510.150886 775.953647c-18.107403 0-32.745798-14.678304-32.745798-32.785707L477.405087 452.191846c0-18.108426 14.638395-32.785707 32.745798-32.785707 18.107403 0 32.745798 14.678304 32.745798 32.785707l0 290.976094C542.896684 761.275343 528.258289 775.953647 510.150886 775.953647z M511.357364 296.458969m-45.080731 0a44.054 44.054 0 1 0 90.161463 0 44.054 44.054 0 1 0-90.161463 0Z',\n onclick () {\n AModal.info({\n title: '说明信息',\n content: (props.toolboxInfoText as string)\n })\n }\n }\n }\n },\n title: {\n text: props.titleText,\n subtext: props.titleSubtext,\n left: 'center'\n },\n grid: {\n top: props.gridTop,\n bottom: props.gridBottom,\n left: props.gridLeft,\n right: props.gridRight,\n containLabel: props.gridContainLabel\n },\n color: props.colors,\n tooltip: {\n trigger: 'axis',\n show: props.tooltipShow,\n formatter: (params) => {\n const len = params.length\n let formatter = ''\n let tooltipFormatter = props.tooltipFormatter as string\n if (tooltipFormatter === '') {\n tooltipFormatter = '{marker} {a} {c}'\n }\n for (let i = 0; i < len; i++) {\n const { marker, seriesName, name, value, data } = params[i] || {}\n if (i === 0) {\n formatter += `${name}<br/>`\n }\n formatter += useVariablesInText(\n tooltipFormatter,\n {\n marker,\n name,\n value,\n a: seriesName,\n b: name,\n c: value,\n ...data\n },\n {\n useNewline: true,\n useSpace: true\n })\n formatter += '<br/>'\n }\n return formatter\n },\n // valueFormatter: (value) => {\n // return useVariablesInText(props.tooltipValueFormatter as string, { value })\n // },\n textStyle: {\n color: props.tooltipTextStyleColor\n }\n },\n legend: {\n show: props.legendShow,\n orient: props.legendOrient,\n top: props.legendTop,\n left: props.legendLeft,\n textStyle: {\n color: props.legendTextStyleColor\n }\n },\n xAxis: {\n type: props.isUseHorizontalAxis ? 'value' : 'category',\n data: props.isUseHorizontalAxis ? null : unref(dimensions),\n inverse: props.isUseHorizontalAxis ? props.xAxisInverse : props.axisInverse,\n splitLine: {\n show: props.xAxisSplitLineShow,\n lineStyle: {\n color: props.xAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.xAxisLabelColor,\n interval: 0,\n rotate: props.xAxisLabelRotate,\n width: props.xAxisLabelWidth,\n overflow: props.xAxisLabelOverflow,\n formatter (value: string) {\n return useValueFormatter(xAxisLabelFormatter, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.xAxisLineStyleColor\n }\n },\n axisTick: {\n show: props.xAxisTickShow\n }\n },\n yAxis: {\n type: props.isUseHorizontalAxis ? 'category' : 'value',\n data: props.isUseHorizontalAxis ? unref(dimensions) : null,\n inverse: props.isUseHorizontalAxis ? props.axisInverse : props.yAxisInverse,\n splitLine: {\n show: props.yAxisSplitLineShow,\n lineStyle: {\n color: props.yAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.yAxisLabelColor,\n rotate: props.yAxisLabelRotate,\n width: props.yAxisLabelWidth,\n overflow: props.yAxisLabelOverflow,\n formatter (value: string) {\n return useValueFormatter(yAxisLabelFormatter, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.yAxisLineStyleColor\n }\n }\n },\n series: unref(series)\n }\n })\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n\n const handleDataset = (data: Data = [], useDataFieldNames: boolean = false) => {\n let chartData = {} as { [key:string]: any }\n if (props.dataFieldConfigType === 'key') {\n const dataFieldNames = useDataFieldNames ? props.keyTypeDataFieldNames as KeyTypeDataFieldNames : null\n chartData = useTransformChartDataByAttrKey(data, dataFieldNames)\n } else if (props.dataFieldConfigType === 'value') {\n const dataFieldNames = useDataFieldNames ? props.valueTypeDataFieldNames as ValueTypeDataFieldNames : null\n chartData = useTransformChartDataByAttrValue(data, dataFieldNames)\n }\n dataSource.value = chartData.dataset\n dimensions.value = chartData.dimensions\n }\n\n const handleIndicatorDataset = (data: any = [], keyTypeDataFieldNames: KeyTypeDataFieldNames, useDataFieldNames: boolean = false) => {\n const dataFieldNames = useDataFieldNames ? keyTypeDataFieldNames : null\n const chartData = useTransformChartDataByAttrKey(data, dataFieldNames)\n dataSource.value = chartData.dataset\n dimensions.value = chartData.dimensions\n }\n\n // 静态数据\n watch(() => props.data, (value: any) => {\n if (props.dataType === 'static' || unref(pageMode) === 'design') {\n handleDataset(value)\n }\n }, {\n immediate: true,\n deep: true\n })\n\n const requestData = useRequestData(props)\n // 动态数据\n const handleRequestData = async () => {\n try {\n loading.value = true\n const res = await requestData()\n handleDataset(res?.data?.data?.rows, true)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n // 指标库\n const indicatorData = useIndicatorData(props)\n const handleIndicatorData = async () => {\n try {\n loading.value = true\n const res = await indicatorData()\n const { columns = [], rows = [] } = res?.data?.data ?? {}\n let fieldNames\n if (columns.length > 0) {\n fieldNames = {\n name: columns[0],\n types: columns.slice(1).map(column => {\n return {\n label: column,\n value: column\n }\n })\n }\n }\n handleIndicatorDataset(rows, fieldNames, true)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const refreshData = () => {\n if (unref(pageMode) === 'design') return\n switch (props.dataType) {\n case 'indicator':\n handleIndicatorData()\n break\n case 'request':\n handleRequestData()\n break\n }\n }\n\n expose({\n refreshData\n })\n\n const emitEvent = useEmitEvent(props)\n\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n const click = emitEvent('click', (e) => {\n // TODO 设置是否保存钻取数据\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: e.data })\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n\n setRequest({\n id: props.id as string,\n requestFn: refreshData,\n sortNum: props.requestSort as number\n })\n\n const resetRecord = () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n setGlobalModel(id, { ...modal, RECORD: '' })\n }\n\n useOnEvent(props, {\n refreshData,\n click,\n resetRecord\n })\n\n return {\n option,\n style,\n refreshData,\n click,\n loading,\n visible,\n hideModal\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.full-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n height: calc(100vh);\n }\n .ant-modal-body {\n flex: 1;\n }\n .ant-modal-body {\n padding: 45px 30px 0;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Bar from './Bar.vue'\nexport const EcanBar = withInstall(Bar)\nexport default EcanBar\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps,\n Data\n} from '@/utils/props'\n\nexport interface ScatterProps extends Props {\n data: Data\n titleText: string\n titleSubtext: string\n colors: string []\n legendShow: boolean,\n tooltipShow: boolean,\n tooltipTrigger: 'item' | 'axis' | 'none'\n tooltipFormatter: string\n legendLeft: 'left' | 'center' | 'right'\n legendTop: 'top' | 'middle' | 'bottom'\n legendOrient: 'vertical' | 'horizontal'\n symbolSize: number // 标记点大小\n xAxisSplitLineShow: boolean // x轴展示分割线\n xAxisLabelColor: string // x轴名称颜色\n xAxisLineStyleColor: string // x轴名称颜色\n xAxisTickShow: boolean // 展示刻度\n xAxisLabelFormatter: string // 格式化\n yAxisSplitLineShow: boolean // y轴展示分割线\n xAxisSplitLineStyleColor: string // x轴分割线颜色\n yAxisSplitLineStyleColor: string // y轴分割线颜色\n yAxisLabelColor: string // y轴名称颜色\n yAxisLineStyleColor: string // y轴名称颜色\n yAxisLabelFormatter: string // 格式化\n gridContainLabel: boolean\n gridTop: string\n gridBottom: string\n gridLeft: string\n gridRight: string\n dataFieldNames: { name: string, value: string }\n graphicConfig?: any\n toolboxShow: boolean\n toolboxOrient: 'horizontal' | 'vertical'\n toolboxItemSize: number // 工具栏 icon 的大小。\n toolboxItemGap: number // 工具栏 icon 每项之间的间隔。横向布局时为水平间隔,纵向布局时为纵向间隔。\n toolboxLeft: 'left' | 'center' | 'right'\n toolboxTop: 'top'| 'middle'| 'bottom'\n toolboxIconStyleBorderColor: string\n toolboxDownloadUrl: string\n toolboxInfoText: string\n}\n\nexport const scatterProps: ScatterProps = {\n ...props,\n id: '',\n name: '散点图',\n keyName: '散点图',\n type: 'ecanScatter',\n width: '400px',\n height: '400px',\n top: '',\n left: '',\n rotate: '',\n data: [\n { name: 233, value: 335 },\n { name: 556, value: 310 },\n { name: 56, value: 234 }\n ],\n titleText: '',\n titleSubtext: '',\n tooltipShow: true,\n tooltipTrigger: 'item',\n tooltipFormatter: '{marker} {b} {c}',\n legendShow: false,\n legendOrient: 'horizontal',\n legendTop: 'top',\n legendLeft: 'center',\n colors: ['#5470c6', '#91cc75', '#fac858', '#ee6666', '#73c0de', '#3ba272', '#fc8452', '#9a60b4', '#ea7ccc'],\n symbolSize: 10,\n xAxisSplitLineShow: true,\n xAxisSplitLineStyleColor: '#333',\n xAxisLabelColor: '#333',\n xAxisLineStyleColor: '#333',\n xAxisTickShow: true,\n xAxisLabelFormatter: '{value}',\n yAxisSplitLineShow: true,\n yAxisSplitLineStyleColor: '#333',\n yAxisLabelColor: '#333',\n yAxisLineStyleColor: '#333',\n yAxisLabelFormatter: '{value}',\n dataFieldNames: { name: 'name', value: 'value' },\n gridContainLabel: true,\n gridTop: '10%',\n gridBottom: '10%',\n gridLeft: '5%',\n gridRight: '5%',\n graphicConfig: undefined,\n toolboxShow: false,\n toolboxOrient: 'horizontal',\n toolboxItemSize: 16,\n toolboxItemGap: 8,\n toolboxLeft: 'right',\n toolboxTop: 'top',\n toolboxIconStyleBorderColor: '#666',\n toolboxDownloadUrl: '',\n toolboxInfoText: '当前无说明信息'\n}\n\n// 转化默认属性\nexport const scatterComponentProps = transformToComponentProps(scatterProps)\n\nexport const scatterEvents = ['click', 'refreshData']\n","<template>\n <div :style=\"style\">\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n autoresize\n @click=\"click\"\n />\n </spin>\n <a-modal\n wrap-class-name=\"full-modal\"\n width=\"100%\"\n :visible=\"visible\"\n :footer=\"null\"\n @cancel=\"hideModal\"\n >\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n />\n </spin>\n </a-modal>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, computed, ref, watch, inject, unref } from 'vue'\nimport {\n useValueFormatter,\n useEmitEvent,\n useOnEvent,\n usePickComponentStyle,\n useRequestData,\n useVariablesInText\n} from '@/hooks'\nimport { RequestModalParam } from '@/utils/types'\nimport Echarts from '@/common/echarts'\nimport { scatterComponentProps } from './props'\nimport { use } from 'echarts/core'\nimport { CanvasRenderer } from 'echarts/renderers'\nimport { ScatterChart } from 'echarts/charts'\nimport { TitleComponent, TooltipComponent, LegendComponent, ToolboxComponent } from 'echarts/components'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport Spin from '@/common/spin/Spin.vue'\nimport useDownloadFile from '@/hooks/useDownloadFile'\nimport { Modal as AModal } from 'ant-design-vue'\nuse([\n CanvasRenderer,\n ScatterChart,\n ToolboxComponent,\n TitleComponent,\n TooltipComponent,\n LegendComponent\n])\nexport default defineComponent({\n name: 'EcanScatter',\n props: {\n ...scatterComponentProps\n },\n components: {\n Spin,\n Echarts,\n AModal\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const dataset = ref<{ [key: string]: any }[]>([])\n const visible = ref(false)\n const hideModal = () => {\n visible.value = false\n }\n const option = computed(() => {\n // 这样写为了触发响应式\n // 返回函数中使用无法触发\n const xAxisLabelFormatter = props.xAxisLabelFormatter as string\n const yAxisLabelFormatter = props.yAxisLabelFormatter as string\n return {\n toolbox: {\n show: props.toolboxShow,\n left: props.toolboxLeft,\n top: props.toolboxTop,\n itemSize: props.toolboxItemSize,\n itemGap: props.toolboxItemGap,\n feature: {\n myDownload: {\n show: true,\n title: '数据下载',\n icon: 'path://M502.010485 765.939573c3.773953 3.719718 8.686846 5.573949 13.596669 5.573949 0.075725 0 0.151449-0.010233 0.227174-0.011256 0.329505 0.016373 0.654916 0.050142 0.988514 0.050142 0.706081 0 1.400906-0.042979 2.087545-0.116657 4.352121-0.366344 8.607028-2.190899 11.961426-5.496178l335.053985-330.166675c7.619538-7.509021 7.709589-19.773346 0.200568-27.393907s-19.774369-7.711636-27.39493-0.201591L536.193005 706.304358 536.193005 50.019207c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 657.032164-306.881342-302.44838c-7.618515-7.509021-19.883863-7.419993-27.393907 0.199545-7.509021 7.619538-7.419993 19.884886 0.199545 27.393907L502.010485 765.939573z, M867.170139 711.020776c-10.698666 0-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 13.054317-10.620895 23.675212-23.676236 23.675212L205.182103 919.486668c-13.054317 0-23.676236-10.620895-23.676236-23.675212L181.505867 730.391962c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 34.416857 28.000728 62.416562 62.417585 62.416562l618.941638 0c34.417881 0 62.417585-27.999704 62.417585-62.416562L886.540302 730.391962C886.541325 719.693296 877.868805 711.020776 867.170139 711.020776z',\n onclick () {\n useDownloadFile(props.toolboxDownloadUrl as string)\n }\n },\n myDataZoom: {\n show: true,\n title: '放大',\n icon: 'path://M932.42 902.246667L792 761.793333A403.84 403.84 0 0 0 896 490.666667c0-223.86-181.473333-405.333333-405.333333-405.333334S85.333333 266.806667 85.333333 490.666667s181.473333 405.333333 405.333334 405.333333a403.84 403.84 0 0 0 271.126666-104l140.453334 140.453333a21.333333 21.333333 0 0 0 30.173333-30.173333zM128 490.666667c0-200.293333 162.373333-362.666667 362.666667-362.666667s362.666667 162.373333 362.666666 362.666667-162.373333 362.666667-362.666666 362.666666-362.666667-162.373333-362.666667-362.666666z m512 0a21.333333 21.333333 0 0 1-21.333333 21.333333H512v106.666667a21.333333 21.333333 0 0 1-42.666667 0V512H362.666667a21.333333 21.333333 0 0 1 0-42.666667h106.666666V362.666667a21.333333 21.333333 0 0 1 42.666667 0v106.666666h106.666667a21.333333 21.333333 0 0 1 21.333333 21.333334z',\n onclick () {\n visible.value = true\n }\n },\n myInfo: {\n show: true,\n title: '说明信息',\n icon: 'path://M512.50142 958.397886c-119.320573 0-231.499491-46.465265-315.871087-130.837884C112.258737 743.188406 65.792449 631.010511 65.792449 511.688915c0-119.319549 46.466288-231.499491 130.837884-315.871087C281.002952 111.445208 393.180847 64.979944 512.50142 64.979944s231.499491 46.465265 315.871087 130.837884c84.372619 84.372619 130.837884 196.551538 130.837884 315.871087 0 119.321596-46.465265 231.499491-130.837884 315.871087C744.000911 911.932622 631.821993 958.397886 512.50142 958.397886zM512.50142 105.962334c-223.718271 0-405.726581 182.00831-405.726581 405.726581s182.00831 405.726581 405.726581 405.726581c223.718271 0 405.727605-182.00831 405.727605-405.726581S736.220714 105.962334 512.50142 105.962334z M510.150886 775.953647c-18.107403 0-32.745798-14.678304-32.745798-32.785707L477.405087 452.191846c0-18.108426 14.638395-32.785707 32.745798-32.785707 18.107403 0 32.745798 14.678304 32.745798 32.785707l0 290.976094C542.896684 761.275343 528.258289 775.953647 510.150886 775.953647z M511.357364 296.458969m-45.080731 0a44.054 44.054 0 1 0 90.161463 0 44.054 44.054 0 1 0-90.161463 0Z',\n onclick () {\n AModal.info({\n title: '说明信息',\n content: (props.toolboxInfoText as string)\n })\n }\n }\n }\n },\n title: {\n text: props.titleText,\n subtext: props.titleSubtext,\n left: 'center'\n },\n grid: {\n top: props.gridTop,\n bottom: props.gridBottom,\n left: props.gridLeft,\n right: props.gridRight,\n containLabel: props.gridContainLabel\n },\n color: props.colors,\n xAxis: {\n // type: 'value'\n splitLine: {\n show: props.xAxisSplitLineShow,\n lineStyle: {\n color: props.xAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.xAxisLabelColor,\n formatter (value: string) {\n return useValueFormatter(xAxisLabelFormatter, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.xAxisLineStyleColor\n }\n },\n axisTick: {\n show: props.xAxisTickShow\n }\n },\n yAxis: {\n splitLine: {\n show: props.yAxisSplitLineShow,\n lineStyle: {\n color: props.yAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.yAxisLabelColor,\n formatter (value: string) {\n return useValueFormatter(yAxisLabelFormatter, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.yAxisLineStyleColor\n }\n }\n },\n // 提示\n tooltip: {\n show: props.tooltipShow,\n trigger: props.tooltipTrigger,\n formatter: function (params) {\n const { marker, seriesName } = params\n const record = params?.data?.record ?? {}\n const { name, value } = record\n return useVariablesInText(props.tooltipFormatter as string, {\n marker,\n seriesName,\n a: seriesName,\n b: name,\n c: value,\n ...record\n })\n },\n axisPointer: {\n type: 'cross'\n }\n },\n // 图例\n legend: {\n show: props.legendShow,\n orient: props.legendOrient,\n top: props.legendTop,\n left: props.legendLeft\n },\n series: [\n {\n data: unref(dataset),\n type: 'scatter',\n symbolSize: props.symbolSize\n }\n ]\n }\n })\n\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n\n const handleDataset = (data: any = [], dataFieldNames?: { name: string, value:string }) => {\n const { name: x = 'name', value: y = 'value' } = dataFieldNames || {}\n dataset.value = data.map(item => ({ value: [item[x], item[y]], record: item }))\n }\n\n // 静态数据\n watch(() => props.data, (value: any) => {\n if (props.dataType === 'static' || unref(pageMode) === 'design') {\n handleDataset(value)\n }\n }, {\n immediate: true,\n deep: true\n })\n\n const loading = ref(false)\n\n const requestData = useRequestData(props)\n // 动态数据\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n loading.value = true\n try {\n const res = await requestData()\n handleDataset(res?.data?.data?.rows, props.dataFieldNames as { name: string, value:string })\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const emitEvent = useEmitEvent(props)\n\n const click = emitEvent('click', (e) => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: e?.data })\n })\n\n const refreshData = () => {\n handleRequestData()\n }\n\n useOnEvent(props, {\n refreshData,\n click\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n setRequest({\n id: props.id as string,\n requestFn: handleRequestData,\n sortNum: props.requestSort as number\n })\n\n return {\n option,\n style,\n click,\n loading,\n visible,\n hideModal\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.full-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n height: calc(100vh);\n }\n .ant-modal-body {\n flex: 1;\n }\n\n .ant-modal-body {\n padding: 45px 30px 0;\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport Scatter from './Scatter.vue'\nexport const EcanScatter = withInstall(Scatter)\nexport default EcanScatter\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface CustomGraphProps extends Props {\n option: { [key:string]: any }\n optionCode: string\n}\n\nexport const customGraphProps: CustomGraphProps = {\n ...props,\n id: '',\n name: '自定义图表',\n keyName: '自定义图表',\n type: 'ecanCustomGraph',\n width: '400px',\n height: '400px',\n option: {},\n optionCode: ''\n}\n\n// 转化默认属性\nexport const customGraphComponentProps = transformToComponentProps(customGraphProps)\n","<template>\n <div :style=\"style\">\n <echarts\n :option=\"myOption\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, watch, ref } from 'vue'\nimport Echarts from '../../common/echarts'\nimport { customGraphComponentProps } from './props'\nimport { usePickComponentStyle } from '../../hooks'\nimport * as echarts from 'echarts'\n// import 'echarts/components'\nexport default defineComponent({\n name: 'EcanCustomGraph',\n props: {\n ...customGraphComponentProps\n },\n components: {\n Echarts\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const myOption = ref()\n watch(() => props.optionCode, (optionCode: string) => {\n /* // eslint-disable-next-line\n let option = {}\n // eslint-disable-next-line\n eval(props.optionCode as string)\n myOption.value = option */\n try {\n // eslint-disable-next-line\n const evalCopy = eval\n myOption.value = evalCopy(optionCode)\n } catch (e) {\n console.error(e)\n }\n }, {\n immediate: true\n })\n return {\n style,\n myOption,\n echarts\n }\n }\n})\n</script>\n","import { withInstall } from '../../utils/withInstall'\nimport CustomGraph from './CustomGraph.vue'\nexport const EcanCustomGraph = withInstall(CustomGraph)\nexport default EcanCustomGraph\nexport * from './props'\n","import {\n Data,\n Props,\n props,\n transformToComponentProps,\n ValueTypeDataFieldNames,\n KeyTypeDataFieldNames\n} from '@/utils/props'\n\nexport interface ComboGraphProps extends Props {\n data: Data,\n titleText: string\n titleSubtext: string\n colors: string []\n legendShow: boolean\n legendTextStyleColor: string\n legendLeft: 'left' | 'center' | 'right'\n legendTop: 'top' | 'middle' | 'bottom'\n legendOrient: 'vertical' | 'horizontal'\n xAxisSplitLineShow: boolean // x轴展示分割线\n xAxisLabelColor: string // x轴名称颜色\n xAxisLineStyleColor: string // x轴名称颜色\n xAxisTickShow: boolean // 展示刻度\n yAxisSplitLineShow: boolean // y轴展示分割线\n xAxisSplitLineStyleColor: string // x轴分割线颜色\n yAxisSplitLineStyleColor: string // y轴分割线颜色\n yAxisLabelColor: string // y轴名称颜色\n yAxisLineStyleColor: string // y轴名称颜色\n valueTypeDataFieldNames: ValueTypeDataFieldNames\n keyTypeDataFieldNames: KeyTypeDataFieldNames\n tooltipShow: boolean\n tooltipTrigger: 'item' | 'axis' | 'none'\n tooltipTextStyleColor: string\n tooltipFormatter: string\n seriesTypes: { [key: string]: any } []\n dataFieldConfigType: 'key' | 'value',\n yAxis: { [key: string]: any } [],\n graphicConfig?: any\n gridContainLabel: boolean\n gridTop: string\n gridBottom: string\n gridLeft: string\n gridRight: string\n toolboxShow: boolean\n toolboxOrient: 'horizontal' | 'vertical'\n toolboxItemSize: number // 工具栏 icon 的大小。\n toolboxItemGap: number // 工具栏 icon 每项之间的间隔。横向布局时为水平间隔,纵向布局时为纵向间隔。\n toolboxLeft: 'left' | 'center' | 'right'\n toolboxTop: 'top'| 'middle'| 'bottom'\n toolboxIconStyleBorderColor: string\n toolboxDownloadUrl: string\n toolboxInfoText: string\n symbolSize: number // 线宽度\n lineStyleWidth: number // 线宽\n smooth: boolean // 光滑\n areaStyleOpacity: number\n barWidth: string\n}\n\nexport const comboGraphProps: ComboGraphProps = {\n ...props,\n id: '',\n name: '组合图表',\n keyName: '组合图表',\n type: 'ecanComboGraph',\n width: '400px',\n height: '400px',\n data: [\n {\n name: '名称一',\n value: 335,\n type: '类型一'\n },\n {\n name: '名称二',\n value: 410,\n type: '类型一'\n },\n {\n name: '名称三',\n value: 210,\n type: '类型一'\n },\n {\n name: '名称一',\n value: 510,\n type: '类型二'\n },\n {\n name: '名称二',\n value: 731,\n type: '类型二'\n },\n {\n name: '名称三',\n value: 910,\n type: '类型二'\n }\n ],\n titleText: '',\n titleSubtext: '',\n colors: ['#5470c6', '#91cc75', '#fac858', '#ee6666', '#73c0de', '#3ba272', '#fc8452', '#9a60b4', '#ea7ccc'],\n legendShow: true,\n legendTextStyleColor: '#333',\n legendOrient: 'horizontal',\n legendTop: 'top',\n legendLeft: 'center',\n tooltipShow: true,\n tooltipTextStyleColor: '',\n tooltipTrigger: 'item',\n tooltipFormatter: '{marker} {a} {c}',\n xAxisSplitLineShow: true,\n xAxisSplitLineStyleColor: '#333',\n xAxisLabelColor: '#333',\n xAxisLineStyleColor: '#333',\n xAxisTickShow: true,\n yAxisSplitLineShow: true,\n yAxisSplitLineStyleColor: '#333',\n yAxisLabelColor: '#333',\n yAxisLineStyleColor: '#333',\n valueTypeDataFieldNames: { name: 'name', value: 'value', type: 'type' },\n keyTypeDataFieldNames: { name: 'name', types: [] },\n dataFieldConfigType: 'value',\n seriesTypes: [\n {\n type: 'bar',\n axisIndex: 0\n },\n {\n type: 'line',\n axisIndex: 0\n }\n ],\n yAxis: [\n {\n axisLabelFormatter: '{value}'\n },\n {\n axisLabelFormatter: '{value}'\n }\n ],\n gridContainLabel: true,\n gridTop: '10%',\n gridBottom: '10%',\n gridLeft: '5%',\n gridRight: '5%',\n graphicConfig: {},\n toolboxShow: false,\n toolboxOrient: 'horizontal',\n toolboxItemSize: 16,\n toolboxItemGap: 8,\n toolboxLeft: 'right',\n toolboxTop: 'top',\n toolboxIconStyleBorderColor: '#666',\n toolboxDownloadUrl: '',\n toolboxInfoText: '当前无说明信息',\n areaStyleOpacity: 0,\n symbolSize: 4,\n lineStyleWidth: 2,\n smooth: false,\n barWidth: '40%'\n}\n\n// 转化默认属性\nexport const comboGraphComponentProps = transformToComponentProps(comboGraphProps)\n\nexport const comboGraphEvents = ['refreshData', 'click', 'resetRecord']\n","<template>\n <div :style=\"style\">\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n @click=\"click\"\n />\n </spin>\n <a-modal\n wrap-class-name=\"full-modal\"\n width=\"100%\"\n :visible=\"visible\"\n :footer=\"null\"\n @cancel=\"hideModal\">\n <spin :spinning=\"loading\">\n <echarts\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n @click=\"click\"\n />\n </spin>\n </a-modal>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, ref, unref, watch } from 'vue'\nimport {\n useEmitEvent,\n useOnEvent,\n usePickComponentStyle,\n useRequestData, useTransformChartDataByAttrKey,\n useTransformChartDataByAttrValue,\n useValueFormatter,\n useRequestDiagramData, useVariablesInText\n // useTooltipFormatter\n} from '@/hooks'\nimport { comboGraphComponentProps } from './props'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport { KeyTypeDataFieldNames, ValueTypeDataFieldNames } from '@/utils/props'\nimport { use } from 'echarts/core'\nimport { CanvasRenderer } from 'echarts/renderers'\nimport { BarChart, LineChart } from 'echarts/charts'\nimport { DatasetComponent, LegendComponent, TitleComponent, ToolboxComponent } from 'echarts/components'\nimport Echarts from '@/common/echarts'\nimport Spin from '@/common/spin/'\nimport useDownloadFile from '@/hooks/useDownloadFile'\nimport { Modal as AModal } from 'ant-design-vue'\nimport { RequestModalParam } from '@/utils/types'\nuse([\n CanvasRenderer,\n BarChart,\n LineChart,\n TitleComponent,\n LegendComponent,\n DatasetComponent,\n ToolboxComponent\n])\nexport default defineComponent({\n name: 'EcanComboGraph',\n props: {\n ...comboGraphComponentProps\n },\n components: {\n Spin,\n Echarts,\n AModal\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const series = ref<{ [key: string]: any }[]>([])\n const dimensions = ref<{ [key: string]: any }[]>([])\n const visible = ref(false)\n const hideModal = () => {\n visible.value = false\n }\n const option = computed(() => ({\n title: {\n text: props.titleText,\n subtext: props.titleSubtext,\n left: 'center'\n },\n toolbox: {\n show: props.toolboxShow,\n left: props.toolboxLeft,\n top: props.toolboxTop,\n itemSize: props.toolboxItemSize,\n itemGap: props.toolboxItemGap,\n feature: {\n myDownload: {\n show: true,\n title: '数据下载',\n icon: 'path://M502.010485 765.939573c3.773953 3.719718 8.686846 5.573949 13.596669 5.573949 0.075725 0 0.151449-0.010233 0.227174-0.011256 0.329505 0.016373 0.654916 0.050142 0.988514 0.050142 0.706081 0 1.400906-0.042979 2.087545-0.116657 4.352121-0.366344 8.607028-2.190899 11.961426-5.496178l335.053985-330.166675c7.619538-7.509021 7.709589-19.773346 0.200568-27.393907s-19.774369-7.711636-27.39493-0.201591L536.193005 706.304358 536.193005 50.019207c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 657.032164-306.881342-302.44838c-7.618515-7.509021-19.883863-7.419993-27.393907 0.199545-7.509021 7.619538-7.419993 19.884886 0.199545 27.393907L502.010485 765.939573z, M867.170139 711.020776c-10.698666 0-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 13.054317-10.620895 23.675212-23.676236 23.675212L205.182103 919.486668c-13.054317 0-23.676236-10.620895-23.676236-23.675212L181.505867 730.391962c0-10.698666-8.67252-19.371186-19.371186-19.371186s-19.371186 8.67252-19.371186 19.371186l0 165.419494c0 34.416857 28.000728 62.416562 62.417585 62.416562l618.941638 0c34.417881 0 62.417585-27.999704 62.417585-62.416562L886.540302 730.391962C886.541325 719.693296 877.868805 711.020776 867.170139 711.020776z',\n onclick () {\n useDownloadFile(props.toolboxDownloadUrl as string)\n }\n },\n myDataZoom: {\n show: true,\n title: '放大',\n icon: 'path://M932.42 902.246667L792 761.793333A403.84 403.84 0 0 0 896 490.666667c0-223.86-181.473333-405.333333-405.333333-405.333334S85.333333 266.806667 85.333333 490.666667s181.473333 405.333333 405.333334 405.333333a403.84 403.84 0 0 0 271.126666-104l140.453334 140.453333a21.333333 21.333333 0 0 0 30.173333-30.173333zM128 490.666667c0-200.293333 162.373333-362.666667 362.666667-362.666667s362.666667 162.373333 362.666666 362.666667-162.373333 362.666667-362.666666 362.666666-362.666667-162.373333-362.666667-362.666666z m512 0a21.333333 21.333333 0 0 1-21.333333 21.333333H512v106.666667a21.333333 21.333333 0 0 1-42.666667 0V512H362.666667a21.333333 21.333333 0 0 1 0-42.666667h106.666666V362.666667a21.333333 21.333333 0 0 1 42.666667 0v106.666666h106.666667a21.333333 21.333333 0 0 1 21.333333 21.333334z',\n onclick () {\n visible.value = true\n }\n },\n myInfo: {\n show: true,\n title: '说明信息',\n icon: 'path://M512.50142 958.397886c-119.320573 0-231.499491-46.465265-315.871087-130.837884C112.258737 743.188406 65.792449 631.010511 65.792449 511.688915c0-119.319549 46.466288-231.499491 130.837884-315.871087C281.002952 111.445208 393.180847 64.979944 512.50142 64.979944s231.499491 46.465265 315.871087 130.837884c84.372619 84.372619 130.837884 196.551538 130.837884 315.871087 0 119.321596-46.465265 231.499491-130.837884 315.871087C744.000911 911.932622 631.821993 958.397886 512.50142 958.397886zM512.50142 105.962334c-223.718271 0-405.726581 182.00831-405.726581 405.726581s182.00831 405.726581 405.726581 405.726581c223.718271 0 405.727605-182.00831 405.727605-405.726581S736.220714 105.962334 512.50142 105.962334z M510.150886 775.953647c-18.107403 0-32.745798-14.678304-32.745798-32.785707L477.405087 452.191846c0-18.108426 14.638395-32.785707 32.745798-32.785707 18.107403 0 32.745798 14.678304 32.745798 32.785707l0 290.976094C542.896684 761.275343 528.258289 775.953647 510.150886 775.953647z M511.357364 296.458969m-45.080731 0a44.054 44.054 0 1 0 90.161463 0 44.054 44.054 0 1 0-90.161463 0Z',\n onclick () {\n AModal.info({\n title: '说明信息',\n content: (props.toolboxInfoText as string)\n })\n }\n }\n }\n },\n grid: {\n top: props.gridTop,\n bottom: props.gridBottom,\n left: props.gridLeft,\n right: props.gridRight,\n containLabel: props.gridContainLabel\n },\n color: props.colors,\n legend: {\n show: props.legendShow,\n orient: props.legendOrient,\n top: props.legendTop,\n left: props.legendLeft,\n textStyle: {\n color: props.legendTextStyleColor\n }\n },\n tooltip: {\n trigger: 'axis',\n show: props.tooltipShow,\n formatter: (params) => {\n const len = params.length\n let formatter = ''\n let tooltipFormatter = props.tooltipFormatter as string\n if (tooltipFormatter === '') {\n tooltipFormatter = '{marker} {a} {c}'\n }\n const seriesTypes = props.seriesTypes as { [key: string]: any } []\n for (let i = 0; i < len; i++) {\n const seriesType = seriesTypes[i]\n const { tooltipFormatter: _tooltipFormatter } = seriesType || {}\n const { marker, seriesName, name, value, data } = params[i] || {}\n if (i === 0) {\n formatter += `${name}<br/>`\n }\n formatter += useVariablesInText(\n // 如果系列有提示框组件就使用自定义,没有就用默认的\n _tooltipFormatter || tooltipFormatter,\n {\n marker,\n name,\n value,\n seriesName,\n a: seriesName,\n b: name,\n c: value,\n ...data\n },\n {\n useNewline: true,\n useSpace: true\n })\n formatter += '<br/>'\n }\n return formatter\n },\n textStyle: {\n color: props.tooltipTextStyleColor\n }\n },\n xAxis: {\n type: 'category',\n data: unref(dimensions),\n splitLine: {\n show: props.xAxisSplitLineShow,\n lineStyle: {\n color: props.xAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.xAxisLabelColor\n },\n axisLine: {\n lineStyle: {\n color: props.xAxisLineStyleColor\n }\n },\n axisTick: {\n show: props.xAxisTickShow\n }\n },\n yAxis: unref(yAxis),\n series: unref(series)\n }))\n\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n\n const handleDataset = (data: any = [], useDataFieldNames: boolean = false) => {\n // dataFieldNames 字段映射\n let chartData\n if (props.dataFieldConfigType === 'key') {\n const dataFieldNames = useDataFieldNames ? props.keyTypeDataFieldNames as KeyTypeDataFieldNames : null\n chartData = useTransformChartDataByAttrKey(data, dataFieldNames)\n } else if (props.dataFieldConfigType === 'value') {\n const dataFieldNames = useDataFieldNames ? props.valueTypeDataFieldNames as ValueTypeDataFieldNames : null\n chartData = useTransformChartDataByAttrValue(data, dataFieldNames)\n }\n // dataFieldNames 字段映射\n dimensions.value = chartData.dimensions\n const dataset = chartData.dataset\n const temp = [] as { [key: string]: any } []\n const len = dataset.length\n const seriesTypes = props.seriesTypes as { [key: string]: any } []\n for (let i = 0; i < len; i++) {\n const seriesType = seriesTypes[i]\n const { type, axisIndex } = seriesType || {}\n let series = {\n type: type,\n yAxisIndex: axisIndex,\n ...dataset[i]\n } as { [key:string]: any }\n if (type === 'line') {\n series = {\n ...series,\n symbolSize: props.symbolSize,\n smooth: props.smooth,\n areaStyle: {\n opacity: props.areaStyleOpacity\n },\n lineStyle: {\n width: props.lineStyleWidth\n }\n }\n }\n if (type === 'bar') {\n series = {\n ...series,\n barWidth: props.barWidth\n }\n }\n temp.push(series)\n }\n series.value = temp\n }\n\n const handleIndicatorDataset = (data: any = [], keyTypeDataFieldNames: KeyTypeDataFieldNames, useDataFieldNames: boolean = false) => {\n const dataFieldNames = useDataFieldNames ? keyTypeDataFieldNames : null\n const chartData = useTransformChartDataByAttrKey(data, dataFieldNames)\n // dataFieldNames 字段映射\n dimensions.value = chartData.dimensions\n const dataset = chartData.dataset\n const temp = [] as { [key: string]: any } []\n const len = dataset.length\n const seriesTypes = props.seriesTypes as { [key: string]: any } []\n for (let i = 0; i < len; i++) {\n const seriesType = seriesTypes[i]\n temp.push({\n type: seriesType?.type,\n yAxisIndex: seriesType?.axisIndex,\n ...dataset[i]\n })\n }\n series.value = temp\n }\n\n // 静态数据\n watch(() => [props.data, props.seriesTypes, props.symbolSize, props.smooth, props.areaStyleOpacity, props.lineStyleWidth, props.barWidth], ([value]) => {\n if (props.dataType === 'static' || unref(pageMode) === 'design') {\n handleDataset(value)\n }\n }, {\n immediate: true,\n deep: true\n })\n\n const yAxis = computed(() => {\n const yAxis = props.yAxis as { [key: string]: any } []\n return yAxis?.map((axis) => {\n return {\n type: 'value',\n splitLine: {\n show: props.yAxisSplitLineShow,\n lineStyle: {\n color: props.yAxisSplitLineStyleColor\n }\n },\n axisLabel: {\n color: props.yAxisLabelColor,\n formatter (value: string) {\n return useValueFormatter(axis.axisLabelFormatter as string, value)\n }\n },\n axisLine: {\n lineStyle: {\n color: props.yAxisLineStyleColor\n }\n }\n }\n })\n })\n\n const loading = ref(false)\n\n const requestData = useRequestData(props)\n\n // 动态数据\n const handleRequestData = async () => {\n if (props.dataType !== 'request' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestData()\n handleDataset(res?.data?.data?.rows, true)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n // 指标库\n const requestDiagram = useRequestDiagramData(props)\n const handleIndicatorData = async () => {\n if (props.dataType !== 'indicator' || unref(pageMode) === 'design') return\n try {\n loading.value = true\n const res = await requestDiagram()\n let a\n if (res?.data?.data?.columns?.length > 0) {\n a = {\n name: res.data.data.columns[0],\n types: res.data.data.columns.slice(1).map(it => {\n return { label: it, value: it }\n })\n }\n }\n handleIndicatorDataset(res?.data?.data?.rows, a, true)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n\n const chooseRequestOrDiagram = () => {\n if (unref(pageMode) === 'design') return\n handleIndicatorData()\n handleRequestData()\n }\n\n const refreshData = () => {\n chooseRequestOrDiagram()\n }\n\n const emitEvent = useEmitEvent(props)\n\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n const click = emitEvent('click', (e) => {\n // TODO 设置是否保存钻取数据\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: e?.data })\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n\n setRequest({\n id: props.id as string,\n requestFn: chooseRequestOrDiagram,\n sortNum: props.requestSort as number\n })\n\n const resetRecord = () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n setGlobalModel(id, { ...modal, RECORD: '' })\n }\n\n useOnEvent(props, {\n resetRecord,\n refreshData,\n click\n })\n\n return {\n style,\n option,\n click,\n loading,\n visible,\n hideModal\n }\n }\n})\n</script>\n\n<style lang=\"less\">\n.full-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n height: calc(100vh);\n }\n .ant-modal-body {\n flex: 1;\n }\n .ant-modal-body {\n padding: 45px 30px 0;\n }\n}\n</style>\n","import { withInstall } from '../../utils/withInstall'\nimport ComboGraph from './ComboGraph.vue'\nexport const EcanComboGraph = withInstall(ComboGraph)\nexport default EcanComboGraph\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface BorderProps extends Props {\n fontSize: string // 字体大小\n fontFamily: string // 字体\n fontWeight: number // 字体的粗细程度\n title: string\n mode: 'top-title' | 'no-title' | 'left-top'\n borderColor: string\n borderRadius: string\n borderStyle: string\n borderWidth: string\n backgroundColor: string\n useBorderModify: boolean\n textShadow: string\n data: { [key:string]: any }\n}\n\nexport const borderProps: BorderProps = {\n ...props,\n name: '边框',\n keyName: '边框',\n type: 'ecanBorder',\n width: '300px',\n height: '300px',\n zIndex: 0,\n fontSize: '16px',\n fontFamily: '',\n fontWeight: 700,\n title: '标题',\n mode: 'no-title',\n borderColor: '#eee',\n borderRadius: '5px',\n borderStyle: 'solid',\n borderWidth: '2px',\n backgroundColor: '#ffffff',\n useBorderModify: false,\n textShadow: '',\n data: {}\n}\n\nexport const borderComponentProps = transformToComponentProps(borderProps)\n\nexport const borderEvents = ['click']\n","<template>\n <div class=\"ecan-border\" :style=\"style\" @click=\"click\">\n <div\n class=\"no-title\"\n :style=\"borderStyle\"\n v-if=\"mode === 'no-title'\"\n >\n <template v-if=\"useBorderModify\">\n <div class=\"top-left border-item\"/>\n <div class=\"top-right border-item\"/>\n <div class=\"bottom-left border-item\"/>\n <div class=\"bottom-right border-item\"/>\n </template>\n </div>\n <div class=\"top-title\" :style=\"borderStyle\" v-if=\"mode === 'top-title'\">\n <div class=\"title-item-wrapper\">\n <div class=\"title-item\">\n <img\n class=\"title-decoration-left\"\n src=\"../../assets/border-title-decoration-left.png\"\n >\n <div class=\"title\">{{ title }}</div>\n <img\n class=\"title-decoration-right\"\n src=\"../../assets/border-title-decoration-right.png\"\n >\n </div>\n </div>\n <div class=\"top-left border-item\"/>\n <div class=\"top-right border-item\"/>\n <div class=\"bottom-left border-item\"/>\n <div class=\"bottom-right border-item\"/>\n </div>\n <div class=\"left-title\" v-if=\"mode === 'left-title'\">\n <div class=\"title\">\n <span>{{ title }}</span>\n </div>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, ref, watch } from 'vue'\nimport { borderComponentProps } from './props'\nimport { useEmitEvent, useOnEvent, usePickComponentStyle } from '@/hooks'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL } from '@/utils/constant'\nexport default defineComponent({\n name: 'EcanBorder',\n props: {\n ...borderComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props, ['background'])\n const { theme } = inject(GLOBAL_CONFIG, {\n theme: 'light'\n })\n const borderStyle = computed(() => {\n return {\n // borderWidth: props.borderWidth,\n // borderStyle: props.borderStyle,\n // borderRadius: props.borderRadius,\n // borderColor: props.borderColor,\n // backgroundColor: props.backgroundColor,\n width: '100%',\n height: '100%'\n }\n })\n const emitEvent = useEmitEvent(props)\n const click = emitEvent('click', () => {})\n const myData = ref<{ [key:string]: any } []>([])\n watch(() => props.data, (data: { [key:string]: any } []) => {\n myData.value = data\n }, {\n immediate: true,\n deep: true\n })\n useOnEvent(props, {\n click\n })\n const { setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n // 初始化设置值\n setGlobalModel(props.id as string, {\n type: props.type,\n value: myData\n })\n return {\n style,\n click,\n borderStyle,\n theme\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.top-title, .no-title {\n position: relative;\n box-sizing: border-box;\n width: 100%;\n height: 100%;\n .border-item {\n position: absolute;\n z-index: 2;\n border-color: #50FCFC;\n border-style: solid;\n width: 13px;\n height: 11px;\n }\n .top-left {\n top: 0;\n left: 0;\n border-top-width: 1px;\n border-right-width: 0;\n border-bottom-width: 0;\n border-left-width: 1px;\n }\n .top-right {\n top: 0;\n right: -2px;\n border-top-width: 1px;\n border-right-width: 1px;\n border-bottom-width: 0;\n border-left-width: 0;\n }\n .bottom-left {\n bottom: -2px;\n left: 0;\n border-top-width: 0;\n border-right-width: 0;\n border-bottom-width: 1px;\n border-left-width: 1px;\n }\n .bottom-right {\n bottom: -2px;\n right: -2px;\n border-top-width: 0;\n border-right-width: 1px;\n border-bottom-width: 1px;\n border-left-width: 0;\n }\n .title-item-wrapper {\n width: 100%;\n padding: 5px 0;\n background-image: url(\"../../assets/border-title-background.png\");\n background-size: cover;\n display: grid;\n place-content: center;\n }\n .title-item {\n display: flex;\n align-items: center;\n }\n .title {\n padding: 0 17px;\n color: #d5fdfd;\n background: linear-gradient(0deg,#01aaff,#00eaff);\n -webkit-background-clip: text;\n -webkit-text-fill-color: transparent;\n }\n .title-decoration-left {\n width: 58px;\n height: 14px;\n }\n .title-decoration-right {\n width: 58px;\n height: 14px;\n }\n}\n\n.left-title {\n position: relative;\n width: 100%;\n height: 100%;\n border: 2px solid #375A8899;\n border-radius: 0;\n .title {\n position: absolute;\n left: -33px;\n top: -14px;\n width: 33px;\n min-height: 194px;\n padding-top: 33px;\n padding-bottom: 31px;\n background-image: url(\"../../assets/border-left-title.png\");\n background-repeat: no-repeat;\n background-size: 100% 100%;\n color: #fff;\n font-weight: 500;\n text-align: center;\n span {\n writing-mode: vertical-lr;\n }\n }\n}\n</style>\n","export default \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHQAAAAcCAMAAACH42siAAAAZlBMVEUAAABBltJCldJCldFEk89BltJCltFBldI/lMBKndtmb9pCltNDldFAkclAldNBldJBltM/lM5AltNCldJBldJBlNJBltVBldJBlNJBlNI/lNNBldJBldNAldJBldJBldJBldNBldIiNK7WAAAAInRSTlMAM4BNGmaz5gQGbiAPCV1WQxUpOCY9EmxQSC2jdoacqZK8uPo7tAAAAZ9JREFUSMe90NmOwjAMheGka0J3SulCy/L+Lzk4I+HYhckEKs7dr1x8kQVM5YJMZ7SLiXVHOw817Z72cSns3BmziY7EnGRGjDqUpKt4pEZQKruvyaJt85YmBUebKLJVNUlpq6oOQ1tVVRzbqu6DwFb1NUlsVd3SNL0UDM0jqkaSqoeQqjKmahtQNUzuC1AtU1sF9KHmnmrtrSK6idqBWqE6GFVxFdGvqDGoJ01Qt7rfTEV0e7V6qSK6VjNPtTaqoOq8Ugnqr7aeav+rAuqrTh+qZw3o1urAVcFVQD3U6ZnaYY9MLZk6G5WhDaDFI9UeUPyE7gCNsAdAD9gxoBJ7ARRPUVwALXdu8/h/s3xmjtwUu0/M0M/UJzBjAei3TUTdpmKmcpkBmOHKBNTPzJi59zYJys3DO2aL78YcmNkLgrrM9m9TucwzmoBy08xlju+bgL42G4c5OcxqZSLqbwqXOVNTGXMWFD0ak6KN1ZKaojYmbribndW9MXELNQEFFUyiNqQlmEQ1JqpgErUifUUTUVEIupx1wzpjvWfdsh4FQX8ANe4nnpsb9NEAAAAASUVORK5CYII=\"","export default \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHQAAAAcCAMAAACH42siAAAAaVBMVEUAAABElM9BltJCldJCldFBltJBldJCltFNmrNCmNNFldNAldJBldNBldRBldNBldNBldJCoNFBldJBltNBldJBldJAldJAltJBldJBldJBldNAlNFAldJBlNJAldJBldNBldJBldJBldLfIVowAAAAI3RSTlMAGjJNgGbmswMSCScgDTs/ZAVRK0eYj2s3r3AWveHEhXjeXb5rzlgAAAFqSURBVEjH1dbJVsJAEIXhHjJ05tlEooK8/0NKsbDrFjmHiBD0Lvqcf9PfthRM7xvoZMQuLHZaOejGYLtcdEItzI9oaLg5xIHj5hgcG262oXXcrGzJ23Umg5717C7NKBrAjOMDM8YgCI5ghmEPprUTmMZkrBOtdbJgfpZovho0gwzNOkfTam9k5jSGkKlTMOezWT3VLH5qlg8wQzSbO5jJ28l8Z+YLmZMwuz9lupvNXpjlFTMTZv7vzFSatTDtGnNeYdpNzZTMSJhx5f84m8Y3mSEzJzTVolko3J7Qve+a0J3vntDWffdEaMUQQo1vTWjuuyA0UWvUUarqzuqLUMPt1MD3uKTaTdRwvdrdorpFtfZtH6eyK2F3RS23U3uhlr9VB1TdE1V2h7Vr1O4mdbdera6o+Wq1Vqi2rEktFapGoZopVLVCtVCXag19IBPUiiWpBrojE1QNXZAp1/TYbhKdKVwuWotORKfn9wu/DSc/X9T6qgAAAABJRU5ErkJggg==\"","import { withInstall } from '@/utils/withInstall'\nimport Border from './Border.vue'\nexport const EcanBorder = withInstall(Border)\nexport default EcanBorder\nexport * from './props'\n","import { transformToComponentProps } from '@/utils/props'\n\nexport type ModalPosition = 'default' | 'top' | 'center' | 'bottom'\n\nexport interface ModalProps {\n id: string\n type: string\n width: string\n height: string\n title: string\n titleFontSize: string\n titleColor: string\n backgroundColor: string\n backgroundImage: string\n backgroundSize: string\n keyName: string\n componentList: { [key: string]: any } []\n fullModal: boolean // 是否充满全屏\n originalWidth: string // 设计稿宽\n originalHeight: string // 设计稿长\n destroyOnClose: boolean\n position: ModalPosition\n}\n\nexport const modalProps: ModalProps = {\n id: '',\n type: 'ecanModal',\n title: '',\n titleFontSize: '14px',\n titleColor: '',\n width: '1000px',\n height: '800px',\n originalWidth: '1920px',\n originalHeight: '1080px',\n backgroundColor: '#fff',\n backgroundImage: '',\n backgroundSize: '100% 100%',\n keyName: '弹窗',\n componentList: [],\n fullModal: false,\n destroyOnClose: true,\n position: 'default'\n}\n\nexport const modalComponentProps = transformToComponentProps(modalProps)\n\nexport const modalEvents = ['showModal']\n","<template>\n <!-- centered + style 中的 verticalAlign 调整弹窗位置 -->\n <a-modal\n :getContainer=\"getContainer\"\n :wrapClassName=\"wrapClassName\"\n centered\n :visible=\"visible\"\n :footer=\"null\"\n :width=\"isFullModal || isFullWidth ? '100%' : modalWith\"\n :destroyOnClose=\"destroyOnClose\"\n :style=\"modalStyle\"\n @ok=\"onOk\"\n @cancel=\"onCancel\"\n >\n <template #title v-if=\"title\" >\n <div\n :style=\"{\n fontSize: titleFontSize,\n color: titleColor,\n backgroundColor,\n padding: '16px 24px'\n }\"\n >\n {{ title }}\n </div>\n </template>\n <div class=\"contain\" ref=\"contain\" :style=\"containStyle\">\n <div class=\"content\" :style=\"contentStyle\">\n <component\n v-for=\"(component, index) in componentList\"\n :key=\"(component.id) + index\"\n :is=\"component.type\"\n v-bind=\"component\"\n />\n </div>\n </div>\n </a-modal>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, nextTick, ref, unref } from 'vue'\nimport { modalComponentProps, ModalPosition } from './props'\nimport { Modal as AModal } from 'ant-design-vue'\nimport 'ant-design-vue/es/modal/style'\nimport { useOnEvent, usePickComponentStyle, useImagePath } from '@/hooks'\nimport { REQUEST_MODEL } from '@/utils/constant'\nexport default defineComponent({\n name: 'EcanModal',\n components: {\n AModal\n },\n props: {\n ...modalComponentProps\n },\n setup (props) {\n const getContainer = () => document.getElementById('ProviderConfig') || document.body\n const modalStyle = computed(() => {\n const position = props.position as ModalPosition\n const map = {\n default: '',\n top: 'top',\n center: 'middle',\n bottom: 'bottom'\n }\n return {\n verticalAlign: map[position]\n }\n })\n const width = props.width as string\n const height = props.height as string\n const originalWidth = props.originalWidth as string\n const originalHeight = props.originalHeight as string\n const scaleWidth = computed(() => parseFloat(width) / parseFloat(originalWidth))\n const scaleHeight = computed(() => parseFloat(height) / parseFloat(originalHeight))\n // 弹窗适配\n const modalWith = computed(() => `${unref(scaleWidth) * 100}%`)\n // const modalHeight = computed(() => `${scaleHeight.value * 100}%`)\n const screenWidth = computed(() => document.body.offsetWidth)\n const screenHeight = computed(() => document.body.offsetHeight)\n const containWidth = computed(() => unref(screenWidth) * unref(scaleWidth))\n const containHeight = computed(() => unref(screenHeight) * unref(scaleHeight))\n const containStyle = computed(() => ({\n width: `${unref(containWidth)}px`,\n height: `${unref(containHeight)}px`\n }))\n const style = usePickComponentStyle(props)\n const contentStyle = computed(() => ({\n ...unref(style),\n backgroundImage: useImagePath(props.backgroundImage as string, true),\n transform: `scale(${unref(containWidth) / parseFloat(width)},${unref(containHeight) / parseFloat(height)})`\n }))\n const isFullWidth = computed(() => unref(scaleWidth) >= 1)\n const isFullModal = computed(() => props.fullModal)\n const wrapClassName = computed(() => {\n let className = 'ecan-modal'\n if (unref(isFullWidth)) className += ' ecan-full-width-modal'\n if (unref(isFullModal)) className += ' ecan-full-modal'\n return className\n })\n const visible = ref(false)\n const contain = ref<HTMLElement>()\n const { touchRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n touchRequest: () => void 0\n })\n const showModal = () => {\n visible.value = true\n nextTick(() => {\n touchRequest()\n })\n }\n const hideModal = () => {\n visible.value = false\n }\n const onOk = () => {\n hideModal()\n }\n const onCancel = () => {\n hideModal()\n }\n // 注册\n useOnEvent(props, {\n showModal\n })\n\n return {\n contain,\n containStyle,\n contentStyle,\n getContainer,\n modalStyle,\n modalWith,\n isFullModal,\n style,\n visible,\n showModal,\n onOk,\n onCancel,\n isFullWidth,\n wrapClassName\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.contain {\n position: relative;\n overflow: hidden;\n}\n.content {\n transform-origin: left top;\n z-index: 999;\n}\n</style>\n\n<style lang=\"less\">\n.ecan-modal {\n .ant-modal-body {\n padding: 0;\n }\n .ant-modal-header {\n padding: 0;\n border-bottom: none;\n background: none;\n }\n}\n\n.ecan-full-width-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n }\n .ant-modal-body {\n flex: 1;\n }\n}\n\n.ecan-full-modal {\n .ant-modal {\n max-width: 100%;\n top: 0;\n padding-bottom: 0;\n margin: 0;\n }\n .ant-modal-content {\n display: flex;\n flex-direction: column;\n height: calc(100vh);\n }\n .ant-modal-body {\n flex: 1;\n }\n}\n\n[datav-theme='darkBlue'] .ecan-modal {\n .anticon-close > svg > path {\n fill: #fff;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Modal from './Modal.vue'\nexport const EcanModal = withInstall(Modal)\nexport default EcanModal\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface TabsProps extends Props {\n data: { [key:string]: any } []\n backgroundColor: string\n tabFontSize: string\n tabColor: string\n activeTabColor: string\n tabBackgroundImage: string\n tabBarGutter: string\n activeTabBackgroundImage\n value: string\n activeKey: number\n tabHorizontalPadding: string\n // 包含组件id\n contains: string []\n tabFontWeight: number\n tabAlignItems: 'flex-start' | 'center' | 'flex-end'\n tabJustifyContent: 'flex-start' | 'center' | 'flex-end',\n tabFlexDirection: 'row' | 'column'\n}\n\nexport const tabsProps: TabsProps = {\n ...props,\n tabHorizontalPadding: '0px',\n type: 'ecanTabs',\n name: '标签页',\n keyName: '标签页',\n width: '500px',\n height: '400px',\n tabFontSize: '14px',\n backgroundColor: '#ffffff',\n activeTabColor: '#1890ff',\n tabBackgroundImage: '',\n activeTabBackgroundImage: '',\n tabColor: '#333',\n tabBarGutter: '24px',\n tabFontWeight: 400,\n value: '',\n activeKey: 0,\n contains: [],\n tabFlexDirection: 'row',\n data: [\n {\n title: '标签1'\n },\n {\n title: '标签2'\n },\n {\n title: '标签3'\n }\n ],\n tabAlignItems: 'flex-start',\n tabJustifyContent: 'flex-start'\n}\n\nexport const tabsComponentProps = transformToComponentProps(tabsProps)\n\nexport const tabsEvents = ['tabChange']\n","<template>\n <div class=\"ecan-tabs\" :style=\"style\">\n <div\n class=\"tabs-header\"\n :style=\"{\n fontSize: tabFontSize,\n alignItems: tabAlignItems,\n justifyContent: tabJustifyContent,\n flexDirection: tabFlexDirection\n }\"\n >\n <div\n class=\"tab\"\n :style=\"{\n padding: `5px ${tabHorizontalPadding}`,\n color: isActive(index) ? activeTabColor : tabColor,\n backgroundImage: isActive(index) ? useImagePath(activeTabBackgroundImage, true) : useImagePath(tabBackgroundImage, true),\n marginRight: tabFlexDirection === 'row' ? tabBarGutter : null,\n marginBottom: tabFlexDirection === 'column' ? tabBarGutter : null,\n fontWeight: tabFontWeight\n }\"\n v-for=\"(tab, index) in myData\"\n :key=\"index\"\n @click.prevent.stop=\"tabChange(tab, index)\"\n >\n <div\n class=\"tab-inner\"\n :style=\"{\n borderBottom: !activeTabBackgroundImage && !tabBackgroundImage ? `1px solid ${isActive(index) ? activeTabColor : 'transparent'}` : ''\n }\"\n >\n {{tab.title}}\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, inject, ref, unref, watch } from 'vue'\nimport { tabsComponentProps } from './props'\nimport { useEmitEvent, useOnEvent, usePickComponentStyle, useImagePath } from '@/hooks'\nimport { GLOBAL_MODEL, REFRESH_PAGE } from '@/utils/constant'\nexport default defineComponent({\n name: 'EcanTabs',\n props: {\n ...tabsComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const activeKey = ref(0)\n watch(() => props.activeKey, (key) => {\n activeKey.value = key\n }, {\n immediate: true\n })\n const myData = ref<{ [key:string]: any } []>([])\n watch(() => props.data, (data: { [key:string]: any } []) => {\n myData.value = data\n }, {\n immediate: true,\n deep: true\n })\n const isActive = (index: number) => activeKey.value === index\n const myValue = ref(props.value || (unref(myData)[0] && unref(myData)[0]?.value) || '')\n // 注册函数触发事件拦截器\n const emitEvent = useEmitEvent(props)\n const { setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n // 初始化设置值\n setGlobalModel(props.id as string, {\n value: myValue,\n activeKey\n })\n\n const { emitRefreshPage } = inject(REFRESH_PAGE, {\n // eslint-disable-next-line no-void\n emitRefreshPage: () => void 0\n })\n\n const tabChange = emitEvent('tabChange', (tab:{ [key:string]:any }, index: number) => {\n if (index !== unref(activeKey)) {\n myValue.value = tab?.value || ''\n activeKey.value = index\n emitRefreshPage()\n }\n })\n useOnEvent(props, {\n tabChange\n })\n return {\n style,\n activeKey,\n isActive,\n tabChange,\n myData,\n useImagePath\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.ecan-tabs {\n display: flex;\n}\n\n.tabs-header {\n width: 100%;\n color: #333333;\n display: flex;\n padding: 0 10px;\n}\n\n.tab {\n background-size: 100% 100%;\n background-repeat: no-repeat;\n cursor: default;\n display: flex;\n justify-content: center;\n align-items: center;\n}\n\n.tab:last-child {\n margin-bottom: 0 !important;\n margin-right: 0 !important;\n}\n\n.tabs-content {\n flex:1;\n}\n</style>\n","import Tabs from './Tabs.vue'\nimport { withInstall } from '../../utils/withInstall'\nexport const EcanTabs = withInstall(Tabs)\nexport default EcanTabs\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface ImageProps extends Props {\n imgUrl: string\n href: string\n target: 'self' | 'blank' | 'event' // 打开方式\n linkPage: string // 传入pageId\n}\n\nexport const imageProps: ImageProps = {\n ...props,\n name: '图片',\n keyName: '图片',\n type: 'ecanImage',\n width: '300px',\n height: '300px',\n imgUrl: '',\n target: 'self',\n href: '',\n linkPage: ''\n}\n\nexport const imageComponentProps = transformToComponentProps(imageProps)\n","<template>\n <img\n :style=\"style\"\n :src=\"myImgUrl\"\n v-if=\"myImgUrl !== ''\"\n @click=\"onClick\"\n />\n <div\n class=\"image-placeholder\"\n :style=\"style\"\n v-else\n >\n 请上传图片\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, inject, unref } from 'vue'\nimport { imageComponentProps } from './props'\nimport { useImagePath, usePickComponentStyle, usePageUrl, useVariablesInText } from '@/hooks'\nimport { GLOBAL_CONFIG } from '@/utils/constant'\nexport default defineComponent({\n name: 'EcanImage',\n props: {\n ...imageComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const myImgUrl = computed(() => useImagePath(props.imgUrl as string))\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n const onClick = () => {\n // 空链接、空页面直接 return\n if (!props.linkPage && !props.href) return\n const linkPage = (props.linkPage || '') as string\n const pageUrl = usePageUrl(unref(pageMode), linkPage)\n // 优先使用外部链接,再使用url\n const href = props.href as string\n let url = href || pageUrl\n url = useVariablesInText(url)\n const target = props.target\n if (target == null || target === '') return\n if (target !== 'event') {\n window.open(url, '_' + (target as string))\n } else {\n window.parent.postMessage({\n type: 'openPage',\n url: href\n }, '*')\n }\n }\n return {\n style,\n myImgUrl,\n onClick\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.image-placeholder {\n display: grid;\n place-content: center;\n border: 1px solid #d9d9d9;\n font-size: 16px;\n color: #333;\n width: 100%;\n overflow: hidden;\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Image from './Image.vue'\nexport const EcanImage = withInstall(Image)\nexport default EcanImage\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface IframeProps extends Props {\n link: string,\n linkType: 'web' | 'erd'\n}\n\nexport const iframeProps: IframeProps = {\n ...props,\n name: '网页',\n keyName: '网页',\n type: 'ecanIframe',\n width: '300px',\n height: '300px',\n link: '',\n linkType: 'web'\n}\n\nexport const iframeComponentProps = transformToComponentProps(iframeProps)\n","<template>\n <iframe\n :src=\"myLink\"\n :style=\"style\"\n v-if=\"myLink\"\n />\n <div\n class=\"iframe-placeholder\"\n :style=\"style\"\n v-else\n >\n 请填写网页链接\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, computed, inject, unref } from 'vue'\nimport { usePickComponentStyle, useVariablesInText } from '@/hooks'\nimport { iframeComponentProps } from '@/media/iframe/props'\nimport { GLOBAL_CONFIG, ERD_URL } from '@/utils/constant'\nexport default defineComponent({\n name: 'EcanIframe',\n props: {\n ...iframeComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props)\n const { contextRequestUrl } = inject(GLOBAL_CONFIG, {\n contextRequestUrl: ''\n })\n const myLink = computed(() => {\n let link = useVariablesInText(props.link as string)\n if (props.linkType === 'erd' && link != null) {\n let ctxErdUrl = unref(contextRequestUrl)\n if (ctxErdUrl[ctxErdUrl.length - 1] === '/') {\n ctxErdUrl += 'erdReport'\n } else {\n ctxErdUrl += '/erdReport'\n }\n const erdUrl = ERD_URL || ctxErdUrl\n link = `${erdUrl}?_t=0&uid=${link}`\n }\n return link\n })\n return {\n style,\n myLink\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.iframe-placeholder {\n display: grid;\n place-content: center;\n border: 1px solid #d9d9d9;\n font-size: 16px;\n color: #333;\n width: 100%;\n overflow: hidden;\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Iframe from './Iframe.vue'\nexport const EcanIframe = withInstall(Iframe)\nexport default EcanIframe\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface TableProps extends Props {\n columns: { [key: string]: any } []\n data: { [key: string]: any } []\n bordered: boolean\n size: 'default' | 'middle' | 'small'\n isUseSeq: boolean\n columnsFixedNum: number\n scrollX: number\n paginationShow: boolean\n paginationPosition: 'topLeft' | 'topCenter' | 'topRight' | 'bottomLeft' | 'bottomCenter' | 'bottomRight'\n simple: boolean\n cellBackgroundColor: string\n borderColor: string\n paginationPageSize: number\n isUseAction: boolean // 添加操作列\n actionColumnWidth: number\n actionList: { [key: string]: any } []\n headerFontSize: string\n headerFontWeight: number\n fontSize: string\n fontWeight: number\n isReverse: boolean\n clickHighlight: boolean\n filterDropdownHeight: string\n graphicConfig: {\n [key:string]: any,\n // 全部属性, 为了属性可拓展,所以在设计器中自由添加\n // classification: { [key:string]: any }\n // series: { [key:string]: any }\n // indicatorList: { [key:string]: any } []\n // sqlConditions: { [key:string]: any } []\n // idxLibMode: string\n // source: string\n // dataViewId: string\n chartType: 'table' // 图表类型,后台接口\n plugin: '1' // 插件类型,后台接口\n layer: '1' // 表格类型, 后台接口\n }\n}\n\nexport const tableProps: TableProps = {\n ...props,\n zIndex: 2,\n name: '表格',\n keyName: '表格',\n type: 'ecanTable',\n width: '400px',\n height: '240px',\n bordered: false,\n headerFontSize: '14px',\n fontSize: '14px',\n isUseSeq: false,\n size: 'default',\n headerFontWeight: 400,\n fontWeight: 400,\n columnsFixedNum: 0,\n scrollX: 0,\n paginationShow: true,\n isReverse: false,\n simple: false,\n cellBackgroundColor: '',\n borderColor: '',\n paginationPosition: 'bottomRight',\n paginationPageSize: 10,\n isUseAction: false,\n clickHighlight: false,\n filterDropdownHeight: '200px',\n actionList: [{\n title: '',\n href: '',\n target: '',\n color: ''\n }],\n actionColumnWidth: 100,\n columns: [\n {\n title: '姓名',\n dataIndex: 'name'\n },\n {\n title: '年龄',\n dataIndex: 'age'\n },\n {\n title: '住址',\n dataIndex: 'address'\n }\n ],\n data: [\n {\n name: '小明',\n age: 32,\n address: '福州软件园'\n },\n {\n name: '小红',\n age: 25,\n address: '福州软件园'\n }\n ],\n graphicConfig: {\n chartType: 'table', // 图表类型,后台接口\n plugin: '1', // 插件类型,后台接口\n layer: '1' // 图类型, 后台接口\n }\n}\n\n// 转化默认属性\nexport const tableComponentProps = transformToComponentProps(tableProps)\n\nexport const tableEvents = ['click', 'refreshData', 'resetRecord']\n","<template>\n <div class=\"ecan-table\" :style=\"style\">\n <skeleton :loading=\"loading\">\n <a-table\n class=\"table\"\n :style=\"{\n height: '100%'\n }\"\n :columns=\"tableColumns\"\n :data-source=\"tableDataSource\"\n :bordered=\"bordered\"\n :size=\"size\"\n :customRow=\"customRow\"\n :scroll=\"{ x, y }\"\n :pagination=\"pagination\"\n @change=\"tableChange\"\n >\n <template #customFilterDropdown=\"{ column, selectedKeys, setSelectedKeys, confirm, clearFilters }\">\n <div\n class=\"ecan-table-filter\"\n :style=\"{\n height: filterDropdownHeight\n }\"\n >\n <a-input\n v-model:value=\"column.filterOptionsInputValue\"\n placeholder=\"请输入关键字\"\n :value=\"selectedKeys[0]\"\n class=\"filter-input\"\n @change=\"onSearchFilterOptions\"\n />\n <a-checkbox-group\n v-model:value=\"column.filterCheckboxGroupValue\"\n class=\"filter-checkbox\"\n :options=\"useFilterOptions(column)\"\n @change=\"useSetSelectedKeys(setSelectedKeys, column)\"\n >\n </a-checkbox-group>\n <div>\n <a-button\n type=\"primary\"\n size=\"small\"\n style=\"width: 90px; margin-right: 8px\"\n @click=\"() => confirm()\"\n >\n 搜索\n </a-button>\n <a-button\n size=\"small\"\n style=\"width: 90px\"\n @click=\"onResetFilter(clearFilters, column)\"\n >\n 重置\n </a-button>\n </div>\n </div>\n </template>\n <template #bodyCell=\"{ column, index, text, record }\">\n <template v-if=\"column.dataIndex === 'SEQ'\">\n <span>{{ index + 1 }}</span>\n </template>\n <!-- 操作列配置 -->\n <template v-if=\"column.dataIndex === 'ACTION'\">\n <div class=\"action-list\">\n <div class=\"action\" v-for=\"(action, index) in actionList\" :key=\"index\">\n <a\n :href=\"handleHref(action.href, record)\"\n :target=\"handleHrefTarget(action.target)\"\n :style=\"{\n color: action.color,\n fontSize,\n fontWeight\n }\"\n @click=\"onTouchHrefEvent(action.target, handleHref(action.href, record))\"\n >\n {{ action.title }}\n </a>\n </div>\n </div>\n </template>\n <template v-else>\n <div\n :class=\"[contrastClass(text, column.format)]\"\n :style=\"{\n fontSize,\n fontWeight\n }\"\n >\n {{ column.format != null ? formatFn(text, column.format) : text }}\n </div>\n </template>\n </template>\n <template #summary>\n <a-table-summary v-if=\"summaryList.length > 0\">\n <a-table-summary-row>\n <a-table-summary-cell\n v-for=\"(summary, index) in summaryList\"\n :key=\"index\"\n :index=\"index\"\n :style=\"{\n backgroundColor: cellBackgroundColor,\n textAlign: summary.cellAlign || 'center',\n color: summary.cellColor,\n borderBottomColor: borderColor,\n }\"\n >\n <div\n :class=\"[contrastClass(summary.total, summary.format)]\"\n :style=\"{\n fontSize,\n fontWeight\n }\"\n >\n {{ (summary.format != null || summary.format !== '') && formatFn(summary.total, summary.format) }}\n </div>\n </a-table-summary-cell>\n </a-table-summary-row>\n </a-table-summary>\n </template>\n </a-table>\n </skeleton>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, unref, ref, watch, inject, reactive } from 'vue'\nimport {\n Input as AInput,\n CheckboxGroup as ACheckboxGroup,\n // Checkbox as ACheckbox,\n Table as ATable,\n TableSummary as ATableSummary,\n TableSummaryRow as ATableSummaryRow,\n TableSummaryCell as ATableSummaryCell\n} from 'ant-design-vue'\nimport 'ant-design-vue/es/input/style'\nimport 'ant-design-vue/es/checkbox/style'\nimport 'ant-design-vue/es/table/style'\nimport {\n usePickComponentStyle,\n useEmitEvent,\n useRequestData,\n useOnEvent,\n useIndicatorData,\n useVariablesInText\n} from '@/hooks'\nimport { tableComponentProps } from './props'\nimport { formatMoney, formatPercentage } from '@/utils/util'\nimport { GLOBAL_CONFIG, GLOBAL_MODEL, REQUEST_MODEL } from '@/utils/constant'\nimport Skeleton from '@/common/skeleton/Skeleton.vue'\nimport { cloneDeep } from 'lodash-es'\nimport { RequestModalParam } from '@/utils/types'\nimport { Big } from 'big.js'\nexport default defineComponent({\n name: 'EcanTable',\n components: {\n Skeleton,\n AInput,\n ACheckboxGroup,\n ATable,\n ATableSummary,\n ATableSummaryRow,\n ATableSummaryCell\n },\n props: {\n ...tableComponentProps\n },\n setup (props, { expose }) {\n const style = usePickComponentStyle(props)\n const splitY = computed(() => {\n if (props.paginationShow) {\n switch (props.size) {\n case 'small':\n return 90\n case 'middle':\n return 100\n default:\n return 120\n }\n } else {\n switch (props.size) {\n case 'small':\n return 40\n case 'middle':\n return 47\n default:\n return 55\n }\n }\n })\n const x = computed(() => props.scrollX)\n const y = computed(() => parseFloat(props.height as string) - unref(splitY))\n const myColumns = ref<{ [key: string]: any } []>([])\n const myDataSource = ref<{ [key: string]: any } []>([])\n const tableColumns = ref<{ [key: string]: any } []>([])\n const tableDataSource = ref<{ [key: string]: any } []>([])\n const total = ref(0)\n const pageNum = ref(1)\n const pageSize = computed(() => props.paginationPageSize as number)\n const filterDataIndexList = reactive([])\n const handleChildrenColumns = (_columns: { [key: string]: any } [] = []) => {\n if (Array.isArray(_columns) && _columns.length > 0) {\n const len = _columns.length\n const columnsFixedNum = props.columnsFixedNum as number\n // 这里的循环为了 props 是引用类型,会造成脏数据(上次修改后,还会存在上次的数据)\n // 如果使用深拷贝会造成性能的浪费,循环来说相对更快\n for (let i = 0; i < len; i++) {\n const column = _columns[i]\n if (i < columnsFixedNum) {\n column.fixed = 'left'\n } else {\n column.fixed = false\n }\n const {\n cellAlign = 'center',\n cellColor,\n dataIndex,\n title,\n tableFilter,\n headerCellAlign,\n headerCellColor\n } = column\n if (tableFilter) {\n filterDataIndexList.push(dataIndex)\n column.filterOptionsInputValue = ''\n column.filterCheckboxGroupValue = []\n column.customFilterDropdown = true\n column.onFilter = (value, record) => record[dataIndex].toString().toLowerCase().includes(value.toLowerCase())\n }\n // 通用配置\n // 头部单元格\n column.customHeaderCell = () => ({\n style: {\n display: 'table-cell',\n verticalAlign: 'middle',\n fontSize: props.headerFontSize,\n fontWeight: props.headerFontWeight,\n textAlign: headerCellAlign || 'center',\n color: headerCellColor,\n borderBottomColor: props.borderColor\n }\n })\n // 表格单元格\n column.customCell = (record, rowIndex) => ({\n style: {\n textAlign: cellAlign,\n color: cellColor,\n backgroundColor: props.cellBackgroundColor,\n borderBottomColor: props.borderColor\n },\n class: {\n highlight: unref(useRowIndex) === rowIndex && props.clickHighlight\n },\n onClick: emitEvent('click', () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n record = {\n dataIndex,\n title,\n ...record\n }\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: record })\n })\n })\n if (Array.isArray(column.children)) {\n handleChildrenColumns(column.children)\n }\n }\n }\n }\n const handleColumns = (columns: { [key: string]: any } [] = []) => {\n // 复制表头数据\n if (props.isUseSeq) {\n // 添加序号\n columns.unshift({\n title: '序号',\n dataIndex: 'SEQ',\n align: 'center'\n })\n }\n // 添加操作列\n if (props.isUseAction) {\n columns.push({\n title: '操作',\n dataIndex: 'ACTION',\n width: props.actionColumnWidth\n })\n }\n handleChildrenColumns(columns)\n return columns\n }\n watch(() => [\n props.columns,\n props.isUseSeq,\n props.isUseAction,\n props.columnsFixedNum,\n props.actionColumnWidth,\n props.cellBackgroundColor,\n props.borderColor\n ], () => {\n myColumns.value = handleColumns(cloneDeep(props.columns as any []))\n }, {\n immediate: true,\n deep: true\n })\n watch(() => [props.data, props.dataType], ([data, dataType]) => {\n if (dataType !== 'static') return\n myDataSource.value = data as { [key:string]:any } []\n }, {\n immediate: true\n })\n const allFilterOptions = ref({})\n const handleFilterCheckboxOptions = (dataSource: { [key:string]: any } []) => {\n if (Array.isArray(dataSource)) {\n const dataLen = dataSource.length\n const keys = filterDataIndexList\n const keysLen = keys.length\n const filterOptionsMap: { [key:string]: Set<string> } = {}\n for (let i = 0; i < dataLen; i++) {\n const record = dataSource[i]\n for (let j = 0; j < keysLen; j++) {\n const key = keys[j]\n if (filterOptionsMap[key]) {\n filterOptionsMap[key].add(record[key])\n } else {\n const set = new Set<string>()\n set.add(record[key])\n filterOptionsMap[key] = set\n }\n }\n }\n const _allFilterOptions: { [key:string]: { label:string, value: string } [] } = {}\n for (const key in filterOptionsMap) {\n if (Object.prototype.hasOwnProperty.call(filterOptionsMap, key)) {\n const optionsSet = filterOptionsMap[key]\n const options = Array.from(optionsSet)\n _allFilterOptions[key] = options.map((option) => ({ label: option, value: option }))\n }\n }\n allFilterOptions.value = _allFilterOptions\n }\n }\n watch(() => [props.isReverse, myColumns.value, myDataSource.value], () => {\n const _columns = unref(myColumns)\n const _dataSource = unref(myDataSource)\n handleFilterCheckboxOptions(_dataSource)\n if (props.isReverse) {\n const { columns, dataSource } = handleReverseTable(cloneDeep(_columns), cloneDeep(_dataSource))\n tableColumns.value = columns\n tableDataSource.value = dataSource\n } else {\n tableColumns.value = _columns\n tableDataSource.value = _dataSource\n }\n }, {\n immediate: true,\n flush: 'post'\n })\n const handleReverseTable = (columns: { [key:string]: any} [], dataSource: { [key:string]: any} []) => {\n const firstColumns = columns[0]\n const _columns = [{\n title: firstColumns.title,\n dataIndex: 'col0',\n key: 'col0',\n align: 'center'\n }] as { [key:string]: any } []\n for (let i = 0; i < dataSource.length; i++) {\n const data = dataSource[i]\n const dataIndex = 'col' + (i + 1)\n _columns.push({\n title: data[firstColumns.dataIndex],\n dataIndex,\n key: dataIndex,\n align: 'center'\n })\n }\n const _dataSource = [] as { [key:string]: any } []\n for (let i = 1; i < columns.length; i++) {\n const column = columns[i]\n const _data = { col0: column.title }\n for (let j = 0; j < dataSource.length; j++) {\n const data = dataSource[j]\n _data[`col${j + 1}`] = data[column.dataIndex]\n }\n _dataSource.push(_data)\n }\n return {\n columns: _columns,\n dataSource: _dataSource\n }\n }\n const orderCondition = ref<string>('')\n const requestData = useRequestData(props)\n const loading = ref(false)\n const handleRequestData = async (isUseLoading: boolean = true) => {\n try {\n if (isUseLoading) loading.value = true\n // 初始参数:排序\n let params = {} as { [key:string]: any }\n if (unref(orderCondition)) {\n params.orderCondition = unref(orderCondition)\n }\n // 分页\n if (props.paginationShow) {\n params = {\n pageNum: unref(pageNum),\n pageSize: unref(pageSize),\n layer: '1',\n ...params\n }\n }\n const res = await requestData(params)\n const { rows = [], total: tableTotal = 0 } = res?.data?.data || {}\n total.value = tableTotal\n if (Array.isArray(rows)) {\n myDataSource.value = rows\n }\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n const tableChange = ({ current }: { current: number }, _filters, sorter) => {\n pageNum.value = current\n if (sorter && Object.keys(sorter).length > 0) {\n const { field, order } = sorter as { field: string | null, order: 'ascend' | 'descend' }\n const map = {\n ascend: 'asc',\n descend: 'desc'\n }\n const fieldOrder = map[order]\n if (field != null && fieldOrder != null) {\n orderCondition.value = field + ' ' + fieldOrder\n pageNum.value = 1\n }\n }\n refreshData(false)\n }\n const pagination = computed(() => {\n const simple = props.simple\n const position = [props.paginationPosition]\n return props.paginationShow && {\n simple,\n position,\n total: unref(total),\n current: unref(pageNum),\n pageSize: unref(pageSize),\n showSizeChanger: false\n }\n })\n const formatBoolean = (value: string | number) => {\n if (+value === 1) return '是'\n if (+value === 0) return '否'\n return value\n }\n type Format = 'money' | 'percentage' | 'contrast' | 'boolean' | ''\n const formatFn = (value: string | number, format?: Format) => {\n if (format == null || format === '') return value\n const map = {\n money: formatMoney,\n percentage: formatPercentage,\n contrast: formatPercentage,\n boolean: formatBoolean\n }\n return map[format](value) || ''\n }\n const contrastClass = (value: string | number, format: Format) => {\n const _value = parseFloat(value + '')\n if (format !== 'contrast') {\n return ''\n }\n switch (true) {\n case _value >= 0:\n return 'goUp'\n case _value < 0:\n return 'goDown'\n }\n }\n\n const emitEvent = useEmitEvent(props)\n\n const { pageMode } = inject(GLOBAL_CONFIG, {\n pageMode: 'normal'\n })\n\n const { getGlobalModel, setGlobalModel } = inject(GLOBAL_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n getGlobalModel: (key: string) => void 0,\n // @ts-ignore\n // eslint-disable-next-line no-void\n setGlobalModel: (key: string, value: any) => void 0\n })\n\n const handleIndicatorDataset = (dataColumns: any [] = [], dataRows: { [key:string]: any }[] = []) => {\n const _columns = dataColumns.map((column: string) => ({ title: column, dataIndex: column, key: column }))\n myColumns.value = handleColumns(_columns)\n myDataSource.value = dataRows\n }\n\n // 指标库\n const indicatorData = useIndicatorData(props)\n const handleIndicatorData = async () => {\n try {\n loading.value = true\n const res = await indicatorData()\n handleIndicatorDataset(res?.data?.data?.columns, res?.data?.data?.rows)\n } catch (e) {\n console.error(e)\n } finally {\n loading.value = false\n }\n }\n const useRowIndex = ref(-1)\n\n const customRow = (record, index) => ({\n onClick: emitEvent('rowClick', () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n // 约定获取数据\n setGlobalModel(id, { ...modal, RECORD: record })\n useRowIndex.value = index\n })\n })\n\n const refreshData = (isUseLoading: boolean = true) => {\n if (unref(pageMode) === 'design') return\n switch (props.dataType) {\n case 'request':\n handleRequestData(isUseLoading)\n break\n case 'indicator':\n handleIndicatorData()\n break\n }\n }\n\n const resetRecord = () => {\n const id = props.id as string\n const modal = getGlobalModel(id)\n setGlobalModel(id, { ...modal, RECORD: '' })\n }\n\n useOnEvent(props, {\n resetRecord,\n refreshData\n })\n const summaryList = computed(() => {\n const columns = unref(tableColumns)\n const summaryList = [] as { [key: string]: any } []\n let calcTotalCount = 0\n for (let i = 0; i < columns.length; i++) {\n const column = columns[i]\n const { isCalcTotal } = column\n if (props.isUseSeq && i === 0) {\n summaryList.push({\n ...column,\n total: '小计'\n })\n } else if (isCalcTotal) {\n summaryList.push({\n ...column,\n index: i,\n total: 0\n })\n calcTotalCount++\n } else {\n summaryList.push({\n ...column\n })\n }\n }\n // 为空直接返回\n if (calcTotalCount === 0) return []\n let records = unref(tableDataSource)\n if (props.paginationShow) {\n const start = (unref(pageNum) - 1) * unref(pageSize)\n const end = start + unref(pageSize)\n records = records.slice(start, end)\n }\n for (let i = 0; i < summaryList.length; i++) {\n const summary = summaryList[i]\n let total: number = 0\n const { isCalcTotal, dataIndex } = summary\n if (isCalcTotal === true) {\n for (let j = 0; j < records.length; j++) {\n const record = records[j]\n const num = +record[dataIndex]\n if (!isNaN(num)) {\n total = new Big(total).add(num).toNumber()\n }\n }\n summary.total = total\n }\n }\n return summaryList\n })\n\n const { setRequest } = inject(REQUEST_MODEL, {\n // @ts-ignore\n // eslint-disable-next-line no-void\n setRequest: ({ id, sortNum, requestFn }: RequestModalParam) => void 0\n })\n\n setRequest({\n id: props.id as string,\n requestFn: refreshData,\n sortNum: props.requestSort as number\n })\n\n expose({\n refreshData\n })\n\n const handleHref = (href: string = '', data: { [key:string]: any }) => {\n return useVariablesInText(href, data)\n }\n\n const handleHrefTarget = (target: 'self' | 'blank' | 'event') => {\n if (target === 'event') {\n return undefined\n } else {\n const map = {\n self: '_self',\n blank: '_blank'\n }\n return map[target]\n }\n }\n\n const onTouchHrefEvent = (target: 'self' | 'blank' | 'event', href: string = '') => {\n if (target === 'event') {\n window.parent.postMessage({\n type: 'openPage',\n url: href\n }, '*')\n }\n }\n\n const useSetSelectedKeys = (setSelectedKeys, column) => {\n setSelectedKeys(column.filterCheckboxGroupValue)\n }\n\n const onResetFilter = (clearFilters, column) => {\n clearFilters({ confirm: true })\n column.filterOptionsInputValue = ''\n column.filterCheckboxGroupValue = []\n }\n const onSearchFilterOptions = () => {}\n const useFilterOptions = (column) => {\n const key = column.dataIndex\n if (typeof key === 'string') {\n let filterOptions = unref(allFilterOptions)[key]\n const _inputValue = unref(column.filterOptionsInputValue).trim()\n if (Array.isArray(filterOptions)) {\n filterOptions = filterOptions.filter((filterOption) => {\n if (typeof filterOption.label === 'string') {\n return filterOption.label.toLowerCase().includes(_inputValue.toLowerCase())\n }\n return true\n })\n return filterOptions\n }\n return []\n }\n return []\n }\n return {\n x,\n y,\n style,\n customRow,\n pagination,\n formatFn,\n contrastClass,\n tableChange,\n summaryList,\n loading,\n onTouchHrefEvent,\n handleHref,\n handleHrefTarget,\n useRowIndex,\n tableColumns,\n tableDataSource,\n useFilterOptions,\n useSetSelectedKeys,\n onResetFilter,\n onSearchFilterOptions\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.table {\n width: 100%;\n}\n\n.goUp {\n color: #FF512E;\n display: flex;\n align-items: center;\n justify-content: center;\n &:before {\n content: '';\n display: block;\n background-image: url(\"../../assets/go-up.png\");\n width: 12px;\n height: 12px;\n background-repeat: no-repeat;\n background-size: cover;\n margin-right: 2px;\n }\n}\n\n.goDown {\n color: #39cf93;\n display: flex;\n align-items: center;\n justify-content: center;\n &:before {\n content: '';\n display: block;\n background-image: url(\"../../assets/go-down.png\");\n width: 12px;\n height: 12px;\n background-repeat: no-repeat;\n background-size: cover;\n margin-right: 2px;\n }\n}\n\n.action-list {\n display: flex;\n width: 100%;\n}\n.action {\n flex: 1;\n}\n\n.filter-input {\n width: 188px;\n margin-bottom: 8px;\n display: block\n}\n\n.filter-checkbox {\n width: 188px;\n margin-bottom: 8px;\n}\n</style>\n\n<style lang=\"less\">\n.ecan-table-filter {\n padding: 8px;\n display: flex;\n flex-direction: column;\n .ant-checkbox-group {\n display: flex;\n flex-direction: column;\n flex: 1;\n overflow-y: auto;\n overflow-x: hidden;\n }\n\n .ant-checkbox-wrapper {\n width: 100%;\n padding: 5px 0;\n font-size: 16px;\n &:hover {\n background-color: #f5f5f5;\n }\n .ant-checkbox + span {\n width: 100%;\n word-break: break-all;\n overflow: hidden;\n text-overflow: ellipsis;\n display: -webkit-box;\n -webkit-line-clamp: 3;\n -webkit-box-orient: vertical\n }\n }\n}\n\n.ecan-table {\n .highlight {\n background: #e6f7ff !important;\n }\n\n *::-webkit-scrollbar {\n //width: 6px;\n //height: 6px;\n }\n\n *::-webkit-scrollbar-thumb {\n border-radius: 3px;\n -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, .3);\n background-color: #c8c9ca !important;\n }\n\n *::-webkit-scrollbar-track {\n background-color: #fff;\n }\n\n .ant-table-cell-scrollbar {\n box-shadow: 0 1px 0 1px transparent;\n }\n\n .ant-table {\n color: rgba(0, 0, 0, .65);\n background: #ffffff;\n }\n\n .ant-table-thead > tr > th {\n color: rgba(0, 0, 0, .85);\n background: #fafafa;\n border-bottom: 1px solid #f0f0f0;\n }\n\n .ant-table-tbody > tr > td {\n border-bottom: 1px solid #f0f0f0;\n }\n\n .ant-table-bordered {\n .ant-table-container {\n border: 1px solid #f0f0f0 !important;\n }\n\n .ant-table-cell {\n border-right: 1px solid #f0f0f0 !important;\n }\n }\n\n .anticon {\n color: #bfbfbf;\n }\n\n}\n\n[datav-theme='darkBlue'] {\n .ecan-table {\n .highlight {\n background: #225b98 !important;\n }\n\n *::-webkit-scrollbar-thumb {\n background-color: #2f4dac !important;\n }\n\n *::-webkit-scrollbar-track {\n background-color: #192c70;\n }\n\n *::-webkit-scrollbar-corner {\n background-color: #192c70 !important;\n }\n .ant-table {\n color: #e8e8e8;\n background: #071655;\n }\n\n .ant-table.ant-table-bordered > .ant-table-container > .ant-table-content > table,\n .ant-table.ant-table-bordered > .ant-table-container > .ant-table-header > table {\n border-top: 1px solid #3e8ee3 !important;\n }\n\n .ant-table-thead > tr > th {\n color: #cdd0f7;\n background: #17338c;\n border-bottom: 1px solid #3e8ee3;\n }\n\n .ant-table-tbody > tr > td {\n border-bottom: 1px solid #3e8ee3;\n }\n\n .ant-table-bordered {\n .ant-table-container {\n border: 1px solid #3e8ee3 !important;\n }\n\n .ant-table-cell {\n border-right: 1px solid #3e8ee3 !important;\n }\n }\n\n .ant-pagination-item-link {\n background: #17338c !important;\n }\n\n .ant-pagination-item {\n background: #17338c !important;\n }\n\n .anticon {\n color: rgba(255, 255, 255, .65) !important;\n }\n\n .ant-table-tbody > tr:hover:not(.ant-table-expanded-row):not(.ant-table-row-selected) > td {\n background: #225b98;\n }\n }\n\n td.ant-table-column-sort {\n background: #225b98;\n }\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Table from './Table.vue'\nexport const EcanTable = withInstall(Table)\nexport default EcanTable\nexport * from './props'\n","import {\n Props,\n props,\n transformToComponentProps\n} from '@/utils/props'\n\nexport interface MapProps extends Props {\n mapJson: { name: string, value: string } | null,\n data: { [key:string]: any } []\n backgroundImage: string\n backgroundImageRepeat: 'repeat' | 'repeat-x' | 'repeat-y' | 'no-repeat',\n symbolImage: string // 图标\n symbolWidth: number\n symbolHeight: number\n geoZoom: number\n geoRoam: boolean\n geoCenter: string\n geoBackgroundImage: string\n geoBackgroundImageRepeat: 'repeat' | 'repeat-x' | 'repeat-y' | 'no-repeat'\n geoLabelShow: boolean\n geoLabelColor: string\n geoLabelFontSize: number\n geoItemStyleAreaColor: string\n geoItemStyleBorderColor: string\n geoItemStyleBorderWidth: number\n geoItemStyleShadowColor: string\n geoItemStyleShadowOffsetX: number\n geoItemStyleShadowOffsetY: number\n geoItemStyleShadowBlur: number\n geoEmphasisDisabled: boolean\n geoEmphasisLabelColor: string\n geoEmphasisItemStyleAreaColor: string\n geoEmphasisItemStyleBorderColor: string\n itemStyleColor: string\n labelFontSize: number\n labelFormatter: string\n labelShow: boolean\n labelColor: string\n tooltipShow: boolean\n tooltipTextStyleColor: string\n tooltipFormatter: string\n}\n\nexport const mapProps: MapProps = {\n ...props,\n mapJson: null,\n data: [],\n name: '地图',\n keyName: '地图',\n type: 'ecanMap',\n width: '400px',\n height: '400px',\n backgroundImage: '',\n backgroundImageRepeat: 'no-repeat',\n geoBackgroundImage: '',\n geoBackgroundImageRepeat: 'no-repeat',\n symbolImage: '',\n symbolWidth: 10,\n symbolHeight: 10,\n itemStyleColor: '#11BFDA',\n labelFontSize: 14,\n labelShow: true,\n geoLabelShow: true,\n geoLabelColor: '#000',\n geoZoom: 1,\n geoRoam: false,\n geoCenter: '',\n geoLabelFontSize: 12,\n labelColor: '',\n labelFormatter: '{b}',\n geoItemStyleAreaColor: '#eee',\n geoItemStyleBorderColor: '#000',\n geoItemStyleBorderWidth: 1,\n geoItemStyleShadowColor: '',\n geoItemStyleShadowOffsetX: 0,\n geoItemStyleShadowOffsetY: 0,\n geoItemStyleShadowBlur: 0,\n geoEmphasisDisabled: false,\n geoEmphasisLabelColor: '#fff',\n geoEmphasisItemStyleAreaColor: '#f00',\n geoEmphasisItemStyleBorderColor: '#000',\n tooltipShow: true,\n tooltipTextStyleColor: '',\n tooltipFormatter: '{b}'\n}\n\nexport const mapComponentProps = transformToComponentProps(mapProps)\n","<template>\n <div class=\"ecan-map\" :style=\"style\">\n <echarts\n v-if=\"isLoadedData\"\n :option=\"option\"\n :update-options=\"{ notMerge: true }\"\n autoresize\n />\n <img\n ref=\"geoBackgroundImageRef\"\n v-show=\"false\"\n :src=\"myGeoBackgroundImage\"\n />\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, defineComponent, watch, ref, unref } from 'vue'\nimport { mapComponentProps } from './props'\nimport Echarts from '@/common/echarts'\nimport { use, registerMap } from 'echarts/core'\nimport { CanvasRenderer } from 'echarts/renderers'\nimport { MapChart, ScatterChart } from 'echarts/charts'\nimport { VisualMapComponent, TooltipComponent, GraphicComponent } from 'echarts/components'\nimport request from '@/utils/request'\nimport { usePickComponentStyle, useImagePath } from '../../hooks'\nuse([\n CanvasRenderer,\n MapChart,\n ScatterChart,\n VisualMapComponent,\n TooltipComponent,\n GraphicComponent\n])\nexport default defineComponent({\n name: 'EcanMap',\n components: {\n Echarts\n },\n props: {\n ...mapComponentProps\n },\n setup (props) {\n const style = usePickComponentStyle(props, ['backgroundImage'])\n const geoBackgroundImageRef = ref()\n const myGeoBackgroundImage = computed(() => useImagePath(props.geoBackgroundImage as string))\n const myBackgroundImage = computed(() => useImagePath(props.backgroundImage as string))\n const areaColor = computed(() => {\n const backgroundImage = props.geoBackgroundImage as string\n if (backgroundImage) {\n return {\n image: unref(geoBackgroundImageRef),\n repeat: props.geoBackgroundImageRepeat\n }\n }\n return props.geoItemStyleAreaColor\n })\n const symbol = computed(() => {\n const symbolImage = props.symbolImage as string\n if (props.symbolImage) {\n return 'image://' + useImagePath(symbolImage)\n }\n return 'circle'\n })\n const option = computed(() => {\n const geoCenter = props.geoCenter\n let center: undefined | Array<any>\n if (typeof geoCenter === 'string' && geoCenter !== '') {\n center = geoCenter.split(',')\n }\n return {\n // backgroundColor: unref(background),\n tooltip: {\n show: true\n },\n graphic: [\n { // 一个图形元素,类型是 image。\n type: 'image',\n style: {\n width: parseFloat(props.width as string),\n height: parseFloat(props.height as string),\n image: unref(myBackgroundImage)\n },\n top: 'center'\n }\n ],\n geo: {\n zoom: props.geoZoom,\n roam: props.geoRoam,\n center,\n map: 'map',\n tooltip: {\n show: false\n },\n label: { // 地图上显示文字属性\n show: props.geoLabelShow,\n color: props.geoLabelColor,\n fontSize: props.geoLabelFontSize\n },\n itemStyle: { // 地图上板块属性\n areaColor: unref(areaColor),\n borderColor: props.geoItemStyleBorderColor,\n borderWidth: props.geoItemStyleBorderWidth,\n shadowColor: props.geoItemStyleShadowColor,\n shadowBlur: props.geoItemStyleShadowBlur,\n shadowOffsetX: props.geoItemStyleShadowOffsetX,\n shadowOffsetY: props.geoItemStyleShadowOffsetY\n },\n emphasis: { // 当鼠标悬停的时候\n disabled: props.geoEmphasisDisabled,\n label: {\n color: props.geoEmphasisLabelColor\n },\n itemStyle: {\n areaColor: props.geoEmphasisItemStyleAreaColor,\n borderColor: props.geoEmphasisItemStyleBorderColor\n }\n }\n },\n series: [\n {\n type: 'scatter',\n coordinateSystem: 'geo',\n itemStyle: {\n color: props.itemStyleColor\n },\n symbol: unref(symbol),\n symbolSize: [props.symbolWidth, props.symbolHeight],\n label: {\n show: props.labelShow,\n fontSize: props.labelFontSize,\n formatter: props.labelFormatter,\n color: props.labelColor\n },\n tooltip: {\n show: props.tooltipShow,\n formatter: props.tooltipFormatter,\n textStyle: {\n color: props.tooltipTextStyleColor\n }\n },\n data: props.data\n }\n ]\n }\n })\n // const echarts = ref()\n const isLoadedData = ref(false)\n const handleRegisterMap = async () => {\n const mapJson = props.mapJson as { name: string, path: string }\n if (mapJson != null && mapJson.path) {\n // @ts-ignore\n const res = await request(window?.config?.uploadPath + mapJson.path)\n registerMap('map', (res?.data || {}) as any)\n }\n isLoadedData.value = true\n }\n watch(() => props.mapJson, () => {\n handleRegisterMap()\n }, {\n immediate: true,\n deep: true\n })\n return {\n option,\n style,\n isLoadedData,\n geoBackgroundImageRef,\n myGeoBackgroundImage\n }\n }\n})\n</script>\n\n<style scoped lang=\"less\">\n.ecan-map {\n display: flex;\n justify-content: center;\n align-items: center;\n}\n</style>\n","import { withInstall } from '@/utils/withInstall'\nimport Map from './Map.vue'\nexport const EcanMap = withInstall(Map)\nexport default EcanMap\nexport * from './props'\n","import { App } from 'vue'\nimport * as components from './components'\nconst install = (app: App) => {\n Object.keys(components).forEach(key => {\n const component = components[key]\n if (component.install) {\n app.use(component)\n }\n })\n}\n\n// 部分导出\nexport * from './components'\n// 全局安装\nexport default {\n install\n}\n"],"names":["METHOD_NAMES","usePublicAPI","chart","init","makePublicMethod","name","args","makePublicMethods","methods","useAutoresize","autoresize","root","resizeListener","watch","_","cleanup","throttle","addListener","removeListener","autoresizeProps","LOADING_OPTIONS_KEY","useLoading","loading","loadingOptions","defaultLoadingOptions","inject","realLoadingOptions","computed","unref","watchEffect","instance","loadingProps","onRE","isOn","key","omitOn","attrs","result","TAG_NAME","THEME_KEY","INIT_OPTIONS_KEY","UPDATE_OPTIONS_KEY","Echarts","defineComponent","props","listeners","shallowRef","manualOption","defaultTheme","defaultInitOptions","defaultUpdateOptions","manualUpdate","toRefs","realOption","realTheme","realInitOptions","realUpdateOptions","nonEventAttrs","option","initChart","realListeners","event","handler","resize","e","commit","nextTick","setOption","updateOptions","unwatchOption","publicApi","onMounted","onUnmounted","h","bound01","n","max","isOnePointZero","isPercent","isPercentage","boundAlpha","a","convertToPercentage","pad2","c","rgbToRgb","r","g","b","hue2rgb","p","q","t","hslToRgb","s","l","rgbToHsv","min","v","d","hsvToRgb","i","f","mod","rgbToHex","allow3Char","hex","convertHexToDecimal","parseIntFromHex","val","names","inputToRGB","color","rgb","ok","format","stringInputToObject","isValidCSSUnit","CSS_INTEGER","CSS_NUMBER","CSS_UNIT","PERMISSIVE_MATCH3","PERMISSIVE_MATCH4","matchers","named","match","hueStep","saturationStep","saturationStep2","brightnessStep1","brightnessStep2","lightColorCount","darkColorCount","darkColorMap","toHsv","_ref","hsv","toHex","_ref2","mix","rgb1","rgb2","amount","getHue","light","hue","getSaturation","saturation","getValue","value","generate","opts","patterns","pColor","colorString","_i","_hsv","_colorString","_ref3","index","opacity","darkColorString","presetPrimaryColors","presetPalettes","presetDarkPalettes","containers","styleElements","usage","createStyleElement","styleElement","insertCss","css","options","position","container","containerId","_objectSpread","target","source","ownKeys","sym","_defineProperty","obj","warn","valid","message","warning","isIconDefinition","node","rootProps","child","getSecondaryColor","primaryColor","generateColor","normalizeTwoToneColors","twoToneColor","iconStyles","cssInjectedFlag","useInsertStyles","styleStr","_excluded","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","sourceSymbolKeys","sourceKeys","twoToneColorPalette","setTwoToneColors","secondaryColor","getTwoToneColors","IconBase","context","_props$context$attrs","icon","restProps","colors","VueIcon","_slicedToArray","arr","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","o","minLen","_arrayLikeToArray","len","arr2","_arr","_n","_d","_s","_e","err","setTwoToneColor","_normalizeTwoToneColo","_normalizeTwoToneColo2","getTwoToneColor","Icon","_classObj","cls","spin","rotate","tabindex","onClick","classObj","svgClassString","iconTabIndex","svgStyle","_createVNode","AntdIcon","LoadingOutlined","LoadingOutlinedSvg","LoadingOutlined$1","_sfc_main$r","ASpin","_component_a_spin","_resolveComponent","_createElementBlock","_hoisted_1","_ctx","_openBlock","_createBlock","_renderSlot","_sfc_main$q","ASkeleton","_component_a_skeleton","withInstall","main","extra","app","comp","transformToComponentProps","mapValues","pageConfig","pageConfigComponentProps","styleList","usePickComponentStyle","excludeStyleList","finalStyleList","without","pick","EVENT_BUS","GLOBAL_CONFIG","GLOBAL_MODEL","REQUEST_MODEL","GLOBAL_TOKEN","REFRESH_PAGE","INDICATOR_URL","_a","_b","BASE_URL","_c","ERD_URL","useOnEvent","events","id","oldId","eventBus","useEmitEvent","type","touchEventId","ref","on","callback","emitEvent","useTransformChartDataByAttrValue","data","dataFieldNames","set","map","item","x","y","dimensions","dataset","handleFormatter","formatter","formatMoney","decimalPlaces","_value","formatPercentage","strValue","lowerCaseIncludes","v1","v2","useVariablesInText","useNewline","useSpace","variables","variable","statement","reg","textVariables","j","textVariable","usedVariable","useRequestData","callBack","requestUrl","method","headers","requestParams","requestInterval","isOpenRequestTimer","contextRequestUrl","pageMode","getGlobalModel","url","requestData","params","_params","param","record","prop","propKey","operate","mode","urlParams","keys","last","keysLen","isSetUrlParams","res","axios","requestDataTimer","useTransformChartDataByAttrKey","types","dataLen","typesLen","vs","label","m","useImagePath","path","isFormat","imagePath","usePageUrl","pageId","envPageUrl","proPageUrl","request","config","error","status","useRequestDiagramData","getIndicatorList","graphicConfig","indicatorList","leftAxis","show","indicator","getCalculationAxis","it","newIndicator","getSqlCondition","relativeList","list","keyName","searchName","searchType","variateName","watchItem","getSortParams","classification","classifyItem","row","rowIndex","handlerFilterParam","parent","conditions","join","fieldValue","fieldList","getFilterParams","filterList","componentType","xAxisValue","series","seriesItem","firstSeries","classify","sqlConditions","fixedDimSql","dataSourceId","idxLibMode","useValueFormatter","useIndicatorData","requestToken","handleQueryColumn","queryColumn","location","indexCode","handleIndicator","calcType","builtInFormula","builtInValueSource","builtInCalcWay","formula","handleSqlConditions","controlList","control","conditionLabel","conditionKey","conditionValueType","sqlCondition","model","dataViewId","plugin","layer","chartType","classificationList","seriesList","leftAxisList","rightAxisList","queryColumnList","indicators","preview","sort","customGroup","queryColumns","rightAxis","useHrefParamsToGlobalVariables","keyAndValue","_sfc_main$p","style","width","height","originalWidth","originalHeight","ready","observer","initSize","resolve","updateSize","updateScale","currentWidth","currentHeight","realWidth","realHeight","widthScale","heightScale","onResize","initMutationObserver","MutationObserver","removeMutationObserver","debounce","_sfc_render","_cache","$props","$setup","$data","$options","_normalizeStyle","EcanPageConfig","providerConfig","providerConfigComponentProps","_sfc_main$o","expose","setTheme","theme","provide","globalModel","setGlobalModel","mitt","eventBusKeySet","onEvent","k","onBeforeUnmount","offEvent","eventName","tokenNum","requestModel","requestMap","setRequest","requestFn","sortNum","requestFnList","handleRequestFnList","reject","resultList","queryUserToken","touchRequest","requestModelArr","emitRefreshPage","onRefreshPage","EcanProviderConfig","textProps","textComponentProps","textEvents","goUp","goDown","_sfc_main$n","Skeleton","myData","dataType","myText","text","handleRequestData","refreshData","click","linkPage","pageUrl","href","_component_skeleton","EcanText","_sfc_main$m","EcanScrollText","timeDisplayProps","timeDisplayComponentProps","_sfc_main$l","time","dayjs","timer","clearTimer","setTimer","EcanTimeDisplay","listProps","listComponentProps","listEvents","_sfc_main$k","dataSource","columnStyle","formatFn","contrastClass","_hoisted_2","_hoisted_3","_hoisted_4","_hoisted_7","_withCtx","_Fragment","_renderList","count","_createCommentVNode","column","_hoisted_5","_normalizeClass","EcanList","proportionProps","proportionComponentProps","proportionEvents","_sfc_main$j","AProgress","myWidth","myValue","defaultValue","valueSet","_component_a_progress","EcanProportion","inputProps","inputComponentProps","inputEvents","_sfc_main$i","AInput","handleSetGlobalModel","modal","inputChange","inputBlur","_component_a_input","$event","EcanInput","datePickerProps","datePickerComponentProps","datePickerEvents","_sfc_main$h","ADatePicker","getPopupContainer","useCurrentTime","dateChange","locale","_component_a_date_picker","EcanDatePicker","selectProps","selectComponentProps","selectEvents","_sfc_main$g","ASelect","filterOption","input","labelKey","valueKey","labelValue","valueValue","firstOption","selectChange","_component_a_select","EcanSelect","rangePickerProps","rangePickerComponentProps","rangePickerEvents","_sfc_main$f","ARangePicker","startTime","endTime","interval","intervalUnit","_startTime","_endTime","myStartTime","myEndTime","_component_a_range_picker","EcanRangePicker","buttonProps","buttonComponentProps","buttonEvents","_sfc_main$e","AButton","myHref","myTarget","_component_a_button","_createElementVNode","EcanButton","checkboxProps","checkboxComponentProps","checkboxEvents","_sfc_main$d","ACheckboxGroup","myOption","handleDataAndOption","checkboxChange","_component_a_checkbox_group","EcanCheckbox","pieProps","pieComponentProps","pieEvents","useDownloadFile","downloadFileUrl","fileName","blob","dom","use","CanvasRenderer","PieChart","TitleComponent","ToolboxComponent","TooltipComponent","LegendComponent","_sfc_main$c","Spin","AModal","visible","hideModal","isUseLabelColors","marker","seriesName","percent","handleDataset","handleIndicatorDataset","chartData","requestDiagram","handleIndicatorData","newArr","_f","chooseRequestOrDiagram","_component_spin","_component_echarts","_component_a_modal","EcanPie","lineProps","lineComponentProps","lineEvents","LineChart","_sfc_main$b","xAxisLabelFormatter","yAxisLabelFormatter","tooltipFormatter","useDataFieldNames","temp","keyTypeDataFieldNames","EcanLine","barProps","barComponentProps","barEvents","BarChart","DatasetComponent","_sfc_main$a","ds","indicatorData","columns","rows","fieldNames","EcanBar","scatterProps","scatterComponentProps","scatterEvents","ScatterChart","_sfc_main$9","EcanScatter","customGraphProps","customGraphComponentProps","_sfc_main$8","optionCode","evalCopy","echarts","EcanCustomGraph","comboGraphProps","comboGraphComponentProps","comboGraphEvents","_sfc_main$7","seriesTypes","seriesType","_tooltipFormatter","yAxis","axisIndex","axis","EcanComboGraph","borderProps","borderComponentProps","borderEvents","_sfc_main$6","borderStyle","_imports_0","_imports_1","_withScopeId","_pushScopeId","_popScopeId","_hoisted_6","_hoisted_8","_hoisted_9","_hoisted_14","_toDisplayString","_hoisted_10","_hoisted_11","_hoisted_12","_hoisted_15","EcanBorder","modalProps","modalComponentProps","modalEvents","_sfc_main$5","getContainer","modalStyle","scaleWidth","scaleHeight","modalWith","screenWidth","screenHeight","containWidth","containHeight","containStyle","contentStyle","isFullWidth","isFullModal","wrapClassName","className","contain","showModal","onOk","onCancel","_createSlots","component","_resolveDynamicComponent","_mergeProps","EcanModal","tabsProps","tabsComponentProps","tabsEvents","_sfc_main$4","activeKey","isActive","tabChange","tab","_withModifiers","EcanTabs","imageProps","imageComponentProps","_sfc_main$3","myImgUrl","EcanImage","iframeProps","iframeComponentProps","_sfc_main$2","myLink","link","ctxErdUrl","EcanIframe","tableProps","tableComponentProps","tableEvents","_sfc_main$1","ATable","ATableSummary","ATableSummaryRow","ATableSummaryCell","splitY","myColumns","myDataSource","tableColumns","tableDataSource","total","pageNum","pageSize","filterDataIndexList","reactive","handleChildrenColumns","_columns","columnsFixedNum","cellAlign","cellColor","dataIndex","title","tableFilter","headerCellAlign","headerCellColor","useRowIndex","handleColumns","cloneDeep","allFilterOptions","handleFilterCheckboxOptions","filterOptionsMap","_allFilterOptions","optionsSet","_dataSource","handleReverseTable","firstColumns","_data","orderCondition","isUseLoading","tableTotal","tableChange","current","_filters","sorter","field","order","fieldOrder","pagination","simple","formatBoolean","dataColumns","dataRows","customRow","summaryList","calcTotalCount","isCalcTotal","records","start","end","summary","num","Big","filterOptions","_inputValue","setSelectedKeys","clearFilters","_component_a_table","selectedKeys","confirm","action","index2","_component_a_table_summary","_component_a_table_summary_row","_component_a_table_summary_cell","EcanTable","mapProps","mapComponentProps","MapChart","VisualMapComponent","GraphicComponent","_sfc_main","geoBackgroundImageRef","myGeoBackgroundImage","myBackgroundImage","areaColor","symbol","symbolImage","geoCenter","center","isLoadedData","handleRegisterMap","mapJson","registerMap","_withDirectives","EcanMap","components"],"mappings":"6pEAGMA,GAAe,CACnB,WACA,YACA,SACA,YACA,SACA,iBACA,iBACA,mBACA,eACA,aACA,sBACA,aACA,QACA,aACA,SACF,EAKgB,SAAAC,GACdC,EACAC,EACe,CACf,SAASC,EACPC,EACqE,CACrE,MAAO,IAAIC,IAAS,CAKd,GAJCJ,EAAM,OACJC,IAGH,CAACD,EAAM,MACH,MAAA,IAAI,MAAM,iCAAiC,EAEnD,OAAQA,EAAM,MAAMG,CAAI,EAAU,MAAMH,EAAM,MAAOI,CAAI,CAAA,CAE7D,CAEA,SAASC,GAAoC,CACrC,MAAAC,EAAiB,OAAA,OAAO,IAAI,EAClC,OAAAR,GAAa,QAAgBK,GAAA,CACnBG,EAAAH,CAAI,EAAID,EAAiBC,CAAI,CAAA,CACtC,EAEMG,CACT,CAEA,OAAOD,EAAkB,CAC3B,CChDgB,SAAAE,GACdP,EACAQ,EACAC,EACM,CACN,IAAIC,EAAwC,KAE5CC,EAAAA,MAAM,CAACF,EAAMT,EAAOQ,CAAU,EAAG,CAAC,CAACC,EAAMT,EAAOQ,CAAU,EAAGI,EAAGC,IAAY,CACtEJ,GAAQT,GAASQ,IACnBE,EAAiBI,YAAS,IAAM,CAC9Bd,EAAM,OAAO,GACZ,GAAG,EAENe,eAAYN,EAAMC,CAAc,GAGlCG,EAAQ,IAAM,CACRH,GAAkBD,GACpBO,kBAAeP,EAAMC,CAAc,CACrC,CACD,CAAA,CACF,CACH,CAEO,MAAMO,GAAkB,CAC7B,WAAY,OACd,EC5BaC,GAAsB,mBAInB,SAAAC,GACdnB,EACAoB,EACAC,EACM,CACN,MAAMC,EAAwBC,EAAAA,OAAOL,GAAqB,CAAE,CAAA,EAGtDM,EAAqBC,EAAAA,SAAS,KAAO,CACzC,GAAGC,EAAAA,MAAMJ,CAAqB,EAC9B,GAAGD,GAAA,YAAAA,EAAgB,KACnB,EAAA,EAEFM,EAAAA,YAAY,IAAM,CAChB,MAAMC,EAAW5B,EAAM,MAClB4B,IAIDR,EAAQ,MACDQ,EAAA,YAAYJ,EAAmB,KAAK,EAE7CI,EAAS,YAAY,EACvB,CACD,CACH,CAEO,MAAMC,GAAe,CAC1B,QAAS,QACT,eAAgB,MAClB,QC/BMC,GAAO,YACAC,GAAQC,GAAyBF,GAAK,KAAKE,CAAG,EAEpD,SAASC,GAAQC,EAAqB,CAC3C,MAAMC,EAAgB,CAAA,EACtB,UAAWH,KAAOE,EACXH,GAAKC,CAAG,IACJG,EAAAH,CAAG,EAAIE,EAAMF,CAAG,GAIpB,OAAAG,CACT,CCoBA,MAAMC,GAAW,gBACJC,GAAY,UACZC,GAAmB,gBACnBC,GAAqB,kBAIlCC,GAAeC,kBAAgB,CAC7B,KAAM,UACN,MAAO,CACL,OAAQ,OACR,MAAO,CACL,KAAM,CAAC,OAAQ,MAAM,CACvB,EACA,YAAa,OACb,cAAe,OACf,MAAO,OACP,aAAc,QACd,GAAGxB,GACH,GAAGY,EACL,EACA,aAAc,GAEd,MAAOa,EAAO,CAAE,MAAAR,EAAO,UAAAS,GAAa,CAClC,MAAMlC,EAAOmC,EAAAA,aACP5C,EAAQ4C,EAAAA,aACRC,EAAeD,EAAAA,aACfE,EAAevB,EAAAA,OAAOc,GAAW,IAAI,EACrCU,EAAqBxB,EAAA,OACzBe,GACA,IAAA,EAEIU,EAAuBzB,EAAA,OAC3BgB,GACA,IAAA,EAGI,CAAE,WAAA/B,EAAY,aAAAyC,EAAc,QAAA7B,EAAS,eAAAC,GAAmB6B,EAAAA,OAAOR,CAAK,EAEpES,EAAa1B,EAAA,SACjB,IAAMoB,EAAa,OAASH,EAAM,QAAU,OAAO,OAAO,IAAI,CAAA,EAE1DU,EAAY3B,WAAS,IAAMiB,EAAM,OAAShB,QAAMoB,CAAY,GAAK,CAAA,CAAE,EACnEO,EAAkB5B,EAAA,SACtB,IAAMiB,EAAM,aAAehB,QAAMqB,CAAkB,GAAK,CAAC,CAAA,EAErDO,EAAoB7B,EAAA,SACxB,IAAMiB,EAAM,eAAiBhB,QAAMsB,CAAoB,GAAK,CAAC,CAAA,EAEzDO,EAAgB9B,EAAA,SAAS,IAAMQ,GAAOC,CAAK,CAAC,EAElD,SAASjC,EAAMuD,EAAiB,CAC9B,GAAIxD,EAAM,OAAS,CAACS,EAAK,MACvB,OAGI,MAAAmB,EAAY5B,EAAM,MAAQyD,GAAA,KAC9BhD,EAAK,MACL2C,EAAU,MACVC,EAAgB,KAAA,EAGdX,EAAM,QACRd,EAAS,MAAQc,EAAM,OAGzB,IAAIgB,EAAgBf,EACfe,IACHA,EAAgB,CAAA,EAEhB,OAAO,KAAKxB,CAAK,EACd,UAAcF,EAAI,QAAQ,IAAI,IAAM,GAAKA,EAAI,OAAS,CAAC,EACvD,QAAeA,GAAA,CAGR,MAAA2B,EAAQ3B,EAAI,OAAO,CAAC,EAAE,YAAY,EAAIA,EAAI,MAAM,CAAC,EACzC0B,EAAAC,CAAK,EAAIzB,EAAMF,CAAG,CAAA,CACjC,GAGL,OAAO,KAAK0B,CAAa,EAAE,QAAe1B,GAAA,CAClC,MAAA4B,EAAUF,EAAc1B,CAAG,EAE5B4B,IAID5B,EAAI,QAAQ,KAAK,IAAM,EAChBJ,EAAA,QAAQ,GAAGI,EAAI,MAAM,CAAC,EAAE,cAAe4B,CAAO,EAEvDhC,EAAS,GAAGI,EAAI,YAAY,EAAG4B,CAAO,EACxC,CACD,EAED,SAASC,GAAU,CACjB,GAAIjC,GAAY,CAACA,EAAS,aAEpB,GAAA,CACFA,EAAS,OAAO,QACTkC,GACH,GAAAA,EAAE,UAAY,0CAChB,OAGI,MAAAA,CACR,CAEJ,CAEA,SAASC,GAAU,CACjBnC,EAAS,UAAU4B,GAAUL,EAAW,MAAOG,EAAkB,KAAK,CACxE,CAEI9C,EAAW,MAGbwD,EAAAA,SAAS,IAAM,CACNH,IACAE,GAAA,CACR,EAEMA,GAEX,CAES,SAAAE,EAAWT,EAAgBU,EAA+B,CAC7DxB,EAAM,eACRG,EAAa,MAAQW,GAGlBxD,EAAM,MAGTA,EAAM,MAAM,UAAUwD,EAAQU,GAAiB,CAAE,CAAA,EAFjDjE,EAAKuD,CAAM,CAIf,CAEA,SAAS3C,GAAW,CACdb,EAAM,QACRA,EAAM,MAAM,UACZA,EAAM,MAAQ,OAElB,CAEA,IAAImE,EAAqC,KACzCxD,EAAA,MACEsC,EACAA,GAAgB,CACV,OAAOkB,GAAkB,aACbA,IACEA,EAAA,MAGblB,IACakB,EAAAxD,EAAA,MACd,IAAM+B,EAAM,OACFc,GAAA,CACHA,IAGAxD,EAAM,MAGTA,EAAM,MAAM,UAAUwD,EAAQF,EAAkB,KAAK,EAFhDrD,IAIT,EACA,CAAE,KAAM,EAAK,CAAA,EAGnB,EACA,CACE,UAAW,EACb,CAAA,EAGFU,EAAA,MACE,CAACyC,EAAWC,CAAe,EAC3B,IAAM,CACIxC,IACHZ,GACP,EACA,CACE,KAAM,EACR,CAAA,EAGF0B,EAAAA,YAAY,IAAM,CACZe,EAAM,OAAS1C,EAAM,QACjBA,EAAA,MAAM,MAAQ0C,EAAM,MAC5B,CACD,EAEK,MAAA0B,EAAYrE,GAAaC,EAAOC,CAAI,EAE/B,OAAAkB,GAAAnB,EAAOoB,EAASC,CAAc,EAE3Bd,GAAAP,EAAOQ,EAAYC,CAAI,EAErC4D,EAAAA,UAAU,IAAM,CACV3B,EAAM,QACHzC,GACP,CACD,EAEDqE,EAAA,YAAYzD,CAAO,EAEZ,CACL,MAAAb,EACA,KAAAS,EACA,UAAAwD,EACA,cAAAV,EACA,GAAGa,CAAA,CAEP,EACA,QAAU,CACR,MAAMlC,EAAQ,CAAE,GAAG,KAAK,aAAc,EACtC,OAAAA,EAAM,IAAM,OACNA,EAAA,MAAQA,EAAM,MAAQ,CAAC,SAAS,EAAE,OAAOA,EAAM,KAAK,EAAI,UACvDqC,EAAA,EAAEnC,GAAUF,CAAK,CAC1B,CACF,CAAC,EC9PM,SAASsC,GAAQC,EAAGC,EAAK,CACxBC,GAAeF,CAAC,IAChBA,EAAI,QAER,IAAIG,EAAYC,GAAaJ,CAAC,EAO9B,OANAA,EAAIC,IAAQ,IAAMD,EAAI,KAAK,IAAIC,EAAK,KAAK,IAAI,EAAG,WAAWD,CAAC,CAAC,CAAC,EAE1DG,IACAH,EAAI,SAAS,OAAOA,EAAIC,CAAG,EAAG,EAAE,EAAI,KAGpC,KAAK,IAAID,EAAIC,CAAG,EAAI,KACb,GAGPA,IAAQ,IAIRD,GAAKA,EAAI,EAAKA,EAAIC,EAAOA,EAAMD,EAAIC,GAAO,WAAW,OAAOA,CAAG,CAAC,EAKhED,EAAKA,EAAIC,EAAO,WAAW,OAAOA,CAAG,CAAC,EAEnCD,EACX,CAaO,SAASE,GAAeF,EAAG,CAC9B,OAAO,OAAOA,GAAM,UAAYA,EAAE,QAAQ,GAAG,IAAM,IAAM,WAAWA,CAAC,IAAM,CAC/E,CAKO,SAASI,GAAaJ,EAAG,CAC5B,OAAO,OAAOA,GAAM,UAAYA,EAAE,QAAQ,GAAG,IAAM,EACvD,CAKO,SAASK,GAAWC,EAAG,CAC1B,OAAAA,EAAI,WAAWA,CAAC,GACZ,MAAMA,CAAC,GAAKA,EAAI,GAAKA,EAAI,KACzBA,EAAI,GAEDA,CACX,CAKO,SAASC,GAAoBP,EAAG,CACnC,OAAIA,GAAK,EACE,GAAG,OAAO,OAAOA,CAAC,EAAI,IAAK,GAAG,EAElCA,CACX,CAKO,SAASQ,GAAKC,EAAG,CACpB,OAAOA,EAAE,SAAW,EAAI,IAAMA,EAAI,OAAOA,CAAC,CAC9C,CCxEO,SAASC,GAASC,EAAGC,EAAGC,EAAG,CAC9B,MAAO,CACH,EAAGd,GAAQY,EAAG,GAAG,EAAI,IACrB,EAAGZ,GAAQa,EAAG,GAAG,EAAI,IACrB,EAAGb,GAAQc,EAAG,GAAG,EAAI,GAC7B,CACA,CAuCA,SAASC,GAAQC,EAAGC,EAAGC,EAAG,CAOtB,OANIA,EAAI,IACJA,GAAK,GAELA,EAAI,IACJA,GAAK,GAELA,EAAI,EAAI,EACDF,GAAKC,EAAID,IAAM,EAAIE,GAE1BA,EAAI,EAAI,EACDD,EAEPC,EAAI,EAAI,EACDF,GAAKC,EAAID,IAAM,EAAI,EAAIE,GAAK,EAEhCF,CACX,CAOO,SAASG,GAASpB,EAAGqB,EAAGC,EAAG,CAC9B,IAAIT,EACAC,EACAC,EAIJ,GAHAf,EAAIC,GAAQD,EAAG,GAAG,EAClBqB,EAAIpB,GAAQoB,EAAG,GAAG,EAClBC,EAAIrB,GAAQqB,EAAG,GAAG,EACdD,IAAM,EAENP,EAAIQ,EACJP,EAAIO,EACJT,EAAIS,MAEH,CACD,IAAIJ,EAAII,EAAI,GAAMA,GAAK,EAAID,GAAKC,EAAID,EAAIC,EAAID,EACxCJ,EAAI,EAAIK,EAAIJ,EAChBL,EAAIG,GAAQC,EAAGC,EAAGlB,EAAI,EAAI,CAAC,EAC3Bc,EAAIE,GAAQC,EAAGC,EAAGlB,CAAC,EACnBe,EAAIC,GAAQC,EAAGC,EAAGlB,EAAI,EAAI,CAAC,CAC9B,CACD,MAAO,CAAE,EAAGa,EAAI,IAAK,EAAGC,EAAI,IAAK,EAAGC,EAAI,IAC5C,CAOO,SAASQ,GAASV,EAAGC,EAAGC,EAAG,CAC9BF,EAAIZ,GAAQY,EAAG,GAAG,EAClBC,EAAIb,GAAQa,EAAG,GAAG,EAClBC,EAAId,GAAQc,EAAG,GAAG,EAClB,IAAIZ,EAAM,KAAK,IAAIU,EAAGC,EAAGC,CAAC,EACtBS,EAAM,KAAK,IAAIX,EAAGC,EAAGC,CAAC,EACtBf,EAAI,EACJyB,EAAItB,EACJuB,EAAIvB,EAAMqB,EACVH,EAAIlB,IAAQ,EAAI,EAAIuB,EAAIvB,EAC5B,GAAIA,IAAQqB,EACRxB,EAAI,MAEH,CACD,OAAQG,EAAG,CACP,KAAKU,EACDb,GAAKc,EAAIC,GAAKW,GAAKZ,EAAIC,EAAI,EAAI,GAC/B,MACJ,KAAKD,EACDd,GAAKe,EAAIF,GAAKa,EAAI,EAClB,MACJ,KAAKX,EACDf,GAAKa,EAAIC,GAAKY,EAAI,EAClB,KAGP,CACD1B,GAAK,CACR,CACD,MAAO,CAAE,EAAGA,EAAG,EAAGqB,EAAG,EAAGI,EAC5B,CAOO,SAASE,GAAS3B,EAAGqB,EAAGI,EAAG,CAC9BzB,EAAIC,GAAQD,EAAG,GAAG,EAAI,EACtBqB,EAAIpB,GAAQoB,EAAG,GAAG,EAClBI,EAAIxB,GAAQwB,EAAG,GAAG,EAClB,IAAIG,EAAI,KAAK,MAAM5B,CAAC,EAChB6B,EAAI7B,EAAI4B,EACRX,EAAIQ,GAAK,EAAIJ,GACbH,EAAIO,GAAK,EAAII,EAAIR,GACjBF,EAAIM,GAAK,GAAK,EAAII,GAAKR,GACvBS,EAAMF,EAAI,EACVf,EAAI,CAACY,EAAGP,EAAGD,EAAGA,EAAGE,EAAGM,CAAC,EAAEK,CAAG,EAC1BhB,EAAI,CAACK,EAAGM,EAAGA,EAAGP,EAAGD,EAAGA,CAAC,EAAEa,CAAG,EAC1Bf,EAAI,CAACE,EAAGA,EAAGE,EAAGM,EAAGA,EAAGP,CAAC,EAAEY,CAAG,EAC9B,MAAO,CAAE,EAAGjB,EAAI,IAAK,EAAGC,EAAI,IAAK,EAAGC,EAAI,IAC5C,CAOO,SAASgB,GAASlB,EAAGC,EAAGC,EAAGiB,EAAY,CAC1C,IAAIC,EAAM,CACNvB,GAAK,KAAK,MAAMG,CAAC,EAAE,SAAS,EAAE,CAAC,EAC/BH,GAAK,KAAK,MAAMI,CAAC,EAAE,SAAS,EAAE,CAAC,EAC/BJ,GAAK,KAAK,MAAMK,CAAC,EAAE,SAAS,EAAE,CAAC,CACvC,EAEI,OAAIiB,GACAC,EAAI,CAAC,EAAE,WAAWA,EAAI,CAAC,EAAE,OAAO,CAAC,CAAC,GAClCA,EAAI,CAAC,EAAE,WAAWA,EAAI,CAAC,EAAE,OAAO,CAAC,CAAC,GAClCA,EAAI,CAAC,EAAE,WAAWA,EAAI,CAAC,EAAE,OAAO,CAAC,CAAC,EAC3BA,EAAI,CAAC,EAAE,OAAO,CAAC,EAAIA,EAAI,CAAC,EAAE,OAAO,CAAC,EAAIA,EAAI,CAAC,EAAE,OAAO,CAAC,EAEzDA,EAAI,KAAK,EAAE,CACtB,CA2CO,SAASC,GAAoBlC,EAAG,CACnC,OAAOmC,GAAgBnC,CAAC,EAAI,GAChC,CAEO,SAASmC,GAAgBC,EAAK,CACjC,OAAO,SAASA,EAAK,EAAE,CAC3B,CC/NO,IAAIC,GAAQ,CACf,UAAW,UACX,aAAc,UACd,KAAM,UACN,WAAY,UACZ,MAAO,UACP,MAAO,UACP,OAAQ,UACR,MAAO,UACP,eAAgB,UAChB,KAAM,UACN,WAAY,UACZ,MAAO,UACP,UAAW,UACX,UAAW,UACX,WAAY,UACZ,UAAW,UACX,MAAO,UACP,eAAgB,UAChB,SAAU,UACV,QAAS,UACT,KAAM,UACN,SAAU,UACV,SAAU,UACV,cAAe,UACf,SAAU,UACV,UAAW,UACX,SAAU,UACV,UAAW,UACX,YAAa,UACb,eAAgB,UAChB,WAAY,UACZ,WAAY,UACZ,QAAS,UACT,WAAY,UACZ,aAAc,UACd,cAAe,UACf,cAAe,UACf,cAAe,UACf,cAAe,UACf,WAAY,UACZ,SAAU,UACV,YAAa,UACb,QAAS,UACT,QAAS,UACT,WAAY,UACZ,UAAW,UACX,YAAa,UACb,YAAa,UACb,QAAS,UACT,UAAW,UACX,WAAY,UACZ,UAAW,UACX,KAAM,UACN,KAAM,UACN,MAAO,UACP,YAAa,UACb,KAAM,UACN,SAAU,UACV,QAAS,UACT,UAAW,UACX,OAAQ,UACR,MAAO,UACP,MAAO,UACP,cAAe,UACf,SAAU,UACV,UAAW,UACX,aAAc,UACd,UAAW,UACX,WAAY,UACZ,UAAW,UACX,qBAAsB,UACtB,UAAW,UACX,WAAY,UACZ,UAAW,UACX,UAAW,UACX,YAAa,UACb,cAAe,UACf,aAAc,UACd,eAAgB,UAChB,eAAgB,UAChB,eAAgB,UAChB,YAAa,UACb,KAAM,UACN,UAAW,UACX,MAAO,UACP,QAAS,UACT,OAAQ,UACR,iBAAkB,UAClB,WAAY,UACZ,aAAc,UACd,aAAc,UACd,eAAgB,UAChB,gBAAiB,UACjB,kBAAmB,UACnB,gBAAiB,UACjB,gBAAiB,UACjB,aAAc,UACd,UAAW,UACX,UAAW,UACX,SAAU,UACV,YAAa,UACb,KAAM,UACN,QAAS,UACT,MAAO,UACP,UAAW,UACX,OAAQ,UACR,UAAW,UACX,OAAQ,UACR,cAAe,UACf,UAAW,UACX,cAAe,UACf,cAAe,UACf,WAAY,UACZ,UAAW,UACX,KAAM,UACN,KAAM,UACN,KAAM,UACN,WAAY,UACZ,OAAQ,UACR,cAAe,UACf,IAAK,UACL,UAAW,UACX,UAAW,UACX,YAAa,UACb,OAAQ,UACR,WAAY,UACZ,SAAU,UACV,SAAU,UACV,OAAQ,UACR,OAAQ,UACR,QAAS,UACT,UAAW,UACX,UAAW,UACX,UAAW,UACX,KAAM,UACN,YAAa,UACb,UAAW,UACX,IAAK,UACL,KAAM,UACN,QAAS,UACT,OAAQ,UACR,UAAW,UACX,OAAQ,UACR,MAAO,UACP,MAAO,UACP,WAAY,UACZ,OAAQ,UACR,YAAa,SACjB,ECpIO,SAASC,GAAWC,EAAO,CAC9B,IAAIC,EAAM,CAAE,EAAG,EAAG,EAAG,EAAG,EAAG,GACvBhC,EAAI,EACJa,EAAI,KACJI,EAAI,KACJH,EAAI,KACJmB,EAAK,GACLC,EAAS,GACb,OAAI,OAAOH,GAAU,WACjBA,EAAQI,GAAoBJ,CAAK,GAEjC,OAAOA,GAAU,WACbK,GAAeL,EAAM,CAAC,GAAKK,GAAeL,EAAM,CAAC,GAAKK,GAAeL,EAAM,CAAC,GAC5EC,EAAM5B,GAAS2B,EAAM,EAAGA,EAAM,EAAGA,EAAM,CAAC,EACxCE,EAAK,GACLC,EAAS,OAAOH,EAAM,CAAC,EAAE,OAAO,EAAE,IAAM,IAAM,OAAS,OAElDK,GAAeL,EAAM,CAAC,GAAKK,GAAeL,EAAM,CAAC,GAAKK,GAAeL,EAAM,CAAC,GACjFlB,EAAIZ,GAAoB8B,EAAM,CAAC,EAC/Bd,EAAIhB,GAAoB8B,EAAM,CAAC,EAC/BC,EAAMb,GAASY,EAAM,EAAGlB,EAAGI,CAAC,EAC5BgB,EAAK,GACLC,EAAS,OAEJE,GAAeL,EAAM,CAAC,GAAKK,GAAeL,EAAM,CAAC,GAAKK,GAAeL,EAAM,CAAC,IACjFlB,EAAIZ,GAAoB8B,EAAM,CAAC,EAC/BjB,EAAIb,GAAoB8B,EAAM,CAAC,EAC/BC,EAAMpB,GAASmB,EAAM,EAAGlB,EAAGC,CAAC,EAC5BmB,EAAK,GACLC,EAAS,OAET,OAAO,UAAU,eAAe,KAAKH,EAAO,GAAG,IAC/C/B,EAAI+B,EAAM,IAGlB/B,EAAID,GAAWC,CAAC,EACT,CACH,GAAIiC,EACJ,OAAQF,EAAM,QAAUG,EACxB,EAAG,KAAK,IAAI,IAAK,KAAK,IAAIF,EAAI,EAAG,CAAC,CAAC,EACnC,EAAG,KAAK,IAAI,IAAK,KAAK,IAAIA,EAAI,EAAG,CAAC,CAAC,EACnC,EAAG,KAAK,IAAI,IAAK,KAAK,IAAIA,EAAI,EAAG,CAAC,CAAC,EACnC,EAAGhC,CACX,CACA,CAEA,IAAIqC,GAAc,gBAEdC,GAAa,uBAEbC,GAAW,MAAM,OAAOD,GAAY,OAAO,EAAE,OAAOD,GAAa,GAAG,EAIpEG,GAAoB,cAAc,OAAOD,GAAU,YAAY,EAAE,OAAOA,GAAU,YAAY,EAAE,OAAOA,GAAU,WAAW,EAC5HE,GAAoB,cAAc,OAAOF,GAAU,YAAY,EAAE,OAAOA,GAAU,YAAY,EAAE,OAAOA,GAAU,YAAY,EAAE,OAAOA,GAAU,WAAW,EAC3JG,GAAW,CACX,SAAU,IAAI,OAAOH,EAAQ,EAC7B,IAAK,IAAI,OAAO,MAAQC,EAAiB,EACzC,KAAM,IAAI,OAAO,OAASC,EAAiB,EAC3C,IAAK,IAAI,OAAO,MAAQD,EAAiB,EACzC,KAAM,IAAI,OAAO,OAASC,EAAiB,EAC3C,IAAK,IAAI,OAAO,MAAQD,EAAiB,EACzC,KAAM,IAAI,OAAO,OAASC,EAAiB,EAC3C,KAAM,uDACN,KAAM,uDACN,KAAM,uEACN,KAAM,sEACV,EAKO,SAASN,GAAoBJ,EAAO,CAEvC,GADAA,EAAQA,EAAM,KAAM,EAAC,YAAW,EAC5BA,EAAM,SAAW,EACjB,MAAO,GAEX,IAAIY,EAAQ,GACZ,GAAId,GAAME,CAAK,EACXA,EAAQF,GAAME,CAAK,EACnBY,EAAQ,WAEHZ,IAAU,cACf,MAAO,CAAE,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,OAAQ,MAAM,EAMnD,IAAIa,EAAQF,GAAS,IAAI,KAAKX,CAAK,EACnC,OAAIa,EACO,CAAE,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,CAAC,GAElDA,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CAAE,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,IAE9DA,EAAQF,GAAS,IAAI,KAAKX,CAAK,EAC3Ba,EACO,CAAE,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,CAAC,GAElDA,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CAAE,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,IAE9DA,EAAQF,GAAS,IAAI,KAAKX,CAAK,EAC3Ba,EACO,CAAE,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,CAAC,GAElDA,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CAAE,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,EAAG,EAAGA,EAAM,CAAC,IAE9DA,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CACH,EAAGjB,GAAgBiB,EAAM,CAAC,CAAC,EAC3B,EAAGjB,GAAgBiB,EAAM,CAAC,CAAC,EAC3B,EAAGjB,GAAgBiB,EAAM,CAAC,CAAC,EAC3B,EAAGlB,GAAoBkB,EAAM,CAAC,CAAC,EAC/B,OAAQD,EAAQ,OAAS,MACrC,GAEIC,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CACH,EAAGjB,GAAgBiB,EAAM,CAAC,CAAC,EAC3B,EAAGjB,GAAgBiB,EAAM,CAAC,CAAC,EAC3B,EAAGjB,GAAgBiB,EAAM,CAAC,CAAC,EAC3B,OAAQD,EAAQ,OAAS,KACrC,GAEIC,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CACH,EAAGjB,GAAgBiB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EACtC,EAAGjB,GAAgBiB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EACtC,EAAGjB,GAAgBiB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EACtC,EAAGlB,GAAoBkB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EAC1C,OAAQD,EAAQ,OAAS,MACrC,GAEIC,EAAQF,GAAS,KAAK,KAAKX,CAAK,EAC5Ba,EACO,CACH,EAAGjB,GAAgBiB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EACtC,EAAGjB,GAAgBiB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EACtC,EAAGjB,GAAgBiB,EAAM,CAAC,EAAIA,EAAM,CAAC,CAAC,EACtC,OAAQD,EAAQ,OAAS,KACrC,EAEW,WACX,CAKO,SAASP,GAAeL,EAAO,CAClC,OAAO,QAAQW,GAAS,SAAS,KAAK,OAAOX,CAAK,CAAC,CAAC,CACxD,CCnLA,IAAIc,GAAU,EAEVC,GAAiB,IAEjBC,GAAkB,IAElBC,GAAkB,IAElBC,GAAkB,IAElBC,GAAkB,EAElBC,GAAiB,EAGjBC,GAAe,CAAC,CAClB,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,EACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,EACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,EAAG,CACD,MAAO,EACP,QAAS,GACX,CAAC,EAGD,SAASC,GAAMC,EAAM,CACnB,IAAIjD,EAAIiD,EAAK,EACThD,EAAIgD,EAAK,EACT/C,EAAI+C,EAAK,EACTC,EAAMxC,GAASV,EAAGC,EAAGC,CAAC,EAC1B,MAAO,CACL,EAAGgD,EAAI,EAAI,IACX,EAAGA,EAAI,EACP,EAAGA,EAAI,CACX,CACA,CAIA,SAASC,GAAMC,EAAO,CACpB,IAAIpD,EAAIoD,EAAM,EACVnD,EAAImD,EAAM,EACVlD,EAAIkD,EAAM,EACd,MAAO,IAAI,OAAOlC,GAASlB,EAAGC,EAAGC,EAAG,EAAK,CAAC,CAC5C,CAKA,SAASmD,GAAIC,EAAMC,EAAMC,EAAQ,CAC/B,IAAIpD,EAAIoD,EAAS,IACb7B,EAAM,CACR,GAAI4B,EAAK,EAAID,EAAK,GAAKlD,EAAIkD,EAAK,EAChC,GAAIC,EAAK,EAAID,EAAK,GAAKlD,EAAIkD,EAAK,EAChC,GAAIC,EAAK,EAAID,EAAK,GAAKlD,EAAIkD,EAAK,CACpC,EACE,OAAO3B,CACT,CAEA,SAAS8B,GAAOP,EAAKnC,EAAG2C,EAAO,CAC7B,IAAIC,EAEJ,OAAI,KAAK,MAAMT,EAAI,CAAC,GAAK,IAAM,KAAK,MAAMA,EAAI,CAAC,GAAK,IAClDS,EAAMD,EAAQ,KAAK,MAAMR,EAAI,CAAC,EAAIV,GAAUzB,EAAI,KAAK,MAAMmC,EAAI,CAAC,EAAIV,GAAUzB,EAE9E4C,EAAMD,EAAQ,KAAK,MAAMR,EAAI,CAAC,EAAIV,GAAUzB,EAAI,KAAK,MAAMmC,EAAI,CAAC,EAAIV,GAAUzB,EAG5E4C,EAAM,EACRA,GAAO,IACEA,GAAO,MAChBA,GAAO,KAGFA,CACT,CAEA,SAASC,GAAcV,EAAKnC,EAAG2C,EAAO,CAEpC,GAAIR,EAAI,IAAM,GAAKA,EAAI,IAAM,EAC3B,OAAOA,EAAI,EAGb,IAAIW,EAEJ,OAAIH,EACFG,EAAaX,EAAI,EAAIT,GAAiB1B,EAC7BA,IAAM+B,GACfe,EAAaX,EAAI,EAAIT,GAErBoB,EAAaX,EAAI,EAAIR,GAAkB3B,EAIrC8C,EAAa,IACfA,EAAa,GAIXH,GAAS3C,IAAM8B,IAAmBgB,EAAa,KACjDA,EAAa,IAGXA,EAAa,MACfA,EAAa,KAGR,OAAOA,EAAW,QAAQ,CAAC,CAAC,CACrC,CAEA,SAASC,GAASZ,EAAKnC,EAAG2C,EAAO,CAC/B,IAAIK,EAEJ,OAAIL,EACFK,EAAQb,EAAI,EAAIP,GAAkB5B,EAElCgD,EAAQb,EAAI,EAAIN,GAAkB7B,EAGhCgD,EAAQ,IACVA,EAAQ,GAGH,OAAOA,EAAM,QAAQ,CAAC,CAAC,CAChC,CAEA,SAASC,GAAStC,EAAO,CAKvB,QAJIuC,EAAO,UAAU,OAAS,GAAK,UAAU,CAAC,IAAM,OAAY,UAAU,CAAC,EAAI,CAAA,EAC3EC,EAAW,CAAA,EACXC,EAAS1C,GAAWC,CAAK,EAEpBX,EAAI8B,GAAiB9B,EAAI,EAAGA,GAAK,EAAG,CAC3C,IAAImC,EAAMF,GAAMmB,CAAM,EAClBC,EAAcjB,GAAM1B,GAAW,CACjC,EAAGgC,GAAOP,EAAKnC,EAAG,EAAI,EACtB,EAAG6C,GAAcV,EAAKnC,EAAG,EAAI,EAC7B,EAAG+C,GAASZ,EAAKnC,EAAG,EAAI,CACzB,CAAA,CAAC,EACFmD,EAAS,KAAKE,CAAW,CAC1B,CAEDF,EAAS,KAAKf,GAAMgB,CAAM,CAAC,EAE3B,QAASE,EAAK,EAAGA,GAAMvB,GAAgBuB,GAAM,EAAG,CAC9C,IAAIC,EAAOtB,GAAMmB,CAAM,EAEnBI,EAAepB,GAAM1B,GAAW,CAClC,EAAGgC,GAAOa,EAAMD,CAAE,EAClB,EAAGT,GAAcU,EAAMD,CAAE,EACzB,EAAGP,GAASQ,EAAMD,CAAE,CACrB,CAAA,CAAC,EAEFH,EAAS,KAAKK,CAAY,CAC3B,CAGD,OAAIN,EAAK,QAAU,OACVlB,GAAa,IAAI,SAAUyB,EAAO,CACvC,IAAIC,EAAQD,EAAM,MACdE,EAAUF,EAAM,QAChBG,EAAkBxB,GAAME,GAAI5B,GAAWwC,EAAK,iBAAmB,SAAS,EAAGxC,GAAWyC,EAASO,CAAK,CAAC,EAAGC,EAAU,GAAG,CAAC,EAC1H,OAAOC,CACb,CAAK,EAGIT,CACT,CAEA,IAAIU,GAAsB,CACxB,IAAK,UACL,QAAS,UACT,OAAQ,UACR,KAAM,UACN,OAAQ,UACR,KAAM,UACN,MAAO,UACP,KAAM,UACN,KAAM,UACN,SAAU,UACV,OAAQ,UACR,QAAS,UACT,KAAM,SACR,EACIC,GAAiB,CAAA,EACjBC,GAAqB,CAAA,EACzB,OAAO,KAAKF,EAAmB,EAAE,QAAQ,SAAUhI,EAAK,CACtDiI,GAAejI,CAAG,EAAIoH,GAASY,GAAoBhI,CAAG,CAAC,EACvDiI,GAAejI,CAAG,EAAE,QAAUiI,GAAejI,CAAG,EAAE,CAAC,EAEnDkI,GAAmBlI,CAAG,EAAIoH,GAASY,GAAoBhI,CAAG,EAAG,CAC3D,MAAO,OACP,gBAAiB,SACrB,CAAG,EACDkI,GAAmBlI,CAAG,EAAE,QAAUkI,GAAmBlI,CAAG,EAAE,CAAC,CAC7D,CAAC,EC1ND,IAAImI,GAAa,CAAA,EAEbC,GAAgB,CAAA,EAEhBC,GAAQ,wFAEZ,SAASC,IAAqB,CAC5B,IAAIC,EAAe,SAAS,cAAc,OAAO,EACjD,OAAAA,EAAa,aAAa,OAAQ,UAAU,EACrCA,CACT,CAGA,SAASC,GAAUC,EAAKC,EAAS,CAG/B,GAFAA,EAAUA,GAAW,GAEjBD,IAAQ,OACV,MAAM,IAAI,MAAMJ,EAAK,EAGvB,IAAIM,EAAWD,EAAQ,UAAY,GAAO,UAAY,SAClDE,EAAYF,EAAQ,YAAc,OAAYA,EAAQ,UAAY,SAAS,cAAc,MAAM,EAC/FG,EAAcV,GAAW,QAAQS,CAAS,EAE1CC,IAAgB,KAClBA,EAAcV,GAAW,KAAKS,CAAS,EAAI,EAC3CR,GAAcS,CAAW,EAAI,IAI/B,IAAIN,EAEJ,OAAIH,GAAcS,CAAW,IAAM,QAAaT,GAAcS,CAAW,EAAEF,CAAQ,IAAM,OACvFJ,EAAeH,GAAcS,CAAW,EAAEF,CAAQ,GAElDJ,EAAeH,GAAcS,CAAW,EAAEF,CAAQ,EAAIL,GAAkB,EAEpEK,IAAa,UACfC,EAAU,aAAaL,EAAcK,EAAU,WAAW,CAAC,CAAC,EAE5DA,EAAU,YAAYL,CAAY,GAKlCE,EAAI,WAAW,CAAC,IAAM,QACxBA,EAAMA,EAAI,OAAO,EAAGA,EAAI,MAAM,GAI5BF,EAAa,WACfA,EAAa,WAAW,SAAWE,EAEnCF,EAAa,aAAeE,EAGvBF,CACT,CC1DA,SAASO,GAAcC,EAAQ,CAAE,QAAS5E,EAAI,EAAGA,EAAI,UAAU,OAAQA,IAAK,CAAE,IAAI6E,EAAS,UAAU7E,CAAC,GAAK,KAAO,OAAO,UAAUA,CAAC,CAAC,EAAI,CAAA,EAAQ8E,EAAU,OAAO,KAAKD,CAAM,EAAO,OAAO,OAAO,uBAA0B,aAAcC,EAAUA,EAAQ,OAAO,OAAO,sBAAsBD,CAAM,EAAE,OAAO,SAAUE,EAAK,CAAE,OAAO,OAAO,yBAAyBF,EAAQE,CAAG,EAAE,WAAa,CAAC,GAAKD,EAAQ,QAAQ,SAAUjJ,EAAK,CAAEmJ,GAAgBJ,EAAQ/I,EAAKgJ,EAAOhJ,CAAG,CAAC,CAAE,CAAE,CAAI,CAAC,OAAO+I,CAAS,CAEze,SAASI,GAAgBC,EAAKpJ,EAAKmH,EAAO,CAAE,OAAInH,KAAOoJ,EAAO,OAAO,eAAeA,EAAKpJ,EAAK,CAAE,MAAOmH,EAAO,WAAY,GAAM,aAAc,GAAM,SAAU,EAAM,CAAA,EAAYiC,EAAIpJ,CAAG,EAAImH,EAAgBiC,CAAM,CAK1M,SAASC,GAAKC,EAAOC,EAAS,CAE/B,QAAQ,IAAI,WAAa,cAAgB,CAACD,GAAS,UAAY,QACjE,QAAQ,MAAM,YAAY,OAAOC,CAAO,CAAC,CAE7C,CACO,SAASC,GAAQF,EAAOC,EAAS,CACtCF,GAAKC,EAAO,2BAA2B,OAAOC,CAAO,CAAC,CACxD,CAEO,SAASE,GAAiBV,EAAQ,CACvC,OAAO,OAAOA,GAAW,UAAY,OAAOA,EAAO,MAAS,UAAY,OAAOA,EAAO,OAAU,WAAa,OAAOA,EAAO,MAAS,UAAY,OAAOA,EAAO,MAAS,WACzK,CAmBO,SAAS3B,GAASsC,EAAM1J,EAAK2J,EAAW,CAC7C,OAAKA,EAQEpH,IAAEmH,EAAK,IAAKZ,GAAc,CAC/B,IAAK9I,CACN,EAAE2J,EAAWD,EAAK,KAAK,GAAIA,EAAK,UAAY,IAAI,IAAI,SAAUE,EAAO/B,EAAO,CAC3E,OAAOT,GAASwC,EAAO,GAAG,OAAO5J,EAAK,GAAG,EAAE,OAAO0J,EAAK,IAAK,GAAG,EAAE,OAAO7B,CAAK,CAAC,CAC/E,CAAA,CAAC,EAXOtF,IAAEmH,EAAK,IAAKZ,GAAc,CAC/B,IAAK9I,CACX,EAAO0J,EAAK,KAAK,GAAIA,EAAK,UAAY,CAAA,GAAI,IAAI,SAAUE,EAAO/B,EAAO,CAChE,OAAOT,GAASwC,EAAO,GAAG,OAAO5J,EAAK,GAAG,EAAE,OAAO0J,EAAK,IAAK,GAAG,EAAE,OAAO7B,CAAK,CAAC,CAC/E,CAAA,CAAC,CAQN,CACO,SAASgC,GAAkBC,EAAc,CAE9C,OAAOC,GAAcD,CAAY,EAAE,CAAC,CACtC,CACO,SAASE,GAAuBC,EAAc,CACnD,OAAKA,EAIE,MAAM,QAAQA,CAAY,EAAIA,EAAe,CAACA,CAAY,EAHxD,EAIX,CAUO,IAAIC,GAAa;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EACpBC,GAAkB,GACXC,GAAkB,UAA2B,CACtD,IAAIC,EAAW,UAAU,OAAS,GAAK,UAAU,CAAC,IAAM,OAAY,UAAU,CAAC,EAAIH,GACnFlI,EAAAA,SAAS,UAAY,CACdmI,KACC,OAAO,OAAW,KAAe,OAAO,UAAY,OAAO,SAAS,iBACtE3B,GAAU6B,EAAU,CAClB,QAAS,EACnB,CAAS,EAGHF,GAAkB,GAExB,CAAG,CACH,ECxFIG,GAAY,CAAC,OAAQ,eAAgB,gBAAgB,EAEzD,SAASC,GAAyBvB,EAAQwB,EAAU,CAAE,GAAIxB,GAAU,KAAM,MAAO,GAAI,IAAID,EAAS0B,GAA8BzB,EAAQwB,CAAQ,EAAOxK,EAAKmE,EAAG,GAAI,OAAO,sBAAuB,CAAE,IAAIuG,EAAmB,OAAO,sBAAsB1B,CAAM,EAAG,IAAK7E,EAAI,EAAGA,EAAIuG,EAAiB,OAAQvG,IAAOnE,EAAM0K,EAAiBvG,CAAC,EAAO,EAAAqG,EAAS,QAAQxK,CAAG,GAAK,IAAkB,OAAO,UAAU,qBAAqB,KAAKgJ,EAAQhJ,CAAG,IAAa+I,EAAO/I,CAAG,EAAIgJ,EAAOhJ,CAAG,EAAI,CAAG,OAAO+I,CAAS,CAE5e,SAAS0B,GAA8BzB,EAAQwB,EAAU,CAAE,GAAIxB,GAAU,KAAM,MAAO,CAAE,EAAE,IAAID,EAAS,CAAE,EAAM4B,EAAa,OAAO,KAAK3B,CAAM,EAAOhJ,EAAKmE,EAAG,IAAKA,EAAI,EAAGA,EAAIwG,EAAW,OAAQxG,IAAOnE,EAAM2K,EAAWxG,CAAC,EAAO,EAAAqG,EAAS,QAAQxK,CAAG,GAAK,KAAa+I,EAAO/I,CAAG,EAAIgJ,EAAOhJ,CAAG,GAAK,OAAO+I,CAAS,CAEnT,SAASD,GAAcC,EAAQ,CAAE,QAAS5E,EAAI,EAAGA,EAAI,UAAU,OAAQA,IAAK,CAAE,IAAI6E,EAAS,UAAU7E,CAAC,GAAK,KAAO,OAAO,UAAUA,CAAC,CAAC,EAAI,CAAA,EAAQ8E,EAAU,OAAO,KAAKD,CAAM,EAAO,OAAO,OAAO,uBAA0B,aAAcC,EAAUA,EAAQ,OAAO,OAAO,sBAAsBD,CAAM,EAAE,OAAO,SAAUE,EAAK,CAAE,OAAO,OAAO,yBAAyBF,EAAQE,CAAG,EAAE,WAAa,CAAC,GAAKD,EAAQ,QAAQ,SAAUjJ,EAAK,CAAEmJ,GAAgBJ,EAAQ/I,EAAKgJ,EAAOhJ,CAAG,CAAC,CAAE,CAAE,CAAI,CAAC,OAAO+I,CAAS,CAEze,SAASI,GAAgBC,EAAKpJ,EAAKmH,EAAO,CAAE,OAAInH,KAAOoJ,EAAO,OAAO,eAAeA,EAAKpJ,EAAK,CAAE,MAAOmH,EAAO,WAAY,GAAM,aAAc,GAAM,SAAU,EAAM,CAAA,EAAYiC,EAAIpJ,CAAG,EAAImH,EAAgBiC,CAAM,CAGjN,IAAIwB,GAAsB,CACxB,aAAc,OACd,eAAgB,UAChB,WAAY,EACd,EAEA,SAASC,GAAiBxE,EAAM,CAC9B,IAAIyD,EAAezD,EAAK,aACpByE,EAAiBzE,EAAK,eAC1BuE,GAAoB,aAAed,EACnCc,GAAoB,eAAiBE,GAAkBjB,GAAkBC,CAAY,EACrFc,GAAoB,WAAa,CAAC,CAACE,CACrC,CAEA,SAASC,IAAmB,CAC1B,OAAOjC,GAAc,GAAI8B,EAAmB,CAC9C,CAEA,IAAII,GAAW,SAAkBtK,EAAOuK,EAAS,CAC/C,IAAIC,EAAuBpC,GAAc,CAAA,EAAIpI,EAAOuK,EAAQ,KAAK,EAC7DE,EAAOD,EAAqB,KAC5BpB,EAAeoB,EAAqB,aACpCJ,EAAiBI,EAAqB,eACtCE,EAAYb,GAAyBW,EAAsBZ,EAAS,EAEpEe,EAAST,GAYb,GAVId,IACFuB,EAAS,CACP,aAAcvB,EACd,eAAgBgB,GAAkBjB,GAAkBC,CAAY,CACtE,GAGEM,KACAZ,GAAQC,GAAiB0B,CAAI,EAAG,0CAA0C,OAAOA,CAAI,CAAC,EAElF,CAAC1B,GAAiB0B,CAAI,EACxB,OAAO,KAGT,IAAIpC,EAASoC,EAEb,OAAIpC,GAAU,OAAOA,EAAO,MAAS,aACnCA,EAASD,GAAc,CAAE,EAAEC,EAAQ,CACjC,KAAMA,EAAO,KAAKsC,EAAO,aAAcA,EAAO,cAAc,CAClE,CAAK,GAGIjE,GAAS2B,EAAO,KAAM,OAAO,OAAOA,EAAO,IAAI,EAAGD,GAAc,CAAA,EAAIsC,EAAW,CACpF,YAAarC,EAAO,KACpB,MAAO,MACP,OAAQ,MACR,KAAM,eACN,cAAe,MAChB,CAAA,CAAC,CACJ,EAEAiC,GAAS,MAAQ,CACf,KAAM,OACN,aAAc,OACd,eAAgB,OAChB,UAAW,MACb,EACAA,GAAS,aAAe,GACxBA,GAAS,YAAc,WACvBA,GAAS,iBAAmBD,GAC5BC,GAAS,iBAAmBH,GAC5B,MAAAS,GAAeN,GC/Ef,SAASO,GAAeC,EAAKrH,EAAG,CAAE,OAAOsH,GAAgBD,CAAG,GAAKE,GAAsBF,EAAKrH,CAAC,GAAKwH,GAA4BH,EAAKrH,CAAC,GAAKyH,GAAgB,CAAK,CAE9J,SAASA,IAAmB,CAAE,MAAM,IAAI,UAAU;AAAA,mFAA2I,CAAI,CAEjM,SAASD,GAA4BE,EAAGC,EAAQ,CAAE,GAAKD,EAAW,IAAI,OAAOA,GAAM,SAAU,OAAOE,GAAkBF,EAAGC,CAAM,EAAG,IAAI,EAAI,OAAO,UAAU,SAAS,KAAKD,CAAC,EAAE,MAAM,EAAG,EAAE,EAAgE,GAAzD,IAAM,UAAYA,EAAE,cAAa,EAAIA,EAAE,YAAY,MAAU,IAAM,OAAS,IAAM,MAAO,OAAO,MAAM,KAAKA,CAAC,EAAG,GAAI,IAAM,aAAe,2CAA2C,KAAK,CAAC,EAAG,OAAOE,GAAkBF,EAAGC,CAAM,EAAI,CAEha,SAASC,GAAkBP,EAAKQ,EAAK,EAAMA,GAAO,MAAQA,EAAMR,EAAI,UAAQQ,EAAMR,EAAI,QAAQ,QAASrH,EAAI,EAAG8H,EAAO,IAAI,MAAMD,CAAG,EAAG7H,EAAI6H,EAAK7H,IAAO8H,EAAK9H,CAAC,EAAIqH,EAAIrH,CAAC,EAAK,OAAO8H,CAAO,CAEvL,SAASP,GAAsBF,EAAKrH,EAAG,CAAE,IAAIsD,EAAK+D,GAAO,KAAO,KAAO,OAAO,OAAW,KAAeA,EAAI,OAAO,QAAQ,GAAKA,EAAI,YAAY,EAAG,GAAI/D,GAAM,KAAc,KAAIyE,EAAO,CAAE,EAAMC,EAAK,GAAUC,EAAK,GAAWC,EAAIC,EAAI,GAAI,CAAE,IAAK7E,EAAKA,EAAG,KAAK+D,CAAG,EAAG,EAAEW,GAAME,EAAK5E,EAAG,QAAQ,QAAoByE,EAAK,KAAKG,EAAG,KAAK,EAAO,EAAAlI,GAAK+H,EAAK,SAAW/H,IAA3DgI,EAAK,GAA6B,CAAoC,OAAUI,EAAP,CAAcH,EAAK,GAAME,EAAKC,SAAe,CAAE,GAAI,CAAM,CAACJ,GAAM1E,EAAG,QAAa,MAAMA,EAAG,OAAW,SAAY,CAAE,GAAI2E,EAAI,MAAME,CAAK,CAAA,CAAG,OAAOJ,EAAO,CAEjgB,SAAST,GAAgBD,EAAK,CAAE,GAAI,MAAM,QAAQA,CAAG,EAAG,OAAOA,CAAM,CAI9D,SAASgB,GAAgBvC,EAAc,CAC5C,IAAIwC,EAAwBzC,GAAuBC,CAAY,EAC3DyC,EAAyBnB,GAAekB,EAAuB,CAAC,EAChE3C,EAAe4C,EAAuB,CAAC,EACvC5B,EAAiB4B,EAAuB,CAAC,EAE7C,OAAOpB,GAAQ,iBAAiB,CAC9B,aAAcxB,EACd,eAAgBgB,CACpB,CAAG,CACH,CACO,SAAS6B,IAAkB,CAChC,IAAItB,EAASC,GAAQ,mBAErB,OAAKD,EAAO,WAIL,CAACA,EAAO,aAAcA,EAAO,cAAc,EAHzCA,EAAO,YAIlB,CCjCA,IAAIf,GAAY,CAAC,QAAS,OAAQ,OAAQ,SAAU,WAAY,eAAgB,SAAS,EAGzF,SAASiB,GAAeC,EAAKrH,EAAG,CAAE,OAAOsH,GAAgBD,CAAG,GAAKE,GAAsBF,EAAKrH,CAAC,GAAKwH,GAA4BH,EAAKrH,CAAC,GAAKyH,GAAgB,CAAK,CAE9J,SAASA,IAAmB,CAAE,MAAM,IAAI,UAAU;AAAA,mFAA2I,CAAI,CAEjM,SAASD,GAA4BE,EAAGC,EAAQ,CAAE,GAAKD,EAAW,IAAI,OAAOA,GAAM,SAAU,OAAOE,GAAkBF,EAAGC,CAAM,EAAG,IAAI,EAAI,OAAO,UAAU,SAAS,KAAKD,CAAC,EAAE,MAAM,EAAG,EAAE,EAAgE,GAAzD,IAAM,UAAYA,EAAE,cAAa,EAAIA,EAAE,YAAY,MAAU,IAAM,OAAS,IAAM,MAAO,OAAO,MAAM,KAAKA,CAAC,EAAG,GAAI,IAAM,aAAe,2CAA2C,KAAK,CAAC,EAAG,OAAOE,GAAkBF,EAAGC,CAAM,EAAI,CAEha,SAASC,GAAkBP,EAAKQ,EAAK,EAAMA,GAAO,MAAQA,EAAMR,EAAI,UAAQQ,EAAMR,EAAI,QAAQ,QAASrH,EAAI,EAAG8H,EAAO,IAAI,MAAMD,CAAG,EAAG7H,EAAI6H,EAAK7H,IAAO8H,EAAK9H,CAAC,EAAIqH,EAAIrH,CAAC,EAAK,OAAO8H,CAAO,CAEvL,SAASP,GAAsBF,EAAKrH,EAAG,CAAE,IAAIsD,EAAK+D,GAAO,KAAO,KAAO,OAAO,OAAW,KAAeA,EAAI,OAAO,QAAQ,GAAKA,EAAI,YAAY,EAAG,GAAI/D,GAAM,KAAc,KAAIyE,EAAO,CAAE,EAAMC,EAAK,GAAUC,EAAK,GAAWC,EAAIC,EAAI,GAAI,CAAE,IAAK7E,EAAKA,EAAG,KAAK+D,CAAG,EAAG,EAAEW,GAAME,EAAK5E,EAAG,QAAQ,QAAoByE,EAAK,KAAKG,EAAG,KAAK,EAAO,EAAAlI,GAAK+H,EAAK,SAAW/H,IAA3DgI,EAAK,GAA6B,CAAoC,OAAUI,EAAP,CAAcH,EAAK,GAAME,EAAKC,SAAe,CAAE,GAAI,CAAM,CAACJ,GAAM1E,EAAG,QAAa,MAAMA,EAAG,OAAW,SAAY,CAAE,GAAI2E,EAAI,MAAME,CAAK,CAAA,CAAG,OAAOJ,EAAO,CAEjgB,SAAST,GAAgBD,EAAK,CAAE,GAAI,MAAM,QAAQA,CAAG,EAAG,OAAOA,CAAM,CAErE,SAAS1C,GAAcC,EAAQ,CAAE,QAAS5E,EAAI,EAAGA,EAAI,UAAU,OAAQA,IAAK,CAAE,IAAI6E,EAAS,UAAU7E,CAAC,GAAK,KAAO,OAAO,UAAUA,CAAC,CAAC,EAAI,CAAA,EAAQ8E,EAAU,OAAO,KAAKD,CAAM,EAAO,OAAO,OAAO,uBAA0B,aAAcC,EAAUA,EAAQ,OAAO,OAAO,sBAAsBD,CAAM,EAAE,OAAO,SAAUE,EAAK,CAAE,OAAO,OAAO,yBAAyBF,EAAQE,CAAG,EAAE,WAAa,CAAC,GAAKD,EAAQ,QAAQ,SAAUjJ,EAAK,CAAEmJ,GAAgBJ,EAAQ/I,EAAKgJ,EAAOhJ,CAAG,CAAC,CAAE,CAAE,CAAI,CAAC,OAAO+I,CAAS,CAEze,SAASI,GAAgBC,EAAKpJ,EAAKmH,EAAO,CAAE,OAAInH,KAAOoJ,EAAO,OAAO,eAAeA,EAAKpJ,EAAK,CAAE,MAAOmH,EAAO,WAAY,GAAM,aAAc,GAAM,SAAU,EAAM,CAAA,EAAYiC,EAAIpJ,CAAG,EAAImH,EAAgBiC,CAAM,CAEjN,SAASmB,GAAyBvB,EAAQwB,EAAU,CAAE,GAAIxB,GAAU,KAAM,MAAO,GAAI,IAAID,EAAS0B,GAA8BzB,EAAQwB,CAAQ,EAAOxK,EAAKmE,EAAG,GAAI,OAAO,sBAAuB,CAAE,IAAIuG,EAAmB,OAAO,sBAAsB1B,CAAM,EAAG,IAAK7E,EAAI,EAAGA,EAAIuG,EAAiB,OAAQvG,IAAOnE,EAAM0K,EAAiBvG,CAAC,EAAO,EAAAqG,EAAS,QAAQxK,CAAG,GAAK,IAAkB,OAAO,UAAU,qBAAqB,KAAKgJ,EAAQhJ,CAAG,IAAa+I,EAAO/I,CAAG,EAAIgJ,EAAOhJ,CAAG,EAAI,CAAG,OAAO+I,CAAS,CAE5e,SAAS0B,GAA8BzB,EAAQwB,EAAU,CAAE,GAAIxB,GAAU,KAAM,MAAO,CAAE,EAAE,IAAID,EAAS,CAAE,EAAM4B,EAAa,OAAO,KAAK3B,CAAM,EAAOhJ,EAAKmE,EAAG,IAAKA,EAAI,EAAGA,EAAIwG,EAAW,OAAQxG,IAAOnE,EAAM2K,EAAWxG,CAAC,EAAO,EAAAqG,EAAS,QAAQxK,CAAG,GAAK,KAAa+I,EAAO/I,CAAG,EAAIgJ,EAAOhJ,CAAG,GAAK,OAAO+I,CAAS,CAMnTyD,GAAgB,SAAS,EAEzB,IAAII,GAAO,SAAclM,EAAOuK,EAAS,CACvC,IAAI4B,EAEA3B,EAAuBpC,GAAc,CAAA,EAAIpI,EAAOuK,EAAQ,KAAK,EAC7D6B,EAAM5B,EAAqB,MAC3BC,EAAOD,EAAqB,KAC5B6B,EAAO7B,EAAqB,KAC5B8B,EAAS9B,EAAqB,OAC9B+B,EAAW/B,EAAqB,SAChCjB,EAAeiB,EAAqB,aACpCgC,EAAUhC,EAAqB,QAC/BE,EAAYb,GAAyBW,EAAsBZ,EAAS,EAEpE6C,GAAYN,EAAY,CAC1B,QAAS,EACb,EAAK1D,GAAgB0D,EAAW,WAAW,OAAO1B,EAAK,IAAI,EAAG,QAAQA,EAAK,IAAI,CAAC,EAAGhC,GAAgB0D,EAAWC,EAAKA,CAAG,EAAGD,GACnHO,EAAiBL,IAAS,IAAQA,GAAQ5B,EAAK,OAAS,UAAY,eAAiB,GACrFkC,EAAeJ,EAEfI,IAAiB,QAAaH,IAChCG,EAAe,GACfjC,EAAU,SAAWiC,GAGvB,IAAIC,EAAWN,EAAS,CACtB,YAAa,UAAU,OAAOA,EAAQ,MAAM,EAC5C,UAAW,UAAU,OAAOA,EAAQ,MAAM,CAC3C,EAAG,OAEAP,EAAwBzC,GAAuBC,CAAY,EAC3DyC,EAAyBnB,GAAekB,EAAuB,CAAC,EAChE3C,EAAe4C,EAAuB,CAAC,EACvC5B,EAAiB4B,EAAuB,CAAC,EAE7C,OAAOa,EAAY,YAAC,OAAQzE,GAAc,CACxC,KAAQ,MACR,aAAcqC,EAAK,IACpB,EAAEC,EAAW,CACZ,QAAW8B,EACX,MAASC,CACb,CAAG,EAAG,CAACI,EAAY,YAACjC,GAAS,CACzB,MAAS8B,EACT,KAAQjC,EACR,aAAgBrB,EAChB,eAAkBgB,EAClB,MAASwC,CACb,EAAK,IAAI,CAAC,CAAC,CACX,EAEAV,GAAK,MAAQ,CACX,KAAM,QACN,OAAQ,OACR,KAAM,OACN,aAAc,MAChB,EACAA,GAAK,YAAc,WACnBA,GAAK,aAAe,GACpBA,GAAK,gBAAkBD,GACvBC,GAAK,gBAAkBJ,GACvB,MAAAgB,GAAeZ,GCvFf,IAAIa,GAAkB,CAAE,KAAQ,CAAE,IAAO,MAAO,MAAS,CAAE,QAAW,gBAAiB,UAAa,OAAS,EAAE,SAAY,CAAC,CAAE,IAAO,OAAQ,MAAS,CAAE,EAAK,6TAA6T,EAAI,CAAC,EAAI,KAAQ,UAAW,MAAS,UAAU,EACzgB,MAAAC,GAAeD,GCAf,SAAS3E,GAAcC,EAAQ,CAAE,QAAS5E,EAAI,EAAGA,EAAI,UAAU,OAAQA,IAAK,CAAE,IAAI6E,EAAS,UAAU7E,CAAC,GAAK,KAAO,OAAO,UAAUA,CAAC,CAAC,EAAI,CAAA,EAAQ8E,EAAU,OAAO,KAAKD,CAAM,EAAO,OAAO,OAAO,uBAA0B,aAAcC,EAAUA,EAAQ,OAAO,OAAO,sBAAsBD,CAAM,EAAE,OAAO,SAAUE,EAAK,CAAE,OAAO,OAAO,yBAAyBF,EAAQE,CAAG,EAAE,WAAa,CAAC,GAAKD,EAAQ,QAAQ,SAAUjJ,EAAK,CAAEmJ,GAAgBJ,EAAQ/I,EAAKgJ,EAAOhJ,CAAG,CAAC,CAAE,CAAE,CAAI,CAAC,OAAO+I,CAAS,CAEze,SAASI,GAAgBC,EAAKpJ,EAAKmH,EAAO,CAAE,OAAInH,KAAOoJ,EAAO,OAAO,eAAeA,EAAKpJ,EAAK,CAAE,MAAOmH,EAAO,WAAY,GAAM,aAAc,GAAM,SAAU,EAAM,CAAA,EAAYiC,EAAIpJ,CAAG,EAAImH,EAAgBiC,CAAM,CAOjN,IAAIqE,GAAkB,SAAyB/M,EAAOuK,EAAS,CAC7D,IAAIzH,EAAIsF,GAAc,CAAA,EAAIpI,EAAOuK,EAAQ,KAAK,EAE9C,OAAOsC,EAAY,YAACC,GAAU1E,GAAc,CAAA,EAAItF,EAAG,CACjD,KAAQkK,EACZ,CAAG,EAAG,IAAI,CACV,EAEAD,GAAgB,YAAc,kBAC9BA,GAAgB,aAAe,GAC/B,MAAAE,GAAeF,GCHfG,GAAenN,kBAAgB,CAC7B,MAAO,CACL,SAAU,CACR,KAAM,QACN,QAAS,EACX,CACF,EACA,WAAY,CAAA,MACVoN,EAAA,IACF,EACA,OAAS,CAQA,MAAA,CACL,UARgBtL,IAAEkL,GAAiB,CACnC,MAAO,CACL,SAAU,OACV,MAAO,SACT,EACA,KAAM,EAAA,CACP,CAEC,CAEJ,CACF,CAAC,gIAvCC,MAAAK,EAAAC,mBAUM,QAVN,uBACEC,qBAOS,MAAAC,GAAA,CAAAC,EAAA,UAAAC,EAAAA,YANKC,EAAAA,YAAAN,EAAA,CACX,IAAA,EAEA,MAAA,OACD,SAAII,EAAQ,SAAA,UAAAA,EAAA,UAGd,IAAA,QAAA,EAAA,KAAA,EAAA,CAAA,WAAA,WAAA,CAAA,GAAAG,aAAAH,EAAA,OAAA,UAAA,CAAA,IAAA,CAAA,CAAA,mCCAJI,GAAe7N,kBAAgB,CAC7B,KAAM,WACN,MAAO,CACL,QAAS,CACP,KAAM,QACN,QAAS,EACX,CACF,EACA,WAAY,CAAA,UACV8N,EAAA,QACF,CACF,CAAC,mCApBCR,mBAEa,YAAA,EAFO,OAAAI,EAAA,UAAA,EAAgBC,EAAA,YAAAI,EAAA,CAAA,OAAA,oIC2cnB,QAAQ,IAAI,WAAa,cACtC,OAAO,OAAO,EAAE,EAEH,QAAQ,IAAI,WAAa,cAAgB,OAAO,OAAO,CAAA,CAAE,EC1c/D,MAAAC,EAAc,CACzBC,EACAC,IACG,CAOH,GANCD,EAA2B,QAAWE,GAAc,CACxC,UAAAC,IAAQ,CAACH,EAAM,GAAG,OAAO,OAAOC,GAAS,CAAE,CAAA,CAAC,EACjDC,EAAA,UAAUC,EAAK,KAAMA,CAAI,CAC/B,EAGEF,EACF,SAAW,CAAC3O,EAAK6O,CAAI,IAAK,OAAO,QAAQF,CAAK,EAC3CD,EAAa1O,CAAG,EAAI6O,EAGlB,OAAAH,CACT,EC0BahO,EAAe,CAC1B,GAAI,GACJ,KAAM,GACN,QAAS,GACT,KAAM,GACN,MAAO,QACP,OAAQ,OACR,SAAU,WACV,IAAK,MACL,KAAM,MACN,OAAQ,EACR,OAAQ,OACR,OAAQ,GACR,SAAU,GACV,WAAY,GACZ,cAAe,MACf,eAAgB,CAAC,EACjB,mBAAoB,GACpB,gBAAiB,EACjB,YAAa,EACb,cAAe,CAAC,CAAE,IAAK,KAAM,MAAO,GAAK,EACzC,OAAQ,CAAC,EACT,SAAU,QACZ,EAEaoO,EAA2CpO,GAE/CqO,GAAA,UAAUrO,EAAQyG,GACnBA,GAAS,KAAa,GACnB,CACL,KAAOA,EAAc,YACrB,QAASA,CAAA,CAEZ,ECnEU6H,GAAwB,CACnC,MAAO,SACP,OAAQ,SACR,gBAAiB,UACjB,gBAAiB,GACjB,eAAgB,YAChB,kBAAmB,GACnB,KAAM,QACR,EAGaC,GAA2BH,EAA0BE,EAAU,ECrBtEE,GAAY,CAChB,QACA,SACA,QACA,WACA,MACA,OACA,SACA,WACA,aACA,aACA,iBACA,YACA,gBACA,WACA,kBACA,kBACA,iBACA,cACA,cACA,eACA,cACA,aACA,iBACA,aACA,QACF,EAOaC,EAAwB,CAAIzO,EAA6B0O,EAA8B,KAAO,CAEzG,MAAMC,EAAiBC,GAAA,QAAQJ,GAAW,GAAGE,CAAgB,EAC7D,OAAO3P,EAAyB,SAAA,IAAM8P,GAAAA,KAAK7O,EAAO2O,CAAc,CAAC,CACnE,ECxCaG,GAAY,YACZC,EAAgB,gBAChBC,EAAe,eACfC,GAAgB,gBAChBC,GAAe,eACfC,GAAe,eAEfC,IAAgBC,GAAA,2BAAQ,SAAR,YAAAA,GAAgB,cAElBC,GAAA,2BAAQ,SAAR,MAAAA,GAAgB,WAE9B,MAAAC,KAAWC,GAAA,2BAAQ,SAAR,YAAAA,GAAgB,gBAAiB,KAE5CC,KAAU/D,GAAA,2BAAQ,SAAR,YAAAA,GAAgB,SAAU,GCXpCgE,GAAa,CAAiC1P,EAA6B2P,IAAmC,CACzH1R,EAAAA,MAAM,IAAM+B,EAAM,GAAI,CAAC4P,EAAIC,IAAU,CAC7B,MAAAC,EAAWjR,SAAOiQ,GAAW,CAGjC,QAAS,CAACrL,EAAWrC,IAA8B,GAGnD,SAAWqC,GAAc,EAAA,CAC1B,EACGmM,GAAM,MAAQA,IAAO,IACdE,EAAA,QAAQF,EAAID,CAAM,CAC7B,EACC,CACD,UAAW,EAAA,CACZ,CACH,ECXaI,GAAgB/P,GAAiC,CAC5D,MAAM2P,EAAS3P,EAAM,OACf4P,EAAK5P,EAAM,GACX8P,EAAWjR,SAAOiQ,GAAW,CAGjC,UAAW,CAACc,EAAWI,IAAiB,EAAA,CACzC,EAEK,CAAE,aAAAC,CAAA,EAAiBpR,EAAA,OAAOkQ,EAAe,CAC7C,aAAcmB,MAAI,EAAE,CAAA,CACrB,EAKM,MAAA,CAACC,EAAYC,EAAqB,IAAM,CAAA,IACtC,UAAY,CAGjB,GADSA,EAAA,KAAK,KAAM,GAAG,SAAS,EAC5BN,EAAU,CACN,KAAA,CAAE,UAAAO,CAAc,EAAAP,EACtBH,EAAO,QAAiB1O,GAAA,CAClB,GAAAkP,IAAOlP,EAAM,GACX,GAAA,CACFgP,EAAa,MAAQL,EACXS,EAAApP,EAAM,OAAQA,EAAM,IAAI,QAC3BG,GACP,QAAQ,MAAMA,CAAC,CACjB,CACF,CACD,CACH,CAAA,CAGN,ECnCakP,GAAmC,CAACC,EAAYC,IAA6C,CACpG,GAAA,CAAE,KAAA/S,EAAO,OAAQ,MAAAgJ,EAAQ,QAAS,KAAAuJ,EAAO,MAAA,EAAWQ,GAAkB,GAE1E/S,EAAOA,GAAA,YAAAA,EAAM,OACbgJ,EAAQA,GAAA,YAAAA,EAAO,OACfuJ,EAAOA,GAAA,YAAAA,EAAM,OACP,MAAAS,MAAU,IACVC,MAAU,IACVpF,EAAMiF,EAAK,OACjB,QAAS9M,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAAkN,EAAOJ,EAAK9M,CAAC,EAEbmN,EAAID,EAAKlT,CAAI,GAAK,GAElBoT,EAAIF,EAAKlK,CAAK,GAAK,GAEnBzD,EAAI2N,EAAKX,CAAI,GAAK,GAEpB,GADJS,EAAI,IAAIG,CAAC,EACLF,EAAI,IAAI1N,CAAC,EAAG,CACR,MAAA8H,EAAM4F,EAAI,IAAI1N,CAAC,EACjB8H,EAAA,KAAK,CAAE,KAAM8F,EAAG,MAAOC,EAAG,GAAGF,EAAM,EACnCD,EAAA,IAAI1N,EAAG8H,CAAG,CAAA,MAEV4F,EAAA,IAAI1N,EAAG,CAAC,CAAE,KAAM4N,EAAG,MAAOC,EAAG,GAAGF,CAAK,CAAC,CAAC,CAE/C,CACM,MAAAG,EAAa,MAAM,KAAKL,CAAG,EAC3BM,EAAmC,CAAA,EACzC,SAAW,CAACtT,EAAM8S,CAAI,IAAKG,EACzBK,EAAQ,KAAK,CACX,KAAAtT,EACA,KAAA8S,CAAA,CACD,EAEI,MAAA,CACL,WAAAO,EACA,QAAAC,CAAA,CAEJ,ECtCaC,GAAmBC,GACvBA,EAAU,QAAQ,OAAQ;AAAA,CAAI,EAQ1BC,GAAc,CAACzK,EAAwB0K,EAAuB,IAAM,CACzE,MAAAC,EAAS,WAAW3K,EAAQ,EAAE,EAChC,OAAA,MAAM2K,CAAM,GAAKA,EAAS,EAAU3K,EACjC2K,EAAO,QAAQD,CAAa,EAAE,QAAQ,sBAAuB,KAAK,CAC3E,EAEaE,GAAmB,CAAC5K,EAAwB0K,EAAuB,IAAM,CACpF,MAAMG,EAAW7K,EAAQ,GACrB,GAAA6K,EAAS,SAAS,GAAG,EAAU,OAAA7K,EAC7B,MAAA2K,EAAS,WAAWE,CAAQ,EAClC,OAAI,MAAMF,CAAM,EAAU3K,EACnB,IAAI2K,EAAS,KAAK,QAAQD,CAAa,IAChD,EAQaI,GAAoB,CAACC,EAAQC,IACpC,OAAOD,GAAO,UAAY,OAAOC,GAAO,SACnCD,EAAG,kBAAkB,EAAE,SAASC,EAAG,mBAAmB,EAExD,GCxCIC,GAAqB,CAChCT,EAAoB,GACpBV,EAA8B,CAAC,EAC/B,CAAE,WAAAoB,EAAa,GAAO,SAAAC,EAAW,EAAM,EAAI,CAAA,IACxC,CAIHrB,EAAO,CAAE,GADM,OAAO,QAAU,GACZ,GAAGA,CAAK,EACtB,MAAAsB,EAAaZ,EAAW,MAAM,YAAY,EAChD,GAAIY,GAAa,MAAQA,EAAU,SAAW,EACrC,OAAAZ,EAET,QAASxN,EAAI,EAAGA,EAAIoO,EAAU,OAAQpO,IAAK,CACnC,MAAAqO,EAAWD,EAAUpO,CAAC,EAC5B,IAAIsO,EAAYD,EAAS,MAAM,EAAG,EAAE,EACpC,MAAME,EAAM,kCACNC,EAAgBF,EAAU,MAAMC,CAAG,EACzC,QAASE,EAAI,EAAGA,EAAID,EAAc,OAAQC,IAAK,CACvC,MAAAC,EAAeF,EAAcC,CAAC,EAC9BE,EAAe7B,EAAK4B,CAAY,EAClCC,GAAgB,OAENL,EAAAA,EAAU,QAAQI,EAAcC,CAAY,EAM5D,CACI,GAAA,CAIFL,KADc,MACIA,CAAS,QACpB3Q,GACP,QAAQ,MAAMA,CAAC,CACjB,CACY6P,EAAAA,EAAU,QAAQa,EAAUC,CAAS,CACnD,CAEA,OAAIJ,IACUV,EAAAA,GAAA,YAAAA,EAAW,QAAQ,UAAW,UAGxCW,IACUX,EAAAA,GAAA,YAAAA,EAAW,QAAQ,WAAY,iBAEtCA,CACT,EC1CaoB,GAAiB,CAACrS,EAA8BsS,EAAqB,IAAM,CAAC,IAAM,CACvF,KAAA,CACJ,WAAAC,EACA,cAAeC,EACf,eAAgBC,EAChB,cAAAC,EACA,gBAAAC,EACA,mBAAAC,CACE,EAAA5S,EACE,CAAE,kBAAA6S,EAAmB,SAAAC,EAAU,aAAA7C,CAAa,EAAIpR,EAAAA,OAAOkQ,EAAe,CAC1E,kBAAmB,GACnB,SAAU,SACV,aAAc,EAAA,CACf,EACK,CAAE,eAAAgE,CAAA,EAAmBlU,EAAA,OAAOmQ,EAAc,CAG9C,eAAiB1P,GAAgB,EAAA,CAClC,EACK0T,EAAMtB,GAAmBa,CAAU,EACnCU,EAAc,MAAOC,EAAiC,KAAO,CAC7D,GAAA,CAACF,GAAO,CAACR,GAAU,CAACC,GAAWzT,EAAA,MAAM8T,CAAQ,IAAM,SAAU,OACjE,IAAIK,EAAU,CAAA,EACAT,EAAA,QAASU,GAAU,CACzB,KAAA,CAAE,IAAA9T,EAAK,MAAAmH,CAAU,EAAA2M,EACvB,GAAK,OAAO3M,GAAU,UAAYA,EAAM,GAAK,CAW3C,IAAI4M,EAAS,CAAA,EACb,KAAM,CAAE,GAAAzD,EAAI,KAAA0D,EAAM,QAAAC,EAAS,QAAAC,GAAY/M,EACnCmJ,IAAO,OAETyD,EAASN,EAAe/T,EAAAA,MAAMiR,CAAY,CAAC,GAAK,CAAA,EAEvCoD,EAAAN,EAAenD,CAAE,GAAK,GAEjC,MAAM9M,EAAI9D,EAAA,MAAMqU,EAAOC,CAAI,CAAC,EAE5B,IAAI,EAAI,KAGR,GADqB,CAAC,OAAQ,OAAO,EAAE,KAAM3C,GAASY,GAAkB8B,GAAA,YAAAA,EAAQ,KAAM1C,CAAI,CAAC,EACzE,CAEhB,KAAM,CAAE,MAAAlK,EAAO,KAAAuJ,EAAM,KAAAyD,CAAK,EAAID,GAAW,GACrC/M,GAAAA,GAASuJ,GAAQyD,EACnB,OAAQzD,EAAM,CACZ,IAAK,MACH,EAAIhR,EAAM,MAAA8D,CAAC,EAAE,IAAI2D,EAAOgN,CAAI,EAC5B,MACF,IAAK,QACH,EAAIzU,EAAM,MAAA8D,CAAC,EAAE,SAAS2D,EAAOgN,CAAI,EACjC,KACJ,CAEE,GAAK,OACP,EAAIzU,EAAAA,MAAM8D,CAAC,GAKb,GAAI,iBAAG,QAAOyQ,GAAA,YAAAA,EAAS,SAAUF,EAAO,UAAW,EAAA,MAI/C,OAAO,UAAU,SAAS,KAAKvQ,CAAC,IAAM,kBACpC,EAAAA,EAAEyQ,GAAW,OAAO,EAEpB,EAAAzQ,EAIRqQ,EAAQ7T,CAAG,EAAI,CAAA,MACN,OAAOmH,GAAU,WAClB0M,EAAA7T,CAAG,EAAIoS,GAAmBjL,CAAK,EACzC,CACD,EAES0M,EAAA,CAAE,GAAG,OAAO,OAAO,cAAe,GAAGD,EAAQ,GAAGC,GAC1D,IAAIO,EAAY,GACV,MAAAC,EAAO,OAAO,KAAKR,CAAO,EAC1BS,EAAOD,EAAK,OAAS,EACrBE,EAAUF,EAAK,OAChBA,EAAA,QAAQ,CAACrU,EAAK6H,IAAU,CACvBA,IAAU,EACR0M,IAAY,EACDH,GAAA,IAAIpU,KAAO6T,EAAQ7T,CAAG,KAEtBoU,GAAA,IAAIpU,KAAO6T,EAAQ7T,CAAG,IAE5B6H,IAAUyM,EACNF,GAAA,GAAGpU,KAAO6T,EAAQ7T,CAAG,IAErBoU,GAAA,GAAGpU,KAAO6T,EAAQ7T,CAAG,IACpC,CACD,EACG,GAAA,CACF,MAAMwU,EAAiB,CAAC,MAAO,MAAM,EAAE,SAAStB,CAAM,EAChDuB,EAAM,MAAMC,GAAM,CACtB,QAAShV,QAAM6T,CAAiB,EAChC,IAAKiB,EAAiBd,EAAMU,EAAYV,EACxC,OAAAR,EACA,QAAAC,EACA,KAAMqB,EAAiB,CAAA,EAAKX,CAAA,CAC7B,EACD,OAAAb,EAASyB,CAAG,EACLA,QACA3S,GACP,QAAQ,MAAMA,CAAC,CACjB,CAAA,EAGI6S,EAAmBrB,GAAsB,YAAYK,EAAaN,EAAkB,GAAI,EAE9F/Q,OAAAA,EAAAA,YAAY,IAAM,CAChB,cAAcqS,CAAgB,CAAA,CAC/B,EAEMhB,CACT,EC9HaiB,GAAiC,CAAC3D,EAAa,GAAIC,IAA0C,CACpG,GAAA,CAAE,KAAA/S,EAAO,OAAQ,MAAA0W,EAAQ,CAAA,CAAG,EAAI3D,GAAkB,GAC/C/S,GAAAA,GAAA,YAAAA,EAAM,SAAUA,EACjB,MAAAgT,MAAU,IACVC,MAAU,IACV0D,EAAU7D,EAAK,OACf8D,EAAWF,EAAM,OAEvB,GAAIC,IAAY,EAAG,CACjB,MAAME,EAAK,CAAA,EAEX,QAAS7Q,EAAI,EAAGA,EAAI4Q,EAAU5Q,IAAK,CAC3B,MAAAuM,EAAOmE,EAAM1Q,CAAC,EACd,CAAE,MAAA8Q,EAAO,MAAA9N,CAAU,EAAAuJ,EACnB1M,EAAI,CAAE,GAAGiN,EAAK,CAAC,EAAG,MAAOA,EAAK,CAAC,EAAE9J,CAAK,GAC5CgK,EAAI,IAAI8D,CAAK,EAEbD,EAAG,KAAKhR,CAAC,CACX,CACA,MAAMvB,EAAIwO,EAAK,CAAC,EAAE9S,CAAI,GAAK,GACvBiT,EAAA,IAAI3O,EAAGuS,CAAE,CAAA,KAEb,SAAS7Q,EAAI,EAAGA,EAAI2Q,EAAS3Q,IAAK,CAC1B,MAAAkN,EAAOJ,EAAK9M,CAAC,EACbmN,EAAID,EAAKlT,CAAI,EACnBgT,EAAI,IAAIG,CAAC,EACT,QAASsB,EAAI,EAAGA,EAAImC,EAAUnC,IAAK,CAC3B,MAAAlC,EAAOmE,EAAMjC,CAAC,EACd,CAAE,MAAAqC,EAAO,MAAA9N,CAAU,EAAAuJ,EACnB1M,EAAI,CAAE,GAAGqN,EAAM,MAAOA,EAAKlK,CAAK,GAClC,GAAAiK,EAAI,IAAI6D,CAAK,EAAG,CACZ,MAAAC,EAAI9D,EAAI,IAAI6D,CAAK,EACvBC,EAAE,KAAKlR,CAAC,EACJoN,EAAA,IAAI6D,EAAOC,CAAC,CAAA,MAEhB9D,EAAI,IAAI6D,EAAO,CAACjR,CAAC,CAAC,CAEtB,CACF,CAGI,MAAAwN,EAAa,MAAM,KAAKL,CAAG,EAC3BM,EAAmC,CAAA,EACzC,SAAW,CAACtT,EAAM8S,CAAI,IAAKG,EACzBK,EAAQ,KAAK,CACX,KAAAtT,EACA,KAAA8S,CAAA,CACD,EAEI,MAAA,CACL,WAAAO,EACA,QAAAC,CAAA,CAEJ,EC5Da0D,GAAe,CAACC,EAAaC,EAAoB,KAAU,OACtE,GAAI,CAACD,EAAa,OAAAA,EAClB,IAAIE,EAAoB,GACpB,OAAAF,GAAA,MAAAA,EAAM,SAAS,OACLE,EAAAF,EAGAE,IAAAvF,EAAA,2BAAQ,SAAR,YAAAA,EAAgB,YAAaqF,EAEvCC,IACFC,EAAY,OAAOA,MAEdA,CACT,ECZaC,GAAa,CAAC/B,EAAkBgC,IAAmB,CACxD,MAAAC,EAAa,GAAGxF,qBAA2BuF,IAC3CE,EAAa,GAAGzF,MAAYuF,IAC3B,OAAAhC,IAAa,UAAYiC,EAAaC,CAC/C,ECFaC,GAAUjB,GAAM,OAAO,CAEpC,CAAC,EACDiB,GAAQ,aAAa,QAAQ,IAAKC,GACzBA,EACLC,GACK,QAAQ,OAAOA,CAAK,CAC5B,EAEDF,GAAQ,aAAa,SAAS,IAAKC,GAAW,WAC5C,MAAI,GAAC7F,EAAA6F,GAAA,YAAAA,EAAQ,OAAR,YAAA7F,EAAc,OAAS,KAC1BxG,EAAAA,QAAQ,MAAM,CACZ,UAASyG,EAAA4F,GAAA,YAAAA,EAAQ,OAAR,YAAA5F,EAAc,QAAOE,EAAA0F,GAAA,YAAAA,EAAQ,OAAR,YAAA1F,EAAc,UAAW,QACvD,IAAK,cAAA,CACN,EAEI0F,CACT,EAAIC,GAAU,CACZ,GAAIA,EAAM,QAAQ,SAAS,SAAS,EAClCtM,EAAAA,QAAQ,MAAM,CACZ,QAAS,cACT,IAAK,SAAA,CACN,MACI,CACC,KAAA,CAAE,OAAAuM,CAAO,EAAID,EAAM,SACrBC,GAAU,KAAOA,EAAS,KAC5BvM,EAAAA,QAAQ,MAAM,CACZ,QAAS,OACT,IAAK,eAAA,CACN,EAGCuM,GAAU,KACZvM,EAAAA,QAAQ,MAAM,CACZ,QAAS,QACT,IAAK,eAAA,CACN,CAEL,CACO,OAAA,QAAQ,OAAOsM,CAAK,CAC7B,CAAC,EClCY,MAAAE,GAAyBrV,GAAU,CAE9C,KAAM,CAAE,eAAA+S,CAAA,EAAmBlU,EAAA,OAAOmQ,EAAc,CAG9C,eAAiB1P,GAAgB,EAAA,CAClC,EACKgW,EAAoBC,GAAkB,CAC1C,MAAMC,EAAgB,CAAA,EAEP,OAAAD,GAAA,MAAAA,EAAA,aAAa,QAAoBE,GAAA,CAC9C,GAAIA,EAAU,CACZ,IAAIC,EAAO,GACPH,EAAc,SAAS,SAASE,EAAS,IAAI,IACxCC,EAAA,IAET,IAAIC,EAAiB,CACnB,MAAOF,EAAS,KAChB,WAAYA,EAAS,MACrB,UAAWA,EAAS,UAAYA,EAAS,UAAY,MACrD,MAAO,KACP,SAAU,OACV,KAAAC,CAAA,EAEEH,EAAc,SAAW,kBAC3BI,EAAU,aAAeF,EAAS,WAExBE,EAAAC,EAAmBH,EAAUE,CAAS,EAClDH,EAAc,KAAKG,CAAS,CAC9B,CAAA,GAGYJ,EAAA,cAAc,QAAcM,GAAA,CACxC,IAAIH,EAAO,GACPH,EAAc,UAAU,SAASM,EAAG,IAAI,IACnCH,EAAA,IAET,IAAIC,EAAiB,CACnB,MAAOE,EAAG,KACV,WAAYA,EAAG,MACf,UAAW,MACX,MAAO,KACP,SAAU,OACV,KAAAH,CAAA,EAEUC,EAAAC,EAAmBC,EAAIF,CAAS,EACxCJ,EAAc,SAAW,kBAC3BI,EAAU,aAAeE,EAAG,WAE9BL,EAAc,KAAKG,CAAS,CAAA,CAC7B,EAEMH,CAAA,EAQHI,EAAqB,CAAKjF,EAAMgF,IAAoB,CAClD,MAAAG,EAAoB,CAAE,GAAGH,GAC/B,OAAIhF,EAAK,WACHA,EAAK,aAAe,WAClBA,EAAK,aACPmF,EAAa,QAAUnF,EAAK,YAE9BmF,EAAa,SAAW,YAExBA,EAAa,eAAiBnF,EAAK,aACnCmF,EAAa,SAAW,WACpBnF,EAAK,WACPmF,EAAa,mBAAqBnF,EAAK,UAErCA,EAAK,kBACPmF,EAAa,eAAiBnF,EAAK,kBAKvCmF,EAAa,SAAW,SAGnBA,CAAA,EASHC,EAAkB,CAACC,EAAe,KAAO,OAE7C,MAAMC,EAAO,CAAA,EACb,QAASxS,EAAI,EAAGA,EAAIuS,EAAa,OAAQvS,IAAK,CACtC,KAAA,CAAE,QAAAyS,EAAS,WAAAC,EAAY,WAAAC,EAAY,YAAAC,EAAa,GAAAzG,CAAG,EAAIoG,EAAavS,CAAC,EACrEkN,EAAY,CAChB,MAAOuF,EACP,UAAWC,EACX,KAAMC,GAAc,OACpB,WAAY,GACZ,UAAW,GACX,YAAAC,CAAA,EAEIC,EAAYvD,EAAenD,CAAE,GAAK,CAAA,EAMpC,GALAuG,IAAe,WACjBxF,EAAK,UAAY,OACR,CAAC,SAAU,aAAa,EAAE,SAASwF,CAAU,IACtDxF,EAAK,UAAY,QAEf2F,EAAU,OAAS,iBAAkB,CACvC3F,EAAK,WAAa2F,EAAU,OAC5B,MAAMrF,GAAYjS,EAAAA,EAAA,MAAMsX,CAAS,IAAftX,YAAAA,EAAkB,MAAM,OACtC,OAAOiS,GAAc,aAClBN,EAAA,WAAaM,EAAUqF,GAAA,YAAAA,EAAW,MAAM,EAEjD,CACAL,EAAK,KAAKtF,CAAI,CAChB,CACO,OAAAsF,CAAA,EAGHM,EAAgB,CAACC,EAAgBP,IAAS,CAExC,MAAAQ,EAAeR,EAAK,KAAatF,GAC9BA,EAAK,OAAS6F,EAAe,KACrC,EACGC,EAAa,KAAK,OAChBA,EAAa,KAAK,OAAS,SAC7BD,EAAe,KAAO,CACpB,MAAOC,EAAa,KAAK,MACzB,WAAYA,EAAa,KAAK,WAC9B,KAAM,SACN,MAAOA,EAAa,KAAK,IAAA,EAG3BD,EAAe,KAAO,CACpB,MAAOC,EAAa,MACpB,WAAYA,EAAa,WACzB,KAAM,SACN,mBAAoBA,EAAa,KAAK,kBAAA,GAIxCA,EAAa,aACXA,EAAa,YAAY,UAAU,OAAS,IAC9CD,EAAe,YAAc,CAC3B,aAAc,CAAC,EACf,eAAgB,EAAA,EAElBC,EAAa,YAAY,UAAU,QAAQ,CAACC,EAAKC,IAAa,CACxDA,IAAa,IACfH,EAAe,YAAY,aAAaE,EAAI,GAAG,EAAIA,EAAI,MACzD,CACD,EACDF,EAAe,YAAY,eAAiBC,EAAa,YAAY,WAAa,IAGtFD,EAAe,mBAAqBC,EAAa,SAClCD,EAAA,oBAAsBC,EAAa,WAAa,EAAA,EAG3DG,EAAqB,CAACC,EAAQC,IAAe,CACjD,QAASrT,EAAI,EAAGA,EAAIoT,EAAO,SAAS,OAAQpT,IAC1C,GAAIoT,EAAO,SAASpT,CAAC,EAAE,SAAS,OAAS,EAAG,CAC1C,IAAIsT,EAAO,GACPF,EAAO,OAAS,MACXE,EAAA,KAEAA,EAAA,KAETD,EAAW,KAAK,CAAE,WAAY,CAAA,EAAI,KAAAC,CAAY,CAAA,EAC3BH,EAAAC,EAAO,SAASpT,CAAC,EAAGqT,EAAWA,EAAW,OAAS,CAAC,EAAE,UAAU,CAAA,SAE/ED,EAAO,SAASpT,CAAC,EAAE,UAAW,CAChC,IAAIuT,EAAa,GACjB,MAAMrG,EAAY,CAChB,UAAWkG,EAAO,SAASpT,CAAC,EAAE,UAC9B,UAAWoT,EAAO,SAASpT,CAAC,EAAE,SAC9B,KAAMoT,EAAO,SAASpT,CAAC,EAAE,KACzB,WAAY,GACZ,MAAOoT,EAAO,SAASpT,CAAC,EAAE,MAC1B,QAASoT,EAAO,SAASpT,CAAC,EAAE,QAAUoT,EAAO,SAASpT,CAAC,EAAE,QAAU,IACnE,aAAcoT,EAAO,SAASpT,CAAC,EAAE,aAAeoT,EAAO,SAASpT,CAAC,EAAE,aAAe,EAAA,EAGpF,GADauT,EAAA,KAAK,MAAM,KAAK,UAAUH,EAAO,SAASpT,CAAC,EAAE,UAAU,CAAC,EACjEoT,EAAO,SAASpT,CAAC,EAAE,WAAa,OAClCkN,EAAK,WAAakG,EAAO,SAASpT,CAAC,EAAE,OACrCkN,EAAK,cAAgBkG,EAAO,SAASpT,CAAC,EAAE,cACxCkN,EAAK,SAAWkG,EAAO,SAASpT,CAAC,EAAE,SAC/BoT,EAAO,SAASpT,CAAC,EAAE,aAAe,OAChCoT,EAAO,SAASpT,CAAC,EAAE,eACRuT,EAAA,UACbrG,EAAK,SAAWkG,EAAO,SAASpT,CAAC,EAAE,UAK5BoT,EAAO,SAASpT,CAAC,EAAE,aAAe,cAC3CuT,EAAa,KAAOH,EAAO,SAASpT,CAAC,EAAE,cAAgB,KAEzDkN,EAAK,WAAakG,EAAO,SAASpT,CAAC,EAAE,OACrCkN,EAAK,cAAgBkG,EAAO,SAASpT,CAAC,EAAE,cACxCkN,EAAK,SAAWkG,EAAO,SAASpT,CAAC,EAAE,iBAE/B,OAAO,UAAU,SAAS,KAAKuT,CAAU,IAAM,iBAAkB,CACnE,MAAMC,EAAiB,CAAA,EACvB,QAASlV,EAAI,EAAGA,EAAIiV,EAAW,OAAQjV,IACjCiV,EAAWjV,CAAC,IAAM,MACVkV,EAAA,KAAKD,EAAWjV,CAAC,CAAC,EAGnBiV,EAAAC,EAAU,KAAK,GAAG,CACjC,CAEFtG,EAAK,WAAaqG,EACdH,EAAO,SAAS,OAAS,GAAKpT,IAAMoT,EAAO,SAAS,OAAS,IAC3DA,EAAO,OAAS,MAClBlG,EAAK,KAAO,KAEZA,EAAK,KAAO,MAGhBmG,EAAW,KAAKnG,CAAI,CACtB,CAEJ,EAIIuG,EAAkB,CAAClH,EAAMiG,EAAMV,IAAkB,CACrD,GAAI,CAACvF,EACH,OAEF,MAAMyG,EAAelB,EAAcU,CAAI,EAAE,KAAatF,GAC7CA,EAAK,OAASX,EAAK,KAC3B,EACD,GAAI,CAACyG,EACH,OAEF,MAAMK,EAAa,CAAA,EACbK,EAAaV,EAAa,WAChC,GAAIU,EACF,QAAS1T,EAAI,EAAGA,EAAI0T,EAAW,OAAQ1T,IACjC0T,EAAW1T,CAAC,EAAE,SAAS,OAAS,GACfmT,EAAAO,EAAW1T,CAAC,EAAGqT,CAAU,EAI3C,OAAAA,CAAA,EAGT,OAAO,gBAAkB,SACvB,MAAMM,EAAgBpX,EAAM,KAC5B,IAAIuV,EAAgBvV,EAAM,eACtB,CAACuV,GAAiB,OAAO,KAAKA,CAAa,EAAE,SAAW,KAC1CA,EAAA,CACd,SAAU,CAAC,EACX,aAAc,CAAC,EACf,OAAQ,CAAC,EACT,WAAY,CAAC,EACb,SAAU,CAAC,EACX,aAAc,CAAC,EACf,UAAW,CAAC,EACZ,cAAe,CAAC,EAChB,aAAc,CAAC,CAAA,GAGnB,MAAM8B,EAAa9B,EAAc,SAE7B,GADe,CAAC,GAAGA,EAAc,SAAU,GAAGA,EAAc,SAAS,EAC1D,SAAW,EAAG,CAC3B1M,UAAQ,MAAM,WAAW,EACzB,MACF,CAGM,MAAA2M,EAAgBF,EAAiBC,CAAa,EAEhD,IAAA+B,EACA,GAAA,MAAM,QAAQ/B,EAAc,MAAM,GAAKA,EAAc,OAAO,OAAS,EAAG,CAC1E,MAAMgC,GAAalI,EAAAkG,EAAc,aAAd,YAAAlG,EAA0B,KAAasB,GAAA,CAClD,MAAA6G,EAAcjC,EAAc,OAAO,CAAC,EAC1C,OAAO5E,EAAK,OAAS6G,GAAe7G,EAAK,UAAY6G,CAAA,GAEnDD,GAAc,OACPD,EAAA,CACP,MAAOC,EAAW,KAClB,WAAYA,EAAW,KAAA,EAG7B,CAEI,IAAAf,EACA,GAAAa,EAAW,OAAS,EAAG,CACRb,EAAA,CACf,MAAOa,EAAW,CAAC,EACnB,WAAYA,EAAW,CAAC,CAAA,EAE1B,MAAMI,IAAWnI,EAAAiG,EAAc,eAAd,YAAAjG,EAA4B,KAAaqB,IACjDA,GAAA,YAAAA,EAAM,QAAS0G,EAAW,CAAC,IAAK1G,GAAA,YAAAA,EAAM,WAAY0G,EAAW,CAAC,KACjE,CAAA,EACNb,EAAe,WAAaiB,EAAS,MAEvBlB,EAAAC,EAAgBjB,EAAc,YAAY,EACxDiB,EAAe,WAAaU,EAAgBV,EAAgB,eAAgBjB,CAAa,GAAK,EAChG,CACI+B,IAEYf,EAAAe,EAAQ/B,EAAc,UAAU,EAC9C+B,EAAO,WAAaJ,EAAgBI,EAAQ,aAAc/B,CAAa,GAAK,IAG9E,QAASvS,EAAI,EAAGA,EAAIwS,EAAc,OAAQxS,IACpCwS,EAAcxS,CAAC,EAAE,WAAa,QAClBwS,EAAAxS,CAAC,EAAE,WAAakU,EAAgB1B,EAAcxS,CAAC,EAAG,gBAAiBuS,CAAa,EAEhFC,EAAAxS,CAAC,EAAE,WAAakU,EAAgB1B,EAAcxS,CAAC,EAAG,eAAgBuS,CAAa,EAI7F,IAAAmC,GACAnC,GAAA,YAAAA,EAAe,YAAa,SAEdmC,EAAAnC,EAAc,eAAiB,GAE/BmC,EAAA3B,EAAgBR,GAAA,YAAAA,EAAe,YAAY,EAE7D,IAAIjN,EAAS,WACTqP,EAAc,GACdC,EAAe,GACfC,EAAa,GACbtC,EAAc,SAAW,kBAClBjN,EAAA,gBACTqP,EAAcpC,EAAc,YAC5BqC,EAAerC,EAAc,aAC7BsC,EAAatC,EAAc,YAG7B,MAAM7E,EAAM,CACV,QAAS,MACT,SAAU,OACV,QAAS,MACT,YAAa,SAAA,EAGX,GAAA,CACF,MAAMqD,EAAM,MAAMkB,GAAQ,IAAI,GAAG7F,mCAA+C,CAC9E,QAAS,CACP,WAAY,mCACZ,gBAAiB,KACnB,CAAA,CACD,EAEM,OAAA6F,GAAQ,KAAK,GAAG7F,aAAyB,CAC9C,WAAYmG,EAAc,WAC1B,OAAQ,IACR,MAAO,IACP,UAAW7E,EAAI0G,CAAa,EAC5B,eAAAZ,EACA,cAAAhB,EACA,OAAA8B,EACA,cAAAI,EACA,OAAApP,EACA,YAAAqP,EACA,aAAAC,EACA,WAAAC,CAAA,EACC,CACD,QAAS,CAAE,eAAgB9D,EAAI,KAAK,KAAK,KAAM,CAAA,CAChD,QACM3S,GACP,QAAQ,MAAMA,CAAC,CACjB,CAAA,CAEJ,EC/Xa0W,GAAoB,CAAC7G,EAAmBxK,IAAiB,CACpE,GAAIwK,GAAa,KAAa,OAAAxK,EACxB,MAAAoL,EAAaZ,EAAW,MAAM,SAAS,EAC7C,GAAIY,GAAa,MAAQA,EAAU,SAAW,EACrC,OAAApL,EAET,MAAM6E,EAAMuG,EAAU,OACtB,QAASpO,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAAqO,EAAWD,EAAUpO,CAAC,EACxB,GAAAqO,GAAY,MAAQA,IAAa,GAAI,MACzC,IAAIC,EAAYD,EAAS,MAAM,EAAG,EAAE,EACxBC,EAAAA,GAAA,YAAAA,EAAW,QAAQ,SAAUtL,GACrC,GAAA,CAEF,IAAIhH,EAASsS,EACR,aAAc,KAAKA,CAAS,IAG/BtS,KADc,MACCsS,CAAS,GAEdd,EAAAA,EAAU,QAAQa,EAAUrS,CAAM,QACvC2B,GACK6P,EAAAA,EAAU,QAAQa,EAAUC,CAAS,EACjD,QAAQ,KAAK3Q,CAAC,CAChB,CACF,CACO,OAAA6P,CACT,ECtBa8G,GAAmB,CAAC/X,EAA+B,KAAO,CACrE,KAAM,CAAE,aAAAgY,CAAA,EAAiBnZ,EAAA,OAAOqQ,GAAc,CAG5C,aAAc,IAAM,EAAA,CACrB,EAEGlP,EAAM,WAAa,aAERgY,IAGf,MAAMC,EAAoB,CAACC,EAAqC,KAAO,CACrE,KAAM,CAAE,MAAA3D,EAAO,KAAA9W,EAAM,SAAA0a,EAAU,KAAAzC,EAAM,UAAA0C,CAAc,EAAAF,EAC5C,MAAA,CACL,MAAA3D,EACA,WAAY9W,EACZ,SAAA0a,EACA,KAAAzC,EACA,SAAU,SACV,aAAc0C,CAAA,CAChB,EAGIC,EAAkB,CAAC1C,EAAmC,KAAO,CAC3D,KAAA,CACJ,MAAApB,EACA,KAAA9W,EACA,SAAA0a,EACA,KAAAzC,EACA,UAAA0C,EACA,SAAAE,EAAW,SACX,eAAAC,EACA,mBAAAC,EACA,eAAAC,EACA,QAAAC,EACA,WAAA5B,CACE,EAAAnB,EACG,MAAA,CACL,MAAApB,EACA,WAAY9W,EACZ,SAAA0a,EACA,KAAAzC,EACA,SAAA4C,EACA,aAAcF,EACd,UAAW,MACX,eAAAG,EACA,mBAAAC,EACA,eAAAC,EACA,QAAAC,EACA,WAAA5B,CAAA,CACF,EAGI,CAAE,eAAA/D,CAAA,EAAmBlU,EAAA,OAAOmQ,EAAc,CAG9C,eAAiB1P,GAAgB,EAAA,CAClC,EACKqZ,EAAsB,CAACC,EAAwC,KAAO,OAC1E,MAAMtN,EAAMsN,EAAY,OAClBlB,EAAgB,CAAA,EACtB,QAASjU,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAAoV,EAAUD,EAAYnV,CAAC,EACvB,CACJ,GAAAmM,EACA,eAAAkJ,EACA,aAAAC,EACA,mBAAAC,CACE,EAAAH,EACEI,EAAsC,CAC1C,KAAM,OACN,MAAOH,EACP,UAAWC,EACX,WAAY,GACZ,UAAWC,CAAA,EAGPE,EAAQnG,EAAenD,CAAE,GAAK,CAAA,EACpC,GAAI2B,GAAkB2H,EAAM,KAAM,MAAM,EAAG,CACzC,KAAM,CAAE,MAAAzS,EAAO,OAAAlC,GAAW2U,GAAS,CAAA,EACnCD,EAAa,YAAaja,EAAAA,EAAA,MAAMyH,CAAK,IAAXzH,YAAAA,EAAc,OAAOuF,GAC/C0U,EAAa,WAAa1U,CAC5B,CACAmT,EAAc,KAAKuB,CAAY,CACjC,CACO,OAAAvB,CAAA,EAET,MAAO,UAAY,OACX,KAAA,CAAE,cAAAnC,CAAkB,EAAAvV,EACpB,CACJ,OAAAsI,EACA,WAAA6Q,EACA,OAAAC,EACA,MAAAC,EACA,UAAAC,EACA,mBAAAC,EAAqB,CAAC,EACtB,WAAAC,EAAa,CAAC,EACd,aAAAC,EAAe,CAAC,EAChB,cAAAC,EAAgB,CAAC,EACjB,gBAAAC,EAAkB,CAAC,EACnB,WAAAC,EAAa,CAAC,EACd,YAAAhB,EAAc,CAAC,EACf,aAAAhB,EACA,WAAAC,EACA,QAAAgC,EAAU,EAAA,EACRtE,GAAiB,CAAA,EASjB,IAAAiB,EACJ,GAAI,MAAM,QAAQ+C,CAAkB,GAAKA,EAAmB,OAAS,EAAG,CACtE,MAAMjO,EAAMiO,EAAmB,OAC/B,QAAS9V,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CAC5B,MAAMkN,EAAO4I,EAAmB9V,CAAC,GAAK,CAAA,EAChC,CAAE,MAAA8Q,EAAQ,GAAI,KAAA9W,EAAO,GAAI,KAAAiY,EAAO,GAAO,KAAAoE,EAAM,YAAAC,EAAa,WAAAjD,EAAA,EAAenG,EAE3E,GAAA+E,GAAQpK,IAAQ,EAAG,CACJkL,EAAA,CACf,MAAAjC,EACA,WAAY9W,EACZ,KAAAiY,EACA,KAAAoE,EACA,YAAAC,EACA,WAAAjD,EAAA,EAEF,KACF,CACF,CACF,CAEI,IAAAQ,EACJ,GAAI,MAAM,QAAQkC,CAAU,GAAKA,EAAW,OAAS,EAAG,CACtD,MAAMlO,EAAMkO,EAAW,OACvB,QAAS/V,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CAC5B,MAAMkN,EAAO6I,EAAW/V,CAAC,GAAK,CAAA,EACxB,CAAE,MAAA8Q,EAAQ,GAAI,KAAA9W,EAAO,GAAI,KAAAiY,EAAO,GAAO,KAAAoE,EAAM,YAAAC,EAAa,WAAAjD,EAAA,EAAenG,EAE3E,GAAA+E,GAAQpK,IAAQ,EAAG,CACZgM,EAAA,CACP,MAAA/C,EACA,WAAY9W,EACZ,KAAAiY,EACA,KAAAoE,EACA,YAAAC,EACA,WAAAjD,EAAA,EAEF,KACF,CACF,CACF,CAEA,MAAMkD,EAAe,CAAA,EACJL,GAAA,MAAAA,EAAA,QAASzB,GAAuC,CAClD8B,EAAA,KAAK/B,EAAkBC,CAAW,CAAC,CAAA,GAIlD,MAAM1C,EAAgB,CAAA,EAatB,GAZciE,GAAA,MAAAA,EAAA,QAAShE,GAAoC,CACzDA,EAAS,SAAW,OACND,EAAA,KAAK6C,EAAgB5C,CAAQ,CAAC,CAAA,GAE/BiE,GAAA,MAAAA,EAAA,QAASO,GAAqC,CAC3DA,EAAU,SAAW,QACPzE,EAAA,KAAK6C,EAAgB4B,CAAS,CAAC,CAAA,GAEnCL,GAAA,MAAAA,EAAA,QAASjE,GAAqC,CACxDA,EAAU,SAAW,OACPH,EAAA,KAAK6C,EAAgB1C,CAAS,CAAC,CAAA,GAE3C0D,IAAU,KAAOW,EAAa,SAAW,EAC3C,OACS,GAAAX,IAAU,KAAO7D,EAAc,SAAW,EACnD,OAEE,IAAAkC,GACAnC,GAAA,YAAAA,EAAe,YAAa,SAEdmC,EAAAnC,EAAc,eAAiB,GAE/CmC,EAAgBiB,EAAoBC,CAAW,EAE7C,GAAA,CAyBK,OAxBK,MAAM3D,GAAQ,KAAK,GAAG7F,aAAyB,CACzD,OAAA9G,EACA,WAAA6Q,EACA,OAAAC,EACA,MAAAC,EACA,UAAAC,EACA,eAAA9C,EACA,OAAAc,EACA,cAAA9B,EACA,aAAAwE,EACA,SAAU,GACV,cAAAtC,EAEA,aAAAE,EACA,WAAAC,EACA,QAAAgC,CACF,EACA,CACE,QAAS,CAEP,gBAAgBxK,EAAA,2BAAQ,SAAR,YAAAA,EAAgB,eAChC,eAAgB,KAClB,CACF,CAAA,QAEOjO,GACP,QAAQ,MAAMA,CAAC,CACjB,CAAA,CAEJ,EC/Na8Y,GAAiC,IAAM,CAElD,MAAMhH,EADS,OAAO,SAAS,OACT,MAAM,CAAC,EAAE,MAAM,GAAG,EAClC5H,EAAM4H,EAAO,OACnB,QAASzP,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAA2P,EAAQF,EAAOzP,CAAC,EAClB,GAAA2P,GAAS,MAAQA,IAAU,GAAI,SAC7B,MAAA+G,EAAc/G,EAAM,MAAM,GAAG,EAC/B,GAAA,MAAM,QAAQ+G,CAAW,EAAG,CACxB,MAAA7a,EAAM6a,EAAY,CAAC,EACnB1T,EAAQ0T,EAAY,CAAC,EAC1B,OAAe,OAAO7a,CAAG,EAAImH,CAChC,CACF,CACF,ECIA2T,GAAera,kBAAgB,CAC7B,KAAM,iBACN,aAAc,GACd,MAAO,CACL,GAAGwO,EACL,EACA,MAAOvO,EAAO,CAEN,MAAAqa,EAAQtb,EAAAA,SAAS,KAAO,CAC5B,MAAOiB,EAAM,MACb,OAAQA,EAAM,OACd,gBAAiBA,EAAM,gBACvB,gBAAiByU,GAAazU,EAAM,gBAA2B,EAAI,EACnE,eAAgBA,EAAM,cACtB,EAAA,EACIsa,EAAQpK,MAAI,CAAC,EACbqK,EAASrK,MAAI,CAAC,EACdsK,EAAgBtK,MAAI,CAAC,EACrBuK,EAAiBvK,MAAI,CAAC,EACtBwK,EAAQxK,MAAI,EAAK,EACjBhI,EAAYgI,EAAAA,MACd,IAAAyK,EACJ,MAAMC,EAAW,IACR,IAAI,QAAeC,GAAY,CACpCvZ,EAAAA,SAAS,IAAM,CAETtB,EAAM,OAASA,EAAM,QACjBsa,EAAA,MAAQ,WAAWta,EAAM,KAAK,EAC7Bua,EAAA,MAAQ,WAAWva,EAAM,MAAM,IAEhCsa,EAAA,MAAQpS,EAAU,MAAM,YACvBqS,EAAA,MAAQrS,EAAU,MAAM,eAG7B,CAACsS,EAAc,OAAS,CAACC,EAAe,SAC5BD,EAAA,MAAQ,OAAO,OAAO,MACrBC,EAAA,MAAQ,OAAO,OAAO,QAE/BI,GAAA,CACT,CAAA,CACF,EAEGC,EAAa,IAAM,CACnBR,EAAM,OAASC,EAAO,OACxBrS,EAAU,MAAM,MAAM,MAAQ,GAAGoS,EAAM,UACvCpS,EAAU,MAAM,MAAM,OAAS,GAAGqS,EAAO,YAEzCrS,EAAU,MAAM,MAAM,MAAQ,GAAGsS,EAAc,UAC/CtS,EAAU,MAAM,MAAM,OAAS,GAAGuS,EAAe,UACnD,EAEIM,EAAc,IAAM,CAElB,MAAAC,EAAe,SAAS,KAAK,YAC7BC,EAAgB,SAAS,KAAK,aAE9BC,EAAYZ,EAAM,OAASE,EAAc,MACzCW,EAAaZ,EAAO,OAASE,EAAe,MAC5CW,EAAaJ,EAAeE,EAC5BG,EAAcJ,EAAgBE,EACpCjT,EAAU,QAAUA,EAAU,MAAM,MAAM,UAAY,SAASkT,MAAeC,KAAA,EAE1EC,EAAW,SAAY,CAC3B,MAAMV,EAAS,EACHG,GAAA,EAERQ,EAAuB,IAAM,CACjC,MAAMC,EAAmB,OAAO,iBACrBb,EAAA,IAAIa,EAAiBF,CAAQ,EAC/BX,EAAA,QAAQzS,EAAU,MAAO,CAChC,WAAY,GACZ,gBAAiB,CAAC,OAAO,EACzB,kBAAmB,EAAA,CACpB,CAAA,EAEGuT,EAAyB,IAAM,CAC/Bd,IACFA,EAAS,WAAW,EACpBA,EAAS,YAAY,EACVA,EAAA,KACb,EAEFhZ,OAAAA,EAAAA,UAAU,SAAY,CACpB+Y,EAAM,MAAQ,GACd,MAAME,EAAS,EACJE,IACCC,IACZ,OAAO,iBAAiB,SAAUW,GAAS,SAAAJ,EAAU,GAAG,CAAC,EACpCC,IACrBb,EAAM,MAAQ,EAAA,CACf,EACD9Y,EAAAA,YAAY,IAAM,CACT,OAAA,oBAAoB,SAAU0Z,CAAQ,EACtBG,GAAA,CACxB,EACM,CACL,MAAApB,EACA,UAAAnS,EACA,MAAAwS,CAAA,CAEJ,CACF,CAAC,QAtHwBnN,GAAY,CAAA,GAAA,sCACjBoO,GAAKnO,EAAAoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,sBACnB1O,qBAKM,MAAAC,GAAA,CAAAC,EAAA,OAAAC,EAAAA,YAJeH,EAAAA,mBAAA,MAAA,CAClB,IAAK,EAAA,MAAA,cAEN,MAAa2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,sFCLR,MAAA0O,GAAiBnO,uDAAsB,ECOvCoO,GAAiC,CAC5C,kBAAmB,GACnB,SAAU,SACV,MAAO,QACP,aAAc,CAAC,CACjB,EAGaC,GAA+BhO,EAA0B+N,EAAc,ECDpFE,GAAetc,kBAAgB,CAC7B,KAAM,qBACN,aAAc,GACd,MAAO,CACL,GAAGqc,EACL,EACA,MAAOpc,EAAO,CAAE,OAAAsc,GAAU,CACOpC,KAE/B,MAAMiC,EAAiBjM,EAAAA,MACjBqM,EAAW,IAAM,CACrBJ,EAAe,MAAM,aAAa,cAAenc,EAAM,KAAe,CAAA,EAElE/B,QAAA,IAAM+B,EAAM,MAAO,IAAM,CACpBuc,GAAA,CACV,EACD5a,EAAAA,UAAU,IAAM,CACL4a,GAAA,CACV,EACK,MAAA1J,EAAoB9T,EAAAA,SAAS,IAC1B2S,GAAmB1R,EAAM,iBAA2B,CAC5D,EACK8S,EAAW/T,EAAA,SAAS,IAAMiB,EAAM,QAAQ,EACxCwc,EAAQzd,EAAA,SAAS,IAAMiB,EAAM,KAAK,EAElCiQ,EAAeC,MAAY,EAAE,EAEnCuM,EAAAA,QAAQ1N,EAAe,CAErB,kBAAA8D,EAEA,SAAAC,EAEA,MAAA0J,EACA,aAAAvM,CAAA,CACD,EAGK,MAAAyM,MAAkB,IAClB3J,EAAkBzT,GACfod,EAAY,IAAIpd,CAAG,EAEtBqd,EAAiB,CAACrd,EAAamH,IAAe,CACtCiW,EAAA,IAAIpd,EAAKmH,CAAK,CAAA,EAE5BgW,EAAAA,QAAQzN,EAAc,CACpB,eAAA+D,EACA,eAAA4J,CAAA,CACD,EAGD,MAAM7M,EAAW8M,KACXC,MAAqB,IACrBC,EAAU,CAACxd,EAAaqQ,IAAkC,CAC1DkN,EAAe,IAAIvd,CAAG,GACxBwQ,EAAS,IAAIxQ,CAAG,EAETwQ,EAAA,GAAGxQ,EAAMyd,IAChBF,EAAe,IAAIvd,CAAG,EACf,OAAO,UAAU,SAAS,KAAKqQ,EAAOoN,CAAC,CAAC,IAAM,qBAAuBpN,EAAOoN,CAAC,EAAE,EACvF,EACDC,EAAAA,gBAAgB,IAAM,CACpBlN,EAAS,IAAIxQ,CAAG,CAAA,CACjB,CAAA,EAEG2d,EAAY3d,GAAQ,CACxBwQ,EAAS,IAAIxQ,CAAG,CAAA,EAEZ+Q,EAAY,CAAC/Q,EAAa4d,IAAsB,CAC3CpN,EAAA,KAAKxQ,EAAK4d,CAAS,CAAA,EAE9BT,EAAAA,QAAQ3N,GAAW,CACjB,QAAAgO,EACA,SAAAG,EACA,UAAA5M,CAAA,CACD,EAGK,MAAA8M,EAAWjN,MAAI,CAAC,EAChB8H,EAAe,IAAM,CAChBmF,EAAA,MAAQne,EAAAA,MAAMme,CAAQ,EAAI,CAAA,EAErCV,EAAAA,QAAQvN,GAAc,CACpB,aAAA8I,CAAA,CACD,EAEK,MAAAoF,MAAmB,IACnBC,MAAiB,IACjBC,EAAa,CAAC,CAAE,UAAAC,EAAY,IAAM,CAAI,EAAA,QAAAC,EAAU,EAAG,GAAA5N,EAAK,MAA4B,CACpF,GAAAwN,EAAa,IAAII,CAAO,EAAG,CACvB,MAAAC,EAAgBL,EAAa,IAAII,CAAO,EAC9CC,GAAA,MAAAA,EAAe,KAAKF,EAAS,MAE7BH,EAAa,IAAII,EAAS,CAACD,CAAS,CAAC,EAE5BF,EAAA,IAAIzN,EAAI2N,CAAS,CAAA,EAExBG,EAAuBD,GACpB,IAAI,QAAQ,CAAC5C,EAAS8C,IAAW,CACtC,MAAMC,EAAaH,EAAc,IAAIF,GAAaA,GAAW,EAC7D,QAAQ,IAAIK,CAAU,EACnB,KAAa3H,GAAA,CACZ4E,EAAQ5E,CAAI,CAAA,CACb,EACA,MAAapK,GAAA,CACZ8R,EAAO9R,CAAG,CAAA,CACX,CAAA,CACJ,EAGGgS,EAAiB,SAAY,OACjC,MAAM9J,EAAM,MAAMC,GAAM,IAAI,GAAG5E,mCAA+C,CAC5E,QAAS,CACP,WAAY,mCACZ,gBAAiB,KACnB,CAAA,CACD,EAIM,OAAA,gBAAiBC,EAAA0E,EAAI,KAAK,OAAT,YAAA1E,EAAe,KAAA,EAEnCyO,EAAe,MAAOlO,GAA2B,CAErD,GAAKA,GAqBL,GAAW,OAAOA,GAAO,SAAU,CAC3B,MAAA2N,EAAYF,EAAW,IAAIzN,CAAE,EAC/B,OAAO2N,GAAc,YACbA,GAEd,MA1BS,CACD,MAAAQ,EAAkB,MAAM,KAAKX,CAAY,EAE/BW,EAAA,KAAK,CAAC1b,EAAGO,IAAMA,EAAE,CAAC,EAAIP,EAAE,CAAC,CAAC,EAC1C,MAAMiJ,EAAMyS,EAAgB,OACxB,GAAA,CAGE/d,EAAM,WAAa,UAAYhB,EAAAA,MAAMme,CAAQ,EAAI,GACnD,MAAMU,EAAe,EAEvB,QAASpa,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CAC5B,MAAMga,EAAgBM,EAAgBta,CAAC,EAAE,CAAC,EAC1C,MAAMia,EAAoBD,CAAa,CACzC,QACOrc,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CAEAgc,EAAa,MAAM,CACrB,CAAA,CAMF,EAGFX,EAAAA,QAAQxN,GAAe,CACrB,WAAAqO,EACA,aAAAQ,CAAA,CACD,EAED,MAAME,EAAkB,IAAM,CAC5BlO,EAAS,KAAKX,EAAY,CAAA,EAE5BsN,EAAAA,QAAQtN,GAAc,CACpB,gBAAA6O,CAAA,CACD,EAGK,MAAAC,EAAiB3L,GAAuB,CAC5CxC,EAAS,GAAGX,GAAc,IAAMmD,EAAU,CAAA,EAC1C3Q,EAAAA,UAAU,IAAM,CACdmO,EAAS,IAAIX,EAAY,CAAA,CAC1B,CAAA,EAGH6N,OAAAA,EAAAA,gBAAgB,IAAM,CACpBI,GAAA,MAAAA,EAAc,QACdC,GAAA,MAAAA,EAAY,OAAM,CACnB,EAEMf,EAAA,CACL,aAAAwB,EACA,eAAA/K,EACA,cAAAkL,CAAA,CACD,EAEM,CACL,eAAA9B,CAAA,CAEJ,CACF,CAAC,EA1M6B5O,GAAC,CAAA,GAAA,gDAC3BoO,GAAanO,EAAAoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,4FCDJ,MAAAkC,GAAqBnQ,uBAA0B,ECsB/CoQ,GAAsB,CACjC,GAAGne,EACH,KAAM,KACN,QAAS,KACT,KAAM,WACN,MAAO,QACP,OAAQ,OACR,KAAM,KACN,MAAO,OACP,cAAe,OACf,SAAU,OACV,WAAY,GACZ,WAAY,IACZ,WAAY,GACZ,eAAgB,SAChB,WAAY,SACZ,iBAAkB,OAClB,KAAM,CAAC,EACP,qBAAsB,IACtB,OAAQ,GACR,OAAQ,OACR,KAAM,GACN,SAAU,EACZ,EAGaoe,GAAqBhQ,EAA0B+P,EAAS,EAExDE,GAAa,CAAC,cAAe,OAAO,ECpDlCC,GAAA,6cCAAC,GAAA,qyECwBfC,GAAeze,kBAAgB,CAC7B,KAAM,WACN,WAAY,CAAE,SAAA0e,EAAS,EACvB,MAAO,CACL,GAAGL,EACL,EACA,MAAOpe,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC0e,EAASxO,MAAI,CAAA,CAA0B,EACvCjS,QAAA,IAAM,CAAC+B,EAAM,KAAMA,EAAM,QAAQ,EAAG,CAAC,CAACuQ,EAAMoO,CAAQ,IAAM,CAC1DA,IAAa,WACfD,EAAO,MAAQnO,EACjB,EACC,CACD,UAAW,EAAA,CACZ,EACK,MAAAqO,EAAS7f,EAAAA,SAAS,IAAM,OACtB,MAAAwR,EAAOvR,QAAM0f,CAAM,EACzB,IAAIG,EAAO7e,EAAM,KACV6e,EAAAA,GAAA,YAAAA,EAAM,QAAQ,UAAW,SACzBA,EAAAA,GAAA,YAAAA,EAAM,QAAQ,MAAO,UACtB,MAAAhN,EAAagN,EAAM,MAAM,+BAA+B,EAC1D,GAAAhN,GAAa,MAAQA,EAAU,SAAW,EAAU,OAAAgN,EACxD,QAASpb,EAAI,EAAGA,EAAIoO,EAAU,OAAQpO,IAAK,CACnC,MAAAqO,EAAWD,EAAUpO,CAAC,EACtBH,GAAI+L,EAAAyC,GAAA,YAAAA,EAAU,MAAM,EAAGA,EAAS,OAAS,KAArC,YAAAzC,EAAyC,OAC/C,IAAA+C,EAAe7B,EAAKjN,CAAC,EAEzB,GAAI8O,GAAgB,KAAM,CAExB,MAAM7N,EAASvE,EAAM,OACjBuE,IAAW,cAEb6N,EAAe,CAACA,EACX,MAAMA,CAAY,EAWdyM,EAAAA,EAAK,QAAQ/M,EAAU,sBAAsB9R,EAAM,2BAA2BA,EAAM,qBAAqB,WAAc,GAV9GoS,GAAAA,EAAe,KAAK,QAAQ,CAAC,EAEzCA,GAAgB,EACXyM,EAAAA,EAAK,QAAQ/M,EAAU,wCAAwC9R,EAAM,wCAAwCA,EAAM,0BAA0Bse,QAAUlM,WAAsB,EAGpLyM,EAAOA,EAAK,QAAQ/M,EAAU,yCAAyC9R,EAAM,wCAAwCA,EAAM,0BAA0Bue,QAAY,KAAK,IAAInM,CAAY,WAAW,IAM5L7N,IAAW,WAGpB6N,EAAe,CAACA,EACX,MAAMA,CAAY,IACLA,GAAAA,EAAe,KAAK,QAAQ,CAAC,EACtCyM,EAAAA,EAAK,QAAQ/M,EAAU,sBAAsB9R,EAAM,2BAA2BA,EAAM,qBAAqBoS,WAAsB,IAE/HpS,EAAM,SAAW,SAE1BoS,EAAe,CAACA,EACX,MAAMA,CAAY,IACrBA,EAAelB,GAAYkB,CAAY,EAChCyM,EAAAA,EAAK,QAAQ/M,EAAU,sBAAsB9R,EAAM,2BAA2BA,EAAM,qBAAqBoS,UAAqB,IAIhIyM,EAAAA,EAAK,QAAQ/M,EAAU,sBAAsB9R,EAAM,2BAA2BA,EAAM,qBAAqBoS,UAAqB,CACvI,MAGAyM,EAAOA,EAAK,QAAQ/M,EAAU9R,EAAM,oBAA8B,CAEtE,CACA,MAAO,SAAS6e,UAAA,CACjB,EACK,CAAE,SAAA/L,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EACKkE,EAAcZ,GAAerS,CAAK,EAClCtB,EAAUwR,MAAI,EAAK,EACnB4O,EAAoB,SAAY,OAChC,GAAA9f,EAAA,MAAM8T,CAAQ,IAAM,SACpB,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClByL,EAAO,QAAQrP,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAQ,CAAA,QAC3BjO,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAEIqgB,EAAc,IAAM,CACpB/e,EAAM,WAAa,UACL8e,GAAA,EAGpBpP,GAAW1P,EAAO,CAChB,YAAA+e,CAAA,CACD,EAED,KAAM,CAAE,WAAAzB,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EAEUD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW+e,EACX,QAAS/e,EAAM,WAAA,CAChB,EACD0P,GAAW1P,EAAO,CAChB,YAAA+e,CAAA,CACD,EAIK,MAAAC,EAFYjP,GAAa/P,CAAK,EAEZ,QAAS,IAAM,CAErC,GAAI,CAACA,EAAM,UAAY,CAACA,EAAM,KAAM,OAC9B,MAAAif,EAAYjf,EAAM,UAAY,GAC9Bkf,EAAUrK,GAAW7V,EAAAA,MAAM8T,CAAQ,EAAGmM,CAAQ,EAE9CE,EAAOnf,EAAM,KACnB,IAAIgT,EAAMmM,GAAQD,EAClBlM,EAAMtB,GAAmBsB,CAAG,EAC5B,MAAM3K,EAASrI,EAAM,OACjBqI,GAAU,MAAQA,IAAW,KAC7BA,IAAW,QACN,OAAA,KAAK2K,EAAK,IAAO3K,CAAiB,EAEzC,OAAO,OAAO,YAAY,CACxB,KAAM,WACN,IAAK8W,GACJ,GAAG,EACR,CACD,EAEM,MAAA,CACL,MAAA9E,EACA,OAAAuE,EACA,QAAAlgB,EACA,MAAAsgB,CAAA,CAEJ,CACF,CAAC,kDAvK2D,MAAAI,EAAA/R,mBAAA,UAAA,kCAA7BC,EAAAA,mBAAA,MAAA,CAAE,IAAK,EAAA,MAAA,mBAClC,MAA8B2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAEhC4R,EAA6E,CAAA,QAAA5R,EAAA,OAAA,EAAA,KAAA,EAAA,CAAA,SAAA,CAAA,CAAA,EAAA,CAAA,IAAAC,EAAAA,YAAvDH,EAAAA,mBAAA,MAAA,CAAE,IAAK,EAAS,MAAA,YAAiB,MAAK2O,EAAAA,eAAAzO,EAAA,KAAA,EAAA,UAAAA,EAAA,yECFjD,MAAA6R,GAAWtR,uDAAgB,ECMxCuR,GAAevf,kBAAgB,CAC7B,KAAM,iBACN,OAAS,CAEA,MAAA,CACL,KAFWmQ,MAAI,MAAM,CAErB,CAEJ,CACF,CAAC,kICdY,MAAAqP,GAAiBxR,uDAAsB,ECevCyR,GAAqC,CAChD,GAAGxf,EACH,KAAM,OACN,QAAS,OACT,KAAM,kBACN,OAAQ,2BACR,SAAU,OACV,MAAO,OACP,MAAO,QACP,OAAQ,OACR,UAAW,SACX,WAAY,GACZ,WAAY,IACZ,WAAY,GACZ,cAAe,QACjB,EAEayf,GAA4BrR,EAA0BoR,EAAgB,ECvBnFE,GAAe3f,kBAAgB,CAC7B,KAAM,kBACN,MAAO,CACL,GAAG0f,EACL,EACA,MAAOzf,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC2f,EAAOzP,EAAAA,IAAI0P,GAAA,EAAQ,OAAO5f,EAAM,MAAgB,CAAC,EACvD,IAAI6f,EAAQ,KACZ,MAAMC,EAAa,IAAM,CACvB,cAAcD,CAAK,EACXA,EAAA,IAAA,EAEJE,EAAW,IAAM,CACjBF,GACSC,IAEbD,EAAQ,YAAY,IAAM,CACnBF,EAAA,MAAQC,GAAQ,EAAA,IAAI,EAAG,GAAG,EAAE,OAAO5f,EAAM,MAAgB,GAC7D,GAAI,CAAA,EAET2B,OAAAA,EAAAA,UAAU,IAAM,CACLoe,GAAA,CACV,EACDne,EAAAA,YAAY,IAAM,CACLke,GAAA,CACZ,EACM,CACL,MAAAzF,EACA,KAAAsF,CAAA,CAEJ,CACF,CAAC,QA1CW,SAAAhE,GAACnO,EAAcoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,QAAOvO,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,6ECC5B,MAAA0S,GAAkBjS,uDAAuB,ECiBzCkS,GAAsB,CACjC,GAAGjgB,EACH,KAAM,WACN,KAAM,KACN,QAAS,KACT,MAAO,QACP,OAAQ,OACR,gBAAiB,UACjB,YAAa,OACb,YAAa,OACb,WAAY,GACZ,SAAU,GACV,WAAY,EACZ,YAAa,EACb,WAAY,OACZ,KAAM,CACJ,CACE,KAAM,IACN,IAAK,EACP,EACA,CACE,KAAM,IACN,IAAK,EACP,CACF,EACA,QAAS,CACP,CACE,IAAK,MACP,EACA,CACE,IAAK,KACP,CACF,CACF,EAEakgB,GAAqB9R,EAA0B6R,EAAS,EAOxDE,GAAsC,CAAC,cAAe,OAAO,EC4B1EC,GAAergB,kBAAgB,CAC7B,KAAM,WACN,WAAY,CAAE,SAAA0e,EAAS,EACvB,MAAO,CACL,GAAGyB,EACL,EACA,MAAOlgB,EAAO,CACN,MAAAqgB,EAAanQ,EAAAA,IAA4BlQ,EAAM,IAA8B,EAC7Eqa,EAAQ5L,EAAsBzO,EAAO,CAAC,iBAAiB,CAAC,EACxDsgB,EAAcvhB,EAAAA,SAAS,IACvBiB,EAAM,WACD,CACL,UAAW,QAAA,EAGN,CACL,UAAW,MAAA,CAGhB,EAEKugB,EAAW,CAAC9Z,EAAwBlC,IACpCA,GAAU,MAAQA,IAAW,GAAWkC,EAChC,CACV,MAAOyK,GACP,WAAYG,GACZ,SAAUA,EAAA,EAED9M,CAAM,EAAEkC,CAAK,GAAK,GAEzB+Z,EAAgB,CAAC/Z,EAAwBlC,IAAmB,CAC1D,MAAA6M,EAAS,WAAW3K,EAAQ,EAAE,EACpC,GAAIlC,IAAW,WACN,MAAA,GAET,OAAQ,GAAM,CACZ,KAAK6M,GAAU,EACN,MAAA,OACT,KAAKA,EAAS,EACL,MAAA,QACX,CAAA,EAEI6B,EAAcZ,GAAerS,CAAK,EAClC,CAAE,SAAA8S,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EACKrQ,EAAUwR,MAAI,EAAK,EACnB4O,EAAoB,SAAY,OACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UAEpD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClBoN,EAAW,QAAQhR,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,KAAK,OAAQ,SACpCjO,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAGIqgB,EAAc,IAAM,CACND,GAAA,EAKdE,EAFYjP,GAAa/P,CAAK,EAEZ,QAAS,IAAM,CAAA,CAAE,EAEzC0P,GAAW1P,EAAO,CAChB,YAAA+e,CAAA,CACa,EAEf,KAAM,CAAE,WAAAzB,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EACU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW8e,EACX,QAAS9e,EAAM,WAAA,CAChB,EACM,CACL,MAAAqa,EACA,SAAAkG,EACA,YAAAD,EACA,cAAAE,EACA,WAAAH,EACA,QAAA3hB,EACA,MAAAsgB,CAAA,CAEJ,CACF,CAAC,8EAlLOzR,GAAa,CAAA,IAAA,iBAcNkT,GAAe,CAAA,IAAA,mBAcnBC,GAAM,CAAA,IAAA,6BAqBFC,GAAe,CAAA,IAAA,mGAqBnBC,GAAa,CAAA,IAAA,kDAzEtBvT,mBA6EM,UAAA,SA7EuBI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,YAClC,MA2EW2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAxED4R,EAAQ,CAAA,QAAA5R,EAAA,OAAA,EAAA,CAFhB,QAAAqT,EAAA,QAAA,IAAA,CAAArT,EAAA,UAAAC,EAAA,UAAA,EAAAH,EAAAA,mBAIE,MAuBMC,GAAA,EAAAE,YAtBE,EAAa,EAAAH,EAAAA,mBAAAwT,EAAA,SAAA,KAAAC,EAAAA,WAAAvT,EAAA,YAAAwT,IACbvT,EAAA,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,oBAAwE2O,EAAAA,eAAU,CAAqC,gBAAAzO,EAAA,gBAAiG,OAAAA,EAAA,WAAA,MAAA,eAAAA,EAAA,iBAAAA,EAAA,kBAAAA,EAAA,YAAA,MAAAA,EAAA,2BAOxNwT,EAAKxT,EAAA,cAAA,EAAAA,EAAA,YAAA,EAAA,CAAA,EAEgB,IAAAwT,CAAA,EAAA,CAC3BxT,EAAA,YAAAC,EAAA,UAAA,EAAAH,EAAA,mBAUM,MAVNmT,EAAA,GAAAQ,EAAAA,mBAAA,GAAA,EAAA,GAAAxT,EAAAA,UACQ,EAAQ,EAAAH,EAAA,mBAAAwT,WAAA,KAAAC,EAAA,WAAAvT,EAAA,QAAA,CAAA0T,EAAAzd,KAERgK,EAAA,UAAA,EAAeH,EAAA,mBAAA,MAAA,CACpB,MAAK,SAAyB,IAAM4T,EAAC,KAAUzd,EAAmB,MAAWwY,EAAAA,eAAA,CAAA,MAAAiF,EAAA,iFASpF,GAAAD,EAAAA,mBAAA,GAAA,EAAA,EAMUzT,EAAA,WAAA,OAAQ,sCALhB,MAMEkT,GAAA,CAAAlT,EAAA,UAAAC,EAAAA,YALyBH,EAAAA,mBAAA,MAAA,CACxB,IAAK,EAA8B,MAAA,oBAAA,MAAA2O,EAAAA,eAAA,6BAKtC,EAAA,KAAA,CAAA,GAAAgF,EAAAA,mBAAA,GAAA,EAAA,GAAAxT,EAAA,UACQ,EAAM,EAAAH,EAAAA,mBAAAwT,EAAAA,SAAA,KAAAC,EAAAA,WAAAvT,EAAA,WAAA,MAAA,EAAAA,EAAA,UAAA,EAAA,CAAAmD,EAAA,KACNlD,EAAA,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,aAAsE2O,EAAAA,eAAU,CAAoC,gBAAAzO,EAAA,gBAAA,OAAAA,EAAA,gCAA4KA,EAAW,iBAAAA,EAAA,kBAAAA,EAAA,YAAA,OAAAA,EAAA,eAAA,aAAA,EAAA,GAAAA,EAAA,cAAA,EAAAA,EAAA,YAAA,gBAQ3SA,EAAO,WAAA,CAAA,sBAGcoO,EAAU,CAAA,IAAAA,EAAA,CAAA,EAAA,IAAAle,IAAA8P,EAAA,OAAAA,EAAA,MAAA,GAAA9P,CAAA,EAAA,EAAA,CACnC8P,EAAA,YAAAC,EAAA,UAAA,6BACkBkT,GACZ,CAAAQ,kEAGR,CAAA,GAAAF,EAAAA,mBAAA,GAAA,EAAA,GAAAxT,YACQ,EAAa,EAAAH,EAAAA,mBAAAwT,EAAA,SAAA,KAAaC,EAAAA,WAAYvT,EAAI,QAAgB0T,IAE1DzT,EAAU,UAAA,EAAAH,EAAA,mBAAA,MAAA,CACf,MAAK8T,EAAA,eAAA,CAAA,SAAA5T,EAAA,cAAAmD,EAAAuQ,EAAA,GAAA,EAAAA,EAAA,MAAA,CAAA,CAAA,EAAA,IAA4BA,EAAO,IAAgC,MAAkBjF,EAAAA,eAAA,CAAmF,SAAAiF,EAAA,SAAA,MAAoC1T,EAAW,cAAAmD,EAAAuQ,EAAA,GAAA,EAAAA,EAAA,MAAA,IAAA,GAAAA,EAAA,MAAA,GAAA,WAAAA,EAAA,6NC7D5N,MAAAG,GAAWtT,uDAAgB,ECqB3BuT,GAAmC,CAC9C,GAAGthB,EACH,KAAM,MACN,QAAS,MACT,KAAM,iBACN,WAAY,SACZ,MAAO,QACP,OAAQ,QACR,YAAa,UACb,cAAe,QACf,WAAY,UACZ,KAAM,CACJ,QAAS,EACX,EACA,KAAM,aACN,SAAU,OACV,MAAO,UACP,YAAa,EACb,WAAY,IACZ,gBAAiB,OACjB,WAAY,OACZ,cAAe,GACf,qBAAsB,GACxB,EAEauhB,GAA2BnT,EAA0BkT,EAAe,EAEpEE,GAAmB,CAAC,cAAe,OAAO,ECRvDC,GAAe1hB,kBAAgB,CAC7B,KAAM,iBACN,WAAY,CAAA,UACV2hB,EAAA,SACA,SAAAjD,EACF,EACA,MAAO,CACL,GAAG8C,EACL,EACA,MAAOvhB,EAAO,CACZ,KAAM,CAAE,SAAA8S,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EACKsL,EAAQ5L,EAAsBzO,CAAK,EACnC2hB,EAAU5iB,EAAAA,SAAS,IAAM,CAC7B,MAAMub,EAAQta,EAAM,MACpB,OAAO,WAAWsa,CAAK,CAAA,CACxB,EACKoE,EAASxO,MAA2B,CAAA,CAAE,EACtCjS,QAAA,IAAM+B,EAAM,KAAM,IAAM,EACxBA,EAAM,WAAa,UAAYhB,EAAAA,MAAM8T,CAAQ,IAAM,YACrD4L,EAAO,MAAQ1e,EAAM,KACvB,EACC,CACD,UAAW,GACX,KAAM,EAAA,CACP,EACK,MAAA4hB,EAAU7iB,EAAAA,SAAS,IAAM,CACvB,MAAAwR,EAAOvR,QAAM0f,CAAM,EACnBmD,EAAe,CAAE7hB,EAAM,qBAC7B,GAAIuQ,GAAQ,KACN,OAAC,MAAMsR,CAAY,EAGd,EAFAA,EAKX,MAAMhQ,EAAa7R,EAAM,KAAgB,MAAM,SAAS,GAAK,GACzD,IAAAyG,EACJ,MAAMqb,EAAW,IAAI,IAAI,OAAO,KAAKvR,CAAI,CAAC,EAC1C,QAAS9M,EAAI,EAAGA,EAAIoO,EAAU,OAAQpO,IAAK,CACnC,MAAAqO,EAAWD,EAAUpO,CAAC,EACtBnE,EAAMwS,EAAS,MAAM,EAAGA,EAAS,OAAS,CAAC,EAC7C,GAAAgQ,EAAS,IAAIxiB,CAAG,EAAG,CACrBmH,EAAQ8J,EAAKjR,CAAG,EAChB,KACF,CACF,CAEI,OAAA,OAAOmH,GAAU,SACnBA,EAAQA,EAAQ,IACP,OAAOA,GAAU,UAAY,CAAC,MAAM,CAACA,CAAK,EACnDA,EAAS,CAACA,EAAS,IACT,MAAMob,CAAY,EAGpBpb,EAAA,EAFRA,EAAQob,EAAe,IAKrB7hB,EAAM,gBACAyG,EAAA,CAACA,EAAM,QAAQ,CAAC,GAEnBA,CAAA,CACR,EACKoY,EAAO9f,EAAAA,SAAS,IAAM,OAC1B,IAAI8f,EAAO7e,EAAM,KACjB,GAAI6e,IAAS,GAAI,OAAO7f,EAAAA,MAAM4iB,CAAO,EACrC,MAAMC,EAAe7hB,EAAM,qBACrBuQ,EAAOvR,QAAM0f,CAAM,EACnB7M,EAAagN,EAAM,MAAM,SAAS,GAAK,CAAA,EAC7C,QAASpb,EAAI,EAAGA,EAAIoO,EAAU,OAAQpO,IAAK,CACnC,MAAAqO,EAAWD,EAAUpO,CAAC,EAC5B,IAAIsO,EAAYD,EAAS,MAAM,EAAGA,EAAS,OAAS,CAAC,EAC/C,MAAAG,EAAgBF,EAAU,MAAM,KAAK,EAC3C,QAASG,EAAI,EAAGA,GAAID,GAAA,YAAAA,EAAe,QAAQC,IAAK,CAC9C,MAAMC,GAAe9C,EAAA4C,EAAcxO,CAAC,IAAf,YAAA4L,EAAkB,OACnCkB,EAAK4B,CAAY,GAAK,KACxBJ,EAAYA,EAAU,QAAQI,EAAc5B,EAAK4B,CAAY,CAAC,EAElDJ,EAAAA,EAAU,QAAQI,EAAc0P,CAAY,CAE5D,CAEA,IAAIzP,EAA+BL,EAE/B,GAAA,CACG,mBAAoB,KAAKA,CAAS,IAGrCK,KADc,MACOL,CAAS,SAEzB3Q,GACP,QAAQ,MAAMA,CAAC,CACjB,EACI,OAAOgR,GAAiB,UAAY,CAAC,MAAM,CAACA,CAAY,KAC1DA,EAAgB,CAACA,EAAe,IAC5BpS,EAAM,gBACOoS,EAAAA,EAAa,QAAQ,CAAC,IAGzCyM,EAAOA,EAAK,QAAQ/M,EAAUM,EAAe,EAAE,CACjD,CACOyM,OAAAA,CAAA,CACR,EACK5L,EAAcZ,GAAerS,CAAK,EAClCtB,EAAUwR,MAAI,EAAK,EACnB4O,EAAoB,SAAY,OACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UACpD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClByL,EAAO,QAAQrP,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAQ,CAAA,QAC3BjO,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAKFgR,GAAW1P,EAAO,CAChB,YAJkB,IAAM,CACN8e,GAAA,CAGlB,CACD,EAIK,MAAAE,EAFYjP,GAAa/P,CAAK,EAEZ,QAAS,IAAM,CAAA,CAAE,EAEnC,CAAE,WAAAsd,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EAEU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW8e,EACX,QAAS9e,EAAM,WAAA,CAChB,EAEM,CACL,MAAAqa,EACA,QAAAsH,EACA,KAAA9C,EACA,QAAA+C,EACA,QAAAljB,EACA,MAAAsgB,CAAA,CAEJ,CACF,CAAC,0EA/LC3R,mBA6BM,YAAA,SA7B6BI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,kBACxC,MA2Ba2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAzBDuU,EAAO,CAChB,MAAO,WACP,QAAMvU,EAAA,QACN,MAAWA,EAAA,QACX,KAAAA,EAAA,WACA,YAAYA,EAAA,YACZ,cAAaA,EAAA,cACb,WAAWA,EAAA,WACX,YAAOA,EAAA,YAAA,UAAAA,EAAA,aAAA,YAAA,GAAA,EAEG,QAAMA,EAAA,KAAA,EAAA,CACf,OAAAqT,EAAA,QAAA,IAAA,CAAArT,EAAA,SAAAC,EAAAA,YAA0CC,EAAAA,YAAA0R,EAAA,CAAA,IAAA,EAC1C,QAAA5R,EAAA,OAAA,EAAA,KAAA,EAAA,CAAA,SAAA,CAAA,IAAAC,YAEgB,EAAAH,EAAA,mBAAA,MAAA,CACb,IAAK,EAAuB,MAAA,SAAqC,MAAA2O,EAAAA,eAAA,CAAc,MAAAzO,EAAA,gBAAmB,SAAAA,EAAA,SAAwB,MAAAA,EAAA,MAAA,WAAAA,EAAA,4LCjBxH,MAAAwU,GAAiBjU,uDAAsB,ECSvCkU,GAAyB,CACpC,GAAGjiB,EACH,MAAO,QACP,GAAI,GACJ,KAAM,MACN,IAAK,MACL,KAAM,MACN,QAAS,MACT,OAAQ,GACR,KAAM,YACN,MAAO,GACP,YAAa,OACf,EAGakiB,GAAsB9T,EAA0B6T,EAAU,EAE1DE,GAAc,CAAC,cAAe,WAAW,ECLtDC,GAAeriB,kBAAgB,CAC7B,KAAM,YACN,WAAY,CAAA,OACVsiB,EAAA,KACF,EACA,MAAO,CACL,GAAGH,EACL,EACA,MAAOliB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC4hB,EAAU1R,MAAY,EAAE,EAC9BjS,EAAAA,MAAM,IAAM+B,EAAM,MAAQyG,GAAkB,CAC1Cmb,EAAQ,MAAQnb,CAAA,EACf,CACD,UAAW,EAAA,CACZ,EACD,MAAMmJ,EAAK5P,EAAM,GACX,CAAE,eAAA+S,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEDkW,EAAe3c,EAAM,GAAc,CACjC,KAAMA,EAAM,KACZ,MAAO4hB,CAAA,CACR,EACD,MAAMU,EAAuB,IAAM,CAC3B,MAAAC,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQX,EAAS,CAAA,EAG5CvR,EAAYN,GAAa/P,CAAK,EAC9BwiB,EAAc9G,GAAAA,SAASrL,EAAU,cAAe,IAAM,CACrCiS,GAAA,CACtB,EAAG,GAAG,EACDG,EAAYpS,EAAU,YAAa,IAAM,CAAA,CAC9C,EACM,MAAA,CACL,MAAAgK,EACA,QAAAuH,EACA,UAAAa,EACA,YAAAD,CAAA,CAEJ,CACF,CAAC,yCAvECnV,mBAWM,SAAA,SATEI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,aAEX,MAME2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAJekV,EAAO,CAAA,MAAA,QACrB,MAAWlV,EAAA,QACX,iBAAQoO,EAAW,CAAA,IAAAA,EAAA,CAAA,EAAA+G,GAAAnV,EAAA,QAAAmV,GACnB,YAAMnV,EAAA,YAAA,SAAAA,EAAA,wFCRF,MAAAoV,GAAY7U,uBAAiB,ECY7B8U,GAAmC,CAC9C,GAAG7iB,EACH,OAAQ,OACR,MAAO,QACP,GAAI,GACJ,KAAM,MACN,IAAK,MACL,KAAM,QACN,QAAS,QACT,OAAQ,GACR,KAAM,iBACN,MAAO,GACP,OAAQ,OACR,OAAQ,aACR,SAAU,GACV,eAAgB,EAClB,EACa8iB,GAA2B1U,EAA0ByU,EAAe,EAEpEE,GAAmB,CAAC,YAAY,ECJ7CC,GAAejjB,kBAAgB,CAC7B,KAAM,iBACN,MAAO,CACL,GAAG+iB,EACL,EACA,WAAY,CAAA,YACVG,EAAA,UACF,EACA,MAAOjjB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCkjB,EAAoB,IAAM,SAAS,eAAe,gBAAgB,GAAK,SAAS,KAChFtB,EAAU1R,MAAkB,IAAI,EAChCjS,QAAA,IAAM,CAAC+B,EAAM,MAAOA,EAAM,cAAc,EAAG,CAAC,CAACyG,EAAO0c,CAAc,IAAyB,CAC/F,IAAI/R,EAAgB,KAChB3K,EACF2K,EAASwO,GAAMnZ,CAAK,EACX0c,IACT/R,EAASwO,GAAM,GAEjBgC,EAAQ,MAAQxQ,CAAA,EACf,CACD,UAAW,EAAA,CACZ,EACD,KAAM,CAAE,eAAAuL,CAAA,EAAmB9d,EAAA,OAAOmQ,EAAc,CAG9C,eAAgB,CAAC1P,EAAamH,IAAe,EAAA,CAC9C,EAEDkW,EAAe3c,EAAM,GAAc,CACjC,KAAMA,EAAM,KACZ,OAAQA,EAAM,OACd,MAAO4hB,CAAA,CACR,EAGK,MAAAwB,EADYrT,GAAa/P,CAAK,EACP,aAAc,IAAM,CAAA,CAChD,EAED,OAAA0P,GAAW1P,EAAO,CAChB,WAAAojB,CAAA,CACD,EACM,CACL,MAAA/I,EACA,kBAAA6I,EACA,QAAAtB,EACA,OAAAyB,GACA,WAAAD,CAAA,CAEJ,CACF,CAAC,yCA9EC/V,mBAgBM,eAAA,SAdEI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,mBAGb,MAUE2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eARA8V,EAAkB,CACV,MAAO,cAAA,kBAAA,4BACd,MAAM9V,EAAE,QACR,iBAAQoO,EAAM,CAAA,IAAAA,EAAA,CAAA,EAAA+G,GAAAnV,EAAA,QAAAmV,GACd,OAAQnV,EAAE,OACV,OAAQA,EAAA,OACR,SAAQA,EAAA,SACR,OAAAA,EAAA,OAAA,SAAAA,EAAA,6ICbM,MAAA+V,GAAiBxV,uBAAsB,ECsBvCyV,GAA2B,CACtC,GAAGxjB,EACH,KAAM,MACN,QAAS,MACT,MAAO,QACP,OAAQ,OACR,KAAM,aACN,KAAM,OACN,KAAM,CACJ,CAAE,MAAO,MAAO,MAAO,GAAI,EAC3B,CAAE,MAAO,MAAO,MAAO,GAAI,EAC3B,CAAE,MAAO,MAAO,MAAO,GAAI,CAC7B,EACA,MAAO,GACP,eAAgB,CAAE,MAAO,QAAS,MAAO,OAAQ,EACjD,YAAa,MACf,EAEayjB,GAAuBrV,EAA0BoV,EAAW,EAE5DE,GAAe,CAAC,cAAc,ECf3CC,GAAe5jB,kBAAgB,CAC7B,KAAM,aACN,WAAY,CAAA,QACV6jB,EAAA,MACF,EACA,MAAO,CACL,GAAGH,EACL,EACA,MAAOzjB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EAEnCkjB,EAAoB,IAAM,SAAS,eAAe,gBAAgB,GAAK,SAAS,KAChFjQ,EAAcZ,GAAerS,CAAK,EAClC,CAAE,SAAA8S,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EACK/G,EAAUkI,EAAAA,IAAIlQ,EAAM,IAAqB,EACzC4hB,EAAU1R,EAAI,IAAAlQ,EAAM,OAASA,EAAM,KAAK,CAAC,CAAC,EAC1CwQ,EAAiBxQ,EAAM,eACvB6jB,EAAe,CAACC,EAAehjB,IAAgB,CACnD,MAAMijB,EAAWvT,EAAe,MAC1BwT,EAAWxT,EAAe,MAC5B,IAAA/J,EAGE,MAAAwd,EAAanjB,EAAOijB,CAAQ,EAC5BG,EAAapjB,EAAOkjB,CAAQ,EAClC,OAAIC,GAAc,KACRxd,EAAAwd,EACCC,GAAc,OACfzd,EAAAyd,IAEAzd,GAAA,YAAAA,EAAO,cAAc,QAAQqd,GAAA,YAAAA,EAAO,iBAAkB,CAAA,EAE5DplB,EAAUwR,MAAI,EAAK,EACnB4O,EAAoB,SAAY,SACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UACxD,CAAApU,EAAQ,MAAQ,GACZ,GAAA,CACI,MAAAqV,EAAM,MAAMd,IAClBjL,EAAQ,QAAQsH,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,OAAQ,GACzC,MAAM6U,EAAcnlB,EAAA,MAAMgJ,CAAO,EAAE,CAAC,EAChChI,EAAM,QAAU,IAAMmkB,GAAe,OAC/BvC,EAAA,MAAQuC,EAAY3T,EAAe,KAAK,SAE3CpP,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,EAAA,EAEI,CAAE,eAAAqU,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEDkW,EAAe3c,EAAM,GAAc,CACjC,KAAMA,EAAM,KACZ,MAAO4hB,CAAA,CACR,EAGK,MAAAwC,EADYrU,GAAa/P,CAAK,EACL,eAAgB,IAAM,CACnD,MAAM4P,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQX,EAAS,CAAA,CACjD,EAEDlS,GAAW1P,EAAO,CAChB,aAAAokB,CAAA,CACD,EACD,KAAM,CAAE,WAAA9G,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EACU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW8e,EACX,QAAS9e,EAAM,WAAA,CAChB,EACM,CACL,MAAAqa,EACA,kBAAA6I,EACA,QAAAtB,EACA,aAAAwC,EACA,QAAApc,EACA,aAAA6b,EACA,QAAAnlB,CAAA,CAEJ,CACF,CAAC,+CA5HC2O,mBAiBM,UAAA,SAfEI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,cAEb,MAYE2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAVe6W,EAAO,CAAA,MAAA,SACrB,MAAO7W,EAAE,QACT,iBAAUoO,EAAA,CAAA,IAAAA,EAAA,CAAA,EAAA+G,GAAAnV,EAAA,QAAAmV,GACV,QAAAnV,EAAA,QACA,KAAAA,EAAA,KACA,kBAAaA,EAAA,kBACd,cAAWA,EAAA,eACV,YAAeA,EAAA,YACf,cAAQ,GACR,gBAASA,EAAO,aAAA,SAAAA,EAAA,4JCdV,MAAA8W,GAAavW,uDAAkB,ECW/BwW,GAAqC,CAChD,GAAGvkB,EACH,KAAM,QACN,QAAS,QACT,KAAM,kBACN,MAAO,QACP,OAAQ,OACR,OAAQ,OACR,OAAQ,aACR,UAAW,GACX,QAAS,GACT,eAAgB,GAChB,SAAU,EACV,aAAc,MAChB,EAEawkB,GAA4BpW,EAA0BmW,EAAgB,EAEtEE,GAAoB,CAAC,YAAY,ECH9CC,GAAe3kB,kBAAgB,CAC7B,KAAM,kBACN,WAAY,CAAA,aACV4kB,EAAA,WACF,EACA,MAAO,CACL,GAAGH,EACL,EACA,MAAOxkB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCkjB,EAAoB,IAAM,SAAS,eAAe,gBAAgB,GAAK,SAAS,KAChFtB,EAAU1R,EAAA,IAAoB,CAAC,KAAM,IAAI,CAAC,EAC1CjS,QAAA,IAAM,CAAC+B,EAAM,UAAWA,EAAM,QAASA,EAAM,eAAgBA,EAAM,SAAUA,EAAM,YAAY,EAAG,CAAC,CAAC4kB,EAAWC,EAAS1B,EAAgB2B,EAAUC,CAAY,IAAyD,CAC3N,IAAIC,EAAoB,KACpBC,EAAkB,KAClB9B,IACF6B,EAAapF,GAAM,EAAE,SAASkF,EAAUC,CAAY,EACpDE,EAAWrF,GAAM,GAEfgF,IACFI,EAAapF,GAAMgF,CAAS,GAE1BC,IACFI,EAAWrF,GAAMiF,CAAO,GAElBjD,EAAA,MAAQ,CAACoD,EAAYC,CAAQ,CAAA,EACpC,CACD,UAAW,EAAA,CACZ,EACD,KAAM,CAAE,eAAAtI,CAAA,EAAmB9d,EAAA,OAAOmQ,EAAc,CAG9C,eAAgB,CAAC1P,EAAamH,IAAe,EAAA,CAC9C,EACKye,EAAcnmB,EAAAA,SAAS,IAAMC,EAAAA,MAAM4iB,CAAO,EAAE,CAAC,CAAC,EAC9CuD,EAAYpmB,EAAAA,SAAS,IAAMC,EAAAA,MAAM4iB,CAAO,EAAE,CAAC,CAAC,EAElDjF,EAAe3c,EAAM,GAAc,CACjC,KAAMA,EAAM,KACZ,OAAQA,EAAM,OACd,UAAWklB,EACX,QAASC,CAAA,CACV,EAGK,MAAA/B,EADYrT,GAAa/P,CAAK,EACP,aAAc,IAAM,CAAA,CAAE,EACnD,OAAA0P,GAAW1P,EAAO,CAChB,WAAAojB,CAAA,CACD,EACM,CACL,MAAA/I,EACA,kBAAA6I,EACA,OAAAG,GACA,WAAAD,EACA,QAAAxB,CAAA,CAEJ,CACF,CAAC,+CApFCvU,mBAcM,gBAAA,SAZEI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,oBAEb,MASE2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAPA4X,EAAkB,CACV,MAAO,eAAA,kBAAA,6BACd,MAAM5X,EAAE,QACR,iBAAQoO,EAAM,CAAA,IAAAA,EAAA,CAAA,EAAA+G,GAAAnV,EAAA,QAAAmV,GACd,OAAQnV,EAAA,OACR,OAAAA,EAAA,OACA,OAAMA,EAAE,OAAA,kBAAAA,EAAA,yHCXF,MAAA6X,GAAkBtX,uDAAuB,ECezCuX,GAA2B,CACtC,GAAGtlB,EACH,MAAO,QACP,KAAM,KACN,QAAS,KACT,KAAM,aACN,KAAM,KACN,KAAM,UACN,OAAQ,GACR,MAAO,UACP,KAAM,GACN,OAAQ,OACR,SAAU,OACV,WAAY,GACd,EAGaulB,GAAuBnX,EAA0BkX,EAAW,EAE5DE,GAAe,CAAC,OAAO,ECJpCC,GAAe1lB,kBAAgB,CAC7B,KAAM,aACN,WAAY,CAAA,QACV2lB,EAAA,MACF,EACA,MAAO,CACL,GAAGH,EACL,EACA,MAAOvlB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EAInCgf,EAFYjP,GAAa/P,CAAK,EAEZ,QAAS,IAAM,CAE/B,MAAAgT,EAAMhU,QAAM2mB,CAAM,EACpB3S,GAAOhT,EAAM,SAAW,SAC1B,OAAO,OAAO,YAAY,CACxB,KAAM,WACN,IAAAgT,GACC,GAAG,CACR,CACD,EAEK4L,EAAS7f,EAAAA,SAAS,IAAM2S,GAAmB1R,EAAM,IAAc,CAAC,EAEhE2lB,EAAS5mB,EAAAA,SAAS,IAAM2S,GAAmB1R,EAAM,IAAc,GAAK,IAAI,EACxE4lB,EAAW7mB,EAAAA,SAAS,IAAM,CAC9B,MAAMsJ,EAASrI,EAAM,OACrB,GAAI,EAAAqI,IAAW,SAAWrJ,EAAM,MAAA2mB,CAAM,GAAK,MAOzC,MAJY,CACV,KAAM,QACN,MAAO,QAAA,EAEEtd,CAAM,CACnB,CACD,EACM,MAAA,CACL,MAAAgS,EACA,MAAA2E,EACA,OAAAJ,EACA,OAAA+G,EACA,SAAAC,CAAA,CAEJ,CACF,CAAC,yCA9ECvY,mBAsBM,UAAA,SApBEI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,cAEb,MAiBW2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAfDqY,EAAK,CACZ,MAAM,GACN,QAAQrY,EAAA,MACR,KAAKA,EAAE,KACP,OAAMA,EAAA,OACN,MAAMA,EAAE,MAAA,KAAAA,EAAA,2BAGD,QAAAqT,EAAA,QAAA,IAAA,CAAAiF,EAAAA,mBAAc,OAAQ,CAAY,MAAA7J,EAAAA,eAAA,CAAA,SAAAzO,EAAA,qICbnC,MAAAuY,GAAahY,uBAAkB,ECiB/BiY,GAA+B,CAC1C,GAAGhmB,EACH,MAAO,QACP,GAAI,GACJ,KAAM,MACN,IAAK,MACL,KAAM,MACN,QAAS,MACT,OAAQ,GACR,KAAM,eACN,MAAO,CAAC,EACR,KAAM,CACJ,CAAE,MAAO,MAAO,MAAO,IAAK,QAAS,EAAK,EAC1C,CAAE,MAAO,MAAO,MAAO,IAAK,QAAS,EAAK,EAC1C,CAAE,MAAO,MAAO,MAAO,GAAI,CAC7B,CACF,EAGaimB,GAAyB7X,EAA0B4X,EAAa,EAEhEE,GAAiB,CAAC,gBAAgB,ECtB/CC,GAAepmB,kBAAgB,CAC7B,KAAM,eACN,WAAY,CAAA,eACVqmB,EAAA,aACF,EACA,MAAO,CACL,GAAGH,EACL,EACA,MAAOjmB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCqmB,EAAWnW,MAAqB,CAAA,CAAE,EAClC0R,EAAU1R,MAAe,CAAA,CAAE,EAC3BoW,EAAuB/V,GAAS,CACpC,MAAM9J,EAAQzG,EAAM,MACpB,IAAIoR,EAAS,CAAA,EACRb,EAAA,QAASI,GAAS,CACjBA,EAAK,SACAS,EAAA,KAAKT,EAAK,KAAK,CACxB,CACD,EACG,OAAOlK,GAAU,UAAYA,IAAU,GACzC2K,EAASA,EAAO,OAAO3K,EAAM,MAAM,GAAG,CAAC,EAC9B,MAAM,QAAQA,CAAK,IACnB2K,EAAAA,EAAO,OAAO3K,CAAK,GAE9B4f,EAAS,MAAQ9V,EACjBqR,EAAQ,MAAQxQ,CAAA,EAEZnT,QAAA,IAAM,CAAC+B,EAAM,KAAMA,EAAM,KAAK,EAAG,CAAC,CAACuQ,CAAI,IAA6C,CACxF+V,EAAoB/V,CAAI,CAAA,EACvB,CACD,UAAW,GACX,KAAM,EAAA,CACP,EACK,MAAA0C,EAAcZ,GAAerS,CAAK,EAClC,CAAE,SAAA8S,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EACK+P,EAAoB,SAAY,SACpC,GAAI9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,SAAU,OAC5D,MAAAiB,EAAM,MAAMd,IACZ1C,IAAOjB,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,OAAQ,CAAA,EACtCgX,EAAoB/V,CAAI,CAAA,EAEpBX,EAAK5P,EAAM,GACX,CAAE,eAAA+S,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEDkW,EAAe3c,EAAM,GAAc,CACjC,KAAMA,EAAM,KACZ,MAAO4hB,CAAA,CACR,EAGK,MAAA2E,EADYxW,GAAa/P,CAAK,EACH,iBAAkB,IAAM,CACjD,MAAAuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQX,EAAS,CAAA,CACjD,EACK,CAAE,WAAAtE,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,CAAmC,IAAA,EAAA,CAChE,EACU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW8e,EACX,QAAS9e,EAAM,WAAA,CAChB,EACM,CACL,SAAAqmB,EACA,MAAAhM,EACA,QAAAuH,EACA,eAAA2E,CAAA,CAEJ,CACF,CAAC,yCAnGClZ,mBAMM,kBAAA,SAN2BI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,gBACtC,MAIE2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAFegZ,EAAO,CAAA,QAAAhZ,EAAA,SACrB,MAAQA,EAAA,QAAA,iBAAAoO,EAAA,CAAA,IAAAA,EAAA,CAAA,EAAA+G,GAAAnV,EAAA,QAAAmV,yECHF,MAAA8D,GAAe1Y,uBAAoB,ECuDnC2Y,GAAqB,CAChC,GAAG1mB,EACH,GAAI,GACJ,KAAM,KACN,QAAS,KACT,KAAM,UACN,MAAO,QACP,OAAQ,QACR,IAAK,GACL,KAAM,GACN,OAAQ,GACR,KAAM,CACJ,CAAE,KAAM,MAAO,MAAO,GAAI,EAC1B,CAAE,KAAM,MAAO,MAAO,GAAI,EAC1B,CAAE,KAAM,MAAO,MAAO,GAAI,CAC5B,EACA,UAAW,GACX,aAAc,GACd,UAAW,GACX,OAAQ,CAAC,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,SAAS,EAC1G,gBAAiB,GACjB,YAAa,GACb,sBAAuB,GACvB,eAAgB,OAChB,iBAAkB,4BAClB,WAAY,GACZ,qBAAsB,OACtB,aAAc,WACd,UAAW,MACX,WAAY,OACZ,YAAa,KACb,YAAa,MACb,WAAY,MACZ,UAAW,MACX,UAAW,GACX,WAAY,OACZ,iBAAkB,GAClB,cAAe,GACf,cAAe,UACf,eAAgB,aAChB,cAAe,GACf,gBAAiB,GACjB,iBAAkB,GAClB,SAAU,GACV,wBAAyB,CAAE,KAAM,OAAQ,MAAO,QAAS,KAAM,MAAO,EACtE,oBAAqB,QACrB,iBAAkB,GAClB,QAAS,MACT,WAAY,MACZ,SAAU,KACV,UAAW,KACX,cAAe,CAAC,EAChB,YAAa,GACb,cAAe,aACf,gBAAiB,GACjB,eAAgB,EAChB,YAAa,QACb,WAAY,MACZ,4BAA6B,OAC7B,mBAAoB,GACpB,gBAAiB,SACnB,EAEa2mB,GAAoBvY,EAA0BsY,EAAQ,EAEtDE,GAA2B,CAAC,QAAS,cAAe,aAAa,ECzHjEC,GAAkB,MAAOC,GAA4B,OAChE,MAAM/S,EAAM,MAAMkB,GAAQ,KAAK6R,EAAiB,CAAA,EAAI,CAClD,aAAc,MAAA,CACf,EACK,CAAE,KAAAvW,EAAM,QAAAkC,CAAY,EAAAsB,EACpBgT,EAAWtU,EAAQ,qBAAqB,EAAE,QAAQ,oBAAqB,IAAI,EAC3EuU,EAAO,IAAI,KAAK,CAACzW,CAAI,CAAC,EACtB0W,EAAM,SAAS,cAAc,GAAG,EAChCjU,EAAM,OAAO,IAAI,gBAAgBgU,CAAI,EAC3CC,EAAI,KAAOjU,EACPiU,EAAA,SAAW,UAAUF,CAAQ,EACjCE,EAAI,MAAM,QAAU,OACX,SAAA,KAAK,YAAYA,CAAG,EAC7BA,EAAI,MAAM,GACN5X,EAAA4X,EAAA,aAAA,MAAA5X,EAAY,YAAY4X,GACrB,OAAA,IAAI,gBAAgBjU,CAAG,CAChC,ECkCAkU,GAAAA,IAAI,CACFC,GAAA,eACAC,GAAA,SACAC,EAAA,eACAC,EAAA,iBACAC,EAAA,iBACAC,EAAA,eACF,CAAC,EACD,MAAAC,GAAe1nB,kBAAgB,CAC7B,KAAM,UACN,MAAO,CACL,GAAG4mB,EACL,EACA,WAAY,CACV,KAAAe,GACA,QAAA5nB,GAAA,OACA6nB,EAAA,KACF,EACA,MAAO3nB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC+Q,EAAUb,MAA8B,CAAA,CAAE,EAC1C0X,EAAU1X,MAAI,EAAK,EACnB2X,EAAY,IAAM,CACtBD,EAAQ,MAAQ,EAAA,EAEZ9mB,EAAS/B,EAAAA,SAAS,IAAM,CACxB,GAAA,CAAE,KAAAwR,EAAO,CAAA,GAAOvR,EAAAA,MAAM+R,CAAO,EAAE,CAAC,GAAK,GACzC,GAAI,MAAM,QAAQ/Q,EAAM,MAAM,EAAG,CAC/B,MAAM8nB,EAAmB9nB,EAAM,iBACzB2K,EAAS3K,EAAM,OACrBuQ,EAAOA,EAAK,IAAI,CAACI,EAAMxJ,KAAW,CAChC,MAAO2gB,EAAmB,CAAE,MAAOnd,EAAOxD,CAAK,CAAA,EAAM,CAAC,EACtD,GAAGwJ,CACH,EAAA,CACJ,CACO,MAAA,CACL,QAAS,CACP,KAAM3Q,EAAM,YACZ,KAAMA,EAAM,YACZ,IAAKA,EAAM,WACX,SAAUA,EAAM,gBAChB,QAASA,EAAM,eACf,QAAS,CACP,WAAY,CACV,KAAM,GACN,MAAO,OACP,KAAM,ivCACN,SAAW,CACT6mB,GAAgB7mB,EAAM,kBAA4B,CACpD,CACF,EACA,WAAY,CACV,KAAM,GACN,MAAO,KACP,KAAM,8yBACN,SAAW,CACT4nB,EAAQ,MAAQ,EAClB,CACF,EACA,OAAQ,CACN,KAAM,GACN,MAAO,OACP,KAAM,glCACN,SAAW,CACTD,EAAAA,MAAO,KAAK,CACV,MAAO,OACP,QAAU3nB,EAAM,eAAA,CACjB,CACH,CACF,CACF,CACF,EACA,MAAO,CACL,KAAMA,EAAM,UACZ,QAASA,EAAM,aACf,KAAM,QACR,EACA,KAAM,CACJ,IAAKA,EAAM,QACX,OAAQA,EAAM,WACd,KAAMA,EAAM,SACZ,MAAOA,EAAM,UACb,aAAcA,EAAM,gBACtB,EAEA,QAAS,CACP,KAAMA,EAAM,YACZ,QAASA,EAAM,eACf,UAAYkT,GAAW,CACf,KAAA,CAAE,OAAA6U,EAAQ,WAAAC,EAAY,KAAAvqB,EAAM,MAAAgJ,EAAO,QAAAwhB,EAAS,KAAA1X,CAAAA,EAAS2C,GAAU,GAC9D,OAAAxB,GACL1R,EAAM,iBACN,CACE,OAAA+nB,EACA,KAAAtqB,EACA,MAAAgJ,EACA,QAAAwhB,EACA,EAAGD,EACH,EAAGvqB,EACH,EAAGgJ,EACH,EAAGwhB,EACH,GAAG1X,CACL,EACA,CACE,WAAY,GACZ,SAAU,EACZ,CAAA,CAEJ,EACA,UAAW,CACT,MAAOvQ,EAAM,qBACf,CACF,EAEA,OAAQ,CACN,KAAMA,EAAM,WACZ,OAAQA,EAAM,aACd,IAAKA,EAAM,UACX,KAAMA,EAAM,WACZ,UAAW,CACT,MAAOA,EAAM,oBACf,CACF,EACA,MAAOA,EAAM,OACb,OAAQ,CACN,CACE,KAAAuQ,EACA,KAAM,MACN,OAAQ,CAACvQ,EAAM,YAAaA,EAAM,WAAW,EAC7C,OAAQ,CAACA,EAAM,WAAYA,EAAM,SAAS,EAC1C,SAAUA,EAAM,SAChB,kBAAmB,GAInB,MAAO,CACL,KAAMA,EAAM,gBAAkB,UAAYA,EAAM,UAChD,MAAOA,EAAM,WACb,SAAUA,EAAM,cAChB,SAAUA,EAAM,cAChB,UAAWgR,GAAgBhR,EAAM,cAAwB,CAC3D,EACA,UAAW,CACT,KAAMA,EAAM,cACZ,OAAQA,EAAM,gBACd,QAASA,EAAM,gBACjB,EACA,SAAU,CACR,UAAW,CACT,WAAY,GACZ,cAAe,EACf,YAAa,oBACf,EACA,MAAO,CAEP,CACF,CACF,CACF,CAAA,CACF,CACD,EAEK,CAAE,eAAA+S,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEK,CAAE,SAAAqM,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAEKmZ,EAAgB,CAAC3X,EAAY,CAAA,EAAIC,IAA6C,CAClF,KAAM,CAAE,QAASjN,CAAA,EAAM+M,GAAiCC,EAAMC,CAAc,EAC5EO,EAAQ,MAAQxN,CAAA,EAGZ4kB,EAAyB,CAAC5X,EAAY,CAAA,EAAIC,IAA6C,CACrF,MAAA4X,EAAY9X,GAAiCC,EAAMC,CAAc,EACvEO,EAAQ,MAAQqX,EAAU,OAAA,EAI5BnqB,EAAAA,MAAM,IAAM+B,EAAM,KAAOyG,GAAe,EAClCzG,EAAM,WAAa,UAAYhB,EAAAA,MAAM8T,CAAQ,IAAM,WACrDoV,EAAczhB,CAAK,CACrB,EACC,CACD,UAAW,GACX,KAAM,EAAA,CACP,EAEK,MAAA/H,EAAUwR,MAAI,EAAK,EACnB+C,EAAcZ,GAAerS,CAAK,EAElC8e,EAAoB,SAAY,SACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UACpD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClBiV,GAAc5Y,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,KAAMtP,EAAM,uBAAkD,QACtFoB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAKIsgB,EAFYjP,GAAa/P,CAAK,EAEZ,QAAUoB,GAAM,CACtC,MAAMwO,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQnhB,GAAA,YAAAA,EAAG,KAAM,CAAA,CACjD,EAGKinB,EAAiBhT,GAAsBrV,CAAK,EAC5CsoB,EAAsB,SAAY,iBACtC,GAAI,EAAAtoB,EAAM,WAAa,aAAehB,EAAAA,MAAM8T,CAAQ,IAAM,UACtD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMsU,IAClB,IAAIE,EAAS,CAAA,EACb,KAAI/Y,GAAAF,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,UAAjB,YAAAE,EAA0B,QAAS,EAAG,CACxC,MAAM/R,EAAOsW,EAAI,KAAK,KAAK,QAAQ,CAAC,EAC9BtN,EAAQsN,EAAI,KAAK,KAAK,QAAQ,CAAC,EACrCwU,GAASC,GAAA5c,GAAAF,EAAAqI,GAAA,YAAAA,EAAK,OAAL,YAAArI,EAAW,OAAX,YAAAE,EAAiB,OAAjB,YAAA4c,EAAuB,IAAY7X,IACnC,CACL,KAAMA,EAAKlT,CAAI,EACf,MAAOkT,EAAKlK,CAAK,CAAA,GAGvB,CACA0hB,EAAuBI,CAAM,QACtBnnB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAGI+pB,EAAyB,IAAM,CAC/BzpB,EAAA,MAAM8T,CAAQ,IAAM,WACJwV,IACFxJ,IAAA,EAapBpP,GAAW1P,EAAO,CAChB,YAPkB,IAAM,CACxB,MAAM4P,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAC/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQ,GAAI,CAAA,EAK3C,YAZkB,IAAM,CACDkG,GAAA,EAYvB,MAAAzJ,CAAA,CACD,EAED,KAAM,CAAE,WAAA1B,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EACU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAWyoB,EACX,QAASzoB,EAAM,WAAA,CAChB,EACM,CACL,OAAAc,EACA,MAAAuZ,EACA,MAAA2E,EACA,QAAAtgB,EACA,QAAAkpB,EACA,UAAAC,CAAA,CAEJ,CACF,CAAC,sGAjVCxa,mBAuBM,SAAA,mDAtBJ,MAAA4O,EAAAA,eAMOzO,EANA,KAAA,CAAA,EAAA,eACLkb,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CACLhU,EAAAA,YAAA8b,EAAA,CACT,OAAKnb,EAAE,OAAA,WAAA,mDAGZ,EAAA,CAAA,EACE,EAAA,CAAA,UAAA,CAAA,EAAAX,EAAAA,YACM+b,EAAM,CACX,kBAAS,aACT,MAAM,OACN,QAAMpb,EAAE,QAAA,OAAA,4BAOL,QAAAqT,EAAA,QAAA,IAAA,CAAAhU,EAAAA,YAJF6b,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OAAA,iBAAA,CAAA,SAAA,EAAA,gGClBG,MAAAqb,GAAU9a,uBAAe,ECsDzB+a,GAAuB,CAClC,GAAG9oB,EACH,GAAI,GACJ,KAAM,MACN,QAAS,MACT,KAAM,WACN,MAAO,QACP,OAAQ,QACR,IAAK,GACL,KAAM,GACN,OAAQ,GACR,KAAM,CACJ,CAAE,KAAM,MAAO,MAAO,IAAK,KAAM,KAAM,EACvC,CAAE,KAAM,MAAO,MAAO,IAAK,KAAM,KAAM,EACvC,CAAE,KAAM,MAAO,MAAO,IAAK,KAAM,KAAM,EACvC,CAAE,KAAM,MAAO,MAAO,IAAK,KAAM,KAAM,CACzC,EACA,UAAW,GACX,aAAc,GACd,UAAW,GACX,WAAY,GACZ,aAAc,aACd,UAAW,MACX,WAAY,SACZ,OAAQ,CAAC,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,SAAS,EAC1G,WAAY,EACZ,eAAgB,EAChB,OAAQ,GACR,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,cAAe,GACf,oBAAqB,UACrB,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,oBAAqB,UACrB,iBAAkB,GAClB,QAAS,MACT,WAAY,MACZ,SAAU,KACV,UAAW,KACX,wBAAyB,CAAE,KAAM,OAAQ,MAAO,QAAS,KAAM,MAAO,EACtE,sBAAuB,CAAE,KAAM,OAAQ,MAAO,CAAA,CAAG,EACjD,oBAAqB,QACrB,cAAe,CAAC,EAChB,YAAa,GACb,iBAAkB,sBAClB,YAAa,GACb,cAAe,aACf,gBAAiB,GACjB,eAAgB,EAChB,YAAa,QACb,WAAY,MACZ,4BAA6B,OAC7B,mBAAoB,GACpB,gBAAiB,UACjB,iBAAkB,CACpB,EAGa+oB,GAAqB3a,EAA0B0a,EAAS,EAExDE,GAAa,CAAC,QAAS,cAAe,aAAa,ECxEhE9B,GAAAA,IAAI,CACFC,GAAA,eACA8B,GAAA,UACA3B,EAAA,iBACAD,EAAA,eACAG,EAAA,eACF,CAAC,EACD,MAAA0B,GAAenpB,kBAAgB,CAC7B,KAAM,WACN,MAAO,CACL,GAAGgpB,EACL,EACA,WAAY,CACV,KAAArB,GACA,QAAA5nB,GAAA,OACA6nB,EAAA,KACF,EACA,MAAO3nB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCsX,EAASpH,MAA8B,CAAA,CAAE,EACzCY,EAAaZ,MAA8B,CAAA,CAAE,EAC7C0X,EAAU1X,MAAI,EAAK,EACnB2X,EAAY,IAAM,CACtBD,EAAQ,MAAQ,EAAA,EAEZ9mB,EAAS/B,EAAAA,SAAS,IAAM,CAG5B,MAAMoqB,EAAsBnpB,EAAM,oBAC5BopB,EAAsBppB,EAAM,oBAC3B,MAAA,CACL,QAAS,CACP,KAAMA,EAAM,YACZ,KAAMA,EAAM,YACZ,IAAKA,EAAM,WACX,SAAUA,EAAM,gBAChB,QAASA,EAAM,eACf,QAAS,CACP,WAAY,CACV,KAAM,GACN,MAAO,OACP,KAAM,ivCACN,SAAW,CACT6mB,GAAgB7mB,EAAM,kBAA4B,CACpD,CACF,EACA,WAAY,CACV,KAAM,GACN,MAAO,KACP,KAAM,8yBACN,SAAW,CACT4nB,EAAQ,MAAQ,EAClB,CACF,EACA,OAAQ,CACN,KAAM,GACN,MAAO,OACP,KAAM,glCACN,SAAW,CACTD,EAAAA,MAAO,KAAK,CACV,MAAO,OACP,QAAU3nB,EAAM,eAAA,CACjB,CACH,CACF,CACF,CACF,EACA,MAAO,CACL,KAAMA,EAAM,UACZ,QAASA,EAAM,aACf,KAAM,QACR,EACA,KAAM,CACJ,IAAKA,EAAM,QACX,OAAQA,EAAM,WACd,KAAMA,EAAM,SACZ,MAAOA,EAAM,UACb,aAAcA,EAAM,gBACtB,EACA,MAAOA,EAAM,OACb,QAAS,CACP,QAAS,OACT,KAAMA,EAAM,YACZ,UAAYkT,GAAW,CACrB,MAAM5H,EAAM4H,EAAO,OACnB,IAAIjC,EAAY,GACZoY,EAAmBrpB,EAAM,iBACzBqpB,IAAqB,KACJA,EAAA,uBAErB,QAAS5lB,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,KAAA,CAAE,OAAAskB,EAAQ,WAAAC,EAAY,KAAAvqB,EAAM,MAAAgJ,EAAO,KAAA8J,GAAS2C,EAAOzP,CAAC,GAAK,GAC3DA,IAAM,IACRwN,GAAa,GAAGxT,UAELwT,GAAAS,GACX2X,EACA,CACE,OAAAtB,EACA,KAAAtqB,EACA,MAAAgJ,EACA,EAAGuhB,EACH,EAAGvqB,EACH,EAAGgJ,EACH,GAAG8J,CACL,EACA,CACE,WAAY,GACZ,SAAU,EACZ,CAAA,EACWU,GAAA,OACf,CACO,OAAAA,CACT,CACF,EACA,MAAO,CACL,KAAM,WACN,KAAMjS,QAAM8R,CAAU,EACtB,UAAW,CACT,KAAM9Q,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,UAAWyG,EAAe,CACjB,OAAAqR,GAAkBqR,EAAqB1iB,CAAK,CACrD,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,EACA,SAAU,CACR,KAAMA,EAAM,aACd,CACF,EACA,MAAO,CACL,KAAM,QACN,UAAW,CACT,KAAMA,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,UAAWyG,EAAe,CACjB,OAAAqR,GAAkBsR,EAAqB3iB,CAAK,CACrD,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,CACF,EAEA,OAAQ,CACN,KAAMA,EAAM,WACZ,OAAQA,EAAM,aACd,IAAKA,EAAM,UACX,KAAMA,EAAM,UACd,EACA,OAAQhB,QAAMsY,CAAM,CAAA,CACtB,CACD,EAEK,CAAE,eAAAvE,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEK,CAAE,SAAAqM,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAEKmZ,EAAgB,CAAC3X,EAAY,CAAA,EAAI+Y,EAA6B,KAAU,CAExE,IAAAlB,EACA,GAAApoB,EAAM,sBAAwB,MAAO,CACjC,MAAAwQ,EAAiB8Y,EAAoBtpB,EAAM,sBAAiD,KACtFooB,EAAAlU,GAA+B3D,EAAMC,CAAc,CAAA,SACtDxQ,EAAM,sBAAwB,QAAS,CAC1C,MAAAwQ,EAAiB8Y,EAAoBtpB,EAAM,wBAAqD,KAC1FooB,EAAA9X,GAAiCC,EAAMC,CAAc,CACnE,CACAM,EAAW,MAAQsX,EAAU,WAC7B,MAAMrX,EAAUqX,EAAU,QACpBmB,EAAO,CAAA,EACPje,EAAMyF,EAAQ,OACpB,QAAStN,EAAI,EAAGA,EAAI6H,EAAK7H,IACvB8lB,EAAK,KAAK,CACR,KAAM,OACN,GAAGxY,EAAQtN,CAAC,EACZ,WAAYzD,EAAM,WAClB,OAAQA,EAAM,OACd,UAAW,CAcT,QAASA,EAAM,gBACjB,EACA,UAAW,CACT,MAAOA,EAAM,cACf,CAAA,CACD,EAEHsX,EAAO,MAAQiS,CAAA,EAGXpB,EAAyB,CAAC5X,EAAY,CAAI,EAAAiZ,EAA8CF,EAA6B,KAAU,CAE7H,MAAAlB,EAAYlU,GAA+B3D,EAD1B+Y,EAAoBE,EAAwB,IACE,EACrE1Y,EAAW,MAAQsX,EAAU,WAC7B,MAAMrX,EAAUqX,EAAU,QACpBmB,EAAO,CAAA,EACPje,EAAMyF,EAAQ,OACpB,QAAStN,EAAI,EAAGA,EAAI6H,EAAK7H,IACvB8lB,EAAK,KAAK,CACR,KAAM,OACN,GAAGxY,EAAQtN,CAAC,EACZ,WAAYzD,EAAM,WAClB,OAAQA,EAAM,OACd,UAAW,CACT,MAAOA,EAAM,cACf,CAAA,CACD,EAEHsX,EAAO,MAAQiS,CAAA,EAIjBtrB,EAAA,MAAM,IAAM,CAAC+B,EAAM,KAAMA,EAAM,WAAYA,EAAM,OAAQA,EAAM,eAAgBA,EAAM,gBAAgB,EAAG,CAAC,CAACuQ,CAAI,IAAM,EAC9GvQ,EAAM,WAAa,UAAYhB,EAAAA,MAAM8T,CAAQ,IAAM,WACrDoV,EAAc3X,CAAgC,CAChD,EACC,CACD,UAAW,GACX,KAAM,EAAA,CACP,EAEK,MAAA7R,EAAUwR,MAAI,EAAK,EACnB+C,EAAcZ,GAAerS,CAAK,EAElC8e,EAAoB,SAAY,SACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UACpD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClBiV,GAAc5Y,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,KAAM,EAAI,QAClClO,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAKIsgB,EAFYjP,GAAa/P,CAAK,EAEZ,QAAUoB,GAAM,CAEtC,MAAMwO,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQnhB,GAAA,YAAAA,EAAG,KAAM,CAAA,CACjD,EAGKinB,EAAiBhT,GAAsBrV,CAAK,EAC5CsoB,EAAsB,SAAY,eACtC,GAAI,EAAAtoB,EAAM,WAAa,aAAehB,EAAAA,MAAM8T,CAAQ,IAAM,UACtD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMsU,IACd,IAAAhmB,IACAmN,GAAAF,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,UAAjB,YAAAE,EAA0B,QAAS,IACjCnN,EAAA,CACF,KAAM0R,EAAI,KAAK,KAAK,QAAQ,CAAC,EAC7B,MAAOA,EAAI,KAAK,KAAK,QAAQ,MAAM,CAAC,EAAE,IAAU8B,IACvC,CAAE,MAAOA,EAAI,MAAOA,CAAG,EAC/B,CAAA,GAGLsS,GAAuBvc,GAAAF,EAAAqI,GAAA,YAAAA,EAAK,OAAL,YAAArI,EAAW,OAAX,YAAAE,EAAiB,KAAMvJ,EAAG,EAAI,QAC9CjB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAGI+pB,EAAyB,IAAM,CAC/BzpB,EAAA,MAAM8T,CAAQ,IAAM,WACJwV,IACFxJ,IAAA,EAapBpP,GAAW1P,EAAO,CAChB,YAXkB,IAAM,CACDyoB,GAAA,EAWvB,YARkB,IAAM,CACxB,MAAM7Y,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAC/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQ,GAAI,CAAA,EAM3C,MAAAvD,CAAA,CACD,EAED,KAAM,CAAE,WAAA1B,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EAEU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAWyoB,EACX,QAASzoB,EAAM,WAAA,CAChB,EAEM,CACL,OAAAc,EACA,MAAAuZ,EACA,MAAA2E,EACA,QAAAtgB,EACA,QAAAkpB,EACA,UAAAC,CAAA,CAEJ,CACF,CAAC,sGA/YCxa,mBAuBM,SAAA,mDAtBJ,MAAA4O,EAAAA,eAMOzO,EANA,KAAA,CAAA,EAAA,eACLkb,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CACLhU,EAAAA,YAAA8b,EAAA,CACT,OAAKnb,EAAE,OAAA,WAAA,mDAGZ,EAAA,CAAA,EACE,EAAA,CAAA,UAAA,CAAA,EAAAX,EAAAA,YACM+b,EAAM,CACX,kBAAS,aACT,MAAM,OACN,QAAMpb,EAAE,QAAA,OAAA,4BAOL,QAAAqT,EAAA,QAAA,IAAA,CAAAhU,EAAAA,YAJF6b,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OAAA,iBAAA,CAAA,SAAA,EAAA,gGClBG,MAAAic,GAAW1b,uBAAgB,ECgF3B2b,GAAqB,CAChC,GAAG1pB,EACH,GAAI,GACJ,KAAM,MACN,QAAS,MACT,KAAM,UACN,MAAO,QACP,OAAQ,QACR,IAAK,GACL,KAAM,GACN,OAAQ,GACR,oBAAqB,UACrB,oBAAqB,UACrB,KAAM,CACJ,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,CACF,EACA,UAAW,GACX,aAAc,GACd,OAAQ,CAAC,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,SAAS,EAC1G,WAAY,GACZ,qBAAsB,OACtB,aAAc,aACd,UAAW,MACX,WAAY,SACZ,YAAa,GACb,sBAAuB,GACvB,iBAAkB,sBAClB,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,gBAAiB,OACjB,iBAAkB,EAClB,mBAAoB,OACpB,oBAAqB,OACrB,cAAe,GACf,gBAAiB,OACjB,iBAAkB,EAClB,mBAAoB,OACpB,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,wBAAyB,CAAE,KAAM,OAAQ,MAAO,QAAS,KAAM,MAAO,EACtE,sBAAuB,CAAE,KAAM,OAAQ,MAAO,CAAA,CAAG,EACjD,oBAAqB,QACrB,SAAU,MACV,iBAAkB,GAClB,QAAS,MACT,WAAY,MACZ,SAAU,KACV,UAAW,KACX,cAAe,CACb,UAAW,MACX,OAAQ,IACR,MAAO,GACT,EACA,YAAa,GACb,cAAe,aACf,gBAAiB,GACjB,eAAgB,EAChB,YAAa,QACb,WAAY,MACZ,4BAA6B,OAC7B,mBAAoB,GACpB,gBAAiB,UACjB,oBAAqB,GACrB,YAAa,GACb,aAAc,GACd,aAAc,GACd,QAAS,GACT,UAAW,GACX,cAAe,OACf,cAAe,SACf,WAAY,EACd,EAGa2pB,GAAoBvb,EAA0Bsb,EAAQ,EAEtDE,GAAuB,CAAC,cAAe,QAAS,aAAa,ECrH1E1C,GAAAA,IAAI,CACFC,GAAA,eACA0C,GAAA,SACAxC,EAAA,eACAG,EAAA,gBACAsC,EAAA,iBACAxC,EAAA,gBACF,CAAC,EACD,MAAAyC,GAAehqB,kBAAgB,CAC7B,KAAM,UACN,MAAO,CACL,GAAG4pB,EACL,EACA,WAAY,CACV,KAAAjC,GACA,QAAA5nB,GAAA,OACA6nB,EAAA,KACF,EACA,MAAO3nB,EAAO,CAAE,OAAAsc,GAAU,CAClB,MAAAjC,EAAQ5L,EAAsBzO,CAAK,EACnCqgB,EAAanQ,MAA8B,CAAA,CAAE,EAC7C0X,EAAU1X,MAAI,EAAK,EACnB2X,EAAY,IAAM,CACtBD,EAAQ,MAAQ,EAAA,EAEZtQ,EAASvY,EAAAA,SAAS,IAAM,CACtB,MAAAirB,EAAKhrB,QAAMqhB,CAAU,EACrB/U,EAAM0e,EAAG,OACT1S,EAAS,CAAA,EACf,QAAS7T,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CAC5B,MAAMkN,EAAO,CACX,GAAGqZ,EAAGvmB,CAAC,EACP,KAAM,MACN,SAAUzD,EAAM,QAAA,EAEdA,EAAM,UACR2Q,EAAK,MAAQ,SAEfA,EAAK,MAAQ,CACX,KAAM3Q,EAAM,UACZ,SAAUA,EAAM,cAChB,SAAUA,EAAM,cAChB,MAAOA,EAAM,UAAA,EAEfsX,EAAO,KAAK3G,CAAI,CAClB,CACO2G,OAAAA,CAAA,CACR,EACKxG,EAAaZ,MAA8B,CAAA,CAAE,EAC7CxR,EAAUwR,MAAI,EAAK,EACnBpP,EAAS/B,EAAAA,SAAS,IAAM,CAG5B,MAAMqqB,EAAsBppB,EAAM,oBAC5BmpB,EAAsBnpB,EAAM,oBAC3B,MAAA,CACL,QAAS,CACP,KAAMA,EAAM,YACZ,KAAMA,EAAM,YACZ,IAAKA,EAAM,WACX,SAAUA,EAAM,gBAChB,QAASA,EAAM,eACf,QAAS,CACP,WAAY,CACV,KAAM,GACN,MAAO,OACP,KAAM,ivCACN,SAAW,CACT6mB,GAAgB7mB,EAAM,kBAA4B,CACpD,CACF,EACA,WAAY,CACV,KAAM,GACN,MAAO,KACP,KAAM,8yBACN,SAAW,CACT4nB,EAAQ,MAAQ,EAClB,CACF,EACA,OAAQ,CACN,KAAM,GACN,MAAO,OACP,KAAM,glCACN,SAAW,CACTD,EAAAA,MAAO,KAAK,CACV,MAAO,OACP,QAAU3nB,EAAM,eAAA,CACjB,CACH,CACF,CACF,CACF,EACA,MAAO,CACL,KAAMA,EAAM,UACZ,QAASA,EAAM,aACf,KAAM,QACR,EACA,KAAM,CACJ,IAAKA,EAAM,QACX,OAAQA,EAAM,WACd,KAAMA,EAAM,SACZ,MAAOA,EAAM,UACb,aAAcA,EAAM,gBACtB,EACA,MAAOA,EAAM,OACb,QAAS,CACP,QAAS,OACT,KAAMA,EAAM,YACZ,UAAYkT,GAAW,CACrB,MAAM5H,EAAM4H,EAAO,OACnB,IAAIjC,EAAY,GACZoY,EAAmBrpB,EAAM,iBACzBqpB,IAAqB,KACJA,EAAA,uBAErB,QAAS5lB,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,KAAA,CAAE,OAAAskB,EAAQ,WAAAC,EAAY,KAAAvqB,EAAM,MAAAgJ,EAAO,KAAA8J,GAAS2C,EAAOzP,CAAC,GAAK,GAC3DA,IAAM,IACRwN,GAAa,GAAGxT,UAELwT,GAAAS,GACX2X,EACA,CACE,OAAAtB,EACA,KAAAtqB,EACA,MAAAgJ,EACA,EAAGuhB,EACH,EAAGvqB,EACH,EAAGgJ,EACH,GAAG8J,CACL,EACA,CACE,WAAY,GACZ,SAAU,EACZ,CAAA,EACWU,GAAA,OACf,CACO,OAAAA,CACT,EAIA,UAAW,CACT,MAAOjR,EAAM,qBACf,CACF,EACA,OAAQ,CACN,KAAMA,EAAM,WACZ,OAAQA,EAAM,aACd,IAAKA,EAAM,UACX,KAAMA,EAAM,WACZ,UAAW,CACT,MAAOA,EAAM,oBACf,CACF,EACA,MAAO,CACL,KAAMA,EAAM,oBAAsB,QAAU,WAC5C,KAAMA,EAAM,oBAAsB,KAAOhB,EAAAA,MAAM8R,CAAU,EACzD,QAAS9Q,EAAM,oBAAsBA,EAAM,aAAeA,EAAM,YAChE,UAAW,CACT,KAAMA,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,SAAU,EACV,OAAQA,EAAM,iBACd,MAAOA,EAAM,gBACb,SAAUA,EAAM,mBAChB,UAAWyG,EAAe,CACjB,OAAAqR,GAAkBqR,EAAqB1iB,CAAK,CACrD,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,EACA,SAAU,CACR,KAAMA,EAAM,aACd,CACF,EACA,MAAO,CACL,KAAMA,EAAM,oBAAsB,WAAa,QAC/C,KAAMA,EAAM,oBAAsBhB,EAAAA,MAAM8R,CAAU,EAAI,KACtD,QAAS9Q,EAAM,oBAAsBA,EAAM,YAAcA,EAAM,aAC/D,UAAW,CACT,KAAMA,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,OAAQA,EAAM,iBACd,MAAOA,EAAM,gBACb,SAAUA,EAAM,mBAChB,UAAWyG,EAAe,CACjB,OAAAqR,GAAkBsR,EAAqB3iB,CAAK,CACrD,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,CACF,EACA,OAAQhB,QAAMsY,CAAM,CAAA,CACtB,CACD,EACK,CAAE,SAAAxE,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAEKmZ,EAAgB,CAAC3X,EAAa,CAAA,EAAI+Y,EAA6B,KAAU,CAC7E,IAAIlB,EAAY,CAAA,EACZ,GAAApoB,EAAM,sBAAwB,MAAO,CACjC,MAAAwQ,EAAiB8Y,EAAoBtpB,EAAM,sBAAiD,KACtFooB,EAAAlU,GAA+B3D,EAAMC,CAAc,CAAA,SACtDxQ,EAAM,sBAAwB,QAAS,CAC1C,MAAAwQ,EAAiB8Y,EAAoBtpB,EAAM,wBAAqD,KAC1FooB,EAAA9X,GAAiCC,EAAMC,CAAc,CACnE,CACA6P,EAAW,MAAQ+H,EAAU,QAC7BtX,EAAW,MAAQsX,EAAU,UAAA,EAGzBD,EAAyB,CAAC5X,EAAY,CAAI,EAAAiZ,EAA8CF,EAA6B,KAAU,CAE7H,MAAAlB,EAAYlU,GAA+B3D,EAD1B+Y,EAAoBE,EAAwB,IACE,EACrEnJ,EAAW,MAAQ+H,EAAU,QAC7BtX,EAAW,MAAQsX,EAAU,UAAA,EAI/BnqB,EAAAA,MAAM,IAAM+B,EAAM,KAAOyG,GAAe,EAClCzG,EAAM,WAAa,UAAYhB,EAAAA,MAAM8T,CAAQ,IAAM,WACrDoV,EAAczhB,CAAK,CACrB,EACC,CACD,UAAW,GACX,KAAM,EAAA,CACP,EAEK,MAAAwM,EAAcZ,GAAerS,CAAK,EAElC8e,EAAoB,SAAY,SAChC,GAAA,CACFpgB,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClBiV,GAAc5Y,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,KAAM,EAAI,QAClClO,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAIIurB,EAAgBlS,GAAiB/X,CAAK,EACtCsoB,EAAsB,SAAY,OAClC,GAAA,CACF5pB,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMkW,IACZ,CAAE,QAAAC,EAAU,CAAI,EAAA,KAAAC,EAAO,CAAA,CAAO,IAAA9a,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAQ,GACnD,IAAA+a,EACAF,EAAQ,OAAS,IACNE,EAAA,CACX,KAAMF,EAAQ,CAAC,EACf,MAAOA,EAAQ,MAAM,CAAC,EAAE,IAAchJ,IAC7B,CACL,MAAOA,EACP,MAAOA,CAAA,EAEV,CAAA,GAGkBiH,EAAAgC,EAAMC,EAAY,EAAI,QACtChpB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAGIqgB,EAAc,IAAM,CACpB,GAAA/f,EAAA,MAAM8T,CAAQ,IAAM,SACxB,OAAQ9S,EAAM,SAAU,CACtB,IAAK,YACiBsoB,IACpB,MACF,IAAK,UACexJ,IAClB,KACJ,CAAA,EAGKxC,EAAA,CACL,YAAAyC,CAAA,CACD,EAEK,MAAA1O,EAAYN,GAAa/P,CAAK,EAE9B,CAAE,eAAA+S,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EACKuY,EAAQ3O,EAAU,QAAUjP,GAAM,CAEtC,MAAMwO,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQnhB,EAAE,KAAM,CAAA,CAChD,EAEK,CAAE,WAAAkc,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EAEU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW+e,EACX,QAAS/e,EAAM,WAAA,CAChB,EAQD0P,GAAW1P,EAAO,CAChB,YAAA+e,EACA,MAAAC,EACA,YATkB,IAAM,CACxB,MAAMpP,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAC/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQ,GAAI,CAAA,CAM3C,CACD,EAEM,CACL,OAAAzhB,EACA,MAAAuZ,EACA,YAAA0E,EACA,MAAAC,EACA,QAAAtgB,EACA,QAAAkpB,EACA,UAAAC,CAAA,CAEJ,CACF,CAAC,sGA5ZCxa,mBAwBM,SAAA,SAxBsBI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,WACjC,MAAA2O,EAAAA,eAOOzO,EAPA,KAAA,CAAA,EAAA,eACLkb,EAKE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAJCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OACC,iBAAO,CAAK,SAAA,EAAA,EAAA,WAAA,mDAGjB,EAAA,CAAA,EACE,EAAA,CAAA,UAAA,CAAA,EAAAX,EAAAA,YACM+b,EAAM,CACX,kBAAS,aACT,MAAM,OACN,QAAMpb,EAAE,QAAA,OAAA,4BAOL,QAAAqT,EAAA,QAAA,IAAA,CAAAhU,EAAAA,YAJF6b,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OAAA,iBAAA,CAAA,SAAA,EAAA,gGCnBG,MAAA6c,GAAUtc,uBAAe,EC+CzBuc,GAA6B,CACxC,GAAGtqB,EACH,GAAI,GACJ,KAAM,MACN,QAAS,MACT,KAAM,cACN,MAAO,QACP,OAAQ,QACR,IAAK,GACL,KAAM,GACN,OAAQ,GACR,KAAM,CACJ,CAAE,KAAM,IAAK,MAAO,GAAI,EACxB,CAAE,KAAM,IAAK,MAAO,GAAI,EACxB,CAAE,KAAM,GAAI,MAAO,GAAI,CACzB,EACA,UAAW,GACX,aAAc,GACd,YAAa,GACb,eAAgB,OAChB,iBAAkB,sBAClB,WAAY,GACZ,aAAc,aACd,UAAW,MACX,WAAY,SACZ,OAAQ,CAAC,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,SAAS,EAC1G,WAAY,GACZ,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,cAAe,GACf,oBAAqB,UACrB,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,oBAAqB,UACrB,eAAgB,CAAE,KAAM,OAAQ,MAAO,OAAQ,EAC/C,iBAAkB,GAClB,QAAS,MACT,WAAY,MACZ,SAAU,KACV,UAAW,KACX,cAAe,OACf,YAAa,GACb,cAAe,aACf,gBAAiB,GACjB,eAAgB,EAChB,YAAa,QACb,WAAY,MACZ,4BAA6B,OAC7B,mBAAoB,GACpB,gBAAiB,SACnB,EAGauqB,GAAwBnc,EAA0Bkc,EAAY,EAE9DE,GAAgB,CAAC,QAAS,aAAa,EC5DpDtD,GAAAA,IAAI,CACFC,GAAA,eACAsD,GAAA,aACAnD,EAAA,iBACAD,EAAA,eACAE,EAAA,iBACAC,EAAA,eACF,CAAC,EACD,MAAAkD,GAAe3qB,kBAAgB,CAC7B,KAAM,cACN,MAAO,CACL,GAAGwqB,EACL,EACA,WAAY,CACV,KAAA7C,GACA,QAAA5nB,GAAA,OACA6nB,EAAA,KACF,EACA,MAAO3nB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC+Q,EAAUb,MAA8B,CAAA,CAAE,EAC1C0X,EAAU1X,MAAI,EAAK,EACnB2X,EAAY,IAAM,CACtBD,EAAQ,MAAQ,EAAA,EAEZ9mB,EAAS/B,EAAAA,SAAS,IAAM,CAG5B,MAAMoqB,EAAsBnpB,EAAM,oBAC5BopB,EAAsBppB,EAAM,oBAC3B,MAAA,CACL,QAAS,CACP,KAAMA,EAAM,YACZ,KAAMA,EAAM,YACZ,IAAKA,EAAM,WACX,SAAUA,EAAM,gBAChB,QAASA,EAAM,eACf,QAAS,CACP,WAAY,CACV,KAAM,GACN,MAAO,OACP,KAAM,ivCACN,SAAW,CACT6mB,GAAgB7mB,EAAM,kBAA4B,CACpD,CACF,EACA,WAAY,CACV,KAAM,GACN,MAAO,KACP,KAAM,8yBACN,SAAW,CACT4nB,EAAQ,MAAQ,EAClB,CACF,EACA,OAAQ,CACN,KAAM,GACN,MAAO,OACP,KAAM,glCACN,SAAW,CACTD,EAAAA,MAAO,KAAK,CACV,MAAO,OACP,QAAU3nB,EAAM,eAAA,CACjB,CACH,CACF,CACF,CACF,EACA,MAAO,CACL,KAAMA,EAAM,UACZ,QAASA,EAAM,aACf,KAAM,QACR,EACA,KAAM,CACJ,IAAKA,EAAM,QACX,OAAQA,EAAM,WACd,KAAMA,EAAM,SACZ,MAAOA,EAAM,UACb,aAAcA,EAAM,gBACtB,EACA,MAAOA,EAAM,OACb,MAAO,CAEL,UAAW,CACT,KAAMA,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,UAAWyG,EAAe,CACjB,OAAAqR,GAAkBqR,EAAqB1iB,CAAK,CACrD,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,EACA,SAAU,CACR,KAAMA,EAAM,aACd,CACF,EACA,MAAO,CACL,UAAW,CACT,KAAMA,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,UAAWyG,EAAe,CACjB,OAAAqR,GAAkBsR,EAAqB3iB,CAAK,CACrD,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,CACF,EAEA,QAAS,CACP,KAAMA,EAAM,YACZ,QAASA,EAAM,eACf,UAAW,SAAUkT,EAAQ,OACrB,KAAA,CAAE,OAAA6U,EAAQ,WAAAC,CAAe,EAAA9U,EACzBG,IAAShE,EAAA6D,GAAA,YAAAA,EAAQ,OAAR,YAAA7D,EAAc,SAAU,CAAA,EACjC,CAAE,KAAA5R,EAAM,MAAAgJ,CAAU,EAAA4M,EACjB,OAAA3B,GAAmB1R,EAAM,iBAA4B,CAC1D,OAAA+nB,EACA,WAAAC,EACA,EAAGA,EACH,EAAGvqB,EACH,EAAGgJ,EACH,GAAG4M,CAAA,CACJ,CACH,EACA,YAAa,CACX,KAAM,OACR,CACF,EAEA,OAAQ,CACN,KAAMrT,EAAM,WACZ,OAAQA,EAAM,aACd,IAAKA,EAAM,UACX,KAAMA,EAAM,UACd,EACA,OAAQ,CACN,CACE,KAAMhB,QAAM+R,CAAO,EACnB,KAAM,UACN,WAAY/Q,EAAM,UACpB,CACF,CAAA,CACF,CACD,EAEK,CAAE,eAAA+S,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEK,CAAE,SAAAqM,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAEKmZ,EAAgB,CAAC3X,EAAY,CAAA,EAAIC,IAAoD,CACnF,KAAA,CAAE,KAAMI,EAAI,OAAQ,MAAOC,EAAI,OAAA,EAAYL,GAAkB,GACnEO,EAAQ,MAAQR,EAAK,IAAaI,IAAA,CAAE,MAAO,CAACA,EAAKC,CAAC,EAAGD,EAAKE,CAAC,CAAC,EAAG,OAAQF,CAAO,EAAA,CAAA,EAIhF1S,EAAAA,MAAM,IAAM+B,EAAM,KAAOyG,GAAe,EAClCzG,EAAM,WAAa,UAAYhB,EAAAA,MAAM8T,CAAQ,IAAM,WACrDoV,EAAczhB,CAAK,CACrB,EACC,CACD,UAAW,GACX,KAAM,EAAA,CACP,EAEK,MAAA/H,EAAUwR,MAAI,EAAK,EAEnB+C,EAAcZ,GAAerS,CAAK,EAElC8e,EAAoB,SAAY,SACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UACxD,CAAApU,EAAQ,MAAQ,GACZ,GAAA,CACI,MAAAqV,EAAM,MAAMd,IAClBiV,GAAc5Y,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,KAAMtP,EAAM,cAAgD,QACpFoB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,EAAA,EAKIsgB,EAFYjP,GAAa/P,CAAK,EAEZ,QAAUoB,GAAM,CACtC,MAAMwO,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQnhB,GAAA,YAAAA,EAAG,KAAM,CAAA,CACjD,EAMDsO,GAAW1P,EAAO,CAChB,YALkB,IAAM,CACN8e,GAAA,EAKlB,MAAAE,CAAA,CACD,EAED,KAAM,CAAE,WAAA1B,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EACU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAW8e,EACX,QAAS9e,EAAM,WAAA,CAChB,EAEM,CACL,OAAAc,EACA,MAAAuZ,EACA,MAAA2E,EACA,QAAAtgB,EACA,QAAAkpB,EACA,UAAAC,CAAA,CAEJ,CACF,CAAC,sGAlSCxa,mBAuBM,SAAA,mDAtBJ,MAAA4O,EAAAA,eAMOzO,EANA,KAAA,CAAA,EAAA,eACLkb,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CACLhU,EAAAA,YAAA8b,EAAA,CACT,OAAKnb,EAAE,OAAA,WAAA,mDAGZ,EAAA,CAAA,EACE,EAAA,CAAA,UAAA,CAAA,EAAAX,EAAAA,YACM+b,EAAM,CACX,kBAAS,aACT,MAAM,OACN,QAAMpb,EAAE,QAAA,OAAA,4BAOL,QAAAqT,EAAA,QAAA,IAAA,CAAAhU,EAAAA,YAJF6b,EAIE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAHCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OAAA,iBAAA,CAAA,SAAA,EAAA,gGClBG,MAAAmd,GAAc5c,uBAAmB,ECSjC6c,GAAqC,CAChD,GAAG5qB,EACH,GAAI,GACJ,KAAM,QACN,QAAS,QACT,KAAM,kBACN,MAAO,QACP,OAAQ,QACR,OAAQ,CAAC,EACT,WAAY,EACd,EAGa6qB,GAA4Bzc,EAA0Bwc,EAAgB,ECPnFE,GAAe/qB,kBAAgB,CAC7B,KAAM,kBACN,MAAO,CACL,GAAG8qB,EACL,EACA,WAAY,CACV,QAAA/qB,EACF,EACA,MAAOE,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCqmB,EAAWnW,EAAAA,MACjBjS,OAAAA,EAAAA,MAAM,IAAM+B,EAAM,WAAa+qB,GAAuB,CAMhD,GAAA,CAEF,MAAMC,EAAW,KACR3E,EAAA,MAAQ2E,EAASD,CAAU,QAC7B3pB,GACP,QAAQ,MAAMA,CAAC,CACjB,CAAA,EACC,CACD,UAAW,EAAA,CACZ,EACM,CACL,MAAAiZ,EACA,SAAAgM,EAAA,QACA4E,EAAA,CAEJ,CACF,CAAC,mCAjDC5d,mBAMM,SAAA,mDALJ,MAIE4O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eAFCmb,EAAgB,CACjB,OAAAnb,EAAA,SAAA,iBAAA,CAAA,SAAA,EAAA,wCCHO,MAAA0d,GAAkBnd,uBAAuB,ECyDzCod,GAAmC,CAC9C,GAAGnrB,EACH,GAAI,GACJ,KAAM,OACN,QAAS,OACT,KAAM,iBACN,MAAO,QACP,OAAQ,QACR,KAAM,CACJ,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,EACA,CACE,KAAM,MACN,MAAO,IACP,KAAM,KACR,CACF,EACA,UAAW,GACX,aAAc,GACd,OAAQ,CAAC,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,UAAW,SAAS,EAC1G,WAAY,GACZ,qBAAsB,OACtB,aAAc,aACd,UAAW,MACX,WAAY,SACZ,YAAa,GACb,sBAAuB,GACvB,eAAgB,OAChB,iBAAkB,sBAClB,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,cAAe,GACf,mBAAoB,GACpB,yBAA0B,OAC1B,gBAAiB,OACjB,oBAAqB,OACrB,wBAAyB,CAAE,KAAM,OAAQ,MAAO,QAAS,KAAM,MAAO,EACtE,sBAAuB,CAAE,KAAM,OAAQ,MAAO,CAAA,CAAG,EACjD,oBAAqB,QACrB,YAAa,CACX,CACE,KAAM,MACN,UAAW,CACb,EACA,CACE,KAAM,OACN,UAAW,CACb,CACF,EACA,MAAO,CACL,CACE,mBAAoB,SACtB,EACA,CACE,mBAAoB,SACtB,CACF,EACA,iBAAkB,GAClB,QAAS,MACT,WAAY,MACZ,SAAU,KACV,UAAW,KACX,cAAe,CAAC,EAChB,YAAa,GACb,cAAe,aACf,gBAAiB,GACjB,eAAgB,EAChB,YAAa,QACb,WAAY,MACZ,4BAA6B,OAC7B,mBAAoB,GACpB,gBAAiB,UACjB,iBAAkB,EAClB,WAAY,EACZ,eAAgB,EAChB,OAAQ,GACR,SAAU,KACZ,EAGaorB,GAA2Bhd,EAA0B+c,EAAe,EAEpEE,GAAmB,CAAC,cAAe,QAAS,aAAa,EClHtEnE,GAAAA,IAAI,CACFC,GAAA,eACA0C,GAAA,SACAZ,GAAA,UACA5B,EAAA,eACAG,EAAA,gBACAsC,EAAA,iBACAxC,EAAA,gBACF,CAAC,EACD,MAAAgE,GAAevrB,kBAAgB,CAC7B,KAAM,iBACN,MAAO,CACL,GAAGqrB,EACL,EACA,WAAY,CACV,KAAA1D,GACA,QAAA5nB,GAAA,OACA6nB,EAAA,KACF,EACA,MAAO3nB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCsX,EAASpH,MAA8B,CAAA,CAAE,EACzCY,EAAaZ,MAA8B,CAAA,CAAE,EAC7C0X,EAAU1X,MAAI,EAAK,EACnB2X,EAAY,IAAM,CACtBD,EAAQ,MAAQ,EAAA,EAEZ9mB,EAAS/B,EAAAA,SAAS,KAAO,CAC7B,MAAO,CACL,KAAMiB,EAAM,UACZ,QAASA,EAAM,aACf,KAAM,QACR,EACA,QAAS,CACP,KAAMA,EAAM,YACZ,KAAMA,EAAM,YACZ,IAAKA,EAAM,WACX,SAAUA,EAAM,gBAChB,QAASA,EAAM,eACf,QAAS,CACP,WAAY,CACV,KAAM,GACN,MAAO,OACP,KAAM,ivCACN,SAAW,CACT6mB,GAAgB7mB,EAAM,kBAA4B,CACpD,CACF,EACA,WAAY,CACV,KAAM,GACN,MAAO,KACP,KAAM,8yBACN,SAAW,CACT4nB,EAAQ,MAAQ,EAClB,CACF,EACA,OAAQ,CACN,KAAM,GACN,MAAO,OACP,KAAM,glCACN,SAAW,CACTD,EAAAA,MAAO,KAAK,CACV,MAAO,OACP,QAAU3nB,EAAM,eAAA,CACjB,CACH,CACF,CACF,CACF,EACA,KAAM,CACJ,IAAKA,EAAM,QACX,OAAQA,EAAM,WACd,KAAMA,EAAM,SACZ,MAAOA,EAAM,UACb,aAAcA,EAAM,gBACtB,EACA,MAAOA,EAAM,OACb,OAAQ,CACN,KAAMA,EAAM,WACZ,OAAQA,EAAM,aACd,IAAKA,EAAM,UACX,KAAMA,EAAM,WACZ,UAAW,CACT,MAAOA,EAAM,oBACf,CACF,EACA,QAAS,CACP,QAAS,OACT,KAAMA,EAAM,YACZ,UAAYkT,GAAW,CACrB,MAAM5H,EAAM4H,EAAO,OACnB,IAAIjC,EAAY,GACZoY,EAAmBrpB,EAAM,iBACzBqpB,IAAqB,KACJA,EAAA,uBAErB,MAAMkC,EAAcvrB,EAAM,YAC1B,QAASyD,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAA+nB,EAAaD,EAAY9nB,CAAC,EAC1B,CAAE,iBAAkBgoB,GAAsBD,GAAc,CAAA,EACxD,CAAE,OAAAzD,EAAQ,WAAAC,EAAY,KAAAvqB,EAAM,MAAAgJ,EAAO,KAAA8J,IAAS2C,EAAOzP,CAAC,GAAK,GAC3DA,IAAM,IACRwN,GAAa,GAAGxT,UAELwT,GAAAS,GAEX+Z,GAAqBpC,EACrB,CACE,OAAAtB,EACA,KAAAtqB,EACA,MAAAgJ,EACA,WAAAuhB,EACA,EAAGA,EACH,EAAGvqB,EACH,EAAGgJ,EACH,GAAG8J,EACL,EACA,CACE,WAAY,GACZ,SAAU,EACZ,CAAA,EACWU,GAAA,OACf,CACO,OAAAA,CACT,EACA,UAAW,CACT,MAAOjR,EAAM,qBACf,CACF,EACA,MAAO,CACL,KAAM,WACN,KAAMhB,QAAM8R,CAAU,EACtB,UAAW,CACT,KAAM9Q,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,eACf,EACA,SAAU,CACR,UAAW,CACT,MAAOA,EAAM,mBACf,CACF,EACA,SAAU,CACR,KAAMA,EAAM,aACd,CACF,EACA,MAAOhB,QAAM0sB,CAAK,EAClB,OAAQ1sB,QAAMsY,CAAM,CACpB,EAAA,EAEI,CAAE,SAAAxE,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAEKmZ,EAAgB,CAAC3X,EAAY,CAAA,EAAI+Y,EAA6B,KAAU,CAExE,IAAAlB,EACA,GAAApoB,EAAM,sBAAwB,MAAO,CACjC,MAAAwQ,EAAiB8Y,EAAoBtpB,EAAM,sBAAiD,KACtFooB,EAAAlU,GAA+B3D,EAAMC,CAAc,CAAA,SACtDxQ,EAAM,sBAAwB,QAAS,CAC1C,MAAAwQ,EAAiB8Y,EAAoBtpB,EAAM,wBAAqD,KAC1FooB,EAAA9X,GAAiCC,EAAMC,CAAc,CACnE,CAEAM,EAAW,MAAQsX,EAAU,WAC7B,MAAMrX,EAAUqX,EAAU,QACpBmB,EAAO,CAAA,EACPje,EAAMyF,EAAQ,OACdwa,EAAcvrB,EAAM,YAC1B,QAASyD,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAA+nB,EAAaD,EAAY9nB,CAAC,EAC1B,CAAE,KAAAuM,EAAM,UAAA2b,GAAcH,GAAc,CAAA,EAC1C,IAAIlU,EAAS,CACX,KAAAtH,EACA,WAAY2b,EACZ,GAAG5a,EAAQtN,CAAC,CAAA,EAEVuM,IAAS,SACXsH,EAAS,CACP,GAAGA,EACH,WAAYtX,EAAM,WAClB,OAAQA,EAAM,OACd,UAAW,CACT,QAASA,EAAM,gBACjB,EACA,UAAW,CACT,MAAOA,EAAM,cACf,CAAA,GAGAgQ,IAAS,QACXsH,EAAS,CACP,GAAGA,EACH,SAAUtX,EAAM,QAAA,GAGpBupB,EAAK,KAAKjS,CAAM,CAClB,CACAA,EAAO,MAAQiS,CAAA,EAGXpB,EAAyB,CAAC5X,EAAY,CAAI,EAAAiZ,EAA8CF,EAA6B,KAAU,CAE7H,MAAAlB,EAAYlU,GAA+B3D,EAD1B+Y,EAAoBE,EAAwB,IACE,EAErE1Y,EAAW,MAAQsX,EAAU,WAC7B,MAAMrX,EAAUqX,EAAU,QACpBmB,EAAO,CAAA,EACPje,EAAMyF,EAAQ,OACdwa,EAAcvrB,EAAM,YAC1B,QAASyD,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAA+nB,EAAaD,EAAY9nB,CAAC,EAChC8lB,EAAK,KAAK,CACR,KAAMiC,GAAA,YAAAA,EAAY,KAClB,WAAYA,GAAA,YAAAA,EAAY,UACxB,GAAGza,EAAQtN,CAAC,CAAA,CACb,CACH,CACA6T,EAAO,MAAQiS,CAAA,EAIXtrB,QAAA,IAAM,CAAC+B,EAAM,KAAMA,EAAM,YAAaA,EAAM,WAAYA,EAAM,OAAQA,EAAM,iBAAkBA,EAAM,eAAgBA,EAAM,QAAQ,EAAG,CAAC,CAACyG,CAAK,IAAM,EAClJzG,EAAM,WAAa,UAAYhB,EAAAA,MAAM8T,CAAQ,IAAM,WACrDoV,EAAczhB,CAAK,CACrB,EACC,CACD,UAAW,GACX,KAAM,EAAA,CACP,EAEK,MAAAilB,EAAQ3sB,EAAAA,SAAS,IAAM,CAC3B,MAAM2sB,EAAQ1rB,EAAM,MACb0rB,OAAAA,GAAAA,YAAAA,EAAO,IAAKE,IACV,CACL,KAAM,QACN,UAAW,CACT,KAAM5rB,EAAM,mBACZ,UAAW,CACT,MAAOA,EAAM,wBACf,CACF,EACA,UAAW,CACT,MAAOA,EAAM,gBACb,UAAWyG,EAAe,CACjB,OAAAqR,GAAkB8T,EAAK,mBAA8BnlB,CAAK,CACnE,CACF,EACA,SAAU,CACR,UAAW,CACT,MAAOzG,EAAM,mBACf,CACF,CAAA,GAEH,CACF,EAEKtB,EAAUwR,MAAI,EAAK,EAEnB+C,EAAcZ,GAAerS,CAAK,EAGlC8e,EAAoB,SAAY,SACpC,GAAI,EAAA9e,EAAM,WAAa,WAAahB,EAAAA,MAAM8T,CAAQ,IAAM,UACpD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMd,IAClBiV,GAAc5Y,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,KAAM,EAAI,QAClClO,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAII2pB,EAAiBhT,GAAsBrV,CAAK,EAC5CsoB,EAAsB,SAAY,eACtC,GAAI,EAAAtoB,EAAM,WAAa,aAAehB,EAAAA,MAAM8T,CAAQ,IAAM,UACtD,GAAA,CACFpU,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMsU,IACd,IAAAhmB,IACAmN,GAAAF,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,UAAjB,YAAAE,EAA0B,QAAS,IACjCnN,EAAA,CACF,KAAM0R,EAAI,KAAK,KAAK,QAAQ,CAAC,EAC7B,MAAOA,EAAI,KAAK,KAAK,QAAQ,MAAM,CAAC,EAAE,IAAU8B,IACvC,CAAE,MAAOA,EAAI,MAAOA,CAAG,EAC/B,CAAA,GAGLsS,GAAuBvc,GAAAF,EAAAqI,GAAA,YAAAA,EAAK,OAAL,YAAArI,EAAW,OAAX,YAAAE,EAAiB,KAAMvJ,EAAG,EAAI,QAC9CjB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAGI+pB,EAAyB,IAAM,CAC/BzpB,EAAA,MAAM8T,CAAQ,IAAM,WACJwV,IACFxJ,IAAA,EAGdC,EAAc,IAAM,CACD0J,GAAA,EAGnBpY,EAAYN,GAAa/P,CAAK,EAE9B,CAAE,eAAA+S,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EACKuY,EAAQ3O,EAAU,QAAUjP,GAAM,CAEtC,MAAMwO,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQnhB,GAAA,YAAAA,EAAG,KAAM,CAAA,CACjD,EAEK,CAAE,WAAAkc,CAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EAEU,OAAAD,EAAA,CACT,GAAItd,EAAM,GACV,UAAWyoB,EACX,QAASzoB,EAAM,WAAA,CAChB,EAQD0P,GAAW1P,EAAO,CAChB,YAPkB,IAAM,CACxB,MAAM4P,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAC/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQ,GAAI,CAAA,EAK3C,YAAAxD,EACA,MAAAC,CAAA,CACD,EAEM,CACL,MAAA3E,EACA,OAAAvZ,EACA,MAAAke,EACA,QAAAtgB,EACA,QAAAkpB,EACA,UAAAC,CAAA,CAEJ,CACF,CAAC,sGAhaCxa,mBAwBM,SAAA,mDAvBJ,MAAA4O,EAAAA,eAOOzO,EAPA,KAAA,CAAA,EAAA,eACLkb,EAKE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAJCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OACC,iBAAO,CAAK,SAAA,EAAA,EAAA,WAAA,mDAGjB,EAAA,CAAA,EACE,EAAA,CAAA,UAAA,CAAA,EAAAX,EAAAA,YACM+b,EAAM,CACX,kBAAS,aACT,MAAM,OACN,QAAMpb,EAAE,QAAA,OAAA,4BAOH,QAAAqT,EAAA,QAAA,IAAA,CAAAhU,EAAAA,YALF6b,EAKE,CAAA,SAAAlb,EAAA,OAAA,EAAA,CAAA,QAJCqT,UAAQ,IAAM,CAAAhU,EAAAA,YACd8b,EAAgB,CACjB,OAAAnb,EAAA,OACC,iBAAO,CAAK,SAAA,EAAA,EAAA,WAAA,6GCnBZ,MAAAqe,GAAiB9d,uBAAsB,ECoBvC+d,GAA2B,CACtC,GAAG9rB,EACH,KAAM,KACN,QAAS,KACT,KAAM,aACN,MAAO,QACP,OAAQ,QACR,OAAQ,EACR,SAAU,OACV,WAAY,GACZ,WAAY,IACZ,MAAO,KACP,KAAM,WACN,YAAa,OACb,aAAc,MACd,YAAa,QACb,YAAa,MACb,gBAAiB,UACjB,gBAAiB,GACjB,WAAY,GACZ,KAAM,CAAC,CACT,EAEa+rB,GAAuB3d,EAA0B0d,EAAW,EAE5DE,GAAe,CAAC,OAAO,ECDpCC,GAAelsB,kBAAgB,CAC7B,KAAM,aACN,MAAO,CACL,GAAGgsB,EACL,EACA,MAAO/rB,EAAO,CACZ,MAAMqa,EAAQ5L,EAAsBzO,EAAO,CAAC,YAAY,CAAC,EACnD,CAAE,MAAAwc,CAAA,EAAU3d,EAAA,OAAOkQ,EAAe,CACtC,MAAO,OAAA,CACR,EACKmd,EAAcntB,EAAAA,SAAS,KACpB,CAML,MAAO,OACP,OAAQ,MAAA,EAEX,EAEKigB,EADYjP,GAAa/P,CAAK,EACZ,QAAS,IAAM,CAAA,CAAE,EACnC0e,EAASxO,MAA8B,CAAA,CAAE,EAC/CjS,EAAAA,MAAM,IAAM+B,EAAM,KAAOuQ,GAAmC,CAC1DmO,EAAO,MAAQnO,CAAA,EACd,CACD,UAAW,GACX,KAAM,EAAA,CACP,EACDb,GAAW1P,EAAO,CAChB,MAAAgf,CAAA,CACD,EACD,KAAM,CAAE,eAAArC,CAAA,EAAmB9d,EAAA,OAAOmQ,EAAc,CAG9C,eAAgB,CAAC1P,EAAamH,IAAe,EAAA,CAC9C,EAED,OAAAkW,EAAe3c,EAAM,GAAc,CACjC,KAAMA,EAAM,KACZ,MAAO0e,CAAA,CACR,EACM,CACL,MAAArE,EACA,MAAA2E,EACA,YAAAkN,EACA,MAAA1P,CAAA,CAEJ,CACF,CAAC,EChGc2P,GAAA,q2BCAAC,GAAA,2yBFSPC,GAAAtqB,IAAAuqB,EAAA,YAAA,iBAAA,EAAAvqB,EAAAA,IAAAwqB,EAAAA,aAAAxqB,aACsC+jB,EAAA,mBAAA,MAAA,CAAjC,MAAM,wBAAyB,KAAA,EAAA,CAAA,YACGA,EAAA,mBAAA,MAAA,CAAlC,MAAM,yBAA0B,KAAA,EAAA,CAAA,KAIRuG,GAAA,IAAAvG,EAAA,mBAAA,MAAA,CAAA,MAAA,2BAAA,KAAA,EAAA,CAAA,KACNuG,GAAA,IAAAvG,EAAA,mBAAA,MAAA,CAAA,MAAA,4BAAA,KAAA,EAAA,CAAA,kCAEnB0G,GAAM,CAAuB,MAAA,cACsB5L,GAAAyL,GAAA,IAAAvG,EAAA,mBAAA,MAAA,CAAA,MAAA,0CAInD2G,GAAM,CAAwB,MAAA,SACsBC,GAAAL,GAAA,IAAAvG,EAAA,mBAAA,MAAA,CAAA,MAAA,qDAMpBA,EAAA,mBAAA,MAAA,CAAjC,MAAM,wBAAyB,KAAA,EAAA,CAAA,YACGA,EAAA,mBAAA,MAAA,CAAlC,MAAM,yBAA0B,KAAA,EAAA,CAAA,qKAElC6G,GAAM,CAAA,IAAA,yCAhCH,SAAAhR,GAACnO,EAAaoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,QAAOvO,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAG,MAAK,cAAA,MAAA2O,EAAAA,eAAAzO,EAAA,KAAA,UAIpCoO,EAAI,CAAA,IAAAA,EAAA,CAAA,EAAA,IAAAle,IAAA8P,EAAA,OAAAA,EAAA,MAAA,GAAA9P,CAAA,EAAA,EAAA,oCAFM4P,EAAAA,mBAAA,MAAA,CACf,IAAK,EAAA,MAAA,iBAGU2O,EAAAA,eAAezO,EAAA,WAAA,CAAA,EAAA,GAC7B,iBACoCC,EAAAA,YAAAH,EAAAA,mBAAAwT,EAAAA,SAAA,CAAA,IAAA,GAAA,CACpCvT,GACAkT,GAAAC,uCAGJ,EAAA,CAAA,GAAAO,qBAAA,GAAA,EAAA,EAAAzT,EAAA,OAAA,aAAAC,EAAA,UAAA,EAAsBH,EAAAA,mBAAA,MAAA,CAAE,IAAK,EAAA,MAAA,YAC3B,MAAA2O,EAAAA,eAYMzO,EAZN,WAYM,CAAA,EAAA,CAPDsY,EAAA,mBAAA,MAAA3E,GAAA,CAAA2E,EAAA,mBACD,MAAoC0G,GAAA,CACpC5L,GAAAkF,EAAA,mBAAA,MAAA2G,GAAAG,EAAAA,gBAAApf,EAAA,KAAA,EAAA,CAAA,IAMJ,CAAA,CAAA,CACA,EACAqf,GACAC,GAAAC,KAEF,EAAA,CAAA,GAAA9L,qBAAA,GAAA,EAAA,EACEzT,EAAA,OAAA,cAAAC,EAAAA,iCAC0B,MAAfkf,GAAA,CAAA7G,EAAA,mBAAA,MAAAkH,GAAA,qGGjCJ,MAAAC,GAAalf,uDAAkB,ECsB/Bmf,GAAyB,CACpC,GAAI,GACJ,KAAM,YACN,MAAO,GACP,cAAe,OACf,WAAY,GACZ,MAAO,SACP,OAAQ,QACR,cAAe,SACf,eAAgB,SAChB,gBAAiB,OACjB,gBAAiB,GACjB,eAAgB,YAChB,QAAS,KACT,cAAe,CAAC,EAChB,UAAW,GACX,eAAgB,GAChB,SAAU,SACZ,EAEaC,GAAsB/e,EAA0B8e,EAAU,EAE1DE,GAAc,CAAC,WAAW,ECAvCC,GAAettB,kBAAgB,CAC7B,KAAM,YACN,WAAY,CAAA,OACV4nB,EAAA,KACF,EACA,MAAO,CACL,GAAGwF,EACL,EACA,MAAOntB,EAAO,CACZ,MAAMstB,EAAe,IAAM,SAAS,eAAe,gBAAgB,GAAK,SAAS,KAC3EC,EAAaxuB,EAAAA,SAAS,IAAM,CAChC,MAAMkJ,EAAWjI,EAAM,SAOhB,MAAA,CACL,cAPU,CACV,QAAS,GACT,IAAK,MACL,OAAQ,SACR,OAAQ,QAAA,EAGWiI,CAAQ,CAAA,CAC7B,CACD,EACKqS,EAAQta,EAAM,MACdua,EAASva,EAAM,OACfwa,EAAgBxa,EAAM,cACtBya,EAAiBza,EAAM,eACvBwtB,EAAazuB,WAAS,IAAM,WAAWub,CAAK,EAAI,WAAWE,CAAa,CAAC,EACzEiT,EAAc1uB,WAAS,IAAM,WAAWwb,CAAM,EAAI,WAAWE,CAAc,CAAC,EAE5EiT,EAAY3uB,WAAS,IAAM,GAAGC,EAAAA,MAAMwuB,CAAU,EAAI,MAAM,EAExDG,EAAc5uB,EAAAA,SAAS,IAAM,SAAS,KAAK,WAAW,EACtD6uB,EAAe7uB,EAAAA,SAAS,IAAM,SAAS,KAAK,YAAY,EACxD8uB,EAAe9uB,WAAS,IAAMC,EAAA,MAAM2uB,CAAW,EAAI3uB,EAAA,MAAMwuB,CAAU,CAAC,EACpEM,EAAgB/uB,WAAS,IAAMC,EAAA,MAAM4uB,CAAY,EAAI5uB,EAAA,MAAMyuB,CAAW,CAAC,EACvEM,EAAehvB,EAAAA,SAAS,KAAO,CACnC,MAAO,GAAGC,EAAAA,MAAM6uB,CAAY,MAC5B,OAAQ,GAAG7uB,EAAAA,MAAM8uB,CAAa,KAC9B,EAAA,EACIzT,EAAQ5L,EAAsBzO,CAAK,EACnCguB,EAAejvB,EAAAA,SAAS,KAAO,CACnC,GAAGC,EAAAA,MAAMqb,CAAK,EACd,gBAAiB5F,GAAazU,EAAM,gBAA2B,EAAI,EACnE,UAAW,SAAShB,EAAAA,MAAM6uB,CAAY,EAAI,WAAWvT,CAAK,KAAKtb,EAAAA,MAAM8uB,CAAa,EAAI,WAAWvT,CAAM,IACvG,EAAA,EACI0T,EAAclvB,EAAAA,SAAS,IAAMC,EAAM,MAAAwuB,CAAU,GAAK,CAAC,EACnDU,EAAcnvB,EAAA,SAAS,IAAMiB,EAAM,SAAS,EAC5CmuB,EAAgBpvB,EAAAA,SAAS,IAAM,CACnC,IAAIqvB,EAAY,aAChB,OAAIpvB,EAAAA,MAAMivB,CAAW,IAAgBG,GAAA,0BACjCpvB,EAAAA,MAAMkvB,CAAW,IAAgBE,GAAA,oBAC9BA,CAAA,CACR,EACKxG,EAAU1X,MAAI,EAAK,EACnBme,EAAUne,EAAAA,MACV,CAAE,aAAA4N,CAAA,EAAiBjf,EAAA,OAAOoQ,GAAe,CAG7C,aAAc,IAAM,EAAA,CACrB,EACKqf,EAAY,IAAM,CACtB1G,EAAQ,MAAQ,GAChBtmB,EAAAA,SAAS,IAAM,CACAwc,GAAA,CACd,CAAA,EAEG+J,EAAY,IAAM,CACtBD,EAAQ,MAAQ,EAAA,EAEZ2G,EAAO,IAAM,CACP1G,GAAA,EAEN2G,EAAW,IAAM,CACX3G,GAAA,EAGZ,OAAAnY,GAAW1P,EAAO,CAChB,UAAAsuB,CAAA,CACD,EAEM,CACL,QAAAD,EACA,aAAAN,EACA,aAAAC,EACA,aAAAV,EACA,WAAAC,EACA,UAAAG,EACA,YAAAQ,EACA,MAAA7T,EACA,QAAAuN,EACA,UAAA0G,EACA,KAAAC,EACA,SAAAC,EACA,YAAAP,EACA,cAAAE,CAAA,CAEJ,CACF,CAAC,+CA7IC9gB,mBAkCU,SAAA,EAhCP,OAAAI,EAAA,UAAA,EAA4BC,EAAA,YAAAkb,EAAA,CAC7B,aAAQpb,EAAA,aACP,cAASA,EAAA,cACT,SAAQ,GACR,QAAOA,EAAA,QACP,OAAA,KACA,MAAKA,eAAEA,EAAU,YAAA,OAAAA,EAAA,UACjB,eAAQA,EAAA,eACR,MAAgByO,EAAAA,eAAAzO,EAAA,UAAA,EAAA,KAAAA,EAAA,wBAcjB,EAAAihB,cAAA,CAAA,QAAU5N,UAAC,IAAS,CAAciF,EAAAA,mBAAA,MAAA,CAAE,MAAK,UAAA,IAAA,UACvC,MAOM7J,EAAAA,eAAAzO,EAAA,YAAA,CAAA,EAAA,sBAPqB,MAAE,CAAA,MAAA,iCAC3BA,EAKE,YAAA,CAAA,EAAA,EAHOC,EAAAA,UAAA,EAAA,EAASH,EAAY,mBAAAwT,WAAA,KAAAC,EAAA,WAAAvT,EAAA,cAAA,CAAAkhB,EAAAvnB,KAEpBsG,EAAAA,UAAS,EAAAC,cAAAihB,EAAAA,wBAAAD,EAAA,IAAA,EAAAE,aAAA,CAAA,IAAAF,EAAA,GAAAvnB,iCAlBA,EAAA,CAAA,EAAA,UACrB,KAAA,QAAA,GACG0Z,EAAK,QAAA,IAAA,CAAAiF,EAAAA,mBAAwB,MAAa,CAAA,MAAmB7J,EAAAA,eAAU,CAAA,SAAAzO,EAAA,wOCdnE,MAAAqhB,GAAY9gB,uDAAiB,ECwB7B+gB,GAAuB,CAClC,GAAG9uB,EACH,qBAAsB,MACtB,KAAM,WACN,KAAM,MACN,QAAS,MACT,MAAO,QACP,OAAQ,QACR,YAAa,OACb,gBAAiB,UACjB,eAAgB,UAChB,mBAAoB,GACpB,yBAA0B,GAC1B,SAAU,OACV,aAAc,OACd,cAAe,IACf,MAAO,GACP,UAAW,EACX,SAAU,CAAC,EACX,iBAAkB,MAClB,KAAM,CACJ,CACE,MAAO,KACT,EACA,CACE,MAAO,KACT,EACA,CACE,MAAO,KACT,CACF,EACA,cAAe,aACf,kBAAmB,YACrB,EAEa+uB,GAAqB3gB,EAA0B0gB,EAAS,EAExDE,GAAa,CAAC,WAAW,ECpBtCC,GAAelvB,kBAAgB,CAC7B,KAAM,WACN,MAAO,CACL,GAAGgvB,EACL,EACA,MAAO/uB,EAAO,OACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnCkvB,EAAYhf,MAAI,CAAC,EACvBjS,EAAAA,MAAM,IAAM+B,EAAM,UAAYV,GAAQ,CACpC4vB,EAAU,MAAQ5vB,CAAA,EACjB,CACD,UAAW,EAAA,CACZ,EACK,MAAAof,EAASxO,MAA8B,CAAA,CAAE,EAC/CjS,EAAAA,MAAM,IAAM+B,EAAM,KAAOuQ,GAAmC,CAC1DmO,EAAO,MAAQnO,CAAA,EACd,CACD,UAAW,GACX,KAAM,EAAA,CACP,EACD,MAAM4e,EAAYhoB,GAAkB+nB,EAAU,QAAU/nB,EAClDya,EAAU1R,EAAAA,IAAIlQ,EAAM,OAAUhB,EAAAA,MAAM0f,CAAM,EAAE,CAAC,KAAK1f,EAAAA,EAAAA,MAAM0f,CAAM,EAAE,CAAC,IAAf1f,YAAAA,EAAkB,QAAU,EAAE,EAEhFqR,EAAYN,GAAa/P,CAAK,EAC9B,CAAE,eAAA2c,CAAA,EAAmB9d,EAAA,OAAOmQ,EAAc,CAG9C,eAAgB,CAAC1P,EAAamH,IAAe,EAAA,CAC9C,EAEDkW,EAAe3c,EAAM,GAAc,CACjC,MAAO4hB,EACP,UAAAsN,CAAA,CACD,EAED,KAAM,CAAE,gBAAAlR,CAAA,EAAoBnf,EAAA,OAAOsQ,GAAc,CAE/C,gBAAiB,IAAM,EAAA,CACxB,EAEKigB,EAAY/e,EAAU,YAAa,CAACgf,EAA0BloB,IAAkB,CAChFA,IAAUnI,QAAMkwB,CAAS,IACnBtN,EAAA,OAAQyN,GAAA,YAAAA,EAAK,QAAS,GAC9BH,EAAU,MAAQ/nB,EACF6W,IAClB,CACD,EACD,OAAAtO,GAAW1P,EAAO,CAChB,UAAAovB,CAAA,CACD,EACM,CACL,MAAA/U,EACA,UAAA6U,EACA,SAAAC,EACA,UAAAC,EACA,OAAA1Q,EACA,aAAAjK,EAAA,CAEJ,CACF,CAAC,uBArGW,SAAAkH,GAACnO,EAAWoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,QAAOvO,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,YAClC,MAgCM2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,CA9BEsY,EAAAA,mBAAA,MAAA,CAAA,MAAA,cAAuD,MAAA7J,EAAAA,eAAA,CAAA,SAAAzO,EAAA,YAAiF,WAAAA,EAAA,cAAA,eAAAA,EAAA,oEAQtI,EAAK,EAAAF,EAAA,mBAAAwT,WAAA,KAAAC,EAAA,WAAAvT,EAAA,OAAA,CAAA6hB,EAAAloB,KACLsG,EAAA,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,YAAuE2O,EAAAA,eAAS,CAA+D,QAAA,OAAAzO,EAAA,uBAAA,MAAAA,EAAA,SAAgIrG,KAAgB,eAAaqG,EAAA,SAA6C,gBAAAA,EAAA,SAAArG,CAAgB,iBAAgBqG,EAAY,yBAAA,EAAA,EAAAA,EAAA,aAAAA,EAAA,mBAAA,EAAA,EAAA,YAA+BA,EAAa,mBAAA,MAAAA,EAAA,aAAA,KAAA,aAAAA,EAAA,mBAAA,SAAAA,EAAA,aAAA,KAStb,WAAUA,EAAA,aAAA,CAAA,QAGX,QAOM8hB,EAAA,cAAA3M,GAAAnV,EAAA,UAAA6hB,EAAAloB,CAAA,EAAA,CAAA,UAAA,MAAA,CAAA,CAAA,EAAA,CALE2e,EAAAA,mBAAA,MAAA,CAAA,MAAA,oDAIJ,0BAAS,CAAAtY,EAAA,mBAAA,aAAAA,EAAA,SAAArG,CAAA,EAAAqG,EAAA,eAAA,gBAAA,EAAA,CAAA,yDC7BR,MAAA+hB,GAAWxhB,uDAAgB,ECW3ByhB,GAAyB,CACpC,GAAGxvB,EACH,KAAM,KACN,QAAS,KACT,KAAM,YACN,MAAO,QACP,OAAQ,QACR,OAAQ,GACR,OAAQ,OACR,KAAM,GACN,SAAU,EACZ,EAEayvB,GAAsBrhB,EAA0BohB,EAAU,ECLvEE,GAAe3vB,kBAAgB,CAC7B,KAAM,YACN,MAAO,CACL,GAAG0vB,EACL,EACA,MAAOzvB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC2vB,EAAW5wB,EAAAA,SAAS,IAAM0V,GAAazU,EAAM,MAAgB,CAAC,EAC9D,CAAE,SAAA8S,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAqBM,MAAA,CACL,MAAAsL,EACA,SAAAsV,EACA,QAvBc,IAAM,CAEpB,GAAI,CAAC3vB,EAAM,UAAY,CAACA,EAAM,KAAM,OAC9B,MAAAif,EAAYjf,EAAM,UAAY,GAC9Bkf,EAAUrK,GAAW7V,EAAAA,MAAM8T,CAAQ,EAAGmM,CAAQ,EAE9CE,EAAOnf,EAAM,KACnB,IAAIgT,EAAMmM,GAAQD,EAClBlM,EAAMtB,GAAmBsB,CAAG,EAC5B,MAAM3K,EAASrI,EAAM,OACjBqI,GAAU,MAAQA,IAAW,KAC7BA,IAAW,QACN,OAAA,KAAK2K,EAAK,IAAO3K,CAAiB,EAEzC,OAAO,OAAO,YAAY,CACxB,KAAM,WACN,IAAK8W,GACJ,GAAG,EACR,CAKA,CAEJ,CACF,CAAC,+BAzDC3R,EAKEoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,qCAJa,EAAA1O,EAAA,mBAAA,MAAA,CACZ,IAAK,EAEL,MAAK2O,EAAAA,eAAAzO,EAAA,KAAA,EAAA,IAAAA,EAAA,mBAER,CAMM,IAAAoO,EAAA,CAAA,EAAA,IAAAle,IAAA8P,EAAA,SAAAA,EAAA,QAAA,GAAA9P,CAAA,EAAA,EAAA,KAAA,GAAA6P,EAAA,IAAAE,EAAAA,UALqB,EAAAH,EAAA,mBAAA,MAAA,CACxB,IAAK,EAEP,MAAA,oBAAA,MAAA2O,EAAAA,eAAAzO,EAAA,KAAA,iBCTU,MAAAoiB,GAAY7hB,uDAAiB,ECS7B8hB,GAA2B,CACtC,GAAG7vB,EACH,KAAM,KACN,QAAS,KACT,KAAM,aACN,MAAO,QACP,OAAQ,QACR,KAAM,GACN,SAAU,KACZ,EAEa8vB,GAAuB1hB,EAA0ByhB,EAAW,ECFzEE,GAAehwB,kBAAgB,CAC7B,KAAM,aACN,MAAO,CACL,GAAG+vB,EACL,EACA,MAAO9vB,EAAO,CACN,MAAAqa,EAAQ5L,EAAsBzO,CAAK,EACnC,CAAE,kBAAA6S,CAAA,EAAsBhU,EAAA,OAAOkQ,EAAe,CAClD,kBAAmB,EAAA,CACpB,EACKihB,EAASjxB,EAAAA,SAAS,IAAM,CACxB,IAAAkxB,EAAOve,GAAmB1R,EAAM,IAAc,EAClD,GAAIA,EAAM,WAAa,OAASiwB,GAAQ,KAAM,CACxC,IAAAC,EAAYlxB,QAAM6T,CAAiB,EACnCqd,EAAUA,EAAU,OAAS,CAAC,IAAM,IACzBA,GAAA,YAEAA,GAAA,aAGfD,EAAO,GADQxgB,IAAWygB,cACGD,GAC/B,CACO,OAAAA,CAAA,CACR,EACM,MAAA,CACL,MAAA5V,EACA,OAAA2V,CAAA,CAEJ,CACF,CAAC,+BAhDCxiB,EAIEoO,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,gCAHY1O,EAAAA,mBAAA,SAAA,CACX,IAAK,EAAA,IAAAE,EAAA,8BAGRA,EAMM,KAAA,CAAA,EAAA,KAAA,GAAAD,EAAA,IAAAE,EAAAA,UALsB,EAAAH,EAAA,mBAAA,MAAA,CACzB,IAAK,EAEP,MAAA,qBAAA,MAAA2O,EAAAA,eAAAzO,EAAA,KAAA,mBCRU,MAAA2iB,GAAapiB,uDAAkB,EC4C/BqiB,GAAyB,CACpC,GAAGpwB,EACH,OAAQ,EACR,KAAM,KACN,QAAS,KACT,KAAM,YACN,MAAO,QACP,OAAQ,QACR,SAAU,GACV,eAAgB,OAChB,SAAU,OACV,SAAU,GACV,KAAM,UACN,iBAAkB,IAClB,WAAY,IACZ,gBAAiB,EACjB,QAAS,EACT,eAAgB,GAChB,UAAW,GACX,OAAQ,GACR,oBAAqB,GACrB,YAAa,GACb,mBAAoB,cACpB,mBAAoB,GACpB,YAAa,GACb,eAAgB,GAChB,qBAAsB,QACtB,WAAY,CAAC,CACX,MAAO,GACP,KAAM,GACN,OAAQ,GACR,MAAO,EAAA,CACR,EACD,kBAAmB,IACnB,QAAS,CACP,CACE,MAAO,KACP,UAAW,MACb,EACA,CACE,MAAO,KACP,UAAW,KACb,EACA,CACE,MAAO,KACP,UAAW,SACb,CACF,EACA,KAAM,CACJ,CACE,KAAM,KACN,IAAK,GACL,QAAS,OACX,EACA,CACE,KAAM,KACN,IAAK,GACL,QAAS,OACX,CACF,EACA,cAAe,CACb,UAAW,QACX,OAAQ,IACR,MAAO,GACT,CACF,EAGaqwB,GAAsBjiB,EAA0BgiB,EAAU,EAE1DE,GAAc,CAAC,QAAS,cAAe,aAAa,ECqCjEC,GAAexwB,kBAAgB,CAC7B,KAAM,YACN,WAAY,CACV,SAAA0e,GAAA,OACA4D,EAAA,MAAA,eACA+D,EAAA,cAAA,OACAoK,EAAA,MAAA,cACAC,EAAA,aAAA,iBACAC,EAAA,gBAAA,kBACAC,EAAA,gBACF,EACA,MAAO,CACL,GAAGN,EACL,EACA,MAAOrwB,EAAO,CAAE,OAAAsc,GAAU,CAClB,MAAAjC,EAAQ5L,EAAsBzO,CAAK,EACnC4wB,EAAS7xB,EAAAA,SAAS,IAAM,CAC5B,GAAIiB,EAAM,eACR,OAAQA,EAAM,KAAM,CAClB,IAAK,QACI,MAAA,IACT,IAAK,SACI,MAAA,KACT,QACS,MAAA,IACX,KAEA,QAAQA,EAAM,KAAM,CAClB,IAAK,QACI,MAAA,IACT,IAAK,SACI,MAAA,IACT,QACS,MAAA,GACX,CACF,CACD,EACK4Q,EAAI7R,EAAA,SAAS,IAAMiB,EAAM,OAAO,EAChC6Q,EAAI9R,WAAS,IAAM,WAAWiB,EAAM,MAAgB,EAAIhB,EAAAA,MAAM4xB,CAAM,CAAC,EACrEC,EAAY3gB,MAA+B,CAAA,CAAE,EAC7C4gB,EAAe5gB,MAA+B,CAAA,CAAE,EAChD6gB,EAAe7gB,MAA+B,CAAA,CAAE,EAChD8gB,EAAkB9gB,MAA+B,CAAA,CAAE,EACnD+gB,EAAQ/gB,MAAI,CAAC,EACbghB,EAAUhhB,MAAI,CAAC,EACfihB,EAAWpyB,EAAA,SAAS,IAAMiB,EAAM,kBAA4B,EAC5DoxB,EAAsBC,WAAS,CAAA,CAAE,EACjCC,EAAwB,CAACC,EAAsC,KAAO,CAC1E,GAAI,MAAM,QAAQA,CAAQ,GAAKA,EAAS,OAAS,EAAG,CAClD,MAAMjmB,EAAMimB,EAAS,OACfC,EAAkBxxB,EAAM,gBAG9B,QAASyD,EAAI,EAAGA,EAAI6H,EAAK7H,IAAK,CACtB,MAAAyd,EAASqQ,EAAS9tB,CAAC,EACrBA,EAAI+tB,EACNtQ,EAAO,MAAQ,OAEfA,EAAO,MAAQ,GAEX,KAAA,CACJ,UAAAuQ,EAAY,SACZ,UAAAC,EACA,UAAAC,GACA,MAAAC,GACA,YAAAC,GACA,gBAAAC,GACA,gBAAAC,EACE,EAAA7Q,EACA2Q,KACFT,EAAoB,KAAKO,EAAS,EAClCzQ,EAAO,wBAA0B,GACjCA,EAAO,yBAA2B,GAClCA,EAAO,qBAAuB,GAC9BA,EAAO,SAAW,CAACza,GAAO4M,KAAWA,GAAOse,EAAS,EAAE,SAAS,EAAE,YAAY,EAAE,SAASlrB,GAAM,YAAa,CAAA,GAI9Gya,EAAO,iBAAmB,KAAO,CAC/B,MAAO,CACL,QAAS,aACT,cAAe,SACf,SAAUlhB,EAAM,eAChB,WAAYA,EAAM,iBAClB,UAAW8xB,IAAmB,SAC9B,MAAOC,GACP,kBAAmB/xB,EAAM,WAC3B,CAAA,GAGKkhB,EAAA,WAAa,CAAC7N,GAAQsD,MAAc,CACzC,MAAO,CACL,UAAW8a,EACX,MAAOC,EACP,gBAAiB1xB,EAAM,oBACvB,kBAAmBA,EAAM,WAC3B,EACA,MAAO,CACL,UAAWhB,EAAAA,MAAMgzB,CAAW,IAAMrb,IAAY3W,EAAM,cACtD,EACA,QAASqQ,EAAU,QAAS,IAAM,CAChC,MAAMT,GAAK5P,EAAM,GACXuiB,GAAQxP,EAAenD,EAAE,EACtByD,GAAA,CACP,UAAAse,GACA,MAAAC,GACA,GAAGve,EAAA,EAGLsJ,EAAe/M,GAAI,CAAE,GAAG2S,GAAO,OAAQlP,GAAQ,CAAA,CAChD,CAAA,GAEC,MAAM,QAAQ6N,EAAO,QAAQ,GAC/BoQ,EAAsBpQ,EAAO,QAAQ,CAEzC,CACF,CAAA,EAEI+Q,EAAgB,CAAC/H,EAAqC,MAEtDlqB,EAAM,UAERkqB,EAAQ,QAAQ,CACd,MAAO,KACP,UAAW,MACX,MAAO,QAAA,CACR,EAGClqB,EAAM,aACRkqB,EAAQ,KAAK,CACX,MAAO,KACP,UAAW,SACX,MAAOlqB,EAAM,iBAAA,CACd,EAEHsxB,EAAsBpH,CAAO,EACtBA,GAETjsB,EAAAA,MAAM,IAAM,CACV+B,EAAM,QACNA,EAAM,SACNA,EAAM,YACNA,EAAM,gBACNA,EAAM,kBACNA,EAAM,oBACNA,EAAM,WAAA,EACL,IAAM,CACP6wB,EAAU,MAAQoB,EAAcC,GAAU,UAAAlyB,EAAM,OAAiB,CAAC,CAAA,EACjE,CACD,UAAW,GACX,KAAM,EAAA,CACP,EACK/B,QAAA,IAAM,CAAC+B,EAAM,KAAMA,EAAM,QAAQ,EAAG,CAAC,CAACuQ,EAAMoO,CAAQ,IAAM,CAC1DA,IAAa,WACjBmS,EAAa,MAAQvgB,EAAA,EACpB,CACD,UAAW,EAAA,CACZ,EACK,MAAA4hB,EAAmBjiB,MAAI,CAAA,CAAE,EACzBkiB,EAA+B/R,GAAyC,CACxE,GAAA,MAAM,QAAQA,CAAU,EAAG,CAC7B,MAAMjM,EAAUiM,EAAW,OACrB1M,EAAOyd,EACPvd,EAAUF,EAAK,OACf0e,EAAkD,CAAA,EACxD,QAAS5uB,EAAI,EAAGA,EAAI2Q,EAAS3Q,IAAK,CAC1B,MAAA4P,GAASgN,EAAW5c,CAAC,EAC3B,QAASyO,GAAI,EAAGA,GAAI2B,EAAS3B,KAAK,CAC1B,MAAA5S,GAAMqU,EAAKzB,EAAC,EACd,GAAAmgB,EAAiB/yB,EAAG,EACtB+yB,EAAiB/yB,EAAG,EAAE,IAAI+T,GAAO/T,EAAG,CAAC,MAChC,CACC,MAAAmR,OAAU,IACZA,GAAA,IAAI4C,GAAO/T,EAAG,CAAC,EACnB+yB,EAAiB/yB,EAAG,EAAImR,EAC1B,CACF,CACF,CACA,MAAM6hB,EAA0E,CAAA,EAChF,UAAWhzB,KAAO+yB,EAChB,GAAI,OAAO,UAAU,eAAe,KAAKA,EAAkB/yB,CAAG,EAAG,CACzD,MAAAizB,GAAaF,EAAiB/yB,CAAG,EACjC0I,GAAU,MAAM,KAAKuqB,EAAU,EACnBD,EAAAhzB,CAAG,EAAI0I,GAAQ,IAAKlH,KAAY,CAAE,MAAOA,GAAQ,MAAOA,EAAA,EAAS,CACrF,CAEFqxB,EAAiB,MAAQG,CAC3B,CAAA,EAEIr0B,QAAA,IAAM,CAAC+B,EAAM,UAAW6wB,EAAU,MAAOC,EAAa,KAAK,EAAG,IAAM,CAClE,MAAAS,EAAWvyB,QAAM6xB,CAAS,EAC1B2B,EAAcxzB,QAAM8xB,CAAY,EAEtC,GADAsB,EAA4BI,CAAW,EACnCxyB,EAAM,UAAW,CACb,KAAA,CAAE,QAAAkqB,EAAS,WAAA7J,CAAA,EAAeoS,EAAmBP,aAAUX,CAAQ,EAAGW,GAAAA,UAAUM,CAAW,CAAC,EAC9FzB,EAAa,MAAQ7G,EACrB8G,EAAgB,MAAQ3Q,CAAA,MAExB0Q,EAAa,MAAQQ,EACrBP,EAAgB,MAAQwB,CAC1B,EACC,CACD,UAAW,GACX,MAAO,MAAA,CACR,EACK,MAAAC,EAAqB,CAACvI,EAAkC7J,IAAwC,CAC9F,MAAAqS,EAAexI,EAAQ,CAAC,EACxBqH,EAAW,CAAC,CAChB,MAAOmB,EAAa,MACpB,UAAW,OACX,IAAK,OACL,MAAO,QAAA,CACR,EACD,QAASjvB,EAAI,EAAGA,EAAI4c,EAAW,OAAQ5c,IAAK,CACpC,MAAA8M,EAAO8P,EAAW5c,CAAC,EACnBkuB,GAAY,OAASluB,EAAI,GAC/B8tB,EAAS,KAAK,CACZ,MAAOhhB,EAAKmiB,EAAa,SAAS,EAClC,UAAAf,GACA,IAAKA,GACL,MAAO,QAAA,CACR,CACH,CACA,MAAMa,EAAc,CAAA,EACpB,QAAS/uB,EAAI,EAAGA,EAAIymB,EAAQ,OAAQzmB,IAAK,CACjC,MAAAyd,EAASgJ,EAAQzmB,CAAC,EAClBkvB,GAAQ,CAAE,KAAMzR,EAAO,KAAM,EACnC,QAAShP,GAAI,EAAGA,GAAImO,EAAW,OAAQnO,KAAK,CACpC,MAAA3B,GAAO8P,EAAWnO,EAAC,EACzBygB,GAAM,MAAMzgB,GAAI,GAAG,EAAI3B,GAAK2Q,EAAO,SAAS,CAC9C,CACAsR,EAAY,KAAKG,EAAK,CACxB,CACO,MAAA,CACL,QAASpB,EACT,WAAYiB,CAAA,CACd,EAEII,EAAiB1iB,MAAY,EAAE,EAC/B+C,EAAcZ,GAAerS,CAAK,EAClCtB,EAAUwR,MAAI,EAAK,EACnB4O,EAAoB,MAAO+T,EAAwB,KAAS,OAC5D,GAAA,CACEA,IAAcn0B,EAAQ,MAAQ,IAElC,IAAIwU,EAAS,CAAA,EACTlU,EAAAA,MAAM4zB,CAAc,IACf1f,EAAA,eAAiBlU,QAAM4zB,CAAc,GAG1C5yB,EAAM,iBACCkT,EAAA,CACP,QAASlU,QAAMkyB,CAAO,EACtB,SAAUlyB,QAAMmyB,CAAQ,EACxB,MAAO,IACP,GAAGje,CAAA,GAGD,MAAAa,EAAM,MAAMd,EAAYC,CAAM,EAC9B,CAAE,KAAAiX,EAAO,GAAI,MAAO2I,EAAa,CAAM,IAAAzjB,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAQ,GAChE4hB,EAAM,MAAQ6B,EACV,MAAM,QAAQ3I,CAAI,IACpB2G,EAAa,MAAQ3G,SAEhB/oB,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAEIq0B,EAAc,CAAC,CAAE,QAAAC,CAAQ,EAAwBC,EAAUC,IAAW,CAE1E,GADAhC,EAAQ,MAAQ8B,EACZE,GAAU,OAAO,KAAKA,CAAM,EAAE,OAAS,EAAG,CACtC,KAAA,CAAE,MAAAC,EAAO,MAAAC,CAAU,EAAAF,EAKnBG,EAJM,CACV,OAAQ,MACR,QAAS,MAAA,EAEYD,CAAK,EACxBD,GAAS,MAAQE,GAAc,OAClBT,EAAA,MAAQO,EAAQ,IAAME,EACrCnC,EAAQ,MAAQ,EAEpB,CACAnS,GAAY,EAAK,CAAA,EAEbuU,EAAav0B,EAAAA,SAAS,IAAM,CAChC,MAAMw0B,EAASvzB,EAAM,OACfiI,EAAW,CAACjI,EAAM,kBAAkB,EAC1C,OAAOA,EAAM,gBAAkB,CAC7B,OAAAuzB,EACA,SAAAtrB,EACA,MAAOjJ,QAAMiyB,CAAK,EAClB,QAASjyB,QAAMkyB,CAAO,EACtB,SAAUlyB,QAAMmyB,CAAQ,EACxB,gBAAiB,EAAA,CACnB,CACD,EACKqC,EAAiB/sB,GACjB,CAACA,GAAU,EAAU,IACrB,CAACA,GAAU,EAAU,IAClBA,EAGH8Z,EAAW,CAAC9Z,EAAwBlC,IACpCA,GAAU,MAAQA,IAAW,GAAWkC,EAChC,CACV,MAAOyK,GACP,WAAYG,GACZ,SAAUA,GACV,QAASmiB,CAAA,EAEAjvB,CAAM,EAAEkC,CAAK,GAAK,GAEzB+Z,EAAgB,CAAC/Z,EAAwBlC,IAAmB,CAC1D,MAAA6M,EAAS,WAAW3K,EAAQ,EAAE,EACpC,GAAIlC,IAAW,WACN,MAAA,GAET,OAAQ,GAAM,CACZ,KAAK6M,GAAU,EACN,MAAA,OACT,KAAKA,EAAS,EACL,MAAA,QACX,CAAA,EAGIf,EAAYN,GAAa/P,CAAK,EAE9B,CAAE,SAAA8S,CAAA,EAAajU,EAAA,OAAOkQ,EAAe,CACzC,SAAU,QAAA,CACX,EAEK,CAAE,eAAAgE,EAAgB,eAAA4J,GAAmB9d,EAAAA,OAAOmQ,EAAc,CAG9D,eAAiB1P,GAAgB,GAGjC,eAAgB,CAACA,EAAamH,IAAe,EAAA,CAC9C,EAEK0hB,EAAyB,CAACsL,EAAsB,CAAA,EAAIC,EAAoC,CAAA,IAAO,CACnG,MAAMnC,EAAWkC,EAAY,IAAKvS,IAAoB,CAAE,MAAOA,EAAQ,UAAWA,EAAQ,IAAKA,CAAA,EAAS,EAC9F2P,EAAA,MAAQoB,EAAcV,CAAQ,EACxCT,EAAa,MAAQ4C,CAAA,EAIjBzJ,EAAgBlS,GAAiB/X,CAAK,EACtCsoB,EAAsB,SAAY,aAClC,GAAA,CACF5pB,EAAQ,MAAQ,GACV,MAAAqV,EAAM,MAAMkW,IAClB9B,GAAuB7Y,GAAAD,EAAA0E,GAAA,YAAAA,EAAK,OAAL,YAAA1E,EAAW,OAAX,YAAAC,EAAiB,SAAS5D,GAAA8D,EAAAuE,GAAA,YAAAA,EAAK,OAAL,YAAAvE,EAAW,OAAX,YAAA9D,EAAiB,IAAI,QAC/DtK,GACP,QAAQ,MAAMA,CAAC,CAAA,QACf,CACA1C,EAAQ,MAAQ,EAClB,CAAA,EAEIszB,EAAc9hB,EAAAA,IAAI,EAAE,EAEpByjB,GAAY,CAACtgB,EAAQlM,KAAW,CACpC,QAASkJ,EAAU,WAAY,IAAM,CACnC,MAAMT,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAE/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQlP,EAAQ,EAC/C2e,EAAY,MAAQ7qB,CAAA,CACrB,CAAA,GAGG4X,GAAc,CAAC8T,EAAwB,KAAS,CAChD,GAAA7zB,EAAA,MAAM8T,CAAQ,IAAM,SACxB,OAAQ9S,EAAM,SAAU,CACtB,IAAK,UACH8e,EAAkB+T,CAAY,EAC9B,MACF,IAAK,YACiBvK,IACpB,KACJ,CAAA,EASF5Y,GAAW1P,EAAO,CAChB,YAPkB,IAAM,CACxB,MAAM4P,EAAK5P,EAAM,GACXuiB,EAAQxP,EAAenD,CAAE,EAC/B+M,EAAe/M,EAAI,CAAE,GAAG2S,EAAO,OAAQ,GAAI,CAAA,EAK3C,YAAAxD,EAAA,CACD,EACK,MAAA6U,GAAc70B,EAAAA,SAAS,IAAM,CAC3B,MAAAmrB,EAAUlrB,QAAM+xB,CAAY,EAC5B6C,EAAc,CAAA,EACpB,IAAIC,EAAiB,EACrB,QAASpwB,EAAI,EAAGA,EAAIymB,EAAQ,OAAQzmB,IAAK,CACjC,MAAAyd,EAASgJ,EAAQzmB,CAAC,EAClB,CAAE,YAAAqwB,CAAgB,EAAA5S,EACpBlhB,EAAM,UAAYyD,IAAM,EAC1BmwB,EAAY,KAAK,CACf,GAAG1S,EACH,MAAO,IAAA,CACR,EACQ4S,GACTF,EAAY,KAAK,CACf,GAAG1S,EACH,MAAOzd,EACP,MAAO,CAAA,CACR,EACDowB,KAEAD,EAAY,KAAK,CACf,GAAG1S,CAAA,CACJ,CAEL,CAEA,GAAI2S,IAAmB,EAAG,MAAO,GAC7B,IAAAE,EAAU/0B,QAAMgyB,CAAe,EACnC,GAAIhxB,EAAM,eAAgB,CACxB,MAAMg0B,GAASh1B,QAAMkyB,CAAO,EAAI,GAAKlyB,EAAAA,MAAMmyB,CAAQ,EAC7C8C,EAAMD,EAAQh1B,EAAA,MAAMmyB,CAAQ,EACxB4C,EAAAA,EAAQ,MAAMC,EAAOC,CAAG,CACpC,CACA,QAASxwB,EAAI,EAAGA,EAAImwB,EAAY,OAAQnwB,IAAK,CACrC,MAAAywB,EAAUN,EAAYnwB,CAAC,EAC7B,IAAIwtB,EAAgB,EACd,KAAA,CAAE,YAAA6C,GAAa,UAAAnC,EAAc,EAAAuC,EACnC,GAAIJ,KAAgB,GAAM,CACxB,QAAS5hB,GAAI,EAAGA,GAAI6hB,EAAQ,OAAQ7hB,KAAK,CAEjC,MAAAiiB,GAAM,CADGJ,EAAQ7hB,EAAC,EACJyf,EAAS,EACxB,MAAMwC,EAAG,IACZlD,EAAQ,IAAImD,GAAAA,IAAInD,CAAK,EAAE,IAAIkD,EAAG,EAAE,WAEpC,CACAD,EAAQ,MAAQjD,CAClB,CACF,CACO2C,OAAAA,CAAA,CACR,EAEK,CAAE,WAAAtW,EAAA,EAAeze,EAAA,OAAOoQ,GAAe,CAG3C,WAAY,CAAC,CAAE,GAAAW,EAAI,QAAA4N,EAAS,UAAAD,KAAmC,EAAA,CAChE,EAEU,OAAAD,GAAA,CACT,GAAItd,EAAM,GACV,UAAW+e,GACX,QAAS/e,EAAM,WAAA,CAChB,EAEMsc,EAAA,CACL,YAAAyC,EAAA,CACD,EAuDM,CACL,EAAAnO,EACA,EAAAC,EACA,MAAAwJ,EACA,UAAAsZ,GACA,WAAAL,EACA,SAAA/S,EACA,cAAAC,EACA,YAAAuS,EACA,YAAAa,GACA,QAAAl1B,EACA,iBAhDuB,CAAC2J,EAAoC8W,EAAe,KAAO,CAC9E9W,IAAW,SACb,OAAO,OAAO,YAAY,CACxB,KAAM,WACN,IAAK8W,GACJ,GAAG,CACR,EA2CA,WAjEiB,CAACA,EAAe,GAAI5O,IAC9BmB,GAAmByN,EAAM5O,CAAI,EAiEpC,iBA9DwBlI,GAAuC,CAC/D,GAAIA,IAAW,QAOb,MAJY,CACV,KAAM,QACN,MAAO,QAAA,EAEEA,CAAM,CACnB,EAsDA,YAAA2pB,EACA,aAAAjB,EACA,gBAAAC,EACA,iBAnCwB9P,GAAW,CACnC,MAAM5hB,EAAM4hB,EAAO,UACf,GAAA,OAAO5hB,GAAQ,SAAU,CAC3B,IAAI+0B,EAAgBr1B,EAAA,MAAMmzB,CAAgB,EAAE7yB,CAAG,EAC/C,MAAMg1B,EAAct1B,EAAAA,MAAMkiB,EAAO,uBAAuB,EAAE,KAAK,EAC3D,OAAA,MAAM,QAAQmT,CAAa,GACbA,EAAAA,EAAc,OAAQxQ,GAChC,OAAOA,EAAa,OAAU,SACzBA,EAAa,MAAM,YAAA,EAAc,SAASyQ,EAAY,aAAa,EAErE,EACR,EACMD,GAEF,EACT,CACA,MAAO,EAAC,EAoBR,mBA9CyB,CAACE,EAAiBrT,IAAW,CACtDqT,EAAgBrT,EAAO,wBAAwB,CAAA,EA8C/C,cA3CoB,CAACsT,EAActT,IAAW,CACjCsT,EAAA,CAAE,QAAS,EAAA,CAAM,EAC9BtT,EAAO,wBAA0B,GACjCA,EAAO,yBAA2B,EAAC,EAyCnC,sBAvC4B,IAAM,CAAA,CAuClC,CAEJ,CACF,CAAC,mFArnBgBP,GAAM,CAAA,IAAA,kWA9DrBtT,mBAwHM,UAAA,SAxHwBI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,aACnC,MAsHW2O,EAAAA,eAAAzO,EAAA,KAAA,CAAA,EAAA,eArHT4R,EAoHU,CAAA,QAAA5R,EAAA,OAAA,EAAA,CAAA,QAnHHqT,EAAQ,QAAA,IAAA,CACLhU,EAAAA,YAAA4nB,EAAA,CAAA,MAAA,QAEP,MAAA,CACA,OAAO,MAAA,EAEP,QAAQjnB,EAAE,aACV,cAAUA,EAAA,gBACV,SAASA,EAAE,SACX,KAAMA,EAAA,KACN,UAAUA,EAAE,UACZ,OAAM,CAAE,EAAWA,EAAA,EAAA,EAAAA,EAAA,CAAA,EAAA,WAAAA,EAAA,WAET,SAAAA,EAAA,WAAA,EAAA,sBAEDqT,EAAAA,QAAmB,CAAA,CAAA,OAAAK,EAAA,aAAAwT,EAAA,gBAAAH,EAAA,QAAAI,EAAA,aAAAH,KAAA,CACnB1O,EAAAA,mBAAA,MAAA,CAAA,MAAA,8EAKWjZ,EAAAA,YAAA6V,EAAA,CACf,MAAYxB,EAAA,wBAEZ,iBAAoByB,GAAAzB,EAAA,wBAAAyB,EACnB,YAAQ,SAAA,MAAA,eAEX,SAMmBnV,EAAA,qBAAA,EALT,KAAO,WAAO,iBAAwB,UAAA,CAAA,EAAxBX,EAAAA,YAAA2Z,EAAA,CACtB,MAAMtF,EAAA,yBACL,oBAAyBA,EAAO,yBAAAyB,EAChC,MAAA,kBAAA,QAAAnV,EAAA,iBAAA0T,CAAA,EAGH,SAgBMyB,GAAAnV,EAAA,mBAAA+mB,EAAArT,CAAA,CAAA,EAfJ,KAOW,EAAA,CAAA,QAAA,iBAAA,UAAA,UAAA,CAAA,EANK4E,EAAA,mBAAA,MAAA,KAAA,CAAAjZ,EAAAA,YACTgZ,EAAO,CACZ,KAAsC,UACrC,KAAA,QAAA,MAAA,CAAA,MAAA,OAAA,eAAA,KAAA,EAGH,QAAA,IAAA8O,EAAA,CAAA,EAAA,6BACA,EAAA,CAAA,EACE,KAAK,CAAO,SAAA,CAAA,EAAA9nB,EAAAA,YACZgZ,EAAmB,CAClB,KAAA,QAAA,MAAA,CAAA,MAAA,MAAA,EAGH,QAAAlD,GAAAnV,EAAA,cAAAgnB,EAAAtT,CAAA,CAAA,EAAA,qDAIK,EAAA,CAAA,CAAA,CAAA,uBAEP,OAAAA,EAA4B,MAAA/Z,EAAA,KAAA0X,EAAA,OAAAxL,KAAA,CAGd6N,EAAA,YAAA,OAAAzT,EAAA,UAAA,EAAgBH,EAAAA,mBAC9B,OAAAoT,GAAAkM,EAAA,gBAAAzlB,EAAA,CAAA,EAAA,CAAA,GAAA8Z,EAAA,mBAAA,GAAA,EAAA,EAAAC,EAAA,YAAA,UAAAzT,EAAAA,UAAA,EAAAH,EAAA,mBACE,MAaMqT,GAAA,EAAAlT,EAAAA,UAbK,EAAQ,EAAAH,EAAA,mBAAAwT,WAAA,KAAAC,EAAA,WAAAvT,EAAA,WAAA,CAAAonB,EAAAC,KAA6CpnB,EAAK,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,SACnE,IAAAunB,CAAA,EAAA,CAEW/O,EAAAA,mBAAA,IAAA,CACR,KAAKtY,EAAA,WAAAonB,EAAA,KAAAvhB,CAAA,EAAA,OAA+B7F,EAAO,iBAAKonB,EAAA,MAAA,EAAA,MAAsB3Y,EAAAA,eAAQ,CAAsB,MAAA2Y,EAAA,MAAA,SAAApnB,EAAA,SAK/F,WAAAA,EAAA,UAAA,CAAA,gIASDF,EAAA,mBAAA,MAAA,CACR,IAAK,EAA4B,MAAA8T,EAAAA,eAAA,CAAA5T,EAAA,cAAAqR,EAAAqC,EAAA,MAAA,CAAA,CAAA,EAAkB,MAAAjF,EAAAA,eAAA,CAAA,SAAAzO,EAAA,kCAS/C,EAAOof,EAyBE,gBAAA1L,EAAA,QAAA,KAAA1T,EAAA,SAAAqR,EAAAqC,EAAA,MAAA,EAAArC,CAAA,EAAA,CAAA,EAAA,CAAA,EAxBlB,QAAAgC,EAAA,QAAA,IAAA,CAAArT,EAAA,YAAA,OAuBwB,iBAAAE,EAAA,YAAAonB,EAAA,CAAA,IAAA,GAAA,CApBqB,QAAAjU,EAAA,QAAA,IAAA,CAmBlBhU,EAAA,YAAAkoB,EAAA,KAAA,CAAA,QAAAlU,EAAA,QAAA,IAAA,cAlBf,EAAK,EAAAvT,EAAA,mBAAAwT,WAAA,KAAAC,EAAA,WAAAvT,EAAA,YAAA,CAAA0mB,EAAA/sB,KACLsG,EAAO,UAAA,EAAAC,EAAA,YAAAsnB,EAAA,CACZ,IAAK7tB,EAAA,MAAAA,QAAyF8U,EAAAA,eAAiB,CAA+C,gBAAAzO,EAAA,oBAAgD,UAAA0mB,EAAA,WAAA,SAAA,MAAAA,EAAA,8CAQvM,QAAArT,EAAA,QAAA,IAAA,CACAiF,EAAAA,mBAAA,MAAA,CAAwB,MAAQ1E,EAAAA,eAAA,CAAA5T,EAAA,cAAA0mB,EAAA,MAAAA,EAAA,MAAA,CAAA,CAAA,EAAsB,MAAUjY,EAAAA,eAAA,CAAA,SAAAzO,EAAA,yUC1G3E,MAAAynB,GAAYlnB,uDAAiB,ECyC7BmnB,GAAqB,CAChC,GAAGl1B,EACH,QAAS,KACT,KAAM,CAAC,EACP,KAAM,KACN,QAAS,KACT,KAAM,UACN,MAAO,QACP,OAAQ,QACR,gBAAiB,GACjB,sBAAuB,YACvB,mBAAoB,GACpB,yBAA0B,YAC1B,YAAa,GACb,YAAa,GACb,aAAc,GACd,eAAgB,UAChB,cAAe,GACf,UAAW,GACX,aAAc,GACd,cAAe,OACf,QAAS,EACT,QAAS,GACT,UAAW,GACX,iBAAkB,GAClB,WAAY,GACZ,eAAgB,MAChB,sBAAuB,OACvB,wBAAyB,OACzB,wBAAyB,EACzB,wBAAyB,GACzB,0BAA2B,EAC3B,0BAA2B,EAC3B,uBAAwB,EACxB,oBAAqB,GACrB,sBAAuB,OACvB,8BAA+B,OAC/B,gCAAiC,OACjC,YAAa,GACb,sBAAuB,GACvB,iBAAkB,KACpB,EAEam1B,GAAoB/mB,EAA0B8mB,EAAQ,EC5DnEhO,GAAAA,IAAI,CACFC,GAAA,eACAiO,GAAA,SACA3K,GAAA,aACA4K,EAAA,mBACA9N,EAAA,iBACA+N,EAAA,gBACF,CAAC,EACD,MAAAC,GAAex1B,kBAAgB,CAC7B,KAAM,UACN,WAAY,CACV,QAAAD,EACF,EACA,MAAO,CACL,GAAGq1B,EACL,EACA,MAAOn1B,EAAO,CACZ,MAAMqa,EAAQ5L,EAAsBzO,EAAO,CAAC,iBAAiB,CAAC,EACxDw1B,EAAwBtlB,EAAAA,MACxBulB,EAAuB12B,EAAAA,SAAS,IAAM0V,GAAazU,EAAM,kBAA4B,CAAC,EACtF01B,EAAoB32B,EAAAA,SAAS,IAAM0V,GAAazU,EAAM,eAAyB,CAAC,EAChF21B,EAAY52B,EAAAA,SAAS,IACDiB,EAAM,mBAErB,CACL,MAAOhB,QAAMw2B,CAAqB,EAClC,OAAQx1B,EAAM,wBAAA,EAGXA,EAAM,qBACd,EACK41B,EAAS72B,EAAAA,SAAS,IAAM,CAC5B,MAAM82B,EAAc71B,EAAM,YAC1B,OAAIA,EAAM,YACD,WAAayU,GAAaohB,CAAW,EAEvC,QAAA,CACR,EACK/0B,EAAS/B,EAAAA,SAAS,IAAM,CAC5B,MAAM+2B,EAAY91B,EAAM,UACpB,IAAA+1B,EACJ,OAAI,OAAOD,GAAc,UAAYA,IAAc,KACxCC,EAAAD,EAAU,MAAM,GAAG,GAEvB,CAEL,QAAS,CACP,KAAM,EACR,EACA,QAAS,CACP,CACE,KAAM,QACN,MAAO,CACL,MAAO,WAAW91B,EAAM,KAAe,EACvC,OAAQ,WAAWA,EAAM,MAAgB,EACzC,MAAOhB,QAAM02B,CAAiB,CAChC,EACA,IAAK,QACP,CACF,EACA,IAAK,CACH,KAAM11B,EAAM,QACZ,KAAMA,EAAM,QACZ,OAAA+1B,EACA,IAAK,MACL,QAAS,CACP,KAAM,EACR,EACA,MAAO,CACL,KAAM/1B,EAAM,aACZ,MAAOA,EAAM,cACb,SAAUA,EAAM,gBAClB,EACA,UAAW,CACT,UAAWhB,QAAM22B,CAAS,EAC1B,YAAa31B,EAAM,wBACnB,YAAaA,EAAM,wBACnB,YAAaA,EAAM,wBACnB,WAAYA,EAAM,uBAClB,cAAeA,EAAM,0BACrB,cAAeA,EAAM,yBACvB,EACA,SAAU,CACR,SAAUA,EAAM,oBAChB,MAAO,CACL,MAAOA,EAAM,qBACf,EACA,UAAW,CACT,UAAWA,EAAM,8BACjB,YAAaA,EAAM,+BACrB,CACF,CACF,EACA,OAAQ,CACN,CACE,KAAM,UACN,iBAAkB,MAClB,UAAW,CACT,MAAOA,EAAM,cACf,EACA,OAAQhB,QAAM42B,CAAM,EACpB,WAAY,CAAC51B,EAAM,YAAaA,EAAM,YAAY,EAClD,MAAO,CACL,KAAMA,EAAM,UACZ,SAAUA,EAAM,cAChB,UAAWA,EAAM,eACjB,MAAOA,EAAM,UACf,EACA,QAAS,CACP,KAAMA,EAAM,YACZ,UAAWA,EAAM,iBACjB,UAAW,CACT,MAAOA,EAAM,qBACf,CACF,EACA,KAAMA,EAAM,IACd,CACF,CAAA,CACF,CACD,EAEKg2B,EAAe9lB,MAAI,EAAK,EACxB+lB,EAAoB,SAAY,OACpC,MAAMC,EAAUl2B,EAAM,QAClB,GAAAk2B,GAAW,MAAQA,EAAQ,KAAM,CAEnC,MAAMniB,EAAM,MAAMkB,KAAQ5F,EAAA,2BAAQ,SAAR,YAAAA,EAAgB,YAAa6mB,EAAQ,IAAI,EACnEC,GAAAA,YAAY,OAAQpiB,GAAA,YAAAA,EAAK,OAAQ,CAAU,CAAA,CAC7C,CACAiiB,EAAa,MAAQ,EAAA,EAEjB/3B,OAAAA,QAAA,IAAM+B,EAAM,QAAS,IAAM,CACbi2B,GAAA,EACjB,CACD,UAAW,GACX,KAAM,EAAA,CACP,EACM,CACL,OAAAn1B,EACA,MAAAuZ,EACA,aAAA2b,EACA,sBAAAR,EACA,qBAAAC,CAAA,CAEJ,CACF,CAAC,oDA1KCpoB,mBAYM,SAAA,SAZsBI,EAAO,UAAA,EAAAH,EAAA,mBAAA,MAAA,CAAA,MAAA,iBAEzB2O,EAAAA,eAAYzO,EAAA,KAAA,CAAA,EAAA,+BACHE,EAAAA,YAAAib,EAAA,CACd,IAAA,EACD,OAAAnb,EAAA,OAAA,iBAAA,CAAA,SAAA,EAAA,eAEF,EAAA,KAAA,EAAA,CAAA,QAAA,CAAA,GACEyT,qBAAI,GAAuB,EAAA,EAAAmV,EAAA,eAErBtQ,EAAoB,mBAAA,MAAA,CAAA,IAAA,wBADlB,IAAAtY,EAAA,oBAAA,EAAA,KAAA,EAAAD,EAAA,EAAA,oBCRD,MAAA8oB,GAAUtoB,uDAAe,uvDCYvB5G,GAAA,CACb,QAbe+G,GAAa,CAC5B,OAAO,KAAKooB,EAAU,EAAE,QAAeh3B,GAAA,CAC/B,MAAAovB,EAAY4H,GAAWh3B,CAAG,EAC5BovB,EAAU,SACZxgB,EAAI,IAAIwgB,CAAS,CACnB,CACD,CACH,CAOA"}
|