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,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);
|