mdt-charts 1.29.0 → 1.30.0
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 +170 -178
- 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 +170 -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 +281 -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 +5 -5
- 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
|
@@ -8,367 +8,229 @@ import { Helper } from "../../helpers/helper";
|
|
|
8
8
|
import { getStackedDataWithOwn } from "./stackedData/dataStacker";
|
|
9
9
|
import { Pipeline } from "../../helpers/pipeline/Pipeline";
|
|
10
10
|
export class Bar {
|
|
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
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
index,
|
|
236
|
-
chart.cssClasses
|
|
237
|
-
);
|
|
238
|
-
if (!newBars.empty())
|
|
239
|
-
EmbeddedLabels.render(
|
|
240
|
-
block,
|
|
241
|
-
newBars,
|
|
242
|
-
barAttrs,
|
|
243
|
-
valueField,
|
|
244
|
-
chart.embeddedLabels,
|
|
245
|
-
keyAxisOrient,
|
|
246
|
-
blockSize,
|
|
247
|
-
margin,
|
|
248
|
-
index,
|
|
249
|
-
chart.cssClasses
|
|
250
|
-
);
|
|
251
|
-
EmbeddedLabels.restoreRemoved(
|
|
252
|
-
block,
|
|
253
|
-
bars,
|
|
254
|
-
barAttrs,
|
|
255
|
-
valueField,
|
|
256
|
-
chart.embeddedLabels,
|
|
257
|
-
keyAxisOrient,
|
|
258
|
-
blockSize,
|
|
259
|
-
margin,
|
|
260
|
-
index,
|
|
261
|
-
chart.cssClasses,
|
|
262
|
-
keyField.name
|
|
263
|
-
);
|
|
264
|
-
}
|
|
265
|
-
});
|
|
266
|
-
return promises;
|
|
267
|
-
}
|
|
268
|
-
updateSegmented(block, newData, scales, margin, keyAxisOrient, chart, barsAmounts, keyField, barSettings) {
|
|
269
|
-
const stackedData = getStackedDataWithOwn(
|
|
270
|
-
newData,
|
|
271
|
-
chart.data.valueFields.map((field) => field.name)
|
|
272
|
-
);
|
|
273
|
-
block.svg
|
|
274
|
-
.getChartGroup(chart.index)
|
|
275
|
-
.selectAll(`.${this.barItemClass}${Helper.getCssClassesLine(chart.cssClasses)}`)
|
|
276
|
-
.filter((d) => newData.findIndex((row) => row[keyField.name] === d.data[keyField.name]) === -1)
|
|
277
|
-
.transition()
|
|
278
|
-
.duration(block.transitionManager.durations.elementFadeOut)
|
|
279
|
-
.style("opacity", 0)
|
|
280
|
-
.remove();
|
|
281
|
-
const groups = block.svg
|
|
282
|
-
.getChartGroup(chart.index)
|
|
283
|
-
.selectAll(`g.${this.barSegmentGroupClass}${Helper.getCssClassesLine(chart.cssClasses)}`)
|
|
284
|
-
.data(stackedData);
|
|
285
|
-
const bars = groups
|
|
286
|
-
.selectAll(`.${this.barItemClass}${Helper.getCssClassesLine(chart.cssClasses)}`)
|
|
287
|
-
.filter((d) => newData.findIndex((row) => row[keyField.name] === d.data[keyField.name]) !== -1)
|
|
288
|
-
.style("opacity", 1)
|
|
289
|
-
.data((d) => d);
|
|
290
|
-
let newBars = bars
|
|
291
|
-
.enter()
|
|
292
|
-
.append("rect")
|
|
293
|
-
.attr("class", this.barItemClass)
|
|
294
|
-
.style("clip-path", `url(#${block.svg.getClipPathId()})`);
|
|
295
|
-
newBars = this.createBarPipeline.execute(newBars, chart);
|
|
296
|
-
const barAttrs = BarHelper.getStackedBarAttr(
|
|
297
|
-
keyAxisOrient,
|
|
298
|
-
scales,
|
|
299
|
-
margin,
|
|
300
|
-
keyField.name,
|
|
301
|
-
chart.barViewOptions.barIndexes[0],
|
|
302
|
-
sum(barsAmounts),
|
|
303
|
-
barSettings
|
|
304
|
-
);
|
|
305
|
-
const prom = this.fillBarAttrs(bars, barAttrs, block.transitionManager.durations.chartUpdate).then(() => {
|
|
306
|
-
this.setInitialAttrsInfo(bars, keyAxisOrient, barSettings);
|
|
307
|
-
bars.style("opacity", null);
|
|
308
|
-
});
|
|
309
|
-
this.fillBarAttrs(newBars, barAttrs);
|
|
310
|
-
this.setInitialAttrsInfo(newBars, keyAxisOrient, barSettings);
|
|
311
|
-
DomHelper.setCssClasses(newBars, chart.cssClasses);
|
|
312
|
-
const thisClass = this;
|
|
313
|
-
groups.each(function (d, i) {
|
|
314
|
-
const barsInGroup = select(this).selectAll(`rect${Helper.getCssClassesLine(chart.cssClasses)}`);
|
|
315
|
-
DomHelper.setCssClasses(barsInGroup, Helper.getCssClassesWithElementIndex(chart.cssClasses, i)); // Для обозначения принадлежности бара к конкретной части стака
|
|
316
|
-
thisClass.createSegmentGroupBarsPipeline.execute(barsInGroup, {
|
|
317
|
-
segmentIndex: i,
|
|
318
|
-
chart
|
|
319
|
-
});
|
|
320
|
-
thisClass.setSegmentColor(
|
|
321
|
-
select(this).selectAll(Helper.getCssClassesLine(chart.cssClasses)),
|
|
322
|
-
chart.style.elementColors,
|
|
323
|
-
i
|
|
324
|
-
);
|
|
325
|
-
});
|
|
326
|
-
return [prom];
|
|
327
|
-
}
|
|
328
|
-
fillBarAttrs(bars, barAttrs, transitionDuration = 0) {
|
|
329
|
-
return new Promise((resolve) => {
|
|
330
|
-
if (bars.size() === 0) {
|
|
331
|
-
resolve("");
|
|
332
|
-
return;
|
|
333
|
-
}
|
|
334
|
-
let barsHandler = bars;
|
|
335
|
-
if (transitionDuration > 0) {
|
|
336
|
-
barsHandler = barsHandler
|
|
337
|
-
.interrupt()
|
|
338
|
-
.transition()
|
|
339
|
-
.duration(transitionDuration)
|
|
340
|
-
.on("end", () => resolve(""));
|
|
341
|
-
}
|
|
342
|
-
barsHandler
|
|
343
|
-
.attr("x", (d) => barAttrs.x(d))
|
|
344
|
-
.attr("y", (d) => barAttrs.y(d))
|
|
345
|
-
.attr("height", (d) => barAttrs.height(d))
|
|
346
|
-
.attr("width", (d) => barAttrs.width(d));
|
|
347
|
-
if (transitionDuration <= 0) resolve("");
|
|
348
|
-
});
|
|
349
|
-
}
|
|
350
|
-
setSegmentColor(segments, colorPalette, segmentedIndex) {
|
|
351
|
-
segments.style("fill", colorPalette[segmentedIndex % colorPalette.length]);
|
|
352
|
-
}
|
|
353
|
-
/**
|
|
354
|
-
* Устнановка координат для удобного обновления.
|
|
355
|
-
*/
|
|
356
|
-
setInitialAttrsInfo(bars, keyAxisOrient, barSettings) {
|
|
357
|
-
bars.each(function () {
|
|
358
|
-
const width = DomHelper.getSelectionNumericAttr(select(this), "width");
|
|
359
|
-
const height = DomHelper.getSelectionNumericAttr(select(this), "height");
|
|
360
|
-
const orient = keyAxisOrient === "left" || keyAxisOrient === "right" ? "horizontal" : "vertical";
|
|
361
|
-
let scaleSize = 0.06 * (orient === "vertical" ? width : height);
|
|
362
|
-
scaleSize = scaleSize > barSettings.barDistance / 2 ? barSettings.barDistance / 2 : scaleSize;
|
|
363
|
-
this.attrs = {
|
|
364
|
-
x: DomHelper.getSelectionNumericAttr(select(this), "x"),
|
|
365
|
-
y: DomHelper.getSelectionNumericAttr(select(this), "y"),
|
|
366
|
-
width,
|
|
367
|
-
height,
|
|
368
|
-
orient,
|
|
369
|
-
scaleSize
|
|
370
|
-
};
|
|
371
|
-
});
|
|
372
|
-
}
|
|
11
|
+
constructor() {
|
|
12
|
+
this.barItemClass = Bar.barItemClass;
|
|
13
|
+
this.barSegmentGroupClass = "bar-segment-group";
|
|
14
|
+
this.createBarPipeline = new Pipeline();
|
|
15
|
+
this.createSegmentGroupBarsPipeline = new Pipeline();
|
|
16
|
+
onBarChartInit(this.createBarPipeline, this.createSegmentGroupBarsPipeline);
|
|
17
|
+
}
|
|
18
|
+
static get() {
|
|
19
|
+
return new Bar();
|
|
20
|
+
}
|
|
21
|
+
render(block, scales, data, keyField, margin, keyAxisOrient, chart, blockSize, barSettings, barsAmounts) {
|
|
22
|
+
if (chart.isSegmented)
|
|
23
|
+
this.renderSegmented(block, scales, data, keyField, margin, keyAxisOrient, chart, barsAmounts, barSettings);
|
|
24
|
+
else
|
|
25
|
+
this.renderGrouped(block, scales, data, keyField, margin, keyAxisOrient, chart, barsAmounts, blockSize, barSettings);
|
|
26
|
+
}
|
|
27
|
+
update(block, newData, scales, margin, keyAxisOrient, chart, blockSize, barsAmounts, keyField, barSettings) {
|
|
28
|
+
let promises;
|
|
29
|
+
if (chart.isSegmented) {
|
|
30
|
+
promises = this.updateSegmented(block, newData, scales, margin, keyAxisOrient, chart, barsAmounts, keyField, barSettings);
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
promises = this.updateGrouped(block, newData, scales, margin, keyAxisOrient, chart, blockSize, barsAmounts, keyField, barSettings);
|
|
34
|
+
}
|
|
35
|
+
return promises;
|
|
36
|
+
}
|
|
37
|
+
updateColors(block, chart) {
|
|
38
|
+
chart.data.valueFields.forEach((_vf, index) => {
|
|
39
|
+
const bars = block.svg
|
|
40
|
+
.getChartGroup(chart.index)
|
|
41
|
+
.selectAll(`.${this.barItemClass}${Helper.getCssClassesLine(chart.cssClasses)}${Helper.getCssClassesLine(Helper.getCssClassesWithElementIndex(chart.cssClasses, index))}`);
|
|
42
|
+
DomHelper.setChartStyle(bars, chart.style, index, "fill");
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
getAllBarsForChart(block, chartCssClasses) {
|
|
46
|
+
return block.getSvg().selectAll(`rect.${this.barItemClass}${Helper.getCssClassesLine(chartCssClasses)}`);
|
|
47
|
+
}
|
|
48
|
+
renderGrouped(block, scales, data, keyField, margin, keyAxisOrient, chart, barsAmounts, blockSize, barSettings) {
|
|
49
|
+
chart.data.valueFields.forEach((field, index) => {
|
|
50
|
+
let bars = block.svg
|
|
51
|
+
.getChartGroup(chart.index)
|
|
52
|
+
.selectAll(`.${this.barItemClass}${Helper.getCssClassesLine(chart.cssClasses)}${Helper.getCssClassesLine(Helper.getCssClassesWithElementIndex(chart.cssClasses, index))}`)
|
|
53
|
+
.data(data)
|
|
54
|
+
.enter()
|
|
55
|
+
.append("rect")
|
|
56
|
+
.attr("class", this.barItemClass)
|
|
57
|
+
.style("clip-path", `url(#${block.svg.getClipPathId()})`);
|
|
58
|
+
bars = this.createBarPipeline.execute(bars, chart);
|
|
59
|
+
const barAttrs = BarHelper.getGroupedBarAttrs(keyAxisOrient, scales, margin, keyField.name, field.name, chart.barViewOptions.barIndexes[index], sum(barsAmounts), barSettings);
|
|
60
|
+
this.fillBarAttrs(bars, barAttrs);
|
|
61
|
+
DomHelper.setCssClasses(bars, Helper.getCssClassesWithElementIndex(chart.cssClasses, index));
|
|
62
|
+
DomHelper.setChartStyle(bars, chart.style, index, "fill");
|
|
63
|
+
this.setInitialAttrsInfo(bars, keyAxisOrient, barSettings);
|
|
64
|
+
if (chart.embeddedLabels !== "none")
|
|
65
|
+
EmbeddedLabels.render(block, bars, barAttrs, EmbeddedLabelsHelper.getLabelField(chart.embeddedLabels, chart.data.valueFields, keyField, index), chart.embeddedLabels, keyAxisOrient, blockSize, margin, index, chart.cssClasses);
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
renderSegmented(block, scales, data, keyField, margin, keyAxisOrient, chart, barsAmounts, barSettings) {
|
|
69
|
+
const stackedData = getStackedDataWithOwn(data, chart.data.valueFields.map((field) => field.name));
|
|
70
|
+
let groups = block.svg
|
|
71
|
+
.getChartGroup(chart.index)
|
|
72
|
+
.selectAll(`g.${this.barSegmentGroupClass}${Helper.getCssClassesLine(chart.cssClasses)}`)
|
|
73
|
+
.data(stackedData);
|
|
74
|
+
if (groups.empty())
|
|
75
|
+
groups = groups.data(stackedData).enter().append("g").attr("class", this.barSegmentGroupClass);
|
|
76
|
+
let bars = groups
|
|
77
|
+
.selectAll(`rect${Helper.getCssClassesLine(chart.cssClasses)}`)
|
|
78
|
+
.data((d) => d)
|
|
79
|
+
.enter()
|
|
80
|
+
.append("rect")
|
|
81
|
+
.attr("class", this.barItemClass)
|
|
82
|
+
.style("clip-path", `url(#${block.svg.getClipPathId()})`);
|
|
83
|
+
bars = this.createBarPipeline.execute(bars, chart);
|
|
84
|
+
const barAttrs = BarHelper.getStackedBarAttr(keyAxisOrient, scales, margin, keyField.name, chart.barViewOptions.barIndexes[0], sum(barsAmounts), barSettings);
|
|
85
|
+
this.fillBarAttrs(bars, barAttrs);
|
|
86
|
+
this.setInitialAttrsInfo(bars, keyAxisOrient, barSettings);
|
|
87
|
+
DomHelper.setCssClasses(groups, chart.cssClasses);
|
|
88
|
+
DomHelper.setCssClasses(bars, chart.cssClasses); // Для обозначения принадлежности бара к конкретному чарту
|
|
89
|
+
const thisClass = this;
|
|
90
|
+
groups.each(function (d, i) {
|
|
91
|
+
const barsInGroup = select(this).selectAll(`rect${Helper.getCssClassesLine(chart.cssClasses)}`);
|
|
92
|
+
DomHelper.setCssClasses(barsInGroup, Helper.getCssClassesWithElementIndex(chart.cssClasses, i)); // Для обозначения принадлежности бара к конкретной части стака
|
|
93
|
+
thisClass.createSegmentGroupBarsPipeline.execute(barsInGroup, { segmentIndex: i, chart });
|
|
94
|
+
thisClass.setSegmentColor(select(this).selectAll(Helper.getCssClassesLine(chart.cssClasses)), chart.style.elementColors, i);
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
updateGrouped(block, newData, scales, margin, keyAxisOrient, chart, blockSize, barsAmounts, keyField, barSettings) {
|
|
98
|
+
const promises = [];
|
|
99
|
+
chart.data.valueFields.forEach((valueField, index) => {
|
|
100
|
+
const indexesOfRemoved = [];
|
|
101
|
+
block.svg
|
|
102
|
+
.getChartGroup(chart.index)
|
|
103
|
+
.selectAll(`.${this.barItemClass}${Helper.getCssClassesLine(chart.cssClasses)}.chart-element-${index}`)
|
|
104
|
+
.filter((d, i) => {
|
|
105
|
+
if (newData.findIndex((row) => row[keyField.name] === d[keyField.name]) === -1) {
|
|
106
|
+
indexesOfRemoved.push(i); // Набор индексов для встроенных лейблов
|
|
107
|
+
return true;
|
|
108
|
+
}
|
|
109
|
+
return false;
|
|
110
|
+
})
|
|
111
|
+
.transition()
|
|
112
|
+
.duration(block.transitionManager.durations.elementFadeOut)
|
|
113
|
+
.style("opacity", 0)
|
|
114
|
+
.remove();
|
|
115
|
+
const bars = block.svg
|
|
116
|
+
.getChartGroup(chart.index)
|
|
117
|
+
.selectAll(`.${this.barItemClass}${Helper.getCssClassesLine(chart.cssClasses)}.chart-element-${index}`)
|
|
118
|
+
.filter((d) => newData.findIndex((row) => row[keyField.name] === d[keyField.name]) !== -1)
|
|
119
|
+
.style("opacity", 1)
|
|
120
|
+
.data(newData);
|
|
121
|
+
let newBars = bars
|
|
122
|
+
.enter()
|
|
123
|
+
.append("rect")
|
|
124
|
+
.attr("class", this.barItemClass)
|
|
125
|
+
.style("clip-path", `url(#${block.svg.getClipPathId()})`);
|
|
126
|
+
newBars = this.createBarPipeline.execute(newBars, chart);
|
|
127
|
+
const barAttrs = BarHelper.getGroupedBarAttrs(keyAxisOrient, scales, margin, keyField.name, valueField.name, chart.barViewOptions.barIndexes[index], sum(barsAmounts), barSettings);
|
|
128
|
+
const prom = this.fillBarAttrs(bars, barAttrs, block.transitionManager.durations.chartUpdate).then(() => {
|
|
129
|
+
bars.style("opacity", null);
|
|
130
|
+
this.setInitialAttrsInfo(bars, keyAxisOrient, barSettings);
|
|
131
|
+
});
|
|
132
|
+
this.fillBarAttrs(newBars, barAttrs);
|
|
133
|
+
promises.push(prom);
|
|
134
|
+
this.setInitialAttrsInfo(newBars, keyAxisOrient, barSettings);
|
|
135
|
+
DomHelper.setCssClasses(newBars, Helper.getCssClassesWithElementIndex(chart.cssClasses, index));
|
|
136
|
+
DomHelper.setChartStyle(newBars, chart.style, index, "fill");
|
|
137
|
+
if (chart.embeddedLabels !== "none") {
|
|
138
|
+
EmbeddedLabels.removeUnused(block, chart.cssClasses, index, indexesOfRemoved);
|
|
139
|
+
EmbeddedLabels.update(block, bars, keyAxisOrient, barAttrs, margin, valueField, chart.embeddedLabels, blockSize, newData, index, chart.cssClasses);
|
|
140
|
+
if (!newBars.empty())
|
|
141
|
+
EmbeddedLabels.render(block, newBars, barAttrs, valueField, chart.embeddedLabels, keyAxisOrient, blockSize, margin, index, chart.cssClasses);
|
|
142
|
+
EmbeddedLabels.restoreRemoved(block, bars, barAttrs, valueField, chart.embeddedLabels, keyAxisOrient, blockSize, margin, index, chart.cssClasses, keyField.name);
|
|
143
|
+
}
|
|
144
|
+
});
|
|
145
|
+
return promises;
|
|
146
|
+
}
|
|
147
|
+
updateSegmented(block, newData, scales, margin, keyAxisOrient, chart, barsAmounts, keyField, barSettings) {
|
|
148
|
+
const stackedData = getStackedDataWithOwn(newData, chart.data.valueFields.map((field) => field.name));
|
|
149
|
+
block.svg
|
|
150
|
+
.getChartGroup(chart.index)
|
|
151
|
+
.selectAll(`.${this.barItemClass}${Helper.getCssClassesLine(chart.cssClasses)}`)
|
|
152
|
+
.filter((d) => newData.findIndex((row) => row[keyField.name] === d.data[keyField.name]) === -1)
|
|
153
|
+
.transition()
|
|
154
|
+
.duration(block.transitionManager.durations.elementFadeOut)
|
|
155
|
+
.style("opacity", 0)
|
|
156
|
+
.remove();
|
|
157
|
+
const groups = block.svg
|
|
158
|
+
.getChartGroup(chart.index)
|
|
159
|
+
.selectAll(`g.${this.barSegmentGroupClass}${Helper.getCssClassesLine(chart.cssClasses)}`)
|
|
160
|
+
.data(stackedData);
|
|
161
|
+
const bars = groups
|
|
162
|
+
.selectAll(`.${this.barItemClass}${Helper.getCssClassesLine(chart.cssClasses)}`)
|
|
163
|
+
.filter((d) => newData.findIndex((row) => row[keyField.name] === d.data[keyField.name]) !== -1)
|
|
164
|
+
.style("opacity", 1)
|
|
165
|
+
.data((d) => d);
|
|
166
|
+
let newBars = bars
|
|
167
|
+
.enter()
|
|
168
|
+
.append("rect")
|
|
169
|
+
.attr("class", this.barItemClass)
|
|
170
|
+
.style("clip-path", `url(#${block.svg.getClipPathId()})`);
|
|
171
|
+
newBars = this.createBarPipeline.execute(newBars, chart);
|
|
172
|
+
const barAttrs = BarHelper.getStackedBarAttr(keyAxisOrient, scales, margin, keyField.name, chart.barViewOptions.barIndexes[0], sum(barsAmounts), barSettings);
|
|
173
|
+
const prom = this.fillBarAttrs(bars, barAttrs, block.transitionManager.durations.chartUpdate).then(() => {
|
|
174
|
+
this.setInitialAttrsInfo(bars, keyAxisOrient, barSettings);
|
|
175
|
+
bars.style("opacity", null);
|
|
176
|
+
});
|
|
177
|
+
this.fillBarAttrs(newBars, barAttrs);
|
|
178
|
+
this.setInitialAttrsInfo(newBars, keyAxisOrient, barSettings);
|
|
179
|
+
DomHelper.setCssClasses(newBars, chart.cssClasses);
|
|
180
|
+
const thisClass = this;
|
|
181
|
+
groups.each(function (d, i) {
|
|
182
|
+
const barsInGroup = select(this).selectAll(`rect${Helper.getCssClassesLine(chart.cssClasses)}`);
|
|
183
|
+
DomHelper.setCssClasses(barsInGroup, Helper.getCssClassesWithElementIndex(chart.cssClasses, i)); // Для обозначения принадлежности бара к конкретной части стака
|
|
184
|
+
thisClass.createSegmentGroupBarsPipeline.execute(barsInGroup, { segmentIndex: i, chart });
|
|
185
|
+
thisClass.setSegmentColor(select(this).selectAll(Helper.getCssClassesLine(chart.cssClasses)), chart.style.elementColors, i);
|
|
186
|
+
});
|
|
187
|
+
return [prom];
|
|
188
|
+
}
|
|
189
|
+
fillBarAttrs(bars, barAttrs, transitionDuration = 0) {
|
|
190
|
+
return new Promise((resolve) => {
|
|
191
|
+
if (bars.size() === 0) {
|
|
192
|
+
resolve("");
|
|
193
|
+
return;
|
|
194
|
+
}
|
|
195
|
+
let barsHandler = bars;
|
|
196
|
+
if (transitionDuration > 0) {
|
|
197
|
+
barsHandler = barsHandler
|
|
198
|
+
.interrupt()
|
|
199
|
+
.transition()
|
|
200
|
+
.duration(transitionDuration)
|
|
201
|
+
.on("end", () => resolve(""));
|
|
202
|
+
}
|
|
203
|
+
barsHandler
|
|
204
|
+
.attr("x", (d) => barAttrs.x(d))
|
|
205
|
+
.attr("y", (d) => barAttrs.y(d))
|
|
206
|
+
.attr("height", (d) => barAttrs.height(d))
|
|
207
|
+
.attr("width", (d) => barAttrs.width(d));
|
|
208
|
+
if (transitionDuration <= 0)
|
|
209
|
+
resolve("");
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
setSegmentColor(segments, colorPalette, segmentedIndex) {
|
|
213
|
+
segments.style("fill", colorPalette[segmentedIndex % colorPalette.length]);
|
|
214
|
+
}
|
|
215
|
+
/**
|
|
216
|
+
* Устнановка координат для удобного обновления.
|
|
217
|
+
*/
|
|
218
|
+
setInitialAttrsInfo(bars, keyAxisOrient, barSettings) {
|
|
219
|
+
bars.each(function () {
|
|
220
|
+
const width = DomHelper.getSelectionNumericAttr(select(this), "width");
|
|
221
|
+
const height = DomHelper.getSelectionNumericAttr(select(this), "height");
|
|
222
|
+
const orient = keyAxisOrient === "left" || keyAxisOrient === "right" ? "horizontal" : "vertical";
|
|
223
|
+
let scaleSize = 0.06 * (orient === "vertical" ? width : height);
|
|
224
|
+
scaleSize = scaleSize > barSettings.barDistance / 2 ? barSettings.barDistance / 2 : scaleSize;
|
|
225
|
+
this.attrs = {
|
|
226
|
+
x: DomHelper.getSelectionNumericAttr(select(this), "x"),
|
|
227
|
+
y: DomHelper.getSelectionNumericAttr(select(this), "y"),
|
|
228
|
+
width,
|
|
229
|
+
height,
|
|
230
|
+
orient,
|
|
231
|
+
scaleSize
|
|
232
|
+
};
|
|
233
|
+
});
|
|
234
|
+
}
|
|
373
235
|
}
|
|
374
236
|
Bar.barItemClass = "bar-item";
|