@orbcharts/plugin-basic 4.0.0-pre-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (208) hide show
  1. package/LICENSE +201 -0
  2. package/dist/orbcharts-plugin-basic.es.js +25335 -0
  3. package/dist/orbcharts-plugin-basic.umd.js +341 -0
  4. package/dist/plugin-basic/src/baseLayers/BaseBars.d.ts +38 -0
  5. package/dist/plugin-basic/src/baseLayers/BaseBarsTriangle.d.ts +37 -0
  6. package/dist/plugin-basic/src/baseLayers/BaseCategoryAxis.d.ts +42 -0
  7. package/dist/plugin-basic/src/baseLayers/BaseDots.d.ts +38 -0
  8. package/dist/plugin-basic/src/baseLayers/BaseLegend.d.ts +31 -0
  9. package/dist/plugin-basic/src/baseLayers/BaseLineAreas.d.ts +36 -0
  10. package/dist/plugin-basic/src/baseLayers/BaseLines.d.ts +36 -0
  11. package/dist/plugin-basic/src/baseLayers/BaseStackedBars.d.ts +41 -0
  12. package/dist/plugin-basic/src/baseLayers/BaseTooltip.d.ts +47 -0
  13. package/dist/plugin-basic/src/baseLayers/BaseValueAxis.d.ts +38 -0
  14. package/dist/plugin-basic/src/baseLayers/BaseXAxis.d.ts +25 -0
  15. package/dist/plugin-basic/src/baseLayers/BaseXZoom.d.ts +22 -0
  16. package/dist/plugin-basic/src/baseLayers/BaseYAxis.d.ts +23 -0
  17. package/dist/plugin-basic/src/baseLayers/types.d.ts +171 -0
  18. package/dist/plugin-basic/src/const/layerIndex.d.ts +10 -0
  19. package/dist/plugin-basic/src/const/sharedPluginParams.d.ts +6 -0
  20. package/dist/plugin-basic/src/index.d.ts +2 -0
  21. package/dist/plugin-basic/src/plugins/CompositionPlot/CompositionPlot.d.ts +22 -0
  22. package/dist/plugin-basic/src/plugins/CompositionPlot/contextObservables.d.ts +40 -0
  23. package/dist/plugin-basic/src/plugins/CompositionPlot/defaults.d.ts +10 -0
  24. package/dist/plugin-basic/src/plugins/CompositionPlot/index.d.ts +3 -0
  25. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/Bubbles.d.ts +16 -0
  26. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/Indicator.d.ts +0 -0
  27. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/Pie.d.ts +16 -0
  28. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/PieEventTexts.d.ts +16 -0
  29. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/PieLabels.d.ts +16 -0
  30. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/Rose.d.ts +16 -0
  31. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/RoseLabels.d.ts +16 -0
  32. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/Waffle.d.ts +0 -0
  33. package/dist/plugin-basic/src/plugins/CompositionPlot/types.d.ts +110 -0
  34. package/dist/plugin-basic/src/plugins/CompositionPlot/utils.d.ts +19 -0
  35. package/dist/plugin-basic/src/plugins/HierarchyPlot/HierarchyPlot.d.ts +22 -0
  36. package/dist/plugin-basic/src/plugins/HierarchyPlot/contextObservables.d.ts +16 -0
  37. package/dist/plugin-basic/src/plugins/HierarchyPlot/defaults.d.ts +4 -0
  38. package/dist/plugin-basic/src/plugins/HierarchyPlot/index.d.ts +3 -0
  39. package/dist/plugin-basic/src/plugins/HierarchyPlot/layers/TreeMap.d.ts +16 -0
  40. package/dist/plugin-basic/src/plugins/HierarchyPlot/types.d.ts +29 -0
  41. package/dist/plugin-basic/src/plugins/Legend/Legend.d.ts +22 -0
  42. package/dist/plugin-basic/src/plugins/Legend/contextObservables.d.ts +9 -0
  43. package/dist/plugin-basic/src/plugins/Legend/defaults.d.ts +4 -0
  44. package/dist/plugin-basic/src/plugins/Legend/index.d.ts +3 -0
  45. package/dist/plugin-basic/src/plugins/Legend/layers/Legend.d.ts +16 -0
  46. package/dist/plugin-basic/src/plugins/Legend/types.d.ts +31 -0
  47. package/dist/plugin-basic/src/plugins/Legend/utils.d.ts +19 -0
  48. package/dist/plugin-basic/src/plugins/NetworkPlot/NetworkPlot.d.ts +22 -0
  49. package/dist/plugin-basic/src/plugins/NetworkPlot/contextObservables.d.ts +19 -0
  50. package/dist/plugin-basic/src/plugins/NetworkPlot/defaults.d.ts +5 -0
  51. package/dist/plugin-basic/src/plugins/NetworkPlot/index.d.ts +3 -0
  52. package/dist/plugin-basic/src/plugins/NetworkPlot/layers/ForceDirected.d.ts +16 -0
  53. package/dist/plugin-basic/src/plugins/NetworkPlot/layers/ForceDirectedBubbles.d.ts +16 -0
  54. package/dist/plugin-basic/src/plugins/NetworkPlot/types.d.ts +117 -0
  55. package/dist/plugin-basic/src/plugins/ScatterPlot/ScatterPlot.d.ts +22 -0
  56. package/dist/plugin-basic/src/plugins/ScatterPlot/contextObservables.d.ts +140 -0
  57. package/dist/plugin-basic/src/plugins/ScatterPlot/defaults.d.ts +8 -0
  58. package/dist/plugin-basic/src/plugins/ScatterPlot/index.d.ts +3 -0
  59. package/dist/plugin-basic/src/plugins/ScatterPlot/layers/Scatter.d.ts +16 -0
  60. package/dist/plugin-basic/src/plugins/ScatterPlot/layers/ScatterBubbles.d.ts +16 -0
  61. package/dist/plugin-basic/src/plugins/ScatterPlot/layers/XYAux.d.ts +16 -0
  62. package/dist/plugin-basic/src/plugins/ScatterPlot/layers/XYAxes.d.ts +16 -0
  63. package/dist/plugin-basic/src/plugins/ScatterPlot/layers/XZoom.d.ts +16 -0
  64. package/dist/plugin-basic/src/plugins/ScatterPlot/types.d.ts +146 -0
  65. package/dist/plugin-basic/src/plugins/SeriesPlot/SeriesPlot.d.ts +22 -0
  66. package/dist/plugin-basic/src/plugins/SeriesPlot/contextObservables.d.ts +77 -0
  67. package/dist/plugin-basic/src/plugins/SeriesPlot/defaults.d.ts +15 -0
  68. package/dist/plugin-basic/src/plugins/SeriesPlot/index.d.ts +3 -0
  69. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/Bars.d.ts +16 -0
  70. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/BarsPN.d.ts +16 -0
  71. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/BarsTriangle.d.ts +16 -0
  72. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/CategoryAux.d.ts +16 -0
  73. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/CategoryAxis.d.ts +16 -0
  74. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/CategoryZoom.d.ts +16 -0
  75. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/Dots.d.ts +16 -0
  76. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/LineAreas.d.ts +16 -0
  77. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/Lines.d.ts +16 -0
  78. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/StackedBars.d.ts +16 -0
  79. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/StackedValueAxis.d.ts +16 -0
  80. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/ValueAxis.d.ts +16 -0
  81. package/dist/plugin-basic/src/plugins/SeriesPlot/types.d.ts +140 -0
  82. package/dist/plugin-basic/src/plugins/Tooltip/Tooltip.d.ts +22 -0
  83. package/dist/plugin-basic/src/plugins/Tooltip/contextObservables.d.ts +9 -0
  84. package/dist/plugin-basic/src/plugins/Tooltip/defaults.d.ts +4 -0
  85. package/dist/plugin-basic/src/plugins/Tooltip/index.d.ts +3 -0
  86. package/dist/plugin-basic/src/plugins/Tooltip/layers/Tooltip.d.ts +16 -0
  87. package/dist/plugin-basic/src/plugins/Tooltip/types.d.ts +35 -0
  88. package/dist/plugin-basic/src/plugins/Tooltip/utils.d.ts +19 -0
  89. package/dist/plugin-basic/src/plugins/index.d.ts +7 -0
  90. package/dist/plugin-basic/src/types/BaseLayer.d.ts +3 -0
  91. package/dist/plugin-basic/src/types/Common.d.ts +14 -0
  92. package/dist/plugin-basic/src/types/ComputedData.d.ts +27 -0
  93. package/dist/plugin-basic/src/types/PluginParams.d.ts +66 -0
  94. package/dist/plugin-basic/src/types/index.d.ts +3 -0
  95. package/dist/plugin-basic/src/utils/commonUtils.d.ts +3 -0
  96. package/dist/plugin-basic/src/utils/d3Graphics.d.ts +24 -0
  97. package/dist/plugin-basic/src/utils/d3Scale.d.ts +28 -0
  98. package/dist/plugin-basic/src/utils/d3Utils.d.ts +14 -0
  99. package/dist/plugin-basic/src/utils/graphObservables.d.ts +0 -0
  100. package/dist/plugin-basic/src/utils/gridObservables.d.ts +51 -0
  101. package/dist/plugin-basic/src/utils/multivariateObservables.d.ts +74 -0
  102. package/dist/plugin-basic/src/utils/observables.d.ts +34 -0
  103. package/dist/plugin-basic/src/utils/orbchartsUtils.d.ts +26 -0
  104. package/dist/plugin-basic/src/utils/seriesObservables.d.ts +22 -0
  105. package/dist/plugin-basic/vite.config.d.ts +2 -0
  106. package/dist/src/index.d.ts +1 -0
  107. package/package.json +62 -0
  108. package/src/baseLayers/BaseBars.ts +783 -0
  109. package/src/baseLayers/BaseBarsTriangle.ts +692 -0
  110. package/src/baseLayers/BaseCategoryAxis.ts +708 -0
  111. package/src/baseLayers/BaseDots.ts +495 -0
  112. package/src/baseLayers/BaseLegend.ts +684 -0
  113. package/src/baseLayers/BaseLineAreas.ts +644 -0
  114. package/src/baseLayers/BaseLines.ts +721 -0
  115. package/src/baseLayers/BaseStackedBars.ts +818 -0
  116. package/src/baseLayers/BaseTooltip.ts +435 -0
  117. package/src/baseLayers/BaseValueAxis.ts +612 -0
  118. package/src/baseLayers/BaseXAxis.ts +412 -0
  119. package/src/baseLayers/BaseXZoom.ts +250 -0
  120. package/src/baseLayers/BaseYAxis.ts +371 -0
  121. package/src/baseLayers/types.ts +174 -0
  122. package/src/const/layerIndex.ts +36 -0
  123. package/src/const/sharedPluginParams.ts +29 -0
  124. package/src/index.ts +3 -0
  125. package/src/plugins/CompositionPlot/CompositionPlot.ts +308 -0
  126. package/src/plugins/CompositionPlot/contextObservables.ts +251 -0
  127. package/src/plugins/CompositionPlot/defaults.ts +162 -0
  128. package/src/plugins/CompositionPlot/index.ts +3 -0
  129. package/src/plugins/CompositionPlot/layers/Bubbles.ts +808 -0
  130. package/src/plugins/CompositionPlot/layers/Indicator.ts +0 -0
  131. package/src/plugins/CompositionPlot/layers/Pie.ts +776 -0
  132. package/src/plugins/CompositionPlot/layers/PieEventTexts.ts +326 -0
  133. package/src/plugins/CompositionPlot/layers/PieLabels.ts +651 -0
  134. package/src/plugins/CompositionPlot/layers/Rose.ts +546 -0
  135. package/src/plugins/CompositionPlot/layers/RoseLabels.ts +616 -0
  136. package/src/plugins/CompositionPlot/layers/Waffle.ts +0 -0
  137. package/src/plugins/CompositionPlot/types.ts +129 -0
  138. package/src/plugins/CompositionPlot/utils.ts +53 -0
  139. package/src/plugins/HierarchyPlot/HierarchyPlot.ts +190 -0
  140. package/src/plugins/HierarchyPlot/contextObservables.ts +136 -0
  141. package/src/plugins/HierarchyPlot/defaults.ts +31 -0
  142. package/src/plugins/HierarchyPlot/index.ts +3 -0
  143. package/src/plugins/HierarchyPlot/layers/TreeMap.ts +371 -0
  144. package/src/plugins/HierarchyPlot/types.ts +36 -0
  145. package/src/plugins/Legend/Legend.ts +151 -0
  146. package/src/plugins/Legend/contextObservables.ts +55 -0
  147. package/src/plugins/Legend/defaults.ts +37 -0
  148. package/src/plugins/Legend/index.ts +3 -0
  149. package/src/plugins/Legend/layers/Legend.ts +114 -0
  150. package/src/plugins/Legend/types.ts +45 -0
  151. package/src/plugins/Legend/utils.ts +53 -0
  152. package/src/plugins/NetworkPlot/NetworkPlot.ts +228 -0
  153. package/src/plugins/NetworkPlot/contextObservables.ts +123 -0
  154. package/src/plugins/NetworkPlot/defaults.ts +147 -0
  155. package/src/plugins/NetworkPlot/index.ts +3 -0
  156. package/src/plugins/NetworkPlot/layers/ForceDirected.ts +1048 -0
  157. package/src/plugins/NetworkPlot/layers/ForceDirectedBubbles.ts +1318 -0
  158. package/src/plugins/NetworkPlot/types.ts +146 -0
  159. package/src/plugins/ScatterPlot/ScatterPlot.ts +569 -0
  160. package/src/plugins/ScatterPlot/contextObservables.ts +901 -0
  161. package/src/plugins/ScatterPlot/defaults.ts +212 -0
  162. package/src/plugins/ScatterPlot/index.ts +3 -0
  163. package/src/plugins/ScatterPlot/layers/Scatter.ts +518 -0
  164. package/src/plugins/ScatterPlot/layers/ScatterBubbles.ts +670 -0
  165. package/src/plugins/ScatterPlot/layers/XYAux.ts +686 -0
  166. package/src/plugins/ScatterPlot/layers/XYAxes.ts +205 -0
  167. package/src/plugins/ScatterPlot/layers/XZoom.ts +48 -0
  168. package/src/plugins/ScatterPlot/types.ts +179 -0
  169. package/src/plugins/SeriesPlot/SeriesPlot.ts +494 -0
  170. package/src/plugins/SeriesPlot/contextObservables.ts +726 -0
  171. package/src/plugins/SeriesPlot/defaults.ts +142 -0
  172. package/src/plugins/SeriesPlot/index.ts +3 -0
  173. package/src/plugins/SeriesPlot/layers/Bars.ts +84 -0
  174. package/src/plugins/SeriesPlot/layers/BarsPN.ts +85 -0
  175. package/src/plugins/SeriesPlot/layers/BarsTriangle.ts +89 -0
  176. package/src/plugins/SeriesPlot/layers/CategoryAux.ts +1131 -0
  177. package/src/plugins/SeriesPlot/layers/CategoryAxis.ts +92 -0
  178. package/src/plugins/SeriesPlot/layers/CategoryZoom.ts +233 -0
  179. package/src/plugins/SeriesPlot/layers/Dots.ts +91 -0
  180. package/src/plugins/SeriesPlot/layers/LineAreas.ts +82 -0
  181. package/src/plugins/SeriesPlot/layers/Lines.ts +75 -0
  182. package/src/plugins/SeriesPlot/layers/StackedBars.ts +85 -0
  183. package/src/plugins/SeriesPlot/layers/StackedValueAxis.ts +111 -0
  184. package/src/plugins/SeriesPlot/layers/ValueAxis.ts +111 -0
  185. package/src/plugins/SeriesPlot/types.ts +201 -0
  186. package/src/plugins/Tooltip/Tooltip.ts +159 -0
  187. package/src/plugins/Tooltip/contextObservables.ts +55 -0
  188. package/src/plugins/Tooltip/defaults.ts +458 -0
  189. package/src/plugins/Tooltip/index.ts +3 -0
  190. package/src/plugins/Tooltip/layers/Tooltip.ts +90 -0
  191. package/src/plugins/Tooltip/types.ts +55 -0
  192. package/src/plugins/Tooltip/utils.ts +53 -0
  193. package/src/plugins/index.ts +8 -0
  194. package/src/types/BaseLayer.ts +3 -0
  195. package/src/types/Common.ts +20 -0
  196. package/src/types/ComputedData.ts +55 -0
  197. package/src/types/PluginParams.ts +81 -0
  198. package/src/types/index.ts +3 -0
  199. package/src/utils/commonUtils.ts +31 -0
  200. package/src/utils/d3Graphics.ts +177 -0
  201. package/src/utils/d3Scale.ts +198 -0
  202. package/src/utils/d3Utils.ts +92 -0
  203. package/src/utils/graphObservables.ts +0 -0
  204. package/src/utils/gridObservables.ts +637 -0
  205. package/src/utils/multivariateObservables.ts +790 -0
  206. package/src/utils/observables.ts +357 -0
  207. package/src/utils/orbchartsUtils.ts +335 -0
  208. package/src/utils/seriesObservables.ts +172 -0
@@ -0,0 +1,326 @@
1
+ import * as d3 from 'd3'
2
+ import {
3
+ combineLatest,
4
+ map,
5
+ switchMap,
6
+ takeUntil,
7
+ distinctUntilChanged,
8
+ shareReplay,
9
+ debounceTime,
10
+ Observable,
11
+ Subject,
12
+ Subscription} from 'rxjs'
13
+ import type { Theme, EventData } from '@orbcharts/core'
14
+ import type { CompositionPlotExtendContext, CompositionPlotPluginParams, PieEventTextsParams } from "../types"
15
+ import type { PieDatum } from '../utils'
16
+ import { defineSVGLayer } from '@orbcharts/core'
17
+ import { validateObject } from '@orbcharts/core'
18
+ import { DEFAULT_PIE_EVENT_TEXTS_PARAMS } from "../defaults"
19
+ import { seriesCenterSelectionObservable } from "../../../utils/seriesObservables"
20
+ import { getDatumColor } from '../../../utils/orbchartsUtils'
21
+ import { createClassName } from '../../../utils/orbchartsUtils'
22
+ import { makeD3Arc } from '../../../utils/d3Utils'
23
+ import { makePieData } from '../utils'
24
+ import type { ComputedDatumSeries } from '../../../types/ComputedData'
25
+ import type { ContainerPosition } from '../../../types/PluginParams'
26
+ import { LAYER_INDEX_OF_LABEL } from '../../../const/layerIndex'
27
+
28
+ type TextDatum = {
29
+ text: string
30
+ attr: { [key:string]: any }
31
+ style: { [key:string]: any }
32
+ }
33
+
34
+ const pluginName = 'CompositionPlot'
35
+ const layerName = 'PieEventTexts'
36
+ const textClassName = createClassName(pluginName, layerName, 'text')
37
+
38
+ function renderText (
39
+ selection: d3.Selection<SVGGElement, unknown, any, any>,
40
+ data: Array<TextDatum>
41
+ ): d3.Selection<SVGTextElement, TextDatum, SVGGElement, unknown> {
42
+ const textUpdate = selection
43
+ .selectAll<SVGTextElement, TextDatum>(`text.${textClassName}`)
44
+ .data(data)
45
+ const textEnter = textUpdate.enter()
46
+ .append('text')
47
+ .classed(textClassName, true)
48
+ const text = textUpdate.merge(textEnter)
49
+ text
50
+ .each((d, i, g) => {
51
+ const t = d3.select(g[i])
52
+ .text(d.text)
53
+ Object.keys(d.attr)
54
+ .forEach(key => {
55
+ t.attr(key, d.attr[key])
56
+ })
57
+ Object.keys(d.style)
58
+ .forEach(key => {
59
+ t.style(key, d.style[key])
60
+ })
61
+ })
62
+
63
+ textUpdate.exit().remove()
64
+
65
+ return text
66
+ }
67
+
68
+ function createTextData ({ eventData, renderFn, textAttrs, textStyles }: {
69
+ eventData: EventData,
70
+ // t: number,
71
+ renderFn: (d: EventData) => string[] | string | null
72
+ textAttrs: Array<{ [key:string]: string | number }>
73
+ textStyles: Array<{ [key:string]: string | number }>
74
+ }): TextDatum[] | null {
75
+ const callbackText: string[] | string | null = renderFn(eventData)
76
+ if (callbackText === null) {
77
+ return null
78
+ }
79
+ const textArr = Array.isArray(callbackText) ? callbackText : [callbackText]
80
+ return textArr.map((d, i) => {
81
+ return {
82
+ text: d,
83
+ attr: textAttrs[i],
84
+ style: textStyles[i]
85
+ }
86
+ })
87
+ }
88
+
89
+ function createEachPieEventTexts (context: {
90
+ containerSelection: d3.Selection<SVGGElement, any, any, unknown>
91
+ computedData$: Observable<ComputedDatumSeries[][]>
92
+ containerComputedSortedData$: Observable<ComputedDatumSeries[]>
93
+ SeriesDataMap$: Observable<Map<string, ComputedDatumSeries[]>>
94
+ layerParams$: Observable<PieEventTextsParams>
95
+ pluginParams$: Observable<CompositionPlotPluginParams>
96
+ seriesHighlight$: Observable<ComputedDatumSeries[]>
97
+ seriesContainerPosition$: Observable<ContainerPosition>
98
+ eventTrigger$: Subject<EventData>
99
+ }) {
100
+ const destroy$ = new Subject()
101
+
102
+ // const graphicSelection: d3.Selection<SVGGElement, any, any, any> = selection.append('g')
103
+ let centerTextSelection: d3.Selection<SVGTextElement, TextDatum, SVGGElement, unknown> | undefined
104
+ let storeEventSubscription: Subscription | undefined
105
+
106
+ // context.layout$
107
+ // .pipe(
108
+ // first()
109
+ // )
110
+ // .subscribe(size => {
111
+ // selection
112
+ // .attr('transform', `translate(${size.width / 2}, ${size.height / 2})`)
113
+ // context.layout$
114
+ // .pipe(
115
+ // takeUntil(destroy$)
116
+ // )
117
+ // .subscribe(size => {
118
+ // selection
119
+ // .transition()
120
+ // .attr('transform', `translate(${size.width / 2}, ${size.height / 2})`)
121
+ // })
122
+ // })
123
+
124
+ const highlightTarget$ = context.pluginParams$.pipe(
125
+ takeUntil(destroy$),
126
+ map(d => d.styles.highlightTarget),
127
+ distinctUntilChanged()
128
+ )
129
+
130
+ // highlight的對象(不做成observable是因為要避免觸發監聽)
131
+ let seriesHighlight: ComputedDatumSeries[] = []
132
+ context.seriesHighlight$
133
+ .pipe(
134
+ takeUntil(destroy$)
135
+ )
136
+ .subscribe(d => seriesHighlight = d)
137
+
138
+ combineLatest({
139
+ computedData: context.computedData$,
140
+ layerParams: context.layerParams$,
141
+ pluginParams: context.pluginParams$,
142
+ highlightTarget: highlightTarget$,
143
+ }).pipe(
144
+ takeUntil(destroy$),
145
+ switchMap(async (d) => d),
146
+ // first()
147
+ ).subscribe(data => {
148
+
149
+ // console.log('PieEventTexts data', data)
150
+
151
+ context.containerSelection
152
+ .transition('move')
153
+ .duration(data.pluginParams.styles.transitionDuration!)
154
+ // .ease(getD3TransitionEase(data.pluginParams.transitionEase!))
155
+ .tween('move', (event, datum) => {
156
+ return (t) => {
157
+ const renderData = createTextData({
158
+ eventData: {
159
+ // type: 'series',
160
+ // pluginName,
161
+ // eventName: 'transitionMove',
162
+ // event,
163
+ // tween: t,
164
+ // highlightTarget: data.highlightTarget,
165
+ // data: data.computedData,
166
+ // series: seriesHighlight,
167
+ // seriesIndex: seriesHighlight[0] ? seriesHighlight[0].seriesIndex : -1,
168
+ // seriesLabel: seriesHighlight[0] ? seriesHighlight[0].seriesLabel : '',
169
+ // datum: seriesHighlight[0] || null
170
+ eventName: 'mousemove',
171
+ pluginName,
172
+ layerName,
173
+ target: seriesHighlight[0] || null,
174
+ event
175
+ },
176
+ // eventName: 'transitionMove',
177
+ // t,
178
+ renderFn: data.layerParams.renderFn!,
179
+ textAttrs: data.layerParams.textAttrs!,
180
+ textStyles: data.layerParams.textStyles!
181
+ })
182
+ if (renderData != null) {
183
+ centerTextSelection = renderText(context.containerSelection, renderData)
184
+ }
185
+ }
186
+ })
187
+ .on('end', (event, datum) => {
188
+ const renderData = createTextData({
189
+ eventData: {
190
+ // type: 'series',
191
+ // pluginName,
192
+ // eventName: 'transitionEnd',
193
+ // event,
194
+ // tween: 1,
195
+ // highlightTarget: data.highlightTarget,
196
+ // data: data.computedData,
197
+ // series: seriesHighlight,
198
+ // seriesIndex: seriesHighlight[0] ? seriesHighlight[0].seriesIndex : -1,
199
+ // seriesLabel: seriesHighlight[0] ? seriesHighlight[0].seriesLabel : '',
200
+ // datum: seriesHighlight[0] || null
201
+ eventName: 'mousemove',
202
+ pluginName,
203
+ layerName,
204
+ target: seriesHighlight[0] || null,
205
+ event
206
+ },
207
+ // eventName: 'transitionMove',
208
+ // t: 1,
209
+ renderFn: data.layerParams.renderFn!,
210
+ textAttrs: data.layerParams.textAttrs!,
211
+ textStyles: data.layerParams.textStyles!
212
+ })
213
+ if (renderData != null) {
214
+ centerTextSelection = renderText(context.containerSelection, renderData)
215
+ }
216
+
217
+ // 監聽 highlight
218
+ if (storeEventSubscription) {
219
+ storeEventSubscription.unsubscribe()
220
+ }
221
+ storeEventSubscription = context.eventTrigger$
222
+ .subscribe(eventData => {
223
+ const renderData = createTextData({
224
+ eventData,
225
+ // t: 1,
226
+ renderFn: data.layerParams.renderFn!,
227
+ textAttrs: data.layerParams.textAttrs!,
228
+ textStyles: data.layerParams.textStyles!
229
+ })
230
+ if (renderData != null) {
231
+ centerTextSelection = renderText(context.containerSelection, renderData)
232
+ }
233
+ })
234
+ })
235
+ })
236
+
237
+ return () => {
238
+ destroy$.next(undefined)
239
+ }
240
+ }
241
+
242
+ export const PieEventTexts = defineSVGLayer<CompositionPlotExtendContext, CompositionPlotPluginParams, PieEventTextsParams>({
243
+ name: layerName,
244
+ defaultParams: DEFAULT_PIE_EVENT_TEXTS_PARAMS,
245
+ layerIndex: LAYER_INDEX_OF_LABEL,
246
+ initShow: false,
247
+ validator: (params) => {
248
+ const result = validateObject(params, {
249
+ renderFn: {
250
+ toBeTypes: ['Function'],
251
+ },
252
+ textAttrs: {
253
+ toBeTypes: ['object[]'],
254
+ },
255
+ textStyles: {
256
+ toBeTypes: ['object[]'],
257
+ }
258
+ })
259
+ return result
260
+ },
261
+ setup: ({ svgG, pluginParams$, layerParams$, context }) => {
262
+
263
+ const destroy$ = new Subject()
264
+
265
+ context.layout$
266
+ .pipe(
267
+ takeUntil(destroy$)
268
+ )
269
+ .subscribe(layout => {
270
+ d3.select(svgG)
271
+ .attr('transform', `translate(${layout.left}, ${layout.top})`)
272
+ })
273
+
274
+ const { seriesCenterSelection$ } = seriesCenterSelectionObservable({
275
+ selection: d3.select(svgG),
276
+ pluginName,
277
+ layerName,
278
+ visibleComputedSortedData$: context.visibleComputedSortedData$,
279
+ seriesContainerPosition$: context.seriesContainerPosition$
280
+ })
281
+
282
+ const unsubscribeFnArr: (() => void)[] = []
283
+
284
+ seriesCenterSelection$
285
+ .pipe(
286
+ takeUntil(destroy$)
287
+ )
288
+ .subscribe(seriesCenterSelection => {
289
+ // 每次重新計算時,清除之前的訂閱
290
+ unsubscribeFnArr.forEach(fn => fn())
291
+
292
+ seriesCenterSelection.each((d, containerIndex, g) => {
293
+
294
+ const containerSelection = d3.select(g[containerIndex])
295
+
296
+ const containerComputedSortedData$ = context.computedSortedData$.pipe(
297
+ takeUntil(destroy$),
298
+ map(data => data[containerIndex] ?? data[0])
299
+ )
300
+
301
+ const containerPosition$ = context.seriesContainerPosition$.pipe(
302
+ takeUntil(destroy$),
303
+ map(data => data[containerIndex] ?? data[0])
304
+ )
305
+
306
+ unsubscribeFnArr[containerIndex] = createEachPieEventTexts({
307
+ containerSelection: containerSelection,
308
+ computedData$: context.computedData$,
309
+ containerComputedSortedData$: containerComputedSortedData$,
310
+ SeriesDataMap$: context.SeriesDataMap$,
311
+ layerParams$: layerParams$,
312
+ pluginParams$: pluginParams$,
313
+ seriesHighlight$: context.seriesHighlight$,
314
+ seriesContainerPosition$: containerPosition$,
315
+ eventTrigger$: context.eventTrigger$,
316
+ })
317
+
318
+ })
319
+ })
320
+
321
+ return () => {
322
+ destroy$.next(undefined)
323
+ unsubscribeFnArr.forEach(fn => fn())
324
+ }
325
+ }
326
+ })