@orbcharts/plugins-basic 3.0.0-beta.6 → 3.0.0-beta.7

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 (93) hide show
  1. package/LICENSE +200 -200
  2. package/dist/orbcharts-plugins-basic/src/utils/d3Utils.d.ts +2 -2
  3. package/dist/orbcharts-plugins-basic.es.js +5001 -4981
  4. package/dist/orbcharts-plugins-basic.umd.js +28 -28
  5. package/lib/core-types.ts +7 -7
  6. package/lib/core.ts +6 -6
  7. package/lib/plugins-basic-types.ts +6 -6
  8. package/package.json +44 -44
  9. package/src/base/BaseBarStack.ts +782 -780
  10. package/src/base/BaseBars.ts +765 -765
  11. package/src/base/BaseBarsTriangle.ts +676 -674
  12. package/src/base/BaseDots.ts +464 -464
  13. package/src/base/BaseGroupAxis.ts +679 -679
  14. package/src/base/BaseLegend.ts +684 -684
  15. package/src/base/BaseLineAreas.ts +629 -629
  16. package/src/base/BaseLines.ts +706 -706
  17. package/src/base/BaseTooltip.ts +385 -385
  18. package/src/base/BaseValueAxis.ts +583 -583
  19. package/src/base/types.ts +2 -2
  20. package/src/const.ts +30 -30
  21. package/src/grid/defaults.ts +246 -244
  22. package/src/grid/gridObservables.ts +554 -554
  23. package/src/grid/index.ts +16 -16
  24. package/src/grid/plugins/BarStack.ts +64 -64
  25. package/src/grid/plugins/Bars.ts +69 -69
  26. package/src/grid/plugins/BarsPN.ts +66 -66
  27. package/src/grid/plugins/BarsTriangle.ts +73 -73
  28. package/src/grid/plugins/Dots.ts +68 -68
  29. package/src/grid/plugins/GridLegend.ts +107 -107
  30. package/src/grid/plugins/GridTooltip.ts +66 -66
  31. package/src/grid/plugins/GridZoom.ts +218 -218
  32. package/src/grid/plugins/GroupAux.ts +1103 -1103
  33. package/src/grid/plugins/GroupAxis.ts +97 -97
  34. package/src/grid/plugins/LineAreas.ts +65 -65
  35. package/src/grid/plugins/Lines.ts +59 -59
  36. package/src/grid/plugins/ValueAxis.ts +94 -94
  37. package/src/grid/plugins/ValueStackAxis.ts +96 -96
  38. package/src/index.ts +10 -10
  39. package/src/multiGrid/defaults.ts +224 -224
  40. package/src/multiGrid/index.ts +14 -14
  41. package/src/multiGrid/multiGridObservables.ts +49 -49
  42. package/src/multiGrid/plugins/MultiBarStack.ts +106 -106
  43. package/src/multiGrid/plugins/MultiBars.ts +108 -108
  44. package/src/multiGrid/plugins/MultiBarsTriangle.ts +114 -114
  45. package/src/multiGrid/plugins/MultiDots.ts +102 -102
  46. package/src/multiGrid/plugins/MultiGridLegend.ts +159 -159
  47. package/src/multiGrid/plugins/MultiGridTooltip.ts +66 -66
  48. package/src/multiGrid/plugins/MultiGroupAxis.ts +137 -137
  49. package/src/multiGrid/plugins/MultiLineAreas.ts +107 -107
  50. package/src/multiGrid/plugins/MultiLines.ts +101 -101
  51. package/src/multiGrid/plugins/MultiValueAxis.ts +134 -134
  52. package/src/multiGrid/plugins/MultiValueStackAxis.ts +134 -134
  53. package/src/multiGrid/plugins/OverlappingValueAxes.ts +300 -300
  54. package/src/multiGrid/plugins/OverlappingValueStackAxes.ts +299 -299
  55. package/src/multiValue/defaults.ts +166 -162
  56. package/src/multiValue/index.ts +8 -8
  57. package/src/multiValue/multiValueObservables.ts +297 -258
  58. package/src/multiValue/plugins/MultiValueLegend.ts +107 -107
  59. package/src/multiValue/plugins/MultiValueTooltip.ts +66 -66
  60. package/src/multiValue/plugins/Scatter.ts +426 -426
  61. package/src/multiValue/plugins/ScatterBubbles.ts +554 -551
  62. package/src/multiValue/plugins/XYAux.ts +681 -681
  63. package/src/multiValue/plugins/XYAxes.ts +684 -676
  64. package/src/multiValue/plugins/XYZoom.ts +299 -299
  65. package/src/noneData/defaults.ts +102 -102
  66. package/src/noneData/index.ts +3 -3
  67. package/src/noneData/plugins/Container.ts +27 -27
  68. package/src/noneData/plugins/Tooltip.ts +373 -373
  69. package/src/series/defaults.ts +206 -206
  70. package/src/series/index.ts +9 -9
  71. package/src/series/plugins/Bubbles.ts +603 -603
  72. package/src/series/plugins/Pie.ts +623 -623
  73. package/src/series/plugins/PieEventTexts.ts +283 -283
  74. package/src/series/plugins/PieLabels.ts +640 -640
  75. package/src/series/plugins/Rose.ts +516 -516
  76. package/src/series/plugins/RoseLabels.ts +600 -600
  77. package/src/series/plugins/SeriesLegend.ts +107 -107
  78. package/src/series/plugins/SeriesTooltip.ts +66 -66
  79. package/src/series/seriesObservables.ts +145 -145
  80. package/src/series/seriesUtils.ts +51 -51
  81. package/src/tree/defaults.ts +78 -78
  82. package/src/tree/index.ts +4 -4
  83. package/src/tree/plugins/TreeLegend.ts +100 -100
  84. package/src/tree/plugins/TreeMap.ts +333 -333
  85. package/src/tree/plugins/TreeTooltip.ts +66 -66
  86. package/src/utils/commonUtils.ts +21 -21
  87. package/src/utils/d3Graphics.ts +174 -174
  88. package/src/utils/d3Utils.ts +74 -74
  89. package/src/utils/observables.ts +14 -14
  90. package/src/utils/orbchartsUtils.ts +116 -101
  91. package/tsconfig.base.json +13 -13
  92. package/tsconfig.json +2 -2
  93. package/vite.config.js +22 -22
@@ -1,14 +1,14 @@
1
- import * as d3 from 'd3'
2
- import { Observable, merge, distinctUntilChanged, fromEvent } from 'rxjs'
3
-
4
- export function d3EventObservable(selection: d3.Selection<any, any, any, any>, event: any) {
5
- // Start with an observable that will never emit
6
- let obs: Observable<MouseEvent> = new Observable(() => {});
7
- selection.each(function () {
8
- // Create observables from each of the elements
9
- const events: Observable<MouseEvent> = fromEvent(this, event);
10
- // Merge the observables into one
11
- obs = merge(obs, events);
12
- });
13
- return obs;
14
- }
1
+ import * as d3 from 'd3'
2
+ import { Observable, merge, distinctUntilChanged, fromEvent } from 'rxjs'
3
+
4
+ export function d3EventObservable(selection: d3.Selection<any, any, any, any>, event: any) {
5
+ // Start with an observable that will never emit
6
+ let obs: Observable<MouseEvent> = new Observable(() => {});
7
+ selection.each(function () {
8
+ // Create observables from each of the elements
9
+ const events: Observable<MouseEvent> = fromEvent(this, event);
10
+ // Merge the observables into one
11
+ obs = merge(obs, events);
12
+ });
13
+ return obs;
14
+ }
@@ -1,101 +1,116 @@
1
- import type {
2
- AxisPosition,
3
- ColorType,
4
- ChartParams,
5
- ComputedDatumBase,
6
- ComputedDatumBaseValue,
7
- ComputedDatumBaseSeries,
8
- ComputedDatumBaseCategory } from '../../lib/core-types'
9
- import { getMinAndMax } from './commonUtils'
10
-
11
- // 取得最小及最大值 - datum格式陣列資料
12
- export function getMinAndMaxValue (data: (ComputedDatumBase & ComputedDatumBaseValue)[]): [number, number] {
13
- const arr = data
14
- .filter(d => d.value != null && d.visible != false)
15
- .map(d => d.value as number)
16
- return getMinAndMax(arr)
17
- }
18
-
19
- // 取得colorType顏色
20
- export function getColor (colorType: ColorType, fullChartParams: ChartParams) {
21
- const colors = fullChartParams.colors[fullChartParams.colorScheme]
22
- // 對應series資料中第1個顏色
23
- if (colorType === 'series') {
24
- return colors.series[0]
25
- }
26
- // 對應colorType設定的顏色
27
- // return colors[colorType] != null
28
- // ? colors[colorType]
29
- // : colors.primary
30
- return colorType == 'none'
31
- ? 'none'
32
- : colors[colorType] != undefined
33
- ? colors[colorType]
34
- : colors.primary // 如果比對不到
35
- }
36
-
37
- export function getSeriesValueColor () {
38
-
39
- }
40
-
41
- export function getCategoryValueColor ({ datum, colorType, fullChartParams }: { datum: ComputedDatumBaseCategory, colorType: ColorType, fullChartParams: ChartParams }) {
42
-
43
- }
44
-
45
- // // 取得Series顏色 @Q@ 待重構完後刪除
46
- // export function getSeriesColor (seriesIndex: number, fullChartParams: ChartParams) {
47
- // const colorIndex = seriesIndex < fullChartParams.colors[fullChartParams.colorScheme].series.length
48
- // ? seriesIndex
49
- // : seriesIndex % fullChartParams.colors[fullChartParams.colorScheme].series.length
50
- // return fullChartParams.colors[fullChartParams.colorScheme].series[colorIndex]
51
- // }
52
-
53
- // 取得Datum顏色 @Q@ 待重構完後刪除
54
- export function getDatumColor ({ datum, colorType, fullChartParams }: { datum: ComputedDatumBase, colorType: ColorType, fullChartParams: ChartParams }) {
55
- // 對應series資料中的顏色
56
- if (colorType === 'series') {
57
- if ((datum as unknown as ComputedDatumBaseSeries).color) {
58
- return (datum as unknown as ComputedDatumBaseSeries).color
59
- } else {
60
- // 非series類型的資料則回傳陣列中第1個顏色
61
- return fullChartParams.colors[fullChartParams.colorScheme].series[0]
62
- }
63
- }
64
- // 對應colorType設定的顏色
65
- return colorType == 'none'
66
- ? 'none'
67
- : fullChartParams.colors[fullChartParams.colorScheme][colorType] != undefined
68
- ? fullChartParams.colors[fullChartParams.colorScheme][colorType]
69
- : fullChartParams.colors[fullChartParams.colorScheme].primary
70
- }
71
-
72
- export function getClassName (pluginName: string, elementName: string, modifier?: string) {
73
- const modifierText = modifier ? `--${modifier}` : ''
74
- return `orbcharts-${pluginName}__${elementName}${modifierText}`
75
- }
76
-
77
- export function getUniID (pluginName: string, elementName: string) {
78
- const textLength = 5
79
- // 英文+數字
80
- const randomText: string = Math.random().toString(36).substr(2, textLength)
81
-
82
- return getClassName(pluginName, elementName, randomText)
83
- }
84
-
85
-
86
- export function calcAxesSize ({ xAxisPosition, yAxisPosition, width, height }: {
87
- xAxisPosition: AxisPosition
88
- yAxisPosition: AxisPosition
89
- width: number
90
- height: number
91
- }) {
92
- if ((xAxisPosition === 'bottom' || xAxisPosition === 'top') && (yAxisPosition === 'left' || yAxisPosition === 'right')) {
93
- return { width, height }
94
- } else if ((xAxisPosition === 'left' || xAxisPosition === 'right') && (yAxisPosition === 'bottom' || yAxisPosition === 'top')) {
95
- return {
96
- width: height,
97
- height: width
98
- }
99
- }
100
- }
101
-
1
+ import type {
2
+ AxisPosition,
3
+ ColorType,
4
+ ChartParams,
5
+ ComputedDatumBase,
6
+ ComputedDatumBaseValue,
7
+ ComputedDatumBaseSeries,
8
+ ComputedDatumBaseCategory } from '../../lib/core-types'
9
+ import { getMinAndMax } from './commonUtils'
10
+
11
+ // 取得最小及最大值 - datum格式陣列資料
12
+ export function getMinAndMaxValue (data: (ComputedDatumBase & ComputedDatumBaseValue)[]): [number, number] {
13
+ const arr = data
14
+ .filter(d => d.value != null && d.visible != false)
15
+ .map(d => d.value as number)
16
+ return getMinAndMax(arr)
17
+ }
18
+
19
+ // 取得colorType顏色
20
+ export function getColor (colorType: ColorType, fullChartParams: ChartParams) {
21
+ const colors = fullChartParams.colors[fullChartParams.colorScheme]
22
+ // 對應series資料中第1個顏色
23
+ if (colorType === 'series') {
24
+ return colors.series[0]
25
+ }
26
+ // 對應colorType設定的顏色
27
+ // return colors[colorType] != null
28
+ // ? colors[colorType]
29
+ // : colors.primary
30
+ return colorType == 'none'
31
+ ? 'none'
32
+ : colors[colorType] != undefined
33
+ ? colors[colorType]
34
+ : colors.primary // 如果比對不到
35
+ }
36
+
37
+ export function getSeriesValueColor () {
38
+
39
+ }
40
+
41
+ export function getCategoryValueColor ({ datum, colorType, fullChartParams }: { datum: ComputedDatumBaseCategory, colorType: ColorType, fullChartParams: ChartParams }) {
42
+
43
+ }
44
+
45
+ // // 取得Series顏色 @Q@ 待重構完後刪除
46
+ // export function getSeriesColor (seriesIndex: number, fullChartParams: ChartParams) {
47
+ // const colorIndex = seriesIndex < fullChartParams.colors[fullChartParams.colorScheme].series.length
48
+ // ? seriesIndex
49
+ // : seriesIndex % fullChartParams.colors[fullChartParams.colorScheme].series.length
50
+ // return fullChartParams.colors[fullChartParams.colorScheme].series[colorIndex]
51
+ // }
52
+
53
+ // 取得Datum顏色 @Q@ 待重構完後刪除
54
+ export function getDatumColor ({ datum, colorType, fullChartParams }: { datum: ComputedDatumBase, colorType: ColorType, fullChartParams: ChartParams }) {
55
+ // 對應series資料中的顏色
56
+ if (colorType === 'series') {
57
+ if ((datum as unknown as ComputedDatumBaseSeries).color) {
58
+ return (datum as unknown as ComputedDatumBaseSeries).color
59
+ } else {
60
+ // 非series類型的資料則回傳陣列中第1個顏色
61
+ return fullChartParams.colors[fullChartParams.colorScheme].series[0]
62
+ }
63
+ }
64
+ // 對應colorType設定的顏色
65
+ return colorType == 'none'
66
+ ? 'none'
67
+ : fullChartParams.colors[fullChartParams.colorScheme][colorType] != undefined
68
+ ? fullChartParams.colors[fullChartParams.colorScheme][colorType]
69
+ : fullChartParams.colors[fullChartParams.colorScheme].primary
70
+ }
71
+
72
+ export function getClassName (pluginName: string, elementName: string, modifier?: string) {
73
+ const modifierText = modifier ? `--${modifier}` : ''
74
+ return `orbcharts-${pluginName}__${elementName}${modifierText}`
75
+ }
76
+
77
+ export function getUniID (pluginName: string, elementName: string) {
78
+ const textLength = 5
79
+ // 英文+數字
80
+ const randomText: string = Math.random().toString(36).substr(2, textLength)
81
+
82
+ return getClassName(pluginName, elementName, randomText)
83
+ }
84
+
85
+
86
+ export function calcAxesSize ({ xAxisPosition, yAxisPosition, width, height }: {
87
+ xAxisPosition: AxisPosition
88
+ yAxisPosition: AxisPosition
89
+ width: number
90
+ height: number
91
+ }) {
92
+ if ((xAxisPosition === 'bottom' || xAxisPosition === 'top') && (yAxisPosition === 'left' || yAxisPosition === 'right')) {
93
+ return { width, height }
94
+ } else if ((xAxisPosition === 'left' || xAxisPosition === 'right') && (yAxisPosition === 'bottom' || yAxisPosition === 'top')) {
95
+ return {
96
+ width: height,
97
+ height: width
98
+ }
99
+ }
100
+ }
101
+
102
+ // export function getTicks (minValue: number, maxValue: number, defaultTicks: number | null) {
103
+ // let valueLength = maxValue - minValue
104
+ // if (defaultTicks === null) {
105
+ // if (valueLength <= 1) {
106
+ // return 1
107
+ // } else {
108
+ // // d3.js自動判斷
109
+ // return null
110
+ // }
111
+ // } else if (valueLength < defaultTicks) {
112
+ // return Math.ceil(valueLength)
113
+ // } else {
114
+ // return defaultTicks
115
+ // }
116
+ // }
@@ -1,14 +1,14 @@
1
- {
2
- "compilerOptions": {
3
- "outDir": "./dist/",
4
- "sourceMap": true,
5
- "noImplicitAny": true,
6
- "module": "esnext",
7
- "target": "es5",
8
- "jsx": "react",
9
- "allowJs": true,
10
- "moduleResolution": "node",
11
- "allowSyntheticDefaultImports" : true,
12
- "esModuleInterop" : true
13
- }
1
+ {
2
+ "compilerOptions": {
3
+ "outDir": "./dist/",
4
+ "sourceMap": true,
5
+ "noImplicitAny": true,
6
+ "module": "esnext",
7
+ "target": "es5",
8
+ "jsx": "react",
9
+ "allowJs": true,
10
+ "moduleResolution": "node",
11
+ "allowSyntheticDefaultImports" : true,
12
+ "esModuleInterop" : true
13
+ }
14
14
  }
package/tsconfig.json CHANGED
@@ -1,3 +1,3 @@
1
- {
2
- "extends": "./tsconfig.base.json"
1
+ {
2
+ "extends": "./tsconfig.base.json"
3
3
  }
package/vite.config.js CHANGED
@@ -1,23 +1,23 @@
1
- import { defineConfig } from 'vite'
2
- import dts from 'vite-plugin-dts'
3
-
4
- export default defineConfig(({ command, mode }) => {
5
- return {
6
- plugins: [
7
- dts({
8
- insertTypesEntry: true
9
- })
10
- ],
11
- compilerOptions: {
12
- composite: true
13
- },
14
- build: {
15
- lib: {
16
- entry: "src/index.ts",
17
- name: 'orbcharts-plugins-basic',
18
- formats: ["es", "umd"],
19
- fileName: format => `orbcharts-plugins-basic.${format}.js`
20
- },
21
- }
22
- }
1
+ import { defineConfig } from 'vite'
2
+ import dts from 'vite-plugin-dts'
3
+
4
+ export default defineConfig(({ command, mode }) => {
5
+ return {
6
+ plugins: [
7
+ dts({
8
+ insertTypesEntry: true
9
+ })
10
+ ],
11
+ compilerOptions: {
12
+ composite: true
13
+ },
14
+ build: {
15
+ lib: {
16
+ entry: "src/index.ts",
17
+ name: 'orbcharts-plugins-basic',
18
+ formats: ["es", "umd"],
19
+ fileName: format => `orbcharts-plugins-basic.${format}.js`
20
+ },
21
+ }
22
+ }
23
23
  })