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

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 (126) hide show
  1. package/LICENSE +200 -200
  2. package/dist/orbcharts-plugins-basic/src/base/{BaseBarStack.d.ts → BaseStackedBar.d.ts} +4 -4
  3. package/dist/orbcharts-plugins-basic/src/grid/defaults.d.ts +3 -3
  4. package/dist/orbcharts-plugins-basic/src/grid/index.d.ts +2 -2
  5. package/dist/orbcharts-plugins-basic/src/grid/plugins/StackedBar.d.ts +1 -0
  6. package/dist/orbcharts-plugins-basic/src/grid/plugins/StackedValueAxis.d.ts +1 -0
  7. package/dist/orbcharts-plugins-basic/src/index.d.ts +1 -0
  8. package/dist/orbcharts-plugins-basic/src/multiGrid/defaults.d.ts +4 -4
  9. package/dist/orbcharts-plugins-basic/src/multiGrid/index.d.ts +3 -3
  10. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiStackedBar.d.ts +1 -0
  11. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiStackedValueAxis.d.ts +1 -0
  12. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/OverlappingStackedValueAxes.d.ts +1 -0
  13. package/dist/orbcharts-plugins-basic/src/noneData/plugins/Container.d.ts +0 -1
  14. package/dist/orbcharts-plugins-basic/src/noneData/plugins/Tooltip.d.ts +0 -3
  15. package/dist/orbcharts-plugins-basic/src/relationship/defaults.d.ts +5 -0
  16. package/dist/orbcharts-plugins-basic/src/relationship/index.d.ts +4 -0
  17. package/dist/orbcharts-plugins-basic/src/relationship/plugins/ForceDirected.d.ts +3 -0
  18. package/dist/orbcharts-plugins-basic/src/relationship/plugins/RelationshipLegend.d.ts +1 -0
  19. package/dist/orbcharts-plugins-basic/src/relationship/plugins/RelationshipTooltip.d.ts +1 -0
  20. package/dist/orbcharts-plugins-basic/src/relationship/relationshipObservables.d.ts +1 -0
  21. package/dist/orbcharts-plugins-basic/src/utils/commonUtils.d.ts +1 -1
  22. package/dist/orbcharts-plugins-basic/src/utils/orbchartsUtils.d.ts +1 -1
  23. package/dist/orbcharts-plugins-basic.es.js +8122 -7467
  24. package/dist/orbcharts-plugins-basic.umd.js +45 -32
  25. package/lib/core-types.ts +7 -7
  26. package/lib/core.ts +6 -6
  27. package/lib/plugins-basic-types.ts +6 -6
  28. package/package.json +44 -44
  29. package/src/base/BaseBars.ts +765 -765
  30. package/src/base/BaseBarsTriangle.ts +676 -676
  31. package/src/base/BaseDots.ts +464 -464
  32. package/src/base/BaseGroupAxis.ts +679 -679
  33. package/src/base/BaseLegend.ts +684 -684
  34. package/src/base/BaseLineAreas.ts +629 -629
  35. package/src/base/BaseLines.ts +706 -706
  36. package/src/base/{BaseBarStack.ts → BaseStackedBar.ts} +782 -782
  37. package/src/base/BaseTooltip.ts +385 -385
  38. package/src/base/BaseValueAxis.ts +583 -583
  39. package/src/base/types.ts +2 -2
  40. package/src/const.ts +30 -30
  41. package/src/grid/defaults.ts +246 -246
  42. package/src/grid/gridObservables.ts +554 -554
  43. package/src/grid/index.ts +16 -16
  44. package/src/grid/plugins/Bars.ts +69 -69
  45. package/src/grid/plugins/BarsPN.ts +66 -66
  46. package/src/grid/plugins/BarsTriangle.ts +73 -73
  47. package/src/grid/plugins/Dots.ts +68 -68
  48. package/src/grid/plugins/GridLegend.ts +107 -107
  49. package/src/grid/plugins/GridTooltip.ts +66 -66
  50. package/src/grid/plugins/GridZoom.ts +218 -218
  51. package/src/grid/plugins/GroupAux.ts +1103 -1103
  52. package/src/grid/plugins/GroupAxis.ts +97 -97
  53. package/src/grid/plugins/LineAreas.ts +65 -65
  54. package/src/grid/plugins/Lines.ts +59 -59
  55. package/src/grid/plugins/{BarStack.ts → StackedBar.ts} +64 -64
  56. package/src/grid/plugins/{ValueStackAxis.ts → StackedValueAxis.ts} +96 -96
  57. package/src/grid/plugins/ValueAxis.ts +94 -94
  58. package/src/index.ts +6 -10
  59. package/src/multiGrid/defaults.ts +224 -224
  60. package/src/multiGrid/index.ts +15 -15
  61. package/src/multiGrid/multiGridObservables.ts +49 -49
  62. package/src/multiGrid/plugins/MultiBars.ts +108 -108
  63. package/src/multiGrid/plugins/MultiBarsTriangle.ts +114 -114
  64. package/src/multiGrid/plugins/MultiDots.ts +102 -102
  65. package/src/multiGrid/plugins/MultiGridLegend.ts +159 -159
  66. package/src/multiGrid/plugins/MultiGridTooltip.ts +66 -66
  67. package/src/multiGrid/plugins/MultiGroupAxis.ts +137 -137
  68. package/src/multiGrid/plugins/MultiLineAreas.ts +107 -107
  69. package/src/multiGrid/plugins/MultiLines.ts +101 -101
  70. package/src/multiGrid/plugins/{MultiBarStack.ts → MultiStackedBar.ts} +106 -106
  71. package/src/multiGrid/plugins/{MultiValueStackAxis.ts → MultiStackedValueAxis.ts} +134 -134
  72. package/src/multiGrid/plugins/MultiValueAxis.ts +134 -134
  73. package/src/multiGrid/plugins/{OverlappingValueStackAxes.ts → OverlappingStackedValueAxes.ts} +299 -299
  74. package/src/multiGrid/plugins/OverlappingValueAxes.ts +300 -300
  75. package/src/multiValue/defaults.ts +166 -166
  76. package/src/multiValue/index.ts +8 -8
  77. package/src/multiValue/multiValueObservables.ts +297 -297
  78. package/src/multiValue/plugins/MultiValueLegend.ts +107 -107
  79. package/src/multiValue/plugins/MultiValueTooltip.ts +66 -66
  80. package/src/multiValue/plugins/Scatter.ts +426 -426
  81. package/src/multiValue/plugins/ScatterBubbles.ts +554 -554
  82. package/src/multiValue/plugins/XYAux.ts +681 -681
  83. package/src/multiValue/plugins/XYAxes.ts +684 -684
  84. package/src/multiValue/plugins/XYZoom.ts +299 -299
  85. package/src/noneData/defaults.ts +102 -102
  86. package/src/noneData/index.ts +3 -3
  87. package/src/noneData/plugins/Container.ts +28 -28
  88. package/src/noneData/plugins/Tooltip.ts +374 -374
  89. package/src/relationship/defaults.ts +113 -0
  90. package/src/relationship/index.ts +4 -0
  91. package/src/relationship/plugins/ForceDirected.ts +1148 -0
  92. package/src/relationship/plugins/RelationshipLegend.ts +100 -0
  93. package/src/relationship/plugins/RelationshipTooltip.ts +66 -0
  94. package/src/relationship/relationshipObservables.ts +50 -0
  95. package/src/series/defaults.ts +206 -206
  96. package/src/series/index.ts +9 -9
  97. package/src/series/plugins/Bubbles.ts +604 -603
  98. package/src/series/plugins/Pie.ts +623 -623
  99. package/src/series/plugins/PieEventTexts.ts +284 -283
  100. package/src/series/plugins/PieLabels.ts +640 -640
  101. package/src/series/plugins/Rose.ts +516 -516
  102. package/src/series/plugins/RoseLabels.ts +600 -600
  103. package/src/series/plugins/SeriesLegend.ts +107 -107
  104. package/src/series/plugins/SeriesTooltip.ts +66 -66
  105. package/src/series/seriesObservables.ts +145 -145
  106. package/src/series/seriesUtils.ts +51 -51
  107. package/src/tree/defaults.ts +78 -78
  108. package/src/tree/index.ts +4 -4
  109. package/src/tree/plugins/TreeLegend.ts +100 -100
  110. package/src/tree/plugins/TreeMap.ts +333 -333
  111. package/src/tree/plugins/TreeTooltip.ts +66 -66
  112. package/src/utils/commonUtils.ts +21 -21
  113. package/src/utils/d3Graphics.ts +174 -174
  114. package/src/utils/d3Utils.ts +74 -74
  115. package/src/utils/observables.ts +14 -14
  116. package/src/utils/orbchartsUtils.ts +115 -115
  117. package/tsconfig.base.json +13 -13
  118. package/tsconfig.json +2 -2
  119. package/vite.config.js +22 -22
  120. package/dist/orbcharts-plugins-basic/src/grid/plugins/BarStack.d.ts +0 -1
  121. package/dist/orbcharts-plugins-basic/src/grid/plugins/ValueStackAxis.d.ts +0 -1
  122. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiBarStack.d.ts +0 -1
  123. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/MultiValueStackAxis.d.ts +0 -1
  124. package/dist/orbcharts-plugins-basic/src/multiGrid/plugins/OverlappingValueStackAxes.d.ts +0 -1
  125. /package/dist/orbcharts-plugins-basic/src/relationship/plugins/{Relationship.d.ts → ForceDirectedBubbles.d.ts} +0 -0
  126. /package/src/relationship/plugins/{Relationship.ts → ForceDirectedBubbles.ts} +0 -0
@@ -1,108 +1,108 @@
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_BARS_PARAMS } from '../defaults'
13
- import { createBaseBars } from '../../base/BaseBars'
14
- import { multiGridPluginDetailObservables } from '../multiGridObservables'
15
- import { getClassName, getUniID } from '../../utils/orbchartsUtils'
16
- import { LAYER_INDEX_OF_GRAPHIC } from '../../const'
17
-
18
- const pluginName = 'MultiBars'
19
-
20
- const gridClassName = getClassName(pluginName, 'grid')
21
-
22
- const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_BARS_PARAMS> = {
23
- name: pluginName,
24
- defaultParams: DEFAULT_MULTI_BARS_PARAMS,
25
- layerIndex: LAYER_INDEX_OF_GRAPHIC,
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
- barWidth: {
35
- toBeTypes: ['number']
36
- },
37
- barPadding: {
38
- toBeTypes: ['number']
39
- },
40
- barGroupPadding: {
41
- toBeTypes: ['number']
42
- },
43
- barRadius: {
44
- toBeTypes: ['number', 'boolean']
45
- }
46
- })
47
- return result
48
- }
49
- }
50
-
51
- export const MultiBars = defineMultiGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
52
- const destroy$ = new Subject()
53
-
54
- const unsubscribeFnArr: (() => void)[] = []
55
-
56
- const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
57
-
58
- multiGridPluginDetail$
59
- .pipe(
60
- takeUntil(destroy$)
61
- )
62
- .subscribe(data => {
63
- // 每次重新計算時,清除之前的訂閱
64
- unsubscribeFnArr.forEach(fn => fn())
65
-
66
- selection.selectAll(`g.${gridClassName}`)
67
- .data(data)
68
- .join('g')
69
- .attr('class', gridClassName)
70
- .each((d, i, g) => {
71
-
72
- const gridSelection = d3.select(g[i])
73
-
74
- const isSeriesSeprate$ = d.dataFormatter$.pipe(
75
- takeUntil(destroy$),
76
- map(d => d.grid.separateSeries),
77
- distinctUntilChanged(),
78
- shareReplay(1)
79
- )
80
-
81
- unsubscribeFnArr[i] = createBaseBars(pluginName, {
82
- selection: gridSelection,
83
- computedData$: d.computedData$,
84
- visibleComputedData$: d.visibleComputedData$,
85
- computedLayoutData$: d.computedLayoutData$,
86
- visibleComputedLayoutData$: d.visibleComputedLayoutData$,
87
- seriesLabels$: d.seriesLabels$,
88
- SeriesDataMap$: d.SeriesDataMap$,
89
- GroupDataMap$: d.GroupDataMap$,
90
- fullParams$: observer.fullParams$,
91
- fullChartParams$: observer.fullChartParams$,
92
- gridAxesTransform$: d.gridAxesTransform$,
93
- gridGraphicTransform$: d.gridGraphicTransform$,
94
- gridGraphicReverseScale$: d.gridGraphicReverseScale$,
95
- gridAxesSize$: d.gridAxesSize$,
96
- gridHighlight$: d.gridHighlight$,
97
- gridContainerPosition$: d.gridContainerPosition$,
98
- isSeriesSeprate$,
99
- event$: subject.event$ as Subject<any>,
100
- })
101
- })
102
- })
103
-
104
- return () => {
105
- destroy$.next(undefined)
106
- unsubscribeFnArr.forEach(fn => fn())
107
- }
108
- })
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_BARS_PARAMS } from '../defaults'
13
+ import { createBaseBars } from '../../base/BaseBars'
14
+ import { multiGridPluginDetailObservables } from '../multiGridObservables'
15
+ import { getClassName, getUniID } from '../../utils/orbchartsUtils'
16
+ import { LAYER_INDEX_OF_GRAPHIC } from '../../const'
17
+
18
+ const pluginName = 'MultiBars'
19
+
20
+ const gridClassName = getClassName(pluginName, 'grid')
21
+
22
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_BARS_PARAMS> = {
23
+ name: pluginName,
24
+ defaultParams: DEFAULT_MULTI_BARS_PARAMS,
25
+ layerIndex: LAYER_INDEX_OF_GRAPHIC,
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
+ barWidth: {
35
+ toBeTypes: ['number']
36
+ },
37
+ barPadding: {
38
+ toBeTypes: ['number']
39
+ },
40
+ barGroupPadding: {
41
+ toBeTypes: ['number']
42
+ },
43
+ barRadius: {
44
+ toBeTypes: ['number', 'boolean']
45
+ }
46
+ })
47
+ return result
48
+ }
49
+ }
50
+
51
+ export const MultiBars = defineMultiGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
52
+ const destroy$ = new Subject()
53
+
54
+ const unsubscribeFnArr: (() => void)[] = []
55
+
56
+ const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
57
+
58
+ multiGridPluginDetail$
59
+ .pipe(
60
+ takeUntil(destroy$)
61
+ )
62
+ .subscribe(data => {
63
+ // 每次重新計算時,清除之前的訂閱
64
+ unsubscribeFnArr.forEach(fn => fn())
65
+
66
+ selection.selectAll(`g.${gridClassName}`)
67
+ .data(data)
68
+ .join('g')
69
+ .attr('class', gridClassName)
70
+ .each((d, i, g) => {
71
+
72
+ const gridSelection = d3.select(g[i])
73
+
74
+ const isSeriesSeprate$ = d.dataFormatter$.pipe(
75
+ takeUntil(destroy$),
76
+ map(d => d.separateSeries),
77
+ distinctUntilChanged(),
78
+ shareReplay(1)
79
+ )
80
+
81
+ unsubscribeFnArr[i] = createBaseBars(pluginName, {
82
+ selection: gridSelection,
83
+ computedData$: d.computedData$,
84
+ visibleComputedData$: d.visibleComputedData$,
85
+ computedLayoutData$: d.computedLayoutData$,
86
+ visibleComputedLayoutData$: d.visibleComputedLayoutData$,
87
+ seriesLabels$: d.seriesLabels$,
88
+ SeriesDataMap$: d.SeriesDataMap$,
89
+ GroupDataMap$: d.GroupDataMap$,
90
+ fullParams$: observer.fullParams$,
91
+ fullChartParams$: observer.fullChartParams$,
92
+ gridAxesTransform$: d.gridAxesTransform$,
93
+ gridGraphicTransform$: d.gridGraphicTransform$,
94
+ gridGraphicReverseScale$: d.gridGraphicReverseScale$,
95
+ gridAxesSize$: d.gridAxesSize$,
96
+ gridHighlight$: d.gridHighlight$,
97
+ gridContainerPosition$: d.gridContainerPosition$,
98
+ isSeriesSeprate$,
99
+ event$: subject.event$ as Subject<any>,
100
+ })
101
+ })
102
+ })
103
+
104
+ return () => {
105
+ destroy$.next(undefined)
106
+ unsubscribeFnArr.forEach(fn => fn())
107
+ }
108
+ })
@@ -1,114 +1,114 @@
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_BARS_TRIANGLE_PARAMS } from '../defaults'
13
- import { createBaseBarsTriangle } from '../../base/BaseBarsTriangle'
14
- import { multiGridPluginDetailObservables } from '../multiGridObservables'
15
- import { getClassName, getUniID } from '../../utils/orbchartsUtils'
16
- import { LAYER_INDEX_OF_GRAPHIC } from '../../const'
17
-
18
- const pluginName = 'MultiBarsTriangle'
19
-
20
- const gridClassName = getClassName(pluginName, 'grid')
21
-
22
- const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_BARS_TRIANGLE_PARAMS> = {
23
- name: pluginName,
24
- defaultParams: DEFAULT_MULTI_BARS_TRIANGLE_PARAMS,
25
- layerIndex: LAYER_INDEX_OF_GRAPHIC,
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
- barWidth: {
35
- toBeTypes: ['number']
36
- },
37
- barPadding: {
38
- toBeTypes: ['number']
39
- },
40
- barGroupPadding: {
41
- toBeTypes: ['number']
42
- },
43
- linearGradientOpacity: {
44
- toBe: '[number, number]',
45
- test: (value: any) => {
46
- return Array.isArray(value)
47
- && value.length === 2
48
- && typeof value[0] === 'number'
49
- && typeof value[1] === 'number'
50
- }
51
- }
52
- })
53
- return result
54
- }
55
- }
56
-
57
- export const MultiBarsTriangle = defineMultiGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
58
- const destroy$ = new Subject()
59
-
60
- const unsubscribeFnArr: (() => void)[] = []
61
-
62
- const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
63
-
64
- multiGridPluginDetail$
65
- .pipe(
66
- takeUntil(destroy$)
67
- )
68
- .subscribe(data => {
69
- // 每次重新計算時,清除之前的訂閱
70
- unsubscribeFnArr.forEach(fn => fn())
71
-
72
- selection.selectAll(`g.${gridClassName}`)
73
- .data(data)
74
- .join('g')
75
- .attr('class', gridClassName)
76
- .each((d, i, g) => {
77
-
78
- const gridSelection = d3.select(g[i])
79
-
80
- const isSeriesSeprate$ = d.dataFormatter$.pipe(
81
- takeUntil(destroy$),
82
- map(d => d.grid.separateSeries),
83
- distinctUntilChanged(),
84
- shareReplay(1)
85
- )
86
-
87
- unsubscribeFnArr[i] = createBaseBarsTriangle(pluginName, {
88
- selection: gridSelection,
89
- computedData$: d.computedData$,
90
- visibleComputedData$: d.visibleComputedData$,
91
- computedLayoutData$: d.computedLayoutData$,
92
- visibleComputedLayoutData$: d.visibleComputedLayoutData$,
93
- seriesLabels$: d.seriesLabels$,
94
- SeriesDataMap$: d.SeriesDataMap$,
95
- GroupDataMap$: d.GroupDataMap$,
96
- fullParams$: observer.fullParams$,
97
- fullChartParams$: observer.fullChartParams$,
98
- fullDataFormatter$: d.dataFormatter$,
99
- gridAxesTransform$: d.gridAxesTransform$,
100
- gridGraphicTransform$: d.gridGraphicTransform$,
101
- gridAxesSize$: d.gridAxesSize$,
102
- gridHighlight$: d.gridHighlight$,
103
- gridContainerPosition$: d.gridContainerPosition$,
104
- isSeriesSeprate$: isSeriesSeprate$,
105
- event$: subject.event$ as Subject<any>,
106
- })
107
- })
108
- })
109
-
110
- return () => {
111
- destroy$.next(undefined)
112
- unsubscribeFnArr.forEach(fn => fn())
113
- }
114
- })
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_BARS_TRIANGLE_PARAMS } from '../defaults'
13
+ import { createBaseBarsTriangle } from '../../base/BaseBarsTriangle'
14
+ import { multiGridPluginDetailObservables } from '../multiGridObservables'
15
+ import { getClassName, getUniID } from '../../utils/orbchartsUtils'
16
+ import { LAYER_INDEX_OF_GRAPHIC } from '../../const'
17
+
18
+ const pluginName = 'MultiBarsTriangle'
19
+
20
+ const gridClassName = getClassName(pluginName, 'grid')
21
+
22
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_BARS_TRIANGLE_PARAMS> = {
23
+ name: pluginName,
24
+ defaultParams: DEFAULT_MULTI_BARS_TRIANGLE_PARAMS,
25
+ layerIndex: LAYER_INDEX_OF_GRAPHIC,
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
+ barWidth: {
35
+ toBeTypes: ['number']
36
+ },
37
+ barPadding: {
38
+ toBeTypes: ['number']
39
+ },
40
+ barGroupPadding: {
41
+ toBeTypes: ['number']
42
+ },
43
+ linearGradientOpacity: {
44
+ toBe: '[number, number]',
45
+ test: (value: any) => {
46
+ return Array.isArray(value)
47
+ && value.length === 2
48
+ && typeof value[0] === 'number'
49
+ && typeof value[1] === 'number'
50
+ }
51
+ }
52
+ })
53
+ return result
54
+ }
55
+ }
56
+
57
+ export const MultiBarsTriangle = defineMultiGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
58
+ const destroy$ = new Subject()
59
+
60
+ const unsubscribeFnArr: (() => void)[] = []
61
+
62
+ const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
63
+
64
+ multiGridPluginDetail$
65
+ .pipe(
66
+ takeUntil(destroy$)
67
+ )
68
+ .subscribe(data => {
69
+ // 每次重新計算時,清除之前的訂閱
70
+ unsubscribeFnArr.forEach(fn => fn())
71
+
72
+ selection.selectAll(`g.${gridClassName}`)
73
+ .data(data)
74
+ .join('g')
75
+ .attr('class', gridClassName)
76
+ .each((d, i, g) => {
77
+
78
+ const gridSelection = d3.select(g[i])
79
+
80
+ const isSeriesSeprate$ = d.dataFormatter$.pipe(
81
+ takeUntil(destroy$),
82
+ map(d => d.separateSeries),
83
+ distinctUntilChanged(),
84
+ shareReplay(1)
85
+ )
86
+
87
+ unsubscribeFnArr[i] = createBaseBarsTriangle(pluginName, {
88
+ selection: gridSelection,
89
+ computedData$: d.computedData$,
90
+ visibleComputedData$: d.visibleComputedData$,
91
+ computedLayoutData$: d.computedLayoutData$,
92
+ visibleComputedLayoutData$: d.visibleComputedLayoutData$,
93
+ seriesLabels$: d.seriesLabels$,
94
+ SeriesDataMap$: d.SeriesDataMap$,
95
+ GroupDataMap$: d.GroupDataMap$,
96
+ fullParams$: observer.fullParams$,
97
+ fullChartParams$: observer.fullChartParams$,
98
+ fullDataFormatter$: d.dataFormatter$,
99
+ gridAxesTransform$: d.gridAxesTransform$,
100
+ gridGraphicTransform$: d.gridGraphicTransform$,
101
+ gridAxesSize$: d.gridAxesSize$,
102
+ gridHighlight$: d.gridHighlight$,
103
+ gridContainerPosition$: d.gridContainerPosition$,
104
+ isSeriesSeprate$: isSeriesSeprate$,
105
+ event$: subject.event$ as Subject<any>,
106
+ })
107
+ })
108
+ })
109
+
110
+ return () => {
111
+ destroy$.next(undefined)
112
+ unsubscribeFnArr.forEach(fn => fn())
113
+ }
114
+ })
@@ -1,102 +1,102 @@
1
- import * as d3 from 'd3'
2
- import {
3
- takeUntil,
4
- Subject } from 'rxjs'
5
- import type { DefinePluginConfig } from '../../../lib/core-types'
6
- import {
7
- defineMultiGridPlugin } from '../../../lib/core'
8
- import { DEFAULT_MULTI_DOTS_PARAMS } from '../defaults'
9
- import { createBaseDots } from '../../base/BaseDots'
10
- import { multiGridPluginDetailObservables } from '../multiGridObservables'
11
- import { getClassName, getUniID } from '../../utils/orbchartsUtils'
12
- import { LAYER_INDEX_OF_GRAPHIC_COVER } from '../../const'
13
-
14
- const pluginName = 'MultiDots'
15
-
16
- const gridClassName = getClassName(pluginName, 'grid')
17
-
18
- const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_DOTS_PARAMS> = {
19
- name: pluginName,
20
- defaultParams: DEFAULT_MULTI_DOTS_PARAMS,
21
- layerIndex: LAYER_INDEX_OF_GRAPHIC_COVER,
22
- validator: (params, { validateColumns }) => {
23
- const result = validateColumns(params, {
24
- gridIndexes: {
25
- toBe: 'number[] | "all"',
26
- test: (value: any) => {
27
- return value === 'all' || (Array.isArray(value) && value.every((v: any) => typeof v === 'number'))
28
- }
29
- },
30
- radius: {
31
- toBeTypes: ['number']
32
- },
33
- fillColorType: {
34
- toBeOption: 'ColorType',
35
- },
36
- strokeColorType: {
37
- toBeOption: 'ColorType',
38
- },
39
- strokeWidth: {
40
- toBeTypes: ['number']
41
- },
42
- // strokeWidthWhileHighlight: {
43
- // toBeTypes: ['number']
44
- // },
45
- onlyShowHighlighted: {
46
- toBeTypes: ['boolean']
47
- }
48
- })
49
- return result
50
- }
51
- }
52
-
53
- export const MultiDots = defineMultiGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
54
- const destroy$ = new Subject()
55
-
56
- const unsubscribeFnArr: (() => void)[] = []
57
-
58
- const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
59
-
60
- multiGridPluginDetail$
61
- .pipe(
62
- takeUntil(destroy$)
63
- )
64
- .subscribe(data => {
65
- // 每次重新計算時,清除之前的訂閱
66
- unsubscribeFnArr.forEach(fn => fn())
67
-
68
- selection.selectAll(`g.${gridClassName}`)
69
- .data(data)
70
- .join('g')
71
- .attr('class', gridClassName)
72
- .each((d, i, g) => {
73
-
74
- const gridSelection = d3.select(g[i])
75
-
76
- unsubscribeFnArr[i] = createBaseDots(pluginName, {
77
- selection: gridSelection,
78
- computedData$: d.computedData$,
79
- visibleComputedData$: d.visibleComputedData$,
80
- computedLayoutData$: d.computedLayoutData$,
81
- visibleComputedLayoutData$: d.visibleComputedLayoutData$,
82
- seriesLabels$: d.seriesLabels$,
83
- SeriesDataMap$: d.SeriesDataMap$,
84
- GroupDataMap$: d.GroupDataMap$,
85
- fullParams$: observer.fullParams$,
86
- fullChartParams$: observer.fullChartParams$,
87
- gridAxesTransform$: d.gridAxesTransform$,
88
- gridGraphicTransform$: d.gridGraphicTransform$,
89
- gridGraphicReverseScale$: d.gridGraphicReverseScale$,
90
- gridAxesSize$: d.gridAxesSize$,
91
- gridHighlight$: d.gridHighlight$,
92
- gridContainerPosition$: d.gridContainerPosition$,
93
- event$: subject.event$ as Subject<any>,
94
- })
95
- })
96
- })
97
-
98
- return () => {
99
- destroy$.next(undefined)
100
- unsubscribeFnArr.forEach(fn => fn())
101
- }
102
- })
1
+ import * as d3 from 'd3'
2
+ import {
3
+ takeUntil,
4
+ Subject } from 'rxjs'
5
+ import type { DefinePluginConfig } from '../../../lib/core-types'
6
+ import {
7
+ defineMultiGridPlugin } from '../../../lib/core'
8
+ import { DEFAULT_MULTI_DOTS_PARAMS } from '../defaults'
9
+ import { createBaseDots } from '../../base/BaseDots'
10
+ import { multiGridPluginDetailObservables } from '../multiGridObservables'
11
+ import { getClassName, getUniID } from '../../utils/orbchartsUtils'
12
+ import { LAYER_INDEX_OF_GRAPHIC_COVER } from '../../const'
13
+
14
+ const pluginName = 'MultiDots'
15
+
16
+ const gridClassName = getClassName(pluginName, 'grid')
17
+
18
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_MULTI_DOTS_PARAMS> = {
19
+ name: pluginName,
20
+ defaultParams: DEFAULT_MULTI_DOTS_PARAMS,
21
+ layerIndex: LAYER_INDEX_OF_GRAPHIC_COVER,
22
+ validator: (params, { validateColumns }) => {
23
+ const result = validateColumns(params, {
24
+ gridIndexes: {
25
+ toBe: 'number[] | "all"',
26
+ test: (value: any) => {
27
+ return value === 'all' || (Array.isArray(value) && value.every((v: any) => typeof v === 'number'))
28
+ }
29
+ },
30
+ radius: {
31
+ toBeTypes: ['number']
32
+ },
33
+ fillColorType: {
34
+ toBeOption: 'ColorType',
35
+ },
36
+ strokeColorType: {
37
+ toBeOption: 'ColorType',
38
+ },
39
+ strokeWidth: {
40
+ toBeTypes: ['number']
41
+ },
42
+ // strokeWidthWhileHighlight: {
43
+ // toBeTypes: ['number']
44
+ // },
45
+ onlyShowHighlighted: {
46
+ toBeTypes: ['boolean']
47
+ }
48
+ })
49
+ return result
50
+ }
51
+ }
52
+
53
+ export const MultiDots = defineMultiGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
54
+ const destroy$ = new Subject()
55
+
56
+ const unsubscribeFnArr: (() => void)[] = []
57
+
58
+ const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
59
+
60
+ multiGridPluginDetail$
61
+ .pipe(
62
+ takeUntil(destroy$)
63
+ )
64
+ .subscribe(data => {
65
+ // 每次重新計算時,清除之前的訂閱
66
+ unsubscribeFnArr.forEach(fn => fn())
67
+
68
+ selection.selectAll(`g.${gridClassName}`)
69
+ .data(data)
70
+ .join('g')
71
+ .attr('class', gridClassName)
72
+ .each((d, i, g) => {
73
+
74
+ const gridSelection = d3.select(g[i])
75
+
76
+ unsubscribeFnArr[i] = createBaseDots(pluginName, {
77
+ selection: gridSelection,
78
+ computedData$: d.computedData$,
79
+ visibleComputedData$: d.visibleComputedData$,
80
+ computedLayoutData$: d.computedLayoutData$,
81
+ visibleComputedLayoutData$: d.visibleComputedLayoutData$,
82
+ seriesLabels$: d.seriesLabels$,
83
+ SeriesDataMap$: d.SeriesDataMap$,
84
+ GroupDataMap$: d.GroupDataMap$,
85
+ fullParams$: observer.fullParams$,
86
+ fullChartParams$: observer.fullChartParams$,
87
+ gridAxesTransform$: d.gridAxesTransform$,
88
+ gridGraphicTransform$: d.gridGraphicTransform$,
89
+ gridGraphicReverseScale$: d.gridGraphicReverseScale$,
90
+ gridAxesSize$: d.gridAxesSize$,
91
+ gridHighlight$: d.gridHighlight$,
92
+ gridContainerPosition$: d.gridContainerPosition$,
93
+ event$: subject.event$ as Subject<any>,
94
+ })
95
+ })
96
+ })
97
+
98
+ return () => {
99
+ destroy$.next(undefined)
100
+ unsubscribeFnArr.forEach(fn => fn())
101
+ }
102
+ })