@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
package/src/grid/index.ts CHANGED
@@ -1,16 +1,16 @@
1
- export * from './defaults'
2
- // export * from './types'
3
- export { Lines } from './plugins/Lines'
4
- export { LineAreas } from './plugins/LineAreas'
5
- export { Bars } from './plugins/Bars'
6
- export { BarsPN } from './plugins/BarsPN'
7
- export { BarStack } from './plugins/BarStack'
8
- export { BarsTriangle } from './plugins/BarsTriangle'
9
- export { Dots } from './plugins/Dots'
10
- export { GridLegend } from './plugins/GridLegend'
11
- export { GroupAxis } from './plugins/GroupAxis'
12
- export { ValueAxis } from './plugins/ValueAxis'
13
- export { ValueStackAxis } from './plugins/ValueStackAxis'
14
- export { GridTooltip } from './plugins/GridTooltip'
15
- export { GridZoom } from './plugins/GridZoom'
16
- export { GroupAux } from './plugins/GroupAux'
1
+ export * from './defaults'
2
+ // export * from './types'
3
+ export { Lines } from './plugins/Lines'
4
+ export { LineAreas } from './plugins/LineAreas'
5
+ export { Bars } from './plugins/Bars'
6
+ export { BarsPN } from './plugins/BarsPN'
7
+ export { StackedBar } from './plugins/StackedBar'
8
+ export { BarsTriangle } from './plugins/BarsTriangle'
9
+ export { Dots } from './plugins/Dots'
10
+ export { GridLegend } from './plugins/GridLegend'
11
+ export { GroupAxis } from './plugins/GroupAxis'
12
+ export { ValueAxis } from './plugins/ValueAxis'
13
+ export { StackedValueAxis } from './plugins/StackedValueAxis'
14
+ export { GridTooltip } from './plugins/GridTooltip'
15
+ export { GridZoom } from './plugins/GridZoom'
16
+ export { GroupAux } from './plugins/GroupAux'
@@ -1,69 +1,69 @@
1
- import {
2
- Subject,
3
- Observable,
4
- map,
5
- distinctUntilChanged,
6
- shareReplay,
7
- takeUntil
8
- } from 'rxjs'
9
- import type { DefinePluginConfig } from '../../../lib/core-types'
10
- import {
11
- defineGridPlugin } from '../../../lib/core'
12
- import { DEFAULT_BARS_PARAMS } from '../defaults'
13
- import { LAYER_INDEX_OF_GRAPHIC } from '../../const'
14
- import { createBaseBars } from '../../base/BaseBars'
15
-
16
- const pluginName = 'Bars'
17
-
18
- const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_BARS_PARAMS> = {
19
- name: pluginName,
20
- defaultParams: DEFAULT_BARS_PARAMS,
21
- layerIndex: LAYER_INDEX_OF_GRAPHIC,
22
- validator: (params, { validateColumns }) => {
23
- const result = validateColumns(params, {
24
- barWidth: {
25
- toBeTypes: ['number']
26
- },
27
- barPadding: {
28
- toBeTypes: ['number']
29
- },
30
- barGroupPadding: {
31
- toBeTypes: ['number']
32
- },
33
- barRadius: {
34
- toBeTypes: ['number', 'boolean']
35
- }
36
- })
37
- return result
38
- }
39
- }
40
-
41
- export const Bars = defineGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
42
- const destroy$ = new Subject()
43
-
44
- const unsubscribeBaseBars = createBaseBars(pluginName, {
45
- selection,
46
- computedData$: observer.computedData$,
47
- computedLayoutData$: observer.computedLayoutData$,
48
- visibleComputedData$: observer.visibleComputedData$,
49
- visibleComputedLayoutData$: observer.visibleComputedLayoutData$,
50
- seriesLabels$: observer.seriesLabels$,
51
- SeriesDataMap$: observer.SeriesDataMap$,
52
- GroupDataMap$: observer.GroupDataMap$,
53
- fullParams$: observer.fullParams$,
54
- fullChartParams$: observer.fullChartParams$,
55
- gridAxesTransform$: observer.gridAxesTransform$,
56
- gridGraphicTransform$: observer.gridGraphicTransform$,
57
- gridGraphicReverseScale$: observer.gridGraphicReverseScale$,
58
- gridAxesSize$: observer.gridAxesSize$,
59
- gridHighlight$: observer.gridHighlight$,
60
- gridContainerPosition$: observer.gridContainerPosition$,
61
- isSeriesSeprate$: observer.isSeriesSeprate$,
62
- event$: subject.event$,
63
- })
64
-
65
- return () => {
66
- destroy$.next(undefined)
67
- unsubscribeBaseBars()
68
- }
69
- })
1
+ import {
2
+ Subject,
3
+ Observable,
4
+ map,
5
+ distinctUntilChanged,
6
+ shareReplay,
7
+ takeUntil
8
+ } from 'rxjs'
9
+ import type { DefinePluginConfig } from '../../../lib/core-types'
10
+ import {
11
+ defineGridPlugin } from '../../../lib/core'
12
+ import { DEFAULT_BARS_PARAMS } from '../defaults'
13
+ import { LAYER_INDEX_OF_GRAPHIC } from '../../const'
14
+ import { createBaseBars } from '../../base/BaseBars'
15
+
16
+ const pluginName = 'Bars'
17
+
18
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_BARS_PARAMS> = {
19
+ name: pluginName,
20
+ defaultParams: DEFAULT_BARS_PARAMS,
21
+ layerIndex: LAYER_INDEX_OF_GRAPHIC,
22
+ validator: (params, { validateColumns }) => {
23
+ const result = validateColumns(params, {
24
+ barWidth: {
25
+ toBeTypes: ['number']
26
+ },
27
+ barPadding: {
28
+ toBeTypes: ['number']
29
+ },
30
+ barGroupPadding: {
31
+ toBeTypes: ['number']
32
+ },
33
+ barRadius: {
34
+ toBeTypes: ['number', 'boolean']
35
+ }
36
+ })
37
+ return result
38
+ }
39
+ }
40
+
41
+ export const Bars = defineGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
42
+ const destroy$ = new Subject()
43
+
44
+ const unsubscribeBaseBars = createBaseBars(pluginName, {
45
+ selection,
46
+ computedData$: observer.computedData$,
47
+ computedLayoutData$: observer.computedLayoutData$,
48
+ visibleComputedData$: observer.visibleComputedData$,
49
+ visibleComputedLayoutData$: observer.visibleComputedLayoutData$,
50
+ seriesLabels$: observer.seriesLabels$,
51
+ SeriesDataMap$: observer.SeriesDataMap$,
52
+ GroupDataMap$: observer.GroupDataMap$,
53
+ fullParams$: observer.fullParams$,
54
+ fullChartParams$: observer.fullChartParams$,
55
+ gridAxesTransform$: observer.gridAxesTransform$,
56
+ gridGraphicTransform$: observer.gridGraphicTransform$,
57
+ gridGraphicReverseScale$: observer.gridGraphicReverseScale$,
58
+ gridAxesSize$: observer.gridAxesSize$,
59
+ gridHighlight$: observer.gridHighlight$,
60
+ gridContainerPosition$: observer.gridContainerPosition$,
61
+ isSeriesSeprate$: observer.isSeriesSeprate$,
62
+ event$: subject.event$,
63
+ })
64
+
65
+ return () => {
66
+ destroy$.next(undefined)
67
+ unsubscribeBaseBars()
68
+ }
69
+ })
@@ -1,66 +1,66 @@
1
- import {
2
- of,
3
- Subject,
4
- Observable } from 'rxjs'
5
- import type { DefinePluginConfig } from '../../../lib/core-types'
6
- import {
7
- defineGridPlugin } from '../../../lib/core'
8
- import { DEFAULT_BARS_PARAMS } from '../defaults'
9
- import { LAYER_INDEX_OF_GRAPHIC } from '../../const'
10
- import { createBaseBars } from '../../base/BaseBars'
11
-
12
- const pluginName = 'BarsPN'
13
-
14
- const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_BARS_PARAMS> = {
15
- name: pluginName,
16
- defaultParams: DEFAULT_BARS_PARAMS,
17
- layerIndex: LAYER_INDEX_OF_GRAPHIC,
18
- validator: (params, { validateColumns }) => {
19
- const result = validateColumns(params, {
20
- barWidth: {
21
- toBeTypes: ['number']
22
- },
23
- barPadding: {
24
- toBeTypes: ['number']
25
- },
26
- barGroupPadding: {
27
- toBeTypes: ['number']
28
- },
29
- barRadius: {
30
- toBeTypes: ['number', 'boolean']
31
- }
32
- })
33
- return result
34
- }
35
- }
36
-
37
- export const BarsPN = defineGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
38
- const destroy$ = new Subject()
39
-
40
- const unsubscribeBaseBars = createBaseBars(pluginName, {
41
- selection,
42
- computedData$: observer.computedData$,
43
- computedLayoutData$: observer.computedLayoutData$,
44
- visibleComputedData$: observer.visibleComputedData$,
45
- visibleComputedLayoutData$: observer.visibleComputedLayoutData$,
46
- seriesLabels$: observer.seriesLabels$,
47
- SeriesDataMap$: observer.SeriesDataMap$,
48
- GroupDataMap$: observer.GroupDataMap$,
49
- fullParams$: observer.fullParams$,
50
- fullChartParams$: observer.fullChartParams$,
51
- gridAxesTransform$: observer.gridAxesTransform$,
52
- gridGraphicTransform$: observer.gridGraphicTransform$,
53
- gridGraphicReverseScale$: observer.gridGraphicReverseScale$,
54
- gridAxesSize$: observer.gridAxesSize$,
55
- gridHighlight$: observer.gridHighlight$,
56
- gridContainerPosition$: observer.gridContainerPosition$,
57
- // isSeriesSeprate$: observer.isSeriesSeprate$,
58
- isSeriesSeprate$: of(true), // hack: 永遠為true,可以強制讓每組series的bars的x位置都是一樣的
59
- event$: subject.event$,
60
- })
61
-
62
- return () => {
63
- destroy$.next(undefined)
64
- unsubscribeBaseBars()
65
- }
66
- })
1
+ import {
2
+ of,
3
+ Subject,
4
+ Observable } from 'rxjs'
5
+ import type { DefinePluginConfig } from '../../../lib/core-types'
6
+ import {
7
+ defineGridPlugin } from '../../../lib/core'
8
+ import { DEFAULT_BARS_PARAMS } from '../defaults'
9
+ import { LAYER_INDEX_OF_GRAPHIC } from '../../const'
10
+ import { createBaseBars } from '../../base/BaseBars'
11
+
12
+ const pluginName = 'BarsPN'
13
+
14
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_BARS_PARAMS> = {
15
+ name: pluginName,
16
+ defaultParams: DEFAULT_BARS_PARAMS,
17
+ layerIndex: LAYER_INDEX_OF_GRAPHIC,
18
+ validator: (params, { validateColumns }) => {
19
+ const result = validateColumns(params, {
20
+ barWidth: {
21
+ toBeTypes: ['number']
22
+ },
23
+ barPadding: {
24
+ toBeTypes: ['number']
25
+ },
26
+ barGroupPadding: {
27
+ toBeTypes: ['number']
28
+ },
29
+ barRadius: {
30
+ toBeTypes: ['number', 'boolean']
31
+ }
32
+ })
33
+ return result
34
+ }
35
+ }
36
+
37
+ export const BarsPN = defineGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
38
+ const destroy$ = new Subject()
39
+
40
+ const unsubscribeBaseBars = createBaseBars(pluginName, {
41
+ selection,
42
+ computedData$: observer.computedData$,
43
+ computedLayoutData$: observer.computedLayoutData$,
44
+ visibleComputedData$: observer.visibleComputedData$,
45
+ visibleComputedLayoutData$: observer.visibleComputedLayoutData$,
46
+ seriesLabels$: observer.seriesLabels$,
47
+ SeriesDataMap$: observer.SeriesDataMap$,
48
+ GroupDataMap$: observer.GroupDataMap$,
49
+ fullParams$: observer.fullParams$,
50
+ fullChartParams$: observer.fullChartParams$,
51
+ gridAxesTransform$: observer.gridAxesTransform$,
52
+ gridGraphicTransform$: observer.gridGraphicTransform$,
53
+ gridGraphicReverseScale$: observer.gridGraphicReverseScale$,
54
+ gridAxesSize$: observer.gridAxesSize$,
55
+ gridHighlight$: observer.gridHighlight$,
56
+ gridContainerPosition$: observer.gridContainerPosition$,
57
+ // isSeriesSeprate$: observer.isSeriesSeprate$,
58
+ isSeriesSeprate$: of(true), // hack: 永遠為true,可以強制讓每組series的bars的x位置都是一樣的
59
+ event$: subject.event$,
60
+ })
61
+
62
+ return () => {
63
+ destroy$.next(undefined)
64
+ unsubscribeBaseBars()
65
+ }
66
+ })
@@ -1,74 +1,74 @@
1
- import {
2
- Subject,
3
- Observable,
4
- takeUntil,
5
- map,
6
- distinctUntilChanged,
7
- shareReplay
8
- } from 'rxjs'
9
- import type { DefinePluginConfig } from '../../../lib/core-types'
10
- import { defineGridPlugin } from '../../../lib/core'
11
- import { DEFAULT_BARS_TRIANGLE_PARAMS } from '../defaults'
12
- import { LAYER_INDEX_OF_GRAPHIC } from '../../const'
13
- import { createBaseBarsTriangle } from '../../base/BaseBarsTriangle'
14
-
15
- const pluginName = 'BarsTriangle'
16
-
17
- const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_BARS_TRIANGLE_PARAMS> = {
18
- name: pluginName,
19
- defaultParams: DEFAULT_BARS_TRIANGLE_PARAMS,
20
- layerIndex: 5,
21
- validator: (params, { validateColumns }) => {
22
- const result = validateColumns(params, {
23
- barWidth: {
24
- toBeTypes: ['number']
25
- },
26
- barPadding: {
27
- toBeTypes: ['number']
28
- },
29
- barGroupPadding: {
30
- toBeTypes: ['number']
31
- },
32
- linearGradientOpacity: {
33
- toBe: '[number, number]',
34
- test: (value: any) => {
35
- return Array.isArray(value)
36
- && value.length === 2
37
- && typeof value[0] === 'number'
38
- && typeof value[1] === 'number'
39
- }
40
- }
41
- })
42
- return result
43
- }
44
- }
45
-
46
- export const BarsTriangle = defineGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
47
- const destroy$ = new Subject()
48
-
49
- const unsubscribeBaseBars = createBaseBarsTriangle(pluginName, {
50
- selection,
51
- computedData$: observer.computedData$,
52
- computedLayoutData$: observer.computedLayoutData$,
53
- visibleComputedData$: observer.visibleComputedData$,
54
- visibleComputedLayoutData$: observer.visibleComputedLayoutData$,
55
- fullDataFormatter$: observer.fullDataFormatter$,
56
- seriesLabels$: observer.seriesLabels$,
57
- SeriesDataMap$: observer.SeriesDataMap$,
58
- GroupDataMap$: observer.GroupDataMap$,
59
- fullParams$: observer.fullParams$,
60
- fullChartParams$: observer.fullChartParams$,
61
- gridAxesTransform$: observer.gridAxesTransform$,
62
- gridGraphicTransform$: observer.gridGraphicTransform$,
63
- gridAxesSize$: observer.gridAxesSize$,
64
- gridHighlight$: observer.gridHighlight$,
65
- gridContainerPosition$: observer.gridContainerPosition$,
66
- isSeriesSeprate$: observer.isSeriesSeprate$,
67
- event$: subject.event$,
68
- })
69
-
70
- return () => {
71
- destroy$.next(undefined)
72
- unsubscribeBaseBars()
73
- }
1
+ import {
2
+ Subject,
3
+ Observable,
4
+ takeUntil,
5
+ map,
6
+ distinctUntilChanged,
7
+ shareReplay
8
+ } from 'rxjs'
9
+ import type { DefinePluginConfig } from '../../../lib/core-types'
10
+ import { defineGridPlugin } from '../../../lib/core'
11
+ import { DEFAULT_BARS_TRIANGLE_PARAMS } from '../defaults'
12
+ import { LAYER_INDEX_OF_GRAPHIC } from '../../const'
13
+ import { createBaseBarsTriangle } from '../../base/BaseBarsTriangle'
14
+
15
+ const pluginName = 'BarsTriangle'
16
+
17
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_BARS_TRIANGLE_PARAMS> = {
18
+ name: pluginName,
19
+ defaultParams: DEFAULT_BARS_TRIANGLE_PARAMS,
20
+ layerIndex: 5,
21
+ validator: (params, { validateColumns }) => {
22
+ const result = validateColumns(params, {
23
+ barWidth: {
24
+ toBeTypes: ['number']
25
+ },
26
+ barPadding: {
27
+ toBeTypes: ['number']
28
+ },
29
+ barGroupPadding: {
30
+ toBeTypes: ['number']
31
+ },
32
+ linearGradientOpacity: {
33
+ toBe: '[number, number]',
34
+ test: (value: any) => {
35
+ return Array.isArray(value)
36
+ && value.length === 2
37
+ && typeof value[0] === 'number'
38
+ && typeof value[1] === 'number'
39
+ }
40
+ }
41
+ })
42
+ return result
43
+ }
44
+ }
45
+
46
+ export const BarsTriangle = defineGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
47
+ const destroy$ = new Subject()
48
+
49
+ const unsubscribeBaseBars = createBaseBarsTriangle(pluginName, {
50
+ selection,
51
+ computedData$: observer.computedData$,
52
+ computedLayoutData$: observer.computedLayoutData$,
53
+ visibleComputedData$: observer.visibleComputedData$,
54
+ visibleComputedLayoutData$: observer.visibleComputedLayoutData$,
55
+ fullDataFormatter$: observer.fullDataFormatter$,
56
+ seriesLabels$: observer.seriesLabels$,
57
+ SeriesDataMap$: observer.SeriesDataMap$,
58
+ GroupDataMap$: observer.GroupDataMap$,
59
+ fullParams$: observer.fullParams$,
60
+ fullChartParams$: observer.fullChartParams$,
61
+ gridAxesTransform$: observer.gridAxesTransform$,
62
+ gridGraphicTransform$: observer.gridGraphicTransform$,
63
+ gridAxesSize$: observer.gridAxesSize$,
64
+ gridHighlight$: observer.gridHighlight$,
65
+ gridContainerPosition$: observer.gridContainerPosition$,
66
+ isSeriesSeprate$: observer.isSeriesSeprate$,
67
+ event$: subject.event$,
68
+ })
69
+
70
+ return () => {
71
+ destroy$.next(undefined)
72
+ unsubscribeBaseBars()
73
+ }
74
74
  })
@@ -1,69 +1,69 @@
1
- import {
2
- Subject } from 'rxjs'
3
- import {
4
- defineGridPlugin } from '../../../lib/core'
5
- import type { DefinePluginConfig } from '../../../lib/core-types'
6
- import { DEFAULT_DOTS_PARAMS } from '../defaults'
7
- import { LAYER_INDEX_OF_GRAPHIC_COVER } from '../../const'
8
- import { createBaseDots } from '../../base/BaseDots'
9
-
10
- const pluginName = 'Dots'
11
-
12
- const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_DOTS_PARAMS> = {
13
- name: pluginName,
14
- defaultParams: DEFAULT_DOTS_PARAMS,
15
- layerIndex: LAYER_INDEX_OF_GRAPHIC_COVER,
16
- validator: (params, { validateColumns }) => {
17
- const result = validateColumns(params, {
18
- radius: {
19
- toBeTypes: ['number']
20
- },
21
- fillColorType: {
22
- toBeOption: 'ColorType',
23
- },
24
- strokeColorType: {
25
- toBeOption: 'ColorType',
26
- },
27
- strokeWidth: {
28
- toBeTypes: ['number']
29
- },
30
- // strokeWidthWhileHighlight: {
31
- // toBeTypes: ['number']
32
- // },
33
- onlyShowHighlighted: {
34
- toBeTypes: ['boolean']
35
- }
36
- })
37
- return result
38
- }
39
- }
40
-
41
- export const Dots = defineGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
42
-
43
- const destroy$ = new Subject()
44
-
45
- const unsubscribeBaseBars = createBaseDots(pluginName, {
46
- selection,
47
- computedData$: observer.computedData$,
48
- computedLayoutData$: observer.computedLayoutData$,
49
- visibleComputedData$: observer.visibleComputedData$,
50
- visibleComputedLayoutData$: observer.visibleComputedLayoutData$,
51
- seriesLabels$: observer.seriesLabels$,
52
- SeriesDataMap$: observer.SeriesDataMap$,
53
- GroupDataMap$: observer.GroupDataMap$,
54
- fullParams$: observer.fullParams$,
55
- fullChartParams$: observer.fullChartParams$,
56
- gridAxesTransform$: observer.gridAxesTransform$,
57
- gridGraphicTransform$: observer.gridGraphicTransform$,
58
- gridGraphicReverseScale$: observer.gridGraphicReverseScale$,
59
- gridAxesSize$: observer.gridAxesSize$,
60
- gridHighlight$: observer.gridHighlight$,
61
- gridContainerPosition$: observer.gridContainerPosition$,
62
- event$: subject.event$,
63
- })
64
-
65
- return () => {
66
- destroy$.next(undefined)
67
- unsubscribeBaseBars()
68
- }
1
+ import {
2
+ Subject } from 'rxjs'
3
+ import {
4
+ defineGridPlugin } from '../../../lib/core'
5
+ import type { DefinePluginConfig } from '../../../lib/core-types'
6
+ import { DEFAULT_DOTS_PARAMS } from '../defaults'
7
+ import { LAYER_INDEX_OF_GRAPHIC_COVER } from '../../const'
8
+ import { createBaseDots } from '../../base/BaseDots'
9
+
10
+ const pluginName = 'Dots'
11
+
12
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_DOTS_PARAMS> = {
13
+ name: pluginName,
14
+ defaultParams: DEFAULT_DOTS_PARAMS,
15
+ layerIndex: LAYER_INDEX_OF_GRAPHIC_COVER,
16
+ validator: (params, { validateColumns }) => {
17
+ const result = validateColumns(params, {
18
+ radius: {
19
+ toBeTypes: ['number']
20
+ },
21
+ fillColorType: {
22
+ toBeOption: 'ColorType',
23
+ },
24
+ strokeColorType: {
25
+ toBeOption: 'ColorType',
26
+ },
27
+ strokeWidth: {
28
+ toBeTypes: ['number']
29
+ },
30
+ // strokeWidthWhileHighlight: {
31
+ // toBeTypes: ['number']
32
+ // },
33
+ onlyShowHighlighted: {
34
+ toBeTypes: ['boolean']
35
+ }
36
+ })
37
+ return result
38
+ }
39
+ }
40
+
41
+ export const Dots = defineGridPlugin(pluginConfig)(({ selection, name, subject, observer }) => {
42
+
43
+ const destroy$ = new Subject()
44
+
45
+ const unsubscribeBaseBars = createBaseDots(pluginName, {
46
+ selection,
47
+ computedData$: observer.computedData$,
48
+ computedLayoutData$: observer.computedLayoutData$,
49
+ visibleComputedData$: observer.visibleComputedData$,
50
+ visibleComputedLayoutData$: observer.visibleComputedLayoutData$,
51
+ seriesLabels$: observer.seriesLabels$,
52
+ SeriesDataMap$: observer.SeriesDataMap$,
53
+ GroupDataMap$: observer.GroupDataMap$,
54
+ fullParams$: observer.fullParams$,
55
+ fullChartParams$: observer.fullChartParams$,
56
+ gridAxesTransform$: observer.gridAxesTransform$,
57
+ gridGraphicTransform$: observer.gridGraphicTransform$,
58
+ gridGraphicReverseScale$: observer.gridGraphicReverseScale$,
59
+ gridAxesSize$: observer.gridAxesSize$,
60
+ gridHighlight$: observer.gridHighlight$,
61
+ gridContainerPosition$: observer.gridContainerPosition$,
62
+ event$: subject.event$,
63
+ })
64
+
65
+ return () => {
66
+ destroy$.next(undefined)
67
+ unsubscribeBaseBars()
68
+ }
69
69
  })