@orbcharts/plugins-basic 3.0.0-beta.10 → 3.0.0-beta.12

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 (99) hide show
  1. package/LICENSE +200 -200
  2. package/dist/orbcharts-plugins-basic.es.js +179 -178
  3. package/dist/orbcharts-plugins-basic.umd.js +28 -28
  4. package/lib/core-types.ts +7 -7
  5. package/lib/core.ts +6 -6
  6. package/lib/plugins-basic-types.ts +6 -6
  7. package/package.json +44 -44
  8. package/src/base/BaseBars.ts +765 -765
  9. package/src/base/BaseBarsTriangle.ts +676 -676
  10. package/src/base/BaseDots.ts +464 -464
  11. package/src/base/BaseGroupAxis.ts +679 -679
  12. package/src/base/BaseLegend.ts +684 -684
  13. package/src/base/BaseLineAreas.ts +629 -629
  14. package/src/base/BaseLines.ts +706 -706
  15. package/src/base/BaseStackedBar.ts +782 -782
  16. package/src/base/BaseTooltip.ts +385 -385
  17. package/src/base/BaseValueAxis.ts +583 -583
  18. package/src/base/types.ts +2 -2
  19. package/src/const.ts +30 -30
  20. package/src/grid/defaults.ts +246 -246
  21. package/src/grid/gridObservables.ts +554 -554
  22. package/src/grid/index.ts +16 -16
  23. package/src/grid/plugins/Bars.ts +69 -69
  24. package/src/grid/plugins/BarsPN.ts +66 -66
  25. package/src/grid/plugins/BarsTriangle.ts +73 -73
  26. package/src/grid/plugins/Dots.ts +68 -68
  27. package/src/grid/plugins/GridLegend.ts +107 -107
  28. package/src/grid/plugins/GridTooltip.ts +66 -66
  29. package/src/grid/plugins/GridZoom.ts +218 -218
  30. package/src/grid/plugins/GroupAux.ts +1103 -1103
  31. package/src/grid/plugins/GroupAxis.ts +97 -97
  32. package/src/grid/plugins/LineAreas.ts +65 -65
  33. package/src/grid/plugins/Lines.ts +59 -59
  34. package/src/grid/plugins/StackedBar.ts +64 -64
  35. package/src/grid/plugins/StackedValueAxis.ts +96 -96
  36. package/src/grid/plugins/ValueAxis.ts +94 -94
  37. package/src/index.ts +6 -6
  38. package/src/multiGrid/defaults.ts +224 -224
  39. package/src/multiGrid/index.ts +14 -14
  40. package/src/multiGrid/multiGridObservables.ts +49 -49
  41. package/src/multiGrid/plugins/MultiBars.ts +108 -108
  42. package/src/multiGrid/plugins/MultiBarsTriangle.ts +114 -114
  43. package/src/multiGrid/plugins/MultiDots.ts +102 -102
  44. package/src/multiGrid/plugins/MultiGridLegend.ts +159 -159
  45. package/src/multiGrid/plugins/MultiGridTooltip.ts +66 -66
  46. package/src/multiGrid/plugins/MultiGroupAxis.ts +137 -137
  47. package/src/multiGrid/plugins/MultiLineAreas.ts +107 -107
  48. package/src/multiGrid/plugins/MultiLines.ts +101 -101
  49. package/src/multiGrid/plugins/MultiStackedBar.ts +106 -106
  50. package/src/multiGrid/plugins/MultiStackedValueAxis.ts +134 -134
  51. package/src/multiGrid/plugins/MultiValueAxis.ts +134 -134
  52. package/src/multiGrid/plugins/OverlappingStackedValueAxes.ts +299 -299
  53. package/src/multiGrid/plugins/OverlappingValueAxes.ts +300 -300
  54. package/src/multiValue/defaults.ts +166 -166
  55. package/src/multiValue/index.ts +8 -8
  56. package/src/multiValue/multiValueObservables.ts +297 -297
  57. package/src/multiValue/plugins/MultiValueLegend.ts +107 -107
  58. package/src/multiValue/plugins/MultiValueTooltip.ts +66 -66
  59. package/src/multiValue/plugins/Scatter.ts +426 -426
  60. package/src/multiValue/plugins/ScatterBubbles.ts +554 -554
  61. package/src/multiValue/plugins/XYAux.ts +681 -681
  62. package/src/multiValue/plugins/XYAxes.ts +684 -684
  63. package/src/multiValue/plugins/XYZoom.ts +299 -299
  64. package/src/noneData/defaults.ts +102 -102
  65. package/src/noneData/index.ts +3 -3
  66. package/src/noneData/plugins/Container.ts +27 -27
  67. package/src/noneData/plugins/Tooltip.ts +373 -373
  68. package/src/relationship/defaults.ts +196 -195
  69. package/src/relationship/index.ts +5 -5
  70. package/src/relationship/plugins/ForceDirected.ts +1168 -1166
  71. package/src/relationship/plugins/ForceDirectedBubbles.ts +1395 -1390
  72. package/src/relationship/plugins/RelationshipLegend.ts +100 -100
  73. package/src/relationship/plugins/RelationshipTooltip.ts +66 -66
  74. package/src/relationship/relationshipObservables.ts +49 -49
  75. package/src/series/defaults.ts +207 -206
  76. package/src/series/index.ts +9 -9
  77. package/src/series/plugins/Bubbles.ts +606 -606
  78. package/src/series/plugins/Pie.ts +623 -623
  79. package/src/series/plugins/PieEventTexts.ts +284 -284
  80. package/src/series/plugins/PieLabels.ts +640 -640
  81. package/src/series/plugins/Rose.ts +516 -516
  82. package/src/series/plugins/RoseLabels.ts +600 -600
  83. package/src/series/plugins/SeriesLegend.ts +107 -107
  84. package/src/series/plugins/SeriesTooltip.ts +66 -66
  85. package/src/series/seriesObservables.ts +145 -145
  86. package/src/series/seriesUtils.ts +51 -51
  87. package/src/tree/defaults.ts +78 -78
  88. package/src/tree/index.ts +4 -4
  89. package/src/tree/plugins/TreeLegend.ts +100 -100
  90. package/src/tree/plugins/TreeMap.ts +333 -333
  91. package/src/tree/plugins/TreeTooltip.ts +66 -66
  92. package/src/utils/commonUtils.ts +21 -21
  93. package/src/utils/d3Graphics.ts +174 -174
  94. package/src/utils/d3Utils.ts +74 -74
  95. package/src/utils/observables.ts +14 -14
  96. package/src/utils/orbchartsUtils.ts +115 -115
  97. package/tsconfig.base.json +13 -13
  98. package/tsconfig.json +2 -2
  99. 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,116 +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 { getMinMax } from './commonUtils'
10
-
11
- // 取得最小及最大值 - datum格式陣列資料
12
- export function getMinMaxValue (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 getMinMax(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 === 'label') {
24
- return colors.label[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 === 'label') {
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].label[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
- // }
1
+ import type {
2
+ AxisPosition,
3
+ ColorType,
4
+ ChartParams,
5
+ ComputedDatumBase,
6
+ ComputedDatumBaseValue,
7
+ ComputedDatumBaseSeries,
8
+ ComputedDatumBaseCategory } from '../../lib/core-types'
9
+ import { getMinMax } from './commonUtils'
10
+
11
+ // 取得最小及最大值 - datum格式陣列資料
12
+ export function getMinMaxValue (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 getMinMax(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 === 'label') {
24
+ return colors.label[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 === 'label') {
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].label[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
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
  })