@antv/infographic 0.1.1 → 0.1.3
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/README.md +26 -2
- package/README.zh-CN.md +26 -3
- package/dist/infographic.min.js +484 -79
- package/dist/infographic.min.js.map +1 -1
- package/esm/constants/components.d.ts +1 -0
- package/esm/constants/components.js +1 -0
- package/esm/constants/element.d.ts +17 -6
- package/esm/constants/index.d.ts +2 -0
- package/esm/constants/index.js +2 -0
- package/esm/constants/shape.d.ts +16 -0
- package/esm/designs/components/Btn.js +2 -2
- package/esm/designs/components/BtnsGroup.js +1 -1
- package/esm/designs/components/Illus.js +2 -2
- package/esm/designs/components/ItemDesc.js +1 -2
- package/esm/designs/components/ItemIcon.js +1 -1
- package/esm/designs/components/ItemLabel.js +1 -2
- package/esm/designs/components/ItemValue.js +1 -2
- package/esm/designs/components/ItemsGroup.js +1 -1
- package/esm/designs/components/Title.js +2 -5
- package/esm/designs/items/CandyCardLite.js +1 -1
- package/esm/designs/items/CircularProgress.js +2 -1
- package/esm/designs/items/HorizontalIconArrow.js +1 -2
- package/esm/designs/items/HorizontalIconLine.js +1 -1
- package/esm/designs/items/IconBadge.js +1 -1
- package/esm/designs/items/LinedText.d.ts +12 -0
- package/esm/designs/items/LinedText.js +57 -0
- package/esm/designs/items/PlainText.d.ts +1 -0
- package/esm/designs/items/PlainText.js +16 -3
- package/esm/designs/items/QuarterCircular.js +1 -31
- package/esm/designs/items/index.d.ts +1 -0
- package/esm/designs/items/index.js +1 -0
- package/esm/designs/layouts/Align.js +31 -45
- package/esm/designs/layouts/Flex.js +33 -29
- package/esm/designs/structures/chart-bar.d.ts +15 -0
- package/esm/designs/structures/chart-bar.js +99 -0
- package/esm/designs/structures/chart-line.d.ts +12 -0
- package/esm/designs/structures/chart-line.js +164 -0
- package/esm/designs/structures/chart-pie.d.ts +9 -0
- package/esm/designs/structures/chart-pie.js +127 -0
- package/esm/designs/structures/compare-binary-horizontal/dividers/pros-cons-arrow.js +1 -1
- package/esm/designs/structures/hierarchy-mindmap.d.ts +24 -0
- package/esm/designs/structures/hierarchy-mindmap.js +199 -0
- package/esm/designs/structures/index.d.ts +4 -0
- package/esm/designs/structures/index.js +4 -0
- package/esm/designs/structures/list-sector.js +1 -1
- package/esm/designs/structures/sequence-circular.js +1 -1
- package/esm/designs/structures/sequence-cylinders-3d.js +4 -4
- package/esm/designs/structures/sequence-roadmap-vertical.js +1 -1
- package/esm/designs/structures/sequence-zigzag-pucks-3d.js +5 -5
- package/esm/editor/commands/Batch.d.ts +11 -0
- package/esm/editor/commands/Batch.js +21 -0
- package/esm/editor/commands/UpdateElement.d.ts +16 -0
- package/esm/editor/commands/UpdateElement.js +83 -0
- package/esm/editor/commands/UpdateOptions.d.ts +14 -0
- package/esm/editor/commands/UpdateOptions.js +25 -0
- package/esm/editor/commands/UpdateText.d.ts +16 -0
- package/esm/editor/commands/UpdateText.js +40 -0
- package/esm/editor/commands/index.d.ts +4 -0
- package/esm/editor/commands/index.js +4 -0
- package/esm/editor/editor.d.ts +16 -0
- package/esm/editor/editor.js +50 -0
- package/esm/editor/index.d.ts +4 -0
- package/esm/editor/index.js +3 -0
- package/esm/editor/interactions/base.d.ts +12 -0
- package/esm/editor/interactions/base.js +5 -0
- package/esm/editor/interactions/brush-select.d.ts +23 -0
- package/esm/editor/interactions/brush-select.js +167 -0
- package/esm/editor/interactions/click-select.d.ts +12 -0
- package/esm/editor/interactions/click-select.js +67 -0
- package/esm/editor/interactions/dblclick-edit-text.d.ts +10 -0
- package/esm/editor/interactions/dblclick-edit-text.js +204 -0
- package/esm/editor/interactions/drag-element.d.ts +41 -0
- package/esm/editor/interactions/drag-element.js +391 -0
- package/esm/editor/interactions/hotkey-history.d.ts +10 -0
- package/esm/editor/interactions/hotkey-history.js +27 -0
- package/esm/editor/interactions/index.d.ts +8 -0
- package/esm/editor/interactions/index.js +8 -0
- package/esm/editor/interactions/select-highlight.d.ts +16 -0
- package/esm/editor/interactions/select-highlight.js +99 -0
- package/esm/editor/interactions/zoom-wheel.d.ts +8 -0
- package/esm/editor/interactions/zoom-wheel.js +46 -0
- package/esm/editor/managers/command.d.ts +19 -0
- package/esm/editor/managers/command.js +63 -0
- package/esm/editor/managers/index.d.ts +4 -0
- package/esm/editor/managers/index.js +4 -0
- package/esm/editor/managers/interaction.d.ts +33 -0
- package/esm/editor/managers/interaction.js +196 -0
- package/esm/editor/managers/plugin.d.ts +14 -0
- package/esm/editor/managers/plugin.js +45 -0
- package/esm/editor/managers/state.d.ts +22 -0
- package/esm/editor/managers/state.js +141 -0
- package/esm/editor/plugins/base.d.ts +12 -0
- package/esm/editor/plugins/base.js +5 -0
- package/esm/editor/plugins/edit-bar/components/button.d.ts +12 -0
- package/esm/editor/plugins/edit-bar/components/button.js +53 -0
- package/esm/editor/plugins/edit-bar/components/color-picker.d.ts +10 -0
- package/esm/editor/plugins/edit-bar/components/color-picker.js +351 -0
- package/esm/editor/plugins/edit-bar/components/icons.d.ts +26 -0
- package/esm/editor/plugins/edit-bar/components/icons.js +30 -0
- package/esm/editor/plugins/edit-bar/components/index.d.ts +5 -0
- package/esm/editor/plugins/edit-bar/components/index.js +5 -0
- package/esm/editor/plugins/edit-bar/components/popover.d.ts +23 -0
- package/esm/editor/plugins/edit-bar/components/popover.js +378 -0
- package/esm/editor/plugins/edit-bar/components/select.d.ts +22 -0
- package/esm/editor/plugins/edit-bar/components/select.js +201 -0
- package/esm/editor/plugins/edit-bar/edit-bar.d.ts +32 -0
- package/esm/editor/plugins/edit-bar/edit-bar.js +211 -0
- package/esm/editor/plugins/edit-bar/edit-items/align-elements.d.ts +2 -0
- package/esm/editor/plugins/edit-bar/edit-items/align-elements.js +312 -0
- package/esm/editor/plugins/edit-bar/edit-items/font-align.d.ts +3 -0
- package/esm/editor/plugins/edit-bar/edit-items/font-align.js +81 -0
- package/esm/editor/plugins/edit-bar/edit-items/font-color.d.ts +3 -0
- package/esm/editor/plugins/edit-bar/edit-items/font-color.js +77 -0
- package/esm/editor/plugins/edit-bar/edit-items/font-family.d.ts +3 -0
- package/esm/editor/plugins/edit-bar/edit-items/font-family.js +115 -0
- package/esm/editor/plugins/edit-bar/edit-items/font-size.d.ts +3 -0
- package/esm/editor/plugins/edit-bar/edit-items/font-size.js +88 -0
- package/esm/editor/plugins/edit-bar/edit-items/icon-color.d.ts +3 -0
- package/esm/editor/plugins/edit-bar/edit-items/icon-color.js +77 -0
- package/esm/editor/plugins/edit-bar/edit-items/index.d.ts +7 -0
- package/esm/editor/plugins/edit-bar/edit-items/index.js +6 -0
- package/esm/editor/plugins/edit-bar/edit-items/types.d.ts +3 -0
- package/esm/editor/plugins/edit-bar/edit-items/types.js +1 -0
- package/esm/editor/plugins/edit-bar/index.d.ts +4 -0
- package/esm/editor/plugins/edit-bar/index.js +2 -0
- package/esm/editor/plugins/edit-bar/utils.d.ts +4 -0
- package/esm/editor/plugins/edit-bar/utils.js +14 -0
- package/esm/editor/plugins/index.d.ts +3 -0
- package/esm/editor/plugins/index.js +3 -0
- package/esm/editor/plugins/resize-element.d.ts +45 -0
- package/esm/editor/plugins/resize-element.js +393 -0
- package/esm/editor/types/command.d.ts +28 -0
- package/esm/editor/types/command.js +1 -0
- package/esm/editor/types/editor.d.ts +4 -0
- package/esm/editor/types/editor.js +1 -0
- package/esm/editor/types/index.d.ts +7 -0
- package/esm/editor/types/index.js +1 -0
- package/esm/editor/types/interaction.d.ts +44 -0
- package/esm/editor/types/interaction.js +1 -0
- package/esm/editor/types/plugin.d.ts +30 -0
- package/esm/editor/types/plugin.js +1 -0
- package/esm/editor/types/selection.d.ts +2 -0
- package/esm/editor/types/selection.js +1 -0
- package/esm/editor/types/shape.d.ts +16 -0
- package/esm/editor/types/shape.js +1 -0
- package/esm/editor/types/state.d.ts +57 -0
- package/esm/editor/types/state.js +1 -0
- package/esm/editor/utils/click-handler.d.ts +28 -0
- package/esm/editor/utils/click-handler.js +97 -0
- package/esm/editor/utils/coordinate.d.ts +6 -0
- package/esm/editor/utils/coordinate.js +31 -0
- package/esm/editor/utils/data.d.ts +10 -0
- package/esm/editor/utils/data.js +18 -0
- package/esm/editor/utils/element.d.ts +2 -0
- package/esm/editor/utils/element.js +9 -0
- package/esm/editor/utils/event.d.ts +3 -0
- package/esm/editor/utils/event.js +63 -0
- package/esm/editor/utils/extension.d.ts +13 -0
- package/esm/editor/utils/extension.js +39 -0
- package/esm/editor/utils/hotkey.d.ts +20 -0
- package/esm/editor/utils/hotkey.js +109 -0
- package/esm/editor/utils/index.d.ts +7 -0
- package/esm/editor/utils/index.js +7 -0
- package/esm/exporter/svg.js +7 -5
- package/esm/index.d.ts +5 -2
- package/esm/index.js +2 -0
- package/esm/jsx/components/Polygon.js +2 -1
- package/esm/jsx/components/Text.js +66 -68
- package/esm/options/types.d.ts +15 -2
- package/esm/renderer/composites/background.js +2 -2
- package/esm/renderer/composites/button.js +4 -3
- package/esm/renderer/composites/icon.d.ts +1 -1
- package/esm/renderer/composites/icon.js +2 -0
- package/esm/renderer/composites/text.js +2 -1
- package/esm/renderer/renderer.js +3 -2
- package/esm/renderer/stylize/rough.js +3 -7
- package/esm/renderer/types/index.d.ts +0 -1
- package/esm/resource/utils/index.d.ts +0 -1
- package/esm/resource/utils/index.js +0 -1
- package/esm/resource/utils/ref.js +1 -1
- package/esm/runtime/Infographic.d.ts +8 -2
- package/esm/runtime/Infographic.js +31 -2
- package/esm/runtime/options.d.ts +2 -0
- package/esm/runtime/options.js +24 -0
- package/esm/runtime/utils.d.ts +2 -0
- package/esm/runtime/utils.js +18 -0
- package/esm/templates/built-in.js +112 -1
- package/esm/templates/hierarchy-mindmap.d.ts +2 -0
- package/esm/templates/hierarchy-mindmap.js +61 -0
- package/esm/types/attrs.d.ts +15 -13
- package/esm/types/data.d.ts +2 -0
- package/esm/types/element.d.ts +1 -1
- package/esm/types/event.d.ts +6 -0
- package/esm/types/event.js +1 -0
- package/esm/types/index.d.ts +2 -0
- package/esm/{renderer/types → types}/text.d.ts +0 -1
- package/esm/types/text.js +1 -0
- package/esm/utils/attrs.d.ts +1 -0
- package/esm/utils/attrs.js +9 -0
- package/esm/utils/element.d.ts +4 -0
- package/esm/utils/element.js +13 -0
- package/esm/utils/icon.d.ts +5 -3
- package/esm/utils/icon.js +38 -19
- package/esm/utils/index.d.ts +5 -0
- package/esm/utils/index.js +5 -0
- package/esm/utils/measure-text.d.ts +5 -0
- package/esm/utils/measure-text.js +22 -0
- package/esm/utils/recognizer.d.ts +15 -0
- package/esm/utils/recognizer.js +61 -1
- package/esm/utils/style.d.ts +1 -0
- package/esm/utils/style.js +8 -0
- package/esm/utils/text.d.ts +7 -0
- package/esm/utils/text.js +110 -35
- package/lib/constants/components.d.ts +1 -0
- package/lib/constants/components.js +4 -0
- package/lib/constants/element.d.ts +17 -6
- package/lib/constants/index.d.ts +2 -0
- package/lib/constants/index.js +2 -0
- package/lib/constants/shape.d.ts +16 -0
- package/lib/designs/components/Btn.js +2 -2
- package/lib/designs/components/BtnsGroup.js +1 -1
- package/lib/designs/components/Illus.js +2 -2
- package/lib/designs/components/ItemDesc.js +1 -2
- package/lib/designs/components/ItemIcon.js +1 -1
- package/lib/designs/components/ItemLabel.js +1 -2
- package/lib/designs/components/ItemValue.js +1 -2
- package/lib/designs/components/ItemsGroup.js +1 -1
- package/lib/designs/components/Title.js +2 -5
- package/lib/designs/items/CandyCardLite.js +1 -1
- package/lib/designs/items/CircularProgress.js +2 -1
- package/lib/designs/items/HorizontalIconArrow.js +1 -2
- package/lib/designs/items/HorizontalIconLine.js +1 -1
- package/lib/designs/items/IconBadge.js +1 -1
- package/lib/designs/items/LinedText.d.ts +12 -0
- package/lib/designs/items/LinedText.js +61 -0
- package/lib/designs/items/PlainText.d.ts +1 -0
- package/lib/designs/items/PlainText.js +16 -3
- package/lib/designs/items/QuarterCircular.js +1 -31
- package/lib/designs/items/index.d.ts +1 -0
- package/lib/designs/items/index.js +1 -0
- package/lib/designs/layouts/Align.js +31 -45
- package/lib/designs/layouts/Flex.js +33 -29
- package/lib/designs/structures/chart-bar.d.ts +15 -0
- package/lib/designs/structures/chart-bar.js +103 -0
- package/lib/designs/structures/chart-line.d.ts +12 -0
- package/lib/designs/structures/chart-line.js +168 -0
- package/lib/designs/structures/chart-pie.d.ts +9 -0
- package/lib/designs/structures/chart-pie.js +131 -0
- package/lib/designs/structures/compare-binary-horizontal/dividers/pros-cons-arrow.js +1 -1
- package/lib/designs/structures/hierarchy-mindmap.d.ts +24 -0
- package/lib/designs/structures/hierarchy-mindmap.js +203 -0
- package/lib/designs/structures/index.d.ts +4 -0
- package/lib/designs/structures/index.js +4 -0
- package/lib/designs/structures/list-sector.js +1 -1
- package/lib/designs/structures/sequence-circular.js +1 -1
- package/lib/designs/structures/sequence-cylinders-3d.js +4 -4
- package/lib/designs/structures/sequence-roadmap-vertical.js +1 -1
- package/lib/designs/structures/sequence-zigzag-pucks-3d.js +5 -5
- package/lib/editor/commands/Batch.d.ts +11 -0
- package/lib/editor/commands/Batch.js +25 -0
- package/lib/editor/commands/UpdateElement.d.ts +16 -0
- package/lib/editor/commands/UpdateElement.js +87 -0
- package/lib/editor/commands/UpdateOptions.d.ts +14 -0
- package/lib/editor/commands/UpdateOptions.js +29 -0
- package/lib/editor/commands/UpdateText.d.ts +16 -0
- package/lib/editor/commands/UpdateText.js +44 -0
- package/lib/editor/commands/index.d.ts +4 -0
- package/lib/editor/commands/index.js +20 -0
- package/lib/editor/editor.d.ts +16 -0
- package/lib/editor/editor.js +54 -0
- package/lib/editor/index.d.ts +4 -0
- package/lib/editor/index.js +21 -0
- package/lib/editor/interactions/base.d.ts +12 -0
- package/lib/editor/interactions/base.js +9 -0
- package/lib/editor/interactions/brush-select.d.ts +23 -0
- package/lib/editor/interactions/brush-select.js +171 -0
- package/lib/editor/interactions/click-select.d.ts +12 -0
- package/lib/editor/interactions/click-select.js +71 -0
- package/lib/editor/interactions/dblclick-edit-text.d.ts +10 -0
- package/lib/editor/interactions/dblclick-edit-text.js +208 -0
- package/lib/editor/interactions/drag-element.d.ts +41 -0
- package/lib/editor/interactions/drag-element.js +395 -0
- package/lib/editor/interactions/hotkey-history.d.ts +10 -0
- package/lib/editor/interactions/hotkey-history.js +31 -0
- package/lib/editor/interactions/index.d.ts +8 -0
- package/lib/editor/interactions/index.js +19 -0
- package/lib/editor/interactions/select-highlight.d.ts +16 -0
- package/lib/editor/interactions/select-highlight.js +103 -0
- package/lib/editor/interactions/zoom-wheel.d.ts +8 -0
- package/lib/editor/interactions/zoom-wheel.js +50 -0
- package/lib/editor/managers/command.d.ts +19 -0
- package/lib/editor/managers/command.js +67 -0
- package/lib/editor/managers/index.d.ts +4 -0
- package/lib/editor/managers/index.js +20 -0
- package/lib/editor/managers/interaction.d.ts +33 -0
- package/lib/editor/managers/interaction.js +200 -0
- package/lib/editor/managers/plugin.d.ts +14 -0
- package/lib/editor/managers/plugin.js +49 -0
- package/lib/editor/managers/state.d.ts +22 -0
- package/lib/editor/managers/state.js +145 -0
- package/lib/editor/plugins/base.d.ts +12 -0
- package/lib/editor/plugins/base.js +9 -0
- package/lib/editor/plugins/edit-bar/components/button.d.ts +12 -0
- package/lib/editor/plugins/edit-bar/components/button.js +57 -0
- package/lib/editor/plugins/edit-bar/components/color-picker.d.ts +10 -0
- package/lib/editor/plugins/edit-bar/components/color-picker.js +354 -0
- package/lib/editor/plugins/edit-bar/components/icons.d.ts +26 -0
- package/lib/editor/plugins/edit-bar/components/icons.js +33 -0
- package/lib/editor/plugins/edit-bar/components/index.d.ts +5 -0
- package/lib/editor/plugins/edit-bar/components/index.js +21 -0
- package/lib/editor/plugins/edit-bar/components/popover.d.ts +23 -0
- package/lib/editor/plugins/edit-bar/components/popover.js +381 -0
- package/lib/editor/plugins/edit-bar/components/select.d.ts +22 -0
- package/lib/editor/plugins/edit-bar/components/select.js +204 -0
- package/lib/editor/plugins/edit-bar/edit-bar.d.ts +32 -0
- package/lib/editor/plugins/edit-bar/edit-bar.js +215 -0
- package/lib/editor/plugins/edit-bar/edit-items/align-elements.d.ts +2 -0
- package/lib/editor/plugins/edit-bar/edit-items/align-elements.js +316 -0
- package/lib/editor/plugins/edit-bar/edit-items/font-align.d.ts +3 -0
- package/lib/editor/plugins/edit-bar/edit-items/font-align.js +85 -0
- package/lib/editor/plugins/edit-bar/edit-items/font-color.d.ts +3 -0
- package/lib/editor/plugins/edit-bar/edit-items/font-color.js +81 -0
- package/lib/editor/plugins/edit-bar/edit-items/font-family.d.ts +3 -0
- package/lib/editor/plugins/edit-bar/edit-items/font-family.js +119 -0
- package/lib/editor/plugins/edit-bar/edit-items/font-size.d.ts +3 -0
- package/lib/editor/plugins/edit-bar/edit-items/font-size.js +92 -0
- package/lib/editor/plugins/edit-bar/edit-items/icon-color.d.ts +3 -0
- package/lib/editor/plugins/edit-bar/edit-items/icon-color.js +81 -0
- package/lib/editor/plugins/edit-bar/edit-items/index.d.ts +7 -0
- package/lib/editor/plugins/edit-bar/edit-items/index.js +22 -0
- package/lib/editor/plugins/edit-bar/edit-items/types.d.ts +3 -0
- package/lib/editor/plugins/edit-bar/edit-items/types.js +2 -0
- package/lib/editor/plugins/edit-bar/index.d.ts +4 -0
- package/lib/editor/plugins/edit-bar/index.js +9 -0
- package/lib/editor/plugins/edit-bar/utils.d.ts +4 -0
- package/lib/editor/plugins/edit-bar/utils.js +17 -0
- package/lib/editor/plugins/index.d.ts +3 -0
- package/lib/editor/plugins/index.js +22 -0
- package/lib/editor/plugins/resize-element.d.ts +45 -0
- package/lib/editor/plugins/resize-element.js +397 -0
- package/lib/editor/types/command.d.ts +28 -0
- package/lib/editor/types/command.js +2 -0
- package/lib/editor/types/editor.d.ts +4 -0
- package/lib/editor/types/editor.js +2 -0
- package/lib/editor/types/index.d.ts +7 -0
- package/lib/editor/types/index.js +2 -0
- package/lib/editor/types/interaction.d.ts +44 -0
- package/lib/editor/types/interaction.js +2 -0
- package/lib/editor/types/plugin.d.ts +30 -0
- package/lib/editor/types/plugin.js +2 -0
- package/lib/editor/types/selection.d.ts +2 -0
- package/lib/editor/types/selection.js +2 -0
- package/lib/editor/types/shape.d.ts +16 -0
- package/lib/editor/types/shape.js +2 -0
- package/lib/editor/types/state.d.ts +57 -0
- package/lib/editor/types/state.js +2 -0
- package/lib/editor/utils/click-handler.d.ts +28 -0
- package/lib/editor/utils/click-handler.js +101 -0
- package/lib/editor/utils/coordinate.d.ts +6 -0
- package/lib/editor/utils/coordinate.js +38 -0
- package/lib/editor/utils/data.d.ts +10 -0
- package/lib/editor/utils/data.js +22 -0
- package/lib/editor/utils/element.d.ts +2 -0
- package/lib/editor/utils/element.js +12 -0
- package/lib/editor/utils/event.d.ts +3 -0
- package/lib/editor/utils/event.js +67 -0
- package/lib/editor/utils/extension.d.ts +13 -0
- package/lib/editor/utils/extension.js +43 -0
- package/lib/editor/utils/hotkey.d.ts +20 -0
- package/lib/editor/utils/hotkey.js +113 -0
- package/lib/editor/utils/index.d.ts +7 -0
- package/lib/editor/utils/index.js +23 -0
- package/lib/exporter/svg.js +6 -4
- package/lib/index.d.ts +5 -2
- package/lib/index.js +14 -1
- package/lib/jsx/components/Polygon.js +2 -1
- package/lib/jsx/components/Text.js +66 -68
- package/lib/options/types.d.ts +15 -2
- package/lib/renderer/composites/background.js +1 -1
- package/lib/renderer/composites/button.js +3 -2
- package/lib/renderer/composites/icon.d.ts +1 -1
- package/lib/renderer/composites/icon.js +2 -0
- package/lib/renderer/composites/text.js +2 -1
- package/lib/renderer/renderer.js +2 -1
- package/lib/renderer/stylize/rough.js +3 -7
- package/lib/renderer/types/index.d.ts +0 -1
- package/lib/resource/utils/index.d.ts +0 -1
- package/lib/resource/utils/index.js +0 -1
- package/lib/resource/utils/ref.js +2 -2
- package/lib/runtime/Infographic.d.ts +8 -2
- package/lib/runtime/Infographic.js +34 -2
- package/lib/runtime/options.d.ts +2 -0
- package/lib/runtime/options.js +27 -0
- package/lib/runtime/utils.d.ts +2 -0
- package/lib/runtime/utils.js +21 -0
- package/lib/templates/built-in.js +112 -1
- package/lib/templates/hierarchy-mindmap.d.ts +2 -0
- package/lib/templates/hierarchy-mindmap.js +64 -0
- package/lib/types/attrs.d.ts +15 -13
- package/lib/types/data.d.ts +2 -0
- package/lib/types/element.d.ts +1 -1
- package/lib/types/event.d.ts +6 -0
- package/lib/types/event.js +2 -0
- package/lib/types/index.d.ts +2 -0
- package/lib/{renderer/types → types}/text.d.ts +0 -1
- package/lib/types/text.js +2 -0
- package/lib/utils/attrs.d.ts +1 -0
- package/lib/utils/attrs.js +12 -0
- package/lib/utils/element.d.ts +4 -0
- package/lib/utils/element.js +18 -0
- package/lib/utils/icon.d.ts +5 -3
- package/lib/utils/icon.js +42 -21
- package/lib/utils/index.d.ts +5 -0
- package/lib/utils/index.js +5 -0
- package/lib/utils/measure-text.d.ts +5 -0
- package/lib/utils/measure-text.js +28 -0
- package/lib/utils/recognizer.d.ts +15 -0
- package/lib/utils/recognizer.js +72 -2
- package/lib/utils/style.d.ts +1 -0
- package/lib/utils/style.js +11 -0
- package/lib/utils/text.d.ts +7 -0
- package/lib/utils/text.js +113 -32
- package/package.json +7 -3
- package/src/constants/components.ts +1 -0
- package/src/constants/element.ts +17 -5
- package/src/constants/index.ts +2 -0
- package/src/constants/shape.ts +16 -0
- package/src/designs/components/Btn.tsx +3 -2
- package/src/designs/components/BtnsGroup.tsx +8 -1
- package/src/designs/components/Illus.tsx +3 -2
- package/src/designs/components/ItemDesc.tsx +2 -2
- package/src/designs/components/ItemIcon.tsx +3 -2
- package/src/designs/components/ItemLabel.tsx +2 -2
- package/src/designs/components/ItemValue.tsx +2 -2
- package/src/designs/components/ItemsGroup.tsx +2 -1
- package/src/designs/components/Title.tsx +8 -5
- package/src/designs/items/CandyCardLite.tsx +3 -3
- package/src/designs/items/CircularProgress.tsx +19 -8
- package/src/designs/items/HorizontalIconArrow.tsx +4 -5
- package/src/designs/items/HorizontalIconLine.tsx +7 -10
- package/src/designs/items/IconBadge.tsx +3 -3
- package/src/designs/items/LinedText.tsx +131 -0
- package/src/designs/items/PlainText.tsx +25 -3
- package/src/designs/items/QuarterCircular.tsx +2 -31
- package/src/designs/items/index.ts +1 -0
- package/src/designs/layouts/Align.tsx +31 -48
- package/src/designs/layouts/Flex.tsx +33 -31
- package/src/designs/structures/chart-bar.tsx +289 -0
- package/src/designs/structures/chart-line.tsx +415 -0
- package/src/designs/structures/chart-pie.tsx +298 -0
- package/src/designs/structures/compare-binary-horizontal/dividers/pros-cons-arrow.tsx +2 -2
- package/src/designs/structures/hierarchy-mindmap.tsx +394 -0
- package/src/designs/structures/index.ts +4 -0
- package/src/designs/structures/list-sector.tsx +2 -1
- package/src/designs/structures/sequence-ascending-steps.tsx +0 -1
- package/src/designs/structures/sequence-circular.tsx +1 -1
- package/src/designs/structures/sequence-cylinders-3d.tsx +5 -5
- package/src/designs/structures/sequence-roadmap-vertical.tsx +2 -1
- package/src/designs/structures/sequence-zigzag-pucks-3d.tsx +18 -25
- package/src/editor/commands/Batch.ts +24 -0
- package/src/editor/commands/UpdateElement.ts +115 -0
- package/src/editor/commands/UpdateOptions.ts +31 -0
- package/src/editor/commands/UpdateText.ts +54 -0
- package/src/editor/commands/index.ts +4 -0
- package/src/editor/editor.ts +78 -0
- package/src/editor/index.ts +4 -0
- package/src/editor/interactions/base.ts +25 -0
- package/src/editor/interactions/brush-select.ts +204 -0
- package/src/editor/interactions/click-select.ts +72 -0
- package/src/editor/interactions/dblclick-edit-text.ts +260 -0
- package/src/editor/interactions/drag-element.ts +516 -0
- package/src/editor/interactions/hotkey-history.ts +34 -0
- package/src/editor/interactions/index.ts +8 -0
- package/src/editor/interactions/select-highlight.ts +140 -0
- package/src/editor/interactions/zoom-wheel.ts +52 -0
- package/src/editor/managers/command.ts +83 -0
- package/src/editor/managers/index.ts +4 -0
- package/src/editor/managers/interaction.ts +244 -0
- package/src/editor/managers/plugin.ts +66 -0
- package/src/editor/managers/state.ts +186 -0
- package/src/editor/plugins/base.ts +25 -0
- package/src/editor/plugins/edit-bar/components/button.ts +77 -0
- package/src/editor/plugins/edit-bar/components/color-picker.ts +397 -0
- package/src/editor/plugins/edit-bar/components/icons.ts +86 -0
- package/src/editor/plugins/edit-bar/components/index.ts +5 -0
- package/src/editor/plugins/edit-bar/components/popover.ts +446 -0
- package/src/editor/plugins/edit-bar/components/select.ts +247 -0
- package/src/editor/plugins/edit-bar/edit-bar.ts +292 -0
- package/src/editor/plugins/edit-bar/edit-items/align-elements.ts +447 -0
- package/src/editor/plugins/edit-bar/edit-items/font-align.ts +129 -0
- package/src/editor/plugins/edit-bar/edit-items/font-color.ts +101 -0
- package/src/editor/plugins/edit-bar/edit-items/font-family.ts +147 -0
- package/src/editor/plugins/edit-bar/edit-items/font-size.ts +116 -0
- package/src/editor/plugins/edit-bar/edit-items/icon-color.ts +101 -0
- package/src/editor/plugins/edit-bar/edit-items/index.ts +7 -0
- package/src/editor/plugins/edit-bar/edit-items/types.ts +9 -0
- package/src/editor/plugins/edit-bar/index.ts +18 -0
- package/src/editor/plugins/edit-bar/utils.ts +16 -0
- package/src/editor/plugins/index.ts +3 -0
- package/src/editor/plugins/resize-element.ts +518 -0
- package/src/editor/types/command.ts +32 -0
- package/src/editor/types/editor.ts +4 -0
- package/src/editor/types/index.ts +7 -0
- package/src/editor/types/interaction.ts +56 -0
- package/src/editor/types/plugin.ts +34 -0
- package/src/editor/types/selection.ts +3 -0
- package/src/editor/types/shape.ts +28 -0
- package/src/editor/types/state.ts +51 -0
- package/src/editor/utils/click-handler.ts +114 -0
- package/src/editor/utils/coordinate.ts +54 -0
- package/src/editor/utils/data.ts +30 -0
- package/src/editor/utils/element.ts +13 -0
- package/src/editor/utils/event.ts +92 -0
- package/src/editor/utils/extension.ts +45 -0
- package/src/editor/utils/hotkey.ts +139 -0
- package/src/editor/utils/index.ts +7 -0
- package/src/exporter/svg.ts +15 -5
- package/src/index.ts +14 -3
- package/src/jsx/components/Polygon.ts +2 -1
- package/src/jsx/components/Text.ts +70 -71
- package/src/options/types.ts +17 -2
- package/src/renderer/composites/background.ts +2 -2
- package/src/renderer/composites/button.ts +4 -3
- package/src/renderer/composites/icon.ts +2 -0
- package/src/renderer/composites/text.ts +2 -1
- package/src/renderer/renderer.ts +4 -2
- package/src/renderer/stylize/rough.ts +3 -7
- package/src/renderer/types/index.ts +0 -1
- package/src/resource/utils/index.ts +0 -1
- package/src/resource/utils/ref.ts +1 -1
- package/src/runtime/Infographic.tsx +45 -4
- package/src/runtime/options.ts +37 -0
- package/src/runtime/utils.ts +23 -0
- package/src/templates/built-in.ts +112 -1
- package/src/templates/hierarchy-mindmap.ts +129 -0
- package/src/types/attrs.ts +17 -13
- package/src/types/data.ts +2 -0
- package/src/types/element.ts +1 -1
- package/src/types/event.ts +6 -0
- package/src/types/index.ts +2 -0
- package/src/{renderer/types → types}/text.ts +0 -1
- package/src/utils/attrs.ts +9 -0
- package/src/utils/element.ts +26 -0
- package/src/utils/icon.ts +45 -25
- package/src/utils/index.ts +5 -0
- package/src/utils/measure-text.ts +38 -0
- package/src/utils/recognizer.ts +75 -1
- package/src/utils/style.ts +8 -0
- package/src/utils/text.ts +135 -40
- /package/esm/{renderer/types/text.js → constants/shape.js} +0 -0
- /package/esm/{resource/utils → utils}/hash.d.ts +0 -0
- /package/esm/{resource/utils → utils}/hash.js +0 -0
- /package/lib/{renderer/types/text.js → constants/shape.js} +0 -0
- /package/lib/{resource/utils → utils}/hash.d.ts +0 -0
- /package/lib/{resource/utils → utils}/hash.js +0 -0
- /package/src/{resource/utils → utils}/hash.ts +0 -0
|
@@ -0,0 +1,289 @@
|
|
|
1
|
+
import { scaleLinear } from 'd3';
|
|
2
|
+
import type { ComponentType, JSXElement } from '../../jsx';
|
|
3
|
+
import { getElementBounds, Group, Path, Rect, Text } from '../../jsx';
|
|
4
|
+
import { ItemDatum, Padding } from '../../types';
|
|
5
|
+
import { parsePadding } from '../../utils';
|
|
6
|
+
import { ItemsGroup } from '../components';
|
|
7
|
+
import { FlexLayout } from '../layouts';
|
|
8
|
+
import { getColorPrimary, getPaletteColor, getThemeColors } from '../utils';
|
|
9
|
+
import { registerStructure } from './registry';
|
|
10
|
+
import type { BaseStructureProps } from './types';
|
|
11
|
+
|
|
12
|
+
export interface ChartBarProps extends BaseStructureProps {
|
|
13
|
+
width?: number;
|
|
14
|
+
gap?: number;
|
|
15
|
+
barGap?: number;
|
|
16
|
+
barHeight?: number;
|
|
17
|
+
barAreaWidth?: number;
|
|
18
|
+
labelGap?: number;
|
|
19
|
+
padding?: Padding;
|
|
20
|
+
showValue?: boolean;
|
|
21
|
+
valueFormatter?: (value: number, datum: ItemDatum) => string;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export const ChartBar: ComponentType<ChartBarProps> = (props) => {
|
|
25
|
+
const {
|
|
26
|
+
Title,
|
|
27
|
+
Item,
|
|
28
|
+
data,
|
|
29
|
+
width,
|
|
30
|
+
gap,
|
|
31
|
+
barGap,
|
|
32
|
+
barHeight = 28,
|
|
33
|
+
barAreaWidth,
|
|
34
|
+
labelGap = 16,
|
|
35
|
+
padding = 24,
|
|
36
|
+
showValue = true,
|
|
37
|
+
options,
|
|
38
|
+
valueFormatter = (value) => value.toString(),
|
|
39
|
+
} = props;
|
|
40
|
+
|
|
41
|
+
const resolvedBarAreaWidth = barAreaWidth ?? width ?? 480;
|
|
42
|
+
const { title, desc, items = [], xTitle, yTitle } = data;
|
|
43
|
+
|
|
44
|
+
const titleContent = Title ? <Title title={title} desc={desc} /> : null;
|
|
45
|
+
|
|
46
|
+
if (items.length === 0) {
|
|
47
|
+
return (
|
|
48
|
+
<FlexLayout
|
|
49
|
+
id="infographic-container"
|
|
50
|
+
flexDirection="column"
|
|
51
|
+
justifyContent="center"
|
|
52
|
+
alignItems="center"
|
|
53
|
+
>
|
|
54
|
+
{titleContent}
|
|
55
|
+
</FlexLayout>
|
|
56
|
+
);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
const [paddingTop, paddingRight, paddingBottom, paddingLeft] =
|
|
60
|
+
parsePadding(padding);
|
|
61
|
+
|
|
62
|
+
const sampleDatum = items[0] ?? { label: '', value: 0 };
|
|
63
|
+
const itemBounds = getElementBounds(
|
|
64
|
+
<Item indexes={[0]} datum={sampleDatum} data={data} />,
|
|
65
|
+
);
|
|
66
|
+
|
|
67
|
+
const labelWidth = itemBounds.width || 140;
|
|
68
|
+
const labelHeight = itemBounds.height || barHeight;
|
|
69
|
+
const rowHeight = Math.max(barHeight, labelHeight);
|
|
70
|
+
const gapByHeight = Math.max(12, rowHeight * 0.35);
|
|
71
|
+
const resolvedGap = barGap ?? gap ?? gapByHeight;
|
|
72
|
+
|
|
73
|
+
const values = items.map((item) => item.value ?? 0);
|
|
74
|
+
const maxValue = Math.max(...values, 0);
|
|
75
|
+
const minValue = Math.min(...values, 0);
|
|
76
|
+
|
|
77
|
+
const domainMin = minValue < 0 ? minValue * 1.1 : 0;
|
|
78
|
+
let domainMax = maxValue > 0 ? maxValue * 1.1 : 0;
|
|
79
|
+
|
|
80
|
+
if (domainMax === domainMin) {
|
|
81
|
+
domainMax = domainMin + 1;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
const scale = scaleLinear()
|
|
85
|
+
.domain([domainMin, domainMax])
|
|
86
|
+
.range([0, resolvedBarAreaWidth]);
|
|
87
|
+
|
|
88
|
+
const zeroX = Math.min(Math.max(scale(0), 0), resolvedBarAreaWidth);
|
|
89
|
+
const minBarWidth = Math.max(2, resolvedBarAreaWidth * 0.02);
|
|
90
|
+
|
|
91
|
+
const chartHeight = items.length * (rowHeight + resolvedGap) - resolvedGap;
|
|
92
|
+
const yTitleSpace = yTitle ? 24 : 0;
|
|
93
|
+
const xTickSpace = 20;
|
|
94
|
+
const xTitleSpace = xTitle ? 24 : 0;
|
|
95
|
+
const yStart = paddingTop + yTitleSpace;
|
|
96
|
+
const barStartX = paddingLeft + labelWidth + labelGap;
|
|
97
|
+
const valueSpace = showValue ? 80 : 0;
|
|
98
|
+
const axisGap = Math.max(8, rowHeight * 0.2);
|
|
99
|
+
const totalWidth =
|
|
100
|
+
barStartX + resolvedBarAreaWidth + valueSpace + paddingRight;
|
|
101
|
+
const totalHeight =
|
|
102
|
+
yStart + chartHeight + axisGap + xTickSpace + xTitleSpace + paddingBottom;
|
|
103
|
+
|
|
104
|
+
const themeColors = getThemeColors(options.themeConfig);
|
|
105
|
+
const axisColor = themeColors.colorText || '#666';
|
|
106
|
+
const colorPrimary = getColorPrimary(options);
|
|
107
|
+
|
|
108
|
+
const barElements: JSXElement[] = [];
|
|
109
|
+
const valueElements: JSXElement[] = [];
|
|
110
|
+
const itemElements: JSXElement[] = [];
|
|
111
|
+
const axisElements: JSXElement[] = [];
|
|
112
|
+
const tickElements: JSXElement[] = [];
|
|
113
|
+
const gridElements: JSXElement[] = [];
|
|
114
|
+
const titleElements: JSXElement[] = [];
|
|
115
|
+
const axisY = yStart + chartHeight + axisGap;
|
|
116
|
+
|
|
117
|
+
const formatTick = (value: number) =>
|
|
118
|
+
Number.isInteger(value) ? value.toString() : value.toFixed(1);
|
|
119
|
+
|
|
120
|
+
items.forEach((item, index) => {
|
|
121
|
+
const indexes = [index];
|
|
122
|
+
const value = item.value ?? 0;
|
|
123
|
+
const rowY = yStart + index * (rowHeight + resolvedGap);
|
|
124
|
+
const barY = rowY + (rowHeight - barHeight) / 2;
|
|
125
|
+
const barX = value >= 0 ? barStartX + zeroX : barStartX + scale(value);
|
|
126
|
+
const barWidthRaw =
|
|
127
|
+
value >= 0 ? scale(value) - zeroX : zeroX - scale(value);
|
|
128
|
+
const barWidth = barWidthRaw === 0 ? minBarWidth : barWidthRaw;
|
|
129
|
+
|
|
130
|
+
const barColor =
|
|
131
|
+
getPaletteColor(options, [index]) || themeColors.colorPrimary;
|
|
132
|
+
|
|
133
|
+
barElements.push(
|
|
134
|
+
<Rect
|
|
135
|
+
x={barX}
|
|
136
|
+
y={barY}
|
|
137
|
+
width={barWidth}
|
|
138
|
+
height={barHeight}
|
|
139
|
+
fill={barColor}
|
|
140
|
+
rx={6}
|
|
141
|
+
ry={6}
|
|
142
|
+
data-element-type="shape"
|
|
143
|
+
/>,
|
|
144
|
+
);
|
|
145
|
+
|
|
146
|
+
if (showValue) {
|
|
147
|
+
const valueX = value >= 0 ? barX + barWidth + 8 : barX - 8;
|
|
148
|
+
valueElements.push(
|
|
149
|
+
<Text
|
|
150
|
+
x={valueX}
|
|
151
|
+
y={barY + barHeight / 2}
|
|
152
|
+
alignHorizontal={value >= 0 ? 'left' : 'right'}
|
|
153
|
+
alignVertical="middle"
|
|
154
|
+
fontSize={14}
|
|
155
|
+
fontWeight="bold"
|
|
156
|
+
fill={barColor}
|
|
157
|
+
>
|
|
158
|
+
{valueFormatter(value, item)}
|
|
159
|
+
</Text>,
|
|
160
|
+
);
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
itemElements.push(
|
|
164
|
+
<Item
|
|
165
|
+
indexes={indexes}
|
|
166
|
+
datum={item}
|
|
167
|
+
data={data}
|
|
168
|
+
x={paddingLeft}
|
|
169
|
+
y={rowY + (rowHeight - labelHeight) / 2}
|
|
170
|
+
width={labelWidth}
|
|
171
|
+
height={labelHeight}
|
|
172
|
+
positionV="middle"
|
|
173
|
+
/>,
|
|
174
|
+
);
|
|
175
|
+
});
|
|
176
|
+
|
|
177
|
+
const tickCount = Math.max(
|
|
178
|
+
3,
|
|
179
|
+
Math.min(7, Math.floor(resolvedBarAreaWidth / 80)),
|
|
180
|
+
);
|
|
181
|
+
const ticks = scale.ticks(tickCount);
|
|
182
|
+
ticks.forEach((tick) => {
|
|
183
|
+
const tickX = barStartX + scale(tick);
|
|
184
|
+
gridElements.push(
|
|
185
|
+
<Path
|
|
186
|
+
d={`M${tickX} ${yStart} L${tickX} ${yStart + chartHeight}`}
|
|
187
|
+
stroke={axisColor}
|
|
188
|
+
strokeOpacity={0.08}
|
|
189
|
+
data-element-type="shape"
|
|
190
|
+
/>,
|
|
191
|
+
);
|
|
192
|
+
tickElements.push(
|
|
193
|
+
<Path
|
|
194
|
+
d={`M${tickX - 0.5} ${axisY} L${tickX - 0.5} ${axisY + 6}`}
|
|
195
|
+
stroke={axisColor}
|
|
196
|
+
data-element-type="shape"
|
|
197
|
+
/>,
|
|
198
|
+
);
|
|
199
|
+
tickElements.push(
|
|
200
|
+
<Text
|
|
201
|
+
x={tickX}
|
|
202
|
+
y={axisY + 14}
|
|
203
|
+
alignHorizontal="center"
|
|
204
|
+
alignVertical="middle"
|
|
205
|
+
fontSize={12}
|
|
206
|
+
fill={axisColor}
|
|
207
|
+
>
|
|
208
|
+
{formatTick(tick)}
|
|
209
|
+
</Text>,
|
|
210
|
+
);
|
|
211
|
+
});
|
|
212
|
+
|
|
213
|
+
axisElements.push(
|
|
214
|
+
<Path
|
|
215
|
+
d={`M${barStartX} ${axisY} L${barStartX + resolvedBarAreaWidth} ${axisY}`}
|
|
216
|
+
stroke={axisColor}
|
|
217
|
+
data-element-type="shape"
|
|
218
|
+
/>,
|
|
219
|
+
);
|
|
220
|
+
|
|
221
|
+
if (domainMin < 0) {
|
|
222
|
+
axisElements.push(
|
|
223
|
+
<Rect
|
|
224
|
+
x={barStartX + zeroX - 0.5}
|
|
225
|
+
y={yStart}
|
|
226
|
+
width={1}
|
|
227
|
+
height={chartHeight}
|
|
228
|
+
fill={colorPrimary}
|
|
229
|
+
data-element-type="shape"
|
|
230
|
+
/>,
|
|
231
|
+
);
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
if (yTitle) {
|
|
235
|
+
titleElements.push(
|
|
236
|
+
<Text
|
|
237
|
+
x={paddingLeft + labelWidth / 2}
|
|
238
|
+
y={paddingTop + yTitleSpace / 2}
|
|
239
|
+
alignHorizontal="center"
|
|
240
|
+
alignVertical="middle"
|
|
241
|
+
fontSize={14}
|
|
242
|
+
fontWeight="bold"
|
|
243
|
+
fill={axisColor}
|
|
244
|
+
>
|
|
245
|
+
{yTitle}
|
|
246
|
+
</Text>,
|
|
247
|
+
);
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
if (xTitle) {
|
|
251
|
+
titleElements.push(
|
|
252
|
+
<Text
|
|
253
|
+
x={barStartX + resolvedBarAreaWidth / 2}
|
|
254
|
+
y={axisY + xTickSpace + xTitleSpace / 2}
|
|
255
|
+
alignHorizontal="center"
|
|
256
|
+
alignVertical="middle"
|
|
257
|
+
fontSize={14}
|
|
258
|
+
fontWeight="bold"
|
|
259
|
+
fill={axisColor}
|
|
260
|
+
>
|
|
261
|
+
{xTitle}
|
|
262
|
+
</Text>,
|
|
263
|
+
);
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
return (
|
|
267
|
+
<FlexLayout
|
|
268
|
+
id="infographic-container"
|
|
269
|
+
flexDirection="column"
|
|
270
|
+
justifyContent="center"
|
|
271
|
+
alignItems="center"
|
|
272
|
+
>
|
|
273
|
+
{titleContent}
|
|
274
|
+
<Group width={totalWidth} height={totalHeight}>
|
|
275
|
+
<Group>{gridElements}</Group>
|
|
276
|
+
<Group>{barElements}</Group>
|
|
277
|
+
<Group>{valueElements}</Group>
|
|
278
|
+
<Group>{titleElements}</Group>
|
|
279
|
+
<Group>{[...axisElements, ...tickElements]}</Group>
|
|
280
|
+
<ItemsGroup>{itemElements}</ItemsGroup>
|
|
281
|
+
</Group>
|
|
282
|
+
</FlexLayout>
|
|
283
|
+
);
|
|
284
|
+
};
|
|
285
|
+
|
|
286
|
+
registerStructure('chart-bar', {
|
|
287
|
+
component: ChartBar,
|
|
288
|
+
composites: ['title', 'item', 'xTitle', 'yTitle'],
|
|
289
|
+
});
|
|
@@ -0,0 +1,415 @@
|
|
|
1
|
+
import { scaleLinear } from 'd3';
|
|
2
|
+
import type { ComponentType, JSXElement } from '../../jsx';
|
|
3
|
+
import { Defs, Ellipse, getElementBounds, Group, Path, Text } from '../../jsx';
|
|
4
|
+
import { ItemDatum, Padding } from '../../types';
|
|
5
|
+
import { getSimpleHash, parsePadding } from '../../utils';
|
|
6
|
+
import { ItemsGroup } from '../components';
|
|
7
|
+
import { FlexLayout } from '../layouts';
|
|
8
|
+
import { getColorPrimary, getPaletteColor, getThemeColors } from '../utils';
|
|
9
|
+
import { registerStructure } from './registry';
|
|
10
|
+
import type { BaseStructureProps } from './types';
|
|
11
|
+
|
|
12
|
+
export interface ChartLineProps extends BaseStructureProps {
|
|
13
|
+
width?: number;
|
|
14
|
+
height?: number;
|
|
15
|
+
gap?: number;
|
|
16
|
+
padding?: Padding;
|
|
17
|
+
showValue?: boolean;
|
|
18
|
+
valueFormatter?: (value: number, datum: ItemDatum) => string;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export const ChartLine: ComponentType<ChartLineProps> = (props) => {
|
|
22
|
+
const {
|
|
23
|
+
Title,
|
|
24
|
+
Item,
|
|
25
|
+
data,
|
|
26
|
+
width,
|
|
27
|
+
height = 260,
|
|
28
|
+
gap = 10,
|
|
29
|
+
padding = 24,
|
|
30
|
+
showValue = true,
|
|
31
|
+
options,
|
|
32
|
+
valueFormatter = (value) => value.toString(),
|
|
33
|
+
} = props;
|
|
34
|
+
|
|
35
|
+
const { title, desc, items = [], xTitle, yTitle } = data;
|
|
36
|
+
const titleContent = Title ? <Title title={title} desc={desc} /> : null;
|
|
37
|
+
|
|
38
|
+
if (items.length === 0) {
|
|
39
|
+
return (
|
|
40
|
+
<FlexLayout
|
|
41
|
+
id="infographic-container"
|
|
42
|
+
flexDirection="column"
|
|
43
|
+
justifyContent="center"
|
|
44
|
+
alignItems="center"
|
|
45
|
+
>
|
|
46
|
+
{titleContent}
|
|
47
|
+
</FlexLayout>
|
|
48
|
+
);
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
const [paddingTop, paddingRight, paddingBottom, paddingLeft] =
|
|
52
|
+
parsePadding(padding);
|
|
53
|
+
|
|
54
|
+
const itemProps = {
|
|
55
|
+
indexes: [0],
|
|
56
|
+
datum: items[0],
|
|
57
|
+
data,
|
|
58
|
+
positionH: 'center',
|
|
59
|
+
positionV: 'normal',
|
|
60
|
+
};
|
|
61
|
+
const sampleBounds = getElementBounds(<Item {...itemProps} />);
|
|
62
|
+
const labelWidth = sampleBounds.width;
|
|
63
|
+
const labelHeight = sampleBounds.height;
|
|
64
|
+
const xTickSpace = Math.max(28, labelHeight + 14);
|
|
65
|
+
const yTickSpace = 44;
|
|
66
|
+
const yTitleSpace = yTitle ? 26 : 0;
|
|
67
|
+
const xTitleSpace = xTitle ? 22 : 0;
|
|
68
|
+
|
|
69
|
+
const baseSpacing = labelWidth + gap;
|
|
70
|
+
const naturalChartWidth =
|
|
71
|
+
items.length > 0 ? (items.length - 1) * baseSpacing + labelWidth : 0;
|
|
72
|
+
const targetChartWidth =
|
|
73
|
+
width !== undefined ? width : Math.max(200, naturalChartWidth || 320);
|
|
74
|
+
const spacing =
|
|
75
|
+
items.length > 1
|
|
76
|
+
? Math.max(
|
|
77
|
+
baseSpacing,
|
|
78
|
+
(targetChartWidth - labelWidth) / (items.length - 1),
|
|
79
|
+
)
|
|
80
|
+
: 0;
|
|
81
|
+
const derivedChartWidth =
|
|
82
|
+
items.length > 0
|
|
83
|
+
? Math.max(labelWidth, (items.length - 1) * spacing + labelWidth)
|
|
84
|
+
: 0;
|
|
85
|
+
|
|
86
|
+
const chartOriginX = paddingLeft + yTickSpace + yTitleSpace;
|
|
87
|
+
const chartOriginY = paddingTop + yTitleSpace;
|
|
88
|
+
|
|
89
|
+
const totalWidth = chartOriginX + derivedChartWidth + paddingRight;
|
|
90
|
+
const totalHeight =
|
|
91
|
+
chartOriginY + height + xTickSpace + xTitleSpace + paddingBottom;
|
|
92
|
+
|
|
93
|
+
const values = items.map((item) => item.value ?? 0);
|
|
94
|
+
const maxValue = Math.max(...values, 0);
|
|
95
|
+
const minValue = Math.min(...values, 0);
|
|
96
|
+
const domainPadding = Math.max(Math.abs(maxValue), Math.abs(minValue)) * 0.1;
|
|
97
|
+
const domainMin = minValue < 0 ? minValue - domainPadding : 0;
|
|
98
|
+
let domainMax = maxValue > 0 ? maxValue + domainPadding : 1;
|
|
99
|
+
|
|
100
|
+
if (domainMax === domainMin) {
|
|
101
|
+
domainMax = domainMin + 1;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
const scaleY = scaleLinear()
|
|
105
|
+
.domain([domainMin, domainMax])
|
|
106
|
+
.nice()
|
|
107
|
+
.range([height, 0]);
|
|
108
|
+
|
|
109
|
+
const zeroY = Math.max(0, Math.min(height, scaleY(0)));
|
|
110
|
+
const axisBaseY = domainMax <= 0 ? 0 : domainMin >= 0 ? height : zeroY;
|
|
111
|
+
const colorPrimary = getColorPrimary(options);
|
|
112
|
+
const themeColors = getThemeColors(options.themeConfig);
|
|
113
|
+
const axisColor = themeColors.colorText || '#666';
|
|
114
|
+
|
|
115
|
+
const gridElements: JSXElement[] = [];
|
|
116
|
+
const axisElements: JSXElement[] = [];
|
|
117
|
+
const lineElements: JSXElement[] = [];
|
|
118
|
+
const pointElements: JSXElement[] = [];
|
|
119
|
+
const valueElements: JSXElement[] = [];
|
|
120
|
+
const titleElements: JSXElement[] = [];
|
|
121
|
+
const tickElements: JSXElement[] = [];
|
|
122
|
+
|
|
123
|
+
const ticksY = scaleY.ticks(6);
|
|
124
|
+
ticksY.forEach((tick) => {
|
|
125
|
+
const yPos = chartOriginY + scaleY(tick);
|
|
126
|
+
gridElements.push(
|
|
127
|
+
<Path
|
|
128
|
+
d={`M ${chartOriginX} ${yPos} L ${
|
|
129
|
+
chartOriginX + derivedChartWidth
|
|
130
|
+
} ${yPos}`}
|
|
131
|
+
width={derivedChartWidth}
|
|
132
|
+
height={1}
|
|
133
|
+
stroke={axisColor}
|
|
134
|
+
strokeWidth={1}
|
|
135
|
+
data-element-type="shape"
|
|
136
|
+
opacity={0.08}
|
|
137
|
+
/>,
|
|
138
|
+
);
|
|
139
|
+
tickElements.push(
|
|
140
|
+
<Text
|
|
141
|
+
x={chartOriginX - 8}
|
|
142
|
+
y={yPos}
|
|
143
|
+
alignHorizontal="right"
|
|
144
|
+
alignVertical="middle"
|
|
145
|
+
fontSize={12}
|
|
146
|
+
fill={axisColor}
|
|
147
|
+
>
|
|
148
|
+
{Number.isInteger(tick) ? tick.toString() : tick.toFixed(1)}
|
|
149
|
+
</Text>,
|
|
150
|
+
);
|
|
151
|
+
});
|
|
152
|
+
|
|
153
|
+
const xLabels: JSXElement[] = [];
|
|
154
|
+
const pointPositions: { x: number; y: number; datum: ItemDatum }[] = [];
|
|
155
|
+
const colorStopsData: { x: number; color: string }[] = [];
|
|
156
|
+
|
|
157
|
+
const createSmoothPath = (points: { x: number; y: number }[]) => {
|
|
158
|
+
if (points.length === 0) return '';
|
|
159
|
+
if (points.length === 1) {
|
|
160
|
+
const p = points[0];
|
|
161
|
+
return `M ${p.x} ${p.y}`;
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
const segments: string[] = [];
|
|
165
|
+
segments.push(`M ${points[0].x} ${points[0].y}`);
|
|
166
|
+
|
|
167
|
+
for (let i = 0; i < points.length - 1; i++) {
|
|
168
|
+
const p0 = points[i - 1] || points[i];
|
|
169
|
+
const p1 = points[i];
|
|
170
|
+
const p2 = points[i + 1];
|
|
171
|
+
const p3 = points[i + 2] || p2;
|
|
172
|
+
|
|
173
|
+
const cp1x = p1.x + (p2.x - p0.x) / 6;
|
|
174
|
+
const cp1y = p1.y + (p2.y - p0.y) / 6;
|
|
175
|
+
const cp2x = p2.x - (p3.x - p1.x) / 6;
|
|
176
|
+
const cp2y = p2.y - (p3.y - p1.y) / 6;
|
|
177
|
+
|
|
178
|
+
segments.push(`C ${cp1x} ${cp1y} ${cp2x} ${cp2y} ${p2.x} ${p2.y}`);
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
return segments.join(' ');
|
|
182
|
+
};
|
|
183
|
+
|
|
184
|
+
items.forEach((item, index) => {
|
|
185
|
+
const x = chartOriginX + index * spacing + labelWidth / 2;
|
|
186
|
+
const y = chartOriginY + scaleY(item.value ?? 0);
|
|
187
|
+
pointPositions.push({ x, y, datum: item });
|
|
188
|
+
xLabels.push(
|
|
189
|
+
<Item
|
|
190
|
+
{...itemProps}
|
|
191
|
+
indexes={[index]}
|
|
192
|
+
datum={item}
|
|
193
|
+
x={x - labelWidth / 2}
|
|
194
|
+
y={chartOriginY + height + 4}
|
|
195
|
+
/>,
|
|
196
|
+
);
|
|
197
|
+
|
|
198
|
+
const stopColor =
|
|
199
|
+
getPaletteColor(options, [index]) || themeColors.colorPrimary;
|
|
200
|
+
colorStopsData.push({ x, color: stopColor });
|
|
201
|
+
});
|
|
202
|
+
|
|
203
|
+
const minStopX =
|
|
204
|
+
colorStopsData.length > 0
|
|
205
|
+
? Math.min(...colorStopsData.map((s) => s.x))
|
|
206
|
+
: chartOriginX;
|
|
207
|
+
const maxStopX =
|
|
208
|
+
colorStopsData.length > 0
|
|
209
|
+
? Math.max(...colorStopsData.map((s) => s.x))
|
|
210
|
+
: chartOriginX + derivedChartWidth;
|
|
211
|
+
const stopSpan = Math.max(1, maxStopX - minStopX);
|
|
212
|
+
|
|
213
|
+
const gradientStops = colorStopsData.map((s) => (
|
|
214
|
+
<stop
|
|
215
|
+
offset={`${((s.x - minStopX) / stopSpan) * 100}%`}
|
|
216
|
+
stopColor={s.color}
|
|
217
|
+
/>
|
|
218
|
+
));
|
|
219
|
+
|
|
220
|
+
const areaStops = colorStopsData.map((s) => (
|
|
221
|
+
<stop
|
|
222
|
+
offset={`${((s.x - minStopX) / stopSpan) * 100}%`}
|
|
223
|
+
stopColor={s.color}
|
|
224
|
+
stopOpacity="0.18"
|
|
225
|
+
/>
|
|
226
|
+
));
|
|
227
|
+
|
|
228
|
+
if (colorStopsData.length > 0) {
|
|
229
|
+
const lastColor = colorStopsData[colorStopsData.length - 1].color;
|
|
230
|
+
gradientStops.push(<stop offset="100%" stopColor={lastColor} />);
|
|
231
|
+
areaStops.push(
|
|
232
|
+
<stop offset="100%" stopColor={lastColor} stopOpacity="0.04" />,
|
|
233
|
+
);
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
const gradientIdBase = `chart-line-${getSimpleHash(
|
|
237
|
+
[
|
|
238
|
+
derivedChartWidth,
|
|
239
|
+
height,
|
|
240
|
+
axisColor,
|
|
241
|
+
colorPrimary,
|
|
242
|
+
colorStopsData.map((s) => `${s.x.toFixed(2)}-${s.color}`).join(),
|
|
243
|
+
].join(':'),
|
|
244
|
+
)}`;
|
|
245
|
+
const gradientStrokeId = `${gradientIdBase}-stroke`;
|
|
246
|
+
const gradientAreaId = `${gradientIdBase}-area`;
|
|
247
|
+
|
|
248
|
+
const smoothLinePath = createSmoothPath(pointPositions);
|
|
249
|
+
|
|
250
|
+
lineElements.push(
|
|
251
|
+
<Path
|
|
252
|
+
d={smoothLinePath}
|
|
253
|
+
width={derivedChartWidth}
|
|
254
|
+
height={height}
|
|
255
|
+
stroke={`url(#${gradientStrokeId})`}
|
|
256
|
+
strokeWidth={3}
|
|
257
|
+
fill="none"
|
|
258
|
+
data-element-type="shape"
|
|
259
|
+
/>,
|
|
260
|
+
);
|
|
261
|
+
|
|
262
|
+
const areaCurveTail = smoothLinePath.includes('C')
|
|
263
|
+
? smoothLinePath.slice(smoothLinePath.indexOf('C'))
|
|
264
|
+
: '';
|
|
265
|
+
|
|
266
|
+
const areaPath = [
|
|
267
|
+
`M ${pointPositions[0].x} ${chartOriginY + axisBaseY}`,
|
|
268
|
+
`L ${pointPositions[0].x} ${pointPositions[0].y}`,
|
|
269
|
+
areaCurveTail,
|
|
270
|
+
`L ${pointPositions[pointPositions.length - 1].x} ${
|
|
271
|
+
chartOriginY + axisBaseY
|
|
272
|
+
}`,
|
|
273
|
+
'Z',
|
|
274
|
+
].join(' ');
|
|
275
|
+
|
|
276
|
+
lineElements.push(
|
|
277
|
+
<Path
|
|
278
|
+
d={areaPath}
|
|
279
|
+
width={derivedChartWidth}
|
|
280
|
+
height={height}
|
|
281
|
+
fill={`url(#${gradientAreaId})`}
|
|
282
|
+
stroke="none"
|
|
283
|
+
data-element-type="shape"
|
|
284
|
+
/>,
|
|
285
|
+
);
|
|
286
|
+
|
|
287
|
+
pointPositions.forEach((pos, index) => {
|
|
288
|
+
const paletteColor =
|
|
289
|
+
getPaletteColor(options, [index]) || themeColors.colorPrimary;
|
|
290
|
+
pointElements.push(
|
|
291
|
+
<Ellipse
|
|
292
|
+
x={pos.x - 6}
|
|
293
|
+
y={pos.y - 6}
|
|
294
|
+
width={12}
|
|
295
|
+
height={12}
|
|
296
|
+
fill={paletteColor}
|
|
297
|
+
data-element-type="shape"
|
|
298
|
+
/>,
|
|
299
|
+
);
|
|
300
|
+
|
|
301
|
+
if (showValue) {
|
|
302
|
+
valueElements.push(
|
|
303
|
+
<Text
|
|
304
|
+
x={pos.x}
|
|
305
|
+
y={pos.y - 12}
|
|
306
|
+
alignHorizontal="center"
|
|
307
|
+
alignVertical="bottom"
|
|
308
|
+
fontSize={12}
|
|
309
|
+
fontWeight="bold"
|
|
310
|
+
fill={paletteColor}
|
|
311
|
+
>
|
|
312
|
+
{valueFormatter(pos.datum.value ?? 0, pos.datum)}
|
|
313
|
+
</Text>,
|
|
314
|
+
);
|
|
315
|
+
}
|
|
316
|
+
});
|
|
317
|
+
|
|
318
|
+
axisElements.push(
|
|
319
|
+
<Path
|
|
320
|
+
d={`M ${chartOriginX} ${chartOriginY + axisBaseY} L ${
|
|
321
|
+
chartOriginX + derivedChartWidth
|
|
322
|
+
} ${chartOriginY + axisBaseY}`}
|
|
323
|
+
width={derivedChartWidth}
|
|
324
|
+
height={1}
|
|
325
|
+
stroke={axisColor}
|
|
326
|
+
strokeWidth={1}
|
|
327
|
+
data-element-type="shape"
|
|
328
|
+
/>,
|
|
329
|
+
);
|
|
330
|
+
|
|
331
|
+
axisElements.push(
|
|
332
|
+
<Path
|
|
333
|
+
d={`M ${chartOriginX} ${chartOriginY} L ${chartOriginX} ${
|
|
334
|
+
chartOriginY + height
|
|
335
|
+
}`}
|
|
336
|
+
width={1}
|
|
337
|
+
height={height}
|
|
338
|
+
stroke={axisColor}
|
|
339
|
+
strokeWidth={1}
|
|
340
|
+
data-element-type="shape"
|
|
341
|
+
/>,
|
|
342
|
+
);
|
|
343
|
+
|
|
344
|
+
if (xTitle) {
|
|
345
|
+
titleElements.push(
|
|
346
|
+
<Text
|
|
347
|
+
x={chartOriginX + derivedChartWidth / 2}
|
|
348
|
+
y={chartOriginY + height + xTickSpace + xTitleSpace / 2}
|
|
349
|
+
alignHorizontal="center"
|
|
350
|
+
alignVertical="middle"
|
|
351
|
+
fontSize={14}
|
|
352
|
+
fontWeight="bold"
|
|
353
|
+
fill={axisColor}
|
|
354
|
+
>
|
|
355
|
+
{xTitle}
|
|
356
|
+
</Text>,
|
|
357
|
+
);
|
|
358
|
+
}
|
|
359
|
+
|
|
360
|
+
if (yTitle) {
|
|
361
|
+
titleElements.push(
|
|
362
|
+
<Text
|
|
363
|
+
x={paddingLeft + yTitleSpace / 2}
|
|
364
|
+
y={chartOriginY + height / 2}
|
|
365
|
+
alignHorizontal="center"
|
|
366
|
+
alignVertical="middle"
|
|
367
|
+
fontSize={14}
|
|
368
|
+
fontWeight="bold"
|
|
369
|
+
fill={axisColor}
|
|
370
|
+
>
|
|
371
|
+
{yTitle}
|
|
372
|
+
</Text>,
|
|
373
|
+
);
|
|
374
|
+
}
|
|
375
|
+
|
|
376
|
+
return (
|
|
377
|
+
<FlexLayout
|
|
378
|
+
id="infographic-container"
|
|
379
|
+
flexDirection="column"
|
|
380
|
+
justifyContent="center"
|
|
381
|
+
alignItems="center"
|
|
382
|
+
>
|
|
383
|
+
{titleContent}
|
|
384
|
+
<Group width={totalWidth} height={totalHeight}>
|
|
385
|
+
<Defs>
|
|
386
|
+
<linearGradient
|
|
387
|
+
id={gradientStrokeId}
|
|
388
|
+
x1="0%"
|
|
389
|
+
y1="0%"
|
|
390
|
+
x2="100%"
|
|
391
|
+
y2="0%"
|
|
392
|
+
>
|
|
393
|
+
{gradientStops}
|
|
394
|
+
</linearGradient>
|
|
395
|
+
<linearGradient id={gradientAreaId} x1="0%" y1="0%" x2="100%" y2="0%">
|
|
396
|
+
{areaStops}
|
|
397
|
+
<stop offset="100%" stopColor={colorPrimary} stopOpacity="0.04" />
|
|
398
|
+
</linearGradient>
|
|
399
|
+
</Defs>
|
|
400
|
+
<Group>{gridElements}</Group>
|
|
401
|
+
<Group>{[...axisElements, ...tickElements]}</Group>
|
|
402
|
+
<Group>{lineElements}</Group>
|
|
403
|
+
<Group>{pointElements}</Group>
|
|
404
|
+
<Group>{valueElements}</Group>
|
|
405
|
+
<Group>{titleElements}</Group>
|
|
406
|
+
<ItemsGroup>{xLabels}</ItemsGroup>
|
|
407
|
+
</Group>
|
|
408
|
+
</FlexLayout>
|
|
409
|
+
);
|
|
410
|
+
};
|
|
411
|
+
|
|
412
|
+
registerStructure('chart-line', {
|
|
413
|
+
component: ChartLine,
|
|
414
|
+
composites: ['title', 'item', 'xTitle', 'yTitle'],
|
|
415
|
+
});
|