@orbcharts/plugins-basic 3.0.0-alpha.61 → 3.0.0-alpha.63

Sign up to get free protection for your applications and to get access to all the features.
Files changed (78) hide show
  1. package/LICENSE +200 -200
  2. package/dist/orbcharts-plugins-basic.es.js +6113 -6065
  3. package/dist/orbcharts-plugins-basic.umd.js +10 -10
  4. package/package.json +42 -42
  5. package/src/base/BaseBarStack.ts +778 -778
  6. package/src/base/BaseBars.ts +764 -764
  7. package/src/base/BaseBarsTriangle.ts +672 -672
  8. package/src/base/BaseDots.ts +513 -513
  9. package/src/base/BaseGroupAxis.ts +637 -558
  10. package/src/base/BaseLegend.ts +641 -641
  11. package/src/base/BaseLineAreas.ts +628 -628
  12. package/src/base/BaseLines.ts +704 -704
  13. package/src/base/BaseValueAxis.ts +577 -478
  14. package/src/base/types.ts +2 -2
  15. package/src/grid/defaults.ts +128 -128
  16. package/src/grid/gridObservables.ts +541 -541
  17. package/src/grid/index.ts +15 -15
  18. package/src/grid/plugins/BarStack.ts +43 -43
  19. package/src/grid/plugins/Bars.ts +44 -44
  20. package/src/grid/plugins/BarsPN.ts +41 -41
  21. package/src/grid/plugins/BarsTriangle.ts +42 -42
  22. package/src/grid/plugins/Dots.ts +37 -37
  23. package/src/grid/plugins/GridLegend.ts +59 -59
  24. package/src/grid/plugins/GroupAux.ts +979 -976
  25. package/src/grid/plugins/GroupAxis.ts +35 -35
  26. package/src/grid/plugins/LineAreas.ts +40 -40
  27. package/src/grid/plugins/Lines.ts +40 -40
  28. package/src/grid/plugins/ScalingArea.ts +173 -173
  29. package/src/grid/plugins/ValueAxis.ts +36 -36
  30. package/src/grid/plugins/ValueStackAxis.ts +38 -38
  31. package/src/grid/types.ts +123 -123
  32. package/src/index.ts +9 -9
  33. package/src/multiGrid/defaults.ts +158 -158
  34. package/src/multiGrid/index.ts +13 -13
  35. package/src/multiGrid/multiGridObservables.ts +49 -49
  36. package/src/multiGrid/plugins/MultiBarStack.ts +78 -78
  37. package/src/multiGrid/plugins/MultiBars.ts +77 -77
  38. package/src/multiGrid/plugins/MultiBarsTriangle.ts +77 -77
  39. package/src/multiGrid/plugins/MultiDots.ts +65 -65
  40. package/src/multiGrid/plugins/MultiGridLegend.ts +89 -89
  41. package/src/multiGrid/plugins/MultiGroupAxis.ts +69 -69
  42. package/src/multiGrid/plugins/MultiLineAreas.ts +77 -77
  43. package/src/multiGrid/plugins/MultiLines.ts +77 -77
  44. package/src/multiGrid/plugins/MultiValueAxis.ts +69 -69
  45. package/src/multiGrid/plugins/MultiValueStackAxis.ts +69 -69
  46. package/src/multiGrid/plugins/OverlappingValueAxes.ts +167 -167
  47. package/src/multiGrid/plugins/OverlappingValueStackAxes.ts +168 -168
  48. package/src/multiGrid/types.ts +72 -72
  49. package/src/noneData/defaults.ts +102 -102
  50. package/src/noneData/index.ts +3 -3
  51. package/src/noneData/plugins/Container.ts +10 -10
  52. package/src/noneData/plugins/Tooltip.ts +310 -310
  53. package/src/noneData/types.ts +26 -26
  54. package/src/series/defaults.ts +144 -144
  55. package/src/series/index.ts +9 -9
  56. package/src/series/plugins/Bubbles.ts +545 -545
  57. package/src/series/plugins/Pie.ts +576 -576
  58. package/src/series/plugins/PieEventTexts.ts +262 -262
  59. package/src/series/plugins/PieLabels.ts +304 -304
  60. package/src/series/plugins/Rose.ts +472 -472
  61. package/src/series/plugins/RoseLabels.ts +362 -362
  62. package/src/series/plugins/SeriesLegend.ts +59 -59
  63. package/src/series/seriesObservables.ts +145 -145
  64. package/src/series/seriesUtils.ts +51 -51
  65. package/src/series/types.ts +83 -83
  66. package/src/tree/defaults.ts +23 -23
  67. package/src/tree/index.ts +3 -3
  68. package/src/tree/plugins/TreeLegend.ts +59 -59
  69. package/src/tree/plugins/TreeMap.ts +305 -305
  70. package/src/tree/types.ts +23 -23
  71. package/src/utils/commonUtils.ts +21 -21
  72. package/src/utils/d3Graphics.ts +124 -124
  73. package/src/utils/d3Utils.ts +73 -73
  74. package/src/utils/observables.ts +14 -14
  75. package/src/utils/orbchartsUtils.ts +100 -100
  76. package/tsconfig.base.json +13 -13
  77. package/tsconfig.json +2 -2
  78. package/vite.config.js +22 -22
@@ -1,14 +1,14 @@
1
- export * from './defaults'
2
- export * from './types'
3
- export { MultiGridLegend } from './plugins/MultiGridLegend'
4
- export { MultiBars } from './plugins/MultiBars'
5
- export { MultiBarStack } from './plugins/MultiBarStack'
6
- export { MultiBarsTriangle } from './plugins/MultiBarsTriangle'
7
- export { MultiLines } from './plugins/MultiLines'
8
- export { MultiLineAreas } from './plugins/MultiLineAreas'
9
- export { MultiDots } from './plugins/MultiDots'
10
- export { MultiGroupAxis } from './plugins/MultiGroupAxis'
11
- export { MultiValueAxis } from './plugins/MultiValueAxis'
12
- export { MultiValueStackAxis } from './plugins/MultiValueStackAxis'
13
- export { OverlappingValueAxes } from './plugins/OverlappingValueAxes'
1
+ export * from './defaults'
2
+ export * from './types'
3
+ export { MultiGridLegend } from './plugins/MultiGridLegend'
4
+ export { MultiBars } from './plugins/MultiBars'
5
+ export { MultiBarStack } from './plugins/MultiBarStack'
6
+ export { MultiBarsTriangle } from './plugins/MultiBarsTriangle'
7
+ export { MultiLines } from './plugins/MultiLines'
8
+ export { MultiLineAreas } from './plugins/MultiLineAreas'
9
+ export { MultiDots } from './plugins/MultiDots'
10
+ export { MultiGroupAxis } from './plugins/MultiGroupAxis'
11
+ export { MultiValueAxis } from './plugins/MultiValueAxis'
12
+ export { MultiValueStackAxis } from './plugins/MultiValueStackAxis'
13
+ export { OverlappingValueAxes } from './plugins/OverlappingValueAxes'
14
14
  export { OverlappingValueStackAxes } from './plugins/OverlappingValueStackAxes'
@@ -1,49 +1,49 @@
1
- import type { Observable } from 'rxjs'
2
- import {
3
- Subject,
4
- takeUntil,
5
- of,
6
- map,
7
- reduce,
8
- switchMap,
9
- combineLatest,
10
- distinctUntilChanged,
11
- shareReplay
12
- } from 'rxjs'
13
- import type {
14
- ContextObserverMultiGrid,
15
- ComputedDataGrid,
16
- DataFormatterGrid,
17
- ContextObserverGridDetail,
18
- ContextObserverMultiGridDetail } from '@orbcharts/core'
19
-
20
- // 可設定多個gridIndex的params
21
- interface MultiGridPluginParams {
22
- gridIndexes: number[] | 'all'
23
- }
24
-
25
- // 對應grid資料的plugin所需Observable(必須有gridIndexes)
26
- export const multiGridPluginDetailObservables = (observer: ContextObserverMultiGrid<MultiGridPluginParams>): Observable<ContextObserverMultiGridDetail[]> => {
27
- const gridIndexes$ = observer.fullParams$.pipe(
28
- map(fullParams => fullParams.gridIndexes),
29
- distinctUntilChanged(),
30
- shareReplay(1)
31
- )
32
-
33
- return combineLatest({
34
- multiGridEachDetail: observer.multiGridEachDetail$,
35
- gridIndexes: gridIndexes$,
36
- }).pipe(
37
- map(data => {
38
- // 對應所有grid
39
- if (data.gridIndexes === 'all') {
40
- return data.multiGridEachDetail
41
- }
42
- // 自訂對應grid
43
- return data.gridIndexes.map(gridIndex => {
44
- return data.multiGridEachDetail[gridIndex] ?? data.multiGridEachDetail[0]
45
- })
46
- })
47
- )
48
- }
49
-
1
+ import type { Observable } from 'rxjs'
2
+ import {
3
+ Subject,
4
+ takeUntil,
5
+ of,
6
+ map,
7
+ reduce,
8
+ switchMap,
9
+ combineLatest,
10
+ distinctUntilChanged,
11
+ shareReplay
12
+ } from 'rxjs'
13
+ import type {
14
+ ContextObserverMultiGrid,
15
+ ComputedDataGrid,
16
+ DataFormatterGrid,
17
+ ContextObserverGridDetail,
18
+ ContextObserverMultiGridDetail } from '@orbcharts/core'
19
+
20
+ // 可設定多個gridIndex的params
21
+ interface MultiGridPluginParams {
22
+ gridIndexes: number[] | 'all'
23
+ }
24
+
25
+ // 對應grid資料的plugin所需Observable(必須有gridIndexes)
26
+ export const multiGridPluginDetailObservables = (observer: ContextObserverMultiGrid<MultiGridPluginParams>): Observable<ContextObserverMultiGridDetail[]> => {
27
+ const gridIndexes$ = observer.fullParams$.pipe(
28
+ map(fullParams => fullParams.gridIndexes),
29
+ distinctUntilChanged(),
30
+ shareReplay(1)
31
+ )
32
+
33
+ return combineLatest({
34
+ multiGridEachDetail: observer.multiGridEachDetail$,
35
+ gridIndexes: gridIndexes$,
36
+ }).pipe(
37
+ map(data => {
38
+ // 對應所有grid
39
+ if (data.gridIndexes === 'all') {
40
+ return data.multiGridEachDetail
41
+ }
42
+ // 自訂對應grid
43
+ return data.gridIndexes.map(gridIndex => {
44
+ return data.multiGridEachDetail[gridIndex] ?? data.multiGridEachDetail[0]
45
+ })
46
+ })
47
+ )
48
+ }
49
+
@@ -1,78 +1,78 @@
1
- import * as d3 from 'd3'
2
- import {
3
- Subject,
4
- map,
5
- distinctUntilChanged,
6
- shareReplay,
7
- takeUntil
8
- } from 'rxjs'
9
- import {
10
- defineMultiGridPlugin } from '@orbcharts/core'
11
- import { DEFAULT_MULTI_BAR_STACK_PARAMS } from '../defaults'
12
- import { createBaseBarStack } from '../../base/BaseBarStack'
13
- import { multiGridPluginDetailObservables } from '../multiGridObservables'
14
- import { getClassName, getUniID } from '../../utils/orbchartsUtils'
15
-
16
- const pluginName = 'MultiBarStack'
17
-
18
- const gridClassName = getClassName(pluginName, 'grid')
19
-
20
- export const MultiBarStack = defineMultiGridPlugin(pluginName, DEFAULT_MULTI_BAR_STACK_PARAMS)(({ selection, name, subject, observer }) => {
21
- const destroy$ = new Subject()
22
-
23
- const unsubscribeFnArr: (() => void)[] = []
24
-
25
- const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
26
-
27
- multiGridPluginDetail$
28
- .pipe(
29
- takeUntil(destroy$)
30
- )
31
- .subscribe(data => {
32
- // 每次重新計算時,清除之前的訂閱
33
- unsubscribeFnArr.forEach(fn => fn())
34
-
35
- selection.selectAll(`g.${gridClassName}`)
36
- .data(data)
37
- .join('g')
38
- .attr('class', gridClassName)
39
- .each((d, i, g) => {
40
-
41
- const gridSelection = d3.select(g[i])
42
-
43
- const isSeriesSeprate$ = d.dataFormatter$.pipe(
44
- takeUntil(destroy$),
45
- map(d => d.grid.separateSeries),
46
- distinctUntilChanged(),
47
- shareReplay(1)
48
- )
49
-
50
- unsubscribeFnArr[i] = createBaseBarStack(pluginName, {
51
- selection: gridSelection,
52
- computedData$: d.computedData$,
53
- visibleComputedData$: d.visibleComputedData$,
54
- computedLayoutData$: d.computedLayoutData$,
55
- visibleComputedLayoutData$: d.visibleComputedLayoutData$,
56
- seriesLabels$: d.seriesLabels$,
57
- SeriesDataMap$: d.SeriesDataMap$,
58
- GroupDataMap$: d.GroupDataMap$,
59
- fullParams$: observer.fullParams$,
60
- fullDataFormatter$: d.dataFormatter$,
61
- fullChartParams$: observer.fullChartParams$,
62
- gridAxesTransform$: d.gridAxesTransform$,
63
- gridGraphicTransform$: d.gridGraphicTransform$,
64
- gridGraphicReverseScale$: d.gridGraphicReverseScale$,
65
- gridAxesSize$: d.gridAxesSize$,
66
- gridHighlight$: d.gridHighlight$,
67
- gridContainerPosition$: d.gridContainerPosition$,
68
- isSeriesSeprate$,
69
- event$: subject.event$ as Subject<any>,
70
- })
71
- })
72
- })
73
-
74
- return () => {
75
- destroy$.next(undefined)
76
- unsubscribeFnArr.forEach(fn => fn())
77
- }
78
- })
1
+ import * as d3 from 'd3'
2
+ import {
3
+ Subject,
4
+ map,
5
+ distinctUntilChanged,
6
+ shareReplay,
7
+ takeUntil
8
+ } from 'rxjs'
9
+ import {
10
+ defineMultiGridPlugin } from '@orbcharts/core'
11
+ import { DEFAULT_MULTI_BAR_STACK_PARAMS } from '../defaults'
12
+ import { createBaseBarStack } from '../../base/BaseBarStack'
13
+ import { multiGridPluginDetailObservables } from '../multiGridObservables'
14
+ import { getClassName, getUniID } from '../../utils/orbchartsUtils'
15
+
16
+ const pluginName = 'MultiBarStack'
17
+
18
+ const gridClassName = getClassName(pluginName, 'grid')
19
+
20
+ export const MultiBarStack = defineMultiGridPlugin(pluginName, DEFAULT_MULTI_BAR_STACK_PARAMS)(({ selection, name, subject, observer }) => {
21
+ const destroy$ = new Subject()
22
+
23
+ const unsubscribeFnArr: (() => void)[] = []
24
+
25
+ const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
26
+
27
+ multiGridPluginDetail$
28
+ .pipe(
29
+ takeUntil(destroy$)
30
+ )
31
+ .subscribe(data => {
32
+ // 每次重新計算時,清除之前的訂閱
33
+ unsubscribeFnArr.forEach(fn => fn())
34
+
35
+ selection.selectAll(`g.${gridClassName}`)
36
+ .data(data)
37
+ .join('g')
38
+ .attr('class', gridClassName)
39
+ .each((d, i, g) => {
40
+
41
+ const gridSelection = d3.select(g[i])
42
+
43
+ const isSeriesSeprate$ = d.dataFormatter$.pipe(
44
+ takeUntil(destroy$),
45
+ map(d => d.grid.separateSeries),
46
+ distinctUntilChanged(),
47
+ shareReplay(1)
48
+ )
49
+
50
+ unsubscribeFnArr[i] = createBaseBarStack(pluginName, {
51
+ selection: gridSelection,
52
+ computedData$: d.computedData$,
53
+ visibleComputedData$: d.visibleComputedData$,
54
+ computedLayoutData$: d.computedLayoutData$,
55
+ visibleComputedLayoutData$: d.visibleComputedLayoutData$,
56
+ seriesLabels$: d.seriesLabels$,
57
+ SeriesDataMap$: d.SeriesDataMap$,
58
+ GroupDataMap$: d.GroupDataMap$,
59
+ fullParams$: observer.fullParams$,
60
+ fullDataFormatter$: d.dataFormatter$,
61
+ fullChartParams$: observer.fullChartParams$,
62
+ gridAxesTransform$: d.gridAxesTransform$,
63
+ gridGraphicTransform$: d.gridGraphicTransform$,
64
+ gridGraphicReverseScale$: d.gridGraphicReverseScale$,
65
+ gridAxesSize$: d.gridAxesSize$,
66
+ gridHighlight$: d.gridHighlight$,
67
+ gridContainerPosition$: d.gridContainerPosition$,
68
+ isSeriesSeprate$,
69
+ event$: subject.event$ as Subject<any>,
70
+ })
71
+ })
72
+ })
73
+
74
+ return () => {
75
+ destroy$.next(undefined)
76
+ unsubscribeFnArr.forEach(fn => fn())
77
+ }
78
+ })
@@ -1,77 +1,77 @@
1
- import * as d3 from 'd3'
2
- import {
3
- Subject,
4
- map,
5
- distinctUntilChanged,
6
- shareReplay,
7
- takeUntil
8
- } from 'rxjs'
9
- import {
10
- defineMultiGridPlugin } from '@orbcharts/core'
11
- import { DEFAULT_MULTI_BARS_PARAMS } from '../defaults'
12
- import { createBaseBars } from '../../base/BaseBars'
13
- import { multiGridPluginDetailObservables } from '../multiGridObservables'
14
- import { getClassName, getUniID } from '../../utils/orbchartsUtils'
15
-
16
- const pluginName = 'MultiBars'
17
-
18
- const gridClassName = getClassName(pluginName, 'grid')
19
-
20
- export const MultiBars = defineMultiGridPlugin(pluginName, DEFAULT_MULTI_BARS_PARAMS)(({ selection, name, subject, observer }) => {
21
- const destroy$ = new Subject()
22
-
23
- const unsubscribeFnArr: (() => void)[] = []
24
-
25
- const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
26
-
27
- multiGridPluginDetail$
28
- .pipe(
29
- takeUntil(destroy$)
30
- )
31
- .subscribe(data => {
32
- // 每次重新計算時,清除之前的訂閱
33
- unsubscribeFnArr.forEach(fn => fn())
34
-
35
- selection.selectAll(`g.${gridClassName}`)
36
- .data(data)
37
- .join('g')
38
- .attr('class', gridClassName)
39
- .each((d, i, g) => {
40
-
41
- const gridSelection = d3.select(g[i])
42
-
43
- const isSeriesSeprate$ = d.dataFormatter$.pipe(
44
- takeUntil(destroy$),
45
- map(d => d.grid.separateSeries),
46
- distinctUntilChanged(),
47
- shareReplay(1)
48
- )
49
-
50
- unsubscribeFnArr[i] = createBaseBars(pluginName, {
51
- selection: gridSelection,
52
- computedData$: d.computedData$,
53
- visibleComputedData$: d.visibleComputedData$,
54
- computedLayoutData$: d.computedLayoutData$,
55
- visibleComputedLayoutData$: d.visibleComputedLayoutData$,
56
- seriesLabels$: d.seriesLabels$,
57
- SeriesDataMap$: d.SeriesDataMap$,
58
- GroupDataMap$: d.GroupDataMap$,
59
- fullParams$: observer.fullParams$,
60
- fullChartParams$: observer.fullChartParams$,
61
- gridAxesTransform$: d.gridAxesTransform$,
62
- gridGraphicTransform$: d.gridGraphicTransform$,
63
- gridGraphicReverseScale$: d.gridGraphicReverseScale$,
64
- gridAxesSize$: d.gridAxesSize$,
65
- gridHighlight$: d.gridHighlight$,
66
- gridContainerPosition$: d.gridContainerPosition$,
67
- isSeriesSeprate$,
68
- event$: subject.event$ as Subject<any>,
69
- })
70
- })
71
- })
72
-
73
- return () => {
74
- destroy$.next(undefined)
75
- unsubscribeFnArr.forEach(fn => fn())
76
- }
77
- })
1
+ import * as d3 from 'd3'
2
+ import {
3
+ Subject,
4
+ map,
5
+ distinctUntilChanged,
6
+ shareReplay,
7
+ takeUntil
8
+ } from 'rxjs'
9
+ import {
10
+ defineMultiGridPlugin } from '@orbcharts/core'
11
+ import { DEFAULT_MULTI_BARS_PARAMS } from '../defaults'
12
+ import { createBaseBars } from '../../base/BaseBars'
13
+ import { multiGridPluginDetailObservables } from '../multiGridObservables'
14
+ import { getClassName, getUniID } from '../../utils/orbchartsUtils'
15
+
16
+ const pluginName = 'MultiBars'
17
+
18
+ const gridClassName = getClassName(pluginName, 'grid')
19
+
20
+ export const MultiBars = defineMultiGridPlugin(pluginName, DEFAULT_MULTI_BARS_PARAMS)(({ selection, name, subject, observer }) => {
21
+ const destroy$ = new Subject()
22
+
23
+ const unsubscribeFnArr: (() => void)[] = []
24
+
25
+ const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
26
+
27
+ multiGridPluginDetail$
28
+ .pipe(
29
+ takeUntil(destroy$)
30
+ )
31
+ .subscribe(data => {
32
+ // 每次重新計算時,清除之前的訂閱
33
+ unsubscribeFnArr.forEach(fn => fn())
34
+
35
+ selection.selectAll(`g.${gridClassName}`)
36
+ .data(data)
37
+ .join('g')
38
+ .attr('class', gridClassName)
39
+ .each((d, i, g) => {
40
+
41
+ const gridSelection = d3.select(g[i])
42
+
43
+ const isSeriesSeprate$ = d.dataFormatter$.pipe(
44
+ takeUntil(destroy$),
45
+ map(d => d.grid.separateSeries),
46
+ distinctUntilChanged(),
47
+ shareReplay(1)
48
+ )
49
+
50
+ unsubscribeFnArr[i] = createBaseBars(pluginName, {
51
+ selection: gridSelection,
52
+ computedData$: d.computedData$,
53
+ visibleComputedData$: d.visibleComputedData$,
54
+ computedLayoutData$: d.computedLayoutData$,
55
+ visibleComputedLayoutData$: d.visibleComputedLayoutData$,
56
+ seriesLabels$: d.seriesLabels$,
57
+ SeriesDataMap$: d.SeriesDataMap$,
58
+ GroupDataMap$: d.GroupDataMap$,
59
+ fullParams$: observer.fullParams$,
60
+ fullChartParams$: observer.fullChartParams$,
61
+ gridAxesTransform$: d.gridAxesTransform$,
62
+ gridGraphicTransform$: d.gridGraphicTransform$,
63
+ gridGraphicReverseScale$: d.gridGraphicReverseScale$,
64
+ gridAxesSize$: d.gridAxesSize$,
65
+ gridHighlight$: d.gridHighlight$,
66
+ gridContainerPosition$: d.gridContainerPosition$,
67
+ isSeriesSeprate$,
68
+ event$: subject.event$ as Subject<any>,
69
+ })
70
+ })
71
+ })
72
+
73
+ return () => {
74
+ destroy$.next(undefined)
75
+ unsubscribeFnArr.forEach(fn => fn())
76
+ }
77
+ })
@@ -1,77 +1,77 @@
1
- import * as d3 from 'd3'
2
- import {
3
- Subject,
4
- map,
5
- distinctUntilChanged,
6
- shareReplay,
7
- takeUntil
8
- } from 'rxjs'
9
- import {
10
- defineMultiGridPlugin } from '@orbcharts/core'
11
- import { DEFAULT_MULTI_BARS_TRIANGLE_PARAMS } from '../defaults'
12
- import { createBaseBarsTriangle } from '../../base/BaseBarsTriangle'
13
- import { multiGridPluginDetailObservables } from '../multiGridObservables'
14
- import { getClassName, getUniID } from '../../utils/orbchartsUtils'
15
-
16
- const pluginName = 'MultiBarsTriangle'
17
-
18
- const gridClassName = getClassName(pluginName, 'grid')
19
-
20
- export const MultiBarsTriangle = defineMultiGridPlugin(pluginName, DEFAULT_MULTI_BARS_TRIANGLE_PARAMS)(({ selection, name, subject, observer }) => {
21
- const destroy$ = new Subject()
22
-
23
- const unsubscribeFnArr: (() => void)[] = []
24
-
25
- const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
26
-
27
- multiGridPluginDetail$
28
- .pipe(
29
- takeUntil(destroy$)
30
- )
31
- .subscribe(data => {
32
- // 每次重新計算時,清除之前的訂閱
33
- unsubscribeFnArr.forEach(fn => fn())
34
-
35
- selection.selectAll(`g.${gridClassName}`)
36
- .data(data)
37
- .join('g')
38
- .attr('class', gridClassName)
39
- .each((d, i, g) => {
40
-
41
- const gridSelection = d3.select(g[i])
42
-
43
- const isSeriesSeprate$ = d.dataFormatter$.pipe(
44
- takeUntil(destroy$),
45
- map(d => d.grid.separateSeries),
46
- distinctUntilChanged(),
47
- shareReplay(1)
48
- )
49
-
50
- unsubscribeFnArr[i] = createBaseBarsTriangle(pluginName, {
51
- selection: gridSelection,
52
- computedData$: d.computedData$,
53
- visibleComputedData$: d.visibleComputedData$,
54
- computedLayoutData$: d.computedLayoutData$,
55
- visibleComputedLayoutData$: d.visibleComputedLayoutData$,
56
- seriesLabels$: d.seriesLabels$,
57
- SeriesDataMap$: d.SeriesDataMap$,
58
- GroupDataMap$: d.GroupDataMap$,
59
- fullParams$: observer.fullParams$,
60
- fullChartParams$: observer.fullChartParams$,
61
- fullDataFormatter$: d.dataFormatter$,
62
- gridAxesTransform$: d.gridAxesTransform$,
63
- gridGraphicTransform$: d.gridGraphicTransform$,
64
- gridAxesSize$: d.gridAxesSize$,
65
- gridHighlight$: d.gridHighlight$,
66
- gridContainerPosition$: d.gridContainerPosition$,
67
- isSeriesSeprate$: isSeriesSeprate$,
68
- event$: subject.event$ as Subject<any>,
69
- })
70
- })
71
- })
72
-
73
- return () => {
74
- destroy$.next(undefined)
75
- unsubscribeFnArr.forEach(fn => fn())
76
- }
77
- })
1
+ import * as d3 from 'd3'
2
+ import {
3
+ Subject,
4
+ map,
5
+ distinctUntilChanged,
6
+ shareReplay,
7
+ takeUntil
8
+ } from 'rxjs'
9
+ import {
10
+ defineMultiGridPlugin } from '@orbcharts/core'
11
+ import { DEFAULT_MULTI_BARS_TRIANGLE_PARAMS } from '../defaults'
12
+ import { createBaseBarsTriangle } from '../../base/BaseBarsTriangle'
13
+ import { multiGridPluginDetailObservables } from '../multiGridObservables'
14
+ import { getClassName, getUniID } from '../../utils/orbchartsUtils'
15
+
16
+ const pluginName = 'MultiBarsTriangle'
17
+
18
+ const gridClassName = getClassName(pluginName, 'grid')
19
+
20
+ export const MultiBarsTriangle = defineMultiGridPlugin(pluginName, DEFAULT_MULTI_BARS_TRIANGLE_PARAMS)(({ selection, name, subject, observer }) => {
21
+ const destroy$ = new Subject()
22
+
23
+ const unsubscribeFnArr: (() => void)[] = []
24
+
25
+ const multiGridPluginDetail$ = multiGridPluginDetailObservables(observer)
26
+
27
+ multiGridPluginDetail$
28
+ .pipe(
29
+ takeUntil(destroy$)
30
+ )
31
+ .subscribe(data => {
32
+ // 每次重新計算時,清除之前的訂閱
33
+ unsubscribeFnArr.forEach(fn => fn())
34
+
35
+ selection.selectAll(`g.${gridClassName}`)
36
+ .data(data)
37
+ .join('g')
38
+ .attr('class', gridClassName)
39
+ .each((d, i, g) => {
40
+
41
+ const gridSelection = d3.select(g[i])
42
+
43
+ const isSeriesSeprate$ = d.dataFormatter$.pipe(
44
+ takeUntil(destroy$),
45
+ map(d => d.grid.separateSeries),
46
+ distinctUntilChanged(),
47
+ shareReplay(1)
48
+ )
49
+
50
+ unsubscribeFnArr[i] = createBaseBarsTriangle(pluginName, {
51
+ selection: gridSelection,
52
+ computedData$: d.computedData$,
53
+ visibleComputedData$: d.visibleComputedData$,
54
+ computedLayoutData$: d.computedLayoutData$,
55
+ visibleComputedLayoutData$: d.visibleComputedLayoutData$,
56
+ seriesLabels$: d.seriesLabels$,
57
+ SeriesDataMap$: d.SeriesDataMap$,
58
+ GroupDataMap$: d.GroupDataMap$,
59
+ fullParams$: observer.fullParams$,
60
+ fullChartParams$: observer.fullChartParams$,
61
+ fullDataFormatter$: d.dataFormatter$,
62
+ gridAxesTransform$: d.gridAxesTransform$,
63
+ gridGraphicTransform$: d.gridGraphicTransform$,
64
+ gridAxesSize$: d.gridAxesSize$,
65
+ gridHighlight$: d.gridHighlight$,
66
+ gridContainerPosition$: d.gridContainerPosition$,
67
+ isSeriesSeprate$: isSeriesSeprate$,
68
+ event$: subject.event$ as Subject<any>,
69
+ })
70
+ })
71
+ })
72
+
73
+ return () => {
74
+ destroy$.next(undefined)
75
+ unsubscribeFnArr.forEach(fn => fn())
76
+ }
77
+ })