@orbcharts/plugins-basic 3.0.0-beta.2 → 3.0.0-beta.20

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 (182) hide show
  1. package/LICENSE +200 -200
  2. package/dist/orbcharts-plugins-basic.es.js +15169 -10684
  3. package/dist/orbcharts-plugins-basic.umd.js +296 -83
  4. package/dist/src/base/BaseBars.d.ts +4 -4
  5. package/dist/src/base/BaseBarsTriangle.d.ts +4 -4
  6. package/dist/src/base/BaseDots.d.ts +4 -4
  7. package/dist/src/base/BaseGroupAxis.d.ts +2 -2
  8. package/dist/src/base/BaseLegend.d.ts +1 -1
  9. package/dist/src/base/BaseLineAreas.d.ts +5 -5
  10. package/dist/src/base/BaseLines.d.ts +5 -5
  11. package/dist/src/base/BaseRacingBars.d.ts +23 -0
  12. package/dist/src/base/BaseRacingLabels.d.ts +20 -0
  13. package/dist/src/base/BaseRacingValueLabels.d.ts +20 -0
  14. package/dist/src/base/{BaseBarStack.d.ts → BaseStackedBars.d.ts} +8 -8
  15. package/dist/src/base/BaseValueAxis.d.ts +6 -8
  16. package/dist/src/base/BaseXAxis.d.ts +20 -0
  17. package/dist/src/base/BaseYAxis.d.ts +18 -0
  18. package/dist/src/grid/defaults.d.ts +5 -5
  19. package/dist/src/grid/gridObservables.d.ts +12 -5
  20. package/dist/src/grid/index.d.ts +3 -3
  21. package/dist/src/grid/plugins/GroupZoom.d.ts +1 -0
  22. package/dist/src/grid/plugins/StackedBars.d.ts +1 -0
  23. package/dist/src/grid/plugins/StackedValueAxis.d.ts +1 -0
  24. package/dist/src/index.d.ts +2 -0
  25. package/dist/src/multiGrid/defaults.d.ts +4 -4
  26. package/dist/src/multiGrid/index.d.ts +3 -3
  27. package/dist/src/multiGrid/plugins/MultiStackedBars.d.ts +1 -0
  28. package/dist/src/multiGrid/plugins/MultiStackedValueAxis.d.ts +1 -0
  29. package/dist/src/multiGrid/plugins/OverlappingStackedValueAxes.d.ts +1 -0
  30. package/dist/src/multiValue/defaults.d.ts +13 -0
  31. package/dist/src/multiValue/index.d.ts +12 -0
  32. package/dist/src/multiValue/multiValueObservables.d.ts +56 -0
  33. package/dist/src/multiValue/plugins/MultiValueLegend.d.ts +1 -0
  34. package/dist/src/multiValue/plugins/MultiValueTooltip.d.ts +1 -0
  35. package/dist/src/multiValue/plugins/RacingBars.d.ts +1 -0
  36. package/dist/src/multiValue/plugins/RacingCounterTexts.d.ts +3 -0
  37. package/dist/src/multiValue/plugins/RacingValueAxis.d.ts +1 -0
  38. package/dist/src/multiValue/plugins/Scatter.d.ts +3 -0
  39. package/dist/src/multiValue/plugins/ScatterBubbles.d.ts +3 -0
  40. package/dist/src/multiValue/plugins/XAxis.d.ts +1 -0
  41. package/dist/src/multiValue/plugins/XYAux.d.ts +3 -0
  42. package/dist/src/multiValue/plugins/XYAxes.d.ts +1 -0
  43. package/dist/src/multiValue/plugins/XYAxes_legacy.d.ts +3 -0
  44. package/dist/src/multiValue/plugins/XZoom.d.ts +1 -0
  45. package/dist/src/noneData/plugins/Container.d.ts +0 -1
  46. package/dist/src/noneData/plugins/Tooltip.d.ts +0 -3
  47. package/dist/src/relationship/defaults.d.ts +6 -0
  48. package/dist/src/relationship/index.d.ts +5 -0
  49. package/dist/src/relationship/plugins/ForceDirected.d.ts +3 -0
  50. package/dist/src/relationship/plugins/ForceDirectedBubbles.d.ts +3 -0
  51. package/dist/src/relationship/plugins/RelationshipLegend.d.ts +1 -0
  52. package/dist/src/relationship/plugins/RelationshipTooltip.d.ts +1 -0
  53. package/dist/src/relationship/relationshipObservables.d.ts +1 -0
  54. package/dist/src/series/seriesObservables.d.ts +3 -3
  55. package/dist/src/utils/commonUtils.d.ts +2 -1
  56. package/dist/src/utils/d3Graphics.d.ts +2 -1
  57. package/dist/src/utils/d3Utils.d.ts +3 -2
  58. package/dist/src/utils/observables.d.ts +1 -1
  59. package/dist/src/utils/orbchartsUtils.d.ts +3 -3
  60. package/lib/core-types.ts +7 -7
  61. package/lib/core.ts +6 -6
  62. package/lib/plugins-basic-types.ts +6 -6
  63. package/package.json +44 -44
  64. package/src/base/BaseBars.ts +765 -765
  65. package/src/base/BaseBarsTriangle.ts +676 -674
  66. package/src/base/BaseDots.ts +464 -515
  67. package/src/base/BaseGroupAxis.ts +691 -679
  68. package/src/base/BaseLegend.ts +684 -680
  69. package/src/base/BaseLineAreas.ts +629 -629
  70. package/src/base/BaseLines.ts +706 -706
  71. package/src/base/BaseRacingBars.ts +552 -0
  72. package/src/base/BaseRacingLabels.ts +396 -0
  73. package/src/base/BaseRacingValueLabels.ts +403 -0
  74. package/src/base/{BaseBarStack.ts → BaseStackedBars.ts} +782 -780
  75. package/src/base/BaseTooltip.ts +386 -385
  76. package/src/base/BaseValueAxis.ts +600 -580
  77. package/src/base/BaseXAxis.ts +427 -0
  78. package/src/base/BaseYAxis.ts +389 -0
  79. package/src/base/types.ts +2 -2
  80. package/src/const.ts +30 -30
  81. package/src/grid/defaults.ts +213 -244
  82. package/src/grid/gridObservables.ts +612 -545
  83. package/src/grid/index.ts +16 -16
  84. package/src/grid/plugins/Bars.ts +69 -69
  85. package/src/grid/plugins/BarsPN.ts +66 -66
  86. package/src/grid/plugins/BarsTriangle.ts +73 -73
  87. package/src/grid/plugins/Dots.ts +68 -68
  88. package/src/grid/plugins/GridLegend.ts +107 -107
  89. package/src/grid/plugins/GridTooltip.ts +66 -66
  90. package/src/grid/plugins/GroupAux.ts +1120 -1098
  91. package/src/grid/plugins/GroupAxis.ts +73 -97
  92. package/src/grid/plugins/{GridZoom.ts → GroupZoom.ts} +218 -218
  93. package/src/grid/plugins/LineAreas.ts +65 -65
  94. package/src/grid/plugins/Lines.ts +59 -59
  95. package/src/grid/plugins/{BarStack.ts → StackedBars.ts} +64 -64
  96. package/src/grid/plugins/{ValueStackAxis.ts → StackedValueAxis.ts} +96 -95
  97. package/src/grid/plugins/ValueAxis.ts +94 -93
  98. package/src/index.ts +6 -9
  99. package/src/multiGrid/defaults.ts +244 -224
  100. package/src/multiGrid/index.ts +15 -15
  101. package/src/multiGrid/multiGridObservables.ts +50 -49
  102. package/src/multiGrid/plugins/MultiBars.ts +108 -108
  103. package/src/multiGrid/plugins/MultiBarsTriangle.ts +114 -114
  104. package/src/multiGrid/plugins/MultiDots.ts +102 -102
  105. package/src/multiGrid/plugins/MultiGridLegend.ts +169 -159
  106. package/src/multiGrid/plugins/MultiGridTooltip.ts +66 -66
  107. package/src/multiGrid/plugins/MultiGroupAxis.ts +137 -137
  108. package/src/multiGrid/plugins/MultiLineAreas.ts +107 -107
  109. package/src/multiGrid/plugins/MultiLines.ts +101 -101
  110. package/src/multiGrid/plugins/{MultiBarStack.ts → MultiStackedBars.ts} +106 -106
  111. package/src/multiGrid/plugins/{MultiValueStackAxis.ts → MultiStackedValueAxis.ts} +134 -133
  112. package/src/multiGrid/plugins/MultiValueAxis.ts +134 -133
  113. package/src/multiGrid/plugins/{OverlappingValueStackAxes.ts → OverlappingStackedValueAxes.ts} +300 -298
  114. package/src/multiGrid/plugins/OverlappingValueAxes.ts +300 -299
  115. package/src/multiValue/defaults.ts +432 -0
  116. package/src/multiValue/index.ts +13 -0
  117. package/src/multiValue/multiValueObservables.ts +667 -0
  118. package/src/multiValue/plugins/MultiValueLegend.ts +107 -0
  119. package/src/multiValue/plugins/MultiValueTooltip.ts +66 -0
  120. package/src/multiValue/plugins/RacingBars.ts +373 -0
  121. package/src/multiValue/plugins/RacingCounterTexts.ts +300 -0
  122. package/src/multiValue/plugins/RacingValueAxis.ts +115 -0
  123. package/src/multiValue/plugins/RankingAxis_legacy.ts +109 -0
  124. package/src/multiValue/plugins/Scatter.ts +426 -0
  125. package/src/multiValue/plugins/ScatterBubbles.ts +554 -0
  126. package/src/multiValue/plugins/XAxis.ts +108 -0
  127. package/src/multiValue/plugins/XYAux.ts +683 -0
  128. package/src/multiValue/plugins/XYAxes.ts +195 -0
  129. package/src/multiValue/plugins/XYAxes_legacy.ts +684 -0
  130. package/src/multiValue/plugins/XZoom.ts +300 -0
  131. package/src/noneData/defaults.ts +102 -102
  132. package/src/noneData/index.ts +3 -3
  133. package/src/noneData/plugins/Container.ts +28 -28
  134. package/src/noneData/plugins/Tooltip.ts +374 -374
  135. package/src/relationship/defaults.ts +222 -0
  136. package/src/relationship/index.ts +5 -0
  137. package/src/relationship/plugins/ForceDirected.ts +1174 -0
  138. package/src/relationship/plugins/ForceDirectedBubbles.ts +1412 -0
  139. package/src/relationship/plugins/RelationshipLegend.ts +100 -0
  140. package/src/relationship/plugins/RelationshipTooltip.ts +66 -0
  141. package/src/relationship/relationshipObservables.ts +50 -0
  142. package/src/series/defaults.ts +221 -206
  143. package/src/series/index.ts +9 -9
  144. package/src/series/plugins/Bubbles.ts +636 -603
  145. package/src/series/plugins/Pie.ts +623 -623
  146. package/src/series/plugins/PieEventTexts.ts +284 -283
  147. package/src/series/plugins/PieLabels.ts +640 -640
  148. package/src/series/plugins/Rose.ts +516 -516
  149. package/src/series/plugins/RoseLabels.ts +600 -600
  150. package/src/series/plugins/SeriesLegend.ts +107 -107
  151. package/src/series/plugins/SeriesTooltip.ts +66 -66
  152. package/src/series/seriesObservables.ts +145 -145
  153. package/src/series/seriesUtils.ts +51 -51
  154. package/src/tree/defaults.ts +102 -78
  155. package/src/tree/index.ts +4 -4
  156. package/src/tree/plugins/TreeLegend.ts +100 -107
  157. package/src/tree/plugins/TreeMap.ts +341 -333
  158. package/src/tree/plugins/TreeTooltip.ts +66 -66
  159. package/src/utils/commonUtils.ts +31 -22
  160. package/src/utils/d3Graphics.ts +176 -174
  161. package/src/utils/d3Utils.ts +92 -73
  162. package/src/utils/observables.ts +14 -14
  163. package/src/utils/orbchartsUtils.ts +130 -100
  164. package/tsconfig.base.json +13 -13
  165. package/tsconfig.json +2 -2
  166. package/vite.config.js +22 -22
  167. package/dist/src/grid/plugins/BarStack.d.ts +0 -1
  168. package/dist/src/grid/plugins/GridZoom.d.ts +0 -1
  169. package/dist/src/grid/plugins/ValueStackAxis.d.ts +0 -1
  170. package/dist/src/multiGrid/plugins/MultiBarStack.d.ts +0 -1
  171. package/dist/src/multiGrid/plugins/MultiValueStackAxis.d.ts +0 -1
  172. package/dist/src/multiGrid/plugins/OverlappingValueStackAxes.d.ts +0 -1
  173. package/src/grid/plugins/RankingAxis.ts +0 -0
  174. package/src/multiValue/plugins/ScatterAxes.ts +0 -0
  175. package/src/relationship/plugins/Relationship.ts +0 -0
  176. /package/dist/src/{base/BaseGroupArea.d.ts → multiValue/plugins/OrdinalBubbles.d.ts} +0 -0
  177. /package/dist/src/{grid/plugins/Ranking.d.ts → multiValue/plugins/OrdinalXAxis.d.ts} +0 -0
  178. /package/dist/src/{grid/plugins/RankingAxis.d.ts → multiValue/plugins/RacingCounterAxis.d.ts} +0 -0
  179. /package/dist/src/multiValue/plugins/{ScatterAxes.d.ts → RankingAxis_legacy.d.ts} +0 -0
  180. /package/{dist/src/relationship/plugins/Relationship.d.ts → src/multiValue/plugins/OrdinalBubbles.ts} +0 -0
  181. /package/src/{base/BaseGroupArea.ts → multiValue/plugins/OrdinalXAxis.ts} +0 -0
  182. /package/src/{grid/plugins/Ranking.ts → multiValue/plugins/RacingCounterAxis.ts} +0 -0
@@ -0,0 +1,107 @@
1
+ import * as d3 from 'd3'
2
+ import {
3
+ combineLatest,
4
+ map,
5
+ switchMap,
6
+ takeUntil,
7
+ Observable,
8
+ Subject } from 'rxjs'
9
+ import type { DefinePluginConfig } from '../../../lib/core-types'
10
+ import {
11
+ defineMultiValuePlugin } from '../../../lib/core'
12
+ import { DEFAULT_MULTI_VALUE_LEGEND_PARAMS } from '../defaults'
13
+ import { createBaseLegend } from '../../base/BaseLegend'
14
+ import { LAYER_INDEX_OF_INFO } from '../../const'
15
+
16
+ const pluginName = 'MultiValueLegend'
17
+
18
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_VALUE_LEGEND_PARAMS> = {
19
+ name: pluginName,
20
+ defaultParams: DEFAULT_MULTI_VALUE_LEGEND_PARAMS,
21
+ layerIndex: LAYER_INDEX_OF_INFO,
22
+ validator: (params, { validateColumns }) => {
23
+ const result = validateColumns(params, {
24
+ placement: {
25
+ toBe: '"top" | "top-start" | "top-end" | "bottom" | "bottom-start" | "bottom-end" | "left" | "left-start" | "left-end" | "right" | "right-start" | "right-end"',
26
+ test: (value) => {
27
+ return [
28
+ 'top', 'top-start', 'top-end',
29
+ 'bottom', 'bottom-start', 'bottom-end',
30
+ 'left', 'left-start', 'left-end',
31
+ 'right', 'right-start', 'right-end'
32
+ ].includes(value)
33
+ }
34
+ },
35
+ padding: {
36
+ toBeTypes: ['number']
37
+ },
38
+ backgroundFill: {
39
+ toBeOption: 'ColorType',
40
+ },
41
+ backgroundStroke: {
42
+ toBeOption: 'ColorType',
43
+ },
44
+ gap: {
45
+ toBeTypes: ['number']
46
+ },
47
+ listRectWidth: {
48
+ toBeTypes: ['number']
49
+ },
50
+ listRectHeight: {
51
+ toBeTypes: ['number']
52
+ },
53
+ listRectRadius: {
54
+ toBeTypes: ['number']
55
+ },
56
+ textColorType: {
57
+ toBeOption: 'ColorType',
58
+ }
59
+ })
60
+ return result
61
+ }
62
+ }
63
+
64
+ export const MultiValueLegend = defineMultiValuePlugin(pluginConfig)(({ selection, rootSelection, observer, subject }) => {
65
+
66
+ const destroy$ = new Subject()
67
+
68
+ const categoryLabels$: Observable<string[]> = observer.CategoryDataMap$.pipe(
69
+ takeUntil(destroy$),
70
+ map(data => {
71
+ return Array.from(data.keys())
72
+ })
73
+ )
74
+
75
+ // 全部列點矩型使用相同樣式參數
76
+ const fullParams$ = observer.fullParams$.pipe(
77
+ takeUntil(destroy$),
78
+ map(d => {
79
+ const labelList = [
80
+ {
81
+ listRectWidth: d.listRectWidth,
82
+ listRectHeight: d.listRectHeight,
83
+ listRectRadius: d.listRectRadius,
84
+ }
85
+ ]
86
+ return {
87
+ ...d,
88
+ labelList
89
+ }
90
+ })
91
+ )
92
+
93
+ const unsubscribeBaseLegend = createBaseLegend(pluginName, {
94
+ rootSelection,
95
+ legendLabels$: categoryLabels$,
96
+ fullParams$,
97
+ layout$: observer.layout$,
98
+ fullChartParams$: observer.fullChartParams$,
99
+ textSizePx$: observer.textSizePx$
100
+ })
101
+
102
+ return () => {
103
+ destroy$.next(undefined)
104
+ unsubscribeBaseLegend()
105
+ }
106
+ })
107
+
@@ -0,0 +1,66 @@
1
+ import {
2
+ Subject,
3
+ } from 'rxjs'
4
+ import type { DefinePluginConfig } from '../../../lib/core-types'
5
+ import {
6
+ defineMultiValuePlugin } from '../../../lib/core'
7
+ import { DEFAULT_MULTI_VALUE_TOOLTIP_PARAMS } from '../defaults'
8
+ import { LAYER_INDEX_OF_TOOLTIP } from '../../const'
9
+ import { createBaseTooltip } from '../../base/BaseTooltip'
10
+
11
+ const pluginName = 'MultiValueTooltip'
12
+
13
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_VALUE_TOOLTIP_PARAMS> = {
14
+ name: pluginName,
15
+ defaultParams: DEFAULT_MULTI_VALUE_TOOLTIP_PARAMS,
16
+ layerIndex: LAYER_INDEX_OF_TOOLTIP,
17
+ validator: (params, { validateColumns }) => {
18
+ const result = validateColumns(params, {
19
+ backgroundColorType: {
20
+ toBeOption: 'ColorType',
21
+ },
22
+ backgroundOpacity: {
23
+ toBeTypes: ['number']
24
+ },
25
+ strokeColorType: {
26
+ toBeOption: 'ColorType',
27
+ },
28
+ offset: {
29
+ toBe: '[number, number]',
30
+ test: (value: any) => {
31
+ return Array.isArray(value)
32
+ && value.length === 2
33
+ && typeof value[0] === 'number'
34
+ && typeof value[1] === 'number'
35
+ }
36
+ },
37
+ padding: {
38
+ toBeTypes: ['number']
39
+ },
40
+ textColorType: {
41
+ toBeOption: 'ColorType',
42
+ },
43
+ renderFn: {
44
+ toBeTypes: ['Function']
45
+ },
46
+ })
47
+ return result
48
+ }
49
+ }
50
+
51
+ export const MultiValueTooltip = defineMultiValuePlugin(pluginConfig)(({ selection, rootSelection, name, subject, observer }) => {
52
+ const destroy$ = new Subject()
53
+
54
+ const unsubscribeTooltip = createBaseTooltip(pluginName, {
55
+ rootSelection,
56
+ fullParams$: observer.fullParams$,
57
+ fullChartParams$: observer.fullChartParams$,
58
+ layout$: observer.layout$,
59
+ event$: subject.event$,
60
+ })
61
+
62
+ return () => {
63
+ destroy$.next(undefined)
64
+ unsubscribeTooltip()
65
+ }
66
+ })
@@ -0,0 +1,373 @@
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
+ loop: {
65
+ toBeTypes: ['boolean']
66
+ },
67
+ })
68
+ if (params.bar) {
69
+ const barResult = validateColumns(params.bar, {
70
+ barWidth: {
71
+ toBeTypes: ['number']
72
+ },
73
+ barPadding: {
74
+ toBeTypes: ['number']
75
+ },
76
+ barRadius: {
77
+ toBeTypes: ['number', 'boolean']
78
+ },
79
+ })
80
+ if (barResult.status === 'error') {
81
+ return barResult
82
+ }
83
+ }
84
+ if (params.barLabel) {
85
+ const barLabelResult = validateColumns(params.barLabel, {
86
+ position: {
87
+ toBe: '"inside" | "outside" | "none"',
88
+ test: (value: any) => {
89
+ return value === 'inside' || value === 'outside' || value === 'none'
90
+ }
91
+ },
92
+ padding: {
93
+ toBeTypes: ['number']
94
+ },
95
+ rotate: {
96
+ toBeTypes: ['number']
97
+ },
98
+ colorType: {
99
+ toBeOption: 'ColorType',
100
+ },
101
+ })
102
+ if (barLabelResult.status === 'error') {
103
+ return barLabelResult
104
+ }
105
+ }
106
+ if (params.valueLabel) {
107
+ const valueLabelResult = validateColumns(params.valueLabel, {
108
+ padding: {
109
+ toBeTypes: ['number']
110
+ },
111
+ colorType: {
112
+ toBeOption: 'ColorType',
113
+ },
114
+ format: {
115
+ toBeTypes: ['Function']
116
+ },
117
+ })
118
+ if (valueLabelResult.status === 'error') {
119
+ return valueLabelResult
120
+ }
121
+ }
122
+ if (params.axisLabel) {
123
+ const axisLabelResult = validateColumns(params.axisLabel, {
124
+ offset: {
125
+ toBe: '[number, number]',
126
+ test: (value) => Array.isArray(value) && value.length === 2 && typeof value[0] === 'number' && typeof value[1] === 'number'
127
+ },
128
+ colorType: {
129
+ toBeOption: 'ColorType',
130
+ },
131
+ })
132
+ if (axisLabelResult.status === 'error') {
133
+ return axisLabelResult
134
+ }
135
+ }
136
+ return result
137
+ }
138
+ }
139
+
140
+ export const RacingBars = defineMultiValuePlugin(pluginConfig)(({ selection, name, observer, subject }) => {
141
+
142
+ const baseRacingBarsSelection = selection.append('g').attr('class', `${pluginName}-bars`)
143
+ const baseRacingLabelsSelection = selection.append('g').attr('class', `${pluginName}-labels`)
144
+ const baseRacingValueLabelsSelection = selection.append('g').attr('class', `${pluginName}-valueLabels`)
145
+
146
+ const destroy$ = new Subject()
147
+
148
+ // const baseRacingLabelsParams$: Observable<BaseRacingLabelsParams> = observer.fullParams$.pipe(
149
+ // takeUntil(destroy$),
150
+ // map(params => {
151
+ // return {
152
+ // ...params,
153
+ // axisLabel: {
154
+ // offset: [0, 0],
155
+ // colorType: 'primary'
156
+ // }
157
+ // }
158
+ // })
159
+ // )
160
+
161
+ // const baseRacingBarsParams$: Observable<BaseRacingBarsParams> = observer.fullParams$.pipe(
162
+ // takeUntil(destroy$),
163
+ // map(params => {
164
+ // return {
165
+ // ...params
166
+ // }
167
+ // })
168
+ // )
169
+
170
+ const baseRacingValueLabelsParams$ = observer.fullParams$.pipe(
171
+ takeUntil(destroy$),
172
+ map(params => {
173
+ return params.valueLabel
174
+ })
175
+ )
176
+
177
+ const rankingAmount$ = observer.fullParams$.pipe(
178
+ takeUntil(destroy$),
179
+ map(p => p.rankingAmount),
180
+ distinctUntilChanged(),
181
+ )
182
+
183
+ const computedRankingAmount$ = computedRankingAmountObservable({
184
+ containerSize$: observer.containerSize$,
185
+ visibleComputedData$: observer.visibleComputedData$,
186
+ textSizePx$: observer.textSizePx$,
187
+ rankingAmount$
188
+ }).pipe(
189
+ takeUntil(destroy$),
190
+ shareReplay(1)
191
+ )
192
+
193
+ const rankingItemHeight$ = rankingItemHeightObservable({
194
+ containerSize$: observer.containerSize$,
195
+ // visibleComputedRankingData$: observer.visibleComputedRankingByIndexData$,
196
+ textSizePx$: observer.textSizePx$,
197
+ computedRankingAmount$
198
+ }).pipe(
199
+ takeUntil(destroy$),
200
+ shareReplay(1)
201
+ )
202
+
203
+ const rankingScaleList$ = rankingScaleListObservable({
204
+ visibleComputedRankingData$: observer.visibleComputedRankingByIndexData$,
205
+ rankingItemHeight$
206
+ }).pipe(
207
+ takeUntil(destroy$),
208
+ shareReplay(1)
209
+ )
210
+
211
+ // const computedRankingWithXYData$ = computedRankingWithXYDataObservable({
212
+ // visibleComputedRankingData$: observer.visibleComputedRankingByIndexData$,
213
+ // rankingScaleList$
214
+ // }).pipe(
215
+ // takeUntil(destroy$),
216
+ // )
217
+
218
+ // const xScale$ = combineLatest({
219
+ // xScale: observer.xScale$,
220
+ // layout: observer.layout$,
221
+ // containerSize: observer.containerSize$,
222
+ // }).pipe(
223
+ // takeUntil(destroy$),
224
+ // switchMap(async d => d),
225
+ // map(data => {
226
+ // // 原本的 xScale 是根據 layout 計算的,現在要根據 containerSize 重新計算
227
+ // const containerWidthScale = data.containerSize.width / data.layout.width
228
+
229
+ // return (n: number) => {
230
+ // const originWidth = data.xScale(n)
231
+ // if (originWidth == null) {
232
+ // return 0
233
+ // }
234
+ // return data.xScale(n) * containerWidthScale
235
+ // }
236
+ // }),
237
+ // shareReplay(1)
238
+ // )
239
+
240
+ const unsubscribeBaseRacingLabels = createBaseRacingLabels(`${pluginName}-labels`, {
241
+ selection: baseRacingLabelsSelection,
242
+ computedData$: observer.computedData$,
243
+ visibleComputedRankingData$: observer.visibleComputedRankingByIndexData$,
244
+ rankingScaleList$,
245
+ xScale$: observer.xScale$,
246
+ fullParams$: observer.fullParams$,
247
+ fullDataFormatter$: observer.fullDataFormatter$,
248
+ fullChartParams$: observer.fullChartParams$,
249
+ // layout$: observer.layout$,
250
+ containerPosition$: observer.containerPosition$,
251
+ containerSize$: observer.containerSize$,
252
+ isCategorySeprate$: observer.isCategorySeprate$,
253
+ // xyValueIndex$: observer.xyValueIndex$,
254
+ })
255
+
256
+ const unsubscribeBaseRacingValueLabels = createBaseRacingValueLabels(`${pluginName}-valueLabels`, {
257
+ selection: baseRacingValueLabelsSelection,
258
+ computedData$: observer.computedData$,
259
+ visibleComputedRankingData$: observer.visibleComputedRankingByIndexData$,
260
+ rankingScaleList$,
261
+ xScale$: observer.xScale$,
262
+ computedRankingAmount$,
263
+ fullParams$: baseRacingValueLabelsParams$,
264
+ // fullDataFormatter$: observer.fullDataFormatter$,
265
+ fullChartParams$: observer.fullChartParams$,
266
+ // layout$: observer.layout$,
267
+ containerPosition$: observer.containerPosition$,
268
+ containerSize$: observer.containerSize$,
269
+ isCategorySeprate$: observer.isCategorySeprate$,
270
+ // xyValueIndex$: observer.xyValueIndex$,
271
+ })
272
+
273
+ const unsubscribeBaseRacingBars = createBaseRacingBars(`${pluginName}-bars`, {
274
+ selection: baseRacingBarsSelection,
275
+ computedData$: observer.computedData$,
276
+ visibleComputedRankingData$: observer.visibleComputedRankingByIndexData$,
277
+ // xyValueIndex$: observer.xyValueIndex$,
278
+ CategoryDataMap$: observer.CategoryDataMap$,
279
+ fullParams$: observer.fullParams$,
280
+ fullChartParams$: observer.fullChartParams$,
281
+ highlight$: observer.highlight$,
282
+ rankingItemHeight$,
283
+ rankingScaleList$,
284
+ xScale$: observer.xScale$,
285
+ containerPosition$: observer.containerPosition$,
286
+ containerSize$: observer.containerSize$,
287
+ // layout$: observer.layout$,
288
+ isCategorySeprate$: observer.isCategorySeprate$,
289
+ event$: subject.event$,
290
+ })
291
+
292
+ const valueAmount$ = observer.visibleComputedRankingByIndexData$.pipe(
293
+ takeUntil(destroy$),
294
+ map(d => (d[0] && d[0][0] && d[0][0].value.length) ?? 0),
295
+ distinctUntilChanged()
296
+ )
297
+
298
+ const autorun$ = observer.fullParams$.pipe(
299
+ takeUntil(destroy$),
300
+ map(p => p.autorun),
301
+ distinctUntilChanged()
302
+ )
303
+
304
+ const loop$ = observer.fullParams$.pipe(
305
+ takeUntil(destroy$),
306
+ map(p => p.loop),
307
+ distinctUntilChanged()
308
+ )
309
+
310
+ const tickDurationPeriod$ = observer.fullChartParams$.pipe(
311
+ takeUntil(destroy$),
312
+ map(p => p.transitionDuration),
313
+ distinctUntilChanged()
314
+ )
315
+
316
+ // -- autorun --
317
+ let toggle = true
318
+
319
+ combineLatest({
320
+ autorun: autorun$,
321
+ loop: loop$,
322
+ valueAmount: valueAmount$,
323
+ tickDurationPeriod: tickDurationPeriod$,
324
+ // xyValueIndex: observer.xyValueIndex$,
325
+ fullDataFormatter: observer.fullDataFormatter$,
326
+ }).pipe(
327
+ takeUntil(destroy$),
328
+ switchMap(async d => d)
329
+ ).subscribe(({ autorun, loop, valueAmount, tickDurationPeriod, fullDataFormatter }) => {
330
+ if (toggle == false) {
331
+ return
332
+ }
333
+ if (autorun) {
334
+ const nextIndex = fullDataFormatter.xAxis.valueIndex + 1
335
+ if (nextIndex < valueAmount) {
336
+ toggle = false // timer 執行期間不可再次執行
337
+
338
+ setTimeout(() => {
339
+ subject.dataFormatter$.next({
340
+ ...fullDataFormatter,
341
+ xAxis: {
342
+ ...fullDataFormatter.xAxis,
343
+ valueIndex: nextIndex
344
+ }
345
+ })
346
+
347
+ toggle = true
348
+ }, tickDurationPeriod)
349
+ } else if (nextIndex >= valueAmount && loop) {
350
+ toggle = false // timer 執行期間不可再次執行
351
+
352
+ setTimeout(() => {
353
+ subject.dataFormatter$.next({
354
+ ...fullDataFormatter,
355
+ xAxis: {
356
+ ...fullDataFormatter.xAxis,
357
+ valueIndex: 0
358
+ }
359
+ })
360
+
361
+ toggle = true
362
+ }, tickDurationPeriod)
363
+ }
364
+ }
365
+ })
366
+
367
+ return () => {
368
+ destroy$.next(undefined)
369
+ unsubscribeBaseRacingLabels()
370
+ unsubscribeBaseRacingValueLabels()
371
+ unsubscribeBaseRacingBars()
372
+ }
373
+ })