xmlui 0.7.13 → 0.7.15

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 (392) hide show
  1. package/dist/{apiInterceptorWorker-BuZoKCP8.mjs → apiInterceptorWorker-yKpXImCG.mjs} +1 -1
  2. package/dist/{index-C8kHu1Bs.mjs → index-XNGGyvQ0.mjs} +9904 -9653
  3. package/dist/index.css +1 -1
  4. package/dist/scripts/bin/build.js +17 -7
  5. package/dist/scripts/bin/vite-ueml-plugin.js +17 -7
  6. package/dist/scripts/bin/viteConfig.js +17 -7
  7. package/dist/scripts/package.json +209 -0
  8. package/dist/scripts/src/abstractions/scripting/ScriptingSourceTreeExp.js +51 -0
  9. package/dist/scripts/src/components/APICall/APICall.js +74 -0
  10. package/dist/scripts/src/components/APICall/APICallNative.js +31 -0
  11. package/dist/scripts/src/components/Accordion/Accordion.js +78 -0
  12. package/dist/scripts/src/components/Accordion/AccordionContext.js +20 -0
  13. package/dist/scripts/src/components/Accordion/AccordionItem.js +28 -0
  14. package/dist/scripts/src/components/Accordion/AccordionItemNative.js +79 -0
  15. package/dist/scripts/src/components/Accordion/AccordionNative.js +122 -0
  16. package/dist/scripts/src/components/Alert/Alert.js +42 -0
  17. package/dist/scripts/src/components/Alert/AlertNative.js +8 -0
  18. package/dist/scripts/src/components/Animation/Animation.js +59 -0
  19. package/dist/scripts/src/components/Animation/AnimationNative.js +75 -0
  20. package/dist/scripts/src/components/App/App.js +76 -0
  21. package/dist/scripts/src/components/App/AppLayoutContext.js +49 -0
  22. package/dist/scripts/src/components/App/AppNative.js +204 -0
  23. package/dist/scripts/src/components/App/AppStateContext.js +9 -0
  24. package/dist/scripts/src/components/App/Sheet.js +99 -0
  25. package/dist/scripts/src/components/AppHeader/AppHeader.js +59 -0
  26. package/dist/scripts/src/components/AppHeader/AppHeaderNative.js +58 -0
  27. package/dist/scripts/src/components/AppState/AppState.js +26 -0
  28. package/dist/scripts/src/components/AppState/AppStateNative.js +24 -0
  29. package/dist/scripts/src/components/AutoComplete/AutoComplete.js +83 -0
  30. package/dist/scripts/src/components/AutoComplete/AutoCompleteContext.js +16 -0
  31. package/dist/scripts/src/components/AutoComplete/AutoCompleteNative.js +225 -0
  32. package/dist/scripts/src/components/Avatar/Avatar.js +47 -0
  33. package/dist/scripts/src/components/Avatar/AvatarNative.js +40 -0
  34. package/dist/scripts/src/components/Backdrop/Backdrop.js +31 -0
  35. package/dist/scripts/src/components/Backdrop/BackdropNative.js +14 -0
  36. package/dist/scripts/src/components/Badge/Badge.js +58 -0
  37. package/dist/scripts/src/components/Badge/BadgeNative.js +22 -0
  38. package/dist/scripts/src/components/BarChart/BarChart.js +49 -0
  39. package/dist/scripts/src/components/BarChart/BarChartNative.js +176 -0
  40. package/dist/scripts/src/components/Bookmark/Bookmark.js +23 -0
  41. package/dist/scripts/src/components/Bookmark/BookmarkNative.js +24 -0
  42. package/dist/scripts/src/components/Breakout/Breakout.js +16 -0
  43. package/dist/scripts/src/components/Breakout/BreakoutNative.js +12 -0
  44. package/dist/scripts/src/components/Button/Button.js +142 -0
  45. package/dist/scripts/src/components/Button/ButtonNative.js +88 -0
  46. package/dist/scripts/src/components/ButtonGroup/ButtonGroup.js +41 -0
  47. package/dist/scripts/src/components/ButtonGroup/ButtonGroupNative.js +8 -0
  48. package/dist/scripts/src/components/Card/Card.js +57 -0
  49. package/dist/scripts/src/components/Card/CardNative.js +26 -0
  50. package/dist/scripts/src/components/Carousel/Carousel.js +68 -0
  51. package/dist/scripts/src/components/Carousel/CarouselItem.js +16 -0
  52. package/dist/scripts/src/components/Carousel/CarouselItemNative.js +13 -0
  53. package/dist/scripts/src/components/Carousel/CarouselNative.js +163 -0
  54. package/dist/scripts/src/components/ChangeListener/ChangeListener.js +24 -0
  55. package/dist/scripts/src/components/ChangeListener/ChangeListenerNative.js +26 -0
  56. package/dist/scripts/src/components/Chart/Chart.js +24 -0
  57. package/dist/scripts/src/components/Chart/ChartNative.js +165 -0
  58. package/dist/scripts/src/components/Checkbox/Checkbox.js +68 -0
  59. package/dist/scripts/src/components/Column/Column.js +34 -0
  60. package/dist/scripts/src/components/Column/ColumnNative.js +38 -0
  61. package/dist/scripts/src/components/Column/TableContext.js +12 -0
  62. package/dist/scripts/src/components/ComponentProvider.js +503 -0
  63. package/dist/scripts/src/components/ComponentRegistryContext.js +44 -0
  64. package/dist/scripts/src/components/ContentSeparator/ContentSeparator.js +38 -0
  65. package/dist/scripts/src/components/ContentSeparator/ContentSeparatorNative.js +16 -0
  66. package/dist/scripts/src/components/DatePicker/DatePicker.js +62 -0
  67. package/dist/scripts/src/components/DatePicker/DatePickerNative.js +196 -0
  68. package/dist/scripts/src/components/DropdownMenu/DropdownMenu.js +125 -0
  69. package/dist/scripts/src/components/DropdownMenu/DropdownMenuNative.js +95 -0
  70. package/dist/scripts/src/components/EmojiSelector/EmojiSelector.js +26 -0
  71. package/dist/scripts/src/components/EmojiSelector/EmojiSelectorNative.js +52 -0
  72. package/dist/scripts/src/components/FileInput/FileInput.js +64 -0
  73. package/dist/scripts/src/components/FileInput/FileInputNative.js +128 -0
  74. package/dist/scripts/src/components/FileUploadDropZone/FileUploadDropZone.js +46 -0
  75. package/dist/scripts/src/components/FileUploadDropZone/FileUploadDropZoneNative.js +112 -0
  76. package/dist/scripts/src/components/FlowLayout/FlowLayout.js +53 -0
  77. package/dist/scripts/src/components/FlowLayout/FlowLayoutNative.js +108 -0
  78. package/dist/scripts/src/components/Footer/Footer.js +35 -0
  79. package/dist/scripts/src/components/Footer/FooterNative.js +20 -0
  80. package/dist/scripts/src/components/Form/Form.js +89 -0
  81. package/dist/scripts/src/components/Form/FormContext.js +9 -0
  82. package/dist/scripts/src/components/Form/FormNative.js +317 -0
  83. package/dist/scripts/src/components/Form/formActions.js +114 -0
  84. package/dist/scripts/src/components/FormItem/FormItem.js +125 -0
  85. package/dist/scripts/src/components/FormItem/FormItemNative.js +157 -0
  86. package/dist/scripts/src/components/FormItem/HelperText.js +27 -0
  87. package/dist/scripts/src/components/FormItem/ItemWithLabel.js +40 -0
  88. package/dist/scripts/src/components/FormItem/Validations.js +351 -0
  89. package/dist/scripts/src/components/FormSection/FormSection.js +41 -0
  90. package/dist/scripts/src/components/Heading/Heading.js +258 -0
  91. package/dist/scripts/src/components/Heading/HeadingNative.js +45 -0
  92. package/dist/scripts/src/components/HoverCard/HoverCard.js +19 -0
  93. package/dist/scripts/src/components/HoverCard/HovercardNative.js +44 -0
  94. package/dist/scripts/src/components/Icon/ApiIcon.js +10 -0
  95. package/dist/scripts/src/components/Icon/Attach.js +10 -0
  96. package/dist/scripts/src/components/Icon/Binding.js +11 -0
  97. package/dist/scripts/src/components/Icon/BoardIcon.js +7 -0
  98. package/dist/scripts/src/components/Icon/BoxIcon.js +10 -0
  99. package/dist/scripts/src/components/Icon/CheckIcon.js +7 -0
  100. package/dist/scripts/src/components/Icon/ChevronLeft.js +7 -0
  101. package/dist/scripts/src/components/Icon/ChevronRight.js +7 -0
  102. package/dist/scripts/src/components/Icon/CodeFileIcon.js +10 -0
  103. package/dist/scripts/src/components/Icon/CodeSandbox.js +10 -0
  104. package/dist/scripts/src/components/Icon/CompactListIcon.js +7 -0
  105. package/dist/scripts/src/components/Icon/ContentCopyIcon.js +7 -0
  106. package/dist/scripts/src/components/Icon/DatabaseIcon.js +11 -0
  107. package/dist/scripts/src/components/Icon/DocFileIcon.js +10 -0
  108. package/dist/scripts/src/components/Icon/DocIcon.js +10 -0
  109. package/dist/scripts/src/components/Icon/DotMenuHorizontalIcon.js +7 -0
  110. package/dist/scripts/src/components/Icon/DotMenuIcon.js +7 -0
  111. package/dist/scripts/src/components/Icon/EmailIcon.js +7 -0
  112. package/dist/scripts/src/components/Icon/EmptyFolderIcon.js +10 -0
  113. package/dist/scripts/src/components/Icon/ErrorIcon.js +7 -0
  114. package/dist/scripts/src/components/Icon/ExpressionIcon.js +10 -0
  115. package/dist/scripts/src/components/Icon/FillPlusCricleIcon.js +7 -0
  116. package/dist/scripts/src/components/Icon/FilterIcon.js +10 -0
  117. package/dist/scripts/src/components/Icon/FolderIcon.js +10 -0
  118. package/dist/scripts/src/components/Icon/GlobeIcon.js +7 -0
  119. package/dist/scripts/src/components/Icon/HomeIcon.js +7 -0
  120. package/dist/scripts/src/components/Icon/HyperLinkIcon.js +7 -0
  121. package/dist/scripts/src/components/Icon/Icon.js +32 -0
  122. package/dist/scripts/src/components/Icon/IconNative.js +102 -0
  123. package/dist/scripts/src/components/Icon/ImageFileIcon.js +10 -0
  124. package/dist/scripts/src/components/Icon/LinkIcon.js +7 -0
  125. package/dist/scripts/src/components/Icon/ListIcon.js +7 -0
  126. package/dist/scripts/src/components/Icon/LooseListIcon.js +7 -0
  127. package/dist/scripts/src/components/Icon/MoonIcon.js +10 -0
  128. package/dist/scripts/src/components/Icon/MoreOptionsIcon.js +7 -0
  129. package/dist/scripts/src/components/Icon/NoSortIcon.js +8 -0
  130. package/dist/scripts/src/components/Icon/PDFIcon.js +10 -0
  131. package/dist/scripts/src/components/Icon/PenIcon.js +7 -0
  132. package/dist/scripts/src/components/Icon/PhoneIcon.js +7 -0
  133. package/dist/scripts/src/components/Icon/PhotoIcon.js +10 -0
  134. package/dist/scripts/src/components/Icon/PlusIcon.js +7 -0
  135. package/dist/scripts/src/components/Icon/SearchIcon.js +7 -0
  136. package/dist/scripts/src/components/Icon/ShareIcon.js +10 -0
  137. package/dist/scripts/src/components/Icon/SortAscendingIcon.js +8 -0
  138. package/dist/scripts/src/components/Icon/SortDescendingIcon.js +8 -0
  139. package/dist/scripts/src/components/Icon/SunIcon.js +10 -0
  140. package/dist/scripts/src/components/Icon/TrashIcon.js +7 -0
  141. package/dist/scripts/src/components/Icon/TrendingDownIcon.js +10 -0
  142. package/dist/scripts/src/components/Icon/TrendingLevelIcon.js +10 -0
  143. package/dist/scripts/src/components/Icon/TrendingUpIcon.js +10 -0
  144. package/dist/scripts/src/components/Icon/TxtIcon.js +10 -0
  145. package/dist/scripts/src/components/Icon/UnknownFileIcon.js +10 -0
  146. package/dist/scripts/src/components/Icon/UnlinkIcon.js +10 -0
  147. package/dist/scripts/src/components/Icon/UserIcon.js +7 -0
  148. package/dist/scripts/src/components/Icon/WarningIcon.js +7 -0
  149. package/dist/scripts/src/components/Icon/XlsIcon.js +10 -0
  150. package/dist/scripts/src/components/IconInfoCard/IconInfoCard.js +39 -0
  151. package/dist/scripts/src/components/IconProvider.js +264 -0
  152. package/dist/scripts/src/components/IconRegistryContext.js +317 -0
  153. package/dist/scripts/src/components/Image/Image.js +35 -0
  154. package/dist/scripts/src/components/Image/ImageNative.js +15 -0
  155. package/dist/scripts/src/components/Input/InputAdornment.js +14 -0
  156. package/dist/scripts/src/components/Items/Items.js +33 -0
  157. package/dist/scripts/src/components/Items/ItemsNative.js +29 -0
  158. package/dist/scripts/src/components/Link/Link.js +64 -0
  159. package/dist/scripts/src/components/Link/LinkNative.js +26 -0
  160. package/dist/scripts/src/components/List/List.js +81 -0
  161. package/dist/scripts/src/components/List/ListNative.js +425 -0
  162. package/dist/scripts/src/components/Logo/Logo.js +16 -0
  163. package/dist/scripts/src/components/Logo/LogoNative.js +15 -0
  164. package/dist/scripts/src/components/Map/Map.js +75 -0
  165. package/dist/scripts/src/components/Map/world_countries.json +45307 -0
  166. package/dist/scripts/src/components/Markdown/Markdown.js +45 -0
  167. package/dist/scripts/src/components/Markdown/MarkdownNative.js +107 -0
  168. package/dist/scripts/src/components/ModalDialog/ConfirmationModalContextProvider.js +116 -0
  169. package/dist/scripts/src/components/ModalDialog/Dialog.js +20 -0
  170. package/dist/scripts/src/components/ModalDialog/ModalDialog.js +64 -0
  171. package/dist/scripts/src/components/ModalDialog/ModalDialogNative.js +167 -0
  172. package/dist/scripts/src/components/ModalDialog/ModalVisibilityContext.js +60 -0
  173. package/dist/scripts/src/components/NavGroup/NavGroup.js +34 -0
  174. package/dist/scripts/src/components/NavGroup/NavGroupNative.js +91 -0
  175. package/dist/scripts/src/components/NavLink/NavLink.js +71 -0
  176. package/dist/scripts/src/components/NavLink/NavLinkNative.js +61 -0
  177. package/dist/scripts/src/components/NavPanel/NavPanel.js +31 -0
  178. package/dist/scripts/src/components/NavPanel/NavPanelNative.js +74 -0
  179. package/dist/scripts/src/components/NoResult/NoResult.js +38 -0
  180. package/dist/scripts/src/components/NoResult/NoResultNative.js +13 -0
  181. package/dist/scripts/src/components/NumberBox/NumberBox.js +61 -0
  182. package/dist/scripts/src/components/NumberBox/NumberBoxNative.js +337 -0
  183. package/dist/scripts/src/components/NumberBox/numberbox-abstractions.js +74 -0
  184. package/dist/scripts/src/components/OffCanvas/OffCanvas.js +57 -0
  185. package/dist/scripts/src/components/OffCanvas/OffCanvasNative.js +48 -0
  186. package/dist/scripts/src/components/Option/Option.js +33 -0
  187. package/dist/scripts/src/components/Option/OptionTypeProvider.js +16 -0
  188. package/dist/scripts/src/components/PageHeader/PageHeader.js +36 -0
  189. package/dist/scripts/src/components/PageMetaTitle/PageMetaTilteNative.js +9 -0
  190. package/dist/scripts/src/components/PageMetaTitle/PageMetaTitle.js +18 -0
  191. package/dist/scripts/src/components/Pages/Pages.js +33 -0
  192. package/dist/scripts/src/components/Pages/PagesNative.js +69 -0
  193. package/dist/scripts/src/components/PieChart/PieChart.js +45 -0
  194. package/dist/scripts/src/components/PieChart/PieChartNative.js +165 -0
  195. package/dist/scripts/src/components/PositionedContainer/PositionedContainer.js +24 -0
  196. package/dist/scripts/src/components/PositionedContainer/PositionedContainerNative.js +14 -0
  197. package/dist/scripts/src/components/ProgressBar/ProgressBar.js +36 -0
  198. package/dist/scripts/src/components/ProgressBar/ProgressBarNative.js +12 -0
  199. package/dist/scripts/src/components/Queue/Queue.js +71 -0
  200. package/dist/scripts/src/components/Queue/QueueNative.js +278 -0
  201. package/dist/scripts/src/components/Queue/queueActions.js +87 -0
  202. package/dist/scripts/src/components/RadioGroup/RadioGroup.js +68 -0
  203. package/dist/scripts/src/components/RadioGroup/RadioGroupNative.js +104 -0
  204. package/dist/scripts/src/components/Range/Range.js +56 -0
  205. package/dist/scripts/src/components/Range/RangeNative.js +8 -0
  206. package/dist/scripts/src/components/RealTimeAdapter/RealTimeAdapter.js +21 -0
  207. package/dist/scripts/src/components/RealTimeAdapter/RealTimeAdapterNative.js +131 -0
  208. package/dist/scripts/src/components/Redirect/Redirect.js +20 -0
  209. package/dist/scripts/src/components/Select/OptionContext.js +12 -0
  210. package/dist/scripts/src/components/Select/Select.js +98 -0
  211. package/dist/scripts/src/components/Select/SelectContext.js +9 -0
  212. package/dist/scripts/src/components/Select/SelectNative.js +214 -0
  213. package/dist/scripts/src/components/SelectionStore/SelectionStore.js +22 -0
  214. package/dist/scripts/src/components/SelectionStore/SelectionStoreNative.js +94 -0
  215. package/dist/scripts/src/components/Slider/Slider.js +54 -0
  216. package/dist/scripts/src/components/Slider/SliderNative.js +8 -0
  217. package/dist/scripts/src/components/SpaceFiller/SpaceFiller.js +19 -0
  218. package/dist/scripts/src/components/SpaceFiller/SpaceFillerNative.js +10 -0
  219. package/dist/scripts/src/components/Spinner/Spinner.js +42 -0
  220. package/dist/scripts/src/components/Spinner/SpinnerNative.js +31 -0
  221. package/dist/scripts/src/components/Splitter/Splitter.js +89 -0
  222. package/dist/scripts/src/components/Splitter/SplitterNative.js +159 -0
  223. package/dist/scripts/src/components/Splitter/utils.js +17 -0
  224. package/dist/scripts/src/components/Stack/Stack.js +110 -0
  225. package/dist/scripts/src/components/Stack/StackNative.js +39 -0
  226. package/dist/scripts/src/components/StateViewer/StateViewerNative.js +19 -0
  227. package/dist/scripts/src/components/StickyBox/StickyBox.js +30 -0
  228. package/dist/scripts/src/components/StickyBox/StickyBoxNative.js +15 -0
  229. package/dist/scripts/src/components/Switch/Switch.js +72 -0
  230. package/dist/scripts/src/components/Table/Table.js +184 -0
  231. package/dist/scripts/src/components/Table/TableNative.js +470 -0
  232. package/dist/scripts/src/components/Table/useRowSelection.js +245 -0
  233. package/dist/scripts/src/components/TableHeader/TableHeader.js +34 -0
  234. package/dist/scripts/src/components/TableOfContents/TableOfContents.js +74 -0
  235. package/dist/scripts/src/components/TableOfContents/TableOfContentsNative.js +55 -0
  236. package/dist/scripts/src/components/Tabs/TabContext.js +45 -0
  237. package/dist/scripts/src/components/Tabs/TabItem.js +20 -0
  238. package/dist/scripts/src/components/Tabs/TabItemNative.js +24 -0
  239. package/dist/scripts/src/components/Tabs/Tabs.js +55 -0
  240. package/dist/scripts/src/components/Tabs/TabsNative.js +72 -0
  241. package/dist/scripts/src/components/Text/Text.js +122 -0
  242. package/dist/scripts/src/components/Text/TextNative.js +124 -0
  243. package/dist/scripts/src/components/TextArea/TextArea.js +65 -0
  244. package/dist/scripts/src/components/TextArea/TextAreaNative.js +176 -0
  245. package/dist/scripts/src/components/TextArea/TextAreaResizable.js +73 -0
  246. package/dist/scripts/src/components/TextArea/useComposedRef.js +60 -0
  247. package/dist/scripts/src/components/TextBox/TextBox.js +85 -0
  248. package/dist/scripts/src/components/TextBox/TextBoxNative.js +109 -0
  249. package/dist/scripts/src/components/Theme/NotificationToast.js +50 -0
  250. package/dist/scripts/src/components/Theme/Theme.js +43 -0
  251. package/dist/scripts/src/components/Theme/ThemeNative.js +126 -0
  252. package/dist/scripts/src/components/ThemeChanger/ThemeChanger.js +115 -0
  253. package/dist/scripts/src/components/ThemeChanger/ToneChangerButton.js +28 -0
  254. package/dist/scripts/src/components/Toggle/Toggle.js +99 -0
  255. package/dist/scripts/src/components/Toolbar/Toolbar.js +32 -0
  256. package/dist/scripts/src/components/ToolbarButton/ToolbarButton.js +38 -0
  257. package/dist/scripts/src/components/Tree/TreeComponent.js +32 -0
  258. package/dist/scripts/src/components/Tree/TreeNative.js +69 -0
  259. package/dist/scripts/src/components/TrendLabel/TrendLabel.js +37 -0
  260. package/dist/scripts/src/components/ValidationSummary/ValidationSummary.js +59 -0
  261. package/dist/scripts/src/components/abstractions.js +151 -0
  262. package/dist/scripts/src/components/chart-color-schemes.js +43 -0
  263. package/dist/scripts/src/components/component-utils.js +17 -0
  264. package/dist/scripts/src/components/container-helpers.js +25 -0
  265. package/dist/scripts/src/components/metadata-helpers.js +245 -0
  266. package/dist/scripts/src/components/slot-helpers.js +22 -0
  267. package/dist/scripts/src/components-core/ApiBoundComponent.js +194 -0
  268. package/dist/scripts/src/components-core/AppContext.js +16 -0
  269. package/dist/scripts/src/components-core/AppRoot.js +424 -0
  270. package/dist/scripts/src/components-core/ComponentBed.js +325 -0
  271. package/dist/scripts/src/components-core/ComponentDecorator.js +90 -0
  272. package/dist/scripts/src/components-core/CompoundComponent.js +144 -0
  273. package/dist/scripts/src/components-core/DebugViewProvider.js +43 -0
  274. package/dist/scripts/src/components-core/EngineError.js +91 -0
  275. package/dist/scripts/src/components-core/ErrorBoundary.js +59 -0
  276. package/dist/scripts/src/components-core/Fragment.js +15 -0
  277. package/dist/scripts/src/components-core/InspectorContext.js +176 -0
  278. package/dist/scripts/src/components-core/InvalidComponent.js +17 -0
  279. package/dist/scripts/src/components-core/LoaderComponent.js +92 -0
  280. package/dist/scripts/src/components-core/RestApiProxy.js +354 -0
  281. package/dist/scripts/src/components-core/ScrollContext.js +11 -0
  282. package/dist/scripts/src/components-core/Slot.js +17 -0
  283. package/dist/scripts/src/components-core/StandaloneApp.js +589 -0
  284. package/dist/scripts/src/components-core/StandaloneComponentManager.js +51 -0
  285. package/dist/scripts/src/components-core/TableOfContentsContext.js +110 -0
  286. package/dist/scripts/src/components-core/UnknownComponent.js +15 -0
  287. package/dist/scripts/src/components-core/XmluiCodeHighlighter.js +110 -0
  288. package/dist/scripts/src/components-core/abstractions/ComponentRenderer.js +2 -0
  289. package/dist/scripts/src/components-core/abstractions/LoaderRenderer.js +2 -0
  290. package/dist/scripts/src/components-core/abstractions/containers.js +18 -0
  291. package/dist/scripts/src/components-core/abstractions/standalone.js +2 -0
  292. package/dist/scripts/src/components-core/abstractions/treeAbstractions.js +2 -0
  293. package/dist/scripts/src/components-core/action/APICall.js +283 -0
  294. package/dist/scripts/src/components-core/action/FileDownloadAction.js +80 -0
  295. package/dist/scripts/src/components-core/action/FileUploadAction.js +88 -0
  296. package/dist/scripts/src/components-core/action/NavigateAction.js +20 -0
  297. package/dist/scripts/src/components-core/action/TimedAction.js +21 -0
  298. package/dist/scripts/src/components-core/action/actions.js +15 -0
  299. package/dist/scripts/src/components-core/appContext/date-functions.js +19 -0
  300. package/dist/scripts/src/components-core/appContext/math-function.js +27 -0
  301. package/dist/scripts/src/components-core/appContext/misc-utils.js +12 -0
  302. package/dist/scripts/src/components-core/component-hooks.js +25 -0
  303. package/dist/scripts/src/components-core/constants.js +18 -0
  304. package/dist/scripts/src/components-core/container/Container.js +1241 -0
  305. package/dist/scripts/src/components-core/container/buildProxy.js +54 -0
  306. package/dist/scripts/src/components-core/container/collectFnVarDeps.js +49 -0
  307. package/dist/scripts/src/components-core/container/valueExtractor.js +205 -0
  308. package/dist/scripts/src/components-core/descriptorHelper.js +72 -0
  309. package/dist/scripts/src/components-core/interception/ApiInterceptor.js +198 -0
  310. package/dist/scripts/src/components-core/interception/ApiInterceptorProvider.js +94 -0
  311. package/dist/scripts/src/components-core/interception/Backend.js +129 -0
  312. package/dist/scripts/src/components-core/interception/Errors.js +129 -0
  313. package/dist/scripts/src/components-core/interception/InMemoryDb.js +41 -0
  314. package/dist/scripts/src/components-core/interception/IndexedDb.js +205 -0
  315. package/dist/scripts/src/components-core/interception/ReadonlyCollection.js +145 -0
  316. package/dist/scripts/src/components-core/interception/abstractions.js +2 -0
  317. package/dist/scripts/src/components-core/interception/apiInterceptorWorker.js +46 -0
  318. package/dist/scripts/src/components-core/interception/useApiInterceptorContext.js +9 -0
  319. package/dist/scripts/src/components-core/loader/ApiLoader.js +54 -0
  320. package/dist/scripts/src/components-core/loader/DataLoader.js +149 -0
  321. package/dist/scripts/src/components-core/loader/ExternalDataLoader.js +62 -0
  322. package/dist/scripts/src/components-core/loader/Loader.js +126 -0
  323. package/dist/scripts/src/components-core/loader/MockLoaderRenderer.js +40 -0
  324. package/dist/scripts/src/components-core/loader/PageableLoader.js +262 -0
  325. package/dist/scripts/src/components-core/markup-check.js +279 -0
  326. package/dist/scripts/src/components-core/renderers.js +45 -0
  327. package/dist/scripts/src/components-core/reportEngineError.js +62 -0
  328. package/dist/scripts/src/components-core/script-runner/BindingTreeEvaluationContext.js +35 -0
  329. package/dist/scripts/src/components-core/script-runner/ICustomOperations.js +34 -0
  330. package/dist/scripts/src/components-core/script-runner/ParameterParser.js +117 -0
  331. package/dist/scripts/src/components-core/script-runner/asyncProxy.js +149 -0
  332. package/dist/scripts/src/components-core/script-runner/bannedFunctions.js +34 -0
  333. package/dist/scripts/src/components-core/script-runner/custom-operations-registry.js +40 -0
  334. package/dist/scripts/src/components-core/script-runner/custom-ui-data.js +40 -0
  335. package/dist/scripts/src/components-core/script-runner/eval-tree-async.js +593 -0
  336. package/dist/scripts/src/components-core/script-runner/eval-tree-common.js +497 -0
  337. package/dist/scripts/src/components-core/script-runner/eval-tree-sync.js +482 -0
  338. package/dist/scripts/src/components-core/script-runner/process-statement-async.js +766 -0
  339. package/dist/scripts/src/components-core/script-runner/process-statement-common.js +193 -0
  340. package/dist/scripts/src/components-core/script-runner/process-statement-sync.js +752 -0
  341. package/dist/scripts/src/components-core/script-runner/statement-queue.js +62 -0
  342. package/dist/scripts/src/components-core/script-runner/syncProxy.js +31 -0
  343. package/dist/scripts/src/components-core/script-runner/visitors.js +361 -0
  344. package/dist/scripts/src/components-core/theming/ThemeContext.js +53 -0
  345. package/dist/scripts/src/components-core/theming/ThemeProvider.js +335 -0
  346. package/dist/scripts/src/components-core/theming/abstractions.js +11 -0
  347. package/dist/scripts/src/components-core/theming/extendThemeUtils.js +114 -0
  348. package/dist/scripts/src/components-core/theming/hvar.js +105 -0
  349. package/dist/scripts/src/components-core/theming/themeVars.js +62 -0
  350. package/dist/scripts/src/components-core/theming/themes/base-utils.js +31 -0
  351. package/dist/scripts/src/components-core/theming/themes/palette.js +55 -0
  352. package/dist/scripts/src/components-core/theming/themes/root.js +287 -0
  353. package/dist/scripts/src/components-core/theming/themes/solid.js +16 -0
  354. package/dist/scripts/src/components-core/theming/themes/theme-colors.js +561 -0
  355. package/dist/scripts/src/components-core/theming/themes/xmlui.js +58 -0
  356. package/dist/scripts/src/components-core/theming/transformThemeVars.js +300 -0
  357. package/dist/scripts/src/components-core/utils/DataLoaderQueryKeyGenerator.js +35 -0
  358. package/dist/scripts/src/components-core/utils/LruCache.js +184 -0
  359. package/dist/scripts/src/components-core/utils/actionUtils.js +32 -0
  360. package/dist/scripts/src/components-core/utils/classnames.js +58 -0
  361. package/dist/scripts/src/components-core/utils/compound-utils.js +11 -0
  362. package/dist/scripts/src/components-core/utils/css-utils.js +163 -0
  363. package/dist/scripts/src/components-core/utils/date-utils.js +78 -0
  364. package/dist/scripts/src/components-core/utils/extractParam.js +148 -0
  365. package/dist/scripts/src/components-core/utils/hooks.js +249 -0
  366. package/dist/scripts/src/components-core/utils/mergeProps.js +45 -0
  367. package/dist/scripts/src/components-core/utils/misc.js +472 -0
  368. package/dist/scripts/src/components-core/utils/request-params.js +70 -0
  369. package/dist/scripts/src/components-core/utils/statementUtils.js +221 -0
  370. package/dist/scripts/src/components-core/utils/treeUtils.js +48 -0
  371. package/dist/scripts/src/index.js +69 -0
  372. package/dist/scripts/src/parsers/common/GenericToken.js +2 -0
  373. package/dist/scripts/src/parsers/scripting-exp/TokenType.js +112 -0
  374. package/dist/scripts/src/parsers/style-parser/StyleInputStream.js +39 -0
  375. package/dist/scripts/src/parsers/style-parser/StyleLexer.js +623 -0
  376. package/dist/scripts/src/parsers/style-parser/StyleParser.js +1036 -0
  377. package/dist/scripts/src/parsers/style-parser/errors.js +37 -0
  378. package/dist/scripts/src/parsers/style-parser/source-tree.js +2 -0
  379. package/dist/scripts/src/parsers/style-parser/style-compiler.js +558 -0
  380. package/dist/scripts/src/parsers/style-parser/tokens.js +43 -0
  381. package/dist/scripts/src/parsers/xmlui-parser/ParserError.js +7 -0
  382. package/dist/scripts/src/parsers/xmlui-parser/transform.js +80 -32
  383. package/dist/scripts/src/syntax/grammar.tmLanguage.json +328 -0
  384. package/dist/scripts/src/syntax/textMate/xmlui.json +630 -0
  385. package/dist/style.css +1 -1
  386. package/dist/xmlui-metadata.mjs +2676 -2608
  387. package/dist/xmlui-metadata.umd.js +16 -16
  388. package/dist/xmlui-standalone.umd.js +186 -186
  389. package/dist/xmlui.d.ts +1868 -13
  390. package/dist/xmlui.mjs +1 -1
  391. package/package.json +5 -5
  392. package/dist/xmlui.umd.js +0 -293
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.passwordInputComponentRenderer = exports.PasswordMd = exports.textBoxComponentRenderer = exports.TextBoxMd = void 0;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const renderers_1 = require("@components-core/renderers");
9
+ const TextBox_module_scss_1 = __importDefault(require("./TextBox.module.scss"));
10
+ const themeVars_1 = require("@components-core/theming/themeVars");
11
+ const ComponentDefs_1 = require("@abstractions/ComponentDefs");
12
+ const metadata_helpers_1 = require("@components/metadata-helpers");
13
+ const TextBoxNative_1 = require("./TextBoxNative");
14
+ const COMP = "TextBox";
15
+ exports.TextBoxMd = (0, ComponentDefs_1.createMetadata)({
16
+ status: "experimental",
17
+ description: `The \`${COMP}\` is an input component that allows users to input and edit textual data.`,
18
+ props: {
19
+ placeholder: (0, metadata_helpers_1.dPlaceholder)(),
20
+ initialValue: (0, metadata_helpers_1.dInitialValue)(),
21
+ label: (0, metadata_helpers_1.dLabel)(),
22
+ labelPosition: (0, metadata_helpers_1.dLabelPosition)("top"),
23
+ labelWidth: (0, metadata_helpers_1.dLabelWidth)(COMP),
24
+ labelBreak: (0, metadata_helpers_1.dLabelBreak)(COMP),
25
+ maxLength: (0, metadata_helpers_1.dMaxLength)(),
26
+ autoFocus: (0, metadata_helpers_1.dAutoFocus)(),
27
+ required: (0, metadata_helpers_1.dRequired)(),
28
+ readOnly: (0, metadata_helpers_1.dReadonly)(),
29
+ enabled: (0, metadata_helpers_1.dEnabled)(),
30
+ validationStatus: (0, metadata_helpers_1.dValidationStatus)(),
31
+ startText: (0, metadata_helpers_1.dStartText)(),
32
+ startIcon: (0, metadata_helpers_1.dStartIcon)(),
33
+ endText: (0, metadata_helpers_1.dEndText)(),
34
+ endIcon: (0, metadata_helpers_1.dEndIcon)(),
35
+ },
36
+ events: {
37
+ gotFocus: (0, metadata_helpers_1.dGotFocus)(COMP),
38
+ lostFocus: (0, metadata_helpers_1.dLostFocus)(COMP),
39
+ didChange: (0, metadata_helpers_1.dDidChange)(COMP),
40
+ },
41
+ apis: {
42
+ focus: (0, metadata_helpers_1.dFocus)(COMP),
43
+ value: (0, ComponentDefs_1.d)(`You can query the component's value. If no value is set, it will retrieve \`undefined\`.`),
44
+ setValue: (0, metadata_helpers_1.dSetValueApi)(),
45
+ },
46
+ themeVars: (0, themeVars_1.parseScssVar)(TextBox_module_scss_1.default.themeVars),
47
+ defaultThemeVars: {
48
+ // TODO: When FormItem is themed, move these defaults there
49
+ "radius-Input": "$radius",
50
+ "color-text-Input": "$color-text-primary",
51
+ "color-bg-Input--disabled": "$color-bg--disabled",
52
+ "thickness-border-Input": "1px",
53
+ "min-height-Input": "39px",
54
+ "padding-Input": "$space-2",
55
+ "style-border-Input": "solid",
56
+ "color-border-Input--disabled": "$color-border--disabled",
57
+ "color-text-Input--disabled": "$color-text--disabled",
58
+ "color-border-Input-error": "$color-border-Input-default--error",
59
+ "color-border-Input-warning": "$color-border-Input-default--warning",
60
+ "color-border-Input-success": "$color-border-Input-default--success",
61
+ "color-placeholder-Input": "$color-text-subtitle",
62
+ "color-adornment-Input": "$color-text-subtitle",
63
+ "color-outline-Input--focus": "$color-outline--focus",
64
+ "thickness-outline-Input--focus": "$thickness-outline--focus",
65
+ "style-outline-Input--focus": "$style-outline--focus",
66
+ "offset-outline-Input--focus": "$offset-outline--focus",
67
+ light: {
68
+ // --- No light-specific theme vars
69
+ },
70
+ dark: {
71
+ // --- No dark-specific theme vars
72
+ },
73
+ },
74
+ });
75
+ function renderTextBox(layoutCss, state, updateState, extractValue, node, lookupEventHandler, registerComponentApi, type = "text") {
76
+ return ((0, jsx_runtime_1.jsx)(TextBoxNative_1.TextBox, { type: type, style: layoutCss, value: state.value, updateState: updateState, initialValue: extractValue(node.props.initialValue), maxLength: extractValue(node.props.maxLength), enabled: extractValue.asOptionalBoolean(node.props.enabled), placeholder: extractValue.asOptionalString(node.props.placeholder), validationStatus: extractValue(node.props.validationStatus), onDidChange: lookupEventHandler("didChange"), onFocus: lookupEventHandler("gotFocus"), onBlur: lookupEventHandler("lostFocus"), registerComponentApi: registerComponentApi, startText: extractValue.asOptionalString(node.props.startText), startIcon: extractValue.asOptionalString(node.props.startIcon), endText: extractValue.asOptionalString(node.props.endText), endIcon: extractValue.asOptionalString(node.props.endIcon), autoFocus: extractValue.asOptionalBoolean(node.props.autoFocus), readOnly: extractValue.asOptionalBoolean(node.props.readOnly), label: extractValue.asOptionalString(node.props.label), labelPosition: extractValue(node.props.labelPosition), labelWidth: extractValue.asOptionalString(node.props.labelWidth), labelBreak: extractValue.asOptionalBoolean(node.props.labelBreak), required: extractValue.asOptionalBoolean(node.props.required) }));
77
+ }
78
+ exports.textBoxComponentRenderer = (0, renderers_1.createComponentRenderer)(COMP, exports.TextBoxMd, ({ node, state, updateState, lookupEventHandler, extractValue, layoutCss, registerComponentApi, }) => {
79
+ return renderTextBox(layoutCss, state, updateState, extractValue, node, lookupEventHandler, registerComponentApi);
80
+ });
81
+ exports.PasswordMd = (0, ComponentDefs_1.createMetadata)(Object.assign(Object.assign({}, exports.TextBoxMd), { description: "The \`Password\` component is a specialized version of the \`TextBox\` component that " +
82
+ "allows users to input and edit passwords." }));
83
+ exports.passwordInputComponentRenderer = (0, renderers_1.createComponentRenderer)("PasswordInput", exports.PasswordMd, ({ node, state, updateState, lookupEventHandler, extractValue, layoutCss, registerComponentApi, }) => {
84
+ return renderTextBox(layoutCss, state, updateState, extractValue, node, lookupEventHandler, registerComponentApi, "password");
85
+ });
@@ -0,0 +1,109 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.TextBox = void 0;
40
+ const jsx_runtime_1 = require("react/jsx-runtime");
41
+ const react_1 = require("react");
42
+ const react_2 = __importStar(require("react"));
43
+ const classnames_1 = __importDefault(require("@components-core/utils/classnames"));
44
+ const TextBox_module_scss_1 = __importDefault(require("./TextBox.module.scss"));
45
+ const constants_1 = require("@components-core/constants");
46
+ const InputAdornment_1 = require("@components/Input/InputAdornment");
47
+ const misc_1 = require("@components-core/utils/misc");
48
+ const ItemWithLabel_1 = require("@components/FormItem/ItemWithLabel");
49
+ exports.TextBox = (0, react_1.forwardRef)(function TextBox({ id, type = "text", value = "", updateState = constants_1.noop, initialValue = "", style, maxLength, enabled = true, placeholder, validationStatus = "none", onDidChange = constants_1.noop, onFocus = constants_1.noop, onBlur = constants_1.noop, registerComponentApi, startText, startIcon, endText, endIcon, autoFocus, readOnly, tabIndex, label, labelPosition, labelWidth, labelBreak, required, }, ref) {
50
+ const inputRef = (0, react_2.useRef)(null);
51
+ (0, react_2.useEffect)(() => {
52
+ if (autoFocus) {
53
+ setTimeout(() => {
54
+ var _a;
55
+ (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
56
+ }, 0);
57
+ }
58
+ }, [autoFocus]);
59
+ // --- NOTE: This is a workaround for the jumping caret issue.
60
+ // --- Local state can sync up values that can get set asynchronously outside the component.
61
+ const [localValue, setLocalValue] = react_2.default.useState(value);
62
+ (0, react_2.useEffect)(() => {
63
+ setLocalValue(value);
64
+ }, [value]);
65
+ // --- End NOTE
66
+ // --- Initialize the related field with the input's initial value
67
+ (0, react_2.useEffect)(() => {
68
+ updateState({ value: initialValue }, { initial: true });
69
+ }, [initialValue, updateState]);
70
+ const updateValue = (0, react_2.useCallback)((value) => {
71
+ setLocalValue(value);
72
+ updateState({ value });
73
+ onDidChange(value);
74
+ }, [onDidChange, updateState]);
75
+ // --- Handle the value change events for this input
76
+ const onInputChange = (0, react_2.useCallback)((event) => {
77
+ updateValue(event.target.value);
78
+ }, [updateValue]);
79
+ // --- Manage obtaining and losing the focus
80
+ const handleOnFocus = (0, react_2.useCallback)(() => {
81
+ onFocus === null || onFocus === void 0 ? void 0 : onFocus();
82
+ }, [onFocus]);
83
+ const handleOnBlur = (0, react_2.useCallback)(() => {
84
+ onBlur === null || onBlur === void 0 ? void 0 : onBlur();
85
+ }, [onBlur]);
86
+ const focus = (0, react_2.useCallback)(() => {
87
+ var _a;
88
+ (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
89
+ }, []);
90
+ const setValue = (0, misc_1.useEvent)((newValue) => {
91
+ updateValue(newValue);
92
+ });
93
+ (0, react_2.useEffect)(() => {
94
+ registerComponentApi === null || registerComponentApi === void 0 ? void 0 : registerComponentApi({
95
+ focus,
96
+ setValue,
97
+ });
98
+ }, [focus, registerComponentApi, setValue]);
99
+ return ((0, jsx_runtime_1.jsx)(ItemWithLabel_1.ItemWithLabel, { labelPosition: labelPosition, label: label, labelWidth: labelWidth, labelBreak: labelBreak, required: required, enabled: enabled, onFocus: onFocus, onBlur: onBlur, style: style, ref: ref, children: (0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)(TextBox_module_scss_1.default.inputRoot, {
100
+ [TextBox_module_scss_1.default.disabled]: !enabled,
101
+ [TextBox_module_scss_1.default.readOnly]: readOnly,
102
+ [TextBox_module_scss_1.default.error]: validationStatus === "error",
103
+ [TextBox_module_scss_1.default.warning]: validationStatus === "warning",
104
+ [TextBox_module_scss_1.default.valid]: validationStatus === "valid",
105
+ }), tabIndex: -1, onFocus: () => {
106
+ var _a;
107
+ (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
108
+ }, children: [(0, jsx_runtime_1.jsx)(InputAdornment_1.Adornment, { text: startText, iconName: startIcon, className: TextBox_module_scss_1.default.adornment }), (0, jsx_runtime_1.jsx)("input", { id: id, type: type, className: (0, classnames_1.default)(TextBox_module_scss_1.default.input, { [TextBox_module_scss_1.default.readOnly]: readOnly }), disabled: !enabled, value: localValue, maxLength: maxLength, placeholder: placeholder, onChange: onInputChange, onFocus: handleOnFocus, onBlur: handleOnBlur, ref: inputRef, readOnly: readOnly, autoFocus: autoFocus, tabIndex: tabIndex }), (0, jsx_runtime_1.jsx)(InputAdornment_1.Adornment, { text: endText, iconName: endIcon, className: TextBox_module_scss_1.default.adornment })] }) }));
109
+ });
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.NotificationToast = void 0;
37
+ const jsx_runtime_1 = require("react/jsx-runtime");
38
+ const react_hot_toast_1 = __importStar(require("react-hot-toast"));
39
+ const TOASTER_CONTAINER_STYLE = {
40
+ top: 40,
41
+ right: 40,
42
+ bottom: 40,
43
+ left: 40,
44
+ position: "absolute",
45
+ overflowY: "hidden",
46
+ };
47
+ const NotificationToast = ({ toastDuration }) => {
48
+ return ((0, jsx_runtime_1.jsx)(react_hot_toast_1.Toaster, { position: "top-right", containerStyle: TOASTER_CONTAINER_STYLE, toastOptions: { style: { padding: "12px 16px" }, duration: toastDuration }, children: (t) => ((0, jsx_runtime_1.jsx)("div", { onClick: () => react_hot_toast_1.default.dismiss(t.id), children: (0, jsx_runtime_1.jsx)(react_hot_toast_1.ToastBar, { position: t.position, toast: t, style: { wordBreak: "break-word" }, children: ({ icon, message }) => ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [icon, message] })) }) })) }));
49
+ };
50
+ exports.NotificationToast = NotificationToast;
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ var __rest = (this && this.__rest) || function (s, e) {
3
+ var t = {};
4
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
+ t[p] = s[p];
6
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
+ t[p[i]] = s[p[i]];
10
+ }
11
+ return t;
12
+ };
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.themeComponentRenderer = exports.ThemeMd = void 0;
15
+ const jsx_runtime_1 = require("react/jsx-runtime");
16
+ const renderers_1 = require("@components-core/renderers");
17
+ const ComponentDefs_1 = require("@abstractions/ComponentDefs");
18
+ const ThemeNative_1 = require("./ThemeNative");
19
+ const COMP = "Theme";
20
+ exports.ThemeMd = (0, ComponentDefs_1.createMetadata)({
21
+ description: `The \`${COMP}\` component provides a way to define a particular theming context for ` +
22
+ `its nested components. The XMLUI framework uses \`${COMP}\` to define the default ` +
23
+ `theming context for all of its child components. Theme variables and theme settings ` +
24
+ `only work in this context.`,
25
+ allowArbitraryProps: true,
26
+ props: {
27
+ themeId: (0, ComponentDefs_1.d)(`This property specifies which theme to use by setting the theme's id.`),
28
+ tone: (0, ComponentDefs_1.d)(`This property allows the setting of the current theme's tone. Tone is either ` +
29
+ `\`light\` or \`dark\`.`),
30
+ root: (0, ComponentDefs_1.d)(`This property indicates whether the component is at the root of the application.`),
31
+ },
32
+ opaque: true,
33
+ });
34
+ exports.themeComponentRenderer = (0, renderers_1.createComponentRenderer)(COMP, exports.ThemeMd, ({ node, extractValue, renderChild, layoutContext, appContext }) => {
35
+ var _a, _b;
36
+ const _c = node.props, { tone } = _c, restProps = __rest(_c, ["tone"]);
37
+ const toastDuration = (_b = (_a = appContext === null || appContext === void 0 ? void 0 : appContext.appGlobals) === null || _a === void 0 ? void 0 : _a.notifications) === null || _b === void 0 ? void 0 : _b.duration;
38
+ let themeTone = extractValue.asOptionalString(tone);
39
+ if (themeTone && themeTone !== "dark") {
40
+ themeTone = "light";
41
+ }
42
+ return ((0, jsx_runtime_1.jsx)(ThemeNative_1.Theme, { id: extractValue.asOptionalString(node.props.themeId), isRoot: extractValue.asOptionalBoolean(node.props.root), layoutContext: layoutContext, renderChild: renderChild, tone: themeTone, toastDuration: toastDuration, themeVars: extractValue(restProps), node: node }));
43
+ });
@@ -0,0 +1,126 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Theme = Theme;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const react_1 = require("react");
9
+ const Theme_module_scss_1 = __importDefault(require("./Theme.module.scss"));
10
+ const ThemeProvider_1 = require("@components-core/theming/ThemeProvider");
11
+ const ThemeContext_1 = require("@components-core/theming/ThemeContext");
12
+ const classnames_1 = __importDefault(require("@components-core/utils/classnames"));
13
+ const react_helmet_async_1 = require("react-helmet-async");
14
+ const react_dom_1 = require("react-dom");
15
+ const constants_1 = require("@components-core/constants");
16
+ const ErrorBoundary_1 = require("@components-core/ErrorBoundary");
17
+ const NotificationToast_1 = require("./NotificationToast");
18
+ const themeVars_1 = require("@components-core/theming/themeVars");
19
+ function getClassName(css) {
20
+ return `theme-${calculateHash(css)}`;
21
+ }
22
+ function calculateHash(str) {
23
+ let hash = 0, i, chr;
24
+ if (str.length === 0)
25
+ return hash;
26
+ for (i = 0; i < str.length; i++) {
27
+ chr = str.charCodeAt(i);
28
+ hash = (hash << 5) - hash + chr;
29
+ hash |= 0; // Convert to 32bit integer
30
+ }
31
+ return hash;
32
+ }
33
+ function Theme({ id, isRoot = false, renderChild, node, tone, toastDuration = 5000, themeVars = constants_1.EMPTY_OBJECT, layoutContext, }) {
34
+ const generatedId = (0, react_1.useId)();
35
+ const { themes, resources, resourceMap, activeThemeId, setRoot, root } = (0, ThemeContext_1.useThemes)();
36
+ const { activeTheme, activeThemeTone } = (0, ThemeContext_1.useTheme)();
37
+ const themeTone = tone || activeThemeTone;
38
+ const currentTheme = (0, react_1.useMemo)(() => {
39
+ var _a, _b, _c;
40
+ const themeToExtend = id ? themes.find((theme) => theme.id === id) : activeTheme;
41
+ if (!themeToExtend) {
42
+ throw new Error("Theme not found");
43
+ }
44
+ const foundTheme = Object.assign(Object.assign({}, themeToExtend), { id: generatedId, tones: Object.assign(Object.assign({}, themeToExtend.tones), { [themeTone]: Object.assign(Object.assign({}, (_a = themeToExtend.tones) === null || _a === void 0 ? void 0 : _a[themeTone]), { themeVars: Object.assign(Object.assign({}, (_c = (_b = themeToExtend.tones) === null || _b === void 0 ? void 0 : _b[themeTone]) === null || _c === void 0 ? void 0 : _c.themeVars), themeVars) }) }) });
45
+ return foundTheme;
46
+ }, [activeTheme, generatedId, id, themeTone, themeVars, themes]);
47
+ const { themeCssVars, getResourceUrl, fontLinks, allThemeVarsWithResolvedHierarchicalVars, getThemeVar } = (0, ThemeProvider_1.useCompiledTheme)(currentTheme, themeTone, themes, resources, resourceMap);
48
+ const { css, className, rangeClassName, fromClass, toClass } = (0, react_1.useMemo)(() => {
49
+ const vars = Object.assign(Object.assign({}, themeCssVars), { "color-scheme": themeTone });
50
+ // const vars = themeCssVars;
51
+ let css = Object.entries(vars)
52
+ .map(([key, value]) => {
53
+ return key + ":" + value + ";";
54
+ })
55
+ .join(" ");
56
+ css += `font-family: var(${(0, themeVars_1.getVarKey)("font-family")});`;
57
+ const className = getClassName(css);
58
+ const fromClass = `${className}-from`;
59
+ const toClass = `${className}-to`;
60
+ let rangeClassName;
61
+ if (!isRoot) {
62
+ rangeClassName = `${fromClass} ~ *:has(~ .${toClass})`;
63
+ }
64
+ return {
65
+ className,
66
+ rangeClassName,
67
+ fromClass,
68
+ toClass,
69
+ css,
70
+ };
71
+ }, [isRoot, themeCssVars, themeTone]);
72
+ // useInsertionEffect(() => {
73
+ // //PERF OPT IDEA: don't inject the css content that we already have
74
+ // // (e.g. in Items component we inject and generate classes for all items if we use a theme for an item, but they have the same content.
75
+ // // We could inject one class, and use that instead. The harder part is keeping track of them, and remove when nobody uses them)
76
+ // injectCSS(`.${className} {${css}}`, className);
77
+ // if (rangeClassName) {
78
+ // injectCSS(`.${rangeClassName} {${css}}`, rangeClassName);
79
+ // }
80
+ // let injectedClassNames = [className, rangeClassName];
81
+ // return () => {
82
+ // injectedClassNames.forEach(injectedClassName => {
83
+ // if (injectedClassName) {
84
+ // cleanupCss(injectedClassName);
85
+ // }
86
+ // });
87
+ // };
88
+ // }, [className, css]);
89
+ const [themeRoot, setThemeRoot] = (0, react_1.useState)(root);
90
+ const currentThemeContextValue = (0, react_1.useMemo)(() => {
91
+ const themeVal = {
92
+ root: themeRoot,
93
+ activeThemeId,
94
+ activeThemeTone: themeTone,
95
+ activeTheme: currentTheme,
96
+ themeStyles: themeCssVars,
97
+ themeVars: allThemeVarsWithResolvedHierarchicalVars,
98
+ getResourceUrl,
99
+ getThemeVar,
100
+ };
101
+ return themeVal;
102
+ }, [
103
+ themeRoot,
104
+ activeThemeId,
105
+ themeTone,
106
+ currentTheme,
107
+ themeCssVars,
108
+ allThemeVarsWithResolvedHierarchicalVars,
109
+ getResourceUrl,
110
+ getThemeVar,
111
+ ]);
112
+ if (isRoot) {
113
+ const faviconUrl = getResourceUrl("resource:favicon") || "/resources/favicon.ico";
114
+ return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsxs)(react_helmet_async_1.Helmet, { children: [!!faviconUrl && (0, jsx_runtime_1.jsx)("link", { rel: "icon", type: "image/svg+xml", href: faviconUrl }), fontLinks === null || fontLinks === void 0 ? void 0 : fontLinks.map((fontLink) => ((0, jsx_runtime_1.jsx)("link", { href: fontLink, rel: "stylesheet" }, fontLink)))] }), (0, jsx_runtime_1.jsx)("style", { children: `.${className} {${css}}` }), (0, jsx_runtime_1.jsxs)("div", { id: "_ui-engine-theme-root", className: (0, classnames_1.default)(Theme_module_scss_1.default.baseRootComponent, className), ref: (el) => {
115
+ if (el) {
116
+ setRoot(el);
117
+ }
118
+ }, children: [(0, jsx_runtime_1.jsx)(ErrorBoundary_1.ErrorBoundary, { node: node, location: "theme-root", children: renderChild(node.children) }), (0, jsx_runtime_1.jsx)(NotificationToast_1.NotificationToast, { toastDuration: toastDuration })] })] }));
119
+ }
120
+ return ((0, jsx_runtime_1.jsxs)(ThemeContext_1.ThemeContext.Provider, { value: currentThemeContextValue, children: [(0, jsx_runtime_1.jsx)("style", { children: `.${rangeClassName} {${css}}` }), (0, jsx_runtime_1.jsx)("style", { children: `.${className} {${css}}` }), (0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)(Theme_module_scss_1.default.from, fromClass) }), renderChild(node.children, Object.assign(Object.assign({}, layoutContext), { themeClassName: className })), (0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)(Theme_module_scss_1.default.to, toClass) }), root &&
121
+ (0, react_dom_1.createPortal)((0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)(className), ref: (el) => {
122
+ if (el) {
123
+ setThemeRoot(el);
124
+ }
125
+ } }), root)] }));
126
+ }
@@ -0,0 +1,115 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.themeChangerButtonComponentRenderer = exports.ThemeChangerButtonMd = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const ComponentDefs_1 = require("@abstractions/ComponentDefs");
6
+ const DropdownMenuNative_1 = require("@components/DropdownMenu/DropdownMenuNative");
7
+ const ButtonNative_1 = require("@components/Button/ButtonNative");
8
+ const ContentSeparatorNative_1 = require("@components/ContentSeparator/ContentSeparatorNative");
9
+ const ModalDialogNative_1 = require("@components/ModalDialog/ModalDialogNative");
10
+ const RadioGroupNative_1 = require("@components/RadioGroup/RadioGroupNative");
11
+ const react_1 = require("react");
12
+ const ThemeContext_1 = require("@components-core/theming/ThemeContext");
13
+ const renderers_1 = require("@components-core/renderers");
14
+ const StackNative_1 = require("@components/Stack/StackNative");
15
+ const TextNative_1 = require("@components/Text/TextNative");
16
+ const IconNative_1 = require("@components/Icon/IconNative");
17
+ const COMP = "ThemeChangerButton";
18
+ exports.ThemeChangerButtonMd = (0, ComponentDefs_1.createMetadata)({
19
+ status: "experimental",
20
+ docFolder: "ThemeChanger",
21
+ description: `The \`${COMP}\` component is a component that allows the user to change the theme of the app.`,
22
+ props: {
23
+ showSettings: (0, ComponentDefs_1.d)("This property indicates if the Settings function of this component is displayed.", null, "boolean", true),
24
+ },
25
+ });
26
+ /**
27
+ * Define the renderer for the Button component
28
+ */
29
+ exports.themeChangerButtonComponentRenderer = (0, renderers_1.createComponentRenderer)(COMP, exports.ThemeChangerButtonMd, ({ renderChild, node, extractValue }) => {
30
+ const [isThemeSettingsOpen, setThemeSettingsOpen] = (0, react_1.useState)(false);
31
+ const { activeThemeId, activeThemeTone, setActiveThemeId, setActiveThemeTone, availableThemeIds, } = (0, ThemeContext_1.useThemes)();
32
+ const renderPreview = (id) => {
33
+ return renderChild({
34
+ type: "Theme",
35
+ props: {
36
+ themeId: id,
37
+ width: "100%",
38
+ isRoot: "true",
39
+ tone: "{activeThemeTone}",
40
+ },
41
+ children: [
42
+ {
43
+ type: "Card",
44
+ props: {
45
+ width: "100%",
46
+ },
47
+ children: [
48
+ {
49
+ type: "App",
50
+ props: {
51
+ width: "100%",
52
+ height: "10rem",
53
+ layout: "horizontal",
54
+ },
55
+ children: [
56
+ {
57
+ type: "NavPanel",
58
+ props: {},
59
+ children: [
60
+ {
61
+ type: "NavLink",
62
+ props: {
63
+ active: "true",
64
+ url: "/",
65
+ label: "Home",
66
+ },
67
+ },
68
+ {
69
+ type: "NavLink",
70
+ props: {
71
+ url: "/about",
72
+ label: "About",
73
+ },
74
+ },
75
+ {
76
+ type: "NavLink",
77
+ props: {
78
+ url: "/contact",
79
+ label: "Contact",
80
+ },
81
+ },
82
+ ],
83
+ },
84
+ {
85
+ type: "Pages",
86
+ props: {
87
+ defaultRoute: "/",
88
+ },
89
+ children: [
90
+ {
91
+ type: "CVStack",
92
+ props: {
93
+ height: "100%",
94
+ },
95
+ children: [
96
+ {
97
+ type: "Text",
98
+ props: {
99
+ value: "Hello",
100
+ },
101
+ },
102
+ ],
103
+ },
104
+ ],
105
+ },
106
+ ],
107
+ },
108
+ ],
109
+ },
110
+ ],
111
+ });
112
+ };
113
+ const showSettings = extractValue.asOptionalBoolean(node.props.showSettings, true);
114
+ return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsxs)(DropdownMenuNative_1.DropdownMenu, { triggerTemplate: (0, jsx_runtime_1.jsx)(ButtonNative_1.Button, { variant: "ghost", icon: (0, jsx_runtime_1.jsx)(IconNative_1.Icon, { name: "palette" }) }), children: [(0, jsx_runtime_1.jsx)(DropdownMenuNative_1.MenuItem, { iconPosition: "end", icon: activeThemeTone === "light" ? (0, jsx_runtime_1.jsx)(IconNative_1.Icon, { name: "checkmark" }) : "", label: "Light", onClick: () => setActiveThemeTone("light") }), (0, jsx_runtime_1.jsx)(DropdownMenuNative_1.MenuItem, { iconPosition: "end", icon: activeThemeTone === "dark" ? (0, jsx_runtime_1.jsx)(IconNative_1.Icon, { name: "checkmark" }) : "", label: "Dark", onClick: () => setActiveThemeTone("dark") }), showSettings && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(ContentSeparatorNative_1.ContentSeparator, {}), (0, jsx_runtime_1.jsx)(DropdownMenuNative_1.MenuItem, { label: "Theme Settings", onClick: () => setThemeSettingsOpen(true) })] }))] }), isThemeSettingsOpen && ((0, jsx_runtime_1.jsx)(ModalDialogNative_1.ModalDialog, { isInitiallyOpen: true, onClose: () => setThemeSettingsOpen(false), children: (0, jsx_runtime_1.jsxs)(StackNative_1.Stack, { orientation: "vertical", children: [(0, jsx_runtime_1.jsx)(TextNative_1.Text, { variant: "strong", layout: { marginBottom: "1rem" }, children: "Set theme" }), (0, jsx_runtime_1.jsx)(StackNative_1.Stack, { orientation: "vertical", layout: { width: "100%", overflow: "scroll" }, children: (0, jsx_runtime_1.jsx)(StackNative_1.Stack, { orientation: "horizontal", verticalAlignment: "center", layout: { gap: ".5rem", flexWrap: "wrap" }, children: availableThemeIds.map((themeUid) => ((0, jsx_runtime_1.jsx)(ButtonNative_1.Button, { style: { padding: 0, width: "calc(50% - 0.5rem)" }, variant: activeThemeId === themeUid ? "solid" : "ghost", themeColor: "primary", onClick: () => setActiveThemeId(themeUid), children: (0, jsx_runtime_1.jsxs)(StackNative_1.Stack, { layout: { width: "100%" }, children: [renderPreview(themeUid), (0, jsx_runtime_1.jsx)(TextNative_1.Text, { children: themeUid })] }) }, themeUid))) }) }), (0, jsx_runtime_1.jsxs)(StackNative_1.Stack, { orientation: "vertical", layout: { minHeight: "fit-content" }, children: [(0, jsx_runtime_1.jsx)(TextNative_1.Text, { variant: "strong", layout: { marginBottom: "1rem" }, children: "Set tone" }), (0, jsx_runtime_1.jsx)(RadioGroupNative_1.RadioGroup, { id: "toneSelector", value: activeThemeTone, onDidChange: (value) => setActiveThemeTone(value), children: (0, jsx_runtime_1.jsxs)(StackNative_1.Stack, { layout: { gap: "1rem" }, orientation: "horizontal", children: [(0, jsx_runtime_1.jsx)(RadioGroupNative_1.RadioGroupOption, { label: "Light", value: "light" }), (0, jsx_runtime_1.jsx)(RadioGroupNative_1.RadioGroupOption, { label: "Dark", value: "dark" })] }) })] })] }) }))] }));
115
+ });
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.toneChangerButtonComponentRenderer = exports.ToneChangerButtonMd = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const ComponentDefs_1 = require("@abstractions/ComponentDefs");
6
+ const ButtonNative_1 = require("@components/Button/ButtonNative");
7
+ const ThemeContext_1 = require("@components-core/theming/ThemeContext");
8
+ const renderers_1 = require("@components-core/renderers");
9
+ const IconNative_1 = require("@components/Icon/IconNative");
10
+ const COMP = "ToneChangerButton";
11
+ exports.ToneChangerButtonMd = (0, ComponentDefs_1.createMetadata)({
12
+ status: "experimental",
13
+ docFolder: "ThemeChanger",
14
+ description: `The \`${COMP}\` component is a component that allows the user to change the tone of the app.`,
15
+ props: {},
16
+ });
17
+ function ToneChangerButton() {
18
+ const { activeThemeTone, setActiveThemeTone } = (0, ThemeContext_1.useThemes)();
19
+ return ((0, jsx_runtime_1.jsx)(ButtonNative_1.Button, { variant: "ghost", icon: (0, jsx_runtime_1.jsx)(IconNative_1.Icon, { name: activeThemeTone === "light" ? "moon" : "sun" }), onClick: () => {
20
+ activeThemeTone === "light" ? setActiveThemeTone("dark") : setActiveThemeTone("light");
21
+ } }));
22
+ }
23
+ /**
24
+ * Define the renderer for the Button component
25
+ */
26
+ exports.toneChangerButtonComponentRenderer = (0, renderers_1.createComponentRenderer)(COMP, exports.ToneChangerButtonMd, () => {
27
+ return (0, jsx_runtime_1.jsx)(ToneChangerButton, {});
28
+ });