@unovis/ts 1.0.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.cache/.npm/_cacache/content-v2/sha512/61/45/6fe676782aa108257b260c25e8140c6d37bbc18450696066eeeb68af0ecc30da712b9d888ddf31844ec3334478f2b142f957298bebde9cba8de0ffc3c2d7 +0 -0
- package/.cache/.npm/_cacache/content-v2/sha512/c1/fd/5918e37e37c05cdfc4482fae30721b118c227a6b70b2830ff04cd62a82899a4ad1beaa562b4c673122c932c2eb017af2f4da3c8b7f9a0affbd1d926341a0 +0 -0
- package/.cache/.npm/_cacache/index-v5/1f/ac/9e290f9c0248c783167cd161d22fe850034423d1a425963bd64808710219 +3 -0
- package/LICENSE +193 -0
- package/components/area/config.d.ts +25 -0
- package/components/area/config.js +16 -0
- package/components/area/config.js.map +1 -0
- package/components/area/index.d.ts +19 -0
- package/components/area/index.js +103 -0
- package/components/area/index.js.map +1 -0
- package/components/area/style.d.ts +3 -0
- package/components/area/style.js +32 -0
- package/components/area/style.js.map +1 -0
- package/components/area/types.d.ts +6 -0
- package/components/axis/config.d.ts +74 -0
- package/components/axis/config.js +33 -0
- package/components/axis/config.js.map +1 -0
- package/components/axis/index.d.ts +51 -0
- package/components/axis/index.js +291 -0
- package/components/axis/index.js.map +1 -0
- package/components/axis/modules/tick.d.ts +5 -0
- package/components/axis/modules/tick.js +48 -0
- package/components/axis/modules/tick.js.map +1 -0
- package/components/axis/style.d.ts +9 -0
- package/components/axis/style.js +95 -0
- package/components/axis/style.js.map +1 -0
- package/components/axis/types.d.ts +4 -0
- package/components/axis/types.js +8 -0
- package/components/axis/types.js.map +1 -0
- package/components/brush/config.d.ts +42 -0
- package/components/brush/config.js +24 -0
- package/components/brush/config.js.map +1 -0
- package/components/brush/index.d.ts +28 -0
- package/components/brush/index.js +199 -0
- package/components/brush/index.js.map +1 -0
- package/components/brush/style.d.ts +5 -0
- package/components/brush/style.js +63 -0
- package/components/brush/style.js.map +1 -0
- package/components/brush/types.d.ts +7 -0
- package/components/brush/types.js +8 -0
- package/components/brush/types.js.map +1 -0
- package/components/bullet-legend/config.d.ts +24 -0
- package/components/bullet-legend/config.js +16 -0
- package/components/bullet-legend/config.js.map +1 -0
- package/components/bullet-legend/index.d.ts +19 -0
- package/components/bullet-legend/index.js +79 -0
- package/components/bullet-legend/index.js.map +1 -0
- package/components/bullet-legend/style.d.ts +6 -0
- package/components/bullet-legend/style.js +66 -0
- package/components/bullet-legend/style.js.map +1 -0
- package/components/bullet-legend/types.d.ts +7 -0
- package/components/chord-diagram/config.d.ts +42 -0
- package/components/chord-diagram/config.js +25 -0
- package/components/chord-diagram/config.js.map +1 -0
- package/components/chord-diagram/index.d.ts +49 -0
- package/components/chord-diagram/index.js +280 -0
- package/components/chord-diagram/index.js.map +1 -0
- package/components/chord-diagram/modules/label.d.ts +8 -0
- package/components/chord-diagram/modules/label.js +128 -0
- package/components/chord-diagram/modules/label.js.map +1 -0
- package/components/chord-diagram/modules/link.d.ts +20 -0
- package/components/chord-diagram/modules/link.js +32 -0
- package/components/chord-diagram/modules/link.js.map +1 -0
- package/components/chord-diagram/modules/node.d.ts +17 -0
- package/components/chord-diagram/modules/node.js +52 -0
- package/components/chord-diagram/modules/node.js.map +1 -0
- package/components/chord-diagram/style.d.ts +13 -0
- package/components/chord-diagram/style.js +88 -0
- package/components/chord-diagram/style.js.map +1 -0
- package/components/chord-diagram/types.d.ts +40 -0
- package/components/chord-diagram/types.js +8 -0
- package/components/chord-diagram/types.js.map +1 -0
- package/components/crosshair/config.d.ts +43 -0
- package/components/crosshair/config.js +19 -0
- package/components/crosshair/config.js.map +1 -0
- package/components/crosshair/index.d.ts +35 -0
- package/components/crosshair/index.js +180 -0
- package/components/crosshair/index.js.map +1 -0
- package/components/crosshair/style.d.ts +4 -0
- package/components/crosshair/style.js +25 -0
- package/components/crosshair/style.js.map +1 -0
- package/components/crosshair/types.d.ts +13 -0
- package/components/donut/config.d.ts +45 -0
- package/components/donut/config.js +25 -0
- package/components/donut/config.js.map +1 -0
- package/components/donut/index.d.ts +20 -0
- package/components/donut/index.js +84 -0
- package/components/donut/index.js.map +1 -0
- package/components/donut/modules/arc.d.ts +10 -0
- package/components/donut/modules/arc.js +53 -0
- package/components/donut/modules/arc.js.map +1 -0
- package/components/donut/style.d.ts +6 -0
- package/components/donut/style.js +53 -0
- package/components/donut/style.js.map +1 -0
- package/components/donut/types.d.ts +12 -0
- package/components/flow-legend/config.d.ts +26 -0
- package/components/flow-legend/config.js +17 -0
- package/components/flow-legend/config.js.map +1 -0
- package/components/flow-legend/index.d.ts +16 -0
- package/components/flow-legend/index.js +73 -0
- package/components/flow-legend/index.js.map +1 -0
- package/components/flow-legend/style.d.ts +8 -0
- package/components/flow-legend/style.js +80 -0
- package/components/flow-legend/style.js.map +1 -0
- package/components/flow-legend/types.d.ts +9 -0
- package/components/flow-legend/types.js +8 -0
- package/components/flow-legend/types.js.map +1 -0
- package/components/free-brush/config.d.ts +45 -0
- package/components/free-brush/config.js +24 -0
- package/components/free-brush/config.js.map +1 -0
- package/components/free-brush/index.d.ts +20 -0
- package/components/free-brush/index.js +191 -0
- package/components/free-brush/index.js.map +1 -0
- package/components/free-brush/style.d.ts +4 -0
- package/components/free-brush/style.js +50 -0
- package/components/free-brush/style.js.map +1 -0
- package/components/free-brush/types.d.ts +7 -0
- package/components/free-brush/types.js +9 -0
- package/components/free-brush/types.js.map +1 -0
- package/components/graph/config.d.ts +207 -0
- package/components/graph/config.js +75 -0
- package/components/graph/config.js.map +1 -0
- package/components/graph/index.d.ts +121 -0
- package/components/graph/index.js +653 -0
- package/components/graph/index.js.map +1 -0
- package/components/graph/modules/layout-helpers.d.ts +2 -0
- package/components/graph/modules/layout-helpers.js +11 -0
- package/components/graph/modules/layout-helpers.js.map +1 -0
- package/components/graph/modules/layout.d.ts +9 -0
- package/components/graph/modules/layout.js +343 -0
- package/components/graph/modules/layout.js.map +1 -0
- package/components/graph/modules/link/helper.d.ts +25 -0
- package/components/graph/modules/link/helper.js +78 -0
- package/components/graph/modules/link/helper.js.map +1 -0
- package/components/graph/modules/link/index.d.ts +12 -0
- package/components/graph/modules/link/index.js +201 -0
- package/components/graph/modules/link/index.js.map +1 -0
- package/components/graph/modules/link/style.d.ts +15 -0
- package/components/graph/modules/link/style.js +112 -0
- package/components/graph/modules/link/style.js.map +1 -0
- package/components/graph/modules/node/helper.d.ts +21 -0
- package/components/graph/modules/node/helper.js +127 -0
- package/components/graph/modules/node/helper.js.map +1 -0
- package/components/graph/modules/node/index.d.ts +12 -0
- package/components/graph/modules/node/index.js +248 -0
- package/components/graph/modules/node/index.js.map +1 -0
- package/components/graph/modules/node/style.d.ts +24 -0
- package/components/graph/modules/node/style.js +273 -0
- package/components/graph/modules/node/style.js.map +1 -0
- package/components/graph/modules/panel/helper.d.ts +16 -0
- package/components/graph/modules/panel/helper.js +110 -0
- package/components/graph/modules/panel/helper.js.map +1 -0
- package/components/graph/modules/panel/index.d.ts +7 -0
- package/components/graph/modules/panel/index.js +103 -0
- package/components/graph/modules/panel/index.js.map +1 -0
- package/components/graph/modules/panel/style.d.ts +14 -0
- package/components/graph/modules/panel/style.js +123 -0
- package/components/graph/modules/panel/style.js.map +1 -0
- package/components/graph/modules/shape.d.ts +7 -0
- package/components/graph/modules/shape.js +80 -0
- package/components/graph/modules/shape.js.map +1 -0
- package/components/graph/modules/zoom-levels.d.ts +6 -0
- package/components/graph/modules/zoom-levels.js +10 -0
- package/components/graph/modules/zoom-levels.js.map +1 -0
- package/components/graph/style.d.ts +6 -0
- package/components/graph/style.js +66 -0
- package/components/graph/style.js.map +1 -0
- package/components/graph/types.d.ts +120 -0
- package/components/graph/types.js +29 -0
- package/components/graph/types.js.map +1 -0
- package/components/grouped-bar/config.d.ts +36 -0
- package/components/grouped-bar/config.js +20 -0
- package/components/grouped-bar/config.js.map +1 -0
- package/components/grouped-bar/index.d.ts +30 -0
- package/components/grouped-bar/index.js +231 -0
- package/components/grouped-bar/index.js.map +1 -0
- package/components/grouped-bar/style.d.ts +5 -0
- package/components/grouped-bar/style.js +36 -0
- package/components/grouped-bar/style.js.map +1 -0
- package/components/leaflet-flow-map/config.d.ts +46 -0
- package/components/leaflet-flow-map/config.js +25 -0
- package/components/leaflet-flow-map/config.js.map +1 -0
- package/components/leaflet-flow-map/index.d.ts +51 -0
- package/components/leaflet-flow-map/index.js +220 -0
- package/components/leaflet-flow-map/index.js.map +1 -0
- package/components/leaflet-flow-map/renderer-utils.d.ts +5 -0
- package/components/leaflet-flow-map/renderer-utils.js +15 -0
- package/components/leaflet-flow-map/renderer-utils.js.map +1 -0
- package/components/leaflet-flow-map/renderer.d.ts +26 -0
- package/components/leaflet-flow-map/renderer.js +117 -0
- package/components/leaflet-flow-map/renderer.js.map +1 -0
- package/components/leaflet-flow-map/shaders.d.ts +2 -0
- package/components/leaflet-flow-map/shaders.js +27 -0
- package/components/leaflet-flow-map/shaders.js.map +1 -0
- package/components/leaflet-flow-map/types.d.ts +23 -0
- package/components/leaflet-map/config.d.ts +175 -0
- package/components/leaflet-map/config.js +67 -0
- package/components/leaflet-map/config.js.map +1 -0
- package/components/leaflet-map/index.d.ts +95 -0
- package/components/leaflet-map/index.js +648 -0
- package/components/leaflet-map/index.js.map +1 -0
- package/components/leaflet-map/leaflet.css.js +4 -0
- package/components/leaflet-map/leaflet.css.js.map +1 -0
- package/components/leaflet-map/modules/clusterBackground.d.ts +4 -0
- package/components/leaflet-map/modules/clusterBackground.js +27 -0
- package/components/leaflet-map/modules/clusterBackground.js.map +1 -0
- package/components/leaflet-map/modules/donut.d.ts +3 -0
- package/components/leaflet-map/modules/donut.js +25 -0
- package/components/leaflet-map/modules/donut.js.map +1 -0
- package/components/leaflet-map/modules/map.d.ts +13 -0
- package/components/leaflet-map/modules/map.js +139 -0
- package/components/leaflet-map/modules/map.js.map +1 -0
- package/components/leaflet-map/modules/node.d.ts +8 -0
- package/components/leaflet-map/modules/node.js +148 -0
- package/components/leaflet-map/modules/node.js.map +1 -0
- package/components/leaflet-map/modules/selectionRing.d.ts +6 -0
- package/components/leaflet-map/modules/selectionRing.js +41 -0
- package/components/leaflet-map/modules/selectionRing.js.map +1 -0
- package/components/leaflet-map/modules/utils.d.ts +49 -0
- package/components/leaflet-map/modules/utils.js +207 -0
- package/components/leaflet-map/modules/utils.js.map +1 -0
- package/components/leaflet-map/renderer/map-style.d.ts +4 -0
- package/components/leaflet-map/renderer/map-style.js +15 -0
- package/components/leaflet-map/renderer/map-style.js.map +1 -0
- package/components/leaflet-map/renderer/mapboxgl/mapboxgl-dark-theme.json.js +40 -0
- package/components/leaflet-map/renderer/mapboxgl/mapboxgl-dark-theme.json.js.map +1 -0
- package/components/leaflet-map/renderer/mapboxgl/mapboxgl-light-theme.json.js +40 -0
- package/components/leaflet-map/renderer/mapboxgl/mapboxgl-light-theme.json.js.map +1 -0
- package/components/leaflet-map/renderer/mapboxgl/mapboxgl-settings.json.js +4987 -0
- package/components/leaflet-map/renderer/mapboxgl/mapboxgl-settings.json.js.map +1 -0
- package/components/leaflet-map/renderer/mapboxgl-layer.d.ts +7 -0
- package/components/leaflet-map/renderer/mapboxgl-layer.js +28 -0
- package/components/leaflet-map/renderer/mapboxgl-layer.js.map +1 -0
- package/components/leaflet-map/renderer/mapboxgl-utils.d.ts +5 -0
- package/components/leaflet-map/renderer/mapboxgl-utils.js +39 -0
- package/components/leaflet-map/renderer/mapboxgl-utils.js.map +1 -0
- package/components/leaflet-map/style.d.ts +19 -0
- package/components/leaflet-map/style.js +192 -0
- package/components/leaflet-map/style.js.map +1 -0
- package/components/leaflet-map/types.d.ts +70 -0
- package/components/leaflet-map/types.js +10 -0
- package/components/leaflet-map/types.js.map +1 -0
- package/components/line/config.d.ts +30 -0
- package/components/line/config.js +17 -0
- package/components/line/config.js.map +1 -0
- package/components/line/index.d.ts +27 -0
- package/components/line/index.js +139 -0
- package/components/line/index.js.map +1 -0
- package/components/line/style.d.ts +6 -0
- package/components/line/style.js +35 -0
- package/components/line/style.js.map +1 -0
- package/components/line/types.d.ts +12 -0
- package/components/radial-dendrogram/config.d.ts +34 -0
- package/components/radial-dendrogram/config.js +20 -0
- package/components/radial-dendrogram/config.js.map +1 -0
- package/components/radial-dendrogram/index.d.ts +22 -0
- package/components/radial-dendrogram/index.js +98 -0
- package/components/radial-dendrogram/index.js.map +1 -0
- package/components/radial-dendrogram/modules/label.d.ts +8 -0
- package/components/radial-dendrogram/modules/label.js +70 -0
- package/components/radial-dendrogram/modules/label.js.map +1 -0
- package/components/radial-dendrogram/modules/link.d.ts +19 -0
- package/components/radial-dendrogram/modules/link.js +59 -0
- package/components/radial-dendrogram/modules/link.js.map +1 -0
- package/components/radial-dendrogram/modules/node.d.ts +16 -0
- package/components/radial-dendrogram/modules/node.js +51 -0
- package/components/radial-dendrogram/modules/node.js.map +1 -0
- package/components/radial-dendrogram/style.d.ts +6 -0
- package/components/radial-dendrogram/style.js +54 -0
- package/components/radial-dendrogram/style.js.map +1 -0
- package/components/radial-dendrogram/types.d.ts +34 -0
- package/components/sankey/config.d.ts +162 -0
- package/components/sankey/config.js +65 -0
- package/components/sankey/config.js.map +1 -0
- package/components/sankey/index.d.ts +56 -0
- package/components/sankey/index.js +299 -0
- package/components/sankey/index.js.map +1 -0
- package/components/sankey/modules/label.d.ts +23 -0
- package/components/sankey/modules/label.js +164 -0
- package/components/sankey/modules/label.js.map +1 -0
- package/components/sankey/modules/link.d.ts +13 -0
- package/components/sankey/modules/link.js +108 -0
- package/components/sankey/modules/link.js.map +1 -0
- package/components/sankey/modules/node.d.ts +10 -0
- package/components/sankey/modules/node.js +156 -0
- package/components/sankey/modules/node.js.map +1 -0
- package/components/sankey/style.d.ts +20 -0
- package/components/sankey/style.js +164 -0
- package/components/sankey/style.js.map +1 -0
- package/components/sankey/types.d.ts +84 -0
- package/components/sankey/types.js +34 -0
- package/components/sankey/types.js.map +1 -0
- package/components/scatter/config.d.ts +44 -0
- package/components/scatter/config.js +23 -0
- package/components/scatter/config.js.map +1 -0
- package/components/scatter/index.d.ts +19 -0
- package/components/scatter/index.js +123 -0
- package/components/scatter/index.js.map +1 -0
- package/components/scatter/modules/point.d.ts +7 -0
- package/components/scatter/modules/point.js +98 -0
- package/components/scatter/modules/point.js.map +1 -0
- package/components/scatter/style.d.ts +5 -0
- package/components/scatter/style.js +53 -0
- package/components/scatter/style.js.map +1 -0
- package/components/scatter/types.d.ts +13 -0
- package/components/stacked-bar/config.d.ts +38 -0
- package/components/stacked-bar/config.js +20 -0
- package/components/stacked-bar/config.js.map +1 -0
- package/components/stacked-bar/index.d.ts +27 -0
- package/components/stacked-bar/index.js +193 -0
- package/components/stacked-bar/index.js.map +1 -0
- package/components/stacked-bar/style.d.ts +5 -0
- package/components/stacked-bar/style.js +36 -0
- package/components/stacked-bar/style.js.map +1 -0
- package/components/stacked-bar/types.d.ts +5 -0
- package/components/timeline/config.d.ts +43 -0
- package/components/timeline/config.js +23 -0
- package/components/timeline/config.js.map +1 -0
- package/components/timeline/index.d.ts +43 -0
- package/components/timeline/index.js +235 -0
- package/components/timeline/index.js.map +1 -0
- package/components/timeline/style.d.ts +12 -0
- package/components/timeline/style.js +86 -0
- package/components/timeline/style.js.map +1 -0
- package/components/tooltip/config.d.ts +46 -0
- package/components/tooltip/config.js +19 -0
- package/components/tooltip/config.js.map +1 -0
- package/components/tooltip/index.d.ts +34 -0
- package/components/tooltip/index.js +147 -0
- package/components/tooltip/index.js.map +1 -0
- package/components/tooltip/style.js +72 -0
- package/components/tooltip/style.js.map +1 -0
- package/components/topojson-map/config.d.ts +99 -0
- package/components/topojson-map/config.js +42 -0
- package/components/topojson-map/config.js.map +1 -0
- package/components/topojson-map/index.d.ts +52 -0
- package/components/topojson-map/index.js +355 -0
- package/components/topojson-map/index.js.map +1 -0
- package/components/topojson-map/style.d.ts +11 -0
- package/components/topojson-map/style.js +97 -0
- package/components/topojson-map/style.js.map +1 -0
- package/components/topojson-map/types.d.ts +48 -0
- package/components/topojson-map/types.js +45 -0
- package/components/topojson-map/types.js.map +1 -0
- package/components/topojson-map/utils.d.ts +3 -0
- package/components/topojson-map/utils.js +30 -0
- package/components/topojson-map/utils.js.map +1 -0
- package/components/vis-controls/config.d.ts +12 -0
- package/components/vis-controls/config.js +13 -0
- package/components/vis-controls/config.js.map +1 -0
- package/components/vis-controls/index.d.ts +14 -0
- package/components/vis-controls/index.js +52 -0
- package/components/vis-controls/index.js.map +1 -0
- package/components/vis-controls/style.d.ts +11 -0
- package/components/vis-controls/style.js +75 -0
- package/components/vis-controls/style.js.map +1 -0
- package/components/vis-controls/types.d.ts +13 -0
- package/components/vis-controls/types.js +8 -0
- package/components/vis-controls/types.js.map +1 -0
- package/components/xy-labels/config.d.ts +48 -0
- package/components/xy-labels/config.js +25 -0
- package/components/xy-labels/config.js.map +1 -0
- package/components/xy-labels/index.d.ts +15 -0
- package/components/xy-labels/index.js +86 -0
- package/components/xy-labels/index.js.map +1 -0
- package/components/xy-labels/modules/label.d.ts +9 -0
- package/components/xy-labels/modules/label.js +105 -0
- package/components/xy-labels/modules/label.js.map +1 -0
- package/components/xy-labels/style.d.ts +5 -0
- package/components/xy-labels/style.js +53 -0
- package/components/xy-labels/style.js.map +1 -0
- package/components/xy-labels/types.d.ts +23 -0
- package/components/xy-labels/types.js +9 -0
- package/components/xy-labels/types.js.map +1 -0
- package/components.d.ts +52 -0
- package/containers/single-container/config.d.ts +12 -0
- package/containers/single-container/config.js +12 -0
- package/containers/single-container/config.js.map +1 -0
- package/containers/single-container/index.d.ts +17 -0
- package/containers/single-container/index.js +115 -0
- package/containers/single-container/index.js.map +1 -0
- package/containers/xy-container/config.d.ts +99 -0
- package/containers/xy-container/config.js +30 -0
- package/containers/xy-container/config.js.map +1 -0
- package/containers/xy-container/index.d.ts +33 -0
- package/containers/xy-container/index.js +322 -0
- package/containers/xy-container/index.js.map +1 -0
- package/containers.d.ts +6 -0
- package/core/component/config.d.ts +58 -0
- package/core/component/config.js +14 -0
- package/core/component/config.js.map +1 -0
- package/core/component/index.d.ts +38 -0
- package/core/component/index.js +112 -0
- package/core/component/index.js.map +1 -0
- package/core/component/types.d.ts +2 -0
- package/core/config/index.d.ts +3 -0
- package/core/config/index.js +16 -0
- package/core/config/index.js.map +1 -0
- package/core/container/config.d.ts +38 -0
- package/core/container/config.js +29 -0
- package/core/container/config.js.map +1 -0
- package/core/container/index.d.ts +25 -0
- package/core/container/index.js +92 -0
- package/core/container/index.js.map +1 -0
- package/core/xy-component/config.d.ts +38 -0
- package/core/xy-component/config.js +20 -0
- package/core/xy-component/config.js.map +1 -0
- package/core/xy-component/index.d.ts +25 -0
- package/core/xy-component/index.js +65 -0
- package/core/xy-component/index.js.map +1 -0
- package/data-models/core.d.ts +6 -0
- package/data-models/core.js +14 -0
- package/data-models/core.js.map +1 -0
- package/data-models/graph.d.ts +24 -0
- package/data-models/graph.js +101 -0
- package/data-models/graph.js.map +1 -0
- package/data-models/map-graph.d.ts +23 -0
- package/data-models/map-graph.js +59 -0
- package/data-models/map-graph.js.map +1 -0
- package/data-models/map.d.ts +5 -0
- package/data-models/map.js +12 -0
- package/data-models/map.js.map +1 -0
- package/data-models/series.d.ts +6 -0
- package/data-models/series.js +19 -0
- package/data-models/series.js.map +1 -0
- package/external/maplibre-gl/dist/maplibre-gl.css.js +4 -0
- package/external/maplibre-gl/dist/maplibre-gl.css.js.map +1 -0
- package/index.d.ts +4 -0
- package/index.js +49 -0
- package/index.js.map +1 -0
- package/maps/china-provinces.json.js +140373 -0
- package/maps/fr-regions.json.js +14162 -0
- package/maps/germany-regions.json.js +35760 -0
- package/maps/ind-regions.json.js +290584 -0
- package/maps/uk-regions.json.js +96233 -0
- package/maps/us-counties.json.js +206318 -0
- package/maps/us-states.json.js +16345 -0
- package/maps/world-110m-alpha.json.js +251366 -0
- package/maps/world-simple.json.js +89428 -0
- package/maps/world-simplest.json.js +28175 -0
- package/maps.d.ts +60 -0
- package/maps.js +23 -0
- package/package.json +61 -0
- package/styles/colors.d.ts +4 -0
- package/styles/colors.js +11 -0
- package/styles/colors.js.map +1 -0
- package/styles/css-variables.d.ts +2 -0
- package/styles/css-variables.js +16 -0
- package/styles/css-variables.js.map +1 -0
- package/types/accessor.d.ts +5 -0
- package/types/component.d.ts +13 -0
- package/types/component.js +14 -0
- package/types/component.js.map +1 -0
- package/types/curve.d.ts +40 -0
- package/types/curve.js +46 -0
- package/types/curve.js.map +1 -0
- package/types/data.d.ts +7 -0
- package/types/direction.d.ts +6 -0
- package/types/direction.js +10 -0
- package/types/direction.js.map +1 -0
- package/types/graph.d.ts +35 -0
- package/types/map.d.ts +4 -0
- package/types/misc.d.ts +8 -0
- package/types/position.d.ts +20 -0
- package/types/position.js +27 -0
- package/types/position.js.map +1 -0
- package/types/scale.d.ts +23 -0
- package/types/scale.js +27 -0
- package/types/scale.js.map +1 -0
- package/types/shape.d.ts +7 -0
- package/types/shape.js +11 -0
- package/types/shape.js.map +1 -0
- package/types/spacing.d.ts +6 -0
- package/types/symbol.d.ts +18 -0
- package/types/symbol.js +24 -0
- package/types/symbol.js.map +1 -0
- package/types/text.d.ts +38 -0
- package/types/text.js +31 -0
- package/types/text.js.map +1 -0
- package/types.d.ts +28 -0
- package/utils/color.d.ts +9 -0
- package/utils/color.js +26 -0
- package/utils/color.js.map +1 -0
- package/utils/d3.d.ts +3 -0
- package/utils/d3.js +16 -0
- package/utils/d3.js.map +1 -0
- package/utils/data.d.ts +123 -0
- package/utils/data.js +193 -0
- package/utils/data.js.map +1 -0
- package/utils/html.d.ts +1 -0
- package/utils/html.js +15 -0
- package/utils/html.js.map +1 -0
- package/utils/map.d.ts +2 -0
- package/utils/map.js +20 -0
- package/utils/map.js.map +1 -0
- package/utils/misc.d.ts +16 -0
- package/utils/misc.js +42 -0
- package/utils/misc.js.map +1 -0
- package/utils/path.d.ts +21 -0
- package/utils/path.js +144 -0
- package/utils/path.js.map +1 -0
- package/utils/scale.d.ts +1 -0
- package/utils/text.d.ts +17 -0
- package/utils/text.js +196 -0
- package/utils/text.js.map +1 -0
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { getNumber, getString, getValue } from '../../../../utils/data.js';
|
|
2
|
+
import { stringToHtmlId } from '../../../../utils/misc.js';
|
|
3
|
+
import { getColor, hexToBrightness } from '../../../../utils/color.js';
|
|
4
|
+
import { color } from 'd3-color';
|
|
5
|
+
import { getX, getY } from '../node/helper.js';
|
|
6
|
+
import { ZoomLevel } from '../zoom-levels.js';
|
|
7
|
+
|
|
8
|
+
// Utils
|
|
9
|
+
const getPolylineData = (d) => `${d.x1},${d.y1} ${(d.x1 + d.x2) / 2},${(d.y1 + d.y2) / 2} ${d.x2},${d.y2}`;
|
|
10
|
+
const LINK_LABEL_RADIUS = 8;
|
|
11
|
+
const LINK_MARKER_WIDTH = 12;
|
|
12
|
+
const LINK_MARKER_HEIGHT = 8;
|
|
13
|
+
function getLinkShift(link, spacing) {
|
|
14
|
+
const sourceNode = link.source;
|
|
15
|
+
const targetNode = link.target;
|
|
16
|
+
const angle = Math.atan2(getY(targetNode) - getY(sourceNode), getX(targetNode) - getX(sourceNode)) - Math.PI / 2;
|
|
17
|
+
const dx = Math.cos(angle) * spacing * link._direction * (link._index - (link._neighbours - 1) / 2);
|
|
18
|
+
const dy = Math.sin(angle) * spacing * link._direction * (link._index - (link._neighbours - 1) / 2);
|
|
19
|
+
return { dx, dy };
|
|
20
|
+
}
|
|
21
|
+
function getLinkShiftTransform(link, spacing) {
|
|
22
|
+
const { dx, dy } = getLinkShift(link, spacing);
|
|
23
|
+
return `translate(${dx}, ${dy})`;
|
|
24
|
+
}
|
|
25
|
+
function getLinkLabelShift(link, linkSpacing, shiftFromCenter = 0) {
|
|
26
|
+
const x1 = getX(link.source);
|
|
27
|
+
const y1 = getY(link.source);
|
|
28
|
+
const x2 = getX(link.target);
|
|
29
|
+
const y2 = getY(link.target);
|
|
30
|
+
const angle = Math.atan2(y2 - y1, x2 - x1);
|
|
31
|
+
const perpendicularShift = getLinkShift(link, linkSpacing);
|
|
32
|
+
const x = x1 + 0.5 * (x2 - x1) + shiftFromCenter * Math.cos(angle) + perpendicularShift.dx;
|
|
33
|
+
const y = y1 + 0.5 * (y2 - y1) + shiftFromCenter * Math.sin(angle) + perpendicularShift.dy;
|
|
34
|
+
return `translate(${x}, ${y})`;
|
|
35
|
+
}
|
|
36
|
+
function getLinkStrokeWidth(d, scale, config) {
|
|
37
|
+
const m = getNumber(d, config.linkWidth, d._indexGlobal);
|
|
38
|
+
return m / Math.pow(scale, 0.5);
|
|
39
|
+
}
|
|
40
|
+
function getLinkBandWidth(d, scale, config) {
|
|
41
|
+
const { nodeSize, linkBandWidth } = config;
|
|
42
|
+
const sourceNodeSize = getNumber(d.source, nodeSize, d.source._index);
|
|
43
|
+
const targetNodeSize = getNumber(d.target, nodeSize, d.target._index);
|
|
44
|
+
const minNodeSize = Math.min(sourceNodeSize, targetNodeSize);
|
|
45
|
+
return Math.min(minNodeSize, getNumber(d, linkBandWidth, d._indexGlobal) / Math.pow(scale || 1, 0.5)) || 0;
|
|
46
|
+
}
|
|
47
|
+
function getLinkColor(link, config) {
|
|
48
|
+
var _a;
|
|
49
|
+
const { linkStroke } = config;
|
|
50
|
+
const c = (_a = getColor(link, linkStroke, link._indexGlobal, true)) !== null && _a !== void 0 ? _a : 'var(--vis-graph-link-stroke-color)';
|
|
51
|
+
return c || null;
|
|
52
|
+
}
|
|
53
|
+
function getMarker(d, scale, config) {
|
|
54
|
+
const { linkArrow } = config;
|
|
55
|
+
if ((scale > ZoomLevel.Level2) && getString(d, linkArrow, d._indexGlobal)) {
|
|
56
|
+
const color = getLinkColor(d, config);
|
|
57
|
+
return `url(#${stringToHtmlId(color)}-${getValue(d, linkArrow, d._indexGlobal)})`;
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
return null;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
function getArrowPath() {
|
|
64
|
+
return `M0,0 V${LINK_MARKER_HEIGHT} L${LINK_MARKER_WIDTH},${LINK_MARKER_HEIGHT / 2} Z`;
|
|
65
|
+
}
|
|
66
|
+
function getDoubleArrowPath() {
|
|
67
|
+
return `M0,${LINK_MARKER_HEIGHT / 2} L${LINK_MARKER_WIDTH},0 L${LINK_MARKER_WIDTH * 2},${LINK_MARKER_HEIGHT / 2} L${LINK_MARKER_WIDTH},${LINK_MARKER_HEIGHT} Z`;
|
|
68
|
+
}
|
|
69
|
+
function getLinkLabelTextColor(label) {
|
|
70
|
+
if (!label.color)
|
|
71
|
+
return null;
|
|
72
|
+
const hex = color(label.color).hex();
|
|
73
|
+
const brightness = hexToBrightness(hex);
|
|
74
|
+
return brightness > 0.65 ? 'var(--vis-graph-link-label-text-color-dark)' : 'var(--vis-graph-link-label-text-color-bright)';
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
export { LINK_LABEL_RADIUS, LINK_MARKER_HEIGHT, LINK_MARKER_WIDTH, getArrowPath, getDoubleArrowPath, getLinkBandWidth, getLinkColor, getLinkLabelShift, getLinkLabelTextColor, getLinkShift, getLinkShiftTransform, getLinkStrokeWidth, getMarker, getPolylineData };
|
|
78
|
+
//# sourceMappingURL=helper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helper.js","sources":["../../../../../src/components/graph/modules/link/helper.ts"],"sourcesContent":["// Utils\nimport { getNumber, getString, getValue } from 'utils/data'\nimport { stringToHtmlId } from 'utils/misc'\nimport { getColor, hexToBrightness } from 'utils/color'\nimport { color } from 'd3-color'\n\n// Types\nimport { GraphInputLink, GraphInputNode } from 'types/graph'\n\n// Local Types\nimport { GraphLink, GraphLinkArrowStyle, GraphCircleLabel } from '../../types'\n\n// Config\nimport { GraphConfig } from '../../config'\n\n// Helpers\nimport { getX, getY } from '../node/helper'\nimport { ZoomLevel } from '../zoom-levels'\n\nexport const getPolylineData = (d: { x1: number; x2: number; y1: number; y2: number}): string => `${d.x1},${d.y1} ${(d.x1 + d.x2) / 2},${(d.y1 + d.y2) / 2} ${d.x2},${d.y2}`\n\nexport const LINK_LABEL_RADIUS = 8\nexport const LINK_MARKER_WIDTH = 12\nexport const LINK_MARKER_HEIGHT = 8\n\nexport function getLinkShift (link: GraphLink, spacing: number): { dx: number; dy: number } {\n const sourceNode = link.source\n const targetNode = link.target\n const angle = Math.atan2(getY(targetNode) - getY(sourceNode), getX(targetNode) - getX(sourceNode)) - Math.PI / 2\n const dx = Math.cos(angle) * spacing * link._direction * (link._index - (link._neighbours - 1) / 2)\n const dy = Math.sin(angle) * spacing * link._direction * (link._index - (link._neighbours - 1) / 2)\n return { dx, dy }\n}\n\nexport function getLinkShiftTransform (link: GraphLink, spacing: number): string {\n const { dx, dy } = getLinkShift(link, spacing)\n return `translate(${dx}, ${dy})`\n}\n\nexport function getLinkLabelShift (link: GraphLink, linkSpacing: number, shiftFromCenter = 0): string {\n const x1 = getX(link.source)\n const y1 = getY(link.source)\n const x2 = getX(link.target)\n const y2 = getY(link.target)\n const angle = Math.atan2(y2 - y1, x2 - x1)\n const perpendicularShift = getLinkShift(link, linkSpacing)\n\n const x = x1 + 0.5 * (x2 - x1) + shiftFromCenter * Math.cos(angle) + perpendicularShift.dx\n const y = y1 + 0.5 * (y2 - y1) + shiftFromCenter * Math.sin(angle) + perpendicularShift.dy\n return `translate(${x}, ${y})`\n}\n\nexport function getLinkStrokeWidth (d: GraphLink, scale: number, config: GraphConfig<GraphInputNode, GraphInputLink>): number {\n const m = getNumber(d, config.linkWidth, d._indexGlobal)\n return m / Math.pow(scale, 0.5)\n}\n\nexport function getLinkBandWidth (d: GraphLink, scale: number, config: GraphConfig<GraphInputNode, GraphInputLink>): number {\n const { nodeSize, linkBandWidth } = config\n const sourceNodeSize = getNumber(d.source, nodeSize, d.source._index)\n const targetNodeSize = getNumber(d.target, nodeSize, d.target._index)\n const minNodeSize = Math.min(sourceNodeSize, targetNodeSize)\n return Math.min(minNodeSize, getNumber(d, linkBandWidth, d._indexGlobal) / Math.pow(scale || 1, 0.5)) || 0\n}\n\nexport function getLinkColor (link: GraphLink, config: GraphConfig<GraphInputNode, GraphInputLink>): string {\n const { linkStroke } = config\n const c = getColor(link, linkStroke, link._indexGlobal, true) ?? 'var(--vis-graph-link-stroke-color)'\n return c || null\n}\n\nexport function getMarker (d: GraphLink, scale: number, config: GraphConfig<GraphInputNode, GraphInputLink>): string {\n const { linkArrow } = config\n if ((scale > ZoomLevel.Level2) && getString(d, linkArrow, d._indexGlobal)) {\n const color = getLinkColor(d, config)\n return `url(#${stringToHtmlId(color)}-${getValue<GraphLink, GraphLinkArrowStyle>(d, linkArrow, d._indexGlobal)})`\n } else {\n return null\n }\n}\n\nexport function getArrowPath (): string {\n return `M0,0 V${LINK_MARKER_HEIGHT} L${LINK_MARKER_WIDTH},${LINK_MARKER_HEIGHT / 2} Z`\n}\n\nexport function getDoubleArrowPath (): string {\n return `M0,${LINK_MARKER_HEIGHT / 2} L${LINK_MARKER_WIDTH},0 L${LINK_MARKER_WIDTH * 2},${LINK_MARKER_HEIGHT / 2} L${LINK_MARKER_WIDTH},${LINK_MARKER_HEIGHT} Z`\n}\n\nexport function getLinkLabelTextColor (label: GraphCircleLabel): string {\n if (!label.color) return null\n\n const hex = color(label.color).hex()\n const brightness = hexToBrightness(hex)\n return brightness > 0.65 ? 'var(--vis-graph-link-label-text-color-dark)' : 'var(--vis-graph-link-label-text-color-bright)'\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/// <reference types="lodash" />
|
|
2
|
+
import { Selection } from 'd3-selection';
|
|
3
|
+
import { GraphInputLink, GraphInputNode } from "../../../../types/graph";
|
|
4
|
+
import { GraphLink } from '../../types';
|
|
5
|
+
import { GraphConfig } from '../../config';
|
|
6
|
+
export declare function createLinks<N extends GraphInputNode, L extends GraphInputLink>(selection: Selection<SVGGElement, GraphLink<N, L>, SVGGElement, GraphLink<N, L>>): void;
|
|
7
|
+
export declare function updateSelectedLinks<N extends GraphInputNode, L extends GraphInputLink>(selection: Selection<SVGGElement, GraphLink<N, L>, SVGGElement, GraphLink<N, L>>, config: GraphConfig<N, L>, scale: number): void;
|
|
8
|
+
export declare function updateLinks<N extends GraphInputNode, L extends GraphInputLink>(selection: Selection<SVGGElement, GraphLink<N, L>, SVGGElement, GraphLink<N, L>>, config: GraphConfig<N, L>, duration: number, scale?: number): void;
|
|
9
|
+
export declare function removeLinks<N extends GraphInputNode, L extends GraphInputLink>(selection: Selection<SVGGElement, GraphLink<N, L>, SVGGElement, GraphLink<N, L>>, config: GraphConfig<N, L>, duration: number): void;
|
|
10
|
+
export declare function animateLinkFlow<N extends GraphInputNode, L extends GraphInputLink>(selection: Selection<SVGGElement, GraphLink<N, L>, SVGGElement, unknown>, config: GraphConfig<N, L>, scale: number): void;
|
|
11
|
+
export declare function zoomLinks<N extends GraphInputNode, L extends GraphInputLink>(selection: Selection<SVGGElement, GraphLink<N, L>, SVGGElement, GraphLink<N, L>>, config: GraphConfig<N, L>, scale: number): void;
|
|
12
|
+
export declare const zoomLinksThrottled: import("lodash").DebouncedFunc<typeof zoomLinks>;
|
|
@@ -0,0 +1,201 @@
|
|
|
1
|
+
import { select } from 'd3-selection';
|
|
2
|
+
import { throttle, range, getBoolean, getValue } from '../../../../utils/data.js';
|
|
3
|
+
import { smartTransition } from '../../../../utils/d3.js';
|
|
4
|
+
import { GraphLinkStyle } from '../../types.js';
|
|
5
|
+
import { getX, getY } from '../node/helper.js';
|
|
6
|
+
import { getMarker, getLinkStrokeWidth, getLinkBandWidth, getLinkColor, getLinkShiftTransform, getPolylineData, LINK_MARKER_WIDTH, getLinkLabelShift, LINK_LABEL_RADIUS, getLinkLabelTextColor } from './helper.js';
|
|
7
|
+
import { ZoomLevel } from '../zoom-levels.js';
|
|
8
|
+
import { zoomOutLevel2 } from '../../style.js';
|
|
9
|
+
import { flowCircle, link, linkBand, linkSupport, flowGroup, labelGroups, greyout, linkDashed, labelGroup, labelCircle, labelContent } from './style.js';
|
|
10
|
+
|
|
11
|
+
function createLinks(selection) {
|
|
12
|
+
selection.attr('opacity', 0);
|
|
13
|
+
selection.append('line')
|
|
14
|
+
.attr('class', linkSupport);
|
|
15
|
+
selection.append('polyline')
|
|
16
|
+
.attr('class', link);
|
|
17
|
+
selection.append('line')
|
|
18
|
+
.attr('class', linkBand)
|
|
19
|
+
.attr('x1', d => getX(d.source))
|
|
20
|
+
.attr('y1', d => getY(d.source))
|
|
21
|
+
.attr('x2', d => getX(d.target))
|
|
22
|
+
.attr('y2', d => getY(d.target));
|
|
23
|
+
selection.append('g')
|
|
24
|
+
.attr('class', flowGroup)
|
|
25
|
+
.selectAll(`.${flowCircle}`)
|
|
26
|
+
.data(range(6)).enter()
|
|
27
|
+
.append('circle')
|
|
28
|
+
.attr('class', flowCircle);
|
|
29
|
+
selection.append('g')
|
|
30
|
+
.attr('class', labelGroups);
|
|
31
|
+
}
|
|
32
|
+
function updateSelectedLinks(selection, config, scale) {
|
|
33
|
+
const isGreyedOut = (d, i) => getBoolean(d, config.linkDisabled, i) || d._state.greyout;
|
|
34
|
+
selection
|
|
35
|
+
.classed(greyout, (d, i) => isGreyedOut(d, i));
|
|
36
|
+
selection.each((d, i, elements) => {
|
|
37
|
+
const element = elements[i];
|
|
38
|
+
const group = select(element);
|
|
39
|
+
group.select(`.${link}`);
|
|
40
|
+
group.select(`.${linkBand}`);
|
|
41
|
+
const linkSupport$1 = group.select(`.${linkSupport}`);
|
|
42
|
+
linkSupport$1
|
|
43
|
+
.style('stroke-opacity', (d._state.hovered || d._state.selected) ? 0.2 : 0)
|
|
44
|
+
.style('stroke-width', d._state.selected
|
|
45
|
+
? getLinkBandWidth(d, scale, config) + 5
|
|
46
|
+
: d._state.hovered ? getLinkBandWidth(d, scale, config) + 10 : null);
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
function updateLinks(selection, config, duration, scale = 1) {
|
|
50
|
+
const { linkFlowParticleSize, linkStyle, linkFlow, linkArrow, linkLabel, linkLabelShiftFromCenter } = config;
|
|
51
|
+
if (!selection.size())
|
|
52
|
+
return;
|
|
53
|
+
selection
|
|
54
|
+
.classed(linkDashed, d => getValue(d, linkStyle, d._indexGlobal) === GraphLinkStyle.Dashed);
|
|
55
|
+
selection.each((d, i, elements) => {
|
|
56
|
+
const element = elements[i];
|
|
57
|
+
const linkGroup = select(element);
|
|
58
|
+
const link$1 = linkGroup.select(`.${link}`);
|
|
59
|
+
const linkBand$1 = linkGroup.select(`.${linkBand}`);
|
|
60
|
+
const linkSupport$1 = linkGroup.select(`.${linkSupport}`);
|
|
61
|
+
const flowGroup$1 = linkGroup.select(`.${flowGroup}`);
|
|
62
|
+
const x1 = getX(d.source);
|
|
63
|
+
const y1 = getY(d.source);
|
|
64
|
+
const x2 = getX(d.target);
|
|
65
|
+
const y2 = getY(d.target);
|
|
66
|
+
link$1
|
|
67
|
+
.attr('class', link)
|
|
68
|
+
.attr('marker-mid', getMarker(d, scale, config))
|
|
69
|
+
.style('stroke-width', getLinkStrokeWidth(d, scale, config))
|
|
70
|
+
.style('stroke', getLinkColor(d, config))
|
|
71
|
+
.attr('transform', getLinkShiftTransform(d, config.linkNeighborSpacing));
|
|
72
|
+
smartTransition(link$1, duration)
|
|
73
|
+
.attr('points', getPolylineData({ x1, y1, x2, y2 }));
|
|
74
|
+
linkBand$1
|
|
75
|
+
.attr('class', linkBand)
|
|
76
|
+
.attr('transform', getLinkShiftTransform(d, config.linkNeighborSpacing))
|
|
77
|
+
.style('stroke-width', getLinkBandWidth(d, scale, config))
|
|
78
|
+
.style('stroke', getLinkColor(d, config));
|
|
79
|
+
smartTransition(linkBand$1, duration)
|
|
80
|
+
.attr('x1', x1)
|
|
81
|
+
.attr('y1', y1)
|
|
82
|
+
.attr('x2', x2)
|
|
83
|
+
.attr('y2', y2);
|
|
84
|
+
linkSupport$1
|
|
85
|
+
.style('stroke', getLinkColor(d, config))
|
|
86
|
+
.attr('transform', getLinkShiftTransform(d, config.linkNeighborSpacing))
|
|
87
|
+
.attr('x1', x1)
|
|
88
|
+
.attr('y1', y1)
|
|
89
|
+
.attr('x2', x2)
|
|
90
|
+
.attr('y2', y2);
|
|
91
|
+
flowGroup$1
|
|
92
|
+
.attr('transform', getLinkShiftTransform(d, config.linkNeighborSpacing))
|
|
93
|
+
.style('display', getBoolean(d, linkFlow, d._indexGlobal) ? null : 'none')
|
|
94
|
+
.style('opacity', 0);
|
|
95
|
+
flowGroup$1
|
|
96
|
+
.selectAll(`.${flowCircle}`)
|
|
97
|
+
.attr('r', linkFlowParticleSize / scale)
|
|
98
|
+
.style('fill', getLinkColor(d, config));
|
|
99
|
+
smartTransition(flowGroup$1, duration)
|
|
100
|
+
.style('opacity', scale < ZoomLevel.Level2 ? 0 : 1);
|
|
101
|
+
// Labels
|
|
102
|
+
const labelGroups$1 = linkGroup.selectAll(`.${labelGroups}`);
|
|
103
|
+
const labelDatum = getValue(d, linkLabel, d._indexGlobal);
|
|
104
|
+
const markerWidth = getValue(d, linkArrow, d._indexGlobal) ? LINK_MARKER_WIDTH * 2 : 0;
|
|
105
|
+
const labelShift = getBoolean(d, linkLabelShiftFromCenter, d._indexGlobal) ? -markerWidth + 4 : 0;
|
|
106
|
+
const labelTranslate = getLinkLabelShift(d, config.linkNeighborSpacing, labelShift);
|
|
107
|
+
const labels = labelGroups$1.selectAll(`.${labelGroup}`).data(labelDatum ? [labelDatum] : []);
|
|
108
|
+
// Enter
|
|
109
|
+
const labelsEnter = labels.enter().append('g')
|
|
110
|
+
.attr('class', labelGroup)
|
|
111
|
+
.attr('transform', labelTranslate)
|
|
112
|
+
.style('opacity', 0);
|
|
113
|
+
labelsEnter.append('circle')
|
|
114
|
+
.attr('class', labelCircle)
|
|
115
|
+
.attr('r', 0);
|
|
116
|
+
labelsEnter.append('text')
|
|
117
|
+
.attr('class', labelContent)
|
|
118
|
+
.attr('dy', 1);
|
|
119
|
+
// Update
|
|
120
|
+
const labelsUpdate = labels.merge(labelsEnter);
|
|
121
|
+
smartTransition(labelsUpdate.select(`.${labelCircle}`), duration)
|
|
122
|
+
.attr('r', LINK_LABEL_RADIUS)
|
|
123
|
+
.style('fill', label => label.color);
|
|
124
|
+
labelsUpdate.select(`.${labelContent}`)
|
|
125
|
+
.text(label => label.text)
|
|
126
|
+
.style('fill', label => getLinkLabelTextColor(label))
|
|
127
|
+
.style('font-size', label => `${10 / Math.pow(label.text.toString().length, 0.3)}px`);
|
|
128
|
+
smartTransition(labelsUpdate, duration)
|
|
129
|
+
.attr('transform', labelTranslate)
|
|
130
|
+
.style('opacity', 1);
|
|
131
|
+
// Exit
|
|
132
|
+
const labelsExit = labels.exit();
|
|
133
|
+
smartTransition(labelsExit.select(`.${labelCircle}`), duration)
|
|
134
|
+
.attr('r', 0);
|
|
135
|
+
smartTransition(labelsExit, duration)
|
|
136
|
+
.style('opacity', 0)
|
|
137
|
+
.remove();
|
|
138
|
+
});
|
|
139
|
+
if (duration > 0) {
|
|
140
|
+
selection.attr('pointer-events', 'none');
|
|
141
|
+
const t = smartTransition(selection, duration);
|
|
142
|
+
t
|
|
143
|
+
.attr('opacity', 1)
|
|
144
|
+
.on('end interrupt', (d, i, elements) => {
|
|
145
|
+
select(elements[i])
|
|
146
|
+
.attr('pointer-events', 'stroke')
|
|
147
|
+
.attr('opacity', 1);
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
else {
|
|
151
|
+
selection.attr('opacity', 1);
|
|
152
|
+
}
|
|
153
|
+
updateSelectedLinks(selection, config, scale);
|
|
154
|
+
}
|
|
155
|
+
function removeLinks(selection, config, duration) {
|
|
156
|
+
smartTransition(selection, duration / 2)
|
|
157
|
+
.attr('opacity', 0)
|
|
158
|
+
.remove();
|
|
159
|
+
}
|
|
160
|
+
function animateLinkFlow(selection, config, scale) {
|
|
161
|
+
const { linkFlow } = config;
|
|
162
|
+
if (scale < ZoomLevel.Level2)
|
|
163
|
+
return;
|
|
164
|
+
selection.each((d, i, elements) => {
|
|
165
|
+
const element = elements[i];
|
|
166
|
+
const linkGroup = select(element);
|
|
167
|
+
const flowGroup$1 = linkGroup.select(`.${flowGroup}`);
|
|
168
|
+
if (!getBoolean(d, linkFlow, d._indexGlobal))
|
|
169
|
+
return;
|
|
170
|
+
const t = d._state.flowAnimTime;
|
|
171
|
+
const circles = flowGroup$1.selectAll(`.${flowCircle}`);
|
|
172
|
+
circles
|
|
173
|
+
.attr('transform', index => {
|
|
174
|
+
const tt = (t + (+index) / (circles.size() - 1)) % 1;
|
|
175
|
+
const x1 = getX(d.source);
|
|
176
|
+
const y1 = getY(d.source);
|
|
177
|
+
const x2 = getX(d.target);
|
|
178
|
+
const y2 = getY(d.target);
|
|
179
|
+
const x = x1 + tt * (x2 - x1);
|
|
180
|
+
const y = y1 + tt * (y2 - y1);
|
|
181
|
+
return `translate(${x}, ${y})`;
|
|
182
|
+
});
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
function zoomLinks(selection, config, scale) {
|
|
186
|
+
const { linkFlowParticleSize } = config;
|
|
187
|
+
selection.classed(zoomOutLevel2, scale < ZoomLevel.Level2);
|
|
188
|
+
selection.selectAll(`.${flowCircle}`)
|
|
189
|
+
.attr('r', linkFlowParticleSize / scale);
|
|
190
|
+
const linkElements = selection.selectAll(`.${link}`);
|
|
191
|
+
linkElements
|
|
192
|
+
.attr('marker-mid', d => getMarker(d, scale, config))
|
|
193
|
+
.style('stroke-width', d => getLinkStrokeWidth(d, scale, config));
|
|
194
|
+
const linkBandElements = selection.selectAll(`.${linkBand}`);
|
|
195
|
+
linkBandElements
|
|
196
|
+
.style('stroke-width', d => getLinkBandWidth(d, scale, config));
|
|
197
|
+
}
|
|
198
|
+
const zoomLinksThrottled = throttle(zoomLinks, 500);
|
|
199
|
+
|
|
200
|
+
export { animateLinkFlow, createLinks, removeLinks, updateLinks, updateSelectedLinks, zoomLinks, zoomLinksThrottled };
|
|
201
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../src/components/graph/modules/link/index.ts"],"sourcesContent":["import { select, Selection } from 'd3-selection'\nimport { Transition } from 'd3-transition'\n\n// Utils\nimport { range, throttle, getValue, getBoolean } from 'utils/data'\nimport { smartTransition } from 'utils/d3'\n\n// Types\nimport { GraphInputLink, GraphInputNode } from 'types/graph'\n\n// Local Types\nimport { GraphCircleLabel, GraphLink, GraphLinkArrowStyle, GraphLinkStyle } from '../../types'\n\n// Config\nimport { GraphConfig } from '../../config'\n\n// Helpers\nimport { getX, getY } from '../node/helper'\nimport {\n getPolylineData,\n getLinkShiftTransform,\n getLinkLabelShift,\n getLinkStrokeWidth,\n getLinkBandWidth,\n getMarker,\n getLinkColor,\n getLinkLabelTextColor,\n LINK_LABEL_RADIUS,\n LINK_MARKER_WIDTH,\n} from './helper'\nimport { ZoomLevel } from '../zoom-levels'\n\n// Styles\nimport * as generalSelectors from '../../style'\nimport * as linkSelectors from './style'\n\nexport function createLinks<N extends GraphInputNode, L extends GraphInputLink> (\n selection: Selection<SVGGElement, GraphLink<N, L>, SVGGElement, GraphLink<N, L>>\n): void {\n selection.attr('opacity', 0)\n\n selection.append('line')\n .attr('class', linkSelectors.linkSupport)\n\n selection.append('polyline')\n .attr('class', linkSelectors.link)\n\n selection.append('line')\n .attr('class', linkSelectors.linkBand)\n .attr('x1', d => getX(d.source))\n .attr('y1', d => getY(d.source))\n .attr('x2', d => getX(d.target))\n .attr('y2', d => getY(d.target))\n\n selection.append('g')\n .attr('class', linkSelectors.flowGroup)\n .selectAll(`.${linkSelectors.flowCircle}`)\n .data(range(6)).enter()\n .append('circle')\n .attr('class', linkSelectors.flowCircle)\n\n selection.append('g')\n .attr('class', linkSelectors.labelGroups)\n}\n\nexport function updateSelectedLinks<N extends GraphInputNode, L extends GraphInputLink> (\n selection: Selection<SVGGElement, GraphLink<N, L>, SVGGElement, GraphLink<N, L>>,\n config: GraphConfig<N, L>,\n scale: number\n): void {\n const isGreyedOut = (d, i): boolean => getBoolean(d, config.linkDisabled, i) || d._state.greyout\n selection\n .classed(linkSelectors.greyout, (d, i) => isGreyedOut(d, i))\n\n selection.each((d, i, elements) => {\n const element = elements[i]\n const group = select(element)\n group.select(`.${linkSelectors.link}`)\n group.select(`.${linkSelectors.linkBand}`)\n const linkSupport = group.select(`.${linkSelectors.linkSupport}`)\n\n linkSupport\n .style('stroke-opacity', (d._state.hovered || d._state.selected) ? 0.2 : 0)\n .style('stroke-width',\n d._state.selected\n ? getLinkBandWidth(d, scale, config) + 5\n : d._state.hovered ? getLinkBandWidth(d, scale, config) + 10 : null\n )\n })\n}\n\nexport function updateLinks<N extends GraphInputNode, L extends GraphInputLink> (\n selection: Selection<SVGGElement, GraphLink<N, L>, SVGGElement, GraphLink<N, L>>,\n config: GraphConfig<N, L>,\n duration: number,\n scale = 1\n): void {\n const { linkFlowParticleSize, linkStyle, linkFlow, linkArrow, linkLabel, linkLabelShiftFromCenter } = config\n if (!selection.size()) return\n\n selection\n .classed(\n linkSelectors.linkDashed,\n d => getValue<GraphLink<N, L>, GraphLinkStyle>(d, linkStyle, d._indexGlobal) === GraphLinkStyle.Dashed\n )\n\n selection.each((d, i, elements) => {\n const element = elements[i]\n const linkGroup = select(element)\n const link = linkGroup.select(`.${linkSelectors.link}`)\n const linkBand = linkGroup.select(`.${linkSelectors.linkBand}`)\n const linkSupport = linkGroup.select(`.${linkSelectors.linkSupport}`)\n const flowGroup = linkGroup.select(`.${linkSelectors.flowGroup}`)\n\n const x1 = getX(d.source)\n const y1 = getY(d.source)\n const x2 = getX(d.target)\n const y2 = getY(d.target)\n\n link\n .attr('class', linkSelectors.link)\n .attr('marker-mid', getMarker(d, scale, config))\n .style('stroke-width', getLinkStrokeWidth(d, scale, config))\n .style('stroke', getLinkColor(d, config))\n .attr('transform', getLinkShiftTransform(d, config.linkNeighborSpacing))\n\n smartTransition(link, duration)\n .attr('points', getPolylineData({ x1, y1, x2, y2 }))\n\n linkBand\n .attr('class', linkSelectors.linkBand)\n .attr('transform', getLinkShiftTransform(d, config.linkNeighborSpacing))\n .style('stroke-width', getLinkBandWidth(d, scale, config))\n .style('stroke', getLinkColor(d, config))\n\n smartTransition(linkBand, duration)\n .attr('x1', x1)\n .attr('y1', y1)\n .attr('x2', x2)\n .attr('y2', y2)\n\n linkSupport\n .style('stroke', getLinkColor(d, config))\n .attr('transform', getLinkShiftTransform(d, config.linkNeighborSpacing))\n .attr('x1', x1)\n .attr('y1', y1)\n .attr('x2', x2)\n .attr('y2', y2)\n\n flowGroup\n .attr('transform', getLinkShiftTransform(d, config.linkNeighborSpacing))\n .style('display', getBoolean(d, linkFlow, d._indexGlobal) ? null : 'none')\n .style('opacity', 0)\n\n flowGroup\n .selectAll(`.${linkSelectors.flowCircle}`)\n .attr('r', linkFlowParticleSize / scale)\n .style('fill', getLinkColor(d, config))\n\n smartTransition(flowGroup, duration)\n .style('opacity', scale < ZoomLevel.Level2 ? 0 : 1)\n\n // Labels\n const labelGroups = linkGroup.selectAll(`.${linkSelectors.labelGroups}`)\n const labelDatum = getValue<GraphLink<N, L>, GraphCircleLabel>(d, linkLabel, d._indexGlobal)\n const markerWidth = getValue<GraphLink<N, L>, GraphLinkArrowStyle>(d, linkArrow, d._indexGlobal) ? LINK_MARKER_WIDTH * 2 : 0\n const labelShift = getBoolean(d, linkLabelShiftFromCenter, d._indexGlobal) ? -markerWidth + 4 : 0\n const labelTranslate = getLinkLabelShift(d, config.linkNeighborSpacing, labelShift)\n\n const labels = labelGroups.selectAll(`.${linkSelectors.labelGroup}`).data(labelDatum ? [labelDatum] : [])\n\n // Enter\n const labelsEnter = labels.enter().append('g')\n .attr('class', linkSelectors.labelGroup)\n .attr('transform', labelTranslate)\n .style('opacity', 0)\n\n labelsEnter.append('circle')\n .attr('class', linkSelectors.labelCircle)\n .attr('r', 0)\n\n labelsEnter.append('text')\n .attr('class', linkSelectors.labelContent)\n .attr('dy', 1)\n\n // Update\n const labelsUpdate = labels.merge(labelsEnter)\n\n smartTransition(labelsUpdate.select(`.${linkSelectors.labelCircle}`), duration)\n .attr('r', LINK_LABEL_RADIUS)\n .style('fill', label => label.color)\n\n labelsUpdate.select(`.${linkSelectors.labelContent}`)\n .text(label => label.text)\n .style('fill', label => getLinkLabelTextColor(label))\n .style('font-size', label => `${10 / Math.pow(label.text.toString().length, 0.3)}px`)\n\n smartTransition(labelsUpdate, duration)\n .attr('transform', labelTranslate)\n .style('opacity', 1)\n\n // Exit\n const labelsExit = labels.exit()\n smartTransition(labelsExit.select(`.${linkSelectors.labelCircle}`), duration)\n .attr('r', 0)\n\n smartTransition(labelsExit, duration)\n .style('opacity', 0)\n .remove()\n })\n\n if (duration > 0) {\n selection.attr('pointer-events', 'none')\n const t = smartTransition(selection, duration) as Transition<SVGGElement, GraphLink<N, L>, SVGGElement, GraphLink<N, L>>\n t\n .attr('opacity', 1)\n .on('end interrupt', (d, i, elements) => {\n select(elements[i])\n .attr('pointer-events', 'stroke')\n .attr('opacity', 1)\n })\n } else {\n selection.attr('opacity', 1)\n }\n\n updateSelectedLinks(selection, config, scale)\n}\n\nexport function removeLinks<N extends GraphInputNode, L extends GraphInputLink> (\n selection: Selection<SVGGElement, GraphLink<N, L>, SVGGElement, GraphLink<N, L>>,\n config: GraphConfig<N, L>,\n duration: number\n): void {\n smartTransition(selection, duration / 2)\n .attr('opacity', 0)\n .remove()\n}\n\nexport function animateLinkFlow<N extends GraphInputNode, L extends GraphInputLink> (\n selection: Selection<SVGGElement, GraphLink<N, L>, SVGGElement, unknown>,\n config: GraphConfig<N, L>,\n scale: number\n): void {\n const { linkFlow } = config\n if (scale < ZoomLevel.Level2) return\n\n selection.each((d, i, elements) => {\n const element = elements[i]\n const linkGroup = select(element)\n const flowGroup = linkGroup.select(`.${linkSelectors.flowGroup}`)\n\n if (!getBoolean(d, linkFlow, d._indexGlobal)) return\n const t = d._state.flowAnimTime\n const circles = flowGroup.selectAll(`.${linkSelectors.flowCircle}`)\n\n circles\n .attr('transform', index => {\n const tt = (t + (+index) / (circles.size() - 1)) % 1\n const x1 = getX(d.source)\n const y1 = getY(d.source)\n const x2 = getX(d.target)\n const y2 = getY(d.target)\n\n const x = x1 + tt * (x2 - x1)\n const y = y1 + tt * (y2 - y1)\n return `translate(${x}, ${y})`\n })\n })\n}\n\nexport function zoomLinks<N extends GraphInputNode, L extends GraphInputLink> (\n selection: Selection<SVGGElement, GraphLink<N, L>, SVGGElement, GraphLink<N, L>>,\n config: GraphConfig<N, L>,\n scale: number\n): void {\n const { linkFlowParticleSize } = config\n\n selection.classed(generalSelectors.zoomOutLevel2, scale < ZoomLevel.Level2)\n selection.selectAll(`.${linkSelectors.flowCircle}`)\n .attr('r', linkFlowParticleSize / scale)\n\n const linkElements = selection.selectAll<SVGGElement, GraphLink<N, L>>(`.${linkSelectors.link}`)\n linkElements\n .attr('marker-mid', d => getMarker(d, scale, config))\n .style('stroke-width', d => getLinkStrokeWidth(d, scale, config))\n\n const linkBandElements = selection.selectAll<SVGGElement, GraphLink<N, L>>(`.${linkSelectors.linkBand}`)\n linkBandElements\n .style('stroke-width', d => getLinkBandWidth(d, scale, config))\n}\n\nexport const zoomLinksThrottled = throttle(zoomLinks, 500)\n"],"names":["linkSelectors.linkSupport","linkSelectors.link","linkSelectors.linkBand","linkSelectors.flowGroup","linkSelectors.flowCircle","linkSelectors.labelGroups","linkSelectors.greyout","linkSupport","linkSelectors.linkDashed","link","linkBand","flowGroup","labelGroups","linkSelectors.labelGroup","linkSelectors.labelCircle","linkSelectors.labelContent","generalSelectors.zoomOutLevel2"],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export declare const links: string;
|
|
2
|
+
export declare const variables: void;
|
|
3
|
+
export declare const linkSupport: string;
|
|
4
|
+
export declare const link: string;
|
|
5
|
+
export declare const linkDashed: string;
|
|
6
|
+
export declare const gLink: string;
|
|
7
|
+
export declare const gLinkExit: string;
|
|
8
|
+
export declare const greyout: string;
|
|
9
|
+
export declare const linkBand: string;
|
|
10
|
+
export declare const flowGroup: string;
|
|
11
|
+
export declare const flowCircle: string;
|
|
12
|
+
export declare const labelGroups: string;
|
|
13
|
+
export declare const labelGroup: string;
|
|
14
|
+
export declare const labelCircle: string;
|
|
15
|
+
export declare const labelContent: string;
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import { css, injectGlobal } from '@emotion/css';
|
|
2
|
+
|
|
3
|
+
const links = css `
|
|
4
|
+
label: links;
|
|
5
|
+
`;
|
|
6
|
+
injectGlobal `
|
|
7
|
+
:root {
|
|
8
|
+
--vis-graph-link-stroke-color: #e6e9f3;
|
|
9
|
+
--vis-graph-link-greyout-opacity: 0.3;
|
|
10
|
+
--vis-graph-link-dashed-stroke-dasharray: 6 6;
|
|
11
|
+
|
|
12
|
+
--vis-graph-link-label-stroke-color: #fff;
|
|
13
|
+
--vis-graph-link-label-fill-color: #e6e9f3;
|
|
14
|
+
--vis-graph-link-label-text-color-dark: #494b56;
|
|
15
|
+
--vis-graph-link-label-text-color-bright: #fff;
|
|
16
|
+
--vis-graph-link-label-text-color: var(--vis-graph-link-label-text-color-dark);
|
|
17
|
+
|
|
18
|
+
--vis-graph-link-band-opacity: 0.35;
|
|
19
|
+
--vis-graph-link-support-stroke-width: 10px;
|
|
20
|
+
|
|
21
|
+
--vis-dark-graph-link-stroke-color: #494b56;
|
|
22
|
+
--vis-dark-graph-link-label-stroke-color: #222;
|
|
23
|
+
--vis-dark-graph-link-label-fill-color: var(--vis-color-gray);
|
|
24
|
+
--vis-dark-graph-link-label-text-color: var(--vis-graph-link-label-text-color-bright)
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
body.theme-dark ${`.${links}`} {
|
|
28
|
+
--vis-graph-link-stroke-color: var(--vis-dark-graph-link-stroke-color);
|
|
29
|
+
--vis-graph-link-label-stroke-color: var(--vis-dark-graph-link-label-stroke-color);
|
|
30
|
+
--vis-graph-link-label-text-color: var(--vis-dark-graph-link-label-text-color);
|
|
31
|
+
--vis-graph-link-label-fill-color: var(--vis-dark-graph-link-label-fill-color);
|
|
32
|
+
}
|
|
33
|
+
`;
|
|
34
|
+
const linkSupport = css `
|
|
35
|
+
label: link-support;
|
|
36
|
+
|
|
37
|
+
fill: none;
|
|
38
|
+
stroke-linecap: round;
|
|
39
|
+
pointer-events: stroke;
|
|
40
|
+
stroke-width: var(--vis-graph-link-support-stroke-width);
|
|
41
|
+
stroke-opacity: 0;
|
|
42
|
+
stroke: var(--vis-graph-link-stroke-color);
|
|
43
|
+
transition: .2s;
|
|
44
|
+
`;
|
|
45
|
+
const link = css `
|
|
46
|
+
label: link;
|
|
47
|
+
|
|
48
|
+
fill: none;
|
|
49
|
+
stroke: var(--vis-graph-link-stroke-color);
|
|
50
|
+
transition: stroke 800ms;
|
|
51
|
+
stroke-linecap: round;
|
|
52
|
+
pointer-events: none;
|
|
53
|
+
`;
|
|
54
|
+
const linkDashed = css `
|
|
55
|
+
label: dashed;
|
|
56
|
+
|
|
57
|
+
${`.${link}`} {
|
|
58
|
+
stroke-dasharray: var(--vis-graph-link-dashed-stroke-dasharray);
|
|
59
|
+
}
|
|
60
|
+
`;
|
|
61
|
+
const gLink = css `
|
|
62
|
+
label: g-link;
|
|
63
|
+
`;
|
|
64
|
+
const gLinkExit = css `
|
|
65
|
+
label: g-link-exit;
|
|
66
|
+
pointer-events: none;
|
|
67
|
+
`;
|
|
68
|
+
const greyout = css `
|
|
69
|
+
label: greyout;
|
|
70
|
+
opacity: var(--vis-graph-link-greyout-opacity);
|
|
71
|
+
`;
|
|
72
|
+
const linkBand = css `
|
|
73
|
+
label: link-band;
|
|
74
|
+
|
|
75
|
+
stroke-opacity: var(--vis-graph-link-band-opacity);
|
|
76
|
+
pointer-events: none;
|
|
77
|
+
stroke: var(--vis-graph-node-stroke-color);
|
|
78
|
+
`;
|
|
79
|
+
const flowGroup = css `
|
|
80
|
+
label: flow-group;
|
|
81
|
+
|
|
82
|
+
pointer-events: none;
|
|
83
|
+
`;
|
|
84
|
+
const flowCircle = css `
|
|
85
|
+
label: flow-circle;
|
|
86
|
+
|
|
87
|
+
fill: var(--vis-graph-link-stroke-color);
|
|
88
|
+
`;
|
|
89
|
+
const labelGroups = css `
|
|
90
|
+
label: label-groups;
|
|
91
|
+
`;
|
|
92
|
+
const labelGroup = css `
|
|
93
|
+
label: label-group;
|
|
94
|
+
pointer-events: none;
|
|
95
|
+
`;
|
|
96
|
+
const labelCircle = css `
|
|
97
|
+
label: label-circle;
|
|
98
|
+
|
|
99
|
+
fill: var(--vis-graph-link-label-fill-color);
|
|
100
|
+
stroke: var(--vis-graph-link-label-stroke-color);
|
|
101
|
+
`;
|
|
102
|
+
const labelContent = css `
|
|
103
|
+
label: label-content;
|
|
104
|
+
|
|
105
|
+
font-family: var(--vis-graph-icon-font-family), var(--vis-font-family);
|
|
106
|
+
fill: var(--vis-graph-link-label-text-color);
|
|
107
|
+
text-anchor: middle;
|
|
108
|
+
dominant-baseline: middle;
|
|
109
|
+
`;
|
|
110
|
+
|
|
111
|
+
export { flowCircle, flowGroup, gLink, gLinkExit, greyout, labelCircle, labelContent, labelGroup, labelGroups, link, linkBand, linkDashed, linkSupport, links };
|
|
112
|
+
//# sourceMappingURL=style.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"style.js","sources":["../../../../../src/components/graph/modules/link/style.ts"],"sourcesContent":["import { css, injectGlobal } from '@emotion/css'\n\nexport const links = css`\n label: links;\n`\n\nexport const variables = injectGlobal`\n :root {\n --vis-graph-link-stroke-color: #e6e9f3;\n --vis-graph-link-greyout-opacity: 0.3;\n --vis-graph-link-dashed-stroke-dasharray: 6 6;\n\n --vis-graph-link-label-stroke-color: #fff;\n --vis-graph-link-label-fill-color: #e6e9f3;\n --vis-graph-link-label-text-color-dark: #494b56;\n --vis-graph-link-label-text-color-bright: #fff;\n --vis-graph-link-label-text-color: var(--vis-graph-link-label-text-color-dark);\n\n --vis-graph-link-band-opacity: 0.35;\n --vis-graph-link-support-stroke-width: 10px;\n\n --vis-dark-graph-link-stroke-color: #494b56;\n --vis-dark-graph-link-label-stroke-color: #222;\n --vis-dark-graph-link-label-fill-color: var(--vis-color-gray);\n --vis-dark-graph-link-label-text-color: var(--vis-graph-link-label-text-color-bright)\n }\n\n body.theme-dark ${`.${links}`} {\n --vis-graph-link-stroke-color: var(--vis-dark-graph-link-stroke-color);\n --vis-graph-link-label-stroke-color: var(--vis-dark-graph-link-label-stroke-color);\n --vis-graph-link-label-text-color: var(--vis-dark-graph-link-label-text-color);\n --vis-graph-link-label-fill-color: var(--vis-dark-graph-link-label-fill-color);\n }\n`\n\nexport const linkSupport = css`\n label: link-support;\n\n fill: none;\n stroke-linecap: round;\n pointer-events: stroke;\n stroke-width: var(--vis-graph-link-support-stroke-width);\n stroke-opacity: 0;\n stroke: var(--vis-graph-link-stroke-color);\n transition: .2s;\n`\n\nexport const link = css`\n label: link;\n\n fill: none;\n stroke: var(--vis-graph-link-stroke-color);\n transition: stroke 800ms;\n stroke-linecap: round;\n pointer-events: none;\n`\n\nexport const linkDashed = css`\n label: dashed;\n\n ${`.${link}`} {\n stroke-dasharray: var(--vis-graph-link-dashed-stroke-dasharray);\n }\n`\n\nexport const gLink = css`\n label: g-link;\n`\n\nexport const gLinkExit = css`\n label: g-link-exit;\n pointer-events: none;\n`\n\nexport const greyout = css`\n label: greyout;\n opacity: var(--vis-graph-link-greyout-opacity);\n`\n\nexport const linkBand = css`\n label: link-band;\n\n stroke-opacity: var(--vis-graph-link-band-opacity);\n pointer-events: none;\n stroke: var(--vis-graph-node-stroke-color);\n`\n\nexport const flowGroup = css`\n label: flow-group;\n\n pointer-events: none;\n`\n\nexport const flowCircle = css`\n label: flow-circle;\n\n fill: var(--vis-graph-link-stroke-color);\n`\n\nexport const labelGroups = css`\n label: label-groups;\n`\n\nexport const labelGroup = css`\n label: label-group;\n pointer-events: none;\n`\n\nexport const labelCircle = css`\n label: label-circle;\n\n fill: var(--vis-graph-link-label-fill-color);\n stroke: var(--vis-graph-link-label-stroke-color);\n`\n\nexport const labelContent = css`\n label: label-content;\n\n font-family: var(--vis-graph-icon-font-family), var(--vis-font-family);\n fill: var(--vis-graph-link-label-text-color);\n text-anchor: middle;\n dominant-baseline: middle;\n`\n"],"names":[],"mappings":";;AAEO,MAAM,KAAK,GAAG,GAAG,CAAA,CAAA;;EAEvB;AAEwB,YAAY,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;AAqBjB,kBAAA,EAAA,CAAA,CAAA,EAAI,KAAK,CAAE,CAAA,CAAA;;;;;;EAM9B;AAEM,MAAM,WAAW,GAAG,GAAG,CAAA,CAAA;;;;;;;;;;EAU7B;AAEM,MAAM,IAAI,GAAG,GAAG,CAAA,CAAA;;;;;;;;EAQtB;AAEM,MAAM,UAAU,GAAG,GAAG,CAAA,CAAA;;;AAGzB,EAAA,EAAA,CAAA,CAAA,EAAI,IAAI,CAAE,CAAA,CAAA;;;EAGb;AAEM,MAAM,KAAK,GAAG,GAAG,CAAA,CAAA;;EAEvB;AAEM,MAAM,SAAS,GAAG,GAAG,CAAA,CAAA;;;EAG3B;AAEM,MAAM,OAAO,GAAG,GAAG,CAAA,CAAA;;;EAGzB;AAEM,MAAM,QAAQ,GAAG,GAAG,CAAA,CAAA;;;;;;EAM1B;AAEM,MAAM,SAAS,GAAG,GAAG,CAAA,CAAA;;;;EAI3B;AAEM,MAAM,UAAU,GAAG,GAAG,CAAA,CAAA;;;;EAI5B;AAEM,MAAM,WAAW,GAAG,GAAG,CAAA,CAAA;;EAE7B;AAEM,MAAM,UAAU,GAAG,GAAG,CAAA,CAAA;;;EAG5B;AAEM,MAAM,WAAW,GAAG,GAAG,CAAA,CAAA;;;;;EAK7B;AAEM,MAAM,YAAY,GAAG,GAAG,CAAA,CAAA;;;;;;;;;;;"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Selection, BaseType } from 'd3-selection';
|
|
2
|
+
import { Arc } from 'd3-shape';
|
|
3
|
+
import { ColorAccessor, NumericAccessor } from "../../../../types/accessor";
|
|
4
|
+
import { GraphInputLink, GraphInputNode } from "../../../../types/graph";
|
|
5
|
+
import { GraphNode, GraphCircleLabel, GraphNodeAnimatedElement, GraphNodeAnimationState } from '../../types';
|
|
6
|
+
import { GraphConfigInterface } from '../../config';
|
|
7
|
+
export declare const NODE_SIZE = 30;
|
|
8
|
+
export declare const LABEL_RECT_HORIZONTAL_PADDING = 10;
|
|
9
|
+
export declare const LABEL_RECT_VERTICAL_PADDING = 4;
|
|
10
|
+
export declare function getNodeSize<T>(d: T, nodeSizeAccessor: NumericAccessor<T>, index: number): number;
|
|
11
|
+
export declare function arcTween<N extends GraphInputNode, L extends GraphInputLink>(d: GraphNode<N, L>, config: GraphConfigInterface<N, L>, arcConstructor: Arc<any, GraphNodeAnimationState>, el: GraphNodeAnimatedElement<SVGElement>): (t: number) => string;
|
|
12
|
+
export declare function polyTween<N extends GraphInputNode, L extends GraphInputLink>(d: GraphNode<N, L>, config: GraphConfigInterface<N, L>, polygonConstructor: any, el: GraphNodeAnimatedElement<SVGElement>): (t: number) => string;
|
|
13
|
+
export declare function setLabelRect<A>(labelSelection: Selection<BaseType, A, SVGGElement, A>, label: string, selector: string): Selection<BaseType, A, SVGGElement, A>;
|
|
14
|
+
export declare function getX(node: GraphNode): number;
|
|
15
|
+
export declare function getY(node: GraphNode): number;
|
|
16
|
+
export declare function configuredNodeSize<T>(nodeSizeAccessor: NumericAccessor<T>): number;
|
|
17
|
+
export declare function getMaxNodeSize<T>(data: T[], nodeSize: NumericAccessor<T>): number;
|
|
18
|
+
export declare function getAverageNodeSize<T>(data: T[], nodeSize: NumericAccessor<T>): number;
|
|
19
|
+
export declare function getSideLabelTextColor(label: GraphCircleLabel): string;
|
|
20
|
+
export declare function getNodeColor<T>(d: T, colorAccessor: ColorAccessor<T>, index: number): string;
|
|
21
|
+
export declare function getNodeIconColor<T>(d: T, colorAccessor: ColorAccessor<T>, index: number): string;
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { interpolate } from 'd3-interpolate';
|
|
2
|
+
import { max, mean } from 'd3-array';
|
|
3
|
+
import { color } from 'd3-color';
|
|
4
|
+
import { scoreRectPath } from '../../../../utils/path.js';
|
|
5
|
+
import { getNumber, isNil, isEmpty, getString } from '../../../../utils/data.js';
|
|
6
|
+
import { getColor, hexToBrightness } from '../../../../utils/color.js';
|
|
7
|
+
import { GraphNodeShape } from '../../types.js';
|
|
8
|
+
|
|
9
|
+
const NODE_SIZE = 30;
|
|
10
|
+
const LABEL_RECT_HORIZONTAL_PADDING = 10;
|
|
11
|
+
const LABEL_RECT_VERTICAL_PADDING = 4;
|
|
12
|
+
function getNodeSize(d, nodeSizeAccessor, index) {
|
|
13
|
+
return getNumber(d, nodeSizeAccessor, index) || NODE_SIZE;
|
|
14
|
+
}
|
|
15
|
+
function _setInitialAnimState(el, index) {
|
|
16
|
+
el._animState = {
|
|
17
|
+
endAngle: 0,
|
|
18
|
+
nodeIndex: index,
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
// Animate the arc around node with keeping
|
|
22
|
+
// the current anim state info
|
|
23
|
+
function arcTween(d, config, arcConstructor, el) {
|
|
24
|
+
var _a;
|
|
25
|
+
const { nodeStrokeWidth, nodeSize, nodeGaugeValue } = config;
|
|
26
|
+
if (!el._animState)
|
|
27
|
+
_setInitialAnimState(el, d._index);
|
|
28
|
+
const i = interpolate(el._animState, {
|
|
29
|
+
endAngle: 2 * Math.PI * ((_a = getNumber(d, nodeGaugeValue, d._index)) !== null && _a !== void 0 ? _a : 0) / 100,
|
|
30
|
+
nodeIndex: d._index,
|
|
31
|
+
nodeSize: getNodeSize(d, nodeSize, d._index),
|
|
32
|
+
borderWidth: getNumber(d, nodeStrokeWidth, d._index),
|
|
33
|
+
});
|
|
34
|
+
el._animState = i(0);
|
|
35
|
+
return (t) => {
|
|
36
|
+
el._animState = i(t);
|
|
37
|
+
return arcConstructor(el._animState);
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
function polyTween(d, config, polygonConstructor, el) {
|
|
41
|
+
var _a;
|
|
42
|
+
const { nodeShape, nodeGaugeValue } = config;
|
|
43
|
+
const nodeSize = getNodeSize(d, config.nodeSize, d._index);
|
|
44
|
+
let n;
|
|
45
|
+
switch (getString(d, nodeShape, d._index)) {
|
|
46
|
+
case GraphNodeShape.Square:
|
|
47
|
+
n = 4;
|
|
48
|
+
break;
|
|
49
|
+
case GraphNodeShape.Triangle:
|
|
50
|
+
n = 3;
|
|
51
|
+
break;
|
|
52
|
+
case GraphNodeShape.Hexagon:
|
|
53
|
+
default:
|
|
54
|
+
n = 6;
|
|
55
|
+
}
|
|
56
|
+
if (!el._animState)
|
|
57
|
+
_setInitialAnimState(el, d._index);
|
|
58
|
+
const i = interpolate(el._animState, {
|
|
59
|
+
endAngle: 2 * Math.PI * ((_a = getNumber(d, nodeGaugeValue, d._index)) !== null && _a !== void 0 ? _a : 0) / 100,
|
|
60
|
+
nodeIndex: d._index,
|
|
61
|
+
});
|
|
62
|
+
el._animState = i(0);
|
|
63
|
+
return (t) => {
|
|
64
|
+
el._animState = i(t);
|
|
65
|
+
return n === 4 ? scoreRectPath({
|
|
66
|
+
x: -nodeSize / 2,
|
|
67
|
+
y: -nodeSize / 2,
|
|
68
|
+
w: nodeSize,
|
|
69
|
+
h: nodeSize,
|
|
70
|
+
r: 5,
|
|
71
|
+
score: el._animState.endAngle / (2 * Math.PI),
|
|
72
|
+
}) : polygonConstructor(nodeSize, n, el._animState.endAngle, true);
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
function setLabelRect(labelSelection, label, selector) {
|
|
76
|
+
// Set label background rectangle size by text size
|
|
77
|
+
const labelIsEmpty = isEmpty(label);
|
|
78
|
+
const labelTextSelection = labelSelection.select(`.${selector}`);
|
|
79
|
+
const labelTextBBox = labelTextSelection.node().getBBox();
|
|
80
|
+
const backgroundRect = labelSelection.select('rect')
|
|
81
|
+
.attr('visibility', labelIsEmpty ? 'hidden' : null)
|
|
82
|
+
.attr('rx', 4)
|
|
83
|
+
.attr('ry', 4)
|
|
84
|
+
.attr('x', -labelTextBBox.width / 2 - LABEL_RECT_HORIZONTAL_PADDING)
|
|
85
|
+
.attr('y', '-0.64em')
|
|
86
|
+
.attr('width', labelTextBBox.width + 2 * LABEL_RECT_HORIZONTAL_PADDING)
|
|
87
|
+
.attr('height', labelTextBBox.height + 2 * LABEL_RECT_VERTICAL_PADDING)
|
|
88
|
+
.style('transform', `translateY(${-LABEL_RECT_VERTICAL_PADDING}px)`);
|
|
89
|
+
return backgroundRect;
|
|
90
|
+
}
|
|
91
|
+
function getX(node) {
|
|
92
|
+
return node._state && !isNil(node._state.fx) ? node._state.fx : node.x;
|
|
93
|
+
}
|
|
94
|
+
function getY(node) {
|
|
95
|
+
return node._state && !isNil(node._state.fy) ? node._state.fy : node.y;
|
|
96
|
+
}
|
|
97
|
+
function configuredNodeSize(nodeSizeAccessor) {
|
|
98
|
+
return typeof nodeSizeAccessor === 'number' ? nodeSizeAccessor : NODE_SIZE;
|
|
99
|
+
}
|
|
100
|
+
function getMaxNodeSize(data, nodeSize) {
|
|
101
|
+
return max(data || [], (d, i) => getNodeSize(d, nodeSize, i)) || NODE_SIZE;
|
|
102
|
+
}
|
|
103
|
+
function getAverageNodeSize(data, nodeSize) {
|
|
104
|
+
return mean(data || [], (d, i) => getNodeSize(d, nodeSize, i)) || NODE_SIZE;
|
|
105
|
+
}
|
|
106
|
+
function getSideLabelTextColor(label) {
|
|
107
|
+
if (!label.color)
|
|
108
|
+
return null;
|
|
109
|
+
const hex = color(label.color).hex();
|
|
110
|
+
const brightness = hexToBrightness(hex);
|
|
111
|
+
return brightness > 0.65 ? 'var(--vis-graph-node-side-label-fill-color-dark)' : 'var(--vis-graph-node-side-label-fill-color-bright)';
|
|
112
|
+
}
|
|
113
|
+
function getNodeColor(d, colorAccessor, index) {
|
|
114
|
+
var _a;
|
|
115
|
+
return (_a = getColor(d, colorAccessor, index, true)) !== null && _a !== void 0 ? _a : null;
|
|
116
|
+
}
|
|
117
|
+
function getNodeIconColor(d, colorAccessor, index) {
|
|
118
|
+
const nodeColor = getNodeColor(d, colorAccessor, index);
|
|
119
|
+
if (!nodeColor)
|
|
120
|
+
return null;
|
|
121
|
+
const hex = color(nodeColor).hex();
|
|
122
|
+
const brightness = hexToBrightness(hex);
|
|
123
|
+
return brightness > 0.65 ? 'var(--vis-graph-node-icon-fill-color-dark)' : 'var(--vis-graph-node-icon-fill-color-bright)';
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
export { LABEL_RECT_HORIZONTAL_PADDING, LABEL_RECT_VERTICAL_PADDING, NODE_SIZE, arcTween, configuredNodeSize, getAverageNodeSize, getMaxNodeSize, getNodeColor, getNodeIconColor, getNodeSize, getSideLabelTextColor, getX, getY, polyTween, setLabelRect };
|
|
127
|
+
//# sourceMappingURL=helper.js.map
|