@milaboratories/miplots4 1.0.151 → 1.0.152
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/dist/bubble/BubbleSettingsImpl.d.ts +9 -1
- package/dist/bubble/BubbleSettingsImpl.d.ts.map +1 -1
- package/dist/bubble/BubbleSettingsImpl.js +25 -16
- package/dist/bubble/BubbleSettingsImpl.js.map +1 -1
- package/dist/bubble/ChartRenderer.d.ts +15 -5
- package/dist/bubble/ChartRenderer.d.ts.map +1 -1
- package/dist/bubble/ChartRenderer.js +146 -146
- package/dist/bubble/ChartRenderer.js.map +1 -1
- package/dist/bubble/components/Chart.d.ts +5 -5
- package/dist/bubble/components/Chart.d.ts.map +1 -1
- package/dist/bubble/components/Chart.js +46 -46
- package/dist/bubble/components/Chart.js.map +1 -1
- package/dist/bubble/components/ChartsGroup.d.ts +4 -4
- package/dist/bubble/components/ChartsGroup.d.ts.map +1 -1
- package/dist/bubble/components/ChartsGroup.js.map +1 -1
- package/dist/bubble/getCellTooltip.d.ts +2 -2
- package/dist/bubble/getCellTooltip.d.ts.map +1 -1
- package/dist/bubble/getCellTooltip.js +17 -17
- package/dist/bubble/getCellTooltip.js.map +1 -1
- package/dist/bubble/getGroupedCellsData.d.ts +7 -29
- package/dist/bubble/getGroupedCellsData.d.ts.map +1 -1
- package/dist/bubble/getGroupedCellsData.js +49 -83
- package/dist/bubble/getGroupedCellsData.js.map +1 -1
- package/dist/bubble/index.d.ts +2 -2
- package/dist/bubble/index.d.ts.map +1 -1
- package/dist/bubble/index.js +54 -37
- package/dist/bubble/index.js.map +1 -1
- package/dist/bubble/utils/calculateCaptionTails.d.ts +2 -2
- package/dist/bubble/utils/calculateCaptionTails.d.ts.map +1 -1
- package/dist/bubble/utils/calculateCaptionTails.js.map +1 -1
- package/dist/heatmap/ChartRenderer.d.ts +7 -7
- package/dist/heatmap/ChartRenderer.d.ts.map +1 -1
- package/dist/heatmap/ChartRenderer.js +2 -2
- package/dist/heatmap/ChartRenderer.js.map +1 -1
- package/dist/heatmap/components/Annotations/Annotation.d.ts +4 -4
- package/dist/heatmap/components/Annotations/Annotation.d.ts.map +1 -1
- package/dist/heatmap/components/Annotations/Annotation.js.map +1 -1
- package/dist/heatmap/components/Annotations/AnnotationCellsCanvas.d.ts +2 -2
- package/dist/heatmap/components/Annotations/AnnotationCellsCanvas.d.ts.map +1 -1
- package/dist/heatmap/components/Annotations/AnnotationCellsCanvas.js.map +1 -1
- package/dist/heatmap/components/Annotations/AnnotationCellsSvg.d.ts +2 -2
- package/dist/heatmap/components/Annotations/AnnotationCellsSvg.d.ts.map +1 -1
- package/dist/heatmap/components/Annotations/AnnotationCellsSvg.js.map +1 -1
- package/dist/heatmap/components/Annotations/index.d.ts +5 -5
- package/dist/heatmap/components/Annotations/index.d.ts.map +1 -1
- package/dist/heatmap/components/Annotations/index.js.map +1 -1
- package/dist/heatmap/components/CanvasCells.d.ts +3 -3
- package/dist/heatmap/components/CanvasCells.d.ts.map +1 -1
- package/dist/heatmap/components/CanvasCells.js +18 -18
- package/dist/heatmap/components/CanvasCells.js.map +1 -1
- package/dist/heatmap/components/Chart.d.ts +6 -6
- package/dist/heatmap/components/Chart.d.ts.map +1 -1
- package/dist/heatmap/components/Chart.js +63 -63
- package/dist/heatmap/components/Chart.js.map +1 -1
- package/dist/heatmap/components/ChartsGroup.d.ts +3 -3
- package/dist/heatmap/components/ChartsGroup.d.ts.map +1 -1
- package/dist/heatmap/components/ChartsGroup.js.map +1 -1
- package/dist/heatmap/components/SvgCells.d.ts +3 -3
- package/dist/heatmap/components/SvgCells.d.ts.map +1 -1
- package/dist/heatmap/components/SvgCells.js +18 -18
- package/dist/heatmap/components/SvgCells.js.map +1 -1
- package/dist/heatmap/components/tooltipUtils.d.ts +5 -5
- package/dist/heatmap/components/tooltipUtils.d.ts.map +1 -1
- package/dist/heatmap/components/tooltipUtils.js +7 -7
- package/dist/heatmap/components/tooltipUtils.js.map +1 -1
- package/dist/heatmap/fillCellsData.d.ts +45 -0
- package/dist/heatmap/fillCellsData.d.ts.map +1 -0
- package/dist/heatmap/fillCellsData.js +244 -0
- package/dist/heatmap/fillCellsData.js.map +1 -0
- package/dist/heatmap/getCells.d.ts +5 -37
- package/dist/heatmap/getCells.d.ts.map +1 -1
- package/dist/heatmap/getCells.js +28 -214
- package/dist/heatmap/getCells.js.map +1 -1
- package/dist/heatmap/getDendrograms.d.ts +2 -2
- package/dist/heatmap/getDendrograms.d.ts.map +1 -1
- package/dist/heatmap/getDendrograms.js +19 -19
- package/dist/heatmap/getDendrograms.js.map +1 -1
- package/dist/heatmap/index.d.ts +2 -2
- package/dist/heatmap/index.d.ts.map +1 -1
- package/dist/heatmap/index.js +7 -7
- package/dist/heatmap/index.js.map +1 -1
- package/dist/heatmap/utils/calculateCaptionTails.d.ts +2 -2
- package/dist/heatmap/utils/calculateCaptionTails.d.ts.map +1 -1
- package/dist/heatmap/utils/calculateCaptionTails.js.map +1 -1
- package/dist/types/bubble.d.ts +92 -0
- package/dist/types/bubble.d.ts.map +1 -1
- package/dist/types/bubble.js +16 -5
- package/dist/types/bubble.js.map +1 -1
- package/dist/types/discrete.d.ts +24 -24
- package/dist/types/heatmap.d.ts +18 -18
- package/dist/utils/getFacetOrGroupKey.d.ts +2 -0
- package/dist/utils/getFacetOrGroupKey.d.ts.map +1 -0
- package/dist/utils/getFacetOrGroupKey.js +7 -0
- package/dist/utils/getFacetOrGroupKey.js.map +1 -0
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { BubbleSettings, ColumnName, FrameType, LegendPosition, NormalizationDirection, NormalizationMethod, SettingsInterface, TitlePosition } from '../types';
|
|
1
|
+
import { AggregationMethod, BubbleSettings, ColumnName, FrameType, LegendPosition, NormalizationDirection, NormalizationMethod, SettingsInterface, TitlePosition } from '../types';
|
|
2
2
|
export declare class BubbleSettingsImpl implements SettingsInterface {
|
|
3
3
|
readonly id: string;
|
|
4
4
|
readonly type = "bubble";
|
|
@@ -10,7 +10,9 @@ export declare class BubbleSettingsImpl implements SettingsInterface {
|
|
|
10
10
|
readonly valueColumnSize: ColumnName;
|
|
11
11
|
readonly valueColumnColor: ColumnName;
|
|
12
12
|
readonly xColumn: ColumnName;
|
|
13
|
+
readonly xGroupBy: ColumnName[];
|
|
13
14
|
readonly yColumn: ColumnName;
|
|
15
|
+
readonly yGroupBy: ColumnName[];
|
|
14
16
|
readonly facetBy: ColumnName[];
|
|
15
17
|
readonly normalization: {
|
|
16
18
|
direction: NormalizationDirection;
|
|
@@ -18,7 +20,13 @@ export declare class BubbleSettingsImpl implements SettingsInterface {
|
|
|
18
20
|
colorRange?: number[];
|
|
19
21
|
sizeRange?: number[];
|
|
20
22
|
} | null;
|
|
23
|
+
readonly aggregation: {
|
|
24
|
+
x: boolean;
|
|
25
|
+
y: boolean;
|
|
26
|
+
method: AggregationMethod;
|
|
27
|
+
};
|
|
21
28
|
readonly NAValueAs: number | null;
|
|
29
|
+
readonly keysOrder: Record<string, string[]>;
|
|
22
30
|
readonly chartSettings: {
|
|
23
31
|
readonly size: {
|
|
24
32
|
width: number | null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BubbleSettingsImpl.d.ts","sourceRoot":"","sources":["../../src/bubble/BubbleSettingsImpl.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACR,cAAc,EACd,UAAU,EACV,SAAS,EACT,cAAc,EACd,sBAAsB,EACtB,mBAAmB,EACnB,iBAAiB,EACjB,aAAa,EAChB,MAAM,UAAU,CAAC;AAGlB,qBAAa,kBAAmB,YAAW,iBAAiB;IACxD,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,IAAI,YAAY;IACzB,QAAQ,CAAC,aAAa,EAAE;QACpB,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,aAAa,EAAE,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;KAC9C,CAAC;IACF,QAAQ,CAAC,eAAe,EAAE,UAAU,CAAC;IACrC,QAAQ,CAAC,gBAAgB,EAAE,UAAU,CAAC;IACtC,QAAQ,CAAC,OAAO,EAAE,UAAU,CAAC;IAC7B,QAAQ,CAAC,OAAO,EAAE,UAAU,CAAC;IAC7B,QAAQ,CAAC,OAAO,EAAE,UAAU,EAAE,CAAC;IAC/B,QAAQ,CAAC,aAAa,EAAE;QACpB,SAAS,EAAE,sBAAsB,CAAC;QAClC,MAAM,EAAE,mBAAmB,CAAC;QAC5B,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;QACtB,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;KACxB,GAAG,IAAI,CAAC;IACT,QAAQ,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IAClC,QAAQ,CAAC,aAAa,EAAE;QACpB,QAAQ,CAAC,IAAI,EAAE;
|
|
1
|
+
{"version":3,"file":"BubbleSettingsImpl.d.ts","sourceRoot":"","sources":["../../src/bubble/BubbleSettingsImpl.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
var
|
|
2
|
-
var
|
|
3
|
-
var o = (a, l, e) =>
|
|
4
|
-
import { DEFAULT_WIDTH_SMALL as
|
|
1
|
+
var A = Object.defineProperty;
|
|
2
|
+
var f = (a, l, e) => l in a ? A(a, l, { enumerable: !0, configurable: !0, writable: !0, value: e }) : a[l] = e;
|
|
3
|
+
var o = (a, l, e) => f(a, typeof l != "symbol" ? l + "" : l, e);
|
|
4
|
+
import { DEFAULT_WIDTH_SMALL as s, DEFAULT_WIDTH as d, DEFAULT_HEIGHT_SMALL as S, DEFAULT_HEIGHT as b, BLACK as L } from "../constants.js";
|
|
5
5
|
import "../types/common.js";
|
|
6
6
|
import "../types/discrete.js";
|
|
7
7
|
import "../types/scatterplot.js";
|
|
8
8
|
import "../types/heatmap.js";
|
|
9
9
|
import "../types/dendro.js";
|
|
10
10
|
import "../types/histogram.js";
|
|
11
|
-
import { BubblesSettingsSchema as
|
|
12
|
-
import
|
|
13
|
-
class
|
|
11
|
+
import { BubblesSettingsSchema as B } from "../types/bubble.js";
|
|
12
|
+
import w from "../node_modules/lodash/lodash.js";
|
|
13
|
+
class F {
|
|
14
14
|
constructor(l) {
|
|
15
15
|
o(this, "id");
|
|
16
16
|
o(this, "type", "bubble");
|
|
@@ -18,17 +18,21 @@ class R {
|
|
|
18
18
|
o(this, "valueColumnSize");
|
|
19
19
|
o(this, "valueColumnColor");
|
|
20
20
|
o(this, "xColumn");
|
|
21
|
+
o(this, "xGroupBy");
|
|
21
22
|
o(this, "yColumn");
|
|
23
|
+
o(this, "yGroupBy");
|
|
22
24
|
o(this, "facetBy");
|
|
23
25
|
o(this, "normalization");
|
|
26
|
+
o(this, "aggregation");
|
|
24
27
|
o(this, "NAValueAs");
|
|
28
|
+
o(this, "keysOrder");
|
|
25
29
|
o(this, "chartSettings");
|
|
26
30
|
o(this, "aes");
|
|
27
|
-
var i,
|
|
28
|
-
|
|
29
|
-
const e = ((i = l.size) == null ? void 0 : i.cellSize) ?? null,
|
|
31
|
+
var i, r, u, t, m, h, y, c, p, C;
|
|
32
|
+
B.parse(l), this.id = w.uniqueId("settings"), this.facetSettings = { titlePosition: "left", ...l.facetSettings }, this.facetBy = l.facetBy ?? [], this.valueColumnSize = l.valueSize, this.valueColumnColor = l.valueColor, this.xColumn = l.xColumn, this.xGroupBy = l.xGroupBy ?? [], this.yColumn = l.yColumn, this.yGroupBy = l.yGroupBy ?? [], this.NAValueAs = l.NAValueAs ?? null, this.keysOrder = l.keysOrder ?? {}, this.normalization = l.normalization ?? null;
|
|
33
|
+
const e = ((i = l.size) == null ? void 0 : i.cellSize) ?? null, x = e ? null : ((r = l == null ? void 0 : l.size) == null ? void 0 : r.width) ?? (this.facetBy.length ? s : d), n = e ? null : ((u = l == null ? void 0 : l.size) == null ? void 0 : u.height) ?? (this.facetBy.length ? S : b);
|
|
30
34
|
this.chartSettings = {
|
|
31
|
-
size: { width:
|
|
35
|
+
size: { width: x, height: n, cellSize: e },
|
|
32
36
|
title: {
|
|
33
37
|
position: "center",
|
|
34
38
|
show: !0,
|
|
@@ -65,16 +69,21 @@ class R {
|
|
|
65
69
|
show: !0,
|
|
66
70
|
...l.tooltips
|
|
67
71
|
}
|
|
72
|
+
}, this.aggregation = {
|
|
73
|
+
x: !1,
|
|
74
|
+
y: !1,
|
|
75
|
+
method: "min",
|
|
76
|
+
...l.aggregation
|
|
68
77
|
}, this.aes = {
|
|
69
78
|
minRadius: ((h = l.aes) == null ? void 0 : h.minRadius) ?? 3,
|
|
70
|
-
maxRadius: ((
|
|
71
|
-
colorsList: ((
|
|
72
|
-
cellStrokeColor: ((p = l.aes) == null ? void 0 : p.cellStrokeColor) ??
|
|
73
|
-
emptyCellColor: ((
|
|
79
|
+
maxRadius: ((y = l.aes) == null ? void 0 : y.maxRadius) ?? 20,
|
|
80
|
+
colorsList: ((c = l.aes) == null ? void 0 : c.colorsList) ?? ["black", "white", "red"],
|
|
81
|
+
cellStrokeColor: ((p = l.aes) == null ? void 0 : p.cellStrokeColor) ?? L,
|
|
82
|
+
emptyCellColor: ((C = l.aes) == null ? void 0 : C.emptyCellColor) ?? "white"
|
|
74
83
|
};
|
|
75
84
|
}
|
|
76
85
|
}
|
|
77
86
|
export {
|
|
78
|
-
|
|
87
|
+
F as BubbleSettingsImpl
|
|
79
88
|
};
|
|
80
89
|
//# sourceMappingURL=BubbleSettingsImpl.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BubbleSettingsImpl.js","sources":["../../src/bubble/BubbleSettingsImpl.ts"],"sourcesContent":["import {BLACK, DEFAULT_HEIGHT, DEFAULT_HEIGHT_SMALL, DEFAULT_WIDTH, DEFAULT_WIDTH_SMALL} from '../constants';\nimport {BubblesSettingsSchema} from '../types';\nimport type {\n BubbleSettings,\n ColumnName,\n FrameType,\n LegendPosition,\n NormalizationDirection,\n NormalizationMethod,\n SettingsInterface,\n TitlePosition,\n} from '../types';\nimport lodash from 'lodash';\n\nexport class BubbleSettingsImpl implements SettingsInterface {\n readonly id: string;\n readonly type = 'bubble';\n readonly facetSettings: {\n nRows?: number;\n nCols?: number;\n titlePosition: 'left' | 'center' | 'right';\n };\n readonly valueColumnSize: ColumnName;\n readonly valueColumnColor: ColumnName;\n readonly xColumn: ColumnName;\n readonly yColumn: ColumnName;\n readonly facetBy: ColumnName[];\n readonly normalization: {\n direction: NormalizationDirection;\n method: NormalizationMethod;\n colorRange?: number[];\n sizeRange?: number[];\n } | null;\n readonly NAValueAs: number | null;\n readonly chartSettings: {\n readonly size: {width: number | null; height: number | null, cellSize: number | null};\n readonly title: {name: string; show: boolean; position: TitlePosition};\n readonly yAxis: {\n title: string;\n showTicks: boolean;\n showTitle: boolean;\n showAxisLabels: boolean;\n position: 'left' | 'right';\n axisLabelsAngle: 0 | 45 | 90;\n sorting: 'asc' | 'desc';\n };\n readonly xAxis: {\n title: string;\n showTicks: boolean;\n showTitle: boolean;\n showAxisLabels: boolean;\n position: 'bottom' | 'top';\n axisLabelsAngle: 0 | 45 | 90;\n sorting: 'asc' | 'desc';\n };\n readonly frame: {type: FrameType};\n readonly legend: {show: boolean; position: LegendPosition};\n readonly tooltips: {show: boolean; content?: ColumnName[]};\n };\n readonly aes: {\n minRadius: number;\n maxRadius: number;\n colorsList: string[];\n cellStrokeColor: string;\n emptyCellColor: string;\n };\n\n constructor(settings: BubbleSettings) {\n BubblesSettingsSchema.parse(settings);\n this.id = lodash.uniqueId('settings');\n this.facetSettings = {titlePosition: 'left', ...settings.facetSettings};\n this.facetBy = settings.facetBy ?? [];\n this.valueColumnSize = settings.valueSize;\n this.valueColumnColor = settings.valueColor;\n this.xColumn = settings.xColumn;\n this.yColumn = settings.yColumn;\n this.NAValueAs = settings.NAValueAs ?? null;\n this.normalization = settings.normalization ?? null;\n\n const cellSize = settings.size?.cellSize ?? null;\n const width = cellSize ? null : settings?.size?.width ?? (this.facetBy.length ? DEFAULT_WIDTH_SMALL : DEFAULT_WIDTH);\n const height = cellSize ? null : settings?.size?.height ?? (this.facetBy.length ? DEFAULT_HEIGHT_SMALL : DEFAULT_HEIGHT);\n this.chartSettings = {\n size: {width, height, cellSize},\n title: {\n position: 'center',\n show: true,\n ...settings.title,\n name: settings.title?.name ?? 'Chart',\n },\n yAxis: {\n title: settings.yColumn.label ?? settings.yColumn.value,\n showTicks: true,\n showTitle: true,\n showAxisLabels: true,\n position: 'left',\n axisLabelsAngle: 90,\n sorting: 'asc',\n ...settings.yAxis,\n },\n xAxis: {\n title: settings.xColumn.label ?? settings.xColumn.value,\n showTicks: true,\n showTitle: true,\n showAxisLabels: true,\n position: 'bottom',\n axisLabelsAngle: 90,\n sorting: 'asc',\n ...settings.xAxis,\n },\n frame: {type: settings.frame?.type ?? 'full'},\n legend: {\n show: true,\n position: 'right',\n ...settings.legend,\n },\n tooltips: {\n show: true,\n ...settings.tooltips,\n },\n };\n\n this.aes = {\n minRadius: settings.aes?.minRadius ?? 3,\n maxRadius: settings.aes?.maxRadius ?? 20,\n colorsList: settings.aes?.colorsList ?? ['black', 'white', 'red'],\n cellStrokeColor: settings.aes?.cellStrokeColor ?? BLACK,\n emptyCellColor: settings.aes?.emptyCellColor ?? 'white',\n };\n }\n}\n"],"names":["BubbleSettingsImpl","settings","__publicField","BubblesSettingsSchema","lodash","cellSize","_a","width","_b","DEFAULT_WIDTH_SMALL","DEFAULT_WIDTH","height","_c","DEFAULT_HEIGHT_SMALL","DEFAULT_HEIGHT","_d","_e","_f","_g","_h","_i","BLACK","_j"],"mappings":";;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"BubbleSettingsImpl.js","sources":["../../src/bubble/BubbleSettingsImpl.ts"],"sourcesContent":["import { BLACK, DEFAULT_HEIGHT, DEFAULT_HEIGHT_SMALL, DEFAULT_WIDTH, DEFAULT_WIDTH_SMALL } from '../constants';\nimport { BubblesSettingsSchema } from '../types';\nimport type {\n AggregationMethod,\n BubbleSettings,\n ColumnName,\n FrameType,\n LegendPosition,\n NormalizationDirection,\n NormalizationMethod,\n SettingsInterface,\n TitlePosition,\n} from '../types';\nimport lodash from 'lodash';\n\nexport class BubbleSettingsImpl implements SettingsInterface {\n readonly id: string;\n readonly type = 'bubble';\n readonly facetSettings: {\n nRows?: number;\n nCols?: number;\n titlePosition: 'left' | 'center' | 'right';\n };\n readonly valueColumnSize: ColumnName;\n readonly valueColumnColor: ColumnName;\n readonly xColumn: ColumnName;\n readonly xGroupBy: ColumnName[];\n readonly yColumn: ColumnName;\n readonly yGroupBy: ColumnName[];\n readonly facetBy: ColumnName[];\n readonly normalization: {\n direction: NormalizationDirection;\n method: NormalizationMethod;\n colorRange?: number[];\n sizeRange?: number[];\n } | null;\n readonly aggregation: {\n x: boolean;\n y: boolean;\n method: AggregationMethod;\n };\n readonly NAValueAs: number | null;\n readonly keysOrder: Record<string, string[]>;\n readonly chartSettings: {\n readonly size: { width: number | null; height: number | null, cellSize: number | null };\n readonly title: { name: string; show: boolean; position: TitlePosition };\n readonly yAxis: {\n title: string;\n showTicks: boolean;\n showTitle: boolean;\n showAxisLabels: boolean;\n position: 'left' | 'right';\n axisLabelsAngle: 0 | 45 | 90;\n sorting: 'asc' | 'desc';\n };\n readonly xAxis: {\n title: string;\n showTicks: boolean;\n showTitle: boolean;\n showAxisLabels: boolean;\n position: 'bottom' | 'top';\n axisLabelsAngle: 0 | 45 | 90;\n sorting: 'asc' | 'desc';\n };\n readonly frame: { type: FrameType };\n readonly legend: { show: boolean; position: LegendPosition };\n readonly tooltips: { show: boolean; content?: ColumnName[] };\n };\n readonly aes: {\n minRadius: number;\n maxRadius: number;\n colorsList: string[];\n cellStrokeColor: string;\n emptyCellColor: string;\n };\n\n constructor(settings: BubbleSettings) {\n BubblesSettingsSchema.parse(settings);\n this.id = lodash.uniqueId('settings');\n this.facetSettings = { titlePosition: 'left', ...settings.facetSettings };\n this.facetBy = settings.facetBy ?? [];\n this.valueColumnSize = settings.valueSize;\n this.valueColumnColor = settings.valueColor;\n this.xColumn = settings.xColumn;\n this.xGroupBy = settings.xGroupBy ?? [];\n this.yColumn = settings.yColumn;\n this.yGroupBy = settings.yGroupBy ?? [];\n this.NAValueAs = settings.NAValueAs ?? null;\n this.keysOrder = settings.keysOrder ?? {};\n this.normalization = settings.normalization ?? null;\n\n const cellSize = settings.size?.cellSize ?? null;\n const width = cellSize ? null : settings?.size?.width ?? (this.facetBy.length ? DEFAULT_WIDTH_SMALL : DEFAULT_WIDTH);\n const height = cellSize ? null : settings?.size?.height ?? (this.facetBy.length ? DEFAULT_HEIGHT_SMALL : DEFAULT_HEIGHT);\n this.chartSettings = {\n size: { width, height, cellSize },\n title: {\n position: 'center',\n show: true,\n ...settings.title,\n name: settings.title?.name ?? 'Chart',\n },\n yAxis: {\n title: settings.yColumn.label ?? settings.yColumn.value,\n showTicks: true,\n showTitle: true,\n showAxisLabels: true,\n position: 'left',\n axisLabelsAngle: 90,\n sorting: 'asc',\n ...settings.yAxis,\n },\n xAxis: {\n title: settings.xColumn.label ?? settings.xColumn.value,\n showTicks: true,\n showTitle: true,\n showAxisLabels: true,\n position: 'bottom',\n axisLabelsAngle: 90,\n sorting: 'asc',\n ...settings.xAxis,\n },\n frame: { type: settings.frame?.type ?? 'full' },\n legend: {\n show: true,\n position: 'right',\n ...settings.legend,\n },\n tooltips: {\n show: true,\n ...settings.tooltips,\n },\n };\n\n this.aggregation = {\n x: false,\n y: false,\n method: 'min',\n ...settings.aggregation\n };\n\n this.aes = {\n minRadius: settings.aes?.minRadius ?? 3,\n maxRadius: settings.aes?.maxRadius ?? 20,\n colorsList: settings.aes?.colorsList ?? ['black', 'white', 'red'],\n cellStrokeColor: settings.aes?.cellStrokeColor ?? BLACK,\n emptyCellColor: settings.aes?.emptyCellColor ?? 'white',\n };\n }\n}\n"],"names":["BubbleSettingsImpl","settings","__publicField","BubblesSettingsSchema","lodash","cellSize","_a","width","_b","DEFAULT_WIDTH_SMALL","DEFAULT_WIDTH","height","_c","DEFAULT_HEIGHT_SMALL","DEFAULT_HEIGHT","_d","_e","_f","_g","_h","_i","BLACK","_j"],"mappings":"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"}
|
|
@@ -6,7 +6,7 @@ import { DataFrame } from '../DataFrame';
|
|
|
6
6
|
import { ColumnName } from '../types';
|
|
7
7
|
import { BubbleSettingsImpl } from './BubbleSettingsImpl';
|
|
8
8
|
import { CaptionsSizes, ChartDimensionsData, ChartScales, ChartSizes, LabelAngles, Margins } from './components/types';
|
|
9
|
-
import {
|
|
9
|
+
import { CellBubble, GroupedCellsBubble } from './getGroupedCellsData';
|
|
10
10
|
declare class ChartRenderer {
|
|
11
11
|
reactRoot: Root | null;
|
|
12
12
|
parentNode: HTMLElement | null;
|
|
@@ -31,12 +31,22 @@ declare class ChartRenderer {
|
|
|
31
31
|
init(node: HTMLElement): void;
|
|
32
32
|
updateMargins(title: BubbleSettingsImpl['chartSettings']['title']): void;
|
|
33
33
|
updateLegendSize(legend: BubbleSettingsImpl['chartSettings']['legend'], columnValueColor: ColumnName, columnValueSize: ColumnName, facetKeys: string[]): void;
|
|
34
|
-
updateCaptionsSize(groupedCells:
|
|
34
|
+
updateCaptionsSize(groupedCells: GroupedCellsBubble, xAxis: BubbleSettingsImpl['chartSettings']['xAxis'], yAxis: BubbleSettingsImpl['chartSettings']['yAxis']): void;
|
|
35
35
|
updateChartDimensions(facetKeys: string[], facetSettings: BubbleSettingsImpl['facetSettings'], xAxis: BubbleSettingsImpl['chartSettings']['xAxis'], yAxis: BubbleSettingsImpl['chartSettings']['yAxis']): void;
|
|
36
|
-
updateChartsSizes(groupedCellsData:
|
|
37
|
-
updateScales(groupedCells:
|
|
36
|
+
updateChartsSizes(groupedCellsData: GroupedCellsBubble, size: BubbleSettingsImpl['chartSettings']['size']): void;
|
|
37
|
+
updateScales(groupedCells: GroupedCellsBubble, size: BubbleSettingsImpl['chartSettings']['size'], xAxis: BubbleSettingsImpl['chartSettings']['xAxis'], yAxis: BubbleSettingsImpl['chartSettings']['yAxis'], customOrder: {
|
|
38
|
+
x: boolean;
|
|
39
|
+
y: boolean;
|
|
40
|
+
xGroup: boolean;
|
|
41
|
+
yGroup: boolean;
|
|
42
|
+
}): void;
|
|
38
43
|
updateAesScale(aes: BubbleSettingsImpl['aes'], valueExtentSize: [number, number], valueExtentColor: [number, number], normalization: BubbleSettingsImpl['normalization']): void;
|
|
39
|
-
render(dataFrame: DataFrame, settingsId: string, chartSettings: BubbleSettingsImpl['chartSettings'], facetSettings: BubbleSettingsImpl['facetSettings'], groupedCellsData:
|
|
44
|
+
render(dataFrame: DataFrame, settingsId: string, chartSettings: BubbleSettingsImpl['chartSettings'], facetSettings: BubbleSettingsImpl['facetSettings'], groupedCellsData: GroupedCellsBubble, valueColumnColor: ColumnName, valueColumnSize: ColumnName, normalization: BubbleSettingsImpl['normalization'], aes: BubbleSettingsImpl['aes'], getCellTooltip: (cell: CellBubble) => string[], onTooltipHintSwitch: (v: boolean) => void, customOrder: {
|
|
45
|
+
x: boolean;
|
|
46
|
+
y: boolean;
|
|
47
|
+
xGroup: boolean;
|
|
48
|
+
yGroup: boolean;
|
|
49
|
+
}): void;
|
|
40
50
|
renderError(message: string): void;
|
|
41
51
|
}
|
|
42
52
|
export default ChartRenderer;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChartRenderer.d.ts","sourceRoot":"","sources":["../../src/bubble/ChartRenderer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAExD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,OAAO,CAAC;AAC1C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAG7C,OAAO,KAAK,EAAE,UAAU,EAAc,MAAM,iBAAiB,CAAC;AAG9D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,KAAK,EAAE,UAAU,EAAa,MAAM,UAAU,CAAC;AAKtD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAE/D,OAAO,KAAK,EACR,aAAa,EACb,mBAAmB,EAAE,WAAW,EAAE,UAAU,EAC5C,WAAW,EACX,OAAO,EACV,MAAM,oBAAoB,CAAC;AAE5B,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"ChartRenderer.d.ts","sourceRoot":"","sources":["../../src/bubble/ChartRenderer.tsx"],"names":[],"mappings":"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"}
|