@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,371 @@
1
+ import * as d3 from 'd3'
2
+ import {
3
+ combineLatest,
4
+ map,
5
+ switchMap,
6
+ debounceTime,
7
+ takeUntil,
8
+ shareReplay,
9
+ distinctUntilChanged,
10
+ Observable,
11
+ Subject } from 'rxjs'
12
+ import type { BaseLayerFn } from '../types/BaseLayer'
13
+ import type { Layout, GraphicStyles, ContainerPositionScaled, XYAxis } from '../types/PluginParams'
14
+ import type { ComputedData, ComputedDatumMultivariate } from '../types/ComputedData'
15
+ import type { BaseYAxisParams } from './types'
16
+ import { createClassName, getColor, getColorScheme } from '../utils/orbchartsUtils'
17
+ import { measureTextWidth } from '../utils/commonUtils'
18
+ import { ColorType, Theme } from '@orbcharts/core'
19
+ import { ContainerSize, Placement } from '../types'
20
+ import { multivariateContainerSelectionsObservable } from '../utils/multivariateObservables'
21
+ import { parseTickFormatValue } from '../utils/d3Utils'
22
+
23
+ interface BaseYAxisContext {
24
+ selection: d3.Selection<any, unknown, any, unknown>
25
+ pluginName: string
26
+ layerName: string
27
+ computedData$: Observable<ComputedData<'multivariate'>>
28
+ // filteredMinMaxValue$: Observable<[number, number]>
29
+ layerParams$: Observable<BaseYAxisParams>
30
+ yAxis$: Observable<XYAxis>
31
+ theme$: Observable<Theme>
32
+ isSeriesSeprate$: Observable<boolean>
33
+ containerPosition$: Observable<ContainerPositionScaled[]>
34
+ containerSize$: Observable<ContainerSize>
35
+ // layout$: Observable<Layout>
36
+ // filteredXYMinMaxData$: Observable<{
37
+ // datumList: ComputedXYDatumMultivariate[];
38
+ // minXDatum: ComputedXYDatumMultivariate | null;
39
+ // maxXDatum: ComputedXYDatumMultivariate | null;
40
+ // minYDatum: ComputedXYDatumMultivariate | null;
41
+ // maxYDatum: ComputedXYDatumMultivariate | null;
42
+ // }>
43
+ yScale$: Observable<d3.ScaleLinear<number, number>>
44
+ // xyMinMax$: Observable<{
45
+ // minX: number;
46
+ // maxX: number;
47
+ // minY: number;
48
+ // maxY: number;
49
+ // }>
50
+ }
51
+
52
+ const defaultTickSize = 6
53
+
54
+ const yTickTextAnchor = 'end'
55
+ const yTickDominantBaseline = 'middle'
56
+ const yAxisLabelAnchor = 'end'
57
+ const yAxisLabelDominantBaseline = 'auto'
58
+
59
+ function renderYAxisLabel ({ selection, yLabelClassName, layerParams, yAxis, theme }: {
60
+ selection: d3.Selection<SVGGElement, any, any, any>,
61
+ yLabelClassName: string
62
+ layerParams: BaseYAxisParams
63
+ yAxis: XYAxis
64
+ theme: Theme
65
+ // axisLabelAlign: TextAlign
66
+ // textReverseTransform: string,
67
+ }) {
68
+ const offsetX = layerParams.tickPadding - layerParams.labelOffset[0]
69
+ const offsetY = layerParams.tickPadding + layerParams.labelOffset[1]
70
+ let labelX = - offsetX
71
+ let labelY = - offsetY
72
+
73
+ const axisLabelSelection = selection
74
+ .selectAll<SVGGElement, BaseYAxisParams>(`g.${yLabelClassName}`)
75
+ .data([layerParams])
76
+ .join('g')
77
+ .classed(yLabelClassName, true)
78
+ .each((d, i, g) => {
79
+ const text = d3.select(g[i])
80
+ .selectAll<SVGTextElement, BaseYAxisParams>(`text`)
81
+ .data([d])
82
+ .join(
83
+ enter => {
84
+ return enter
85
+ .append('text')
86
+ .style('font-weight', 'bold')
87
+ },
88
+ update => update,
89
+ exit => exit.remove()
90
+ )
91
+ .attr('text-anchor', yAxisLabelAnchor)
92
+ .attr('dominant-baseline', yAxisLabelDominantBaseline)
93
+ .attr('font-size', theme.fontSize)
94
+ .style('fill', getColor(layerParams.labelColorType, theme))
95
+ // .style('transform', textReverseTransform)
96
+ // 偏移使用 x, y 而非 transform 才不會受到外層 scale 變形影響
97
+ .attr('x', labelX)
98
+ .attr('y', labelY)
99
+ .text(d => yAxis.label)
100
+ })
101
+ // .attr('transform', d => `translate(0, ${layout.height})`)
102
+ }
103
+
104
+ function renderYAxis ({ selection, yAxisClassName, layerParams, containerSize, theme, yScale }: {
105
+ selection: d3.Selection<SVGGElement, any, any, any>,
106
+ yAxisClassName: string
107
+ layerParams: BaseYAxisParams
108
+ // tickTextAlign: TextAlign
109
+ containerSize: ContainerSize
110
+ theme: Theme,
111
+ yScale: d3.ScaleLinear<number, number>
112
+ // textReverseTransform: string,
113
+ // xyMinMax: {
114
+ // minX: number;
115
+ // maxX: number;
116
+ // minY: number;
117
+ // maxY: number;
118
+ // }
119
+ }) {
120
+
121
+ const yAxisSelection = selection
122
+ .selectAll<SVGGElement, BaseYAxisParams>(`g.${yAxisClassName}`)
123
+ .data([layerParams])
124
+ .join('g')
125
+ .classed(yAxisClassName, true)
126
+
127
+ // const _yScale = d3.scaleLinear()
128
+ // .domain([0, 150])
129
+ // .range([416.5, 791.349])
130
+
131
+ // 刻度文字偏移
132
+ let tickPadding = layerParams.tickPadding
133
+
134
+ // 設定Y軸刻度
135
+ const yAxis = d3.axisLeft(yScale)
136
+ .scale(yScale)
137
+ .ticks(layerParams.ticks) // 刻度分段數量
138
+ .tickFormat(d => parseTickFormatValue(d, layerParams.tickFormat))
139
+ .tickSize(layerParams.tickFullLine == true
140
+ ? -containerSize.width
141
+ : defaultTickSize)
142
+ .tickPadding(tickPadding)
143
+
144
+ const yAxisEl = yAxisSelection
145
+ .transition()
146
+ .duration(100)
147
+ .ease(d3.easeLinear) // 線性的 - 當托曳或快速變動的時候比較滑順
148
+ .call(yAxis)
149
+
150
+ yAxisEl.selectAll('line')
151
+ .style('fill', 'none')
152
+ .style('stroke', layerParams.tickLineVisible == true ? getColor(layerParams.tickColorType, theme) : 'none')
153
+ .style('stroke-dasharray', layerParams.tickFullLineDasharray)
154
+ .attr('pointer-events', 'none')
155
+
156
+ yAxisEl.selectAll('path')
157
+ .style('fill', 'none')
158
+ // .style('stroke', this.layerParams.axisLineColor!)
159
+ .style('stroke', layerParams.axisLineVisible == true ? getColor(layerParams.axisLineColorType, theme) : 'none')
160
+ .style('shape-rendering', 'crispEdges')
161
+
162
+ // const yText = yAxisEl.selectAll('text')
163
+ const yText = yAxisSelection.selectAll('text')
164
+ // .style('font-family', 'sans-serif')
165
+ .attr('font-size', theme.fontSize)
166
+ .style('color', getColor(layerParams.tickTextColorType, theme))
167
+ .attr('text-anchor', yTickTextAnchor)
168
+ .attr('dominant-baseline', yTickDominantBaseline)
169
+ // .attr('dy', 0)
170
+ .attr('x', - tickPadding)
171
+ .attr('dy', 0)
172
+ // yText.style('transform', textReverseTransform)
173
+
174
+ // // 抵消掉預設的偏移
175
+ // if (fullDataFormatter.grid.valueAxis.position === 'bottom' || fullDataFormatter.grid.valueAxis.position === 'top') {
176
+ // yText.attr('dy', 0)
177
+ // }
178
+
179
+ return yAxisSelection
180
+ }
181
+
182
+
183
+ export const createBaseYAxis: BaseLayerFn<BaseYAxisContext> = ({
184
+ selection,
185
+ pluginName,
186
+ layerName,
187
+ computedData$,
188
+ layerParams$,
189
+ yAxis$,
190
+ theme$,
191
+ isSeriesSeprate$,
192
+ containerPosition$,
193
+ containerSize$,
194
+ // layout$,
195
+ // filteredXYMinMaxData$,
196
+ yScale$,
197
+ // xyMinMax$
198
+ }) => {
199
+
200
+ const destroy$ = new Subject()
201
+
202
+ // const containerClassName = createClassName(pluginName, 'container')
203
+ const yAxisGClassName = createClassName(pluginName, layerName, 'yAxisG')
204
+ const yAxisClassName = createClassName(pluginName, layerName, 'yAxis')
205
+ const yLabelClassName = createClassName(pluginName, layerName, 'yLabel')
206
+
207
+ const containerSelection$ = multivariateContainerSelectionsObservable({
208
+ selection,
209
+ pluginName,
210
+ layerName,
211
+ clipPathID: null,
212
+ computedData$,
213
+ containerPosition$,
214
+ isSeriesSeprate$,
215
+ }).pipe(
216
+ takeUntil(destroy$),
217
+ )
218
+
219
+ // const containerSelection$ = combineLatest({
220
+ // computedData: computedData$.pipe(
221
+ // distinctUntilChanged((a, b) => {
222
+ // // 只有當series的數量改變時,才重新計算
223
+ // return a.length === b.length
224
+ // }),
225
+ // ),
226
+ // isSeriesSeprate: isSeriesSeprate$
227
+ // }).pipe(
228
+ // takeUntil(destroy$),
229
+ // switchMap(async (d) => d),
230
+ // map(data => {
231
+ // return data.isSeriesSeprate
232
+ // // category分開的時候顯示各別axis
233
+ // ? data.computedData
234
+ // // category合併的時候只顯示第一個axis
235
+ // : [data.computedData[0]]
236
+ // }),
237
+ // map((computedData, i) => {
238
+ // return selection
239
+ // .selectAll<SVGGElement, ComputedDatumMultivariate[]>(`g.${containerClassName}`)
240
+ // .data(computedData, d => d[0] ? d[0].categoryIndex : i)
241
+ // .join('g')
242
+ // .classed(containerClassName, true)
243
+ // })
244
+ // )
245
+
246
+ const axisSelection$ = containerSelection$.pipe(
247
+ takeUntil(destroy$),
248
+ map((containerSelection, i) => {
249
+ return containerSelection
250
+ .selectAll<SVGGElement, ComputedDatumMultivariate[]>(`g.${yAxisGClassName}`)
251
+ .data([yAxisGClassName])
252
+ .join('g')
253
+ .classed(yAxisGClassName, true)
254
+ })
255
+ )
256
+
257
+ // combineLatest({
258
+ // containerSelection: containerSelection$,
259
+ // gridContainerPosition: containerPosition$
260
+ // }).pipe(
261
+ // takeUntil(destroy$),
262
+ // switchMap(async d => d)
263
+ // ).subscribe(data => {
264
+ // data.containerSelection
265
+ // .attr('transform', (d, i) => {
266
+ // const gridContainerPosition = data.gridContainerPosition[i] ?? data.gridContainerPosition[0]
267
+ // const translate = gridContainerPosition.translate
268
+ // const scale = gridContainerPosition.scale
269
+ // // return `translate(${translate[0]}, ${translate[1]}) scale(${scale[0]}, ${scale[1]})`
270
+ // return `translate(${translate[0]}, ${translate[1]})`
271
+ // })
272
+ // // .attr('opacity', 0)
273
+ // // .transition()
274
+ // // .attr('opacity', 1)
275
+ // })
276
+
277
+ // const textReverseTransform$ = containerPosition$.pipe(
278
+ // takeUntil(destroy$),
279
+ // switchMap(async (d) => d),
280
+ // map(containerPosition => {
281
+ // // const axesRotateXYReverseValue = `rotateX(${data.gridAxesReverseTransform.rotateX}deg) rotateY(${data.gridAxesReverseTransform.rotateY}deg)`
282
+ // // const axesRotateReverseValue = `rotate(${data.gridAxesReverseTransform.rotate}deg)`
283
+ // const containerScaleReverseValue = `scale(${1 / containerPosition[0].scale[0]}, ${1 / containerPosition[0].scale[1]})`
284
+ // // 抵消最外層scale
285
+ // return `${containerScaleReverseValue}`
286
+ // }),
287
+ // distinctUntilChanged()
288
+ // )
289
+
290
+ // const yScale$: Observable<d3.ScaleLinear<number, number>> = new Observable(subscriber => {
291
+ // combineLatest({
292
+ // fullDataFormatter: fullDataFormatter$,
293
+ // layout: layout$,
294
+ // // xyMinMax: observer.xyMinMax$
295
+ // filteredXYMinMaxData: filteredXYMinMaxData$
296
+ // }).pipe(
297
+ // takeUntil(destroy$),
298
+ // switchMap(async (d) => d),
299
+ // ).subscribe(data => {
300
+ // const valueIndex = data.fullDataFormatter.xAxis.valueIndex
301
+ // if (!data.filteredXYMinMaxData.minYDatum || !data.filteredXYMinMaxData.maxYDatum
302
+ // || data.filteredXYMinMaxData.minYDatum.value[valueIndex] == null || data.filteredXYMinMaxData.maxYDatum.value[valueIndex] == null
303
+ // ) {
304
+ // return
305
+ // }
306
+ // let maxValue = data.filteredXYMinMaxData.maxYDatum.value[valueIndex]
307
+ // let minValue = data.filteredXYMinMaxData.minYDatum.value[valueIndex]
308
+ // if (maxValue === minValue && maxValue === 0) {
309
+ // // 避免最大及最小值同等於 0 造成無法計算scale
310
+ // maxValue = 1
311
+ // }
312
+
313
+ // const yScale: d3.ScaleLinear<number, number> = createValueToAxisScale({
314
+ // maxValue,
315
+ // minValue,
316
+ // axisWidth: data.layout.height,
317
+ // scaleDomain: data.fullDataFormatter.yAxis.scaleDomain,
318
+ // scaleRange: data.fullDataFormatter.yAxis.scaleRange,
319
+ // reverse: true
320
+ // })
321
+
322
+ // subscriber.next(yScale)
323
+ // })
324
+ // })
325
+
326
+
327
+ combineLatest({
328
+ axisSelection: axisSelection$,
329
+ layerParams: layerParams$,
330
+ // tickTextAlign: tickTextAlign$,
331
+ // axisLabelAlign: axisLabelAlign$,
332
+ computedData: computedData$,
333
+ containerSize: containerSize$,
334
+ yAxis: yAxis$,
335
+ yScale: yScale$,
336
+ theme: theme$
337
+ // textReverseTransform: textReverseTransform$,
338
+ // xyMinMax: xyMinMax$
339
+ }).pipe(
340
+ takeUntil(destroy$),
341
+ switchMap(async (d) => d),
342
+ ).subscribe(data => {
343
+
344
+ renderYAxis({
345
+ selection: data.axisSelection,
346
+ yAxisClassName,
347
+ layerParams: data.layerParams,
348
+ // tickTextAlign: data.tickTextAlign,
349
+ containerSize: data.containerSize,
350
+ theme: data.theme,
351
+ yScale: data.yScale,
352
+ // textReverseTransform: data.textReverseTransform,
353
+ // xyMinMax: data.xyMinMax
354
+ })
355
+
356
+ renderYAxisLabel({
357
+ selection: data.axisSelection,
358
+ yLabelClassName,
359
+ layerParams: data.layerParams,
360
+ // axisLabelAlign: data.axisLabelAlign,
361
+ yAxis: data.yAxis,
362
+ theme: data.theme,
363
+ // textReverseTransform: data.textReverseTransform,
364
+ })
365
+
366
+ })
367
+
368
+ return () => {
369
+ destroy$.next(undefined)
370
+ }
371
+ }
@@ -0,0 +1,174 @@
1
+ import type { ColorType, EventData } from '@orbcharts/core'
2
+ import type { Placement } from '../types/Common'
3
+ import type { ComputedDatum } from '../types';
4
+
5
+
6
+ // -- base layer params --
7
+ export interface BaseBarsParams {
8
+ barWidth: number;
9
+ barPadding: number;
10
+ barGroupPadding: number;
11
+ barRadius: number | boolean;
12
+ }
13
+ export interface BaseStackedBarsParams {
14
+ barWidth: number;
15
+ barGroupPadding: number;
16
+ barRadius: number | boolean;
17
+ }
18
+ export interface BaseBarsTriangleParams {
19
+ barWidth: number;
20
+ barPadding: number;
21
+ barGroupPadding: number;
22
+ linearGradientOpacity: [number, number];
23
+ }
24
+ export interface BaseDotsParams {
25
+ radius: number;
26
+ fillColorType: ColorType;
27
+ strokeColorType: ColorType;
28
+ strokeWidth: number;
29
+ onlyShowHighlighted: boolean;
30
+ }
31
+ export interface BaseCategoryAxisParams {
32
+ labelOffset: [number, number];
33
+ labelColorType: ColorType;
34
+ axisLineVisible: boolean;
35
+ axisLineColorType: ColorType;
36
+ ticks: number | null | 'all';
37
+ tickFormat: string | ((text: any) => string | d3.NumberValue);
38
+ tickLineVisible: boolean;
39
+ tickPadding: number;
40
+ tickFullLine: boolean;
41
+ tickFullLineDasharray: string;
42
+ tickColorType: ColorType;
43
+ tickTextRotate: number;
44
+ tickTextColorType: ColorType;
45
+ }
46
+ export interface BaseLegendParams {
47
+ placement: Placement;
48
+ padding: number;
49
+ backgroundFill: ColorType;
50
+ backgroundStroke: ColorType;
51
+ textColorType: ColorType;
52
+ gap: number;
53
+ labelList: Array<{
54
+ listRectWidth: number;
55
+ listRectHeight: number;
56
+ listRectRadius: number;
57
+ }>;
58
+ }
59
+ export interface BaseLineAreasParams {
60
+ lineCurve: string;
61
+ linearGradientOpacity: [number, number];
62
+ }
63
+ export interface BaseLinesParams {
64
+ lineCurve: string;
65
+ lineWidth: number;
66
+ }
67
+ export interface BaseOrdinalBubblesParams {
68
+ bubble: {
69
+ sizeAdjust: number;
70
+ arcScaleType: 'area' | 'radius';
71
+ valueLinearOpacity: [number, number];
72
+ };
73
+ itemLabel: {
74
+ padding: number;
75
+ colorType: ColorType;
76
+ };
77
+ rankingAmount: 'auto' | number;
78
+ }
79
+ export interface BaseRacingBarsParams {
80
+ bar: {
81
+ barWidth: number;
82
+ barPadding: number;
83
+ barRadius: number | boolean;
84
+ };
85
+ rankingAmount: 'auto' | number;
86
+ }
87
+ export interface BaseRacingLabelsParams {
88
+ barLabel: {
89
+ position: 'inside' | 'outside' | 'none';
90
+ padding: number;
91
+ colorType: ColorType;
92
+ };
93
+ axisLabel: {
94
+ offset: [number, number];
95
+ colorType: ColorType;
96
+ };
97
+ }
98
+ export interface BaseRacingValueLabelsParams {
99
+ padding: number;
100
+ colorType: ColorType;
101
+ format: string | ((text: d3.NumberValue) => string | d3.NumberValue);
102
+ }
103
+ export interface BaseTooltipStyle {
104
+ backgroundColor: string;
105
+ backgroundOpacity: number;
106
+ strokeColor: string;
107
+ offset: [number, number];
108
+ padding: number;
109
+ textColor: string;
110
+ textSize: number | string;
111
+ textSizePx: number;
112
+ // seriesColors: string[];
113
+ }
114
+ export interface BaseTooltipUtils {
115
+ toCurrency: (num: number | null) => string;
116
+ measureTextWidth(text: string, size?: number): number;
117
+ }
118
+ export type BaseTooltipParams = {
119
+ backgroundColorType: ColorType;
120
+ backgroundOpacity: number;
121
+ strokeColorType: ColorType;
122
+ textColorType: ColorType;
123
+ offset: [number, number];
124
+ padding: number;
125
+ renderFn: ((eventData: EventData<any>, context: {
126
+ styles: BaseTooltipStyle;
127
+ utils: BaseTooltipUtils;
128
+ seriesData: ComputedDatum<any>[]
129
+ categoryData: ComputedDatum<any>[]
130
+ }) => string[] | string);
131
+ };
132
+ export interface BaseValueAxisParams {
133
+ labelOffset: [number, number];
134
+ labelColorType: ColorType;
135
+ axisLineVisible: boolean;
136
+ axisLineColorType: ColorType;
137
+ ticks: number;
138
+ tickFormat: string | ((text: d3.NumberValue) => string | d3.NumberValue);
139
+ tickLineVisible: boolean;
140
+ tickPadding: number;
141
+ tickFullLine: boolean;
142
+ tickFullLineDasharray: string;
143
+ tickColorType: ColorType;
144
+ tickTextRotate: number;
145
+ tickTextColorType: ColorType;
146
+ }
147
+ export interface BaseXAxisParams {
148
+ labelOffset: [number, number];
149
+ labelColorType: ColorType;
150
+ axisLineVisible: boolean;
151
+ axisLineColorType: ColorType;
152
+ ticks: number | null;
153
+ tickFormat: string | ((text: d3.NumberValue) => string | d3.NumberValue);
154
+ tickLineVisible: boolean;
155
+ tickPadding: number;
156
+ tickFullLine: boolean;
157
+ tickFullLineDasharray: string;
158
+ tickColorType: ColorType;
159
+ tickTextColorType: ColorType;
160
+ }
161
+ export interface BaseYAxisParams {
162
+ labelOffset: [number, number];
163
+ labelColorType: ColorType;
164
+ axisLineVisible: boolean;
165
+ axisLineColorType: ColorType;
166
+ ticks: number | null;
167
+ tickFormat: string | ((text: d3.NumberValue) => string | d3.NumberValue);
168
+ tickLineVisible: boolean;
169
+ tickPadding: number;
170
+ tickFullLine: boolean;
171
+ tickFullLineDasharray: string;
172
+ tickColorType: ColorType;
173
+ tickTextColorType: ColorType;
174
+ }
@@ -0,0 +1,36 @@
1
+
2
+ // 圖層索引 - 底層(無圖型)
3
+ export const LAYER_INDEX_OF_ROOT = 0
4
+
5
+ // 圖層索引 - 背景 *預留
6
+ // 之後改成 LAYER_INDEX_OF_BACKGROUND
7
+ export const LAYER_INDEX_OF_BG = 1
8
+
9
+ // 圖層索引 - 圖軸
10
+ export const LAYER_INDEX_OF_AXIS = 2
11
+
12
+ // 圖層索引 - 輔助線、圖軸的輔助資訊
13
+ export const LAYER_INDEX_OF_AUX = 3
14
+
15
+ // 圖層索引 - 底層圖型
16
+ // 之後改成 LAYER_INDEX_OF_PLOT_LOWER
17
+ export const LAYER_INDEX_OF_GRAPHIC_GROUND = 4
18
+
19
+ // 圖層索引 - 一般圖型
20
+ // 之後改成 LAYER_INDEX_OF_PLOT
21
+ export const LAYER_INDEX_OF_GRAPHIC = 5
22
+
23
+ // 圖層索引 - 覆蓋圖型
24
+ // 之後改成 LAYER_INDEX_OF_PLOT_HIGHER
25
+ export const LAYER_INDEX_OF_GRAPHIC_COVER = 6
26
+
27
+ // 圖層索引 - 圖型上的標籤文字
28
+ export const LAYER_INDEX_OF_LABEL = 7
29
+
30
+ // 圖層索引 - 圖例、圖表上的文字
31
+ // 之後改成 LAYER_INDEX_OF_FOREGROUND
32
+ export const LAYER_INDEX_OF_INFO = 8
33
+
34
+ // 圖層索引 - Tooltip、事件觸發的覆蓋圖型
35
+ // 之後改成 LAYER_INDEX_OF_EVENT
36
+ export const LAYER_INDEX_OF_TOOLTIP = 9
@@ -0,0 +1,29 @@
1
+ import type { Container, CategoryAxis, ValueAxis, XYAxis } from '../types/PluginParams'
2
+
3
+ export const DEFAULT_VALUE_AXIS: ValueAxis = {
4
+ position: 'left',
5
+ scaleDomain: ['auto', 'auto'],
6
+ scaleRange: [0, 0.9],
7
+ label: '',
8
+ }
9
+
10
+ export const DEFAULT_CATEGORY_AXIS: CategoryAxis = {
11
+ position: 'bottom',
12
+ scaleDomain: [0, 'max'],
13
+ scalePadding: 0.5,
14
+ label: ''
15
+ }
16
+
17
+ export const DEFAULT_X_Y_AXIS: XYAxis = {
18
+ scaleDomain: ['auto', 'auto'],
19
+ scaleRange: [0, 0.9],
20
+ label: '',
21
+ // valueIndex: 0
22
+ }
23
+
24
+ export const DEFAULT_CONTAINER: Container = {
25
+ columnAmount: 1,
26
+ rowAmount: 1,
27
+ columnGap: 'auto',
28
+ rowGap: 'auto'
29
+ }
package/src/index.ts ADDED
@@ -0,0 +1,3 @@
1
+
2
+ export * from './plugins'
3
+ export * from './types'