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.
- package/dist/Pdf-DeGhSMXe.mjs +19537 -0
- package/dist/Pdf.css +1 -0
- package/dist/apiInterceptorWorker-CwuUhYyc.mjs +9229 -0
- package/dist/array-USo-Szhp.mjs +12 -0
- package/dist/index-C24dkfpd.mjs +1434 -0
- package/dist/index-ao27SnVp.mjs +145185 -0
- package/dist/index.css +1 -0
- package/dist/nivo-bar.es-CWh0ZlxB.mjs +1666 -0
- package/dist/nivo-geo.es-BTqNt5Db.mjs +1579 -0
- package/dist/nivo-legends.es-BuIxHGSU.mjs +6916 -0
- package/dist/nivo-pie.es-BvCBFA0L.mjs +700 -0
- package/dist/react-apexcharts.min-DqWuDOyO.mjs +8881 -0
- package/dist/scripts/bin/bootstrap.js +11 -0
- package/dist/scripts/bin/build.js +256 -0
- package/dist/scripts/bin/index.js +88 -0
- package/dist/scripts/bin/preview.js +27 -0
- package/dist/scripts/bin/start.js +41 -0
- package/dist/scripts/bin/vite-ueml-plugin.js +113 -0
- package/dist/scripts/bin/viteConfig.js +112 -0
- package/dist/scripts/src/abstractions/ActionDefs.js +2 -0
- package/dist/scripts/src/abstractions/AppContextDefs.js +2 -0
- package/dist/scripts/src/abstractions/BlockScope.js +4 -0
- package/dist/scripts/src/abstractions/ComponentDefs.js +2 -0
- package/dist/scripts/src/abstractions/ComponentDescriptorDefs.js +2 -0
- package/dist/scripts/src/abstractions/ContainerDefs.js +2 -0
- package/dist/scripts/src/abstractions/FunctionDefs.js +2 -0
- package/dist/scripts/src/abstractions/RendererDefs.js +2 -0
- package/dist/scripts/src/abstractions/scripting/ScriptParserError.js +2 -0
- package/dist/scripts/src/abstractions/scripting/ScriptingSourceTree.js +2 -0
- package/dist/scripts/src/abstractions/scripting/Token.js +110 -0
- package/dist/scripts/src/components/App/App.js +253 -0
- package/dist/scripts/src/components/App/AppLayoutContext.js +9 -0
- package/dist/scripts/src/components/App/AppStateContext.js +9 -0
- package/dist/scripts/src/components/App/Sheet.js +89 -0
- package/dist/scripts/src/components/AppHeader/AppHeader.js +121 -0
- package/dist/scripts/src/components/AppState/AppState.js +29 -0
- package/dist/scripts/src/components/Avatar/Avatar.js +81 -0
- package/dist/scripts/src/components/Badge/Badge.js +56 -0
- package/dist/scripts/src/components/BarChart/BarChart.js +199 -0
- package/dist/scripts/src/components/Bookmark/Bookmark.js +11 -0
- package/dist/scripts/src/components/Button/Button.js +196 -0
- package/dist/scripts/src/components/Card/Card.js +65 -0
- package/dist/scripts/src/components/ChangeListener/ChangeListener.js +43 -0
- package/dist/scripts/src/components/Chart/Chart.js +158 -0
- package/dist/scripts/src/components/Checkbox/Checkbox.js +43 -0
- package/dist/scripts/src/components/Combobox/Combobox.js +145 -0
- package/dist/scripts/src/components/ComponentProvider.js +357 -0
- package/dist/scripts/src/components/ContentSeparator/ContentSeparator.js +40 -0
- package/dist/scripts/src/components/DatePicker/DatePicker.js +196 -0
- package/dist/scripts/src/components/DropdownMenu/DropdownMenu.js +175 -0
- package/dist/scripts/src/components/EmojiSelector/EmojiSelector.js +56 -0
- package/dist/scripts/src/components/FileInput/FileInput.js +127 -0
- package/dist/scripts/src/components/FileUploadDropZone/FileUploadDropZone.js +106 -0
- package/dist/scripts/src/components/FlowLayout/FlowLayout.js +139 -0
- package/dist/scripts/src/components/Footer/Footer.js +42 -0
- package/dist/scripts/src/components/Form/Form.js +320 -0
- package/dist/scripts/src/components/Form/FormContext.js +9 -0
- package/dist/scripts/src/components/Form/formActions.js +86 -0
- package/dist/scripts/src/components/FormItem/FormItem.js +204 -0
- package/dist/scripts/src/components/FormItem/HelperText.js +27 -0
- package/dist/scripts/src/components/FormItem/ItemWithLabel.js +39 -0
- package/dist/scripts/src/components/FormItem/Validations.js +346 -0
- package/dist/scripts/src/components/FormSection/FormSection.js +45 -0
- package/dist/scripts/src/components/Heading/Heading.js +206 -0
- package/dist/scripts/src/components/HoverCard/HoverCard.js +45 -0
- package/dist/scripts/src/components/Icon/ApiIcon.js +10 -0
- package/dist/scripts/src/components/Icon/Attach.js +10 -0
- package/dist/scripts/src/components/Icon/Binding.js +11 -0
- package/dist/scripts/src/components/Icon/BoardIcon.js +7 -0
- package/dist/scripts/src/components/Icon/BoxIcon.js +10 -0
- package/dist/scripts/src/components/Icon/CheckIcon.js +7 -0
- package/dist/scripts/src/components/Icon/ChevronDownIcon.js +7 -0
- package/dist/scripts/src/components/Icon/ChevronLeft.js +7 -0
- package/dist/scripts/src/components/Icon/ChevronRight.js +7 -0
- package/dist/scripts/src/components/Icon/ChevronUpIcon.js +7 -0
- package/dist/scripts/src/components/Icon/CodeFileIcon.js +10 -0
- package/dist/scripts/src/components/Icon/CodeSandbox.js +10 -0
- package/dist/scripts/src/components/Icon/CompactListIcon.js +7 -0
- package/dist/scripts/src/components/Icon/ContentCopyIcon.js +7 -0
- package/dist/scripts/src/components/Icon/DatabaseIcon.js +11 -0
- package/dist/scripts/src/components/Icon/DocFileIcon.js +10 -0
- package/dist/scripts/src/components/Icon/DocIcon.js +10 -0
- package/dist/scripts/src/components/Icon/DotMenuHorizontalIcon.js +7 -0
- package/dist/scripts/src/components/Icon/DotMenuIcon.js +7 -0
- package/dist/scripts/src/components/Icon/EmailIcon.js +7 -0
- package/dist/scripts/src/components/Icon/EmptyFolderIcon.js +10 -0
- package/dist/scripts/src/components/Icon/ErrorIcon.js +7 -0
- package/dist/scripts/src/components/Icon/ExpressionIcon.js +10 -0
- package/dist/scripts/src/components/Icon/FillPlusCricleIcon.js +7 -0
- package/dist/scripts/src/components/Icon/FilterIcon.js +10 -0
- package/dist/scripts/src/components/Icon/FolderIcon.js +10 -0
- package/dist/scripts/src/components/Icon/GlobeIcon.js +7 -0
- package/dist/scripts/src/components/Icon/HomeIcon.js +7 -0
- package/dist/scripts/src/components/Icon/HyperLinkIcon.js +7 -0
- package/dist/scripts/src/components/Icon/Icon.js +101 -0
- package/dist/scripts/src/components/Icon/ImageFileIcon.js +10 -0
- package/dist/scripts/src/components/Icon/LinkIcon.js +7 -0
- package/dist/scripts/src/components/Icon/ListIcon.js +7 -0
- package/dist/scripts/src/components/Icon/LooseListIcon.js +7 -0
- package/dist/scripts/src/components/Icon/MoonIcon.js +10 -0
- package/dist/scripts/src/components/Icon/MoreOptionsIcon.js +7 -0
- package/dist/scripts/src/components/Icon/PDFIcon.js +10 -0
- package/dist/scripts/src/components/Icon/PenIcon.js +7 -0
- package/dist/scripts/src/components/Icon/PhoneIcon.js +7 -0
- package/dist/scripts/src/components/Icon/PhotoIcon.js +10 -0
- package/dist/scripts/src/components/Icon/PlusIcon.js +7 -0
- package/dist/scripts/src/components/Icon/SearchIcon.js +7 -0
- package/dist/scripts/src/components/Icon/ShareIcon.js +10 -0
- package/dist/scripts/src/components/Icon/SunIcon.js +10 -0
- package/dist/scripts/src/components/Icon/TrashIcon.js +7 -0
- package/dist/scripts/src/components/Icon/TxtIcon.js +10 -0
- package/dist/scripts/src/components/Icon/UnknownFileIcon.js +10 -0
- package/dist/scripts/src/components/Icon/UnlinkIcon.js +10 -0
- package/dist/scripts/src/components/Icon/UserIcon.js +7 -0
- package/dist/scripts/src/components/Icon/WarningIcon.js +7 -0
- package/dist/scripts/src/components/Icon/XlsIcon.js +10 -0
- package/dist/scripts/src/components/IconProvider.js +249 -0
- package/dist/scripts/src/components/IconRegistryContext.js +307 -0
- package/dist/scripts/src/components/Image/Image.js +34 -0
- package/dist/scripts/src/components/Input/InputAdornment.js +14 -0
- package/dist/scripts/src/components/Input/input-abstractions.js +44 -0
- package/dist/scripts/src/components/Items/Items.js +48 -0
- package/dist/scripts/src/components/Link/Link.js +72 -0
- package/dist/scripts/src/components/List/List.js +442 -0
- package/dist/scripts/src/components/Logo/Logo.js +25 -0
- package/dist/scripts/src/components/Map/Map.js +60 -0
- package/dist/scripts/src/components/Map/world_countries.json +45307 -0
- package/dist/scripts/src/components/Markdown/Markdown.js +120 -0
- package/dist/scripts/src/components/ModalDialog/ConfirmationModalContextProvider.js +106 -0
- package/dist/scripts/src/components/ModalDialog/Dialog.js +20 -0
- package/dist/scripts/src/components/ModalDialog/ModalDialog.js +145 -0
- package/dist/scripts/src/components/MultiCombobox/MultiCombobox.js +249 -0
- package/dist/scripts/src/components/MultiSelect/MultiSelect.js +192 -0
- package/dist/scripts/src/components/NavGroup/NavGroup.js +113 -0
- package/dist/scripts/src/components/NavLink/NavLink.js +115 -0
- package/dist/scripts/src/components/NavPanel/NavPanel.js +101 -0
- package/dist/scripts/src/components/NoResult/NoResult.js +39 -0
- package/dist/scripts/src/components/NumberBox/NumberBox.js +373 -0
- package/dist/scripts/src/components/Option/Option.js +41 -0
- package/dist/scripts/src/components/PageMetaTitle/PageMetaTitle.js +22 -0
- package/dist/scripts/src/components/Pages/Pages.js +74 -0
- package/dist/scripts/src/components/Pdf/LazyPdf.js +44 -0
- package/dist/scripts/src/components/Pdf/Pdf.js +19 -0
- package/dist/scripts/src/components/PieChart/PieChart.js +184 -0
- package/dist/scripts/src/components/PositionedContainer/PositionedContainer.js +29 -0
- package/dist/scripts/src/components/ProgressBar/ProgressBar.js +38 -0
- package/dist/scripts/src/components/Queue/Queue.js +286 -0
- package/dist/scripts/src/components/Queue/queueActions.js +87 -0
- package/dist/scripts/src/components/RadioGroup/RadioGroup.js +144 -0
- package/dist/scripts/src/components/RealTimeAdapter/RealTimeAdapter.js +147 -0
- package/dist/scripts/src/components/Redirect/Redirect.js +10 -0
- package/dist/scripts/src/components/Select/Select.js +139 -0
- package/dist/scripts/src/components/Select/SelectContext.js +45 -0
- package/dist/scripts/src/components/SelectionStore/SelectionStore.js +88 -0
- package/dist/scripts/src/components/SpaceFiller/SpaceFiller.js +22 -0
- package/dist/scripts/src/components/Spinner/Spinner.js +59 -0
- package/dist/scripts/src/components/Splitter/Splitter.js +205 -0
- package/dist/scripts/src/components/Splitter/utils.js +17 -0
- package/dist/scripts/src/components/Stack/Stack.js +117 -0
- package/dist/scripts/src/components/StickyBox/StickyBox.js +33 -0
- package/dist/scripts/src/components/Switch/Switch.js +50 -0
- package/dist/scripts/src/components/Table/Table.js +499 -0
- package/dist/scripts/src/components/Table/useRowSelection.js +169 -0
- package/dist/scripts/src/components/TableColumnDef/TableColumnDef.js +44 -0
- package/dist/scripts/src/components/TableColumnDef/TableContext.js +12 -0
- package/dist/scripts/src/components/Tabs/Tabs.js +85 -0
- package/dist/scripts/src/components/Text/Text.js +175 -0
- package/dist/scripts/src/components/TextArea/TextArea.js +194 -0
- package/dist/scripts/src/components/TextArea/TextAreaResizable.js +63 -0
- package/dist/scripts/src/components/TextArea/useComposedRef.js +50 -0
- package/dist/scripts/src/components/TextBox/TextBox.js +145 -0
- package/dist/scripts/src/components/Theme/NotificationToast.js +39 -0
- package/dist/scripts/src/components/Theme/Theme.js +153 -0
- package/dist/scripts/src/components/ThemeChanger/ThemeChanger.js +125 -0
- package/dist/scripts/src/components/Toggle/Toggle.js +88 -0
- package/dist/scripts/src/components/Tree/TreeComponent.js +79 -0
- package/dist/scripts/src/components/ValidationSummary/ValidationSummary.js +59 -0
- package/dist/scripts/src/components/ViewComponentRegistryContext.js +34 -0
- package/dist/scripts/src/components/abstractions.js +2 -0
- package/dist/scripts/src/components/chart-color-schemes.js +43 -0
- package/dist/scripts/src/components/component-utils.js +32 -0
- package/dist/scripts/src/components/container-helpers.js +18 -0
- package/dist/scripts/src/components-core/ApiBoundComponent.js +189 -0
- package/dist/scripts/src/components-core/AppContext.js +17 -0
- package/dist/scripts/src/components-core/ChildrenSlot.js +10 -0
- package/dist/scripts/src/components-core/Component.js +280 -0
- package/dist/scripts/src/components-core/ComponentDecorator.js +63 -0
- package/dist/scripts/src/components-core/CompoundComponent.js +132 -0
- package/dist/scripts/src/components-core/EngineError.js +91 -0
- package/dist/scripts/src/components-core/ErrorBoundary.js +58 -0
- package/dist/scripts/src/components-core/Fragment.js +14 -0
- package/dist/scripts/src/components-core/InvalidComponent.js +15 -0
- package/dist/scripts/src/components-core/LoaderComponent.js +78 -0
- package/dist/scripts/src/components-core/RestApiProxy.js +341 -0
- package/dist/scripts/src/components-core/RootComponent.js +272 -0
- package/dist/scripts/src/components-core/RouteContext.js +45 -0
- package/dist/scripts/src/components-core/ScrollContext.js +9 -0
- package/dist/scripts/src/components-core/UnknownComponent.js +15 -0
- package/dist/scripts/src/components-core/abstractions/ComponentRenderer.js +2 -0
- package/dist/scripts/src/components-core/abstractions/LoaderRenderer.js +2 -0
- package/dist/scripts/src/components-core/abstractions/containers.js +18 -0
- package/dist/scripts/src/components-core/abstractions/treeAbstractions.js +2 -0
- package/dist/scripts/src/components-core/action/ApiAction.js +276 -0
- package/dist/scripts/src/components-core/action/DownloadFileAction.js +80 -0
- package/dist/scripts/src/components-core/action/NavigateAction.js +20 -0
- package/dist/scripts/src/components-core/action/TimedAction.js +21 -0
- package/dist/scripts/src/components-core/action/UploadAction.js +88 -0
- package/dist/scripts/src/components-core/action/actions.js +15 -0
- package/dist/scripts/src/components-core/appContext/date-functions.js +19 -0
- package/dist/scripts/src/components-core/appContext/misc-utils.js +12 -0
- package/dist/scripts/src/components-core/component-hooks.js +25 -0
- package/dist/scripts/src/components-core/constants.js +18 -0
- package/dist/scripts/src/components-core/container/Container.js +1110 -0
- package/dist/scripts/src/components-core/container/ContainerComponentDef.js +16 -0
- package/dist/scripts/src/components-core/container/buildProxy.js +54 -0
- package/dist/scripts/src/components-core/container/collectFnVarDeps.js +26 -0
- package/dist/scripts/src/components-core/container/valueExtractor.js +195 -0
- package/dist/scripts/src/components-core/descriptorHelper.js +75 -0
- package/dist/scripts/src/components-core/interception/abstractions.js +2 -0
- package/dist/scripts/src/components-core/interception/useApiInterceptorContext.js +9 -0
- package/dist/scripts/src/components-core/loader/ApiLoader.js +46 -0
- package/dist/scripts/src/components-core/loader/DataLoader.js +160 -0
- package/dist/scripts/src/components-core/loader/ExternalDataLoader.js +52 -0
- package/dist/scripts/src/components-core/loader/Loader.js +115 -0
- package/dist/scripts/src/components-core/loader/MockLoaderRenderer.js +32 -0
- package/dist/scripts/src/components-core/loader/PageableLoader.js +240 -0
- package/dist/scripts/src/components-core/renderers.js +45 -0
- package/dist/scripts/src/components-core/reportEngineError.js +59 -0
- package/dist/scripts/src/components-core/script-runner/BindingTreeEvaluationContext.js +35 -0
- package/dist/scripts/src/components-core/script-runner/ICustomOperations.js +34 -0
- package/dist/scripts/src/components-core/script-runner/LogicalThread.js +2 -0
- package/dist/scripts/src/components-core/script-runner/LoopScope.js +2 -0
- package/dist/scripts/src/components-core/script-runner/ParameterParser.js +117 -0
- package/dist/scripts/src/components-core/script-runner/TryScope.js +2 -0
- package/dist/scripts/src/components-core/script-runner/asyncProxy.js +96 -0
- package/dist/scripts/src/components-core/script-runner/bannedFunctions.js +34 -0
- package/dist/scripts/src/components-core/script-runner/custom-operations-registry.js +40 -0
- package/dist/scripts/src/components-core/script-runner/custom-ui-data.js +40 -0
- package/dist/scripts/src/components-core/script-runner/eval-tree-async.js +551 -0
- package/dist/scripts/src/components-core/script-runner/eval-tree-common.js +498 -0
- package/dist/scripts/src/components-core/script-runner/eval-tree-sync.js +434 -0
- package/dist/scripts/src/components-core/script-runner/modules.js +250 -0
- package/dist/scripts/src/components-core/script-runner/process-statement-async.js +818 -0
- package/dist/scripts/src/components-core/script-runner/process-statement-common.js +193 -0
- package/dist/scripts/src/components-core/script-runner/process-statement-sync.js +740 -0
- package/dist/scripts/src/components-core/script-runner/statement-queue.js +62 -0
- package/dist/scripts/src/components-core/script-runner/visitors.js +352 -0
- package/dist/scripts/src/components-core/theming/ThemeContext.js +43 -0
- package/dist/scripts/src/components-core/theming/ThemeProvider.js +334 -0
- package/dist/scripts/src/components-core/theming/abstractions.js +11 -0
- package/dist/scripts/src/components-core/theming/extendThemeUtils.js +114 -0
- package/dist/scripts/src/components-core/theming/hvar.js +105 -0
- package/dist/scripts/src/components-core/theming/themeVars.js +62 -0
- package/dist/scripts/src/components-core/theming/themes/base-utils.js +31 -0
- package/dist/scripts/src/components-core/theming/themes/palette.js +53 -0
- package/dist/scripts/src/components-core/theming/themes/root.js +257 -0
- package/dist/scripts/src/components-core/theming/themes/solid.js +16 -0
- package/dist/scripts/src/components-core/theming/themes/theme-colors.js +407 -0
- package/dist/scripts/src/components-core/theming/themes/xmlui.js +32 -0
- package/dist/scripts/src/components-core/theming/transformThemeVars.js +286 -0
- package/dist/scripts/src/components-core/utils/DataLoaderQueryKeyGenerator.js +34 -0
- package/dist/scripts/src/components-core/utils/LruCache.js +184 -0
- package/dist/scripts/src/components-core/utils/actionUtils.js +32 -0
- package/dist/scripts/src/components-core/utils/classnames.js +58 -0
- package/dist/scripts/src/components-core/utils/css-utils.js +127 -0
- package/dist/scripts/src/components-core/utils/date-utils.js +78 -0
- package/dist/scripts/src/components-core/utils/extractParam.js +148 -0
- package/dist/scripts/src/components-core/utils/hooks.js +221 -0
- package/dist/scripts/src/components-core/utils/mergeProps.js +45 -0
- package/dist/scripts/src/components-core/utils/misc.js +460 -0
- package/dist/scripts/src/components-core/utils/statementUtils.js +205 -0
- package/dist/scripts/src/components-core/utils/treeUtils.js +48 -0
- package/dist/scripts/src/components-core/xmlui-parser.js +52 -0
- package/dist/scripts/src/parsers/scripting/InputStream.js +59 -0
- package/dist/scripts/src/parsers/scripting/Lexer.js +1028 -0
- package/dist/scripts/src/parsers/scripting/Parser.js +2647 -0
- package/dist/scripts/src/parsers/scripting/ParserError.js +46 -0
- package/dist/scripts/src/parsers/scripting/TokenTrait.js +109 -0
- package/dist/scripts/src/parsers/scripting/code-behind-collect.js +118 -0
- package/dist/scripts/src/parsers/scripting/tree-visitor.js +602 -0
- package/dist/scripts/src/parsers/style-parser/StyleInputStream.js +39 -0
- package/dist/scripts/src/parsers/style-parser/StyleLexer.js +621 -0
- package/dist/scripts/src/parsers/style-parser/StyleParser.js +1000 -0
- package/dist/scripts/src/parsers/style-parser/errors.js +37 -0
- package/dist/scripts/src/parsers/style-parser/source-tree.js +2 -0
- package/dist/scripts/src/parsers/style-parser/style-compiler.js +513 -0
- package/dist/scripts/src/parsers/style-parser/tokens.js +42 -0
- package/dist/scripts/src/parsers/ueml/ParserError.js +54 -0
- package/dist/scripts/src/parsers/ueml/UemlHelper.js +579 -0
- package/dist/scripts/src/parsers/ueml/UemlInputStream.js +59 -0
- package/dist/scripts/src/parsers/ueml/UemlLexer.js +868 -0
- package/dist/scripts/src/parsers/ueml/UemlParser.js +1439 -0
- package/dist/scripts/src/parsers/ueml/UemlToken.js +24 -0
- package/dist/scripts/src/parsers/ueml/fileExtensions.js +6 -0
- package/dist/scripts/src/parsers/ueml/source-tree.js +2 -0
- package/dist/scripts/src/parsers/ueml/ueml-tree.js +2 -0
- package/dist/scripts/src/parsers/xmlui-parser/CharacterCodes.js +136 -0
- package/dist/scripts/src/parsers/xmlui-parser/diagnostics.js +100 -0
- package/dist/scripts/src/parsers/xmlui-parser/parser.js +476 -0
- package/dist/scripts/src/parsers/xmlui-parser/scanner.js +415 -0
- package/dist/scripts/src/parsers/xmlui-parser/syntax-kind.js +106 -0
- package/dist/scripts/src/parsers/xmlui-parser/syntax-node.js +2 -0
- package/dist/scripts/src/parsers/xmlui-parser/transform.js +922 -0
- package/dist/scripts/src/parsers/xmlui-parser/utils.js +83 -0
- package/dist/xmlui.es.d.ts +1667 -0
- package/dist/xmlui.es.js +17 -0
- package/dist/xmlui.umd.js +1589 -0
- package/package.json +175 -0
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TokenType = void 0;
|
|
4
|
+
// Token types available for parsing
|
|
5
|
+
var TokenType;
|
|
6
|
+
(function (TokenType) {
|
|
7
|
+
TokenType[TokenType["Eof"] = -1] = "Eof";
|
|
8
|
+
TokenType[TokenType["Ws"] = -2] = "Ws";
|
|
9
|
+
TokenType[TokenType["BlockComment"] = -3] = "BlockComment";
|
|
10
|
+
TokenType[TokenType["EolComment"] = -4] = "EolComment";
|
|
11
|
+
TokenType[TokenType["Unknown"] = 0] = "Unknown";
|
|
12
|
+
// --- Binding Expression specific tokens
|
|
13
|
+
TokenType[TokenType["LParent"] = 1] = "LParent";
|
|
14
|
+
TokenType[TokenType["RParent"] = 2] = "RParent";
|
|
15
|
+
TokenType[TokenType["Identifier"] = 3] = "Identifier";
|
|
16
|
+
TokenType[TokenType["Exponent"] = 4] = "Exponent";
|
|
17
|
+
TokenType[TokenType["Divide"] = 5] = "Divide";
|
|
18
|
+
TokenType[TokenType["Multiply"] = 6] = "Multiply";
|
|
19
|
+
TokenType[TokenType["Remainder"] = 7] = "Remainder";
|
|
20
|
+
TokenType[TokenType["Plus"] = 8] = "Plus";
|
|
21
|
+
TokenType[TokenType["Minus"] = 9] = "Minus";
|
|
22
|
+
TokenType[TokenType["BitwiseXor"] = 10] = "BitwiseXor";
|
|
23
|
+
TokenType[TokenType["BitwiseOr"] = 11] = "BitwiseOr";
|
|
24
|
+
TokenType[TokenType["LogicalOr"] = 12] = "LogicalOr";
|
|
25
|
+
TokenType[TokenType["BitwiseAnd"] = 13] = "BitwiseAnd";
|
|
26
|
+
TokenType[TokenType["LogicalAnd"] = 14] = "LogicalAnd";
|
|
27
|
+
TokenType[TokenType["IncOp"] = 15] = "IncOp";
|
|
28
|
+
TokenType[TokenType["DecOp"] = 16] = "DecOp";
|
|
29
|
+
TokenType[TokenType["Assignment"] = 17] = "Assignment";
|
|
30
|
+
TokenType[TokenType["AddAssignment"] = 18] = "AddAssignment";
|
|
31
|
+
TokenType[TokenType["SubtractAssignment"] = 19] = "SubtractAssignment";
|
|
32
|
+
TokenType[TokenType["ExponentAssignment"] = 20] = "ExponentAssignment";
|
|
33
|
+
TokenType[TokenType["MultiplyAssignment"] = 21] = "MultiplyAssignment";
|
|
34
|
+
TokenType[TokenType["DivideAssignment"] = 22] = "DivideAssignment";
|
|
35
|
+
TokenType[TokenType["RemainderAssignment"] = 23] = "RemainderAssignment";
|
|
36
|
+
TokenType[TokenType["ShiftLeftAssignment"] = 24] = "ShiftLeftAssignment";
|
|
37
|
+
TokenType[TokenType["ShiftRightAssignment"] = 25] = "ShiftRightAssignment";
|
|
38
|
+
TokenType[TokenType["SignedShiftRightAssignment"] = 26] = "SignedShiftRightAssignment";
|
|
39
|
+
TokenType[TokenType["BitwiseAndAssignment"] = 27] = "BitwiseAndAssignment";
|
|
40
|
+
TokenType[TokenType["BitwiseXorAssignment"] = 28] = "BitwiseXorAssignment";
|
|
41
|
+
TokenType[TokenType["BitwiseOrAssignment"] = 29] = "BitwiseOrAssignment";
|
|
42
|
+
TokenType[TokenType["LogicalAndAssignment"] = 30] = "LogicalAndAssignment";
|
|
43
|
+
TokenType[TokenType["LogicalOrAssignment"] = 31] = "LogicalOrAssignment";
|
|
44
|
+
TokenType[TokenType["NullCoalesceAssignment"] = 32] = "NullCoalesceAssignment";
|
|
45
|
+
TokenType[TokenType["Semicolon"] = 33] = "Semicolon";
|
|
46
|
+
TokenType[TokenType["Comma"] = 34] = "Comma";
|
|
47
|
+
TokenType[TokenType["Colon"] = 35] = "Colon";
|
|
48
|
+
TokenType[TokenType["LSquare"] = 36] = "LSquare";
|
|
49
|
+
TokenType[TokenType["RSquare"] = 37] = "RSquare";
|
|
50
|
+
TokenType[TokenType["QuestionMark"] = 38] = "QuestionMark";
|
|
51
|
+
TokenType[TokenType["NullCoalesce"] = 39] = "NullCoalesce";
|
|
52
|
+
TokenType[TokenType["OptionalChaining"] = 40] = "OptionalChaining";
|
|
53
|
+
TokenType[TokenType["BinaryNot"] = 41] = "BinaryNot";
|
|
54
|
+
TokenType[TokenType["LBrace"] = 42] = "LBrace";
|
|
55
|
+
TokenType[TokenType["RBrace"] = 43] = "RBrace";
|
|
56
|
+
TokenType[TokenType["Equal"] = 44] = "Equal";
|
|
57
|
+
TokenType[TokenType["StrictEqual"] = 45] = "StrictEqual";
|
|
58
|
+
TokenType[TokenType["LogicalNot"] = 46] = "LogicalNot";
|
|
59
|
+
TokenType[TokenType["NotEqual"] = 47] = "NotEqual";
|
|
60
|
+
TokenType[TokenType["StrictNotEqual"] = 48] = "StrictNotEqual";
|
|
61
|
+
TokenType[TokenType["LessThan"] = 49] = "LessThan";
|
|
62
|
+
TokenType[TokenType["LessThanOrEqual"] = 50] = "LessThanOrEqual";
|
|
63
|
+
TokenType[TokenType["ShiftLeft"] = 51] = "ShiftLeft";
|
|
64
|
+
TokenType[TokenType["GreaterThan"] = 52] = "GreaterThan";
|
|
65
|
+
TokenType[TokenType["GreaterThanOrEqual"] = 53] = "GreaterThanOrEqual";
|
|
66
|
+
TokenType[TokenType["ShiftRight"] = 54] = "ShiftRight";
|
|
67
|
+
TokenType[TokenType["SignedShiftRight"] = 55] = "SignedShiftRight";
|
|
68
|
+
TokenType[TokenType["Dot"] = 56] = "Dot";
|
|
69
|
+
TokenType[TokenType["Spread"] = 57] = "Spread";
|
|
70
|
+
TokenType[TokenType["Global"] = 58] = "Global";
|
|
71
|
+
TokenType[TokenType["Arrow"] = 59] = "Arrow";
|
|
72
|
+
TokenType[TokenType["DecimalLiteral"] = 60] = "DecimalLiteral";
|
|
73
|
+
TokenType[TokenType["HexadecimalLiteral"] = 61] = "HexadecimalLiteral";
|
|
74
|
+
TokenType[TokenType["BinaryLiteral"] = 62] = "BinaryLiteral";
|
|
75
|
+
TokenType[TokenType["RealLiteral"] = 63] = "RealLiteral";
|
|
76
|
+
TokenType[TokenType["StringLiteral"] = 64] = "StringLiteral";
|
|
77
|
+
TokenType[TokenType["Infinity"] = 65] = "Infinity";
|
|
78
|
+
TokenType[TokenType["NaN"] = 66] = "NaN";
|
|
79
|
+
TokenType[TokenType["True"] = 67] = "True";
|
|
80
|
+
TokenType[TokenType["False"] = 68] = "False";
|
|
81
|
+
TokenType[TokenType["Typeof"] = 69] = "Typeof";
|
|
82
|
+
TokenType[TokenType["Null"] = 70] = "Null";
|
|
83
|
+
TokenType[TokenType["Undefined"] = 71] = "Undefined";
|
|
84
|
+
TokenType[TokenType["In"] = 72] = "In";
|
|
85
|
+
TokenType[TokenType["Let"] = 73] = "Let";
|
|
86
|
+
TokenType[TokenType["Const"] = 74] = "Const";
|
|
87
|
+
TokenType[TokenType["Var"] = 75] = "Var";
|
|
88
|
+
TokenType[TokenType["If"] = 76] = "If";
|
|
89
|
+
TokenType[TokenType["Else"] = 77] = "Else";
|
|
90
|
+
TokenType[TokenType["Return"] = 78] = "Return";
|
|
91
|
+
TokenType[TokenType["Break"] = 79] = "Break";
|
|
92
|
+
TokenType[TokenType["Continue"] = 80] = "Continue";
|
|
93
|
+
TokenType[TokenType["Do"] = 81] = "Do";
|
|
94
|
+
TokenType[TokenType["While"] = 82] = "While";
|
|
95
|
+
TokenType[TokenType["For"] = 83] = "For";
|
|
96
|
+
TokenType[TokenType["Of"] = 84] = "Of";
|
|
97
|
+
TokenType[TokenType["Try"] = 85] = "Try";
|
|
98
|
+
TokenType[TokenType["Catch"] = 86] = "Catch";
|
|
99
|
+
TokenType[TokenType["Finally"] = 87] = "Finally";
|
|
100
|
+
TokenType[TokenType["Throw"] = 88] = "Throw";
|
|
101
|
+
TokenType[TokenType["Switch"] = 89] = "Switch";
|
|
102
|
+
TokenType[TokenType["Case"] = 90] = "Case";
|
|
103
|
+
TokenType[TokenType["Default"] = 91] = "Default";
|
|
104
|
+
TokenType[TokenType["Delete"] = 92] = "Delete";
|
|
105
|
+
TokenType[TokenType["Function"] = 93] = "Function";
|
|
106
|
+
TokenType[TokenType["Export"] = 94] = "Export";
|
|
107
|
+
TokenType[TokenType["Import"] = 95] = "Import";
|
|
108
|
+
TokenType[TokenType["As"] = 96] = "As";
|
|
109
|
+
TokenType[TokenType["From"] = 97] = "From";
|
|
110
|
+
})(TokenType || (exports.TokenType = TokenType = {}));
|
|
@@ -0,0 +1,253 @@
|
|
|
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.appRenderer = void 0;
|
|
18
|
+
exports.getAppLayoutOrientation = getAppLayoutOrientation;
|
|
19
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
20
|
+
const react_1 = require("react");
|
|
21
|
+
const react_2 = require("@remix-run/react");
|
|
22
|
+
const lodash_es_1 = require("lodash-es");
|
|
23
|
+
const classnames_1 = __importDefault(require("@components-core/utils/classnames"));
|
|
24
|
+
const App_module_scss_1 = __importDefault(require("./App.module.scss"));
|
|
25
|
+
const renderers_1 = require("@components-core/renderers");
|
|
26
|
+
const AppContext_1 = require("@components-core/AppContext");
|
|
27
|
+
const AppLayoutContext_1 = require("./AppLayoutContext");
|
|
28
|
+
const Sheet_1 = require("@components/App/Sheet");
|
|
29
|
+
const ScrollContext_1 = require("@components-core/ScrollContext");
|
|
30
|
+
const descriptorHelper_1 = require("@components-core/descriptorHelper");
|
|
31
|
+
const themeVars_1 = require("@components-core/theming/themeVars");
|
|
32
|
+
const AppHeader_1 = require("@components/AppHeader/AppHeader");
|
|
33
|
+
const misc_1 = require("@components-core/utils/misc");
|
|
34
|
+
const hooks_1 = require("@components-core/utils/hooks");
|
|
35
|
+
function App({ children, style, layout = "horizontal", loggedInUser, logoContent, scrollWholePage = true, onReady = lodash_es_1.noop, header, footer, }) {
|
|
36
|
+
const safeLayout = layout === null || layout === void 0 ? void 0 : layout.trim().replace(/[\u2013\u2014\u2011]/g, "-"); //It replaces all – (–) and — (—) and non-breaking hyphen '‑' symbols with simple dashes (-).
|
|
37
|
+
const { setLoggedInUser, mediaSize } = (0, AppContext_1.useAppContext)();
|
|
38
|
+
const [registeredHeaders, setRegisteredHeaders] = (0, react_1.useState)({});
|
|
39
|
+
const [registeredNavPanels, setRegisteredNavPanels] = (0, react_1.useState)({});
|
|
40
|
+
const hasRegisteredHeader = Object.keys(registeredHeaders).length > 0 || header !== undefined;
|
|
41
|
+
const hasRegisteredFooter = Object.keys(registeredHeaders).length > 0 || footer !== undefined;
|
|
42
|
+
const hasRegisteredNavPanel = Object.keys(registeredNavPanels).length > 0;
|
|
43
|
+
(0, react_1.useEffect)(() => {
|
|
44
|
+
setLoggedInUser(loggedInUser);
|
|
45
|
+
}, [loggedInUser, setLoggedInUser]);
|
|
46
|
+
(0, react_1.useEffect)(() => {
|
|
47
|
+
onReady();
|
|
48
|
+
}, [onReady]);
|
|
49
|
+
//we don't hide the nav panel if there's no header,
|
|
50
|
+
// because in that case we don't have a show drawer button
|
|
51
|
+
// the exception is the condensed layout, because we render a header in that case (otherwise we couldn't show the navPanel)
|
|
52
|
+
const navPanelVisible = mediaSize.largeScreen || (!hasRegisteredHeader && safeLayout !== "condensed" && safeLayout !== "condensed-sticky");
|
|
53
|
+
const scrollPageContainerRef = (0, react_1.useRef)(null);
|
|
54
|
+
const noScrollPageContainerRef = (0, react_1.useRef)(null);
|
|
55
|
+
const scrollContainerRef = scrollWholePage ? scrollPageContainerRef : noScrollPageContainerRef;
|
|
56
|
+
const [footerHeight, setFooterHeight] = (0, react_1.useState)(0);
|
|
57
|
+
const [headerHeight, setHeaderHeight] = (0, react_1.useState)(0);
|
|
58
|
+
const [navPanelRoot, setNavPanelRoot] = (0, react_1.useState)(null);
|
|
59
|
+
const [drawerRoot, setDrawerRoot] = (0, react_1.useState)(null);
|
|
60
|
+
const [headerRoot, setHeaderRoot] = (0, react_1.useState)(null);
|
|
61
|
+
const [footerRoot, setFooterRoot] = (0, react_1.useState)(null);
|
|
62
|
+
const footerRef = (0, react_1.useRef)();
|
|
63
|
+
const footerRefCallback = (0, react_1.useCallback)((element) => {
|
|
64
|
+
footerRef.current = element;
|
|
65
|
+
setFooterRoot(element);
|
|
66
|
+
}, []);
|
|
67
|
+
const headerRef = (0, react_1.useRef)();
|
|
68
|
+
const headerRefCallback = (0, react_1.useCallback)((element) => {
|
|
69
|
+
headerRef.current = element;
|
|
70
|
+
if (safeLayout !== "horizontal" && safeLayout !== "horizontal-sticky") {
|
|
71
|
+
setHeaderRoot(element);
|
|
72
|
+
}
|
|
73
|
+
}, [safeLayout]);
|
|
74
|
+
(0, hooks_1.useResizeObserver)(footerRef, (0, react_1.useCallback)((entries) => {
|
|
75
|
+
var _a, _b;
|
|
76
|
+
setFooterHeight((_b = (_a = entries === null || entries === void 0 ? void 0 : entries[0]) === null || _a === void 0 ? void 0 : _a.contentRect) === null || _b === void 0 ? void 0 : _b.height);
|
|
77
|
+
}, []));
|
|
78
|
+
(0, hooks_1.useResizeObserver)(headerRef, (0, react_1.useCallback)((entries) => {
|
|
79
|
+
var _a, _b;
|
|
80
|
+
setHeaderHeight((_b = (_a = entries === null || entries === void 0 ? void 0 : entries[0]) === null || _a === void 0 ? void 0 : _a.contentRect) === null || _b === void 0 ? void 0 : _b.height);
|
|
81
|
+
}, []));
|
|
82
|
+
const styleWithHelpers = (0, react_1.useMemo)(() => {
|
|
83
|
+
return Object.assign(Object.assign({}, style), { "--header-height": !scrollWholePage ? 0 : headerHeight + "px", "--footer-height": !scrollWholePage ? 0 : footerHeight + "px" });
|
|
84
|
+
}, [footerHeight, headerHeight, scrollWholePage, style]);
|
|
85
|
+
const [drawerVisible, setDrawerVisible] = (0, react_1.useState)(false);
|
|
86
|
+
const location = (0, react_2.useLocation)();
|
|
87
|
+
const toggleDrawer = (0, react_1.useCallback)(() => {
|
|
88
|
+
setDrawerVisible((prev) => !prev);
|
|
89
|
+
}, []);
|
|
90
|
+
const layoutContextValue = (0, react_1.useMemo)(() => {
|
|
91
|
+
return {
|
|
92
|
+
registerHeader: (id) => {
|
|
93
|
+
setRegisteredHeaders((prev) => {
|
|
94
|
+
if (prev[id]) {
|
|
95
|
+
return prev;
|
|
96
|
+
}
|
|
97
|
+
return Object.assign(Object.assign({}, prev), { [id]: true });
|
|
98
|
+
});
|
|
99
|
+
},
|
|
100
|
+
unregisterHeader: (id) => {
|
|
101
|
+
setRegisteredHeaders((prev) => {
|
|
102
|
+
if (!prev[id]) {
|
|
103
|
+
return prev;
|
|
104
|
+
}
|
|
105
|
+
const ret = Object.assign({}, prev);
|
|
106
|
+
delete ret[id];
|
|
107
|
+
return ret;
|
|
108
|
+
});
|
|
109
|
+
},
|
|
110
|
+
registerNavPanel: (id) => {
|
|
111
|
+
setRegisteredNavPanels((prev) => {
|
|
112
|
+
if (prev[id]) {
|
|
113
|
+
return prev;
|
|
114
|
+
}
|
|
115
|
+
return Object.assign(Object.assign({}, prev), { [id]: true });
|
|
116
|
+
});
|
|
117
|
+
},
|
|
118
|
+
unregisterNavPanel: (id) => {
|
|
119
|
+
setRegisteredNavPanels((prev) => {
|
|
120
|
+
if (!prev[id]) {
|
|
121
|
+
return prev;
|
|
122
|
+
}
|
|
123
|
+
const ret = Object.assign({}, prev);
|
|
124
|
+
delete ret[id];
|
|
125
|
+
return ret;
|
|
126
|
+
});
|
|
127
|
+
},
|
|
128
|
+
navPanelRoot,
|
|
129
|
+
drawerRoot,
|
|
130
|
+
headerRoot,
|
|
131
|
+
footerRoot,
|
|
132
|
+
navPanelVisible,
|
|
133
|
+
drawerVisible,
|
|
134
|
+
hasRegisteredHeader,
|
|
135
|
+
hasRegisteredNavPanel,
|
|
136
|
+
hasRegisteredFooter,
|
|
137
|
+
layout: safeLayout,
|
|
138
|
+
setNavPanelRoot: (el) => {
|
|
139
|
+
setNavPanelRoot(el);
|
|
140
|
+
},
|
|
141
|
+
showDrawer: () => {
|
|
142
|
+
setDrawerVisible(true);
|
|
143
|
+
},
|
|
144
|
+
hideDrawer: () => {
|
|
145
|
+
setDrawerVisible(false);
|
|
146
|
+
},
|
|
147
|
+
toggleDrawer: toggleDrawer,
|
|
148
|
+
};
|
|
149
|
+
}, [
|
|
150
|
+
navPanelRoot,
|
|
151
|
+
drawerRoot,
|
|
152
|
+
headerRoot,
|
|
153
|
+
footerRoot,
|
|
154
|
+
navPanelVisible,
|
|
155
|
+
drawerVisible,
|
|
156
|
+
hasRegisteredHeader,
|
|
157
|
+
hasRegisteredNavPanel,
|
|
158
|
+
hasRegisteredFooter,
|
|
159
|
+
safeLayout,
|
|
160
|
+
toggleDrawer,
|
|
161
|
+
]);
|
|
162
|
+
(0, react_1.useEffect)(() => {
|
|
163
|
+
if (navPanelVisible) {
|
|
164
|
+
setDrawerVisible(false);
|
|
165
|
+
}
|
|
166
|
+
}, [navPanelVisible]);
|
|
167
|
+
(0, react_1.useEffect)(() => {
|
|
168
|
+
setDrawerVisible(false);
|
|
169
|
+
}, [location, safeLayout]);
|
|
170
|
+
const wrapperBaseClasses = [
|
|
171
|
+
App_module_scss_1.default.wrapper,
|
|
172
|
+
{
|
|
173
|
+
[App_module_scss_1.default.scrollWholePage]: scrollWholePage,
|
|
174
|
+
"media-large": mediaSize.largeScreen,
|
|
175
|
+
"media-small": mediaSize.smallScreen,
|
|
176
|
+
"media-desktop": mediaSize.desktop,
|
|
177
|
+
"media-phone": mediaSize.phone,
|
|
178
|
+
"media-tablet": mediaSize.tablet,
|
|
179
|
+
},
|
|
180
|
+
];
|
|
181
|
+
let content;
|
|
182
|
+
switch (safeLayout) {
|
|
183
|
+
case "vertical":
|
|
184
|
+
content = ((0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)(wrapperBaseClasses, App_module_scss_1.default.vertical), style: styleWithHelpers, children: [navPanelVisible && (0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)(App_module_scss_1.default.navPanelWrapper), ref: setNavPanelRoot }), (0, jsx_runtime_1.jsxs)("div", { className: App_module_scss_1.default.contentWrapper, ref: scrollPageContainerRef, children: [(0, jsx_runtime_1.jsx)("header", { ref: headerRefCallback, className: (0, classnames_1.default)(App_module_scss_1.default.headerWrapper), children: header }), (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.PagesWrapper, ref: noScrollPageContainerRef, children: (0, jsx_runtime_1.jsx)(ScrollContext_1.ScrollContext.Provider, { value: scrollContainerRef, children: (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.PagesWrapperInner, children: children }) }) }), (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.footerWrapper, ref: footerRefCallback, children: footer })] })] }));
|
|
185
|
+
break;
|
|
186
|
+
case "vertical-sticky":
|
|
187
|
+
content = ((0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)(wrapperBaseClasses, App_module_scss_1.default.vertical, App_module_scss_1.default.sticky), style: styleWithHelpers, children: [navPanelVisible && (0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)(App_module_scss_1.default.navPanelWrapper), ref: setNavPanelRoot }), (0, jsx_runtime_1.jsxs)("div", { className: App_module_scss_1.default.contentWrapper, ref: scrollPageContainerRef, children: [(0, jsx_runtime_1.jsx)("header", { ref: headerRefCallback, className: (0, classnames_1.default)(App_module_scss_1.default.headerWrapper, App_module_scss_1.default.sticky), children: header }), (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.PagesWrapper, ref: noScrollPageContainerRef, children: (0, jsx_runtime_1.jsx)(ScrollContext_1.ScrollContext.Provider, { value: scrollContainerRef, children: (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.PagesWrapperInner, children: children }) }) }), (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.footerWrapper, ref: footerRefCallback, children: footer })] })] }));
|
|
188
|
+
break;
|
|
189
|
+
case "vertical-full-header":
|
|
190
|
+
content = ((0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)(wrapperBaseClasses, App_module_scss_1.default.verticalFullHeader), style: styleWithHelpers, ref: scrollPageContainerRef, children: [(0, jsx_runtime_1.jsx)("header", { className: (0, classnames_1.default)(App_module_scss_1.default.headerWrapper, App_module_scss_1.default.sticky), ref: headerRefCallback, children: header }), (0, jsx_runtime_1.jsxs)("div", { className: App_module_scss_1.default.content, children: [navPanelVisible && (0, jsx_runtime_1.jsx)("aside", { className: App_module_scss_1.default.navPanelWrapper, ref: setNavPanelRoot }), (0, jsx_runtime_1.jsx)("main", { className: App_module_scss_1.default.contentWrapper, children: (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.PagesWrapper, ref: noScrollPageContainerRef, children: (0, jsx_runtime_1.jsx)(ScrollContext_1.ScrollContext.Provider, { value: scrollContainerRef, children: (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.PagesWrapperInner, children: children }) }) }) })] }), (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.footerWrapper, ref: footerRefCallback, children: footer })] }));
|
|
191
|
+
break;
|
|
192
|
+
case "condensed":
|
|
193
|
+
case "condensed-sticky":
|
|
194
|
+
content = ((0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)(wrapperBaseClasses, App_module_scss_1.default.horizontal, {
|
|
195
|
+
[App_module_scss_1.default.sticky]: safeLayout === "condensed-sticky",
|
|
196
|
+
}), style: styleWithHelpers, ref: scrollPageContainerRef, children: [(0, jsx_runtime_1.jsxs)("header", { className: (0, classnames_1.default)(App_module_scss_1.default.headerWrapper, {
|
|
197
|
+
[App_module_scss_1.default.sticky]: safeLayout === "condensed-sticky",
|
|
198
|
+
}), ref: headerRefCallback, children: [!hasRegisteredHeader && hasRegisteredNavPanel && ((0, jsx_runtime_1.jsx)(AppHeader_1.AppHeader, { canRestrictContentWidth: true, logoContent: logoContent, navPanelVisible: navPanelVisible, toggleDrawer: toggleDrawer, children: (0, jsx_runtime_1.jsx)("div", { ref: setNavPanelRoot, style: { minWidth: 0 } }) })), header] }), (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.PagesWrapper, ref: noScrollPageContainerRef, children: (0, jsx_runtime_1.jsx)(ScrollContext_1.ScrollContext.Provider, { value: scrollContainerRef, children: (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.PagesWrapperInner, children: children }) }) }), (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.footerWrapper, ref: footerRefCallback, children: footer })] }));
|
|
199
|
+
break;
|
|
200
|
+
case "horizontal": {
|
|
201
|
+
content = ((0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)(wrapperBaseClasses, App_module_scss_1.default.horizontal), style: styleWithHelpers, ref: scrollPageContainerRef, children: [(0, jsx_runtime_1.jsxs)("header", { className: (0, classnames_1.default)(App_module_scss_1.default.headerWrapper), ref: headerRefCallback, children: [(0, jsx_runtime_1.jsx)("div", { ref: setHeaderRoot, children: header }), navPanelVisible && (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.navPanelWrapper, ref: setNavPanelRoot })] }), (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.PagesWrapper, ref: noScrollPageContainerRef, children: (0, jsx_runtime_1.jsx)(ScrollContext_1.ScrollContext.Provider, { value: scrollContainerRef, children: (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.PagesWrapperInner, children: children }) }) }), (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.footerWrapper, ref: footerRefCallback, children: footer })] }));
|
|
202
|
+
break;
|
|
203
|
+
}
|
|
204
|
+
case "horizontal-sticky":
|
|
205
|
+
content = ((0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)(wrapperBaseClasses, App_module_scss_1.default.horizontal, App_module_scss_1.default.sticky), style: styleWithHelpers, ref: scrollPageContainerRef, children: [(0, jsx_runtime_1.jsxs)("header", { className: (0, classnames_1.default)(App_module_scss_1.default.headerWrapper, App_module_scss_1.default.sticky), ref: headerRefCallback, children: [(0, jsx_runtime_1.jsx)("div", { ref: setHeaderRoot, children: header }), navPanelVisible && (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.navPanelWrapper, ref: setNavPanelRoot })] }), (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.PagesWrapper, ref: noScrollPageContainerRef, children: (0, jsx_runtime_1.jsx)(ScrollContext_1.ScrollContext.Provider, { value: scrollContainerRef, children: (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.PagesWrapperInner, children: children }) }) }), (0, jsx_runtime_1.jsx)("div", { className: App_module_scss_1.default.footerWrapper, ref: footerRefCallback, children: footer })] }));
|
|
206
|
+
break;
|
|
207
|
+
default:
|
|
208
|
+
throw new Error("layout type not supported: " + safeLayout);
|
|
209
|
+
}
|
|
210
|
+
return ((0, jsx_runtime_1.jsxs)(AppLayoutContext_1.AppLayoutContext.Provider, { value: layoutContextValue, children: [(0, jsx_runtime_1.jsx)(Sheet_1.Sheet, { open: drawerVisible, onOpenChange: (open) => setDrawerVisible(open), children: (0, jsx_runtime_1.jsx)(Sheet_1.SheetContent, { side: "left", ref: setDrawerRoot }) }), content] }));
|
|
211
|
+
}
|
|
212
|
+
function getAppLayoutOrientation(appLayout) {
|
|
213
|
+
switch (appLayout) {
|
|
214
|
+
case "vertical":
|
|
215
|
+
case "vertical-sticky":
|
|
216
|
+
case "vertical-full-header":
|
|
217
|
+
return "vertical";
|
|
218
|
+
default:
|
|
219
|
+
return "horizontal";
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
const metadata = {
|
|
223
|
+
displayName: "App",
|
|
224
|
+
description: "Display an app",
|
|
225
|
+
props: {
|
|
226
|
+
layout: (0, descriptorHelper_1.desc)("The layout type of the app"),
|
|
227
|
+
defaultRoute: (0, descriptorHelper_1.desc)("The app's default route"),
|
|
228
|
+
loggedInUser: (0, descriptorHelper_1.desc)("Optional information about the logged-in user"),
|
|
229
|
+
logoTemplate: {
|
|
230
|
+
description: "Optional template of the app logo",
|
|
231
|
+
valueType: "ComponentDef",
|
|
232
|
+
},
|
|
233
|
+
scrollWholePage: (0, descriptorHelper_1.desc)("Whether the whole page should scroll or just the content area"),
|
|
234
|
+
},
|
|
235
|
+
themeVars: (0, themeVars_1.parseScssVar)(App_module_scss_1.default.themeVars),
|
|
236
|
+
defaultThemeVars: {
|
|
237
|
+
"width-navPanel-App": "$space-72",
|
|
238
|
+
"max-content-width-App": "$max-content-width",
|
|
239
|
+
"shadow-header-App": "$shadow-spread",
|
|
240
|
+
"shadow-pages-App": "$shadow-spread",
|
|
241
|
+
light: {
|
|
242
|
+
// --- No light-specific theme vars
|
|
243
|
+
},
|
|
244
|
+
dark: {
|
|
245
|
+
// --- No dark-specific theme vars
|
|
246
|
+
},
|
|
247
|
+
},
|
|
248
|
+
};
|
|
249
|
+
exports.appRenderer = (0, renderers_1.createComponentRenderer)("App", ({ node, extractValue, renderChild, layoutCss, lookupEventHandler }) => {
|
|
250
|
+
const _a = (0, misc_1.groupChildrenByType)(node), { AppHeader, Footer } = _a, rest = __rest(_a, ["AppHeader", "Footer"]);
|
|
251
|
+
const layoutType = extractValue(node.props.layout) || "condensed-sticky";
|
|
252
|
+
return ((0, jsx_runtime_1.jsx)(App, { scrollWholePage: extractValue.asOptionalBoolean(node.props.scrollWholePage), style: layoutCss, layout: layoutType, loggedInUser: extractValue(node.props.loggedInUser), logoContent: renderChild(node.props.logoTemplate), onReady: lookupEventHandler("ready"), header: renderChild(AppHeader), footer: renderChild(Footer), children: renderChild(Object.values(rest).flatMap((a) => a)) }));
|
|
253
|
+
}, metadata);
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AppLayoutContext = void 0;
|
|
4
|
+
exports.useAppLayoutContext = useAppLayoutContext;
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
exports.AppLayoutContext = (0, react_1.createContext)(null);
|
|
7
|
+
function useAppLayoutContext() {
|
|
8
|
+
return (0, react_1.useContext)(exports.AppLayoutContext);
|
|
9
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AppStateContext = void 0;
|
|
4
|
+
exports.useAppStateContextPart = useAppStateContextPart;
|
|
5
|
+
const use_context_selector_1 = require("use-context-selector");
|
|
6
|
+
exports.AppStateContext = (0, use_context_selector_1.createContext)(null);
|
|
7
|
+
function useAppStateContextPart(selector) {
|
|
8
|
+
return (0, use_context_selector_1.useContextSelector)(exports.AppStateContext, selector);
|
|
9
|
+
}
|
|
@@ -0,0 +1,89 @@
|
|
|
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 __rest = (this && this.__rest) || function (s, e) {
|
|
26
|
+
var t = {};
|
|
27
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
28
|
+
t[p] = s[p];
|
|
29
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
30
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
31
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
32
|
+
t[p[i]] = s[p[i]];
|
|
33
|
+
}
|
|
34
|
+
return t;
|
|
35
|
+
};
|
|
36
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
37
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
38
|
+
};
|
|
39
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
40
|
+
exports.SheetContent = exports.Sheet = void 0;
|
|
41
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
42
|
+
const React = __importStar(require("react"));
|
|
43
|
+
const SheetPrimitive = __importStar(require("@radix-ui/react-dialog"));
|
|
44
|
+
const classnames_1 = __importDefault(require("@components-core/utils/classnames"));
|
|
45
|
+
const Icon_1 = require("@components/Icon/Icon");
|
|
46
|
+
const Sheet_module_scss_1 = __importDefault(require("./Sheet.module.scss"));
|
|
47
|
+
const react_visually_hidden_1 = require("@radix-ui/react-visually-hidden");
|
|
48
|
+
const ThemeContext_1 = require("@components-core/theming/ThemeContext");
|
|
49
|
+
//based on this: https://ui.shadcn.com/docs/components/sheet
|
|
50
|
+
const Sheet = SheetPrimitive.Root;
|
|
51
|
+
exports.Sheet = Sheet;
|
|
52
|
+
const SheetPortal = SheetPrimitive.Portal;
|
|
53
|
+
const SheetOverlay = React.forwardRef((_a, ref) => {
|
|
54
|
+
var { className } = _a, props = __rest(_a, ["className"]);
|
|
55
|
+
return ((0, jsx_runtime_1.jsx)(SheetPrimitive.Overlay, Object.assign({ className: (0, classnames_1.default)(Sheet_module_scss_1.default.overlay, className) }, props, { ref: ref })));
|
|
56
|
+
});
|
|
57
|
+
SheetOverlay.displayName = SheetPrimitive.Overlay.displayName;
|
|
58
|
+
const SheetContent = React.forwardRef((_a, ref) => {
|
|
59
|
+
var { side = "left", className, children } = _a, props = __rest(_a, ["side", "className", "children"]);
|
|
60
|
+
const { root } = (0, ThemeContext_1.useTheme)();
|
|
61
|
+
return ((0, jsx_runtime_1.jsxs)(SheetPortal, { container: root, children: [(0, jsx_runtime_1.jsx)(SheetOverlay, {}), (0, jsx_runtime_1.jsxs)(SheetPrimitive.Content, Object.assign({ forceMount: true, ref: ref, className: (0, classnames_1.default)(Sheet_module_scss_1.default.sheetContent, {
|
|
62
|
+
[Sheet_module_scss_1.default.top]: side === "top",
|
|
63
|
+
[Sheet_module_scss_1.default.bottom]: side === "bottom",
|
|
64
|
+
[Sheet_module_scss_1.default.left]: side === "left",
|
|
65
|
+
[Sheet_module_scss_1.default.right]: side === "right",
|
|
66
|
+
}, className) }, props, { children: [children, (0, jsx_runtime_1.jsxs)(SheetPrimitive.Close, { className: Sheet_module_scss_1.default.close, children: [(0, jsx_runtime_1.jsx)(Icon_1.Icon, { name: "close" }), (0, jsx_runtime_1.jsx)(react_visually_hidden_1.VisuallyHidden, { children: "Close" })] })] }))] }));
|
|
67
|
+
});
|
|
68
|
+
exports.SheetContent = SheetContent;
|
|
69
|
+
SheetContent.displayName = SheetPrimitive.Content.displayName;
|
|
70
|
+
const SheetHeader = (_a) => {
|
|
71
|
+
var { className } = _a, props = __rest(_a, ["className"]);
|
|
72
|
+
return ((0, jsx_runtime_1.jsx)("div", Object.assign({ className: (0, classnames_1.default)("flex flex-col space-y-2 text-center sm:text-left", className) }, props)));
|
|
73
|
+
};
|
|
74
|
+
SheetHeader.displayName = "SheetHeader";
|
|
75
|
+
const SheetFooter = (_a) => {
|
|
76
|
+
var { className } = _a, props = __rest(_a, ["className"]);
|
|
77
|
+
return ((0, jsx_runtime_1.jsx)("div", Object.assign({ className: (0, classnames_1.default)("flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2", className) }, props)));
|
|
78
|
+
};
|
|
79
|
+
SheetFooter.displayName = "SheetFooter";
|
|
80
|
+
const SheetTitle = React.forwardRef((_a, ref) => {
|
|
81
|
+
var { className } = _a, props = __rest(_a, ["className"]);
|
|
82
|
+
return ((0, jsx_runtime_1.jsx)(SheetPrimitive.Title, Object.assign({ ref: ref, className: (0, classnames_1.default)("text-lg font-semibold text-foreground", className) }, props)));
|
|
83
|
+
});
|
|
84
|
+
SheetTitle.displayName = SheetPrimitive.Title.displayName;
|
|
85
|
+
const SheetDescription = React.forwardRef((_a, ref) => {
|
|
86
|
+
var { className } = _a, props = __rest(_a, ["className"]);
|
|
87
|
+
return ((0, jsx_runtime_1.jsx)(SheetPrimitive.Description, Object.assign({ ref: ref, className: (0, classnames_1.default)("text-sm text-muted-foreground", className) }, props)));
|
|
88
|
+
});
|
|
89
|
+
SheetDescription.displayName = SheetPrimitive.Description.displayName;
|
|
@@ -0,0 +1,121 @@
|
|
|
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.appHeaderComponentRenderer = exports.AppHeader = void 0;
|
|
7
|
+
exports.useLogoUrl = useLogoUrl;
|
|
8
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
9
|
+
const react_1 = require("react");
|
|
10
|
+
const react_dom_1 = require("react-dom");
|
|
11
|
+
const classnames_1 = __importDefault(require("@components-core/utils/classnames"));
|
|
12
|
+
const AppHeader_module_scss_1 = __importDefault(require("./AppHeader.module.scss"));
|
|
13
|
+
const Icon_1 = require("@components/Icon/Icon");
|
|
14
|
+
const renderers_1 = require("@components-core/renderers");
|
|
15
|
+
const constants_1 = require("@components-core/constants");
|
|
16
|
+
const AppContext_1 = require("@components-core/AppContext");
|
|
17
|
+
const Logo_1 = require("@components/Logo/Logo");
|
|
18
|
+
const AppLayoutContext_1 = require("@components/App/AppLayoutContext");
|
|
19
|
+
const Button_1 = require("@components/Button/Button");
|
|
20
|
+
const ThemeContext_1 = require("@components-core/theming/ThemeContext");
|
|
21
|
+
const themeVars_1 = require("@components-core/theming/themeVars");
|
|
22
|
+
const base_utils_1 = require("@components-core/theming/themes/base-utils");
|
|
23
|
+
const hooks_1 = require("@components-core/utils/hooks");
|
|
24
|
+
function useLogoUrl(inDrawer) {
|
|
25
|
+
const { activeThemeId, activeThemeTone } = (0, ThemeContext_1.useTheme)();
|
|
26
|
+
const logoResourceString = "resource:logo";
|
|
27
|
+
const drawerLogoResourceString = "resource:logo.drawer";
|
|
28
|
+
const tonedLogoResourceString = `resource:logo-${activeThemeTone}`;
|
|
29
|
+
const themedLogoResourceString = `resource:logo-${activeThemeId}`;
|
|
30
|
+
const baseLogoUrl = (0, ThemeContext_1.useResourceUrl)(logoResourceString);
|
|
31
|
+
const drawerLogoUrl = (0, ThemeContext_1.useResourceUrl)(drawerLogoResourceString);
|
|
32
|
+
const toneLogoUrl = (0, ThemeContext_1.useResourceUrl)(tonedLogoResourceString); //TODO illesg review, it's for light/dark built in themes
|
|
33
|
+
const themeLogoUrl = (0, ThemeContext_1.useResourceUrl)(themedLogoResourceString); //TODO illesg review, it's for light/dark built in themes
|
|
34
|
+
if (inDrawer) {
|
|
35
|
+
return drawerLogoUrl || baseLogoUrl;
|
|
36
|
+
}
|
|
37
|
+
return themeLogoUrl || toneLogoUrl || baseLogoUrl;
|
|
38
|
+
}
|
|
39
|
+
const AppHeader = ({ children, profileMenu, style = constants_1.EMPTY_OBJECT, logoContent, className, canRestrictContentWidth, navPanelVisible = true, toggleDrawer, showLogo, hasRegisteredNavPanel, logoTitle }) => {
|
|
40
|
+
const { loggedInUser } = (0, AppContext_1.useAppContext)();
|
|
41
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)(AppHeader_module_scss_1.default.header, className), style: style, children: (0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)(AppHeader_module_scss_1.default.headerInner, {
|
|
42
|
+
[AppHeader_module_scss_1.default.full]: !canRestrictContentWidth,
|
|
43
|
+
}), children: [!navPanelVisible && hasRegisteredNavPanel && ((0, jsx_runtime_1.jsx)(Button_1.Button, { onClick: toggleDrawer, icon: (0, jsx_runtime_1.jsx)(Icon_1.Icon, { name: "hamburger" }), variant: "ghost", style: { color: "inherit" } })), (showLogo || !navPanelVisible) && ((0, jsx_runtime_1.jsx)("div", { className: AppHeader_module_scss_1.default.logoContainer, children: logoContent ? (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: logoContent }) : (0, jsx_runtime_1.jsx)(Logo_1.Logo, { title: logoTitle }) })), (0, jsx_runtime_1.jsx)("div", { className: AppHeader_module_scss_1.default.childrenWrapper, children: children }), (0, jsx_runtime_1.jsx)("div", { className: AppHeader_module_scss_1.default.rightItems, children: profileMenu })] }) }));
|
|
44
|
+
};
|
|
45
|
+
exports.AppHeader = AppHeader;
|
|
46
|
+
function AppContextAwareAppHeader({ children, logoContent, profileMenu, style, className, logoTitle, }) {
|
|
47
|
+
const appLayoutContext = (0, AppLayoutContext_1.useAppLayoutContext)();
|
|
48
|
+
const id = (0, react_1.useId)();
|
|
49
|
+
const registered = (0, react_1.useRef)(false);
|
|
50
|
+
(0, hooks_1.useIsomorphicLayoutEffect)(() => {
|
|
51
|
+
if (!appLayoutContext || registered.current) {
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
appLayoutContext.registerHeader(id);
|
|
55
|
+
registered.current = true;
|
|
56
|
+
return () => {
|
|
57
|
+
registered.current = false;
|
|
58
|
+
appLayoutContext.unregisterHeader(id);
|
|
59
|
+
};
|
|
60
|
+
}, [appLayoutContext, id]);
|
|
61
|
+
const { navPanelVisible, toggleDrawer, headerRoot, layout, setNavPanelRoot, hasRegisteredHeader, hasRegisteredNavPanel, } = appLayoutContext || {};
|
|
62
|
+
const showLogo = layout !== "vertical" && layout !== "vertical-sticky";
|
|
63
|
+
const canRestrictContentWidth = layout !== "vertical-full-header";
|
|
64
|
+
if (headerRoot) {
|
|
65
|
+
return (0, react_dom_1.createPortal)((0, jsx_runtime_1.jsxs)(exports.AppHeader, { hasRegisteredNavPanel: hasRegisteredNavPanel, navPanelVisible: navPanelVisible, toggleDrawer: toggleDrawer, canRestrictContentWidth: canRestrictContentWidth, showLogo: showLogo, logoContent: logoContent, profileMenu: profileMenu, style: style, className: className, logoTitle: logoTitle, children: [layout && layout.startsWith("condensed") && (0, jsx_runtime_1.jsx)("div", { ref: setNavPanelRoot, style: { minWidth: 0 } }), children] }), headerRoot);
|
|
66
|
+
}
|
|
67
|
+
return ((0, jsx_runtime_1.jsxs)(exports.AppHeader, { hasRegisteredNavPanel: hasRegisteredNavPanel, navPanelVisible: navPanelVisible, toggleDrawer: toggleDrawer, canRestrictContentWidth: canRestrictContentWidth, showLogo: showLogo, logoContent: logoContent, profileMenu: profileMenu, style: style, className: className, logoTitle: logoTitle, children: [layout && layout.startsWith("condensed") && (0, jsx_runtime_1.jsx)("div", { ref: setNavPanelRoot, style: { minWidth: 0 } }), children] }));
|
|
68
|
+
}
|
|
69
|
+
// @ts-ignore
|
|
70
|
+
const metadata = {
|
|
71
|
+
displayName: "AppHeader",
|
|
72
|
+
description: "Display an application header",
|
|
73
|
+
props: {
|
|
74
|
+
logoTemplate: {
|
|
75
|
+
description: "Template for the application logo",
|
|
76
|
+
valueType: "ComponentDef",
|
|
77
|
+
},
|
|
78
|
+
profileMenuTemplate: {
|
|
79
|
+
description: "Template for the profile menu",
|
|
80
|
+
valueType: "ComponentDef",
|
|
81
|
+
},
|
|
82
|
+
},
|
|
83
|
+
themeVars: (0, themeVars_1.parseScssVar)(AppHeader_module_scss_1.default.themeVars),
|
|
84
|
+
defaultThemeVars: Object.assign(Object.assign(Object.assign(Object.assign({ "height-AppHeader": "$space-16", "max-content-width-AppHeader": "$max-content-width-App" }, (0, base_utils_1.borderSubject)("AppHeader", {
|
|
85
|
+
bottom: {
|
|
86
|
+
color: "$color-border",
|
|
87
|
+
thickness: "1px",
|
|
88
|
+
style: "solid",
|
|
89
|
+
},
|
|
90
|
+
all: {
|
|
91
|
+
color: "$color-border",
|
|
92
|
+
thickness: "0",
|
|
93
|
+
style: "solid",
|
|
94
|
+
},
|
|
95
|
+
})), (0, base_utils_1.paddingSubject)("logo-AppHeader", { horizontal: "$space-0", vertical: "$space-4" })), (0, base_utils_1.paddingSubject)("AppHeader", { horizontal: "$space-4", vertical: "$space-0" })), { "radius-AppHeader": "0px", light: {
|
|
96
|
+
"color-bg-AppHeader": "white",
|
|
97
|
+
}, dark: {
|
|
98
|
+
"color-bg-AppHeader": "$color-surface-900",
|
|
99
|
+
} }),
|
|
100
|
+
};
|
|
101
|
+
exports.appHeaderComponentRenderer = (0, renderers_1.createComponentRenderer)("AppHeader", ({ node, renderChild, layoutCss, layoutContext, extractValue }) => {
|
|
102
|
+
// --- Convert the plain (text) logo template into component definition
|
|
103
|
+
let logoTemplate = node.props.logoTemplate;
|
|
104
|
+
if (typeof logoTemplate === "string") {
|
|
105
|
+
logoTemplate = {
|
|
106
|
+
type: "TextNode",
|
|
107
|
+
props: {
|
|
108
|
+
value: logoTemplate,
|
|
109
|
+
},
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
return ((0, jsx_runtime_1.jsx)(AppContextAwareAppHeader, { profileMenu: renderChild(extractValue(node.props.profileMenuTemplate, true)), logoTitle: extractValue(node.props.logoTitle) || (layoutContext === null || layoutContext === void 0 ? void 0 : layoutContext.logoTitle), logoContent: renderChild(logoTemplate, {
|
|
113
|
+
type: "Stack",
|
|
114
|
+
orientation: "horizontal",
|
|
115
|
+
}) || (layoutContext === null || layoutContext === void 0 ? void 0 : layoutContext.logoContent), style: layoutCss, className: layoutContext === null || layoutContext === void 0 ? void 0 : layoutContext.themeClassName, children: renderChild(node.children, {
|
|
116
|
+
// Since the AppHeader is a flex container, it's children should behave the same as in a stack
|
|
117
|
+
type: "Stack",
|
|
118
|
+
width: "100%",
|
|
119
|
+
height: "100%",
|
|
120
|
+
}) }));
|
|
121
|
+
}, metadata);
|