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,184 @@
|
|
|
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.pieChartComponentRenderer = void 0;
|
|
30
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
31
|
+
const react_1 = __importStar(require("react"));
|
|
32
|
+
const renderers_1 = require("@components-core/renderers");
|
|
33
|
+
const descriptorHelper_1 = require("@components-core/descriptorHelper");
|
|
34
|
+
const PieChart_module_scss_1 = __importDefault(require("./PieChart.module.scss"));
|
|
35
|
+
const themeVars_1 = require("@components-core/theming/themeVars");
|
|
36
|
+
const ThemeContext_1 = require("@components-core/theming/ThemeContext");
|
|
37
|
+
const chart_color_schemes_1 = __importDefault(require("@components/chart-color-schemes"));
|
|
38
|
+
const classnames_1 = __importDefault(require("classnames"));
|
|
39
|
+
const hooks_1 = require("@components-core/utils/hooks");
|
|
40
|
+
const ResponsivePie = react_1.default.lazy(() => Promise.resolve().then(() => __importStar(require("@nivo/pie"))).then((module) => ({ default: module.ResponsivePie })));
|
|
41
|
+
const PieChart = ({ data = [], isInteractive = true, style, showLabels = false, showLegends = true, legendPosition = "bottom", legendDirection = "row", }) => {
|
|
42
|
+
const { getThemeVar } = (0, ThemeContext_1.useTheme)();
|
|
43
|
+
const [customLegendData, setCustomLegendData] = react_1.default.useState([]);
|
|
44
|
+
const colors = (0, hooks_1.useColors)({
|
|
45
|
+
name: "color-text-PieChart",
|
|
46
|
+
format: "hex",
|
|
47
|
+
}, {
|
|
48
|
+
name: "color-ticks-PieChart",
|
|
49
|
+
format: "hex",
|
|
50
|
+
}, {
|
|
51
|
+
name: "color-bg-tooltip-PieChart",
|
|
52
|
+
format: "hex",
|
|
53
|
+
}, {
|
|
54
|
+
name: "color-text-tooltip-PieChart",
|
|
55
|
+
format: "hex",
|
|
56
|
+
}, {
|
|
57
|
+
name: "color-axis-PieChart",
|
|
58
|
+
format: "hex",
|
|
59
|
+
}, {
|
|
60
|
+
name: "color-text-legend-PieChart",
|
|
61
|
+
format: "hex",
|
|
62
|
+
});
|
|
63
|
+
const pieChart = (0, react_1.useMemo)(() => ((0, jsx_runtime_1.jsx)(ResponsivePie, { fit: true, data: data, colors: { scheme: chart_color_schemes_1.default[getThemeVar("scheme-PieChart")] }, margin: { top: 12, right: 12, bottom: 12, left: 12 }, forwardLegendData: setCustomLegendData, theme: {
|
|
64
|
+
background: "transparent",
|
|
65
|
+
text: {
|
|
66
|
+
fontSize: 11,
|
|
67
|
+
fill: colors["color-text-PieChart"],
|
|
68
|
+
outlineWidth: 0,
|
|
69
|
+
outlineColor: "transparent",
|
|
70
|
+
},
|
|
71
|
+
axis: {
|
|
72
|
+
domain: {
|
|
73
|
+
line: {
|
|
74
|
+
stroke: colors["color-axis-PieChart"],
|
|
75
|
+
strokeWidth: 1,
|
|
76
|
+
},
|
|
77
|
+
},
|
|
78
|
+
legend: {
|
|
79
|
+
text: {
|
|
80
|
+
fontSize: 12,
|
|
81
|
+
fill: colors["color-text-legend-PieChart"],
|
|
82
|
+
outlineWidth: 0,
|
|
83
|
+
outlineColor: "transparent",
|
|
84
|
+
},
|
|
85
|
+
},
|
|
86
|
+
ticks: {
|
|
87
|
+
line: {
|
|
88
|
+
stroke: "#777777",
|
|
89
|
+
strokeWidth: 1,
|
|
90
|
+
},
|
|
91
|
+
text: {
|
|
92
|
+
fontSize: 11,
|
|
93
|
+
fill: colors["color-ticks-PieChart"],
|
|
94
|
+
outlineWidth: 0,
|
|
95
|
+
outlineColor: "transparent",
|
|
96
|
+
},
|
|
97
|
+
},
|
|
98
|
+
},
|
|
99
|
+
grid: {
|
|
100
|
+
line: {
|
|
101
|
+
stroke: "#dddddd",
|
|
102
|
+
strokeWidth: 1,
|
|
103
|
+
},
|
|
104
|
+
},
|
|
105
|
+
annotations: {
|
|
106
|
+
text: {
|
|
107
|
+
fontSize: 13,
|
|
108
|
+
fill: "#333333",
|
|
109
|
+
outlineWidth: 2,
|
|
110
|
+
outlineColor: "#ffffff",
|
|
111
|
+
outlineOpacity: 1,
|
|
112
|
+
},
|
|
113
|
+
link: {
|
|
114
|
+
stroke: "#000000",
|
|
115
|
+
strokeWidth: 1,
|
|
116
|
+
outlineWidth: 2,
|
|
117
|
+
outlineColor: "#ffffff",
|
|
118
|
+
outlineOpacity: 1,
|
|
119
|
+
},
|
|
120
|
+
outline: {
|
|
121
|
+
stroke: "#000000",
|
|
122
|
+
strokeWidth: 2,
|
|
123
|
+
outlineWidth: 2,
|
|
124
|
+
outlineColor: "#ffffff",
|
|
125
|
+
outlineOpacity: 1,
|
|
126
|
+
},
|
|
127
|
+
symbol: {
|
|
128
|
+
fill: "#000000",
|
|
129
|
+
outlineWidth: 2,
|
|
130
|
+
outlineColor: "#ffffff",
|
|
131
|
+
outlineOpacity: 1,
|
|
132
|
+
},
|
|
133
|
+
},
|
|
134
|
+
tooltip: {
|
|
135
|
+
wrapper: {},
|
|
136
|
+
container: {
|
|
137
|
+
background: colors["color-bg-tooltip-PieChart"],
|
|
138
|
+
color: colors["color-text-tooltip-PieChart"],
|
|
139
|
+
fontSize: 12,
|
|
140
|
+
},
|
|
141
|
+
basic: {},
|
|
142
|
+
chip: {},
|
|
143
|
+
table: {},
|
|
144
|
+
tableCell: {},
|
|
145
|
+
tableCellValue: {},
|
|
146
|
+
},
|
|
147
|
+
}, padAngle: 0.7, cornerRadius: 3, activeOuterRadiusOffset: 8, borderWidth: 1, borderColor: { from: "color", modifiers: [["darker", 0.2]] }, enableArcLinkLabels: showLabels, arcLinkLabelsSkipAngle: 10, arcLinkLabelsThickness: 2, arcLabelsSkipAngle: 10, isInteractive: isInteractive })), [showLegends, data, colors, isInteractive, legendPosition, legendDirection]);
|
|
148
|
+
return ((0, jsx_runtime_1.jsx)(react_1.Suspense, { children: (0, jsx_runtime_1.jsx)("div", { style: Object.assign({}, style), children: (0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)(PieChart_module_scss_1.default.chart, {
|
|
149
|
+
[PieChart_module_scss_1.default.legendTop]: legendPosition === "top",
|
|
150
|
+
[PieChart_module_scss_1.default.legendRight]: legendPosition === "right",
|
|
151
|
+
[PieChart_module_scss_1.default.legendBottom]: legendPosition === "bottom",
|
|
152
|
+
[PieChart_module_scss_1.default.legendLeft]: legendPosition === "left",
|
|
153
|
+
}), children: [(0, jsx_runtime_1.jsx)("div", { className: PieChart_module_scss_1.default.wrapper, children: (0, jsx_runtime_1.jsx)("div", { className: PieChart_module_scss_1.default.chartContainer, children: pieChart }) }), showLegends && ((0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)(PieChart_module_scss_1.default.legends, {
|
|
154
|
+
[PieChart_module_scss_1.default.legendRow]: legendDirection === "row",
|
|
155
|
+
[PieChart_module_scss_1.default.legendColumn]: legendDirection === "column",
|
|
156
|
+
}), children: customLegendData.map((item, i) => ((0, jsx_runtime_1.jsxs)("div", { className: PieChart_module_scss_1.default.legendItem, children: [(0, jsx_runtime_1.jsx)("div", { className: PieChart_module_scss_1.default.legendBullet, style: { backgroundColor: item.color } }), (0, jsx_runtime_1.jsx)("div", { className: PieChart_module_scss_1.default.legendLabel, children: item.label })] }, i))) }))] }) }) }));
|
|
157
|
+
};
|
|
158
|
+
const metadata = {
|
|
159
|
+
displayName: "PieChart",
|
|
160
|
+
description: "A pie chart component",
|
|
161
|
+
props: {
|
|
162
|
+
data: (0, descriptorHelper_1.desc)("The data to be displayed in the pie chart"),
|
|
163
|
+
},
|
|
164
|
+
themeVars: (0, themeVars_1.parseScssVar)(PieChart_module_scss_1.default.themeVars),
|
|
165
|
+
defaultThemeVars: {
|
|
166
|
+
"scheme-PieChart": "nivo",
|
|
167
|
+
"color-text-PieChart": "$color-text-secondary",
|
|
168
|
+
"color-ticks-PieChart": "$color-text-primary",
|
|
169
|
+
"color-bg-tooltip-PieChart": "$color-bg-primary",
|
|
170
|
+
"color-text-tooltip-PieChart": "$color-text-primary",
|
|
171
|
+
"color-axis-PieChart": "$color-text-primary",
|
|
172
|
+
"color-text-legend-PieChart": "$color-text-primary",
|
|
173
|
+
light: {
|
|
174
|
+
"scheme-PieChart": "set3",
|
|
175
|
+
},
|
|
176
|
+
dark: {
|
|
177
|
+
"scheme-PieChart": "dark2",
|
|
178
|
+
},
|
|
179
|
+
},
|
|
180
|
+
};
|
|
181
|
+
exports.pieChartComponentRenderer = (0, renderers_1.createComponentRenderer)("PieChart", ({ extractValue, node, layoutCss }) => {
|
|
182
|
+
var _a, _b, _c, _d, _e, _f;
|
|
183
|
+
return ((0, jsx_runtime_1.jsx)(PieChart, { data: extractValue((_a = node.props) === null || _a === void 0 ? void 0 : _a.data), isInteractive: extractValue.asOptionalBoolean((_b = node.props) === null || _b === void 0 ? void 0 : _b.isInteractive), showLabels: extractValue.asOptionalBoolean((_c = node.props) === null || _c === void 0 ? void 0 : _c.showLabels), style: layoutCss, showLegends: extractValue.asOptionalBoolean((_d = node.props) === null || _d === void 0 ? void 0 : _d.showLegends), legendPosition: extractValue((_e = node.props) === null || _e === void 0 ? void 0 : _e.legendPosition), legendDirection: extractValue((_f = node.props) === null || _f === void 0 ? void 0 : _f.legendDirection) }));
|
|
184
|
+
}, metadata);
|
|
@@ -0,0 +1,29 @@
|
|
|
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.positionedContainerComponentRenderer = void 0;
|
|
7
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
8
|
+
const renderers_1 = require("@components-core/renderers");
|
|
9
|
+
const PositionedContainer_module_scss_1 = __importDefault(require("./PositionedContainer.module.scss"));
|
|
10
|
+
const classnames_1 = __importDefault(require("@components-core/utils/classnames"));
|
|
11
|
+
const descriptorHelper_1 = require("@components-core/descriptorHelper");
|
|
12
|
+
const themeVars_1 = require("@components-core/theming/themeVars");
|
|
13
|
+
function PositionedContainer({ children, top, right, bottom, left, visibleOnHover = false, }) {
|
|
14
|
+
return ((0, jsx_runtime_1.jsx)("div", { style: { top, right, bottom, left }, className: (0, classnames_1.default)(PositionedContainer_module_scss_1.default.wrapper, {
|
|
15
|
+
[PositionedContainer_module_scss_1.default.visibleOnHover]: visibleOnHover,
|
|
16
|
+
}), children: children }));
|
|
17
|
+
}
|
|
18
|
+
const metadata = {
|
|
19
|
+
displayName: "PositionedContainer",
|
|
20
|
+
description: "",
|
|
21
|
+
props: {
|
|
22
|
+
visibleOnHover: (0, descriptorHelper_1.desc)(""),
|
|
23
|
+
},
|
|
24
|
+
themeVars: (0, themeVars_1.parseScssVar)(PositionedContainer_module_scss_1.default.themeVars),
|
|
25
|
+
};
|
|
26
|
+
exports.positionedContainerComponentRenderer = (0, renderers_1.createComponentRenderer)("PositionedContainer", ({ node, extractValue, renderChild, layoutCss }) => {
|
|
27
|
+
return ((0, jsx_runtime_1.jsx)(PositionedContainer, { top: layoutCss.top, right: layoutCss.right, bottom: layoutCss.bottom, left: layoutCss.left, visibleOnHover: extractValue.asOptionalBoolean(node.props.visibleOnHover), children: renderChild(node.children) }));
|
|
28
|
+
}, metadata);
|
|
29
|
+
exports.default = PositionedContainer;
|
|
@@ -0,0 +1,38 @@
|
|
|
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.progressBarComponentRenderer = void 0;
|
|
7
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
8
|
+
const renderers_1 = require("@components-core/renderers");
|
|
9
|
+
const ProgressBar_module_scss_1 = __importDefault(require("./ProgressBar.module.scss"));
|
|
10
|
+
const descriptorHelper_1 = require("@components-core/descriptorHelper");
|
|
11
|
+
const themeVars_1 = require("@components-core/theming/themeVars");
|
|
12
|
+
function ProgressBar({ value = 0, style }) {
|
|
13
|
+
return ((0, jsx_runtime_1.jsx)("div", { className: ProgressBar_module_scss_1.default.wrapper, style: style, children: (0, jsx_runtime_1.jsx)("div", { style: { width: `${value * 100}%` }, className: ProgressBar_module_scss_1.default.bar }) }));
|
|
14
|
+
}
|
|
15
|
+
const metadata = {
|
|
16
|
+
displayName: "ProgressBar",
|
|
17
|
+
description: "Display a progress value",
|
|
18
|
+
props: {
|
|
19
|
+
value: (0, descriptorHelper_1.desc)("Progress value (from 0 to 1) to display"),
|
|
20
|
+
},
|
|
21
|
+
themeVars: (0, themeVars_1.parseScssVar)(ProgressBar_module_scss_1.default.themeVars),
|
|
22
|
+
defaultThemeVars: {
|
|
23
|
+
"radius-ProgressBar": "$radius",
|
|
24
|
+
"radius-indicator-ProgressBar": "$radius",
|
|
25
|
+
"thickness-ProgressBar": "$space-2",
|
|
26
|
+
light: {
|
|
27
|
+
"color-bg-ProgressBar": "$color-surface-200",
|
|
28
|
+
"color-indicator-ProgressBar": "$color-primary-500",
|
|
29
|
+
},
|
|
30
|
+
dark: {
|
|
31
|
+
"color-bg-ProgressBar": "$color-surface-700",
|
|
32
|
+
"color-indicator-ProgressBar": "$color-primary-500",
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
};
|
|
36
|
+
exports.progressBarComponentRenderer = (0, renderers_1.createComponentRenderer)("ProgressBar", ({ node, extractValue, layoutCss }) => {
|
|
37
|
+
return (0, jsx_runtime_1.jsx)(ProgressBar, { value: Math.max(0, Math.min(1, extractValue(node.props.value))), style: layoutCss });
|
|
38
|
+
}, metadata);
|
|
@@ -0,0 +1,286 @@
|
|
|
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.queueComponentRenderer = void 0;
|
|
16
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
17
|
+
const react_1 = require("react");
|
|
18
|
+
const renderers_1 = require("@components-core/renderers");
|
|
19
|
+
const react_hot_toast_1 = __importDefault(require("react-hot-toast"));
|
|
20
|
+
const lodash_es_1 = require("lodash-es");
|
|
21
|
+
const misc_1 = require("@components-core/utils/misc");
|
|
22
|
+
const AppContext_1 = require("@components-core/AppContext");
|
|
23
|
+
const descriptorHelper_1 = require("@components-core/descriptorHelper");
|
|
24
|
+
const immer_1 = __importDefault(require("immer"));
|
|
25
|
+
const queueActions_1 = require("@components/Queue/queueActions");
|
|
26
|
+
const container_helpers_1 = require("@components/container-helpers");
|
|
27
|
+
const hooks_1 = require("@components-core/utils/hooks");
|
|
28
|
+
const queueReducer = (0, immer_1.default)((state, action) => {
|
|
29
|
+
switch (action.type) {
|
|
30
|
+
case queueActions_1.QueueActionKind.ACTION_QUEUE_INITIALIZED: {
|
|
31
|
+
const queueState = {};
|
|
32
|
+
const itemsById = {};
|
|
33
|
+
action.payload.queue.forEach((item, index) => {
|
|
34
|
+
itemsById[action.payload.actionItemIds[index]] = item;
|
|
35
|
+
});
|
|
36
|
+
const queue = Object.keys(itemsById);
|
|
37
|
+
Object.entries(itemsById).forEach(([actionItemId, item]) => {
|
|
38
|
+
queueState[actionItemId] = {
|
|
39
|
+
batchId: action.payload.batchId,
|
|
40
|
+
actionItemId,
|
|
41
|
+
status: "pending",
|
|
42
|
+
item,
|
|
43
|
+
};
|
|
44
|
+
});
|
|
45
|
+
return {
|
|
46
|
+
queue: [...(state.queue || []), ...queue],
|
|
47
|
+
queueState: Object.assign(Object.assign({}, state.queueState), queueState),
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
case queueActions_1.QueueActionKind.ACTION_ITEM_STARTED: {
|
|
51
|
+
if (state.queueState[action.payload.actionItemId]) {
|
|
52
|
+
state.queueState[action.payload.actionItemId].status = "started";
|
|
53
|
+
}
|
|
54
|
+
break;
|
|
55
|
+
}
|
|
56
|
+
case queueActions_1.QueueActionKind.ACTION_ITEM_PROGRESS: {
|
|
57
|
+
if (state.queueState[action.payload.actionItemId]) {
|
|
58
|
+
state.queueState[action.payload.actionItemId].status = "in-progress";
|
|
59
|
+
state.queueState[action.payload.actionItemId].progress = action.payload.progressEvent;
|
|
60
|
+
}
|
|
61
|
+
break;
|
|
62
|
+
}
|
|
63
|
+
case queueActions_1.QueueActionKind.ACTION_ITEM_COMPLETED: {
|
|
64
|
+
state.queue = state.queue.filter((aiId) => aiId !== action.payload.actionItemId);
|
|
65
|
+
if (state.queueState[action.payload.actionItemId]) {
|
|
66
|
+
state.queueState[action.payload.actionItemId].status = "completed";
|
|
67
|
+
state.queueState[action.payload.actionItemId].result = action.payload.result;
|
|
68
|
+
}
|
|
69
|
+
break;
|
|
70
|
+
}
|
|
71
|
+
case queueActions_1.QueueActionKind.ACTION_ITEM_REMOVED: {
|
|
72
|
+
state.queue = state.queue.filter((aiId) => aiId !== action.payload.actionItemId);
|
|
73
|
+
delete state.queueState[action.payload.actionItemId];
|
|
74
|
+
break;
|
|
75
|
+
}
|
|
76
|
+
case queueActions_1.QueueActionKind.ACTION_ITEM_ERROR: {
|
|
77
|
+
state.queue = state.queue.filter((aiId) => aiId !== action.payload.actionItemId);
|
|
78
|
+
if (state.queueState[action.payload.actionItemId]) {
|
|
79
|
+
state.queueState[action.payload.actionItemId].status = "error";
|
|
80
|
+
state.queueState[action.payload.actionItemId].error = action.payload.error;
|
|
81
|
+
}
|
|
82
|
+
break;
|
|
83
|
+
}
|
|
84
|
+
case queueActions_1.QueueActionKind.CLEAR_COMPLETED_ACTION_ITEMS: {
|
|
85
|
+
if (state.queueState) {
|
|
86
|
+
Object.entries(state.queueState).forEach(([key, value]) => {
|
|
87
|
+
if (value.status === "completed" || value.status === "error") {
|
|
88
|
+
delete state.queueState[key];
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
break;
|
|
93
|
+
}
|
|
94
|
+
default:
|
|
95
|
+
throw new Error();
|
|
96
|
+
}
|
|
97
|
+
// console.log("queue action arrived", action);
|
|
98
|
+
// console.log("queue state", cloneDeep(state));
|
|
99
|
+
});
|
|
100
|
+
const INITIAL_STATE = {
|
|
101
|
+
queue: [],
|
|
102
|
+
queueState: {},
|
|
103
|
+
};
|
|
104
|
+
function Queue({ registerComponentApi, willProcessItem, processItem, didProcessItem, processItemError, onComplete, progressFeedback, resultFeedback, renderResultFeedback, clearAfterFinish = true, }) {
|
|
105
|
+
const runningActionItemRef = (0, react_1.useRef)(new Set());
|
|
106
|
+
const [queueState, dispatch] = (0, react_1.useReducer)(queueReducer, INITIAL_STATE);
|
|
107
|
+
let appContext = (0, AppContext_1.useAppContext)();
|
|
108
|
+
// --- This Queue API adds a single item to the queue
|
|
109
|
+
const enqueueItem = (0, misc_1.useEvent)((item) => {
|
|
110
|
+
const itemId = (0, misc_1.generatedId)();
|
|
111
|
+
dispatch((0, queueActions_1.actionQueueInitialized)([item], (0, misc_1.generatedId)(), [itemId]));
|
|
112
|
+
return itemId;
|
|
113
|
+
});
|
|
114
|
+
// --- This Queue API adds a list of items to the queue
|
|
115
|
+
const enqueueItems = (0, misc_1.useEvent)((items) => {
|
|
116
|
+
const itemIds = items.map(() => (0, misc_1.generatedId)());
|
|
117
|
+
dispatch((0, queueActions_1.actionQueueInitialized)(items, (0, misc_1.generatedId)(), itemIds));
|
|
118
|
+
return itemIds;
|
|
119
|
+
});
|
|
120
|
+
const clearCompleted = (0, react_1.useCallback)(() => {
|
|
121
|
+
dispatch((0, queueActions_1.clearCompletedActionItems)());
|
|
122
|
+
}, []);
|
|
123
|
+
const remove = (0, react_1.useCallback)((actionItemId) => {
|
|
124
|
+
if (actionItemId) {
|
|
125
|
+
dispatch((0, queueActions_1.removeActionItem)(actionItemId));
|
|
126
|
+
}
|
|
127
|
+
}, []);
|
|
128
|
+
const getQueueLength = (0, react_1.useCallback)(() => {
|
|
129
|
+
return queueState.queue.length;
|
|
130
|
+
}, [queueState.queue.length]);
|
|
131
|
+
const getQueuedItems = (0, react_1.useCallback)(() => {
|
|
132
|
+
// console.log("GET QUEUED ITEMS", Object.values(queueState.queueState));
|
|
133
|
+
return Object.values(queueState.queueState);
|
|
134
|
+
}, [queueState.queueState]);
|
|
135
|
+
(0, react_1.useEffect)(() => {
|
|
136
|
+
registerComponentApi({
|
|
137
|
+
enqueueItem,
|
|
138
|
+
enqueueItems,
|
|
139
|
+
clearCompleted,
|
|
140
|
+
remove,
|
|
141
|
+
getQueueLength,
|
|
142
|
+
getQueuedItems,
|
|
143
|
+
});
|
|
144
|
+
}, [registerComponentApi, enqueueItem, enqueueItems, clearCompleted, remove, getQueueLength, getQueuedItems]);
|
|
145
|
+
const doSingle = (0, react_1.useCallback)((actionItemId) => __awaiter(this, void 0, void 0, function* () {
|
|
146
|
+
const queueItem = queueState.queueState[actionItemId];
|
|
147
|
+
if ((queueItem === null || queueItem === void 0 ? void 0 : queueItem.status) !== "pending") {
|
|
148
|
+
return;
|
|
149
|
+
}
|
|
150
|
+
if (runningActionItemRef.current.has(actionItemId)) {
|
|
151
|
+
return;
|
|
152
|
+
}
|
|
153
|
+
runningActionItemRef.current.add(actionItemId);
|
|
154
|
+
const item = queueItem.item;
|
|
155
|
+
let processItemContext = {};
|
|
156
|
+
try {
|
|
157
|
+
const willProcessResult = yield (willProcessItem === null || willProcessItem === void 0 ? void 0 : willProcessItem({
|
|
158
|
+
item,
|
|
159
|
+
actionItemId,
|
|
160
|
+
processItemContext,
|
|
161
|
+
}));
|
|
162
|
+
processItemContext = Object.assign(Object.assign({}, processItemContext), { willProcessResult: willProcessResult });
|
|
163
|
+
if (willProcessResult === false) {
|
|
164
|
+
dispatch((0, queueActions_1.removeActionItem)(actionItemId));
|
|
165
|
+
return;
|
|
166
|
+
}
|
|
167
|
+
dispatch((0, queueActions_1.actionItemStarted)(actionItemId));
|
|
168
|
+
const result = yield (processItem === null || processItem === void 0 ? void 0 : processItem({
|
|
169
|
+
item: item,
|
|
170
|
+
actionItemId,
|
|
171
|
+
processItemContext,
|
|
172
|
+
onProgress: (progressEvent) => {
|
|
173
|
+
dispatch((0, queueActions_1.actionItemProgress)(actionItemId, progressEvent));
|
|
174
|
+
},
|
|
175
|
+
}));
|
|
176
|
+
processItemContext = Object.assign(Object.assign({}, processItemContext), { processResult: result });
|
|
177
|
+
yield (didProcessItem === null || didProcessItem === void 0 ? void 0 : didProcessItem({
|
|
178
|
+
item,
|
|
179
|
+
actionItemId,
|
|
180
|
+
processItemContext,
|
|
181
|
+
}));
|
|
182
|
+
dispatch((0, queueActions_1.actionItemCompleted)(actionItemId, result));
|
|
183
|
+
}
|
|
184
|
+
catch (error) {
|
|
185
|
+
let result = yield (processItemError === null || processItemError === void 0 ? void 0 : processItemError(error, {
|
|
186
|
+
item,
|
|
187
|
+
actionItemId,
|
|
188
|
+
processItemContext,
|
|
189
|
+
}));
|
|
190
|
+
dispatch((0, queueActions_1.actionItemError)(actionItemId, error));
|
|
191
|
+
if (result !== false) {
|
|
192
|
+
appContext.signError(error);
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
finally {
|
|
196
|
+
runningActionItemRef.current.delete(actionItemId);
|
|
197
|
+
}
|
|
198
|
+
}), [appContext, didProcessItem, dispatch, processItem, processItemError, queueState.queueState, willProcessItem]);
|
|
199
|
+
const toastId = (0, react_1.useRef)();
|
|
200
|
+
const queue = queueState.queue;
|
|
201
|
+
const prevQueue = (0, hooks_1.usePrevious)(queue);
|
|
202
|
+
const doComplete = (0, react_1.useCallback)(() => {
|
|
203
|
+
onComplete === null || onComplete === void 0 ? void 0 : onComplete();
|
|
204
|
+
const completedItems = getQueuedItems().filter((item) => item.status === "completed");
|
|
205
|
+
const resultFeedback = renderResultFeedback === null || renderResultFeedback === void 0 ? void 0 : renderResultFeedback(completedItems);
|
|
206
|
+
if (resultFeedback && completedItems.length) {
|
|
207
|
+
let currentToast = toastId.current;
|
|
208
|
+
react_hot_toast_1.default.success((0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: resultFeedback }), {
|
|
209
|
+
id: currentToast,
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
else {
|
|
213
|
+
if (toastId.current) {
|
|
214
|
+
let currentToast = toastId.current;
|
|
215
|
+
react_hot_toast_1.default.dismiss(currentToast);
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
// toastId.current = undefined;
|
|
219
|
+
if (clearAfterFinish) {
|
|
220
|
+
clearCompleted();
|
|
221
|
+
}
|
|
222
|
+
}, [clearAfterFinish, clearCompleted, getQueuedItems, onComplete, renderResultFeedback]);
|
|
223
|
+
//with useEffect, it's showing the previous state for some reason, review!
|
|
224
|
+
(0, react_1.useLayoutEffect)(() => {
|
|
225
|
+
if (!queue.length) {
|
|
226
|
+
return;
|
|
227
|
+
}
|
|
228
|
+
if (progressFeedback) {
|
|
229
|
+
if (toastId.current) {
|
|
230
|
+
let anotherLoading = react_hot_toast_1.default.loading((0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: progressFeedback }), {
|
|
231
|
+
id: toastId.current,
|
|
232
|
+
});
|
|
233
|
+
// console.log("reusing toast, loading toast", toastId.current, anotherLoading);
|
|
234
|
+
}
|
|
235
|
+
else {
|
|
236
|
+
toastId.current = react_hot_toast_1.default.loading((0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: progressFeedback }));
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
}, [progressFeedback, queue === null || queue === void 0 ? void 0 : queue.length]);
|
|
240
|
+
(0, react_1.useEffect)(() => {
|
|
241
|
+
if (!queue) {
|
|
242
|
+
return;
|
|
243
|
+
}
|
|
244
|
+
if (prevQueue === queue) {
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
if ((0, lodash_es_1.isEqual)(prevQueue, queue)) {
|
|
248
|
+
return;
|
|
249
|
+
}
|
|
250
|
+
if ((prevQueue === null || prevQueue === void 0 ? void 0 : prevQueue.length) && !queue.length) {
|
|
251
|
+
doComplete();
|
|
252
|
+
return;
|
|
253
|
+
}
|
|
254
|
+
let queueItem = queue[0];
|
|
255
|
+
(() => __awaiter(this, void 0, void 0, function* () {
|
|
256
|
+
yield doSingle(queueItem);
|
|
257
|
+
}))();
|
|
258
|
+
}, [doComplete, doSingle, prevQueue, queue]);
|
|
259
|
+
return null;
|
|
260
|
+
}
|
|
261
|
+
const metadata = {
|
|
262
|
+
displayName: "Queue",
|
|
263
|
+
description: "A queue managing tasks to process in a FIFO order",
|
|
264
|
+
props: {
|
|
265
|
+
progressFeedback: (0, descriptorHelper_1.desc)("The template of the component that provides progress feedback"),
|
|
266
|
+
resultFeedback: (0, descriptorHelper_1.desc)("The template of the component that displays result feedback"),
|
|
267
|
+
clearAfterFinish: (0, descriptorHelper_1.desc)("Should completed items be removed from the queue?"),
|
|
268
|
+
},
|
|
269
|
+
nonVisual: true,
|
|
270
|
+
events: {
|
|
271
|
+
willProcess: (0, descriptorHelper_1.desc)("This item is fired when an item is about to be processed"),
|
|
272
|
+
process: (0, descriptorHelper_1.desc)("This event is triggered to process a particular item"),
|
|
273
|
+
didProcess: (0, descriptorHelper_1.desc)("This event is fired when a particular item's processing has finished"),
|
|
274
|
+
processError: (0, descriptorHelper_1.desc)("This event is raised when an item processed with an error"),
|
|
275
|
+
complete: (0, descriptorHelper_1.desc)("This event is raised when an item's processing has been successfully completed"),
|
|
276
|
+
},
|
|
277
|
+
};
|
|
278
|
+
exports.queueComponentRenderer = (0, renderers_1.createComponentRenderer)("Queue", ({ node, registerComponentApi, lookupEventHandler, renderChild, extractValue }) => {
|
|
279
|
+
return ((0, jsx_runtime_1.jsx)(Queue, { registerComponentApi: registerComponentApi, progressFeedback: renderChild(node.props.progressFeedback), resultFeedback: renderChild(node.props.resultFeedback), renderResultFeedback: node.props.resultFeedback
|
|
280
|
+
? (completedItems) => {
|
|
281
|
+
return ((0, jsx_runtime_1.jsx)(container_helpers_1.MemoizedItem, { node: node.props.resultFeedback, contextVars: {
|
|
282
|
+
$completedItems: completedItems,
|
|
283
|
+
}, renderChild: renderChild }));
|
|
284
|
+
}
|
|
285
|
+
: undefined, willProcessItem: lookupEventHandler("willProcess"), processItem: lookupEventHandler("process", { signError: false }), didProcessItem: lookupEventHandler("didProcess"), processItemError: lookupEventHandler("processError"), onComplete: lookupEventHandler("complete"), clearAfterFinish: extractValue.asOptionalBoolean(node.props.clearAfterFinish) }));
|
|
286
|
+
}, metadata);
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.QueueActionKind = void 0;
|
|
4
|
+
exports.actionItemStarted = actionItemStarted;
|
|
5
|
+
exports.actionItemProgress = actionItemProgress;
|
|
6
|
+
exports.actionItemCompleted = actionItemCompleted;
|
|
7
|
+
exports.removeActionItem = removeActionItem;
|
|
8
|
+
exports.clearCompletedActionItems = clearCompletedActionItems;
|
|
9
|
+
exports.actionItemError = actionItemError;
|
|
10
|
+
exports.actionQueueInitialized = actionQueueInitialized;
|
|
11
|
+
var QueueActionKind;
|
|
12
|
+
(function (QueueActionKind) {
|
|
13
|
+
QueueActionKind["ACTION_ITEM_STARTED"] = "ACTION_ITEM_STARTED";
|
|
14
|
+
QueueActionKind["ACTION_ITEM_PROGRESS"] = "ACTION_ITEM_PROGRESS";
|
|
15
|
+
QueueActionKind["ACTION_ITEM_COMPLETED"] = "ACTION_ITEM_COMPLETED";
|
|
16
|
+
QueueActionKind["CLEAR_COMPLETED_ACTION_ITEMS"] = "CLEAR_COMPLETED_ACTION_ITEMS";
|
|
17
|
+
QueueActionKind["ACTION_ITEM_ERROR"] = "ACTION_ITEM_ERROR";
|
|
18
|
+
QueueActionKind["ACTION_QUEUE_INITIALIZED"] = "ACTION_QUEUE_INITIALIZED";
|
|
19
|
+
QueueActionKind["ACTION_ITEM_REMOVED"] = "ACTION_ITEM_REMOVED";
|
|
20
|
+
})(QueueActionKind || (exports.QueueActionKind = QueueActionKind = {}));
|
|
21
|
+
// Signs that a particular component (`uid`) has started running an action with `actionItemId`.
|
|
22
|
+
function actionItemStarted(actionItemId) {
|
|
23
|
+
return {
|
|
24
|
+
type: QueueActionKind.ACTION_ITEM_STARTED,
|
|
25
|
+
payload: {
|
|
26
|
+
actionItemId,
|
|
27
|
+
},
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
// Signs that a particular component (`uid`) reports progress information (`progressEvent`)
|
|
31
|
+
// on an action with `actionItemId`.
|
|
32
|
+
function actionItemProgress(actionItemId, progressEvent) {
|
|
33
|
+
return {
|
|
34
|
+
type: QueueActionKind.ACTION_ITEM_PROGRESS,
|
|
35
|
+
payload: {
|
|
36
|
+
actionItemId,
|
|
37
|
+
progressEvent,
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
// Signs that a particular component (`uid`) has completed an action with `actionItemId` resulting in `result`.
|
|
42
|
+
function actionItemCompleted(actionItemId, result) {
|
|
43
|
+
return {
|
|
44
|
+
type: QueueActionKind.ACTION_ITEM_COMPLETED,
|
|
45
|
+
payload: {
|
|
46
|
+
actionItemId,
|
|
47
|
+
result,
|
|
48
|
+
},
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
// Signs that a particular component (`uid`) has removed an action with `actionItemId` from the execution queue.
|
|
52
|
+
function removeActionItem(actionItemId) {
|
|
53
|
+
return {
|
|
54
|
+
type: QueueActionKind.ACTION_ITEM_REMOVED,
|
|
55
|
+
payload: {
|
|
56
|
+
actionItemId,
|
|
57
|
+
},
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
// Signs that a particular component (`uid`) has cleared completed action items from its execution queue.
|
|
61
|
+
function clearCompletedActionItems() {
|
|
62
|
+
return {
|
|
63
|
+
type: QueueActionKind.CLEAR_COMPLETED_ACTION_ITEMS,
|
|
64
|
+
payload: {},
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
// Signs that a particular component (`uid`) received an `error` when running an action with `actionItemId`.
|
|
68
|
+
function actionItemError(actionItemId, error) {
|
|
69
|
+
return {
|
|
70
|
+
type: QueueActionKind.ACTION_ITEM_ERROR,
|
|
71
|
+
payload: {
|
|
72
|
+
actionItemId,
|
|
73
|
+
error,
|
|
74
|
+
},
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
// Signs that a particular component (`uid`) has initialized its execution `queue` with the specified `batchId`.
|
|
78
|
+
function actionQueueInitialized(queue, batchId, actionItemIds) {
|
|
79
|
+
return {
|
|
80
|
+
type: QueueActionKind.ACTION_QUEUE_INITIALIZED,
|
|
81
|
+
payload: {
|
|
82
|
+
queue,
|
|
83
|
+
actionItemIds,
|
|
84
|
+
batchId,
|
|
85
|
+
},
|
|
86
|
+
};
|
|
87
|
+
}
|