xmlui 0.4.0

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 (308) hide show
  1. package/dist/Pdf-DeGhSMXe.mjs +19537 -0
  2. package/dist/Pdf.css +1 -0
  3. package/dist/apiInterceptorWorker-CwuUhYyc.mjs +9229 -0
  4. package/dist/array-USo-Szhp.mjs +12 -0
  5. package/dist/index-C24dkfpd.mjs +1434 -0
  6. package/dist/index-ao27SnVp.mjs +145185 -0
  7. package/dist/index.css +1 -0
  8. package/dist/nivo-bar.es-CWh0ZlxB.mjs +1666 -0
  9. package/dist/nivo-geo.es-BTqNt5Db.mjs +1579 -0
  10. package/dist/nivo-legends.es-BuIxHGSU.mjs +6916 -0
  11. package/dist/nivo-pie.es-BvCBFA0L.mjs +700 -0
  12. package/dist/react-apexcharts.min-DqWuDOyO.mjs +8881 -0
  13. package/dist/scripts/bin/bootstrap.js +11 -0
  14. package/dist/scripts/bin/build.js +256 -0
  15. package/dist/scripts/bin/index.js +88 -0
  16. package/dist/scripts/bin/preview.js +27 -0
  17. package/dist/scripts/bin/start.js +41 -0
  18. package/dist/scripts/bin/vite-ueml-plugin.js +113 -0
  19. package/dist/scripts/bin/viteConfig.js +112 -0
  20. package/dist/scripts/src/abstractions/ActionDefs.js +2 -0
  21. package/dist/scripts/src/abstractions/AppContextDefs.js +2 -0
  22. package/dist/scripts/src/abstractions/BlockScope.js +4 -0
  23. package/dist/scripts/src/abstractions/ComponentDefs.js +2 -0
  24. package/dist/scripts/src/abstractions/ComponentDescriptorDefs.js +2 -0
  25. package/dist/scripts/src/abstractions/ContainerDefs.js +2 -0
  26. package/dist/scripts/src/abstractions/FunctionDefs.js +2 -0
  27. package/dist/scripts/src/abstractions/RendererDefs.js +2 -0
  28. package/dist/scripts/src/abstractions/scripting/ScriptParserError.js +2 -0
  29. package/dist/scripts/src/abstractions/scripting/ScriptingSourceTree.js +2 -0
  30. package/dist/scripts/src/abstractions/scripting/Token.js +110 -0
  31. package/dist/scripts/src/components/App/App.js +253 -0
  32. package/dist/scripts/src/components/App/AppLayoutContext.js +9 -0
  33. package/dist/scripts/src/components/App/AppStateContext.js +9 -0
  34. package/dist/scripts/src/components/App/Sheet.js +89 -0
  35. package/dist/scripts/src/components/AppHeader/AppHeader.js +121 -0
  36. package/dist/scripts/src/components/AppState/AppState.js +29 -0
  37. package/dist/scripts/src/components/Avatar/Avatar.js +81 -0
  38. package/dist/scripts/src/components/Badge/Badge.js +56 -0
  39. package/dist/scripts/src/components/BarChart/BarChart.js +199 -0
  40. package/dist/scripts/src/components/Bookmark/Bookmark.js +11 -0
  41. package/dist/scripts/src/components/Button/Button.js +196 -0
  42. package/dist/scripts/src/components/Card/Card.js +65 -0
  43. package/dist/scripts/src/components/ChangeListener/ChangeListener.js +43 -0
  44. package/dist/scripts/src/components/Chart/Chart.js +158 -0
  45. package/dist/scripts/src/components/Checkbox/Checkbox.js +43 -0
  46. package/dist/scripts/src/components/Combobox/Combobox.js +145 -0
  47. package/dist/scripts/src/components/ComponentProvider.js +357 -0
  48. package/dist/scripts/src/components/ContentSeparator/ContentSeparator.js +40 -0
  49. package/dist/scripts/src/components/DatePicker/DatePicker.js +196 -0
  50. package/dist/scripts/src/components/DropdownMenu/DropdownMenu.js +175 -0
  51. package/dist/scripts/src/components/EmojiSelector/EmojiSelector.js +56 -0
  52. package/dist/scripts/src/components/FileInput/FileInput.js +127 -0
  53. package/dist/scripts/src/components/FileUploadDropZone/FileUploadDropZone.js +106 -0
  54. package/dist/scripts/src/components/FlowLayout/FlowLayout.js +139 -0
  55. package/dist/scripts/src/components/Footer/Footer.js +42 -0
  56. package/dist/scripts/src/components/Form/Form.js +320 -0
  57. package/dist/scripts/src/components/Form/FormContext.js +9 -0
  58. package/dist/scripts/src/components/Form/formActions.js +86 -0
  59. package/dist/scripts/src/components/FormItem/FormItem.js +204 -0
  60. package/dist/scripts/src/components/FormItem/HelperText.js +27 -0
  61. package/dist/scripts/src/components/FormItem/ItemWithLabel.js +39 -0
  62. package/dist/scripts/src/components/FormItem/Validations.js +346 -0
  63. package/dist/scripts/src/components/FormSection/FormSection.js +45 -0
  64. package/dist/scripts/src/components/Heading/Heading.js +206 -0
  65. package/dist/scripts/src/components/HoverCard/HoverCard.js +45 -0
  66. package/dist/scripts/src/components/Icon/ApiIcon.js +10 -0
  67. package/dist/scripts/src/components/Icon/Attach.js +10 -0
  68. package/dist/scripts/src/components/Icon/Binding.js +11 -0
  69. package/dist/scripts/src/components/Icon/BoardIcon.js +7 -0
  70. package/dist/scripts/src/components/Icon/BoxIcon.js +10 -0
  71. package/dist/scripts/src/components/Icon/CheckIcon.js +7 -0
  72. package/dist/scripts/src/components/Icon/ChevronDownIcon.js +7 -0
  73. package/dist/scripts/src/components/Icon/ChevronLeft.js +7 -0
  74. package/dist/scripts/src/components/Icon/ChevronRight.js +7 -0
  75. package/dist/scripts/src/components/Icon/ChevronUpIcon.js +7 -0
  76. package/dist/scripts/src/components/Icon/CodeFileIcon.js +10 -0
  77. package/dist/scripts/src/components/Icon/CodeSandbox.js +10 -0
  78. package/dist/scripts/src/components/Icon/CompactListIcon.js +7 -0
  79. package/dist/scripts/src/components/Icon/ContentCopyIcon.js +7 -0
  80. package/dist/scripts/src/components/Icon/DatabaseIcon.js +11 -0
  81. package/dist/scripts/src/components/Icon/DocFileIcon.js +10 -0
  82. package/dist/scripts/src/components/Icon/DocIcon.js +10 -0
  83. package/dist/scripts/src/components/Icon/DotMenuHorizontalIcon.js +7 -0
  84. package/dist/scripts/src/components/Icon/DotMenuIcon.js +7 -0
  85. package/dist/scripts/src/components/Icon/EmailIcon.js +7 -0
  86. package/dist/scripts/src/components/Icon/EmptyFolderIcon.js +10 -0
  87. package/dist/scripts/src/components/Icon/ErrorIcon.js +7 -0
  88. package/dist/scripts/src/components/Icon/ExpressionIcon.js +10 -0
  89. package/dist/scripts/src/components/Icon/FillPlusCricleIcon.js +7 -0
  90. package/dist/scripts/src/components/Icon/FilterIcon.js +10 -0
  91. package/dist/scripts/src/components/Icon/FolderIcon.js +10 -0
  92. package/dist/scripts/src/components/Icon/GlobeIcon.js +7 -0
  93. package/dist/scripts/src/components/Icon/HomeIcon.js +7 -0
  94. package/dist/scripts/src/components/Icon/HyperLinkIcon.js +7 -0
  95. package/dist/scripts/src/components/Icon/Icon.js +101 -0
  96. package/dist/scripts/src/components/Icon/ImageFileIcon.js +10 -0
  97. package/dist/scripts/src/components/Icon/LinkIcon.js +7 -0
  98. package/dist/scripts/src/components/Icon/ListIcon.js +7 -0
  99. package/dist/scripts/src/components/Icon/LooseListIcon.js +7 -0
  100. package/dist/scripts/src/components/Icon/MoonIcon.js +10 -0
  101. package/dist/scripts/src/components/Icon/MoreOptionsIcon.js +7 -0
  102. package/dist/scripts/src/components/Icon/PDFIcon.js +10 -0
  103. package/dist/scripts/src/components/Icon/PenIcon.js +7 -0
  104. package/dist/scripts/src/components/Icon/PhoneIcon.js +7 -0
  105. package/dist/scripts/src/components/Icon/PhotoIcon.js +10 -0
  106. package/dist/scripts/src/components/Icon/PlusIcon.js +7 -0
  107. package/dist/scripts/src/components/Icon/SearchIcon.js +7 -0
  108. package/dist/scripts/src/components/Icon/ShareIcon.js +10 -0
  109. package/dist/scripts/src/components/Icon/SunIcon.js +10 -0
  110. package/dist/scripts/src/components/Icon/TrashIcon.js +7 -0
  111. package/dist/scripts/src/components/Icon/TxtIcon.js +10 -0
  112. package/dist/scripts/src/components/Icon/UnknownFileIcon.js +10 -0
  113. package/dist/scripts/src/components/Icon/UnlinkIcon.js +10 -0
  114. package/dist/scripts/src/components/Icon/UserIcon.js +7 -0
  115. package/dist/scripts/src/components/Icon/WarningIcon.js +7 -0
  116. package/dist/scripts/src/components/Icon/XlsIcon.js +10 -0
  117. package/dist/scripts/src/components/IconProvider.js +249 -0
  118. package/dist/scripts/src/components/IconRegistryContext.js +307 -0
  119. package/dist/scripts/src/components/Image/Image.js +34 -0
  120. package/dist/scripts/src/components/Input/InputAdornment.js +14 -0
  121. package/dist/scripts/src/components/Input/input-abstractions.js +44 -0
  122. package/dist/scripts/src/components/Items/Items.js +48 -0
  123. package/dist/scripts/src/components/Link/Link.js +72 -0
  124. package/dist/scripts/src/components/List/List.js +442 -0
  125. package/dist/scripts/src/components/Logo/Logo.js +25 -0
  126. package/dist/scripts/src/components/Map/Map.js +60 -0
  127. package/dist/scripts/src/components/Map/world_countries.json +45307 -0
  128. package/dist/scripts/src/components/Markdown/Markdown.js +120 -0
  129. package/dist/scripts/src/components/ModalDialog/ConfirmationModalContextProvider.js +106 -0
  130. package/dist/scripts/src/components/ModalDialog/Dialog.js +20 -0
  131. package/dist/scripts/src/components/ModalDialog/ModalDialog.js +145 -0
  132. package/dist/scripts/src/components/MultiCombobox/MultiCombobox.js +249 -0
  133. package/dist/scripts/src/components/MultiSelect/MultiSelect.js +192 -0
  134. package/dist/scripts/src/components/NavGroup/NavGroup.js +113 -0
  135. package/dist/scripts/src/components/NavLink/NavLink.js +115 -0
  136. package/dist/scripts/src/components/NavPanel/NavPanel.js +101 -0
  137. package/dist/scripts/src/components/NoResult/NoResult.js +39 -0
  138. package/dist/scripts/src/components/NumberBox/NumberBox.js +373 -0
  139. package/dist/scripts/src/components/Option/Option.js +41 -0
  140. package/dist/scripts/src/components/PageMetaTitle/PageMetaTitle.js +22 -0
  141. package/dist/scripts/src/components/Pages/Pages.js +74 -0
  142. package/dist/scripts/src/components/Pdf/LazyPdf.js +44 -0
  143. package/dist/scripts/src/components/Pdf/Pdf.js +19 -0
  144. package/dist/scripts/src/components/PieChart/PieChart.js +184 -0
  145. package/dist/scripts/src/components/PositionedContainer/PositionedContainer.js +29 -0
  146. package/dist/scripts/src/components/ProgressBar/ProgressBar.js +38 -0
  147. package/dist/scripts/src/components/Queue/Queue.js +286 -0
  148. package/dist/scripts/src/components/Queue/queueActions.js +87 -0
  149. package/dist/scripts/src/components/RadioGroup/RadioGroup.js +144 -0
  150. package/dist/scripts/src/components/RealTimeAdapter/RealTimeAdapter.js +147 -0
  151. package/dist/scripts/src/components/Redirect/Redirect.js +10 -0
  152. package/dist/scripts/src/components/Select/Select.js +139 -0
  153. package/dist/scripts/src/components/Select/SelectContext.js +45 -0
  154. package/dist/scripts/src/components/SelectionStore/SelectionStore.js +88 -0
  155. package/dist/scripts/src/components/SpaceFiller/SpaceFiller.js +22 -0
  156. package/dist/scripts/src/components/Spinner/Spinner.js +59 -0
  157. package/dist/scripts/src/components/Splitter/Splitter.js +205 -0
  158. package/dist/scripts/src/components/Splitter/utils.js +17 -0
  159. package/dist/scripts/src/components/Stack/Stack.js +117 -0
  160. package/dist/scripts/src/components/StickyBox/StickyBox.js +33 -0
  161. package/dist/scripts/src/components/Switch/Switch.js +50 -0
  162. package/dist/scripts/src/components/Table/Table.js +499 -0
  163. package/dist/scripts/src/components/Table/useRowSelection.js +169 -0
  164. package/dist/scripts/src/components/TableColumnDef/TableColumnDef.js +44 -0
  165. package/dist/scripts/src/components/TableColumnDef/TableContext.js +12 -0
  166. package/dist/scripts/src/components/Tabs/Tabs.js +85 -0
  167. package/dist/scripts/src/components/Text/Text.js +175 -0
  168. package/dist/scripts/src/components/TextArea/TextArea.js +194 -0
  169. package/dist/scripts/src/components/TextArea/TextAreaResizable.js +63 -0
  170. package/dist/scripts/src/components/TextArea/useComposedRef.js +50 -0
  171. package/dist/scripts/src/components/TextBox/TextBox.js +145 -0
  172. package/dist/scripts/src/components/Theme/NotificationToast.js +39 -0
  173. package/dist/scripts/src/components/Theme/Theme.js +153 -0
  174. package/dist/scripts/src/components/ThemeChanger/ThemeChanger.js +125 -0
  175. package/dist/scripts/src/components/Toggle/Toggle.js +88 -0
  176. package/dist/scripts/src/components/Tree/TreeComponent.js +79 -0
  177. package/dist/scripts/src/components/ValidationSummary/ValidationSummary.js +59 -0
  178. package/dist/scripts/src/components/ViewComponentRegistryContext.js +34 -0
  179. package/dist/scripts/src/components/abstractions.js +2 -0
  180. package/dist/scripts/src/components/chart-color-schemes.js +43 -0
  181. package/dist/scripts/src/components/component-utils.js +32 -0
  182. package/dist/scripts/src/components/container-helpers.js +18 -0
  183. package/dist/scripts/src/components-core/ApiBoundComponent.js +189 -0
  184. package/dist/scripts/src/components-core/AppContext.js +17 -0
  185. package/dist/scripts/src/components-core/ChildrenSlot.js +10 -0
  186. package/dist/scripts/src/components-core/Component.js +280 -0
  187. package/dist/scripts/src/components-core/ComponentDecorator.js +63 -0
  188. package/dist/scripts/src/components-core/CompoundComponent.js +132 -0
  189. package/dist/scripts/src/components-core/EngineError.js +91 -0
  190. package/dist/scripts/src/components-core/ErrorBoundary.js +58 -0
  191. package/dist/scripts/src/components-core/Fragment.js +14 -0
  192. package/dist/scripts/src/components-core/InvalidComponent.js +15 -0
  193. package/dist/scripts/src/components-core/LoaderComponent.js +78 -0
  194. package/dist/scripts/src/components-core/RestApiProxy.js +341 -0
  195. package/dist/scripts/src/components-core/RootComponent.js +272 -0
  196. package/dist/scripts/src/components-core/RouteContext.js +45 -0
  197. package/dist/scripts/src/components-core/ScrollContext.js +9 -0
  198. package/dist/scripts/src/components-core/UnknownComponent.js +15 -0
  199. package/dist/scripts/src/components-core/abstractions/ComponentRenderer.js +2 -0
  200. package/dist/scripts/src/components-core/abstractions/LoaderRenderer.js +2 -0
  201. package/dist/scripts/src/components-core/abstractions/containers.js +18 -0
  202. package/dist/scripts/src/components-core/abstractions/treeAbstractions.js +2 -0
  203. package/dist/scripts/src/components-core/action/ApiAction.js +276 -0
  204. package/dist/scripts/src/components-core/action/DownloadFileAction.js +80 -0
  205. package/dist/scripts/src/components-core/action/NavigateAction.js +20 -0
  206. package/dist/scripts/src/components-core/action/TimedAction.js +21 -0
  207. package/dist/scripts/src/components-core/action/UploadAction.js +88 -0
  208. package/dist/scripts/src/components-core/action/actions.js +15 -0
  209. package/dist/scripts/src/components-core/appContext/date-functions.js +19 -0
  210. package/dist/scripts/src/components-core/appContext/misc-utils.js +12 -0
  211. package/dist/scripts/src/components-core/component-hooks.js +25 -0
  212. package/dist/scripts/src/components-core/constants.js +18 -0
  213. package/dist/scripts/src/components-core/container/Container.js +1110 -0
  214. package/dist/scripts/src/components-core/container/ContainerComponentDef.js +16 -0
  215. package/dist/scripts/src/components-core/container/buildProxy.js +54 -0
  216. package/dist/scripts/src/components-core/container/collectFnVarDeps.js +26 -0
  217. package/dist/scripts/src/components-core/container/valueExtractor.js +195 -0
  218. package/dist/scripts/src/components-core/descriptorHelper.js +75 -0
  219. package/dist/scripts/src/components-core/interception/abstractions.js +2 -0
  220. package/dist/scripts/src/components-core/interception/useApiInterceptorContext.js +9 -0
  221. package/dist/scripts/src/components-core/loader/ApiLoader.js +46 -0
  222. package/dist/scripts/src/components-core/loader/DataLoader.js +160 -0
  223. package/dist/scripts/src/components-core/loader/ExternalDataLoader.js +52 -0
  224. package/dist/scripts/src/components-core/loader/Loader.js +115 -0
  225. package/dist/scripts/src/components-core/loader/MockLoaderRenderer.js +32 -0
  226. package/dist/scripts/src/components-core/loader/PageableLoader.js +240 -0
  227. package/dist/scripts/src/components-core/renderers.js +45 -0
  228. package/dist/scripts/src/components-core/reportEngineError.js +59 -0
  229. package/dist/scripts/src/components-core/script-runner/BindingTreeEvaluationContext.js +35 -0
  230. package/dist/scripts/src/components-core/script-runner/ICustomOperations.js +34 -0
  231. package/dist/scripts/src/components-core/script-runner/LogicalThread.js +2 -0
  232. package/dist/scripts/src/components-core/script-runner/LoopScope.js +2 -0
  233. package/dist/scripts/src/components-core/script-runner/ParameterParser.js +117 -0
  234. package/dist/scripts/src/components-core/script-runner/TryScope.js +2 -0
  235. package/dist/scripts/src/components-core/script-runner/asyncProxy.js +96 -0
  236. package/dist/scripts/src/components-core/script-runner/bannedFunctions.js +34 -0
  237. package/dist/scripts/src/components-core/script-runner/custom-operations-registry.js +40 -0
  238. package/dist/scripts/src/components-core/script-runner/custom-ui-data.js +40 -0
  239. package/dist/scripts/src/components-core/script-runner/eval-tree-async.js +551 -0
  240. package/dist/scripts/src/components-core/script-runner/eval-tree-common.js +498 -0
  241. package/dist/scripts/src/components-core/script-runner/eval-tree-sync.js +434 -0
  242. package/dist/scripts/src/components-core/script-runner/modules.js +250 -0
  243. package/dist/scripts/src/components-core/script-runner/process-statement-async.js +818 -0
  244. package/dist/scripts/src/components-core/script-runner/process-statement-common.js +193 -0
  245. package/dist/scripts/src/components-core/script-runner/process-statement-sync.js +740 -0
  246. package/dist/scripts/src/components-core/script-runner/statement-queue.js +62 -0
  247. package/dist/scripts/src/components-core/script-runner/visitors.js +352 -0
  248. package/dist/scripts/src/components-core/theming/ThemeContext.js +43 -0
  249. package/dist/scripts/src/components-core/theming/ThemeProvider.js +334 -0
  250. package/dist/scripts/src/components-core/theming/abstractions.js +11 -0
  251. package/dist/scripts/src/components-core/theming/extendThemeUtils.js +114 -0
  252. package/dist/scripts/src/components-core/theming/hvar.js +105 -0
  253. package/dist/scripts/src/components-core/theming/themeVars.js +62 -0
  254. package/dist/scripts/src/components-core/theming/themes/base-utils.js +31 -0
  255. package/dist/scripts/src/components-core/theming/themes/palette.js +53 -0
  256. package/dist/scripts/src/components-core/theming/themes/root.js +257 -0
  257. package/dist/scripts/src/components-core/theming/themes/solid.js +16 -0
  258. package/dist/scripts/src/components-core/theming/themes/theme-colors.js +407 -0
  259. package/dist/scripts/src/components-core/theming/themes/xmlui.js +32 -0
  260. package/dist/scripts/src/components-core/theming/transformThemeVars.js +286 -0
  261. package/dist/scripts/src/components-core/utils/DataLoaderQueryKeyGenerator.js +34 -0
  262. package/dist/scripts/src/components-core/utils/LruCache.js +184 -0
  263. package/dist/scripts/src/components-core/utils/actionUtils.js +32 -0
  264. package/dist/scripts/src/components-core/utils/classnames.js +58 -0
  265. package/dist/scripts/src/components-core/utils/css-utils.js +127 -0
  266. package/dist/scripts/src/components-core/utils/date-utils.js +78 -0
  267. package/dist/scripts/src/components-core/utils/extractParam.js +148 -0
  268. package/dist/scripts/src/components-core/utils/hooks.js +221 -0
  269. package/dist/scripts/src/components-core/utils/mergeProps.js +45 -0
  270. package/dist/scripts/src/components-core/utils/misc.js +460 -0
  271. package/dist/scripts/src/components-core/utils/statementUtils.js +205 -0
  272. package/dist/scripts/src/components-core/utils/treeUtils.js +48 -0
  273. package/dist/scripts/src/components-core/xmlui-parser.js +52 -0
  274. package/dist/scripts/src/parsers/scripting/InputStream.js +59 -0
  275. package/dist/scripts/src/parsers/scripting/Lexer.js +1028 -0
  276. package/dist/scripts/src/parsers/scripting/Parser.js +2647 -0
  277. package/dist/scripts/src/parsers/scripting/ParserError.js +46 -0
  278. package/dist/scripts/src/parsers/scripting/TokenTrait.js +109 -0
  279. package/dist/scripts/src/parsers/scripting/code-behind-collect.js +118 -0
  280. package/dist/scripts/src/parsers/scripting/tree-visitor.js +602 -0
  281. package/dist/scripts/src/parsers/style-parser/StyleInputStream.js +39 -0
  282. package/dist/scripts/src/parsers/style-parser/StyleLexer.js +621 -0
  283. package/dist/scripts/src/parsers/style-parser/StyleParser.js +1000 -0
  284. package/dist/scripts/src/parsers/style-parser/errors.js +37 -0
  285. package/dist/scripts/src/parsers/style-parser/source-tree.js +2 -0
  286. package/dist/scripts/src/parsers/style-parser/style-compiler.js +513 -0
  287. package/dist/scripts/src/parsers/style-parser/tokens.js +42 -0
  288. package/dist/scripts/src/parsers/ueml/ParserError.js +54 -0
  289. package/dist/scripts/src/parsers/ueml/UemlHelper.js +579 -0
  290. package/dist/scripts/src/parsers/ueml/UemlInputStream.js +59 -0
  291. package/dist/scripts/src/parsers/ueml/UemlLexer.js +868 -0
  292. package/dist/scripts/src/parsers/ueml/UemlParser.js +1439 -0
  293. package/dist/scripts/src/parsers/ueml/UemlToken.js +24 -0
  294. package/dist/scripts/src/parsers/ueml/fileExtensions.js +6 -0
  295. package/dist/scripts/src/parsers/ueml/source-tree.js +2 -0
  296. package/dist/scripts/src/parsers/ueml/ueml-tree.js +2 -0
  297. package/dist/scripts/src/parsers/xmlui-parser/CharacterCodes.js +136 -0
  298. package/dist/scripts/src/parsers/xmlui-parser/diagnostics.js +100 -0
  299. package/dist/scripts/src/parsers/xmlui-parser/parser.js +476 -0
  300. package/dist/scripts/src/parsers/xmlui-parser/scanner.js +415 -0
  301. package/dist/scripts/src/parsers/xmlui-parser/syntax-kind.js +106 -0
  302. package/dist/scripts/src/parsers/xmlui-parser/syntax-node.js +2 -0
  303. package/dist/scripts/src/parsers/xmlui-parser/transform.js +922 -0
  304. package/dist/scripts/src/parsers/xmlui-parser/utils.js +83 -0
  305. package/dist/xmlui.es.d.ts +1667 -0
  306. package/dist/xmlui.es.js +17 -0
  307. package/dist/xmlui.umd.js +1589 -0
  308. package/package.json +175 -0
@@ -0,0 +1,192 @@
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.multiSelectComponentRenderer = void 0;
7
+ exports.MultiSelect = MultiSelect;
8
+ const react_1 = require("react");
9
+ const jsx_runtime_1 = require("react/jsx-runtime");
10
+ const downshift_1 = require("downshift");
11
+ const react_2 = require("react");
12
+ const constants_1 = require("@components-core/constants");
13
+ const renderers_1 = require("@components-core/renderers");
14
+ const MultiSelect_module_scss_1 = __importDefault(require("./MultiSelect.module.scss"));
15
+ const container_helpers_1 = require("@components/container-helpers");
16
+ const classnames_1 = __importDefault(require("@components-core/utils/classnames"));
17
+ const input_abstractions_1 = require("@components/Input/input-abstractions");
18
+ const descriptorHelper_1 = require("@components-core/descriptorHelper");
19
+ const themeVars_1 = require("@components-core/theming/themeVars");
20
+ const ThemeContext_1 = require("@components-core/theming/ThemeContext");
21
+ const react_popper_1 = require("react-popper");
22
+ const react_dom_1 = require("react-dom");
23
+ const SelectContext_1 = require("@components/Select/SelectContext");
24
+ const ChevronDownIcon_1 = require("@components/Icon/ChevronDownIcon");
25
+ const ChevronUpIcon_1 = require("@components/Icon/ChevronUpIcon");
26
+ const Icon_1 = __importDefault(require("@components/Icon/Icon"));
27
+ const lodash_es_1 = require("lodash-es");
28
+ const InputAdornment_1 = require("@components/Input/InputAdornment");
29
+ function defaultRenderer(item) {
30
+ return (0, jsx_runtime_1.jsx)("div", { children: item.label });
31
+ }
32
+ function MultiSelect({ id, emptyListTemplate, initialValue = constants_1.EMPTY_ARRAY, value = constants_1.EMPTY_ARRAY, placeholder, updateState = constants_1.noop, onDidChange = constants_1.noop, onFocus = constants_1.noop, onBlur = constants_1.noop, registerComponentApi, validationStatus = "none", enabled = true, optionRenderer = defaultRenderer, children, startText, startIcon, endText, endIcon, }) {
33
+ const [initValue, setInitValue] = (0, react_2.useState)(initialValue);
34
+ const { options, selectContextValue } = (0, SelectContext_1.useSelectContextValue)();
35
+ const [referenceElement, setReferenceElement] = (0, react_2.useState)(null);
36
+ const [popperElement, setPopperElement] = (0, react_2.useState)(null);
37
+ const { styles: popperStyles, attributes } = (0, react_popper_1.usePopper)(referenceElement, popperElement, {
38
+ placement: "bottom-start",
39
+ });
40
+ const { root } = (0, ThemeContext_1.useTheme)();
41
+ const onInputChange = (0, react_2.useCallback)((newValue) => {
42
+ updateState({ value: newValue });
43
+ onDidChange(newValue);
44
+ }, [onDidChange, updateState]);
45
+ const { getSelectedItemProps, getDropdownProps } = (0, downshift_1.useMultipleSelection)({
46
+ onSelectedItemsChange: ({ selectedItems }) => {
47
+ if (selectedItems) {
48
+ onInputChange(selectedItems.map((item) => item.value) || []);
49
+ }
50
+ },
51
+ });
52
+ const items = (0, react_2.useMemo)(() => options.filter((option) => !value.includes(option.value)), [options, value]);
53
+ const { isOpen, selectedItem, getToggleButtonProps, getMenuProps, highlightedIndex, getItemProps, closeMenu } = (0, downshift_1.useSelect)({
54
+ items,
55
+ toggleButtonId: id,
56
+ itemToString(item) {
57
+ return item ? item.label : "";
58
+ },
59
+ isItemDisabled: (item) => item.disabled,
60
+ stateReducer: (state, actionAndChanges) => {
61
+ const { changes, type } = actionAndChanges;
62
+ switch (type) {
63
+ case downshift_1.useSelect.stateChangeTypes.ToggleButtonKeyDownEnter:
64
+ case downshift_1.useSelect.stateChangeTypes.ToggleButtonKeyDownSpaceButton:
65
+ case downshift_1.useSelect.stateChangeTypes.ItemClick:
66
+ return Object.assign(Object.assign({}, changes), { isOpen: true, highlightedIndex: 0 });
67
+ }
68
+ return changes;
69
+ },
70
+ onStateChange: ({ type, selectedItem }) => {
71
+ switch (type) {
72
+ case downshift_1.useSelect.stateChangeTypes.ToggleButtonKeyDownEnter:
73
+ case downshift_1.useSelect.stateChangeTypes.ToggleButtonKeyDownSpaceButton:
74
+ case downshift_1.useSelect.stateChangeTypes.ItemClick:
75
+ case downshift_1.useSelect.stateChangeTypes.ToggleButtonBlur:
76
+ handleOnBlur();
77
+ if (selectedItem) {
78
+ onInputChange([...value, selectedItem.value]);
79
+ closeMenu();
80
+ }
81
+ break;
82
+ case downshift_1.useSelect.stateChangeTypes.ToggleButtonClick:
83
+ handleOnFocus();
84
+ break;
85
+ default:
86
+ break;
87
+ }
88
+ },
89
+ });
90
+ (0, react_2.useEffect)(() => {
91
+ setInitValue((prevState) => {
92
+ if ((0, lodash_es_1.isEqual)(prevState, initialValue)) {
93
+ return prevState;
94
+ }
95
+ return initialValue;
96
+ });
97
+ }, [initialValue]);
98
+ (0, react_2.useEffect)(() => {
99
+ updateState({ value: initValue });
100
+ }, [initValue, updateState]);
101
+ // --- Manage obtaining and losing the focus
102
+ const handleOnFocus = (0, react_2.useCallback)(() => {
103
+ onFocus === null || onFocus === void 0 ? void 0 : onFocus();
104
+ }, [onFocus]);
105
+ const handleOnBlur = (0, react_2.useCallback)(() => {
106
+ onBlur === null || onBlur === void 0 ? void 0 : onBlur();
107
+ }, [onBlur]);
108
+ const focus = (0, react_2.useCallback)(() => {
109
+ referenceElement === null || referenceElement === void 0 ? void 0 : referenceElement.focus();
110
+ }, [referenceElement]);
111
+ (0, react_2.useEffect)(() => {
112
+ registerComponentApi === null || registerComponentApi === void 0 ? void 0 : registerComponentApi({
113
+ focus,
114
+ });
115
+ }, [focus, registerComponentApi]);
116
+ // Sizing the dropdown list width to the reference button size
117
+ const [width, setWidth] = (0, react_2.useState)(0);
118
+ const observer = (0, react_2.useRef)();
119
+ (0, react_2.useEffect)(() => {
120
+ const current = referenceElement;
121
+ // --- We are already observing old element
122
+ if ((observer === null || observer === void 0 ? void 0 : observer.current) && current) {
123
+ observer.current.unobserve(current);
124
+ }
125
+ observer.current = new ResizeObserver(() => referenceElement && setWidth(referenceElement.clientWidth));
126
+ if (current && observer.current) {
127
+ observer.current.observe(referenceElement);
128
+ }
129
+ }, [referenceElement]);
130
+ return ((0, jsx_runtime_1.jsxs)(SelectContext_1.SelectContext.Provider, { value: selectContextValue, children: [children, (0, jsx_runtime_1.jsxs)("div", { className: MultiSelect_module_scss_1.default.multiSelectContainer, children: [(0, jsx_runtime_1.jsxs)("button", Object.assign({ type: "button", disabled: !enabled, className: (0, classnames_1.default)(MultiSelect_module_scss_1.default.selectToggleButton, MultiSelect_module_scss_1.default[validationStatus], {
131
+ [MultiSelect_module_scss_1.default.disabled]: !enabled,
132
+ }) }, getToggleButtonProps(Object.assign({}, getDropdownProps({
133
+ preventKeyAction: isOpen,
134
+ ref: (el) => setReferenceElement(el),
135
+ }))), { children: [(0, jsx_runtime_1.jsxs)("div", { className: MultiSelect_module_scss_1.default.selectedOptions, children: [(0, jsx_runtime_1.jsx)(InputAdornment_1.Adornment, { text: startText, iconName: startIcon, className: MultiSelect_module_scss_1.default.adornment }), value.length === 0 ? ((0, jsx_runtime_1.jsx)("span", { className: MultiSelect_module_scss_1.default.placeholder, children: placeholder })) : (options
136
+ .filter((option) => value.includes(option.value))
137
+ .map(function renderSelectedItem(selectedItemForRender, index) {
138
+ return ((0, jsx_runtime_1.jsxs)("div", Object.assign({ className: MultiSelect_module_scss_1.default.multiValue }, getSelectedItemProps({
139
+ selectedItem: selectedItemForRender,
140
+ index,
141
+ }), { children: [(0, jsx_runtime_1.jsx)("div", { className: MultiSelect_module_scss_1.default.multiValueLabel, children: selectedItemForRender === null || selectedItemForRender === void 0 ? void 0 : selectedItemForRender.label }), (0, jsx_runtime_1.jsx)("div", { role: "button", className: (0, classnames_1.default)(MultiSelect_module_scss_1.default.multiValueRemove, {
142
+ [MultiSelect_module_scss_1.default.disabled]: !enabled,
143
+ }), onClick: (e) => {
144
+ if (enabled) {
145
+ e.stopPropagation();
146
+ onInputChange(value.filter((v) => v !== selectedItemForRender.value));
147
+ }
148
+ }, children: "\u2715" })] }), `selected-item-${index}`));
149
+ }))] }), (0, jsx_runtime_1.jsxs)("div", { style: { display: "flex" }, children: [(0, jsx_runtime_1.jsx)(InputAdornment_1.Adornment, { text: endText, iconName: endIcon, className: MultiSelect_module_scss_1.default.adornment }), (0, jsx_runtime_1.jsx)("span", { "aria-label": "toggle menu", className: MultiSelect_module_scss_1.default.indicator, children: isOpen ? (0, jsx_runtime_1.jsx)(ChevronUpIcon_1.ChevronUpIcon, {}) : (0, jsx_runtime_1.jsx)(ChevronDownIcon_1.ChevronDownIcon, {}) })] })] })), (0, jsx_runtime_1.jsx)("div", Object.assign({}, getMenuProps(), { children: isOpen &&
150
+ root &&
151
+ (0, react_dom_1.createPortal)((0, jsx_runtime_1.jsx)("ul", Object.assign({ className: MultiSelect_module_scss_1.default.selectMenu, ref: (el) => setPopperElement(el), style: Object.assign(Object.assign({}, popperStyles.popper), { width }) }, attributes.popper, { children: items.length > 0 ? (items.map((item, index) => {
152
+ const props = getItemProps({ item, index });
153
+ return ((0, react_1.createElement)("li", Object.assign({}, props, { key: `${item.value}${index}`, className: (0, classnames_1.default)(MultiSelect_module_scss_1.default.item, {
154
+ [MultiSelect_module_scss_1.default.itemActive]: highlightedIndex === index,
155
+ [MultiSelect_module_scss_1.default.itemSelected]: selectedItem === item,
156
+ [MultiSelect_module_scss_1.default.itemDisabled]: item.disabled,
157
+ }) }), optionRenderer(item)));
158
+ })) : ((0, jsx_runtime_1.jsx)("li", { className: MultiSelect_module_scss_1.default.item, children: emptyListTemplate !== null && emptyListTemplate !== void 0 ? emptyListTemplate : ((0, jsx_runtime_1.jsxs)("span", { className: MultiSelect_module_scss_1.default.empty, children: [(0, jsx_runtime_1.jsx)(Icon_1.default, { name: "noresult" }), "List is empty"] })) })) })), root) }))] })] }));
159
+ }
160
+ const defaultOptionRenderer = {
161
+ type: "Text",
162
+ props: {
163
+ value: "{$item.label}",
164
+ },
165
+ };
166
+ const metadata = {
167
+ displayName: "MultiSelect",
168
+ description: "A multi-select dropdown component",
169
+ props: Object.assign(Object.assign({}, input_abstractions_1.inputComponentPropertyDescriptors), { options: (0, descriptorHelper_1.desc)("List of options to display"), optionTemplate: (0, descriptorHelper_1.desc)("Template to render each option") }),
170
+ events: input_abstractions_1.inputComponentEventDescriptors,
171
+ themeVars: (0, themeVars_1.parseScssVar)(MultiSelect_module_scss_1.default.themeVars),
172
+ defaultThemeVars: {
173
+ "color-bg-menu-MultiSelect": "$color-bg-primary",
174
+ "shadow-menu-MultiSelect": "$shadow-md",
175
+ "radius-menu-MultiSelect": "$radius",
176
+ "color-text-value-MultiSelect": "$color-text-primary",
177
+ "color-bg-value-MultiSelect": "$color-bg-primary",
178
+ "color-bg-item-MultiSelect": "$color-bg-dropdown-item",
179
+ "color-bg-item-MultiSelect--hover": "$color-bg-dropdown-item--active",
180
+ light: {
181
+ "color-text-item-MultiSelect--disabled": "$color-surface-200",
182
+ },
183
+ dark: {
184
+ "color-text-item-MultiSelect--disabled": "$color-surface-800",
185
+ },
186
+ },
187
+ };
188
+ exports.multiSelectComponentRenderer = (0, renderers_1.createComponentRenderer)("MultiSelect", ({ node, state, updateState, extractValue, renderChild, lookupEventHandler }) => {
189
+ return ((0, jsx_runtime_1.jsx)(MultiSelect, { placeholder: extractValue(node.props.placeholder), updateState: updateState, enabled: extractValue.asOptionalBoolean(node.props.enabled), initialValue: extractValue.asOptionalStringArray(node.props.initialValue), value: state === null || state === void 0 ? void 0 : state.value, validationStatus: extractValue(node.props.validationStatus), onDidChange: lookupEventHandler("didChange"), onFocus: lookupEventHandler("gotFocus"), onBlur: lookupEventHandler("lostFocus"), emptyListTemplate: renderChild(node.props.emptyListTemplate), startText: extractValue.asOptionalString(node.props.startText), startIcon: extractValue.asOptionalString(node.props.startIcon), endText: extractValue.asOptionalString(node.props.endText), endIcon: extractValue.asOptionalString(node.props.endIcon), optionRenderer: (item) => {
190
+ return ((0, jsx_runtime_1.jsx)(container_helpers_1.MemoizedItem, { node: node.props.optionTemplate || defaultOptionRenderer, item: item, renderChild: renderChild }));
191
+ }, children: renderChild(node.children) }));
192
+ }, metadata);
@@ -0,0 +1,113 @@
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.navGroupComponentRenderer = void 0;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const react_1 = require("react");
9
+ const renderers_1 = require("@components-core/renderers");
10
+ const react_dropdown_menu_1 = require("@radix-ui/react-dropdown-menu");
11
+ const NavGroup_module_scss_1 = __importDefault(require("./NavGroup.module.scss"));
12
+ const Icon_1 = require("@components/Icon/Icon");
13
+ const NavLink_1 = require("@components/NavLink/NavLink");
14
+ const NavLink_module_scss_1 = __importDefault(require("@components/NavLink/NavLink.module.scss"));
15
+ const descriptorHelper_1 = require("@components-core/descriptorHelper");
16
+ const themeVars_1 = require("@components-core/theming/themeVars");
17
+ const AppLayoutContext_1 = require("@components/App/AppLayoutContext");
18
+ const NavPanel_1 = require("@components/NavPanel/NavPanel");
19
+ const constants_1 = require("@components-core/constants");
20
+ const classnames_1 = __importDefault(require("@components-core/utils/classnames"));
21
+ const mergeProps_1 = require("@components-core/utils/mergeProps");
22
+ const ThemeContext_1 = require("@components-core/theming/ThemeContext");
23
+ const NavGroupContext = (0, react_1.createContext)({
24
+ level: -1,
25
+ });
26
+ const NavGroup = (0, react_1.forwardRef)(function NavGroup({ node, style, label, icon, renderChild }, ref) {
27
+ const { level } = (0, react_1.useContext)(NavGroupContext);
28
+ const appLayoutContext = (0, AppLayoutContext_1.useAppLayoutContext)();
29
+ const navPanelContext = (0, react_1.useContext)(NavPanel_1.NavPanelContext);
30
+ let inline = (appLayoutContext === null || appLayoutContext === void 0 ? void 0 : appLayoutContext.layout) === "vertical" ||
31
+ (appLayoutContext === null || appLayoutContext === void 0 ? void 0 : appLayoutContext.layout) === "vertical-sticky" ||
32
+ (appLayoutContext === null || appLayoutContext === void 0 ? void 0 : appLayoutContext.layout) === "vertical-full-header";
33
+ if (navPanelContext !== null) {
34
+ inline = navPanelContext.inDrawer;
35
+ }
36
+ const navGroupContextValue = (0, react_1.useMemo)(() => {
37
+ return {
38
+ level: level + 1,
39
+ };
40
+ }, [level]);
41
+ return ((0, jsx_runtime_1.jsx)(NavGroupContext.Provider, { value: navGroupContextValue, children: inline ? ((0, jsx_runtime_1.jsx)(ExpandableNavGroup, { style: style, label: label, icon: icon, node: node, renderChild: renderChild, ref: ref })) : ((0, jsx_runtime_1.jsx)(DropDownNavGroup, { label: label, icon: icon, node: node, renderChild: renderChild, ref: ref })) }));
42
+ });
43
+ const ExpandableNavGroup = (0, react_1.forwardRef)(function ExpandableNavGroup({ style = constants_1.EMPTY_OBJECT, label, icon, renderChild, node, }, ref) {
44
+ const { level } = (0, react_1.useContext)(NavGroupContext);
45
+ const [expanded, setExpanded] = (0, react_1.useState)(false);
46
+ const toggleStyle = Object.assign(Object.assign({}, style), { paddingLeft: level >= 1 ? (level * 2) + "em" : undefined });
47
+ return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsxs)(NavLink_1.NavLink, { style: toggleStyle, onClick: () => setExpanded((prev) => !prev), icon: icon, children: [label, (0, jsx_runtime_1.jsx)("div", { style: { flex: 1 } }), (0, jsx_runtime_1.jsx)(Icon_1.Icon, { name: expanded ? "chevronup" : "chevrondown" })] }), expanded &&
48
+ renderChild(node.children, {
49
+ wrapChild: ({ node }, renderedChild) => {
50
+ if (node.type === "NavLink") {
51
+ const element = renderedChild;
52
+ return (0, react_1.cloneElement)(element, Object.assign({}, (0, mergeProps_1.mergeProps)(renderedChild.props, {
53
+ style: {
54
+ paddingLeft: ((level + 1) * 2) + "em",
55
+ },
56
+ })));
57
+ }
58
+ return renderedChild;
59
+ },
60
+ })] }));
61
+ });
62
+ const DropDownNavGroup = (0, react_1.forwardRef)(function DropDownNavGroup({ style, label, icon, renderChild, node, }, ref) {
63
+ const { level } = (0, react_1.useContext)(NavGroupContext);
64
+ const { root } = (0, ThemeContext_1.useTheme)();
65
+ let Wrapper = react_dropdown_menu_1.DropdownMenu;
66
+ let Trigger = react_dropdown_menu_1.DropdownMenuTrigger;
67
+ let Content = react_dropdown_menu_1.DropdownMenuContent;
68
+ if (level >= 1) {
69
+ Wrapper = react_dropdown_menu_1.DropdownMenuSub;
70
+ Trigger = react_dropdown_menu_1.DropdownMenuSubTrigger;
71
+ Content = react_dropdown_menu_1.DropdownMenuSubContent;
72
+ }
73
+ return ((0, jsx_runtime_1.jsxs)(Wrapper, { children: [(0, jsx_runtime_1.jsx)(Trigger, { asChild: true, children: (0, jsx_runtime_1.jsx)(NavLink_1.NavLink, { icon: icon, style: { flexShrink: 0 }, vertical: level >= 1, children: (0, jsx_runtime_1.jsx)("span", { className: (0, classnames_1.default)(NavGroup_module_scss_1.default.withNavGroupChevron, {
74
+ [NavGroup_module_scss_1.default.pointRight]: level >= 1
75
+ }), children: label }) }) }), (0, jsx_runtime_1.jsx)(react_dropdown_menu_1.DropdownMenuPortal, { container: root, children: (0, jsx_runtime_1.jsx)(Content, { className: NavGroup_module_scss_1.default.dropdownList, style: { display: "flex", flexDirection: "column" }, side: "bottom", align: "start", children: renderChild(node.children, {
76
+ wrapChild: ({ node }, renderedChild, hints) => {
77
+ if (hints === null || hints === void 0 ? void 0 : hints.opaque) {
78
+ return renderedChild;
79
+ }
80
+ if (node.type === "List") {
81
+ return renderedChild;
82
+ }
83
+ if (node.type === "NavGroup") {
84
+ return renderedChild;
85
+ }
86
+ let child = renderedChild;
87
+ if (node.type === "NavLink") {
88
+ child = (0, react_1.cloneElement)(renderedChild, Object.assign({}, (0, mergeProps_1.mergeProps)(renderedChild.props, {
89
+ vertical: true
90
+ })));
91
+ }
92
+ return (0, jsx_runtime_1.jsx)(react_dropdown_menu_1.DropdownMenuItem, { asChild: true, children: child });
93
+ },
94
+ }) }) })] }));
95
+ });
96
+ const metadata = {
97
+ displayName: "NavGroup",
98
+ description: "Groups related navigation components",
99
+ props: {
100
+ label: (0, descriptorHelper_1.desc)("Specifies the optional text to display in the navigation group. " +
101
+ "If omitted, children can be used to set the group's content."),
102
+ icon: (0, descriptorHelper_1.desc)("Optional icon ID to display the particular icon in the navigation group"),
103
+ },
104
+ themeVars: (0, themeVars_1.parseScssVar)(NavGroup_module_scss_1.default.themeVars),
105
+ defaultThemeVars: {
106
+ "color-bg-dropdown-NavGroup": "$color-bg-primary",
107
+ "radius-dropdown-NavGroup": "$radius",
108
+ "shadow-dropdown-NavGroup": "$shadow-spread"
109
+ }
110
+ };
111
+ exports.navGroupComponentRenderer = (0, renderers_1.createComponentRenderer)("NavGroup", ({ node, extractValue, renderChild }) => {
112
+ return ((0, jsx_runtime_1.jsx)(NavGroup, { label: extractValue.asDisplayText(node.props.label), icon: (0, jsx_runtime_1.jsx)(Icon_1.Icon, { name: extractValue.asString(node.props.icon), className: NavLink_module_scss_1.default.icon }), node: node, renderChild: renderChild }));
113
+ }, metadata);
@@ -0,0 +1,115 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
14
+ return (mod && mod.__esModule) ? mod : { "default": mod };
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.navLinkComponentRenderer = exports.NavLink = void 0;
18
+ const jsx_runtime_1 = require("react/jsx-runtime");
19
+ const react_1 = require("react");
20
+ const NavLink_module_scss_1 = __importDefault(require("./NavLink.module.scss"));
21
+ const react_2 = require("@remix-run/react");
22
+ const classnames_1 = __importDefault(require("@components-core/utils/classnames"));
23
+ const renderers_1 = require("@components-core/renderers");
24
+ const Icon_1 = require("@components/Icon/Icon");
25
+ const descriptorHelper_1 = require("@components-core/descriptorHelper");
26
+ const themeVars_1 = require("@components-core/theming/themeVars");
27
+ const App_1 = require("@components/App/App");
28
+ const AppLayoutContext_1 = require("@components/App/AppLayoutContext");
29
+ const NavPanel_1 = require("@components/NavPanel/NavPanel");
30
+ const component_utils_1 = require("@components/component-utils");
31
+ exports.NavLink = (0, react_1.forwardRef)(function NavLink(_a, ref) {
32
+ var {
33
+ /* eslint-disable react/prop-types */
34
+ uid, children, disabled, to, sx = {}, displayActive = true, vertical, style, onClick, icon, forceActive } = _a, rest = __rest(_a, ["uid", "children", "disabled", "to", "sx", "displayActive", "vertical", "style", "onClick", "icon", "forceActive"]);
35
+ const appLayoutContext = (0, AppLayoutContext_1.useAppLayoutContext)();
36
+ const navPanelContext = (0, react_1.useContext)(NavPanel_1.NavPanelContext);
37
+ let safeVertical = vertical;
38
+ if (appLayoutContext && safeVertical === undefined) {
39
+ safeVertical = (0, App_1.getAppLayoutOrientation)(appLayoutContext.layout) === "vertical" || (navPanelContext === null || navPanelContext === void 0 ? void 0 : navPanelContext.inDrawer);
40
+ }
41
+ const smartTo = (0, react_1.useMemo)(() => {
42
+ if (to) {
43
+ return (0, component_utils_1.createUrlWithQueryParams)(to);
44
+ }
45
+ }, [to]);
46
+ const styleObj = Object.assign(Object.assign({}, sx), style);
47
+ const baseClasses = (0, classnames_1.default)(NavLink_module_scss_1.default.base, {
48
+ [NavLink_module_scss_1.default.disabled]: disabled,
49
+ [NavLink_module_scss_1.default.vertical]: safeVertical,
50
+ [NavLink_module_scss_1.default.includeHoverIndicator]: displayActive,
51
+ [NavLink_module_scss_1.default.navItemActive]: displayActive && forceActive,
52
+ });
53
+ let content;
54
+ if (disabled || !smartTo) {
55
+ content = ((0, jsx_runtime_1.jsxs)("button", Object.assign({}, rest, { ref: ref, onClick: onClick, className: baseClasses, style: styleObj, disabled: disabled, children: [icon, children] })));
56
+ }
57
+ else {
58
+ content = ((0, jsx_runtime_1.jsxs)(react_2.NavLink, Object.assign({ id: uid }, rest, { ref: ref, to: smartTo, style: styleObj, onClick: onClick, className: ({ isActive }) => (0, classnames_1.default)(baseClasses, {
59
+ [NavLink_module_scss_1.default.displayActive]: displayActive,
60
+ [NavLink_module_scss_1.default.navItemActive]: displayActive && (isActive || forceActive),
61
+ }), children: [icon, children] })));
62
+ }
63
+ return content;
64
+ });
65
+ const metadata = {
66
+ displayName: "NavLink",
67
+ description: "Represents a navigation link",
68
+ props: {
69
+ to: (0, descriptorHelper_1.desc)("The target URL"),
70
+ enabled: (0, descriptorHelper_1.desc)("Is the link enabled?"),
71
+ active: (0, descriptorHelper_1.desc)("Indicates if the link is active"),
72
+ target: (0, descriptorHelper_1.desc)("the target type of the link: '_self', '_blank', '_parent', '_top'"),
73
+ label: (0, descriptorHelper_1.desc)("Specifies the optional text to display in the navigation group. " +
74
+ "If omitted, children can be used to set the group's content."),
75
+ vertical: (0, descriptorHelper_1.desc)("Use vertical orientation instead of the default horizontal?"),
76
+ displayActive: (0, descriptorHelper_1.desc)("Allow displaying the active state of this navigation link?"),
77
+ icon: (0, descriptorHelper_1.desc)("Optional icon ID to display the particular icon in the navigation group"),
78
+ },
79
+ events: {
80
+ click: (0, descriptorHelper_1.desc)("Triggers when the button is clicked"),
81
+ },
82
+ themeVars: (0, themeVars_1.parseScssVar)(NavLink_module_scss_1.default.themeVars),
83
+ defaultThemeVars: {
84
+ "radius-NavLink": "$radius",
85
+ "color-bg-NavLink": "transparent",
86
+ "padding-horizontal-NavLink": "$space-4",
87
+ "padding-vertical-NavLink": "$space-2",
88
+ "font-size-NavLink": "$font-size",
89
+ "font-weight-NavLink": "$font-weight-normal",
90
+ "color-text-NavLink": "$color-text-primary",
91
+ "color-icon-NavLink": "$color-text-NavLink",
92
+ "font-weight-NavLink--pressed": "$font-weight-normal",
93
+ "thickness-indicator-NavLink": "$space-0_5",
94
+ "color-outline-NavLink--focus": "$color-outline--focus",
95
+ "thickness-outline-NavLink--focus": "$thickness-outline--focus",
96
+ "style-outline-NavLink--focus": "$style-outline--focus",
97
+ "offset-outline-NavLink--focus": "-1px",
98
+ "radius-indicator-NavLink": "$radius",
99
+ light: {
100
+ "color-indicator-NavLink--active": "$color-primary-500",
101
+ "color-indicator-NavLink--pressed": "$color-primary-500",
102
+ "color-indicator-NavLink--hover": "$color-primary-600",
103
+ },
104
+ dark: {
105
+ "color-indicator-NavLink--active": "$color-primary-500",
106
+ "color-indicator-NavLink--pressed": "$color-primary-500",
107
+ "color-indicator-NavLink--hover": "$color-primary-400",
108
+ }
109
+ },
110
+ };
111
+ exports.navLinkComponentRenderer = (0, renderers_1.createComponentRenderer)("NavLink", ({ node, extractValue, renderChild, layoutCss }) => {
112
+ var _a, _b;
113
+ const iconName = extractValue.asString(node.props.icon);
114
+ return ((0, jsx_runtime_1.jsx)(exports.NavLink, { uid: node.uid, to: extractValue(node.props.to), disabled: !extractValue.asOptionalBoolean((_a = node.props.enabled) !== null && _a !== void 0 ? _a : true), vertical: extractValue.asOptionalBoolean(node.props.vertical), displayActive: extractValue.asOptionalBoolean(node.props.displayActive), forceActive: extractValue.asOptionalBoolean(node.props.active), style: layoutCss, target: extractValue((_b = node.props) === null || _b === void 0 ? void 0 : _b.target), icon: (0, jsx_runtime_1.jsx)(Icon_1.Icon, { name: iconName, className: NavLink_module_scss_1.default.icon }), children: extractValue.asDisplayText(node.props.label) || renderChild(node.children) }));
115
+ }, metadata);
@@ -0,0 +1,101 @@
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 (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.navPanelRenderer = exports.NavPanelContext = void 0;
30
+ const jsx_runtime_1 = require("react/jsx-runtime");
31
+ const react_1 = __importStar(require("react"));
32
+ const NavPanel_module_scss_1 = __importDefault(require("./NavPanel.module.scss"));
33
+ const renderers_1 = require("@components-core/renderers");
34
+ const classnames_1 = __importDefault(require("@components-core/utils/classnames"));
35
+ const Logo_1 = require("@components/Logo/Logo");
36
+ const ScrollContext_1 = require("@components-core/ScrollContext");
37
+ const themeVars_1 = require("@components-core/theming/themeVars");
38
+ const base_utils_1 = require("@components-core/theming/themes/base-utils");
39
+ const AppLayoutContext_1 = require("@components/App/AppLayoutContext");
40
+ const react_dom_1 = require("react-dom");
41
+ const App_1 = require("@components/App/App");
42
+ const hooks_1 = require("@components-core/utils/hooks");
43
+ exports.NavPanelContext = react_1.default.createContext(null);
44
+ const contextValue = {
45
+ inDrawer: true,
46
+ };
47
+ function DrawerNavPanel({ logoContent, children, className, style, }) {
48
+ const scrollContainerRef = (0, react_1.useRef)(null);
49
+ return ((0, jsx_runtime_1.jsx)(exports.NavPanelContext.Provider, { value: contextValue, children: (0, jsx_runtime_1.jsx)("div", { ref: scrollContainerRef, className: (0, classnames_1.default)(NavPanel_module_scss_1.default.wrapper, className), children: (0, jsx_runtime_1.jsxs)(ScrollContext_1.ScrollContext.Provider, { value: scrollContainerRef, children: [(0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)(NavPanel_module_scss_1.default.logoWrapper, NavPanel_module_scss_1.default.inDrawer), children: logoContent || (0, jsx_runtime_1.jsx)(Logo_1.Logo, { inDrawer: true }) }), (0, jsx_runtime_1.jsx)("div", { className: NavPanel_module_scss_1.default.wrapperInner, style: style, children: children })] }) }) }));
50
+ }
51
+ function NavPanel({ children, style, logoContent, className, }) {
52
+ const id = (0, react_1.useId)();
53
+ const scrollContainerRef = (0, react_1.useRef)(null);
54
+ const appLayoutContext = (0, AppLayoutContext_1.useAppLayoutContext)();
55
+ const horizontal = (0, App_1.getAppLayoutOrientation)(appLayoutContext === null || appLayoutContext === void 0 ? void 0 : appLayoutContext.layout) === "horizontal";
56
+ const showLogo = (appLayoutContext === null || appLayoutContext === void 0 ? void 0 : appLayoutContext.layout) === "vertical" || (appLayoutContext === null || appLayoutContext === void 0 ? void 0 : appLayoutContext.layout) === "vertical-sticky";
57
+ const registered = (0, react_1.useRef)(false);
58
+ (0, hooks_1.useIsomorphicLayoutEffect)(() => {
59
+ if (!appLayoutContext || registered.current) {
60
+ return;
61
+ }
62
+ appLayoutContext.registerNavPanel(id);
63
+ registered.current = true;
64
+ return () => {
65
+ registered.current = false;
66
+ appLayoutContext.unregisterNavPanel(id);
67
+ };
68
+ }, [appLayoutContext, id]);
69
+ if (appLayoutContext) {
70
+ const { navPanelRoot, navPanelVisible, drawerVisible, drawerRoot } = appLayoutContext;
71
+ return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [navPanelRoot &&
72
+ navPanelVisible &&
73
+ (0, react_dom_1.createPortal)((0, jsx_runtime_1.jsx)("div", { ref: scrollContainerRef, className: (0, classnames_1.default)(NavPanel_module_scss_1.default.wrapper, className, {
74
+ [NavPanel_module_scss_1.default.horizontal]: horizontal,
75
+ }), children: (0, jsx_runtime_1.jsxs)(ScrollContext_1.ScrollContext.Provider, { value: scrollContainerRef, children: [showLogo && (0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)(NavPanel_module_scss_1.default.logoWrapper), children: logoContent || (0, jsx_runtime_1.jsx)(Logo_1.Logo, {}) }), (0, jsx_runtime_1.jsx)("div", { className: NavPanel_module_scss_1.default.wrapperInner, style: style, children: children })] }) }), navPanelRoot), drawerRoot &&
76
+ drawerVisible &&
77
+ (0, react_dom_1.createPortal)((0, jsx_runtime_1.jsx)(DrawerNavPanel, { className: className, style: style, logoContent: logoContent, children: children }), drawerRoot)] }));
78
+ }
79
+ return ((0, jsx_runtime_1.jsx)("div", { ref: scrollContainerRef, className: (0, classnames_1.default)(NavPanel_module_scss_1.default.wrapper, className, {
80
+ [NavPanel_module_scss_1.default.horizontal]: horizontal,
81
+ }), children: (0, jsx_runtime_1.jsxs)(ScrollContext_1.ScrollContext.Provider, { value: scrollContainerRef, children: [showLogo && (0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)(NavPanel_module_scss_1.default.logoWrapper), children: logoContent || (0, jsx_runtime_1.jsx)(Logo_1.Logo, {}) }), (0, jsx_runtime_1.jsx)("div", { className: NavPanel_module_scss_1.default.wrapperInner, style: style, children: children })] }) }));
82
+ }
83
+ const metadata = {
84
+ displayName: "NavPanel",
85
+ description: "Display an avatar associated with an entity",
86
+ props: {
87
+ logoTemplate: {
88
+ description: "Optional logo template for the navigation panel. " + "It may be different than the one used for the app",
89
+ valueType: "ComponentDef",
90
+ },
91
+ },
92
+ themeVars: (0, themeVars_1.parseScssVar)(NavPanel_module_scss_1.default.themeVars),
93
+ defaultThemeVars: Object.assign(Object.assign({ "color-bg-NavPanel": "transparent" }, (0, base_utils_1.borderSubject)("NavPanel", {})), { "padding-horizontal-NavPanel": "$space-4", "padding-vertical-logo-NavPanel": "$space-4", "padding-horizontal-logo-NavPanel": "$space-4", "margin-bottom-logo-NavPanel": "$space-4", light: {
94
+ "shadow-NavPanel-vertical": "4px 0 4px 0 rgb(0 0 0 / 10%)",
95
+ }, dark: {
96
+ "shadow-NavPanel-vertical": "4px 0 6px 0 rgba(0, 0, 0, 0.2)",
97
+ } }),
98
+ };
99
+ exports.navPanelRenderer = (0, renderers_1.createComponentRenderer)("NavPanel", ({ node, renderChild, layoutCss, layoutContext }) => {
100
+ return ((0, jsx_runtime_1.jsx)(NavPanel, { style: layoutCss, logoContent: renderChild(node.props.logoTemplate) || (layoutContext === null || layoutContext === void 0 ? void 0 : layoutContext.logoContent), className: layoutContext === null || layoutContext === void 0 ? void 0 : layoutContext.themeClassName, children: renderChild(node.children) }));
101
+ }, metadata);
@@ -0,0 +1,39 @@
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.noResultComponentRenderer = void 0;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const Icon_1 = require("@components/Icon/Icon");
9
+ const NoResult_module_scss_1 = __importDefault(require("./NoResult.module.scss"));
10
+ const renderers_1 = require("@components-core/renderers");
11
+ const descriptorHelper_1 = require("@components-core/descriptorHelper");
12
+ const themeVars_1 = require("@components-core/theming/themeVars");
13
+ const NoResult = ({ label, icon, hideIcon = false, style }) => {
14
+ return ((0, jsx_runtime_1.jsxs)("div", { className: NoResult_module_scss_1.default.wrapper, style: style, children: [!hideIcon && (0, jsx_runtime_1.jsx)(Icon_1.Icon, { name: icon !== null && icon !== void 0 ? icon : "noResult", className: NoResult_module_scss_1.default.icon }), label] }));
15
+ };
16
+ const metadata = {
17
+ displayName: "NoResult",
18
+ description: "Component representing a date fetch result with an empty result set",
19
+ props: {
20
+ label: (0, descriptorHelper_1.desc)("Optional label to display"),
21
+ icon: (0, descriptorHelper_1.desc)("Optional icon ID to display"),
22
+ hideIcon: (0, descriptorHelper_1.desc)("Indicates if the icon should be hidden"),
23
+ },
24
+ themeVars: (0, themeVars_1.parseScssVar)(NoResult_module_scss_1.default.themeVars),
25
+ defaultThemeVars: {
26
+ "padding-vertical-NoResult": "$space-2",
27
+ "gap-icon-NoResult": "$space-2",
28
+ "size-icon-NoResult": "$space-8",
29
+ light: {
30
+ // --- No light-specific theme vars
31
+ },
32
+ dark: {
33
+ // --- No dark-specific theme vars
34
+ },
35
+ },
36
+ };
37
+ exports.noResultComponentRenderer = (0, renderers_1.createComponentRenderer)("NoResult", ({ node, extractValue, layoutCss }) => {
38
+ return ((0, jsx_runtime_1.jsx)(NoResult, { label: extractValue.asDisplayText(node.props.label || node.children || "No results found"), icon: node.props.icon, hideIcon: extractValue.asOptionalBoolean(node.props.hideIcon), style: layoutCss }));
39
+ }, metadata);