@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
@@ -1,159 +1,159 @@
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
- defineMultiGridPlugin, mergeOptionsWithDefault } from '../../../lib/core'
12
- import { DEFAULT_MULTI_GRID_LEGEND_PARAMS } from '../defaults'
13
- import { createBaseLegend } from '../../base/BaseLegend'
14
- import type { BaseLegendParams } from '../../../lib/plugins-basic-types'
15
- import { LAYER_INDEX_OF_INFO } from '../../const'
16
-
17
- const pluginName = 'MultiGridLegend'
18
-
19
- const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_GRID_LEGEND_PARAMS> = {
20
- name: pluginName,
21
- defaultParams: DEFAULT_MULTI_GRID_LEGEND_PARAMS,
22
- layerIndex: LAYER_INDEX_OF_INFO,
23
- validator: (params, { validateColumns }) => {
24
- const result = validateColumns(params, {
25
- placement: {
26
- toBe: '"top" | "top-start" | "top-end" | "bottom" | "bottom-start" | "bottom-end" | "left" | "left-start" | "left-end" | "right" | "right-start" | "right-end"',
27
- test: (value) => {
28
- return [
29
- 'top', 'top-start', 'top-end',
30
- 'bottom', 'bottom-start', 'bottom-end',
31
- 'left', 'left-start', 'left-end',
32
- 'right', 'right-start', 'right-end'
33
- ].includes(value)
34
- }
35
- },
36
- padding: {
37
- toBeTypes: ['number']
38
- },
39
- backgroundFill: {
40
- toBeOption: 'ColorType',
41
- },
42
- backgroundStroke: {
43
- toBeOption: 'ColorType',
44
- },
45
- gap: {
46
- toBeTypes: ['number']
47
- },
48
- listRectWidth: {
49
- toBeTypes: ['number']
50
- },
51
- listRectHeight: {
52
- toBeTypes: ['number']
53
- },
54
- listRectRadius: {
55
- toBeTypes: ['number']
56
- },
57
- gridList: {
58
- toBeTypes: ['object[]']
59
- },
60
- textColorType: {
61
- toBeOption: 'ColorType',
62
- }
63
- })
64
- if (params.gridList) {
65
- const gridListResult = params.gridList.map((grid, gridIndex) => {
66
- return validateColumns(grid, {
67
- listRectWidth: {
68
- toBeTypes: ['number']
69
- },
70
- listRectHeight: {
71
- toBeTypes: ['number']
72
- },
73
- listRectRadius: {
74
- toBeTypes: ['number']
75
- }
76
- })
77
- })
78
- const errorResult = gridListResult.find(r => r.status === 'error')
79
- if (errorResult) {
80
- return errorResult
81
- }
82
- }
83
- return result
84
- }
85
- }
86
-
87
- export const MultiGridLegend = defineMultiGridPlugin(pluginConfig)(({ selection, rootSelection, observer, subject }) => {
88
-
89
- const destroy$ = new Subject()
90
-
91
- const seriesLabels$ = observer.multiGridEachDetail$.pipe(
92
- takeUntil(destroy$),
93
- map(multiGrid => {
94
- const seriesLabelsObservableArr = multiGrid.map((grid, gridIndex) => {
95
- return grid.SeriesDataMap$.pipe(
96
- // grid內的seriesLabels
97
- map(seriesDataMap => Array.from(seriesDataMap.keys()))
98
- )
99
- })
100
- return seriesLabelsObservableArr
101
- }),
102
- switchMap(seriesLabelsObservableArr => combineLatest(seriesLabelsObservableArr)),
103
- map(data => data.flat())
104
- )
105
-
106
- const seriesList$ = combineLatest({
107
- fullParams: observer.fullParams$,
108
- // multiGrid: observer.multiGridEachDetail$,
109
- computedData: observer.computedData$,
110
- }).pipe(
111
- takeUntil(destroy$),
112
- switchMap(async d => d),
113
- map(data => {
114
- // grid
115
- return data.computedData
116
- .map((gridData, gridIndex) => {
117
- // 這個grid全部series要套用的圖例列點樣式
118
- const gridListStyle = mergeOptionsWithDefault(data.fullParams.gridList[gridIndex] ?? {}, {
119
- listRectWidth: data.fullParams.listRectWidth,
120
- listRectHeight: data.fullParams.listRectHeight,
121
- listRectRadius: data.fullParams.listRectRadius,
122
- })
123
- // series
124
- return gridData.map(d => gridListStyle)
125
- })
126
- .flat()
127
-
128
- })
129
- )
130
-
131
- const fullParams$: Observable<BaseLegendParams> = combineLatest({
132
- fullParams: observer.fullParams$,
133
- seriesList: seriesList$
134
- }).pipe(
135
- takeUntil(destroy$),
136
- switchMap(async d => d),
137
- map(d => {
138
- return {
139
- ...d.fullParams,
140
- labelList: d.seriesList
141
- }
142
- })
143
- )
144
-
145
- const unsubscribeBaseLegend = createBaseLegend(pluginName, {
146
- rootSelection,
147
- legendLabels$: seriesLabels$,
148
- fullParams$,
149
- layout$: observer.layout$,
150
- fullChartParams$: observer.fullChartParams$,
151
- textSizePx$: observer.textSizePx$
152
- })
153
-
154
- return () => {
155
- destroy$.next(undefined)
156
- unsubscribeBaseLegend()
157
- }
158
- })
159
-
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
+ defineMultiGridPlugin, mergeOptionsWithDefault } from '../../../lib/core'
12
+ import { DEFAULT_MULTI_GRID_LEGEND_PARAMS } from '../defaults'
13
+ import { createBaseLegend } from '../../base/BaseLegend'
14
+ import type { BaseLegendParams } from '../../../lib/plugins-basic-types'
15
+ import { LAYER_INDEX_OF_INFO } from '../../const'
16
+
17
+ const pluginName = 'MultiGridLegend'
18
+
19
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_GRID_LEGEND_PARAMS> = {
20
+ name: pluginName,
21
+ defaultParams: DEFAULT_MULTI_GRID_LEGEND_PARAMS,
22
+ layerIndex: LAYER_INDEX_OF_INFO,
23
+ validator: (params, { validateColumns }) => {
24
+ const result = validateColumns(params, {
25
+ placement: {
26
+ toBe: '"top" | "top-start" | "top-end" | "bottom" | "bottom-start" | "bottom-end" | "left" | "left-start" | "left-end" | "right" | "right-start" | "right-end"',
27
+ test: (value) => {
28
+ return [
29
+ 'top', 'top-start', 'top-end',
30
+ 'bottom', 'bottom-start', 'bottom-end',
31
+ 'left', 'left-start', 'left-end',
32
+ 'right', 'right-start', 'right-end'
33
+ ].includes(value)
34
+ }
35
+ },
36
+ padding: {
37
+ toBeTypes: ['number']
38
+ },
39
+ backgroundFill: {
40
+ toBeOption: 'ColorType',
41
+ },
42
+ backgroundStroke: {
43
+ toBeOption: 'ColorType',
44
+ },
45
+ gap: {
46
+ toBeTypes: ['number']
47
+ },
48
+ listRectWidth: {
49
+ toBeTypes: ['number']
50
+ },
51
+ listRectHeight: {
52
+ toBeTypes: ['number']
53
+ },
54
+ listRectRadius: {
55
+ toBeTypes: ['number']
56
+ },
57
+ gridList: {
58
+ toBeTypes: ['object[]']
59
+ },
60
+ textColorType: {
61
+ toBeOption: 'ColorType',
62
+ }
63
+ })
64
+ if (params.gridList) {
65
+ const gridListResult = params.gridList.map((grid, gridIndex) => {
66
+ return validateColumns(grid, {
67
+ listRectWidth: {
68
+ toBeTypes: ['number']
69
+ },
70
+ listRectHeight: {
71
+ toBeTypes: ['number']
72
+ },
73
+ listRectRadius: {
74
+ toBeTypes: ['number']
75
+ }
76
+ })
77
+ })
78
+ const errorResult = gridListResult.find(r => r.status === 'error')
79
+ if (errorResult) {
80
+ return errorResult
81
+ }
82
+ }
83
+ return result
84
+ }
85
+ }
86
+
87
+ export const MultiGridLegend = defineMultiGridPlugin(pluginConfig)(({ selection, rootSelection, observer, subject }) => {
88
+
89
+ const destroy$ = new Subject()
90
+
91
+ const seriesLabels$ = observer.multiGridEachDetail$.pipe(
92
+ takeUntil(destroy$),
93
+ map(multiGrid => {
94
+ const seriesLabelsObservableArr = multiGrid.map((grid, gridIndex) => {
95
+ return grid.SeriesDataMap$.pipe(
96
+ // grid內的seriesLabels
97
+ map(seriesDataMap => Array.from(seriesDataMap.keys()))
98
+ )
99
+ })
100
+ return seriesLabelsObservableArr
101
+ }),
102
+ switchMap(seriesLabelsObservableArr => combineLatest(seriesLabelsObservableArr)),
103
+ map(data => data.flat())
104
+ )
105
+
106
+ const seriesList$ = combineLatest({
107
+ fullParams: observer.fullParams$,
108
+ // multiGrid: observer.multiGridEachDetail$,
109
+ computedData: observer.computedData$,
110
+ }).pipe(
111
+ takeUntil(destroy$),
112
+ switchMap(async d => d),
113
+ map(data => {
114
+ // grid
115
+ return data.computedData
116
+ .map((gridData, gridIndex) => {
117
+ // 這個grid全部series要套用的圖例列點樣式
118
+ const gridListStyle = mergeOptionsWithDefault(data.fullParams.gridList[gridIndex] ?? {}, {
119
+ listRectWidth: data.fullParams.listRectWidth,
120
+ listRectHeight: data.fullParams.listRectHeight,
121
+ listRectRadius: data.fullParams.listRectRadius,
122
+ })
123
+ // series
124
+ return gridData.map(d => gridListStyle)
125
+ })
126
+ .flat()
127
+
128
+ })
129
+ )
130
+
131
+ const fullParams$: Observable<BaseLegendParams> = combineLatest({
132
+ fullParams: observer.fullParams$,
133
+ seriesList: seriesList$
134
+ }).pipe(
135
+ takeUntil(destroy$),
136
+ switchMap(async d => d),
137
+ map(d => {
138
+ return {
139
+ ...d.fullParams,
140
+ labelList: d.seriesList
141
+ }
142
+ })
143
+ )
144
+
145
+ const unsubscribeBaseLegend = createBaseLegend(pluginName, {
146
+ rootSelection,
147
+ legendLabels$: seriesLabels$,
148
+ fullParams$,
149
+ layout$: observer.layout$,
150
+ fullChartParams$: observer.fullChartParams$,
151
+ textSizePx$: observer.textSizePx$
152
+ })
153
+
154
+ return () => {
155
+ destroy$.next(undefined)
156
+ unsubscribeBaseLegend()
157
+ }
158
+ })
159
+
@@ -1,66 +1,66 @@
1
- import {
2
- Subject,
3
- } from 'rxjs'
4
- import type { DefinePluginConfig } from '../../../lib/core-types'
5
- import {
6
- defineMultiGridPlugin } from '../../../lib/core'
7
- import { DEFAULT_MULTI_GRID_TOOLTIP_PARAMS } from '../defaults'
8
- import { LAYER_INDEX_OF_TOOLTIP } from '../../const'
9
- import { createBaseTooltip } from '../../base/BaseTooltip'
10
-
11
- const pluginName = 'MultiGridTooltip'
12
-
13
- const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_GRID_TOOLTIP_PARAMS> = {
14
- name: pluginName,
15
- defaultParams: DEFAULT_MULTI_GRID_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 MultiGridTooltip = defineMultiGridPlugin(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
- })
1
+ import {
2
+ Subject,
3
+ } from 'rxjs'
4
+ import type { DefinePluginConfig } from '../../../lib/core-types'
5
+ import {
6
+ defineMultiGridPlugin } from '../../../lib/core'
7
+ import { DEFAULT_MULTI_GRID_TOOLTIP_PARAMS } from '../defaults'
8
+ import { LAYER_INDEX_OF_TOOLTIP } from '../../const'
9
+ import { createBaseTooltip } from '../../base/BaseTooltip'
10
+
11
+ const pluginName = 'MultiGridTooltip'
12
+
13
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_GRID_TOOLTIP_PARAMS> = {
14
+ name: pluginName,
15
+ defaultParams: DEFAULT_MULTI_GRID_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 MultiGridTooltip = defineMultiGridPlugin(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
+ })