@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,92 @@
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 { CategoryAxisParams, SeriesPlotPluginParams } from '../types'
11
+ import { DEFAULT_CATEGORY_AXIS_PARAMS } from '../defaults'
12
+ import { LAYER_INDEX_OF_INFO } from '../../../const/layerIndex'
13
+ import { defineSVGLayer } from '@orbcharts/core'
14
+ import { SeriesPlotExtendContext } from '../types'
15
+ import { validateObject } from '@orbcharts/core'
16
+ import { createBaseCategoryAxis } from '../../../baseLayers/BaseCategoryAxis'
17
+
18
+ const pluginName = 'SeriesPlot'
19
+ const layerName = 'CategoryAxis'
20
+
21
+ export const CategoryAxis = defineSVGLayer<SeriesPlotExtendContext, SeriesPlotPluginParams, CategoryAxisParams>({
22
+ name: layerName,
23
+ defaultParams: DEFAULT_CATEGORY_AXIS_PARAMS,
24
+ layerIndex: LAYER_INDEX_OF_INFO,
25
+ initShow: false,
26
+ validator: (params) => {
27
+ const result = validateObject(params, {
28
+ labelOffset: {
29
+ toBe: '[number, number]',
30
+ test: (value: any) => {
31
+ return Array.isArray(value)
32
+ && value.length === 2
33
+ && typeof value[0] === 'number'
34
+ && typeof value[1] === 'number'
35
+ }
36
+ },
37
+ labelColorType: {
38
+ toBeOption: 'ColorType',
39
+ },
40
+ axisLineVisible: {
41
+ toBeTypes: ['boolean']
42
+ },
43
+ axisLineColorType: {
44
+ toBeOption: 'ColorType',
45
+ },
46
+ ticks: {
47
+ toBe: 'number | null | "all"',
48
+ test: (value: any) => {
49
+ return value === null || value === 'all' || typeof value === 'number'
50
+ }
51
+ },
52
+ })
53
+ return result
54
+ },
55
+ setup: ({ svgG, pluginParams$, layerParams$, context }) => {
56
+ const destroy$ = new Subject()
57
+
58
+ context.layout$
59
+ .pipe(
60
+ takeUntil(destroy$)
61
+ )
62
+ .subscribe(layout => {
63
+ d3.select(svgG)
64
+ .attr('transform', `translate(${layout.left}, ${layout.top})`)
65
+ })
66
+
67
+ const unsubscribeBaseGroupAxis = createBaseCategoryAxis({
68
+ selection: d3.select(svgG),
69
+ pluginName,
70
+ layerName,
71
+ computedData$: context.computedData$,
72
+ baseCategoryAxisParams$: layerParams$,
73
+ gridAxesTransform$: context.gridAxesTransform$,
74
+ gridAxesReverseTransform$: context.gridAxesReverseTransform$,
75
+ gridAxesSize$: context.gridAxesSize$,
76
+ gridContainerPosition$: context.gridContainerPosition$,
77
+ isSeriesSeprate$: context.isSeriesSeprate$,
78
+ fontSizePx$: context.fontSizePx$,
79
+ categoryAxis$: context.zoomedCategoryAxis$,
80
+ valueAxis$: pluginParams$.pipe(map(params => params.valueAxis)),
81
+ styles$: pluginParams$.pipe(
82
+ map(params => params.styles),
83
+ ),
84
+ theme$: context.theme$,
85
+ })
86
+
87
+ return () => {
88
+ destroy$.next(undefined)
89
+ unsubscribeBaseGroupAxis()
90
+ }
91
+ }
92
+ })
@@ -0,0 +1,233 @@
1
+ import * as d3 from 'd3'
2
+ import {
3
+ Observable,
4
+ combineLatest,
5
+ switchMap,
6
+ distinctUntilChanged,
7
+ first,
8
+ map,
9
+ takeUntil,
10
+ debounceTime,
11
+ Subject
12
+ } from 'rxjs'
13
+ import type { CategoryZoomParams, SeriesPlotPluginParams } from '../types'
14
+ import { DEFAULT_CATEGORY_ZOOM_PARAMS } from '../defaults'
15
+ import { LAYER_INDEX_OF_ROOT } from '../../../const/layerIndex'
16
+ import { defineSVGLayer } from '@orbcharts/core'
17
+ import { SeriesPlotExtendContext } from '../types'
18
+ import { validateObject } from '@orbcharts/core'
19
+ import { createValueToAxisScale } from '../../../utils/d3Scale'
20
+
21
+ const pluginName = 'SeriesPlot'
22
+ const layerName = 'CategoryZoom'
23
+
24
+ export const CategoryZoom = defineSVGLayer<SeriesPlotExtendContext, SeriesPlotPluginParams, CategoryZoomParams>({
25
+ name: layerName,
26
+ defaultParams: DEFAULT_CATEGORY_ZOOM_PARAMS,
27
+ layerIndex: LAYER_INDEX_OF_ROOT,
28
+ initShow: false,
29
+ validator: (params) => {
30
+ return {
31
+ status: 'success',
32
+ columnName: '',
33
+ expectToBe: ''
34
+ }
35
+ },
36
+ setup: ({ svgG, pluginParams$, layerParams$, context }) => {
37
+ const destroy$ = new Subject()
38
+
39
+ // const rootSelection = d3.select(svgG.parentElement)
40
+ const rootSelection = d3.select(context.svg)
41
+
42
+ // const rootRectSelection: d3.Selection<SVGRectElement, any, any, any> = rootSelection
43
+ // .append('rect')
44
+ // .classed(rectClassName, true)
45
+ // .attr('opacity', 0)
46
+
47
+ // 紀錄zoom最後一次的transform
48
+ let lastTransform = {
49
+ k: 1,
50
+ x: 0,
51
+ y: 0
52
+ }
53
+ // let lastDomain: [number, number] = [0, 0]
54
+
55
+ // context.layout$.pipe(
56
+ // takeUntil(destroy$),
57
+ // ).subscribe(d => {
58
+ // rootRectSelection
59
+ // .attr('width', d.width)
60
+ // .attr('height', d.height)
61
+ // .attr('x', d.left)
62
+ // .attr('y', d.top)
63
+ // })
64
+
65
+ const categoryMaxIndex$ = context.computedData$.pipe(
66
+ map(d => d[0] ? d[0].length - 1 : 0),
67
+ distinctUntilChanged()
68
+ )
69
+
70
+ // const fullDataFormatterEvent$: Subject<DataFormatterGrid> = new Subject()
71
+ // fullDataFormatterEvent$
72
+ // .pipe(
73
+ // takeUntil(destroy$),
74
+ // debounceTime(50)
75
+ // )
76
+ // .subscribe(fullDataFormatter => {
77
+ // store.fullDataFormatter$.next(fullDataFormatter)
78
+ // })
79
+
80
+ const initCategoryAxis$ = pluginParams$.pipe(
81
+ map(d => d.categoryAxis),
82
+ // // 只用第一次資料來計算scale才不會造成每次變動都受到影響
83
+ // first()
84
+ )
85
+
86
+
87
+ const initGroupScale$ = combineLatest({
88
+ initCategoryAxis: initCategoryAxis$,
89
+ // fullDataFormatter: context.fullDataFormatter$,
90
+ categoryMaxIndex: categoryMaxIndex$,
91
+ layout: context.layout$,
92
+ axisSize: context.gridAxesSize$
93
+ }).pipe(
94
+ takeUntil(destroy$),
95
+ debounceTime(0),
96
+ map(data => {
97
+ // const categoryMin = 0
98
+ const categoryScaleDomainMin = data.initCategoryAxis.scaleDomain[0] - data.initCategoryAxis.scalePadding
99
+ const categoryScaleDomainMax = data.initCategoryAxis.scaleDomain[1] === 'max'
100
+ ? data.categoryMaxIndex + data.initCategoryAxis.scalePadding
101
+ : data.initCategoryAxis.scaleDomain[1] as number + data.initCategoryAxis.scalePadding
102
+
103
+ const categoryScale: d3.ScaleLinear<number, number> = createValueToAxisScale({
104
+ maxValue: data.categoryMaxIndex,
105
+ minValue: 0,
106
+ axisWidth: data.axisSize.width,
107
+ scaleDomain: [categoryScaleDomainMin, categoryScaleDomainMax],
108
+ scaleRange: [0, 1]
109
+ })
110
+
111
+ return categoryScale
112
+ })
113
+ )
114
+
115
+ combineLatest({
116
+ initGroupScale: initGroupScale$,
117
+ // initCategoryAxis: initCategoryAxis$,
118
+ // fullDataFormatter: fullDataFormatter$.pipe(first()), // 只用第一次資料來計算scale才不會造成每次變動都受到影響
119
+ pluginParams: pluginParams$,
120
+ categoryMaxIndex: categoryMaxIndex$,
121
+ // layout: context.layout$,
122
+ // axisSize: context.gridAxesSize$
123
+ }).pipe(
124
+ takeUntil(destroy$),
125
+ debounceTime(0),
126
+ ).subscribe(data => {
127
+ const categoryMinIndex = 0
128
+
129
+ const shadowScale = data.initGroupScale.copy()
130
+
131
+ const zoom = d3.zoom()
132
+ // .scaleExtent([1, data.categoryMaxIndex])
133
+ // .translateExtent([[0, 0], [data.layout.rootWidth, data.layout.rootWidth]])
134
+ .on("zoom", function zoomed(event) {
135
+ // debugger
136
+ // console.log('event', event)
137
+ const t = event.transform;
138
+
139
+ // if (event.sourceEvent.type === 'mousemove') {
140
+ // // 當進行平移時,反向計算 x 軸
141
+ // const dx = event.transform.x - currentTransform.x; // 本次平移增量
142
+ // const reversedX = currentTransform.x - dx; // 反向累積平移
143
+ // // 更新變換狀態
144
+ // currentTransform = d3.zoomIdentity
145
+ // .translate(reversedX, event.transform.y)
146
+ // .scale(event.transform.k);
147
+ // } else {
148
+ // // 縮放操作:只更新縮放比例
149
+ // currentTransform = d3.zoomIdentity
150
+ // .translate(currentTransform.x, currentTransform.y)
151
+ // .scale(event.transform.k);
152
+ // }
153
+ // console.log('currentTransform', currentTransform)
154
+
155
+ // console.log('t.x', t.x)
156
+ const mapGroupindex = (d: number) => {
157
+ const n = Math.round(d)
158
+ return Math.min(data.categoryMaxIndex, Math.max(categoryMinIndex, n));
159
+ }
160
+
161
+ const zoomedDomain = data.pluginParams.categoryAxis.position === 'bottom' || data.pluginParams.categoryAxis.position === 'top'
162
+ ? t.rescaleX(shadowScale)
163
+ .domain()
164
+ .map(mapGroupindex)
165
+ : t.rescaleY(shadowScale)
166
+ .domain()
167
+ .map(mapGroupindex)
168
+
169
+
170
+ // domain超過極限值
171
+ if (zoomedDomain[0] <= categoryMinIndex && zoomedDomain[1] >= data.categoryMaxIndex) {
172
+ // 繼續縮小
173
+ if (t.k < lastTransform.k) {
174
+ // 維持前一次的transform
175
+ t.k = lastTransform.k
176
+ t.x = lastTransform.x
177
+ t.y = lastTransform.y
178
+ }
179
+ // domain間距小於1
180
+ } else if ((zoomedDomain[1] - zoomedDomain[0]) <= 1) {
181
+ // 繼續放大
182
+ if (t.k > lastTransform.k) {
183
+ // 維持前一次的transform
184
+ t.k = lastTransform.k
185
+ t.x = lastTransform.x
186
+ t.y = lastTransform.y
187
+ }
188
+ }
189
+
190
+ // 紀錄transform
191
+ lastTransform.k = t.k
192
+ lastTransform.x = t.x
193
+ lastTransform.y = t.y
194
+
195
+
196
+ // const newPluginParams: SeriesPlotPluginParams = {
197
+ // ...data.pluginParams,
198
+ // // grid: {
199
+ // // ...data.fullDataFormatter.grid,
200
+ // categoryAxis: {
201
+ // ...data.pluginParams.categoryAxis,
202
+ // scaleDomain: zoomedDomain
203
+ // }
204
+ // // }
205
+ // }
206
+
207
+ // pluginParams$.next(newPluginParams)
208
+ // context.updateScaleDomain$.next(zoomedDomain as [number, number | "max"])
209
+ context.eventTrigger$.next({
210
+ eventName: 'zoom',
211
+ pluginName,
212
+ layerName,
213
+ target: null,
214
+ data: {
215
+ scaleDomain: zoomedDomain
216
+ }
217
+ })
218
+ })
219
+
220
+ // 傳入外層selection
221
+ // subject.selection.call(zoom as any)
222
+ rootSelection.call(zoom)
223
+
224
+ })
225
+
226
+ return () => {
227
+ destroy$.next(undefined)
228
+ // rootRectSelection.remove()
229
+
230
+ rootSelection.call(d3.zoom().on('zoom', null))
231
+ }
232
+ }
233
+ })
@@ -0,0 +1,91 @@
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 { DotsParams, SeriesPlotPluginParams } from '../types'
11
+ import { DEFAULT_DOTS_PARAMS } from '../defaults'
12
+ import { LAYER_INDEX_OF_GRAPHIC } from '../../../const/layerIndex'
13
+ import { createBaseDots } from '../../../baseLayers/BaseDots'
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 = 'Dots'
20
+
21
+ export const Dots = defineSVGLayer<SeriesPlotExtendContext, SeriesPlotPluginParams, DotsParams>({
22
+ name: layerName,
23
+ defaultParams: DEFAULT_DOTS_PARAMS,
24
+ layerIndex: LAYER_INDEX_OF_GRAPHIC,
25
+ initShow: false,
26
+ validator: (params) => {
27
+ const result = validateObject(params, {
28
+ radius: {
29
+ toBeTypes: ['number']
30
+ },
31
+ fillColorType: {
32
+ toBeOption: 'ColorType',
33
+ },
34
+ strokeColorType: {
35
+ toBeOption: 'ColorType',
36
+ },
37
+ strokeWidth: {
38
+ toBeTypes: ['number']
39
+ },
40
+ // strokeWidthWhileHighlight: {
41
+ // toBeTypes: ['number']
42
+ // },
43
+ onlyShowHighlighted: {
44
+ toBeTypes: ['boolean']
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 unsubscribeBaseDots = createBaseDots({
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
+ baseDotsParams$: layerParams$,
72
+ styles$: pluginParams$.pipe(
73
+ map(params => params.styles),
74
+ ),
75
+ theme$: context.theme$,
76
+ gridAxesTransform$: context.gridAxesTransform$,
77
+ gridGraphicTransform$: context.gridGraphicTransform$,
78
+ gridGraphicReverseScale$: context.gridGraphicReverseScale$,
79
+ gridAxesSize$: context.gridAxesSize$,
80
+ gridHighlight$: context.gridHighlight$,
81
+ gridContainerPosition$: context.gridContainerPosition$,
82
+ // isSeriesSeprate$: context.isSeriesSeprate$,
83
+ eventTrigger$: context.eventTrigger$,
84
+ })
85
+
86
+ return () => {
87
+ destroy$.next(undefined)
88
+ unsubscribeBaseDots()
89
+ }
90
+ }
91
+ })
@@ -0,0 +1,82 @@
1
+ import * as d3 from 'd3'
2
+ import { map, Subject, takeUntil } from 'rxjs'
3
+ import type { LineAreasParams, SeriesPlotPluginParams } from '../types'
4
+ import { defineSVGLayer } from '@orbcharts/core'
5
+ import { SeriesPlotExtendContext } from '../types'
6
+ import { validateObject } from '@orbcharts/core'
7
+ import { DEFAULT_LINE_AREAS_PARAMS } from '../defaults'
8
+ import { createBaseLineAreas } from '../../../baseLayers/BaseLineAreas'
9
+ import { LAYER_INDEX_OF_GRAPHIC_GROUND } from '../../../const/layerIndex'
10
+
11
+ const pluginName = 'SeriesPlot'
12
+ const layerName = 'LineAreas'
13
+
14
+
15
+ export const LineAreas = defineSVGLayer<SeriesPlotExtendContext, SeriesPlotPluginParams, LineAreasParams>({
16
+ name: layerName,
17
+ defaultParams: DEFAULT_LINE_AREAS_PARAMS,
18
+ layerIndex: LAYER_INDEX_OF_GRAPHIC_GROUND,
19
+ initShow: false,
20
+ validator: (params) => {
21
+ const result = validateObject(params, {
22
+ lineCurve: {
23
+ toBeTypes: ['string']
24
+ },
25
+ linearGradientOpacity: {
26
+ toBe: '[number, number]',
27
+ test: (value: any) => {
28
+ return Array.isArray(value)
29
+ && value.length === 2
30
+ && typeof value[0] === 'number'
31
+ && typeof value[1] === 'number'
32
+ }
33
+ },
34
+ })
35
+ return result
36
+ },
37
+ setup: ({ svgG, pluginParams$, layerParams$, context }) => {
38
+
39
+ const destroy$ = new Subject()
40
+
41
+ context.layout$
42
+ .pipe(
43
+ takeUntil(destroy$)
44
+ )
45
+ .subscribe(layout => {
46
+ d3.select(svgG)
47
+ .attr('transform', `translate(${layout.left}, ${layout.top})`)
48
+ })
49
+
50
+ const unsubscribeBaseBars = createBaseLineAreas({
51
+ selection: d3.select(svgG),
52
+ pluginName,
53
+ layerName,
54
+ computedData$: context.computedData$,
55
+ // visibleComputedData$: context.visibleComputedData$,
56
+ // computedAxesData$: context.computedAxesData$,
57
+ visibleComputedAxesData$: context.visibleComputedAxesData$,
58
+ seriesLabels$: context.seriesLabels$,
59
+ SeriesDataMap$: context.SeriesDataMap$,
60
+ CategoryDataMap$: context.CategoryDataMap$,
61
+ baseLineAreasParams$: layerParams$,
62
+ pluginParams$,
63
+ styles$: pluginParams$.pipe(
64
+ map(params => params.styles),
65
+ ),
66
+ gridAxesTransform$: context.gridAxesTransform$,
67
+ gridGraphicTransform$: context.gridGraphicTransform$,
68
+ gridAxesSize$: context.gridAxesSize$,
69
+ gridHighlight$: context.gridHighlight$,
70
+ gridContainerPosition$: context.gridContainerPosition$,
71
+ allContainerPosition$: context.gridContainerPosition$,
72
+ layout$: context.layout$,
73
+ eventTrigger$: context.eventTrigger$,
74
+ })
75
+
76
+
77
+ return () => {
78
+ destroy$.next(undefined)
79
+ unsubscribeBaseBars()
80
+ }
81
+ }
82
+ })
@@ -0,0 +1,75 @@
1
+ import * as d3 from 'd3'
2
+ import { map, Subject, takeUntil } from 'rxjs'
3
+ import type { LinesParams, SeriesPlotPluginParams } from '../types'
4
+ import { defineSVGLayer } from '@orbcharts/core'
5
+ import { SeriesPlotExtendContext } from '../types'
6
+ import { validateObject } from '@orbcharts/core'
7
+ import { DEFAULT_LINES_PARAMS } from '../defaults'
8
+ import { createBaseLines } from '../../../baseLayers/BaseLines'
9
+ import { LAYER_INDEX_OF_GRAPHIC } from '../../../const/layerIndex'
10
+
11
+ const pluginName = 'SeriesPlot'
12
+ const layerName = 'Lines'
13
+
14
+ export const Lines = defineSVGLayer<SeriesPlotExtendContext, SeriesPlotPluginParams, LinesParams>({
15
+ name: layerName,
16
+ defaultParams: DEFAULT_LINES_PARAMS,
17
+ layerIndex: LAYER_INDEX_OF_GRAPHIC,
18
+ initShow: false,
19
+ validator: (params) => {
20
+ const result = validateObject(params, {
21
+ lineCurve: {
22
+ toBeTypes: ['string']
23
+ },
24
+ lineWidth: {
25
+ toBeTypes: ['number']
26
+ },
27
+ })
28
+ return result
29
+ },
30
+ setup: ({ svgG, pluginParams$, layerParams$, context }) => {
31
+
32
+ const destroy$ = new Subject()
33
+
34
+ context.layout$
35
+ .pipe(
36
+ takeUntil(destroy$)
37
+ )
38
+ .subscribe(layout => {
39
+ d3.select(svgG)
40
+ .attr('transform', `translate(${layout.left}, ${layout.top})`)
41
+ })
42
+
43
+ const unsubscribeBaseBars = createBaseLines({
44
+ selection: d3.select(svgG),
45
+ pluginName,
46
+ layerName,
47
+ computedData$: context.computedData$,
48
+ // computedAxesData$: context.computedAxesData$,
49
+ // visibleComputedData$: context.visibleComputedData$,
50
+ visibleComputedAxesData$: context.visibleComputedAxesData$,
51
+ seriesLabels$: context.seriesLabels$,
52
+ SeriesDataMap$: context.SeriesDataMap$,
53
+ CategoryDataMap$: context.CategoryDataMap$,
54
+ baseLinesParams$: layerParams$,
55
+ pluginParams$,
56
+ styles$: pluginParams$.pipe(
57
+ map(params => params.styles),
58
+ ),
59
+ gridAxesTransform$: context.gridAxesTransform$,
60
+ gridGraphicTransform$: context.gridGraphicTransform$,
61
+ gridAxesSize$: context.gridAxesSize$,
62
+ gridHighlight$: context.gridHighlight$,
63
+ gridContainerPosition$: context.gridContainerPosition$,
64
+ allContainerPosition$: context.gridContainerPosition$,
65
+ layout$: context.layout$,
66
+ eventTrigger$: context.eventTrigger$
67
+ })
68
+
69
+
70
+ return () => {
71
+ destroy$.next(undefined)
72
+ unsubscribeBaseBars()
73
+ }
74
+ }
75
+ })
@@ -0,0 +1,85 @@
1
+ import * as d3 from 'd3'
2
+ import {
3
+ map,
4
+ distinctUntilChanged,
5
+ shareReplay,
6
+ takeUntil,
7
+ Subject,
8
+ Observable } from 'rxjs'
9
+ import type { SeriesPlotPluginParams, StackedBarsParams } from '../types'
10
+ import { DEFAULT_STACKED_BARS_PARAMS } from '../defaults'
11
+ import { LAYER_INDEX_OF_GRAPHIC } from '../../../const/layerIndex'
12
+ import { createBaseStackedBars } from '../../../baseLayers/BaseStackedBars'
13
+ import { defineSVGLayer } from '@orbcharts/core'
14
+ import { SeriesPlotExtendContext } from '../types'
15
+ import { validateObject } from '@orbcharts/core'
16
+
17
+ const pluginName = 'SeriesPlot'
18
+ const layerName = 'StackedBars'
19
+
20
+ export const StackedBars = defineSVGLayer<SeriesPlotExtendContext, SeriesPlotPluginParams, StackedBarsParams>({
21
+ name: layerName,
22
+ defaultParams: DEFAULT_STACKED_BARS_PARAMS,
23
+ layerIndex: LAYER_INDEX_OF_GRAPHIC,
24
+ initShow: false,
25
+ validator: (params) => {
26
+ const result = validateObject(params, {
27
+ barWidth: {
28
+ toBeTypes: ['number']
29
+ },
30
+ barGroupPadding: {
31
+ toBeTypes: ['number']
32
+ },
33
+ barRadius: {
34
+ toBeTypes: ['number', 'boolean']
35
+ }
36
+ })
37
+ return result
38
+ },
39
+ setup: ({ svgG, pluginParams$, layerParams$, context }) => {
40
+
41
+ const destroy$ = new Subject()
42
+
43
+ context.layout$
44
+ .pipe(
45
+ takeUntil(destroy$)
46
+ )
47
+ .subscribe(layout => {
48
+ d3.select(svgG)
49
+ .attr('transform', `translate(${layout.left}, ${layout.top})`)
50
+ })
51
+
52
+ const unsubscribeBaseBars = createBaseStackedBars({
53
+ selection: d3.select(svgG),
54
+ pluginName,
55
+ layerName,
56
+ computedData$: context.computedData$,
57
+ computedAxesData$: context.computedAxesData$,
58
+ visibleComputedData$: context.visibleComputedData$,
59
+ visibleComputedAxesData$: context.visibleComputedAxesData$,
60
+ filteredMinMaxValue$: context.filteredMinMaxValue$,
61
+ filteredStackedMinMaxValue$: context.filteredStackedMinMaxValue$,
62
+ seriesLabels$: context.seriesLabels$,
63
+ SeriesDataMap$: context.SeriesDataMap$,
64
+ CategoryDataMap$: context.CategoryDataMap$,
65
+ baseStackedBarParams$: layerParams$,
66
+ pluginParams$,
67
+ styles$: pluginParams$.pipe(
68
+ map(params => params.styles),
69
+ ),
70
+ gridAxesTransform$: context.gridAxesTransform$,
71
+ gridGraphicTransform$: context.gridGraphicTransform$,
72
+ gridGraphicReverseScale$: context.gridGraphicReverseScale$,
73
+ gridAxesSize$: context.gridAxesSize$,
74
+ gridHighlight$: context.gridHighlight$,
75
+ gridContainerPosition$: context.gridContainerPosition$,
76
+ isSeriesSeprate$: context.isSeriesSeprate$,
77
+ eventTrigger$: context.eventTrigger$,
78
+ })
79
+
80
+ return () => {
81
+ destroy$.next(undefined)
82
+ unsubscribeBaseBars()
83
+ }
84
+ }
85
+ })