cx 24.6.2 → 24.6.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 (780) hide show
  1. package/LICENSE-THIRD-PARTY.md +91 -91
  2. package/LICENSE.md +7 -7
  3. package/README.md +46 -46
  4. package/dist/charts.js +15 -7
  5. package/dist/manifest.js +773 -773
  6. package/dist/widgets.css +31 -2
  7. package/dist/widgets.js +197 -91
  8. package/index.js +17 -17
  9. package/locale/de-de.js +74 -74
  10. package/locale/en-us.js +74 -74
  11. package/locale/es-es.js +74 -74
  12. package/locale/fr-fr.js +74 -74
  13. package/locale/nl-nl.js +74 -74
  14. package/locale/pt-pt.js +74 -74
  15. package/locale/sr-latn-ba.js +74 -74
  16. package/package.json +1 -1
  17. package/src/charts/Bar.js +89 -89
  18. package/src/charts/Bar.scss +26 -26
  19. package/src/charts/BarGraph.d.ts +15 -15
  20. package/src/charts/BarGraph.js +112 -112
  21. package/src/charts/BarGraph.scss +27 -27
  22. package/src/charts/BubbleGraph.js +92 -92
  23. package/src/charts/BubbleGraph.scss +29 -29
  24. package/src/charts/Chart.d.ts +12 -12
  25. package/src/charts/Chart.js +75 -75
  26. package/src/charts/ColorMap.d.ts +21 -21
  27. package/src/charts/ColorMap.js +96 -96
  28. package/src/charts/Column.d.ts +27 -27
  29. package/src/charts/Column.js +88 -88
  30. package/src/charts/Column.scss +26 -26
  31. package/src/charts/ColumnBarBase.d.ts +64 -64
  32. package/src/charts/ColumnBarBase.js +172 -172
  33. package/src/charts/ColumnBarGraphBase.d.ts +73 -73
  34. package/src/charts/ColumnBarGraphBase.js +114 -114
  35. package/src/charts/ColumnGraph.d.ts +18 -18
  36. package/src/charts/ColumnGraph.scss +27 -27
  37. package/src/charts/Grid.js +5 -5
  38. package/src/charts/Gridlines.d.ts +24 -24
  39. package/src/charts/Gridlines.js +48 -48
  40. package/src/charts/Gridlines.scss +22 -22
  41. package/src/charts/Legend.d.ts +27 -27
  42. package/src/charts/Legend.scss +41 -41
  43. package/src/charts/LegendEntry.d.ts +37 -37
  44. package/src/charts/LegendEntry.js +117 -117
  45. package/src/charts/LegendEntry.scss +30 -30
  46. package/src/charts/LineGraph.d.ts +92 -92
  47. package/src/charts/LineGraph.scss +23 -23
  48. package/src/charts/Marker.d.ts +96 -96
  49. package/src/charts/Marker.js +299 -299
  50. package/src/charts/Marker.scss +41 -41
  51. package/src/charts/MarkerLine.d.ts +57 -57
  52. package/src/charts/MarkerLine.js +128 -128
  53. package/src/charts/MarkerLine.scss +17 -17
  54. package/src/charts/MouseTracker.d.ts +16 -16
  55. package/src/charts/MouseTracker.js +80 -80
  56. package/src/charts/Pie.js +8 -8
  57. package/src/charts/PieChart.d.ts +89 -89
  58. package/src/charts/PieChart.js +527 -527
  59. package/src/charts/PieChart.scss +26 -26
  60. package/src/charts/PieLabel.d.ts +26 -26
  61. package/src/charts/PieLabel.js +71 -71
  62. package/src/charts/PieLabelsContainer.d.ts +6 -6
  63. package/src/charts/PieLabelsContainer.js +55 -55
  64. package/src/charts/Range.d.ts +74 -74
  65. package/src/charts/Range.js +205 -205
  66. package/src/charts/Range.scss +18 -18
  67. package/src/charts/RangeMarker.d.ts +35 -35
  68. package/src/charts/RangeMarker.js +155 -155
  69. package/src/charts/RangeMarker.scss +15 -15
  70. package/src/charts/ScatterGraph.d.ts +64 -64
  71. package/src/charts/ScatterGraph.js +155 -155
  72. package/src/charts/ScatterGraph.scss +21 -21
  73. package/src/charts/Swimlane.d.ts +24 -24
  74. package/src/charts/Swimlane.js +140 -140
  75. package/src/charts/Swimlane.scss +14 -14
  76. package/src/charts/Swimlanes.d.ts +41 -41
  77. package/src/charts/Swimlanes.js +114 -114
  78. package/src/charts/Swimlanes.scss +14 -14
  79. package/src/charts/axis/Axis.js +254 -254
  80. package/src/charts/axis/Axis.scss +22 -22
  81. package/src/charts/axis/CategoryAxis.d.ts +24 -24
  82. package/src/charts/axis/CategoryAxis.js +212 -212
  83. package/src/charts/axis/CategoryAxis.scss +32 -32
  84. package/src/charts/axis/NumericAxis.d.ts +46 -46
  85. package/src/charts/axis/NumericAxis.js +347 -347
  86. package/src/charts/axis/NumericAxis.scss +32 -32
  87. package/src/charts/axis/Stack.d.ts +10 -10
  88. package/src/charts/axis/Stack.js +16 -19
  89. package/src/charts/axis/TimeAxis.d.ts +23 -23
  90. package/src/charts/axis/TimeAxis.js +510 -510
  91. package/src/charts/axis/TimeAxis.scss +32 -32
  92. package/src/charts/axis/index.d.ts +3 -3
  93. package/src/charts/axis/index.js +3 -3
  94. package/src/charts/axis/index.scss +5 -5
  95. package/src/charts/axis/variables.scss +2 -2
  96. package/src/charts/helpers/MinMaxFinder.d.ts +22 -22
  97. package/src/charts/helpers/MinMaxFinder.js +36 -36
  98. package/src/charts/helpers/PointReducer.d.ts +15 -15
  99. package/src/charts/helpers/PointReducer.js +39 -39
  100. package/src/charts/helpers/index.d.ts +4 -4
  101. package/src/charts/helpers/index.js +4 -4
  102. package/src/charts/index.d.ts +27 -27
  103. package/src/charts/index.js +34 -34
  104. package/src/charts/index.scss +22 -22
  105. package/src/charts/palette.scss +95 -95
  106. package/src/charts/shapes.d.ts +22 -22
  107. package/src/charts/shapes.js +79 -79
  108. package/src/charts/variables.scss +21 -21
  109. package/src/core.d.ts +271 -271
  110. package/src/data/AggregateFunction.d.ts +20 -20
  111. package/src/data/AggregateFunction.js +145 -145
  112. package/src/data/ArrayElementView.d.ts +13 -13
  113. package/src/data/ArrayElementView.js +46 -46
  114. package/src/data/ArrayElementView.spec.js +70 -70
  115. package/src/data/ArrayRef.d.ts +14 -14
  116. package/src/data/ArrayRef.js +34 -34
  117. package/src/data/AugmentedViewBase.d.ts +18 -18
  118. package/src/data/AugmentedViewBase.js +67 -67
  119. package/src/data/Binding.d.ts +19 -19
  120. package/src/data/Binding.js +76 -76
  121. package/src/data/Binding.spec.js +69 -69
  122. package/src/data/ExposedRecordView.d.ts +14 -14
  123. package/src/data/ExposedRecordView.js +69 -69
  124. package/src/data/ExposedValueView.d.ts +19 -19
  125. package/src/data/ExposedValueView.js +72 -72
  126. package/src/data/Expression.d.ts +17 -17
  127. package/src/data/Expression.js +220 -220
  128. package/src/data/Expression.spec.js +174 -174
  129. package/src/data/Grouper.d.ts +21 -21
  130. package/src/data/Grouper.js +144 -144
  131. package/src/data/Grouper.spec.js +57 -57
  132. package/src/data/NestedDataView.d.ts +19 -19
  133. package/src/data/NestedDataView.js +22 -22
  134. package/src/data/ReadOnlyDataView.d.ts +14 -14
  135. package/src/data/ReadOnlyDataView.js +26 -26
  136. package/src/data/Ref.d.ts +24 -24
  137. package/src/data/Ref.js +79 -79
  138. package/src/data/Ref.spec.js +79 -79
  139. package/src/data/Store.d.ts +14 -14
  140. package/src/data/Store.js +46 -46
  141. package/src/data/Store.spec.js +22 -22
  142. package/src/data/StoreProxy.d.ts +4 -4
  143. package/src/data/StoreProxy.js +16 -16
  144. package/src/data/StoreRef.js +54 -54
  145. package/src/data/StoreRef.spec.js +24 -24
  146. package/src/data/StringTemplate.d.ts +15 -15
  147. package/src/data/StringTemplate.js +92 -92
  148. package/src/data/StructuredDataAccessor.d.ts +7 -7
  149. package/src/data/StructuredSelector.d.ts +17 -17
  150. package/src/data/StructuredSelector.js +131 -131
  151. package/src/data/StructuredSelector.spec.js +113 -113
  152. package/src/data/SubscribableView.d.ts +11 -11
  153. package/src/data/SubscribableView.js +54 -54
  154. package/src/data/View.d.ts +131 -131
  155. package/src/data/View.js +182 -182
  156. package/src/data/View.spec.js +60 -60
  157. package/src/data/ZoomIntoPropertyView.d.ts +11 -11
  158. package/src/data/ZoomIntoPropertyView.js +33 -33
  159. package/src/data/ZoomIntoPropertyView.spec.js +65 -65
  160. package/src/data/comparer.d.ts +7 -7
  161. package/src/data/comparer.js +54 -54
  162. package/src/data/comparer.spec.js +60 -60
  163. package/src/data/computable.d.ts +125 -125
  164. package/src/data/computable.js +56 -56
  165. package/src/data/computable.spec.js +55 -55
  166. package/src/data/createAccessorModelProxy.d.ts +6 -6
  167. package/src/data/createAccessorModelProxy.js +43 -43
  168. package/src/data/createAccessorModelProxy.spec.tsx +44 -44
  169. package/src/data/createStructuredSelector.d.ts +2 -2
  170. package/src/data/createStructuredSelector.js +43 -43
  171. package/src/data/createStructuredSelector.spec.js +46 -46
  172. package/src/data/defaultCompare.js +14 -14
  173. package/src/data/diff/diffArrays.d.ts +15 -15
  174. package/src/data/diff/diffArrays.js +41 -41
  175. package/src/data/diff/diffs.spec.js +49 -49
  176. package/src/data/diff/index.d.ts +1 -1
  177. package/src/data/diff/index.js +1 -1
  178. package/src/data/enableFatArrowExpansion.d.ts +1 -1
  179. package/src/data/enableFatArrowExpansion.js +6 -6
  180. package/src/data/getAccessor.d.ts +8 -8
  181. package/src/data/getAccessor.js +61 -61
  182. package/src/data/getSelector.d.ts +3 -3
  183. package/src/data/getSelector.js +48 -48
  184. package/src/data/getSelector.spec.js +43 -43
  185. package/src/data/index.d.ts +30 -30
  186. package/src/data/index.js +28 -28
  187. package/src/data/isSelector.d.ts +1 -1
  188. package/src/data/isSelector.js +26 -26
  189. package/src/data/ops/append.d.ts +1 -1
  190. package/src/data/ops/append.js +7 -7
  191. package/src/data/ops/append.spec.js +28 -28
  192. package/src/data/ops/filter.d.ts +1 -1
  193. package/src/data/ops/filter.js +8 -8
  194. package/src/data/ops/filter.spec.js +29 -29
  195. package/src/data/ops/findTreeNode.d.ts +1 -1
  196. package/src/data/ops/findTreeNode.js +15 -15
  197. package/src/data/ops/findTreeNode.spec.js +24 -24
  198. package/src/data/ops/findTreePath.d.ts +6 -6
  199. package/src/data/ops/findTreePath.js +16 -16
  200. package/src/data/ops/index.d.ts +10 -10
  201. package/src/data/ops/index.js +11 -11
  202. package/src/data/ops/insertElement.d.ts +1 -1
  203. package/src/data/ops/insertElement.js +2 -2
  204. package/src/data/ops/merge.d.ts +3 -3
  205. package/src/data/ops/merge.js +9 -9
  206. package/src/data/ops/merge.spec.js +27 -27
  207. package/src/data/ops/moveElement.d.ts +1 -1
  208. package/src/data/ops/moveElement.js +13 -13
  209. package/src/data/ops/removeTreeNodes.d.ts +5 -5
  210. package/src/data/ops/removeTreeNodes.js +5 -5
  211. package/src/data/ops/removeTreeNodes.spec.js +28 -28
  212. package/src/data/ops/updateArray.d.ts +5 -5
  213. package/src/data/ops/updateArray.js +24 -24
  214. package/src/data/ops/updateArray.spec.js +38 -38
  215. package/src/data/ops/updateTree.d.ts +7 -7
  216. package/src/data/ops/updateTree.js +25 -25
  217. package/src/data/ops/updateTree.spec.js +36 -36
  218. package/src/global.scss +13 -13
  219. package/src/hooks/createLocalStorageRef.d.ts +2 -2
  220. package/src/hooks/createLocalStorageRef.js +22 -22
  221. package/src/hooks/index.d.ts +8 -8
  222. package/src/hooks/index.js +7 -7
  223. package/src/hooks/invokeCallback.d.ts +5 -5
  224. package/src/hooks/invokeCallback.js +6 -6
  225. package/src/hooks/invokeCallback.spec.js +53 -53
  226. package/src/hooks/resolveCallback.d.ts +3 -3
  227. package/src/hooks/resolveCallback.js +11 -11
  228. package/src/hooks/resolveCallback.spec.js +54 -54
  229. package/src/hooks/store.d.ts +7 -7
  230. package/src/hooks/store.js +32 -32
  231. package/src/hooks/store.spec.js +73 -73
  232. package/src/hooks/useEffect.d.ts +2 -2
  233. package/src/hooks/useEffect.js +14 -14
  234. package/src/hooks/useInterval.js +7 -7
  235. package/src/hooks/useState.d.ts +2 -2
  236. package/src/hooks/useState.js +15 -15
  237. package/src/hooks/useTrigger.d.ts +4 -4
  238. package/src/hooks/useTrigger.js +20 -20
  239. package/src/hooks/useTrigger.spec.js +102 -102
  240. package/src/index.js +7 -7
  241. package/src/index.scss +6 -6
  242. package/src/svg/BoundedObject.d.ts +22 -22
  243. package/src/svg/BoundedObject.js +59 -59
  244. package/src/svg/ClipRect.d.ts +4 -4
  245. package/src/svg/ClipRect.js +23 -23
  246. package/src/svg/Ellipse.d.ts +23 -23
  247. package/src/svg/Ellipse.js +36 -36
  248. package/src/svg/Line.d.ts +20 -20
  249. package/src/svg/Line.js +32 -32
  250. package/src/svg/NonOverlappingRect.d.ts +5 -5
  251. package/src/svg/NonOverlappingRect.js +14 -14
  252. package/src/svg/NonOverlappingRectGroup.d.ts +3 -3
  253. package/src/svg/NonOverlappingRectGroup.js +36 -36
  254. package/src/svg/Rectangle.d.ts +23 -23
  255. package/src/svg/Rectangle.js +36 -36
  256. package/src/svg/Svg.d.ts +32 -32
  257. package/src/svg/Svg.js +177 -177
  258. package/src/svg/Svg.scss +26 -26
  259. package/src/svg/Text.d.ts +40 -40
  260. package/src/svg/Text.js +78 -78
  261. package/src/svg/TextualBoundedObject.d.ts +6 -6
  262. package/src/svg/TextualBoundedObject.js +28 -28
  263. package/src/svg/index.d.ts +11 -11
  264. package/src/svg/index.js +17 -17
  265. package/src/svg/index.scss +8 -8
  266. package/src/svg/util/Rect.d.ts +40 -40
  267. package/src/svg/util/Rect.js +108 -108
  268. package/src/ui/CSS.d.ts +19 -19
  269. package/src/ui/CSS.js +79 -79
  270. package/src/ui/CSSHelper.d.ts +10 -10
  271. package/src/ui/CSSHelper.js +17 -17
  272. package/src/ui/Container.d.ts +18 -18
  273. package/src/ui/Container.js +183 -183
  274. package/src/ui/ContentResolver.d.ts +12 -12
  275. package/src/ui/ContentResolver.js +78 -78
  276. package/src/ui/Controller.js +114 -114
  277. package/src/ui/Controller.spec.js +414 -414
  278. package/src/ui/Culture.d.ts +51 -51
  279. package/src/ui/Culture.js +129 -129
  280. package/src/ui/Cx.d.ts +18 -18
  281. package/src/ui/Cx.js +313 -313
  282. package/src/ui/Cx.spec.js +193 -193
  283. package/src/ui/DataProxy.d.ts +12 -12
  284. package/src/ui/DataProxy.js +44 -44
  285. package/src/ui/DataProxy.spec.js +335 -335
  286. package/src/ui/DetachedScope.d.ts +21 -21
  287. package/src/ui/DetachedScope.js +93 -93
  288. package/src/ui/FocusManager.d.ts +29 -29
  289. package/src/ui/Format.d.ts +2 -2
  290. package/src/ui/Format.js +107 -107
  291. package/src/ui/HoverSync.d.ts +13 -13
  292. package/src/ui/HoverSync.js +147 -147
  293. package/src/ui/Instance.js +610 -610
  294. package/src/ui/IsolatedScope.d.ts +16 -16
  295. package/src/ui/IsolatedScope.js +29 -29
  296. package/src/ui/IsolatedScope.spec.js +62 -62
  297. package/src/ui/Localization.d.ts +17 -17
  298. package/src/ui/Localization.js +70 -70
  299. package/src/ui/PureContainer.d.ts +16 -16
  300. package/src/ui/PureContainer.js +7 -7
  301. package/src/ui/RenderingContext.d.ts +9 -9
  302. package/src/ui/RenderingContext.js +88 -88
  303. package/src/ui/Repeater.d.ts +60 -60
  304. package/src/ui/Repeater.js +102 -102
  305. package/src/ui/Repeater.spec.js +143 -143
  306. package/src/ui/Rescope.d.ts +10 -10
  307. package/src/ui/Rescope.js +31 -31
  308. package/src/ui/Rescope.spec.js +195 -195
  309. package/src/ui/ResizeManager.d.ts +9 -9
  310. package/src/ui/ResizeManager.js +30 -30
  311. package/src/ui/Restate.d.ts +21 -21
  312. package/src/ui/Restate.js +163 -163
  313. package/src/ui/Restate.spec.js +422 -422
  314. package/src/ui/StaticText.d.ts +8 -8
  315. package/src/ui/StaticText.js +9 -9
  316. package/src/ui/StructuredInstanceDataAccessor.d.ts +16 -16
  317. package/src/ui/StructuredInstanceDataAccessor.js +26 -26
  318. package/src/ui/Text.d.ts +10 -10
  319. package/src/ui/Text.js +25 -25
  320. package/src/ui/VDOM.d.ts +3 -3
  321. package/src/ui/VDOM.js +2 -2
  322. package/src/ui/Widget.d.ts +14 -14
  323. package/src/ui/Widget.js +200 -200
  324. package/src/ui/ZIndexManager.d.ts +7 -7
  325. package/src/ui/ZIndexManager.js +11 -11
  326. package/src/ui/adapter/ArrayAdapter.d.ts +17 -17
  327. package/src/ui/adapter/ArrayAdapter.js +142 -142
  328. package/src/ui/adapter/ArrayAdapter.spec.js +55 -55
  329. package/src/ui/adapter/DataAdapter.js +15 -15
  330. package/src/ui/adapter/GroupAdapter.d.ts +23 -23
  331. package/src/ui/adapter/TreeAdapter.d.ts +24 -24
  332. package/src/ui/adapter/TreeAdapter.js +100 -100
  333. package/src/ui/adapter/TreeAdapter.spec.js +67 -67
  334. package/src/ui/adapter/index.d.ts +4 -4
  335. package/src/ui/adapter/index.js +4 -4
  336. package/src/ui/app/History.d.ts +17 -17
  337. package/src/ui/app/History.js +114 -114
  338. package/src/ui/app/Url.d.ts +21 -21
  339. package/src/ui/app/Url.js +103 -103
  340. package/src/ui/app/Url.spec.js +51 -51
  341. package/src/ui/app/index.d.ts +4 -4
  342. package/src/ui/app/index.js +5 -5
  343. package/src/ui/app/startAppLoop.d.ts +3 -3
  344. package/src/ui/app/startAppLoop.js +57 -57
  345. package/src/ui/app/startHotAppLoop.d.ts +6 -6
  346. package/src/ui/app/startHotAppLoop.js +25 -25
  347. package/src/ui/batchUpdates.d.ts +10 -10
  348. package/src/ui/batchUpdates.js +67 -67
  349. package/src/ui/bind.d.ts +4 -4
  350. package/src/ui/bind.js +7 -7
  351. package/src/ui/createFunctionalComponent.d.ts +1 -1
  352. package/src/ui/createFunctionalComponent.js +68 -68
  353. package/src/ui/createFunctionalComponent.spec.js +400 -400
  354. package/src/ui/expr.d.ts +24 -24
  355. package/src/ui/expr.js +17 -17
  356. package/src/ui/flattenProps.js +21 -21
  357. package/src/ui/index.js +44 -44
  358. package/src/ui/index.scss +2 -2
  359. package/src/ui/keyboardShortcuts.d.ts +4 -4
  360. package/src/ui/keyboardShortcuts.js +31 -31
  361. package/src/ui/layout/Content.d.ts +14 -14
  362. package/src/ui/layout/Content.js +16 -16
  363. package/src/ui/layout/ContentPlaceholder.d.ts +17 -17
  364. package/src/ui/layout/ContentPlaceholder.js +79 -79
  365. package/src/ui/layout/ContentPlaceholder.spec.js +368 -368
  366. package/src/ui/layout/FirstVisibleChildLayout.d.ts +4 -4
  367. package/src/ui/layout/FirstVisibleChildLayout.js +65 -65
  368. package/src/ui/layout/FirstVisibleChildLayout.spec.js +196 -196
  369. package/src/ui/layout/LabelsLeftLayout.d.ts +11 -11
  370. package/src/ui/layout/LabelsLeftLayout.js +59 -59
  371. package/src/ui/layout/LabelsLeftLayout.scss +44 -44
  372. package/src/ui/layout/LabelsTopLayout.d.ts +15 -15
  373. package/src/ui/layout/LabelsTopLayout.js +134 -134
  374. package/src/ui/layout/LabelsTopLayout.scss +63 -63
  375. package/src/ui/layout/UseParentLayout.d.ts +4 -4
  376. package/src/ui/layout/UseParentLayout.js +6 -6
  377. package/src/ui/layout/exploreChildren.d.ts +14 -14
  378. package/src/ui/layout/exploreChildren.js +40 -40
  379. package/src/ui/layout/index.d.ts +10 -10
  380. package/src/ui/layout/index.js +10 -10
  381. package/src/ui/layout/index.scss +3 -3
  382. package/src/ui/layout/variables.scss +2 -2
  383. package/src/ui/selection/KeySelection.d.ts +17 -17
  384. package/src/ui/selection/KeySelection.js +129 -129
  385. package/src/ui/selection/PropertySelection.d.ts +17 -17
  386. package/src/ui/selection/PropertySelection.js +55 -55
  387. package/src/ui/selection/Selection.d.ts +27 -27
  388. package/src/ui/selection/Selection.js +93 -93
  389. package/src/ui/selection/index.d.ts +3 -3
  390. package/src/ui/selection/index.js +3 -3
  391. package/src/ui/tpl.d.ts +2 -2
  392. package/src/ui/tpl.js +4 -4
  393. package/src/ui/variables.scss +1 -1
  394. package/src/util/Component.d.ts +41 -41
  395. package/src/util/Component.js +107 -107
  396. package/src/util/Console.d.ts +4 -4
  397. package/src/util/Console.js +11 -11
  398. package/src/util/DOM.d.ts +33 -33
  399. package/src/util/DOM.js +72 -72
  400. package/src/util/Debug.d.ts +10 -10
  401. package/src/util/Debug.js +45 -45
  402. package/src/util/Format.d.ts +18 -18
  403. package/src/util/Format.spec.js +69 -69
  404. package/src/util/GlobalCacheIdentifier.js +11 -11
  405. package/src/util/GlobalCacheldentifier.d.ts +6 -6
  406. package/src/util/KeyCode.d.ts +21 -21
  407. package/src/util/KeyCode.js +21 -21
  408. package/src/util/SubscriberList.d.ts +41 -41
  409. package/src/util/SubscriberList.js +57 -57
  410. package/src/util/Timing.d.ts +13 -13
  411. package/src/util/Timing.js +57 -57
  412. package/src/util/TraversalStack.js +42 -42
  413. package/src/util/TraversalStack.spec.js +46 -46
  414. package/src/util/addEventListenerWithOptions.d.ts +6 -6
  415. package/src/util/addEventListenerWithOptions.js +9 -9
  416. package/src/util/browserSupportsPassiveEventHandlers.d.ts +4 -4
  417. package/src/util/browserSupportsPassiveEventHandlers.js +18 -18
  418. package/src/util/calculateNaturalElementHeight.d.ts +1 -1
  419. package/src/util/calculateNaturalElementHeight.js +22 -22
  420. package/src/util/call-once.scss +6 -6
  421. package/src/util/coalesce.d.ts +1 -1
  422. package/src/util/coalesce.js +6 -6
  423. package/src/util/color/hslToRgb.d.ts +8 -8
  424. package/src/util/color/hslToRgb.js +27 -27
  425. package/src/util/color/index.d.ts +3 -3
  426. package/src/util/color/index.js +4 -4
  427. package/src/util/color/parseColor.d.ts +59 -59
  428. package/src/util/color/parseColor.js +119 -119
  429. package/src/util/color/rgbToHex.d.ts +8 -8
  430. package/src/util/color/rgbToHex.js +7 -7
  431. package/src/util/color/rgbToHsl.d.ts +8 -8
  432. package/src/util/color/rgbToHsl.js +27 -27
  433. package/src/util/date/dateDiff.d.ts +7 -7
  434. package/src/util/date/dateDiff.js +3 -3
  435. package/src/util/date/diff.d.ts +7 -7
  436. package/src/util/date/diff.js +7 -7
  437. package/src/util/date/encodeDateWithTimezoneOffset.js +18 -18
  438. package/src/util/date/index.d.ts +8 -8
  439. package/src/util/date/index.js +9 -9
  440. package/src/util/date/lowerBoundCheck.d.ts +7 -7
  441. package/src/util/date/lowerBoundCheck.js +6 -6
  442. package/src/util/date/maxDate.d.ts +5 -5
  443. package/src/util/date/maxDate.js +9 -9
  444. package/src/util/date/minDate.d.ts +5 -5
  445. package/src/util/date/minDate.js +9 -9
  446. package/src/util/date/monthStart.d.ts +5 -5
  447. package/src/util/date/monthStart.js +3 -3
  448. package/src/util/date/sameDate.d.ts +6 -6
  449. package/src/util/date/sameDate.js +5 -5
  450. package/src/util/date/upperBoundCheck.d.ts +7 -7
  451. package/src/util/date/upperBoundCheck.js +6 -6
  452. package/src/util/date/upperBoundCheck.spec.js +30 -30
  453. package/src/util/date/zeroTime.d.ts +6 -6
  454. package/src/util/date/zeroTime.js +3 -3
  455. package/src/util/debounce.d.ts +9 -9
  456. package/src/util/debounce.js +18 -18
  457. package/src/util/dummyCallback.d.ts +1 -1
  458. package/src/util/dummyCallback.js +1 -1
  459. package/src/util/escapeSpecialRegexCharacters.d.ts +6 -6
  460. package/src/util/escapeSpecialRegexCharacters.js +3 -3
  461. package/src/util/eventCallbacks.d.ts +4 -4
  462. package/src/util/eventCallbacks.js +2 -2
  463. package/src/util/expandFatArrows.js +118 -118
  464. package/src/util/findScrollableParent.js +16 -16
  465. package/src/util/getActiveElement.js +3 -3
  466. package/src/util/getParentFrameBoundingClientRect.js +21 -21
  467. package/src/util/getScrollerBoundingClientRect.js +21 -21
  468. package/src/util/getSearchQueryPredicate.js +58 -58
  469. package/src/util/getSearchQueryPredicate.spec.js +40 -40
  470. package/src/util/getTopLevelBoundingClientRect.js +13 -13
  471. package/src/util/getVendorPrefix.js +26 -26
  472. package/src/util/index.d.ts +50 -50
  473. package/src/util/index.js +52 -52
  474. package/src/util/index.scss +10 -10
  475. package/src/util/innerTextTrim.d.ts +6 -6
  476. package/src/util/innerTextTrim.js +5 -5
  477. package/src/util/isArray.d.ts +1 -1
  478. package/src/util/isArray.js +3 -3
  479. package/src/util/isDefined.js +3 -3
  480. package/src/util/isDigit.d.ts +6 -6
  481. package/src/util/isDigit.js +3 -3
  482. package/src/util/isFunction.d.ts +1 -1
  483. package/src/util/isFunction.js +3 -3
  484. package/src/util/isNonEmptyArray.d.ts +1 -1
  485. package/src/util/isNonEmptyArray.js +3 -3
  486. package/src/util/isNumber.d.ts +1 -1
  487. package/src/util/isNumber.js +3 -3
  488. package/src/util/isObject.d.ts +1 -1
  489. package/src/util/isObject.js +3 -3
  490. package/src/util/isPromise.d.ts +1 -1
  491. package/src/util/isPromise.js +6 -6
  492. package/src/util/isString.d.ts +1 -1
  493. package/src/util/isString.js +3 -3
  494. package/src/util/isTextInputElement.d.ts +1 -1
  495. package/src/util/isTextInputElement.js +2 -2
  496. package/src/util/isTouchDevice.d.ts +1 -1
  497. package/src/util/isTouchDevice.js +7 -7
  498. package/src/util/isTouchEvent.d.ts +3 -3
  499. package/src/util/isTouchEvent.js +64 -64
  500. package/src/util/isUndefined.d.ts +1 -1
  501. package/src/util/isUndefined.js +3 -3
  502. package/src/util/onIdleCallback.js +13 -13
  503. package/src/util/parseStyle.d.ts +3 -3
  504. package/src/util/parseStyle.js +27 -27
  505. package/src/util/quote.d.ts +2 -2
  506. package/src/util/quote.js +4 -4
  507. package/src/util/reverseSlice.js +9 -9
  508. package/src/util/routeAppend.js +15 -15
  509. package/src/util/routeAppend.spec.js +19 -19
  510. package/src/util/scrollElementIntoView.d.ts +7 -7
  511. package/src/util/scrollElementIntoView.js +34 -34
  512. package/src/util/scss/add-rules.scss +39 -39
  513. package/src/util/scss/calc.scss +40 -40
  514. package/src/util/scss/call-once.scss +10 -10
  515. package/src/util/scss/clockwise.scss +47 -47
  516. package/src/util/scss/colors.scss +7 -7
  517. package/src/util/scss/deep-get.scss +9 -9
  518. package/src/util/scss/deep-merge.scss +18 -18
  519. package/src/util/scss/include.scss +47 -47
  520. package/src/util/scss/index.scss +9 -9
  521. package/src/util/shallowEquals.js +43 -43
  522. package/src/util/throttle.d.ts +8 -8
  523. package/src/util/throttle.js +14 -14
  524. package/src/util/validatedDebounce.js +19 -19
  525. package/src/variables.scss +217 -217
  526. package/src/widgets/AccessorBindings.spec.tsx +66 -66
  527. package/src/widgets/Button.d.ts +58 -58
  528. package/src/widgets/Button.js +118 -118
  529. package/src/widgets/Button.scss +117 -117
  530. package/src/widgets/CxCredit.d.ts +12 -12
  531. package/src/widgets/CxCredit.js +31 -31
  532. package/src/widgets/CxCredit.scss +41 -41
  533. package/src/widgets/DocumentTitle.d.ts +11 -11
  534. package/src/widgets/DocumentTitle.js +68 -68
  535. package/src/widgets/FlexBox.d.ts +69 -69
  536. package/src/widgets/FlexBox.js +92 -92
  537. package/src/widgets/FlexBox.scss +146 -146
  538. package/src/widgets/Heading.d.ts +16 -16
  539. package/src/widgets/Heading.js +32 -32
  540. package/src/widgets/Heading.scss +38 -38
  541. package/src/widgets/HighlightedSearchText.d.ts +9 -9
  542. package/src/widgets/HighlightedSearchText.js +36 -36
  543. package/src/widgets/HighlightedSearchText.scss +18 -18
  544. package/src/widgets/HtmlElement.d.ts +26 -26
  545. package/src/widgets/HtmlElement.js +273 -273
  546. package/src/widgets/HtmlElement.spec.js +57 -57
  547. package/src/widgets/Icon.d.ts +34 -34
  548. package/src/widgets/Icon.js +50 -50
  549. package/src/widgets/Icon.scss +20 -20
  550. package/src/widgets/List.d.ts +96 -96
  551. package/src/widgets/List.js +587 -587
  552. package/src/widgets/List.scss +92 -92
  553. package/src/widgets/ProgressBar.d.ts +17 -17
  554. package/src/widgets/ProgressBar.js +46 -46
  555. package/src/widgets/ProgressBar.scss +49 -49
  556. package/src/widgets/Resizer.d.ts +27 -27
  557. package/src/widgets/Resizer.js +151 -151
  558. package/src/widgets/Resizer.scss +42 -42
  559. package/src/widgets/Sandbox.d.ts +16 -16
  560. package/src/widgets/Sandbox.js +62 -62
  561. package/src/widgets/Section.d.ts +52 -52
  562. package/src/widgets/Section.js +139 -139
  563. package/src/widgets/Section.scss +54 -54
  564. package/src/widgets/animations.scss +10 -10
  565. package/src/widgets/autoFocus.d.ts +1 -1
  566. package/src/widgets/autoFocus.js +9 -9
  567. package/src/widgets/cx.d.ts +1 -1
  568. package/src/widgets/cx.js +71 -71
  569. package/src/widgets/drag-drop/DragClone.scss +33 -33
  570. package/src/widgets/drag-drop/DragHandle.d.ts +10 -10
  571. package/src/widgets/drag-drop/DragHandle.js +37 -37
  572. package/src/widgets/drag-drop/DragHandle.scss +16 -16
  573. package/src/widgets/drag-drop/DragSource.d.ts +45 -45
  574. package/src/widgets/drag-drop/DragSource.js +160 -160
  575. package/src/widgets/drag-drop/DragSource.scss +24 -24
  576. package/src/widgets/drag-drop/DropZone.d.ts +98 -98
  577. package/src/widgets/drag-drop/DropZone.scss +74 -74
  578. package/src/widgets/drag-drop/index.d.ts +4 -4
  579. package/src/widgets/drag-drop/index.js +4 -4
  580. package/src/widgets/drag-drop/index.scss +3 -3
  581. package/src/widgets/drag-drop/ops.d.ts +56 -56
  582. package/src/widgets/drag-drop/ops.js +344 -344
  583. package/src/widgets/drag-drop/variables.scss +11 -11
  584. package/src/widgets/enableAllInternalDependencies.d.ts +1 -1
  585. package/src/widgets/enableAllInternalDependencies.js +11 -11
  586. package/src/widgets/form/Calendar.d.ts +86 -86
  587. package/src/widgets/form/Calendar.js +145 -55
  588. package/src/widgets/form/Calendar.scss +34 -2
  589. package/src/widgets/form/Calendar.variables.scss +63 -63
  590. package/src/widgets/form/Checkbox.d.ts +43 -43
  591. package/src/widgets/form/Checkbox.js +200 -200
  592. package/src/widgets/form/Checkbox.scss +125 -125
  593. package/src/widgets/form/Checkbox.variables.scss +39 -39
  594. package/src/widgets/form/ColorField.d.ts +43 -43
  595. package/src/widgets/form/ColorField.js +397 -397
  596. package/src/widgets/form/ColorField.scss +92 -92
  597. package/src/widgets/form/ColorPicker.d.ts +23 -23
  598. package/src/widgets/form/ColorPicker.js +480 -480
  599. package/src/widgets/form/ColorPicker.scss +275 -275
  600. package/src/widgets/form/ColorPicker.variables.scss +22 -22
  601. package/src/widgets/form/DateField.d.ts +6 -6
  602. package/src/widgets/form/DateField.js +12 -12
  603. package/src/widgets/form/DateTimeField.d.ts +86 -86
  604. package/src/widgets/form/DateTimeField.js +573 -573
  605. package/src/widgets/form/DateTimeField.scss +90 -90
  606. package/src/widgets/form/DateTimePicker.js +391 -391
  607. package/src/widgets/form/DateTimePicker.scss +44 -44
  608. package/src/widgets/form/Field.d.ts +112 -112
  609. package/src/widgets/form/Field.scss +162 -162
  610. package/src/widgets/form/FieldGroup.d.ts +6 -6
  611. package/src/widgets/form/FieldGroup.js +5 -5
  612. package/src/widgets/form/FieldIcon.js +42 -42
  613. package/src/widgets/form/HelpText.d.ts +10 -10
  614. package/src/widgets/form/HelpText.js +9 -9
  615. package/src/widgets/form/HelpText.scss +23 -23
  616. package/src/widgets/form/Label.d.ts +23 -23
  617. package/src/widgets/form/Label.js +89 -89
  618. package/src/widgets/form/Label.scss +36 -36
  619. package/src/widgets/form/LabeledContainer.d.ts +9 -9
  620. package/src/widgets/form/LabeledContainer.js +59 -59
  621. package/src/widgets/form/LookupField.d.ts +173 -173
  622. package/src/widgets/form/LookupField.scss +219 -219
  623. package/src/widgets/form/MonthField.d.ts +92 -92
  624. package/src/widgets/form/MonthField.js +516 -516
  625. package/src/widgets/form/MonthField.scss +99 -99
  626. package/src/widgets/form/MonthPicker.d.ts +74 -74
  627. package/src/widgets/form/MonthPicker.js +632 -632
  628. package/src/widgets/form/MonthPicker.scss +120 -120
  629. package/src/widgets/form/NumberField.d.ts +96 -96
  630. package/src/widgets/form/NumberField.js +459 -459
  631. package/src/widgets/form/NumberField.scss +65 -65
  632. package/src/widgets/form/Radio.d.ts +37 -37
  633. package/src/widgets/form/Radio.js +188 -188
  634. package/src/widgets/form/Radio.scss +122 -122
  635. package/src/widgets/form/Radio.variables.scss +45 -45
  636. package/src/widgets/form/Select.d.ts +69 -69
  637. package/src/widgets/form/Select.js +269 -269
  638. package/src/widgets/form/Select.scss +98 -98
  639. package/src/widgets/form/Slider.d.ts +65 -65
  640. package/src/widgets/form/Slider.js +351 -351
  641. package/src/widgets/form/Slider.scss +119 -119
  642. package/src/widgets/form/Switch.d.ts +38 -38
  643. package/src/widgets/form/Switch.js +118 -118
  644. package/src/widgets/form/Switch.scss +140 -140
  645. package/src/widgets/form/TextArea.d.ts +17 -17
  646. package/src/widgets/form/TextArea.js +186 -186
  647. package/src/widgets/form/TextArea.scss +60 -60
  648. package/src/widgets/form/TextField.d.ts +78 -78
  649. package/src/widgets/form/TextField.js +288 -288
  650. package/src/widgets/form/TextField.scss +55 -55
  651. package/src/widgets/form/TimeField.d.ts +6 -6
  652. package/src/widgets/form/TimeField.js +11 -11
  653. package/src/widgets/form/TimeList.js +84 -84
  654. package/src/widgets/form/UploadButton.js +213 -213
  655. package/src/widgets/form/UploadButton.scss +47 -47
  656. package/src/widgets/form/ValidationError.d.ts +10 -10
  657. package/src/widgets/form/ValidationError.js +44 -44
  658. package/src/widgets/form/ValidationError.scss +21 -21
  659. package/src/widgets/form/ValidationGroup.d.ts +41 -41
  660. package/src/widgets/form/ValidationGroup.js +68 -68
  661. package/src/widgets/form/ValidationGroup.spec.js +148 -148
  662. package/src/widgets/form/Validator.d.ts +8 -8
  663. package/src/widgets/form/Validator.js +21 -21
  664. package/src/widgets/form/Wheel.js +261 -261
  665. package/src/widgets/form/Wheel.scss +150 -150
  666. package/src/widgets/form/index.d.ts +26 -26
  667. package/src/widgets/form/index.js +28 -28
  668. package/src/widgets/form/index.scss +24 -24
  669. package/src/widgets/form/variables.scss +352 -352
  670. package/src/widgets/grid/Grid.d.ts +1 -0
  671. package/src/widgets/grid/Grid.js +5 -3
  672. package/src/widgets/grid/Grid.scss +680 -680
  673. package/src/widgets/grid/GridCell.d.ts +38 -38
  674. package/src/widgets/grid/GridCell.js +71 -71
  675. package/src/widgets/grid/GridCellEditor.js +41 -41
  676. package/src/widgets/grid/GridRow.js +228 -228
  677. package/src/widgets/grid/GridRowLine.js +24 -24
  678. package/src/widgets/grid/Pagination.d.ts +14 -14
  679. package/src/widgets/grid/Pagination.js +94 -94
  680. package/src/widgets/grid/Pagination.scss +113 -113
  681. package/src/widgets/grid/TreeNode.d.ts +25 -25
  682. package/src/widgets/grid/TreeNode.js +102 -102
  683. package/src/widgets/grid/TreeNode.scss +89 -89
  684. package/src/widgets/grid/index.d.ts +3 -3
  685. package/src/widgets/grid/index.js +14 -14
  686. package/src/widgets/grid/index.scss +3 -3
  687. package/src/widgets/icons/arrow-down.svg +3 -3
  688. package/src/widgets/icons/arrow-right.svg +2 -2
  689. package/src/widgets/icons/base.svg +104 -104
  690. package/src/widgets/icons/calendar-old.svg +169 -169
  691. package/src/widgets/icons/calendar.js +16 -16
  692. package/src/widgets/icons/calendar.svg +187 -187
  693. package/src/widgets/icons/check.js +12 -12
  694. package/src/widgets/icons/clear.js +14 -14
  695. package/src/widgets/icons/clear.svg +74 -74
  696. package/src/widgets/icons/close.js +19 -19
  697. package/src/widgets/icons/close.svg +74 -74
  698. package/src/widgets/icons/cx.js +37 -37
  699. package/src/widgets/icons/drop-down.js +14 -14
  700. package/src/widgets/icons/dropdown-arrow.svg +61 -61
  701. package/src/widgets/icons/file.js +12 -12
  702. package/src/widgets/icons/file.svg +4 -4
  703. package/src/widgets/icons/folder-open.js +14 -14
  704. package/src/widgets/icons/folder-open.svg +5 -5
  705. package/src/widgets/icons/folder.js +12 -12
  706. package/src/widgets/icons/folder.svg +58 -58
  707. package/src/widgets/icons/forward.js +21 -21
  708. package/src/widgets/icons/forward.svg +67 -67
  709. package/src/widgets/icons/index.js +14 -14
  710. package/src/widgets/icons/loading.js +23 -23
  711. package/src/widgets/icons/loading.svg +4 -4
  712. package/src/widgets/icons/menu.js +16 -16
  713. package/src/widgets/icons/pixel-picker.js +17 -17
  714. package/src/widgets/icons/registry.js +53 -53
  715. package/src/widgets/icons/search.js +12 -12
  716. package/src/widgets/icons/search.svg +107 -107
  717. package/src/widgets/icons/sort-asc.js +13 -13
  718. package/src/widgets/icons/sort-asc.svg +3 -3
  719. package/src/widgets/icons/square.js +17 -17
  720. package/src/widgets/index.d.ts +55 -55
  721. package/src/widgets/index.js +57 -57
  722. package/src/widgets/index.scss +16 -16
  723. package/src/widgets/nav/Link.d.ts +26 -26
  724. package/src/widgets/nav/Link.js +7 -7
  725. package/src/widgets/nav/Link.scss +18 -18
  726. package/src/widgets/nav/LinkButton.d.ts +31 -31
  727. package/src/widgets/nav/Menu.d.ts +27 -27
  728. package/src/widgets/nav/Menu.js +406 -406
  729. package/src/widgets/nav/Menu.scss +74 -74
  730. package/src/widgets/nav/MenuItem.d.ts +31 -31
  731. package/src/widgets/nav/MenuItem.js +445 -445
  732. package/src/widgets/nav/MenuSpacer.d.ts +5 -5
  733. package/src/widgets/nav/MenuSpacer.js +12 -12
  734. package/src/widgets/nav/RedirectRoute.d.ts +9 -9
  735. package/src/widgets/nav/RedirectRoute.js +40 -40
  736. package/src/widgets/nav/Route.d.ts +21 -21
  737. package/src/widgets/nav/Route.js +105 -105
  738. package/src/widgets/nav/Route.spec.js +27 -27
  739. package/src/widgets/nav/Scroller.d.ts +17 -17
  740. package/src/widgets/nav/Scroller.js +214 -214
  741. package/src/widgets/nav/Scroller.scss +146 -146
  742. package/src/widgets/nav/Submenu.d.ts +6 -6
  743. package/src/widgets/nav/Submenu.js +6 -6
  744. package/src/widgets/nav/Tab.d.ts +33 -33
  745. package/src/widgets/nav/Tab.js +82 -82
  746. package/src/widgets/nav/Tab.scss +81 -81
  747. package/src/widgets/nav/cover.scss +21 -21
  748. package/src/widgets/nav/index.d.ts +10 -10
  749. package/src/widgets/nav/index.js +10 -10
  750. package/src/widgets/nav/index.scss +5 -5
  751. package/src/widgets/nav/variables.scss +25 -25
  752. package/src/widgets/overlay/ContextMenu.d.ts +10 -10
  753. package/src/widgets/overlay/ContextMenu.js +29 -29
  754. package/src/widgets/overlay/Dropdown.d.ts +32 -32
  755. package/src/widgets/overlay/Dropdown.js +612 -612
  756. package/src/widgets/overlay/Dropdown.scss +184 -184
  757. package/src/widgets/overlay/FlyweightTooltipTracker.d.ts +8 -8
  758. package/src/widgets/overlay/FlyweightTooltipTracker.js +36 -36
  759. package/src/widgets/overlay/MsgBox.d.ts +16 -16
  760. package/src/widgets/overlay/MsgBox.js +116 -116
  761. package/src/widgets/overlay/Overlay.d.ts +69 -69
  762. package/src/widgets/overlay/Overlay.js +747 -747
  763. package/src/widgets/overlay/Overlay.scss +66 -66
  764. package/src/widgets/overlay/Toast.d.ts +30 -30
  765. package/src/widgets/overlay/Toast.js +92 -92
  766. package/src/widgets/overlay/Toast.scss +162 -162
  767. package/src/widgets/overlay/Tooltip.d.ts +50 -50
  768. package/src/widgets/overlay/Tooltip.js +288 -288
  769. package/src/widgets/overlay/Tooltip.scss +175 -175
  770. package/src/widgets/overlay/alerts.d.ts +7 -7
  771. package/src/widgets/overlay/alerts.js +39 -39
  772. package/src/widgets/overlay/captureMouse.d.ts +53 -53
  773. package/src/widgets/overlay/captureMouse.js +124 -124
  774. package/src/widgets/overlay/captureMouse.scss +13 -13
  775. package/src/widgets/overlay/index.d.ts +10 -10
  776. package/src/widgets/overlay/index.js +10 -10
  777. package/src/widgets/overlay/index.scss +15 -15
  778. package/src/widgets/overlay/tooltip-ops.d.ts +8 -8
  779. package/src/widgets/overlay/tooltip-ops.js +24 -24
  780. package/src/widgets/variables.scss +144 -144
@@ -1,12 +1,12 @@
1
- $cx-default-dragclone-background-color: rgba(white, 0.9) !default;
2
- $cx-default-dragclone-box-shadow: 0 0 3px rgba(128, 128, 128, 0.3) !default;
3
-
4
- $cx-dragclone-style: (
5
- background-color: $cx-default-dragclone-background-color,
6
- box-shadow: $cx-default-dragclone-box-shadow,
7
- opacity: 0.9
8
- ) !default;
9
-
10
- $cx-dependencies: map-merge($cx-dependencies, (
11
- 'cx/widgets/DragSource': 'cx/widgets/DragClone'
1
+ $cx-default-dragclone-background-color: rgba(white, 0.9) !default;
2
+ $cx-default-dragclone-box-shadow: 0 0 3px rgba(128, 128, 128, 0.3) !default;
3
+
4
+ $cx-dragclone-style: (
5
+ background-color: $cx-default-dragclone-background-color,
6
+ box-shadow: $cx-default-dragclone-box-shadow,
7
+ opacity: 0.9
8
+ ) !default;
9
+
10
+ $cx-dependencies: map-merge($cx-dependencies, (
11
+ 'cx/widgets/DragSource': 'cx/widgets/DragClone'
12
12
  ))
@@ -1 +1 @@
1
- export function enableAllInternalDependencies();
1
+ export function enableAllInternalDependencies();
@@ -1,11 +1,11 @@
1
- import {enableTooltips} from './overlay/Tooltip';
2
- import {enableMsgBoxAlerts} from './overlay/MsgBox';
3
- import {enableCultureSensitiveFormatting} from '../ui/Format';
4
- import {enableFatArrowExpansion} from '../data/enableFatArrowExpansion';
5
-
6
- export function enableAllInternalDependencies() {
7
- enableTooltips();
8
- enableMsgBoxAlerts();
9
- enableCultureSensitiveFormatting();
10
- enableFatArrowExpansion();
11
- }
1
+ import {enableTooltips} from './overlay/Tooltip';
2
+ import {enableMsgBoxAlerts} from './overlay/MsgBox';
3
+ import {enableCultureSensitiveFormatting} from '../ui/Format';
4
+ import {enableFatArrowExpansion} from '../data/enableFatArrowExpansion';
5
+
6
+ export function enableAllInternalDependencies() {
7
+ enableTooltips();
8
+ enableMsgBoxAlerts();
9
+ enableCultureSensitiveFormatting();
10
+ enableFatArrowExpansion();
11
+ }
@@ -1,86 +1,86 @@
1
- import * as Cx from "../../core";
2
- import { FieldProps } from "./Field";
3
-
4
- interface DayInfo {
5
- mod?: string;
6
- className?: string;
7
- style?: Cx.Record;
8
- unselectable?: boolean;
9
- disabled?: boolean;
10
- }
11
-
12
- interface DayData {
13
- [day: string]: DayInfo;
14
- }
15
-
16
- interface CalendarProps extends FieldProps {
17
- /** Selected date. This should be a `Date` object or a valid date string consumable by `Date.parse` function. */
18
- value?: Cx.Prop<string | Date>;
19
-
20
- /** View reference date. If no date is selected, this date is used to determine which month to show in the calendar. */
21
- refDate?: Cx.Prop<string | Date>;
22
-
23
- /** Minimum date value. This should be a `Date` object or a valid date string consumable by `Date.parse` function. */
24
- minValue?: Cx.Prop<string | Date>;
25
-
26
- /** Set to `true` to disallow the `minValue`. Default value is `false`. */
27
- minExclusive?: Cx.BooleanProp;
28
-
29
- /** Maximum date value. This should be a `Date` object or a valid date string consumable by `Date.parse` function. */
30
- maxValue?: Cx.Prop<string | Date>;
31
-
32
- /** Set to `true` to disallow the `maxValue`. Default value is `false`. */
33
- maxExclusive?: Cx.BooleanProp;
34
-
35
- /** Base CSS class to be applied to the calendar. Defaults to `calendar`. */
36
- baseClass?: string;
37
-
38
- /** Highlight today's date. Default is true. */
39
- highlightToday?: boolean;
40
-
41
- /** Maximum value error text. */
42
- maxValueErrorText?: string;
43
-
44
- /** Maximum exclusive value error text. */
45
- maxExclusiveErrorText?: string;
46
-
47
- /** Minimum value error text. */
48
- minValueErrorText?: string;
49
-
50
- /** Minimum exclusive value error text. */
51
- minExclusiveErrorText?: string;
52
-
53
- /** The function that will be used to convert Date objects before writing data to the store.
54
- * Default implementation is Date.toISOString.
55
- * See also Culture.setDefaultDateEncoding.
56
- */
57
- encoding?: (date: Date) => any;
58
-
59
- /** Set to true to show the button for quickly selecting today's date. */
60
- showTodayButton?: boolean;
61
-
62
- /** Localizable text for the todayButton. Defaults to `"Today"`. */
63
- todayButtonText?: string;
64
-
65
- /** Defines which days of week should be displayed as disabled, i.e. `[0, 6]` will make Sunday and Saturday unselectable. */
66
- disabledDaysOfWeek?: number[];
67
-
68
- /** Set to true to show weeks starting from Monday. */
69
- startWithMonday?: boolean;
70
-
71
- /** Map of days to additional day information such as style, className, mod, unselectable and disabled.
72
- * Keys for the map should be created with date.toDateString().
73
- * Example. {
74
- * [new Date().toDateString()]: {
75
- * style: "color: red",
76
- * className: 'test-class',
77
- * mod: 'holiday',
78
- * unselectable: false,
79
- * disabled: false
80
- * }
81
- * }
82
- */
83
- dayData?: Cx.Prop<DayData>;
84
- }
85
-
86
- export class Calendar extends Cx.Widget<CalendarProps> {}
1
+ import * as Cx from "../../core";
2
+ import { FieldProps } from "./Field";
3
+
4
+ interface DayInfo {
5
+ mod?: string;
6
+ className?: string;
7
+ style?: Cx.Record;
8
+ unselectable?: boolean;
9
+ disabled?: boolean;
10
+ }
11
+
12
+ interface DayData {
13
+ [day: string]: DayInfo;
14
+ }
15
+
16
+ interface CalendarProps extends FieldProps {
17
+ /** Selected date. This should be a `Date` object or a valid date string consumable by `Date.parse` function. */
18
+ value?: Cx.Prop<string | Date>;
19
+
20
+ /** View reference date. If no date is selected, this date is used to determine which month to show in the calendar. */
21
+ refDate?: Cx.Prop<string | Date>;
22
+
23
+ /** Minimum date value. This should be a `Date` object or a valid date string consumable by `Date.parse` function. */
24
+ minValue?: Cx.Prop<string | Date>;
25
+
26
+ /** Set to `true` to disallow the `minValue`. Default value is `false`. */
27
+ minExclusive?: Cx.BooleanProp;
28
+
29
+ /** Maximum date value. This should be a `Date` object or a valid date string consumable by `Date.parse` function. */
30
+ maxValue?: Cx.Prop<string | Date>;
31
+
32
+ /** Set to `true` to disallow the `maxValue`. Default value is `false`. */
33
+ maxExclusive?: Cx.BooleanProp;
34
+
35
+ /** Base CSS class to be applied to the calendar. Defaults to `calendar`. */
36
+ baseClass?: string;
37
+
38
+ /** Highlight today's date. Default is true. */
39
+ highlightToday?: boolean;
40
+
41
+ /** Maximum value error text. */
42
+ maxValueErrorText?: string;
43
+
44
+ /** Maximum exclusive value error text. */
45
+ maxExclusiveErrorText?: string;
46
+
47
+ /** Minimum value error text. */
48
+ minValueErrorText?: string;
49
+
50
+ /** Minimum exclusive value error text. */
51
+ minExclusiveErrorText?: string;
52
+
53
+ /** The function that will be used to convert Date objects before writing data to the store.
54
+ * Default implementation is Date.toISOString.
55
+ * See also Culture.setDefaultDateEncoding.
56
+ */
57
+ encoding?: (date: Date) => any;
58
+
59
+ /** Set to true to show the button for quickly selecting today's date. */
60
+ showTodayButton?: boolean;
61
+
62
+ /** Localizable text for the todayButton. Defaults to `"Today"`. */
63
+ todayButtonText?: string;
64
+
65
+ /** Defines which days of week should be displayed as disabled, i.e. `[0, 6]` will make Sunday and Saturday unselectable. */
66
+ disabledDaysOfWeek?: number[];
67
+
68
+ /** Set to true to show weeks starting from Monday. */
69
+ startWithMonday?: boolean;
70
+
71
+ /** Map of days to additional day information such as style, className, mod, unselectable and disabled.
72
+ * Keys for the map should be created with date.toDateString().
73
+ * Example. {
74
+ * [new Date().toDateString()]: {
75
+ * style: "color: red",
76
+ * className: 'test-class',
77
+ * mod: 'holiday',
78
+ * unselectable: false,
79
+ * disabled: false
80
+ * }
81
+ * }
82
+ */
83
+ dayData?: Cx.Prop<DayData>;
84
+ }
85
+
86
+ export class Calendar extends Cx.Widget<CalendarProps> {}
@@ -1,26 +1,26 @@
1
- import { Widget, VDOM } from "../../ui/Widget";
2
- import { Field, getFieldTooltip } from "./Field";
3
- import { Culture } from "../../ui/Culture";
4
- import { FocusManager, oneFocusOut, offFocusOut } from "../../ui/FocusManager";
5
1
  import { StringTemplate } from "../../data/StringTemplate";
6
- import { zeroTime } from "../../util/date/zeroTime";
2
+ import { Culture } from "../../ui/Culture";
3
+ import { FocusManager, offFocusOut, oneFocusOut } from "../../ui/FocusManager";
4
+ import "../../ui/Format";
5
+ import { Localization } from "../../ui/Localization";
6
+ import { VDOM, Widget } from "../../ui/Widget";
7
+ import { KeyCode } from "../../util/KeyCode";
7
8
  import { dateDiff } from "../../util/date/dateDiff";
8
9
  import { lowerBoundCheck } from "../../util/date/lowerBoundCheck";
9
- import { upperBoundCheck } from "../../util/date/upperBoundCheck";
10
+ import { monthStart } from "../../util/date/monthStart";
10
11
  import { sameDate } from "../../util/date/sameDate";
12
+ import { upperBoundCheck } from "../../util/date/upperBoundCheck";
13
+ import { zeroTime } from "../../util/date/zeroTime";
14
+ import DropdownIcon from "../icons/drop-down";
15
+ import ForwardIcon from "../icons/forward";
11
16
  import {
12
- tooltipParentWillReceiveProps,
13
- tooltipParentWillUnmount,
14
- tooltipMouseMove,
15
17
  tooltipMouseLeave,
18
+ tooltipMouseMove,
16
19
  tooltipParentDidMount,
20
+ tooltipParentWillReceiveProps,
21
+ tooltipParentWillUnmount,
17
22
  } from "../overlay/tooltip-ops";
18
- import { KeyCode } from "../../util/KeyCode";
19
- import { Localization } from "../../ui/Localization";
20
- import ForwardIcon from "../icons/forward";
21
- import DropdownIcon from "../icons/drop-down";
22
- import "../../ui/Format";
23
- import { monthStart } from "../../util/date/monthStart";
23
+ import { Field, getFieldTooltip } from "./Field";
24
24
 
25
25
  export class Calendar extends Field {
26
26
  declareData() {
@@ -37,7 +37,7 @@ export class Calendar extends Field {
37
37
  focusable: undefined,
38
38
  dayData: undefined,
39
39
  },
40
- ...arguments
40
+ ...arguments,
41
41
  );
42
42
  }
43
43
 
@@ -175,8 +175,9 @@ export class CalendarCmp extends VDOM.Component {
175
175
  hover: false,
176
176
  focus: false,
177
177
  cursor: zeroTime(data.date || refDate),
178
+ activeView: "calendar",
178
179
  },
179
- this.getPage(refDate)
180
+ this.getPage(refDate),
180
181
  );
181
182
 
182
183
  this.handleMouseMove = this.handleMouseMove.bind(this);
@@ -367,6 +368,7 @@ export class CalendarCmp extends VDOM.Component {
367
368
  if (this.props.instance.widget.autoFocus) this.el.focus();
368
369
 
369
370
  tooltipParentDidMount(this.el, ...getFieldTooltip(this.props.instance));
371
+ this.el.addEventListener("wheel", (e) => this.handleWheel(e));
370
372
  }
371
373
 
372
374
  UNSAFE_componentWillReceiveProps(props) {
@@ -385,6 +387,85 @@ export class CalendarCmp extends VDOM.Component {
385
387
  tooltipParentWillUnmount(this.props.instance);
386
388
  }
387
389
 
390
+ showYearDropdown() {
391
+ this.setState({
392
+ activeView: "year-picker",
393
+ yearPickerHeight: this.el.firstChild.offsetHeight,
394
+ });
395
+ }
396
+
397
+ handleYearSelect(e, year) {
398
+ e.preventDefault();
399
+ e.stopPropagation();
400
+ let refDate = new Date(this.state.refDate);
401
+ refDate.setFullYear(year);
402
+ this.setState({
403
+ ...this.getPage(refDate),
404
+ refDate,
405
+ activeView: "calendar",
406
+ });
407
+ }
408
+
409
+ renderYearPicker() {
410
+ let { data, widget } = this.props.instance;
411
+ let minYear = data.minValue?.getFullYear();
412
+ let maxYear = data.maxValue?.getFullYear();
413
+ let { CSS } = this.props.instance.widget;
414
+
415
+ let years = [];
416
+ let currentYear = new Date().getFullYear();
417
+ let midYear = currentYear - (currentYear % 5);
418
+ let refYear = new Date(this.state.refDate).getFullYear();
419
+ for (let i = midYear - 100; i <= midYear + 100; i++) {
420
+ years.push(i);
421
+ }
422
+
423
+ let rows = [];
424
+ for (let i = 0; i < years.length; i += 5) {
425
+ rows.push(years.slice(i, i + 5));
426
+ }
427
+ return (
428
+ <div
429
+ className={CSS.element(widget.baseClass, "year-picker")}
430
+ style={{
431
+ height: this.state.yearPickerHeight,
432
+ }}
433
+ ref={(el) => {
434
+ if (el) {
435
+ el.addEventListener("wheel", (e) => {
436
+ e.stopPropagation();
437
+ });
438
+
439
+ let activeYear = el.querySelector("." + CSS.state("selected"));
440
+ if (activeYear) activeYear.scrollIntoView({ block: "center", behavior: "instant" });
441
+ }
442
+ }}
443
+ >
444
+ <table>
445
+ <tbody>
446
+ {rows.map((row, rowIndex) => (
447
+ <tr key={rowIndex}>
448
+ {row.map((year) => (
449
+ <td
450
+ key={year}
451
+ className={CSS.element(this.props.instance.widget.baseClass, "year-option", {
452
+ unselectable: (minYear && year < minYear) || (maxYear && year > maxYear),
453
+ selected: year === refYear,
454
+ active: year === currentYear,
455
+ })}
456
+ onClick={(e) => this.handleYearSelect(e, year)}
457
+ >
458
+ {year}
459
+ </td>
460
+ ))}
461
+ </tr>
462
+ ))}
463
+ </tbody>
464
+ </table>
465
+ </div>
466
+ );
467
+ }
468
+
388
469
  render() {
389
470
  let { data, widget } = this.props.instance;
390
471
  let { CSS, baseClass, disabledDaysOfWeek, startWithMonday } = widget;
@@ -414,7 +495,7 @@ export class CalendarCmp extends VDOM.Component {
414
495
  today: widget.highlightToday && sameDate(date, today),
415
496
  }),
416
497
  dayInfo.className,
417
- CSS.mod(dayInfo.mod)
498
+ CSS.mod(dayInfo.mod),
418
499
  );
419
500
  let dateInst = new Date(date);
420
501
  days.push(
@@ -429,7 +510,7 @@ export class CalendarCmp extends VDOM.Component {
429
510
  onMouseDown={unselectable ? null : this.handleMouseDown}
430
511
  >
431
512
  {date.getDate()}
432
- </td>
513
+ </td>,
433
514
  );
434
515
  date.setDate(date.getDate() + 1);
435
516
  }
@@ -438,7 +519,7 @@ export class CalendarCmp extends VDOM.Component {
438
519
  <td />
439
520
  {days}
440
521
  <td />
441
- </tr>
522
+ </tr>,
442
523
  );
443
524
  }
444
525
 
@@ -465,44 +546,51 @@ export class CalendarCmp extends VDOM.Component {
465
546
  onMouseMove={(e) => tooltipMouseMove(e, ...getFieldTooltip(this.props.instance))}
466
547
  onMouseLeave={(e) => this.handleMouseLeave(e)}
467
548
  onMouseEnter={(e) => this.handleMouseEnter(e)}
468
- onWheel={(e) => this.handleWheel(e)}
549
+ // onWheel={(e) => this.handleWheel(e)}
469
550
  onFocus={(e) => this.handleFocus(e)}
470
551
  onBlur={(e) => this.handleBlur(e)}
471
552
  >
472
- <table>
473
- <thead>
474
- <tr key="h" className={CSS.element(baseClass, "header")}>
475
- <td />
476
- <td onClick={(e) => this.move(e, "y", -1)}>
477
- <ForwardIcon className={CSS.element(baseClass, "icon-prev-year")} />
478
- </td>
479
- <td onClick={(e) => this.move(e, "m", -1)}>
480
- <DropdownIcon className={CSS.element(baseClass, "icon-prev-month")} />
481
- </td>
482
- <th className={CSS.element(baseClass, "display")} colSpan="3">
483
- {monthNames[month]}
484
- <br />
485
- {year}
486
- </th>
487
- <td onClick={(e) => this.move(e, "m", +1)}>
488
- <DropdownIcon className={CSS.element(baseClass, "icon-next-month")} />
489
- </td>
490
- <td onClick={(e) => this.move(e, "y", +1)}>
491
- <ForwardIcon className={CSS.element(baseClass, "icon-next-year")} />
492
- </td>
493
- <td />
494
- </tr>
495
- <tr key="d" className={CSS.element(baseClass, "day-names")}>
496
- <td />
497
- {dayNames.map((name, i) => (
498
- <th key={i}>{name}</th>
499
- ))}
500
- <td />
501
- </tr>
502
- </thead>
503
- <tbody>{weeks}</tbody>
504
- </table>
505
- {widget.showTodayButton && (
553
+ {this.state.activeView == "calendar" && (
554
+ <table>
555
+ <thead>
556
+ <tr key="h" className={CSS.element(baseClass, "header")}>
557
+ <td />
558
+ <td onClick={(e) => this.move(e, "y", -1)}>
559
+ <ForwardIcon className={CSS.element(baseClass, "icon-prev-year")} />
560
+ </td>
561
+ <td onClick={(e) => this.move(e, "m", -1)}>
562
+ <DropdownIcon className={CSS.element(baseClass, "icon-prev-month")} />
563
+ </td>
564
+ <th className={CSS.element(baseClass, "display")} colSpan="3">
565
+ {monthNames[month]}
566
+ <br />
567
+ <span
568
+ onClick={() => this.showYearDropdown()}
569
+ className={CSS.element(baseClass, "year-name")}
570
+ >
571
+ {year}
572
+ </span>
573
+ </th>
574
+ <td onClick={(e) => this.move(e, "m", +1)}>
575
+ <DropdownIcon className={CSS.element(baseClass, "icon-next-month")} />
576
+ </td>
577
+ <td onClick={(e) => this.move(e, "y", +1)}>
578
+ <ForwardIcon className={CSS.element(baseClass, "icon-next-year")} />
579
+ </td>
580
+ <td />
581
+ </tr>
582
+ <tr key="d" className={CSS.element(baseClass, "day-names")}>
583
+ <td />
584
+ {dayNames.map((name, i) => (
585
+ <th key={i}>{name}</th>
586
+ ))}
587
+ <td />
588
+ </tr>
589
+ </thead>
590
+ <tbody>{weeks}</tbody>
591
+ </table>
592
+ )}
593
+ {this.state.activeView == "calendar" && widget.showTodayButton && (
506
594
  <div className={CSS.element(baseClass, "toolbar")}>
507
595
  <button
508
596
  className={CSS.expand(CSS.element(baseClass, "today-button"), CSS.block("button", "hollow"))}
@@ -517,6 +605,8 @@ export class CalendarCmp extends VDOM.Component {
517
605
  </button>
518
606
  </div>
519
607
  )}
608
+
609
+ {this.state.activeView == "year-picker" && this.renderYearPicker()}
520
610
  </div>
521
611
  );
522
612
  }
@@ -16,6 +16,7 @@
16
16
  display: inline-block;
17
17
  vertical-align: middle;
18
18
  width: 18em;
19
+ overflow-y: auto;
19
20
  box-sizing: border-box;
20
21
 
21
22
  &:hover {
@@ -91,8 +92,8 @@
91
92
  }
92
93
  }
93
94
 
94
- td:first-child,
95
- td:last-child {
95
+ td:not(.cxe-calendar-year-option):first-child,
96
+ td:not(.cxe-calendar-year-option):last-child {
96
97
  display: none;
97
98
  pointer-events: none;
98
99
  }
@@ -137,6 +138,37 @@
137
138
  user-select: none;
138
139
  }
139
140
 
141
+ .#{$element}#{$name}-year {
142
+ &-name {
143
+ cursor: pointer;
144
+ }
145
+
146
+ &-picker {
147
+ user-select: none;
148
+ overflow-y: scroll;
149
+ width: 100%;
150
+ max-height: 24em;
151
+ height: auto;
152
+ }
153
+
154
+ &-option {
155
+ cursor: pointer;
156
+ @include cx-add-state-rules($cx-calendar-day-state-style-map, default);
157
+
158
+ &.#{$state}active {
159
+ @include cx-add-state-rules($cx-calendar-day-state-style-map, today);
160
+ }
161
+
162
+ &:hover {
163
+ @include cx-add-state-rules($cx-calendar-day-state-style-map, hover);
164
+ }
165
+
166
+ &.#{$state}selected {
167
+ @include cx-add-state-rules($cx-calendar-day-state-style-map, selected);
168
+ }
169
+ }
170
+ }
171
+
140
172
  .#{$element}#{$name}-icon-prev-year {
141
173
  transform: rotate(180deg);
142
174
  }