@vertesia/ui 0.56.0 → 0.57.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/lib/esm/core/components/Avatar.js +31 -0
- package/lib/esm/core/components/Avatar.js.map +1 -0
- package/lib/esm/core/components/Badge.js +62 -0
- package/lib/esm/core/components/Badge.js.map +1 -0
- package/lib/esm/core/components/Button.js +32 -0
- package/lib/esm/core/components/Button.js.map +1 -0
- package/lib/esm/core/components/Center.js +6 -0
- package/lib/esm/core/components/Center.js.map +1 -0
- package/lib/esm/core/components/ComboBox.js +356 -0
- package/lib/esm/core/components/ComboBox.js.map +1 -0
- package/lib/esm/core/components/ConfirmModal.js +10 -0
- package/lib/esm/core/components/ConfirmModal.js.map +1 -0
- package/lib/esm/core/components/DeleteModal.js +28 -0
- package/lib/esm/core/components/DeleteModal.js.map +1 -0
- package/lib/esm/core/components/Divider.js +6 -0
- package/lib/esm/core/components/Divider.js.map +1 -0
- package/lib/esm/core/components/Dropdown.js +16 -0
- package/lib/esm/core/components/Dropdown.js.map +1 -0
- package/lib/esm/core/components/DropdownList.js +9 -0
- package/lib/esm/core/components/DropdownList.js.map +1 -0
- package/lib/esm/core/components/EmptyCollection.js +7 -0
- package/lib/esm/core/components/EmptyCollection.js.map +1 -0
- package/lib/esm/core/components/FileUpload.js +119 -0
- package/lib/esm/core/components/FileUpload.js.map +1 -0
- package/lib/esm/core/components/Input.js +16 -0
- package/lib/esm/core/components/Input.js.map +1 -0
- package/lib/esm/core/components/InputList.js +42 -0
- package/lib/esm/core/components/InputList.js.map +1 -0
- package/lib/esm/core/components/Link.js +13 -0
- package/lib/esm/core/components/Link.js.map +1 -0
- package/lib/esm/core/components/MenuList.js +23 -0
- package/lib/esm/core/components/MenuList.js.map +1 -0
- package/lib/esm/core/components/MessageBox.js +66 -0
- package/lib/esm/core/components/MessageBox.js.map +1 -0
- package/lib/esm/core/components/Modal.js +26 -0
- package/lib/esm/core/components/Modal.js.map +1 -0
- package/lib/esm/core/components/NumberInput.js +43 -0
- package/lib/esm/core/components/NumberInput.js.map +1 -0
- package/lib/esm/core/components/Portal.js +28 -0
- package/lib/esm/core/components/Portal.js.map +1 -0
- package/lib/esm/core/components/RadioGroup.js +34 -0
- package/lib/esm/core/components/RadioGroup.js.map +1 -0
- package/lib/esm/core/components/SelectBox.js +68 -0
- package/lib/esm/core/components/SelectBox.js.map +1 -0
- package/lib/esm/core/components/SelectList.js +47 -0
- package/lib/esm/core/components/SelectList.js.map +1 -0
- package/lib/esm/core/components/SelectStack.js +8 -0
- package/lib/esm/core/components/SelectStack.js.map +1 -0
- package/lib/esm/core/components/SidePanel.js +33 -0
- package/lib/esm/core/components/SidePanel.js.map +1 -0
- package/lib/esm/core/components/Spinner.js +18 -0
- package/lib/esm/core/components/Spinner.js.map +1 -0
- package/lib/esm/core/components/Switch.js +12 -0
- package/lib/esm/core/components/Switch.js.map +1 -0
- package/lib/esm/core/components/Textarea.js +15 -0
- package/lib/esm/core/components/Textarea.js.map +1 -0
- package/lib/esm/core/components/index.js +34 -0
- package/lib/esm/core/components/index.js.map +1 -0
- package/lib/esm/core/components/libs/utils.js +6 -0
- package/lib/esm/core/components/libs/utils.js.map +1 -0
- package/lib/esm/core/components/libs/visuallyHidden.js +16 -0
- package/lib/esm/core/components/libs/visuallyHidden.js.map +1 -0
- package/lib/esm/core/components/popup/Popup.js +60 -0
- package/lib/esm/core/components/popup/Popup.js.map +1 -0
- package/lib/esm/core/components/popup/PopupController.js +149 -0
- package/lib/esm/core/components/popup/PopupController.js.map +1 -0
- package/lib/esm/core/components/popup/index.js +4 -0
- package/lib/esm/core/components/popup/index.js.map +1 -0
- package/lib/esm/core/components/popup/position.js +221 -0
- package/lib/esm/core/components/popup/position.js.map +1 -0
- package/lib/esm/core/components/popup/utils.js +74 -0
- package/lib/esm/core/components/popup/utils.js.map +1 -0
- package/lib/esm/core/components/shadcn/breadcrumb.js +30 -0
- package/lib/esm/core/components/shadcn/breadcrumb.js.map +1 -0
- package/lib/esm/core/components/shadcn/button.js +45 -0
- package/lib/esm/core/components/shadcn/button.js.map +1 -0
- package/lib/esm/core/components/shadcn/calendar.js +46 -0
- package/lib/esm/core/components/shadcn/calendar.js.map +1 -0
- package/lib/esm/core/components/shadcn/card.js +17 -0
- package/lib/esm/core/components/shadcn/card.js.map +1 -0
- package/lib/esm/core/components/shadcn/checkbox.js +10 -0
- package/lib/esm/core/components/shadcn/checkbox.js.map +1 -0
- package/lib/esm/core/components/shadcn/command.js +30 -0
- package/lib/esm/core/components/shadcn/command.js.map +1 -0
- package/lib/esm/core/components/shadcn/dialog.js +61 -0
- package/lib/esm/core/components/shadcn/dialog.js.map +1 -0
- package/lib/esm/core/components/shadcn/filters/animateChangeInHeight.js +23 -0
- package/lib/esm/core/components/shadcn/filters/animateChangeInHeight.js.map +1 -0
- package/lib/esm/core/components/shadcn/filters/comboBox.js +82 -0
- package/lib/esm/core/components/shadcn/filters/comboBox.js.map +1 -0
- package/lib/esm/core/components/shadcn/filters/dateFilter.js +31 -0
- package/lib/esm/core/components/shadcn/filters/dateFilter.js.map +1 -0
- package/lib/esm/core/components/shadcn/filters/filterBar.js +140 -0
- package/lib/esm/core/components/shadcn/filters/filterBar.js.map +1 -0
- package/lib/esm/core/components/shadcn/filters/filters.js +42 -0
- package/lib/esm/core/components/shadcn/filters/filters.js.map +1 -0
- package/lib/esm/core/components/shadcn/filters/index.js +6 -0
- package/lib/esm/core/components/shadcn/filters/index.js.map +1 -0
- package/lib/esm/core/components/shadcn/filters/selectFilter.js +58 -0
- package/lib/esm/core/components/shadcn/filters/selectFilter.js.map +1 -0
- package/lib/esm/core/components/shadcn/filters/textFilter.js +20 -0
- package/lib/esm/core/components/shadcn/filters/textFilter.js.map +1 -0
- package/lib/esm/core/components/shadcn/filters/types.js +10 -0
- package/lib/esm/core/components/shadcn/filters/types.js.map +1 -0
- package/lib/esm/core/components/shadcn/heading.js +17 -0
- package/lib/esm/core/components/shadcn/heading.js.map +1 -0
- package/lib/esm/core/components/shadcn/index.js +22 -0
- package/lib/esm/core/components/shadcn/index.js.map +1 -0
- package/lib/esm/core/components/shadcn/input.js +38 -0
- package/lib/esm/core/components/shadcn/input.js.map +1 -0
- package/lib/esm/core/components/shadcn/label.js +11 -0
- package/lib/esm/core/components/shadcn/label.js.map +1 -0
- package/lib/esm/core/components/shadcn/popover.js +50 -0
- package/lib/esm/core/components/shadcn/popover.js.map +1 -0
- package/lib/esm/core/components/shadcn/selectBox.js +62 -0
- package/lib/esm/core/components/shadcn/selectBox.js.map +1 -0
- package/lib/esm/core/components/shadcn/separator.js +8 -0
- package/lib/esm/core/components/shadcn/separator.js.map +1 -0
- package/lib/esm/core/components/shadcn/tabs.js +77 -0
- package/lib/esm/core/components/shadcn/tabs.js.map +1 -0
- package/lib/esm/core/components/shadcn/text.js +30 -0
- package/lib/esm/core/components/shadcn/text.js.map +1 -0
- package/lib/esm/core/components/shadcn/theme/ThemeProvider.js +38 -0
- package/lib/esm/core/components/shadcn/theme/ThemeProvider.js.map +1 -0
- package/lib/esm/core/components/shadcn/theme/ThemeSwitcher.js +13 -0
- package/lib/esm/core/components/shadcn/theme/ThemeSwitcher.js.map +1 -0
- package/lib/esm/core/components/shadcn/tooltip.js +14 -0
- package/lib/esm/core/components/shadcn/tooltip.js.map +1 -0
- package/lib/esm/core/components/styles.js +10 -0
- package/lib/esm/core/components/styles.js.map +1 -0
- package/lib/esm/core/components/table/index.js +20 -0
- package/lib/esm/core/components/table/index.js.map +1 -0
- package/lib/esm/core/components/tabs/Tabs.js +78 -0
- package/lib/esm/core/components/tabs/Tabs.js.map +1 -0
- package/lib/esm/core/components/tabs/TabsContext.js +7 -0
- package/lib/esm/core/components/tabs/TabsContext.js.map +1 -0
- package/lib/esm/core/components/tabs/index.js +3 -0
- package/lib/esm/core/components/tabs/index.js.map +1 -0
- package/lib/esm/core/components/toast/NotificationPanel.js +37 -0
- package/lib/esm/core/components/toast/NotificationPanel.js.map +1 -0
- package/lib/esm/core/components/toast/ToastContext.js +7 -0
- package/lib/esm/core/components/toast/ToastContext.js.map +1 -0
- package/lib/esm/core/components/toast/ToastProps.js +2 -0
- package/lib/esm/core/components/toast/ToastProps.js.map +1 -0
- package/lib/esm/core/components/toast/ToastProvider.js +13 -0
- package/lib/esm/core/components/toast/ToastProvider.js.map +1 -0
- package/lib/esm/core/components/toast/index.js +3 -0
- package/lib/esm/core/components/toast/index.js.map +1 -0
- package/lib/esm/core/hooks/CompositeState.js +118 -0
- package/lib/esm/core/hooks/CompositeState.js.map +1 -0
- package/lib/esm/core/hooks/SharedState.js +64 -0
- package/lib/esm/core/hooks/SharedState.js.map +1 -0
- package/lib/esm/core/hooks/index.js +14 -0
- package/lib/esm/core/hooks/index.js.map +1 -0
- package/lib/esm/core/hooks/useClickOutside.js +29 -0
- package/lib/esm/core/hooks/useClickOutside.js.map +1 -0
- package/lib/esm/core/hooks/useCopyToClipboard.js +23 -0
- package/lib/esm/core/hooks/useCopyToClipboard.js.map +1 -0
- package/lib/esm/core/hooks/useDarkMode.js +11 -0
- package/lib/esm/core/hooks/useDarkMode.js.map +1 -0
- package/lib/esm/core/hooks/useDebounce.js +14 -0
- package/lib/esm/core/hooks/useDebounce.js.map +1 -0
- package/lib/esm/core/hooks/useEventSource.js +31 -0
- package/lib/esm/core/hooks/useEventSource.js.map +1 -0
- package/lib/esm/core/hooks/useFetch.js +40 -0
- package/lib/esm/core/hooks/useFetch.js.map +1 -0
- package/lib/esm/core/hooks/useFlag.js +13 -0
- package/lib/esm/core/hooks/useFlag.js.map +1 -0
- package/lib/esm/core/hooks/useIntersectionObserver.js +34 -0
- package/lib/esm/core/hooks/useIntersectionObserver.js.map +1 -0
- package/lib/esm/core/hooks/useIsFistRendering.js +14 -0
- package/lib/esm/core/hooks/useIsFistRendering.js.map +1 -0
- package/lib/esm/core/hooks/useSafeLayoutEffect.js +4 -0
- package/lib/esm/core/hooks/useSafeLayoutEffect.js.map +1 -0
- package/lib/esm/core/hooks/useSharedValue.js +21 -0
- package/lib/esm/core/hooks/useSharedValue.js.map +1 -0
- package/lib/esm/core/index.js +3 -0
- package/lib/esm/core/index.js.map +1 -0
- package/lib/esm/env/index.js +69 -0
- package/lib/esm/env/index.js.map +1 -0
- package/lib/esm/features/activity-doc/ActivityDoc.js +71 -0
- package/lib/esm/features/activity-doc/ActivityDoc.js.map +1 -0
- package/lib/esm/features/activity-doc/index.js +2 -0
- package/lib/esm/features/activity-doc/index.js.map +1 -0
- package/lib/esm/features/index.js +2 -2
- package/lib/esm/features/index.js.map +1 -1
- package/lib/esm/features/permissions/SecureButton.js +13 -0
- package/lib/esm/features/permissions/SecureButton.js.map +1 -0
- package/lib/esm/features/permissions/SecureSidebarItem.js +14 -0
- package/lib/esm/features/permissions/SecureSidebarItem.js.map +1 -0
- package/lib/esm/features/permissions/UserPermissionsProvider.js +86 -0
- package/lib/esm/features/permissions/UserPermissionsProvider.js.map +1 -0
- package/lib/esm/features/permissions/helpers.js +12 -0
- package/lib/esm/features/permissions/helpers.js.map +1 -0
- package/lib/esm/features/permissions/index.js +5 -0
- package/lib/esm/features/permissions/index.js.map +1 -0
- package/lib/esm/layout/AppLayout.js +46 -0
- package/lib/esm/layout/AppLayout.js.map +1 -0
- package/lib/esm/layout/FullHeightLayout.js +20 -0
- package/lib/esm/layout/FullHeightLayout.js.map +1 -0
- package/lib/esm/layout/Navbar.js +40 -0
- package/lib/esm/layout/Navbar.js.map +1 -0
- package/lib/esm/layout/Sidebar.js +35 -0
- package/lib/esm/layout/Sidebar.js.map +1 -0
- package/lib/esm/layout/SidebarContext.js +10 -0
- package/lib/esm/layout/SidebarContext.js.map +1 -0
- package/lib/esm/layout/TitleBar.js +5 -0
- package/lib/esm/layout/TitleBar.js.map +1 -0
- package/lib/esm/layout/index.js +7 -0
- package/lib/esm/layout/index.js.map +1 -0
- package/lib/esm/router/FixLinks.js +23 -0
- package/lib/esm/router/FixLinks.js.map +1 -0
- package/lib/esm/router/HistoryNavigator.js +149 -0
- package/lib/esm/router/HistoryNavigator.js.map +1 -0
- package/lib/esm/router/Nav.js +26 -0
- package/lib/esm/router/Nav.js.map +1 -0
- package/lib/esm/router/NestedNavigationContext.js +19 -0
- package/lib/esm/router/NestedNavigationContext.js.map +1 -0
- package/lib/esm/router/NestedRouterProvider.js +44 -0
- package/lib/esm/router/NestedRouterProvider.js.map +1 -0
- package/lib/esm/router/PathMatcher.js +159 -0
- package/lib/esm/router/PathMatcher.js.map +1 -0
- package/lib/esm/router/PathWithParams.js +34 -0
- package/lib/esm/router/PathWithParams.js.map +1 -0
- package/lib/esm/router/Route404.js +18 -0
- package/lib/esm/router/Route404.js.map +1 -0
- package/lib/esm/router/RouteComponent.js +32 -0
- package/lib/esm/router/RouteComponent.js.map +1 -0
- package/lib/esm/router/Router.js +161 -0
- package/lib/esm/router/Router.js.map +1 -0
- package/lib/esm/router/RouterProvider.js +41 -0
- package/lib/esm/router/RouterProvider.js.map +1 -0
- package/lib/esm/router/index.js +10 -5
- package/lib/esm/router/index.js.map +1 -1
- package/lib/esm/router/path.js +137 -0
- package/lib/esm/router/path.js.map +1 -0
- package/lib/esm/session/TypeRegistry.js +24 -0
- package/lib/esm/session/TypeRegistry.js.map +1 -0
- package/lib/esm/session/UserSession.js +191 -0
- package/lib/esm/session/UserSession.js.map +1 -0
- package/lib/esm/session/UserSessionProvider.js +161 -0
- package/lib/esm/session/UserSessionProvider.js.map +1 -0
- package/lib/esm/session/auth/composable.js +162 -0
- package/lib/esm/session/auth/composable.js.map +1 -0
- package/lib/esm/session/auth/firebase.js +151 -0
- package/lib/esm/session/auth/firebase.js.map +1 -0
- package/lib/esm/session/auth/useAuthState.js +49 -0
- package/lib/esm/session/auth/useAuthState.js.map +1 -0
- package/lib/esm/session/index.js +6 -2
- package/lib/esm/session/index.js.map +1 -1
- package/lib/esm/session/useUXTracking.js +29 -0
- package/lib/esm/session/useUXTracking.js.map +1 -0
- package/lib/esm/widgets/codemirror/CodeMirrorEditor.js +103 -0
- package/lib/esm/widgets/codemirror/CodeMirrorEditor.js.map +1 -0
- package/lib/esm/widgets/codemirror/CodemirrorStateSingleton.js +33 -0
- package/lib/esm/widgets/codemirror/CodemirrorStateSingleton.js.map +1 -0
- package/lib/esm/widgets/codemirror/index.js +2 -0
- package/lib/esm/widgets/codemirror/index.js.map +1 -0
- package/lib/esm/widgets/form/Form.js +102 -0
- package/lib/esm/widgets/form/Form.js.map +1 -0
- package/lib/esm/widgets/form/FormContext.js +29 -0
- package/lib/esm/widgets/form/FormContext.js.map +1 -0
- package/lib/esm/widgets/form/ManagedObject.js +283 -0
- package/lib/esm/widgets/form/ManagedObject.js.map +1 -0
- package/lib/esm/widgets/form/fields.js +11 -0
- package/lib/esm/widgets/form/fields.js.map +1 -0
- package/lib/esm/widgets/form/index.js +7 -0
- package/lib/esm/widgets/form/index.js.map +1 -0
- package/lib/esm/widgets/form/inputs.js +36 -0
- package/lib/esm/widgets/form/inputs.js.map +1 -0
- package/lib/esm/widgets/form/schema.js +191 -0
- package/lib/esm/widgets/form/schema.js.map +1 -0
- package/lib/esm/widgets/index.js +6 -0
- package/lib/esm/widgets/index.js.map +1 -0
- package/lib/esm/widgets/json-view/JSONCode.js +157 -0
- package/lib/esm/widgets/json-view/JSONCode.js.map +1 -0
- package/lib/esm/widgets/json-view/JSONDisplay.js +10 -0
- package/lib/esm/widgets/json-view/JSONDisplay.js.map +1 -0
- package/lib/esm/widgets/json-view/JSONView.js +106 -0
- package/lib/esm/widgets/json-view/JSONView.js.map +1 -0
- package/lib/esm/widgets/json-view/index.js +4 -0
- package/lib/esm/widgets/json-view/index.js.map +1 -0
- package/lib/esm/widgets/json-view/types.js +2 -0
- package/lib/esm/widgets/json-view/types.js.map +1 -0
- package/lib/esm/widgets/schema-editor/JSONSchemaEditorModal.js +50 -0
- package/lib/esm/widgets/schema-editor/JSONSchemaEditorModal.js.map +1 -0
- package/lib/esm/widgets/schema-editor/ManagedSchema.js +303 -0
- package/lib/esm/widgets/schema-editor/ManagedSchema.js.map +1 -0
- package/lib/esm/widgets/schema-editor/editor/Editable.js +111 -0
- package/lib/esm/widgets/schema-editor/editor/Editable.js.map +1 -0
- package/lib/esm/widgets/schema-editor/editor/EditableSchemaProperty.js +8 -0
- package/lib/esm/widgets/schema-editor/editor/EditableSchemaProperty.js.map +1 -0
- package/lib/esm/widgets/schema-editor/editor/PropertyEditor.js +81 -0
- package/lib/esm/widgets/schema-editor/editor/PropertyEditor.js.map +1 -0
- package/lib/esm/widgets/schema-editor/editor/PropertyViewer.js +7 -0
- package/lib/esm/widgets/schema-editor/editor/PropertyViewer.js.map +1 -0
- package/lib/esm/widgets/schema-editor/editor/SchemaContext.js +9 -0
- package/lib/esm/widgets/schema-editor/editor/SchemaContext.js.map +1 -0
- package/lib/esm/widgets/schema-editor/editor/SchemaEditor.js +84 -0
- package/lib/esm/widgets/schema-editor/editor/SchemaEditor.js.map +1 -0
- package/lib/esm/widgets/schema-editor/index.js +8 -0
- package/lib/esm/widgets/schema-editor/index.js.map +1 -0
- package/lib/esm/widgets/schema-editor/json-schema4-utils.js +188 -0
- package/lib/esm/widgets/schema-editor/json-schema4-utils.js.map +1 -0
- package/lib/esm/widgets/schema-editor/type-signature.js +30 -0
- package/lib/esm/widgets/schema-editor/type-signature.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/components/Attributes/index.js +11 -0
- package/lib/esm/widgets/xml-viewer/components/Attributes/index.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/components/CDataTag/index.js +8 -0
- package/lib/esm/widgets/xml-viewer/components/CDataTag/index.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/components/CollapseIcon/index.js +11 -0
- package/lib/esm/widgets/xml-viewer/components/CollapseIcon/index.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/components/CommentTag/index.js +11 -0
- package/lib/esm/widgets/xml-viewer/components/CommentTag/index.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/components/DeclarationTag/index.js +9 -0
- package/lib/esm/widgets/xml-viewer/components/DeclarationTag/index.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/components/Elements/index.js +36 -0
- package/lib/esm/widgets/xml-viewer/components/Elements/index.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/components/InvalidXml/index.js +5 -0
- package/lib/esm/widgets/xml-viewer/components/InvalidXml/index.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/components/Tag/index.js +13 -0
- package/lib/esm/widgets/xml-viewer/components/Tag/index.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/components/TextElement/index.js +13 -0
- package/lib/esm/widgets/xml-viewer/components/TextElement/index.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/components/XMLViewer.js +30 -0
- package/lib/esm/widgets/xml-viewer/components/XMLViewer.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/components/types.js +2 -0
- package/lib/esm/widgets/xml-viewer/components/types.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/constants/index.js +17 -0
- package/lib/esm/widgets/xml-viewer/constants/index.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/context/xml-viewer-context.js +10 -0
- package/lib/esm/widgets/xml-viewer/context/xml-viewer-context.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/helpers/index.js +40 -0
- package/lib/esm/widgets/xml-viewer/helpers/index.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/hooks/useCollapsible.js +22 -0
- package/lib/esm/widgets/xml-viewer/hooks/useCollapsible.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/hooks/useXMLViewer.js +31 -0
- package/lib/esm/widgets/xml-viewer/hooks/useXMLViewer.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/index.js +3 -0
- package/lib/esm/widgets/xml-viewer/index.js.map +1 -0
- package/lib/esm/widgets/xml-viewer/types/index.js +2 -0
- package/lib/esm/widgets/xml-viewer/types/index.js.map +1 -0
- package/lib/tsconfig.tsbuildinfo +1 -1
- package/lib/types/core/components/Avatar.d.ts +15 -0
- package/lib/types/core/components/Badge.d.ts +20 -0
- package/lib/types/core/components/Button.d.ts +13 -0
- package/lib/types/core/components/Center.d.ts +7 -0
- package/lib/types/core/components/ComboBox.d.ts +123 -0
- package/lib/types/core/components/ConfirmModal.d.ts +10 -0
- package/lib/types/core/components/DeleteModal.d.ts +10 -0
- package/lib/types/core/components/Divider.d.ts +5 -0
- package/lib/types/core/components/Dropdown.d.ts +14 -0
- package/lib/types/core/components/DropdownList.d.ts +12 -0
- package/lib/types/core/components/EmptyCollection.d.ts +8 -0
- package/lib/types/core/components/FileUpload.d.ts +28 -0
- package/lib/types/core/components/Input.d.ts +8 -0
- package/lib/types/core/components/InputList.d.ts +10 -0
- package/lib/types/core/components/Link.d.ts +6 -0
- package/lib/types/core/components/MenuList.d.ts +13 -0
- package/lib/types/core/components/MessageBox.d.ts +35 -0
- package/lib/types/core/components/Modal.d.ts +29 -0
- package/lib/types/core/components/NumberInput.d.ts +15 -0
- package/lib/types/core/components/Portal.d.ts +5 -0
- package/lib/types/core/components/RadioGroup.d.ts +25 -0
- package/lib/types/core/components/SelectBox.d.ts +35 -0
- package/lib/types/core/components/SelectList.d.ts +17 -0
- package/lib/types/core/components/SelectStack.d.ts +12 -0
- package/lib/types/core/components/SidePanel.d.ts +8 -0
- package/lib/types/core/components/Spinner.d.ts +6 -0
- package/lib/types/core/components/Switch.d.ts +9 -0
- package/lib/types/core/components/Textarea.d.ts +7 -0
- package/lib/types/core/components/index.d.ts +37 -0
- package/lib/types/core/components/libs/utils.d.ts +2 -0
- package/lib/types/core/components/libs/visuallyHidden.d.ts +6 -0
- package/lib/types/core/components/popup/Popup.d.ts +25 -0
- package/lib/types/core/components/popup/PopupController.d.ts +40 -0
- package/lib/types/core/components/popup/index.d.ts +3 -0
- package/lib/types/core/components/popup/position.d.ts +58 -0
- package/lib/types/core/components/popup/utils.d.ts +29 -0
- package/lib/types/core/components/shadcn/breadcrumb.d.ts +13 -0
- package/lib/types/core/components/shadcn/button.d.ts +15 -0
- package/lib/types/core/components/shadcn/calendar.d.ts +10 -0
- package/lib/types/core/components/shadcn/card.d.ts +8 -0
- package/lib/types/core/components/shadcn/checkbox.d.ts +4 -0
- package/lib/types/core/components/shadcn/command.d.ts +80 -0
- package/lib/types/core/components/shadcn/dialog.d.ts +34 -0
- package/lib/types/core/components/shadcn/filters/animateChangeInHeight.d.ts +6 -0
- package/lib/types/core/components/shadcn/filters/comboBox.d.ts +17 -0
- package/lib/types/core/components/shadcn/filters/dateFilter.d.ts +14 -0
- package/lib/types/core/components/shadcn/filters/filterBar.d.ts +9 -0
- package/lib/types/core/components/shadcn/filters/filters.d.ts +9 -0
- package/lib/types/core/components/shadcn/filters/index.d.ts +5 -0
- package/lib/types/core/components/shadcn/filters/selectFilter.d.ts +11 -0
- package/lib/types/core/components/shadcn/filters/textFilter.d.ts +12 -0
- package/lib/types/core/components/shadcn/filters/types.d.ts +26 -0
- package/lib/types/core/components/shadcn/heading.d.ts +5 -0
- package/lib/types/core/components/shadcn/index.d.ts +21 -0
- package/lib/types/core/components/shadcn/input.d.ts +16 -0
- package/lib/types/core/components/shadcn/label.d.ts +7 -0
- package/lib/types/core/components/shadcn/popover.d.ts +16 -0
- package/lib/types/core/components/shadcn/selectBox.d.ts +21 -0
- package/lib/types/core/components/shadcn/separator.d.ts +4 -0
- package/lib/types/core/components/shadcn/tabs.d.ts +26 -0
- package/lib/types/core/components/shadcn/text.d.ts +10 -0
- package/lib/types/core/components/shadcn/theme/ThemeProvider.d.ts +13 -0
- package/lib/types/core/components/shadcn/theme/ThemeSwitcher.d.ts +9 -0
- package/lib/types/core/components/shadcn/tooltip.d.ts +19 -0
- package/lib/types/core/components/styles.d.ts +6 -0
- package/lib/types/core/components/table/index.d.ts +13 -0
- package/lib/types/core/components/tabs/Tabs.d.ts +24 -0
- package/lib/types/core/components/tabs/TabsContext.d.ts +16 -0
- package/lib/types/core/components/tabs/index.d.ts +2 -0
- package/lib/types/core/components/toast/NotificationPanel.d.ts +7 -0
- package/lib/types/core/components/toast/ToastContext.d.ts +5 -0
- package/lib/types/core/components/toast/ToastProps.d.ts +6 -0
- package/lib/types/core/components/toast/ToastProvider.d.ts +5 -0
- package/lib/types/core/components/toast/index.d.ts +2 -0
- package/lib/types/core/hooks/CompositeState.d.ts +27 -0
- package/lib/types/core/hooks/SharedState.d.ts +9 -0
- package/lib/types/core/hooks/index.d.ts +13 -0
- package/lib/types/core/hooks/useClickOutside.d.ts +7 -0
- package/lib/types/core/hooks/useCopyToClipboard.d.ts +4 -0
- package/lib/types/core/hooks/useDarkMode.d.ts +1 -0
- package/lib/types/core/hooks/useDebounce.d.ts +1 -0
- package/lib/types/core/hooks/useEventSource.d.ts +1 -0
- package/lib/types/core/hooks/useFetch.d.ts +23 -0
- package/lib/types/core/hooks/useFlag.d.ts +8 -0
- package/lib/types/core/hooks/useIntersectionObserver.d.ts +13 -0
- package/lib/types/core/hooks/useIsFistRendering.d.ts +1 -0
- package/lib/types/core/hooks/useSafeLayoutEffect.d.ts +3 -0
- package/lib/types/core/hooks/useSharedValue.d.ts +11 -0
- package/lib/types/core/index.d.ts +2 -0
- package/lib/types/env/index.d.ts +70 -0
- package/lib/types/features/activity-doc/ActivityDoc.d.ts +13 -0
- package/lib/types/features/activity-doc/index.d.ts +1 -0
- package/lib/types/features/index.d.ts +2 -0
- package/lib/types/features/permissions/SecureButton.d.ts +7 -0
- package/lib/types/features/permissions/SecureSidebarItem.d.ts +7 -0
- package/lib/types/features/permissions/UserPermissionsProvider.d.ts +19 -0
- package/lib/types/features/permissions/helpers.d.ts +4 -0
- package/lib/types/features/permissions/index.d.ts +4 -0
- package/lib/types/layout/AppLayout.d.ts +12 -0
- package/lib/types/layout/FullHeightLayout.d.ts +26 -0
- package/lib/types/layout/Navbar.d.ts +32 -0
- package/lib/types/layout/Sidebar.d.ts +29 -0
- package/lib/types/layout/SidebarContext.d.ts +8 -0
- package/lib/types/layout/TitleBar.d.ts +5 -0
- package/lib/types/layout/index.d.ts +6 -0
- package/lib/types/router/FixLinks.d.ts +6 -0
- package/lib/types/router/HistoryNavigator.d.ts +55 -0
- package/lib/types/router/Nav.d.ts +28 -0
- package/lib/types/router/NestedNavigationContext.d.ts +8 -0
- package/lib/types/router/NestedRouterProvider.d.ts +13 -0
- package/lib/types/router/PathMatcher.d.ts +35 -0
- package/lib/types/router/PathWithParams.d.ts +8 -0
- package/lib/types/router/Route404.d.ts +3 -0
- package/lib/types/router/RouteComponent.d.ts +5 -0
- package/lib/types/router/Router.d.ts +73 -0
- package/lib/types/router/RouterProvider.d.ts +14 -0
- package/lib/types/router/index.d.ts +10 -4
- package/lib/types/router/path.d.ts +7 -0
- package/lib/types/session/TypeRegistry.d.ts +9 -0
- package/lib/types/session/UserSession.d.ts +39 -0
- package/lib/types/session/UserSessionProvider.d.ts +6 -0
- package/lib/types/session/auth/composable.d.ts +25 -0
- package/lib/types/session/auth/firebase.d.ts +9 -0
- package/lib/types/session/auth/useAuthState.d.ts +9 -0
- package/lib/types/session/index.d.ts +6 -0
- package/lib/types/session/useUXTracking.d.ts +5 -0
- package/lib/types/widgets/codemirror/CodeMirrorEditor.d.ts +22 -0
- package/lib/types/widgets/codemirror/CodemirrorStateSingleton.d.ts +14 -0
- package/lib/types/widgets/codemirror/index.d.ts +1 -0
- package/lib/types/widgets/form/Form.d.ts +20 -0
- package/lib/types/widgets/form/FormContext.d.ts +16 -0
- package/lib/types/widgets/form/ManagedObject.d.ts +81 -0
- package/lib/types/widgets/form/fields.d.ts +15 -0
- package/lib/types/widgets/form/index.d.ts +6 -0
- package/lib/types/widgets/form/inputs.d.ts +7 -0
- package/lib/types/widgets/form/schema.d.ts +45 -0
- package/lib/types/widgets/index.d.ts +5 -0
- package/lib/types/widgets/json-view/JSONCode.d.ts +21 -0
- package/lib/types/widgets/json-view/JSONDisplay.d.ts +7 -0
- package/lib/types/widgets/json-view/JSONView.d.ts +6 -0
- package/lib/types/widgets/json-view/index.d.ts +4 -0
- package/lib/types/widgets/json-view/types.d.ts +7 -0
- package/lib/types/widgets/schema-editor/JSONSchemaEditorModal.d.ts +9 -0
- package/lib/types/widgets/schema-editor/ManagedSchema.d.ts +74 -0
- package/lib/types/widgets/schema-editor/editor/Editable.d.ts +39 -0
- package/lib/types/widgets/schema-editor/editor/EditableSchemaProperty.d.ts +7 -0
- package/lib/types/widgets/schema-editor/editor/PropertyEditor.d.ts +4 -0
- package/lib/types/widgets/schema-editor/editor/PropertyViewer.d.ts +3 -0
- package/lib/types/widgets/schema-editor/editor/SchemaContext.d.ts +2 -0
- package/lib/types/widgets/schema-editor/editor/SchemaEditor.d.ts +8 -0
- package/lib/types/widgets/schema-editor/index.d.ts +7 -0
- package/lib/types/widgets/schema-editor/json-schema4-utils.d.ts +15 -0
- package/lib/types/widgets/schema-editor/type-signature.d.ts +18 -0
- package/lib/types/widgets/xml-viewer/components/Attributes/index.d.ts +5 -0
- package/lib/types/widgets/xml-viewer/components/CDataTag/index.d.ts +7 -0
- package/lib/types/widgets/xml-viewer/components/CollapseIcon/index.d.ts +4 -0
- package/lib/types/widgets/xml-viewer/components/CommentTag/index.d.ts +8 -0
- package/lib/types/widgets/xml-viewer/components/DeclarationTag/index.d.ts +7 -0
- package/lib/types/widgets/xml-viewer/components/Elements/index.d.ts +7 -0
- package/lib/types/widgets/xml-viewer/components/InvalidXml/index.d.ts +1 -0
- package/lib/types/widgets/xml-viewer/components/Tag/index.d.ts +12 -0
- package/lib/types/widgets/xml-viewer/components/TextElement/index.d.ts +7 -0
- package/lib/types/widgets/xml-viewer/components/XMLViewer.d.ts +2 -0
- package/lib/types/widgets/xml-viewer/components/types.d.ts +103 -0
- package/lib/types/widgets/xml-viewer/constants/index.d.ts +16 -0
- package/lib/types/widgets/xml-viewer/context/xml-viewer-context.d.ts +3 -0
- package/lib/types/widgets/xml-viewer/helpers/index.d.ts +12 -0
- package/lib/types/widgets/xml-viewer/hooks/useCollapsible.d.ts +14 -0
- package/lib/types/widgets/xml-viewer/hooks/useXMLViewer.d.ts +9 -0
- package/lib/types/widgets/xml-viewer/index.d.ts +2 -0
- package/lib/types/widgets/xml-viewer/types/index.d.ts +15 -0
- package/lib/vertesia-ui-core.js +2 -0
- package/lib/vertesia-ui-core.js.map +1 -0
- package/lib/vertesia-ui-env.js +2 -0
- package/lib/vertesia-ui-env.js.map +1 -0
- package/lib/vertesia-ui-features.js +1 -1
- package/lib/vertesia-ui-features.js.map +1 -1
- package/lib/vertesia-ui-layout.js +2 -0
- package/lib/vertesia-ui-layout.js.map +1 -0
- package/lib/vertesia-ui-router.js +1 -1
- package/lib/vertesia-ui-router.js.map +1 -1
- package/lib/vertesia-ui-session.js +1 -1
- package/lib/vertesia-ui-session.js.map +1 -1
- package/lib/vertesia-ui-widgets.js +2 -0
- package/lib/vertesia-ui-widgets.js.map +1 -0
- package/package.json +80 -19
- package/src/code/index.ts +1 -1
- package/src/core/components/Avatar.tsx +67 -0
- package/src/core/components/Badge.tsx +114 -0
- package/src/core/components/Button.tsx +63 -0
- package/src/core/components/Center.tsx +12 -0
- package/src/core/components/ComboBox.tsx +488 -0
- package/src/core/components/ConfirmModal.tsx +51 -0
- package/src/core/components/DeleteModal.tsx +45 -0
- package/src/core/components/Divider.tsx +11 -0
- package/src/core/components/Dropdown.tsx +63 -0
- package/src/core/components/DropdownList.tsx +72 -0
- package/src/core/components/EmptyCollection.tsx +39 -0
- package/src/core/components/FileUpload.tsx +196 -0
- package/src/core/components/Input.tsx +43 -0
- package/src/core/components/InputList.tsx +75 -0
- package/src/core/components/Link.tsx +16 -0
- package/src/core/components/MenuList.tsx +44 -0
- package/src/core/components/MessageBox.tsx +96 -0
- package/src/core/components/Modal.tsx +144 -0
- package/src/core/components/NumberInput.tsx +64 -0
- package/src/core/components/Portal.tsx +33 -0
- package/src/core/components/RadioGroup.tsx +100 -0
- package/src/core/components/SelectBox.tsx +189 -0
- package/src/core/components/SelectList.tsx +85 -0
- package/src/core/components/SelectStack.tsx +63 -0
- package/src/core/components/SidePanel.tsx +104 -0
- package/src/core/components/Spinner.tsx +33 -0
- package/src/core/components/Switch.tsx +29 -0
- package/src/core/components/Textarea.tsx +25 -0
- package/src/core/components/index.ts +39 -0
- package/src/core/components/libs/utils.tsx +6 -0
- package/src/core/components/libs/visuallyHidden.tsx +25 -0
- package/src/core/components/popup/Popup.tsx +94 -0
- package/src/core/components/popup/PopupController.ts +182 -0
- package/src/core/components/popup/index.ts +3 -0
- package/src/core/components/popup/position.ts +277 -0
- package/src/core/components/popup/utils.ts +82 -0
- package/src/core/components/shadcn/breadcrumb.tsx +174 -0
- package/src/core/components/shadcn/button.tsx +95 -0
- package/src/core/components/shadcn/calendar.tsx +87 -0
- package/src/core/components/shadcn/card.tsx +76 -0
- package/src/core/components/shadcn/checkbox.tsx +30 -0
- package/src/core/components/shadcn/command.tsx +155 -0
- package/src/core/components/shadcn/dialog.tsx +230 -0
- package/src/core/components/shadcn/filters/animateChangeInHeight.tsx +41 -0
- package/src/core/components/shadcn/filters/comboBox.tsx +251 -0
- package/src/core/components/shadcn/filters/dateFilter.tsx +65 -0
- package/src/core/components/shadcn/filters/filterBar.tsx +262 -0
- package/src/core/components/shadcn/filters/filters.tsx +110 -0
- package/src/core/components/shadcn/filters/index.ts +5 -0
- package/src/core/components/shadcn/filters/selectFilter.tsx +91 -0
- package/src/core/components/shadcn/filters/textFilter.tsx +59 -0
- package/src/core/components/shadcn/filters/types.ts +29 -0
- package/src/core/components/shadcn/heading.tsx +23 -0
- package/src/core/components/shadcn/index.ts +22 -0
- package/src/core/components/shadcn/input.tsx +89 -0
- package/src/core/components/shadcn/label.tsx +31 -0
- package/src/core/components/shadcn/popover.tsx +115 -0
- package/src/core/components/shadcn/selectBox.tsx +186 -0
- package/src/core/components/shadcn/separator.tsx +29 -0
- package/src/core/components/shadcn/tabs.tsx +218 -0
- package/src/core/components/shadcn/text.tsx +33 -0
- package/src/core/components/shadcn/theme/ThemeProvider.tsx +73 -0
- package/src/core/components/shadcn/theme/ThemeSwitcher.tsx +35 -0
- package/src/core/components/shadcn/tooltip.tsx +57 -0
- package/src/core/components/styles.ts +11 -0
- package/src/core/components/table/index.tsx +49 -0
- package/src/core/components/tabs/Tabs.tsx +132 -0
- package/src/core/components/tabs/TabsContext.ts +25 -0
- package/src/core/components/tabs/index.ts +2 -0
- package/src/core/components/toast/NotificationPanel.tsx +91 -0
- package/src/core/components/toast/ToastContext.ts +12 -0
- package/src/core/components/toast/ToastProps.ts +6 -0
- package/src/core/components/toast/ToastProvider.tsx +26 -0
- package/src/core/components/toast/index.ts +2 -0
- package/src/core/hooks/CompositeState.tsx +142 -0
- package/src/core/hooks/SharedState.tsx +69 -0
- package/src/core/hooks/index.ts +13 -0
- package/src/core/hooks/useClickOutside.tsx +29 -0
- package/src/core/hooks/useCopyToClipboard.tsx +28 -0
- package/src/core/hooks/useDarkMode.ts +11 -0
- package/src/core/hooks/useDebounce.tsx +15 -0
- package/src/core/hooks/useEventSource.ts +35 -0
- package/src/core/hooks/useFetch.ts +51 -0
- package/src/core/hooks/useFlag.tsx +13 -0
- package/src/core/hooks/useIntersectionObserver.tsx +40 -0
- package/src/core/hooks/useIsFistRendering.ts +17 -0
- package/src/core/hooks/useSafeLayoutEffect.ts +5 -0
- package/src/core/hooks/useSharedValue.ts +22 -0
- package/src/core/index.ts +2 -0
- package/src/env/index.ts +116 -0
- package/src/features/activity-doc/ActivityDoc.tsx +199 -0
- package/src/features/activity-doc/index.ts +1 -0
- package/src/features/index.ts +2 -1
- package/src/features/permissions/SecureButton.tsx +18 -0
- package/src/features/permissions/SecureSidebarItem.tsx +19 -0
- package/src/features/permissions/UserPermissionsProvider.tsx +102 -0
- package/src/features/permissions/helpers.ts +16 -0
- package/src/features/permissions/index.ts +4 -0
- package/src/layout/AppLayout.tsx +132 -0
- package/src/layout/FullHeightLayout.tsx +74 -0
- package/src/layout/Navbar.tsx +127 -0
- package/src/layout/Sidebar.tsx +129 -0
- package/src/layout/SidebarContext.ts +17 -0
- package/src/layout/TitleBar.tsx +7 -0
- package/src/layout/index.ts +6 -0
- package/src/router/FixLinks.tsx +28 -0
- package/src/router/HistoryNavigator.ts +178 -0
- package/src/router/Nav.tsx +55 -0
- package/src/router/NestedNavigationContext.tsx +32 -0
- package/src/router/NestedRouterProvider.tsx +64 -0
- package/src/router/PathMatcher.ts +166 -0
- package/src/router/PathWithParams.ts +34 -0
- package/src/router/Route404.tsx +18 -0
- package/src/router/RouteComponent.tsx +41 -0
- package/src/router/Router.tsx +216 -0
- package/src/router/RouterProvider.tsx +55 -0
- package/src/router/index.ts +10 -8
- package/src/router/path.ts +151 -0
- package/src/session/TypeRegistry.ts +27 -0
- package/src/session/UserSession.ts +227 -0
- package/src/session/UserSessionProvider.tsx +170 -0
- package/src/session/auth/composable.ts +190 -0
- package/src/session/auth/firebase.ts +160 -0
- package/src/session/auth/useAuthState.ts +61 -0
- package/src/session/index.ts +6 -1
- package/src/session/useUXTracking.tsx +38 -0
- package/src/widgets/codemirror/CodeMirrorEditor.tsx +121 -0
- package/src/widgets/codemirror/CodemirrorStateSingleton.tsx +39 -0
- package/src/widgets/codemirror/index.ts +2 -0
- package/src/widgets/form/Form.tsx +194 -0
- package/src/widgets/form/FormContext.ts +38 -0
- package/src/widgets/form/ManagedObject.ts +332 -0
- package/src/widgets/form/fields.tsx +34 -0
- package/src/widgets/form/index.ts +6 -0
- package/src/widgets/form/inputs.tsx +44 -0
- package/src/widgets/form/schema.ts +215 -0
- package/src/widgets/index.ts +5 -0
- package/src/widgets/json-view/JSONCode.tsx +176 -0
- package/src/widgets/json-view/JSONDisplay.tsx +24 -0
- package/src/widgets/json-view/JSONView.tsx +183 -0
- package/src/widgets/json-view/index.ts +4 -0
- package/src/widgets/json-view/types.ts +5 -0
- package/src/widgets/schema-editor/JSONSchemaEditorModal.tsx +68 -0
- package/src/widgets/schema-editor/ManagedSchema.ts +340 -0
- package/src/widgets/schema-editor/editor/Editable.tsx +252 -0
- package/src/widgets/schema-editor/editor/EditableSchemaProperty.tsx +15 -0
- package/src/widgets/schema-editor/editor/PropertyEditor.tsx +150 -0
- package/src/widgets/schema-editor/editor/PropertyViewer.tsx +15 -0
- package/src/widgets/schema-editor/editor/SchemaContext.tsx +9 -0
- package/src/widgets/schema-editor/editor/SchemaEditor.test.ts +48 -0
- package/src/widgets/schema-editor/editor/SchemaEditor.tsx +161 -0
- package/src/widgets/schema-editor/index.ts +7 -0
- package/src/widgets/schema-editor/json-schema4-utils.ts +187 -0
- package/src/widgets/schema-editor/type-signature.ts +39 -0
- package/src/widgets/xml-viewer/components/Attributes/index.tsx +27 -0
- package/src/widgets/xml-viewer/components/CDataTag/index.tsx +21 -0
- package/src/widgets/xml-viewer/components/CollapseIcon/index.tsx +32 -0
- package/src/widgets/xml-viewer/components/CommentTag/index.tsx +30 -0
- package/src/widgets/xml-viewer/components/DeclarationTag/index.tsx +23 -0
- package/src/widgets/xml-viewer/components/Elements/index.tsx +83 -0
- package/src/widgets/xml-viewer/components/InvalidXml/index.tsx +3 -0
- package/src/widgets/xml-viewer/components/Tag/index.tsx +47 -0
- package/src/widgets/xml-viewer/components/TextElement/index.tsx +28 -0
- package/src/widgets/xml-viewer/components/XMLViewer.tsx +53 -0
- package/src/widgets/xml-viewer/components/types.ts +104 -0
- package/src/widgets/xml-viewer/constants/index.ts +17 -0
- package/src/widgets/xml-viewer/context/xml-viewer-context.ts +12 -0
- package/src/widgets/xml-viewer/helpers/index.ts +56 -0
- package/src/widgets/xml-viewer/hooks/useCollapsible.ts +28 -0
- package/src/widgets/xml-viewer/hooks/useXMLViewer.ts +34 -0
- package/src/widgets/xml-viewer/index.ts +2 -0
- package/src/widgets/xml-viewer/types/index.ts +21 -0
- package/lib/esm/components/index.js +0 -3
- package/lib/esm/components/index.js.map +0 -1
- package/lib/types/components/index.d.ts +0 -0
- package/lib/vertesia-ui-components.js +0 -2
- package/lib/vertesia-ui-components.js.map +0 -1
- package/src/components/index.ts +0 -1
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import * as React from "react"
|
|
2
|
+
import { cva, type VariantProps } from "class-variance-authority"
|
|
3
|
+
import { cn } from "./libs/utils"
|
|
4
|
+
|
|
5
|
+
// Base badge variants
|
|
6
|
+
const badgeVariants = cva(
|
|
7
|
+
"inline-flex items-center rounded-md px-2 py-1 text-xs font-medium",
|
|
8
|
+
{
|
|
9
|
+
variants: {
|
|
10
|
+
variant: {
|
|
11
|
+
default: "text-foreground bg-muted",
|
|
12
|
+
secondary: "bg-secondary text-primary",
|
|
13
|
+
destructive: "bg-destructive text-destructive",
|
|
14
|
+
attention: "bg-attention text-attention",
|
|
15
|
+
success: "bg-success text-success",
|
|
16
|
+
info: "bg-info text-info",
|
|
17
|
+
done: "bg-done text-done",
|
|
18
|
+
},
|
|
19
|
+
},
|
|
20
|
+
defaultVariants: {
|
|
21
|
+
variant: "default",
|
|
22
|
+
},
|
|
23
|
+
}
|
|
24
|
+
)
|
|
25
|
+
|
|
26
|
+
// Base Badge props interface
|
|
27
|
+
interface BaseBadgeProps
|
|
28
|
+
extends React.HTMLAttributes<HTMLSpanElement>,
|
|
29
|
+
VariantProps<typeof badgeVariants> {
|
|
30
|
+
children: React.ReactNode;
|
|
31
|
+
onClick?: () => void;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
// Base Badge component
|
|
35
|
+
export function Badge({ className, variant, children, onClick, ...props }: BaseBadgeProps) {
|
|
36
|
+
return (
|
|
37
|
+
<span
|
|
38
|
+
className={cn(badgeVariants({ variant }), className)}
|
|
39
|
+
onClick={onClick}
|
|
40
|
+
{...props}
|
|
41
|
+
>
|
|
42
|
+
{children}
|
|
43
|
+
</span>
|
|
44
|
+
)
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
const dotBadgeVariants = cva(
|
|
48
|
+
// Base styles
|
|
49
|
+
"inline-flex items-center gap-x-1.5 rounded-md px-2 py-1 text-xs font-medium ring-1 ring-inset ring-border",
|
|
50
|
+
{
|
|
51
|
+
variants: {
|
|
52
|
+
variant: {
|
|
53
|
+
default: "",
|
|
54
|
+
success: "",
|
|
55
|
+
destructive: "",
|
|
56
|
+
attention: "",
|
|
57
|
+
done: "",
|
|
58
|
+
info: "",
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
defaultVariants: {
|
|
62
|
+
variant: "default"
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
);
|
|
66
|
+
|
|
67
|
+
// Separate dot variants to allow className overrides
|
|
68
|
+
const dotVariants = cva("h-1.5 w-1.5", {
|
|
69
|
+
variants: {
|
|
70
|
+
variant: {
|
|
71
|
+
default: "fill-foreground",
|
|
72
|
+
success: "fill-success",
|
|
73
|
+
destructive: "fill-destructive",
|
|
74
|
+
attention: "fill-attention",
|
|
75
|
+
done: "fill-done",
|
|
76
|
+
info: "fill-info",
|
|
77
|
+
}
|
|
78
|
+
},
|
|
79
|
+
defaultVariants: {
|
|
80
|
+
variant: "default"
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
interface DotBadgeProps
|
|
85
|
+
extends React.HTMLAttributes<HTMLSpanElement>,
|
|
86
|
+
VariantProps<typeof dotBadgeVariants> {
|
|
87
|
+
children?: React.ReactNode;
|
|
88
|
+
// Add specific dot className prop for backward compatibility
|
|
89
|
+
dotClassName?: string;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
export function DotBadge({
|
|
93
|
+
variant,
|
|
94
|
+
className,
|
|
95
|
+
dotClassName, // New prop for dot-specific classes
|
|
96
|
+
children,
|
|
97
|
+
...props
|
|
98
|
+
}: DotBadgeProps) {
|
|
99
|
+
return (
|
|
100
|
+
<span
|
|
101
|
+
className={cn(dotBadgeVariants({ variant }), className)}
|
|
102
|
+
{...props}
|
|
103
|
+
>
|
|
104
|
+
<svg
|
|
105
|
+
className={cn(dotVariants({ variant }), dotClassName)}
|
|
106
|
+
viewBox="0 0 6 6"
|
|
107
|
+
aria-hidden="true"
|
|
108
|
+
>
|
|
109
|
+
<circle cx={3} cy={3} r={3} />
|
|
110
|
+
</svg>
|
|
111
|
+
{children}
|
|
112
|
+
</span>
|
|
113
|
+
);
|
|
114
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import clsx from 'clsx';
|
|
2
|
+
import React from "react";
|
|
3
|
+
import { Spinner } from "./Spinner.js";
|
|
4
|
+
|
|
5
|
+
function getRealSize(size: 'xs' | 'sm' | 'md' | 'lg' | 'xl') {
|
|
6
|
+
switch (size) {
|
|
7
|
+
case 'xs': return 'rounded-xs px-2 py-1 text-xs gap-x-1';
|
|
8
|
+
case 'sm': return 'rounded-xs px-2 py-1 text-sm gap-x-1';
|
|
9
|
+
case 'md': return 'rounded-md px-2.5 py-1.5 text-sm gap-x-1.5';
|
|
10
|
+
case 'lg': return 'rounded-md px-3 py-2 text-sm gap-x-1.5';
|
|
11
|
+
case 'xl': return 'rounded-md px-3.5 py-2.5 text-sm gap-x-2';
|
|
12
|
+
default: throw new Error('Unexpected size: ' + size);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
const Variants = {
|
|
17
|
+
primary: "shadow-2xs bg-indigo-600 text-white hover:bg-indigo-500 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-indigo-600",
|
|
18
|
+
secondary: "shadow-2xs bg-white text-gray-900 hover:bg-gray-50 ring-1 ring-inset ring-gray-300",
|
|
19
|
+
soft: "shadow-2xs bg-indigo-50 text-indigo-600 hover:bg-indigo-100",
|
|
20
|
+
ghost: "text-indigo-600 hover:bg-indigo-100 dark:text-indigo-400 dark:hover:bg-indigo-900",
|
|
21
|
+
unstyled: ""
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
const SpinnerVariants = {
|
|
25
|
+
primary: "text-white",
|
|
26
|
+
secondary: "text-indigo-500",
|
|
27
|
+
soft: "text-indigo-600",
|
|
28
|
+
ghost: "text-indigo-600",
|
|
29
|
+
unstyled: "text-gray-600"
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export interface ButtonProps {
|
|
33
|
+
isLoading?: boolean
|
|
34
|
+
isDisabled?: boolean
|
|
35
|
+
variant?: "primary" | "secondary" | "soft" | "ghost" | "unstyled"
|
|
36
|
+
size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl'
|
|
37
|
+
children: React.ReactNode | React.ReactNode[];
|
|
38
|
+
onClick?: (ev: React.MouseEvent<HTMLButtonElement, MouseEvent>) => void;
|
|
39
|
+
type?: "button" | "submit" | "reset";
|
|
40
|
+
title?: string;
|
|
41
|
+
className?: string;
|
|
42
|
+
}
|
|
43
|
+
export function Button({ title, className, type = 'button', children, size, onClick, variant = "primary", isLoading = false, isDisabled = false }: ButtonProps) {
|
|
44
|
+
const sizeClass = getRealSize(size || 'md');
|
|
45
|
+
return (
|
|
46
|
+
<button
|
|
47
|
+
title={title}
|
|
48
|
+
disabled={isDisabled || isLoading}
|
|
49
|
+
onClick={onClick}
|
|
50
|
+
type={type}
|
|
51
|
+
className={
|
|
52
|
+
clsx("whitespace-nowrap inline-flex items-center justify-center font-semibold hover:cursor-pointer",
|
|
53
|
+
Variants[variant],
|
|
54
|
+
sizeClass,
|
|
55
|
+
isDisabled && "cursor-not-allowed text-gray-300!",
|
|
56
|
+
className
|
|
57
|
+
)}
|
|
58
|
+
>
|
|
59
|
+
{isLoading && <Spinner className={SpinnerVariants[variant]} size={size} />}
|
|
60
|
+
{children}
|
|
61
|
+
</button>
|
|
62
|
+
)
|
|
63
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import clsx from "clsx";
|
|
2
|
+
import { ReactNode } from "react";
|
|
3
|
+
|
|
4
|
+
interface CenterProps {
|
|
5
|
+
children: ReactNode | ReactNode[]
|
|
6
|
+
className?: string;
|
|
7
|
+
}
|
|
8
|
+
export function Center({ className, children }: CenterProps) {
|
|
9
|
+
return (
|
|
10
|
+
<div className={clsx('flex items-ceter justify-center', className)}>{children}</div>
|
|
11
|
+
)
|
|
12
|
+
}
|
|
@@ -0,0 +1,488 @@
|
|
|
1
|
+
import { ChevronDownIcon, ChevronUpIcon } from 'lucide-react';
|
|
2
|
+
import clsx from 'clsx';
|
|
3
|
+
import React, { ReactNode, useEffect, useRef, useState } from 'react';
|
|
4
|
+
import { AlignType, Popup, PopupController } from "./popup/index";
|
|
5
|
+
|
|
6
|
+
const INPUT_UNSTYLED = "block m-0 p-0 border-0 focus:outline-none focus:ring-0 bg-transparent"
|
|
7
|
+
const INPUT_NO_PADDING = "block sm:text-sm sm:leading-6 rounded-md border-0 text-gray-900 shadow-sm ring-1 ring-inset ring-gray-300 dark:ring-slate-600 dark:text-slate-50 dark:bg-slate-800 placeholder:text-gray-400 dark:placeholder:text-gray-400 focus:ring-2 focus:ring-inset focus:ring-indigo-600 dark:focus:ring-indigo-800"
|
|
8
|
+
const INPUT = INPUT_NO_PADDING + " py-1.5";
|
|
9
|
+
const COMBOBOX_POPUP = "combobox-popup";
|
|
10
|
+
|
|
11
|
+
function genComboboxPopupId() {
|
|
12
|
+
return `combobox-popup-${Math.floor(Math.random() * 1000000)}`;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export abstract class OptionAdapter<T> {
|
|
16
|
+
abstract valueOf(item: T): string;
|
|
17
|
+
abstract idOf(item: T): string;
|
|
18
|
+
filter(items: T[], text: string) {
|
|
19
|
+
const lcText = text.toLowerCase();
|
|
20
|
+
return items.filter((item: T) => this.valueOf(item).toLowerCase().includes(lcText));
|
|
21
|
+
}
|
|
22
|
+
renderOption(item: T): ReactNode {
|
|
23
|
+
return this.valueOf(item);
|
|
24
|
+
}
|
|
25
|
+
findById(items: T[], id: string) {
|
|
26
|
+
return items.find(item => this.idOf(item) === id);
|
|
27
|
+
}
|
|
28
|
+
// override to support creating new items
|
|
29
|
+
createItem(_value: string): T | null {
|
|
30
|
+
return null; // default is no new item
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export class StringOptionAdapter extends OptionAdapter<string> {
|
|
35
|
+
valueOf(item: string): string {
|
|
36
|
+
return String(item);
|
|
37
|
+
}
|
|
38
|
+
idOf(item: string): string {
|
|
39
|
+
return String(item);
|
|
40
|
+
}
|
|
41
|
+
static instance = new StringOptionAdapter();
|
|
42
|
+
}
|
|
43
|
+
export class StringOptionAdapterWithCreate extends StringOptionAdapter {
|
|
44
|
+
createItem(value: string): string {
|
|
45
|
+
return value;
|
|
46
|
+
}
|
|
47
|
+
static instance = new StringOptionAdapterWithCreate();
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
export interface ComboBoxLayoutProps<T> {
|
|
51
|
+
buttonRight?: number;
|
|
52
|
+
buttonWidth?: number;
|
|
53
|
+
maxMenuHeight?: number;
|
|
54
|
+
menuClass?: string;
|
|
55
|
+
inputClass?: string;
|
|
56
|
+
optionClass?: string;
|
|
57
|
+
Input?: React.ComponentType<ComboInputProps<T>>;
|
|
58
|
+
Menu?: React.ComponentType<ComboMenuProps<T>>;
|
|
59
|
+
Toggle?: React.ComponentType<ComboToggleProps<T>> | null;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
export type ComboBoxLayout<T> = Required<ComboBoxLayoutProps<T>>
|
|
63
|
+
|
|
64
|
+
export function getDefaultComboBoxLayout<T>(fullWidth?: boolean, unstyledInput?: boolean): ComboBoxLayout<T> {
|
|
65
|
+
return {
|
|
66
|
+
buttonRight: 4,
|
|
67
|
+
buttonWidth: 24,
|
|
68
|
+
maxMenuHeight: 240,
|
|
69
|
+
menuClass: "w-72 bg-white mt-1 shadow-md border border-gray-200 overflow-auto p-0 z-10",
|
|
70
|
+
inputClass: clsx(unstyledInput ? INPUT_UNSTYLED : INPUT, fullWidth ? "w-full" : "!w-auto"),
|
|
71
|
+
optionClass: "py-2 px-3 shadow-sm flex flex-col [&.option-selected]:font-semibold [&.option-highlighted]:bg-blue-300",
|
|
72
|
+
Input: ComboInput<T>,
|
|
73
|
+
Menu: ComboMenu<T>,
|
|
74
|
+
Toggle: ComboToggle<T>,
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
export interface ComboBoxApi<T> {
|
|
79
|
+
open: () => void;
|
|
80
|
+
close: () => void;
|
|
81
|
+
toggle: () => void;
|
|
82
|
+
inputValue: string;
|
|
83
|
+
selectedItem: T | null;
|
|
84
|
+
setInputValue: (value: string) => void;
|
|
85
|
+
focus: () => void;
|
|
86
|
+
}
|
|
87
|
+
interface ComboBoxProps<T> {
|
|
88
|
+
items: T[];
|
|
89
|
+
adapter: OptionAdapter<T>;
|
|
90
|
+
// if true then the default layout will use an unstyled input
|
|
91
|
+
unstyledInput?: boolean;
|
|
92
|
+
// if true then the default layout will use w-full on the input
|
|
93
|
+
fullWidth?: boolean;
|
|
94
|
+
layout?: ComboBoxLayoutProps<T>;
|
|
95
|
+
placeholder?: string;
|
|
96
|
+
api?: React.MutableRefObject<ComboBoxApi<T> | null>;
|
|
97
|
+
//TODO
|
|
98
|
+
value?: T | null;
|
|
99
|
+
//TODO onselect too?
|
|
100
|
+
onSelect?: (value: T | null) => void;
|
|
101
|
+
// menu zIndex
|
|
102
|
+
zIndex?: number;
|
|
103
|
+
focusOnMount?: boolean
|
|
104
|
+
menuGap?: number;
|
|
105
|
+
menuAlign?: AlignType;
|
|
106
|
+
}
|
|
107
|
+
export function ComboBox<T>({ menuAlign = "fill", menuGap, focusOnMount, onSelect, value, zIndex, unstyledInput, fullWidth, api, layout: layoutOpts, adapter, items, placeholder }: ComboBoxProps<T>) {
|
|
108
|
+
const [popupId] = useState(genComboboxPopupId());
|
|
109
|
+
const popupCtrl = useRef<PopupController | undefined>(undefined);
|
|
110
|
+
const inputRef = useRef<HTMLInputElement>(null);
|
|
111
|
+
const layout: ComboBoxLayout<T> = layoutOpts ? Object.assign(getDefaultComboBoxLayout<T>(fullWidth, unstyledInput), layoutOpts) : getDefaultComboBoxLayout<T>(fullWidth, unstyledInput);
|
|
112
|
+
const inputBoxRef = React.useRef<HTMLDivElement>(null);
|
|
113
|
+
const ctrl = useComboboxCtrl<T>({
|
|
114
|
+
adapter,
|
|
115
|
+
items,
|
|
116
|
+
value,
|
|
117
|
+
popupId
|
|
118
|
+
});
|
|
119
|
+
useEffect(() => {
|
|
120
|
+
if (inputRef.current) {
|
|
121
|
+
focusOnMount && inputRef.current.focus();
|
|
122
|
+
}
|
|
123
|
+
}, [inputRef.current]);
|
|
124
|
+
// the onSelect callback may change so we need to refresh it.
|
|
125
|
+
useEffect(() => {
|
|
126
|
+
ctrl.onSelect = onSelect
|
|
127
|
+
ctrl.popupCtrl = popupCtrl.current;
|
|
128
|
+
}, [onSelect, popupCtrl.current]);
|
|
129
|
+
useEffect(() => {
|
|
130
|
+
if (api && ctrl && inputRef.current) {
|
|
131
|
+
api.current = {
|
|
132
|
+
open: () => ctrl.openMenu(),
|
|
133
|
+
close: () => ctrl.closeMenu(),
|
|
134
|
+
toggle: () => ctrl.toggleMenu(),
|
|
135
|
+
setInputValue: (value: string) => ctrl.inputText = value,
|
|
136
|
+
inputValue: ctrl.inputText || '',
|
|
137
|
+
selectedItem: ctrl.selectedItem,
|
|
138
|
+
focus: () => inputRef.current?.focus()
|
|
139
|
+
}
|
|
140
|
+
return () => {
|
|
141
|
+
api.current = null;
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
}, [api, ctrl, inputRef.current]);
|
|
145
|
+
|
|
146
|
+
const showMenu = ctrl.isMenuOpen && ctrl.filteredItems.length > 0;
|
|
147
|
+
|
|
148
|
+
return (
|
|
149
|
+
<>
|
|
150
|
+
<layout.Input boxRef={inputBoxRef} inputRef={inputRef} ctrl={ctrl} layout={layout} placeholder={placeholder} />
|
|
151
|
+
<Popup
|
|
152
|
+
id={popupId}
|
|
153
|
+
ctrlRef={popupCtrl}
|
|
154
|
+
className={COMBOBOX_POPUP}
|
|
155
|
+
closeOnClick closeOnEsc
|
|
156
|
+
onClose={() => ctrl.closeMenu()}
|
|
157
|
+
isOpen={showMenu} anchor={inputBoxRef} zIndex={zIndex} constraints={{
|
|
158
|
+
position: "bottom",
|
|
159
|
+
align: menuAlign,
|
|
160
|
+
gap: menuGap != null ? menuGap : 4
|
|
161
|
+
}}>
|
|
162
|
+
<layout.Menu fillWidth={menuAlign === "fill"} items={ctrl.filteredItems} ctrl={ctrl} layout={layout} adapter={adapter} />
|
|
163
|
+
</Popup>
|
|
164
|
+
</>
|
|
165
|
+
);
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
export interface ComboInputProps<T> {
|
|
169
|
+
layout: ComboBoxLayout<T>;
|
|
170
|
+
ctrl: ComboboxController<T>,
|
|
171
|
+
placeholder?: string
|
|
172
|
+
boxRef?: React.RefObject<HTMLDivElement | null>;
|
|
173
|
+
inputRef?: React.RefObject<HTMLInputElement | null>;
|
|
174
|
+
}
|
|
175
|
+
function ComboInput<T>({ inputRef, placeholder, boxRef, ctrl, layout }: ComboInputProps<T>) {
|
|
176
|
+
const buttonWidth = layout.buttonWidth;
|
|
177
|
+
const style = buttonWidth > 0 ? { paddingRight: `${buttonWidth}px` } : undefined;
|
|
178
|
+
const Toggle = layout.Toggle;
|
|
179
|
+
return (
|
|
180
|
+
<div className="relative" ref={boxRef}>
|
|
181
|
+
<input ref={inputRef} placeholder={placeholder} {...ctrl.getInputProps()} style={style} className={layout.inputClass} />
|
|
182
|
+
{Toggle &&
|
|
183
|
+
<button style={{
|
|
184
|
+
top: 0, bottom: 0, right: `${layout.buttonRight}px`, width: `${buttonWidth}px`,
|
|
185
|
+
position: "absolute",
|
|
186
|
+
border: "none",
|
|
187
|
+
padding: 0,
|
|
188
|
+
margin: 0,
|
|
189
|
+
backgroundColor: "transparent",
|
|
190
|
+
display: "flex",
|
|
191
|
+
alignItems: "center",
|
|
192
|
+
justifyContent: "center"
|
|
193
|
+
}} {...ctrl.getToggleButtonProps()}>
|
|
194
|
+
<Toggle ctrl={ctrl} layout={layout} />
|
|
195
|
+
</button>
|
|
196
|
+
}
|
|
197
|
+
</div>
|
|
198
|
+
)
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
export interface ComboToggleProps<T> {
|
|
202
|
+
ctrl: ComboboxController<T>;
|
|
203
|
+
layout: ComboBoxLayout<T>;
|
|
204
|
+
}
|
|
205
|
+
function ComboToggle<T>({ ctrl }: ComboToggleProps<T>) {
|
|
206
|
+
return ctrl.isMenuOpen ? <ChevronUpIcon className="w-4 h-4" /> : <ChevronDownIcon className="w-4 h-4" />;
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
export interface ComboMenuProps<T> {
|
|
210
|
+
items: T[];
|
|
211
|
+
layout: ComboBoxLayout<T>;
|
|
212
|
+
ctrl: ComboboxController<T>;
|
|
213
|
+
adapter: OptionAdapter<T>;
|
|
214
|
+
fillWidth: boolean;
|
|
215
|
+
}
|
|
216
|
+
function ComboMenu<T>({ fillWidth, items, layout, ctrl, adapter }: ComboMenuProps<T>) {
|
|
217
|
+
const { highlightedIndex, selectedItem } = ctrl;
|
|
218
|
+
return (
|
|
219
|
+
<ul style={{ width: fillWidth ? "100%" : undefined, maxHeight: layout.maxMenuHeight ? `${layout.maxMenuHeight}px` : '240px' }}
|
|
220
|
+
className={layout.menuClass} {...ctrl.getMenuProps()}>
|
|
221
|
+
{items.map((item, index) => (
|
|
222
|
+
<li
|
|
223
|
+
data-index={index}
|
|
224
|
+
key={adapter.idOf(item)}
|
|
225
|
+
className={clsx(layout.optionClass,
|
|
226
|
+
highlightedIndex === index && "option-highlighted",
|
|
227
|
+
selectedItem === item && "option-selected")}
|
|
228
|
+
{...ctrl.getItemProps(item, index)}
|
|
229
|
+
>
|
|
230
|
+
{adapter.renderOption(item)}
|
|
231
|
+
</li>
|
|
232
|
+
))
|
|
233
|
+
}
|
|
234
|
+
</ul >
|
|
235
|
+
)
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
|
|
239
|
+
|
|
240
|
+
export interface ComboboxControllerProps<ItemT> {
|
|
241
|
+
adapter: OptionAdapter<ItemT>,
|
|
242
|
+
items: ItemT[],
|
|
243
|
+
value?: ItemT | string | null,
|
|
244
|
+
popupId: string;
|
|
245
|
+
}
|
|
246
|
+
export function useComboboxCtrl<ItemT>(props: ComboboxControllerProps<ItemT>): ComboboxController<ItemT> {
|
|
247
|
+
const [ctrl, setCtrl] = useState<ComboboxController<ItemT>>(new ComboboxController(props));
|
|
248
|
+
useEffect(() => {
|
|
249
|
+
ctrl?.withState(setCtrl);
|
|
250
|
+
}, []);
|
|
251
|
+
return ctrl;
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
|
|
255
|
+
class ComboboxController<ItemT> {
|
|
256
|
+
private popupId: string;
|
|
257
|
+
public items: ItemT[];
|
|
258
|
+
private adapter: OptionAdapter<ItemT>;
|
|
259
|
+
onSelect?: (item: ItemT | null) => void;
|
|
260
|
+
private setState?: (ctrl: ComboboxController<ItemT>) => void;
|
|
261
|
+
private _selectedItem: ItemT | null = null;
|
|
262
|
+
private _filteredItems: ItemT[];
|
|
263
|
+
private _inputText: string = "";
|
|
264
|
+
private _highlightedIndex: number | null = null;
|
|
265
|
+
private _isMenuOpen: boolean = false;
|
|
266
|
+
popupCtrl?: PopupController;
|
|
267
|
+
|
|
268
|
+
constructor({ adapter, items, value, popupId }: ComboboxControllerProps<ItemT>) {
|
|
269
|
+
this.adapter = adapter;
|
|
270
|
+
this.items = items;
|
|
271
|
+
this.popupId = popupId;
|
|
272
|
+
if (typeof value === "string") {
|
|
273
|
+
this._inputText = value;
|
|
274
|
+
} else if (value) {
|
|
275
|
+
this._selectedItem = adapter.findById(items, adapter.idOf(value)) || null;
|
|
276
|
+
if (this._selectedItem) {
|
|
277
|
+
this._inputText = adapter.valueOf(value);
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
if (this._inputText) {
|
|
281
|
+
this._filteredItems = this.adapter.filter(this.items, this._inputText);
|
|
282
|
+
} else {
|
|
283
|
+
this._filteredItems = this.items;
|
|
284
|
+
}
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
withState(setState: (ctrl: ComboboxController<ItemT>) => void) {
|
|
288
|
+
this.setState = setState;
|
|
289
|
+
return this;
|
|
290
|
+
}
|
|
291
|
+
|
|
292
|
+
private clone() {
|
|
293
|
+
const clone = new ComboboxController({ adapter: this.adapter, items: this.items, popupId: this.popupId });
|
|
294
|
+
clone.setState = this.setState;
|
|
295
|
+
clone.onSelect = this.onSelect;
|
|
296
|
+
clone._inputText = this._inputText;
|
|
297
|
+
clone._highlightedIndex = this._highlightedIndex;
|
|
298
|
+
clone._selectedItem = this._selectedItem;
|
|
299
|
+
clone._isMenuOpen = this._isMenuOpen;
|
|
300
|
+
clone._filteredItems = this._filteredItems;
|
|
301
|
+
clone.popupCtrl = this.popupCtrl;
|
|
302
|
+
return clone;
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
private updateState() {
|
|
306
|
+
this.setState?.(this.clone())
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
get filteredItems() {
|
|
310
|
+
if (this._inputText) {
|
|
311
|
+
return this.adapter.filter(this.items, this._inputText);
|
|
312
|
+
} else {
|
|
313
|
+
return this.items;
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
get selectedItem() {
|
|
317
|
+
return this._selectedItem;
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
set selectedItem(item: ItemT | null) {
|
|
321
|
+
this._selectedItem = item;
|
|
322
|
+
this._inputText = item ? this.adapter.valueOf(item) : "";
|
|
323
|
+
this._filteredItems = this._inputText ?
|
|
324
|
+
this.adapter.filter(this.items, this._inputText)
|
|
325
|
+
: this.items;
|
|
326
|
+
this.updateState();
|
|
327
|
+
this.onSelect?.(item);
|
|
328
|
+
}
|
|
329
|
+
|
|
330
|
+
get isMenuOpen() {
|
|
331
|
+
return this._isMenuOpen;
|
|
332
|
+
}
|
|
333
|
+
|
|
334
|
+
set inputText(inputText: string) {
|
|
335
|
+
this._inputText = inputText;
|
|
336
|
+
if (inputText) {
|
|
337
|
+
this._filteredItems = this.adapter.filter(this.items, inputText);
|
|
338
|
+
} else {
|
|
339
|
+
this._filteredItems = this.items;
|
|
340
|
+
}
|
|
341
|
+
this._highlightedIndex = null;
|
|
342
|
+
this._selectedItem = null;
|
|
343
|
+
this.updateState();
|
|
344
|
+
// TODO -- experimental - it works but it's not perfect
|
|
345
|
+
// we need to update if the popup is on top and the filtered items changed
|
|
346
|
+
if (this.isMenuOpen && this.popupCtrl) {
|
|
347
|
+
const popupCtrl = this.popupCtrl;
|
|
348
|
+
const popupPosition = popupCtrl.context?.position?.position;
|
|
349
|
+
if (popupPosition && popupPosition === "top") {
|
|
350
|
+
window.setTimeout(() => {
|
|
351
|
+
popupCtrl.update();
|
|
352
|
+
}, 100);
|
|
353
|
+
}
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
|
|
357
|
+
get inputText() {
|
|
358
|
+
return this._inputText;
|
|
359
|
+
}
|
|
360
|
+
|
|
361
|
+
set highlightedIndex(index: number | null) {
|
|
362
|
+
this._highlightedIndex = index;
|
|
363
|
+
this.updateState();
|
|
364
|
+
}
|
|
365
|
+
|
|
366
|
+
get highlightedIndex() {
|
|
367
|
+
return this._highlightedIndex;
|
|
368
|
+
}
|
|
369
|
+
|
|
370
|
+
openMenu() {
|
|
371
|
+
if (this._filteredItems.length > 0) {
|
|
372
|
+
this._isMenuOpen = true;
|
|
373
|
+
//this._highlightedIndex = 0;
|
|
374
|
+
this.updateState();
|
|
375
|
+
} else {
|
|
376
|
+
// TODO nothing to show.
|
|
377
|
+
// display a create value option?
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
|
|
381
|
+
closeMenu(_item?: ItemT | null) {
|
|
382
|
+
if (this._isMenuOpen) {
|
|
383
|
+
this._highlightedIndex = null;
|
|
384
|
+
this._isMenuOpen = false;
|
|
385
|
+
this.updateState();
|
|
386
|
+
}
|
|
387
|
+
}
|
|
388
|
+
|
|
389
|
+
toggleMenu() {
|
|
390
|
+
if (this._isMenuOpen) {
|
|
391
|
+
this.closeMenu();
|
|
392
|
+
} else {
|
|
393
|
+
this.openMenu();
|
|
394
|
+
}
|
|
395
|
+
}
|
|
396
|
+
|
|
397
|
+
private highlightIndex(index: number, navigateToTop: boolean = false) {
|
|
398
|
+
this.highlightedIndex = index;
|
|
399
|
+
const popup = document.getElementById(this.popupId);
|
|
400
|
+
if (popup) {
|
|
401
|
+
popup.querySelector(`li[data-index="${index}"]`)?.scrollIntoView(navigateToTop);
|
|
402
|
+
}
|
|
403
|
+
}
|
|
404
|
+
|
|
405
|
+
getMenuProps() {
|
|
406
|
+
return {}
|
|
407
|
+
}
|
|
408
|
+
|
|
409
|
+
getToggleButtonProps() {
|
|
410
|
+
return {
|
|
411
|
+
onClick: () => {
|
|
412
|
+
this._isMenuOpen = !this._isMenuOpen;
|
|
413
|
+
this.updateState();
|
|
414
|
+
}
|
|
415
|
+
}
|
|
416
|
+
}
|
|
417
|
+
|
|
418
|
+
getItemProps(item: ItemT, index: number): React.HTMLProps<HTMLLIElement> {
|
|
419
|
+
return {
|
|
420
|
+
"aria-selected": this._highlightedIndex === index,
|
|
421
|
+
onClick: () => {
|
|
422
|
+
this.selectedItem = item;
|
|
423
|
+
this.closeMenu();
|
|
424
|
+
},
|
|
425
|
+
onMouseEnter: () => {
|
|
426
|
+
if (this.highlightedIndex !== index) {
|
|
427
|
+
this.highlightedIndex = index;
|
|
428
|
+
}
|
|
429
|
+
},
|
|
430
|
+
onMouseLeave: () => {
|
|
431
|
+
if (this.highlightedIndex === index) {
|
|
432
|
+
this.highlightedIndex = null;
|
|
433
|
+
}
|
|
434
|
+
}
|
|
435
|
+
}
|
|
436
|
+
}
|
|
437
|
+
|
|
438
|
+
getInputProps() {
|
|
439
|
+
const items = this._filteredItems;
|
|
440
|
+
return {
|
|
441
|
+
onClick: () => {
|
|
442
|
+
this.openMenu();
|
|
443
|
+
},
|
|
444
|
+
onChange: (ev: React.ChangeEvent<HTMLInputElement>) => {
|
|
445
|
+
const value = ev.target.value;
|
|
446
|
+
this.inputText = value;
|
|
447
|
+
this.openMenu();
|
|
448
|
+
},
|
|
449
|
+
value: this.inputText,
|
|
450
|
+
onKeyDown: (ev: React.KeyboardEvent<HTMLInputElement>) => {
|
|
451
|
+
const key = ev.key;
|
|
452
|
+
if (key === "Enter") {
|
|
453
|
+
if (this.highlightedIndex != null) {
|
|
454
|
+
this.selectedItem = items[this.highlightedIndex || 0];
|
|
455
|
+
} else {
|
|
456
|
+
// create new value?
|
|
457
|
+
if (this.inputText) {
|
|
458
|
+
const item = this.adapter.createItem(this.inputText);
|
|
459
|
+
if (item) {
|
|
460
|
+
this.items.push(item);
|
|
461
|
+
this.selectedItem = item;
|
|
462
|
+
}
|
|
463
|
+
}
|
|
464
|
+
}
|
|
465
|
+
this.closeMenu();
|
|
466
|
+
} else if (key === "ArrowDown") {
|
|
467
|
+
if (this.isMenuOpen) {
|
|
468
|
+
this.highlightIndex(this.highlightedIndex === null ? 0 : incrModulo(this.highlightedIndex, items.length), false);
|
|
469
|
+
} else {
|
|
470
|
+
this.openMenu();
|
|
471
|
+
}
|
|
472
|
+
} else if (key === "ArrowUp") {
|
|
473
|
+
if (this.isMenuOpen) {
|
|
474
|
+
this.highlightIndex(this.highlightedIndex === null ? 0 : decrModulo(this.highlightedIndex, items.length), true);
|
|
475
|
+
}
|
|
476
|
+
}
|
|
477
|
+
}
|
|
478
|
+
}
|
|
479
|
+
}
|
|
480
|
+
}
|
|
481
|
+
|
|
482
|
+
|
|
483
|
+
function incrModulo(value: number, max: number) {
|
|
484
|
+
return (value + 1) % max;
|
|
485
|
+
}
|
|
486
|
+
function decrModulo(value: number, max: number) {
|
|
487
|
+
return (value - 1 + max) % max;
|
|
488
|
+
}
|