@orbcharts/plugins-basic 3.0.0-beta.7 → 3.0.0-beta.9

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.
Files changed (169) hide show
  1. package/LICENSE +200 -200
  2. package/dist/orbcharts-plugins-basic/lib/plugins-basic-types.d.ts +1 -1
  3. package/dist/orbcharts-plugins-basic/src/base/{BaseBarStack.d.ts → BaseStackedBar.d.ts} +4 -4
  4. package/dist/orbcharts-plugins-basic/src/grid/defaults.d.ts +3 -3
  5. package/dist/orbcharts-plugins-basic/src/grid/index.d.ts +2 -2
  6. package/dist/orbcharts-plugins-basic/src/grid/plugins/Bars.d.ts +1 -1
  7. package/dist/orbcharts-plugins-basic/src/grid/plugins/BarsPN.d.ts +1 -1
  8. package/dist/orbcharts-plugins-basic/src/grid/plugins/BarsTriangle.d.ts +1 -1
  9. package/dist/orbcharts-plugins-basic/src/grid/plugins/Dots.d.ts +1 -1
  10. package/dist/orbcharts-plugins-basic/src/grid/plugins/GridLegend.d.ts +1 -1
  11. package/dist/orbcharts-plugins-basic/src/grid/plugins/GridTooltip.d.ts +1 -1
  12. package/dist/orbcharts-plugins-basic/src/grid/plugins/GridZoom.d.ts +1 -1
  13. package/dist/orbcharts-plugins-basic/src/grid/plugins/GroupAux.d.ts +1 -1
  14. package/dist/orbcharts-plugins-basic/src/grid/plugins/GroupAxis.d.ts +1 -1
  15. package/dist/orbcharts-plugins-basic/src/grid/plugins/LineAreas.d.ts +1 -1
  16. package/dist/orbcharts-plugins-basic/src/grid/plugins/Lines.d.ts +1 -1
  17. package/dist/orbcharts-plugins-basic/src/grid/plugins/StackedBar.d.ts +1 -0
  18. package/dist/orbcharts-plugins-basic/src/grid/plugins/StackedValueAxis.d.ts +1 -0
  19. package/dist/orbcharts-plugins-basic/src/grid/plugins/ValueAxis.d.ts +1 -1
  20. package/dist/orbcharts-plugins-basic/src/index.d.ts +1 -0
  21. package/dist/orbcharts-plugins-basic/src/multiGrid/defaults.d.ts +4 -4
  22. package/dist/orbcharts-plugins-basic/src/multiGrid/index.d.ts +3 -3
  23. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiBars.d.ts +1 -1
  24. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiBarsTriangle.d.ts +1 -1
  25. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiDots.d.ts +1 -1
  26. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiGridLegend.d.ts +1 -1
  27. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiGridTooltip.d.ts +1 -1
  28. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiGroupAxis.d.ts +1 -1
  29. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiLineAreas.d.ts +1 -1
  30. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiLines.d.ts +1 -1
  31. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiStackedBar.d.ts +1 -0
  32. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiStackedValueAxis.d.ts +1 -0
  33. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiValueAxis.d.ts +1 -1
  34. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/OverlappingStackedValueAxes.d.ts +1 -0
  35. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/OverlappingValueAxes.d.ts +1 -1
  36. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/MultiValueLegend.d.ts +1 -1
  37. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/MultiValueTooltip.d.ts +1 -1
  38. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/Scatter.d.ts +1 -1
  39. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/ScatterBubbles.d.ts +1 -1
  40. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/XYAux.d.ts +1 -1
  41. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/XYAxes.d.ts +1 -1
  42. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/XYZoom.d.ts +1 -1
  43. package/dist/orbcharts-plugins-basic/src/noneData/plugins/Container.d.ts +0 -1
  44. package/dist/orbcharts-plugins-basic/src/noneData/plugins/Tooltip.d.ts +0 -3
  45. package/dist/orbcharts-plugins-basic/src/relationship/defaults.d.ts +6 -0
  46. package/dist/orbcharts-plugins-basic/src/relationship/index.d.ts +5 -0
  47. package/dist/orbcharts-plugins-basic/src/relationship/plugins/ForceDirected.d.ts +3 -0
  48. package/dist/orbcharts-plugins-basic/src/relationship/plugins/ForceDirectedBubbles.d.ts +3 -0
  49. package/dist/orbcharts-plugins-basic/src/relationship/plugins/RelationshipLegend.d.ts +1 -0
  50. package/dist/orbcharts-plugins-basic/src/relationship/plugins/RelationshipTooltip.d.ts +1 -0
  51. package/dist/orbcharts-plugins-basic/src/relationship/relationshipObservables.d.ts +1 -0
  52. package/dist/orbcharts-plugins-basic/src/series/plugins/Bubbles.d.ts +1 -1
  53. package/dist/orbcharts-plugins-basic/src/series/plugins/Pie.d.ts +1 -1
  54. package/dist/orbcharts-plugins-basic/src/series/plugins/PieEventTexts.d.ts +1 -1
  55. package/dist/orbcharts-plugins-basic/src/series/plugins/PieLabels.d.ts +1 -1
  56. package/dist/orbcharts-plugins-basic/src/series/plugins/Rose.d.ts +1 -1
  57. package/dist/orbcharts-plugins-basic/src/series/plugins/RoseLabels.d.ts +1 -1
  58. package/dist/orbcharts-plugins-basic/src/series/plugins/SeriesLegend.d.ts +1 -1
  59. package/dist/orbcharts-plugins-basic/src/series/plugins/SeriesTooltip.d.ts +1 -1
  60. package/dist/orbcharts-plugins-basic/src/tree/plugins/TreeLegend.d.ts +1 -1
  61. package/dist/orbcharts-plugins-basic/src/tree/plugins/TreeMap.d.ts +1 -1
  62. package/dist/orbcharts-plugins-basic/src/tree/plugins/TreeTooltip.d.ts +1 -1
  63. package/dist/orbcharts-plugins-basic/src/utils/commonUtils.d.ts +1 -1
  64. package/dist/orbcharts-plugins-basic/src/utils/orbchartsUtils.d.ts +1 -1
  65. package/dist/orbcharts-plugins-basic.es.js +9421 -8102
  66. package/dist/orbcharts-plugins-basic.umd.js +69 -51
  67. package/lib/core-types.ts +7 -7
  68. package/lib/core.ts +6 -6
  69. package/lib/plugins-basic-types.ts +6 -6
  70. package/package.json +44 -44
  71. package/src/base/BaseBars.ts +765 -765
  72. package/src/base/BaseBarsTriangle.ts +676 -676
  73. package/src/base/BaseDots.ts +464 -464
  74. package/src/base/BaseGroupAxis.ts +679 -679
  75. package/src/base/BaseLegend.ts +684 -684
  76. package/src/base/BaseLineAreas.ts +629 -629
  77. package/src/base/BaseLines.ts +706 -706
  78. package/src/base/{BaseBarStack.ts → BaseStackedBar.ts} +782 -782
  79. package/src/base/BaseTooltip.ts +385 -385
  80. package/src/base/BaseValueAxis.ts +583 -583
  81. package/src/base/types.ts +2 -2
  82. package/src/const.ts +30 -30
  83. package/src/grid/defaults.ts +246 -246
  84. package/src/grid/gridObservables.ts +554 -554
  85. package/src/grid/index.ts +16 -16
  86. package/src/grid/plugins/Bars.ts +69 -69
  87. package/src/grid/plugins/BarsPN.ts +66 -66
  88. package/src/grid/plugins/BarsTriangle.ts +73 -73
  89. package/src/grid/plugins/Dots.ts +68 -68
  90. package/src/grid/plugins/GridLegend.ts +107 -107
  91. package/src/grid/plugins/GridTooltip.ts +66 -66
  92. package/src/grid/plugins/GridZoom.ts +218 -218
  93. package/src/grid/plugins/GroupAux.ts +1103 -1103
  94. package/src/grid/plugins/GroupAxis.ts +97 -97
  95. package/src/grid/plugins/LineAreas.ts +65 -65
  96. package/src/grid/plugins/Lines.ts +59 -59
  97. package/src/grid/plugins/{BarStack.ts → StackedBar.ts} +64 -64
  98. package/src/grid/plugins/{ValueStackAxis.ts → StackedValueAxis.ts} +96 -96
  99. package/src/grid/plugins/ValueAxis.ts +94 -94
  100. package/src/index.ts +6 -10
  101. package/src/multiGrid/defaults.ts +224 -224
  102. package/src/multiGrid/index.ts +15 -15
  103. package/src/multiGrid/multiGridObservables.ts +49 -49
  104. package/src/multiGrid/plugins/MultiBars.ts +108 -108
  105. package/src/multiGrid/plugins/MultiBarsTriangle.ts +114 -114
  106. package/src/multiGrid/plugins/MultiDots.ts +102 -102
  107. package/src/multiGrid/plugins/MultiGridLegend.ts +159 -159
  108. package/src/multiGrid/plugins/MultiGridTooltip.ts +66 -66
  109. package/src/multiGrid/plugins/MultiGroupAxis.ts +137 -137
  110. package/src/multiGrid/plugins/MultiLineAreas.ts +107 -107
  111. package/src/multiGrid/plugins/MultiLines.ts +101 -101
  112. package/src/multiGrid/plugins/{MultiBarStack.ts → MultiStackedBar.ts} +106 -106
  113. package/src/multiGrid/plugins/{MultiValueStackAxis.ts → MultiStackedValueAxis.ts} +134 -134
  114. package/src/multiGrid/plugins/MultiValueAxis.ts +134 -134
  115. package/src/multiGrid/plugins/{OverlappingValueStackAxes.ts → OverlappingStackedValueAxes.ts} +299 -299
  116. package/src/multiGrid/plugins/OverlappingValueAxes.ts +300 -300
  117. package/src/multiValue/defaults.ts +166 -166
  118. package/src/multiValue/index.ts +8 -8
  119. package/src/multiValue/multiValueObservables.ts +297 -297
  120. package/src/multiValue/plugins/MultiValueLegend.ts +107 -107
  121. package/src/multiValue/plugins/MultiValueTooltip.ts +66 -66
  122. package/src/multiValue/plugins/Scatter.ts +426 -426
  123. package/src/multiValue/plugins/ScatterBubbles.ts +554 -554
  124. package/src/multiValue/plugins/XYAux.ts +681 -681
  125. package/src/multiValue/plugins/XYAxes.ts +684 -684
  126. package/src/multiValue/plugins/XYZoom.ts +299 -299
  127. package/src/noneData/defaults.ts +102 -102
  128. package/src/noneData/index.ts +3 -3
  129. package/src/noneData/plugins/Container.ts +28 -28
  130. package/src/noneData/plugins/Tooltip.ts +374 -374
  131. package/src/relationship/defaults.ts +196 -0
  132. package/src/relationship/index.ts +5 -0
  133. package/src/relationship/plugins/ForceDirected.ts +1167 -0
  134. package/src/relationship/plugins/ForceDirectedBubbles.ts +1391 -0
  135. package/src/relationship/plugins/RelationshipLegend.ts +100 -0
  136. package/src/relationship/plugins/RelationshipTooltip.ts +66 -0
  137. package/src/relationship/relationshipObservables.ts +50 -0
  138. package/src/series/defaults.ts +206 -206
  139. package/src/series/index.ts +9 -9
  140. package/src/series/plugins/Bubbles.ts +606 -603
  141. package/src/series/plugins/Pie.ts +623 -623
  142. package/src/series/plugins/PieEventTexts.ts +284 -283
  143. package/src/series/plugins/PieLabels.ts +640 -640
  144. package/src/series/plugins/Rose.ts +516 -516
  145. package/src/series/plugins/RoseLabels.ts +600 -600
  146. package/src/series/plugins/SeriesLegend.ts +107 -107
  147. package/src/series/plugins/SeriesTooltip.ts +66 -66
  148. package/src/series/seriesObservables.ts +145 -145
  149. package/src/series/seriesUtils.ts +51 -51
  150. package/src/tree/defaults.ts +78 -78
  151. package/src/tree/index.ts +4 -4
  152. package/src/tree/plugins/TreeLegend.ts +100 -100
  153. package/src/tree/plugins/TreeMap.ts +333 -333
  154. package/src/tree/plugins/TreeTooltip.ts +66 -66
  155. package/src/utils/commonUtils.ts +21 -21
  156. package/src/utils/d3Graphics.ts +174 -174
  157. package/src/utils/d3Utils.ts +74 -74
  158. package/src/utils/observables.ts +14 -14
  159. package/src/utils/orbchartsUtils.ts +115 -115
  160. package/tsconfig.base.json +13 -13
  161. package/tsconfig.json +2 -2
  162. package/vite.config.js +22 -22
  163. package/dist/orbcharts-plugins-basic/src/grid/plugins/BarStack.d.ts +0 -1
  164. package/dist/orbcharts-plugins-basic/src/grid/plugins/ValueStackAxis.d.ts +0 -1
  165. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiBarStack.d.ts +0 -1
  166. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiValueStackAxis.d.ts +0 -1
  167. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/OverlappingValueStackAxes.d.ts +0 -1
  168. package/dist/orbcharts-plugins-basic/src/relationship/plugins/Relationship.d.ts +0 -0
  169. package/src/relationship/plugins/Relationship.ts +0 -0
@@ -0,0 +1,100 @@
1
+ import * as d3 from 'd3'
2
+ import {
3
+ combineLatest,
4
+ map,
5
+ switchMap,
6
+ takeUntil,
7
+ Observable,
8
+ Subject } from 'rxjs'
9
+ import type { DefinePluginConfig } from '../../../lib/core-types'
10
+ import {
11
+ defineRelationshipPlugin } from '../../../lib/core'
12
+ import { DEFAULT_RELATIONSHIP_LEGEND_PARAMS } from '../defaults'
13
+ import { createBaseLegend } from '../../base/BaseLegend'
14
+ import { LAYER_INDEX_OF_INFO } from '../../const'
15
+
16
+ const pluginName = 'RelationshipLegend'
17
+
18
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_RELATIONSHIP_LEGEND_PARAMS> = {
19
+ name: pluginName,
20
+ defaultParams: DEFAULT_RELATIONSHIP_LEGEND_PARAMS,
21
+ layerIndex: LAYER_INDEX_OF_INFO,
22
+ validator: (params, { validateColumns }) => {
23
+ const result = validateColumns(params, {
24
+ placement: {
25
+ toBe: '"top" | "top-start" | "top-end" | "bottom" | "bottom-start" | "bottom-end" | "left" | "left-start" | "left-end" | "right" | "right-start" | "right-end"',
26
+ test: (value) => {
27
+ return [
28
+ 'top', 'top-start', 'top-end',
29
+ 'bottom', 'bottom-start', 'bottom-end',
30
+ 'left', 'left-start', 'left-end',
31
+ 'right', 'right-start', 'right-end'
32
+ ].includes(value)
33
+ }
34
+ },
35
+ padding: {
36
+ toBeTypes: ['number']
37
+ },
38
+ backgroundFill: {
39
+ toBeOption: 'ColorType',
40
+ },
41
+ backgroundStroke: {
42
+ toBeOption: 'ColorType',
43
+ },
44
+ gap: {
45
+ toBeTypes: ['number']
46
+ },
47
+ listRectWidth: {
48
+ toBeTypes: ['number']
49
+ },
50
+ listRectHeight: {
51
+ toBeTypes: ['number']
52
+ },
53
+ listRectRadius: {
54
+ toBeTypes: ['number']
55
+ },
56
+ textColorType: {
57
+ toBeOption: 'ColorType',
58
+ }
59
+ })
60
+ return result
61
+ }
62
+ }
63
+
64
+ export const RelationshipLegend = defineRelationshipPlugin(pluginConfig)(({ selection, rootSelection, observer, subject }) => {
65
+
66
+ const destroy$ = new Subject()
67
+
68
+ // 全部列點矩型使用相同樣式參數
69
+ const fullParams$ = observer.fullParams$.pipe(
70
+ takeUntil(destroy$),
71
+ map(d => {
72
+ const labelList = [
73
+ {
74
+ listRectWidth: d.listRectWidth,
75
+ listRectHeight: d.listRectHeight,
76
+ listRectRadius: d.listRectRadius,
77
+ }
78
+ ]
79
+ return {
80
+ ...d,
81
+ labelList
82
+ }
83
+ })
84
+ )
85
+
86
+ const unsubscribeBaseLegend = createBaseLegend(pluginName, {
87
+ rootSelection,
88
+ legendLabels$: observer.categoryLabels$,
89
+ fullParams$,
90
+ layout$: observer.layout$,
91
+ fullChartParams$: observer.fullChartParams$,
92
+ textSizePx$: observer.textSizePx$
93
+ })
94
+
95
+ return () => {
96
+ destroy$.next(undefined)
97
+ unsubscribeBaseLegend()
98
+ }
99
+ })
100
+
@@ -0,0 +1,66 @@
1
+ import {
2
+ Subject,
3
+ } from 'rxjs'
4
+ import type { DefinePluginConfig } from '../../../lib/core-types'
5
+ import {
6
+ defineRelationshipPlugin } from '../../../lib/core'
7
+ import { DEFAULT_RELATIONSHIP_TOOLTIP_PARAMS } from '../defaults'
8
+ import { LAYER_INDEX_OF_TOOLTIP } from '../../const'
9
+ import { createBaseTooltip } from '../../base/BaseTooltip'
10
+
11
+ const pluginName = 'RelationshipTooltip'
12
+
13
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_RELATIONSHIP_TOOLTIP_PARAMS> = {
14
+ name: pluginName,
15
+ defaultParams: DEFAULT_RELATIONSHIP_TOOLTIP_PARAMS,
16
+ layerIndex: LAYER_INDEX_OF_TOOLTIP,
17
+ validator: (params, { validateColumns }) => {
18
+ const result = validateColumns(params, {
19
+ backgroundColorType: {
20
+ toBeOption: 'ColorType',
21
+ },
22
+ backgroundOpacity: {
23
+ toBeTypes: ['number']
24
+ },
25
+ strokeColorType: {
26
+ toBeOption: 'ColorType',
27
+ },
28
+ offset: {
29
+ toBe: '[number, number]',
30
+ test: (value: any) => {
31
+ return Array.isArray(value)
32
+ && value.length === 2
33
+ && typeof value[0] === 'number'
34
+ && typeof value[1] === 'number'
35
+ }
36
+ },
37
+ padding: {
38
+ toBeTypes: ['number']
39
+ },
40
+ textColorType: {
41
+ toBeOption: 'ColorType',
42
+ },
43
+ renderFn: {
44
+ toBeTypes: ['Function']
45
+ },
46
+ })
47
+ return result
48
+ }
49
+ }
50
+
51
+ export const RelationshipTooltip = defineRelationshipPlugin(pluginConfig)(({ selection, rootSelection, name, subject, observer }) => {
52
+ const destroy$ = new Subject()
53
+
54
+ const unsubscribeTooltip = createBaseTooltip(pluginName, {
55
+ rootSelection,
56
+ fullParams$: observer.fullParams$,
57
+ fullChartParams$: observer.fullChartParams$,
58
+ layout$: observer.layout$,
59
+ event$: subject.event$,
60
+ })
61
+
62
+ return () => {
63
+ destroy$.next(undefined)
64
+ unsubscribeTooltip()
65
+ }
66
+ })
@@ -0,0 +1,50 @@
1
+ import * as d3 from 'd3'
2
+ import {
3
+ Observable,
4
+ Subject,
5
+ of,
6
+ takeUntil,
7
+ filter,
8
+ first,
9
+ map,
10
+ switchMap,
11
+ combineLatest,
12
+ merge,
13
+ shareReplay,
14
+ distinctUntilChanged
15
+ } from 'rxjs'
16
+ import type {
17
+ ContainerPosition } from '../../lib/core-types'
18
+ import { getClassName, getUniID } from '../utils/orbchartsUtils'
19
+
20
+ // function createRelationshipSelection ({ selection, pluginName, separateSeries$, seriesLabels$ }: {
21
+ // selection: d3.Selection<any, unknown, any, unknown>
22
+ // pluginName: string
23
+ // separateSeries$: Observable<boolean>
24
+ // seriesLabels$: Observable<string[]>
25
+ // }) {
26
+ // const seriesClassName = getClassName(pluginName, 'series')
27
+
28
+ // return combineLatest({
29
+ // seriesLabels: seriesLabels$,
30
+ // separateSeries: separateSeries$
31
+ // }).pipe(
32
+ // switchMap(async d => d),
33
+ // map((data, i) => {
34
+ // const selectionData = data.separateSeries ? data.seriesLabels : [data.seriesLabels.join('')]
35
+ // return selection
36
+ // .selectAll<SVGGElement, string>(`g.${seriesClassName}`)
37
+ // .data(selectionData, d => d)
38
+ // .join(
39
+ // enter => {
40
+ // return enter
41
+ // .append('g')
42
+ // .classed(seriesClassName, true)
43
+ // },
44
+ // update => update,
45
+ // exit => exit.remove()
46
+ // )
47
+ // }),
48
+ // shareReplay(1)
49
+ // )
50
+ // }
@@ -1,207 +1,207 @@
1
- import type { ComputedDatumSeries, EventSeries, EventName, ColorType } from '../../lib/core-types'
2
- import type {
3
- BubblesParams,
4
- PieParams,
5
- PieEventTextsParams,
6
- PieLabelsParams,
7
- RoseParams,
8
- RoseLabelsParams,
9
- SeriesLegendParams,
10
- SeriesTooltipParams
11
- } from '../../lib/plugins-basic-types'
12
-
13
-
14
- export const DEFAULT_BUBBLES_PARAMS: BubblesParams = {
15
- force: {
16
- strength: 0.08, // 泡泡引力
17
- velocityDecay: 0.3, // 衰減數
18
- collisionSpacing: 2 // 泡泡間距
19
- },
20
- bubbleText: {
21
- fillRate: 0.6,
22
- lineHeight: 12,
23
- lineLengthMin: 4
24
- },
25
- // highlightRIncrease: 0,
26
- arcScaleType: 'area'
27
- }
28
-
29
- export const DEFAULT_PIE_PARAMS: PieParams = {
30
- // padding: {
31
- // top: 50,
32
- // right: 70,
33
- // bottom: 50,
34
- // left: 70
35
- // },
36
- outerRadius: 0.85,
37
- innerRadius: 0,
38
- outerRadiusWhileHighlight: 0.9,
39
- // label?: LabelStyle
40
- // enterDuration: 800,
41
- startAngle: 0,
42
- endAngle: Math.PI * 2,
43
- padAngle: 0,
44
- strokeColorType: 'background',
45
- strokeWidth: 1,
46
- // padRadius: 100,
47
- cornerRadius: 0,
48
- // highlightTarget: 'datum',
49
- // highlightId: null,
50
- // highlightLabel: null,
51
- }
52
-
53
- export const DEFAULT_PIE_EVENT_TEXTS_PARAMS: PieEventTextsParams = {
54
- eventFn: (eventData: EventSeries, eventName: EventName, t: number) => {
55
- if (eventName === 'mouseover' || eventName === 'mousemove') {
56
- return [String(eventData.datum!.value)]
57
- }
58
- return [
59
- String(
60
- Math.round(
61
- eventData.data.reduce((acc, seriesData) => {
62
- return acc + seriesData.reduce((_acc, data) => {
63
- return _acc + (data.value ?? 0)
64
- }, 0)
65
- }, 0) * t
66
- )
67
- )
68
- ]
69
- },
70
- textAttrs: [
71
- {
72
- "transform": "translate(0, 0)"
73
- }
74
- ],
75
- textStyles: [
76
- {
77
- "font-weight": "bold",
78
- "text-anchor": "middle",
79
- "pointer-events": "none",
80
- "dominant-baseline": "middle",
81
- "font-size": 64,
82
- "fill": "#000"
83
- }
84
- ]
85
- }
86
- DEFAULT_PIE_EVENT_TEXTS_PARAMS.eventFn.toString = () => `(eventData: EventSeries, eventName: EventName, t: number) => {
87
- if (eventName === 'mouseover' || eventName === 'mousemove') {
88
- return [String(eventData.datum!.value)]
89
- }
90
- return [
91
- String(
92
- Math.round(
93
- eventData.data.reduce((acc, seriesData) => {
94
- return acc + seriesData.reduce((_acc, data) => {
95
- return _acc + (data.value ?? 0)
96
- }, 0)
97
- }, 0) * t
98
- )
99
- )
100
- ]
101
- }`
102
-
103
- export const DEFAULT_PIE_LABELS_PARAMS: PieLabelsParams = {
104
- // solidColor: undefined,
105
- // colors: DEFAULT_COLORS,
106
- outerRadius: 0.85,
107
- outerRadiusWhileHighlight: 0.9,
108
- // innerRadius: 0,
109
- // enterDuration: 800,
110
- startAngle: 0,
111
- endAngle: Math.PI * 2,
112
- labelCentroid: 2.1,
113
- // fontSize: 12,
114
- labelColorType: 'primary',
115
- labelFn: d => String(d.label),
116
- }
117
- DEFAULT_PIE_LABELS_PARAMS.labelFn.toString = () => `d => String(d.label)`
118
-
119
- export const DEFAULT_ROSE_PARAMS: RoseParams = {
120
- outerRadius: 0.85,
121
- padAngle: 0,
122
- strokeColorType: 'background',
123
- strokeWidth: 0,
124
- cornerRadius: 0,
125
- arcScaleType: 'area',
126
- angleIncreaseWhileHighlight: 0.05
127
- }
128
-
129
- export const DEFAULT_ROSE_LABELS_PARAMS: RoseLabelsParams = {
130
- outerRadius: 0.85,
131
- labelCentroid: 2.1,
132
- labelFn: d => String(d.label),
133
- labelColorType: 'primary',
134
- arcScaleType: 'area'
135
- }
136
- DEFAULT_ROSE_LABELS_PARAMS.labelFn.toString = () => `d => String(d.label)`
137
-
138
- export const DEFAULT_SERIES_LEGEND_PARAMS: SeriesLegendParams = {
139
- // position: 'right',
140
- // justify: 'end',
141
- placement: 'right-end',
142
- padding: 28,
143
- // offset: [0, 0],
144
- backgroundFill: 'none',
145
- backgroundStroke: 'none',
146
- gap: 10,
147
- listRectWidth: 14,
148
- listRectHeight: 14,
149
- listRectRadius: 0,
150
- // highlightEvent: false
151
- textColorType: 'primary'
152
- }
153
-
154
- export const DEFAULT_SERIES_TOOLTIP_PARAMS: SeriesTooltipParams = {
155
- backgroundColorType: 'background',
156
- strokeColorType: 'primary',
157
- backgroundOpacity: 0.8,
158
- textColorType: 'primary',
159
- offset: [20, 5],
160
- padding: 10,
161
- renderFn: (eventData, { styles, utils }) => {
162
- const hasSeriesLabel = eventData.seriesLabel.slice(0, 7) === 'series_' ? false : true
163
- const hasDatumLabel = eventData.datum.label.slice(0, 7) === 'series_' ? false : true
164
- const bulletWidth = styles.textSizePx * 0.7
165
- const offset = (styles.textSizePx / 2) - (bulletWidth / 2)
166
- const seriesSvg = hasSeriesLabel
167
- ? `<rect width="${bulletWidth}" height="${bulletWidth}" x="${offset}" y="${offset - 1}" rx="${bulletWidth / 2}" fill="${eventData.datum.color}"></rect>
168
- <text x="${styles.textSizePx * 1.5}" font-size="${styles.textSizePx}" dominant-baseline="hanging" fill="${styles.textColor}">
169
- <tspan>${eventData.seriesLabel}</tspan>
170
- </text>`
171
- : ''
172
- const datumLabelSvg = hasDatumLabel
173
- ? `<tspan>${eventData.datum.label}</tspan> `
174
- : ''
175
- const datumSvg = `<text font-size="${styles.textSizePx}" dominant-baseline="hanging" fill="${styles.textColor}">
176
- ${datumLabelSvg}<tspan font-weight="bold">${eventData.datum.value}</tspan>
177
- </text>`
178
-
179
- return `${seriesSvg}
180
- <g ${hasSeriesLabel ? `transform="translate(0, ${styles.textSizePx * 2})"` : ''}>
181
- ${datumSvg}
182
- </g>`
183
- },
184
- }
185
- DEFAULT_SERIES_TOOLTIP_PARAMS.renderFn.toString = () => `(eventData, { styles, utils }) => {
186
- const hasSeriesLabel = eventData.seriesLabel.slice(0, 7) === 'series_' ? false : true
187
- const hasDatumLabel = eventData.datum.label.slice(0, 7) === 'series_' ? false : true
188
- const bulletWidth = styles.textSizePx * 0.7
189
- const offset = (styles.textSizePx / 2) - (bulletWidth / 2)
190
- const seriesSvg = hasSeriesLabel
191
- ? \`<rect width="\${bulletWidth}" height="\${bulletWidth}" x="\${offset}" y="\${offset - 1}" rx="\${bulletWidth / 2}" fill="\${eventData.datum.color}"></rect>
192
- <text x="\${styles.textSizePx * 1.5}" font-size="\${styles.textSizePx}" dominant-baseline="hanging" fill="\${styles.textColor}">
193
- <tspan>\${eventData.seriesLabel}</tspan>
194
- </text>\`
195
- : ''
196
- const datumLabelSvg = hasDatumLabel
197
- ? \`<tspan>\${eventData.datum.label}</tspan> \`
198
- : ''
199
- const datumSvg = \`<text font-size="\${styles.textSizePx}" dominant-baseline="hanging" fill="\${styles.textColor}">
200
- \${datumLabelSvg}<tspan font-weight="bold">\${eventData.datum.value}</tspan>
201
- </text>\`
202
-
203
- return \`\${seriesSvg}
204
- <g \${hasSeriesLabel ? \`transform="translate(0, \${styles.textSizePx * 2})"\` : ''}>
205
- \${datumSvg}
206
- </g>\`
1
+ import type { ComputedDatumSeries, EventSeries, EventName, ColorType } from '../../lib/core-types'
2
+ import type {
3
+ BubblesParams,
4
+ PieParams,
5
+ PieEventTextsParams,
6
+ PieLabelsParams,
7
+ RoseParams,
8
+ RoseLabelsParams,
9
+ SeriesLegendParams,
10
+ SeriesTooltipParams
11
+ } from '../../lib/plugins-basic-types'
12
+
13
+
14
+ export const DEFAULT_BUBBLES_PARAMS: BubblesParams = {
15
+ force: {
16
+ strength: 0.08, // 泡泡引力
17
+ velocityDecay: 0.3, // 衰減數
18
+ collisionSpacing: 2 // 泡泡間距
19
+ },
20
+ bubbleLabel: {
21
+ fillRate: 0.6,
22
+ lineHeight: 1,
23
+ lineLengthMin: 4
24
+ },
25
+ // highlightRIncrease: 0,
26
+ arcScaleType: 'area'
27
+ }
28
+
29
+ export const DEFAULT_PIE_PARAMS: PieParams = {
30
+ // padding: {
31
+ // top: 50,
32
+ // right: 70,
33
+ // bottom: 50,
34
+ // left: 70
35
+ // },
36
+ outerRadius: 0.85,
37
+ innerRadius: 0,
38
+ outerRadiusWhileHighlight: 0.9,
39
+ // label?: LabelStyle
40
+ // enterDuration: 800,
41
+ startAngle: 0,
42
+ endAngle: Math.PI * 2,
43
+ padAngle: 0,
44
+ strokeColorType: 'background',
45
+ strokeWidth: 1,
46
+ // padRadius: 100,
47
+ cornerRadius: 0,
48
+ // highlightTarget: 'datum',
49
+ // highlightId: null,
50
+ // highlightLabel: null,
51
+ }
52
+
53
+ export const DEFAULT_PIE_EVENT_TEXTS_PARAMS: PieEventTextsParams = {
54
+ renderFn: (eventData: EventSeries) => {
55
+ if (eventData.eventName === 'mouseover' || eventData.eventName === 'mousemove') {
56
+ return [String(eventData.datum!.value)]
57
+ }
58
+ return [
59
+ String(
60
+ Math.round(
61
+ eventData.data.reduce((acc, seriesData) => {
62
+ return acc + seriesData.reduce((_acc, data) => {
63
+ return _acc + (data.value ?? 0)
64
+ }, 0)
65
+ }, 0) * (eventData.tween ?? 1)
66
+ )
67
+ )
68
+ ]
69
+ },
70
+ textAttrs: [
71
+ {
72
+ "transform": "translate(0, 0)"
73
+ }
74
+ ],
75
+ textStyles: [
76
+ {
77
+ "font-weight": "bold",
78
+ "text-anchor": "middle",
79
+ "pointer-events": "none",
80
+ "dominant-baseline": "middle",
81
+ "font-size": 64,
82
+ "fill": "#000"
83
+ }
84
+ ]
85
+ }
86
+ DEFAULT_PIE_EVENT_TEXTS_PARAMS.renderFn.toString = () => `(eventData) => {
87
+ if (eventData.eventName === 'mouseover' || eventData.eventName === 'mousemove') {
88
+ return [String(eventData.datum.value)]
89
+ }
90
+ return [
91
+ String(
92
+ Math.round(
93
+ eventData.data.reduce((acc, seriesData) => {
94
+ return acc + seriesData.reduce((_acc, data) => {
95
+ return _acc + (data.value ?? 0)
96
+ }, 0)
97
+ }, 0) * (eventData.tween ?? 1)
98
+ )
99
+ )
100
+ ]
101
+ }`
102
+
103
+ export const DEFAULT_PIE_LABELS_PARAMS: PieLabelsParams = {
104
+ // solidColor: undefined,
105
+ // colors: DEFAULT_COLORS,
106
+ outerRadius: 0.85,
107
+ outerRadiusWhileHighlight: 0.9,
108
+ // innerRadius: 0,
109
+ // enterDuration: 800,
110
+ startAngle: 0,
111
+ endAngle: Math.PI * 2,
112
+ labelCentroid: 2.1,
113
+ // fontSize: 12,
114
+ labelColorType: 'primary',
115
+ labelFn: d => String(d.label),
116
+ }
117
+ DEFAULT_PIE_LABELS_PARAMS.labelFn.toString = () => `d => String(d.label)`
118
+
119
+ export const DEFAULT_ROSE_PARAMS: RoseParams = {
120
+ outerRadius: 0.85,
121
+ padAngle: 0,
122
+ strokeColorType: 'background',
123
+ strokeWidth: 0,
124
+ cornerRadius: 0,
125
+ arcScaleType: 'area',
126
+ angleIncreaseWhileHighlight: 0.05
127
+ }
128
+
129
+ export const DEFAULT_ROSE_LABELS_PARAMS: RoseLabelsParams = {
130
+ outerRadius: 0.85,
131
+ labelCentroid: 2.1,
132
+ labelFn: d => String(d.label),
133
+ labelColorType: 'primary',
134
+ arcScaleType: 'area'
135
+ }
136
+ DEFAULT_ROSE_LABELS_PARAMS.labelFn.toString = () => `d => String(d.label)`
137
+
138
+ export const DEFAULT_SERIES_LEGEND_PARAMS: SeriesLegendParams = {
139
+ // position: 'right',
140
+ // justify: 'end',
141
+ placement: 'right-end',
142
+ padding: 28,
143
+ // offset: [0, 0],
144
+ backgroundFill: 'none',
145
+ backgroundStroke: 'none',
146
+ gap: 10,
147
+ listRectWidth: 14,
148
+ listRectHeight: 14,
149
+ listRectRadius: 0,
150
+ // highlightEvent: false
151
+ textColorType: 'primary'
152
+ }
153
+
154
+ export const DEFAULT_SERIES_TOOLTIP_PARAMS: SeriesTooltipParams = {
155
+ backgroundColorType: 'background',
156
+ strokeColorType: 'primary',
157
+ backgroundOpacity: 0.8,
158
+ textColorType: 'primary',
159
+ offset: [20, 5],
160
+ padding: 10,
161
+ renderFn: (eventData, { styles, utils }) => {
162
+ const hasSeriesLabel = eventData.seriesLabel.slice(0, 7) === 'series_' ? false : true
163
+ const hasDatumLabel = eventData.datum.label.slice(0, 7) === 'series_' ? false : true
164
+ const bulletWidth = styles.textSizePx * 0.7
165
+ const offset = (styles.textSizePx / 2) - (bulletWidth / 2)
166
+ const seriesSvg = hasSeriesLabel
167
+ ? `<rect width="${bulletWidth}" height="${bulletWidth}" x="${offset}" y="${offset - 1}" rx="${bulletWidth / 2}" fill="${eventData.datum.color}"></rect>
168
+ <text x="${styles.textSizePx * 1.5}" font-size="${styles.textSizePx}" dominant-baseline="hanging" fill="${styles.textColor}">
169
+ <tspan>${eventData.seriesLabel}</tspan>
170
+ </text>`
171
+ : ''
172
+ const datumLabelSvg = hasDatumLabel
173
+ ? `<tspan>${eventData.datum.label}</tspan> `
174
+ : ''
175
+ const datumSvg = `<text font-size="${styles.textSizePx}" dominant-baseline="hanging" fill="${styles.textColor}">
176
+ ${datumLabelSvg}<tspan font-weight="bold">${eventData.datum.value}</tspan>
177
+ </text>`
178
+
179
+ return `${seriesSvg}
180
+ <g ${hasSeriesLabel ? `transform="translate(0, ${styles.textSizePx * 2})"` : ''}>
181
+ ${datumSvg}
182
+ </g>`
183
+ },
184
+ }
185
+ DEFAULT_SERIES_TOOLTIP_PARAMS.renderFn.toString = () => `(eventData, { styles, utils }) => {
186
+ const hasSeriesLabel = eventData.seriesLabel.slice(0, 7) === 'series_' ? false : true
187
+ const hasDatumLabel = eventData.datum.label.slice(0, 7) === 'series_' ? false : true
188
+ const bulletWidth = styles.textSizePx * 0.7
189
+ const offset = (styles.textSizePx / 2) - (bulletWidth / 2)
190
+ const seriesSvg = hasSeriesLabel
191
+ ? \`<rect width="\${bulletWidth}" height="\${bulletWidth}" x="\${offset}" y="\${offset - 1}" rx="\${bulletWidth / 2}" fill="\${eventData.datum.color}"></rect>
192
+ <text x="\${styles.textSizePx * 1.5}" font-size="\${styles.textSizePx}" dominant-baseline="hanging" fill="\${styles.textColor}">
193
+ <tspan>\${eventData.seriesLabel}</tspan>
194
+ </text>\`
195
+ : ''
196
+ const datumLabelSvg = hasDatumLabel
197
+ ? \`<tspan>\${eventData.datum.label}</tspan> \`
198
+ : ''
199
+ const datumSvg = \`<text font-size="\${styles.textSizePx}" dominant-baseline="hanging" fill="\${styles.textColor}">
200
+ \${datumLabelSvg}<tspan font-weight="bold">\${eventData.datum.value}</tspan>
201
+ </text>\`
202
+
203
+ return \`\${seriesSvg}
204
+ <g \${hasSeriesLabel ? \`transform="translate(0, \${styles.textSizePx * 2})"\` : ''}>
205
+ \${datumSvg}
206
+ </g>\`
207
207
  }`
@@ -1,10 +1,10 @@
1
- export * from './defaults'
2
- // export * from './types'
3
- export { Bubbles } from './plugins/Bubbles'
4
- export { Pie } from './plugins/Pie'
5
- export { PieEventTexts } from './plugins/PieEventTexts'
6
- export { PieLabels } from './plugins/PieLabels'
7
- export { Rose } from './plugins/Rose'
8
- export { RoseLabels } from './plugins/RoseLabels'
9
- export { SeriesLegend } from './plugins/SeriesLegend'
1
+ export * from './defaults'
2
+ // export * from './types'
3
+ export { Bubbles } from './plugins/Bubbles'
4
+ export { Pie } from './plugins/Pie'
5
+ export { PieEventTexts } from './plugins/PieEventTexts'
6
+ export { PieLabels } from './plugins/PieLabels'
7
+ export { Rose } from './plugins/Rose'
8
+ export { RoseLabels } from './plugins/RoseLabels'
9
+ export { SeriesLegend } from './plugins/SeriesLegend'
10
10
  export { SeriesTooltip } from './plugins/SeriesTooltip'