@orbcharts/plugins-basic 3.0.0-beta.7 → 3.0.0-beta.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (169) hide show
  1. package/LICENSE +200 -200
  2. package/dist/orbcharts-plugins-basic/lib/plugins-basic-types.d.ts +1 -1
  3. package/dist/orbcharts-plugins-basic/src/base/{BaseBarStack.d.ts → BaseStackedBar.d.ts} +4 -4
  4. package/dist/orbcharts-plugins-basic/src/grid/defaults.d.ts +3 -3
  5. package/dist/orbcharts-plugins-basic/src/grid/index.d.ts +2 -2
  6. package/dist/orbcharts-plugins-basic/src/grid/plugins/Bars.d.ts +1 -1
  7. package/dist/orbcharts-plugins-basic/src/grid/plugins/BarsPN.d.ts +1 -1
  8. package/dist/orbcharts-plugins-basic/src/grid/plugins/BarsTriangle.d.ts +1 -1
  9. package/dist/orbcharts-plugins-basic/src/grid/plugins/Dots.d.ts +1 -1
  10. package/dist/orbcharts-plugins-basic/src/grid/plugins/GridLegend.d.ts +1 -1
  11. package/dist/orbcharts-plugins-basic/src/grid/plugins/GridTooltip.d.ts +1 -1
  12. package/dist/orbcharts-plugins-basic/src/grid/plugins/GridZoom.d.ts +1 -1
  13. package/dist/orbcharts-plugins-basic/src/grid/plugins/GroupAux.d.ts +1 -1
  14. package/dist/orbcharts-plugins-basic/src/grid/plugins/GroupAxis.d.ts +1 -1
  15. package/dist/orbcharts-plugins-basic/src/grid/plugins/LineAreas.d.ts +1 -1
  16. package/dist/orbcharts-plugins-basic/src/grid/plugins/Lines.d.ts +1 -1
  17. package/dist/orbcharts-plugins-basic/src/grid/plugins/StackedBar.d.ts +1 -0
  18. package/dist/orbcharts-plugins-basic/src/grid/plugins/StackedValueAxis.d.ts +1 -0
  19. package/dist/orbcharts-plugins-basic/src/grid/plugins/ValueAxis.d.ts +1 -1
  20. package/dist/orbcharts-plugins-basic/src/index.d.ts +1 -0
  21. package/dist/orbcharts-plugins-basic/src/multiGrid/defaults.d.ts +4 -4
  22. package/dist/orbcharts-plugins-basic/src/multiGrid/index.d.ts +3 -3
  23. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiBars.d.ts +1 -1
  24. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiBarsTriangle.d.ts +1 -1
  25. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiDots.d.ts +1 -1
  26. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiGridLegend.d.ts +1 -1
  27. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiGridTooltip.d.ts +1 -1
  28. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiGroupAxis.d.ts +1 -1
  29. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiLineAreas.d.ts +1 -1
  30. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiLines.d.ts +1 -1
  31. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiStackedBar.d.ts +1 -0
  32. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiStackedValueAxis.d.ts +1 -0
  33. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiValueAxis.d.ts +1 -1
  34. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/OverlappingStackedValueAxes.d.ts +1 -0
  35. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/OverlappingValueAxes.d.ts +1 -1
  36. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/MultiValueLegend.d.ts +1 -1
  37. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/MultiValueTooltip.d.ts +1 -1
  38. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/Scatter.d.ts +1 -1
  39. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/ScatterBubbles.d.ts +1 -1
  40. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/XYAux.d.ts +1 -1
  41. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/XYAxes.d.ts +1 -1
  42. package/dist/orbcharts-plugins-basic/src/multiValue/plugins/XYZoom.d.ts +1 -1
  43. package/dist/orbcharts-plugins-basic/src/noneData/plugins/Container.d.ts +0 -1
  44. package/dist/orbcharts-plugins-basic/src/noneData/plugins/Tooltip.d.ts +0 -3
  45. package/dist/orbcharts-plugins-basic/src/relationship/defaults.d.ts +6 -0
  46. package/dist/orbcharts-plugins-basic/src/relationship/index.d.ts +5 -0
  47. package/dist/orbcharts-plugins-basic/src/relationship/plugins/ForceDirected.d.ts +3 -0
  48. package/dist/orbcharts-plugins-basic/src/relationship/plugins/ForceDirectedBubbles.d.ts +3 -0
  49. package/dist/orbcharts-plugins-basic/src/relationship/plugins/RelationshipLegend.d.ts +1 -0
  50. package/dist/orbcharts-plugins-basic/src/relationship/plugins/RelationshipTooltip.d.ts +1 -0
  51. package/dist/orbcharts-plugins-basic/src/relationship/relationshipObservables.d.ts +1 -0
  52. package/dist/orbcharts-plugins-basic/src/series/plugins/Bubbles.d.ts +1 -1
  53. package/dist/orbcharts-plugins-basic/src/series/plugins/Pie.d.ts +1 -1
  54. package/dist/orbcharts-plugins-basic/src/series/plugins/PieEventTexts.d.ts +1 -1
  55. package/dist/orbcharts-plugins-basic/src/series/plugins/PieLabels.d.ts +1 -1
  56. package/dist/orbcharts-plugins-basic/src/series/plugins/Rose.d.ts +1 -1
  57. package/dist/orbcharts-plugins-basic/src/series/plugins/RoseLabels.d.ts +1 -1
  58. package/dist/orbcharts-plugins-basic/src/series/plugins/SeriesLegend.d.ts +1 -1
  59. package/dist/orbcharts-plugins-basic/src/series/plugins/SeriesTooltip.d.ts +1 -1
  60. package/dist/orbcharts-plugins-basic/src/tree/plugins/TreeLegend.d.ts +1 -1
  61. package/dist/orbcharts-plugins-basic/src/tree/plugins/TreeMap.d.ts +1 -1
  62. package/dist/orbcharts-plugins-basic/src/tree/plugins/TreeTooltip.d.ts +1 -1
  63. package/dist/orbcharts-plugins-basic/src/utils/commonUtils.d.ts +1 -1
  64. package/dist/orbcharts-plugins-basic/src/utils/orbchartsUtils.d.ts +1 -1
  65. package/dist/orbcharts-plugins-basic.es.js +9421 -8102
  66. package/dist/orbcharts-plugins-basic.umd.js +69 -51
  67. package/lib/core-types.ts +7 -7
  68. package/lib/core.ts +6 -6
  69. package/lib/plugins-basic-types.ts +6 -6
  70. package/package.json +44 -44
  71. package/src/base/BaseBars.ts +765 -765
  72. package/src/base/BaseBarsTriangle.ts +676 -676
  73. package/src/base/BaseDots.ts +464 -464
  74. package/src/base/BaseGroupAxis.ts +679 -679
  75. package/src/base/BaseLegend.ts +684 -684
  76. package/src/base/BaseLineAreas.ts +629 -629
  77. package/src/base/BaseLines.ts +706 -706
  78. package/src/base/{BaseBarStack.ts → BaseStackedBar.ts} +782 -782
  79. package/src/base/BaseTooltip.ts +385 -385
  80. package/src/base/BaseValueAxis.ts +583 -583
  81. package/src/base/types.ts +2 -2
  82. package/src/const.ts +30 -30
  83. package/src/grid/defaults.ts +246 -246
  84. package/src/grid/gridObservables.ts +554 -554
  85. package/src/grid/index.ts +16 -16
  86. package/src/grid/plugins/Bars.ts +69 -69
  87. package/src/grid/plugins/BarsPN.ts +66 -66
  88. package/src/grid/plugins/BarsTriangle.ts +73 -73
  89. package/src/grid/plugins/Dots.ts +68 -68
  90. package/src/grid/plugins/GridLegend.ts +107 -107
  91. package/src/grid/plugins/GridTooltip.ts +66 -66
  92. package/src/grid/plugins/GridZoom.ts +218 -218
  93. package/src/grid/plugins/GroupAux.ts +1103 -1103
  94. package/src/grid/plugins/GroupAxis.ts +97 -97
  95. package/src/grid/plugins/LineAreas.ts +65 -65
  96. package/src/grid/plugins/Lines.ts +59 -59
  97. package/src/grid/plugins/{BarStack.ts → StackedBar.ts} +64 -64
  98. package/src/grid/plugins/{ValueStackAxis.ts → StackedValueAxis.ts} +96 -96
  99. package/src/grid/plugins/ValueAxis.ts +94 -94
  100. package/src/index.ts +6 -10
  101. package/src/multiGrid/defaults.ts +224 -224
  102. package/src/multiGrid/index.ts +15 -15
  103. package/src/multiGrid/multiGridObservables.ts +49 -49
  104. package/src/multiGrid/plugins/MultiBars.ts +108 -108
  105. package/src/multiGrid/plugins/MultiBarsTriangle.ts +114 -114
  106. package/src/multiGrid/plugins/MultiDots.ts +102 -102
  107. package/src/multiGrid/plugins/MultiGridLegend.ts +159 -159
  108. package/src/multiGrid/plugins/MultiGridTooltip.ts +66 -66
  109. package/src/multiGrid/plugins/MultiGroupAxis.ts +137 -137
  110. package/src/multiGrid/plugins/MultiLineAreas.ts +107 -107
  111. package/src/multiGrid/plugins/MultiLines.ts +101 -101
  112. package/src/multiGrid/plugins/{MultiBarStack.ts → MultiStackedBar.ts} +106 -106
  113. package/src/multiGrid/plugins/{MultiValueStackAxis.ts → MultiStackedValueAxis.ts} +134 -134
  114. package/src/multiGrid/plugins/MultiValueAxis.ts +134 -134
  115. package/src/multiGrid/plugins/{OverlappingValueStackAxes.ts → OverlappingStackedValueAxes.ts} +299 -299
  116. package/src/multiGrid/plugins/OverlappingValueAxes.ts +300 -300
  117. package/src/multiValue/defaults.ts +166 -166
  118. package/src/multiValue/index.ts +8 -8
  119. package/src/multiValue/multiValueObservables.ts +297 -297
  120. package/src/multiValue/plugins/MultiValueLegend.ts +107 -107
  121. package/src/multiValue/plugins/MultiValueTooltip.ts +66 -66
  122. package/src/multiValue/plugins/Scatter.ts +426 -426
  123. package/src/multiValue/plugins/ScatterBubbles.ts +554 -554
  124. package/src/multiValue/plugins/XYAux.ts +681 -681
  125. package/src/multiValue/plugins/XYAxes.ts +684 -684
  126. package/src/multiValue/plugins/XYZoom.ts +299 -299
  127. package/src/noneData/defaults.ts +102 -102
  128. package/src/noneData/index.ts +3 -3
  129. package/src/noneData/plugins/Container.ts +28 -28
  130. package/src/noneData/plugins/Tooltip.ts +374 -374
  131. package/src/relationship/defaults.ts +196 -0
  132. package/src/relationship/index.ts +5 -0
  133. package/src/relationship/plugins/ForceDirected.ts +1167 -0
  134. package/src/relationship/plugins/ForceDirectedBubbles.ts +1391 -0
  135. package/src/relationship/plugins/RelationshipLegend.ts +100 -0
  136. package/src/relationship/plugins/RelationshipTooltip.ts +66 -0
  137. package/src/relationship/relationshipObservables.ts +50 -0
  138. package/src/series/defaults.ts +206 -206
  139. package/src/series/index.ts +9 -9
  140. package/src/series/plugins/Bubbles.ts +606 -603
  141. package/src/series/plugins/Pie.ts +623 -623
  142. package/src/series/plugins/PieEventTexts.ts +284 -283
  143. package/src/series/plugins/PieLabels.ts +640 -640
  144. package/src/series/plugins/Rose.ts +516 -516
  145. package/src/series/plugins/RoseLabels.ts +600 -600
  146. package/src/series/plugins/SeriesLegend.ts +107 -107
  147. package/src/series/plugins/SeriesTooltip.ts +66 -66
  148. package/src/series/seriesObservables.ts +145 -145
  149. package/src/series/seriesUtils.ts +51 -51
  150. package/src/tree/defaults.ts +78 -78
  151. package/src/tree/index.ts +4 -4
  152. package/src/tree/plugins/TreeLegend.ts +100 -100
  153. package/src/tree/plugins/TreeMap.ts +333 -333
  154. package/src/tree/plugins/TreeTooltip.ts +66 -66
  155. package/src/utils/commonUtils.ts +21 -21
  156. package/src/utils/d3Graphics.ts +174 -174
  157. package/src/utils/d3Utils.ts +74 -74
  158. package/src/utils/observables.ts +14 -14
  159. package/src/utils/orbchartsUtils.ts +115 -115
  160. package/tsconfig.base.json +13 -13
  161. package/tsconfig.json +2 -2
  162. package/vite.config.js +22 -22
  163. package/dist/orbcharts-plugins-basic/src/grid/plugins/BarStack.d.ts +0 -1
  164. package/dist/orbcharts-plugins-basic/src/grid/plugins/ValueStackAxis.d.ts +0 -1
  165. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiBarStack.d.ts +0 -1
  166. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiValueStackAxis.d.ts +0 -1
  167. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/OverlappingValueStackAxes.d.ts +0 -1
  168. package/dist/orbcharts-plugins-basic/src/relationship/plugins/Relationship.d.ts +0 -0
  169. package/src/relationship/plugins/Relationship.ts +0 -0
@@ -1,134 +1,134 @@
1
- import * as d3 from 'd3'
2
- import {
3
- Subject,
4
- map,
5
- distinctUntilChanged,
6
- shareReplay,
7
- takeUntil
8
- } from 'rxjs'
9
- import type { DefinePluginConfig } from '../../../lib/core-types'
10
- import {
11
- defineMultiGridPlugin } from '../../../lib/core'
12
- import { DEFAULT_MULTI_VALUE_AXIS_PARAMS } from '../defaults'
13
- import { createBaseValueAxis } from '../../base/BaseValueAxis'
14
- import { multiGridPluginDetailObservables } from '../multiGridObservables'
15
- import { getClassName, getUniID } from '../../utils/orbchartsUtils'
16
- import { LAYER_INDEX_OF_AXIS } from '../../const'
17
-
18
- const pluginName = 'MultiValueStackAxis'
19
-
20
- const gridClassName = getClassName(pluginName, 'grid')
21
-
22
- const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_VALUE_AXIS_PARAMS> = {
23
- name: pluginName,
24
- defaultParams: DEFAULT_MULTI_VALUE_AXIS_PARAMS,
25
- layerIndex: LAYER_INDEX_OF_AXIS,
26
- validator: (params, { validateColumns }) => {
27
- const result = validateColumns(params, {
28
- gridIndexes: {
29
- toBe: 'number[] | "all"',
30
- test: (value: any) => {
31
- return value === 'all' || (Array.isArray(value) && value.every((v: any) => typeof v === 'number'))
32
- }
33
- },
34
- labelOffset: {
35
- toBe: '[number, number]',
36
- test: (value: any) => {
37
- return Array.isArray(value)
38
- && value.length === 2
39
- && typeof value[0] === 'number'
40
- && typeof value[1] === 'number'
41
- }
42
- },
43
- labelColorType: {
44
- toBeOption: 'ColorType',
45
- },
46
- axisLineVisible: {
47
- toBeTypes: ['boolean']
48
- },
49
- axisLineColorType: {
50
- toBeOption: 'ColorType',
51
- },
52
- ticks: {
53
- toBeTypes: ['number', 'null']
54
- },
55
- tickFormat: {
56
- toBeTypes: ['string', 'Function']
57
- },
58
- tickLineVisible: {
59
- toBeTypes: ['boolean']
60
- },
61
- tickPadding: {
62
- toBeTypes: ['number']
63
- },
64
- tickFullLine: {
65
- toBeTypes: ['boolean']
66
- },
67
- tickFullLineDasharray: {
68
- toBeTypes: ['string']
69
- },
70
- tickColorType: {
71
- toBeOption: 'ColorType',
72
- },
73
- tickTextRotate: {
74
- toBeTypes: ['number']
75
- },
76
- tickTextColorType: {
77
- toBeOption: 'ColorType',
78
- }
79
- })
80
- return result
81
- }
82
- }
83
-
84
- export const MultiValueStackAxis = defineMultiGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
85
- const destroy$ = new Subject()
86
-
87
- const unsubscribeFnArr: (() => void)[] = []
88
-
89
- const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
90
-
91
- multiGridPluginDetail$
92
- .pipe(
93
- takeUntil(destroy$)
94
- )
95
- .subscribe(data => {
96
- // 每次重新計算時,清除之前的訂閱
97
- unsubscribeFnArr.forEach(fn => fn())
98
-
99
- selection.selectAll(`g.${gridClassName}`)
100
- .data(data)
101
- .join('g')
102
- .attr('class', gridClassName)
103
- .each((d, i, g) => {
104
-
105
- const gridSelection = d3.select(g[i])
106
-
107
- const isSeriesSeprate$ = d.dataFormatter$.pipe(
108
- takeUntil(destroy$),
109
- map(d => d.grid.separateSeries),
110
- distinctUntilChanged(),
111
- shareReplay(1)
112
- )
113
-
114
- unsubscribeFnArr[i] = createBaseValueAxis(pluginName, {
115
- selection: gridSelection,
116
- computedData$: d.computedStackedData$, // 計算疊加value的資料
117
- filteredMinMaxValue$: d.filteredMinMaxValue$,
118
- fullParams$: observer.fullParams$,
119
- fullDataFormatter$: d.dataFormatter$,
120
- fullChartParams$: observer.fullChartParams$,
121
- gridAxesTransform$: d.gridAxesTransform$,
122
- gridAxesReverseTransform$: d.gridAxesReverseTransform$,
123
- gridAxesSize$: d.gridAxesSize$,
124
- gridContainerPosition$: d.gridContainerPosition$,
125
- isSeriesSeprate$,
126
- })
127
- })
128
- })
129
-
130
- return () => {
131
- destroy$.next(undefined)
132
- unsubscribeFnArr.forEach(fn => fn())
133
- }
134
- })
1
+ import * as d3 from 'd3'
2
+ import {
3
+ Subject,
4
+ map,
5
+ distinctUntilChanged,
6
+ shareReplay,
7
+ takeUntil
8
+ } from 'rxjs'
9
+ import type { DefinePluginConfig } from '../../../lib/core-types'
10
+ import {
11
+ defineMultiGridPlugin } from '../../../lib/core'
12
+ import { DEFAULT_MULTI_VALUE_AXIS_PARAMS } from '../defaults'
13
+ import { createBaseValueAxis } from '../../base/BaseValueAxis'
14
+ import { multiGridPluginDetailObservables } from '../multiGridObservables'
15
+ import { getClassName, getUniID } from '../../utils/orbchartsUtils'
16
+ import { LAYER_INDEX_OF_AXIS } from '../../const'
17
+
18
+ const pluginName = 'MultiStackedValueAxis'
19
+
20
+ const gridClassName = getClassName(pluginName, 'grid')
21
+
22
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_VALUE_AXIS_PARAMS> = {
23
+ name: pluginName,
24
+ defaultParams: DEFAULT_MULTI_VALUE_AXIS_PARAMS,
25
+ layerIndex: LAYER_INDEX_OF_AXIS,
26
+ validator: (params, { validateColumns }) => {
27
+ const result = validateColumns(params, {
28
+ gridIndexes: {
29
+ toBe: 'number[] | "all"',
30
+ test: (value: any) => {
31
+ return value === 'all' || (Array.isArray(value) && value.every((v: any) => typeof v === 'number'))
32
+ }
33
+ },
34
+ labelOffset: {
35
+ toBe: '[number, number]',
36
+ test: (value: any) => {
37
+ return Array.isArray(value)
38
+ && value.length === 2
39
+ && typeof value[0] === 'number'
40
+ && typeof value[1] === 'number'
41
+ }
42
+ },
43
+ labelColorType: {
44
+ toBeOption: 'ColorType',
45
+ },
46
+ axisLineVisible: {
47
+ toBeTypes: ['boolean']
48
+ },
49
+ axisLineColorType: {
50
+ toBeOption: 'ColorType',
51
+ },
52
+ ticks: {
53
+ toBeTypes: ['number', 'null']
54
+ },
55
+ tickFormat: {
56
+ toBeTypes: ['string', 'Function']
57
+ },
58
+ tickLineVisible: {
59
+ toBeTypes: ['boolean']
60
+ },
61
+ tickPadding: {
62
+ toBeTypes: ['number']
63
+ },
64
+ tickFullLine: {
65
+ toBeTypes: ['boolean']
66
+ },
67
+ tickFullLineDasharray: {
68
+ toBeTypes: ['string']
69
+ },
70
+ tickColorType: {
71
+ toBeOption: 'ColorType',
72
+ },
73
+ tickTextRotate: {
74
+ toBeTypes: ['number']
75
+ },
76
+ tickTextColorType: {
77
+ toBeOption: 'ColorType',
78
+ }
79
+ })
80
+ return result
81
+ }
82
+ }
83
+
84
+ export const MultiStackedValueAxis = defineMultiGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
85
+ const destroy$ = new Subject()
86
+
87
+ const unsubscribeFnArr: (() => void)[] = []
88
+
89
+ const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
90
+
91
+ multiGridPluginDetail$
92
+ .pipe(
93
+ takeUntil(destroy$)
94
+ )
95
+ .subscribe(data => {
96
+ // 每次重新計算時,清除之前的訂閱
97
+ unsubscribeFnArr.forEach(fn => fn())
98
+
99
+ selection.selectAll(`g.${gridClassName}`)
100
+ .data(data)
101
+ .join('g')
102
+ .attr('class', gridClassName)
103
+ .each((d, i, g) => {
104
+
105
+ const gridSelection = d3.select(g[i])
106
+
107
+ const isSeriesSeprate$ = d.dataFormatter$.pipe(
108
+ takeUntil(destroy$),
109
+ map(d => d.separateSeries),
110
+ distinctUntilChanged(),
111
+ shareReplay(1)
112
+ )
113
+
114
+ unsubscribeFnArr[i] = createBaseValueAxis(pluginName, {
115
+ selection: gridSelection,
116
+ computedData$: d.computedStackedData$, // 計算疊加value的資料
117
+ filteredMinMaxValue$: d.filteredMinMaxValue$,
118
+ fullParams$: observer.fullParams$,
119
+ fullDataFormatter$: d.dataFormatter$,
120
+ fullChartParams$: observer.fullChartParams$,
121
+ gridAxesTransform$: d.gridAxesTransform$,
122
+ gridAxesReverseTransform$: d.gridAxesReverseTransform$,
123
+ gridAxesSize$: d.gridAxesSize$,
124
+ gridContainerPosition$: d.gridContainerPosition$,
125
+ isSeriesSeprate$,
126
+ })
127
+ })
128
+ })
129
+
130
+ return () => {
131
+ destroy$.next(undefined)
132
+ unsubscribeFnArr.forEach(fn => fn())
133
+ }
134
+ })
@@ -1,134 +1,134 @@
1
- import * as d3 from 'd3'
2
- import {
3
- Subject,
4
- map,
5
- distinctUntilChanged,
6
- shareReplay,
7
- takeUntil
8
- } from 'rxjs'
9
- import type { DefinePluginConfig } from '../../../lib/core-types'
10
- import {
11
- defineMultiGridPlugin } from '../../../lib/core'
12
- import { DEFAULT_MULTI_VALUE_AXIS_PARAMS } from '../defaults'
13
- import { createBaseValueAxis } from '../../base/BaseValueAxis'
14
- import { multiGridPluginDetailObservables } from '../multiGridObservables'
15
- import { getClassName, getUniID } from '../../utils/orbchartsUtils'
16
- import { LAYER_INDEX_OF_AXIS } from '../../const'
17
-
18
- const pluginName = 'MultiValueAxis'
19
-
20
- const gridClassName = getClassName(pluginName, 'grid')
21
-
22
- const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_VALUE_AXIS_PARAMS> = {
23
- name: pluginName,
24
- defaultParams: DEFAULT_MULTI_VALUE_AXIS_PARAMS,
25
- layerIndex: LAYER_INDEX_OF_AXIS,
26
- validator: (params, { validateColumns }) => {
27
- const result = validateColumns(params, {
28
- gridIndexes: {
29
- toBe: 'number[] | "all"',
30
- test: (value: any) => {
31
- return value === 'all' || (Array.isArray(value) && value.every((v: any) => typeof v === 'number'))
32
- }
33
- },
34
- labelOffset: {
35
- toBe: '[number, number]',
36
- test: (value: any) => {
37
- return Array.isArray(value)
38
- && value.length === 2
39
- && typeof value[0] === 'number'
40
- && typeof value[1] === 'number'
41
- }
42
- },
43
- labelColorType: {
44
- toBeOption: 'ColorType',
45
- },
46
- axisLineVisible: {
47
- toBeTypes: ['boolean']
48
- },
49
- axisLineColorType: {
50
- toBeOption: 'ColorType',
51
- },
52
- ticks: {
53
- toBeTypes: ['number', 'null']
54
- },
55
- tickFormat: {
56
- toBeTypes: ['string', 'Function']
57
- },
58
- tickLineVisible: {
59
- toBeTypes: ['boolean']
60
- },
61
- tickPadding: {
62
- toBeTypes: ['number']
63
- },
64
- tickFullLine: {
65
- toBeTypes: ['boolean']
66
- },
67
- tickFullLineDasharray: {
68
- toBeTypes: ['string']
69
- },
70
- tickColorType: {
71
- toBeOption: 'ColorType',
72
- },
73
- tickTextRotate: {
74
- toBeTypes: ['number']
75
- },
76
- tickTextColorType: {
77
- toBeOption: 'ColorType',
78
- }
79
- })
80
- return result
81
- }
82
- }
83
-
84
- export const MultiValueAxis = defineMultiGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
85
- const destroy$ = new Subject()
86
-
87
- const unsubscribeFnArr: (() => void)[] = []
88
-
89
- const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
90
-
91
- multiGridPluginDetail$
92
- .pipe(
93
- takeUntil(destroy$)
94
- )
95
- .subscribe(data => {
96
- // 每次重新計算時,清除之前的訂閱
97
- unsubscribeFnArr.forEach(fn => fn())
98
-
99
- selection.selectAll(`g.${gridClassName}`)
100
- .data(data)
101
- .join('g')
102
- .attr('class', gridClassName)
103
- .each((d, i, g) => {
104
-
105
- const gridSelection = d3.select(g[i])
106
-
107
- const isSeriesSeprate$ = d.dataFormatter$.pipe(
108
- takeUntil(destroy$),
109
- map(d => d.grid.separateSeries),
110
- distinctUntilChanged(),
111
- shareReplay(1)
112
- )
113
-
114
- unsubscribeFnArr[i] = createBaseValueAxis(pluginName, {
115
- selection: gridSelection,
116
- computedData$: d.computedData$,
117
- filteredMinMaxValue$: d.filteredMinMaxValue$,
118
- fullParams$: observer.fullParams$,
119
- fullDataFormatter$: d.dataFormatter$,
120
- fullChartParams$: observer.fullChartParams$,
121
- gridAxesTransform$: d.gridAxesTransform$,
122
- gridAxesReverseTransform$: d.gridAxesReverseTransform$,
123
- gridAxesSize$: d.gridAxesSize$,
124
- gridContainerPosition$: d.gridContainerPosition$,
125
- isSeriesSeprate$,
126
- })
127
- })
128
- })
129
-
130
- return () => {
131
- destroy$.next(undefined)
132
- unsubscribeFnArr.forEach(fn => fn())
133
- }
134
- })
1
+ import * as d3 from 'd3'
2
+ import {
3
+ Subject,
4
+ map,
5
+ distinctUntilChanged,
6
+ shareReplay,
7
+ takeUntil
8
+ } from 'rxjs'
9
+ import type { DefinePluginConfig } from '../../../lib/core-types'
10
+ import {
11
+ defineMultiGridPlugin } from '../../../lib/core'
12
+ import { DEFAULT_MULTI_VALUE_AXIS_PARAMS } from '../defaults'
13
+ import { createBaseValueAxis } from '../../base/BaseValueAxis'
14
+ import { multiGridPluginDetailObservables } from '../multiGridObservables'
15
+ import { getClassName, getUniID } from '../../utils/orbchartsUtils'
16
+ import { LAYER_INDEX_OF_AXIS } from '../../const'
17
+
18
+ const pluginName = 'MultiValueAxis'
19
+
20
+ const gridClassName = getClassName(pluginName, 'grid')
21
+
22
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_VALUE_AXIS_PARAMS> = {
23
+ name: pluginName,
24
+ defaultParams: DEFAULT_MULTI_VALUE_AXIS_PARAMS,
25
+ layerIndex: LAYER_INDEX_OF_AXIS,
26
+ validator: (params, { validateColumns }) => {
27
+ const result = validateColumns(params, {
28
+ gridIndexes: {
29
+ toBe: 'number[] | "all"',
30
+ test: (value: any) => {
31
+ return value === 'all' || (Array.isArray(value) && value.every((v: any) => typeof v === 'number'))
32
+ }
33
+ },
34
+ labelOffset: {
35
+ toBe: '[number, number]',
36
+ test: (value: any) => {
37
+ return Array.isArray(value)
38
+ && value.length === 2
39
+ && typeof value[0] === 'number'
40
+ && typeof value[1] === 'number'
41
+ }
42
+ },
43
+ labelColorType: {
44
+ toBeOption: 'ColorType',
45
+ },
46
+ axisLineVisible: {
47
+ toBeTypes: ['boolean']
48
+ },
49
+ axisLineColorType: {
50
+ toBeOption: 'ColorType',
51
+ },
52
+ ticks: {
53
+ toBeTypes: ['number', 'null']
54
+ },
55
+ tickFormat: {
56
+ toBeTypes: ['string', 'Function']
57
+ },
58
+ tickLineVisible: {
59
+ toBeTypes: ['boolean']
60
+ },
61
+ tickPadding: {
62
+ toBeTypes: ['number']
63
+ },
64
+ tickFullLine: {
65
+ toBeTypes: ['boolean']
66
+ },
67
+ tickFullLineDasharray: {
68
+ toBeTypes: ['string']
69
+ },
70
+ tickColorType: {
71
+ toBeOption: 'ColorType',
72
+ },
73
+ tickTextRotate: {
74
+ toBeTypes: ['number']
75
+ },
76
+ tickTextColorType: {
77
+ toBeOption: 'ColorType',
78
+ }
79
+ })
80
+ return result
81
+ }
82
+ }
83
+
84
+ export const MultiValueAxis = defineMultiGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
85
+ const destroy$ = new Subject()
86
+
87
+ const unsubscribeFnArr: (() => void)[] = []
88
+
89
+ const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
90
+
91
+ multiGridPluginDetail$
92
+ .pipe(
93
+ takeUntil(destroy$)
94
+ )
95
+ .subscribe(data => {
96
+ // 每次重新計算時,清除之前的訂閱
97
+ unsubscribeFnArr.forEach(fn => fn())
98
+
99
+ selection.selectAll(`g.${gridClassName}`)
100
+ .data(data)
101
+ .join('g')
102
+ .attr('class', gridClassName)
103
+ .each((d, i, g) => {
104
+
105
+ const gridSelection = d3.select(g[i])
106
+
107
+ const isSeriesSeprate$ = d.dataFormatter$.pipe(
108
+ takeUntil(destroy$),
109
+ map(d => d.separateSeries),
110
+ distinctUntilChanged(),
111
+ shareReplay(1)
112
+ )
113
+
114
+ unsubscribeFnArr[i] = createBaseValueAxis(pluginName, {
115
+ selection: gridSelection,
116
+ computedData$: d.computedData$,
117
+ filteredMinMaxValue$: d.filteredMinMaxValue$,
118
+ fullParams$: observer.fullParams$,
119
+ fullDataFormatter$: d.dataFormatter$,
120
+ fullChartParams$: observer.fullChartParams$,
121
+ gridAxesTransform$: d.gridAxesTransform$,
122
+ gridAxesReverseTransform$: d.gridAxesReverseTransform$,
123
+ gridAxesSize$: d.gridAxesSize$,
124
+ gridContainerPosition$: d.gridContainerPosition$,
125
+ isSeriesSeprate$,
126
+ })
127
+ })
128
+ })
129
+
130
+ return () => {
131
+ destroy$.next(undefined)
132
+ unsubscribeFnArr.forEach(fn => fn())
133
+ }
134
+ })