mdt-charts 1.28.1 → 1.29.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.
Files changed (255) hide show
  1. package/lib/config/config.d.ts +164 -165
  2. package/lib/designer/designerConfig.d.ts +62 -59
  3. package/lib/engine/block/block.d.ts +22 -16
  4. package/lib/engine/block/block.js +51 -51
  5. package/lib/engine/block/blockHelper.d.ts +6 -6
  6. package/lib/engine/block/blockHelper.js +16 -16
  7. package/lib/engine/block/blockHtml.d.ts +8 -8
  8. package/lib/engine/block/blockHtml.js +15 -15
  9. package/lib/engine/block/blockSvg.d.ts +20 -20
  10. package/lib/engine/block/blockSvg.js +65 -66
  11. package/lib/engine/block/defs/LinearGradientDef.d.ts +2 -2
  12. package/lib/engine/block/defs/LinearGradientDef.js +27 -27
  13. package/lib/engine/block/defs/hatchPattern.d.ts +4 -4
  14. package/lib/engine/block/defs/hatchPattern.js +9 -9
  15. package/lib/engine/colorReader/colorReader.d.ts +5 -5
  16. package/lib/engine/colorReader/colorReader.js +18 -18
  17. package/lib/engine/contentManager/contentManager.d.ts +6 -6
  18. package/lib/engine/contentManager/contentManager.js +15 -15
  19. package/lib/engine/contentManager/contentManagerFactory.d.ts +6 -6
  20. package/lib/engine/contentManager/contentManagerFactory.js +12 -12
  21. package/lib/engine/elementHighlighter/elementHighlighter.d.ts +70 -22
  22. package/lib/engine/elementHighlighter/elementHighlighter.js +230 -181
  23. package/lib/engine/elementHighlighter/selectHighlighter.d.ts +29 -4
  24. package/lib/engine/elementHighlighter/selectHighlighter.js +189 -87
  25. package/lib/engine/engine.d.ts +16 -16
  26. package/lib/engine/engine.js +87 -62
  27. package/lib/engine/features/aggregator/aggregator.d.ts +24 -17
  28. package/lib/engine/features/aggregator/aggregator.js +113 -102
  29. package/lib/engine/features/axis/axis.d.ts +22 -9
  30. package/lib/engine/features/axis/axis.js +159 -150
  31. package/lib/engine/features/axis/axisDomHelper.d.ts +7 -2
  32. package/lib/engine/features/axis/axisDomHelper.js +19 -20
  33. package/lib/engine/features/axis/axisHelper.d.ts +9 -5
  34. package/lib/engine/features/axis/axisHelper.js +28 -33
  35. package/lib/engine/features/axis/axisLabelDomHelper.d.ts +26 -11
  36. package/lib/engine/features/axis/axisLabelDomHelper.js +156 -152
  37. package/lib/engine/features/axis/axisLabelsEventManager.d.ts +2 -2
  38. package/lib/engine/features/axis/axisLabelsEventManager.js +32 -32
  39. package/lib/engine/features/embeddedLabels/embeddedLabels.d.ts +51 -16
  40. package/lib/engine/features/embeddedLabels/embeddedLabels.js +234 -134
  41. package/lib/engine/features/embeddedLabels/embeddedLabelsDomHelper.d.ts +13 -2
  42. package/lib/engine/features/embeddedLabels/embeddedLabelsDomHelper.js +20 -23
  43. package/lib/engine/features/embeddedLabels/embeddedLabelsHelper.d.ts +32 -15
  44. package/lib/engine/features/embeddedLabels/embeddedLabelsHelper.js +56 -63
  45. package/lib/engine/features/gridLine/gidLineHelper.d.ts +13 -7
  46. package/lib/engine/features/gridLine/gidLineHelper.js +42 -49
  47. package/lib/engine/features/gridLine/gridLine.d.ts +19 -5
  48. package/lib/engine/features/gridLine/gridLine.js +35 -36
  49. package/lib/engine/features/legend/legend.d.ts +38 -29
  50. package/lib/engine/features/legend/legend.js +117 -92
  51. package/lib/engine/features/legend/legendDomHelper.d.ts +13 -6
  52. package/lib/engine/features/legend/legendDomHelper.js +63 -62
  53. package/lib/engine/features/legend/legendEventsManager.d.ts +13 -8
  54. package/lib/engine/features/legend/legendEventsManager.js +48 -47
  55. package/lib/engine/features/legend/legendHelper.d.ts +39 -14
  56. package/lib/engine/features/legend/legendHelper.js +98 -93
  57. package/lib/engine/features/legend/legendHelperService.d.ts +13 -6
  58. package/lib/engine/features/legend/legendHelperService.js +24 -25
  59. package/lib/engine/features/legend/legendMarkerCreator.d.ts +18 -9
  60. package/lib/engine/features/legend/legendMarkerCreator.js +79 -76
  61. package/lib/engine/features/legend/legendWidthCalculator.d.ts +7 -7
  62. package/lib/engine/features/legend/legendWidthCalculator.js +126 -122
  63. package/lib/engine/features/markDots/markDot.d.ts +42 -15
  64. package/lib/engine/features/markDots/markDot.js +101 -70
  65. package/lib/engine/features/markDots/markDotsHelper.d.ts +8 -1
  66. package/lib/engine/features/markDots/markDotsHelper.js +13 -12
  67. package/lib/engine/features/recordOverflowAlert/recordOverflowAlertCore.d.ts +17 -17
  68. package/lib/engine/features/recordOverflowAlert/recordOverflowAlertCore.js +42 -47
  69. package/lib/engine/features/scale/scale.d.ts +17 -12
  70. package/lib/engine/features/scale/scale.js +76 -69
  71. package/lib/engine/features/tipBox/tipBox.d.ts +9 -5
  72. package/lib/engine/features/tipBox/tipBox.js +24 -24
  73. package/lib/engine/features/tipBox/tipBoxHelper.d.ts +16 -9
  74. package/lib/engine/features/tipBox/tipBoxHelper.js +60 -45
  75. package/lib/engine/features/title/title.d.ts +6 -6
  76. package/lib/engine/features/title/title.js +34 -35
  77. package/lib/engine/features/tolltip/newTooltip/newTooltip.d.ts +15 -11
  78. package/lib/engine/features/tolltip/newTooltip/newTooltip.js +21 -21
  79. package/lib/engine/features/tolltip/newTooltip/newTooltipService.d.ts +13 -8
  80. package/lib/engine/features/tolltip/newTooltip/newTooltipService.js +26 -23
  81. package/lib/engine/features/tolltip/tooltip.d.ts +17 -11
  82. package/lib/engine/features/tolltip/tooltip.js +296 -142
  83. package/lib/engine/features/tolltip/tooltipComponentsManager.d.ts +21 -10
  84. package/lib/engine/features/tolltip/tooltipComponentsManager.js +113 -114
  85. package/lib/engine/features/tolltip/tooltipDomHelper.d.ts +43 -21
  86. package/lib/engine/features/tolltip/tooltipDomHelper.js +144 -120
  87. package/lib/engine/features/tolltip/tooltipHelper.d.ts +39 -9
  88. package/lib/engine/features/tolltip/tooltipHelper.js +114 -91
  89. package/lib/engine/features/valueLabels/valueLabels.d.ts +58 -38
  90. package/lib/engine/features/valueLabels/valueLabels.js +205 -169
  91. package/lib/engine/features/valueLabels/valueLabelsHelper.d.ts +7 -1
  92. package/lib/engine/features/valueLabels/valueLabelsHelper.js +23 -18
  93. package/lib/engine/features/valueLabelsCollision/valueLabelsCollision.d.ts +18 -15
  94. package/lib/engine/features/valueLabelsCollision/valueLabelsCollision.js +46 -47
  95. package/lib/engine/features/valueLabelsCollision/valueLabelsCollisionHelper.d.ts +6 -3
  96. package/lib/engine/features/valueLabelsCollision/valueLabelsCollisionHelper.js +49 -45
  97. package/lib/engine/filterManager/filterEventManager.d.ts +37 -26
  98. package/lib/engine/filterManager/filterEventManager.js +174 -129
  99. package/lib/engine/helpers/domHelper.d.ts +45 -20
  100. package/lib/engine/helpers/domHelper.js +62 -61
  101. package/lib/engine/helpers/fontResizer/fontResizer.d.ts +10 -10
  102. package/lib/engine/helpers/fontResizer/fontResizer.js +21 -16
  103. package/lib/engine/helpers/fontResizer/fontResizerService.d.ts +1 -1
  104. package/lib/engine/helpers/fontResizer/fontResizerService.js +9 -10
  105. package/lib/engine/helpers/helper.d.ts +27 -27
  106. package/lib/engine/helpers/helper.js +91 -92
  107. package/lib/engine/helpers/namesHelper.d.ts +3 -3
  108. package/lib/engine/helpers/namesHelper.js +6 -6
  109. package/lib/engine/helpers/pipeline/Pipeline.d.ts +5 -5
  110. package/lib/engine/helpers/pipeline/Pipeline.js +33 -33
  111. package/lib/engine/polarNotation/donut/DonutHelper.d.ts +25 -11
  112. package/lib/engine/polarNotation/donut/DonutHelper.js +71 -70
  113. package/lib/engine/polarNotation/donut/donut.d.ts +38 -23
  114. package/lib/engine/polarNotation/donut/donut.js +109 -99
  115. package/lib/engine/polarNotation/extenders/polarRecordOverflowAlert.d.ts +7 -7
  116. package/lib/engine/polarNotation/extenders/polarRecordOverflowAlert.js +36 -36
  117. package/lib/engine/polarNotation/polarManager.d.ts +5 -5
  118. package/lib/engine/polarNotation/polarManager.js +66 -52
  119. package/lib/engine/transitionManager.d.ts +13 -14
  120. package/lib/engine/transitionManager.js +48 -49
  121. package/lib/engine/twoDimensionalNotation/area/area.d.ts +44 -28
  122. package/lib/engine/twoDimensionalNotation/area/area.js +272 -238
  123. package/lib/engine/twoDimensionalNotation/area/areaGenerator.d.ts +13 -5
  124. package/lib/engine/twoDimensionalNotation/area/areaGenerator.js +13 -13
  125. package/lib/engine/twoDimensionalNotation/area/areaHelper.d.ts +4 -4
  126. package/lib/engine/twoDimensionalNotation/area/areaHelper.js +57 -41
  127. package/lib/engine/twoDimensionalNotation/bar/bar.d.ts +54 -29
  128. package/lib/engine/twoDimensionalNotation/bar/bar.js +362 -224
  129. package/lib/engine/twoDimensionalNotation/bar/barHelper.d.ts +71 -32
  130. package/lib/engine/twoDimensionalNotation/bar/barHelper.js +162 -126
  131. package/lib/engine/twoDimensionalNotation/bar/stackedData/dataStacker.d.ts +6 -6
  132. package/lib/engine/twoDimensionalNotation/bar/stackedData/dataStacker.js +24 -24
  133. package/lib/engine/twoDimensionalNotation/bar/stackedData/dataStackerService.d.ts +2 -2
  134. package/lib/engine/twoDimensionalNotation/bar/stackedData/dataStackerService.js +16 -17
  135. package/lib/engine/twoDimensionalNotation/dot/dotChart.d.ts +23 -23
  136. package/lib/engine/twoDimensionalNotation/dot/dotChart.js +135 -114
  137. package/lib/engine/twoDimensionalNotation/extenders/twoDimRecordOverflowAlert.d.ts +7 -7
  138. package/lib/engine/twoDimensionalNotation/extenders/twoDimRecordOverflowAlert.js +28 -28
  139. package/lib/engine/twoDimensionalNotation/line/line.d.ts +37 -16
  140. package/lib/engine/twoDimensionalNotation/line/line.js +162 -132
  141. package/lib/engine/twoDimensionalNotation/line/lineBuilder.d.ts +14 -11
  142. package/lib/engine/twoDimensionalNotation/line/lineBuilder.js +47 -48
  143. package/lib/engine/twoDimensionalNotation/line/lineGenerator.d.ts +4 -4
  144. package/lib/engine/twoDimensionalNotation/line/lineGenerator.js +8 -8
  145. package/lib/engine/twoDimensionalNotation/line/lineHelper.d.ts +12 -6
  146. package/lib/engine/twoDimensionalNotation/line/lineHelper.js +76 -60
  147. package/lib/engine/twoDimensionalNotation/lineLike/generatorFactory/lineLikeGeneratorFactory.d.ts +6 -6
  148. package/lib/engine/twoDimensionalNotation/lineLike/generatorMiddleware/lineLikeGeneratorCurveMiddleware.d.ts +5 -5
  149. package/lib/engine/twoDimensionalNotation/lineLike/generatorMiddleware/lineLikeGeneratorCurveMiddleware.js +16 -17
  150. package/lib/engine/twoDimensionalNotation/lineLike/generatorMiddleware/lineLikeGeneratorDefineMiddleware.d.ts +11 -10
  151. package/lib/engine/twoDimensionalNotation/lineLike/generatorMiddleware/lineLikeGeneratorDefineMiddleware.js +9 -7
  152. package/lib/engine/twoDimensionalNotation/lineLike/generatorMiddleware/lineLikeGeneratorMiddleware.d.ts +3 -1
  153. package/lib/engine/twoDimensionalNotation/twoDimensionalManager.d.ts +9 -9
  154. package/lib/engine/twoDimensionalNotation/twoDimensionalManager.js +252 -143
  155. package/lib/engine/valueFormatter.d.ts +3 -3
  156. package/lib/engine/valueFormatter.js +6 -6
  157. package/lib/main.d.ts +82 -75
  158. package/lib/main.js +79 -84
  159. package/lib/model/EventEmitter.d.ts +8 -8
  160. package/lib/model/EventEmitter.js +24 -24
  161. package/lib/model/chartStyleModel/chartStyleModel.d.ts +5 -5
  162. package/lib/model/chartStyleModel/chartStyleModel.js +27 -25
  163. package/lib/model/chartStyleModel/colorRange.d.ts +3 -3
  164. package/lib/model/chartStyleModel/colorRange.js +19 -24
  165. package/lib/model/chartStyleModel/twoDimensionalChartStyleModel.d.ts +22 -12
  166. package/lib/model/chartStyleModel/twoDimensionalChartStyleModel.js +69 -60
  167. package/lib/model/configsValidator/configValidator.d.ts +1 -1
  168. package/lib/model/configsValidator/configValidator.js +4 -4
  169. package/lib/model/dataManagerModel/dataManagerModel.d.ts +36 -26
  170. package/lib/model/dataManagerModel/dataManagerModel.js +179 -128
  171. package/lib/model/dataManagerModel/dataManagerModelService.d.ts +2 -2
  172. package/lib/model/dataManagerModel/dataManagerModelService.js +25 -26
  173. package/lib/model/featuresModel/axisModel.d.ts +69 -18
  174. package/lib/model/featuresModel/axisModel.js +224 -169
  175. package/lib/model/featuresModel/axisModelService.d.ts +10 -6
  176. package/lib/model/featuresModel/axisModelService.js +27 -27
  177. package/lib/model/featuresModel/legendModel/legendCanvasModel.d.ts +16 -11
  178. package/lib/model/featuresModel/legendModel/legendCanvasModel.js +55 -59
  179. package/lib/model/featuresModel/legendModel/legendModel.d.ts +7 -3
  180. package/lib/model/featuresModel/legendModel/legendModel.js +59 -41
  181. package/lib/model/featuresModel/legendModel/polarMarginCalculator.d.ts +8 -3
  182. package/lib/model/featuresModel/legendModel/polarMarginCalculator.js +18 -20
  183. package/lib/model/featuresModel/legendModel/twoDimLegendModel.d.ts +8 -4
  184. package/lib/model/featuresModel/legendModel/twoDimLegendModel.js +40 -27
  185. package/lib/model/featuresModel/otherComponents.d.ts +7 -4
  186. package/lib/model/featuresModel/otherComponents.js +9 -9
  187. package/lib/model/featuresModel/scaleModel/scaleAxisRecalcer.d.ts +6 -6
  188. package/lib/model/featuresModel/scaleModel/scaleAxisRecalcer.js +27 -23
  189. package/lib/model/featuresModel/scaleModel/scaleDomainService.d.ts +19 -5
  190. package/lib/model/featuresModel/scaleModel/scaleDomainService.js +44 -55
  191. package/lib/model/featuresModel/scaleModel/scaleModel.d.ts +10 -10
  192. package/lib/model/featuresModel/scaleModel/scaleModel.js +61 -50
  193. package/lib/model/featuresModel/scaleModel/scaleModelServices.js +15 -22
  194. package/lib/model/featuresModel/titleModel.d.ts +1 -1
  195. package/lib/model/featuresModel/titleModel.js +14 -14
  196. package/lib/model/featuresModel/tooltipModel.d.ts +1 -1
  197. package/lib/model/featuresModel/tooltipModel.js +5 -5
  198. package/lib/model/featuresModel/valueLabelsModel/valueLabelsModel.d.ts +23 -11
  199. package/lib/model/featuresModel/valueLabelsModel/valueLabelsModel.js +53 -51
  200. package/lib/model/helpers/modelHelper.d.ts +7 -7
  201. package/lib/model/helpers/modelHelper.js +38 -42
  202. package/lib/model/helpers/twoDimensionalModelHelper.d.ts +37 -9
  203. package/lib/model/helpers/twoDimensionalModelHelper.js +147 -125
  204. package/lib/model/helpers/unitsFromConfigReader.js +4 -4
  205. package/lib/model/helpers/unitsReader.d.ts +2 -2
  206. package/lib/model/helpers/unitsReader.js +11 -13
  207. package/lib/model/margin/marginModel.d.ts +7 -7
  208. package/lib/model/margin/marginModel.js +23 -20
  209. package/lib/model/margin/twoDim/twoDimMarginModel.d.ts +13 -13
  210. package/lib/model/margin/twoDim/twoDimMarginModel.js +184 -113
  211. package/lib/model/model.d.ts +308 -280
  212. package/lib/model/model.js +4 -4
  213. package/lib/model/modelBuilder.d.ts +27 -18
  214. package/lib/model/modelBuilder.js +85 -79
  215. package/lib/model/modelInstance/canvasModel/canvasModel.d.ts +17 -17
  216. package/lib/model/modelInstance/canvasModel/canvasModel.js +42 -43
  217. package/lib/model/modelInstance/canvasModel/canvasSizesModel/canvasMarginModel.d.ts +7 -7
  218. package/lib/model/modelInstance/canvasModel/canvasSizesModel/canvasSizeModel.d.ts +2 -2
  219. package/lib/model/modelInstance/canvasModel/canvasSizesModel/marginModelService.d.ts +6 -6
  220. package/lib/model/modelInstance/canvasModel/canvasSizesModel/marginModelService.js +24 -24
  221. package/lib/model/modelInstance/canvasModel/legendCanvasModel.d.ts +4 -4
  222. package/lib/model/modelInstance/canvasModel/legendCanvasModel.js +11 -11
  223. package/lib/model/modelInstance/canvasModel/titleCanvas.d.ts +4 -4
  224. package/lib/model/modelInstance/canvasModel/titleCanvas.js +9 -9
  225. package/lib/model/modelInstance/chartBlockVersion/chartBlockVersion.d.ts +3 -3
  226. package/lib/model/modelInstance/chartBlockVersion/chartBlockVersion.js +6 -6
  227. package/lib/model/modelInstance/configReader.d.ts +32 -23
  228. package/lib/model/modelInstance/configReader.js +125 -94
  229. package/lib/model/modelInstance/dataModel/dataModel.d.ts +9 -9
  230. package/lib/model/modelInstance/dataModel/dataModel.js +24 -24
  231. package/lib/model/modelInstance/dataModel/dataRepository.d.ts +14 -14
  232. package/lib/model/modelInstance/dataModel/dataRepository.js +42 -42
  233. package/lib/model/modelInstance/modelInstance.d.ts +11 -6
  234. package/lib/model/modelInstance/modelInstance.js +16 -16
  235. package/lib/model/modelInstance/titleConfigReader.d.ts +8 -8
  236. package/lib/model/modelInstance/titleConfigReader.js +37 -30
  237. package/lib/model/notations/polar/donut/donutAggregatorService.d.ts +9 -6
  238. package/lib/model/notations/polar/donut/donutAggregatorService.js +40 -37
  239. package/lib/model/notations/polar/donut/donutModel.d.ts +9 -5
  240. package/lib/model/notations/polar/donut/donutModel.js +28 -28
  241. package/lib/model/notations/polar/donut/donutThicknessService.d.ts +3 -3
  242. package/lib/model/notations/polar/donut/donutThicknessService.js +13 -15
  243. package/lib/model/notations/polar/polarModel.d.ts +18 -7
  244. package/lib/model/notations/polar/polarModel.js +79 -65
  245. package/lib/model/notations/twoDimensional/styles.d.ts +44 -7
  246. package/lib/model/notations/twoDimensional/styles.js +234 -125
  247. package/lib/model/notations/twoDimensionalModel.d.ts +23 -13
  248. package/lib/model/notations/twoDimensionalModel.js +330 -162
  249. package/lib/optionsServices/publicOptionsService.d.ts +1 -1
  250. package/lib/optionsServices/publicOptionsService.js +4 -4
  251. package/lib/optionsServices/validators/sizeValidator.d.ts +2 -2
  252. package/lib/optionsServices/validators/sizeValidator.js +10 -11
  253. package/lib/style/charts-main.css +150 -151
  254. package/lib/style/charts-main.less +150 -151
  255. package/package.json +1 -1
@@ -1,22 +1,21 @@
1
1
  export class AxisDomHelper {
2
- static updateAxisElement(axisGenerator, axisElement, translate, transitionDuration = 0) {
3
- return new Promise((resolve) => {
4
- let axisHandler = axisElement;
5
- if (transitionDuration > 0) {
6
- axisHandler = axisHandler
7
- .interrupt()
8
- .transition()
9
- .duration(transitionDuration)
10
- .on("end", () => resolve("updated"));
11
- }
12
- axisHandler
13
- .attr("transform", `translate(${translate.translateX}, ${translate.translateY})`)
14
- .call(axisGenerator.bind(this));
15
- if (transitionDuration <= 0)
16
- resolve("updated");
17
- });
18
- }
19
- static rotateElementsBack(axisElement) {
20
- axisElement.selectAll(".tick text").attr("transform", null).attr("text-anchor", "middle").attr("x", null);
21
- }
2
+ static updateAxisElement(axisGenerator, axisElement, translate, transitionDuration = 0) {
3
+ return new Promise((resolve) => {
4
+ let axisHandler = axisElement;
5
+ if (transitionDuration > 0) {
6
+ axisHandler = axisHandler
7
+ .interrupt()
8
+ .transition()
9
+ .duration(transitionDuration)
10
+ .on("end", () => resolve("updated"));
11
+ }
12
+ axisHandler
13
+ .attr("transform", `translate(${translate.translateX}, ${translate.translateY})`)
14
+ .call(axisGenerator.bind(this));
15
+ if (transitionDuration <= 0) resolve("updated");
16
+ });
17
+ }
18
+ static rotateElementsBack(axisElement) {
19
+ axisElement.selectAll(".tick text").attr("transform", null).attr("text-anchor", "middle").attr("x", null);
20
+ }
22
21
  }
@@ -1,9 +1,13 @@
1
1
  import { AxisScale, Axis as IAxis } from "d3-axis";
2
2
  import { AxisLabelModel, AxisModelOptions, Orient, ScaleValueModel } from "../../../model/model";
3
3
  export declare class AxisHelper {
4
- static getAxisByOrient(orient: Orient, scale: AxisScale<any>): IAxis<any>;
5
- static setValueAxisLabelsSettings(axisGenerator: IAxis<any>, scaleOptions: ScaleValueModel, labelsOptions: AxisLabelModel): void;
6
- static getBaseAxisGenerator(axisOptions: AxisModelOptions, scale: AxisScale<any>): IAxis<any>;
7
- private static removeTicks;
8
- private static setNumTickFormat;
4
+ static getAxisByOrient(orient: Orient, scale: AxisScale<any>): IAxis<any>;
5
+ static setValueAxisLabelsSettings(
6
+ axisGenerator: IAxis<any>,
7
+ scaleOptions: ScaleValueModel,
8
+ labelsOptions: AxisLabelModel
9
+ ): void;
10
+ static getBaseAxisGenerator(axisOptions: AxisModelOptions, scale: AxisScale<any>): IAxis<any>;
11
+ private static removeTicks;
12
+ private static setNumTickFormat;
9
13
  }
@@ -2,37 +2,32 @@ import { axisTop, axisBottom, axisLeft, axisRight } from "d3-axis";
2
2
  import { format } from "d3-format";
3
3
  import { AxisLabelHelper } from "./axisLabelDomHelper";
4
4
  export class AxisHelper {
5
- static getAxisByOrient(orient, scale) {
6
- if (orient === "top")
7
- return axisTop(scale);
8
- if (orient === "bottom")
9
- return axisBottom(scale);
10
- if (orient === "left")
11
- return axisLeft(scale);
12
- if (orient === "right")
13
- return axisRight(scale);
14
- }
15
- static setValueAxisLabelsSettings(axisGenerator, scaleOptions, labelsOptions) {
16
- if (labelsOptions.tickAmountSettings.policy.type === "amount")
17
- axisGenerator.ticks(labelsOptions.tickAmountSettings.policy.amount);
18
- if (labelsOptions.tickAmountSettings.policy.type === "constant")
19
- axisGenerator.tickValues(labelsOptions.tickAmountSettings.policy.values);
20
- if (scaleOptions.type === "linear") {
21
- this.setNumTickFormat(axisGenerator, scaleOptions.formatter);
22
- }
23
- }
24
- static getBaseAxisGenerator(axisOptions, scale) {
25
- const axisGenerator = AxisHelper.getAxisByOrient(axisOptions.orient, scale);
26
- if (!axisOptions.ticks.flag)
27
- this.removeTicks(axisGenerator);
28
- AxisLabelHelper.setAxisLabelPaddingByOrient(axisGenerator, axisOptions);
29
- return axisGenerator;
30
- }
31
- static removeTicks(axis) {
32
- axis.tickSize(0);
33
- }
34
- static setNumTickFormat(axis, formatter) {
35
- const defaultFormatter = format("~s");
36
- axis.tickFormat(formatter !== null && formatter !== void 0 ? formatter : defaultFormatter);
37
- }
5
+ static getAxisByOrient(orient, scale) {
6
+ if (orient === "top") return axisTop(scale);
7
+ if (orient === "bottom") return axisBottom(scale);
8
+ if (orient === "left") return axisLeft(scale);
9
+ if (orient === "right") return axisRight(scale);
10
+ }
11
+ static setValueAxisLabelsSettings(axisGenerator, scaleOptions, labelsOptions) {
12
+ if (labelsOptions.tickAmountSettings.policy.type === "amount")
13
+ axisGenerator.ticks(labelsOptions.tickAmountSettings.policy.amount);
14
+ if (labelsOptions.tickAmountSettings.policy.type === "constant")
15
+ axisGenerator.tickValues(labelsOptions.tickAmountSettings.policy.values);
16
+ if (scaleOptions.type === "linear") {
17
+ this.setNumTickFormat(axisGenerator, scaleOptions.formatter);
18
+ }
19
+ }
20
+ static getBaseAxisGenerator(axisOptions, scale) {
21
+ const axisGenerator = AxisHelper.getAxisByOrient(axisOptions.orient, scale);
22
+ if (!axisOptions.ticks.flag) this.removeTicks(axisGenerator);
23
+ AxisLabelHelper.setAxisLabelPaddingByOrient(axisGenerator, axisOptions);
24
+ return axisGenerator;
25
+ }
26
+ static removeTicks(axis) {
27
+ axis.tickSize(0);
28
+ }
29
+ static setNumTickFormat(axis, formatter) {
30
+ const defaultFormatter = format("~s");
31
+ axis.tickFormat(formatter !== null && formatter !== void 0 ? formatter : defaultFormatter);
32
+ }
38
33
  }
@@ -4,15 +4,30 @@ import { AxisModelOptions, Orient, ScaleKeyModel, ScaleValueModel } from "../../
4
4
  import { Block } from "../../block/block";
5
5
  import { Size } from "../../../config/config";
6
6
  export declare class AxisLabelHelper {
7
- static setTitles(axisElement: Selection<SVGGElement, unknown, BaseType, any>, axisOptions: AxisModelOptions): void;
8
- static setAxisLabelPaddingByOrient(axis: IAxis<any>, axisOptions: AxisModelOptions): void;
9
- static rotateLabels(axisElement: Selection<SVGGElement, unknown, HTMLElement, any>, keyAxisOrient: Orient): void;
10
- static cropLabels(block: Block, scale: AxisScale<any>, scaleOptions: ScaleKeyModel | ScaleValueModel, axisOptions: AxisModelOptions, blockSize: Size): void;
11
- static hideLabels(axisElement: Selection<SVGGElement, unknown, BaseType, unknown>): void;
12
- static alignLabelsInKeyAxis(axisOptions: AxisModelOptions, axisElement: Selection<SVGGElement, unknown, HTMLElement, any>): void;
13
- private static alignLabelsInVerticalAxis;
14
- static alignHorizontalAxisLastLabel(block: Block, maxLabelSize: number, axisOptions: AxisModelOptions, blockSize: Size, crop: boolean): void;
15
- private static cropAndAlignExtremeLabels;
16
- private static getTranslateNumber;
17
- static wrapHandler(textBlocks: Selection<SVGGElement, unknown, BaseType, any>, maxWidth: number): void;
7
+ static setTitles(axisElement: Selection<SVGGElement, unknown, BaseType, any>, axisOptions: AxisModelOptions): void;
8
+ static setAxisLabelPaddingByOrient(axis: IAxis<any>, axisOptions: AxisModelOptions): void;
9
+ static rotateLabels(axisElement: Selection<SVGGElement, unknown, HTMLElement, any>, keyAxisOrient: Orient): void;
10
+ static cropLabels(
11
+ block: Block,
12
+ scale: AxisScale<any>,
13
+ scaleOptions: ScaleKeyModel | ScaleValueModel,
14
+ axisOptions: AxisModelOptions,
15
+ blockSize: Size
16
+ ): void;
17
+ static hideLabels(axisElement: Selection<SVGGElement, unknown, BaseType, unknown>): void;
18
+ static alignLabelsInKeyAxis(
19
+ axisOptions: AxisModelOptions,
20
+ axisElement: Selection<SVGGElement, unknown, HTMLElement, any>
21
+ ): void;
22
+ private static alignLabelsInVerticalAxis;
23
+ static alignHorizontalAxisLastLabel(
24
+ block: Block,
25
+ maxLabelSize: number,
26
+ axisOptions: AxisModelOptions,
27
+ blockSize: Size,
28
+ crop: boolean
29
+ ): void;
30
+ private static cropAndAlignExtremeLabels;
31
+ private static getTranslateNumber;
32
+ static wrapHandler(textBlocks: Selection<SVGGElement, unknown, BaseType, any>, maxWidth: number): void;
18
33
  }
@@ -1,157 +1,161 @@
1
1
  import { select } from "d3-selection";
2
2
  import { DomHelper } from "../../helpers/domHelper";
3
3
  import { Helper } from "../../helpers/helper";
4
- import { AXIS_HORIZONTAL_LABEL_PADDING, AXIS_VERTICAL_LABEL_PADDING } from "../../../model/margin/twoDim/twoDimMarginModel";
4
+ import {
5
+ AXIS_HORIZONTAL_LABEL_PADDING,
6
+ AXIS_VERTICAL_LABEL_PADDING
7
+ } from "../../../model/margin/twoDim/twoDimMarginModel";
5
8
  export class AxisLabelHelper {
6
- static setTitles(axisElement, axisOptions) {
7
- axisElement.selectAll(".tick text").each(function (d, i) {
8
- const tickTitle = select(this).select("title");
9
- if (tickTitle.empty())
10
- select(this).append("title").text(axisOptions.browserTooltip.format(d));
11
- else {
12
- tickTitle.text(axisOptions.browserTooltip.format(d));
13
- }
14
- });
15
- }
16
- static setAxisLabelPaddingByOrient(axis, axisOptions) {
17
- let axisLabelPadding = AXIS_HORIZONTAL_LABEL_PADDING;
18
- if (axisOptions.orient === "left" || axisOptions.orient === "right")
19
- axisLabelPadding = AXIS_VERTICAL_LABEL_PADDING;
20
- axis.tickPadding(axisLabelPadding);
21
- }
22
- static rotateLabels(axisElement, keyAxisOrient) {
23
- const labelBlocks = axisElement.selectAll("text");
24
- labelBlocks.attr("transform", "rotate(-90)");
25
- if (keyAxisOrient === "bottom") {
26
- labelBlocks.attr("text-anchor", "end").attr("x", -AXIS_HORIZONTAL_LABEL_PADDING).attr("y", -4);
27
- }
28
- else if (keyAxisOrient === "top") {
29
- labelBlocks.attr("text-anchor", "start").attr("x", AXIS_HORIZONTAL_LABEL_PADDING).attr("y", 6);
30
- }
31
- }
32
- static cropLabels(block, scale, scaleOptions, axisOptions, blockSize) {
33
- var _a, _b, _c;
34
- const axisTextBlocks = block
35
- .getSvg()
36
- .select(`.${axisOptions.cssClass}`)
37
- .selectAll("text");
38
- let maxLabelSize;
39
- if (axisOptions.orient === "left" ||
40
- axisOptions.orient === "right" ||
41
- (axisOptions.type === "key" && axisOptions.labels.position === "rotated"))
42
- maxLabelSize = axisOptions.labels.maxSize;
43
- else
44
- maxLabelSize = ((_c = (_b = (_a = scale).step) === null || _b === void 0 ? void 0 : _b.call(_a)) !== null && _c !== void 0 ? _c : Infinity) - 4;
45
- DomHelper.cropSvgLabels(axisTextBlocks, maxLabelSize);
46
- if (axisOptions.labels.position === "straight" &&
47
- (axisOptions.orient === "top" || axisOptions.orient === "bottom")) {
48
- this.cropAndAlignExtremeLabels(block, maxLabelSize, axisOptions, blockSize);
49
- }
50
- }
51
- static hideLabels(axisElement) {
52
- axisElement.selectAll(".tick text").style("display", "none");
53
- }
54
- static alignLabelsInKeyAxis(axisOptions, axisElement) {
55
- if (axisOptions.orient === "left")
56
- this.alignLabelsInVerticalAxis(axisElement, "start", axisOptions.labels.maxSize, true);
57
- else if (axisOptions.orient === "right")
58
- this.alignLabelsInVerticalAxis(axisElement, "start", axisOptions.labels.maxSize, false);
59
- }
60
- static alignLabelsInVerticalAxis(axisElement, anchor, maxLabelSize, changeCoordinate) {
61
- const axisTextBlocks = axisElement.selectAll("text");
62
- const spans = axisElement.selectAll("tspan");
63
- axisTextBlocks.attr("text-anchor", anchor);
64
- spans.attr("text-anchor", anchor);
65
- if (changeCoordinate) {
66
- axisTextBlocks.attr("x", -(maxLabelSize + AXIS_VERTICAL_LABEL_PADDING));
67
- spans.attr("x", -(maxLabelSize + AXIS_VERTICAL_LABEL_PADDING));
68
- }
69
- else {
70
- spans.attr("x", AXIS_VERTICAL_LABEL_PADDING);
71
- }
72
- }
73
- static alignHorizontalAxisLastLabel(block, maxLabelSize, axisOptions, blockSize, crop) {
74
- const lastTick = block
75
- .getSvg()
76
- .select(`.${axisOptions.cssClass}`)
77
- .select(".tick:last-of-type");
78
- const lastLabel = lastTick.select("text");
79
- if (lastTick.empty() || lastTick.size() === 0 || lastLabel.size() === 0)
80
- return;
81
- const tickTranslateX = Helper.getTranslateNumbers(lastTick.attr("transform"))[0];
82
- const marginRight = blockSize.width - axisOptions.translate.translateX - tickTranslateX;
83
- if (tickTranslateX + lastLabel.node().getBBox().width + axisOptions.translate.translateX > blockSize.width) {
84
- lastLabel.attr("text-anchor", "start");
85
- lastLabel.attr("transform", `translate(${this.getTranslateNumber(maxLabelSize, lastLabel, marginRight)}, 0)`);
86
- if (crop)
87
- DomHelper.cropSvgLabels(lastLabel, maxLabelSize / 2 + marginRight);
88
- }
89
- }
90
- static cropAndAlignExtremeLabels(block, maxLabelSize, axisOptions, blockSize) {
91
- this.alignHorizontalAxisLastLabel(block, maxLabelSize, axisOptions, blockSize, true);
92
- const firstLabel = block
93
- .getSvg()
94
- .select(`.${axisOptions.cssClass}`)
95
- .select(".tick:first-of-type")
96
- .select("text");
97
- if (firstLabel.empty())
98
- return;
99
- const axisElementTranslate = Helper.getTranslateNumbers(block.getSvg().select(`.${axisOptions.cssClass}`).attr("transform"))[0];
100
- if (axisOptions.translate.translateX - firstLabel.node().getBBox().width / 2 < 0) {
101
- firstLabel.attr("text-anchor", "start");
102
- firstLabel.attr("transform", `translate(${-axisOptions.translate.translateX}, 0)`);
103
- DomHelper.cropSvgLabels(firstLabel, maxLabelSize / 2 + axisElementTranslate);
104
- }
105
- }
106
- static getTranslateNumber(maxLabelSize, lastLabel, marginRight) {
107
- if (maxLabelSize / 2 > lastLabel.node().getBBox().width)
108
- return -(lastLabel.node().getBBox().width - marginRight);
109
- return -maxLabelSize / 2;
110
- // return -Math.min(maxLabelSize / 2, lastLabel.node().getBBox().width - marginRight)
111
- }
112
- static wrapHandler(textBlocks, maxWidth) {
113
- textBlocks.each(function () {
114
- let textBlock = select(this);
115
- if (!textBlock.selectAll("tspan").empty())
116
- return;
117
- textBlock.select("title").remove();
118
- let textContent = textBlock.text();
119
- if (textBlock.node().getBBox().width > maxWidth) {
120
- let letters = textBlock.text().split("").reverse(), // split text to letters.
121
- letter, line = [], // one line. letters from this var into tpsans.
122
- lineNumber = 0, dy = 1.4, tspan = textBlock
123
- .text(null)
124
- .append("tspan")
125
- .attr("dy", dy + "em");
126
- while ((letter = letters.pop())) {
127
- line.push(letter);
128
- tspan.text(line.join(""));
129
- if (tspan.node().getComputedTextLength() > maxWidth && line.length > 1 && letters.length > 0) {
130
- line.pop();
131
- tspan.text(line.join(""));
132
- if (lineNumber === 0 && line[line.length - 1] !== " ")
133
- tspan.text(tspan.text() + "-");
134
- line = [letter];
135
- if (lineNumber >= 1) {
136
- // If text block has 2 lines, text cropped.
137
- if (letters.length > 0)
138
- tspan.text(tspan.text().substr(0, tspan.text().length - 1) + "...");
139
- break;
140
- }
141
- tspan = textBlock
142
- .append("tspan")
143
- .attr("dy", dy * lineNumber + 1 + "em")
144
- .text(letter);
145
- lineNumber++;
146
- }
147
- }
148
- if (textBlock.selectAll("tspan").size() === 1) {
149
- textBlock.text(textContent).attr("y", null);
150
- }
151
- if (!textBlock.selectAll("tspan").empty()) {
152
- textBlock.attr("y", -(textBlock.node().getBBox().height / 2 + 4.8));
153
- }
154
- }
155
- });
156
- }
9
+ static setTitles(axisElement, axisOptions) {
10
+ axisElement.selectAll(".tick text").each(function (d, i) {
11
+ const tickTitle = select(this).select("title");
12
+ if (tickTitle.empty()) select(this).append("title").text(axisOptions.browserTooltip.format(d));
13
+ else {
14
+ tickTitle.text(axisOptions.browserTooltip.format(d));
15
+ }
16
+ });
17
+ }
18
+ static setAxisLabelPaddingByOrient(axis, axisOptions) {
19
+ let axisLabelPadding = AXIS_HORIZONTAL_LABEL_PADDING;
20
+ if (axisOptions.orient === "left" || axisOptions.orient === "right")
21
+ axisLabelPadding = AXIS_VERTICAL_LABEL_PADDING;
22
+ axis.tickPadding(axisLabelPadding);
23
+ }
24
+ static rotateLabels(axisElement, keyAxisOrient) {
25
+ const labelBlocks = axisElement.selectAll("text");
26
+ labelBlocks.attr("transform", "rotate(-90)");
27
+ if (keyAxisOrient === "bottom") {
28
+ labelBlocks.attr("text-anchor", "end").attr("x", -AXIS_HORIZONTAL_LABEL_PADDING).attr("y", -4);
29
+ } else if (keyAxisOrient === "top") {
30
+ labelBlocks.attr("text-anchor", "start").attr("x", AXIS_HORIZONTAL_LABEL_PADDING).attr("y", 6);
31
+ }
32
+ }
33
+ static cropLabels(block, scale, scaleOptions, axisOptions, blockSize) {
34
+ var _a, _b, _c;
35
+ const axisTextBlocks = block.getSvg().select(`.${axisOptions.cssClass}`).selectAll("text");
36
+ let maxLabelSize;
37
+ if (
38
+ axisOptions.orient === "left" ||
39
+ axisOptions.orient === "right" ||
40
+ (axisOptions.type === "key" && axisOptions.labels.position === "rotated")
41
+ )
42
+ maxLabelSize = axisOptions.labels.maxSize;
43
+ else
44
+ maxLabelSize =
45
+ ((_c = (_b = (_a = scale).step) === null || _b === void 0 ? void 0 : _b.call(_a)) !== null &&
46
+ _c !== void 0
47
+ ? _c
48
+ : Infinity) - 4;
49
+ DomHelper.cropSvgLabels(axisTextBlocks, maxLabelSize);
50
+ if (
51
+ axisOptions.labels.position === "straight" &&
52
+ (axisOptions.orient === "top" || axisOptions.orient === "bottom")
53
+ ) {
54
+ this.cropAndAlignExtremeLabels(block, maxLabelSize, axisOptions, blockSize);
55
+ }
56
+ }
57
+ static hideLabels(axisElement) {
58
+ axisElement.selectAll(".tick text").style("display", "none");
59
+ }
60
+ static alignLabelsInKeyAxis(axisOptions, axisElement) {
61
+ if (axisOptions.orient === "left")
62
+ this.alignLabelsInVerticalAxis(axisElement, "start", axisOptions.labels.maxSize, true);
63
+ else if (axisOptions.orient === "right")
64
+ this.alignLabelsInVerticalAxis(axisElement, "start", axisOptions.labels.maxSize, false);
65
+ }
66
+ static alignLabelsInVerticalAxis(axisElement, anchor, maxLabelSize, changeCoordinate) {
67
+ const axisTextBlocks = axisElement.selectAll("text");
68
+ const spans = axisElement.selectAll("tspan");
69
+ axisTextBlocks.attr("text-anchor", anchor);
70
+ spans.attr("text-anchor", anchor);
71
+ if (changeCoordinate) {
72
+ axisTextBlocks.attr("x", -(maxLabelSize + AXIS_VERTICAL_LABEL_PADDING));
73
+ spans.attr("x", -(maxLabelSize + AXIS_VERTICAL_LABEL_PADDING));
74
+ } else {
75
+ spans.attr("x", AXIS_VERTICAL_LABEL_PADDING);
76
+ }
77
+ }
78
+ static alignHorizontalAxisLastLabel(block, maxLabelSize, axisOptions, blockSize, crop) {
79
+ const lastTick = block.getSvg().select(`.${axisOptions.cssClass}`).select(".tick:last-of-type");
80
+ const lastLabel = lastTick.select("text");
81
+ if (lastTick.empty() || lastTick.size() === 0 || lastLabel.size() === 0) return;
82
+ const tickTranslateX = Helper.getTranslateNumbers(lastTick.attr("transform"))[0];
83
+ const marginRight = blockSize.width - axisOptions.translate.translateX - tickTranslateX;
84
+ if (tickTranslateX + lastLabel.node().getBBox().width + axisOptions.translate.translateX > blockSize.width) {
85
+ lastLabel.attr("text-anchor", "start");
86
+ lastLabel.attr(
87
+ "transform",
88
+ `translate(${this.getTranslateNumber(maxLabelSize, lastLabel, marginRight)}, 0)`
89
+ );
90
+ if (crop) DomHelper.cropSvgLabels(lastLabel, maxLabelSize / 2 + marginRight);
91
+ }
92
+ }
93
+ static cropAndAlignExtremeLabels(block, maxLabelSize, axisOptions, blockSize) {
94
+ this.alignHorizontalAxisLastLabel(block, maxLabelSize, axisOptions, blockSize, true);
95
+ const firstLabel = block
96
+ .getSvg()
97
+ .select(`.${axisOptions.cssClass}`)
98
+ .select(".tick:first-of-type")
99
+ .select("text");
100
+ if (firstLabel.empty()) return;
101
+ const axisElementTranslate = Helper.getTranslateNumbers(
102
+ block.getSvg().select(`.${axisOptions.cssClass}`).attr("transform")
103
+ )[0];
104
+ if (axisOptions.translate.translateX - firstLabel.node().getBBox().width / 2 < 0) {
105
+ firstLabel.attr("text-anchor", "start");
106
+ firstLabel.attr("transform", `translate(${-axisOptions.translate.translateX}, 0)`);
107
+ DomHelper.cropSvgLabels(firstLabel, maxLabelSize / 2 + axisElementTranslate);
108
+ }
109
+ }
110
+ static getTranslateNumber(maxLabelSize, lastLabel, marginRight) {
111
+ if (maxLabelSize / 2 > lastLabel.node().getBBox().width)
112
+ return -(lastLabel.node().getBBox().width - marginRight);
113
+ return -maxLabelSize / 2;
114
+ // return -Math.min(maxLabelSize / 2, lastLabel.node().getBBox().width - marginRight)
115
+ }
116
+ static wrapHandler(textBlocks, maxWidth) {
117
+ textBlocks.each(function () {
118
+ let textBlock = select(this);
119
+ if (!textBlock.selectAll("tspan").empty()) return;
120
+ textBlock.select("title").remove();
121
+ let textContent = textBlock.text();
122
+ if (textBlock.node().getBBox().width > maxWidth) {
123
+ let letters = textBlock.text().split("").reverse(), // split text to letters.
124
+ letter,
125
+ line = [], // one line. letters from this var into tpsans.
126
+ lineNumber = 0,
127
+ dy = 1.4,
128
+ tspan = textBlock
129
+ .text(null)
130
+ .append("tspan")
131
+ .attr("dy", dy + "em");
132
+ while ((letter = letters.pop())) {
133
+ line.push(letter);
134
+ tspan.text(line.join(""));
135
+ if (tspan.node().getComputedTextLength() > maxWidth && line.length > 1 && letters.length > 0) {
136
+ line.pop();
137
+ tspan.text(line.join(""));
138
+ if (lineNumber === 0 && line[line.length - 1] !== " ") tspan.text(tspan.text() + "-");
139
+ line = [letter];
140
+ if (lineNumber >= 1) {
141
+ // If text block has 2 lines, text cropped.
142
+ if (letters.length > 0) tspan.text(tspan.text().substr(0, tspan.text().length - 1) + "...");
143
+ break;
144
+ }
145
+ tspan = textBlock
146
+ .append("tspan")
147
+ .attr("dy", dy * lineNumber + 1 + "em")
148
+ .text(letter);
149
+ lineNumber++;
150
+ }
151
+ }
152
+ if (textBlock.selectAll("tspan").size() === 1) {
153
+ textBlock.text(textContent).attr("y", null);
154
+ }
155
+ if (!textBlock.selectAll("tspan").empty()) {
156
+ textBlock.attr("y", -(textBlock.node().getBBox().height / 2 + 4.8));
157
+ }
158
+ }
159
+ });
160
+ }
157
161
  }
@@ -1,6 +1,6 @@
1
1
  import { Selection } from "d3-selection";
2
2
  import { Block } from "../../block/block";
3
3
  export declare class AxisLabelsEventManager {
4
- static setHoverEvents(block: Block, axisElement: Selection<SVGGElement, unknown, HTMLElement, any>): void;
5
- static removeEvents(axisElement: Selection<SVGGElement, unknown, HTMLElement, any>): void;
4
+ static setHoverEvents(block: Block, axisElement: Selection<SVGGElement, unknown, HTMLElement, any>): void;
5
+ static removeEvents(axisElement: Selection<SVGGElement, unknown, HTMLElement, any>): void;
6
6
  }
@@ -1,36 +1,36 @@
1
1
  import { pointer } from "d3-selection";
2
2
  import { TipBox } from "../tipBox/tipBox";
3
3
  export class AxisLabelsEventManager {
4
- static setHoverEvents(block, axisElement) {
5
- const labels = axisElement.selectAll(".tick text");
6
- labels.on("mousemove", function (e, d) {
7
- TipBox.get(block).dispatch("mousemove", {
8
- bubbles: false,
9
- cancelable: true,
10
- detail: {
11
- keyValue: d,
12
- pointer: pointer(e, block.getWrapper().node())
13
- }
14
- });
15
- });
16
- labels.on("mouseleave", function (e, d) {
17
- TipBox.get(block).dispatch("mouseleave");
18
- });
19
- labels.on("click", function (e, d) {
20
- TipBox.get(block).dispatch("click", {
21
- bubbles: false,
22
- cancelable: true,
23
- detail: {
24
- multySelect: e.ctrlKey || e.metaKey,
25
- keyValue: d
26
- }
27
- });
28
- });
29
- }
30
- static removeEvents(axisElement) {
31
- const labels = axisElement.selectAll(".tick text");
32
- labels.on("mousemove", null);
33
- labels.on("mouseleave", null);
34
- labels.on("click", null);
35
- }
4
+ static setHoverEvents(block, axisElement) {
5
+ const labels = axisElement.selectAll(".tick text");
6
+ labels.on("mousemove", function (e, d) {
7
+ TipBox.get(block).dispatch("mousemove", {
8
+ bubbles: false,
9
+ cancelable: true,
10
+ detail: {
11
+ keyValue: d,
12
+ pointer: pointer(e, block.getWrapper().node())
13
+ }
14
+ });
15
+ });
16
+ labels.on("mouseleave", function (e, d) {
17
+ TipBox.get(block).dispatch("mouseleave");
18
+ });
19
+ labels.on("click", function (e, d) {
20
+ TipBox.get(block).dispatch("click", {
21
+ bubbles: false,
22
+ cancelable: true,
23
+ detail: {
24
+ multySelect: e.ctrlKey || e.metaKey,
25
+ keyValue: d
26
+ }
27
+ });
28
+ });
29
+ }
30
+ static removeEvents(axisElement) {
31
+ const labels = axisElement.selectAll(".tick text");
32
+ labels.on("mousemove", null);
33
+ labels.on("mouseleave", null);
34
+ labels.on("click", null);
35
+ }
36
36
  }