@orbcharts/plugin-basic 4.0.0-pre-alpha.0

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 (208) hide show
  1. package/LICENSE +201 -0
  2. package/dist/orbcharts-plugin-basic.es.js +25335 -0
  3. package/dist/orbcharts-plugin-basic.umd.js +341 -0
  4. package/dist/plugin-basic/src/baseLayers/BaseBars.d.ts +38 -0
  5. package/dist/plugin-basic/src/baseLayers/BaseBarsTriangle.d.ts +37 -0
  6. package/dist/plugin-basic/src/baseLayers/BaseCategoryAxis.d.ts +42 -0
  7. package/dist/plugin-basic/src/baseLayers/BaseDots.d.ts +38 -0
  8. package/dist/plugin-basic/src/baseLayers/BaseLegend.d.ts +31 -0
  9. package/dist/plugin-basic/src/baseLayers/BaseLineAreas.d.ts +36 -0
  10. package/dist/plugin-basic/src/baseLayers/BaseLines.d.ts +36 -0
  11. package/dist/plugin-basic/src/baseLayers/BaseStackedBars.d.ts +41 -0
  12. package/dist/plugin-basic/src/baseLayers/BaseTooltip.d.ts +47 -0
  13. package/dist/plugin-basic/src/baseLayers/BaseValueAxis.d.ts +38 -0
  14. package/dist/plugin-basic/src/baseLayers/BaseXAxis.d.ts +25 -0
  15. package/dist/plugin-basic/src/baseLayers/BaseXZoom.d.ts +22 -0
  16. package/dist/plugin-basic/src/baseLayers/BaseYAxis.d.ts +23 -0
  17. package/dist/plugin-basic/src/baseLayers/types.d.ts +171 -0
  18. package/dist/plugin-basic/src/const/layerIndex.d.ts +10 -0
  19. package/dist/plugin-basic/src/const/sharedPluginParams.d.ts +6 -0
  20. package/dist/plugin-basic/src/index.d.ts +2 -0
  21. package/dist/plugin-basic/src/plugins/CompositionPlot/CompositionPlot.d.ts +22 -0
  22. package/dist/plugin-basic/src/plugins/CompositionPlot/contextObservables.d.ts +40 -0
  23. package/dist/plugin-basic/src/plugins/CompositionPlot/defaults.d.ts +10 -0
  24. package/dist/plugin-basic/src/plugins/CompositionPlot/index.d.ts +3 -0
  25. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/Bubbles.d.ts +16 -0
  26. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/Indicator.d.ts +0 -0
  27. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/Pie.d.ts +16 -0
  28. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/PieEventTexts.d.ts +16 -0
  29. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/PieLabels.d.ts +16 -0
  30. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/Rose.d.ts +16 -0
  31. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/RoseLabels.d.ts +16 -0
  32. package/dist/plugin-basic/src/plugins/CompositionPlot/layers/Waffle.d.ts +0 -0
  33. package/dist/plugin-basic/src/plugins/CompositionPlot/types.d.ts +110 -0
  34. package/dist/plugin-basic/src/plugins/CompositionPlot/utils.d.ts +19 -0
  35. package/dist/plugin-basic/src/plugins/HierarchyPlot/HierarchyPlot.d.ts +22 -0
  36. package/dist/plugin-basic/src/plugins/HierarchyPlot/contextObservables.d.ts +16 -0
  37. package/dist/plugin-basic/src/plugins/HierarchyPlot/defaults.d.ts +4 -0
  38. package/dist/plugin-basic/src/plugins/HierarchyPlot/index.d.ts +3 -0
  39. package/dist/plugin-basic/src/plugins/HierarchyPlot/layers/TreeMap.d.ts +16 -0
  40. package/dist/plugin-basic/src/plugins/HierarchyPlot/types.d.ts +29 -0
  41. package/dist/plugin-basic/src/plugins/Legend/Legend.d.ts +22 -0
  42. package/dist/plugin-basic/src/plugins/Legend/contextObservables.d.ts +9 -0
  43. package/dist/plugin-basic/src/plugins/Legend/defaults.d.ts +4 -0
  44. package/dist/plugin-basic/src/plugins/Legend/index.d.ts +3 -0
  45. package/dist/plugin-basic/src/plugins/Legend/layers/Legend.d.ts +16 -0
  46. package/dist/plugin-basic/src/plugins/Legend/types.d.ts +31 -0
  47. package/dist/plugin-basic/src/plugins/Legend/utils.d.ts +19 -0
  48. package/dist/plugin-basic/src/plugins/NetworkPlot/NetworkPlot.d.ts +22 -0
  49. package/dist/plugin-basic/src/plugins/NetworkPlot/contextObservables.d.ts +19 -0
  50. package/dist/plugin-basic/src/plugins/NetworkPlot/defaults.d.ts +5 -0
  51. package/dist/plugin-basic/src/plugins/NetworkPlot/index.d.ts +3 -0
  52. package/dist/plugin-basic/src/plugins/NetworkPlot/layers/ForceDirected.d.ts +16 -0
  53. package/dist/plugin-basic/src/plugins/NetworkPlot/layers/ForceDirectedBubbles.d.ts +16 -0
  54. package/dist/plugin-basic/src/plugins/NetworkPlot/types.d.ts +117 -0
  55. package/dist/plugin-basic/src/plugins/ScatterPlot/ScatterPlot.d.ts +22 -0
  56. package/dist/plugin-basic/src/plugins/ScatterPlot/contextObservables.d.ts +140 -0
  57. package/dist/plugin-basic/src/plugins/ScatterPlot/defaults.d.ts +8 -0
  58. package/dist/plugin-basic/src/plugins/ScatterPlot/index.d.ts +3 -0
  59. package/dist/plugin-basic/src/plugins/ScatterPlot/layers/Scatter.d.ts +16 -0
  60. package/dist/plugin-basic/src/plugins/ScatterPlot/layers/ScatterBubbles.d.ts +16 -0
  61. package/dist/plugin-basic/src/plugins/ScatterPlot/layers/XYAux.d.ts +16 -0
  62. package/dist/plugin-basic/src/plugins/ScatterPlot/layers/XYAxes.d.ts +16 -0
  63. package/dist/plugin-basic/src/plugins/ScatterPlot/layers/XZoom.d.ts +16 -0
  64. package/dist/plugin-basic/src/plugins/ScatterPlot/types.d.ts +146 -0
  65. package/dist/plugin-basic/src/plugins/SeriesPlot/SeriesPlot.d.ts +22 -0
  66. package/dist/plugin-basic/src/plugins/SeriesPlot/contextObservables.d.ts +77 -0
  67. package/dist/plugin-basic/src/plugins/SeriesPlot/defaults.d.ts +15 -0
  68. package/dist/plugin-basic/src/plugins/SeriesPlot/index.d.ts +3 -0
  69. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/Bars.d.ts +16 -0
  70. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/BarsPN.d.ts +16 -0
  71. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/BarsTriangle.d.ts +16 -0
  72. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/CategoryAux.d.ts +16 -0
  73. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/CategoryAxis.d.ts +16 -0
  74. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/CategoryZoom.d.ts +16 -0
  75. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/Dots.d.ts +16 -0
  76. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/LineAreas.d.ts +16 -0
  77. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/Lines.d.ts +16 -0
  78. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/StackedBars.d.ts +16 -0
  79. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/StackedValueAxis.d.ts +16 -0
  80. package/dist/plugin-basic/src/plugins/SeriesPlot/layers/ValueAxis.d.ts +16 -0
  81. package/dist/plugin-basic/src/plugins/SeriesPlot/types.d.ts +140 -0
  82. package/dist/plugin-basic/src/plugins/Tooltip/Tooltip.d.ts +22 -0
  83. package/dist/plugin-basic/src/plugins/Tooltip/contextObservables.d.ts +9 -0
  84. package/dist/plugin-basic/src/plugins/Tooltip/defaults.d.ts +4 -0
  85. package/dist/plugin-basic/src/plugins/Tooltip/index.d.ts +3 -0
  86. package/dist/plugin-basic/src/plugins/Tooltip/layers/Tooltip.d.ts +16 -0
  87. package/dist/plugin-basic/src/plugins/Tooltip/types.d.ts +35 -0
  88. package/dist/plugin-basic/src/plugins/Tooltip/utils.d.ts +19 -0
  89. package/dist/plugin-basic/src/plugins/index.d.ts +7 -0
  90. package/dist/plugin-basic/src/types/BaseLayer.d.ts +3 -0
  91. package/dist/plugin-basic/src/types/Common.d.ts +14 -0
  92. package/dist/plugin-basic/src/types/ComputedData.d.ts +27 -0
  93. package/dist/plugin-basic/src/types/PluginParams.d.ts +66 -0
  94. package/dist/plugin-basic/src/types/index.d.ts +3 -0
  95. package/dist/plugin-basic/src/utils/commonUtils.d.ts +3 -0
  96. package/dist/plugin-basic/src/utils/d3Graphics.d.ts +24 -0
  97. package/dist/plugin-basic/src/utils/d3Scale.d.ts +28 -0
  98. package/dist/plugin-basic/src/utils/d3Utils.d.ts +14 -0
  99. package/dist/plugin-basic/src/utils/graphObservables.d.ts +0 -0
  100. package/dist/plugin-basic/src/utils/gridObservables.d.ts +51 -0
  101. package/dist/plugin-basic/src/utils/multivariateObservables.d.ts +74 -0
  102. package/dist/plugin-basic/src/utils/observables.d.ts +34 -0
  103. package/dist/plugin-basic/src/utils/orbchartsUtils.d.ts +26 -0
  104. package/dist/plugin-basic/src/utils/seriesObservables.d.ts +22 -0
  105. package/dist/plugin-basic/vite.config.d.ts +2 -0
  106. package/dist/src/index.d.ts +1 -0
  107. package/package.json +62 -0
  108. package/src/baseLayers/BaseBars.ts +783 -0
  109. package/src/baseLayers/BaseBarsTriangle.ts +692 -0
  110. package/src/baseLayers/BaseCategoryAxis.ts +708 -0
  111. package/src/baseLayers/BaseDots.ts +495 -0
  112. package/src/baseLayers/BaseLegend.ts +684 -0
  113. package/src/baseLayers/BaseLineAreas.ts +644 -0
  114. package/src/baseLayers/BaseLines.ts +721 -0
  115. package/src/baseLayers/BaseStackedBars.ts +818 -0
  116. package/src/baseLayers/BaseTooltip.ts +435 -0
  117. package/src/baseLayers/BaseValueAxis.ts +612 -0
  118. package/src/baseLayers/BaseXAxis.ts +412 -0
  119. package/src/baseLayers/BaseXZoom.ts +250 -0
  120. package/src/baseLayers/BaseYAxis.ts +371 -0
  121. package/src/baseLayers/types.ts +174 -0
  122. package/src/const/layerIndex.ts +36 -0
  123. package/src/const/sharedPluginParams.ts +29 -0
  124. package/src/index.ts +3 -0
  125. package/src/plugins/CompositionPlot/CompositionPlot.ts +308 -0
  126. package/src/plugins/CompositionPlot/contextObservables.ts +251 -0
  127. package/src/plugins/CompositionPlot/defaults.ts +162 -0
  128. package/src/plugins/CompositionPlot/index.ts +3 -0
  129. package/src/plugins/CompositionPlot/layers/Bubbles.ts +808 -0
  130. package/src/plugins/CompositionPlot/layers/Indicator.ts +0 -0
  131. package/src/plugins/CompositionPlot/layers/Pie.ts +776 -0
  132. package/src/plugins/CompositionPlot/layers/PieEventTexts.ts +326 -0
  133. package/src/plugins/CompositionPlot/layers/PieLabels.ts +651 -0
  134. package/src/plugins/CompositionPlot/layers/Rose.ts +546 -0
  135. package/src/plugins/CompositionPlot/layers/RoseLabels.ts +616 -0
  136. package/src/plugins/CompositionPlot/layers/Waffle.ts +0 -0
  137. package/src/plugins/CompositionPlot/types.ts +129 -0
  138. package/src/plugins/CompositionPlot/utils.ts +53 -0
  139. package/src/plugins/HierarchyPlot/HierarchyPlot.ts +190 -0
  140. package/src/plugins/HierarchyPlot/contextObservables.ts +136 -0
  141. package/src/plugins/HierarchyPlot/defaults.ts +31 -0
  142. package/src/plugins/HierarchyPlot/index.ts +3 -0
  143. package/src/plugins/HierarchyPlot/layers/TreeMap.ts +371 -0
  144. package/src/plugins/HierarchyPlot/types.ts +36 -0
  145. package/src/plugins/Legend/Legend.ts +151 -0
  146. package/src/plugins/Legend/contextObservables.ts +55 -0
  147. package/src/plugins/Legend/defaults.ts +37 -0
  148. package/src/plugins/Legend/index.ts +3 -0
  149. package/src/plugins/Legend/layers/Legend.ts +114 -0
  150. package/src/plugins/Legend/types.ts +45 -0
  151. package/src/plugins/Legend/utils.ts +53 -0
  152. package/src/plugins/NetworkPlot/NetworkPlot.ts +228 -0
  153. package/src/plugins/NetworkPlot/contextObservables.ts +123 -0
  154. package/src/plugins/NetworkPlot/defaults.ts +147 -0
  155. package/src/plugins/NetworkPlot/index.ts +3 -0
  156. package/src/plugins/NetworkPlot/layers/ForceDirected.ts +1048 -0
  157. package/src/plugins/NetworkPlot/layers/ForceDirectedBubbles.ts +1318 -0
  158. package/src/plugins/NetworkPlot/types.ts +146 -0
  159. package/src/plugins/ScatterPlot/ScatterPlot.ts +569 -0
  160. package/src/plugins/ScatterPlot/contextObservables.ts +901 -0
  161. package/src/plugins/ScatterPlot/defaults.ts +212 -0
  162. package/src/plugins/ScatterPlot/index.ts +3 -0
  163. package/src/plugins/ScatterPlot/layers/Scatter.ts +518 -0
  164. package/src/plugins/ScatterPlot/layers/ScatterBubbles.ts +670 -0
  165. package/src/plugins/ScatterPlot/layers/XYAux.ts +686 -0
  166. package/src/plugins/ScatterPlot/layers/XYAxes.ts +205 -0
  167. package/src/plugins/ScatterPlot/layers/XZoom.ts +48 -0
  168. package/src/plugins/ScatterPlot/types.ts +179 -0
  169. package/src/plugins/SeriesPlot/SeriesPlot.ts +494 -0
  170. package/src/plugins/SeriesPlot/contextObservables.ts +726 -0
  171. package/src/plugins/SeriesPlot/defaults.ts +142 -0
  172. package/src/plugins/SeriesPlot/index.ts +3 -0
  173. package/src/plugins/SeriesPlot/layers/Bars.ts +84 -0
  174. package/src/plugins/SeriesPlot/layers/BarsPN.ts +85 -0
  175. package/src/plugins/SeriesPlot/layers/BarsTriangle.ts +89 -0
  176. package/src/plugins/SeriesPlot/layers/CategoryAux.ts +1131 -0
  177. package/src/plugins/SeriesPlot/layers/CategoryAxis.ts +92 -0
  178. package/src/plugins/SeriesPlot/layers/CategoryZoom.ts +233 -0
  179. package/src/plugins/SeriesPlot/layers/Dots.ts +91 -0
  180. package/src/plugins/SeriesPlot/layers/LineAreas.ts +82 -0
  181. package/src/plugins/SeriesPlot/layers/Lines.ts +75 -0
  182. package/src/plugins/SeriesPlot/layers/StackedBars.ts +85 -0
  183. package/src/plugins/SeriesPlot/layers/StackedValueAxis.ts +111 -0
  184. package/src/plugins/SeriesPlot/layers/ValueAxis.ts +111 -0
  185. package/src/plugins/SeriesPlot/types.ts +201 -0
  186. package/src/plugins/Tooltip/Tooltip.ts +159 -0
  187. package/src/plugins/Tooltip/contextObservables.ts +55 -0
  188. package/src/plugins/Tooltip/defaults.ts +458 -0
  189. package/src/plugins/Tooltip/index.ts +3 -0
  190. package/src/plugins/Tooltip/layers/Tooltip.ts +90 -0
  191. package/src/plugins/Tooltip/types.ts +55 -0
  192. package/src/plugins/Tooltip/utils.ts +53 -0
  193. package/src/plugins/index.ts +8 -0
  194. package/src/types/BaseLayer.ts +3 -0
  195. package/src/types/Common.ts +20 -0
  196. package/src/types/ComputedData.ts +55 -0
  197. package/src/types/PluginParams.ts +81 -0
  198. package/src/types/index.ts +3 -0
  199. package/src/utils/commonUtils.ts +31 -0
  200. package/src/utils/d3Graphics.ts +177 -0
  201. package/src/utils/d3Scale.ts +198 -0
  202. package/src/utils/d3Utils.ts +92 -0
  203. package/src/utils/graphObservables.ts +0 -0
  204. package/src/utils/gridObservables.ts +637 -0
  205. package/src/utils/multivariateObservables.ts +790 -0
  206. package/src/utils/observables.ts +357 -0
  207. package/src/utils/orbchartsUtils.ts +335 -0
  208. package/src/utils/seriesObservables.ts +172 -0
@@ -0,0 +1,142 @@
1
+ import type { BarsParams, BarsTriangleParams, DotsParams, SeriesPlotPluginParams, CategoryAuxParams, CategoryAxisParams, CategoryZoomParams, LineAreasParams, LinesParams, StackedBarsParams, StackedValueAxisParams, ValueAxisParams } from './types'
2
+ import { DEFAULT_CATEGORY_AXIS, DEFAULT_CONTAINER, DEFAULT_VALUE_AXIS } from '../../const/sharedPluginParams'
3
+
4
+ export const DEFAULT_SERIES_PLOT_PARAMS: SeriesPlotPluginParams = {
5
+ styles: {
6
+ padding: {
7
+ top: 20,
8
+ right: 60,
9
+ bottom: 80,
10
+ left: 60
11
+ },
12
+ highlightTarget: 'datum',
13
+ highlightDefault: null,
14
+ unhighlightedOpacity: 0.3,
15
+ transitionDuration: 800,
16
+ transitionEase: 'easeCubic'
17
+ },
18
+ visibleFilter: (datum) => true,
19
+ container: { ...DEFAULT_CONTAINER },
20
+ valueAxis: { ...DEFAULT_VALUE_AXIS },
21
+ categoryAxis: { ...DEFAULT_CATEGORY_AXIS},
22
+ separateSeries: false,
23
+ datasetIndex: 0
24
+ }
25
+ DEFAULT_SERIES_PLOT_PARAMS.visibleFilter.toString = () => '(datum) => true'
26
+
27
+ export const DEFAULT_LINES_PARAMS: LinesParams = {
28
+ lineCurve: 'curveLinear',
29
+ lineWidth: 2
30
+ }
31
+
32
+ export const DEFAULT_LINE_AREAS_PARAMS: LineAreasParams = {
33
+ lineCurve: 'curveLinear',
34
+ linearGradientOpacity: [1, 0]
35
+ }
36
+
37
+ export const DEFAULT_DOTS_PARAMS: DotsParams = {
38
+ radius: 4,
39
+ fillColorType: 'background',
40
+ strokeColorType: 'data',
41
+ strokeWidth: 2,
42
+ // strokeWidthWhileHighlight: 3,
43
+ onlyShowHighlighted: false
44
+ }
45
+
46
+ export const DEFAULT_CATEGORY_AUX_PARAMS: CategoryAuxParams = {
47
+ showLine: true,
48
+ showLabel: true,
49
+ lineDashArray: '3, 3',
50
+ lineColorType: 'primary',
51
+ labelColorType: 'primary',
52
+ labelTextColorType: 'background',
53
+ labelTextFormat: text => text,
54
+ labelPadding: 20,
55
+ labelRotate: 0
56
+ }
57
+ DEFAULT_CATEGORY_AUX_PARAMS.labelTextFormat.toString = () => `text => text`
58
+
59
+ export const DEFAULT_BARS_PARAMS: BarsParams = {
60
+ // barType: 'rect',
61
+ barWidth: 0,
62
+ barPadding: 1,
63
+ barGroupPadding: 40,
64
+ barRadius: false,
65
+ }
66
+
67
+ export const DEFAULT_BARS_DIVERGING_PARAMS: BarsParams = {
68
+ ...DEFAULT_BARS_PARAMS
69
+ }
70
+
71
+ export const DEFAULT_STACKED_BARS_PARAMS: StackedBarsParams = {
72
+ barWidth: 0,
73
+ barGroupPadding: 10,
74
+ barRadius: false,
75
+ }
76
+
77
+ export const DEFAULT_BARS_TRIANGLE_PARAMS: BarsTriangleParams = {
78
+ barWidth: 0,
79
+ barPadding: 1,
80
+ barGroupPadding: 20,
81
+ linearGradientOpacity: [1, 0]
82
+ }
83
+
84
+ export const DEFAULT_CATEGORY_AXIS_PARAMS: CategoryAxisParams = {
85
+ // labelAnchor: 'start',
86
+ labelOffset: [0, 0],
87
+ labelColorType: 'primary',
88
+ axisLineVisible: true,
89
+ axisLineColorType: 'primary',
90
+ ticks: 'all',
91
+ tickFormat: text => text,
92
+ tickLineVisible: true,
93
+ tickPadding: 20,
94
+ tickFullLine: false,
95
+ tickFullLineDasharray: 'none',
96
+ tickColorType: 'secondary',
97
+ tickTextRotate: 0,
98
+ tickTextColorType: 'primary',
99
+ }
100
+ DEFAULT_CATEGORY_AXIS_PARAMS.tickFormat.toString = () => `text => text`
101
+
102
+ export const DEFAULT_VALUE_AXIS_PARAMS: ValueAxisParams = {
103
+ // labelAnchor: 'end',
104
+ labelOffset: [0, 0],
105
+ labelColorType: 'primary',
106
+ axisLineVisible: false,
107
+ axisLineColorType: 'primary',
108
+ ticks: null,
109
+ // tickFormat: ',.0f',
110
+ // tickFormat: v => v,
111
+ tickFormat: num => {
112
+ if (num === null || Number.isNaN(num) == true) {
113
+ return num || 0
114
+ }
115
+ const parts = num.toString().split('.')
116
+ parts[0] = parts[0].replace(/\B(?=(\d{3})+(?!\d))/g, ',')
117
+ return parts.join('.')
118
+ },
119
+ tickLineVisible: true,
120
+ tickPadding: 20,
121
+ tickFullLine: true,
122
+ tickFullLineDasharray: 'none',
123
+ tickColorType: 'secondary',
124
+ tickTextRotate: 0,
125
+ tickTextColorType: 'primary'
126
+ }
127
+ DEFAULT_VALUE_AXIS_PARAMS.tickFormat.toString = () => `num => {
128
+ if (num === null || Number.isNaN(num) == true) {
129
+ return num || 0
130
+ }
131
+ const parts = num.toString().split('.')
132
+ parts[0] = parts[0].replace(/\B(?=(\d{3})+(?!\d))/g, ',')
133
+ return parts.join('.')
134
+ }`
135
+
136
+ export const DEFAULT_STACKED_VALUE_AXIS_PARAMS: StackedValueAxisParams = {
137
+ ...DEFAULT_VALUE_AXIS_PARAMS
138
+ }
139
+
140
+ export const DEFAULT_CATEGORY_ZOOM_PARAMS: CategoryZoomParams = {
141
+
142
+ }
@@ -0,0 +1,3 @@
1
+ export { SeriesPlot } from './SeriesPlot'
2
+ export * from './defaults'
3
+ export * from './types'
@@ -0,0 +1,84 @@
1
+ import * as d3 from 'd3'
2
+ import {
3
+ Subject,
4
+ Observable,
5
+ map,
6
+ distinctUntilChanged,
7
+ shareReplay,
8
+ takeUntil
9
+ } from 'rxjs'
10
+ import type { BarsParams, SeriesPlotPluginParams } from '../types'
11
+ import { DEFAULT_BARS_PARAMS } from '../defaults'
12
+ import { LAYER_INDEX_OF_GRAPHIC } from '../../../const/layerIndex'
13
+ import { createBaseBars } from '../../../baseLayers/BaseBars'
14
+ import { defineSVGLayer } from '@orbcharts/core'
15
+ import { SeriesPlotExtendContext } from '../types'
16
+ import { validateObject } from '@orbcharts/core'
17
+
18
+ const pluginName = 'SeriesPlot'
19
+ const layerName = 'Bars'
20
+
21
+ export const Bars = defineSVGLayer<SeriesPlotExtendContext, SeriesPlotPluginParams, BarsParams>({
22
+ name: layerName,
23
+ defaultParams: DEFAULT_BARS_PARAMS,
24
+ layerIndex: LAYER_INDEX_OF_GRAPHIC,
25
+ initShow: true,
26
+ validator: (params) => {
27
+ const result = validateObject(params, {
28
+ barWidth: {
29
+ toBeTypes: ['number']
30
+ },
31
+ barPadding: {
32
+ toBeTypes: ['number']
33
+ },
34
+ barGroupPadding: {
35
+ toBeTypes: ['number']
36
+ },
37
+ barRadius: {
38
+ toBeTypes: ['number', 'boolean']
39
+ }
40
+ })
41
+ return result
42
+ },
43
+ setup: ({ svgG, pluginParams$, layerParams$, context }) => {
44
+ const destroy$ = new Subject()
45
+
46
+ context.layout$
47
+ .pipe(
48
+ takeUntil(destroy$)
49
+ )
50
+ .subscribe(layout => {
51
+ d3.select(svgG)
52
+ .attr('transform', `translate(${layout.left}, ${layout.top})`)
53
+ })
54
+
55
+ const unsubscribeBaseBars = createBaseBars({
56
+ selection: d3.select(svgG),
57
+ pluginName,
58
+ layerName,
59
+ computedData$: context.computedData$,
60
+ visibleComputedData$: context.visibleComputedData$,
61
+ visibleComputedAxesData$: context.visibleComputedAxesData$,
62
+ seriesLabels$: context.seriesLabels$,
63
+ SeriesDataMap$: context.SeriesDataMap$,
64
+ CategoryDataMap$: context.CategoryDataMap$,
65
+ baseBarsParams$: layerParams$,
66
+ gridAxesTransform$: context.gridAxesTransform$,
67
+ gridGraphicTransform$: context.gridGraphicTransform$,
68
+ gridGraphicReverseScale$: context.gridGraphicReverseScale$,
69
+ gridAxesSize$: context.gridAxesSize$,
70
+ gridHighlight$: context.gridHighlight$,
71
+ gridContainerPosition$: context.gridContainerPosition$,
72
+ isSeriesSeprate$: context.isSeriesSeprate$,
73
+ styles$: pluginParams$.pipe(
74
+ map(params => params.styles),
75
+ ),
76
+ eventTrigger$: context.eventTrigger$
77
+ })
78
+
79
+ return () => {
80
+ destroy$.next(undefined)
81
+ unsubscribeBaseBars()
82
+ }
83
+ }
84
+ })
@@ -0,0 +1,85 @@
1
+ import * as d3 from 'd3'
2
+ import {
3
+ Subject,
4
+ Observable,
5
+ of,
6
+ map,
7
+ distinctUntilChanged,
8
+ shareReplay,
9
+ takeUntil
10
+ } from 'rxjs'
11
+ import type { BarsParams, SeriesPlotPluginParams } from '../types'
12
+ import { DEFAULT_BARS_PARAMS } from '../defaults'
13
+ import { LAYER_INDEX_OF_GRAPHIC } from '../../../const/layerIndex'
14
+ import { createBaseBars } from '../../../baseLayers/BaseBars'
15
+ import { defineSVGLayer } from '@orbcharts/core'
16
+ import { SeriesPlotExtendContext } from '../types'
17
+ import { validateObject } from '@orbcharts/core'
18
+
19
+ const pluginName = 'SeriesPlot'
20
+ const layerName = 'BarsPN'
21
+
22
+ export const Bars = defineSVGLayer<SeriesPlotExtendContext, SeriesPlotPluginParams, BarsParams>({
23
+ name: layerName,
24
+ defaultParams: DEFAULT_BARS_PARAMS,
25
+ layerIndex: LAYER_INDEX_OF_GRAPHIC,
26
+ initShow: false,
27
+ validator: (params) => {
28
+ const result = validateObject(params, {
29
+ barWidth: {
30
+ toBeTypes: ['number']
31
+ },
32
+ barPadding: {
33
+ toBeTypes: ['number']
34
+ },
35
+ barGroupPadding: {
36
+ toBeTypes: ['number']
37
+ },
38
+ barRadius: {
39
+ toBeTypes: ['number', 'boolean']
40
+ }
41
+ })
42
+ return result
43
+ },
44
+ setup: ({ svgG, pluginParams$, layerParams$, context }) => {
45
+ const destroy$ = new Subject()
46
+
47
+ context.layout$
48
+ .pipe(
49
+ takeUntil(destroy$)
50
+ )
51
+ .subscribe(layout => {
52
+ d3.select(svgG)
53
+ .attr('transform', `translate(${layout.left}, ${layout.top})`)
54
+ })
55
+
56
+ const unsubscribeBaseBars = createBaseBars({
57
+ selection: d3.select(svgG),
58
+ pluginName,
59
+ layerName,
60
+ computedData$: context.computedData$,
61
+ visibleComputedData$: context.visibleComputedData$,
62
+ visibleComputedAxesData$: context.visibleComputedAxesData$,
63
+ seriesLabels$: context.seriesLabels$,
64
+ SeriesDataMap$: context.SeriesDataMap$,
65
+ CategoryDataMap$: context.CategoryDataMap$,
66
+ baseBarsParams$: layerParams$,
67
+ gridAxesTransform$: context.gridAxesTransform$,
68
+ gridGraphicTransform$: context.gridGraphicTransform$,
69
+ gridGraphicReverseScale$: context.gridGraphicReverseScale$,
70
+ gridAxesSize$: context.gridAxesSize$,
71
+ gridHighlight$: context.gridHighlight$,
72
+ gridContainerPosition$: context.gridContainerPosition$,
73
+ isSeriesSeprate$: of(true), // hack: 永遠為true,可以強制讓每組series的bars的x位置都是一樣的
74
+ styles$: pluginParams$.pipe(
75
+ map(params => params.styles),
76
+ ),
77
+ eventTrigger$: context.eventTrigger$
78
+ })
79
+
80
+ return () => {
81
+ destroy$.next(undefined)
82
+ unsubscribeBaseBars()
83
+ }
84
+ }
85
+ })
@@ -0,0 +1,89 @@
1
+ import * as d3 from 'd3'
2
+ import {
3
+ Subject,
4
+ Observable,
5
+ map,
6
+ distinctUntilChanged,
7
+ shareReplay,
8
+ takeUntil
9
+ } from 'rxjs'
10
+ import type { BarsTriangleParams, SeriesPlotPluginParams } from '../types'
11
+ import { DEFAULT_BARS_TRIANGLE_PARAMS } from '../defaults'
12
+ import { LAYER_INDEX_OF_GRAPHIC } from '../../../const/layerIndex'
13
+ import { createBaseBarsTriangle } from '../../../baseLayers/BaseBarsTriangle'
14
+ import { defineSVGLayer } from '@orbcharts/core'
15
+ import { SeriesPlotExtendContext } from '../types'
16
+ import { validateObject } from '@orbcharts/core'
17
+
18
+ const pluginName = 'SeriesPlot'
19
+ const layerName = 'BarsTriangle'
20
+
21
+ export const BarsTriangle = defineSVGLayer<SeriesPlotExtendContext, SeriesPlotPluginParams, BarsTriangleParams>({
22
+ name: layerName,
23
+ defaultParams: DEFAULT_BARS_TRIANGLE_PARAMS,
24
+ layerIndex: LAYER_INDEX_OF_GRAPHIC,
25
+ initShow: false,
26
+ validator: (params) => {
27
+ const result = validateObject(params, {
28
+ barWidth: {
29
+ toBeTypes: ['number']
30
+ },
31
+ barPadding: {
32
+ toBeTypes: ['number']
33
+ },
34
+ barGroupPadding: {
35
+ toBeTypes: ['number']
36
+ },
37
+ linearGradientOpacity: {
38
+ toBe: '[number, number]',
39
+ test: (value: any) => {
40
+ return Array.isArray(value)
41
+ && value.length === 2
42
+ && typeof value[0] === 'number'
43
+ && typeof value[1] === 'number'
44
+ }
45
+ }
46
+ })
47
+ return result
48
+ },
49
+ setup: ({ svgG, pluginParams$, layerParams$, context }) => {
50
+ const destroy$ = new Subject()
51
+
52
+ context.layout$
53
+ .pipe(
54
+ takeUntil(destroy$)
55
+ )
56
+ .subscribe(layout => {
57
+ d3.select(svgG)
58
+ .attr('transform', `translate(${layout.left}, ${layout.top})`)
59
+ })
60
+
61
+ const unsubscribeBaseBars = createBaseBarsTriangle({
62
+ selection: d3.select(svgG),
63
+ pluginName,
64
+ layerName,
65
+ computedData$: context.computedData$,
66
+ visibleComputedData$: context.visibleComputedData$,
67
+ visibleComputedAxesData$: context.visibleComputedAxesData$,
68
+ seriesLabels$: context.seriesLabels$,
69
+ SeriesDataMap$: context.SeriesDataMap$,
70
+ CategoryDataMap$: context.CategoryDataMap$,
71
+ baseBarsTriangleParams$: layerParams$,
72
+ gridAxesTransform$: context.gridAxesTransform$,
73
+ gridGraphicTransform$: context.gridGraphicTransform$,
74
+ gridAxesSize$: context.gridAxesSize$,
75
+ gridHighlight$: context.gridHighlight$,
76
+ gridContainerPosition$: context.gridContainerPosition$,
77
+ isSeriesSeprate$: context.isSeriesSeprate$,
78
+ styles$: pluginParams$.pipe(
79
+ map(params => params.styles),
80
+ ),
81
+ eventTrigger$: context.eventTrigger$,
82
+ })
83
+
84
+ return () => {
85
+ destroy$.next(undefined)
86
+ unsubscribeBaseBars()
87
+ }
88
+ }
89
+ })