cx 26.0.12 → 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 (363) 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/util/Console.d.ts +1 -0
  120. package/build/util/Console.js +7 -3
  121. package/build/util/Format.spec.d.ts +1 -0
  122. package/build/util/Format.spec.js +58 -0
  123. package/build/util/TraversalStack.spec.d.ts +1 -0
  124. package/build/util/TraversalStack.spec.js +43 -0
  125. package/build/util/date/upperBoundCheck.spec.d.ts +1 -0
  126. package/build/util/date/upperBoundCheck.spec.js +22 -0
  127. package/build/util/getSearchQueryPredicate.spec.d.ts +1 -0
  128. package/build/util/getSearchQueryPredicate.spec.js +33 -0
  129. package/build/util/isValidIdentifierName.spec.d.ts +1 -0
  130. package/build/util/isValidIdentifierName.spec.js +28 -0
  131. package/build/util/routeAppend.spec.d.ts +1 -0
  132. package/build/util/routeAppend.spec.js +14 -0
  133. package/build/widgets/AccessorBindings.spec.d.ts +1 -0
  134. package/build/widgets/AccessorBindings.spec.js +40 -0
  135. package/build/widgets/Button.d.ts +3 -6
  136. package/build/widgets/Button.js +1 -1
  137. package/build/widgets/DocumentTitle.d.ts +2 -0
  138. package/build/widgets/Heading.d.ts +2 -2
  139. package/build/widgets/HtmlElement.d.ts +31 -8
  140. package/build/widgets/HtmlElement.js +7 -9
  141. package/build/widgets/HtmlElement.spec.d.ts +1 -0
  142. package/build/widgets/HtmlElement.spec.js +38 -0
  143. package/build/widgets/Icon.d.ts +3 -13
  144. package/build/widgets/List.d.ts +4 -0
  145. package/build/widgets/ReactElementWrapper.d.ts +29 -0
  146. package/build/widgets/ReactElementWrapper.js +59 -0
  147. package/build/widgets/drag-drop/DragSource.d.ts +3 -3
  148. package/build/widgets/drag-drop/DragSource.js +2 -3
  149. package/build/widgets/drag-drop/DropZone.d.ts +3 -3
  150. package/build/widgets/drag-drop/DropZone.js +2 -3
  151. package/build/widgets/form/Checkbox.d.ts +2 -0
  152. package/build/widgets/form/ColorField.d.ts +2 -0
  153. package/build/widgets/form/DateTimeField.d.ts +2 -0
  154. package/build/widgets/form/Field.d.ts +0 -2
  155. package/build/widgets/form/LabeledContainer.d.ts +9 -8
  156. package/build/widgets/form/LabeledContainer.js +9 -9
  157. package/build/widgets/form/LookupField.d.ts +57 -9
  158. package/build/widgets/form/MonthField.d.ts +2 -0
  159. package/build/widgets/form/NumberField.d.ts +2 -0
  160. package/build/widgets/form/Radio.d.ts +2 -0
  161. package/build/widgets/form/Select.d.ts +2 -0
  162. package/build/widgets/form/Slider.d.ts +3 -0
  163. package/build/widgets/form/Switch.d.ts +2 -0
  164. package/build/widgets/form/TextField.d.ts +34 -0
  165. package/build/widgets/form/TimeList.d.ts +16 -1
  166. package/build/widgets/form/TimeList.js +34 -62
  167. package/build/widgets/form/UploadButton.d.ts +34 -2
  168. package/build/widgets/form/UploadButton.js +3 -1
  169. package/build/widgets/form/ValidationGroup.spec.d.ts +1 -0
  170. package/build/widgets/form/ValidationGroup.spec.js +62 -0
  171. package/build/widgets/form/Validator.d.ts +33 -2
  172. package/build/widgets/form/Validator.js +3 -0
  173. package/build/widgets/grid/Grid.d.ts +9 -9
  174. package/build/widgets/grid/TreeNode.d.ts +6 -0
  175. package/build/widgets/index.d.ts +1 -0
  176. package/build/widgets/index.js +1 -0
  177. package/build/widgets/nav/MenuItem.d.ts +3 -2
  178. package/build/widgets/nav/Route.spec.d.ts +1 -0
  179. package/build/widgets/nav/Route.spec.js +15 -0
  180. package/build/widgets/nav/Scroller.d.ts +4 -6
  181. package/build/widgets/nav/Scroller.js +6 -3
  182. package/build/widgets/nav/Tab.d.ts +2 -2
  183. package/build/widgets/overlay/ContextMenu.d.ts +3 -3
  184. package/build/widgets/overlay/Overlay.d.ts +2 -1
  185. package/build/widgets/overlay/Overlay.js +1 -1
  186. package/build.js +133 -133
  187. package/dist/data.js +2 -2
  188. package/dist/jsx-runtime.js +6 -1
  189. package/dist/manifest.d.ts +1443 -0
  190. package/dist/manifest.js +855 -807
  191. package/dist/ui.js +91 -5
  192. package/dist/util.js +3 -0
  193. package/dist/widgets.js +520 -161
  194. package/package.json +46 -20
  195. package/src/charts/Chart.ts +108 -108
  196. package/src/charts/ScatterGraph.tsx +6 -6
  197. package/src/data/ArrayElementView.ts +90 -90
  198. package/src/data/AugmentedViewBase.ts +88 -88
  199. package/src/data/Binding.ts +104 -104
  200. package/src/data/ExposedRecordView.ts +95 -95
  201. package/src/data/ExposedValueView.ts +89 -89
  202. package/src/data/Expression.spec.ts +229 -229
  203. package/src/data/Expression.ts +233 -233
  204. package/src/data/Grouper.spec.ts +57 -57
  205. package/src/data/Grouper.ts +158 -158
  206. package/src/data/NestedDataView.ts +43 -43
  207. package/src/data/ReadOnlyDataView.ts +39 -39
  208. package/src/data/Ref.ts +104 -104
  209. package/src/data/Selector.ts +10 -10
  210. package/src/data/Store.ts +52 -52
  211. package/src/data/StoreProxy.ts +19 -19
  212. package/src/data/StoreRef.ts +66 -66
  213. package/src/data/StringTemplate.spec.ts +132 -132
  214. package/src/data/StringTemplate.ts +93 -93
  215. package/src/data/StructuredSelector.spec.ts +113 -113
  216. package/src/data/StructuredSelector.ts +146 -146
  217. package/src/data/SubscribableView.ts +63 -63
  218. package/src/data/ZoomIntoPropertyView.spec.ts +64 -64
  219. package/src/data/ZoomIntoPropertyView.ts +45 -45
  220. package/src/data/computable.spec.ts +87 -62
  221. package/src/data/computable.ts +3 -6
  222. package/src/data/createAccessorModelProxy.spec.tsx +102 -1
  223. package/src/data/createAccessorModelProxy.ts +9 -3
  224. package/src/data/createStructuredSelector.ts +62 -62
  225. package/src/data/getAccessor.spec.ts +11 -11
  226. package/src/data/getAccessor.ts +74 -74
  227. package/src/data/getSelector.spec.ts +43 -43
  228. package/src/data/getSelector.ts +66 -66
  229. package/src/data/ops/filter.spec.ts +35 -35
  230. package/src/data/ops/filter.ts +9 -9
  231. package/src/data/ops/findTreeNode.ts +1 -5
  232. package/src/data/ops/findTreePath.ts +1 -1
  233. package/src/data/ops/merge.ts +13 -13
  234. package/src/data/ops/removeTreeNodes.spec.ts +37 -37
  235. package/src/data/ops/removeTreeNodes.ts +2 -2
  236. package/src/data/ops/updateArray.spec.ts +69 -69
  237. package/src/data/ops/updateArray.ts +31 -31
  238. package/src/data/ops/updateTree.ts +1 -1
  239. package/src/data/test-types.ts +7 -7
  240. package/src/hooks/resolveCallback.spec.tsx +30 -7
  241. package/src/hooks/useTrigger.ts +26 -26
  242. package/src/index.scss +6 -6
  243. package/src/jsx-dev-runtime.ts +4 -4
  244. package/src/jsx-runtime.spec.tsx +402 -0
  245. package/src/jsx-runtime.ts +26 -22
  246. package/src/svg/BoundedObject.ts +101 -101
  247. package/src/svg/util/Rect.ts +105 -105
  248. package/src/ui/CSSHelper.ts +17 -17
  249. package/src/ui/ContentResolver.spec.tsx +172 -19
  250. package/src/ui/ContentResolver.ts +16 -8
  251. package/src/ui/Controller.ts +15 -2
  252. package/src/ui/Culture.ts +159 -159
  253. package/src/ui/DataProxy.ts +55 -55
  254. package/src/ui/FocusManager.ts +171 -171
  255. package/src/ui/Instance.ts +866 -868
  256. package/src/ui/Prop.ts +140 -112
  257. package/src/ui/RenderingContext.ts +99 -99
  258. package/src/ui/Repeater.ts +3 -12
  259. package/src/ui/Rescope.ts +49 -49
  260. package/src/ui/StructuredInstanceDataAccessor.ts +32 -32
  261. package/src/ui/Text.ts +21 -2
  262. package/src/ui/VDOM.ts +34 -34
  263. package/src/ui/adapter/ArrayAdapter.spec.ts +55 -55
  264. package/src/ui/adapter/ArrayAdapter.ts +4 -1
  265. package/src/ui/adapter/TreeAdapter.spec.ts +76 -76
  266. package/src/ui/adapter/TreeAdapter.ts +185 -185
  267. package/src/ui/app/History.ts +133 -133
  268. package/src/ui/app/Url.spec.ts +50 -50
  269. package/src/ui/app/startHotAppLoop.ts +41 -41
  270. package/src/ui/createFunctionalComponent.spec.tsx +53 -0
  271. package/src/ui/createFunctionalComponent.ts +86 -65
  272. package/src/ui/expr.ts +4 -1
  273. package/src/ui/exprHelpers.spec.ts +379 -0
  274. package/src/ui/exprHelpers.ts +78 -0
  275. package/src/ui/index.ts +47 -46
  276. package/src/ui/layout/Content.ts +30 -30
  277. package/src/ui/layout/FirstVisibleChildLayout.spec.tsx +1 -1
  278. package/src/ui/layout/FirstVisibleChildLayout.ts +60 -60
  279. package/src/ui/selection/KeySelection.ts +153 -153
  280. package/src/ui/selection/Selection.ts +128 -128
  281. package/src/util/Console.ts +13 -11
  282. package/src/util/Format.ts +267 -267
  283. package/src/util/addEventListenerWithOptions.ts +41 -41
  284. package/src/util/browserSupportsPassiveEventHandlers.ts +20 -20
  285. package/src/util/color/rgbToHsl.ts +35 -35
  286. package/src/util/getActiveElement.ts +4 -4
  287. package/src/util/hasKey.ts +18 -18
  288. package/src/util/index.ts +55 -55
  289. package/src/util/innerTextTrim.ts +10 -10
  290. package/src/util/isArray.ts +3 -3
  291. package/src/util/isDataRecord.ts +5 -5
  292. package/src/util/isDefined.ts +3 -3
  293. package/src/util/isString.ts +3 -3
  294. package/src/widgets/AccessorBindings.spec.tsx +26 -0
  295. package/src/widgets/Button.tsx +5 -17
  296. package/src/widgets/DocumentTitle.ts +95 -92
  297. package/src/widgets/Heading.ts +2 -2
  298. package/src/widgets/HtmlElement.spec.helpers.tsx +108 -0
  299. package/src/widgets/HtmlElement.spec.tsx +20 -12
  300. package/src/widgets/HtmlElement.tsx +77 -23
  301. package/src/widgets/Icon.ts +3 -17
  302. package/src/widgets/List.tsx +6 -0
  303. package/src/widgets/ReactElementWrapper.spec.tsx +452 -0
  304. package/src/widgets/ReactElementWrapper.tsx +108 -0
  305. package/src/widgets/Sandbox.ts +103 -103
  306. package/src/widgets/autoFocus.ts +9 -9
  307. package/src/widgets/cx.ts +63 -63
  308. package/src/widgets/drag-drop/DragSource.tsx +3 -4
  309. package/src/widgets/drag-drop/DropZone.tsx +3 -4
  310. package/src/widgets/form/Checkbox.tsx +3 -0
  311. package/src/widgets/form/ColorField.tsx +3 -0
  312. package/src/widgets/form/DateTimeField.tsx +5 -0
  313. package/src/widgets/form/Field.tsx +0 -3
  314. package/src/widgets/form/Label.tsx +1 -0
  315. package/src/widgets/form/LabeledContainer.ts +22 -26
  316. package/src/widgets/form/LookupField.spec.tsx +93 -0
  317. package/src/widgets/form/LookupField.tsx +104 -9
  318. package/src/widgets/form/MonthField.tsx +5 -0
  319. package/src/widgets/form/NumberField.tsx +3 -0
  320. package/src/widgets/form/Radio.tsx +5 -0
  321. package/src/widgets/form/Select.tsx +5 -0
  322. package/src/widgets/form/Slider.tsx +4 -0
  323. package/src/widgets/form/Switch.tsx +3 -0
  324. package/src/widgets/form/TextField.tsx +62 -0
  325. package/src/widgets/form/TimeList.tsx +84 -73
  326. package/src/widgets/form/UploadButton.tsx +53 -2
  327. package/src/widgets/form/Validator.ts +40 -3
  328. package/src/widgets/grid/Grid.tsx +9 -12
  329. package/src/widgets/grid/GridCell.ts +143 -143
  330. package/src/widgets/grid/TreeNode.tsx +9 -0
  331. package/src/widgets/icons/calendar.tsx +17 -17
  332. package/src/widgets/icons/check.tsx +13 -13
  333. package/src/widgets/icons/clear.tsx +15 -15
  334. package/src/widgets/icons/close.tsx +20 -20
  335. package/src/widgets/icons/cx.tsx +38 -38
  336. package/src/widgets/icons/drop-down.tsx +15 -15
  337. package/src/widgets/icons/file.tsx +13 -13
  338. package/src/widgets/icons/folder-open.tsx +15 -15
  339. package/src/widgets/icons/folder.tsx +13 -13
  340. package/src/widgets/icons/forward.tsx +22 -22
  341. package/src/widgets/icons/loading.tsx +24 -24
  342. package/src/widgets/icons/menu.tsx +17 -17
  343. package/src/widgets/icons/pixel-picker.tsx +18 -18
  344. package/src/widgets/icons/search.tsx +13 -13
  345. package/src/widgets/icons/sort-asc.tsx +14 -14
  346. package/src/widgets/icons/square.tsx +18 -18
  347. package/src/widgets/index.ts +1 -0
  348. package/src/widgets/nav/MenuItem.tsx +3 -2
  349. package/src/widgets/nav/Route.ts +142 -142
  350. package/src/widgets/nav/Scroller.tsx +8 -9
  351. package/src/widgets/nav/Tab.ts +2 -2
  352. package/src/widgets/overlay/ContextMenu.ts +42 -42
  353. package/src/widgets/overlay/Dropdown.tsx +762 -762
  354. package/src/widgets/overlay/MsgBox.tsx +141 -141
  355. package/src/widgets/overlay/Overlay.tsx +5 -4
  356. package/src/widgets/overlay/Toast.ts +111 -111
  357. package/src/widgets/overlay/Window.tsx +299 -299
  358. package/src/widgets/overlay/alerts.ts +46 -46
  359. package/src/widgets/overlay/captureMouse.ts +195 -195
  360. package/src/widgets/overlay/createHotPromiseWindowFactory.ts +72 -72
  361. package/src/widgets/overlay/index.d.ts +11 -11
  362. package/src/widgets/overlay/index.ts +11 -11
  363. package/src/widgets/overlay/tooltip-ops.ts +173 -173
@@ -1,46 +1,46 @@
1
- import {debug, deprecatedFlag} from '../../util/Debug';
2
- import {isString} from '../../util/isString';
3
-
4
- export type AlertOptions = string | { message?: string; [key: string]: any };
5
-
6
- interface AlertImpl {
7
- alert(options: AlertOptions): Promise<void>;
8
- yesNo(options: AlertOptions): Promise<string>;
9
- }
10
-
11
- function getMessage(options: AlertOptions): string | null {
12
- debug(deprecatedFlag, "Call enableMsgBoxes() on startup to use Cx based message boxes. Message boxes are not auto enabled anymore to reduce the bundle size for apps that do not use them. ");
13
- if (!options)
14
- return null;
15
- if (isString(options))
16
- return options;
17
- if (options && typeof options === 'object' && options.message)
18
- return options.message;
19
- return null;
20
- }
21
-
22
- let impl: AlertImpl = {
23
- yesNo: function (options: AlertOptions): Promise<string> {
24
- let result = window.confirm(getMessage(options) || '');
25
- return Promise.resolve(result ? 'yes' : 'no');
26
- },
27
-
28
- alert: function (options: AlertOptions): Promise<void> {
29
- window.alert(getMessage(options) || '');
30
- return Promise.resolve();
31
- }
32
- };
33
-
34
- export function alert(options: AlertOptions): Promise<void> {
35
- return impl.alert(options);
36
- }
37
-
38
- export function yesNo(options: AlertOptions): Promise<string> {
39
- return impl.yesNo(options);
40
- }
41
-
42
- export function registerAlertImpl(x: AlertImpl): void {
43
- impl = x;
44
- }
45
-
46
-
1
+ import {debug, deprecatedFlag} from '../../util/Debug';
2
+ import {isString} from '../../util/isString';
3
+
4
+ export type AlertOptions = string | { message?: string; [key: string]: any };
5
+
6
+ interface AlertImpl {
7
+ alert(options: AlertOptions): Promise<void>;
8
+ yesNo(options: AlertOptions): Promise<string>;
9
+ }
10
+
11
+ function getMessage(options: AlertOptions): string | null {
12
+ debug(deprecatedFlag, "Call enableMsgBoxes() on startup to use Cx based message boxes. Message boxes are not auto enabled anymore to reduce the bundle size for apps that do not use them. ");
13
+ if (!options)
14
+ return null;
15
+ if (isString(options))
16
+ return options;
17
+ if (options && typeof options === 'object' && options.message)
18
+ return options.message;
19
+ return null;
20
+ }
21
+
22
+ let impl: AlertImpl = {
23
+ yesNo: function (options: AlertOptions): Promise<string> {
24
+ let result = window.confirm(getMessage(options) || '');
25
+ return Promise.resolve(result ? 'yes' : 'no');
26
+ },
27
+
28
+ alert: function (options: AlertOptions): Promise<void> {
29
+ window.alert(getMessage(options) || '');
30
+ return Promise.resolve();
31
+ }
32
+ };
33
+
34
+ export function alert(options: AlertOptions): Promise<void> {
35
+ return impl.alert(options);
36
+ }
37
+
38
+ export function yesNo(options: AlertOptions): Promise<string> {
39
+ return impl.yesNo(options);
40
+ }
41
+
42
+ export function registerAlertImpl(x: AlertImpl): void {
43
+ impl = x;
44
+ }
45
+
46
+
@@ -1,195 +1,195 @@
1
- import { batchUpdates } from "../../ui/batchUpdates";
2
- import { getParentFrameBoundingClientRect } from "../../util/getParentFrameBoundingClientRect";
3
-
4
- /** Cursor position with client coordinates */
5
- export interface CursorPosition {
6
- clientX: number;
7
- clientY: number;
8
- }
9
-
10
- /**
11
- * Configuration options for mouse capture
12
- */
13
- interface CaptureMouseOptions {
14
- /** Callback function called on mouse move events */
15
- onMouseMove?: (e: MouseEvent, captureData?: any) => void;
16
- /** Callback function called on mouse up events */
17
- onMouseUp?: (e: MouseEvent, captureData?: any) => void;
18
- /** Callback function called on double click events */
19
- onDblClick?: (e: MouseEvent) => void;
20
- /** Additional data passed to callbacks */
21
- captureData?: any;
22
- /** CSS cursor style for the capture surface */
23
- cursor?: string;
24
- }
25
-
26
- /**
27
- * Captures mouse events globally by creating a transparent overlay
28
- * @param e - The initial mouse event that triggered the capture
29
- * @param options - Configuration options for the capture behavior
30
- */
31
- export function captureMouse2(
32
- e: React.MouseEvent | React.TouchEvent | MouseEvent | TouchEvent,
33
- options: CaptureMouseOptions,
34
- ): void {
35
- let surface = document.createElement("div");
36
- surface.className = "cxb-mousecapture";
37
- surface.style.cursor = options.cursor || getComputedStyle(e.currentTarget as Element).cursor;
38
-
39
- document.body.appendChild(surface);
40
-
41
- // In case when the event originates from an iframe,
42
- // we use that document as events do not bubble up.
43
- let parentDocument = (e.target as Element)?.ownerDocument;
44
- let eventOptions = { capture: true };
45
-
46
- let active = true;
47
- parentDocument.addEventListener("mousemove", move, eventOptions);
48
- parentDocument.addEventListener("mouseup", end, eventOptions);
49
- if (options.onDblClick) parentDocument.addEventListener("dblclick", doubleClick, eventOptions);
50
-
51
- function tear() {
52
- if (surface == null) return;
53
- parentDocument.removeEventListener("mousemove", move, eventOptions);
54
- parentDocument.removeEventListener("mouseup", end, eventOptions);
55
- if (options.onDblClick) parentDocument.removeEventListener("dblclick", doubleClick, eventOptions);
56
- document.body.removeChild(surface);
57
- surface = null as any;
58
- }
59
-
60
- function doubleClick(e: Event) {
61
- try {
62
- options.onDblClick && options.onDblClick(e as MouseEvent);
63
- } finally {
64
- tear();
65
- }
66
- }
67
-
68
- e.stopPropagation();
69
-
70
- function move(e: Event) {
71
- if (!active) {
72
- tear();
73
- return;
74
- }
75
-
76
- //if mouse moves double clicking is off
77
- options.onDblClick = undefined;
78
-
79
- batchUpdates(() => {
80
- if (options.onMouseMove) options.onMouseMove(e as MouseEvent, options.captureData);
81
- e.stopPropagation();
82
- e.preventDefault(); //disable text selection
83
- });
84
- }
85
-
86
- function end(e: Event) {
87
- active = false;
88
- batchUpdates(() => {
89
- // if (surface.releaseCapture)
90
- // surface.releaseCapture();
91
-
92
- if (!options.onDblClick) surface.style.display = "none";
93
- try {
94
- if (options.onMouseUp) options.onMouseUp(e as MouseEvent, options.captureData);
95
- } finally {
96
- if (options.onDblClick) {
97
- //keep the surface a little longer to detect double clicks
98
- setTimeout(tear, 1500);
99
- } else tear();
100
- }
101
- });
102
- }
103
- }
104
-
105
- /**
106
- * Captures mouse or touch events, automatically detecting the event type
107
- * @param e - The initial mouse or touch event that triggered the capture
108
- * @param options - Configuration options for the capture behavior
109
- */
110
- export function captureMouseOrTouch2(
111
- e: React.MouseEvent | React.TouchEvent | MouseEvent | TouchEvent,
112
- options: CaptureMouseOptions,
113
- ): void {
114
- if (e.type.indexOf("touch") == 0) {
115
- let el = e.currentTarget as HTMLElement;
116
-
117
- let move = (e: TouchEvent) => {
118
- batchUpdates(() => {
119
- if (options.onMouseMove) options.onMouseMove(e as any, options.captureData);
120
- e.preventDefault();
121
- });
122
- };
123
-
124
- let end = (e: TouchEvent) => {
125
- batchUpdates(() => {
126
- el.removeEventListener("touchmove", move);
127
- el.removeEventListener("touchend", end);
128
-
129
- if (options.onMouseUp) options.onMouseUp(e as any);
130
-
131
- e.preventDefault();
132
- });
133
- };
134
-
135
- el.addEventListener("touchmove", move);
136
- el.addEventListener("touchend", end);
137
-
138
- e.stopPropagation();
139
- } else captureMouse2(e, options);
140
- }
141
-
142
- /**
143
- * Legacy function for capturing mouse events with individual parameters
144
- * @param e - The initial mouse event that triggered the capture
145
- * @param onMouseMove - Callback function called on mouse move events
146
- * @param onMouseUp - Callback function called on mouse up events
147
- * @param captureData - Additional data passed to callbacks
148
- * @param cursor - CSS cursor style for the capture surface
149
- */
150
- export function captureMouse(
151
- e: React.MouseEvent,
152
- onMouseMove?: (e: MouseEvent | TouchEvent, captureData?: any) => void,
153
- onMouseUp?: (e: MouseEvent | TouchEvent, captureData?: any) => void,
154
- captureData?: any,
155
- cursor?: string,
156
- ): void {
157
- captureMouse2(e, {
158
- onMouseMove,
159
- onMouseUp,
160
- captureData,
161
- cursor,
162
- });
163
- }
164
-
165
- /**
166
- * Legacy function for capturing mouse or touch events with individual parameters
167
- * @param e - The initial mouse or touch event that triggered the capture
168
- * @param onMouseMove - Callback function called on mouse/touch move events
169
- * @param onMouseUp - Callback function called on mouse/touch up events
170
- * @param captureData - Additional data passed to callbacks
171
- * @param cursor - CSS cursor style for the capture surface
172
- */
173
- export function captureMouseOrTouch(
174
- e: React.MouseEvent | React.TouchEvent | MouseEvent | TouchEvent,
175
- onMouseMove?: (e: MouseEvent, captureData?: any) => void,
176
- onMouseUp?: (e: MouseEvent, captureData?: any) => void,
177
- captureData?: any,
178
- cursor?: string,
179
- ): void {
180
- captureMouseOrTouch2(e, { onMouseMove, onMouseUp, captureData, cursor });
181
- }
182
-
183
- /**
184
- * Gets the cursor position relative to the parent frame
185
- * @param e - Mouse or touch event (React or native)
186
- * @returns Object with clientX and clientY coordinates adjusted for parent frame offset
187
- */
188
- export function getCursorPos(e: React.MouseEvent | React.TouchEvent | MouseEvent | TouchEvent): CursorPosition {
189
- let p = (e as TouchEvent).touches?.[0] || (e as MouseEvent);
190
- let offset = getParentFrameBoundingClientRect(e.target as Element);
191
- return {
192
- clientX: p.clientX + offset.left,
193
- clientY: p.clientY + offset.top,
194
- };
195
- }
1
+ import { batchUpdates } from "../../ui/batchUpdates";
2
+ import { getParentFrameBoundingClientRect } from "../../util/getParentFrameBoundingClientRect";
3
+
4
+ /** Cursor position with client coordinates */
5
+ export interface CursorPosition {
6
+ clientX: number;
7
+ clientY: number;
8
+ }
9
+
10
+ /**
11
+ * Configuration options for mouse capture
12
+ */
13
+ interface CaptureMouseOptions {
14
+ /** Callback function called on mouse move events */
15
+ onMouseMove?: (e: MouseEvent, captureData?: any) => void;
16
+ /** Callback function called on mouse up events */
17
+ onMouseUp?: (e: MouseEvent, captureData?: any) => void;
18
+ /** Callback function called on double click events */
19
+ onDblClick?: (e: MouseEvent) => void;
20
+ /** Additional data passed to callbacks */
21
+ captureData?: any;
22
+ /** CSS cursor style for the capture surface */
23
+ cursor?: string;
24
+ }
25
+
26
+ /**
27
+ * Captures mouse events globally by creating a transparent overlay
28
+ * @param e - The initial mouse event that triggered the capture
29
+ * @param options - Configuration options for the capture behavior
30
+ */
31
+ export function captureMouse2(
32
+ e: React.MouseEvent | React.TouchEvent | MouseEvent | TouchEvent,
33
+ options: CaptureMouseOptions,
34
+ ): void {
35
+ let surface = document.createElement("div");
36
+ surface.className = "cxb-mousecapture";
37
+ surface.style.cursor = options.cursor || getComputedStyle(e.currentTarget as Element).cursor;
38
+
39
+ document.body.appendChild(surface);
40
+
41
+ // In case when the event originates from an iframe,
42
+ // we use that document as events do not bubble up.
43
+ let parentDocument = (e.target as Element)?.ownerDocument;
44
+ let eventOptions = { capture: true };
45
+
46
+ let active = true;
47
+ parentDocument.addEventListener("mousemove", move, eventOptions);
48
+ parentDocument.addEventListener("mouseup", end, eventOptions);
49
+ if (options.onDblClick) parentDocument.addEventListener("dblclick", doubleClick, eventOptions);
50
+
51
+ function tear() {
52
+ if (surface == null) return;
53
+ parentDocument.removeEventListener("mousemove", move, eventOptions);
54
+ parentDocument.removeEventListener("mouseup", end, eventOptions);
55
+ if (options.onDblClick) parentDocument.removeEventListener("dblclick", doubleClick, eventOptions);
56
+ document.body.removeChild(surface);
57
+ surface = null as any;
58
+ }
59
+
60
+ function doubleClick(e: Event) {
61
+ try {
62
+ options.onDblClick && options.onDblClick(e as MouseEvent);
63
+ } finally {
64
+ tear();
65
+ }
66
+ }
67
+
68
+ e.stopPropagation();
69
+
70
+ function move(e: Event) {
71
+ if (!active) {
72
+ tear();
73
+ return;
74
+ }
75
+
76
+ //if mouse moves double clicking is off
77
+ options.onDblClick = undefined;
78
+
79
+ batchUpdates(() => {
80
+ if (options.onMouseMove) options.onMouseMove(e as MouseEvent, options.captureData);
81
+ e.stopPropagation();
82
+ e.preventDefault(); //disable text selection
83
+ });
84
+ }
85
+
86
+ function end(e: Event) {
87
+ active = false;
88
+ batchUpdates(() => {
89
+ // if (surface.releaseCapture)
90
+ // surface.releaseCapture();
91
+
92
+ if (!options.onDblClick) surface.style.display = "none";
93
+ try {
94
+ if (options.onMouseUp) options.onMouseUp(e as MouseEvent, options.captureData);
95
+ } finally {
96
+ if (options.onDblClick) {
97
+ //keep the surface a little longer to detect double clicks
98
+ setTimeout(tear, 1500);
99
+ } else tear();
100
+ }
101
+ });
102
+ }
103
+ }
104
+
105
+ /**
106
+ * Captures mouse or touch events, automatically detecting the event type
107
+ * @param e - The initial mouse or touch event that triggered the capture
108
+ * @param options - Configuration options for the capture behavior
109
+ */
110
+ export function captureMouseOrTouch2(
111
+ e: React.MouseEvent | React.TouchEvent | MouseEvent | TouchEvent,
112
+ options: CaptureMouseOptions,
113
+ ): void {
114
+ if (e.type.indexOf("touch") == 0) {
115
+ let el = e.currentTarget as HTMLElement;
116
+
117
+ let move = (e: TouchEvent) => {
118
+ batchUpdates(() => {
119
+ if (options.onMouseMove) options.onMouseMove(e as any, options.captureData);
120
+ e.preventDefault();
121
+ });
122
+ };
123
+
124
+ let end = (e: TouchEvent) => {
125
+ batchUpdates(() => {
126
+ el.removeEventListener("touchmove", move);
127
+ el.removeEventListener("touchend", end);
128
+
129
+ if (options.onMouseUp) options.onMouseUp(e as any);
130
+
131
+ e.preventDefault();
132
+ });
133
+ };
134
+
135
+ el.addEventListener("touchmove", move);
136
+ el.addEventListener("touchend", end);
137
+
138
+ e.stopPropagation();
139
+ } else captureMouse2(e, options);
140
+ }
141
+
142
+ /**
143
+ * Legacy function for capturing mouse events with individual parameters
144
+ * @param e - The initial mouse event that triggered the capture
145
+ * @param onMouseMove - Callback function called on mouse move events
146
+ * @param onMouseUp - Callback function called on mouse up events
147
+ * @param captureData - Additional data passed to callbacks
148
+ * @param cursor - CSS cursor style for the capture surface
149
+ */
150
+ export function captureMouse(
151
+ e: React.MouseEvent,
152
+ onMouseMove?: (e: MouseEvent | TouchEvent, captureData?: any) => void,
153
+ onMouseUp?: (e: MouseEvent | TouchEvent, captureData?: any) => void,
154
+ captureData?: any,
155
+ cursor?: string,
156
+ ): void {
157
+ captureMouse2(e, {
158
+ onMouseMove,
159
+ onMouseUp,
160
+ captureData,
161
+ cursor,
162
+ });
163
+ }
164
+
165
+ /**
166
+ * Legacy function for capturing mouse or touch events with individual parameters
167
+ * @param e - The initial mouse or touch event that triggered the capture
168
+ * @param onMouseMove - Callback function called on mouse/touch move events
169
+ * @param onMouseUp - Callback function called on mouse/touch up events
170
+ * @param captureData - Additional data passed to callbacks
171
+ * @param cursor - CSS cursor style for the capture surface
172
+ */
173
+ export function captureMouseOrTouch(
174
+ e: React.MouseEvent | React.TouchEvent | MouseEvent | TouchEvent,
175
+ onMouseMove?: (e: MouseEvent, captureData?: any) => void,
176
+ onMouseUp?: (e: MouseEvent, captureData?: any) => void,
177
+ captureData?: any,
178
+ cursor?: string,
179
+ ): void {
180
+ captureMouseOrTouch2(e, { onMouseMove, onMouseUp, captureData, cursor });
181
+ }
182
+
183
+ /**
184
+ * Gets the cursor position relative to the parent frame
185
+ * @param e - Mouse or touch event (React or native)
186
+ * @returns Object with clientX and clientY coordinates adjusted for parent frame offset
187
+ */
188
+ export function getCursorPos(e: React.MouseEvent | React.TouchEvent | MouseEvent | TouchEvent): CursorPosition {
189
+ let p = (e as TouchEvent).touches?.[0] || (e as MouseEvent);
190
+ let offset = getParentFrameBoundingClientRect(e.target as Element);
191
+ return {
192
+ clientX: p.clientX + offset.left,
193
+ clientY: p.clientY + offset.top,
194
+ };
195
+ }
@@ -1,72 +1,72 @@
1
- import { Store } from "../../data/Store";
2
- import { HotModule } from "../../ui/app/startHotAppLoop";
3
- import { SubscriberList } from "../../util/SubscriberList";
4
- import { Window } from "./Window";
5
- import { View } from "../../data/View";
6
- import { Instance } from "../../ui/Instance";
7
- import { Overlay } from "./Overlay";
8
-
9
- export interface HotPromiseWindowFactoryOptions {
10
- parent?: Instance;
11
- store?: View;
12
- }
13
-
14
- export function createHotPromiseWindowFactoryWithProps<Props, R = any>(
15
- module: HotModule,
16
- factory: (props: Props) => (resolve: (value: R | PromiseLike<R>) => void, reject: (reason?: any) => void) => Overlay,
17
- ): (props: Props, options?: HotPromiseWindowFactoryOptions) => Promise<R> {
18
- let subscriberList: SubscriberList | undefined;
19
- if (module.hot) {
20
- if (module.hot.data?.subscriberList) subscriberList = module.hot.data.subscriberList;
21
- if (!subscriberList) subscriberList = new SubscriberList();
22
-
23
- module.hot.dispose((data: any) => {
24
- data.subscriberList = subscriberList;
25
- });
26
-
27
- module.hot.accept();
28
-
29
- if (!subscriberList.isEmpty()) subscriberList.notify(factory);
30
-
31
- subscriberList.subscribe((updatedFactory) => {
32
- factory = updatedFactory;
33
- });
34
- }
35
-
36
- return (props: Props, options?: HotPromiseWindowFactoryOptions): Promise<R> => {
37
- let store = options?.parent ?? options?.store ?? new Store();
38
- let reloading = false;
39
- return new Promise<R>((resolve, reject) => {
40
- let dismiss: (() => void) | undefined;
41
- let unsubscribe: (() => void) | undefined;
42
- function rerun() {
43
- dismiss?.();
44
- let window = Window.create(factory(props)(resolve, reject) as any) as any;
45
- window.overlayWillDismiss = () => {
46
- if (!reloading && unsubscribe) unsubscribe();
47
- return false;
48
- };
49
- dismiss = window.open(store);
50
- }
51
- unsubscribe = subscriberList?.subscribe((updatedFactory: any) => {
52
- factory = updatedFactory;
53
- setTimeout(() => {
54
- // timeout is required for proper module initialization
55
- // sometimes elements are defined in the lower part of the module and if the function is run immediately, it will fail
56
- reloading = true;
57
- rerun();
58
- reloading = false;
59
- }, 10);
60
- });
61
- rerun();
62
- });
63
- };
64
- }
65
-
66
- export function createHotPromiseWindowFactory<R = any>(
67
- module: HotModule,
68
- factory: (resolve: (value: R | PromiseLike<R>) => void, reject: (reason?: any) => void) => Overlay,
69
- ): (options?: HotPromiseWindowFactoryOptions) => Promise<R> {
70
- let result = createHotPromiseWindowFactoryWithProps(module, () => factory);
71
- return (options?: HotPromiseWindowFactoryOptions) => result(null, options);
72
- }
1
+ import { Store } from "../../data/Store";
2
+ import { HotModule } from "../../ui/app/startHotAppLoop";
3
+ import { SubscriberList } from "../../util/SubscriberList";
4
+ import { Window } from "./Window";
5
+ import { View } from "../../data/View";
6
+ import { Instance } from "../../ui/Instance";
7
+ import { Overlay } from "./Overlay";
8
+
9
+ export interface HotPromiseWindowFactoryOptions {
10
+ parent?: Instance;
11
+ store?: View;
12
+ }
13
+
14
+ export function createHotPromiseWindowFactoryWithProps<Props, R = any>(
15
+ module: HotModule,
16
+ factory: (props: Props) => (resolve: (value: R | PromiseLike<R>) => void, reject: (reason?: any) => void) => Overlay,
17
+ ): (props: Props, options?: HotPromiseWindowFactoryOptions) => Promise<R> {
18
+ let subscriberList: SubscriberList | undefined;
19
+ if (module.hot) {
20
+ if (module.hot.data?.subscriberList) subscriberList = module.hot.data.subscriberList;
21
+ if (!subscriberList) subscriberList = new SubscriberList();
22
+
23
+ module.hot.dispose((data: any) => {
24
+ data.subscriberList = subscriberList;
25
+ });
26
+
27
+ module.hot.accept();
28
+
29
+ if (!subscriberList.isEmpty()) subscriberList.notify(factory);
30
+
31
+ subscriberList.subscribe((updatedFactory) => {
32
+ factory = updatedFactory;
33
+ });
34
+ }
35
+
36
+ return (props: Props, options?: HotPromiseWindowFactoryOptions): Promise<R> => {
37
+ let store = options?.parent ?? options?.store ?? new Store();
38
+ let reloading = false;
39
+ return new Promise<R>((resolve, reject) => {
40
+ let dismiss: (() => void) | undefined;
41
+ let unsubscribe: (() => void) | undefined;
42
+ function rerun() {
43
+ dismiss?.();
44
+ let window = Window.create(factory(props)(resolve, reject) as any) as any;
45
+ window.overlayWillDismiss = () => {
46
+ if (!reloading && unsubscribe) unsubscribe();
47
+ return false;
48
+ };
49
+ dismiss = window.open(store);
50
+ }
51
+ unsubscribe = subscriberList?.subscribe((updatedFactory: any) => {
52
+ factory = updatedFactory;
53
+ setTimeout(() => {
54
+ // timeout is required for proper module initialization
55
+ // sometimes elements are defined in the lower part of the module and if the function is run immediately, it will fail
56
+ reloading = true;
57
+ rerun();
58
+ reloading = false;
59
+ }, 10);
60
+ });
61
+ rerun();
62
+ });
63
+ };
64
+ }
65
+
66
+ export function createHotPromiseWindowFactory<R = any>(
67
+ module: HotModule,
68
+ factory: (resolve: (value: R | PromiseLike<R>) => void, reject: (reason?: any) => void) => Overlay,
69
+ ): (options?: HotPromiseWindowFactoryOptions) => Promise<R> {
70
+ let result = createHotPromiseWindowFactoryWithProps(module, () => factory);
71
+ return (options?: HotPromiseWindowFactoryOptions) => result(null, options);
72
+ }
@@ -1,11 +1,11 @@
1
- export * from "./Overlay";
2
- export * from "./Dropdown";
3
- export * from "./tooltip-ops";
4
- export * from "./Tooltip";
5
- export * from "./Window";
6
- export * from "./MsgBox";
7
- export * from "./Toast";
8
- export * from "./captureMouse";
9
- export * from "./ContextMenu";
10
- export * from "./FlyweightTooltipTracker";
11
- export * from "./createHotPromiseWindowFactory";
1
+ export * from "./Overlay";
2
+ export * from "./Dropdown";
3
+ export * from "./tooltip-ops";
4
+ export * from "./Tooltip";
5
+ export * from "./Window";
6
+ export * from "./MsgBox";
7
+ export * from "./Toast";
8
+ export * from "./captureMouse";
9
+ export * from "./ContextMenu";
10
+ export * from "./FlyweightTooltipTracker";
11
+ export * from "./createHotPromiseWindowFactory";