@orbcharts/plugins-basic 3.0.0-beta.15 → 3.0.0-beta.16

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 (180) hide show
  1. package/dist/orbcharts-plugins-basic.es.js +15129 -13927
  2. package/dist/orbcharts-plugins-basic.umd.js +72 -72
  3. package/dist/{orbcharts-plugins-basic/src → src}/base/BaseBars.d.ts +3 -3
  4. package/dist/{orbcharts-plugins-basic/src → src}/base/BaseBarsTriangle.d.ts +3 -3
  5. package/dist/{orbcharts-plugins-basic/src → src}/base/BaseDots.d.ts +3 -3
  6. package/dist/{orbcharts-plugins-basic/src → src}/base/BaseLineAreas.d.ts +3 -3
  7. package/dist/{orbcharts-plugins-basic/src → src}/base/BaseLines.d.ts +3 -3
  8. package/dist/src/base/BaseRacingBars.d.ts +23 -0
  9. package/dist/src/base/BaseRacingLabels.d.ts +20 -0
  10. package/dist/src/base/BaseRacingValueLabels.d.ts +20 -0
  11. package/dist/{orbcharts-plugins-basic/src/base/BaseStackedBar.d.ts → src/base/BaseStackedBars.d.ts} +7 -7
  12. package/dist/{orbcharts-plugins-basic/src → src}/base/BaseValueAxis.d.ts +4 -7
  13. package/dist/src/base/BaseXAxis.d.ts +20 -0
  14. package/dist/src/base/BaseYAxis.d.ts +18 -0
  15. package/dist/{orbcharts-plugins-basic/src → src}/grid/defaults.d.ts +3 -3
  16. package/dist/{orbcharts-plugins-basic/src → src}/grid/gridObservables.d.ts +8 -1
  17. package/dist/{orbcharts-plugins-basic/src → src}/grid/index.d.ts +2 -2
  18. package/dist/src/grid/plugins/GroupZoom.d.ts +1 -0
  19. package/dist/src/grid/plugins/StackedBars.d.ts +1 -0
  20. package/dist/src/index.d.ts +7 -1
  21. package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/defaults.d.ts +2 -2
  22. package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/index.d.ts +1 -1
  23. package/dist/src/multiGrid/plugins/MultiStackedBars.d.ts +1 -0
  24. package/dist/src/multiValue/defaults.d.ts +13 -0
  25. package/dist/{orbcharts-plugins-basic/src → src}/multiValue/index.d.ts +5 -1
  26. package/dist/src/multiValue/multiValueObservables.d.ts +56 -0
  27. package/dist/src/multiValue/plugins/RacingBars.d.ts +1 -0
  28. package/dist/src/multiValue/plugins/RacingCounterTexts.d.ts +3 -0
  29. package/dist/src/multiValue/plugins/RacingValueAxis.d.ts +1 -0
  30. package/dist/src/multiValue/plugins/XAxis.d.ts +1 -0
  31. package/dist/src/multiValue/plugins/XYAxes.d.ts +1 -0
  32. package/dist/src/multiValue/plugins/XZoom.d.ts +1 -0
  33. package/lib/core.ts +1 -1
  34. package/package.json +4 -4
  35. package/src/base/BaseBars.ts +11 -11
  36. package/src/base/BaseBarsTriangle.ts +11 -11
  37. package/src/base/BaseDots.ts +10 -10
  38. package/src/base/BaseGroupAxis.ts +2 -0
  39. package/src/base/BaseLineAreas.ts +8 -8
  40. package/src/base/BaseLines.ts +7 -7
  41. package/src/base/BaseRacingBars.ts +552 -0
  42. package/src/base/BaseRacingLabels.ts +392 -0
  43. package/src/base/BaseRacingValueLabels.ts +403 -0
  44. package/src/base/{BaseStackedBar.ts → BaseStackedBars.ts} +22 -22
  45. package/src/base/BaseValueAxis.ts +70 -53
  46. package/src/base/BaseXAxis.ts +427 -0
  47. package/src/base/BaseYAxis.ts +389 -0
  48. package/src/grid/defaults.ts +4 -56
  49. package/src/grid/gridObservables.ts +58 -0
  50. package/src/grid/index.ts +2 -2
  51. package/src/grid/plugins/Bars.ts +2 -2
  52. package/src/grid/plugins/BarsPN.ts +2 -2
  53. package/src/grid/plugins/BarsTriangle.ts +2 -2
  54. package/src/grid/plugins/Dots.ts +2 -2
  55. package/src/grid/plugins/GridLegend.ts +7 -7
  56. package/src/grid/plugins/GroupAxis.ts +0 -24
  57. package/src/grid/plugins/{GridZoom.ts → GroupZoom.ts} +2 -2
  58. package/src/grid/plugins/LineAreas.ts +2 -2
  59. package/src/grid/plugins/Lines.ts +2 -2
  60. package/src/grid/plugins/{StackedBar.ts → StackedBars.ts} +6 -6
  61. package/src/multiGrid/defaults.ts +2 -2
  62. package/src/multiGrid/index.ts +1 -1
  63. package/src/multiGrid/multiGridObservables.ts +1 -0
  64. package/src/multiGrid/plugins/MultiBars.ts +3 -3
  65. package/src/multiGrid/plugins/MultiBarsTriangle.ts +3 -3
  66. package/src/multiGrid/plugins/MultiDots.ts +3 -3
  67. package/src/multiGrid/plugins/MultiGridLegend.ts +20 -10
  68. package/src/multiGrid/plugins/MultiLineAreas.ts +3 -3
  69. package/src/multiGrid/plugins/MultiLines.ts +3 -3
  70. package/src/multiGrid/plugins/{MultiStackedBar.ts → MultiStackedBars.ts} +7 -7
  71. package/src/multiGrid/plugins/OverlappingStackedValueAxes.ts +1 -0
  72. package/src/multiValue/defaults.ts +137 -4
  73. package/src/multiValue/index.ts +5 -1
  74. package/src/multiValue/multiValueObservables.ts +414 -44
  75. package/src/multiValue/plugins/OrdinalBubbles.ts +0 -0
  76. package/src/multiValue/plugins/OrdinalXAxis.ts +0 -0
  77. package/src/multiValue/plugins/RacingBars.ts +362 -0
  78. package/src/multiValue/plugins/RacingCounterAxis.ts +0 -0
  79. package/src/multiValue/plugins/RacingCounterTexts.ts +300 -0
  80. package/src/multiValue/plugins/RacingValueAxis.ts +115 -0
  81. package/src/multiValue/plugins/RankingAxis_legacy.ts +109 -0
  82. package/src/multiValue/plugins/Scatter.ts +13 -13
  83. package/src/multiValue/plugins/ScatterBubbles.ts +13 -13
  84. package/src/multiValue/plugins/XAxis.ts +108 -0
  85. package/src/multiValue/plugins/XYAux.ts +13 -13
  86. package/src/multiValue/plugins/XYAxes.ts +38 -528
  87. package/src/multiValue/plugins/XYAxes_legacy.ts +684 -0
  88. package/src/multiValue/plugins/{XYZoom.ts → XZoom.ts} +14 -14
  89. package/src/series/defaults.ts +2 -13
  90. package/src/series/plugins/Bubbles.ts +45 -29
  91. package/src/series/plugins/Pie.ts +5 -5
  92. package/src/series/plugins/PieEventTexts.ts +3 -3
  93. package/src/series/plugins/PieLabels.ts +5 -5
  94. package/src/series/plugins/Rose.ts +11 -11
  95. package/src/series/plugins/RoseLabels.ts +9 -9
  96. package/dist/orbcharts-plugins-basic/src/grid/plugins/GridZoom.d.ts +0 -1
  97. package/dist/orbcharts-plugins-basic/src/grid/plugins/StackedBar.d.ts +0 -1
  98. package/dist/orbcharts-plugins-basic/src/index.d.ts +0 -7
  99. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiStackedBar.d.ts +0 -1
  100. package/dist/orbcharts-plugins-basic/src/multiValue/defaults.d.ts +0 -9
  101. package/dist/orbcharts-plugins-basic/src/multiValue/multiValueObservables.d.ts +0 -33
  102. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/XYZoom.d.ts +0 -1
  103. /package/dist/{orbcharts-plugins-basic/lib → lib}/core-types.d.ts +0 -0
  104. /package/dist/{orbcharts-plugins-basic/lib → lib}/core.d.ts +0 -0
  105. /package/dist/{orbcharts-plugins-basic/lib → lib}/plugins-basic-types.d.ts +0 -0
  106. /package/dist/{orbcharts-plugins-basic/src → src}/base/BaseGroupAxis.d.ts +0 -0
  107. /package/dist/{orbcharts-plugins-basic/src → src}/base/BaseLegend.d.ts +0 -0
  108. /package/dist/{orbcharts-plugins-basic/src → src}/base/BaseTooltip.d.ts +0 -0
  109. /package/dist/{orbcharts-plugins-basic/src → src}/base/types.d.ts +0 -0
  110. /package/dist/{orbcharts-plugins-basic/src → src}/const.d.ts +0 -0
  111. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/Bars.d.ts +0 -0
  112. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/BarsPN.d.ts +0 -0
  113. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/BarsTriangle.d.ts +0 -0
  114. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/Dots.d.ts +0 -0
  115. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/GridLegend.d.ts +0 -0
  116. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/GridTooltip.d.ts +0 -0
  117. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/GroupAux.d.ts +0 -0
  118. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/GroupAxis.d.ts +0 -0
  119. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/LineAreas.d.ts +0 -0
  120. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/Lines.d.ts +0 -0
  121. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/StackedValueAxis.d.ts +0 -0
  122. /package/dist/{orbcharts-plugins-basic/src → src}/grid/plugins/ValueAxis.d.ts +0 -0
  123. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/multiGridObservables.d.ts +0 -0
  124. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiBars.d.ts +0 -0
  125. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiBarsTriangle.d.ts +0 -0
  126. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiDots.d.ts +0 -0
  127. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiGridLegend.d.ts +0 -0
  128. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiGridTooltip.d.ts +0 -0
  129. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiGroupAxis.d.ts +0 -0
  130. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiLineAreas.d.ts +0 -0
  131. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiLines.d.ts +0 -0
  132. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiStackedValueAxis.d.ts +0 -0
  133. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/MultiValueAxis.d.ts +0 -0
  134. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/OverlappingStackedValueAxes.d.ts +0 -0
  135. /package/dist/{orbcharts-plugins-basic/src → src}/multiGrid/plugins/OverlappingValueAxes.d.ts +0 -0
  136. /package/dist/{orbcharts-plugins-basic/src → src}/multiValue/plugins/MultiValueLegend.d.ts +0 -0
  137. /package/dist/{orbcharts-plugins-basic/src → src}/multiValue/plugins/MultiValueTooltip.d.ts +0 -0
  138. /package/dist/{orbcharts-plugins-basic/src/multiValue/plugins/Ranking.d.ts → src/multiValue/plugins/OrdinalBubbles.d.ts} +0 -0
  139. /package/dist/{orbcharts-plugins-basic/src/multiValue/plugins/RankingAxis.d.ts → src/multiValue/plugins/OrdinalXAxis.d.ts} +0 -0
  140. /package/dist/{orbcharts-plugins-basic/src/noneData/plugins/Container.d.ts → src/multiValue/plugins/RacingCounterAxis.d.ts} +0 -0
  141. /package/dist/{orbcharts-plugins-basic/src/noneData/plugins/Tooltip.d.ts → src/multiValue/plugins/RankingAxis_legacy.d.ts} +0 -0
  142. /package/dist/{orbcharts-plugins-basic/src → src}/multiValue/plugins/Scatter.d.ts +0 -0
  143. /package/dist/{orbcharts-plugins-basic/src → src}/multiValue/plugins/ScatterBubbles.d.ts +0 -0
  144. /package/dist/{orbcharts-plugins-basic/src → src}/multiValue/plugins/XYAux.d.ts +0 -0
  145. /package/dist/{orbcharts-plugins-basic/src/multiValue/plugins/XYAxes.d.ts → src/multiValue/plugins/XYAxes_legacy.d.ts} +0 -0
  146. /package/dist/{orbcharts-plugins-basic/src → src}/noneData/defaults.d.ts +0 -0
  147. /package/dist/{orbcharts-plugins-basic/src → src}/noneData/index.d.ts +0 -0
  148. /package/dist/{orbcharts-plugins-basic/src/series/plugins/Waffle.d.ts → src/noneData/plugins/Container.d.ts} +0 -0
  149. /package/{src/multiValue/plugins/Ranking.ts → dist/src/noneData/plugins/Tooltip.d.ts} +0 -0
  150. /package/dist/{orbcharts-plugins-basic/src → src}/relationship/defaults.d.ts +0 -0
  151. /package/dist/{orbcharts-plugins-basic/src → src}/relationship/index.d.ts +0 -0
  152. /package/dist/{orbcharts-plugins-basic/src → src}/relationship/plugins/ForceDirected.d.ts +0 -0
  153. /package/dist/{orbcharts-plugins-basic/src → src}/relationship/plugins/ForceDirectedBubbles.d.ts +0 -0
  154. /package/dist/{orbcharts-plugins-basic/src → src}/relationship/plugins/RelationshipLegend.d.ts +0 -0
  155. /package/dist/{orbcharts-plugins-basic/src → src}/relationship/plugins/RelationshipTooltip.d.ts +0 -0
  156. /package/dist/{orbcharts-plugins-basic/src → src}/relationship/relationshipObservables.d.ts +0 -0
  157. /package/dist/{orbcharts-plugins-basic/src → src}/series/defaults.d.ts +0 -0
  158. /package/dist/{orbcharts-plugins-basic/src → src}/series/index.d.ts +0 -0
  159. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/Bubbles.d.ts +0 -0
  160. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/Pie.d.ts +0 -0
  161. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/PieEventTexts.d.ts +0 -0
  162. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/PieLabels.d.ts +0 -0
  163. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/Rose.d.ts +0 -0
  164. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/RoseLabels.d.ts +0 -0
  165. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/SeriesLegend.d.ts +0 -0
  166. /package/dist/{orbcharts-plugins-basic/src → src}/series/plugins/SeriesTooltip.d.ts +0 -0
  167. /package/{src/multiValue/plugins/RankingAxis.ts → dist/src/series/plugins/Waffle.d.ts} +0 -0
  168. /package/dist/{orbcharts-plugins-basic/src → src}/series/seriesObservables.d.ts +0 -0
  169. /package/dist/{orbcharts-plugins-basic/src → src}/series/seriesUtils.d.ts +0 -0
  170. /package/dist/{orbcharts-plugins-basic/src → src}/tree/defaults.d.ts +0 -0
  171. /package/dist/{orbcharts-plugins-basic/src → src}/tree/index.d.ts +0 -0
  172. /package/dist/{orbcharts-plugins-basic/src → src}/tree/plugins/TreeLegend.d.ts +0 -0
  173. /package/dist/{orbcharts-plugins-basic/src → src}/tree/plugins/TreeMap.d.ts +0 -0
  174. /package/dist/{orbcharts-plugins-basic/src → src}/tree/plugins/TreeTooltip.d.ts +0 -0
  175. /package/dist/{orbcharts-plugins-basic/src → src}/utils/commonUtils.d.ts +0 -0
  176. /package/dist/{orbcharts-plugins-basic/src → src}/utils/d3Graphics.d.ts +0 -0
  177. /package/dist/{orbcharts-plugins-basic/src → src}/utils/d3Utils.d.ts +0 -0
  178. /package/dist/{orbcharts-plugins-basic/src → src}/utils/observables.d.ts +0 -0
  179. /package/dist/{orbcharts-plugins-basic/src → src}/utils/orbchartsUtils.d.ts +0 -0
  180. /package/dist/{orbcharts-plugins-basic/vite.config.d.ts → vite.config.d.ts} +0 -0
@@ -0,0 +1,362 @@
1
+ import {
2
+ takeUntil,
3
+ combineLatest,
4
+ of,
5
+ iif,
6
+ interval,
7
+ map,
8
+ distinctUntilChanged,
9
+ shareReplay,
10
+ switchMap,
11
+ EMPTY,
12
+ Subject,
13
+ } from 'rxjs'
14
+ import type { Observable } from 'rxjs'
15
+ import type {
16
+ DefinePluginConfig,
17
+ } from '../../../lib/core-types'
18
+ import type { BaseRacingLabelsParams, BaseRacingBarsParams } from '../../../lib/plugins-basic-types'
19
+ import { defineMultiValuePlugin } from '../../../lib/core'
20
+ import { createBaseRacingLabels } from '../../base/BaseRacingLabels'
21
+ import { createBaseRacingValueLabels } from '../../base/BaseRacingValueLabels'
22
+ import { createBaseRacingBars } from '../../base/BaseRacingBars'
23
+ import { DEFAULT_RACING_BARS_PARAMS } from '../defaults'
24
+ import { LAYER_INDEX_OF_GRAPHIC } from '../../const'
25
+ import {
26
+ // visibleComputedSumDataObservable,
27
+ // visibleComputedRankingByIndexDataObservable,
28
+ // rankingAmountLimitObservable,
29
+ computedRankingAmountObservable,
30
+ rankingItemHeightObservable,
31
+ rankingScaleListObservable,
32
+ // computedRankingWithXYDataObservable
33
+ } from '../multiValueObservables'
34
+
35
+ const pluginName = 'RacingBars'
36
+
37
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_RACING_BARS_PARAMS> = {
38
+ name: pluginName,
39
+ defaultParams: DEFAULT_RACING_BARS_PARAMS,
40
+ layerIndex: LAYER_INDEX_OF_GRAPHIC,
41
+ validator: (params, { validateColumns }) => {
42
+ const result = validateColumns(params, {
43
+ bar: {
44
+ toBeTypes: ['object']
45
+ },
46
+ barLabel: {
47
+ toBeTypes: ['object']
48
+ },
49
+ valueLabel: {
50
+ toBeTypes: ['object']
51
+ },
52
+ // axisLabel: {
53
+ // toBeTypes: ['object']
54
+ // },
55
+ rankingAmount: {
56
+ toBe: 'number | "auto"',
57
+ test: (value: any) => {
58
+ return typeof value === 'number' || value === 'auto'
59
+ }
60
+ },
61
+ autorun: {
62
+ toBeTypes: ['boolean']
63
+ },
64
+ })
65
+ if (params.bar) {
66
+ const barResult = validateColumns(params.bar, {
67
+ barWidth: {
68
+ toBeTypes: ['number']
69
+ },
70
+ barPadding: {
71
+ toBeTypes: ['number']
72
+ },
73
+ barRadius: {
74
+ toBeTypes: ['number', 'boolean']
75
+ },
76
+ })
77
+ if (barResult.status === 'error') {
78
+ return barResult
79
+ }
80
+ }
81
+ if (params.barLabel) {
82
+ const barLabelResult = validateColumns(params.barLabel, {
83
+ position: {
84
+ toBe: '"inside" | "outside" | "none"',
85
+ test: (value: any) => {
86
+ return value === 'inside' || value === 'outside' || value === 'none'
87
+ }
88
+ },
89
+ padding: {
90
+ toBeTypes: ['number']
91
+ },
92
+ rotate: {
93
+ toBeTypes: ['number']
94
+ },
95
+ colorType: {
96
+ toBeOption: 'ColorType',
97
+ },
98
+ })
99
+ if (barLabelResult.status === 'error') {
100
+ return barLabelResult
101
+ }
102
+ }
103
+ if (params.valueLabel) {
104
+ const valueLabelResult = validateColumns(params.valueLabel, {
105
+ padding: {
106
+ toBeTypes: ['number']
107
+ },
108
+ colorType: {
109
+ toBeOption: 'ColorType',
110
+ },
111
+ format: {
112
+ toBeTypes: ['Function']
113
+ },
114
+ })
115
+ if (valueLabelResult.status === 'error') {
116
+ return valueLabelResult
117
+ }
118
+ }
119
+ // if (params.axisLabel) {
120
+ // const axisLabelResult = validateColumns(params.axisLabel, {
121
+ // offset: {
122
+ // toBe: '[number, number]',
123
+ // test: (value) => Array.isArray(value) && value.length === 2 && typeof value[0] === 'number' && typeof value[1] === 'number'
124
+ // },
125
+ // colorType: {
126
+ // toBeOption: 'ColorType',
127
+ // },
128
+ // })
129
+ // if (axisLabelResult.status === 'error') {
130
+ // return axisLabelResult
131
+ // }
132
+ // }
133
+ // if (params.timer) {
134
+ // const timerResult = validateColumns(params.timer, {
135
+ // active: {
136
+ // toBeTypes: ['boolean']
137
+ // },
138
+ // period: {
139
+ // toBeTypes: ['number']
140
+ // },
141
+ // })
142
+ // if (timerResult.status === 'error') {
143
+ // return timerResult
144
+ // }
145
+ // }
146
+ return result
147
+ }
148
+ }
149
+
150
+ export const RacingBars = defineMultiValuePlugin(pluginConfig)(({ selection, name, observer, subject }) => {
151
+
152
+ const baseRacingBarsSelection = selection.append('g').attr('class', `${pluginName}-bars`)
153
+ const baseRacingLabelsSelection = selection.append('g').attr('class', `${pluginName}-labels`)
154
+ const baseRacingValueLabelsSelection = selection.append('g').attr('class', `${pluginName}-valueLabels`)
155
+
156
+ const destroy$ = new Subject()
157
+
158
+ // const baseRacingLabelsParams$: Observable<BaseRacingLabelsParams> = observer.fullParams$.pipe(
159
+ // takeUntil(destroy$),
160
+ // map(params => {
161
+ // return {
162
+ // ...params,
163
+ // axisLabel: {
164
+ // offset: [0, 0],
165
+ // colorType: 'primary'
166
+ // }
167
+ // }
168
+ // })
169
+ // )
170
+
171
+ // const baseRacingBarsParams$: Observable<BaseRacingBarsParams> = observer.fullParams$.pipe(
172
+ // takeUntil(destroy$),
173
+ // map(params => {
174
+ // return {
175
+ // ...params
176
+ // }
177
+ // })
178
+ // )
179
+
180
+ const baseRacingValueLabelsParams$ = observer.fullParams$.pipe(
181
+ takeUntil(destroy$),
182
+ map(params => {
183
+ return params.valueLabel
184
+ })
185
+ )
186
+
187
+ const rankingAmount$ = observer.fullParams$.pipe(
188
+ takeUntil(destroy$),
189
+ map(p => p.rankingAmount),
190
+ distinctUntilChanged(),
191
+ )
192
+
193
+ const computedRankingAmount$ = computedRankingAmountObservable({
194
+ containerSize$: observer.containerSize$,
195
+ visibleComputedData$: observer.visibleComputedData$,
196
+ textSizePx$: observer.textSizePx$,
197
+ rankingAmount$
198
+ }).pipe(
199
+ takeUntil(destroy$),
200
+ shareReplay(1)
201
+ )
202
+
203
+ const rankingItemHeight$ = rankingItemHeightObservable({
204
+ containerSize$: observer.containerSize$,
205
+ // visibleComputedRankingData$: observer.visibleComputedRankingByIndexData$,
206
+ textSizePx$: observer.textSizePx$,
207
+ computedRankingAmount$
208
+ }).pipe(
209
+ takeUntil(destroy$),
210
+ shareReplay(1)
211
+ )
212
+
213
+ const rankingScaleList$ = rankingScaleListObservable({
214
+ visibleComputedRankingData$: observer.visibleComputedRankingByIndexData$,
215
+ rankingItemHeight$
216
+ }).pipe(
217
+ takeUntil(destroy$),
218
+ shareReplay(1)
219
+ )
220
+
221
+ // const computedRankingWithXYData$ = computedRankingWithXYDataObservable({
222
+ // visibleComputedRankingData$: observer.visibleComputedRankingByIndexData$,
223
+ // rankingScaleList$
224
+ // }).pipe(
225
+ // takeUntil(destroy$),
226
+ // )
227
+
228
+ // const xScale$ = combineLatest({
229
+ // xScale: observer.xScale$,
230
+ // layout: observer.layout$,
231
+ // containerSize: observer.containerSize$,
232
+ // }).pipe(
233
+ // takeUntil(destroy$),
234
+ // switchMap(async d => d),
235
+ // map(data => {
236
+ // // 原本的 xScale 是根據 layout 計算的,現在要根據 containerSize 重新計算
237
+ // const containerWidthScale = data.containerSize.width / data.layout.width
238
+
239
+ // return (n: number) => {
240
+ // const originWidth = data.xScale(n)
241
+ // if (originWidth == null) {
242
+ // return 0
243
+ // }
244
+ // return data.xScale(n) * containerWidthScale
245
+ // }
246
+ // }),
247
+ // shareReplay(1)
248
+ // )
249
+
250
+ const unsubscribeBaseRacingLabels = createBaseRacingLabels(`${pluginName}-labels`, {
251
+ selection: baseRacingLabelsSelection,
252
+ computedData$: observer.computedData$,
253
+ visibleComputedRankingData$: observer.visibleComputedRankingByIndexData$,
254
+ rankingScaleList$,
255
+ xScale$: observer.xScale$,
256
+ fullParams$: observer.fullParams$,
257
+ fullDataFormatter$: observer.fullDataFormatter$,
258
+ fullChartParams$: observer.fullChartParams$,
259
+ // layout$: observer.layout$,
260
+ containerPosition$: observer.containerPosition$,
261
+ containerSize$: observer.containerSize$,
262
+ isCategorySeprate$: observer.isCategorySeprate$,
263
+ // xyValueIndex$: observer.xyValueIndex$,
264
+ })
265
+
266
+ const unsubscribeBaseRacingValueLabels = createBaseRacingValueLabels(`${pluginName}-valueLabels`, {
267
+ selection: baseRacingValueLabelsSelection,
268
+ computedData$: observer.computedData$,
269
+ visibleComputedRankingData$: observer.visibleComputedRankingByIndexData$,
270
+ rankingScaleList$,
271
+ xScale$: observer.xScale$,
272
+ computedRankingAmount$,
273
+ fullParams$: baseRacingValueLabelsParams$,
274
+ // fullDataFormatter$: observer.fullDataFormatter$,
275
+ fullChartParams$: observer.fullChartParams$,
276
+ // layout$: observer.layout$,
277
+ containerPosition$: observer.containerPosition$,
278
+ containerSize$: observer.containerSize$,
279
+ isCategorySeprate$: observer.isCategorySeprate$,
280
+ // xyValueIndex$: observer.xyValueIndex$,
281
+ })
282
+
283
+ const unsubscribeBaseRacingBars = createBaseRacingBars(`${pluginName}-bars`, {
284
+ selection: baseRacingBarsSelection,
285
+ computedData$: observer.computedData$,
286
+ visibleComputedRankingData$: observer.visibleComputedRankingByIndexData$,
287
+ // xyValueIndex$: observer.xyValueIndex$,
288
+ CategoryDataMap$: observer.CategoryDataMap$,
289
+ fullParams$: observer.fullParams$,
290
+ fullChartParams$: observer.fullChartParams$,
291
+ highlight$: observer.highlight$,
292
+ rankingItemHeight$,
293
+ rankingScaleList$,
294
+ xScale$: observer.xScale$,
295
+ containerPosition$: observer.containerPosition$,
296
+ containerSize$: observer.containerSize$,
297
+ // layout$: observer.layout$,
298
+ isCategorySeprate$: observer.isCategorySeprate$,
299
+ event$: subject.event$,
300
+ })
301
+
302
+ const valueAmount$ = observer.visibleComputedRankingByIndexData$.pipe(
303
+ takeUntil(destroy$),
304
+ map(d => (d[0] && d[0][0] && d[0][0].value.length) ?? 0),
305
+ distinctUntilChanged()
306
+ )
307
+
308
+ const autorun$ = observer.fullParams$.pipe(
309
+ takeUntil(destroy$),
310
+ map(p => p.autorun),
311
+ distinctUntilChanged()
312
+ )
313
+
314
+ const tickDurationPeriod$ = observer.fullChartParams$.pipe(
315
+ takeUntil(destroy$),
316
+ map(p => p.transitionDuration),
317
+ distinctUntilChanged()
318
+ )
319
+
320
+ // -- autorun --
321
+ let toggle = true
322
+
323
+ combineLatest({
324
+ autorun: autorun$,
325
+ valueAmount: valueAmount$,
326
+ tickDurationPeriod: tickDurationPeriod$,
327
+ // xyValueIndex: observer.xyValueIndex$,
328
+ fullDataFormatter: observer.fullDataFormatter$,
329
+ }).pipe(
330
+ takeUntil(destroy$),
331
+ switchMap(async d => d)
332
+ ).subscribe(({ autorun, valueAmount, tickDurationPeriod, fullDataFormatter }) => {
333
+ if (toggle == false) {
334
+ return
335
+ }
336
+ if (autorun) {
337
+ const nextIndex = fullDataFormatter.xAxis.valueIndex + 1
338
+ if (nextIndex < valueAmount) {
339
+ toggle = false // timer 執行期間不可再次執行
340
+
341
+ setTimeout(() => {
342
+ subject.dataFormatter$.next({
343
+ ...fullDataFormatter,
344
+ xAxis: {
345
+ ...fullDataFormatter.xAxis,
346
+ valueIndex: nextIndex
347
+ }
348
+ })
349
+
350
+ toggle = true
351
+ }, tickDurationPeriod)
352
+ }
353
+ }
354
+ })
355
+
356
+ return () => {
357
+ destroy$.next(undefined)
358
+ unsubscribeBaseRacingLabels()
359
+ unsubscribeBaseRacingValueLabels()
360
+ unsubscribeBaseRacingBars()
361
+ }
362
+ })
File without changes
@@ -0,0 +1,300 @@
1
+ import * as d3 from 'd3'
2
+ import {
3
+ combineLatest,
4
+ switchMap,
5
+ first,
6
+ takeUntil,
7
+ map,
8
+ distinctUntilChanged,
9
+ shareReplay,
10
+ Observable,
11
+ Subject } from 'rxjs'
12
+ import type { DefinePluginConfig } from '../../../lib/core-types'
13
+ import type { Subscription } from 'rxjs'
14
+ import {
15
+ defineMultiValuePlugin} from '../../../lib/core'
16
+ import type {
17
+ ComputedDatumMultiValue,
18
+ ComputedDataMultiValue,
19
+ ChartParams,
20
+ ContainerPositionScaled,
21
+ ContainerSize
22
+ } from '../../../lib/core-types'
23
+ import type { RacingCounterTextsParams } from '../../../lib/plugins-basic-types'
24
+ import { DEFAULT_RACING_COUNTER_TEXTS_PARAMS } from '../defaults'
25
+ // import { getD3TransitionEase } from '../../utils/d3Utils'
26
+ import { getClassName } from '../../utils/orbchartsUtils'
27
+ import { LAYER_INDEX_OF_LABEL } from '../../const'
28
+
29
+ type TextDatum = {
30
+ text: string
31
+ attr: { [key:string]: any }
32
+ style: { [key:string]: any }
33
+ }
34
+
35
+ const pluginName = 'RacingCounterTexts'
36
+ const containerClassName = getClassName(pluginName, 'container')
37
+ const boxClassName = getClassName(pluginName, 'box')
38
+ const textClassName = getClassName(pluginName, 'text')
39
+
40
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_RACING_COUNTER_TEXTS_PARAMS> = {
41
+ name: pluginName,
42
+ defaultParams: DEFAULT_RACING_COUNTER_TEXTS_PARAMS,
43
+ layerIndex: LAYER_INDEX_OF_LABEL,
44
+ validator: (params, { validateColumns }) => {
45
+ const result = validateColumns(params, {
46
+ renderFn: {
47
+ toBeTypes: ['Function'],
48
+ },
49
+ textAttrs: {
50
+ toBeTypes: ['object[]'],
51
+ },
52
+ textStyles: {
53
+ toBeTypes: ['object[]'],
54
+ },
55
+ paddingRight: {
56
+ toBeTypes: ['number']
57
+ },
58
+ paddingBottom: {
59
+ toBeTypes: ['number']
60
+ },
61
+ })
62
+ return result
63
+ }
64
+ }
65
+
66
+ function renderText ({ selection, data, fullParams, containerSize }: {
67
+ selection: d3.Selection<SVGGElement, unknown, any, any>,
68
+ data: Array<TextDatum>
69
+ fullParams: RacingCounterTextsParams,
70
+ containerSize: ContainerSize
71
+ }): d3.Selection<SVGTextElement, TextDatum, SVGGElement, unknown> {
72
+
73
+ const x = containerSize.width - fullParams.paddingRight
74
+ const y = containerSize.height - fullParams.paddingBottom
75
+
76
+ const gSelection = selection
77
+ .selectAll<SVGGElement, unknown>(`g.${boxClassName}`)
78
+ .data([boxClassName])
79
+ .join('g')
80
+ .classed(boxClassName, true)
81
+ .attr('transform', `translate(${x}, ${y})`)
82
+ .each((d, i, g) => {
83
+ const _g = d3.select(g[i])
84
+ const textSelection = _g.selectAll<SVGTextElement, TextDatum>(`text.${textClassName}`)
85
+ .data(data)
86
+ .join('text')
87
+ .classed(textClassName, true)
88
+ .each((d, i, g) => {
89
+ const t = d3.select(g[i])
90
+ .text(d.text)
91
+ Object.keys(d.attr)
92
+ .forEach(key => {
93
+ t.attr(key, d.attr[key])
94
+ })
95
+ Object.keys(d.style)
96
+ .forEach(key => {
97
+ t.style(key, d.style[key])
98
+ })
99
+ })
100
+ })
101
+
102
+ return gSelection.selectAll<SVGTextElement, TextDatum>(`text.${textClassName}`)
103
+ }
104
+
105
+ function createTextData ({ computedData, valueLabel, valueIndex, renderFn, textAttrs, textStyles }: {
106
+ computedData: ComputedDataMultiValue
107
+ valueLabel: string
108
+ valueIndex: number
109
+ // eventData: EventMultiValue,
110
+ // t: number,
111
+ renderFn: (valueLabel: string, valueIndex: number, data: ComputedDataMultiValue) => string[] | string
112
+ textAttrs: Array<{ [key:string]: string | number }>
113
+ textStyles: Array<{ [key:string]: string | number }>
114
+ }): TextDatum[] {
115
+ const text = valueLabel || String(valueIndex) // 如果沒有文字就跑數字
116
+ const callbackText = renderFn(text, valueIndex, computedData)
117
+ const textArr = Array.isArray(callbackText) ? callbackText : [callbackText]
118
+ return textArr.map((d, i) => {
119
+ return {
120
+ text: d,
121
+ attr: textAttrs[i],
122
+ style: textStyles[i]
123
+ }
124
+ })
125
+ }
126
+
127
+ function createEachPieEventTexts (pluginName: string, context: {
128
+ containerSelection: d3.Selection<SVGGElement, any, any, unknown>
129
+ textData$: Observable<TextDatum[]>
130
+ // computedData$: Observable<ComputedDatumMultiValue[][]>
131
+ // containerComputedSortedData$: Observable<ComputedDatumMultiValue[]>
132
+ // CategoryDataMap$: Observable<Map<string, ComputedDatumMultiValue[]>>
133
+ fullParams$: Observable<RacingCounterTextsParams>
134
+ // fullChartParams$: Observable<ChartParams>
135
+ xyValueIndex$: Observable<[number, number]>
136
+ valueLabel$: Observable<string>
137
+ // multiValueHighlight$: Observable<ComputedDatumMultiValue[]>
138
+ // multiValueContainerPosition$: Observable<ContainerPositionScaled>
139
+ // event$: Subject<EventMultiValue>
140
+ containerSize$: Observable<ContainerSize>
141
+ }) {
142
+ const destroy$ = new Subject()
143
+
144
+ let textSelection: d3.Selection<SVGTextElement, TextDatum, SVGGElement, unknown> | undefined
145
+
146
+ combineLatest({
147
+ textData: context.textData$,
148
+ fullParams: context.fullParams$,
149
+ containerSize: context.containerSize$,
150
+ }).pipe(
151
+ takeUntil(destroy$),
152
+ ).subscribe(data => {
153
+ textSelection = renderText({
154
+ selection: context.containerSelection,
155
+ data: data.textData,
156
+ fullParams: data.fullParams,
157
+ containerSize: data.containerSize
158
+ })
159
+ })
160
+
161
+ return () => {
162
+ destroy$.next(undefined)
163
+ }
164
+ }
165
+
166
+ export const RacingCounterTexts = defineMultiValuePlugin(pluginConfig)(({ selection, name, observer, subject }) => {
167
+ const destroy$ = new Subject()
168
+
169
+ const containerSelection$ = combineLatest({
170
+ computedData: observer.computedData$.pipe(
171
+ distinctUntilChanged((a, b) => {
172
+ // 只有當series的數量改變時,才重新計算
173
+ return a.length === b.length
174
+ }),
175
+ ),
176
+ isCategorySeprate: observer.isCategorySeprate$
177
+ }).pipe(
178
+ takeUntil(destroy$),
179
+ switchMap(async (d) => d),
180
+ map(data => {
181
+ return data.isCategorySeprate
182
+ // category分開的時候顯示各別axis
183
+ ? data.computedData
184
+ // category合併的時候只顯示第一個axis
185
+ : [data.computedData[0]]
186
+ }),
187
+ map((computedData, i) => {
188
+ return selection
189
+ .selectAll<SVGGElement, ComputedDatumMultiValue[]>(`g.${containerClassName}`)
190
+ .data(computedData, d => d[0] ? d[0].categoryIndex : i)
191
+ .join('g')
192
+ .classed(containerClassName, true)
193
+ })
194
+ )
195
+
196
+ const axisSelection$ = containerSelection$.pipe(
197
+ takeUntil(destroy$),
198
+ map((containerSelection, i) => {
199
+ return containerSelection
200
+ .selectAll<SVGGElement, ComputedDatumMultiValue[]>(`g.${boxClassName}`)
201
+ .data([boxClassName])
202
+ .join('g')
203
+ .classed(boxClassName, true)
204
+ })
205
+ )
206
+
207
+ combineLatest({
208
+ containerSelection: containerSelection$,
209
+ gridContainerPosition: observer.containerPosition$
210
+ }).pipe(
211
+ takeUntil(destroy$),
212
+ switchMap(async d => d)
213
+ ).subscribe(data => {
214
+ data.containerSelection
215
+ .attr('transform', (d, i) => {
216
+ const gridContainerPosition = data.gridContainerPosition[i] ?? data.gridContainerPosition[0]
217
+ const translate = gridContainerPosition.translate
218
+ const scale = gridContainerPosition.scale
219
+ // return `translate(${translate[0]}, ${translate[1]}) scale(${scale[0]}, ${scale[1]})`
220
+ return `translate(${translate[0]}, ${translate[1]})`
221
+ })
222
+ // .attr('opacity', 0)
223
+ // .transition()
224
+ // .attr('opacity', 1)
225
+ })
226
+
227
+
228
+ const valueLabel$ = combineLatest({
229
+ xyValueIndex: observer.xyValueIndex$,
230
+ fullDataFormatter: observer.fullDataFormatter$,
231
+ }).pipe(
232
+ takeUntil(destroy$),
233
+ switchMap(async d => d),
234
+ map(d => d.fullDataFormatter.valueLabels[d.xyValueIndex[0]] ?? ''),
235
+ distinctUntilChanged(),
236
+ shareReplay(1)
237
+ )
238
+
239
+ const textData$ = combineLatest({
240
+ xyValueIndex: observer.xyValueIndex$,
241
+ valueLabel: valueLabel$,
242
+ computedData: observer.computedData$,
243
+ fullParams: observer.fullParams$,
244
+ }).pipe(
245
+ takeUntil(destroy$),
246
+ switchMap(async d => d),
247
+ map(data => {
248
+ return createTextData({
249
+ valueIndex: data.xyValueIndex[0],
250
+ valueLabel: data.valueLabel,
251
+ computedData: data.computedData,
252
+ renderFn: data.fullParams.renderFn!,
253
+ textAttrs: data.fullParams.textAttrs!,
254
+ textStyles: data.fullParams.textStyles!,
255
+ })
256
+ }),
257
+ shareReplay(1)
258
+ )
259
+
260
+ const unsubscribeFnArr: (() => void)[] = []
261
+
262
+ containerSelection$
263
+ .pipe(
264
+ takeUntil(destroy$)
265
+ )
266
+ .subscribe(seriesCenterSelection => {
267
+ // 每次重新計算時,清除之前的訂閱
268
+ unsubscribeFnArr.forEach(fn => fn())
269
+
270
+ seriesCenterSelection.each((d, containerIndex, g) => {
271
+
272
+ const containerSelection = d3.select(g[containerIndex])
273
+
274
+ const containerComputedData$ = observer.visibleComputedRankingByIndexData$.pipe(
275
+ takeUntil(destroy$),
276
+ map(data => data[containerIndex] ?? data[0])
277
+ )
278
+
279
+ const containerPosition$ = observer.containerPosition$.pipe(
280
+ takeUntil(destroy$),
281
+ map(data => data[containerIndex] ?? data[0])
282
+ )
283
+
284
+ unsubscribeFnArr[containerIndex] = createEachPieEventTexts(pluginName, {
285
+ containerSelection: containerSelection,
286
+ textData$: textData$,
287
+ fullParams$: observer.fullParams$,
288
+ valueLabel$: valueLabel$,
289
+ xyValueIndex$: observer.xyValueIndex$,
290
+ containerSize$: observer.containerSize$
291
+ })
292
+
293
+ })
294
+ })
295
+
296
+ return () => {
297
+ destroy$.next(undefined)
298
+ unsubscribeFnArr.forEach(fn => fn())
299
+ }
300
+ })