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

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 (126) hide show
  1. package/LICENSE +200 -200
  2. package/dist/orbcharts-plugins-basic/src/base/{BaseBarStack.d.ts → BaseStackedBar.d.ts} +4 -4
  3. package/dist/orbcharts-plugins-basic/src/grid/defaults.d.ts +3 -3
  4. package/dist/orbcharts-plugins-basic/src/grid/index.d.ts +2 -2
  5. package/dist/orbcharts-plugins-basic/src/grid/plugins/StackedBar.d.ts +1 -0
  6. package/dist/orbcharts-plugins-basic/src/grid/plugins/StackedValueAxis.d.ts +1 -0
  7. package/dist/orbcharts-plugins-basic/src/index.d.ts +1 -0
  8. package/dist/orbcharts-plugins-basic/src/multiGrid/defaults.d.ts +4 -4
  9. package/dist/orbcharts-plugins-basic/src/multiGrid/index.d.ts +3 -3
  10. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiStackedBar.d.ts +1 -0
  11. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiStackedValueAxis.d.ts +1 -0
  12. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/OverlappingStackedValueAxes.d.ts +1 -0
  13. package/dist/orbcharts-plugins-basic/src/noneData/plugins/Container.d.ts +0 -1
  14. package/dist/orbcharts-plugins-basic/src/noneData/plugins/Tooltip.d.ts +0 -3
  15. package/dist/orbcharts-plugins-basic/src/relationship/defaults.d.ts +5 -0
  16. package/dist/orbcharts-plugins-basic/src/relationship/index.d.ts +4 -0
  17. package/dist/orbcharts-plugins-basic/src/relationship/plugins/ForceDirected.d.ts +3 -0
  18. package/dist/orbcharts-plugins-basic/src/relationship/plugins/RelationshipLegend.d.ts +1 -0
  19. package/dist/orbcharts-plugins-basic/src/relationship/plugins/RelationshipTooltip.d.ts +1 -0
  20. package/dist/orbcharts-plugins-basic/src/relationship/relationshipObservables.d.ts +1 -0
  21. package/dist/orbcharts-plugins-basic/src/utils/commonUtils.d.ts +1 -1
  22. package/dist/orbcharts-plugins-basic/src/utils/orbchartsUtils.d.ts +1 -1
  23. package/dist/orbcharts-plugins-basic.es.js +8122 -7467
  24. package/dist/orbcharts-plugins-basic.umd.js +45 -32
  25. package/lib/core-types.ts +7 -7
  26. package/lib/core.ts +6 -6
  27. package/lib/plugins-basic-types.ts +6 -6
  28. package/package.json +44 -44
  29. package/src/base/BaseBars.ts +765 -765
  30. package/src/base/BaseBarsTriangle.ts +676 -676
  31. package/src/base/BaseDots.ts +464 -464
  32. package/src/base/BaseGroupAxis.ts +679 -679
  33. package/src/base/BaseLegend.ts +684 -684
  34. package/src/base/BaseLineAreas.ts +629 -629
  35. package/src/base/BaseLines.ts +706 -706
  36. package/src/base/{BaseBarStack.ts → BaseStackedBar.ts} +782 -782
  37. package/src/base/BaseTooltip.ts +385 -385
  38. package/src/base/BaseValueAxis.ts +583 -583
  39. package/src/base/types.ts +2 -2
  40. package/src/const.ts +30 -30
  41. package/src/grid/defaults.ts +246 -246
  42. package/src/grid/gridObservables.ts +554 -554
  43. package/src/grid/index.ts +16 -16
  44. package/src/grid/plugins/Bars.ts +69 -69
  45. package/src/grid/plugins/BarsPN.ts +66 -66
  46. package/src/grid/plugins/BarsTriangle.ts +73 -73
  47. package/src/grid/plugins/Dots.ts +68 -68
  48. package/src/grid/plugins/GridLegend.ts +107 -107
  49. package/src/grid/plugins/GridTooltip.ts +66 -66
  50. package/src/grid/plugins/GridZoom.ts +218 -218
  51. package/src/grid/plugins/GroupAux.ts +1103 -1103
  52. package/src/grid/plugins/GroupAxis.ts +97 -97
  53. package/src/grid/plugins/LineAreas.ts +65 -65
  54. package/src/grid/plugins/Lines.ts +59 -59
  55. package/src/grid/plugins/{BarStack.ts → StackedBar.ts} +64 -64
  56. package/src/grid/plugins/{ValueStackAxis.ts → StackedValueAxis.ts} +96 -96
  57. package/src/grid/plugins/ValueAxis.ts +94 -94
  58. package/src/index.ts +6 -10
  59. package/src/multiGrid/defaults.ts +224 -224
  60. package/src/multiGrid/index.ts +15 -15
  61. package/src/multiGrid/multiGridObservables.ts +49 -49
  62. package/src/multiGrid/plugins/MultiBars.ts +108 -108
  63. package/src/multiGrid/plugins/MultiBarsTriangle.ts +114 -114
  64. package/src/multiGrid/plugins/MultiDots.ts +102 -102
  65. package/src/multiGrid/plugins/MultiGridLegend.ts +159 -159
  66. package/src/multiGrid/plugins/MultiGridTooltip.ts +66 -66
  67. package/src/multiGrid/plugins/MultiGroupAxis.ts +137 -137
  68. package/src/multiGrid/plugins/MultiLineAreas.ts +107 -107
  69. package/src/multiGrid/plugins/MultiLines.ts +101 -101
  70. package/src/multiGrid/plugins/{MultiBarStack.ts → MultiStackedBar.ts} +106 -106
  71. package/src/multiGrid/plugins/{MultiValueStackAxis.ts → MultiStackedValueAxis.ts} +134 -134
  72. package/src/multiGrid/plugins/MultiValueAxis.ts +134 -134
  73. package/src/multiGrid/plugins/{OverlappingValueStackAxes.ts → OverlappingStackedValueAxes.ts} +299 -299
  74. package/src/multiGrid/plugins/OverlappingValueAxes.ts +300 -300
  75. package/src/multiValue/defaults.ts +166 -166
  76. package/src/multiValue/index.ts +8 -8
  77. package/src/multiValue/multiValueObservables.ts +297 -297
  78. package/src/multiValue/plugins/MultiValueLegend.ts +107 -107
  79. package/src/multiValue/plugins/MultiValueTooltip.ts +66 -66
  80. package/src/multiValue/plugins/Scatter.ts +426 -426
  81. package/src/multiValue/plugins/ScatterBubbles.ts +554 -554
  82. package/src/multiValue/plugins/XYAux.ts +681 -681
  83. package/src/multiValue/plugins/XYAxes.ts +684 -684
  84. package/src/multiValue/plugins/XYZoom.ts +299 -299
  85. package/src/noneData/defaults.ts +102 -102
  86. package/src/noneData/index.ts +3 -3
  87. package/src/noneData/plugins/Container.ts +28 -28
  88. package/src/noneData/plugins/Tooltip.ts +374 -374
  89. package/src/relationship/defaults.ts +113 -0
  90. package/src/relationship/index.ts +4 -0
  91. package/src/relationship/plugins/ForceDirected.ts +1148 -0
  92. package/src/relationship/plugins/RelationshipLegend.ts +100 -0
  93. package/src/relationship/plugins/RelationshipTooltip.ts +66 -0
  94. package/src/relationship/relationshipObservables.ts +50 -0
  95. package/src/series/defaults.ts +206 -206
  96. package/src/series/index.ts +9 -9
  97. package/src/series/plugins/Bubbles.ts +604 -603
  98. package/src/series/plugins/Pie.ts +623 -623
  99. package/src/series/plugins/PieEventTexts.ts +284 -283
  100. package/src/series/plugins/PieLabels.ts +640 -640
  101. package/src/series/plugins/Rose.ts +516 -516
  102. package/src/series/plugins/RoseLabels.ts +600 -600
  103. package/src/series/plugins/SeriesLegend.ts +107 -107
  104. package/src/series/plugins/SeriesTooltip.ts +66 -66
  105. package/src/series/seriesObservables.ts +145 -145
  106. package/src/series/seriesUtils.ts +51 -51
  107. package/src/tree/defaults.ts +78 -78
  108. package/src/tree/index.ts +4 -4
  109. package/src/tree/plugins/TreeLegend.ts +100 -100
  110. package/src/tree/plugins/TreeMap.ts +333 -333
  111. package/src/tree/plugins/TreeTooltip.ts +66 -66
  112. package/src/utils/commonUtils.ts +21 -21
  113. package/src/utils/d3Graphics.ts +174 -174
  114. package/src/utils/d3Utils.ts +74 -74
  115. package/src/utils/observables.ts +14 -14
  116. package/src/utils/orbchartsUtils.ts +115 -115
  117. package/tsconfig.base.json +13 -13
  118. package/tsconfig.json +2 -2
  119. package/vite.config.js +22 -22
  120. package/dist/orbcharts-plugins-basic/src/grid/plugins/BarStack.d.ts +0 -1
  121. package/dist/orbcharts-plugins-basic/src/grid/plugins/ValueStackAxis.d.ts +0 -1
  122. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiBarStack.d.ts +0 -1
  123. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiValueStackAxis.d.ts +0 -1
  124. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/OverlappingValueStackAxes.d.ts +0 -1
  125. /package/dist/orbcharts-plugins-basic/src/relationship/plugins/{Relationship.d.ts → ForceDirectedBubbles.d.ts} +0 -0
  126. /package/src/relationship/plugins/{Relationship.ts → ForceDirectedBubbles.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: 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
+ 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'