cx 26.2.1 → 26.2.3

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 (324) hide show
  1. package/build/charts/Chart.d.ts.map +1 -1
  2. package/build/charts/Chart.js +5 -4
  3. package/build/charts/ColumnBarBase.d.ts +3 -3
  4. package/build/charts/ColumnBarBase.d.ts.map +1 -1
  5. package/build/charts/ColumnBarBase.js +1 -1
  6. package/build/charts/Legend.d.ts.map +1 -1
  7. package/build/charts/Legend.js +11 -4
  8. package/build/charts/Marker.d.ts +3 -3
  9. package/build/charts/Marker.d.ts.map +1 -1
  10. package/build/charts/MarkerLine.d.ts +7 -7
  11. package/build/charts/MarkerLine.d.ts.map +1 -1
  12. package/build/charts/MarkerLine.js +14 -10
  13. package/build/charts/PieChart.d.ts +4 -4
  14. package/build/charts/PieChart.d.ts.map +1 -1
  15. package/build/charts/PieChart.js +36 -14
  16. package/build/charts/PieLabel.d.ts.map +1 -1
  17. package/build/charts/PieLabel.js +2 -1
  18. package/build/charts/RangeMarker.d.ts +3 -3
  19. package/build/charts/RangeMarker.d.ts.map +1 -1
  20. package/build/charts/RangeMarker.js +1 -1
  21. package/build/charts/axis/TimeAxis.d.ts +3 -3
  22. package/build/charts/axis/TimeAxis.d.ts.map +1 -1
  23. package/build/charts/axis/TimeAxis.js +70 -21
  24. package/build/charts/helpers/ValueAtFinder.d.ts +1 -1
  25. package/build/charts/helpers/ValueAtFinder.d.ts.map +1 -1
  26. package/build/charts/helpers/ValueAtFinder.js +5 -2
  27. package/build/data/StructuredSelector.js +3 -4
  28. package/build/data/createAccessorModelProxy.d.ts +6 -11
  29. package/build/data/createAccessorModelProxy.d.ts.map +1 -1
  30. package/build/data/createAccessorModelProxy.js +1 -3
  31. package/build/svg/Ellipse.d.ts +5 -4
  32. package/build/svg/Ellipse.d.ts.map +1 -1
  33. package/build/svg/Ellipse.js +9 -6
  34. package/build/svg/Line.d.ts +1 -0
  35. package/build/svg/Line.d.ts.map +1 -1
  36. package/build/svg/Line.js +4 -1
  37. package/build/svg/Text.d.ts +12 -6
  38. package/build/svg/Text.d.ts.map +1 -1
  39. package/build/svg/Text.js +12 -4
  40. package/build/ui/Controller.d.ts +2 -0
  41. package/build/ui/Controller.d.ts.map +1 -1
  42. package/build/ui/Controller.js +3 -0
  43. package/build/ui/HoverSync.d.ts.map +1 -1
  44. package/build/ui/HoverSync.js +7 -2
  45. package/build/ui/Prop.d.ts +1 -1
  46. package/build/ui/Prop.d.ts.map +1 -1
  47. package/build/ui/Text.d.ts +3 -3
  48. package/build/ui/Text.d.ts.map +1 -1
  49. package/build/ui/Text.js +5 -5
  50. package/build/ui/adapter/GroupAdapter.d.ts.map +1 -1
  51. package/build/ui/adapter/GroupAdapter.js +20 -10
  52. package/build/ui/app/History.js +1 -1
  53. package/build/widgets/List.d.ts.map +1 -1
  54. package/build/widgets/List.js +6 -7
  55. package/build/widgets/drag-drop/DropZone.d.ts +3 -3
  56. package/build/widgets/drag-drop/DropZone.d.ts.map +1 -1
  57. package/build/widgets/form/Calendar.d.ts.map +1 -1
  58. package/build/widgets/form/Calendar.js +30 -11
  59. package/build/widgets/form/ColorField.d.ts.map +1 -1
  60. package/build/widgets/form/ColorField.js +16 -7
  61. package/build/widgets/form/DateTimeField.d.ts.map +1 -1
  62. package/build/widgets/form/DateTimeField.js +23 -10
  63. package/build/widgets/form/Field.d.ts +2 -0
  64. package/build/widgets/form/Field.d.ts.map +1 -1
  65. package/build/widgets/form/Field.js +11 -5
  66. package/build/widgets/form/LookupField.d.ts +1 -1
  67. package/build/widgets/form/LookupField.d.ts.map +1 -1
  68. package/build/widgets/form/LookupField.js +6 -6
  69. package/build/widgets/form/MonthField.d.ts.map +1 -1
  70. package/build/widgets/form/MonthField.js +15 -7
  71. package/build/widgets/form/MonthPicker.d.ts +1 -2
  72. package/build/widgets/form/MonthPicker.d.ts.map +1 -1
  73. package/build/widgets/form/MonthPicker.js +84 -41
  74. package/build/widgets/form/NumberField.d.ts +2 -0
  75. package/build/widgets/form/NumberField.d.ts.map +1 -1
  76. package/build/widgets/form/NumberField.js +45 -15
  77. package/build/widgets/form/TextField.d.ts +1 -9
  78. package/build/widgets/form/TextField.d.ts.map +1 -1
  79. package/build/widgets/form/TextField.js +1 -1
  80. package/build/widgets/grid/Grid.d.ts +2 -2
  81. package/build/widgets/grid/Grid.d.ts.map +1 -1
  82. package/build/widgets/grid/Grid.js +9 -4
  83. package/build/widgets/grid/Pagination.d.ts.map +1 -1
  84. package/build/widgets/grid/Pagination.js +4 -4
  85. package/build/widgets/grid/TreeNode.d.ts.map +1 -1
  86. package/build/widgets/grid/TreeNode.js +10 -2
  87. package/build/widgets/icons/folder.d.ts.map +1 -1
  88. package/build/widgets/icons/folder.js +1 -0
  89. package/build/widgets/icons/forward.d.ts.map +1 -1
  90. package/build/widgets/icons/forward.js +4 -3
  91. package/build/widgets/icons/loading.d.ts.map +1 -1
  92. package/build/widgets/icons/loading.js +6 -5
  93. package/build/widgets/icons/square.d.ts.map +1 -1
  94. package/build/widgets/icons/square.js +3 -3
  95. package/build/widgets/index.d.ts +3 -1
  96. package/build/widgets/index.d.ts.map +1 -1
  97. package/build/widgets/index.js +3 -1
  98. package/build/widgets/overlay/ContextMenu.d.ts.map +1 -1
  99. package/build/widgets/overlay/ContextMenu.js +2 -0
  100. package/build/widgets/overlay/Dropdown.d.ts +2 -1
  101. package/build/widgets/overlay/Dropdown.d.ts.map +1 -1
  102. package/build/widgets/overlay/Dropdown.js +75 -20
  103. package/build/widgets/overlay/MsgBox.d.ts +1 -0
  104. package/build/widgets/overlay/MsgBox.d.ts.map +1 -1
  105. package/build/widgets/overlay/MsgBox.js +2 -2
  106. package/build/widgets/overlay/Overlay.d.ts +32 -2
  107. package/build/widgets/overlay/Overlay.d.ts.map +1 -1
  108. package/build/widgets/overlay/Overlay.js +47 -16
  109. package/build/widgets/overlay/Toast.d.ts +1 -1
  110. package/build/widgets/overlay/Toast.d.ts.map +1 -1
  111. package/build/widgets/overlay/Toast.js +4 -1
  112. package/build/widgets/overlay/Tooltip.d.ts +6 -0
  113. package/build/widgets/overlay/Tooltip.d.ts.map +1 -1
  114. package/build/widgets/overlay/Tooltip.js +24 -9
  115. package/build/widgets/overlay/Window.d.ts.map +1 -1
  116. package/build/widgets/overlay/Window.js +24 -9
  117. package/dist/charts.css +325 -272
  118. package/dist/charts.js +11 -5
  119. package/dist/data.js +2 -2
  120. package/dist/manifest.js +892 -880
  121. package/dist/svg.css +14 -8
  122. package/dist/svg.js +9 -1
  123. package/dist/ui.js +29 -16
  124. package/dist/widgets.css +997 -294
  125. package/dist/widgets.js +317 -121
  126. package/package.json +1 -1
  127. package/src/charts/Bar.scss +13 -10
  128. package/src/charts/BarGraph.scss +31 -29
  129. package/src/charts/BubbleGraph.scss +11 -8
  130. package/src/charts/Chart.ts +5 -3
  131. package/src/charts/Column.scss +13 -10
  132. package/src/charts/ColumnBarBase.tsx +255 -230
  133. package/src/charts/ColumnGraph.scss +13 -11
  134. package/src/charts/Gridlines.scss +10 -8
  135. package/src/charts/Legend.scss +57 -50
  136. package/src/charts/Legend.tsx +257 -213
  137. package/src/charts/LegendEntry.scss +35 -29
  138. package/src/charts/LineGraph.scss +28 -25
  139. package/src/charts/Marker.scss +12 -10
  140. package/src/charts/Marker.tsx +3 -2
  141. package/src/charts/MarkerLine.scss +11 -8
  142. package/src/charts/MarkerLine.tsx +196 -177
  143. package/src/charts/PieChart.scss +12 -9
  144. package/src/charts/PieChart.tsx +717 -591
  145. package/src/charts/PieLabel.tsx +99 -81
  146. package/src/charts/Range.scss +11 -8
  147. package/src/charts/RangeMarker.tsx +204 -187
  148. package/src/charts/ScatterGraph.scss +12 -9
  149. package/src/charts/axis/Axis.scss +6 -5
  150. package/src/charts/axis/CategoryAxis.scss +10 -8
  151. package/src/charts/axis/NumericAxis.scss +9 -6
  152. package/src/charts/axis/TimeAxis.scss +9 -6
  153. package/src/charts/axis/TimeAxis.tsx +753 -637
  154. package/src/charts/axis/index.scss +4 -5
  155. package/src/charts/axis/variables.scss +4 -2
  156. package/src/charts/helpers/ValueAtFinder.ts +19 -5
  157. package/src/charts/index.scss +16 -19
  158. package/src/charts/maps.scss +0 -0
  159. package/src/charts/palette.scss +11 -31
  160. package/src/charts/palette.variables.scss +23 -0
  161. package/src/charts/variables.scss +35 -3
  162. package/src/data/StructuredSelector.ts +2 -2
  163. package/src/data/createAccessorModelProxy.ts +66 -74
  164. package/src/index.scss +5 -6
  165. package/src/maps.scss +5 -0
  166. package/src/svg/Ellipse.tsx +62 -55
  167. package/src/svg/Line.tsx +57 -42
  168. package/src/svg/Svg.scss +6 -6
  169. package/src/svg/Text.scss +19 -0
  170. package/src/svg/Text.tsx +172 -116
  171. package/src/svg/index.scss +3 -2
  172. package/src/svg/maps.scss +0 -0
  173. package/src/svg/variables.scss +0 -0
  174. package/src/ui/Container.spec.ts +59 -0
  175. package/src/ui/Controller.spec.tsx +30 -0
  176. package/src/ui/Controller.ts +5 -0
  177. package/src/ui/HoverSync.tsx +179 -147
  178. package/src/ui/Prop.ts +1 -1
  179. package/src/ui/Text.ts +12 -9
  180. package/src/ui/adapter/GroupAdapter.spec.ts +42 -0
  181. package/src/ui/adapter/GroupAdapter.ts +25 -14
  182. package/src/ui/app/History.ts +1 -1
  183. package/src/ui/index.scss +1 -1
  184. package/src/ui/layout/LabelsLeftLayout.scss +5 -7
  185. package/src/ui/layout/LabelsTopLayout.scss +4 -6
  186. package/src/ui/layout/index.scss +2 -3
  187. package/src/ui/maps.scss +0 -0
  188. package/src/ui/variables.scss +1 -2
  189. package/src/util/index.scss +4 -2
  190. package/src/util/maps.scss +1 -0
  191. package/src/util/scss/besm.scss +15 -0
  192. package/src/util/scss/calc.scss +103 -11
  193. package/src/util/scss/defaults.scss +24 -0
  194. package/src/util/scss/elements.scss +78 -0
  195. package/src/util/scss/global.scss +15 -0
  196. package/src/util/scss/include.scss +17 -9
  197. package/src/util/scss/index.scss +1 -9
  198. package/src/util/scss/maps.scss +2 -0
  199. package/src/util/scss/pad-size.scss +9 -0
  200. package/src/util/scss/padding.scss +6 -0
  201. package/src/util/scss/screen-size.scss +5 -0
  202. package/src/util/scss/variables.scss +6 -0
  203. package/src/util/variables.scss +1 -0
  204. package/src/variables.scss +5 -217
  205. package/src/widgets/Button.maps.scss +103 -0
  206. package/src/widgets/Button.scss +33 -9
  207. package/src/widgets/Button.variables.scss +8 -104
  208. package/src/widgets/CxCredit.scss +2 -0
  209. package/src/widgets/FlexBox.scss +16 -11
  210. package/src/widgets/Heading.scss +6 -0
  211. package/src/widgets/HighlightedSearchText.scss +8 -1
  212. package/src/widgets/Icon.scss +6 -0
  213. package/src/widgets/List.scss +7 -0
  214. package/src/widgets/List.tsx +6 -7
  215. package/src/widgets/ProgressBar.scss +9 -0
  216. package/src/widgets/Resizer.scss +9 -7
  217. package/src/widgets/Section.scss +53 -56
  218. package/src/widgets/animations.scss +4 -2
  219. package/src/widgets/box.scss +47 -0
  220. package/src/widgets/drag-drop/DragClone.scss +12 -4
  221. package/src/widgets/drag-drop/DragHandle.scss +12 -6
  222. package/src/widgets/drag-drop/DragSource.scss +12 -6
  223. package/src/widgets/drag-drop/DropZone.scss +9 -0
  224. package/src/widgets/drag-drop/DropZone.tsx +3 -3
  225. package/src/widgets/drag-drop/index.scss +4 -4
  226. package/src/widgets/drag-drop/maps.scss +7 -0
  227. package/src/widgets/drag-drop/variables.scss +8 -5
  228. package/src/widgets/form/Calendar.maps.scss +54 -0
  229. package/src/widgets/form/Calendar.scss +49 -11
  230. package/src/widgets/form/Calendar.tsx +755 -653
  231. package/src/widgets/form/Calendar.variables.scss +3 -46
  232. package/src/widgets/form/Checkbox.maps.scss +34 -0
  233. package/src/widgets/form/Checkbox.scss +14 -3
  234. package/src/widgets/form/Checkbox.variables.scss +4 -36
  235. package/src/widgets/form/ColorField.scss +21 -2
  236. package/src/widgets/form/ColorField.tsx +485 -431
  237. package/src/widgets/form/ColorPicker.maps.scss +21 -0
  238. package/src/widgets/form/ColorPicker.scss +26 -9
  239. package/src/widgets/form/ColorPicker.variables.scss +3 -16
  240. package/src/widgets/form/DateTimeField.scss +54 -21
  241. package/src/widgets/form/DateTimeField.tsx +697 -615
  242. package/src/widgets/form/DateTimePicker.scss +14 -4
  243. package/src/widgets/form/Field.maps.scss +122 -0
  244. package/src/widgets/form/Field.scss +54 -18
  245. package/src/widgets/form/Field.tsx +611 -504
  246. package/src/widgets/form/Field.variables.scss +46 -0
  247. package/src/widgets/form/HelpText.scss +8 -5
  248. package/src/widgets/form/Label.scss +10 -3
  249. package/src/widgets/form/LookupField.maps.scss +26 -0
  250. package/src/widgets/form/LookupField.scss +54 -24
  251. package/src/widgets/form/LookupField.tsx +25 -21
  252. package/src/widgets/form/MonthField.scss +48 -26
  253. package/src/widgets/form/MonthField.tsx +645 -567
  254. package/src/widgets/form/MonthPicker.maps.scss +50 -0
  255. package/src/widgets/form/MonthPicker.scss +44 -35
  256. package/src/widgets/form/MonthPicker.tsx +954 -724
  257. package/src/widgets/form/MonthPicker.variables.scss +24 -0
  258. package/src/widgets/form/NumberField.scss +19 -2
  259. package/src/widgets/form/NumberField.tsx +576 -466
  260. package/src/widgets/form/Radio.maps.scss +36 -0
  261. package/src/widgets/form/Radio.scss +12 -2
  262. package/src/widgets/form/Radio.variables.scss +3 -42
  263. package/src/widgets/form/Select.scss +25 -9
  264. package/src/widgets/form/Slider.scss +23 -14
  265. package/src/widgets/form/Switch.scss +18 -8
  266. package/src/widgets/form/TextArea.scss +14 -1
  267. package/src/widgets/form/TextField.scss +24 -3
  268. package/src/widgets/form/TextField.tsx +9 -21
  269. package/src/widgets/form/UploadButton.scss +14 -6
  270. package/src/widgets/form/ValidationError.scss +10 -6
  271. package/src/widgets/form/Wheel.scss +14 -4
  272. package/src/widgets/form/index.scss +22 -24
  273. package/src/widgets/form/maps.scss +81 -0
  274. package/src/widgets/form/variables.scss +111 -355
  275. package/src/widgets/grid/Grid.scss +19 -2
  276. package/src/widgets/grid/Grid.spec.ts +42 -0
  277. package/src/widgets/grid/Grid.tsx +15 -7
  278. package/src/widgets/grid/Pagination.scss +11 -2
  279. package/src/widgets/grid/Pagination.tsx +110 -102
  280. package/src/widgets/grid/TreeNode.scss +25 -8
  281. package/src/widgets/grid/TreeNode.tsx +127 -116
  282. package/src/widgets/grid/index.scss +3 -4
  283. package/src/widgets/grid/maps.scss +110 -0
  284. package/src/widgets/grid/variables.scss +48 -137
  285. package/src/widgets/icons/folder.tsx +1 -2
  286. package/src/widgets/icons/forward.tsx +23 -20
  287. package/src/widgets/icons/loading.tsx +22 -19
  288. package/src/widgets/icons/square.tsx +20 -17
  289. package/src/widgets/index.scss +16 -16
  290. package/src/widgets/index.ts +63 -58
  291. package/src/widgets/lists.scss +42 -0
  292. package/src/widgets/maps.scss +139 -0
  293. package/src/widgets/nav/Link.scss +14 -1
  294. package/src/widgets/nav/Menu.scss +13 -7
  295. package/src/widgets/nav/Menu.variables.scss +1 -12
  296. package/src/widgets/nav/MenuItem.scss +21 -6
  297. package/src/widgets/nav/Scroller.scss +11 -2
  298. package/src/widgets/nav/Tab.maps.scss +78 -0
  299. package/src/widgets/nav/Tab.scss +12 -6
  300. package/src/widgets/nav/Tab.variables.scss +7 -76
  301. package/src/widgets/nav/cover.scss +6 -4
  302. package/src/widgets/nav/index.scss +6 -6
  303. package/src/widgets/nav/maps.scss +32 -0
  304. package/src/widgets/nav/variables.scss +4 -11
  305. package/src/widgets/overlay/ContextMenu.ts +3 -0
  306. package/src/widgets/overlay/Dropdown.scss +47 -16
  307. package/src/widgets/overlay/Dropdown.tsx +851 -676
  308. package/src/widgets/overlay/MsgBox.tsx +125 -111
  309. package/src/widgets/overlay/Overlay.scss +60 -40
  310. package/src/widgets/overlay/Overlay.tsx +948 -800
  311. package/src/widgets/overlay/Toast.scss +42 -34
  312. package/src/widgets/overlay/Toast.ts +11 -1
  313. package/src/widgets/overlay/Tooltip.scss +27 -96
  314. package/src/widgets/overlay/Tooltip.tsx +376 -309
  315. package/src/widgets/overlay/Window.maps.scss +51 -0
  316. package/src/widgets/overlay/Window.scss +17 -17
  317. package/src/widgets/overlay/Window.tsx +291 -236
  318. package/src/widgets/overlay/Window.variables.scss +2 -43
  319. package/src/widgets/overlay/index.d.ts +11 -11
  320. package/src/widgets/overlay/index.scss +6 -15
  321. package/src/widgets/overlay/maps.scss +44 -0
  322. package/src/widgets/overlay/variables.scss +11 -42
  323. package/src/widgets/variables.scss +33 -117
  324. package/src/global.scss +0 -14
@@ -1,29 +1,35 @@
1
- @use "sass:map";
2
-
3
- @mixin cx-legendentry($name: "legendentry", $besm: $cx-besm) {
4
- $block: map.get($besm, block);
5
- $element: map.get($besm, element);
6
- $state: map.get($besm, state);
7
-
8
- .#{$block}#{$name} {
9
- display: inline-flex;
10
- align-items: center;
11
- padding: 5px;
12
- gap: 5px;
13
- position: relative;
14
- box-sizing: border-box;
15
- cursor: pointer;
16
- }
17
-
18
- .#{$element}#{$name}-svg {
19
- flex-shrink: 0;
20
- }
21
-
22
- .#{$element}#{$name}-shape {
23
- fill: #eee;
24
- }
25
- }
26
-
27
- @if (cx-should-include("cx/charts/LegendEntry")) {
28
- @include cx-legendentry();
29
- }
1
+ @use "sass:math";
2
+ @use "sass:map";
3
+ @use "../util/scss/besm.scss" as *;
4
+ @use "../util/scss/include.scss" as *;
5
+ @use "../util/scss/add-rules.scss" as *;
6
+ @use "../util/scss/clockwise.scss" as *;
7
+ @use "./variables" as *;
8
+
9
+ @mixin cx-legendentry($name: "legendentry", $besm: $cx-besm) {
10
+ $block: map.get($besm, block);
11
+ $element: map.get($besm, element);
12
+ $state: map.get($besm, state);
13
+
14
+ .#{$block}#{$name} {
15
+ display: inline-flex;
16
+ align-items: center;
17
+ padding: $cx-default-chart-legend-padding;
18
+ gap: $cx-default-chart-legend-entry-gap;
19
+ position: relative;
20
+ box-sizing: border-box;
21
+ cursor: pointer;
22
+ }
23
+
24
+ .#{$element}#{$name}-svg {
25
+ flex-shrink: 0;
26
+ }
27
+
28
+ .#{$element}#{$name}-shape {
29
+ fill: $cx-default-chart-shape-fill-color;
30
+ }
31
+ }
32
+
33
+ @if (cx-should-include("cx/charts/LegendEntry")) {
34
+ @include cx-legendentry();
35
+ }
@@ -1,25 +1,28 @@
1
- @use "sass:map";
2
-
3
- @mixin cx-linegraph(
4
- $name: 'linegraph',
5
- $besm: $cx-besm
6
- ) {
7
- $block: map.get($besm, block);
8
- $element: map.get($besm, element);
9
- $state: map.get($besm, state);
10
-
11
- .#{$element}#{$name}-line {
12
- stroke: gray;
13
- stroke-width: 2px;
14
- fill: none !important;
15
- }
16
-
17
- .#{$element}#{$name}-area {
18
- stroke-width: 0;
19
- opacity: 0.5;
20
- }
21
- }
22
-
23
- @if (cx-should-include('cx/charts/LineGraph')) {
24
- @include cx-linegraph();
25
- }
1
+ @use "sass:math";
2
+ @use "sass:map";
3
+ @use "../util/scss/besm.scss" as *;
4
+ @use "../util/scss/include.scss" as *;
5
+ @use "../util/scss/add-rules.scss" as *;
6
+ @use "../util/scss/clockwise.scss" as *;
7
+ @use "./variables" as *;
8
+
9
+ @mixin cx-linegraph($name: "linegraph", $besm: $cx-besm) {
10
+ $block: map.get($besm, block);
11
+ $element: map.get($besm, element);
12
+ $state: map.get($besm, state);
13
+
14
+ .#{$element}#{$name}-line {
15
+ stroke: $cx-default-chart-line-stroke-color;
16
+ stroke-width: $cx-default-chart-line-stroke-width;
17
+ fill: none !important;
18
+ }
19
+
20
+ .#{$element}#{$name}-area {
21
+ stroke-width: 0;
22
+ opacity: $cx-default-chart-area-opacity;
23
+ }
24
+ }
25
+
26
+ @if (cx-should-include("cx/charts/LineGraph")) {
27
+ @include cx-linegraph();
28
+ }
@@ -1,18 +1,20 @@
1
-
1
+ @use "sass:math";
2
2
  @use "sass:map";
3
+ @use "../util/scss/besm.scss" as *;
4
+ @use "../util/scss/include.scss" as *;
5
+ @use "../util/scss/add-rules.scss" as *;
6
+ @use "../util/scss/clockwise.scss" as *;
7
+ @use "./variables" as *;
3
8
 
4
- @mixin cx-marker(
5
- $name: 'marker',
6
- $besm: $cx-besm
7
- ) {
9
+ @mixin cx-marker($name: "marker", $besm: $cx-besm) {
8
10
  $block: map.get($besm, block);
9
11
  $element: map.get($besm, element);
10
12
  $state: map.get($besm, state);
11
13
 
12
14
  .#{$element}#{$name}-shape {
13
- fill: rgb(128, 128, 128);
14
- stroke: rgb(128, 128, 128);
15
- stroke-width: 1px;
15
+ fill: $cx-default-chart-marker-color;
16
+ stroke: $cx-default-chart-marker-color;
17
+ stroke-width: $cx-default-chart-marker-stroke-width;
16
18
 
17
19
  .#{$state}draggable-x > & {
18
20
  cursor: ew-resize;
@@ -39,6 +41,6 @@
39
41
  }
40
42
  }
41
43
 
42
- @if (cx-should-include('cx/charts/Marker')) {
44
+ @if (cx-should-include("cx/charts/Marker")) {
43
45
  @include cx-marker();
44
- }
46
+ }
@@ -31,16 +31,17 @@ import {
31
31
  BooleanProp,
32
32
  StringProp,
33
33
  StructuredProp,
34
+ Prop,
34
35
  } from "../ui/Prop";
35
36
  import { Instance } from "../ui/Instance";
36
37
  import type { ChartRenderingContext } from "./Chart";
37
38
 
38
39
  export interface MarkerConfig extends BoundedObjectConfig {
39
40
  /** The `x` value binding or expression. */
40
- x?: NumberProp | StringProp;
41
+ x?: Prop<number | string | Date | null>;
41
42
 
42
43
  /** The `y` value binding or expression. */
43
- y?: NumberProp | StringProp;
44
+ y?: Prop<number | string | Date | null>;
44
45
 
45
46
  /** Used to indicate if the data should affect axis span. */
46
47
  affectsAxes?: boolean;
@@ -1,20 +1,23 @@
1
+ @use "sass:math";
2
+ @use "../util/scss/besm.scss" as *;
3
+ @use "../util/scss/include.scss" as *;
4
+ @use "../util/scss/add-rules.scss" as *;
5
+ @use "../util/scss/clockwise.scss" as *;
6
+ @use "./variables" as *;
1
7
 
2
8
  @use "sass:map";
3
9
 
4
- @mixin cx-markerline(
5
- $name: 'markerline',
6
- $besm: $cx-besm
7
- ) {
10
+ @mixin cx-markerline($name: "markerline", $besm: $cx-besm) {
8
11
  $block: map.get($besm, block);
9
12
  $element: map.get($besm, element);
10
13
  $state: map.get($besm, state);
11
14
 
12
15
  .#{$element}#{$name}-line {
13
- stroke: rgb(128, 128, 128);
14
- stroke-width: 1px;
16
+ stroke: $cx-default-chart-marker-color;
17
+ stroke-width: $cx-default-chart-markerline-stroke-width;
15
18
  }
16
19
  }
17
20
 
18
- @if (cx-should-include('cx/charts/MarkerLine')) {
21
+ @if (cx-should-include("cx/charts/MarkerLine")) {
19
22
  @include cx-markerline();
20
- }
23
+ }
@@ -1,214 +1,233 @@
1
1
  /** @jsxImportSource react */
2
2
 
3
- import { BoundedObject, BoundedObjectConfig, BoundedObjectInstance } from "../svg/BoundedObject";
3
+ import {
4
+ BoundedObject,
5
+ BoundedObjectConfig,
6
+ BoundedObjectInstance,
7
+ } from "../svg/BoundedObject";
4
8
  import { VDOM } from "../ui/Widget";
5
9
  import { isDefined } from "../util/isDefined";
6
10
  import { Rect } from "../svg/util/Rect";
7
11
  import { RenderingContext } from "../ui/RenderingContext";
8
- import { NumberProp, BooleanProp, StringProp } from "../ui/Prop";
12
+ import { NumberProp, BooleanProp, StringProp, Prop } from "../ui/Prop";
9
13
  import type { ChartRenderingContext } from "./Chart";
10
14
 
11
15
  export interface MarkerLineConfig extends BoundedObjectConfig {
12
- /** X coordinate for vertical line. */
13
- x?: NumberProp;
16
+ /** X coordinate for vertical line. */
17
+ x?: Prop<string | number | Date | null>;
14
18
 
15
- /** Y coordinate for horizontal line. */
16
- y?: NumberProp;
19
+ /** Y coordinate for horizontal line. */
20
+ y?: Prop<string | number | Date | null>;
17
21
 
18
- /** Starting X coordinate. */
19
- x1?: NumberProp;
22
+ /** Starting X coordinate. */
23
+ x1?: Prop<string | number | Date | null>;
20
24
 
21
- /** Starting Y coordinate. */
22
- y1?: NumberProp;
25
+ /** Starting Y coordinate. */
26
+ y1?: Prop<string | number | Date | null>;
23
27
 
24
- /** Ending X coordinate. */
25
- x2?: NumberProp;
28
+ /** Ending X coordinate. */
29
+ x2?: Prop<string | number | Date | null>;
26
30
 
27
- /** Ending Y coordinate. */
28
- y2?: NumberProp;
31
+ /** Ending Y coordinate. */
32
+ y2?: Prop<string | number | Date | null>;
29
33
 
30
- /** Index of a color from the standard palette of colors. 0-15. */
31
- colorIndex?: NumberProp;
34
+ /** Index of a color from the standard palette of colors. 0-15. */
35
+ colorIndex?: NumberProp;
32
36
 
33
- /** Used to indicate if the line is active or not. */
34
- active?: BooleanProp;
37
+ /** Used to indicate if the line is active or not. */
38
+ active?: BooleanProp;
35
39
 
36
- /** Name of the line as it will appear in the legend. */
37
- name?: StringProp;
40
+ /** Name of the line as it will appear in the legend. */
41
+ name?: StringProp;
38
42
 
39
- /** Name of the legend to be used. Default is `legend`. */
40
- legend?: StringProp;
43
+ /** Name of the legend to be used. Default is `legend`. */
44
+ legend?: StringProp;
41
45
 
42
- /** Name of the horizontal axis. Default value is `x`. */
43
- xAxis?: string;
46
+ /** Name of the horizontal axis. Default value is `x`. */
47
+ xAxis?: string;
44
48
 
45
- /** Name of the vertical axis. Default value is `y`. */
46
- yAxis?: string;
49
+ /** Name of the vertical axis. Default value is `y`. */
50
+ yAxis?: string;
47
51
 
48
- /** Set to `false` to prevent the line from affecting axis bounds. */
49
- affectsAxes?: boolean;
52
+ /** Set to `false` to prevent the line from affecting axis bounds. */
53
+ affectsAxes?: boolean;
50
54
 
51
- /** Action to perform on legend item click. Default is `auto`. */
52
- legendAction?: string;
55
+ /** Action to perform on legend item click. Default is `auto`. */
56
+ legendAction?: string;
53
57
  }
54
58
 
55
59
  export interface MarkerLineInstance extends BoundedObjectInstance {
56
- xAxis: any;
57
- yAxis: any;
58
- x1: number;
59
- y1: number;
60
- x2: number;
61
- y2: number;
60
+ xAxis: any;
61
+ yAxis: any;
62
+ x1: number;
63
+ y1: number;
64
+ x2: number;
65
+ y2: number;
62
66
  }
63
67
 
64
68
  export class MarkerLine extends BoundedObject {
65
- declare baseClass: string;
66
- declare xAxis: string;
67
- declare yAxis: string;
68
- declare legend: string;
69
- declare legendAction: string;
70
- declare affectsAxes: boolean;
71
- declare x: number;
72
- declare y: number;
73
- declare x1: number;
74
- declare x2: number;
75
- declare y1: number;
76
- declare y2: number;
77
-
78
- constructor(config: MarkerLineConfig) {
79
- super(config);
80
- }
81
-
82
- init(): void {
83
- if (isDefined(this.x)) this.x1 = this.x2 = this.x;
84
-
85
- if (isDefined(this.y)) this.y1 = this.y2 = this.y;
86
-
87
- super.init();
88
- }
89
-
90
- declareData(...args: any[]): void {
91
- super.declareData(...args, {
92
- x1: undefined,
93
- y1: undefined,
94
- x2: undefined,
95
- y2: undefined,
96
- colorIndex: undefined,
97
- active: true,
98
- name: undefined,
99
- legend: undefined
100
- });
101
- }
102
-
103
- explore(context: RenderingContext, instance: MarkerLineInstance): void {
104
- let { data } = instance;
105
-
106
- let xAxis = (instance.xAxis = context.axes[this.xAxis]);
107
- let yAxis = (instance.yAxis = context.axes[this.yAxis]);
69
+ declare baseClass: string;
70
+ declare xAxis: string;
71
+ declare yAxis: string;
72
+ declare legend: string;
73
+ declare legendAction: string;
74
+ declare affectsAxes: boolean;
75
+ declare x: number;
76
+ declare y: number;
77
+ declare x1: number;
78
+ declare x2: number;
79
+ declare y1: number;
80
+ declare y2: number;
81
+
82
+ constructor(config: MarkerLineConfig) {
83
+ super(config);
84
+ }
85
+
86
+ init(): void {
87
+ if (isDefined(this.x)) this.x1 = this.x2 = this.x;
88
+
89
+ if (isDefined(this.y)) this.y1 = this.y2 = this.y;
90
+
91
+ super.init();
92
+ }
93
+
94
+ declareData(...args: any[]): void {
95
+ super.declareData(...args, {
96
+ x1: undefined,
97
+ y1: undefined,
98
+ x2: undefined,
99
+ y2: undefined,
100
+ colorIndex: undefined,
101
+ active: true,
102
+ name: undefined,
103
+ legend: undefined,
104
+ });
105
+ }
106
+
107
+ explore(context: RenderingContext, instance: MarkerLineInstance): void {
108
+ let { data } = instance;
109
+
110
+ let xAxis = (instance.xAxis = context.axes[this.xAxis]);
111
+ let yAxis = (instance.yAxis = context.axes[this.yAxis]);
112
+
113
+ if (data.active) {
114
+ if (this.affectsAxes) {
115
+ if (data.x1 != null) xAxis.acknowledge(data.x1);
116
+
117
+ if (data.x2 != null) xAxis.acknowledge(data.x2);
118
+
119
+ if (data.y1 != null) yAxis.acknowledge(data.y1);
120
+
121
+ if (data.y2 != null) yAxis.acknowledge(data.y2);
122
+ }
108
123
 
109
- if (data.active) {
110
- if (this.affectsAxes) {
111
- if (data.x1 != null) xAxis.acknowledge(data.x1);
124
+ super.explore(context, instance);
125
+ }
126
+ }
112
127
 
113
- if (data.x2 != null) xAxis.acknowledge(data.x2);
128
+ prepare(context: RenderingContext, instance: MarkerLineInstance): void {
129
+ let { data, xAxis, yAxis } = instance;
114
130
 
115
- if (data.y1 != null) yAxis.acknowledge(data.y1);
131
+ if ((xAxis && xAxis.shouldUpdate) || (yAxis && yAxis.shouldUpdate))
132
+ instance.markShouldUpdate(context);
116
133
 
117
- if (data.y2 != null) yAxis.acknowledge(data.y2);
118
- }
134
+ super.prepare(context, instance);
119
135
 
120
- super.explore(context, instance);
121
- }
122
- }
123
-
124
- prepare(context: RenderingContext, instance: MarkerLineInstance): void {
125
- let { data, xAxis, yAxis } = instance;
126
-
127
- if ((xAxis && xAxis.shouldUpdate) || (yAxis && yAxis.shouldUpdate)) instance.markShouldUpdate(context);
128
-
129
- super.prepare(context, instance);
130
-
131
- if (data.name && data.legend && context.addLegendEntry)
132
- context.addLegendEntry(data.legend, {
133
- name: data.name,
134
- active: data.active,
135
- colorIndex: data.colorIndex,
136
- style: data.style,
137
- shape: "line",
138
- onClick: (e: MouseEvent) => {
139
- this.onLegendClick(e, instance);
140
- },
141
- });
142
- }
143
-
144
- calculateBounds(context: RenderingContext, instance: MarkerLineInstance): Rect {
145
- let { data, xAxis, yAxis } = instance;
146
- let bounds = super.calculateBounds(context, instance);
147
-
148
- let x1 = bounds.l,
149
- x2 = bounds.r,
150
- y1 = bounds.t,
151
- y2 = bounds.b;
152
-
153
- if (data.x1 != null) x1 = xAxis.map(data.x1);
154
-
155
- if (data.x2 != null) x2 = xAxis.map(data.x2);
156
-
157
- if (data.y1 != null) y1 = yAxis.map(data.y1);
158
-
159
- if (data.y2 != null) y2 = yAxis.map(data.y2);
160
-
161
- bounds.l = Math.min(x1, x2);
162
- bounds.t = Math.min(y1, y2);
163
- bounds.r = Math.max(x1, x2);
164
- bounds.b = Math.max(y1, y2);
165
-
166
- instance.x1 = x1;
167
- instance.x2 = x2;
168
- instance.y1 = y1;
169
- instance.y2 = y2;
170
-
171
- return bounds;
172
- }
173
-
174
- onLegendClick(e: MouseEvent, instance: MarkerLineInstance): void {
175
- let allActions = this.legendAction == "auto";
176
- let { data } = instance;
177
- if (allActions || this.legendAction == "toggle") instance.set("active", !data.active);
178
- }
179
-
180
- render(context: RenderingContext, instance: MarkerLineInstance, key: string): React.ReactNode {
181
- let { data, x1, x2, y1, y2 } = instance;
182
-
183
- if (!data.active || data.x1 === null || data.x2 === null || data.y1 === null || data.y2 === null) return null;
184
-
185
- let stateMods: Record<string, boolean> = {
186
- ["color-" + data.colorIndex]: data.colorIndex != null,
187
- };
188
-
189
- return (
190
- <g key={key} className={data.classNames}>
191
- <line
192
- className={this.CSS.element(this.baseClass, "line", stateMods)}
193
- style={data.style}
194
- x1={x1}
195
- y1={y1}
196
- x2={x2}
197
- y2={y2}
198
- />
199
- {this.renderChildren(context, instance)}
200
- </g>
201
- );
202
- }
136
+ if (data.name && data.legend && context.addLegendEntry)
137
+ context.addLegendEntry(data.legend, {
138
+ name: data.name,
139
+ active: data.active,
140
+ colorIndex: data.colorIndex,
141
+ style: data.style,
142
+ shape: "line",
143
+ onClick: (e: MouseEvent) => {
144
+ this.onLegendClick(e, instance);
145
+ },
146
+ });
147
+ }
148
+
149
+ calculateBounds(
150
+ context: RenderingContext,
151
+ instance: MarkerLineInstance,
152
+ ): Rect {
153
+ let { data, xAxis, yAxis } = instance;
154
+ let bounds = super.calculateBounds(context, instance);
155
+
156
+ let x1 = bounds.l,
157
+ x2 = bounds.r,
158
+ y1 = bounds.t,
159
+ y2 = bounds.b;
160
+
161
+ if (data.x1 != null) x1 = xAxis.map(data.x1);
162
+
163
+ if (data.x2 != null) x2 = xAxis.map(data.x2);
164
+
165
+ if (data.y1 != null) y1 = yAxis.map(data.y1);
166
+
167
+ if (data.y2 != null) y2 = yAxis.map(data.y2);
168
+
169
+ bounds.l = Math.min(x1, x2);
170
+ bounds.t = Math.min(y1, y2);
171
+ bounds.r = Math.max(x1, x2);
172
+ bounds.b = Math.max(y1, y2);
173
+
174
+ instance.x1 = x1;
175
+ instance.x2 = x2;
176
+ instance.y1 = y1;
177
+ instance.y2 = y2;
178
+
179
+ return bounds;
180
+ }
181
+
182
+ onLegendClick(e: MouseEvent, instance: MarkerLineInstance): void {
183
+ let allActions = this.legendAction == "auto";
184
+ let { data } = instance;
185
+ if (allActions || this.legendAction == "toggle")
186
+ instance.set("active", !data.active);
187
+ }
188
+
189
+ render(
190
+ context: RenderingContext,
191
+ instance: MarkerLineInstance,
192
+ key: string,
193
+ ): React.ReactNode {
194
+ let { data, x1, x2, y1, y2 } = instance;
195
+
196
+ if (
197
+ !data.active ||
198
+ data.x1 === null ||
199
+ data.x2 === null ||
200
+ data.y1 === null ||
201
+ data.y2 === null
202
+ )
203
+ return null;
204
+
205
+ let stateMods: Record<string, boolean> = {
206
+ ["color-" + data.colorIndex]: data.colorIndex != null,
207
+ };
208
+
209
+ return (
210
+ <g key={key} className={data.classNames}>
211
+ <line
212
+ className={this.CSS.element(this.baseClass, "line", stateMods)}
213
+ style={data.style}
214
+ x1={x1}
215
+ y1={y1}
216
+ x2={x2}
217
+ y2={y2}
218
+ />
219
+ {this.renderChildren(context, instance)}
220
+ </g>
221
+ );
222
+ }
203
223
  }
204
224
 
205
- MarkerLine.prototype.xAxis = 'x';
206
- MarkerLine.prototype.yAxis = 'y';
207
- MarkerLine.prototype.anchors = '0 1 1 0';
208
- MarkerLine.prototype.baseClass = 'markerline';
209
- MarkerLine.prototype.legend = 'legend';
210
- MarkerLine.prototype.legendAction = 'auto';
225
+ MarkerLine.prototype.xAxis = "x";
226
+ MarkerLine.prototype.yAxis = "y";
227
+ MarkerLine.prototype.anchors = "0 1 1 0";
228
+ MarkerLine.prototype.baseClass = "markerline";
229
+ MarkerLine.prototype.legend = "legend";
230
+ MarkerLine.prototype.legendAction = "auto";
211
231
  MarkerLine.prototype.affectsAxes = true;
212
232
 
213
- BoundedObject.alias('marker-line', MarkerLine);
214
-
233
+ BoundedObject.alias("marker-line", MarkerLine);
@@ -1,29 +1,32 @@
1
+ @use "sass:math";
2
+ @use "../util/scss/besm.scss" as *;
3
+ @use "../util/scss/include.scss" as *;
4
+ @use "../util/scss/add-rules.scss" as *;
5
+ @use "../util/scss/clockwise.scss" as *;
6
+ @use "./variables" as *;
1
7
 
2
8
  @use "sass:map";
3
9
 
4
- @mixin cx-pieslice(
5
- $name: 'pieslice',
6
- $besm: $cx-besm
7
- ) {
10
+ @mixin cx-pieslice($name: "pieslice", $besm: $cx-besm) {
8
11
  $block: map.get($besm, block);
9
12
  $element: map.get($besm, element);
10
13
  $state: map.get($besm, state);
11
14
 
12
15
  .#{$element}#{$name}-slice {
13
16
  stroke-width: 0;
14
- fill: #eee;
15
- stroke: #ccc;
17
+ fill: $cx-default-chart-shape-fill-color;
18
+ stroke: $cx-default-chart-shape-stroke-color;
16
19
 
17
20
  &.#{$state}selectable {
18
21
  cursor: pointer;
19
22
  }
20
23
 
21
24
  &.#{$state}selected {
22
- stroke-width: 2px;
25
+ stroke-width: $cx-default-chart-selected-stroke-width;
23
26
  }
24
27
  }
25
28
  }
26
29
 
27
- @if (cx-should-include('cx/charts/PieSlice')) {
30
+ @if (cx-should-include("cx/charts/PieSlice")) {
28
31
  @include cx-pieslice();
29
- }
32
+ }