@orbcharts/plugins-basic 3.0.2 → 3.0.3

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 (133) hide show
  1. package/LICENSE +200 -200
  2. package/dist/lib/gridObservables.d.ts +1 -0
  3. package/dist/orbcharts-plugins-basic.es.js +14800 -13543
  4. package/dist/orbcharts-plugins-basic.umd.js +129 -99
  5. package/dist/src/base/BaseOrdinalBubbles.d.ts +26 -0
  6. package/dist/src/base/BaseRacingBars.d.ts +2 -1
  7. package/dist/src/base/BaseRacingLabels.d.ts +1 -0
  8. package/dist/src/base/BaseXZoom.d.ts +18 -0
  9. package/dist/src/grid/gridObservables.d.ts +4 -7
  10. package/dist/src/multiValue/defaults.d.ts +5 -1
  11. package/dist/src/multiValue/index.d.ts +4 -0
  12. package/dist/src/multiValue/multiValueObservables.d.ts +14 -1
  13. package/dist/src/multiValue/plugins/OrdinalAux.d.ts +3 -0
  14. package/dist/src/multiValue/plugins/OrdinalAxis.d.ts +3 -0
  15. package/dist/src/multiValue/plugins/OrdinalBubbles.d.ts +3 -0
  16. package/dist/src/multiValue/plugins/OrdinalZoom.d.ts +1 -0
  17. package/lib/core-types.ts +7 -7
  18. package/lib/core.ts +6 -6
  19. package/lib/gridObservables.ts +6 -0
  20. package/lib/plugins-basic-types.ts +6 -6
  21. package/package.json +48 -48
  22. package/src/base/BaseBars.ts +765 -765
  23. package/src/base/BaseBarsTriangle.ts +676 -676
  24. package/src/base/BaseDots.ts +464 -464
  25. package/src/base/BaseGroupAxis.ts +691 -691
  26. package/src/base/BaseLegend.ts +684 -684
  27. package/src/base/BaseLineAreas.ts +629 -629
  28. package/src/base/BaseLines.ts +706 -706
  29. package/src/base/BaseOrdinalBubbles.ts +728 -0
  30. package/src/base/BaseRacingBars.ts +582 -551
  31. package/src/base/BaseRacingLabels.ts +404 -396
  32. package/src/base/BaseRacingValueLabels.ts +403 -403
  33. package/src/base/BaseStackedBars.ts +782 -782
  34. package/src/base/BaseTooltip.ts +386 -386
  35. package/src/base/BaseValueAxis.ts +600 -600
  36. package/src/base/BaseXAxis.ts +427 -427
  37. package/src/base/BaseXZoom.ts +242 -0
  38. package/src/base/BaseYAxis.ts +389 -389
  39. package/src/base/types.ts +2 -2
  40. package/src/const.ts +30 -30
  41. package/src/grid/defaults.ts +213 -213
  42. package/src/grid/gridObservables.ts +635 -612
  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/GroupAux.ts +1095 -1120
  51. package/src/grid/plugins/GroupAxis.ts +73 -73
  52. package/src/grid/plugins/GroupZoom.ts +218 -218
  53. package/src/grid/plugins/LineAreas.ts +65 -65
  54. package/src/grid/plugins/Lines.ts +59 -59
  55. package/src/grid/plugins/StackedBars.ts +64 -64
  56. package/src/grid/plugins/StackedValueAxis.ts +96 -96
  57. package/src/grid/plugins/ValueAxis.ts +94 -94
  58. package/src/index.ts +6 -6
  59. package/src/multiGrid/defaults.ts +244 -244
  60. package/src/multiGrid/index.ts +14 -14
  61. package/src/multiGrid/multiGridObservables.ts +50 -50
  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 +169 -169
  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/MultiStackedBars.ts +106 -106
  71. package/src/multiGrid/plugins/MultiStackedValueAxis.ts +134 -134
  72. package/src/multiGrid/plugins/MultiValueAxis.ts +134 -134
  73. package/src/multiGrid/plugins/OverlappingStackedValueAxes.ts +300 -300
  74. package/src/multiGrid/plugins/OverlappingValueAxes.ts +300 -300
  75. package/src/multiValue/defaults.ts +523 -431
  76. package/src/multiValue/index.ts +16 -12
  77. package/src/multiValue/multiValueObservables.ts +781 -666
  78. package/src/multiValue/plugins/MultiValueLegend.ts +107 -107
  79. package/src/multiValue/plugins/MultiValueTooltip.ts +66 -66
  80. package/src/multiValue/plugins/OrdinalAux.ts +661 -0
  81. package/src/multiValue/plugins/OrdinalAxis.ts +525 -0
  82. package/src/multiValue/plugins/OrdinalBubbles.ts +226 -0
  83. package/src/multiValue/plugins/OrdinalZoom.ts +57 -0
  84. package/src/multiValue/plugins/RacingBars.ts +375 -373
  85. package/src/multiValue/plugins/RacingCounterTexts.ts +300 -300
  86. package/src/multiValue/plugins/RacingValueAxis.ts +114 -114
  87. package/src/multiValue/plugins/Scatter.ts +486 -426
  88. package/src/multiValue/plugins/ScatterBubbles.ts +635 -554
  89. package/src/multiValue/plugins/XAxis.ts +107 -107
  90. package/src/multiValue/plugins/XYAux.ts +683 -682
  91. package/src/multiValue/plugins/XYAxes.ts +194 -194
  92. package/src/multiValue/plugins/XYAxes_legacy.ts +683 -683
  93. package/src/multiValue/plugins/XZoom.ts +40 -299
  94. package/src/noneData/defaults.ts +102 -102
  95. package/src/noneData/index.ts +3 -3
  96. package/src/noneData/plugins/Container.ts +27 -27
  97. package/src/noneData/plugins/Tooltip.ts +373 -373
  98. package/src/relationship/defaults.ts +221 -221
  99. package/src/relationship/index.ts +5 -5
  100. package/src/relationship/plugins/ForceDirected.ts +1173 -1173
  101. package/src/relationship/plugins/ForceDirectedBubbles.ts +1411 -1411
  102. package/src/relationship/plugins/RelationshipLegend.ts +100 -100
  103. package/src/relationship/plugins/RelationshipTooltip.ts +66 -66
  104. package/src/relationship/relationshipObservables.ts +49 -49
  105. package/src/series/defaults.ts +221 -221
  106. package/src/series/index.ts +9 -9
  107. package/src/series/plugins/Bubbles.ts +636 -636
  108. package/src/series/plugins/Pie.ts +623 -623
  109. package/src/series/plugins/PieEventTexts.ts +284 -284
  110. package/src/series/plugins/PieLabels.ts +640 -640
  111. package/src/series/plugins/Rose.ts +516 -516
  112. package/src/series/plugins/RoseLabels.ts +600 -600
  113. package/src/series/plugins/SeriesLegend.ts +107 -107
  114. package/src/series/plugins/SeriesTooltip.ts +66 -66
  115. package/src/series/seriesObservables.ts +145 -145
  116. package/src/series/seriesUtils.ts +51 -51
  117. package/src/tree/defaults.ts +102 -102
  118. package/src/tree/index.ts +4 -4
  119. package/src/tree/plugins/TreeLegend.ts +100 -100
  120. package/src/tree/plugins/TreeMap.ts +341 -341
  121. package/src/tree/plugins/TreeTooltip.ts +66 -66
  122. package/src/utils/commonUtils.ts +31 -31
  123. package/src/utils/d3Graphics.ts +176 -176
  124. package/src/utils/d3Utils.ts +92 -92
  125. package/src/utils/observables.ts +14 -14
  126. package/src/utils/orbchartsUtils.ts +129 -129
  127. package/tsconfig.base.json +13 -13
  128. package/tsconfig.json +2 -2
  129. package/vite.config.js +22 -22
  130. package/dist/src/multiValue/plugins/OrdinalXAxis.d.ts +0 -0
  131. package/dist/src/multiValue/plugins/RankingAxis_legacy.d.ts +0 -0
  132. package/src/multiValue/plugins/OrdinalXAxis.ts +0 -0
  133. package/src/multiValue/plugins/RankingAxis_legacy.ts +0 -109
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 { StackedBars } from './plugins/StackedBars'
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 { GroupZoom } from './plugins/GroupZoom'
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 { StackedBars } from './plugins/StackedBars'
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 { GroupZoom } from './plugins/GroupZoom'
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
- computedAxesData$: observer.computedAxesData$,
48
- visibleComputedData$: observer.visibleComputedData$,
49
- visibleComputedAxesData$: observer.visibleComputedAxesData$,
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
+ computedAxesData$: observer.computedAxesData$,
48
+ visibleComputedData$: observer.visibleComputedData$,
49
+ visibleComputedAxesData$: observer.visibleComputedAxesData$,
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
- computedAxesData$: observer.computedAxesData$,
44
- visibleComputedData$: observer.visibleComputedData$,
45
- visibleComputedAxesData$: observer.visibleComputedAxesData$,
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
+ computedAxesData$: observer.computedAxesData$,
44
+ visibleComputedData$: observer.visibleComputedData$,
45
+ visibleComputedAxesData$: observer.visibleComputedAxesData$,
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
- computedAxesData$: observer.computedAxesData$,
53
- visibleComputedData$: observer.visibleComputedData$,
54
- visibleComputedAxesData$: observer.visibleComputedAxesData$,
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
+ computedAxesData$: observer.computedAxesData$,
53
+ visibleComputedData$: observer.visibleComputedData$,
54
+ visibleComputedAxesData$: observer.visibleComputedAxesData$,
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
- computedAxesData$: observer.computedAxesData$,
49
- visibleComputedData$: observer.visibleComputedData$,
50
- visibleComputedAxesData$: observer.visibleComputedAxesData$,
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
+ computedAxesData$: observer.computedAxesData$,
49
+ visibleComputedData$: observer.visibleComputedData$,
50
+ visibleComputedAxesData$: observer.visibleComputedAxesData$,
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
  })