mdt-charts 1.29.0 → 1.29.1
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/lib/config/config.d.ts +167 -177
- package/lib/designer/designerConfig.d.ts +59 -62
- package/lib/engine/block/block.d.ts +16 -22
- package/lib/engine/block/block.js +51 -51
- package/lib/engine/block/blockHelper.d.ts +6 -6
- package/lib/engine/block/blockHelper.js +16 -16
- package/lib/engine/block/blockHtml.d.ts +8 -8
- package/lib/engine/block/blockHtml.js +15 -15
- package/lib/engine/block/blockSvg.d.ts +20 -20
- package/lib/engine/block/blockSvg.js +66 -65
- package/lib/engine/block/defs/LinearGradientDef.d.ts +2 -2
- package/lib/engine/block/defs/LinearGradientDef.js +27 -27
- package/lib/engine/block/defs/hatchPattern.d.ts +4 -4
- package/lib/engine/block/defs/hatchPattern.js +9 -9
- package/lib/engine/colorReader/colorReader.d.ts +5 -5
- package/lib/engine/colorReader/colorReader.js +18 -18
- package/lib/engine/contentManager/contentManager.d.ts +7 -6
- package/lib/engine/contentManager/contentManager.js +15 -15
- package/lib/engine/contentManager/contentManagerFactory.d.ts +7 -7
- package/lib/engine/contentManager/contentManagerFactory.js +12 -12
- package/lib/engine/elementHighlighter/elementHighlighter.d.ts +22 -70
- package/lib/engine/elementHighlighter/elementHighlighter.js +181 -230
- package/lib/engine/elementHighlighter/selectHighlighter.d.ts +4 -29
- package/lib/engine/elementHighlighter/selectHighlighter.js +87 -189
- package/lib/engine/engine.d.ts +17 -17
- package/lib/engine/engine.js +62 -87
- package/lib/engine/features/aggregator/aggregator.d.ts +17 -24
- package/lib/engine/features/aggregator/aggregator.js +102 -113
- package/lib/engine/features/axis/axis.d.ts +9 -22
- package/lib/engine/features/axis/axis.js +150 -159
- package/lib/engine/features/axis/axisDomHelper.d.ts +2 -7
- package/lib/engine/features/axis/axisDomHelper.js +20 -19
- package/lib/engine/features/axis/axisHelper.d.ts +5 -9
- package/lib/engine/features/axis/axisHelper.js +33 -28
- package/lib/engine/features/axis/axisLabelDomHelper.d.ts +11 -26
- package/lib/engine/features/axis/axisLabelDomHelper.js +152 -156
- package/lib/engine/features/axis/axisLabelsEventManager.d.ts +2 -2
- package/lib/engine/features/axis/axisLabelsEventManager.js +32 -32
- package/lib/engine/features/embeddedLabels/embeddedLabels.d.ts +16 -51
- package/lib/engine/features/embeddedLabels/embeddedLabels.js +134 -234
- package/lib/engine/features/embeddedLabels/embeddedLabelsDomHelper.d.ts +2 -13
- package/lib/engine/features/embeddedLabels/embeddedLabelsDomHelper.js +23 -20
- package/lib/engine/features/embeddedLabels/embeddedLabelsHelper.d.ts +15 -32
- package/lib/engine/features/embeddedLabels/embeddedLabelsHelper.js +63 -56
- package/lib/engine/features/gridLine/gidLineHelper.d.ts +7 -13
- package/lib/engine/features/gridLine/gidLineHelper.js +49 -42
- package/lib/engine/features/gridLine/gridLine.d.ts +5 -19
- package/lib/engine/features/gridLine/gridLine.js +36 -35
- package/lib/engine/features/legend/legend.d.ts +28 -38
- package/lib/engine/features/legend/legend.js +92 -118
- package/lib/engine/features/legend/legendDomHelper.d.ts +6 -13
- package/lib/engine/features/legend/legendDomHelper.js +62 -63
- package/lib/engine/features/legend/legendEventsManager.d.ts +8 -13
- package/lib/engine/features/legend/legendEventsManager.js +47 -48
- package/lib/engine/features/legend/legendHelper.d.ts +14 -39
- package/lib/engine/features/legend/legendHelper.js +92 -98
- package/lib/engine/features/legend/legendHelperService.d.ts +6 -13
- package/lib/engine/features/legend/legendHelperService.js +25 -24
- package/lib/engine/features/legend/legendMarkerCreator.d.ts +9 -18
- package/lib/engine/features/legend/legendMarkerCreator.js +76 -79
- package/lib/engine/features/legend/legendWidthCalculator.d.ts +7 -7
- package/lib/engine/features/legend/legendWidthCalculator.js +122 -126
- package/lib/engine/features/markDots/markDot.d.ts +15 -42
- package/lib/engine/features/markDots/markDot.js +70 -101
- package/lib/engine/features/markDots/markDotsHelper.d.ts +1 -8
- package/lib/engine/features/markDots/markDotsHelper.js +12 -13
- package/lib/engine/features/recordOverflowAlert/recordOverflowAlertCore.d.ts +5 -23
- package/lib/engine/features/recordOverflowAlert/recordOverflowAlertCore.js +34 -42
- package/lib/engine/features/scale/scale.d.ts +12 -17
- package/lib/engine/features/scale/scale.js +69 -76
- package/lib/engine/features/tipBox/tipBox.d.ts +5 -9
- package/lib/engine/features/tipBox/tipBox.js +24 -24
- package/lib/engine/features/tipBox/tipBoxHelper.d.ts +9 -16
- package/lib/engine/features/tipBox/tipBoxHelper.js +45 -60
- package/lib/engine/features/title/title.d.ts +6 -6
- package/lib/engine/features/title/title.js +35 -34
- package/lib/engine/features/tolltip/newTooltip/newTooltip.d.ts +11 -15
- package/lib/engine/features/tolltip/newTooltip/newTooltip.js +21 -21
- package/lib/engine/features/tolltip/newTooltip/newTooltipService.d.ts +8 -13
- package/lib/engine/features/tolltip/newTooltip/newTooltipService.js +23 -26
- package/lib/engine/features/tolltip/tooltip.d.ts +11 -17
- package/lib/engine/features/tolltip/tooltip.js +142 -296
- package/lib/engine/features/tolltip/tooltipComponentsManager.d.ts +10 -21
- package/lib/engine/features/tolltip/tooltipComponentsManager.js +114 -113
- package/lib/engine/features/tolltip/tooltipDomHelper.d.ts +21 -43
- package/lib/engine/features/tolltip/tooltipDomHelper.js +120 -144
- package/lib/engine/features/tolltip/tooltipHelper.d.ts +9 -39
- package/lib/engine/features/tolltip/tooltipHelper.js +91 -114
- package/lib/engine/features/valueLabels/valueLabels.d.ts +38 -58
- package/lib/engine/features/valueLabels/valueLabels.js +169 -205
- package/lib/engine/features/valueLabels/valueLabelsHelper.d.ts +1 -7
- package/lib/engine/features/valueLabels/valueLabelsHelper.js +18 -23
- package/lib/engine/features/valueLabelsCollision/valueLabelsCollision.d.ts +15 -18
- package/lib/engine/features/valueLabelsCollision/valueLabelsCollision.js +47 -46
- package/lib/engine/features/valueLabelsCollision/valueLabelsCollisionHelper.d.ts +3 -6
- package/lib/engine/features/valueLabelsCollision/valueLabelsCollisionHelper.js +45 -49
- package/lib/engine/filterManager/filterEventManager.d.ts +30 -37
- package/lib/engine/filterManager/filterEventManager.js +131 -174
- package/lib/engine/helpers/domHelper.d.ts +20 -45
- package/lib/engine/helpers/domHelper.js +61 -62
- package/lib/engine/helpers/fontResizer/fontResizer.d.ts +10 -10
- package/lib/engine/helpers/fontResizer/fontResizer.js +16 -21
- package/lib/engine/helpers/fontResizer/fontResizerService.d.ts +1 -1
- package/lib/engine/helpers/fontResizer/fontResizerService.js +10 -9
- package/lib/engine/helpers/helper.d.ts +27 -27
- package/lib/engine/helpers/helper.js +92 -91
- package/lib/engine/helpers/namesHelper.d.ts +3 -3
- package/lib/engine/helpers/namesHelper.js +6 -6
- package/lib/engine/helpers/pipeline/Pipeline.d.ts +5 -5
- package/lib/engine/helpers/pipeline/Pipeline.js +33 -33
- package/lib/engine/polarNotation/donut/DonutHelper.d.ts +11 -25
- package/lib/engine/polarNotation/donut/DonutHelper.js +70 -71
- package/lib/engine/polarNotation/donut/donut.d.ts +23 -38
- package/lib/engine/polarNotation/donut/donut.js +99 -109
- package/lib/engine/polarNotation/polarManager.d.ts +6 -6
- package/lib/engine/polarNotation/polarManager.js +47 -67
- package/lib/engine/transitionManager.d.ts +14 -13
- package/lib/engine/transitionManager.js +49 -48
- package/lib/engine/twoDimensionalNotation/area/area.d.ts +28 -44
- package/lib/engine/twoDimensionalNotation/area/area.js +238 -272
- package/lib/engine/twoDimensionalNotation/area/areaGenerator.d.ts +5 -13
- package/lib/engine/twoDimensionalNotation/area/areaGenerator.js +13 -13
- package/lib/engine/twoDimensionalNotation/area/areaHelper.d.ts +4 -4
- package/lib/engine/twoDimensionalNotation/area/areaHelper.js +41 -57
- package/lib/engine/twoDimensionalNotation/bar/bar.d.ts +29 -54
- package/lib/engine/twoDimensionalNotation/bar/bar.js +224 -362
- package/lib/engine/twoDimensionalNotation/bar/barHelper.d.ts +32 -71
- package/lib/engine/twoDimensionalNotation/bar/barHelper.js +126 -162
- package/lib/engine/twoDimensionalNotation/bar/stackedData/dataStacker.d.ts +6 -6
- package/lib/engine/twoDimensionalNotation/bar/stackedData/dataStacker.js +24 -24
- package/lib/engine/twoDimensionalNotation/bar/stackedData/dataStackerService.d.ts +2 -2
- package/lib/engine/twoDimensionalNotation/bar/stackedData/dataStackerService.js +17 -16
- package/lib/engine/twoDimensionalNotation/dot/dotChart.d.ts +23 -23
- package/lib/engine/twoDimensionalNotation/dot/dotChart.js +114 -135
- package/lib/engine/twoDimensionalNotation/line/line.d.ts +16 -37
- package/lib/engine/twoDimensionalNotation/line/line.js +132 -162
- package/lib/engine/twoDimensionalNotation/line/lineBuilder.d.ts +11 -14
- package/lib/engine/twoDimensionalNotation/line/lineBuilder.js +48 -47
- package/lib/engine/twoDimensionalNotation/line/lineGenerator.d.ts +4 -4
- package/lib/engine/twoDimensionalNotation/line/lineGenerator.js +8 -8
- package/lib/engine/twoDimensionalNotation/line/lineHelper.d.ts +6 -12
- package/lib/engine/twoDimensionalNotation/line/lineHelper.js +60 -76
- package/lib/engine/twoDimensionalNotation/lineLike/generatorFactory/lineLikeGeneratorFactory.d.ts +6 -6
- package/lib/engine/twoDimensionalNotation/lineLike/generatorMiddleware/lineLikeGeneratorCurveMiddleware.d.ts +5 -5
- package/lib/engine/twoDimensionalNotation/lineLike/generatorMiddleware/lineLikeGeneratorCurveMiddleware.js +17 -16
- package/lib/engine/twoDimensionalNotation/lineLike/generatorMiddleware/lineLikeGeneratorDefineMiddleware.d.ts +10 -11
- package/lib/engine/twoDimensionalNotation/lineLike/generatorMiddleware/lineLikeGeneratorDefineMiddleware.js +7 -9
- package/lib/engine/twoDimensionalNotation/lineLike/generatorMiddleware/lineLikeGeneratorMiddleware.d.ts +1 -3
- package/lib/engine/twoDimensionalNotation/twoDimensionalManager.d.ts +10 -10
- package/lib/engine/twoDimensionalNotation/twoDimensionalManager.js +138 -253
- package/lib/engine/valueFormatter.d.ts +3 -3
- package/lib/engine/valueFormatter.js +6 -6
- package/lib/main.d.ts +79 -82
- package/lib/main.js +84 -79
- package/lib/model/EventEmitter.d.ts +8 -8
- package/lib/model/EventEmitter.js +24 -24
- package/lib/model/chartStyleModel/chartStyleModel.d.ts +5 -5
- package/lib/model/chartStyleModel/chartStyleModel.js +25 -27
- package/lib/model/chartStyleModel/colorRange.d.ts +3 -3
- package/lib/model/chartStyleModel/colorRange.js +24 -19
- package/lib/model/chartStyleModel/twoDimensionalChartStyleModel.d.ts +12 -22
- package/lib/model/chartStyleModel/twoDimensionalChartStyleModel.js +60 -69
- package/lib/model/configsValidator/configValidator.d.ts +1 -1
- package/lib/model/configsValidator/configValidator.js +4 -4
- package/lib/model/dataManagerModel/dataManagerModel.d.ts +26 -36
- package/lib/model/dataManagerModel/dataManagerModel.js +128 -179
- package/lib/model/dataManagerModel/dataManagerModelService.d.ts +2 -2
- package/lib/model/dataManagerModel/dataManagerModelService.js +26 -25
- package/lib/model/featuresModel/axisModel.d.ts +18 -69
- package/lib/model/featuresModel/axisModel.js +169 -224
- package/lib/model/featuresModel/axisModelService.d.ts +6 -10
- package/lib/model/featuresModel/axisModelService.js +27 -27
- package/lib/model/featuresModel/legendModel/legendCanvasModel.d.ts +11 -16
- package/lib/model/featuresModel/legendModel/legendCanvasModel.js +59 -55
- package/lib/model/featuresModel/legendModel/legendModel.d.ts +3 -7
- package/lib/model/featuresModel/legendModel/legendModel.js +41 -59
- package/lib/model/featuresModel/legendModel/polarMarginCalculator.d.ts +3 -8
- package/lib/model/featuresModel/legendModel/polarMarginCalculator.js +20 -18
- package/lib/model/featuresModel/legendModel/twoDimLegendModel.d.ts +4 -8
- package/lib/model/featuresModel/legendModel/twoDimLegendModel.js +27 -40
- package/lib/model/featuresModel/otherComponents.d.ts +4 -7
- package/lib/model/featuresModel/otherComponents.js +9 -9
- package/lib/model/featuresModel/recordOverflowModel/recordOverflowModel.d.ts +4 -0
- package/lib/model/featuresModel/recordOverflowModel/recordOverflowModel.js +33 -0
- package/lib/model/featuresModel/scaleModel/scaleAxisRecalcer.d.ts +6 -6
- package/lib/model/featuresModel/scaleModel/scaleAxisRecalcer.js +23 -27
- package/lib/model/featuresModel/scaleModel/scaleDomainService.d.ts +5 -19
- package/lib/model/featuresModel/scaleModel/scaleDomainService.js +55 -44
- package/lib/model/featuresModel/scaleModel/scaleModel.d.ts +10 -10
- package/lib/model/featuresModel/scaleModel/scaleModel.js +50 -61
- package/lib/model/featuresModel/scaleModel/scaleModelServices.js +22 -15
- package/lib/model/featuresModel/titleModel.d.ts +1 -1
- package/lib/model/featuresModel/titleModel.js +14 -14
- package/lib/model/featuresModel/tooltipModel.d.ts +1 -1
- package/lib/model/featuresModel/tooltipModel.js +5 -5
- package/lib/model/featuresModel/valueLabelsModel/valueLabelsModel.d.ts +11 -23
- package/lib/model/featuresModel/valueLabelsModel/valueLabelsModel.js +51 -53
- package/lib/model/helpers/modelHelper.d.ts +7 -7
- package/lib/model/helpers/modelHelper.js +42 -38
- package/lib/model/helpers/twoDimensionalModelHelper.d.ts +9 -37
- package/lib/model/helpers/twoDimensionalModelHelper.js +125 -147
- package/lib/model/helpers/unitsFromConfigReader.js +4 -4
- package/lib/model/helpers/unitsReader.d.ts +2 -2
- package/lib/model/helpers/unitsReader.js +13 -11
- package/lib/model/margin/marginModel.d.ts +7 -7
- package/lib/model/margin/marginModel.js +20 -23
- package/lib/model/margin/twoDim/twoDimMarginModel.d.ts +13 -13
- package/lib/model/margin/twoDim/twoDimMarginModel.js +113 -184
- package/lib/model/model.d.ts +284 -315
- package/lib/model/model.js +4 -4
- package/lib/model/modelBuilder.d.ts +18 -27
- package/lib/model/modelBuilder.js +79 -85
- package/lib/model/modelInstance/canvasModel/canvasModel.d.ts +17 -17
- package/lib/model/modelInstance/canvasModel/canvasModel.js +43 -42
- package/lib/model/modelInstance/canvasModel/canvasSizesModel/canvasMarginModel.d.ts +7 -7
- package/lib/model/modelInstance/canvasModel/canvasSizesModel/canvasSizeModel.d.ts +2 -2
- package/lib/model/modelInstance/canvasModel/canvasSizesModel/marginModelService.d.ts +6 -6
- package/lib/model/modelInstance/canvasModel/canvasSizesModel/marginModelService.js +24 -24
- package/lib/model/modelInstance/canvasModel/legendCanvasModel.d.ts +4 -4
- package/lib/model/modelInstance/canvasModel/legendCanvasModel.js +11 -11
- package/lib/model/modelInstance/canvasModel/titleCanvas.d.ts +4 -4
- package/lib/model/modelInstance/canvasModel/titleCanvas.js +9 -9
- package/lib/model/modelInstance/chartBlockVersion/chartBlockVersion.d.ts +3 -3
- package/lib/model/modelInstance/chartBlockVersion/chartBlockVersion.js +6 -6
- package/lib/model/modelInstance/configReader.d.ts +23 -32
- package/lib/model/modelInstance/configReader.js +94 -125
- package/lib/model/modelInstance/dataModel/dataModel.d.ts +10 -10
- package/lib/model/modelInstance/dataModel/dataModel.js +25 -25
- package/lib/model/modelInstance/dataModel/dataRepository.d.ts +14 -14
- package/lib/model/modelInstance/dataModel/dataRepository.js +42 -42
- package/lib/model/modelInstance/modelInstance.d.ts +6 -11
- package/lib/model/modelInstance/modelInstance.js +16 -16
- package/lib/model/modelInstance/titleConfigReader.d.ts +8 -8
- package/lib/model/modelInstance/titleConfigReader.js +30 -37
- package/lib/model/notations/polar/donut/donutAggregatorService.d.ts +6 -9
- package/lib/model/notations/polar/donut/donutAggregatorService.js +37 -40
- package/lib/model/notations/polar/donut/donutModel.d.ts +5 -9
- package/lib/model/notations/polar/donut/donutModel.js +28 -28
- package/lib/model/notations/polar/donut/donutThicknessService.d.ts +3 -3
- package/lib/model/notations/polar/donut/donutThicknessService.js +15 -13
- package/lib/model/notations/polar/polarModel.d.ts +7 -18
- package/lib/model/notations/polar/polarModel.js +72 -79
- package/lib/model/notations/twoDimensional/styles.d.ts +7 -44
- package/lib/model/notations/twoDimensional/styles.js +125 -234
- package/lib/model/notations/twoDimensionalModel.d.ts +13 -23
- package/lib/model/notations/twoDimensionalModel.js +170 -330
- package/lib/optionsServices/publicOptionsService.d.ts +1 -1
- package/lib/optionsServices/publicOptionsService.js +4 -4
- package/lib/optionsServices/validators/sizeValidator.d.ts +2 -2
- package/lib/optionsServices/validators/sizeValidator.js +11 -10
- package/lib/style/charts-main.css +151 -150
- package/lib/style/charts-main.less +151 -150
- package/package.json +1 -1
- package/lib/engine/polarNotation/extenders/polarRecordOverflowAlert.d.ts +0 -15
- package/lib/engine/polarNotation/extenders/polarRecordOverflowAlert.js +0 -40
- package/lib/engine/twoDimensionalNotation/extenders/twoDimRecordOverflowAlert.d.ts +0 -15
- package/lib/engine/twoDimensionalNotation/extenders/twoDimRecordOverflowAlert.js +0 -32
|
@@ -1,60 +1,67 @@
|
|
|
1
1
|
export const LABEL_BAR_PADDING = 6;
|
|
2
2
|
export const MIN_BAR_HEIGHT_FOR_LABEL_SERVE = 12;
|
|
3
3
|
export class EmbeddedLabelsHelper {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
4
|
+
static getLabelPosition(barAttrs, labelBlockWidth, margin, blockSize, labelUnserveFlag) {
|
|
5
|
+
if (labelUnserveFlag ||
|
|
6
|
+
(this.getSpaceSizeForType("inside", barAttrs.width, margin, blockSize) < labelBlockWidth &&
|
|
7
|
+
this.getSpaceSizeForType("inside", barAttrs.width, margin, blockSize) <
|
|
8
|
+
this.getSpaceSizeForType("outside", barAttrs.width, margin, blockSize)))
|
|
9
|
+
return "outside";
|
|
10
|
+
return "inside";
|
|
11
|
+
}
|
|
12
|
+
static getSpaceSizeForType(position, barWidth, margin, blockSize) {
|
|
13
|
+
if (position === "outside")
|
|
14
|
+
return blockSize.width - margin.left - margin.right - barWidth - LABEL_BAR_PADDING;
|
|
15
|
+
return barWidth - LABEL_BAR_PADDING * 2;
|
|
16
|
+
}
|
|
17
|
+
static getLabelAttrs(barAttrs, type, position, keyAxisOrient, labelWidth) {
|
|
18
|
+
const textAnchor = this.getTextAnchor(type, position, keyAxisOrient);
|
|
19
|
+
const y = this.getLabelAttrY(barAttrs.y, barAttrs.height);
|
|
20
|
+
let x = this.getLabelAttrX(barAttrs, type, position, keyAxisOrient);
|
|
21
|
+
if (textAnchor === "end") {
|
|
22
|
+
x = x - labelWidth;
|
|
23
|
+
}
|
|
24
|
+
return {
|
|
25
|
+
x,
|
|
26
|
+
y,
|
|
27
|
+
textAnchor
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
static getLabelField(type, valueFields, keyField, index) {
|
|
31
|
+
if (type === "key")
|
|
32
|
+
return keyField;
|
|
33
|
+
if (type === "value")
|
|
34
|
+
return valueFields[index];
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
static getLabelUnserveFlag(barHeight) {
|
|
38
|
+
return barHeight < MIN_BAR_HEIGHT_FOR_LABEL_SERVE;
|
|
39
|
+
}
|
|
40
|
+
static getLabelAttrX(barAttrs, type, position, keyAxisOrient) {
|
|
41
|
+
if (keyAxisOrient === "left") {
|
|
42
|
+
if (position === "outside")
|
|
43
|
+
return barAttrs.x + barAttrs.width + LABEL_BAR_PADDING;
|
|
44
|
+
if (type === "key")
|
|
45
|
+
return barAttrs.x + LABEL_BAR_PADDING;
|
|
46
|
+
return barAttrs.x + barAttrs.width - LABEL_BAR_PADDING;
|
|
47
|
+
}
|
|
48
|
+
if (position === "outside")
|
|
49
|
+
return barAttrs.x - LABEL_BAR_PADDING;
|
|
50
|
+
if (type === "key")
|
|
51
|
+
return barAttrs.x + barAttrs.width - LABEL_BAR_PADDING;
|
|
52
|
+
return barAttrs.x + LABEL_BAR_PADDING;
|
|
53
|
+
}
|
|
54
|
+
static getLabelAttrY(barY, barHeight) {
|
|
55
|
+
return barY + barHeight / 2 + 1;
|
|
56
|
+
}
|
|
57
|
+
static getTextAnchor(type, position, keyAxisOrient) {
|
|
58
|
+
if (keyAxisOrient === "left") {
|
|
59
|
+
if (position === "outside" || type === "key")
|
|
60
|
+
return "start";
|
|
61
|
+
return "end";
|
|
62
|
+
}
|
|
63
|
+
if (position === "outside" || type === "key")
|
|
64
|
+
return "end";
|
|
65
|
+
return "start";
|
|
66
|
+
}
|
|
60
67
|
}
|
|
@@ -3,19 +3,13 @@ import { Size } from "../../../config/config";
|
|
|
3
3
|
import { AxisModelOptions, BlockMargin } from "../../../model/model";
|
|
4
4
|
export declare type GridLineType = "key" | "value";
|
|
5
5
|
export interface GridLineAttributes {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
6
|
+
x1: number;
|
|
7
|
+
y1: number;
|
|
8
|
+
x2: number;
|
|
9
|
+
y2: number;
|
|
10
10
|
}
|
|
11
11
|
export declare class GridLineHelper {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
valueAxis: AxisModelOptions,
|
|
16
|
-
blockSize: Size,
|
|
17
|
-
margin: BlockMargin
|
|
18
|
-
): number;
|
|
19
|
-
static getLineAttributes(axis: AxisModelOptions, lineLength: number): GridLineAttributes;
|
|
20
|
-
static getKeyLineAttributes(axis: AxisModelOptions, scaleValue: AxisScale<any>): GridLineAttributes;
|
|
12
|
+
static getGridLineLength(gridLineType: GridLineType, keyAxis: AxisModelOptions, valueAxis: AxisModelOptions, blockSize: Size, margin: BlockMargin): number;
|
|
13
|
+
static getLineAttributes(axis: AxisModelOptions, lineLength: number): GridLineAttributes;
|
|
14
|
+
static getKeyLineAttributes(axis: AxisModelOptions, scaleValue: AxisScale<any>): GridLineAttributes;
|
|
21
15
|
}
|
|
@@ -1,45 +1,52 @@
|
|
|
1
1
|
import { max, min } from "d3-array";
|
|
2
2
|
export class GridLineHelper {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
3
|
+
static getGridLineLength(gridLineType, keyAxis, valueAxis, blockSize, margin) {
|
|
4
|
+
let axis;
|
|
5
|
+
let axisLength;
|
|
6
|
+
if (gridLineType === "key")
|
|
7
|
+
axis = keyAxis;
|
|
8
|
+
else
|
|
9
|
+
axis = valueAxis;
|
|
10
|
+
if (axis.orient === "left" || axis.orient === "right")
|
|
11
|
+
axisLength = blockSize.width - margin.left - margin.right;
|
|
12
|
+
else
|
|
13
|
+
axisLength = blockSize.height - margin.top - margin.bottom;
|
|
14
|
+
if (axis.orient === "right" || axis.orient === "bottom")
|
|
15
|
+
axisLength = -axisLength;
|
|
16
|
+
return axisLength;
|
|
17
|
+
}
|
|
18
|
+
static getLineAttributes(axis, lineLength) {
|
|
19
|
+
const attributes = {
|
|
20
|
+
x1: 0,
|
|
21
|
+
y1: 0,
|
|
22
|
+
x2: 0,
|
|
23
|
+
y2: 0
|
|
24
|
+
};
|
|
25
|
+
if (axis.orient === "left" || axis.orient === "right")
|
|
26
|
+
attributes.x2 = lineLength;
|
|
27
|
+
else
|
|
28
|
+
attributes.y2 = lineLength;
|
|
29
|
+
return attributes;
|
|
30
|
+
}
|
|
31
|
+
static getKeyLineAttributes(axis, scaleValue) {
|
|
32
|
+
const attributes = {
|
|
33
|
+
x1: 0,
|
|
34
|
+
y1: 0,
|
|
35
|
+
x2: 0,
|
|
36
|
+
y2: 0
|
|
37
|
+
};
|
|
38
|
+
const scaledStart = scaleValue(scaleValue.domain()[0]);
|
|
39
|
+
const scaledEnd = scaleValue(scaleValue.domain()[1]);
|
|
40
|
+
const minCoord = min([scaledStart, scaledEnd]) - scaleValue(0);
|
|
41
|
+
const maxCoord = max([scaledStart, scaledEnd]) - scaleValue(0);
|
|
42
|
+
if (axis.orient === "left" || axis.orient === "right") {
|
|
43
|
+
attributes.x1 = minCoord;
|
|
44
|
+
attributes.x2 = maxCoord;
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
attributes.y1 = minCoord;
|
|
48
|
+
attributes.y2 = maxCoord;
|
|
49
|
+
}
|
|
50
|
+
return attributes;
|
|
51
|
+
}
|
|
45
52
|
}
|
|
@@ -3,23 +3,9 @@ import { BlockMargin, GridLineOptions, IAxisModel } from "../../../model/model";
|
|
|
3
3
|
import { Block } from "../../block/block";
|
|
4
4
|
import { Scales } from "../scale/scale";
|
|
5
5
|
export declare class GridLine {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
blockSize: Size,
|
|
12
|
-
margin: BlockMargin,
|
|
13
|
-
scales: Scales
|
|
14
|
-
): void;
|
|
15
|
-
static update(
|
|
16
|
-
block: Block,
|
|
17
|
-
options: GridLineOptions,
|
|
18
|
-
axes: IAxisModel,
|
|
19
|
-
blockSize: Size,
|
|
20
|
-
margin: BlockMargin,
|
|
21
|
-
scales: Scales
|
|
22
|
-
): void;
|
|
23
|
-
private static renderLine;
|
|
24
|
-
private static clear;
|
|
6
|
+
private static readonly gridLineClass;
|
|
7
|
+
static render(block: Block, options: GridLineOptions, axes: IAxisModel, blockSize: Size, margin: BlockMargin, scales: Scales): void;
|
|
8
|
+
static update(block: Block, options: GridLineOptions, axes: IAxisModel, blockSize: Size, margin: BlockMargin, scales: Scales): void;
|
|
9
|
+
private static renderLine;
|
|
10
|
+
private static clear;
|
|
25
11
|
}
|
|
@@ -1,39 +1,40 @@
|
|
|
1
1
|
import { GridLineHelper } from "./gidLineHelper";
|
|
2
2
|
export class GridLine {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
3
|
+
static render(block, options, axes, blockSize, margin, scales) {
|
|
4
|
+
if (options.flag.value) {
|
|
5
|
+
const lineLength = GridLineHelper.getGridLineLength("value", axes.key, axes.value, blockSize, margin);
|
|
6
|
+
const lineAttributes = GridLineHelper.getLineAttributes(axes.value, lineLength);
|
|
7
|
+
this.renderLine(block, axes.value, lineAttributes, options).style("display", (d, i, group) => {
|
|
8
|
+
return d === 0 ? "none" : "block";
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
if (options.flag.key) {
|
|
12
|
+
const lineAttributes = GridLineHelper.getKeyLineAttributes(axes.key, scales.value);
|
|
13
|
+
this.renderLine(block, axes.key, lineAttributes, options);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
static update(block, options, axes, blockSize, margin, scales) {
|
|
17
|
+
this.clear(block, axes.key.cssClass, axes.value.cssClass);
|
|
18
|
+
this.render(block, options, axes, blockSize, margin, scales);
|
|
19
|
+
}
|
|
20
|
+
static renderLine(block, axis, lineAttributes, options) {
|
|
21
|
+
const gridLine = block
|
|
22
|
+
.getSvg()
|
|
23
|
+
.selectAll(`.${axis.cssClass}`)
|
|
24
|
+
.selectAll("g.tick")
|
|
25
|
+
.append("line")
|
|
26
|
+
.attr("class", this.gridLineClass)
|
|
27
|
+
.attr("x1", lineAttributes.x1)
|
|
28
|
+
.attr("y1", lineAttributes.y1)
|
|
29
|
+
.attr("x2", lineAttributes.x2)
|
|
30
|
+
.attr("y2", lineAttributes.y2);
|
|
31
|
+
if (options.styles.dash.on)
|
|
32
|
+
gridLine.style("stroke-dasharray", 3);
|
|
33
|
+
return gridLine;
|
|
34
|
+
}
|
|
35
|
+
static clear(block, keyAxisClass, valueAxisClass) {
|
|
36
|
+
block.getSvg().selectAll(`.${keyAxisClass} `).selectAll("g.tick").selectAll(`.${this.gridLineClass}`).remove();
|
|
37
|
+
block.getSvg().selectAll(`.${valueAxisClass}`).selectAll("g.tick").selectAll(`.${this.gridLineClass}`).remove();
|
|
38
|
+
}
|
|
38
39
|
}
|
|
39
40
|
GridLine.gridLineClass = "grid-line";
|
|
@@ -5,44 +5,34 @@ import { Block } from "../../block/block";
|
|
|
5
5
|
import { SelectionCondition } from "../../helpers/domHelper";
|
|
6
6
|
import { ChartLegendEngineModel } from "./legendHelper";
|
|
7
7
|
export interface LegendContentRenderingOptions {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
8
|
+
wrapperClasses: string[];
|
|
9
|
+
shouldCropLabels: boolean;
|
|
10
|
+
blockModel: LegendBlockModel;
|
|
11
|
+
itemsOptions: {
|
|
12
|
+
wrapperClasses: string[];
|
|
13
|
+
markerClass: string;
|
|
14
|
+
labelClass: string;
|
|
15
|
+
};
|
|
16
16
|
}
|
|
17
17
|
export declare class Legend {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
block: Block,
|
|
39
|
-
keys: string[],
|
|
40
|
-
condition?: SelectionCondition
|
|
41
|
-
): Selection<HTMLDivElement, ChartLegendEngineModel, BaseType, unknown>;
|
|
42
|
-
private setContent;
|
|
43
|
-
private renderObject;
|
|
44
|
-
private renderContent;
|
|
45
|
-
private getObject;
|
|
46
|
-
private removeContent;
|
|
47
|
-
private fillCoordinate;
|
|
18
|
+
static get(): Legend;
|
|
19
|
+
static readonly objectClass = "legend-object";
|
|
20
|
+
static readonly labelClass = "legend-label";
|
|
21
|
+
static readonly label2DClass = "legend-2d-label";
|
|
22
|
+
static readonly labelPolarClass = "legend-polar-label";
|
|
23
|
+
static readonly itemClass = "legend-item";
|
|
24
|
+
static readonly markerClass = "legend-marker";
|
|
25
|
+
static readonly markerCircle = "legend-circle";
|
|
26
|
+
static readonly legendBlockClass = "legend-block";
|
|
27
|
+
private readonly markerCreator;
|
|
28
|
+
render(block: Block, data: MdtChartsDataSource, options: TwoDimensionalOptionsModel | PolarOptionsModel, model: Model): void;
|
|
29
|
+
update(block: Block, data: MdtChartsDataSource, model: Model<TwoDimensionalOptionsModel | PolarOptionsModel>): void;
|
|
30
|
+
updateColors(block: Block, options: TwoDimensionalOptionsModel | PolarOptionsModel): void;
|
|
31
|
+
static getItemsByKeys(block: Block, keys: string[], condition?: SelectionCondition): Selection<HTMLDivElement, ChartLegendEngineModel, BaseType, unknown>;
|
|
32
|
+
private setContent;
|
|
33
|
+
private renderObject;
|
|
34
|
+
private renderContent;
|
|
35
|
+
private getObject;
|
|
36
|
+
private removeContent;
|
|
37
|
+
private fillCoordinate;
|
|
48
38
|
}
|