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,144 @@
|
|
|
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.radioGroupRenderer = exports.radioGroupOptionRenderer = exports.RadioGroupOption = exports.RadioGroup = void 0;
|
|
30
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
31
|
+
const react_1 = __importStar(require("react"));
|
|
32
|
+
const classnames_1 = __importDefault(require("@components-core/utils/classnames"));
|
|
33
|
+
const RadioGroup_module_scss_1 = __importDefault(require("./RadioGroup.module.scss"));
|
|
34
|
+
const renderers_1 = require("@components-core/renderers");
|
|
35
|
+
const constants_1 = require("@components-core/constants");
|
|
36
|
+
const input_abstractions_1 = require("@components/Input/input-abstractions");
|
|
37
|
+
const InnerRadioGroup = __importStar(require("@radix-ui/react-radio-group"));
|
|
38
|
+
const descriptorHelper_1 = require("@components-core/descriptorHelper");
|
|
39
|
+
const themeVars_1 = require("@components-core/theming/themeVars");
|
|
40
|
+
const misc_1 = require("@components-core/utils/misc");
|
|
41
|
+
// =====================================================================================================================
|
|
42
|
+
// React RadioGroup component implementation
|
|
43
|
+
const RadioGroupValidationStatusContext = (0, react_1.createContext)({
|
|
44
|
+
status: "none",
|
|
45
|
+
});
|
|
46
|
+
const RadioGroup = ({ id, value = "", initialValue = "", enabled = true, validationStatus = "none", updateState = constants_1.noop, onDidChange = constants_1.noop, onFocus = constants_1.noop, onBlur = constants_1.noop, children, registerComponentApi, }) => {
|
|
47
|
+
const [focused, setFocused] = react_1.default.useState(false);
|
|
48
|
+
// --- Initialize the related field with the input's initial value
|
|
49
|
+
(0, react_1.useEffect)(() => {
|
|
50
|
+
updateState({ value: initialValue });
|
|
51
|
+
}, [initialValue, updateState]);
|
|
52
|
+
// --- Handle the value change events for this input
|
|
53
|
+
const updateValue = (0, react_1.useCallback)((value) => {
|
|
54
|
+
updateState({ value });
|
|
55
|
+
onDidChange(value);
|
|
56
|
+
}, [onDidChange, updateState]);
|
|
57
|
+
const onInputChange = (0, react_1.useCallback)((value) => {
|
|
58
|
+
updateValue(value);
|
|
59
|
+
}, [updateValue]);
|
|
60
|
+
// --- Manage obtaining and losing the focus
|
|
61
|
+
const handleOnFocus = (0, react_1.useCallback)(() => {
|
|
62
|
+
setFocused(true);
|
|
63
|
+
onFocus === null || onFocus === void 0 ? void 0 : onFocus();
|
|
64
|
+
}, [onFocus]);
|
|
65
|
+
const handleOnBlur = (0, react_1.useCallback)(() => {
|
|
66
|
+
setFocused(false);
|
|
67
|
+
onBlur === null || onBlur === void 0 ? void 0 : onBlur();
|
|
68
|
+
}, [onBlur]);
|
|
69
|
+
const setValue = (0, misc_1.useEvent)((val) => {
|
|
70
|
+
updateValue(val);
|
|
71
|
+
});
|
|
72
|
+
(0, react_1.useEffect)(() => {
|
|
73
|
+
registerComponentApi === null || registerComponentApi === void 0 ? void 0 : registerComponentApi({
|
|
74
|
+
//focus,
|
|
75
|
+
setValue,
|
|
76
|
+
});
|
|
77
|
+
}, [/* focus, */ registerComponentApi, setValue]);
|
|
78
|
+
const contextValue = (0, react_1.useMemo)(() => {
|
|
79
|
+
return { value, status: validationStatus };
|
|
80
|
+
}, [value, validationStatus]);
|
|
81
|
+
return ((0, jsx_runtime_1.jsx)(RadioGroupValidationStatusContext.Provider, { value: contextValue, children: (0, jsx_runtime_1.jsx)(InnerRadioGroup.Root, { id: id, onBlur: handleOnBlur, onFocus: handleOnFocus, onValueChange: onInputChange, value: value, disabled: !enabled, className: (0, classnames_1.default)(RadioGroup_module_scss_1.default.radioGroupContainer, {
|
|
82
|
+
[RadioGroup_module_scss_1.default.focused]: focused,
|
|
83
|
+
[RadioGroup_module_scss_1.default.disabled]: !enabled,
|
|
84
|
+
}), children: children }) }));
|
|
85
|
+
};
|
|
86
|
+
exports.RadioGroup = RadioGroup;
|
|
87
|
+
const RadioGroupOption = ({ value, label, enabled = true }) => {
|
|
88
|
+
const id = (0, react_1.useId)();
|
|
89
|
+
const validationContext = (0, react_1.useContext)(RadioGroupValidationStatusContext);
|
|
90
|
+
const statusStyles = {
|
|
91
|
+
[RadioGroup_module_scss_1.default.disabled]: !enabled,
|
|
92
|
+
[RadioGroup_module_scss_1.default.error]: value === validationContext.value && validationContext.status === "error",
|
|
93
|
+
[RadioGroup_module_scss_1.default.warning]: value === validationContext.value && validationContext.status === "warning",
|
|
94
|
+
[RadioGroup_module_scss_1.default.valid]: value === validationContext.value && validationContext.status === "valid",
|
|
95
|
+
};
|
|
96
|
+
return ((0, jsx_runtime_1.jsxs)("div", { className: RadioGroup_module_scss_1.default.radioOptionContainer, children: [(0, jsx_runtime_1.jsx)(InnerRadioGroup.Item, { className: (0, classnames_1.default)(RadioGroup_module_scss_1.default.radioOption, statusStyles), value: value, disabled: !enabled, id: id, children: (0, jsx_runtime_1.jsx)(InnerRadioGroup.Indicator, { className: (0, classnames_1.default)(RadioGroup_module_scss_1.default.indicator, statusStyles) }) }), (0, jsx_runtime_1.jsx)("label", { htmlFor: id, className: (0, classnames_1.default)(RadioGroup_module_scss_1.default.label, statusStyles), children: label !== null && label !== void 0 ? label : value })] }, id));
|
|
97
|
+
};
|
|
98
|
+
exports.RadioGroupOption = RadioGroupOption;
|
|
99
|
+
const radioGroupOptionMetadata = {
|
|
100
|
+
displayName: "RadioGroupOption",
|
|
101
|
+
description: "A single radio button within a radio button group",
|
|
102
|
+
props: {
|
|
103
|
+
enabled: (0, descriptorHelper_1.desc)("Is the particular option enabled?"),
|
|
104
|
+
value: (0, descriptorHelper_1.desc)("The value of the option"),
|
|
105
|
+
label: (0, descriptorHelper_1.desc)("The option's label"),
|
|
106
|
+
},
|
|
107
|
+
themeVars: (0, themeVars_1.parseScssVar)(RadioGroup_module_scss_1.default.themeVars),
|
|
108
|
+
defaultThemeVars: {
|
|
109
|
+
"gap-RadioGroupOption": "$space-1_5",
|
|
110
|
+
"thickness-border-RadioGroupOption": "2px",
|
|
111
|
+
"color-bg-checked-RadioGroupOption-default": "$color-border-RadioGroupOption-default--active",
|
|
112
|
+
"color-bg-checked-RadioGroupOption--disabled": "$color-border-RadioGroupOption--disabled",
|
|
113
|
+
"color-bg-checked-RadioGroupOption-error": "$color-border-RadioGroupOption-error",
|
|
114
|
+
"color-bg-checked-RadioGroupOption-warning": "$color-border-RadioGroupOption-warning",
|
|
115
|
+
"color-bg-checked-RadioGroupOption-success": "$color-border-RadioGroupOption-success",
|
|
116
|
+
"font-size-RadioGroupOption": "$font-size-small",
|
|
117
|
+
"font-weight-RadioGroupOption": "$font-weight-bold",
|
|
118
|
+
"color-text-RadioGroupOption-error": "$color-border-RadioGroupOption-error",
|
|
119
|
+
"color-text-RadioGroupOption-warning": "$color-border-RadioGroupOption-warning",
|
|
120
|
+
"color-text-RadioGroupOption-success": "$color-border-RadioGroupOption-success",
|
|
121
|
+
light: {
|
|
122
|
+
"color-border-RadioGroupOption-default": "$color-surface-500",
|
|
123
|
+
"color-border-RadioGroupOption-default--hover": "$color-surface-700",
|
|
124
|
+
"color-border-RadioGroupOption-default--active": "$color-primary-500",
|
|
125
|
+
},
|
|
126
|
+
dark: {
|
|
127
|
+
"color-border-RadioGroupOption-default": "$color-surface-500",
|
|
128
|
+
"color-border-RadioGroupOption-default--hover": "$color-surface-300",
|
|
129
|
+
"color-border-RadioGroupOption-default--active": "$color-primary-400",
|
|
130
|
+
},
|
|
131
|
+
},
|
|
132
|
+
};
|
|
133
|
+
exports.radioGroupOptionRenderer = (0, renderers_1.createComponentRenderer)("RadioGroupOption", ({ node, extractValue }) => {
|
|
134
|
+
return ((0, jsx_runtime_1.jsx)(exports.RadioGroupOption, { value: extractValue.asString(node.props.value), label: extractValue.asOptionalString(node.props.label), enabled: extractValue.asOptionalBoolean(node.props.enabled) }));
|
|
135
|
+
}, radioGroupOptionMetadata);
|
|
136
|
+
const radioGroupMetadata = {
|
|
137
|
+
displayName: "RadioGroup",
|
|
138
|
+
description: "A group of radio buttons (mutually exclusive selection)",
|
|
139
|
+
props: Object.assign({}, input_abstractions_1.inputComponentPropertyDescriptors),
|
|
140
|
+
events: input_abstractions_1.inputComponentEventDescriptors,
|
|
141
|
+
};
|
|
142
|
+
exports.radioGroupRenderer = (0, renderers_1.createComponentRenderer)("RadioGroup", ({ node, extractValue, layoutCss, state, updateState, lookupEventHandler, renderChild, registerComponentApi }) => {
|
|
143
|
+
return ((0, jsx_runtime_1.jsx)(exports.RadioGroup, { enabled: extractValue.asOptionalBoolean(node.props.enabled), layout: layoutCss, initialValue: extractValue(node.props.initialValue), value: state === null || state === void 0 ? void 0 : state.value, updateState: updateState, validationStatus: extractValue(node.props.validationStatus), onDidChange: lookupEventHandler("didChange"), onFocus: lookupEventHandler("gotFocus"), onBlur: lookupEventHandler("lostFocus"), registerComponentApi: registerComponentApi, children: renderChild(node.children) }));
|
|
144
|
+
}, radioGroupMetadata);
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.realTimeAdapterComponentRenderer = void 0;
|
|
16
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
17
|
+
const renderers_1 = require("@components-core/renderers");
|
|
18
|
+
const react_1 = require("react");
|
|
19
|
+
const RestApiProxy_1 = __importDefault(require("@components-core/RestApiProxy"));
|
|
20
|
+
const misc_1 = require("@components-core/utils/misc");
|
|
21
|
+
const AppContext_1 = require("@components-core/AppContext");
|
|
22
|
+
const descriptorHelper_1 = require("@components-core/descriptorHelper");
|
|
23
|
+
class PollClient {
|
|
24
|
+
constructor(url, appContext) {
|
|
25
|
+
this.url = url;
|
|
26
|
+
this.appContext = appContext;
|
|
27
|
+
this.handlers = [];
|
|
28
|
+
this.tries = 0;
|
|
29
|
+
this.polling = false;
|
|
30
|
+
this.abortController = new AbortController();
|
|
31
|
+
}
|
|
32
|
+
refreshAppContext(appContext) {
|
|
33
|
+
this.appContext = appContext;
|
|
34
|
+
}
|
|
35
|
+
poll(abortSignal) {
|
|
36
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
37
|
+
if (!this.polling || abortSignal.aborted) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
try {
|
|
41
|
+
const response = yield new RestApiProxy_1.default(this.appContext).execute({
|
|
42
|
+
abortSignal,
|
|
43
|
+
operation: {
|
|
44
|
+
url: this.url,
|
|
45
|
+
method: "get",
|
|
46
|
+
headers: {
|
|
47
|
+
"Cache-Control": "no-cache, no-store",
|
|
48
|
+
},
|
|
49
|
+
queryParams: {
|
|
50
|
+
lastEventId: this.lastEventId,
|
|
51
|
+
},
|
|
52
|
+
},
|
|
53
|
+
resolveBindingExpressions: true,
|
|
54
|
+
});
|
|
55
|
+
this.eventArrived(response);
|
|
56
|
+
yield this.poll(abortSignal);
|
|
57
|
+
}
|
|
58
|
+
catch (e) {
|
|
59
|
+
if (this.tries < 100) {
|
|
60
|
+
this.tries++;
|
|
61
|
+
yield (0, misc_1.delay)(this.tries * 100); //TODO we should do some exponential fallback here
|
|
62
|
+
yield this.poll(abortSignal);
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
this.stopPoll();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
startPoll() {
|
|
71
|
+
if (this.polling) {
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
this.polling = true;
|
|
75
|
+
this.tries = 0;
|
|
76
|
+
this.abortController = new AbortController();
|
|
77
|
+
// console.log("poll client: start polling", this.handlers);
|
|
78
|
+
this.poll(this.abortController.signal);
|
|
79
|
+
}
|
|
80
|
+
stopPoll() {
|
|
81
|
+
this.polling = false;
|
|
82
|
+
this.abortController.abort();
|
|
83
|
+
// console.log("poll client: stop polling");
|
|
84
|
+
}
|
|
85
|
+
eventArrived(response) {
|
|
86
|
+
if (!response) {
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
let events = [response];
|
|
90
|
+
if (Array.isArray(response)) {
|
|
91
|
+
events = response;
|
|
92
|
+
}
|
|
93
|
+
this.lastEventId = events[events.length - 1].id;
|
|
94
|
+
this.handlers.forEach((handler) => {
|
|
95
|
+
handler(events);
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
subscribe(handler) {
|
|
99
|
+
// console.log("subscribe", handler);
|
|
100
|
+
this.handlers.push(handler);
|
|
101
|
+
this.startPoll();
|
|
102
|
+
}
|
|
103
|
+
unsubscribe(handler) {
|
|
104
|
+
// console.log("unsubscribe", handler);
|
|
105
|
+
this.handlers = this.handlers.filter((existingHandler) => handler !== existingHandler);
|
|
106
|
+
if (!this.handlers.length) {
|
|
107
|
+
this.stopPoll();
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
const clients = {};
|
|
112
|
+
function createOrGetPollClient(url, appContext) {
|
|
113
|
+
if (!clients[url]) {
|
|
114
|
+
clients[url] = new PollClient(url, appContext);
|
|
115
|
+
}
|
|
116
|
+
clients[url].refreshAppContext(appContext);
|
|
117
|
+
return clients[url];
|
|
118
|
+
}
|
|
119
|
+
function RealTimeAdapter({ url, onEvent }) {
|
|
120
|
+
const appContext = (0, AppContext_1.useAppContext)();
|
|
121
|
+
(0, react_1.useEffect)(() => {
|
|
122
|
+
const pollClient = createOrGetPollClient(url, appContext);
|
|
123
|
+
const handler = (events) => {
|
|
124
|
+
events.forEach((event) => {
|
|
125
|
+
onEvent === null || onEvent === void 0 ? void 0 : onEvent(event);
|
|
126
|
+
});
|
|
127
|
+
};
|
|
128
|
+
pollClient.subscribe(handler);
|
|
129
|
+
return () => {
|
|
130
|
+
pollClient.unsubscribe(handler);
|
|
131
|
+
};
|
|
132
|
+
}, [appContext, onEvent, url]);
|
|
133
|
+
return null;
|
|
134
|
+
}
|
|
135
|
+
const metadata = {
|
|
136
|
+
displayName: "RealTimeAdapter",
|
|
137
|
+
description: "A non-visual component listening to real time change events through long-polling",
|
|
138
|
+
props: {
|
|
139
|
+
url: (0, descriptorHelper_1.desc)("URL to listen to for changes"),
|
|
140
|
+
},
|
|
141
|
+
events: {
|
|
142
|
+
eventArrived: (0, descriptorHelper_1.desc)("An event arrived that the adapter should process"),
|
|
143
|
+
},
|
|
144
|
+
};
|
|
145
|
+
exports.realTimeAdapterComponentRenderer = (0, renderers_1.createComponentRenderer)("RealTimeAdapter", ({ node, lookupEventHandler, extractValue }) => {
|
|
146
|
+
return (0, jsx_runtime_1.jsx)(RealTimeAdapter, { url: extractValue(node.props.url), onEvent: lookupEventHandler("eventArrived") });
|
|
147
|
+
}, metadata);
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.redirectRenderer = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const renderers_1 = require("@components-core/renderers");
|
|
6
|
+
const react_1 = require("@remix-run/react");
|
|
7
|
+
const component_utils_1 = require("../component-utils");
|
|
8
|
+
exports.redirectRenderer = (0, renderers_1.createComponentRenderer)("Redirect", ({ node, extractValue }) => {
|
|
9
|
+
return (0, jsx_runtime_1.jsx)(react_1.Navigate, { to: (0, component_utils_1.createUrlWithQueryParams)(extractValue(node.props.to)) });
|
|
10
|
+
});
|
|
@@ -0,0 +1,139 @@
|
|
|
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.selectComponentRenderer = void 0;
|
|
7
|
+
exports.Select = Select;
|
|
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 misc_1 = require("@components-core/utils/misc");
|
|
15
|
+
const Select_module_scss_1 = __importDefault(require("@components/Select/Select.module.scss"));
|
|
16
|
+
const Icon_1 = require("@components/Icon/Icon");
|
|
17
|
+
const container_helpers_1 = require("@components/container-helpers");
|
|
18
|
+
const classnames_1 = __importDefault(require("@components-core/utils/classnames"));
|
|
19
|
+
const react_popper_1 = require("react-popper");
|
|
20
|
+
const ThemeContext_1 = require("@components-core/theming/ThemeContext");
|
|
21
|
+
const react_dom_1 = require("react-dom");
|
|
22
|
+
const input_abstractions_1 = require("@components/Input/input-abstractions");
|
|
23
|
+
const themeVars_1 = require("@components-core/theming/themeVars");
|
|
24
|
+
const descriptorHelper_1 = require("@components-core/descriptorHelper");
|
|
25
|
+
const SelectContext_1 = require("./SelectContext");
|
|
26
|
+
const ChevronDownIcon_1 = require("@components/Icon/ChevronDownIcon");
|
|
27
|
+
const ChevronUpIcon_1 = require("@components/Icon/ChevronUpIcon");
|
|
28
|
+
function defaultRenderer(item) {
|
|
29
|
+
return (0, jsx_runtime_1.jsx)("div", { children: item.label });
|
|
30
|
+
}
|
|
31
|
+
function Select({ id, initialValue = "", value = "", enabled = true, placeholder, updateState = constants_1.noop, validationStatus = "none", onDidChange = constants_1.noop, onFocus = constants_1.noop, onBlur = constants_1.noop, registerComponentApi, optionRenderer = defaultRenderer, emptyListTemplate, layout, children, }) {
|
|
32
|
+
const { options, selectContextValue } = (0, SelectContext_1.useSelectContextValue)();
|
|
33
|
+
const [referenceElement, setReferenceElement] = (0, react_2.useState)(null);
|
|
34
|
+
const [popperElement, setPopperElement] = (0, react_2.useState)(null);
|
|
35
|
+
const { styles: popperStyles, attributes } = (0, react_popper_1.usePopper)(referenceElement, popperElement, {
|
|
36
|
+
placement: "bottom-start",
|
|
37
|
+
});
|
|
38
|
+
const { root } = (0, ThemeContext_1.useTheme)();
|
|
39
|
+
const { isOpen, selectedItem, getToggleButtonProps, getMenuProps, highlightedIndex, getItemProps } = (0, downshift_1.useSelect)({
|
|
40
|
+
//labelId: id,
|
|
41
|
+
toggleButtonId: id,
|
|
42
|
+
items: options,
|
|
43
|
+
itemToString(item) {
|
|
44
|
+
return item ? item.value + "" : "";
|
|
45
|
+
},
|
|
46
|
+
onSelectedItemChange: ({ selectedItem: newSelectedItem }) => {
|
|
47
|
+
if (newSelectedItem)
|
|
48
|
+
onInputChange(newSelectedItem);
|
|
49
|
+
},
|
|
50
|
+
initialSelectedItem: options.find((item) => item.value === value) || null,
|
|
51
|
+
selectedItem: options.find((item) => item.value === value) || null,
|
|
52
|
+
isItemDisabled: (item) => item.disabled,
|
|
53
|
+
});
|
|
54
|
+
// --- Initialize the related field with the input's initial value
|
|
55
|
+
(0, react_2.useEffect)(() => {
|
|
56
|
+
updateState({ value: initialValue });
|
|
57
|
+
}, [initialValue, updateState]);
|
|
58
|
+
const updateValue = (0, react_2.useCallback)((value) => {
|
|
59
|
+
updateState({ value });
|
|
60
|
+
onDidChange(value);
|
|
61
|
+
}, [onDidChange, updateState]);
|
|
62
|
+
const onInputChange = (0, react_2.useCallback)((selectedOption) => updateValue(selectedOption.value), [updateValue]);
|
|
63
|
+
// --- Manage obtaining and losing the focus
|
|
64
|
+
const handleOnFocus = (0, react_2.useCallback)(() => {
|
|
65
|
+
onFocus === null || onFocus === void 0 ? void 0 : onFocus();
|
|
66
|
+
}, [onFocus]);
|
|
67
|
+
const handleOnBlur = (0, react_2.useCallback)(() => {
|
|
68
|
+
onBlur === null || onBlur === void 0 ? void 0 : onBlur();
|
|
69
|
+
}, [onBlur]);
|
|
70
|
+
const focus = (0, react_2.useCallback)(() => {
|
|
71
|
+
referenceElement === null || referenceElement === void 0 ? void 0 : referenceElement.focus();
|
|
72
|
+
}, [referenceElement]);
|
|
73
|
+
const setValue = (0, misc_1.useEvent)((newValue) => {
|
|
74
|
+
updateValue(newValue);
|
|
75
|
+
});
|
|
76
|
+
(0, react_2.useEffect)(() => {
|
|
77
|
+
registerComponentApi === null || registerComponentApi === void 0 ? void 0 : registerComponentApi({
|
|
78
|
+
focus,
|
|
79
|
+
setValue,
|
|
80
|
+
});
|
|
81
|
+
}, [focus, registerComponentApi, setValue]);
|
|
82
|
+
// Sizing the dropdown list width to the reference button size
|
|
83
|
+
const [width, setWidth] = (0, react_2.useState)(0);
|
|
84
|
+
const observer = (0, react_2.useRef)();
|
|
85
|
+
(0, react_2.useEffect)(() => {
|
|
86
|
+
const current = referenceElement;
|
|
87
|
+
// --- We are already observing old element
|
|
88
|
+
if ((observer === null || observer === void 0 ? void 0 : observer.current) && current) {
|
|
89
|
+
observer.current.unobserve(current);
|
|
90
|
+
}
|
|
91
|
+
observer.current = new ResizeObserver(() => referenceElement && setWidth(referenceElement.clientWidth));
|
|
92
|
+
if (current && observer.current) {
|
|
93
|
+
observer.current.observe(referenceElement);
|
|
94
|
+
}
|
|
95
|
+
}, [referenceElement]);
|
|
96
|
+
return ((0, jsx_runtime_1.jsxs)(SelectContext_1.SelectContext.Provider, { value: selectContextValue, children: [children, (0, jsx_runtime_1.jsxs)("div", { className: Select_module_scss_1.default.selectContainer, style: layout, children: [(0, jsx_runtime_1.jsxs)("button", Object.assign({ type: "button", disabled: !enabled, className: (0, classnames_1.default)(Select_module_scss_1.default.selectToggleButton, Select_module_scss_1.default[validationStatus], {
|
|
97
|
+
[Select_module_scss_1.default.disabled]: !enabled,
|
|
98
|
+
}) }, getToggleButtonProps({ ref: (el) => setReferenceElement(el) }), { onFocus: handleOnFocus, onBlur: handleOnBlur, children: [selectedItem ? (0, jsx_runtime_1.jsx)("span", { children: selectedItem.label }) : (0, jsx_runtime_1.jsx)("span", { className: Select_module_scss_1.default.placeholder, children: placeholder }), (0, jsx_runtime_1.jsx)("span", { "aria-label": "toggle menu", className: Select_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 &&
|
|
99
|
+
root &&
|
|
100
|
+
(0, react_dom_1.createPortal)((0, jsx_runtime_1.jsx)("ul", Object.assign({ className: Select_module_scss_1.default.selectMenu, ref: (el) => setPopperElement(el), style: Object.assign(Object.assign({}, popperStyles.popper), { width }) }, attributes.popper, { children: options.length > 0 ? (options.map((item, index) => {
|
|
101
|
+
const props = getItemProps({ item, index });
|
|
102
|
+
return ((0, react_1.createElement)("li", Object.assign({}, props, { key: index, className: (0, classnames_1.default)(Select_module_scss_1.default.item, Select_module_scss_1.default.selectable, {
|
|
103
|
+
[Select_module_scss_1.default.itemActive]: highlightedIndex === index,
|
|
104
|
+
[Select_module_scss_1.default.itemSelected]: (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.value) === item.value,
|
|
105
|
+
[Select_module_scss_1.default.itemDisabled]: item.disabled,
|
|
106
|
+
}) }), optionRenderer(item)));
|
|
107
|
+
})) : ((0, jsx_runtime_1.jsx)("li", { className: Select_module_scss_1.default.item, children: emptyListTemplate !== null && emptyListTemplate !== void 0 ? emptyListTemplate : ((0, jsx_runtime_1.jsxs)("span", { className: Select_module_scss_1.default.empty, children: [(0, jsx_runtime_1.jsx)(Icon_1.Icon, { name: "noresult" }), "List is empty"] })) })) })), root) }))] })] }));
|
|
108
|
+
}
|
|
109
|
+
const defaultOptionRenderer = {
|
|
110
|
+
type: "Text",
|
|
111
|
+
props: {
|
|
112
|
+
value: "{$item.label}",
|
|
113
|
+
},
|
|
114
|
+
};
|
|
115
|
+
const metadata = {
|
|
116
|
+
displayName: "Select",
|
|
117
|
+
description: "A dropdown list of options",
|
|
118
|
+
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"), emptyListTemplate: (0, descriptorHelper_1.desc)("Template to render when the list is empty") }),
|
|
119
|
+
events: input_abstractions_1.inputComponentEventDescriptors,
|
|
120
|
+
themeVars: (0, themeVars_1.parseScssVar)(Select_module_scss_1.default.themeVars),
|
|
121
|
+
defaultThemeVars: {
|
|
122
|
+
"color-bg-menu-Select": "$color-bg-primary",
|
|
123
|
+
"shadow-menu-Select": "$shadow-md",
|
|
124
|
+
"radius-menu-Select": "$radius",
|
|
125
|
+
"color-bg-item-Select": "$color-bg-dropdown-item",
|
|
126
|
+
"color-bg-item-Select--hover": "$color-bg-dropdown-item--active",
|
|
127
|
+
light: {
|
|
128
|
+
"color-text-item-Select--disabled": "$color-surface-200",
|
|
129
|
+
},
|
|
130
|
+
dark: {
|
|
131
|
+
"color-text-item-Select--disabled": "$color-surface-800",
|
|
132
|
+
},
|
|
133
|
+
},
|
|
134
|
+
};
|
|
135
|
+
exports.selectComponentRenderer = (0, renderers_1.createComponentRenderer)("Select", ({ node, state, updateState, extractValue, renderChild, lookupEventHandler, layoutCss, registerComponentApi }) => {
|
|
136
|
+
return ((0, jsx_runtime_1.jsx)(Select, { layout: layoutCss, updateState: updateState, initialValue: extractValue(node.props.initialValue), value: state === null || state === void 0 ? void 0 : state.value, enabled: extractValue.asOptionalBoolean(node.props.enabled), placeholder: extractValue.asOptionalString(node.props.placeholder), validationStatus: extractValue(node.props.validationStatus), onDidChange: lookupEventHandler("didChange"), onFocus: lookupEventHandler("gotFocus"), onBlur: lookupEventHandler("lostFocus"), registerComponentApi: registerComponentApi, emptyListTemplate: renderChild(node.props.emptyListTemplate), optionRenderer: (item) => {
|
|
137
|
+
return ((0, jsx_runtime_1.jsx)(container_helpers_1.MemoizedItem, { node: node.props.optionTemplate || defaultOptionRenderer, item: item, renderChild: renderChild }));
|
|
138
|
+
}, children: renderChild(node.children) }));
|
|
139
|
+
}, metadata);
|
|
@@ -0,0 +1,45 @@
|
|
|
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.SelectContext = void 0;
|
|
7
|
+
exports.useSelectContextValue = useSelectContextValue;
|
|
8
|
+
exports.useSelectContext = useSelectContext;
|
|
9
|
+
const react_1 = require("react");
|
|
10
|
+
const immer_1 = __importDefault(require("immer"));
|
|
11
|
+
const constants_1 = require("@components-core/constants");
|
|
12
|
+
exports.SelectContext = (0, react_1.createContext)({
|
|
13
|
+
register: (col) => { },
|
|
14
|
+
unRegister: (id) => { },
|
|
15
|
+
});
|
|
16
|
+
function useSelectContextValue() {
|
|
17
|
+
const [options, setOptions] = (0, react_1.useState)(constants_1.EMPTY_ARRAY);
|
|
18
|
+
const selectContextValue = (0, react_1.useMemo)(() => {
|
|
19
|
+
return {
|
|
20
|
+
register: (column) => {
|
|
21
|
+
setOptions((0, immer_1.default)((draft) => {
|
|
22
|
+
const existing = draft.findIndex((col) => col.id === column.id);
|
|
23
|
+
if (existing < 0) {
|
|
24
|
+
draft.push(column);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
draft[existing] = column;
|
|
28
|
+
}
|
|
29
|
+
}));
|
|
30
|
+
},
|
|
31
|
+
unRegister: (id) => {
|
|
32
|
+
setOptions((0, immer_1.default)((draft) => {
|
|
33
|
+
return draft.filter((col) => col.id !== id);
|
|
34
|
+
}));
|
|
35
|
+
},
|
|
36
|
+
};
|
|
37
|
+
}, [setOptions]);
|
|
38
|
+
return {
|
|
39
|
+
options,
|
|
40
|
+
selectContextValue,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
function useSelectContext() {
|
|
44
|
+
return (0, react_1.useContext)(exports.SelectContext);
|
|
45
|
+
}
|
|
@@ -0,0 +1,88 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.selectionStoreComponentRenderer = void 0;
|
|
27
|
+
exports.useSelectionContext = useSelectionContext;
|
|
28
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
29
|
+
const react_1 = __importStar(require("react"));
|
|
30
|
+
const lodash_es_1 = require("lodash-es");
|
|
31
|
+
const misc_1 = require("@components-core/utils/misc");
|
|
32
|
+
const renderers_1 = require("@components-core/renderers");
|
|
33
|
+
const constants_1 = require("@components-core/constants");
|
|
34
|
+
const descriptorHelper_1 = require("@components-core/descriptorHelper");
|
|
35
|
+
const SelectionStore = ({ updateState = lodash_es_1.noop, idKey = "id", children, selectedItems = constants_1.EMPTY_ARRAY, registerComponentApi, }) => {
|
|
36
|
+
const [items, setItems] = (0, react_1.useState)(selectedItems);
|
|
37
|
+
const refreshSelection = (0, misc_1.useEvent)((allItems = constants_1.EMPTY_ARRAY) => {
|
|
38
|
+
setItems(allItems);
|
|
39
|
+
updateState({
|
|
40
|
+
value: allItems.filter((item) => !!selectedItems.find((si) => si[idKey] === item[idKey])),
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
const setSelectedRowIds = (0, misc_1.useEvent)((rowIds) => {
|
|
44
|
+
updateState({ value: items.filter((item) => rowIds.includes(item[idKey])) });
|
|
45
|
+
});
|
|
46
|
+
const clearSelection = (0, misc_1.useEvent)(() => {
|
|
47
|
+
setSelectedRowIds(constants_1.EMPTY_ARRAY);
|
|
48
|
+
});
|
|
49
|
+
(0, react_1.useLayoutEffect)(() => {
|
|
50
|
+
registerComponentApi({
|
|
51
|
+
clearSelection,
|
|
52
|
+
setSelectedRowIds,
|
|
53
|
+
refreshSelection,
|
|
54
|
+
});
|
|
55
|
+
}, [clearSelection, setSelectedRowIds, registerComponentApi, refreshSelection]);
|
|
56
|
+
// --- Pass this selection context to the provider
|
|
57
|
+
const contextValue = (0, react_1.useMemo)(() => {
|
|
58
|
+
return {
|
|
59
|
+
selectedItems,
|
|
60
|
+
setSelectedRowIds,
|
|
61
|
+
refreshSelection,
|
|
62
|
+
idKey,
|
|
63
|
+
};
|
|
64
|
+
}, [refreshSelection, selectedItems, setSelectedRowIds, idKey]);
|
|
65
|
+
return (0, jsx_runtime_1.jsx)(SelectionContext.Provider, { value: contextValue, children: children });
|
|
66
|
+
};
|
|
67
|
+
// Represents the default selection context
|
|
68
|
+
const SelectionContext = react_1.default.createContext({
|
|
69
|
+
selectedItems: [],
|
|
70
|
+
setSelectedRowIds: lodash_es_1.noop,
|
|
71
|
+
refreshSelection: lodash_es_1.noop,
|
|
72
|
+
idKey: "id",
|
|
73
|
+
});
|
|
74
|
+
const metadata = {
|
|
75
|
+
displayName: "SelectionStore",
|
|
76
|
+
description: "A component providing services to store the selection state of items in a list",
|
|
77
|
+
props: {
|
|
78
|
+
idKey: (0, descriptorHelper_1.desc)("The name of the property holding the unique ID of an item"),
|
|
79
|
+
},
|
|
80
|
+
};
|
|
81
|
+
exports.selectionStoreComponentRenderer = (0, renderers_1.createComponentRenderer)("SelectionStore", (rendererContext) => {
|
|
82
|
+
const { node, state, updateState, renderChild, registerComponentApi } = rendererContext;
|
|
83
|
+
return ((0, jsx_runtime_1.jsx)(SelectionStore, { updateState: updateState, idKey: node.props.idKey, selectedItems: state === null || state === void 0 ? void 0 : state.value, registerComponentApi: registerComponentApi, children: renderChild(node.children) }));
|
|
84
|
+
}, metadata);
|
|
85
|
+
// This React hook takes care of retrieving the current selection context
|
|
86
|
+
function useSelectionContext() {
|
|
87
|
+
return (0, react_1.useContext)(SelectionContext);
|
|
88
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
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.spaceFillerComponentRenderer = exports.SpaceFiller = void 0;
|
|
7
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
8
|
+
const renderers_1 = require("@components-core/renderers");
|
|
9
|
+
const SpaceFiller_module_scss_1 = __importDefault(require("./SpaceFiller.module.scss"));
|
|
10
|
+
const themeVars_1 = require("@components-core/theming/themeVars");
|
|
11
|
+
// =====================================================================================================================
|
|
12
|
+
// React SpaceFiller component implementation
|
|
13
|
+
const SpaceFiller = () => {
|
|
14
|
+
return (0, jsx_runtime_1.jsx)("div", { className: SpaceFiller_module_scss_1.default.spacer });
|
|
15
|
+
};
|
|
16
|
+
exports.SpaceFiller = SpaceFiller;
|
|
17
|
+
const metadata = {
|
|
18
|
+
displayName: "SpaceFiller",
|
|
19
|
+
description: "Fills the space between two components in a Stack or FlowLayout container.",
|
|
20
|
+
themeVars: (0, themeVars_1.parseScssVar)(SpaceFiller_module_scss_1.default.themeVars),
|
|
21
|
+
};
|
|
22
|
+
exports.spaceFillerComponentRenderer = (0, renderers_1.createComponentRenderer)("SpaceFiller", () => (0, jsx_runtime_1.jsx)(exports.SpaceFiller, {}), metadata);
|
|
@@ -0,0 +1,59 @@
|
|
|
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.spinnerComponentRenderer = void 0;
|
|
7
|
+
exports.Spinner = Spinner;
|
|
8
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
9
|
+
const Spinner_module_scss_1 = __importDefault(require("./Spinner.module.scss"));
|
|
10
|
+
const react_1 = require("react");
|
|
11
|
+
const renderers_1 = require("@components-core/renderers");
|
|
12
|
+
const themeVars_1 = require("@components-core/theming/themeVars");
|
|
13
|
+
// source https://loading.io/css/
|
|
14
|
+
function Spinner({ delay = 400, fullScreen = false, style, }) {
|
|
15
|
+
const [pastDelay, setPastDelay] = (0, react_1.useState)(delay === 0);
|
|
16
|
+
(0, react_1.useEffect)(() => {
|
|
17
|
+
const timeout = setTimeout(() => {
|
|
18
|
+
setPastDelay(true);
|
|
19
|
+
}, delay);
|
|
20
|
+
return () => {
|
|
21
|
+
clearTimeout(timeout);
|
|
22
|
+
};
|
|
23
|
+
}, [delay]);
|
|
24
|
+
const spinner = ((0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: (0, jsx_runtime_1.jsx)("div", { style: style, children: (0, jsx_runtime_1.jsxs)("div", { className: Spinner_module_scss_1.default["lds-ring"], children: [(0, jsx_runtime_1.jsx)("div", {}), (0, jsx_runtime_1.jsx)("div", {}), (0, jsx_runtime_1.jsx)("div", {}), (0, jsx_runtime_1.jsx)("div", {})] }) }) }));
|
|
25
|
+
if (!pastDelay) {
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
if (fullScreen) {
|
|
30
|
+
return (0, jsx_runtime_1.jsx)("div", { className: Spinner_module_scss_1.default.fullScreenSpinnerWrapper, children: spinner });
|
|
31
|
+
}
|
|
32
|
+
return spinner;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
const metadata = {
|
|
36
|
+
displayName: "Spinner",
|
|
37
|
+
description: "Component representing progress",
|
|
38
|
+
props: {},
|
|
39
|
+
themeVars: (0, themeVars_1.parseScssVar)(Spinner_module_scss_1.default.themeVars),
|
|
40
|
+
defaultThemeVars: {
|
|
41
|
+
"size-Spinner": "$space-10",
|
|
42
|
+
"thickness-Spinner": "$space-0_5",
|
|
43
|
+
light: {
|
|
44
|
+
"color-border-Spinner": "$color-surface-400",
|
|
45
|
+
},
|
|
46
|
+
dark: {
|
|
47
|
+
"color-border-Spinner": "$color-surface-600",
|
|
48
|
+
},
|
|
49
|
+
},
|
|
50
|
+
};
|
|
51
|
+
exports.spinnerComponentRenderer = (0, renderers_1.createComponentRenderer)("Spinner", ({ node, layoutCss, extractValue }) => {
|
|
52
|
+
delete layoutCss.width;
|
|
53
|
+
delete layoutCss.minWidth;
|
|
54
|
+
delete layoutCss.maxWidth;
|
|
55
|
+
delete layoutCss.height;
|
|
56
|
+
delete layoutCss.minHeight;
|
|
57
|
+
delete layoutCss.maxHeight;
|
|
58
|
+
return ((0, jsx_runtime_1.jsx)(Spinner, { style: layoutCss, delay: extractValue.asOptionalNumber(node.props.delay), fullScreen: extractValue.asOptionalBoolean(node.props.fullScreen) }));
|
|
59
|
+
}, metadata);
|