cx 22.3.0 → 22.3.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 (773) 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/data.js +2467 -2401
  5. package/dist/manifest.js +703 -697
  6. package/dist/ui.js +5209 -5191
  7. package/dist/widgets.js +21866 -21850
  8. package/index.js +17 -17
  9. package/locale/de-de.js +69 -69
  10. package/locale/en-us.js +71 -71
  11. package/locale/es-es.js +69 -69
  12. package/locale/fr-fr.js +70 -70
  13. package/locale/nl-nl.js +75 -75
  14. package/locale/pt-pt.js +63 -63
  15. package/locale/sr-latn-ba.js +70 -70
  16. package/package.json +30 -30
  17. package/src/charts/Bar.d.ts +27 -27
  18. package/src/charts/Bar.js +89 -89
  19. package/src/charts/Bar.scss +26 -26
  20. package/src/charts/BarGraph.d.ts +16 -16
  21. package/src/charts/BarGraph.js +110 -110
  22. package/src/charts/BarGraph.scss +27 -27
  23. package/src/charts/BubbleGraph.js +92 -92
  24. package/src/charts/BubbleGraph.scss +29 -29
  25. package/src/charts/Chart.d.ts +12 -12
  26. package/src/charts/Chart.js +77 -77
  27. package/src/charts/ColorMap.d.ts +26 -26
  28. package/src/charts/ColorMap.js +98 -98
  29. package/src/charts/Column.scss +26 -26
  30. package/src/charts/ColumnBarBase.d.ts +61 -61
  31. package/src/charts/ColumnBarBase.js +169 -169
  32. package/src/charts/ColumnBarGraphBase.d.ts +71 -71
  33. package/src/charts/ColumnBarGraphBase.js +119 -119
  34. package/src/charts/ColumnGraph.d.ts +19 -19
  35. package/src/charts/ColumnGraph.js +114 -114
  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 +26 -26
  42. package/src/charts/Legend.js +142 -142
  43. package/src/charts/Legend.scss +41 -41
  44. package/src/charts/LegendEntry.d.ts +37 -37
  45. package/src/charts/LegendEntry.js +117 -117
  46. package/src/charts/LegendEntry.scss +30 -30
  47. package/src/charts/LineGraph.d.ts +90 -90
  48. package/src/charts/LineGraph.js +201 -201
  49. package/src/charts/LineGraph.scss +23 -23
  50. package/src/charts/Marker.d.ts +87 -87
  51. package/src/charts/Marker.js +287 -287
  52. package/src/charts/Marker.scss +41 -41
  53. package/src/charts/MarkerLine.d.ts +57 -57
  54. package/src/charts/MarkerLine.js +128 -128
  55. package/src/charts/MarkerLine.scss +17 -17
  56. package/src/charts/MouseTracker.d.ts +16 -16
  57. package/src/charts/MouseTracker.js +80 -80
  58. package/src/charts/Pie.js +8 -8
  59. package/src/charts/PieChart.d.ts +80 -80
  60. package/src/charts/PieChart.js +370 -370
  61. package/src/charts/PieChart.scss +26 -26
  62. package/src/charts/PieLabel.d.ts +26 -26
  63. package/src/charts/PieLabel.js +65 -65
  64. package/src/charts/PieLabelsContainer.d.ts +3 -3
  65. package/src/charts/PieLabelsContainer.js +55 -55
  66. package/src/charts/Range.d.ts +74 -74
  67. package/src/charts/Range.js +205 -205
  68. package/src/charts/Range.scss +18 -18
  69. package/src/charts/ScatterGraph.d.ts +65 -65
  70. package/src/charts/ScatterGraph.js +155 -155
  71. package/src/charts/ScatterGraph.scss +21 -21
  72. package/src/charts/axis/Axis.d.ts +82 -82
  73. package/src/charts/axis/Axis.js +222 -222
  74. package/src/charts/axis/Axis.scss +22 -22
  75. package/src/charts/axis/CategoryAxis.d.ts +21 -21
  76. package/src/charts/axis/CategoryAxis.js +224 -224
  77. package/src/charts/axis/CategoryAxis.scss +32 -32
  78. package/src/charts/axis/NumericAxis.js +349 -349
  79. package/src/charts/axis/NumericAxis.scss +32 -32
  80. package/src/charts/axis/Stack.d.ts +10 -10
  81. package/src/charts/axis/Stack.js +58 -58
  82. package/src/charts/axis/TimeAxis.d.ts +23 -23
  83. package/src/charts/axis/TimeAxis.js +510 -510
  84. package/src/charts/axis/TimeAxis.scss +32 -32
  85. package/src/charts/axis/index.d.ts +3 -3
  86. package/src/charts/axis/index.js +3 -3
  87. package/src/charts/axis/index.scss +5 -5
  88. package/src/charts/axis/variables.scss +2 -2
  89. package/src/charts/helpers/MinMaxFinder.js +37 -37
  90. package/src/charts/helpers/MinMaxReducer.d.ts +22 -22
  91. package/src/charts/helpers/PointReducer.d.ts +15 -15
  92. package/src/charts/helpers/PointReducer.js +39 -39
  93. package/src/charts/helpers/SnapPointFinder.d.ts +18 -18
  94. package/src/charts/helpers/SnapPointFinder.js +46 -46
  95. package/src/charts/helpers/ValueAtFinder.d.ts +16 -16
  96. package/src/charts/helpers/ValueAtFinder.js +41 -41
  97. package/src/charts/helpers/index.d.ts +4 -4
  98. package/src/charts/helpers/index.js +4 -4
  99. package/src/charts/index.d.ts +23 -23
  100. package/src/charts/index.js +31 -31
  101. package/src/charts/index.scss +20 -20
  102. package/src/charts/palette.scss +95 -95
  103. package/src/charts/shapes.d.ts +22 -22
  104. package/src/charts/shapes.js +79 -79
  105. package/src/charts/variables.scss +14 -14
  106. package/src/core.d.ts +231 -196
  107. package/src/data/AggregateFunction.d.ts +17 -17
  108. package/src/data/AggregateFunction.js +148 -148
  109. package/src/data/ArrayElementView.d.ts +13 -13
  110. package/src/data/ArrayElementView.js +46 -46
  111. package/src/data/ArrayRef.d.ts +14 -14
  112. package/src/data/ArrayRef.js +34 -34
  113. package/src/data/AugmentedViewBase.d.ts +18 -18
  114. package/src/data/AugmentedViewBase.js +67 -67
  115. package/src/data/Binding.d.ts +16 -15
  116. package/src/data/Binding.js +12 -8
  117. package/src/data/Binding.spec.js +51 -51
  118. package/src/data/ExposedRecordView.d.ts +14 -14
  119. package/src/data/ExposedRecordView.js +69 -69
  120. package/src/data/ExposedValueView.d.ts +19 -19
  121. package/src/data/ExposedValueView.js +72 -72
  122. package/src/data/Expression.d.ts +16 -16
  123. package/src/data/Grouper.d.ts +21 -21
  124. package/src/data/Grouper.js +120 -120
  125. package/src/data/Grouper.spec.js +22 -22
  126. package/src/data/NestedDataView.d.ts +19 -19
  127. package/src/data/NestedDataView.js +22 -22
  128. package/src/data/ReadOnlyDataView.d.ts +14 -14
  129. package/src/data/ReadOnlyDataView.js +26 -26
  130. package/src/data/Ref.js +79 -79
  131. package/src/data/Store.d.ts +14 -14
  132. package/src/data/Store.js +46 -46
  133. package/src/data/Store.spec.js +22 -22
  134. package/src/data/StoreProxy.d.ts +4 -4
  135. package/src/data/StoreProxy.js +16 -16
  136. package/src/data/StoreRef.js +54 -52
  137. package/src/data/StringTemplate.d.ts +13 -13
  138. package/src/data/StringTemplate.js +97 -97
  139. package/src/data/StringTemplate.spec.js +82 -82
  140. package/src/data/StructuredSelector.d.ts +16 -16
  141. package/src/data/StructuredSelector.js +131 -145
  142. package/src/data/StructuredSelector.spec.js +113 -98
  143. package/src/data/SubscribableView.d.ts +11 -11
  144. package/src/data/View.d.ts +40 -16
  145. package/src/data/View.js +27 -19
  146. package/src/data/View.spec.js +60 -60
  147. package/src/data/ZoomIntoPropertyView.d.ts +11 -11
  148. package/src/data/ZoomIntoPropertyView.js +33 -33
  149. package/src/data/ZoomIntoPropertyView.spec.js +65 -65
  150. package/src/data/comparer.d.ts +7 -7
  151. package/src/data/comparer.js +46 -46
  152. package/src/data/comparer.spec.js +60 -60
  153. package/src/data/computable.d.ts +27 -4
  154. package/src/data/computable.js +56 -55
  155. package/src/data/computable.spec.js +55 -47
  156. package/src/data/createAccessorModelProxy.d.ts +6 -0
  157. package/src/data/createAccessorModelProxy.js +24 -0
  158. package/src/data/createAccessorModelProxy.spec.tsx +23 -0
  159. package/src/data/createStructuredSelector.d.ts +2 -2
  160. package/src/data/createStructuredSelector.js +43 -42
  161. package/src/data/createStructuredSelector.spec.js +46 -46
  162. package/src/data/defaultCompare.js +14 -14
  163. package/src/data/diff/diffArrays.d.ts +15 -15
  164. package/src/data/diff/diffArrays.js +41 -41
  165. package/src/data/diff/diffs.spec.js +49 -49
  166. package/src/data/diff/index.d.ts +1 -1
  167. package/src/data/diff/index.js +1 -1
  168. package/src/data/enableFatArrowExpansion.d.ts +1 -1
  169. package/src/data/enableFatArrowExpansion.js +6 -6
  170. package/src/data/getAccessor.d.ts +8 -8
  171. package/src/data/getAccessor.js +24 -15
  172. package/src/data/getSelector.d.ts +3 -3
  173. package/src/data/getSelector.js +4 -1
  174. package/src/data/getSelector.spec.js +43 -36
  175. package/src/data/index.d.ts +2 -0
  176. package/src/data/index.js +2 -0
  177. package/src/data/isSelector.d.ts +1 -1
  178. package/src/data/isSelector.js +26 -26
  179. package/src/data/ops/append.d.ts +1 -1
  180. package/src/data/ops/append.js +7 -7
  181. package/src/data/ops/append.spec.js +28 -28
  182. package/src/data/ops/filter.d.ts +1 -1
  183. package/src/data/ops/filter.js +8 -8
  184. package/src/data/ops/filter.spec.js +29 -29
  185. package/src/data/ops/findTreeNode.js +15 -15
  186. package/src/data/ops/findTreeNode.spec.js +24 -24
  187. package/src/data/ops/index.d.ts +10 -10
  188. package/src/data/ops/index.js +10 -10
  189. package/src/data/ops/insertElement.js +2 -2
  190. package/src/data/ops/merge.d.ts +3 -3
  191. package/src/data/ops/merge.js +9 -9
  192. package/src/data/ops/merge.spec.js +27 -27
  193. package/src/data/ops/moveElement.js +13 -13
  194. package/src/data/ops/removeTreeNodes.d.ts +1 -1
  195. package/src/data/ops/removeTreeNodes.js +5 -5
  196. package/src/data/ops/removeTreeNodes.spec.js +28 -28
  197. package/src/data/ops/updateArray.d.ts +5 -5
  198. package/src/data/ops/updateArray.js +24 -24
  199. package/src/data/ops/updateArray.spec.js +38 -38
  200. package/src/data/ops/updateTree.d.ts +7 -7
  201. package/src/data/ops/updateTree.js +25 -25
  202. package/src/data/ops/updateTree.spec.js +34 -34
  203. package/src/global.scss +13 -13
  204. package/src/hooks/createLocalStorageRef.d.ts +2 -2
  205. package/src/hooks/createLocalStorageRef.js +22 -22
  206. package/src/hooks/index.d.ts +8 -8
  207. package/src/hooks/index.js +7 -7
  208. package/src/hooks/invokeCallback.d.ts +5 -5
  209. package/src/hooks/invokeCallback.js +6 -6
  210. package/src/hooks/invokeCallback.spec.js +53 -53
  211. package/src/hooks/resolveCallback.d.ts +3 -3
  212. package/src/hooks/resolveCallback.js +11 -11
  213. package/src/hooks/resolveCallback.spec.js +54 -54
  214. package/src/hooks/store.d.ts +7 -7
  215. package/src/hooks/store.js +32 -32
  216. package/src/hooks/store.spec.js +73 -73
  217. package/src/hooks/useEffect.d.ts +2 -2
  218. package/src/hooks/useEffect.js +14 -14
  219. package/src/hooks/useInterval.js +7 -7
  220. package/src/hooks/useState.d.ts +2 -2
  221. package/src/hooks/useState.js +15 -15
  222. package/src/hooks/useTrigger.d.ts +4 -4
  223. package/src/hooks/useTrigger.js +20 -20
  224. package/src/hooks/useTrigger.spec.js +102 -102
  225. package/src/index.js +7 -7
  226. package/src/index.scss +6 -6
  227. package/src/svg/BoundedObject.d.ts +22 -22
  228. package/src/svg/BoundedObject.js +59 -59
  229. package/src/svg/ClipRect.d.ts +4 -4
  230. package/src/svg/ClipRect.js +23 -23
  231. package/src/svg/Ellipse.d.ts +23 -23
  232. package/src/svg/Ellipse.js +36 -36
  233. package/src/svg/Line.d.ts +20 -20
  234. package/src/svg/Line.js +32 -32
  235. package/src/svg/NonOverlappingRect.d.ts +5 -5
  236. package/src/svg/NonOverlappingRect.js +14 -14
  237. package/src/svg/NonOverlappingRectGroup.d.ts +3 -3
  238. package/src/svg/NonOverlappingRectGroup.js +36 -36
  239. package/src/svg/Rectangle.d.ts +23 -23
  240. package/src/svg/Rectangle.js +36 -36
  241. package/src/svg/Svg.d.ts +32 -32
  242. package/src/svg/Svg.js +177 -177
  243. package/src/svg/Svg.scss +26 -26
  244. package/src/svg/Text.d.ts +38 -38
  245. package/src/svg/Text.js +61 -61
  246. package/src/svg/TextualBoundedObject.d.ts +6 -6
  247. package/src/svg/TextualBoundedObject.js +28 -28
  248. package/src/svg/index.d.ts +11 -11
  249. package/src/svg/index.js +17 -17
  250. package/src/svg/index.scss +8 -8
  251. package/src/svg/util/Rect.d.ts +40 -40
  252. package/src/svg/util/Rect.js +108 -108
  253. package/src/ui/CSS.d.ts +19 -19
  254. package/src/ui/CSS.js +79 -79
  255. package/src/ui/CSSHelper.d.ts +10 -10
  256. package/src/ui/CSSHelper.js +17 -17
  257. package/src/ui/Container.d.ts +18 -18
  258. package/src/ui/Container.js +183 -183
  259. package/src/ui/ContentResolver.d.ts +13 -13
  260. package/src/ui/ContentResolver.js +78 -78
  261. package/src/ui/Controller.d.ts +13 -8
  262. package/src/ui/Controller.js +114 -114
  263. package/src/ui/Controller.spec.js +414 -414
  264. package/src/ui/Culture.d.ts +22 -22
  265. package/src/ui/Culture.js +65 -65
  266. package/src/ui/Cx.d.ts +18 -18
  267. package/src/ui/Cx.js +313 -313
  268. package/src/ui/Cx.spec.js +193 -193
  269. package/src/ui/DataProxy.d.ts +10 -10
  270. package/src/ui/DataProxy.js +44 -44
  271. package/src/ui/DataProxy.spec.js +335 -335
  272. package/src/ui/DetachedScope.d.ts +21 -21
  273. package/src/ui/DetachedScope.js +93 -93
  274. package/src/ui/FocusManager.d.ts +29 -29
  275. package/src/ui/FocusManager.js +163 -163
  276. package/src/ui/Format.d.ts +2 -2
  277. package/src/ui/Format.js +88 -88
  278. package/src/ui/HoverSync.d.ts +13 -13
  279. package/src/ui/HoverSync.js +147 -147
  280. package/src/ui/Instance.d.ts +6 -6
  281. package/src/ui/Instance.js +6 -5
  282. package/src/ui/IsolatedScope.d.ts +16 -16
  283. package/src/ui/IsolatedScope.js +29 -29
  284. package/src/ui/IsolatedScope.spec.js +62 -62
  285. package/src/ui/Localization.d.ts +17 -17
  286. package/src/ui/Localization.js +72 -72
  287. package/src/ui/PureContainer.d.ts +16 -16
  288. package/src/ui/PureContainer.js +7 -7
  289. package/src/ui/RenderingContext.d.ts +9 -9
  290. package/src/ui/RenderingContext.js +88 -88
  291. package/src/ui/Repeater.d.ts +46 -36
  292. package/src/ui/Repeater.js +98 -98
  293. package/src/ui/Repeater.spec.js +59 -59
  294. package/src/ui/Rescope.d.ts +9 -9
  295. package/src/ui/Rescope.js +31 -31
  296. package/src/ui/Rescope.spec.js +195 -195
  297. package/src/ui/ResizeManager.d.ts +9 -9
  298. package/src/ui/ResizeManager.js +30 -30
  299. package/src/ui/Restate.d.ts +12 -12
  300. package/src/ui/Restate.js +155 -155
  301. package/src/ui/Restate.spec.js +422 -423
  302. package/src/ui/StaticText.d.ts +8 -8
  303. package/src/ui/StaticText.js +9 -9
  304. package/src/ui/StructuredInstanceDataAccessor.d.ts +16 -16
  305. package/src/ui/StructuredInstanceDataAccessor.js +26 -26
  306. package/src/ui/Text.d.ts +10 -10
  307. package/src/ui/Text.js +27 -27
  308. package/src/ui/VDOM.d.ts +3 -3
  309. package/src/ui/VDOM.js +2 -2
  310. package/src/ui/Widget.d.ts +14 -14
  311. package/src/ui/Widget.js +200 -200
  312. package/src/ui/ZIndexManager.d.ts +7 -7
  313. package/src/ui/ZIndexManager.js +11 -11
  314. package/src/ui/adapter/ArrayAdapter.d.ts +16 -17
  315. package/src/ui/adapter/ArrayAdapter.js +142 -149
  316. package/src/ui/adapter/DataAdapter.d.ts +19 -19
  317. package/src/ui/adapter/DataAdapter.js +19 -19
  318. package/src/ui/adapter/GroupAdapter.d.ts +4 -4
  319. package/src/ui/adapter/GroupAdapter.js +135 -135
  320. package/src/ui/adapter/TreeAdapter.d.ts +4 -4
  321. package/src/ui/adapter/TreeAdapter.js +73 -76
  322. package/src/ui/adapter/TreeAdapter.spec.js +67 -67
  323. package/src/ui/adapter/index.d.ts +4 -4
  324. package/src/ui/adapter/index.js +4 -4
  325. package/src/ui/app/History.d.ts +17 -17
  326. package/src/ui/app/History.js +114 -114
  327. package/src/ui/app/Url.d.ts +21 -21
  328. package/src/ui/app/Url.js +103 -103
  329. package/src/ui/app/Url.spec.js +51 -51
  330. package/src/ui/app/index.d.ts +4 -4
  331. package/src/ui/app/index.js +5 -5
  332. package/src/ui/app/startAppLoop.d.ts +3 -3
  333. package/src/ui/app/startAppLoop.js +57 -57
  334. package/src/ui/app/startHotAppLoop.d.ts +6 -6
  335. package/src/ui/app/startHotAppLoop.js +25 -25
  336. package/src/ui/batchUpdates.d.ts +10 -10
  337. package/src/ui/batchUpdates.js +67 -67
  338. package/src/ui/bind.d.ts +3 -2
  339. package/src/ui/bind.js +7 -6
  340. package/src/ui/createFunctionalComponent.d.ts +1 -1
  341. package/src/ui/createFunctionalComponent.js +68 -68
  342. package/src/ui/createFunctionalComponent.spec.js +400 -400
  343. package/src/ui/expr.d.ts +23 -2
  344. package/src/ui/expr.js +17 -5
  345. package/src/ui/flattenProps.js +21 -21
  346. package/src/ui/index.js +44 -44
  347. package/src/ui/index.scss +2 -2
  348. package/src/ui/keyboardShortcuts.d.ts +4 -4
  349. package/src/ui/keyboardShortcuts.js +32 -32
  350. package/src/ui/layout/Content.d.ts +11 -11
  351. package/src/ui/layout/Content.js +16 -16
  352. package/src/ui/layout/ContentPlaceholder.d.ts +17 -17
  353. package/src/ui/layout/ContentPlaceholder.js +79 -79
  354. package/src/ui/layout/ContentPlaceholder.spec.js +368 -368
  355. package/src/ui/layout/FirstVisibleChildLayout.d.ts +4 -4
  356. package/src/ui/layout/FirstVisibleChildLayout.js +65 -65
  357. package/src/ui/layout/FirstVisibleChildLayout.spec.js +196 -196
  358. package/src/ui/layout/LabelsLeftLayout.d.ts +11 -11
  359. package/src/ui/layout/LabelsLeftLayout.js +59 -59
  360. package/src/ui/layout/LabelsLeftLayout.scss +44 -44
  361. package/src/ui/layout/LabelsTopLayout.d.ts +15 -15
  362. package/src/ui/layout/LabelsTopLayout.js +134 -134
  363. package/src/ui/layout/LabelsTopLayout.scss +63 -63
  364. package/src/ui/layout/UseParentLayout.d.ts +4 -4
  365. package/src/ui/layout/UseParentLayout.js +6 -6
  366. package/src/ui/layout/exploreChildren.d.ts +14 -14
  367. package/src/ui/layout/exploreChildren.js +40 -40
  368. package/src/ui/layout/index.d.ts +10 -10
  369. package/src/ui/layout/index.js +10 -10
  370. package/src/ui/layout/index.scss +3 -3
  371. package/src/ui/layout/variables.scss +2 -2
  372. package/src/ui/selection/KeySelection.d.ts +17 -17
  373. package/src/ui/selection/KeySelection.js +129 -129
  374. package/src/ui/selection/PropertySelection.d.ts +17 -17
  375. package/src/ui/selection/PropertySelection.js +57 -57
  376. package/src/ui/selection/Selection.d.ts +27 -27
  377. package/src/ui/selection/Selection.js +97 -97
  378. package/src/ui/selection/index.d.ts +3 -3
  379. package/src/ui/selection/index.js +3 -3
  380. package/src/ui/tpl.d.ts +2 -2
  381. package/src/ui/tpl.js +4 -4
  382. package/src/ui/variables.scss +1 -1
  383. package/src/util/Component.d.ts +41 -41
  384. package/src/util/Component.js +107 -107
  385. package/src/util/Console.d.ts +9 -9
  386. package/src/util/Console.js +11 -11
  387. package/src/util/DOM.d.ts +33 -33
  388. package/src/util/DOM.js +72 -72
  389. package/src/util/Debug.d.ts +10 -10
  390. package/src/util/Debug.js +45 -45
  391. package/src/util/Format.d.ts +13 -13
  392. package/src/util/Format.js +241 -241
  393. package/src/util/Format.spec.js +69 -69
  394. package/src/util/GlobalCacheIdentifier.js +11 -11
  395. package/src/util/GlobalCacheldentifier.d.ts +6 -6
  396. package/src/util/KeyCode.d.ts +21 -21
  397. package/src/util/KeyCode.js +21 -21
  398. package/src/util/SubscriberList.d.ts +41 -41
  399. package/src/util/SubscriberList.js +57 -57
  400. package/src/util/Timing.d.ts +13 -13
  401. package/src/util/Timing.js +57 -57
  402. package/src/util/TraversalStack.js +42 -42
  403. package/src/util/TraversalStack.spec.js +46 -46
  404. package/src/util/addEventListenerWithOptions.d.ts +6 -6
  405. package/src/util/addEventListenerWithOptions.js +9 -9
  406. package/src/util/browserSupportsPassiveEventHandlers.d.ts +4 -4
  407. package/src/util/browserSupportsPassiveEventHandlers.js +18 -18
  408. package/src/util/calculateNaturalElementHeight.d.ts +1 -1
  409. package/src/util/calculateNaturalElementHeight.js +22 -22
  410. package/src/util/call-once.scss +6 -6
  411. package/src/util/coalesce.d.ts +1 -1
  412. package/src/util/coalesce.js +6 -6
  413. package/src/util/color/hslToRgb.d.ts +8 -8
  414. package/src/util/color/hslToRgb.js +27 -27
  415. package/src/util/color/index.d.ts +3 -3
  416. package/src/util/color/index.js +4 -4
  417. package/src/util/color/parseColor.d.ts +59 -59
  418. package/src/util/color/parseColor.js +119 -119
  419. package/src/util/color/rgbToHex.d.ts +8 -8
  420. package/src/util/color/rgbToHex.js +7 -7
  421. package/src/util/color/rgbToHsl.d.ts +8 -8
  422. package/src/util/color/rgbToHsl.js +27 -27
  423. package/src/util/date/dateDiff.d.ts +7 -7
  424. package/src/util/date/dateDiff.js +3 -3
  425. package/src/util/date/diff.d.ts +7 -7
  426. package/src/util/date/diff.js +7 -7
  427. package/src/util/date/encodeDateWithTimezoneOffset.js +18 -18
  428. package/src/util/date/index.d.ts +8 -8
  429. package/src/util/date/index.js +9 -9
  430. package/src/util/date/lowerBoundCheck.d.ts +7 -7
  431. package/src/util/date/lowerBoundCheck.js +6 -6
  432. package/src/util/date/maxDate.d.ts +5 -5
  433. package/src/util/date/maxDate.js +9 -9
  434. package/src/util/date/minDate.d.ts +5 -5
  435. package/src/util/date/minDate.js +9 -9
  436. package/src/util/date/monthStart.d.ts +5 -5
  437. package/src/util/date/monthStart.js +3 -3
  438. package/src/util/date/sameDate.d.ts +6 -6
  439. package/src/util/date/sameDate.js +5 -5
  440. package/src/util/date/upperBoundCheck.d.ts +7 -7
  441. package/src/util/date/upperBoundCheck.js +6 -6
  442. package/src/util/date/upperBoundCheck.spec.js +30 -30
  443. package/src/util/date/zeroTime.d.ts +6 -6
  444. package/src/util/date/zeroTime.js +3 -3
  445. package/src/util/debounce.d.ts +9 -9
  446. package/src/util/dummyCallback.d.ts +1 -1
  447. package/src/util/dummyCallback.js +1 -1
  448. package/src/util/escapeSpecialRegexCharacters.d.ts +6 -6
  449. package/src/util/escapeSpecialRegexCharacters.js +3 -3
  450. package/src/util/eventCallbacks.d.ts +4 -4
  451. package/src/util/eventCallbacks.js +2 -2
  452. package/src/util/expandFatArrows.js +118 -118
  453. package/src/util/findScrollableParent.js +16 -16
  454. package/src/util/getActiveElement.js +3 -3
  455. package/src/util/getParentFrameBoundingClientRect.js +18 -18
  456. package/src/util/getScrollerBoundingClientRect.js +21 -21
  457. package/src/util/getSearchQueryPredicate.js +58 -58
  458. package/src/util/getSearchQueryPredicate.spec.js +40 -40
  459. package/src/util/getTopLevelBoundingClientRect.js +13 -13
  460. package/src/util/getVendorPrefix.js +26 -26
  461. package/src/util/index.d.ts +50 -50
  462. package/src/util/index.js +52 -52
  463. package/src/util/index.scss +10 -10
  464. package/src/util/innerTextTrim.d.ts +6 -6
  465. package/src/util/innerTextTrim.js +5 -5
  466. package/src/util/isArray.js +3 -3
  467. package/src/util/isDefined.js +3 -3
  468. package/src/util/isDigit.d.ts +6 -6
  469. package/src/util/isDigit.js +3 -3
  470. package/src/util/isFunction.d.ts +1 -1
  471. package/src/util/isFunction.js +3 -3
  472. package/src/util/isNonEmptyArray.d.ts +1 -1
  473. package/src/util/isNonEmptyArray.js +3 -3
  474. package/src/util/isNumber.js +3 -3
  475. package/src/util/isObject.js +3 -3
  476. package/src/util/isPromise.d.ts +1 -1
  477. package/src/util/isPromise.js +6 -6
  478. package/src/util/isString.js +3 -3
  479. package/src/util/isTextInputElement.d.ts +1 -1
  480. package/src/util/isTextInputElement.js +2 -2
  481. package/src/util/isTouchDevice.d.ts +1 -1
  482. package/src/util/isTouchDevice.js +7 -7
  483. package/src/util/isTouchEvent.d.ts +3 -3
  484. package/src/util/isTouchEvent.js +52 -52
  485. package/src/util/isUndefined.js +3 -3
  486. package/src/util/onIdleCallback.js +13 -13
  487. package/src/util/parseStyle.d.ts +3 -3
  488. package/src/util/parseStyle.js +27 -27
  489. package/src/util/quote.d.ts +2 -2
  490. package/src/util/quote.js +5 -5
  491. package/src/util/reverseSlice.js +9 -9
  492. package/src/util/routeAppend.js +15 -15
  493. package/src/util/routeAppend.spec.js +19 -19
  494. package/src/util/scrollElementIntoView.d.ts +6 -6
  495. package/src/util/scrollElementIntoView.js +59 -59
  496. package/src/util/scss/add-rules.scss +39 -39
  497. package/src/util/scss/calc.scss +40 -40
  498. package/src/util/scss/call-once.scss +10 -10
  499. package/src/util/scss/clockwise.scss +47 -47
  500. package/src/util/scss/colors.scss +7 -7
  501. package/src/util/scss/deep-get.scss +9 -9
  502. package/src/util/scss/deep-merge.scss +18 -18
  503. package/src/util/scss/include.scss +47 -47
  504. package/src/util/scss/index.scss +8 -8
  505. package/src/util/shallowEquals.js +43 -43
  506. package/src/util/throttle.d.ts +8 -8
  507. package/src/util/throttle.js +14 -14
  508. package/src/variables.scss +217 -217
  509. package/src/widgets/AccessorBindings.spec.tsx +66 -0
  510. package/src/widgets/Button.d.ts +52 -52
  511. package/src/widgets/Button.scss +108 -108
  512. package/src/widgets/Button.variables.scss +107 -107
  513. package/src/widgets/CxCredit.d.ts +12 -12
  514. package/src/widgets/CxCredit.js +31 -31
  515. package/src/widgets/CxCredit.scss +41 -41
  516. package/src/widgets/DocumentTitle.d.ts +10 -10
  517. package/src/widgets/DocumentTitle.js +68 -68
  518. package/src/widgets/FlexBox.d.ts +69 -69
  519. package/src/widgets/FlexBox.js +92 -92
  520. package/src/widgets/FlexBox.scss +155 -155
  521. package/src/widgets/Heading.d.ts +16 -16
  522. package/src/widgets/Heading.js +32 -32
  523. package/src/widgets/Heading.scss +38 -38
  524. package/src/widgets/HighlightedSearchText.d.ts +9 -9
  525. package/src/widgets/HighlightedSearchText.js +36 -36
  526. package/src/widgets/HighlightedSearchText.scss +18 -18
  527. package/src/widgets/HtmlElement.d.ts +26 -26
  528. package/src/widgets/HtmlElement.js +273 -273
  529. package/src/widgets/HtmlElement.spec.js +57 -57
  530. package/src/widgets/Icon.d.ts +36 -36
  531. package/src/widgets/Icon.js +50 -50
  532. package/src/widgets/Icon.scss +20 -20
  533. package/src/widgets/List.d.ts +84 -72
  534. package/src/widgets/List.js +578 -578
  535. package/src/widgets/List.scss +92 -92
  536. package/src/widgets/ProgressBar.d.ts +17 -17
  537. package/src/widgets/ProgressBar.js +46 -46
  538. package/src/widgets/ProgressBar.scss +49 -49
  539. package/src/widgets/Resizer.d.ts +27 -27
  540. package/src/widgets/Resizer.js +151 -151
  541. package/src/widgets/Resizer.scss +42 -42
  542. package/src/widgets/Sandbox.d.ts +18 -18
  543. package/src/widgets/Sandbox.js +58 -58
  544. package/src/widgets/Section.d.ts +52 -52
  545. package/src/widgets/Section.js +139 -139
  546. package/src/widgets/Section.scss +54 -54
  547. package/src/widgets/animations.scss +10 -10
  548. package/src/widgets/autoFocus.d.ts +1 -1
  549. package/src/widgets/autoFocus.js +11 -11
  550. package/src/widgets/cx.d.ts +1 -1
  551. package/src/widgets/cx.js +71 -71
  552. package/src/widgets/drag-drop/DragClone.scss +33 -33
  553. package/src/widgets/drag-drop/DragHandle.d.ts +10 -10
  554. package/src/widgets/drag-drop/DragHandle.js +37 -37
  555. package/src/widgets/drag-drop/DragHandle.scss +16 -16
  556. package/src/widgets/drag-drop/DragSource.d.ts +34 -34
  557. package/src/widgets/drag-drop/DragSource.js +160 -160
  558. package/src/widgets/drag-drop/DragSource.scss +24 -24
  559. package/src/widgets/drag-drop/DropZone.d.ts +90 -90
  560. package/src/widgets/drag-drop/DropZone.js +213 -213
  561. package/src/widgets/drag-drop/DropZone.scss +74 -74
  562. package/src/widgets/drag-drop/index.d.ts +4 -4
  563. package/src/widgets/drag-drop/index.js +4 -4
  564. package/src/widgets/drag-drop/index.scss +3 -3
  565. package/src/widgets/drag-drop/ops.d.ts +56 -56
  566. package/src/widgets/drag-drop/ops.js +344 -344
  567. package/src/widgets/drag-drop/variables.scss +11 -11
  568. package/src/widgets/enableAllInternalDependencies.d.ts +1 -1
  569. package/src/widgets/enableAllInternalDependencies.js +11 -11
  570. package/src/widgets/form/Calendar.d.ts +57 -57
  571. package/src/widgets/form/Calendar.js +506 -506
  572. package/src/widgets/form/Calendar.scss +164 -164
  573. package/src/widgets/form/Calendar.variables.scss +63 -63
  574. package/src/widgets/form/Checkbox.d.ts +43 -39
  575. package/src/widgets/form/Checkbox.js +200 -194
  576. package/src/widgets/form/Checkbox.scss +122 -122
  577. package/src/widgets/form/Checkbox.variables.scss +39 -39
  578. package/src/widgets/form/ColorField.d.ts +43 -43
  579. package/src/widgets/form/ColorField.js +389 -389
  580. package/src/widgets/form/ColorField.scss +92 -92
  581. package/src/widgets/form/ColorPicker.d.ts +23 -23
  582. package/src/widgets/form/ColorPicker.js +451 -451
  583. package/src/widgets/form/ColorPicker.scss +184 -184
  584. package/src/widgets/form/ColorPicker.variables.scss +20 -20
  585. package/src/widgets/form/DateField.d.ts +6 -6
  586. package/src/widgets/form/DateField.js +12 -12
  587. package/src/widgets/form/DateTimeField.d.ts +83 -83
  588. package/src/widgets/form/DateTimeField.js +571 -571
  589. package/src/widgets/form/DateTimeField.scss +90 -90
  590. package/src/widgets/form/DateTimePicker.js +391 -391
  591. package/src/widgets/form/DateTimePicker.scss +44 -44
  592. package/src/widgets/form/Field.d.ts +112 -112
  593. package/src/widgets/form/Field.js +419 -419
  594. package/src/widgets/form/Field.scss +162 -162
  595. package/src/widgets/form/FieldGroup.d.ts +6 -6
  596. package/src/widgets/form/FieldGroup.js +5 -5
  597. package/src/widgets/form/HelpText.d.ts +10 -10
  598. package/src/widgets/form/HelpText.js +9 -9
  599. package/src/widgets/form/HelpText.scss +23 -23
  600. package/src/widgets/form/Label.d.ts +25 -25
  601. package/src/widgets/form/Label.js +86 -86
  602. package/src/widgets/form/Label.scss +36 -36
  603. package/src/widgets/form/LabeledContainer.d.ts +17 -17
  604. package/src/widgets/form/LabeledContainer.js +57 -57
  605. package/src/widgets/form/LookupField.d.ts +159 -159
  606. package/src/widgets/form/LookupField.js +1109 -1109
  607. package/src/widgets/form/LookupField.scss +210 -210
  608. package/src/widgets/form/MonthField.d.ts +88 -88
  609. package/src/widgets/form/MonthField.js +512 -512
  610. package/src/widgets/form/MonthField.scss +99 -99
  611. package/src/widgets/form/MonthPicker.d.ts +68 -68
  612. package/src/widgets/form/MonthPicker.js +631 -631
  613. package/src/widgets/form/MonthPicker.scss +120 -120
  614. package/src/widgets/form/NumberField.d.ts +94 -94
  615. package/src/widgets/form/NumberField.js +443 -443
  616. package/src/widgets/form/NumberField.scss +65 -65
  617. package/src/widgets/form/Radio.d.ts +37 -37
  618. package/src/widgets/form/Radio.js +188 -188
  619. package/src/widgets/form/Radio.scss +122 -122
  620. package/src/widgets/form/Radio.variables.scss +45 -45
  621. package/src/widgets/form/Select.d.ts +73 -73
  622. package/src/widgets/form/Select.js +274 -274
  623. package/src/widgets/form/Select.scss +98 -98
  624. package/src/widgets/form/Slider.d.ts +62 -62
  625. package/src/widgets/form/Slider.js +339 -339
  626. package/src/widgets/form/Slider.scss +121 -121
  627. package/src/widgets/form/Switch.d.ts +38 -38
  628. package/src/widgets/form/Switch.js +120 -120
  629. package/src/widgets/form/Switch.scss +140 -140
  630. package/src/widgets/form/TextArea.d.ts +17 -17
  631. package/src/widgets/form/TextArea.js +182 -182
  632. package/src/widgets/form/TextArea.scss +60 -60
  633. package/src/widgets/form/TextField.d.ts +75 -75
  634. package/src/widgets/form/TextField.js +286 -286
  635. package/src/widgets/form/TextField.scss +67 -67
  636. package/src/widgets/form/TimeField.d.ts +6 -6
  637. package/src/widgets/form/TimeField.js +11 -11
  638. package/src/widgets/form/TimeList.js +84 -84
  639. package/src/widgets/form/UploadButton.d.ts +31 -31
  640. package/src/widgets/form/UploadButton.js +213 -213
  641. package/src/widgets/form/UploadButton.scss +47 -47
  642. package/src/widgets/form/ValidationError.d.ts +10 -10
  643. package/src/widgets/form/ValidationError.js +37 -37
  644. package/src/widgets/form/ValidationError.scss +21 -21
  645. package/src/widgets/form/ValidationGroup.spec.js +148 -148
  646. package/src/widgets/form/Validator.d.ts +6 -6
  647. package/src/widgets/form/Wheel.js +261 -261
  648. package/src/widgets/form/Wheel.scss +148 -148
  649. package/src/widgets/form/index.d.ts +26 -26
  650. package/src/widgets/form/index.js +29 -29
  651. package/src/widgets/form/index.scss +24 -24
  652. package/src/widgets/form/variables.scss +351 -351
  653. package/src/widgets/grid/Grid.d.ts +368 -350
  654. package/src/widgets/grid/Grid.js +3208 -3202
  655. package/src/widgets/grid/Grid.scss +656 -656
  656. package/src/widgets/grid/GridCell.d.ts +29 -29
  657. package/src/widgets/grid/GridCell.js +70 -70
  658. package/src/widgets/grid/GridCellEditor.js +41 -41
  659. package/src/widgets/grid/GridRow.js +228 -228
  660. package/src/widgets/grid/GridRowLine.js +24 -24
  661. package/src/widgets/grid/Pagination.d.ts +14 -14
  662. package/src/widgets/grid/Pagination.js +94 -94
  663. package/src/widgets/grid/Pagination.scss +113 -113
  664. package/src/widgets/grid/TreeNode.d.ts +25 -25
  665. package/src/widgets/grid/TreeNode.js +102 -102
  666. package/src/widgets/grid/TreeNode.scss +90 -90
  667. package/src/widgets/grid/index.d.ts +3 -3
  668. package/src/widgets/grid/index.js +14 -14
  669. package/src/widgets/grid/index.scss +3 -3
  670. package/src/widgets/grid/variables.scss +88 -88
  671. package/src/widgets/icons/arrow-down.svg +3 -3
  672. package/src/widgets/icons/arrow-right.svg +2 -2
  673. package/src/widgets/icons/base.svg +104 -104
  674. package/src/widgets/icons/calendar-old.svg +169 -169
  675. package/src/widgets/icons/calendar.js +16 -16
  676. package/src/widgets/icons/calendar.svg +187 -187
  677. package/src/widgets/icons/check.js +12 -12
  678. package/src/widgets/icons/clear.js +14 -14
  679. package/src/widgets/icons/clear.svg +74 -74
  680. package/src/widgets/icons/close.js +19 -19
  681. package/src/widgets/icons/close.svg +74 -74
  682. package/src/widgets/icons/cx.js +37 -37
  683. package/src/widgets/icons/drop-down.js +14 -14
  684. package/src/widgets/icons/dropdown-arrow.svg +61 -61
  685. package/src/widgets/icons/file.js +12 -12
  686. package/src/widgets/icons/file.svg +4 -4
  687. package/src/widgets/icons/folder-open.js +14 -14
  688. package/src/widgets/icons/folder-open.svg +5 -5
  689. package/src/widgets/icons/folder.js +12 -12
  690. package/src/widgets/icons/folder.svg +58 -58
  691. package/src/widgets/icons/forward.js +21 -21
  692. package/src/widgets/icons/forward.svg +67 -67
  693. package/src/widgets/icons/index.js +14 -14
  694. package/src/widgets/icons/loading.js +23 -23
  695. package/src/widgets/icons/loading.svg +4 -4
  696. package/src/widgets/icons/menu.js +16 -16
  697. package/src/widgets/icons/registry.js +53 -53
  698. package/src/widgets/icons/search.js +12 -12
  699. package/src/widgets/icons/search.svg +107 -107
  700. package/src/widgets/icons/sort-asc.js +13 -13
  701. package/src/widgets/icons/sort-asc.svg +3 -3
  702. package/src/widgets/icons/square.js +17 -17
  703. package/src/widgets/index.d.ts +55 -55
  704. package/src/widgets/index.js +57 -57
  705. package/src/widgets/index.scss +16 -16
  706. package/src/widgets/nav/Link.d.ts +22 -22
  707. package/src/widgets/nav/Link.js +7 -7
  708. package/src/widgets/nav/LinkButton.d.ts +31 -31
  709. package/src/widgets/nav/LinkButton.js +127 -127
  710. package/src/widgets/nav/Menu.d.ts +27 -27
  711. package/src/widgets/nav/Menu.js +411 -411
  712. package/src/widgets/nav/Menu.scss +74 -74
  713. package/src/widgets/nav/Menu.variables.scss +17 -17
  714. package/src/widgets/nav/MenuItem.d.ts +32 -32
  715. package/src/widgets/nav/MenuItem.js +442 -442
  716. package/src/widgets/nav/MenuItem.scss +128 -128
  717. package/src/widgets/nav/MenuSpacer.d.ts +5 -5
  718. package/src/widgets/nav/MenuSpacer.js +12 -12
  719. package/src/widgets/nav/RedirectRoute.d.ts +9 -9
  720. package/src/widgets/nav/RedirectRoute.js +40 -40
  721. package/src/widgets/nav/Route.d.ts +21 -21
  722. package/src/widgets/nav/Route.js +105 -105
  723. package/src/widgets/nav/Route.spec.js +27 -27
  724. package/src/widgets/nav/Scroller.d.ts +17 -17
  725. package/src/widgets/nav/Scroller.js +214 -214
  726. package/src/widgets/nav/Scroller.scss +146 -146
  727. package/src/widgets/nav/Submenu.d.ts +6 -6
  728. package/src/widgets/nav/Submenu.js +6 -6
  729. package/src/widgets/nav/Tab.d.ts +33 -33
  730. package/src/widgets/nav/Tab.js +82 -82
  731. package/src/widgets/nav/Tab.scss +81 -81
  732. package/src/widgets/nav/Tab.variables.scss +80 -80
  733. package/src/widgets/nav/cover.scss +21 -21
  734. package/src/widgets/nav/index.d.ts +10 -10
  735. package/src/widgets/nav/index.js +10 -10
  736. package/src/widgets/nav/index.scss +5 -5
  737. package/src/widgets/nav/variables.scss +25 -25
  738. package/src/widgets/overlay/ContextMenu.d.ts +8 -8
  739. package/src/widgets/overlay/ContextMenu.js +28 -28
  740. package/src/widgets/overlay/Dropdown.d.ts +27 -27
  741. package/src/widgets/overlay/Dropdown.js +601 -601
  742. package/src/widgets/overlay/Dropdown.scss +184 -184
  743. package/src/widgets/overlay/FlyweightTooltipTracker.d.ts +8 -8
  744. package/src/widgets/overlay/FlyweightTooltipTracker.js +36 -36
  745. package/src/widgets/overlay/MsgBox.d.ts +16 -16
  746. package/src/widgets/overlay/MsgBox.js +116 -116
  747. package/src/widgets/overlay/Overlay.d.ts +69 -69
  748. package/src/widgets/overlay/Overlay.js +737 -737
  749. package/src/widgets/overlay/Overlay.scss +66 -66
  750. package/src/widgets/overlay/Toast.d.ts +30 -30
  751. package/src/widgets/overlay/Toast.js +92 -92
  752. package/src/widgets/overlay/Toast.scss +162 -162
  753. package/src/widgets/overlay/Tooltip.d.ts +50 -50
  754. package/src/widgets/overlay/Tooltip.js +283 -283
  755. package/src/widgets/overlay/Tooltip.scss +175 -175
  756. package/src/widgets/overlay/Window.d.ts +38 -38
  757. package/src/widgets/overlay/Window.js +195 -195
  758. package/src/widgets/overlay/Window.scss +112 -112
  759. package/src/widgets/overlay/Window.variables.scss +67 -67
  760. package/src/widgets/overlay/alerts.d.ts +7 -7
  761. package/src/widgets/overlay/alerts.js +39 -39
  762. package/src/widgets/overlay/captureMouse.d.ts +53 -53
  763. package/src/widgets/overlay/captureMouse.js +132 -132
  764. package/src/widgets/overlay/captureMouse.scss +13 -13
  765. package/src/widgets/overlay/index.d.ts +10 -10
  766. package/src/widgets/overlay/index.js +10 -10
  767. package/src/widgets/overlay/index.scss +15 -15
  768. package/src/widgets/overlay/tooltip-ops.d.ts +8 -8
  769. package/src/widgets/overlay/tooltip-ops.js +24 -24
  770. package/src/widgets/overlay/variables.scss +82 -82
  771. package/src/widgets/variables.scss +144 -144
  772. package/yarn-error.log +7973 -0
  773. package/dist/reset.js +0 -1
@@ -1,350 +1,368 @@
1
- import * as Cx from "../../core";
2
- import * as React from "react";
3
- import { Instance } from "../../ui/Instance";
4
- import { DragEvent } from "../drag-drop/ops";
5
- import { View } from "../../data/View";
6
-
7
- type FetchRecordsResult = Cx.Record[] | { records: Cx.Record[]; lastPage?: boolean; totalRecordCount?: number };
8
-
9
- interface MappedGridRecord {
10
- data: Cx.Record;
11
- store: View;
12
- }
13
-
14
- interface GridDragEvent extends DragEvent {
15
- target: {
16
- recordBefore: MappedGridRecord;
17
- recordAfter: MappedGridRecord;
18
- insertionIndex: number;
19
- totalRecordCount: number;
20
- };
21
- }
22
-
23
- interface GridRowDragEvent extends DragEvent {
24
- target: {
25
- record: MappedGridRecord;
26
- index: number;
27
- };
28
- }
29
-
30
- interface GridColumnDropEvent extends DragEvent {
31
- target: {
32
- grid: any;
33
- instance: Instance;
34
- index: number;
35
- };
36
- }
37
-
38
- interface GridGroupingKey {
39
- [key: string]:
40
- | Cx.Prop<any>
41
- | {
42
- value: Cx.Prop<any>;
43
- direction: Cx.SortDirection;
44
- };
45
- }
46
-
47
- type GridColumnAlignment = "left" | "right" | "center";
48
-
49
- interface GridGroupingConfig {
50
- key: GridGroupingKey;
51
- aggregates?: Cx.StructuredProp;
52
- showCaption?: boolean;
53
- showFooter?: boolean;
54
- showHeader?: boolean;
55
- caption?: Cx.StringProp;
56
- name?: Cx.StringProp;
57
- text?: Cx.StringProp;
58
- }
59
-
60
- // TODO: Check Column config
61
- // Props are in order based on docs
62
-
63
- interface GridColumnHeaderConfig {
64
- text?: Cx.StringProp;
65
- colSpan?: Cx.NumberProp;
66
- rowSpan?: Cx.NumberProp;
67
- align?: GridColumnAlignment;
68
- allowSorting?: boolean;
69
- items?: React.ReactNode;
70
- children?: React.ReactNode;
71
- tool?: React.ReactNode;
72
- }
73
-
74
- interface GridColumnConfig {
75
- align?: GridColumnAlignment;
76
- field?: string;
77
- format?: Cx.StringProp;
78
- header?: Cx.StringProp | GridColumnHeaderConfig;
79
- header1?: Cx.StringProp | GridColumnHeaderConfig;
80
- header2?: Cx.StringProp | GridColumnHeaderConfig;
81
- header3?: Cx.StringProp | GridColumnHeaderConfig;
82
- sortable?: boolean;
83
- aggregate?: "min" | "max" | "count" | "sum" | "distinct" | "avg";
84
- aggregateAlias?: string;
85
- aggregateField?: string;
86
- caption?: Cx.StringProp;
87
- class?: Cx.ClassProp;
88
- className?: Cx.ClassProp;
89
- draggable?: boolean;
90
- editable?: boolean;
91
- editor?: React.ReactNode;
92
- footer?: Cx.StringProp | false;
93
- items?: React.ReactNode;
94
- children?: React.ReactNode;
95
- layout?: Cx.StringProp;
96
- key?: string;
97
- pad?: boolean;
98
- sortField?: string;
99
- sortValue?: Cx.Prop<any>;
100
- style?: Cx.StyleProp;
101
- trimWhitespace?: boolean;
102
- visible?: Cx.BooleanProp;
103
- if?: Cx.BooleanProp;
104
- weightField?: string;
105
-
106
- // Not in docs
107
- value?: Cx.Prop<any>;
108
- defaultWidth?: Cx.NumberProp;
109
- width?: Cx.NumberProp;
110
- resizable?: boolean;
111
- comparer?: (a: any, b: any) => number;
112
-
113
- /** Options for data sorting. See: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Collator */
114
- sortOptions?: Cx.CollatorOptions;
115
- }
116
-
117
- interface GridRowLineConfig {
118
- visible?: Cx.BooleanProp;
119
- columns: GridColumnConfig[];
120
- }
121
-
122
- interface GridRowConfig {
123
- invalid?: Cx.BooleanProp;
124
- valid?: Cx.BooleanProp;
125
- style?: Cx.StyleProp;
126
- class?: Cx.ClassProp;
127
- className?: Cx.ClassProp;
128
- line1?: GridRowLineConfig;
129
- line2?: GridRowLineConfig;
130
- line3?: GridRowLineConfig;
131
- }
132
-
133
- interface GridProps extends Cx.StyledContainerProps {
134
- /** An array of records to be displayed in the grid. */
135
- records?: Cx.Prop<Cx.Record[]>;
136
-
137
- /** Set to true to add a vertical scroll and a fixed header to the grid. */
138
- scrollable?: boolean;
139
-
140
- /** A binding used to store the sorting order list. Commonly used for server-side sorting. */
141
- sorters?: Cx.SortersProp;
142
-
143
- /** A list of sorters to be prepended to the actual list of sorters. */
144
- preSorters?: Cx.SortersProp;
145
-
146
- /** A binding used to store the name of the field used for sorting grids. Available only if sorters are not used. */
147
- sortField?: Cx.StringProp;
148
-
149
- /** A binding used to store the sort direction. Available only if sorters are not used. Possible values are "ASC" and "DESC". Deafults to "ASC". */
150
- sortDirection?: Cx.StringProp;
151
-
152
- /** Default sort field. Used if neither sortField or sorters are set. */
153
- defaultSortField?: string;
154
-
155
- /** Default sort direction. */
156
- defaultSortDirection?: "ASC" | "DESC";
157
-
158
- /** Set to true to add vertical gridlines. */
159
- vlines?: boolean;
160
-
161
- /** Text to be displayed instead of an empty table. */
162
- emptyText?: Cx.StringProp;
163
-
164
- /** Drag source configuration. Define mode as 'move' or 'copy` and additional data. */
165
- dragSource?: Cx.StructuredProp;
166
-
167
- /** Drop zone configuration. Define mode as either preview or insertion. */
168
- dropZone?: Cx.StructuredProp;
169
-
170
- /** Row configuration. See grid examples. */
171
- row?: GridRowConfig;
172
-
173
- /**An array of columns. Check column configuration options in the section below. */
174
- columns?: GridColumnConfig[];
175
-
176
- /** Whenever columnParams change, columns are recalculated using the onGetColumn callback. */
177
- columnParams?: Cx.Config;
178
-
179
- /** Selection configuration. */
180
- selection?: Cx.Config;
181
-
182
- /** An array of grouping level definitions. Check allowed grouping level properties in the section below. */
183
- grouping?: GridGroupingConfig[];
184
-
185
- /** Params for grouping. Whenever params change grouping is recalculated using the onGetGrouping callback. */
186
- groupingParams?: Cx.Config;
187
-
188
- /**
189
- * Determines header appearance. Supported values are plain and default. Default mode is used if some of the columns are sortable.
190
- * Plain mode better suits reports and other scenarios in which users do not interact with the grid.
191
- */
192
- headerMode?: Cx.StringProp;
193
-
194
- /** Set to true to add default border around the table. Automatically set if grid is scrollable. */
195
- border?: Cx.BooleanProp;
196
-
197
- /** Base CSS class to be applied to the element. Default is 'grid'. */
198
- baseClass?: string;
199
-
200
- /** A field used to get the unique identifier of the record. Setting keyField improves grid performance on sort operations as the widget is able to identify row movement inside the grid. */
201
- keyField?: string;
202
-
203
- /** Show grid header within the group. Useful for long report-like (printable) grids. Defaults to false. */
204
- showHeader?: boolean;
205
-
206
- /** Show grid footer. Defaults to false. */
207
- showFooter?: boolean;
208
-
209
- /** Record alias. Default is $record. */
210
- recordName?: string;
211
-
212
- /** Record alias. Default is $record. */
213
- recordAlias?: string;
214
-
215
- /** Set to true if sorting is done remotely, on the server-side. Default value is false. */
216
- remoteSort?: boolean;
217
-
218
- /** Set to true to enable row caching. This greatly improves grid performance
219
- on subsequent render operations, however, only changes on records
220
- are allowed. If grid rows display any data outside records, changes on that
221
- data will be ignored. */
222
- cached?: boolean;
223
-
224
- /** Render only rows visible on the screen. */
225
- buffered?: boolean;
226
-
227
- /** Specifies how many rows should be visible on the screen */
228
- bufferSize?: number;
229
-
230
- /** Specifies how many rows needs to be scrolled in order to recalculate buffer */
231
- bufferStep?: number;
232
-
233
- /** Used when rows have variable heights to improve buffered rendering by measuring and caching rendered row heights. Default value is false. */
234
- measureRowHeights?: boolean;
235
-
236
- /** Scrolls selection into the view. Default value is false. */
237
- scrollSelectionIntoView?: boolean;
238
-
239
- /**
240
- * Set to true to lock column widths after the first render.
241
- * This is helpful in pagination scenarios to maintain consistent looks across pages.
242
- */
243
- lockColumnWidths?: boolean;
244
-
245
- lockColumnWidthsRequiredRowCount?: number;
246
- focused?: boolean;
247
- showBorder?: boolean;
248
-
249
- /** Data adapter used to convert data in list of records. Used to enable grouping and tree operations. */
250
- dataAdapter?: any;
251
-
252
- /** Additional CSS class to be added to each grid row. */
253
- rowClass?: Cx.ClassProp;
254
-
255
- /** Additional CSS styles to be added to each grid row. */
256
- rowStyle?: Cx.StyleProp;
257
-
258
- // drag-drop handlers
259
- onDrop?: (e: GridDragEvent, instance: Instance) => void;
260
- onDropTest?: (e: DragEvent, instance: Instance) => boolean;
261
- onDragStart?: (e: DragEvent, instance: Instance) => void;
262
- onDragEnd?: (e: DragEvent, instance: Instance) => void;
263
- onDragOver?: (e: GridDragEvent, instance: Instance) => void | boolean;
264
-
265
- onRowDropTest?: (e: DragEvent, instance: Instance) => boolean;
266
- onRowDragOver?: (e: GridRowDragEvent, instance: Instance) => void | boolean;
267
- onRowDrop?: (e: GridRowDragEvent, instance: Instance) => void | boolean;
268
-
269
- onColumnDrop?: (e: GridColumnDropEvent, instance: Instance) => void;
270
- onColumnDropTest?: (e: DragEvent, instance: Instance) => boolean;
271
-
272
- /** Parameters that affect filtering. */
273
- filterParams?: Cx.StructuredProp;
274
-
275
- /** Callback to create a filter function for given filter params. */
276
- onCreateFilter?: (filterParams: any, instance?: Instance) => (record: Cx.Record) => boolean;
277
-
278
- /** Enable infinite scrolling */
279
- infinite?: boolean;
280
-
281
- /** If set, clicking on the column header will loop between ASC, DESC and no sorting order, instead of ASC and DESC only. */
282
- clearableSort?: boolean;
283
-
284
- /** A callback to fetch records during infinite loading */
285
- onFetchRecords?: (
286
- pageInfo: {
287
- page: number;
288
- pageSize: number;
289
- sorters?: Cx.Record[];
290
- sortField?: string;
291
- sortDirection?: string;
292
- },
293
- instance?: Instance
294
- ) => FetchRecordsResult | Promise<FetchRecordsResult>;
295
-
296
- /** Callback function to be executed when a row is double-clicked. */
297
- onRowDoubleClick?: string | ((e: React.SyntheticEvent<any>, instance: Instance) => void);
298
-
299
- /** Callback function to be executed when a row is clicked. */
300
- onRowClick?: string | ((e: React.SyntheticEvent<any>, instance: Instance) => void);
301
-
302
- /** Set to true to add a fixed footer at the bottom of the grid. */
303
- fixedFooter?: boolean;
304
-
305
- /** Set to true to enable cell editing. Please note that all editable columns should specify the editor field. */
306
- cellEditable?: boolean;
307
-
308
- /** A callback function which is executed before a cell editor is initalized. Return false from the callback to prevent the cell from going into the edit mode. */
309
- onBeforeCellEdit?: (change, record) => any;
310
-
311
- /** A callback function which is executed after a cell has been successfully edited. */
312
- onCellEdited?: (change, record) => void;
313
-
314
- /** A callback function which is executed after a column has been resized. */
315
- onColumnResize?: (data: { width: number; column: Cx.Record }, instance: Instance) => void;
316
-
317
- /** Options for data sorting. See: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Collator */
318
- sortOptions?: Cx.CollatorOptions;
319
-
320
- onCreateIsRecordSelectable?: (
321
- params: any,
322
- instance: Instance
323
- ) => (record: Cx.Record, options?: { range?: boolean; toggle?: boolean }) => boolean;
324
-
325
- /** Parameters whose change will casuse scroll to be reset. */
326
- scrollResetParams?: Cx.StructuredProp;
327
-
328
- /** Enable precise (sub-pixel) measurements. Useful for grids with many columns. Better behavior at small zoom factors. */
329
- preciseMeasurements?: boolean;
330
-
331
- /** A value used to identify the group of components participating in hover effect synchronization. */
332
- hoverChannel?: string;
333
-
334
- /** A value used to uniquely identify the record within the hover sync group. */
335
- rowHoverId?: Cx.StringProp;
336
-
337
- /** Set to true or false to explicitly define if grid is allowed to receive focus. */
338
- focusable?: boolean;
339
-
340
- /** Callback function to retrieve grouping data. */
341
- onGetGrouping?: (params: any, instance: Instance) => GridGroupingConfig[];
342
-
343
- /** Callback function to dynamically calculate columns. */
344
- onGetColumns?: (params: any, instance: Instance) => GridColumnConfig[] | GridRowConfig;
345
-
346
- /** Allow grid to receive drag and drop operations containing files. */
347
- allowsFileDrops?: boolean;
348
- }
349
-
350
- export class Grid extends Cx.Widget<GridProps> {}
1
+ import * as React from "react";
2
+ import { Instance } from "../../ui/Instance";
3
+ import { DragEvent } from "../drag-drop/ops";
4
+ import { View } from "../../data/View";
5
+ import {
6
+ BooleanProp,
7
+ ClassProp,
8
+ CollatorOptions,
9
+ Config,
10
+ NumberProp,
11
+ Prop,
12
+ Record,
13
+ RecordAlias,
14
+ SortDirection,
15
+ SortersProp,
16
+ StringProp,
17
+ StructuredProp,
18
+ StyledContainerProps,
19
+ StyleProp,
20
+ Widget,
21
+ } from "../../core";
22
+
23
+ type FetchRecordsResult = Record[] | { records: Record[]; lastPage?: boolean; totalRecordCount?: number };
24
+
25
+ interface MappedGridRecord {
26
+ data: Record;
27
+ store: View;
28
+ }
29
+
30
+ interface GridDragEvent extends DragEvent {
31
+ target: {
32
+ recordBefore: MappedGridRecord;
33
+ recordAfter: MappedGridRecord;
34
+ insertionIndex: number;
35
+ totalRecordCount: number;
36
+ };
37
+ }
38
+
39
+ interface GridRowDragEvent extends DragEvent {
40
+ target: {
41
+ record: MappedGridRecord;
42
+ index: number;
43
+ };
44
+ }
45
+
46
+ interface GridColumnDropEvent extends DragEvent {
47
+ target: {
48
+ grid: any;
49
+ instance: Instance;
50
+ index: number;
51
+ };
52
+ }
53
+
54
+ interface GridGroupingKey {
55
+ [key: string]:
56
+ | Prop<any>
57
+ | {
58
+ value: Prop<any>;
59
+ direction: SortDirection;
60
+ };
61
+ }
62
+
63
+ type GridColumnAlignment = "left" | "right" | "center";
64
+
65
+ interface GridGroupingConfig {
66
+ key: GridGroupingKey;
67
+ aggregates?: StructuredProp;
68
+ showCaption?: boolean;
69
+ showFooter?: boolean;
70
+ showHeader?: boolean;
71
+ caption?: StringProp;
72
+ name?: StringProp;
73
+ text?: StringProp;
74
+ }
75
+
76
+ // TODO: Check Column config
77
+ // Props are in order based on docs
78
+
79
+ interface GridColumnHeaderConfig {
80
+ text?: StringProp;
81
+ colSpan?: NumberProp;
82
+ rowSpan?: NumberProp;
83
+ align?: GridColumnAlignment;
84
+ allowSorting?: boolean;
85
+ items?: React.ReactNode;
86
+ children?: React.ReactNode;
87
+ tool?: React.ReactNode;
88
+ style?: StyleProp;
89
+ class?: ClassProp;
90
+ className?: ClassProp;
91
+ }
92
+
93
+ interface GridColumnConfig {
94
+ align?: GridColumnAlignment;
95
+ field?: string;
96
+ format?: StringProp;
97
+ header?: StringProp | GridColumnHeaderConfig;
98
+ header1?: StringProp | GridColumnHeaderConfig;
99
+ header2?: StringProp | GridColumnHeaderConfig;
100
+ header3?: StringProp | GridColumnHeaderConfig;
101
+ sortable?: boolean;
102
+ aggregate?: "min" | "max" | "count" | "sum" | "distinct" | "avg";
103
+ aggregateAlias?: string;
104
+ aggregateField?: string;
105
+ caption?: StringProp;
106
+ class?: ClassProp;
107
+ className?: ClassProp;
108
+ draggable?: boolean;
109
+ editable?: boolean;
110
+ editor?: React.ReactNode;
111
+ footer?: StringProp | false;
112
+ items?: React.ReactNode;
113
+ children?: React.ReactNode;
114
+ key?: string;
115
+ pad?: boolean;
116
+ sortField?: string;
117
+ sortValue?: Prop<any>;
118
+ style?: StyleProp;
119
+ trimWhitespace?: boolean;
120
+ visible?: BooleanProp;
121
+ if?: BooleanProp;
122
+ weightField?: string;
123
+
124
+ // Not in docs
125
+ value?: Prop<any>;
126
+ defaultWidth?: NumberProp;
127
+ width?: NumberProp;
128
+ resizable?: boolean;
129
+ comparer?: (a: any, b: any) => number;
130
+
131
+ /** Options for data sorting. See: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Collator */
132
+ sortOptions?: CollatorOptions;
133
+ }
134
+
135
+ interface GridRowLineConfig {
136
+ visible?: BooleanProp;
137
+ columns: GridColumnConfig[];
138
+ }
139
+
140
+ interface GridRowConfig {
141
+ invalid?: BooleanProp;
142
+ valid?: BooleanProp;
143
+ style?: StyleProp;
144
+ class?: ClassProp;
145
+ className?: ClassProp;
146
+ line1?: GridRowLineConfig;
147
+ line2?: GridRowLineConfig;
148
+ line3?: GridRowLineConfig;
149
+ }
150
+
151
+ interface GridProps extends StyledContainerProps {
152
+ /** An array of records to be displayed in the grid. */
153
+ records?: Prop<Record[]>;
154
+
155
+ /** Set to true to add a vertical scroll and a fixed header to the grid. */
156
+ scrollable?: boolean;
157
+
158
+ /** A binding used to store the sorting order list. Commonly used for server-side sorting. */
159
+ sorters?: SortersProp;
160
+
161
+ /** A list of sorters to be prepended to the actual list of sorters. */
162
+ preSorters?: SortersProp;
163
+
164
+ /** A binding used to store the name of the field used for sorting grids. Available only if sorters are not used. */
165
+ sortField?: StringProp;
166
+
167
+ /** A binding used to store the sort direction. Available only if sorters are not used. Possible values are "ASC" and "DESC". Defaults to "ASC". */
168
+ sortDirection?: StringProp;
169
+
170
+ /** Default sort field. Used if neither sortField or sorters are set. */
171
+ defaultSortField?: string;
172
+
173
+ /** Default sort direction. */
174
+ defaultSortDirection?: "ASC" | "DESC";
175
+
176
+ /** Set to true to add vertical gridlines. */
177
+ vlines?: boolean;
178
+
179
+ /** Text to be displayed instead of an empty table. */
180
+ emptyText?: StringProp;
181
+
182
+ /** Drag source configuration. Define mode as 'move' or 'copy` and additional data. */
183
+ dragSource?: StructuredProp;
184
+
185
+ /** Drop zone configuration. Define mode as either preview or insertion. */
186
+ dropZone?: StructuredProp;
187
+
188
+ /** Row configuration. See grid examples. */
189
+ row?: GridRowConfig;
190
+
191
+ /**An array of columns. Check column configuration options in the section below. */
192
+ columns?: GridColumnConfig[];
193
+
194
+ /** Whenever columnParams change, columns are recalculated using the onGetColumn callback. */
195
+ columnParams?: Config;
196
+
197
+ /** Selection configuration. */
198
+ selection?: Config;
199
+
200
+ /** An array of grouping level definitions. Check allowed grouping level properties in the section below. */
201
+ grouping?: GridGroupingConfig[];
202
+
203
+ /** Params for grouping. Whenever params change grouping is recalculated using the onGetGrouping callback. */
204
+ groupingParams?: Config;
205
+
206
+ /**
207
+ * Determines header appearance. Supported values are plain and default. Default mode is used if some of the columns are sortable.
208
+ * Plain mode better suits reports and other scenarios in which users do not interact with the grid.
209
+ */
210
+ headerMode?: StringProp;
211
+
212
+ /** Set to true to add default border around the table. Automatically set if grid is scrollable. */
213
+ border?: BooleanProp;
214
+
215
+ /** Base CSS class to be applied to the element. Default is 'grid'. */
216
+ baseClass?: string;
217
+
218
+ /** A field used to get the unique identifier of the record. Setting keyField improves grid performance on sort operations as the widget is able to identify row movement inside the grid. */
219
+ keyField?: string;
220
+
221
+ /** Show grid header within the group. Useful for long report-like (printable) grids. Defaults to false. */
222
+ showHeader?: boolean;
223
+
224
+ /** Show grid footer. Defaults to false. */
225
+ showFooter?: boolean;
226
+
227
+ /** Record alias. Default is $record. */
228
+ recordName?: RecordAlias;
229
+
230
+ /** Record alias. Default is $record. */
231
+ recordAlias?: RecordAlias;
232
+
233
+ /** Set to true if sorting is done remotely, on the server-side. Default value is false. */
234
+ remoteSort?: boolean;
235
+
236
+ /** Set to true to enable row caching. This greatly improves grid performance
237
+ on subsequent render operations, however, only changes on records
238
+ are allowed. If grid rows display any data outside records, changes on that
239
+ data will be ignored. */
240
+ cached?: boolean;
241
+
242
+ /** Render only rows visible on the screen. */
243
+ buffered?: boolean;
244
+
245
+ /** Specifies how many rows should be visible on the screen */
246
+ bufferSize?: number;
247
+
248
+ /** Specifies how many rows needs to be scrolled in order to recalculate buffer */
249
+ bufferStep?: number;
250
+
251
+ /** Used when rows have variable heights to improve buffered rendering by measuring and caching rendered row heights. Default value is false. */
252
+ measureRowHeights?: boolean;
253
+
254
+ /** Scrolls selection into the view. Default value is false. */
255
+ scrollSelectionIntoView?: boolean;
256
+
257
+ /**
258
+ * Set to true to lock column widths after the first render.
259
+ * This is helpful in pagination scenarios to maintain consistent looks across pages.
260
+ */
261
+ lockColumnWidths?: boolean;
262
+
263
+ lockColumnWidthsRequiredRowCount?: number;
264
+ focused?: boolean;
265
+ showBorder?: boolean;
266
+
267
+ /** Data adapter used to convert data in list of records. Used to enable grouping and tree operations. */
268
+ dataAdapter?: any;
269
+
270
+ /** Additional CSS class to be added to each grid row. */
271
+ rowClass?: ClassProp;
272
+
273
+ /** Additional CSS styles to be added to each grid row. */
274
+ rowStyle?: StyleProp;
275
+
276
+ // drag-drop handlers
277
+ onDrop?: (e: GridDragEvent, instance: Instance) => void;
278
+ onDropTest?: (e: DragEvent, instance: Instance) => boolean;
279
+ onDragStart?: (e: DragEvent, instance: Instance) => void;
280
+ onDragEnd?: (e: DragEvent, instance: Instance) => void;
281
+ onDragOver?: (e: GridDragEvent, instance: Instance) => void | boolean;
282
+
283
+ onRowDropTest?: (e: DragEvent, instance: Instance) => boolean;
284
+ onRowDragOver?: (e: GridRowDragEvent, instance: Instance) => void | boolean;
285
+ onRowDrop?: (e: GridRowDragEvent, instance: Instance) => void | boolean;
286
+
287
+ onColumnDrop?: (e: GridColumnDropEvent, instance: Instance) => void;
288
+ onColumnDropTest?: (e: DragEvent, instance: Instance) => boolean;
289
+
290
+ /** Parameters that affect filtering. */
291
+ filterParams?: StructuredProp;
292
+
293
+ /** Callback to create a filter function for given filter params. */
294
+ onCreateFilter?: (filterParams: any, instance?: Instance) => (record: Record) => boolean;
295
+
296
+ /** Enable infinite scrolling */
297
+ infinite?: boolean;
298
+
299
+ /** If set, clicking on the column header will loop between ASC, DESC and no sorting order, instead of ASC and DESC only. */
300
+ clearableSort?: boolean;
301
+
302
+ /** A callback to fetch records during infinite loading */
303
+ onFetchRecords?: (
304
+ pageInfo: {
305
+ page: number;
306
+ pageSize: number;
307
+ sorters?: Record[];
308
+ sortField?: string;
309
+ sortDirection?: string;
310
+ },
311
+ instance?: Instance
312
+ ) => FetchRecordsResult | Promise<FetchRecordsResult>;
313
+
314
+ /** Callback function to be executed when a row is double-clicked. */
315
+ onRowDoubleClick?: string | ((e: React.SyntheticEvent<any>, instance: Instance) => void);
316
+
317
+ /** Callback function to be executed when a row is clicked. */
318
+ onRowClick?: string | ((e: React.SyntheticEvent<any>, instance: Instance) => void);
319
+
320
+ /** Set to true to add a fixed footer at the bottom of the grid. */
321
+ fixedFooter?: boolean;
322
+
323
+ /** Set to true to enable cell editing. Please note that all editable columns should specify the editor field. */
324
+ cellEditable?: boolean;
325
+
326
+ /** A callback function which is executed before a cell editor is initialized. Return false from the callback to prevent the cell from going into the edit mode. */
327
+ onBeforeCellEdit?: (change, record) => any;
328
+
329
+ /** A callback function which is executed after a cell has been successfully edited. */
330
+ onCellEdited?: (change, record) => void;
331
+
332
+ /** A callback function which is executed after a column has been resized. */
333
+ onColumnResize?: (data: { width: number; column: Record }, instance: Instance) => void;
334
+
335
+ /** Options for data sorting. See: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Collator */
336
+ sortOptions?: CollatorOptions;
337
+
338
+ onCreateIsRecordSelectable?: (
339
+ params: any,
340
+ instance: Instance
341
+ ) => (record: Record, options?: { range?: boolean; toggle?: boolean }) => boolean;
342
+
343
+ /** Parameters whose change will cause scroll to be reset. */
344
+ scrollResetParams?: StructuredProp;
345
+
346
+ /** Enable precise (sub-pixel) measurements. Useful for grids with many columns. Better behavior at small zoom factors. */
347
+ preciseMeasurements?: boolean;
348
+
349
+ /** A value used to identify the group of components participating in hover effect synchronization. */
350
+ hoverChannel?: string;
351
+
352
+ /** A value used to uniquely identify the record within the hover sync group. */
353
+ rowHoverId?: StringProp;
354
+
355
+ /** Set to true or false to explicitly define if grid is allowed to receive focus. */
356
+ focusable?: boolean;
357
+
358
+ /** Callback function to retrieve grouping data. */
359
+ onGetGrouping?: (params: any, instance: Instance) => GridGroupingConfig[];
360
+
361
+ /** Callback function to dynamically calculate columns. */
362
+ onGetColumns?: (params: any, instance: Instance) => GridColumnConfig[] | GridRowConfig;
363
+
364
+ /** Allow grid to receive drag and drop operations containing files. */
365
+ allowsFileDrops?: boolean;
366
+ }
367
+
368
+ export class Grid extends Widget<GridProps> {}