@orbcharts/plugins-basic 3.0.0-alpha.75 → 3.0.0-alpha.77

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 (143) hide show
  1. package/LICENSE +200 -200
  2. package/dist/lib/plugins-basic-types.d.ts +1 -0
  3. package/dist/orbcharts-plugins-basic.es.js +3461 -3468
  4. package/dist/orbcharts-plugins-basic.umd.js +17 -17
  5. package/dist/src/base/BaseBarStack.d.ts +1 -5
  6. package/dist/src/base/BaseBars.d.ts +1 -6
  7. package/dist/src/base/BaseBarsTriangle.d.ts +1 -6
  8. package/dist/src/base/BaseDots.d.ts +2 -8
  9. package/dist/src/base/BaseGroupAxis.d.ts +2 -16
  10. package/dist/src/base/BaseLegend.d.ts +2 -15
  11. package/dist/src/base/BaseLineAreas.d.ts +1 -4
  12. package/dist/src/base/BaseLines.d.ts +1 -4
  13. package/dist/src/base/BaseValueAxis.d.ts +2 -16
  14. package/dist/src/grid/defaults.d.ts +1 -1
  15. package/dist/src/grid/index.d.ts +0 -1
  16. package/dist/src/grid/plugins/BarStack.d.ts +1 -1
  17. package/dist/src/grid/plugins/Bars.d.ts +1 -1
  18. package/dist/src/grid/plugins/BarsPN.d.ts +1 -1
  19. package/dist/src/grid/plugins/BarsTriangle.d.ts +1 -1
  20. package/dist/src/grid/plugins/Dots.d.ts +1 -1
  21. package/dist/src/grid/plugins/GridLegend.d.ts +1 -1
  22. package/dist/src/grid/plugins/GroupAux.d.ts +1 -1
  23. package/dist/src/grid/plugins/GroupAxis.d.ts +1 -1
  24. package/dist/src/grid/plugins/LineAreas.d.ts +1 -1
  25. package/dist/src/grid/plugins/Lines.d.ts +1 -1
  26. package/dist/src/grid/plugins/ScalingArea.d.ts +1 -1
  27. package/dist/src/grid/plugins/ValueAxis.d.ts +1 -1
  28. package/dist/src/grid/plugins/ValueStackAxis.d.ts +1 -1
  29. package/dist/src/multiGrid/defaults.d.ts +1 -1
  30. package/dist/src/multiGrid/index.d.ts +0 -1
  31. package/dist/src/multiGrid/plugins/MultiBarStack.d.ts +1 -1
  32. package/dist/src/multiGrid/plugins/MultiBars.d.ts +1 -1
  33. package/dist/src/multiGrid/plugins/MultiBarsTriangle.d.ts +1 -1
  34. package/dist/src/multiGrid/plugins/MultiDots.d.ts +1 -1
  35. package/dist/src/multiGrid/plugins/MultiGridLegend.d.ts +1 -1
  36. package/dist/src/multiGrid/plugins/MultiGroupAxis.d.ts +1 -1
  37. package/dist/src/multiGrid/plugins/MultiLineAreas.d.ts +1 -1
  38. package/dist/src/multiGrid/plugins/MultiLines.d.ts +1 -1
  39. package/dist/src/multiGrid/plugins/MultiValueAxis.d.ts +1 -1
  40. package/dist/src/multiGrid/plugins/MultiValueStackAxis.d.ts +1 -1
  41. package/dist/src/multiGrid/plugins/OverlappingValueAxes.d.ts +1 -1
  42. package/dist/src/multiGrid/plugins/OverlappingValueStackAxes.d.ts +1 -1
  43. package/dist/src/noneData/defaults.d.ts +1 -1
  44. package/dist/src/noneData/index.d.ts +0 -1
  45. package/dist/src/noneData/plugins/Container.d.ts +1 -1
  46. package/dist/src/noneData/plugins/Tooltip.d.ts +1 -1
  47. package/dist/src/series/defaults.d.ts +1 -1
  48. package/dist/src/series/index.d.ts +0 -1
  49. package/dist/src/series/plugins/Bubbles.d.ts +1 -1
  50. package/dist/src/series/plugins/Pie.d.ts +1 -1
  51. package/dist/src/series/plugins/PieEventTexts.d.ts +1 -1
  52. package/dist/src/series/plugins/PieLabels.d.ts +1 -1
  53. package/dist/src/series/plugins/Rose.d.ts +1 -1
  54. package/dist/src/series/plugins/RoseLabels.d.ts +1 -1
  55. package/dist/src/series/plugins/SeriesLegend.d.ts +1 -1
  56. package/dist/src/tree/defaults.d.ts +1 -1
  57. package/dist/src/tree/index.d.ts +0 -1
  58. package/dist/src/tree/plugins/TreeLegend.d.ts +1 -1
  59. package/dist/src/tree/plugins/TreeMap.d.ts +1 -1
  60. package/lib/core-types.ts +7 -7
  61. package/lib/core.ts +6 -6
  62. package/lib/plugins-basic-types.ts +6 -0
  63. package/package.json +44 -43
  64. package/src/base/BaseBarStack.ts +780 -779
  65. package/src/base/BaseBars.ts +765 -764
  66. package/src/base/BaseBarsTriangle.ts +674 -672
  67. package/src/base/BaseDots.ts +515 -513
  68. package/src/base/BaseGroupAxis.ts +679 -678
  69. package/src/base/BaseLegend.ts +644 -642
  70. package/src/base/BaseLineAreas.ts +629 -627
  71. package/src/base/BaseLines.ts +706 -704
  72. package/src/base/BaseValueAxis.ts +580 -578
  73. package/src/base/types.ts +2 -2
  74. package/src/const.ts +30 -30
  75. package/src/grid/defaults.ts +128 -128
  76. package/src/grid/gridObservables.ts +545 -545
  77. package/src/grid/index.ts +15 -15
  78. package/src/grid/plugins/BarStack.ts +64 -64
  79. package/src/grid/plugins/Bars.ts +69 -69
  80. package/src/grid/plugins/BarsPN.ts +66 -66
  81. package/src/grid/plugins/BarsTriangle.ts +73 -73
  82. package/src/grid/plugins/Dots.ts +68 -68
  83. package/src/grid/plugins/GridLegend.ts +96 -96
  84. package/src/grid/plugins/GroupAux.ts +1098 -1098
  85. package/src/grid/plugins/GroupAxis.ts +97 -97
  86. package/src/grid/plugins/LineAreas.ts +65 -65
  87. package/src/grid/plugins/Lines.ts +59 -59
  88. package/src/grid/plugins/ScalingArea.ts +218 -218
  89. package/src/grid/plugins/ValueAxis.ts +93 -93
  90. package/src/grid/plugins/ValueStackAxis.ts +95 -95
  91. package/src/index.ts +9 -9
  92. package/src/multiGrid/defaults.ts +158 -158
  93. package/src/multiGrid/index.ts +13 -13
  94. package/src/multiGrid/multiGridObservables.ts +49 -49
  95. package/src/multiGrid/plugins/MultiBarStack.ts +106 -106
  96. package/src/multiGrid/plugins/MultiBars.ts +108 -108
  97. package/src/multiGrid/plugins/MultiBarsTriangle.ts +114 -114
  98. package/src/multiGrid/plugins/MultiDots.ts +102 -102
  99. package/src/multiGrid/plugins/MultiGridLegend.ts +148 -148
  100. package/src/multiGrid/plugins/MultiGroupAxis.ts +137 -137
  101. package/src/multiGrid/plugins/MultiLineAreas.ts +107 -107
  102. package/src/multiGrid/plugins/MultiLines.ts +101 -101
  103. package/src/multiGrid/plugins/MultiValueAxis.ts +133 -133
  104. package/src/multiGrid/plugins/MultiValueStackAxis.ts +133 -133
  105. package/src/multiGrid/plugins/OverlappingValueAxes.ts +299 -299
  106. package/src/multiGrid/plugins/OverlappingValueStackAxes.ts +298 -298
  107. package/src/noneData/defaults.ts +102 -102
  108. package/src/noneData/index.ts +3 -3
  109. package/src/noneData/plugins/Container.ts +27 -27
  110. package/src/noneData/plugins/Tooltip.ts +373 -373
  111. package/src/series/defaults.ts +149 -149
  112. package/src/series/index.ts +9 -9
  113. package/src/series/plugins/Bubbles.ts +603 -603
  114. package/src/series/plugins/Pie.ts +623 -623
  115. package/src/series/plugins/PieEventTexts.ts +283 -283
  116. package/src/series/plugins/PieLabels.ts +640 -640
  117. package/src/series/plugins/Rose.ts +516 -516
  118. package/src/series/plugins/RoseLabels.ts +600 -600
  119. package/src/series/plugins/SeriesLegend.ts +96 -96
  120. package/src/series/seriesObservables.ts +145 -145
  121. package/src/series/seriesUtils.ts +51 -51
  122. package/src/tree/defaults.ts +23 -23
  123. package/src/tree/index.ts +3 -3
  124. package/src/tree/plugins/TreeLegend.ts +96 -96
  125. package/src/tree/plugins/TreeMap.ts +333 -333
  126. package/src/utils/commonUtils.ts +21 -21
  127. package/src/utils/d3Graphics.ts +174 -174
  128. package/src/utils/d3Utils.ts +73 -73
  129. package/src/utils/observables.ts +14 -14
  130. package/src/utils/orbchartsUtils.ts +100 -100
  131. package/tsconfig.base.json +13 -13
  132. package/tsconfig.json +2 -2
  133. package/vite.config.js +22 -22
  134. package/dist/src/grid/types.d.ts +0 -93
  135. package/dist/src/multiGrid/types.d.ts +0 -61
  136. package/dist/src/noneData/types.d.ts +0 -24
  137. package/dist/src/series/types.d.ts +0 -73
  138. package/dist/src/tree/types.d.ts +0 -21
  139. package/src/grid/types.ts +0 -124
  140. package/src/multiGrid/types.ts +0 -73
  141. package/src/noneData/types.ts +0 -26
  142. package/src/series/types.ts +0 -87
  143. package/src/tree/types.ts +0 -23
@@ -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
  })
@@ -1,96 +1,96 @@
1
- import * as d3 from 'd3'
2
- import {
3
- combineLatest,
4
- map,
5
- switchMap,
6
- takeUntil,
7
- Observable,
8
- Subject } from 'rxjs'
9
- import {
10
- defineGridPlugin } from '../../../lib/core'
11
- import type { DefinePluginConfig } from '../../../lib/core-types'
12
- import { DEFAULT_GRID_LEGEND_PARAMS } from '../defaults'
13
- import { LAYER_INDEX_OF_INFO } from '../../const'
14
- import { createBaseLegend } from '../../base/BaseLegend'
15
-
16
- const pluginName = 'GridLegend'
17
-
18
- const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_GRID_LEGEND_PARAMS> = {
19
- name: pluginName,
20
- defaultParams: DEFAULT_GRID_LEGEND_PARAMS,
21
- layerIndex: LAYER_INDEX_OF_INFO,
22
- validator: (params, { validateColumns }) => {
23
- const result = validateColumns(params, {
24
- padding: {
25
- toBeTypes: ['number']
26
- },
27
- backgroundFill: {
28
- toBeOption: 'ColorType',
29
- },
30
- backgroundStroke: {
31
- toBeOption: 'ColorType',
32
- },
33
- gap: {
34
- toBeTypes: ['number']
35
- },
36
- listRectWidth: {
37
- toBeTypes: ['number']
38
- },
39
- listRectHeight: {
40
- toBeTypes: ['number']
41
- },
42
- listRectRadius: {
43
- toBeTypes: ['number']
44
- },
45
- textColorType: {
46
- toBeOption: 'ColorType',
47
- }
48
- })
49
- return result
50
- }
51
- }
52
-
53
- export const GridLegend = defineGridPlugin(pluginConfig)(({ selection, rootSelection, observer, subject }) => {
54
-
55
- const destroy$ = new Subject()
56
-
57
- const seriesLabels$: Observable<string[]> = observer.SeriesDataMap$.pipe(
58
- takeUntil(destroy$),
59
- map(data => {
60
- return Array.from(data.keys())
61
- })
62
- )
63
-
64
- // 全部列點矩型使用相同樣式參數
65
- const fullParams$ = observer.fullParams$.pipe(
66
- takeUntil(destroy$),
67
- map(d => {
68
- const seriesList = [
69
- {
70
- listRectWidth: d.listRectWidth,
71
- listRectHeight: d.listRectHeight,
72
- listRectRadius: d.listRectRadius,
73
- }
74
- ]
75
- return {
76
- ...d,
77
- seriesList
78
- }
79
- })
80
- )
81
-
82
- const unsubscribeBaseLegend = createBaseLegend(pluginName, {
83
- rootSelection,
84
- seriesLabels$,
85
- fullParams$,
86
- layout$: observer.layout$,
87
- fullChartParams$: observer.fullChartParams$,
88
- textSizePx$: observer.textSizePx$
89
- })
90
-
91
- return () => {
92
- destroy$.next(undefined)
93
- unsubscribeBaseLegend()
94
- }
95
- })
96
-
1
+ import * as d3 from 'd3'
2
+ import {
3
+ combineLatest,
4
+ map,
5
+ switchMap,
6
+ takeUntil,
7
+ Observable,
8
+ Subject } from 'rxjs'
9
+ import {
10
+ defineGridPlugin } from '../../../lib/core'
11
+ import type { DefinePluginConfig } from '../../../lib/core-types'
12
+ import { DEFAULT_GRID_LEGEND_PARAMS } from '../defaults'
13
+ import { LAYER_INDEX_OF_INFO } from '../../const'
14
+ import { createBaseLegend } from '../../base/BaseLegend'
15
+
16
+ const pluginName = 'GridLegend'
17
+
18
+ const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_GRID_LEGEND_PARAMS> = {
19
+ name: pluginName,
20
+ defaultParams: DEFAULT_GRID_LEGEND_PARAMS,
21
+ layerIndex: LAYER_INDEX_OF_INFO,
22
+ validator: (params, { validateColumns }) => {
23
+ const result = validateColumns(params, {
24
+ padding: {
25
+ toBeTypes: ['number']
26
+ },
27
+ backgroundFill: {
28
+ toBeOption: 'ColorType',
29
+ },
30
+ backgroundStroke: {
31
+ toBeOption: 'ColorType',
32
+ },
33
+ gap: {
34
+ toBeTypes: ['number']
35
+ },
36
+ listRectWidth: {
37
+ toBeTypes: ['number']
38
+ },
39
+ listRectHeight: {
40
+ toBeTypes: ['number']
41
+ },
42
+ listRectRadius: {
43
+ toBeTypes: ['number']
44
+ },
45
+ textColorType: {
46
+ toBeOption: 'ColorType',
47
+ }
48
+ })
49
+ return result
50
+ }
51
+ }
52
+
53
+ export const GridLegend = defineGridPlugin(pluginConfig)(({ selection, rootSelection, observer, subject }) => {
54
+
55
+ const destroy$ = new Subject()
56
+
57
+ const seriesLabels$: Observable<string[]> = observer.SeriesDataMap$.pipe(
58
+ takeUntil(destroy$),
59
+ map(data => {
60
+ return Array.from(data.keys())
61
+ })
62
+ )
63
+
64
+ // 全部列點矩型使用相同樣式參數
65
+ const fullParams$ = observer.fullParams$.pipe(
66
+ takeUntil(destroy$),
67
+ map(d => {
68
+ const seriesList = [
69
+ {
70
+ listRectWidth: d.listRectWidth,
71
+ listRectHeight: d.listRectHeight,
72
+ listRectRadius: d.listRectRadius,
73
+ }
74
+ ]
75
+ return {
76
+ ...d,
77
+ seriesList
78
+ }
79
+ })
80
+ )
81
+
82
+ const unsubscribeBaseLegend = createBaseLegend(pluginName, {
83
+ rootSelection,
84
+ seriesLabels$,
85
+ fullParams$,
86
+ layout$: observer.layout$,
87
+ fullChartParams$: observer.fullChartParams$,
88
+ textSizePx$: observer.textSizePx$
89
+ })
90
+
91
+ return () => {
92
+ destroy$.next(undefined)
93
+ unsubscribeBaseLegend()
94
+ }
95
+ })
96
+