cx 26.0.11 → 26.0.13

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 (366) hide show
  1. package/build/charts/ScatterGraph.d.ts +4 -4
  2. package/build/charts/ScatterGraph.js +2 -2
  3. package/build/data/ArrayElementView.spec.d.ts +1 -0
  4. package/build/data/ArrayElementView.spec.js +81 -0
  5. package/build/data/Binding.spec.d.ts +1 -0
  6. package/build/data/Binding.spec.js +61 -0
  7. package/build/data/Expression.spec.d.ts +1 -0
  8. package/build/data/Expression.spec.js +196 -0
  9. package/build/data/Grouper.spec.d.ts +1 -0
  10. package/build/data/Grouper.spec.js +48 -0
  11. package/build/data/Ref.spec.d.ts +1 -0
  12. package/build/data/Ref.spec.js +72 -0
  13. package/build/data/Selector.d.ts +1 -1
  14. package/build/data/Store.spec.d.ts +1 -0
  15. package/build/data/Store.spec.js +19 -0
  16. package/build/data/StoreRef.spec.d.ts +1 -0
  17. package/build/data/StoreRef.spec.js +22 -0
  18. package/build/data/StringTemplate.spec.d.ts +1 -0
  19. package/build/data/StringTemplate.spec.js +112 -0
  20. package/build/data/StructuredSelector.spec.d.ts +1 -0
  21. package/build/data/StructuredSelector.spec.js +102 -0
  22. package/build/data/View.spec.d.ts +1 -0
  23. package/build/data/View.spec.js +44 -0
  24. package/build/data/ZoomIntoPropertyView.spec.d.ts +1 -0
  25. package/build/data/ZoomIntoPropertyView.spec.js +54 -0
  26. package/build/data/comparer.spec.d.ts +1 -0
  27. package/build/data/comparer.spec.js +50 -0
  28. package/build/data/computable.d.ts +3 -6
  29. package/build/data/computable.spec.d.ts +1 -0
  30. package/build/data/computable.spec.js +56 -0
  31. package/build/data/createAccessorModelProxy.d.ts +5 -3
  32. package/build/data/createAccessorModelProxy.spec.d.ts +1 -0
  33. package/build/data/createAccessorModelProxy.spec.js +30 -0
  34. package/build/data/createStructuredSelector.spec.d.ts +1 -0
  35. package/build/data/createStructuredSelector.spec.js +42 -0
  36. package/build/data/diff/diffs.spec.d.ts +1 -0
  37. package/build/data/diff/diffs.spec.js +45 -0
  38. package/build/data/getAccessor.spec.d.ts +1 -0
  39. package/build/data/getAccessor.spec.js +10 -0
  40. package/build/data/getSelector.spec.d.ts +1 -0
  41. package/build/data/getSelector.spec.js +36 -0
  42. package/build/data/ops/append.spec.d.ts +1 -0
  43. package/build/data/ops/append.spec.js +24 -0
  44. package/build/data/ops/filter.spec.d.ts +1 -0
  45. package/build/data/ops/filter.spec.js +25 -0
  46. package/build/data/ops/findTreeNode.d.ts +1 -1
  47. package/build/data/ops/findTreeNode.js +1 -1
  48. package/build/data/ops/findTreeNode.spec.d.ts +1 -0
  49. package/build/data/ops/findTreeNode.spec.js +20 -0
  50. package/build/data/ops/findTreePath.d.ts +1 -1
  51. package/build/data/ops/merge.spec.d.ts +1 -0
  52. package/build/data/ops/merge.spec.js +23 -0
  53. package/build/data/ops/removeTreeNodes.d.ts +1 -1
  54. package/build/data/ops/removeTreeNodes.js +1 -1
  55. package/build/data/ops/removeTreeNodes.spec.d.ts +1 -0
  56. package/build/data/ops/removeTreeNodes.spec.js +35 -0
  57. package/build/data/ops/updateArray.spec.d.ts +1 -0
  58. package/build/data/ops/updateArray.spec.js +33 -0
  59. package/build/data/ops/updateTree.d.ts +1 -1
  60. package/build/data/ops/updateTree.spec.d.ts +1 -0
  61. package/build/data/ops/updateTree.spec.js +44 -0
  62. package/build/hooks/invokeCallback.spec.d.ts +1 -0
  63. package/build/hooks/invokeCallback.spec.js +44 -0
  64. package/build/hooks/resolveCallback.spec.d.ts +1 -0
  65. package/build/hooks/resolveCallback.spec.js +35 -0
  66. package/build/hooks/store.spec.d.ts +1 -0
  67. package/build/hooks/store.spec.js +48 -0
  68. package/build/hooks/useTrigger.spec.d.ts +1 -0
  69. package/build/hooks/useTrigger.spec.js +59 -0
  70. package/build/jsx-runtime.d.ts +10 -10
  71. package/build/jsx-runtime.js +6 -0
  72. package/build/svg/util/Rect.d.ts +1 -1
  73. package/build/ui/ContentResolver.d.ts +16 -6
  74. package/build/ui/Controller.d.ts +7 -0
  75. package/build/ui/Controller.js +2 -1
  76. package/build/ui/Controller.spec.d.ts +1 -0
  77. package/build/ui/Controller.spec.js +247 -0
  78. package/build/ui/Cx.spec.d.ts +1 -0
  79. package/build/ui/Cx.spec.js +153 -0
  80. package/build/ui/DataProxy.spec.d.ts +1 -0
  81. package/build/ui/DataProxy.spec.js +208 -0
  82. package/build/ui/Instance.d.ts +1 -1
  83. package/build/ui/Instance.js +10 -10
  84. package/build/ui/IsolatedScope.spec.d.ts +1 -0
  85. package/build/ui/IsolatedScope.spec.js +42 -0
  86. package/build/ui/Prop.d.ts +12 -1
  87. package/build/ui/PureContainer.spec.d.ts +1 -0
  88. package/build/ui/PureContainer.spec.js +149 -0
  89. package/build/ui/Repeater.d.ts +3 -3
  90. package/build/ui/Repeater.spec.d.ts +1 -0
  91. package/build/ui/Repeater.spec.js +109 -0
  92. package/build/ui/Rescope.spec.d.ts +1 -0
  93. package/build/ui/Rescope.spec.js +134 -0
  94. package/build/ui/Restate.spec.d.ts +1 -0
  95. package/build/ui/Restate.spec.js +257 -0
  96. package/build/ui/Text.d.ts +14 -2
  97. package/build/ui/Text.js +3 -0
  98. package/build/ui/adapter/ArrayAdapter.js +4 -1
  99. package/build/ui/adapter/ArrayAdapter.spec.d.ts +1 -0
  100. package/build/ui/adapter/ArrayAdapter.spec.js +44 -0
  101. package/build/ui/adapter/TreeAdapter.spec.d.ts +1 -0
  102. package/build/ui/adapter/TreeAdapter.spec.js +71 -0
  103. package/build/ui/app/Url.spec.d.ts +1 -0
  104. package/build/ui/app/Url.spec.js +43 -0
  105. package/build/ui/app/startHotAppLoop.js +1 -1
  106. package/build/ui/createFunctionalComponent.d.ts +14 -1
  107. package/build/ui/createFunctionalComponent.js +7 -4
  108. package/build/ui/createFunctionalComponent.spec.d.ts +1 -0
  109. package/build/ui/createFunctionalComponent.spec.js +272 -0
  110. package/build/ui/expr.d.ts +3 -1
  111. package/build/ui/exprHelpers.d.ts +32 -0
  112. package/build/ui/exprHelpers.js +61 -0
  113. package/build/ui/index.d.ts +1 -0
  114. package/build/ui/index.js +1 -0
  115. package/build/ui/layout/ContentPlaceholder.spec.d.ts +1 -0
  116. package/build/ui/layout/ContentPlaceholder.spec.js +333 -0
  117. package/build/ui/layout/FirstVisibleChildLayout.spec.d.ts +1 -0
  118. package/build/ui/layout/FirstVisibleChildLayout.spec.js +101 -0
  119. package/build/ui/selection/KeySelection.d.ts +0 -8
  120. package/build/ui/selection/Selection.d.ts +9 -3
  121. package/build/util/Console.d.ts +1 -0
  122. package/build/util/Console.js +7 -3
  123. package/build/util/Format.spec.d.ts +1 -0
  124. package/build/util/Format.spec.js +58 -0
  125. package/build/util/TraversalStack.spec.d.ts +1 -0
  126. package/build/util/TraversalStack.spec.js +43 -0
  127. package/build/util/date/upperBoundCheck.spec.d.ts +1 -0
  128. package/build/util/date/upperBoundCheck.spec.js +22 -0
  129. package/build/util/getSearchQueryPredicate.spec.d.ts +1 -0
  130. package/build/util/getSearchQueryPredicate.spec.js +33 -0
  131. package/build/util/isValidIdentifierName.spec.d.ts +1 -0
  132. package/build/util/isValidIdentifierName.spec.js +28 -0
  133. package/build/util/routeAppend.spec.d.ts +1 -0
  134. package/build/util/routeAppend.spec.js +14 -0
  135. package/build/widgets/AccessorBindings.spec.d.ts +1 -0
  136. package/build/widgets/AccessorBindings.spec.js +40 -0
  137. package/build/widgets/Button.d.ts +3 -6
  138. package/build/widgets/Button.js +1 -1
  139. package/build/widgets/DocumentTitle.d.ts +2 -0
  140. package/build/widgets/Heading.d.ts +2 -2
  141. package/build/widgets/HtmlElement.d.ts +33 -8
  142. package/build/widgets/HtmlElement.js +7 -9
  143. package/build/widgets/HtmlElement.spec.d.ts +1 -0
  144. package/build/widgets/HtmlElement.spec.js +38 -0
  145. package/build/widgets/Icon.d.ts +3 -13
  146. package/build/widgets/List.d.ts +4 -0
  147. package/build/widgets/ReactElementWrapper.d.ts +29 -0
  148. package/build/widgets/ReactElementWrapper.js +59 -0
  149. package/build/widgets/drag-drop/DragSource.d.ts +3 -3
  150. package/build/widgets/drag-drop/DragSource.js +2 -3
  151. package/build/widgets/drag-drop/DropZone.d.ts +3 -3
  152. package/build/widgets/drag-drop/DropZone.js +2 -3
  153. package/build/widgets/form/Checkbox.d.ts +2 -0
  154. package/build/widgets/form/ColorField.d.ts +2 -0
  155. package/build/widgets/form/DateTimeField.d.ts +2 -0
  156. package/build/widgets/form/Field.d.ts +0 -2
  157. package/build/widgets/form/LabeledContainer.d.ts +9 -8
  158. package/build/widgets/form/LabeledContainer.js +9 -9
  159. package/build/widgets/form/LookupField.d.ts +57 -9
  160. package/build/widgets/form/MonthField.d.ts +2 -0
  161. package/build/widgets/form/NumberField.d.ts +2 -0
  162. package/build/widgets/form/Radio.d.ts +2 -0
  163. package/build/widgets/form/Select.d.ts +2 -0
  164. package/build/widgets/form/Slider.d.ts +3 -0
  165. package/build/widgets/form/Switch.d.ts +2 -0
  166. package/build/widgets/form/TextField.d.ts +34 -0
  167. package/build/widgets/form/TimeList.d.ts +16 -1
  168. package/build/widgets/form/TimeList.js +34 -62
  169. package/build/widgets/form/UploadButton.d.ts +34 -2
  170. package/build/widgets/form/UploadButton.js +3 -1
  171. package/build/widgets/form/ValidationGroup.spec.d.ts +1 -0
  172. package/build/widgets/form/ValidationGroup.spec.js +62 -0
  173. package/build/widgets/form/Validator.d.ts +33 -2
  174. package/build/widgets/form/Validator.js +3 -0
  175. package/build/widgets/grid/Grid.d.ts +9 -9
  176. package/build/widgets/grid/TreeNode.d.ts +6 -0
  177. package/build/widgets/index.d.ts +1 -0
  178. package/build/widgets/index.js +1 -0
  179. package/build/widgets/nav/MenuItem.d.ts +3 -2
  180. package/build/widgets/nav/Route.spec.d.ts +1 -0
  181. package/build/widgets/nav/Route.spec.js +15 -0
  182. package/build/widgets/nav/Scroller.d.ts +4 -6
  183. package/build/widgets/nav/Scroller.js +6 -3
  184. package/build/widgets/nav/Tab.d.ts +2 -2
  185. package/build/widgets/overlay/ContextMenu.d.ts +3 -3
  186. package/build/widgets/overlay/Overlay.d.ts +2 -1
  187. package/build/widgets/overlay/Overlay.js +1 -1
  188. package/build.js +133 -133
  189. package/dist/data.js +2 -2
  190. package/dist/jsx-runtime.js +6 -1
  191. package/dist/manifest.d.ts +1443 -0
  192. package/dist/manifest.js +852 -804
  193. package/dist/ui.js +91 -5
  194. package/dist/util.js +3 -0
  195. package/dist/widgets.js +520 -161
  196. package/package.json +46 -20
  197. package/src/charts/Chart.ts +108 -108
  198. package/src/charts/ScatterGraph.tsx +6 -6
  199. package/src/data/ArrayElementView.ts +90 -90
  200. package/src/data/AugmentedViewBase.ts +88 -88
  201. package/src/data/Binding.ts +104 -104
  202. package/src/data/ExposedRecordView.ts +95 -95
  203. package/src/data/ExposedValueView.ts +89 -89
  204. package/src/data/Expression.spec.ts +229 -229
  205. package/src/data/Expression.ts +233 -233
  206. package/src/data/Grouper.spec.ts +57 -57
  207. package/src/data/Grouper.ts +158 -158
  208. package/src/data/NestedDataView.ts +43 -43
  209. package/src/data/ReadOnlyDataView.ts +39 -39
  210. package/src/data/Ref.ts +104 -104
  211. package/src/data/Selector.ts +10 -10
  212. package/src/data/Store.ts +52 -52
  213. package/src/data/StoreProxy.ts +19 -19
  214. package/src/data/StoreRef.ts +66 -66
  215. package/src/data/StringTemplate.spec.ts +132 -132
  216. package/src/data/StringTemplate.ts +93 -93
  217. package/src/data/StructuredSelector.spec.ts +113 -113
  218. package/src/data/StructuredSelector.ts +146 -146
  219. package/src/data/SubscribableView.ts +63 -63
  220. package/src/data/ZoomIntoPropertyView.spec.ts +64 -64
  221. package/src/data/ZoomIntoPropertyView.ts +45 -45
  222. package/src/data/computable.spec.ts +87 -62
  223. package/src/data/computable.ts +3 -6
  224. package/src/data/createAccessorModelProxy.spec.tsx +102 -1
  225. package/src/data/createAccessorModelProxy.ts +9 -3
  226. package/src/data/createStructuredSelector.ts +62 -62
  227. package/src/data/getAccessor.spec.ts +11 -11
  228. package/src/data/getAccessor.ts +74 -74
  229. package/src/data/getSelector.spec.ts +43 -43
  230. package/src/data/getSelector.ts +66 -66
  231. package/src/data/ops/filter.spec.ts +35 -35
  232. package/src/data/ops/filter.ts +9 -9
  233. package/src/data/ops/findTreeNode.ts +1 -5
  234. package/src/data/ops/findTreePath.ts +1 -1
  235. package/src/data/ops/merge.ts +13 -13
  236. package/src/data/ops/removeTreeNodes.spec.ts +37 -37
  237. package/src/data/ops/removeTreeNodes.ts +2 -2
  238. package/src/data/ops/updateArray.spec.ts +69 -69
  239. package/src/data/ops/updateArray.ts +31 -31
  240. package/src/data/ops/updateTree.ts +1 -1
  241. package/src/data/test-types.ts +7 -7
  242. package/src/hooks/resolveCallback.spec.tsx +30 -7
  243. package/src/hooks/useTrigger.ts +26 -26
  244. package/src/index.scss +6 -6
  245. package/src/jsx-dev-runtime.ts +4 -4
  246. package/src/jsx-runtime.spec.tsx +402 -0
  247. package/src/jsx-runtime.ts +26 -22
  248. package/src/svg/BoundedObject.ts +101 -101
  249. package/src/svg/util/Rect.ts +105 -105
  250. package/src/ui/CSSHelper.ts +17 -17
  251. package/src/ui/ContentResolver.spec.tsx +172 -19
  252. package/src/ui/ContentResolver.ts +16 -8
  253. package/src/ui/Controller.ts +15 -2
  254. package/src/ui/Culture.ts +159 -159
  255. package/src/ui/DataProxy.ts +55 -55
  256. package/src/ui/FocusManager.ts +171 -171
  257. package/src/ui/Instance.ts +866 -868
  258. package/src/ui/Prop.ts +140 -112
  259. package/src/ui/RenderingContext.ts +99 -99
  260. package/src/ui/Repeater.ts +3 -12
  261. package/src/ui/Rescope.ts +49 -49
  262. package/src/ui/StructuredInstanceDataAccessor.ts +32 -32
  263. package/src/ui/Text.ts +21 -2
  264. package/src/ui/VDOM.ts +34 -34
  265. package/src/ui/adapter/ArrayAdapter.spec.ts +55 -55
  266. package/src/ui/adapter/ArrayAdapter.ts +4 -1
  267. package/src/ui/adapter/TreeAdapter.spec.ts +76 -76
  268. package/src/ui/adapter/TreeAdapter.ts +185 -185
  269. package/src/ui/app/History.ts +133 -133
  270. package/src/ui/app/Url.spec.ts +50 -50
  271. package/src/ui/app/startHotAppLoop.ts +41 -41
  272. package/src/ui/createFunctionalComponent.spec.tsx +53 -0
  273. package/src/ui/createFunctionalComponent.ts +86 -65
  274. package/src/ui/expr.ts +4 -1
  275. package/src/ui/exprHelpers.spec.ts +379 -0
  276. package/src/ui/exprHelpers.ts +78 -0
  277. package/src/ui/index.ts +47 -46
  278. package/src/ui/layout/Content.ts +30 -30
  279. package/src/ui/layout/FirstVisibleChildLayout.spec.tsx +1 -1
  280. package/src/ui/layout/FirstVisibleChildLayout.ts +60 -60
  281. package/src/ui/selection/KeySelection.ts +0 -12
  282. package/src/ui/selection/PropertySelection.ts +87 -87
  283. package/src/ui/selection/Selection.ts +13 -3
  284. package/src/util/Console.ts +13 -11
  285. package/src/util/Format.ts +267 -267
  286. package/src/util/addEventListenerWithOptions.ts +41 -41
  287. package/src/util/browserSupportsPassiveEventHandlers.ts +20 -20
  288. package/src/util/color/rgbToHsl.ts +35 -35
  289. package/src/util/getActiveElement.ts +4 -4
  290. package/src/util/hasKey.ts +18 -18
  291. package/src/util/index.ts +55 -55
  292. package/src/util/innerTextTrim.ts +10 -10
  293. package/src/util/isArray.ts +3 -3
  294. package/src/util/isDataRecord.ts +5 -5
  295. package/src/util/isDefined.ts +3 -3
  296. package/src/util/isString.ts +3 -3
  297. package/src/widgets/AccessorBindings.spec.tsx +26 -0
  298. package/src/widgets/Button.tsx +5 -17
  299. package/src/widgets/DocumentTitle.ts +95 -92
  300. package/src/widgets/Heading.ts +2 -2
  301. package/src/widgets/HtmlElement.spec.helpers.tsx +108 -0
  302. package/src/widgets/HtmlElement.spec.tsx +20 -12
  303. package/src/widgets/HtmlElement.tsx +82 -24
  304. package/src/widgets/Icon.ts +3 -17
  305. package/src/widgets/List.tsx +6 -0
  306. package/src/widgets/ReactElementWrapper.spec.tsx +452 -0
  307. package/src/widgets/ReactElementWrapper.tsx +108 -0
  308. package/src/widgets/Sandbox.ts +103 -103
  309. package/src/widgets/autoFocus.ts +9 -9
  310. package/src/widgets/cx.ts +63 -63
  311. package/src/widgets/drag-drop/DragSource.tsx +3 -4
  312. package/src/widgets/drag-drop/DropZone.tsx +3 -4
  313. package/src/widgets/form/Checkbox.tsx +3 -0
  314. package/src/widgets/form/ColorField.tsx +3 -0
  315. package/src/widgets/form/DateTimeField.tsx +5 -0
  316. package/src/widgets/form/Field.tsx +0 -3
  317. package/src/widgets/form/Label.tsx +1 -0
  318. package/src/widgets/form/LabeledContainer.ts +22 -26
  319. package/src/widgets/form/LookupField.spec.tsx +93 -0
  320. package/src/widgets/form/LookupField.tsx +104 -9
  321. package/src/widgets/form/MonthField.tsx +5 -0
  322. package/src/widgets/form/NumberField.tsx +3 -0
  323. package/src/widgets/form/Radio.tsx +5 -0
  324. package/src/widgets/form/Select.tsx +5 -0
  325. package/src/widgets/form/Slider.tsx +4 -0
  326. package/src/widgets/form/Switch.tsx +3 -0
  327. package/src/widgets/form/TextField.tsx +62 -0
  328. package/src/widgets/form/TimeList.tsx +84 -73
  329. package/src/widgets/form/UploadButton.tsx +53 -2
  330. package/src/widgets/form/Validator.ts +40 -3
  331. package/src/widgets/grid/Grid.tsx +9 -12
  332. package/src/widgets/grid/GridCell.ts +143 -143
  333. package/src/widgets/grid/TreeNode.tsx +9 -0
  334. package/src/widgets/icons/calendar.tsx +17 -17
  335. package/src/widgets/icons/check.tsx +13 -13
  336. package/src/widgets/icons/clear.tsx +15 -15
  337. package/src/widgets/icons/close.tsx +20 -20
  338. package/src/widgets/icons/cx.tsx +38 -38
  339. package/src/widgets/icons/drop-down.tsx +15 -15
  340. package/src/widgets/icons/file.tsx +13 -13
  341. package/src/widgets/icons/folder-open.tsx +15 -15
  342. package/src/widgets/icons/folder.tsx +13 -13
  343. package/src/widgets/icons/forward.tsx +22 -22
  344. package/src/widgets/icons/loading.tsx +24 -24
  345. package/src/widgets/icons/menu.tsx +17 -17
  346. package/src/widgets/icons/pixel-picker.tsx +18 -18
  347. package/src/widgets/icons/search.tsx +13 -13
  348. package/src/widgets/icons/sort-asc.tsx +14 -14
  349. package/src/widgets/icons/square.tsx +18 -18
  350. package/src/widgets/index.ts +1 -0
  351. package/src/widgets/nav/MenuItem.tsx +3 -2
  352. package/src/widgets/nav/Route.ts +142 -142
  353. package/src/widgets/nav/Scroller.tsx +8 -9
  354. package/src/widgets/nav/Tab.ts +2 -2
  355. package/src/widgets/overlay/ContextMenu.ts +42 -42
  356. package/src/widgets/overlay/Dropdown.tsx +762 -762
  357. package/src/widgets/overlay/MsgBox.tsx +141 -141
  358. package/src/widgets/overlay/Overlay.tsx +5 -4
  359. package/src/widgets/overlay/Toast.ts +111 -111
  360. package/src/widgets/overlay/Window.tsx +299 -299
  361. package/src/widgets/overlay/alerts.ts +46 -46
  362. package/src/widgets/overlay/captureMouse.ts +195 -195
  363. package/src/widgets/overlay/createHotPromiseWindowFactory.ts +72 -72
  364. package/src/widgets/overlay/index.d.ts +11 -11
  365. package/src/widgets/overlay/index.ts +11 -11
  366. package/src/widgets/overlay/tooltip-ops.ts +173 -173
@@ -17,12 +17,12 @@ import { GridRow, GridRowConfig, GridRowInstance } from "./GridRow";
17
17
  import { Create, CreateConfig } from "../../util";
18
18
  import type { TreeAdapter } from "../../ui/adapter/TreeAdapter";
19
19
  export { GridRowConfig };
20
- type FetchRecordsResult<T> = T[] | {
20
+ export type GridFetchRecordsResult<T> = T[] | {
21
21
  records: T[];
22
22
  lastPage?: boolean;
23
23
  totalRecordCount?: number;
24
24
  };
25
- interface MappedGridRecord<T = any> extends DataAdapterRecord<T> {
25
+ export interface MappedGridRecord<T = any> extends DataAdapterRecord<T> {
26
26
  row?: GridRowInstance;
27
27
  vdom?: any;
28
28
  fixedVdom?: any;
@@ -30,7 +30,7 @@ interface MappedGridRecord<T = any> extends DataAdapterRecord<T> {
30
30
  level?: number;
31
31
  group?: any;
32
32
  }
33
- interface GridDragEvent<T> extends DragEvent {
33
+ export interface GridDragEvent<T> extends DragEvent {
34
34
  target: {
35
35
  recordBefore?: MappedGridRecord<T>;
36
36
  recordAfter?: MappedGridRecord<T>;
@@ -39,20 +39,20 @@ interface GridDragEvent<T> extends DragEvent {
39
39
  dropNextToTheRowAbove?: boolean | null;
40
40
  };
41
41
  }
42
- interface GridRowDragEvent<T> extends DragEvent {
42
+ export interface GridRowDragEvent<T> extends DragEvent {
43
43
  target: {
44
44
  record: MappedGridRecord<T>;
45
45
  index: number;
46
46
  };
47
47
  }
48
- interface GridColumnDropEvent extends DragEvent {
48
+ export interface GridColumnDropEvent extends DragEvent {
49
49
  target: {
50
50
  grid: any;
51
51
  instance: Instance;
52
52
  index: number;
53
53
  };
54
54
  }
55
- interface GridGroupingKey {
55
+ export interface GridGroupingKey {
56
56
  [key: string]: Prop<any> | {
57
57
  value: Prop<any>;
58
58
  direction: SortDirection;
@@ -65,8 +65,8 @@ interface GroupingResult<T> {
65
65
  indexes: number[];
66
66
  records: MappedGridRecord<T>[];
67
67
  }
68
- type GridColumnAlignment = "left" | "right" | "center";
69
- interface GridGroupingConfig<T> {
68
+ export type GridColumnAlignment = "left" | "right" | "center";
69
+ export interface GridGroupingConfig<T> {
70
70
  key: GridGroupingKey;
71
71
  aggregates?: StructuredProp;
72
72
  showCaption?: boolean;
@@ -267,7 +267,7 @@ export interface GridConfig<T = any> extends StyledContainerConfig {
267
267
  sorters?: DataRecord[];
268
268
  sortField?: string;
269
269
  sortDirection?: string;
270
- }, instance?: Instance) => FetchRecordsResult<T> | Promise<FetchRecordsResult<T>>;
270
+ }, instance?: Instance) => GridFetchRecordsResult<T> | Promise<GridFetchRecordsResult<T>>;
271
271
  /** Callback function to be executed when a row is double-clicked. */
272
272
  onRowDoubleClick?: string | ((e: React.SyntheticEvent<any>, instance: Instance) => void);
273
273
  /** Callback function to be executed on key down. Accepts instance of the currently focused record as the second argument. */
@@ -15,12 +15,18 @@ export interface TreeNodeConfig extends StyledContainerConfig {
15
15
  loading?: BooleanProp;
16
16
  /** Icon to be displayed. */
17
17
  icon?: StringProp;
18
+ /** Icon for items (sets leafIcon). */
19
+ itemIcon?: StringProp;
18
20
  /** Icon for leaf nodes. */
19
21
  leafIcon?: StringProp;
22
+ /** Icon displayed when the node is loading. */
23
+ loadingIcon?: string;
20
24
  /** Icon for open folder. */
21
25
  openFolderIcon?: StringProp;
22
26
  /** Icon for folder. */
23
27
  folderIcon?: StringProp;
28
+ /** Set to `true` to hide the icon. */
29
+ hideIcon?: boolean;
24
30
  /** Set to `true` to hide the arrow. */
25
31
  hideArrow?: BooleanProp;
26
32
  }
@@ -27,6 +27,7 @@ export * from "./ProgressBar";
27
27
  export * from "./Resizer";
28
28
  export * from "./HighlightedSearchText";
29
29
  export * from "./autoFocus";
30
+ export * from "./ReactElementWrapper";
30
31
  export * from "./icons/index";
31
32
  export * from "./overlay/index";
32
33
  export * from "./nav/index";
@@ -28,6 +28,7 @@ export * from "./ProgressBar";
28
28
  export * from "./Resizer";
29
29
  export * from "./HighlightedSearchText";
30
30
  export * from "./autoFocus";
31
+ export * from "./ReactElementWrapper";
31
32
  export * from "./icons/index";
32
33
  export * from "./overlay/index";
33
34
  export * from "./nav/index";
@@ -1,10 +1,10 @@
1
- import { HtmlElement, HtmlElementConfig, HtmlElementInstance } from "../HtmlElement";
1
+ import { HtmlElement, HtmlElementConfigBase, HtmlElementInstance } from "../HtmlElement";
2
2
  import { RenderingContext } from "../../ui/RenderingContext";
3
3
  import { DropdownConfig } from "../overlay/Dropdown";
4
4
  import { KeyboardShortcut } from "../../ui/keyboardShortcuts";
5
5
  import { BooleanProp, Prop, StringProp } from "../../ui/Prop";
6
6
  import { Config } from "../../ui/Prop";
7
- export interface MenuItemConfig extends HtmlElementConfig {
7
+ export interface MenuItemConfig extends HtmlElementConfigBase {
8
8
  baseClass?: string;
9
9
  hoverFocusTimeout?: number;
10
10
  clickToOpen?: boolean;
@@ -31,6 +31,7 @@ export interface MenuItemConfig extends HtmlElementConfig {
31
31
  hideCursor?: boolean;
32
32
  dropdown?: any;
33
33
  onClick?: string | ((e: React.MouseEvent | null, instance: HtmlElementInstance<MenuItem>) => void);
34
+ onMouseDown?: string | ((e: React.MouseEvent, instance: HtmlElementInstance<MenuItem>) => void);
34
35
  }
35
36
  export declare class MenuItemInstance extends HtmlElementInstance<MenuItem> {
36
37
  horizontal?: boolean;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,15 @@
1
+ import { jsx as _jsx } from "cx/jsx-runtime";
2
+ import { Route } from "./Route";
3
+ import { Store } from "../../data/Store";
4
+ import { createTestRenderer } from "../../util/test/createTestRenderer";
5
+ import assert from "assert";
6
+ describe("Route", () => {
7
+ it("matching works for ~/widgets/color-pickers", () => {
8
+ let widget = (_jsx("cx", { children: _jsx(Route, { url: "~/widgets/color-pickers", route: "~/widgets/color-pickers", children: _jsx("div", {}) }) }));
9
+ let store = new Store();
10
+ const component = createTestRenderer(store, widget);
11
+ let tree = component.toJSON();
12
+ assert(tree && !Array.isArray(tree));
13
+ assert.equal(tree.type, "div");
14
+ });
15
+ });
@@ -1,21 +1,19 @@
1
1
  import { VDOM } from "../../ui/Widget";
2
- import { Container, ContainerConfig } from "../../ui/Container";
2
+ import { StyledContainerBase, StyledContainerConfig } from "../../ui/Container";
3
3
  import { RenderingContext } from "../../ui/RenderingContext";
4
4
  import { Instance } from "../../ui/Instance";
5
5
  import { BooleanProp, StringProp } from "../../ui/Prop";
6
- export interface ScrollerConfig extends ContainerConfig {
7
- /** Base CSS class. Default is `hscroller`. */
8
- baseClass?: string;
6
+ export interface ScrollerConfig extends StyledContainerConfig {
9
7
  horizontal?: BooleanProp;
10
8
  vertical?: BooleanProp;
11
9
  scrollIntoViewSelector?: StringProp;
12
10
  }
13
- export declare class Scroller extends Container {
11
+ export declare class Scroller extends StyledContainerBase<ScrollerConfig> {
14
12
  baseClass: string;
15
- styled: boolean;
16
13
  horizontal?: any;
17
14
  vertical?: any;
18
15
  scrollIntoViewSelector?: any;
16
+ constructor(config?: ScrollerConfig);
19
17
  init(): void;
20
18
  declareData(...args: any[]): void;
21
19
  render(context: RenderingContext, instance: Instance, key: string): import("react/jsx-runtime").JSX.Element;
@@ -1,10 +1,14 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ /** @jsxImportSource react */
2
3
  import { Icon } from "../Icon";
3
4
  import { VDOM } from "../../ui/Widget";
4
- import { Container } from "../../ui/Container";
5
+ import { StyledContainerBase } from "../../ui/Container";
5
6
  import { ResizeManager } from "../../ui/ResizeManager";
6
7
  import { isString, scrollElementIntoView } from "../../util";
7
- export class Scroller extends Container {
8
+ export class Scroller extends StyledContainerBase {
9
+ constructor(config) {
10
+ super(config);
11
+ }
8
12
  init() {
9
13
  if (!this.vertical)
10
14
  this.horizontal = true; //default
@@ -19,7 +23,6 @@ export class Scroller extends Container {
19
23
  return (_jsx(HScrollerComponent, { widget: this, data: instance.data, children: this.renderChildren(context, instance) }, key));
20
24
  }
21
25
  }
22
- Scroller.prototype.styled = true;
23
26
  Scroller.prototype.baseClass = "scroller";
24
27
  export class HScrollerComponent extends VDOM.Component {
25
28
  unsubscribeResize;
@@ -1,8 +1,8 @@
1
- import { HtmlElement, HtmlElementConfig, HtmlElementInstance } from "../HtmlElement";
1
+ import { HtmlElement, HtmlElementConfigBase, HtmlElementInstance } from "../HtmlElement";
2
2
  import { Instance } from "../../ui/Instance";
3
3
  import { RenderingContext } from "../../ui/RenderingContext";
4
4
  import { BooleanProp, Prop, StringProp } from "../../ui/Prop";
5
- export interface TabConfig extends HtmlElementConfig {
5
+ export interface TabConfig extends HtmlElementConfigBase {
6
6
  /** A value to be written to the `value` property if the tab is clicked. */
7
7
  tab?: Prop<string | number>;
8
8
  /**
@@ -1,9 +1,9 @@
1
- import { Dropdown, DropdownConfig } from "./Dropdown";
2
- import { View } from "../../data/View";
1
+ import { Store } from "../../data/Store";
3
2
  import { Instance } from "../../ui/Instance";
3
+ import { Dropdown, DropdownConfig } from "./Dropdown";
4
4
  export interface ContextMenuConfig extends DropdownConfig {
5
5
  }
6
6
  export declare class ContextMenu extends Dropdown {
7
7
  constructor(config?: ContextMenuConfig);
8
8
  }
9
- export declare const openContextMenu: (e: React.MouseEvent, content: any, storeOrInstance?: View | Instance, options?: any) => () => void;
9
+ export declare const openContextMenu: (e: React.MouseEvent, content: any, storeOrInstance?: Store | Instance, options?: any) => () => void;
@@ -1,3 +1,4 @@
1
+ import { Store } from "../../data/Store";
1
2
  import { ContainerBase, StyledContainerConfig } from "../../ui/Container";
2
3
  import { Instance } from "../../ui/Instance";
3
4
  import { BooleanProp, NumberProp } from "../../ui/Prop";
@@ -124,7 +125,7 @@ export declare class OverlayBase<Config extends OverlayConfig = OverlayConfig, I
124
125
  handleMouseEnter(instance: InstanceType, component: any): void;
125
126
  getOverlayContainer(): HTMLElement;
126
127
  containerFactory(): HTMLElement;
127
- open(storeOrInstance: any, options?: any): () => void;
128
+ open(storeOrInstance?: Store | Instance, options?: any): () => void;
128
129
  handleMove(e: any, instance: InstanceType, component: any): void;
129
130
  handleResize(e: any, instance: InstanceType, component: any): void;
130
131
  }
@@ -7,9 +7,9 @@ import { FocusManager, offFocusOut, oneFocusOut } from "../../ui/FocusManager";
7
7
  import { Instance } from "../../ui/Instance";
8
8
  import { VDOM, Widget } from "../../ui/Widget";
9
9
  import { ZIndexManager } from "../../ui/ZIndexManager";
10
- import { getActiveElement } from "../../util";
11
10
  import { addEventListenerWithOptions } from "../../util/addEventListenerWithOptions";
12
11
  import { closest, isSelfOrDescendant } from "../../util/DOM";
12
+ import { getActiveElement } from "../../util/getActiveElement";
13
13
  import { getTopLevelBoundingClientRect } from "../../util/getTopLevelBoundingClientRect";
14
14
  import { isDataRecord } from "../../util/isDataRecord";
15
15
  import { isNumber } from "../../util/isNumber";
package/build.js CHANGED
@@ -1,133 +1,133 @@
1
- const buildJS = require("cx-build-tools/buildJS"),
2
- buildSCSS = require("cx-build-tools/buildSCSS"),
3
- copyFiles = require("cx-build-tools/copyFiles"),
4
- getPathResolver = require("cx-build-tools/getPathResolver"),
5
- fs = require("fs"),
6
- resolvePath = getPathResolver(__dirname),
7
- cxSrc = getPathResolver(resolvePath("./src")),
8
- cxBuild = getPathResolver(resolvePath("./build"));
9
-
10
- const entries = [
11
- {
12
- name: "util",
13
- options: {
14
- input: cxBuild("util/index.js"),
15
- },
16
- output: {},
17
- },
18
- {
19
- name: "data",
20
-
21
- options: {
22
- input: cxBuild("data/index.js"),
23
- },
24
- output: {},
25
- },
26
- {
27
- name: "ui",
28
- options: {
29
- input: cxBuild("ui/index.js"),
30
- },
31
- output: {},
32
- },
33
- {
34
- name: "widgets",
35
- options: {
36
- input: cxBuild("widgets/index.js"),
37
- },
38
- output: {},
39
- },
40
- {
41
- name: "svg",
42
- options: {
43
- input: cxBuild("svg/index.js"),
44
- },
45
- output: {},
46
- },
47
- {
48
- name: "charts",
49
- options: {
50
- input: cxBuild("charts/index.js"),
51
- },
52
- output: {},
53
- },
54
- {
55
- name: "hooks",
56
- options: {
57
- input: cxBuild("hooks/index.js"),
58
- },
59
- output: {},
60
- },
61
- {
62
- name: "jsx-runtime",
63
- options: {
64
- input: cxBuild("jsx-runtime.js"),
65
- },
66
- output: {},
67
- },
68
- ];
69
-
70
- const externalPaths = {
71
- [cxBuild("./util/")]: "cx/util",
72
- [cxBuild("./data/")]: "cx/data",
73
- [cxBuild("./ui/")]: "cx/ui",
74
- [cxBuild("./widgets")]: "cx/widgets",
75
- [cxBuild("./charts")]: "cx/charts",
76
- [cxBuild("./svg/")]: "cx/svg",
77
- [cxBuild("./hooks/")]: "cx/hooks",
78
- [cxBuild("./jsx-runtime")]: "cx/jsx-runtime",
79
- };
80
-
81
- (async function buildAll() {
82
- console.log("Building cx...");
83
- try {
84
- let distPath = resolvePath("./dist");
85
- if (!fs.existsSync(distPath)) {
86
- fs.mkdirSync(distPath);
87
- }
88
-
89
- // // Copy SCSS files from src to build
90
- // copyFiles(cxSrc("."), cxBuild("."), ".scss");
91
-
92
- await Promise.all([
93
- buildJS(resolvePath("./src"), resolvePath("./dist"), entries, externalPaths),
94
- buildSCSS([resolvePath("../cx-build-tools/reset.scss")], resolvePath("./dist/reset.css")),
95
- buildSCSS(
96
- [
97
- cxSrc("variables.scss"),
98
- resolvePath("../cx-build-tools/divide.scss"),
99
- cxSrc("widgets/index.scss"),
100
- cxSrc("ui/index.scss"),
101
- ],
102
- resolvePath("./dist/widgets.css"),
103
- ),
104
- buildSCSS(
105
- [cxSrc("variables.scss"), resolvePath("../cx-build-tools/divide.scss"), cxSrc("charts/index.scss")],
106
- resolvePath("./dist/charts.css"),
107
- ),
108
- buildSCSS(
109
- [cxSrc("variables.scss"), resolvePath("../cx-build-tools/divide.scss"), cxSrc("svg/index.scss")],
110
- resolvePath("./dist/svg.css"),
111
- ),
112
- ]);
113
- } catch (err) {
114
- console.log("Build error.", err);
115
- }
116
-
117
- // console.log("Building cx-redux...");
118
- // await build(
119
- // resolvePath("../../cx-redux/src"),
120
- // resolvePath("../../cx-redux/dist"),
121
- // [
122
- // {
123
- // name: "index",
124
- // options: {
125
- // input: [resolvePath("../../cx-redux/src/index.js")]
126
- // },
127
- // output: {}
128
- // }
129
- // ],
130
- // null,
131
- // ["redux", "cx/data"]
132
- // );
133
- })();
1
+ const buildJS = require("cx-build-tools/buildJS"),
2
+ buildSCSS = require("cx-build-tools/buildSCSS"),
3
+ copyFiles = require("cx-build-tools/copyFiles"),
4
+ getPathResolver = require("cx-build-tools/getPathResolver"),
5
+ fs = require("fs"),
6
+ resolvePath = getPathResolver(__dirname),
7
+ cxSrc = getPathResolver(resolvePath("./src")),
8
+ cxBuild = getPathResolver(resolvePath("./build"));
9
+
10
+ const entries = [
11
+ {
12
+ name: "util",
13
+ options: {
14
+ input: cxBuild("util/index.js"),
15
+ },
16
+ output: {},
17
+ },
18
+ {
19
+ name: "data",
20
+
21
+ options: {
22
+ input: cxBuild("data/index.js"),
23
+ },
24
+ output: {},
25
+ },
26
+ {
27
+ name: "ui",
28
+ options: {
29
+ input: cxBuild("ui/index.js"),
30
+ },
31
+ output: {},
32
+ },
33
+ {
34
+ name: "widgets",
35
+ options: {
36
+ input: cxBuild("widgets/index.js"),
37
+ },
38
+ output: {},
39
+ },
40
+ {
41
+ name: "svg",
42
+ options: {
43
+ input: cxBuild("svg/index.js"),
44
+ },
45
+ output: {},
46
+ },
47
+ {
48
+ name: "charts",
49
+ options: {
50
+ input: cxBuild("charts/index.js"),
51
+ },
52
+ output: {},
53
+ },
54
+ {
55
+ name: "hooks",
56
+ options: {
57
+ input: cxBuild("hooks/index.js"),
58
+ },
59
+ output: {},
60
+ },
61
+ {
62
+ name: "jsx-runtime",
63
+ options: {
64
+ input: cxBuild("jsx-runtime.js"),
65
+ },
66
+ output: {},
67
+ },
68
+ ];
69
+
70
+ const externalPaths = {
71
+ [cxBuild("./util/")]: "cx/util",
72
+ [cxBuild("./data/")]: "cx/data",
73
+ [cxBuild("./ui/")]: "cx/ui",
74
+ [cxBuild("./widgets")]: "cx/widgets",
75
+ [cxBuild("./charts")]: "cx/charts",
76
+ [cxBuild("./svg/")]: "cx/svg",
77
+ [cxBuild("./hooks/")]: "cx/hooks",
78
+ [cxBuild("./jsx-runtime")]: "cx/jsx-runtime",
79
+ };
80
+
81
+ (async function buildAll() {
82
+ console.log("Building cx...");
83
+ try {
84
+ let distPath = resolvePath("./dist");
85
+ if (!fs.existsSync(distPath)) {
86
+ fs.mkdirSync(distPath);
87
+ }
88
+
89
+ // // Copy SCSS files from src to build
90
+ // copyFiles(cxSrc("."), cxBuild("."), ".scss");
91
+
92
+ await Promise.all([
93
+ buildJS(resolvePath("./src"), resolvePath("./dist"), entries, externalPaths),
94
+ buildSCSS([resolvePath("../cx-build-tools/reset.scss")], resolvePath("./dist/reset.css")),
95
+ buildSCSS(
96
+ [
97
+ cxSrc("variables.scss"),
98
+ resolvePath("../cx-build-tools/divide.scss"),
99
+ cxSrc("widgets/index.scss"),
100
+ cxSrc("ui/index.scss"),
101
+ ],
102
+ resolvePath("./dist/widgets.css"),
103
+ ),
104
+ buildSCSS(
105
+ [cxSrc("variables.scss"), resolvePath("../cx-build-tools/divide.scss"), cxSrc("charts/index.scss")],
106
+ resolvePath("./dist/charts.css"),
107
+ ),
108
+ buildSCSS(
109
+ [cxSrc("variables.scss"), resolvePath("../cx-build-tools/divide.scss"), cxSrc("svg/index.scss")],
110
+ resolvePath("./dist/svg.css"),
111
+ ),
112
+ ]);
113
+ } catch (err) {
114
+ console.log("Build error.", err);
115
+ }
116
+
117
+ // console.log("Building cx-redux...");
118
+ // await build(
119
+ // resolvePath("../../cx-redux/src"),
120
+ // resolvePath("../../cx-redux/dist"),
121
+ // [
122
+ // {
123
+ // name: "index",
124
+ // options: {
125
+ // input: [resolvePath("../../cx-redux/src/index.js")]
126
+ // },
127
+ // output: {}
128
+ // }
129
+ // ],
130
+ // null,
131
+ // ["redux", "cx/data"]
132
+ // );
133
+ })();
package/dist/data.js CHANGED
@@ -1663,7 +1663,7 @@ function updateTree(array, updateCallback, itemFilter, childrenField, removeFilt
1663
1663
  );
1664
1664
  }
1665
1665
 
1666
- function removeTreeNodes(array, criteria, childrenField = "$children") {
1666
+ function removeTreeNodes(array, criteria, childrenField) {
1667
1667
  return updateTree(
1668
1668
  array,
1669
1669
  (x) => x,
@@ -1673,7 +1673,7 @@ function removeTreeNodes(array, criteria, childrenField = "$children") {
1673
1673
  );
1674
1674
  }
1675
1675
 
1676
- function findTreeNode(array, criteria, childrenField = "$children") {
1676
+ function findTreeNode(array, criteria, childrenField) {
1677
1677
  if (!Array.isArray(array)) return false;
1678
1678
  for (const node of array) {
1679
1679
  if (criteria(node)) return node;
@@ -1,5 +1,5 @@
1
1
  import { isArray, isString } from "cx/util";
2
- import { HtmlElement } from "cx/widgets";
2
+ import { HtmlElement, ReactElementWrapper } from "cx/widgets";
3
3
 
4
4
  function jsx(typeName, props, key) {
5
5
  if (isArray(typeName)) return typeName;
@@ -13,6 +13,11 @@ function jsx(typeName, props, key) {
13
13
  props.tag = typeName;
14
14
  typeName = HtmlElement;
15
15
  }
16
+ // React components (functions/classes without isComponentType and not CxJS functional components) should go through ReactElementWrapper
17
+ else if (typeof typeName === "function" && !typeName.isComponentType && !typeName.$isComponentFactory) {
18
+ props.componentType = typeName;
19
+ typeName = ReactElementWrapper;
20
+ }
16
21
  return {
17
22
  $type: typeName,
18
23
  ...props,