@orbcharts/plugins-basic 3.0.0-beta.1 → 3.0.0-beta.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +200 -200
- package/dist/orbcharts-plugins-basic.es.js +2863 -2860
- package/dist/orbcharts-plugins-basic.umd.js +46 -46
- package/lib/core-types.ts +7 -7
- package/lib/core.ts +6 -6
- package/lib/plugins-basic-types.ts +6 -6
- package/package.json +44 -44
- package/src/base/BaseBarStack.ts +780 -780
- package/src/base/BaseBars.ts +765 -765
- package/src/base/BaseBarsTriangle.ts +674 -674
- package/src/base/BaseDots.ts +515 -515
- package/src/base/BaseGroupAxis.ts +679 -679
- package/src/base/BaseLegend.ts +680 -680
- package/src/base/BaseLineAreas.ts +629 -629
- package/src/base/BaseLines.ts +706 -706
- package/src/base/BaseTooltip.ts +385 -382
- package/src/base/BaseValueAxis.ts +580 -580
- package/src/base/types.ts +2 -2
- package/src/const.ts +30 -30
- package/src/grid/defaults.ts +244 -244
- package/src/grid/gridObservables.ts +545 -545
- package/src/grid/index.ts +16 -16
- package/src/grid/plugins/BarStack.ts +64 -64
- package/src/grid/plugins/Bars.ts +69 -69
- package/src/grid/plugins/BarsPN.ts +66 -66
- package/src/grid/plugins/BarsTriangle.ts +73 -73
- package/src/grid/plugins/Dots.ts +68 -68
- package/src/grid/plugins/GridLegend.ts +107 -107
- package/src/grid/plugins/GridTooltip.ts +66 -66
- package/src/grid/plugins/GridZoom.ts +218 -218
- package/src/grid/plugins/GroupAux.ts +1098 -1098
- package/src/grid/plugins/GroupAxis.ts +97 -97
- package/src/grid/plugins/LineAreas.ts +65 -65
- package/src/grid/plugins/Lines.ts +59 -59
- package/src/grid/plugins/ValueAxis.ts +93 -93
- package/src/grid/plugins/ValueStackAxis.ts +95 -95
- package/src/index.ts +9 -9
- package/src/multiGrid/defaults.ts +224 -224
- package/src/multiGrid/index.ts +14 -14
- package/src/multiGrid/multiGridObservables.ts +49 -49
- package/src/multiGrid/plugins/MultiBarStack.ts +106 -106
- package/src/multiGrid/plugins/MultiBars.ts +108 -108
- package/src/multiGrid/plugins/MultiBarsTriangle.ts +114 -114
- package/src/multiGrid/plugins/MultiDots.ts +102 -102
- package/src/multiGrid/plugins/MultiGridLegend.ts +159 -159
- package/src/multiGrid/plugins/MultiGridTooltip.ts +66 -66
- package/src/multiGrid/plugins/MultiGroupAxis.ts +137 -137
- package/src/multiGrid/plugins/MultiLineAreas.ts +107 -107
- package/src/multiGrid/plugins/MultiLines.ts +101 -101
- package/src/multiGrid/plugins/MultiValueAxis.ts +133 -133
- package/src/multiGrid/plugins/MultiValueStackAxis.ts +133 -133
- package/src/multiGrid/plugins/OverlappingValueAxes.ts +299 -299
- package/src/multiGrid/plugins/OverlappingValueStackAxes.ts +298 -298
- package/src/noneData/defaults.ts +102 -102
- package/src/noneData/index.ts +3 -3
- package/src/noneData/plugins/Container.ts +27 -27
- package/src/noneData/plugins/Tooltip.ts +373 -373
- package/src/series/defaults.ts +206 -206
- package/src/series/index.ts +9 -9
- package/src/series/plugins/Bubbles.ts +603 -603
- package/src/series/plugins/Pie.ts +623 -623
- package/src/series/plugins/PieEventTexts.ts +283 -283
- package/src/series/plugins/PieLabels.ts +640 -640
- package/src/series/plugins/Rose.ts +516 -516
- package/src/series/plugins/RoseLabels.ts +600 -600
- package/src/series/plugins/SeriesLegend.ts +107 -107
- package/src/series/plugins/SeriesTooltip.ts +66 -66
- package/src/series/seriesObservables.ts +145 -145
- package/src/series/seriesUtils.ts +51 -51
- package/src/tree/defaults.ts +78 -78
- package/src/tree/index.ts +4 -4
- package/src/tree/plugins/TreeLegend.ts +107 -107
- package/src/tree/plugins/TreeMap.ts +333 -333
- package/src/tree/plugins/TreeTooltip.ts +66 -66
- package/src/utils/commonUtils.ts +21 -21
- package/src/utils/d3Graphics.ts +174 -174
- package/src/utils/d3Utils.ts +73 -73
- package/src/utils/observables.ts +14 -14
- package/src/utils/orbchartsUtils.ts +100 -100
- package/tsconfig.base.json +13 -13
- package/tsconfig.json +2 -2
- package/vite.config.js +22 -22
@@ -1,219 +1,219 @@
|
|
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 } from 'rxjs'
|
12
|
-
import type { DefinePluginConfig } from '../../../lib/core-types'
|
13
|
-
import type { DataFormatterGrid } from '../../../lib/core-types'
|
14
|
-
import {
|
15
|
-
defineGridPlugin, createAxisLinearScale } from '../../../lib/core'
|
16
|
-
import { DEFAULT_GRID_ZOOM_PARAMS } from '../defaults'
|
17
|
-
import { getClassName, getUniID } from '../../utils/orbchartsUtils'
|
18
|
-
import { LAYER_INDEX_OF_ROOT } from '../../const'
|
19
|
-
|
20
|
-
const pluginName = 'GridZoom'
|
21
|
-
const rectClassName = getClassName(pluginName, 'rect')
|
22
|
-
|
23
|
-
const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_GRID_ZOOM_PARAMS> = {
|
24
|
-
name: pluginName,
|
25
|
-
defaultParams: DEFAULT_GRID_ZOOM_PARAMS,
|
26
|
-
layerIndex: LAYER_INDEX_OF_ROOT,
|
27
|
-
validator: (params, { validateColumns }) => {
|
28
|
-
return {
|
29
|
-
status: 'success',
|
30
|
-
columnName: '',
|
31
|
-
expectToBe: ''
|
32
|
-
}
|
33
|
-
}
|
34
|
-
}
|
35
|
-
|
36
|
-
export const GridZoom = defineGridPlugin(pluginConfig)(({ selection, rootSelection, name, observer, subject }) => {
|
37
|
-
|
38
|
-
const destroy$ = new Subject()
|
39
|
-
|
40
|
-
// const rootRectSelection: d3.Selection<SVGRectElement, any, any, any> = rootSelection
|
41
|
-
// .append('rect')
|
42
|
-
// .classed(rectClassName, true)
|
43
|
-
// .attr('opacity', 0)
|
44
|
-
|
45
|
-
// 紀錄zoom最後一次的transform
|
46
|
-
let lastTransform = {
|
47
|
-
k: 1,
|
48
|
-
x: 0,
|
49
|
-
y: 0
|
50
|
-
}
|
51
|
-
// let lastDomain: [number, number] = [0, 0]
|
52
|
-
|
53
|
-
// observer.layout$.pipe(
|
54
|
-
// takeUntil(destroy$),
|
55
|
-
// ).subscribe(d => {
|
56
|
-
// rootRectSelection
|
57
|
-
// .attr('width', d.width)
|
58
|
-
// .attr('height', d.height)
|
59
|
-
// .attr('x', d.left)
|
60
|
-
// .attr('y', d.top)
|
61
|
-
// })
|
62
|
-
|
63
|
-
const groupMax$ = observer.computedData$.pipe(
|
64
|
-
map(d => d[0] ? d[0].length - 1 : 0),
|
65
|
-
distinctUntilChanged()
|
66
|
-
)
|
67
|
-
|
68
|
-
// const fullDataFormatterEvent$: Subject<DataFormatterGrid> = new Subject()
|
69
|
-
// fullDataFormatterEvent$
|
70
|
-
// .pipe(
|
71
|
-
// takeUntil(destroy$),
|
72
|
-
// debounceTime(50)
|
73
|
-
// )
|
74
|
-
// .subscribe(fullDataFormatter => {
|
75
|
-
// store.fullDataFormatter$.next(fullDataFormatter)
|
76
|
-
// })
|
77
|
-
|
78
|
-
const initGroupAxis$ = observer.fullDataFormatter$.pipe(
|
79
|
-
map(d => d.grid.groupAxis),
|
80
|
-
// 只用第一次資料來計算scale才不會造成每次變動都受到影響
|
81
|
-
first()
|
82
|
-
)
|
83
|
-
|
84
|
-
|
85
|
-
const groupScale$ = combineLatest({
|
86
|
-
initGroupAxis: initGroupAxis$,
|
87
|
-
fullDataFormatter: observer.fullDataFormatter$,
|
88
|
-
groupMax: groupMax$,
|
89
|
-
layout: observer.layout$,
|
90
|
-
axisSize: observer.gridAxesSize$
|
91
|
-
}).pipe(
|
92
|
-
takeUntil(destroy$),
|
93
|
-
switchMap(async (d) => d),
|
94
|
-
map(data => {
|
95
|
-
// const groupMin = 0
|
96
|
-
const groupScaleDomainMin = data.initGroupAxis.scaleDomain[0] - data.initGroupAxis.scalePadding
|
97
|
-
const groupScaleDomainMax = data.initGroupAxis.scaleDomain[1] === 'max'
|
98
|
-
? data.groupMax + data.initGroupAxis.scalePadding
|
99
|
-
: data.initGroupAxis.scaleDomain[1] as number + data.initGroupAxis.scalePadding
|
100
|
-
|
101
|
-
const groupScale: d3.ScaleLinear<number, number> = createAxisLinearScale({
|
102
|
-
maxValue: data.groupMax,
|
103
|
-
minValue: 0,
|
104
|
-
axisWidth: data.axisSize.width,
|
105
|
-
scaleDomain: [groupScaleDomainMin, groupScaleDomainMax],
|
106
|
-
scaleRange: [0, 1]
|
107
|
-
})
|
108
|
-
|
109
|
-
return groupScale
|
110
|
-
})
|
111
|
-
)
|
112
|
-
|
113
|
-
combineLatest({
|
114
|
-
groupScale: groupScale$,
|
115
|
-
// initGroupAxis: initGroupAxis$,
|
116
|
-
// fullDataFormatter: fullDataFormatter$.pipe(first()), // 只用第一次資料來計算scale才不會造成每次變動都受到影響
|
117
|
-
fullDataFormatter: observer.fullDataFormatter$,
|
118
|
-
groupMax: groupMax$,
|
119
|
-
// layout: observer.layout$,
|
120
|
-
// axisSize: observer.gridAxesSize$
|
121
|
-
}).pipe(
|
122
|
-
takeUntil(destroy$),
|
123
|
-
switchMap(async (d) => d),
|
124
|
-
).subscribe(data => {
|
125
|
-
const groupMin = 0
|
126
|
-
|
127
|
-
const shadowScale = data.groupScale.copy()
|
128
|
-
|
129
|
-
const zoom = d3.zoom()
|
130
|
-
// .scaleExtent([1, data.groupMaxIndex])
|
131
|
-
// .translateExtent([[0, 0], [data.layout.rootWidth, data.layout.rootWidth]])
|
132
|
-
.on("zoom", function zoomed(event) {
|
133
|
-
// debugger
|
134
|
-
// console.log('event', event)
|
135
|
-
const t = event.transform;
|
136
|
-
|
137
|
-
// if (event.sourceEvent.type === 'mousemove') {
|
138
|
-
// // 當進行平移時,反向計算 x 軸
|
139
|
-
// const dx = event.transform.x - currentTransform.x; // 本次平移增量
|
140
|
-
// const reversedX = currentTransform.x - dx; // 反向累積平移
|
141
|
-
// // 更新變換狀態
|
142
|
-
// currentTransform = d3.zoomIdentity
|
143
|
-
// .translate(reversedX, event.transform.y)
|
144
|
-
// .scale(event.transform.k);
|
145
|
-
// } else {
|
146
|
-
// // 縮放操作:只更新縮放比例
|
147
|
-
// currentTransform = d3.zoomIdentity
|
148
|
-
// .translate(currentTransform.x, currentTransform.y)
|
149
|
-
// .scale(event.transform.k);
|
150
|
-
// }
|
151
|
-
// console.log('currentTransform', currentTransform)
|
152
|
-
|
153
|
-
// console.log('t.x', t.x)
|
154
|
-
const mapGroupindex = (d: number) => {
|
155
|
-
const n = Math.round(d)
|
156
|
-
return Math.min(data.groupMax, Math.max(groupMin, n));
|
157
|
-
}
|
158
|
-
|
159
|
-
const zoomedDomain = data.fullDataFormatter.grid.groupAxis.position === 'bottom' || data.fullDataFormatter.grid.groupAxis.position === 'top'
|
160
|
-
? t.rescaleX(shadowScale)
|
161
|
-
.domain()
|
162
|
-
.map(mapGroupindex)
|
163
|
-
: t.rescaleY(shadowScale)
|
164
|
-
.domain()
|
165
|
-
.map(mapGroupindex)
|
166
|
-
|
167
|
-
|
168
|
-
// domain超過極限值
|
169
|
-
if (zoomedDomain[0] <= groupMin && zoomedDomain[1] >= data.groupMax) {
|
170
|
-
// 繼續縮小
|
171
|
-
if (t.k < lastTransform.k) {
|
172
|
-
// 維持前一次的transform
|
173
|
-
t.k = lastTransform.k
|
174
|
-
t.x = lastTransform.x
|
175
|
-
t.y = lastTransform.y
|
176
|
-
}
|
177
|
-
// domain間距小於1
|
178
|
-
} else if ((zoomedDomain[1] - zoomedDomain[0]) <= 1) {
|
179
|
-
// 繼續放大
|
180
|
-
if (t.k > lastTransform.k) {
|
181
|
-
// 維持前一次的transform
|
182
|
-
t.k = lastTransform.k
|
183
|
-
t.x = lastTransform.x
|
184
|
-
t.y = lastTransform.y
|
185
|
-
}
|
186
|
-
}
|
187
|
-
|
188
|
-
// 紀錄transform
|
189
|
-
lastTransform.k = t.k
|
190
|
-
lastTransform.x = t.x
|
191
|
-
lastTransform.y = t.y
|
192
|
-
|
193
|
-
|
194
|
-
const newDataFormatter: DataFormatterGrid = {
|
195
|
-
...data.fullDataFormatter,
|
196
|
-
grid: {
|
197
|
-
...data.fullDataFormatter.grid,
|
198
|
-
groupAxis: {
|
199
|
-
...data.fullDataFormatter.grid.groupAxis,
|
200
|
-
scaleDomain: zoomedDomain
|
201
|
-
}
|
202
|
-
}
|
203
|
-
}
|
204
|
-
subject.dataFormatter$.next(newDataFormatter)
|
205
|
-
})
|
206
|
-
|
207
|
-
// 傳入外層selection
|
208
|
-
// subject.selection.call(zoom as any)
|
209
|
-
rootSelection.call(zoom)
|
210
|
-
|
211
|
-
})
|
212
|
-
|
213
|
-
return () => {
|
214
|
-
destroy$.next(undefined)
|
215
|
-
// rootRectSelection.remove()
|
216
|
-
|
217
|
-
rootSelection.call(d3.zoom().on('zoom', null))
|
218
|
-
}
|
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 } from 'rxjs'
|
12
|
+
import type { DefinePluginConfig } from '../../../lib/core-types'
|
13
|
+
import type { DataFormatterGrid } from '../../../lib/core-types'
|
14
|
+
import {
|
15
|
+
defineGridPlugin, createAxisLinearScale } from '../../../lib/core'
|
16
|
+
import { DEFAULT_GRID_ZOOM_PARAMS } from '../defaults'
|
17
|
+
import { getClassName, getUniID } from '../../utils/orbchartsUtils'
|
18
|
+
import { LAYER_INDEX_OF_ROOT } from '../../const'
|
19
|
+
|
20
|
+
const pluginName = 'GridZoom'
|
21
|
+
const rectClassName = getClassName(pluginName, 'rect')
|
22
|
+
|
23
|
+
const pluginConfig: DefinePluginConfig<typeof pluginName, typeof DEFAULT_GRID_ZOOM_PARAMS> = {
|
24
|
+
name: pluginName,
|
25
|
+
defaultParams: DEFAULT_GRID_ZOOM_PARAMS,
|
26
|
+
layerIndex: LAYER_INDEX_OF_ROOT,
|
27
|
+
validator: (params, { validateColumns }) => {
|
28
|
+
return {
|
29
|
+
status: 'success',
|
30
|
+
columnName: '',
|
31
|
+
expectToBe: ''
|
32
|
+
}
|
33
|
+
}
|
34
|
+
}
|
35
|
+
|
36
|
+
export const GridZoom = defineGridPlugin(pluginConfig)(({ selection, rootSelection, name, observer, subject }) => {
|
37
|
+
|
38
|
+
const destroy$ = new Subject()
|
39
|
+
|
40
|
+
// const rootRectSelection: d3.Selection<SVGRectElement, any, any, any> = rootSelection
|
41
|
+
// .append('rect')
|
42
|
+
// .classed(rectClassName, true)
|
43
|
+
// .attr('opacity', 0)
|
44
|
+
|
45
|
+
// 紀錄zoom最後一次的transform
|
46
|
+
let lastTransform = {
|
47
|
+
k: 1,
|
48
|
+
x: 0,
|
49
|
+
y: 0
|
50
|
+
}
|
51
|
+
// let lastDomain: [number, number] = [0, 0]
|
52
|
+
|
53
|
+
// observer.layout$.pipe(
|
54
|
+
// takeUntil(destroy$),
|
55
|
+
// ).subscribe(d => {
|
56
|
+
// rootRectSelection
|
57
|
+
// .attr('width', d.width)
|
58
|
+
// .attr('height', d.height)
|
59
|
+
// .attr('x', d.left)
|
60
|
+
// .attr('y', d.top)
|
61
|
+
// })
|
62
|
+
|
63
|
+
const groupMax$ = observer.computedData$.pipe(
|
64
|
+
map(d => d[0] ? d[0].length - 1 : 0),
|
65
|
+
distinctUntilChanged()
|
66
|
+
)
|
67
|
+
|
68
|
+
// const fullDataFormatterEvent$: Subject<DataFormatterGrid> = new Subject()
|
69
|
+
// fullDataFormatterEvent$
|
70
|
+
// .pipe(
|
71
|
+
// takeUntil(destroy$),
|
72
|
+
// debounceTime(50)
|
73
|
+
// )
|
74
|
+
// .subscribe(fullDataFormatter => {
|
75
|
+
// store.fullDataFormatter$.next(fullDataFormatter)
|
76
|
+
// })
|
77
|
+
|
78
|
+
const initGroupAxis$ = observer.fullDataFormatter$.pipe(
|
79
|
+
map(d => d.grid.groupAxis),
|
80
|
+
// 只用第一次資料來計算scale才不會造成每次變動都受到影響
|
81
|
+
first()
|
82
|
+
)
|
83
|
+
|
84
|
+
|
85
|
+
const groupScale$ = combineLatest({
|
86
|
+
initGroupAxis: initGroupAxis$,
|
87
|
+
fullDataFormatter: observer.fullDataFormatter$,
|
88
|
+
groupMax: groupMax$,
|
89
|
+
layout: observer.layout$,
|
90
|
+
axisSize: observer.gridAxesSize$
|
91
|
+
}).pipe(
|
92
|
+
takeUntil(destroy$),
|
93
|
+
switchMap(async (d) => d),
|
94
|
+
map(data => {
|
95
|
+
// const groupMin = 0
|
96
|
+
const groupScaleDomainMin = data.initGroupAxis.scaleDomain[0] - data.initGroupAxis.scalePadding
|
97
|
+
const groupScaleDomainMax = data.initGroupAxis.scaleDomain[1] === 'max'
|
98
|
+
? data.groupMax + data.initGroupAxis.scalePadding
|
99
|
+
: data.initGroupAxis.scaleDomain[1] as number + data.initGroupAxis.scalePadding
|
100
|
+
|
101
|
+
const groupScale: d3.ScaleLinear<number, number> = createAxisLinearScale({
|
102
|
+
maxValue: data.groupMax,
|
103
|
+
minValue: 0,
|
104
|
+
axisWidth: data.axisSize.width,
|
105
|
+
scaleDomain: [groupScaleDomainMin, groupScaleDomainMax],
|
106
|
+
scaleRange: [0, 1]
|
107
|
+
})
|
108
|
+
|
109
|
+
return groupScale
|
110
|
+
})
|
111
|
+
)
|
112
|
+
|
113
|
+
combineLatest({
|
114
|
+
groupScale: groupScale$,
|
115
|
+
// initGroupAxis: initGroupAxis$,
|
116
|
+
// fullDataFormatter: fullDataFormatter$.pipe(first()), // 只用第一次資料來計算scale才不會造成每次變動都受到影響
|
117
|
+
fullDataFormatter: observer.fullDataFormatter$,
|
118
|
+
groupMax: groupMax$,
|
119
|
+
// layout: observer.layout$,
|
120
|
+
// axisSize: observer.gridAxesSize$
|
121
|
+
}).pipe(
|
122
|
+
takeUntil(destroy$),
|
123
|
+
switchMap(async (d) => d),
|
124
|
+
).subscribe(data => {
|
125
|
+
const groupMin = 0
|
126
|
+
|
127
|
+
const shadowScale = data.groupScale.copy()
|
128
|
+
|
129
|
+
const zoom = d3.zoom()
|
130
|
+
// .scaleExtent([1, data.groupMaxIndex])
|
131
|
+
// .translateExtent([[0, 0], [data.layout.rootWidth, data.layout.rootWidth]])
|
132
|
+
.on("zoom", function zoomed(event) {
|
133
|
+
// debugger
|
134
|
+
// console.log('event', event)
|
135
|
+
const t = event.transform;
|
136
|
+
|
137
|
+
// if (event.sourceEvent.type === 'mousemove') {
|
138
|
+
// // 當進行平移時,反向計算 x 軸
|
139
|
+
// const dx = event.transform.x - currentTransform.x; // 本次平移增量
|
140
|
+
// const reversedX = currentTransform.x - dx; // 反向累積平移
|
141
|
+
// // 更新變換狀態
|
142
|
+
// currentTransform = d3.zoomIdentity
|
143
|
+
// .translate(reversedX, event.transform.y)
|
144
|
+
// .scale(event.transform.k);
|
145
|
+
// } else {
|
146
|
+
// // 縮放操作:只更新縮放比例
|
147
|
+
// currentTransform = d3.zoomIdentity
|
148
|
+
// .translate(currentTransform.x, currentTransform.y)
|
149
|
+
// .scale(event.transform.k);
|
150
|
+
// }
|
151
|
+
// console.log('currentTransform', currentTransform)
|
152
|
+
|
153
|
+
// console.log('t.x', t.x)
|
154
|
+
const mapGroupindex = (d: number) => {
|
155
|
+
const n = Math.round(d)
|
156
|
+
return Math.min(data.groupMax, Math.max(groupMin, n));
|
157
|
+
}
|
158
|
+
|
159
|
+
const zoomedDomain = data.fullDataFormatter.grid.groupAxis.position === 'bottom' || data.fullDataFormatter.grid.groupAxis.position === 'top'
|
160
|
+
? t.rescaleX(shadowScale)
|
161
|
+
.domain()
|
162
|
+
.map(mapGroupindex)
|
163
|
+
: t.rescaleY(shadowScale)
|
164
|
+
.domain()
|
165
|
+
.map(mapGroupindex)
|
166
|
+
|
167
|
+
|
168
|
+
// domain超過極限值
|
169
|
+
if (zoomedDomain[0] <= groupMin && zoomedDomain[1] >= data.groupMax) {
|
170
|
+
// 繼續縮小
|
171
|
+
if (t.k < lastTransform.k) {
|
172
|
+
// 維持前一次的transform
|
173
|
+
t.k = lastTransform.k
|
174
|
+
t.x = lastTransform.x
|
175
|
+
t.y = lastTransform.y
|
176
|
+
}
|
177
|
+
// domain間距小於1
|
178
|
+
} else if ((zoomedDomain[1] - zoomedDomain[0]) <= 1) {
|
179
|
+
// 繼續放大
|
180
|
+
if (t.k > lastTransform.k) {
|
181
|
+
// 維持前一次的transform
|
182
|
+
t.k = lastTransform.k
|
183
|
+
t.x = lastTransform.x
|
184
|
+
t.y = lastTransform.y
|
185
|
+
}
|
186
|
+
}
|
187
|
+
|
188
|
+
// 紀錄transform
|
189
|
+
lastTransform.k = t.k
|
190
|
+
lastTransform.x = t.x
|
191
|
+
lastTransform.y = t.y
|
192
|
+
|
193
|
+
|
194
|
+
const newDataFormatter: DataFormatterGrid = {
|
195
|
+
...data.fullDataFormatter,
|
196
|
+
grid: {
|
197
|
+
...data.fullDataFormatter.grid,
|
198
|
+
groupAxis: {
|
199
|
+
...data.fullDataFormatter.grid.groupAxis,
|
200
|
+
scaleDomain: zoomedDomain
|
201
|
+
}
|
202
|
+
}
|
203
|
+
}
|
204
|
+
subject.dataFormatter$.next(newDataFormatter)
|
205
|
+
})
|
206
|
+
|
207
|
+
// 傳入外層selection
|
208
|
+
// subject.selection.call(zoom as any)
|
209
|
+
rootSelection.call(zoom)
|
210
|
+
|
211
|
+
})
|
212
|
+
|
213
|
+
return () => {
|
214
|
+
destroy$.next(undefined)
|
215
|
+
// rootRectSelection.remove()
|
216
|
+
|
217
|
+
rootSelection.call(d3.zoom().on('zoom', null))
|
218
|
+
}
|
219
219
|
})
|