@orbcharts/plugins-basic 3.0.0-alpha.45 → 3.0.0-alpha.47

Sign up to get free protection for your applications and to get access to all the features.
Files changed (153) hide show
  1. package/LICENSE +200 -200
  2. package/dist/orbcharts-plugins-basic.es.js +826 -791
  3. package/dist/orbcharts-plugins-basic.umd.js +7 -7
  4. package/dist/src/index.d.ts +5 -1
  5. package/dist/{orbcharts-plugins-basic/src → src}/series/seriesObservables.d.ts +4 -4
  6. package/package.json +42 -42
  7. package/src/base/BaseBarStack.ts +778 -778
  8. package/src/base/BaseBars.ts +764 -764
  9. package/src/base/BaseBarsTriangle.ts +672 -672
  10. package/src/base/BaseDots.ts +502 -502
  11. package/src/base/BaseGroupAxis.ts +496 -496
  12. package/src/base/BaseLegend.ts +641 -641
  13. package/src/base/BaseLineAreas.ts +625 -625
  14. package/src/base/BaseLines.ts +699 -699
  15. package/src/base/BaseValueAxis.ts +478 -478
  16. package/src/base/types.ts +2 -2
  17. package/src/grid/defaults.ts +121 -121
  18. package/src/grid/gridObservables.ts +247 -247
  19. package/src/grid/index.ts +15 -15
  20. package/src/grid/plugins/BarStack.ts +50 -50
  21. package/src/grid/plugins/Bars.ts +51 -51
  22. package/src/grid/plugins/BarsDiverging.ts +41 -41
  23. package/src/grid/plugins/BarsTriangle.ts +50 -50
  24. package/src/grid/plugins/Dots.ts +37 -37
  25. package/src/grid/plugins/GridLegend.ts +59 -59
  26. package/src/grid/plugins/GroupAux.ts +645 -645
  27. package/src/grid/plugins/GroupAxis.ts +42 -42
  28. package/src/grid/plugins/LineAreas.ts +39 -39
  29. package/src/grid/plugins/Lines.ts +38 -38
  30. package/src/grid/plugins/ScalingArea.ts +173 -173
  31. package/src/grid/plugins/ValueAxis.ts +43 -43
  32. package/src/grid/plugins/ValueStackAxis.ts +79 -79
  33. package/src/grid/types.ts +120 -120
  34. package/src/index.ts +9 -9
  35. package/src/multiGrid/defaults.ts +147 -147
  36. package/src/multiGrid/index.ts +11 -11
  37. package/src/multiGrid/multiGridObservables.ts +42 -42
  38. package/src/multiGrid/plugins/MultiBarStack.ts +78 -74
  39. package/src/multiGrid/plugins/MultiBars.ts +77 -73
  40. package/src/multiGrid/plugins/MultiBarsTriangle.ts +77 -73
  41. package/src/multiGrid/plugins/MultiDots.ts +65 -60
  42. package/src/multiGrid/plugins/MultiGridLegend.ts +89 -89
  43. package/src/multiGrid/plugins/MultiGroupAxis.ts +69 -65
  44. package/src/multiGrid/plugins/MultiLineAreas.ts +67 -62
  45. package/src/multiGrid/plugins/MultiLines.ts +66 -61
  46. package/src/multiGrid/plugins/MultiValueAxis.ts +69 -65
  47. package/src/multiGrid/plugins/OverlappingValueAxes.ts +173 -169
  48. package/src/multiGrid/types.ts +67 -67
  49. package/src/noneData/defaults.ts +64 -64
  50. package/src/noneData/index.ts +3 -3
  51. package/src/noneData/plugins/Container.ts +10 -10
  52. package/src/noneData/plugins/Tooltip.ts +310 -310
  53. package/src/noneData/types.ts +26 -26
  54. package/src/series/defaults.ts +109 -109
  55. package/src/series/index.ts +6 -6
  56. package/src/series/plugins/Bubbles.ts +602 -571
  57. package/src/series/plugins/Pie.ts +563 -548
  58. package/src/series/plugins/PieEventTexts.ts +262 -258
  59. package/src/series/plugins/PieLabels.ts +339 -335
  60. package/src/series/plugins/SeriesLegend.ts +59 -59
  61. package/src/series/seriesObservables.ts +145 -145
  62. package/src/series/seriesUtils.ts +50 -50
  63. package/src/series/types.ts +67 -67
  64. package/src/tree/defaults.ts +22 -22
  65. package/src/tree/index.ts +3 -3
  66. package/src/tree/plugins/TreeLegend.ts +59 -59
  67. package/src/tree/plugins/TreeMap.ts +305 -305
  68. package/src/tree/types.ts +23 -23
  69. package/src/utils/commonUtils.ts +21 -21
  70. package/src/utils/d3Graphics.ts +124 -124
  71. package/src/utils/d3Utils.ts +73 -73
  72. package/src/utils/observables.ts +14 -14
  73. package/src/utils/orbchartsUtils.ts +100 -100
  74. package/tsconfig.dev.json +16 -16
  75. package/tsconfig.json +13 -16
  76. package/tsconfig.prod.json +13 -13
  77. package/vite.config.js +49 -49
  78. package/dist/orbcharts-plugins-basic/src/index.d.ts +0 -5
  79. /package/dist/{orbcharts-plugins-basic/src → src}/base/BaseBarStack.d.ts +0 -0
  80. /package/dist/{orbcharts-plugins-basic/src → src}/base/BaseBars.d.ts +0 -0
  81. /package/dist/{orbcharts-plugins-basic/src → src}/base/BaseBarsTriangle.d.ts +0 -0
  82. /package/dist/{orbcharts-plugins-basic/src → src}/base/BaseDots.d.ts +0 -0
  83. /package/dist/{orbcharts-plugins-basic/src → src}/base/BaseGroupArea.d.ts +0 -0
  84. /package/dist/{orbcharts-plugins-basic/src → src}/base/BaseGroupAxis.d.ts +0 -0
  85. /package/dist/{orbcharts-plugins-basic/src → src}/base/BaseLegend.d.ts +0 -0
  86. /package/dist/{orbcharts-plugins-basic/src → src}/base/BaseLineAreas.d.ts +0 -0
  87. /package/dist/{orbcharts-plugins-basic/src → src}/base/BaseLines.d.ts +0 -0
  88. /package/dist/{orbcharts-plugins-basic/src → src}/base/BaseValueAxis.d.ts +0 -0
  89. /package/dist/{orbcharts-plugins-basic/src → src}/base/types.d.ts +0 -0
  90. /package/dist/{orbcharts-plugins-basic/src → src}/grid/defaults.d.ts +0 -0
  91. /package/dist/{orbcharts-plugins-basic/src → src}/grid/gridObservables.d.ts +0 -0
  92. /package/dist/{orbcharts-plugins-basic/src → src}/grid/index.d.ts +0 -0
  93. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/BarStack.d.ts +0 -0
  94. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/Bars.d.ts +0 -0
  95. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/BarsDiverging.d.ts +0 -0
  96. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/BarsTriangle.d.ts +0 -0
  97. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/Dots.d.ts +0 -0
  98. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/GridLegend.d.ts +0 -0
  99. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/GroupAux.d.ts +0 -0
  100. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/GroupAxis.d.ts +0 -0
  101. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/LineAreas.d.ts +0 -0
  102. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/Lines.d.ts +0 -0
  103. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/Ranking.d.ts +0 -0
  104. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/RankingAxis.d.ts +0 -0
  105. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/ScalingArea.d.ts +0 -0
  106. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/ValueAxis.d.ts +0 -0
  107. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/ValueStackAxis.d.ts +0 -0
  108. /package/dist/{orbcharts-plugins-basic/src → src}/grid/types.d.ts +0 -0
  109. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/defaults.d.ts +0 -0
  110. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/index.d.ts +0 -0
  111. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/multiGridObservables.d.ts +0 -0
  112. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiBarStack.d.ts +0 -0
  113. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiBars.d.ts +0 -0
  114. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiBarsTriangle.d.ts +0 -0
  115. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiDots.d.ts +0 -0
  116. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiGridLegend.d.ts +0 -0
  117. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiGroupAxis.d.ts +0 -0
  118. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiLineAreas.d.ts +0 -0
  119. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiLines.d.ts +0 -0
  120. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiValueAxis.d.ts +0 -0
  121. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/OverlappingValueAxes.d.ts +0 -0
  122. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/types.d.ts +0 -0
  123. /package/dist/{orbcharts-plugins-basic/src → src}/multiValue/index.d.ts +0 -0
  124. /package/dist/{orbcharts-plugins-basic/src → src}/multiValue/plugins/Scatter.d.ts +0 -0
  125. /package/dist/{orbcharts-plugins-basic/src → src}/multiValue/plugins/ScatterAxes.d.ts +0 -0
  126. /package/dist/{orbcharts-plugins-basic/src → src}/noneData/defaults.d.ts +0 -0
  127. /package/dist/{orbcharts-plugins-basic/src → src}/noneData/index.d.ts +0 -0
  128. /package/dist/{orbcharts-plugins-basic/src → src}/noneData/plugins/Container.d.ts +0 -0
  129. /package/dist/{orbcharts-plugins-basic/src → src}/noneData/plugins/Tooltip.d.ts +0 -0
  130. /package/dist/{orbcharts-plugins-basic/src → src}/noneData/types.d.ts +0 -0
  131. /package/dist/{orbcharts-plugins-basic/src → src}/relationship/index.d.ts +0 -0
  132. /package/dist/{orbcharts-plugins-basic/src → src}/relationship/plugins/Relationship.d.ts +0 -0
  133. /package/dist/{orbcharts-plugins-basic/src → src}/series/defaults.d.ts +0 -0
  134. /package/dist/{orbcharts-plugins-basic/src → src}/series/index.d.ts +0 -0
  135. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/Bubbles.d.ts +0 -0
  136. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/Pie.d.ts +0 -0
  137. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/PieEventTexts.d.ts +0 -0
  138. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/PieLabels.d.ts +0 -0
  139. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/SeriesLegend.d.ts +0 -0
  140. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/Waffle.d.ts +0 -0
  141. /package/dist/{orbcharts-plugins-basic/src → src}/series/seriesUtils.d.ts +0 -0
  142. /package/dist/{orbcharts-plugins-basic/src → src}/series/types.d.ts +0 -0
  143. /package/dist/{orbcharts-plugins-basic/src → src}/tree/defaults.d.ts +0 -0
  144. /package/dist/{orbcharts-plugins-basic/src → src}/tree/index.d.ts +0 -0
  145. /package/dist/{orbcharts-plugins-basic/src → src}/tree/plugins/TreeLegend.d.ts +0 -0
  146. /package/dist/{orbcharts-plugins-basic/src → src}/tree/plugins/TreeMap.d.ts +0 -0
  147. /package/dist/{orbcharts-plugins-basic/src → src}/tree/types.d.ts +0 -0
  148. /package/dist/{orbcharts-plugins-basic/src → src}/utils/commonUtils.d.ts +0 -0
  149. /package/dist/{orbcharts-plugins-basic/src → src}/utils/d3Graphics.d.ts +0 -0
  150. /package/dist/{orbcharts-plugins-basic/src → src}/utils/d3Utils.d.ts +0 -0
  151. /package/dist/{orbcharts-plugins-basic/src → src}/utils/observables.d.ts +0 -0
  152. /package/dist/{orbcharts-plugins-basic/src → src}/utils/orbchartsUtils.d.ts +0 -0
  153. /package/dist/{orbcharts-plugins-basic/vite.config.d.ts → vite.config.d.ts} +0 -0
@@ -1,503 +1,503 @@
1
- import * as d3 from 'd3'
2
- import {
3
- combineLatest,
4
- map,
5
- switchMap,
6
- takeUntil,
7
- distinctUntilChanged,
8
- Observable,
9
- Subject } from 'rxjs'
10
- import type { BasePluginFn } from './types'
11
- import type {
12
- ComputedDatumGrid,
13
- ComputedDataGrid,
14
- ComputedLayoutDataGrid,
15
- EventGrid,
16
- ChartParams,
17
- GridContainerPosition,
18
- Layout,
19
- TransformData,
20
- ColorType } from '@orbcharts/core'
21
- import { getDatumColor, getClassName, getUniID } from '../utils/orbchartsUtils'
22
- import { gridSelectionsObservable } from '../grid/gridObservables'
23
-
24
- export interface BaseDotsParams {
25
- radius: number
26
- fillColorType: ColorType
27
- strokeColorType: ColorType
28
- strokeWidth: number
29
- onlyShowHighlighted: boolean
30
- }
31
-
32
- interface BaseDotsContext {
33
- selection: d3.Selection<any, unknown, any, unknown>
34
- computedData$: Observable<ComputedDataGrid>
35
- computedLayoutData$: Observable<ComputedLayoutDataGrid>
36
- visibleComputedData$: Observable<ComputedDatumGrid[][]>
37
- visibleComputedLayoutData$: Observable<ComputedLayoutDataGrid>
38
- seriesLabels$: Observable<string[]>
39
- SeriesDataMap$: Observable<Map<string, ComputedDatumGrid[]>>
40
- GroupDataMap$: Observable<Map<string, ComputedDatumGrid[]>>
41
- fullParams$: Observable<BaseDotsParams>
42
- fullChartParams$: Observable<ChartParams>
43
- gridAxesTransform$: Observable<TransformData>
44
- gridGraphicTransform$: Observable<TransformData>
45
- gridGraphicReverseScale$: Observable<[number, number][]>
46
- gridAxesSize$: Observable<{
47
- width: number;
48
- height: number;
49
- }>
50
- gridHighlight$: Observable<ComputedDatumGrid[]>
51
- gridContainerPosition$: Observable<GridContainerPosition[]>
52
- event$: Subject<EventGrid>
53
- }
54
-
55
-
56
- type ClipPathDatum = {
57
- id: string;
58
- // x: number;
59
- // y: number;
60
- width: number;
61
- height: number;
62
- }
63
-
64
- // const pluginName = 'Dots'
65
- // const circleGClassName = getClassName(pluginName, 'circleG')
66
- // const circleClassName = getClassName(pluginName, 'circle')
67
-
68
- function renderDots ({ graphicGSelection, circleGClassName, circleClassName, visibleComputedLayoutData, fullParams, fullChartParams, graphicReverseScale }: {
69
- graphicGSelection: d3.Selection<SVGGElement, any, any, any>
70
- circleGClassName: string
71
- circleClassName: string
72
- visibleComputedLayoutData: ComputedLayoutDataGrid
73
- fullParams: BaseDotsParams
74
- fullChartParams: ChartParams
75
- graphicReverseScale: [number, number][]
76
- }) {
77
- const createEnterDuration = (enter: d3.Selection<d3.EnterElement, ComputedDatumGrid, SVGGElement, any>) => {
78
- const enterSize = enter.size()
79
- const eachDuration = fullChartParams.transitionDuration / enterSize
80
- return eachDuration
81
- }
82
- // enterDuration
83
- let enterDuration = 0
84
-
85
- graphicGSelection
86
- .each((seriesData, seriesIndex, g) => {
87
- d3.select(g[seriesIndex])
88
- .selectAll<SVGGElement, ComputedDatumGrid>('g')
89
- .data(visibleComputedLayoutData[seriesIndex], d => d.id)
90
- .join(
91
- enter => {
92
- // enterDuration
93
- enterDuration = createEnterDuration(enter)
94
-
95
- return enter
96
- .append('g')
97
- .classed(circleGClassName, true)
98
- },
99
- update => update,
100
- exit => exit.remove()
101
- )
102
- .attr('transform', d => `translate(${d.axisX}, ${d.axisY})`)
103
- .each((d, i, g) => {
104
- const circle = d3.select(g[i])
105
- .selectAll('circle')
106
- .data([d])
107
- .join(
108
- enter => {
109
- return enter
110
- .append('circle')
111
- .style('cursor', 'pointer')
112
- .style('vector-effect', 'non-scaling-stroke')
113
- .classed(circleClassName, true)
114
- .attr('opacity', 0)
115
- .transition()
116
- .delay((_d, _i) => {
117
- return i * enterDuration
118
- })
119
- .attr('opacity', 1)
120
- },
121
- update => {
122
- return update
123
- .transition()
124
- .duration(50)
125
- // .attr('cx', d => d.axisX)
126
- // .attr('cy', d => d.axisY)
127
- .attr('opacity', 1)
128
- },
129
- exit => exit.remove()
130
- )
131
- .attr('r', fullParams.radius)
132
- .attr('fill', (d, i) => getDatumColor({ datum: d, colorType: fullParams.fillColorType, fullChartParams }))
133
- .attr('stroke', (d, i) => getDatumColor({ datum: d, colorType: fullParams.strokeColorType, fullChartParams }))
134
- .attr('stroke-width', fullParams.strokeWidth)
135
- .attr('transform', `scale(${graphicReverseScale[seriesIndex][0] ?? 1}, ${graphicReverseScale[seriesIndex][1] ?? 1})`)
136
- })
137
- })
138
-
139
- // const dots = graphicGSelection
140
- // .selectAll<SVGGElement, ComputedDatumGrid>('g')
141
- // .data(data, d => d.id)
142
- // .join(
143
- // enter => {
144
- // // enterDuration
145
- // enterDuration = createEnterDuration(enter)
146
-
147
- // return enter
148
- // .append('g')
149
- // .classed(circleGClassName, true)
150
- // },
151
- // update => update,
152
- // exit => exit.remove()
153
- // )
154
- // .attr('transform', d => `translate(${d.axisX}, ${d.axisY})`)
155
- // .each((d, i, g) => {
156
- // const circle = d3.select(g[i])
157
- // .selectAll('circle')
158
- // .data([d])
159
- // .join(
160
- // enter => {
161
- // return enter
162
- // .append('circle')
163
- // .style('cursor', 'pointer')
164
- // .style('vector-effect', 'non-scaling-stroke')
165
- // .classed(circleClassName, true)
166
- // .attr('opacity', 0)
167
- // .transition()
168
- // .delay((_d, _i) => {
169
- // return i * enterDuration
170
- // })
171
- // .attr('opacity', 1)
172
- // },
173
- // update => {
174
- // return update
175
- // .transition()
176
- // .duration(50)
177
- // // .attr('cx', d => d.axisX)
178
- // // .attr('cy', d => d.axisY)
179
- // .attr('opacity', 1)
180
- // },
181
- // exit => exit.remove()
182
- // )
183
- // .attr('r', fullParams.radius)
184
- // .attr('fill', (d, i) => getDatumColor({ datum: d, colorType: fullParams.fillColorType, fullChartParams }))
185
- // .attr('stroke', (d, i) => getDatumColor({ datum: d, colorType: fullParams.strokeColorType, fullChartParams }))
186
- // .attr('stroke-width', fullParams.strokeWidth)
187
- // .attr('transform', `scale(${graphicReverseScale[0]}, ${graphicReverseScale[1]})`)
188
- // })
189
-
190
- const graphicCircleSelection: d3.Selection<SVGRectElement, ComputedDatumGrid, SVGGElement, unknown> = graphicGSelection.selectAll(`circle.${circleClassName}`)
191
-
192
- return graphicCircleSelection
193
- }
194
-
195
-
196
- function highlightDots ({ selection, ids, onlyShowHighlighted, fullChartParams }: {
197
- selection: d3.Selection<SVGGElement, ComputedDatumGrid, any, any>
198
- ids: string[]
199
- onlyShowHighlighted: boolean
200
- fullChartParams: ChartParams
201
- }) {
202
- selection.interrupt('highlight')
203
- if (!ids.length) {
204
- // remove highlight
205
- selection
206
- .transition('highlight')
207
- .duration(200)
208
- .style('opacity', onlyShowHighlighted === true ? 0 : 1)
209
- return
210
- }
211
-
212
- selection
213
- .each((d, i, n) => {
214
- if (ids.includes(d.id)) {
215
- d3.select(n[i])
216
- .style('opacity', 1)
217
- .transition('highlight')
218
- .duration(200)
219
- } else {
220
- d3.select(n[i])
221
- .style('opacity', onlyShowHighlighted === true ? 0 : fullChartParams.styles.unhighlightedOpacity)
222
- .transition('highlight')
223
- .duration(200)
224
- }
225
- })
226
- }
227
-
228
- function renderClipPath ({ defsSelection, clipPathData }: {
229
- defsSelection: d3.Selection<SVGDefsElement, any, any, any>
230
- clipPathData: ClipPathDatum[]
231
- }) {
232
- const clipPath = defsSelection
233
- .selectAll<SVGClipPathElement, Layout>('clipPath')
234
- .data(clipPathData)
235
- .join(
236
- enter => {
237
- return enter
238
- .append('clipPath')
239
- },
240
- update => update,
241
- exit => exit.remove()
242
- )
243
- .attr('id', d => d.id)
244
- .each((d, i, g) => {
245
- const rect = d3.select(g[i])
246
- .selectAll<SVGRectElement, typeof d>('rect')
247
- .data([d])
248
- .join('rect')
249
- .attr('x', 0)
250
- .attr('y', 0)
251
- .attr('width', _d => _d.width)
252
- .attr('height', _d => _d.height)
253
- })
254
-
255
- }
256
-
257
-
258
-
259
- export const createBaseDots: BasePluginFn<BaseDotsContext> = (pluginName: string, {
260
- selection,
261
- computedData$,
262
- computedLayoutData$,
263
- visibleComputedData$,
264
- visibleComputedLayoutData$,
265
- seriesLabels$,
266
- SeriesDataMap$,
267
- GroupDataMap$,
268
- fullParams$,
269
- fullChartParams$,
270
- gridAxesTransform$,
271
- gridGraphicTransform$,
272
- gridGraphicReverseScale$,
273
- gridAxesSize$,
274
- gridHighlight$,
275
- gridContainerPosition$,
276
- event$
277
- }) => {
278
-
279
- const destroy$ = new Subject()
280
-
281
- const clipPathID = getUniID(pluginName, 'clipPath-box')
282
- const circleGClassName = getClassName(pluginName, 'circleG')
283
- const circleClassName = getClassName(pluginName, 'circle')
284
-
285
- // const axisSelection: d3.Selection<SVGGElement, any, any, any> = selection
286
- // .append('g')
287
- // .attr('clip-path', `url(#${clipPathID})`)
288
- // const defsSelection: d3.Selection<SVGDefsElement, any, any, any> = axisSelection.append('defs')
289
- // const dataAreaSelection: d3.Selection<SVGGElement, any, any, any> = axisSelection.append('g')
290
- // const graphicSelection$: Subject<d3.Selection<SVGGElement, ComputedDatumGrid, any, any>> = new Subject()
291
-
292
- const {
293
- seriesSelection$,
294
- axesSelection$,
295
- defsSelection$,
296
- graphicGSelection$
297
- } = gridSelectionsObservable({
298
- selection,
299
- pluginName,
300
- clipPathID,
301
- seriesLabels$,
302
- gridContainerPosition$,
303
- gridAxesTransform$,
304
- gridGraphicTransform$
305
- })
306
-
307
- const graphicReverseScale$: Observable<[number, number][]> = combineLatest({
308
- // gridGraphicTransform: gridGraphicTransform$,
309
- // gridContainerPosition: gridContainerPosition$,
310
- // gridAxesTransform: gridAxesTransform$
311
- computedData: computedData$,
312
- gridGraphicReverseScale: gridGraphicReverseScale$
313
- }).pipe(
314
- takeUntil(destroy$),
315
- switchMap(async data => data),
316
- map(data => {
317
- return data.computedData.map((series, seriesIndex) => {
318
- return data.gridGraphicReverseScale[seriesIndex]
319
- })
320
- })
321
- )
322
-
323
- const clipPathSubscription = combineLatest({
324
- defsSelection: defsSelection$,
325
- gridAxesSize: gridAxesSize$,
326
- }).pipe(
327
- takeUntil(destroy$),
328
- switchMap(async (d) => d),
329
- ).subscribe(data => {
330
- // 外層的遮罩
331
- const clipPathData = [{
332
- id: clipPathID,
333
- width: data.gridAxesSize.width,
334
- height: data.gridAxesSize.height
335
- }]
336
- renderClipPath({
337
- defsSelection: data.defsSelection,
338
- clipPathData,
339
- })
340
- })
341
-
342
- const highlightTarget$ = fullChartParams$.pipe(
343
- takeUntil(destroy$),
344
- map(d => d.highlightTarget),
345
- distinctUntilChanged()
346
- )
347
-
348
- const graphicSelection$ = combineLatest({
349
- graphicGSelection: graphicGSelection$,
350
- visibleComputedLayoutData: visibleComputedLayoutData$,
351
- graphicReverseScale: graphicReverseScale$,
352
- fullChartParams: fullChartParams$,
353
- fullParams: fullParams$,
354
- }).pipe(
355
- takeUntil(destroy$),
356
- switchMap(async (d) => d),
357
- map(data => {
358
- return renderDots({
359
- graphicGSelection: data.graphicGSelection,
360
- circleGClassName,
361
- circleClassName,
362
- visibleComputedLayoutData: data.visibleComputedLayoutData,
363
- fullParams: data.fullParams,
364
- fullChartParams: data.fullChartParams,
365
- graphicReverseScale: data.graphicReverseScale
366
- })
367
- })
368
- )
369
-
370
- combineLatest({
371
- graphicSelection: graphicSelection$,
372
- computedData: computedData$,
373
- SeriesDataMap: SeriesDataMap$,
374
- GroupDataMap: GroupDataMap$,
375
- highlightTarget: highlightTarget$
376
- }).pipe(
377
- takeUntil(destroy$),
378
- switchMap(async (d) => d),
379
- ).subscribe(data => {
380
-
381
- data.graphicSelection
382
- .on('mouseover', (event, datum) => {
383
- event.stopPropagation()
384
-
385
- event$.next({
386
- type: 'grid',
387
- eventName: 'mouseover',
388
- pluginName,
389
- highlightTarget: data.highlightTarget,
390
- datum,
391
- gridIndex: datum.gridIndex,
392
- series: data.SeriesDataMap.get(datum.seriesLabel)!,
393
- seriesIndex: datum.seriesIndex,
394
- seriesLabel: datum.seriesLabel,
395
- groups: data.GroupDataMap.get(datum.groupLabel)!,
396
- groupIndex: datum.groupIndex,
397
- groupLabel: datum.groupLabel,
398
- event,
399
- data: data.computedData
400
- })
401
- })
402
- .on('mousemove', (event, datum) => {
403
- event.stopPropagation()
404
-
405
- event$.next({
406
- type: 'grid',
407
- eventName: 'mousemove',
408
- pluginName,
409
- highlightTarget: data.highlightTarget,
410
- data: data.computedData,
411
- datum,
412
- gridIndex: datum.gridIndex,
413
- series: data.SeriesDataMap.get(datum.seriesLabel)!,
414
- seriesIndex: datum.seriesIndex,
415
- seriesLabel: datum.seriesLabel,
416
- groups: data.GroupDataMap.get(datum.groupLabel)!,
417
- groupIndex: datum.groupIndex,
418
- groupLabel: datum.groupLabel,
419
- event
420
- })
421
- })
422
- .on('mouseout', (event, datum) => {
423
- event.stopPropagation()
424
-
425
- event$.next({
426
- type: 'grid',
427
- eventName: 'mouseout',
428
- pluginName,
429
- highlightTarget: data.highlightTarget,
430
- datum,
431
- gridIndex: datum.gridIndex,
432
- series: data.SeriesDataMap.get(datum.seriesLabel)!,
433
- seriesIndex: datum.seriesIndex,
434
- seriesLabel: datum.seriesLabel,
435
- groups: data.GroupDataMap.get(datum.groupLabel)!,
436
- groupIndex: datum.groupIndex,
437
- groupLabel: datum.groupLabel,
438
- event,
439
- data: data.computedData
440
- })
441
- })
442
- .on('click', (event, datum) => {
443
- event.stopPropagation()
444
-
445
- event$.next({
446
- type: 'grid',
447
- eventName: 'click',
448
- pluginName,
449
- highlightTarget: data.highlightTarget,
450
- datum,
451
- gridIndex: datum.gridIndex,
452
- series: data.SeriesDataMap.get(datum.seriesLabel)!,
453
- seriesIndex: datum.seriesIndex,
454
- seriesLabel: datum.seriesLabel,
455
- groups: data.GroupDataMap.get(datum.groupLabel)!,
456
- groupIndex: datum.groupIndex,
457
- groupLabel: datum.groupLabel,
458
- event,
459
- data: data.computedData
460
- })
461
- })
462
-
463
- })
464
-
465
- // const datumList$ = computedData$.pipe(
466
- // takeUntil(destroy$),
467
- // map(d => d.flat())
468
- // )
469
- // const highlight$ = highlightObservable({ datumList$, fullChartParams$, event$: store.event$ })
470
- // const highlightSubscription = gridHighlight$.subscribe()
471
- const onlyShowHighlighted$ = fullParams$.pipe(
472
- takeUntil(destroy$),
473
- map(d => d.onlyShowHighlighted),
474
- distinctUntilChanged()
475
- )
476
-
477
- fullChartParams$.pipe(
478
- takeUntil(destroy$),
479
- switchMap(d => combineLatest({
480
- graphicSelection: graphicSelection$,
481
- highlight: gridHighlight$.pipe(
482
- map(data => data.map(d => d.id))
483
- ),
484
- onlyShowHighlighted: onlyShowHighlighted$,
485
- fullChartParams: fullChartParams$
486
- }).pipe(
487
- takeUntil(destroy$),
488
- switchMap(async d => d)
489
- ))
490
- ).subscribe(data => {
491
- highlightDots({
492
- selection: data.graphicSelection,
493
- ids: data.highlight,
494
- onlyShowHighlighted: data.onlyShowHighlighted,
495
- fullChartParams: data.fullChartParams
496
- })
497
- })
498
-
499
- return () => {
500
- destroy$.next(undefined)
501
- // highlightSubscription.unsubscribe()
502
- }
1
+ import * as d3 from 'd3'
2
+ import {
3
+ combineLatest,
4
+ map,
5
+ switchMap,
6
+ takeUntil,
7
+ distinctUntilChanged,
8
+ Observable,
9
+ Subject } from 'rxjs'
10
+ import type { BasePluginFn } from './types'
11
+ import type {
12
+ ComputedDatumGrid,
13
+ ComputedDataGrid,
14
+ ComputedLayoutDataGrid,
15
+ EventGrid,
16
+ ChartParams,
17
+ GridContainerPosition,
18
+ Layout,
19
+ TransformData,
20
+ ColorType } from '@orbcharts/core'
21
+ import { getDatumColor, getClassName, getUniID } from '../utils/orbchartsUtils'
22
+ import { gridSelectionsObservable } from '../grid/gridObservables'
23
+
24
+ export interface BaseDotsParams {
25
+ radius: number
26
+ fillColorType: ColorType
27
+ strokeColorType: ColorType
28
+ strokeWidth: number
29
+ onlyShowHighlighted: boolean
30
+ }
31
+
32
+ interface BaseDotsContext {
33
+ selection: d3.Selection<any, unknown, any, unknown>
34
+ computedData$: Observable<ComputedDataGrid>
35
+ computedLayoutData$: Observable<ComputedLayoutDataGrid>
36
+ visibleComputedData$: Observable<ComputedDatumGrid[][]>
37
+ visibleComputedLayoutData$: Observable<ComputedLayoutDataGrid>
38
+ seriesLabels$: Observable<string[]>
39
+ SeriesDataMap$: Observable<Map<string, ComputedDatumGrid[]>>
40
+ GroupDataMap$: Observable<Map<string, ComputedDatumGrid[]>>
41
+ fullParams$: Observable<BaseDotsParams>
42
+ fullChartParams$: Observable<ChartParams>
43
+ gridAxesTransform$: Observable<TransformData>
44
+ gridGraphicTransform$: Observable<TransformData>
45
+ gridGraphicReverseScale$: Observable<[number, number][]>
46
+ gridAxesSize$: Observable<{
47
+ width: number;
48
+ height: number;
49
+ }>
50
+ gridHighlight$: Observable<ComputedDatumGrid[]>
51
+ gridContainerPosition$: Observable<GridContainerPosition[]>
52
+ event$: Subject<EventGrid>
53
+ }
54
+
55
+
56
+ type ClipPathDatum = {
57
+ id: string;
58
+ // x: number;
59
+ // y: number;
60
+ width: number;
61
+ height: number;
62
+ }
63
+
64
+ // const pluginName = 'Dots'
65
+ // const circleGClassName = getClassName(pluginName, 'circleG')
66
+ // const circleClassName = getClassName(pluginName, 'circle')
67
+
68
+ function renderDots ({ graphicGSelection, circleGClassName, circleClassName, visibleComputedLayoutData, fullParams, fullChartParams, graphicReverseScale }: {
69
+ graphicGSelection: d3.Selection<SVGGElement, any, any, any>
70
+ circleGClassName: string
71
+ circleClassName: string
72
+ visibleComputedLayoutData: ComputedLayoutDataGrid
73
+ fullParams: BaseDotsParams
74
+ fullChartParams: ChartParams
75
+ graphicReverseScale: [number, number][]
76
+ }) {
77
+ const createEnterDuration = (enter: d3.Selection<d3.EnterElement, ComputedDatumGrid, SVGGElement, any>) => {
78
+ const enterSize = enter.size()
79
+ const eachDuration = fullChartParams.transitionDuration / enterSize
80
+ return eachDuration
81
+ }
82
+ // enterDuration
83
+ let enterDuration = 0
84
+
85
+ graphicGSelection
86
+ .each((seriesData, seriesIndex, g) => {
87
+ d3.select(g[seriesIndex])
88
+ .selectAll<SVGGElement, ComputedDatumGrid>('g')
89
+ .data(visibleComputedLayoutData[seriesIndex], d => d.id)
90
+ .join(
91
+ enter => {
92
+ // enterDuration
93
+ enterDuration = createEnterDuration(enter)
94
+
95
+ return enter
96
+ .append('g')
97
+ .classed(circleGClassName, true)
98
+ },
99
+ update => update,
100
+ exit => exit.remove()
101
+ )
102
+ .attr('transform', d => `translate(${d.axisX}, ${d.axisY})`)
103
+ .each((d, i, g) => {
104
+ const circle = d3.select(g[i])
105
+ .selectAll('circle')
106
+ .data([d])
107
+ .join(
108
+ enter => {
109
+ return enter
110
+ .append('circle')
111
+ .style('cursor', 'pointer')
112
+ .style('vector-effect', 'non-scaling-stroke')
113
+ .classed(circleClassName, true)
114
+ .attr('opacity', 0)
115
+ .transition()
116
+ .delay((_d, _i) => {
117
+ return i * enterDuration
118
+ })
119
+ .attr('opacity', 1)
120
+ },
121
+ update => {
122
+ return update
123
+ .transition()
124
+ .duration(50)
125
+ // .attr('cx', d => d.axisX)
126
+ // .attr('cy', d => d.axisY)
127
+ .attr('opacity', 1)
128
+ },
129
+ exit => exit.remove()
130
+ )
131
+ .attr('r', fullParams.radius)
132
+ .attr('fill', (d, i) => getDatumColor({ datum: d, colorType: fullParams.fillColorType, fullChartParams }))
133
+ .attr('stroke', (d, i) => getDatumColor({ datum: d, colorType: fullParams.strokeColorType, fullChartParams }))
134
+ .attr('stroke-width', fullParams.strokeWidth)
135
+ .attr('transform', `scale(${graphicReverseScale[seriesIndex][0] ?? 1}, ${graphicReverseScale[seriesIndex][1] ?? 1})`)
136
+ })
137
+ })
138
+
139
+ // const dots = graphicGSelection
140
+ // .selectAll<SVGGElement, ComputedDatumGrid>('g')
141
+ // .data(data, d => d.id)
142
+ // .join(
143
+ // enter => {
144
+ // // enterDuration
145
+ // enterDuration = createEnterDuration(enter)
146
+
147
+ // return enter
148
+ // .append('g')
149
+ // .classed(circleGClassName, true)
150
+ // },
151
+ // update => update,
152
+ // exit => exit.remove()
153
+ // )
154
+ // .attr('transform', d => `translate(${d.axisX}, ${d.axisY})`)
155
+ // .each((d, i, g) => {
156
+ // const circle = d3.select(g[i])
157
+ // .selectAll('circle')
158
+ // .data([d])
159
+ // .join(
160
+ // enter => {
161
+ // return enter
162
+ // .append('circle')
163
+ // .style('cursor', 'pointer')
164
+ // .style('vector-effect', 'non-scaling-stroke')
165
+ // .classed(circleClassName, true)
166
+ // .attr('opacity', 0)
167
+ // .transition()
168
+ // .delay((_d, _i) => {
169
+ // return i * enterDuration
170
+ // })
171
+ // .attr('opacity', 1)
172
+ // },
173
+ // update => {
174
+ // return update
175
+ // .transition()
176
+ // .duration(50)
177
+ // // .attr('cx', d => d.axisX)
178
+ // // .attr('cy', d => d.axisY)
179
+ // .attr('opacity', 1)
180
+ // },
181
+ // exit => exit.remove()
182
+ // )
183
+ // .attr('r', fullParams.radius)
184
+ // .attr('fill', (d, i) => getDatumColor({ datum: d, colorType: fullParams.fillColorType, fullChartParams }))
185
+ // .attr('stroke', (d, i) => getDatumColor({ datum: d, colorType: fullParams.strokeColorType, fullChartParams }))
186
+ // .attr('stroke-width', fullParams.strokeWidth)
187
+ // .attr('transform', `scale(${graphicReverseScale[0]}, ${graphicReverseScale[1]})`)
188
+ // })
189
+
190
+ const graphicCircleSelection: d3.Selection<SVGRectElement, ComputedDatumGrid, SVGGElement, unknown> = graphicGSelection.selectAll(`circle.${circleClassName}`)
191
+
192
+ return graphicCircleSelection
193
+ }
194
+
195
+
196
+ function highlightDots ({ selection, ids, onlyShowHighlighted, fullChartParams }: {
197
+ selection: d3.Selection<SVGGElement, ComputedDatumGrid, any, any>
198
+ ids: string[]
199
+ onlyShowHighlighted: boolean
200
+ fullChartParams: ChartParams
201
+ }) {
202
+ selection.interrupt('highlight')
203
+ if (!ids.length) {
204
+ // remove highlight
205
+ selection
206
+ .transition('highlight')
207
+ .duration(200)
208
+ .style('opacity', onlyShowHighlighted === true ? 0 : 1)
209
+ return
210
+ }
211
+
212
+ selection
213
+ .each((d, i, n) => {
214
+ if (ids.includes(d.id)) {
215
+ d3.select(n[i])
216
+ .style('opacity', 1)
217
+ .transition('highlight')
218
+ .duration(200)
219
+ } else {
220
+ d3.select(n[i])
221
+ .style('opacity', onlyShowHighlighted === true ? 0 : fullChartParams.styles.unhighlightedOpacity)
222
+ .transition('highlight')
223
+ .duration(200)
224
+ }
225
+ })
226
+ }
227
+
228
+ function renderClipPath ({ defsSelection, clipPathData }: {
229
+ defsSelection: d3.Selection<SVGDefsElement, any, any, any>
230
+ clipPathData: ClipPathDatum[]
231
+ }) {
232
+ const clipPath = defsSelection
233
+ .selectAll<SVGClipPathElement, Layout>('clipPath')
234
+ .data(clipPathData)
235
+ .join(
236
+ enter => {
237
+ return enter
238
+ .append('clipPath')
239
+ },
240
+ update => update,
241
+ exit => exit.remove()
242
+ )
243
+ .attr('id', d => d.id)
244
+ .each((d, i, g) => {
245
+ const rect = d3.select(g[i])
246
+ .selectAll<SVGRectElement, typeof d>('rect')
247
+ .data([d])
248
+ .join('rect')
249
+ .attr('x', 0)
250
+ .attr('y', 0)
251
+ .attr('width', _d => _d.width)
252
+ .attr('height', _d => _d.height)
253
+ })
254
+
255
+ }
256
+
257
+
258
+
259
+ export const createBaseDots: BasePluginFn<BaseDotsContext> = (pluginName: string, {
260
+ selection,
261
+ computedData$,
262
+ computedLayoutData$,
263
+ visibleComputedData$,
264
+ visibleComputedLayoutData$,
265
+ seriesLabels$,
266
+ SeriesDataMap$,
267
+ GroupDataMap$,
268
+ fullParams$,
269
+ fullChartParams$,
270
+ gridAxesTransform$,
271
+ gridGraphicTransform$,
272
+ gridGraphicReverseScale$,
273
+ gridAxesSize$,
274
+ gridHighlight$,
275
+ gridContainerPosition$,
276
+ event$
277
+ }) => {
278
+
279
+ const destroy$ = new Subject()
280
+
281
+ const clipPathID = getUniID(pluginName, 'clipPath-box')
282
+ const circleGClassName = getClassName(pluginName, 'circleG')
283
+ const circleClassName = getClassName(pluginName, 'circle')
284
+
285
+ // const axisSelection: d3.Selection<SVGGElement, any, any, any> = selection
286
+ // .append('g')
287
+ // .attr('clip-path', `url(#${clipPathID})`)
288
+ // const defsSelection: d3.Selection<SVGDefsElement, any, any, any> = axisSelection.append('defs')
289
+ // const dataAreaSelection: d3.Selection<SVGGElement, any, any, any> = axisSelection.append('g')
290
+ // const graphicSelection$: Subject<d3.Selection<SVGGElement, ComputedDatumGrid, any, any>> = new Subject()
291
+
292
+ const {
293
+ seriesSelection$,
294
+ axesSelection$,
295
+ defsSelection$,
296
+ graphicGSelection$
297
+ } = gridSelectionsObservable({
298
+ selection,
299
+ pluginName,
300
+ clipPathID,
301
+ seriesLabels$,
302
+ gridContainerPosition$,
303
+ gridAxesTransform$,
304
+ gridGraphicTransform$
305
+ })
306
+
307
+ const graphicReverseScale$: Observable<[number, number][]> = combineLatest({
308
+ // gridGraphicTransform: gridGraphicTransform$,
309
+ // gridContainerPosition: gridContainerPosition$,
310
+ // gridAxesTransform: gridAxesTransform$
311
+ computedData: computedData$,
312
+ gridGraphicReverseScale: gridGraphicReverseScale$
313
+ }).pipe(
314
+ takeUntil(destroy$),
315
+ switchMap(async data => data),
316
+ map(data => {
317
+ return data.computedData.map((series, seriesIndex) => {
318
+ return data.gridGraphicReverseScale[seriesIndex]
319
+ })
320
+ })
321
+ )
322
+
323
+ const clipPathSubscription = combineLatest({
324
+ defsSelection: defsSelection$,
325
+ gridAxesSize: gridAxesSize$,
326
+ }).pipe(
327
+ takeUntil(destroy$),
328
+ switchMap(async (d) => d),
329
+ ).subscribe(data => {
330
+ // 外層的遮罩
331
+ const clipPathData = [{
332
+ id: clipPathID,
333
+ width: data.gridAxesSize.width,
334
+ height: data.gridAxesSize.height
335
+ }]
336
+ renderClipPath({
337
+ defsSelection: data.defsSelection,
338
+ clipPathData,
339
+ })
340
+ })
341
+
342
+ const highlightTarget$ = fullChartParams$.pipe(
343
+ takeUntil(destroy$),
344
+ map(d => d.highlightTarget),
345
+ distinctUntilChanged()
346
+ )
347
+
348
+ const graphicSelection$ = combineLatest({
349
+ graphicGSelection: graphicGSelection$,
350
+ visibleComputedLayoutData: visibleComputedLayoutData$,
351
+ graphicReverseScale: graphicReverseScale$,
352
+ fullChartParams: fullChartParams$,
353
+ fullParams: fullParams$,
354
+ }).pipe(
355
+ takeUntil(destroy$),
356
+ switchMap(async (d) => d),
357
+ map(data => {
358
+ return renderDots({
359
+ graphicGSelection: data.graphicGSelection,
360
+ circleGClassName,
361
+ circleClassName,
362
+ visibleComputedLayoutData: data.visibleComputedLayoutData,
363
+ fullParams: data.fullParams,
364
+ fullChartParams: data.fullChartParams,
365
+ graphicReverseScale: data.graphicReverseScale
366
+ })
367
+ })
368
+ )
369
+
370
+ combineLatest({
371
+ graphicSelection: graphicSelection$,
372
+ computedData: computedData$,
373
+ SeriesDataMap: SeriesDataMap$,
374
+ GroupDataMap: GroupDataMap$,
375
+ highlightTarget: highlightTarget$
376
+ }).pipe(
377
+ takeUntil(destroy$),
378
+ switchMap(async (d) => d),
379
+ ).subscribe(data => {
380
+
381
+ data.graphicSelection
382
+ .on('mouseover', (event, datum) => {
383
+ event.stopPropagation()
384
+
385
+ event$.next({
386
+ type: 'grid',
387
+ eventName: 'mouseover',
388
+ pluginName,
389
+ highlightTarget: data.highlightTarget,
390
+ datum,
391
+ gridIndex: datum.gridIndex,
392
+ series: data.SeriesDataMap.get(datum.seriesLabel)!,
393
+ seriesIndex: datum.seriesIndex,
394
+ seriesLabel: datum.seriesLabel,
395
+ groups: data.GroupDataMap.get(datum.groupLabel)!,
396
+ groupIndex: datum.groupIndex,
397
+ groupLabel: datum.groupLabel,
398
+ event,
399
+ data: data.computedData
400
+ })
401
+ })
402
+ .on('mousemove', (event, datum) => {
403
+ event.stopPropagation()
404
+
405
+ event$.next({
406
+ type: 'grid',
407
+ eventName: 'mousemove',
408
+ pluginName,
409
+ highlightTarget: data.highlightTarget,
410
+ data: data.computedData,
411
+ datum,
412
+ gridIndex: datum.gridIndex,
413
+ series: data.SeriesDataMap.get(datum.seriesLabel)!,
414
+ seriesIndex: datum.seriesIndex,
415
+ seriesLabel: datum.seriesLabel,
416
+ groups: data.GroupDataMap.get(datum.groupLabel)!,
417
+ groupIndex: datum.groupIndex,
418
+ groupLabel: datum.groupLabel,
419
+ event
420
+ })
421
+ })
422
+ .on('mouseout', (event, datum) => {
423
+ event.stopPropagation()
424
+
425
+ event$.next({
426
+ type: 'grid',
427
+ eventName: 'mouseout',
428
+ pluginName,
429
+ highlightTarget: data.highlightTarget,
430
+ datum,
431
+ gridIndex: datum.gridIndex,
432
+ series: data.SeriesDataMap.get(datum.seriesLabel)!,
433
+ seriesIndex: datum.seriesIndex,
434
+ seriesLabel: datum.seriesLabel,
435
+ groups: data.GroupDataMap.get(datum.groupLabel)!,
436
+ groupIndex: datum.groupIndex,
437
+ groupLabel: datum.groupLabel,
438
+ event,
439
+ data: data.computedData
440
+ })
441
+ })
442
+ .on('click', (event, datum) => {
443
+ event.stopPropagation()
444
+
445
+ event$.next({
446
+ type: 'grid',
447
+ eventName: 'click',
448
+ pluginName,
449
+ highlightTarget: data.highlightTarget,
450
+ datum,
451
+ gridIndex: datum.gridIndex,
452
+ series: data.SeriesDataMap.get(datum.seriesLabel)!,
453
+ seriesIndex: datum.seriesIndex,
454
+ seriesLabel: datum.seriesLabel,
455
+ groups: data.GroupDataMap.get(datum.groupLabel)!,
456
+ groupIndex: datum.groupIndex,
457
+ groupLabel: datum.groupLabel,
458
+ event,
459
+ data: data.computedData
460
+ })
461
+ })
462
+
463
+ })
464
+
465
+ // const datumList$ = computedData$.pipe(
466
+ // takeUntil(destroy$),
467
+ // map(d => d.flat())
468
+ // )
469
+ // const highlight$ = highlightObservable({ datumList$, fullChartParams$, event$: store.event$ })
470
+ // const highlightSubscription = gridHighlight$.subscribe()
471
+ const onlyShowHighlighted$ = fullParams$.pipe(
472
+ takeUntil(destroy$),
473
+ map(d => d.onlyShowHighlighted),
474
+ distinctUntilChanged()
475
+ )
476
+
477
+ fullChartParams$.pipe(
478
+ takeUntil(destroy$),
479
+ switchMap(d => combineLatest({
480
+ graphicSelection: graphicSelection$,
481
+ highlight: gridHighlight$.pipe(
482
+ map(data => data.map(d => d.id))
483
+ ),
484
+ onlyShowHighlighted: onlyShowHighlighted$,
485
+ fullChartParams: fullChartParams$
486
+ }).pipe(
487
+ takeUntil(destroy$),
488
+ switchMap(async d => d)
489
+ ))
490
+ ).subscribe(data => {
491
+ highlightDots({
492
+ selection: data.graphicSelection,
493
+ ids: data.highlight,
494
+ onlyShowHighlighted: data.onlyShowHighlighted,
495
+ fullChartParams: data.fullChartParams
496
+ })
497
+ })
498
+
499
+ return () => {
500
+ destroy$.next(undefined)
501
+ // highlightSubscription.unsubscribe()
502
+ }
503
503
  }