@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,102 @@
|
|
|
1
|
+
import { Permission, ProjectRoles } from "@vertesia/common"
|
|
2
|
+
import { ErrorBox, useFetch } from "@vertesia/ui/core"
|
|
3
|
+
import { UserSession, useUserSession } from "@vertesia/ui/session"
|
|
4
|
+
import { createContext, useContext, useMemo } from "react"
|
|
5
|
+
import { isAnyOf } from "./helpers"
|
|
6
|
+
|
|
7
|
+
type ListRolesResponse = {
|
|
8
|
+
name: ProjectRoles,
|
|
9
|
+
permissions: Permission[]
|
|
10
|
+
}[];
|
|
11
|
+
|
|
12
|
+
export class UserPermissions {
|
|
13
|
+
system_roles: ListRolesResponse; // all roles defined in the system
|
|
14
|
+
roles: Set<string>; // all roles of the current user
|
|
15
|
+
permissions: Set<string>; // all permissions of the current user
|
|
16
|
+
|
|
17
|
+
constructor(session: UserSession, roles: ListRolesResponse) {
|
|
18
|
+
if (!session.authToken) {
|
|
19
|
+
throw new Error('No auth token found in user session')
|
|
20
|
+
}
|
|
21
|
+
this.system_roles = roles;
|
|
22
|
+
const userRoles = new Set<string>(session.authToken.account_roles || []);
|
|
23
|
+
if (session.authToken.project_roles) {
|
|
24
|
+
for (const role of session.authToken.project_roles) {
|
|
25
|
+
userRoles.add(role);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
this.roles = userRoles;
|
|
29
|
+
// build a temporary role to permissions map
|
|
30
|
+
const map: Record<string, Permission[]> = {};
|
|
31
|
+
for (const role of roles) {
|
|
32
|
+
map[role.name] = role.permissions;
|
|
33
|
+
}
|
|
34
|
+
const permissions = new Set<string>();
|
|
35
|
+
for (const role of userRoles) {
|
|
36
|
+
const rolePermissions = map[role];
|
|
37
|
+
if (rolePermissions) {
|
|
38
|
+
for (const permission of rolePermissions) {
|
|
39
|
+
permissions.add(permission);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
this.permissions = permissions;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
hasPermission(permission: string | string[]) {
|
|
48
|
+
if (typeof permission === 'string') {
|
|
49
|
+
return this.permissions.has(permission);
|
|
50
|
+
} else if (isAnyOf(permission as Permission[])) {
|
|
51
|
+
return permission.some(p => this.permissions.has(p));
|
|
52
|
+
} else { // all of
|
|
53
|
+
for (const p of permission) {
|
|
54
|
+
if (!this.permissions.has(p)) {
|
|
55
|
+
return false;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
return true;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
const UserPermissionsContext = createContext<UserPermissions | undefined>(undefined)
|
|
65
|
+
|
|
66
|
+
export function useUserPermissions() {
|
|
67
|
+
const perms = useContext(UserPermissionsContext);
|
|
68
|
+
if (!perms) {
|
|
69
|
+
throw new Error('UserPermissionContext cannot be used outside UserPermissionProvider')
|
|
70
|
+
}
|
|
71
|
+
return perms;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
interface UserPermissionProviderProps {
|
|
75
|
+
children: React.ReactNode
|
|
76
|
+
}
|
|
77
|
+
export function UserPermissionProvider({ children }: UserPermissionProviderProps) {
|
|
78
|
+
const session = useUserSession();
|
|
79
|
+
const { data, error, isLoading } = useFetch<ListRolesResponse | undefined>(() => {
|
|
80
|
+
if (session.user) {
|
|
81
|
+
return session.client.iam.roles.list();
|
|
82
|
+
} else {
|
|
83
|
+
return Promise.resolve(undefined);
|
|
84
|
+
}
|
|
85
|
+
}, [session.user]);
|
|
86
|
+
|
|
87
|
+
const perms = useMemo(() => {
|
|
88
|
+
if (session.authToken && data && !isLoading) {
|
|
89
|
+
return new UserPermissions(session, data);
|
|
90
|
+
} else {
|
|
91
|
+
return undefined;
|
|
92
|
+
}
|
|
93
|
+
}, [session, data, isLoading]);
|
|
94
|
+
|
|
95
|
+
if (error) {
|
|
96
|
+
return <ErrorBox title="Failed to fetch role mappings">{error.message}</ErrorBox>
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
return perms && (
|
|
100
|
+
<UserPermissionsContext.Provider value={perms}>{children}</UserPermissionsContext.Provider>
|
|
101
|
+
)
|
|
102
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Permission } from "@vertesia/common";
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
export function AnyOf(...permissions: Permission[]): Permission[] {
|
|
5
|
+
const p = Array.from(permissions);
|
|
6
|
+
(p as any).__AnyOf__ = true;
|
|
7
|
+
return p;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export function AllOf(...permissions: Permission[]): Permission[] {
|
|
11
|
+
return Array.from(permissions);
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export function isAnyOf(permissions: Permission[]) {
|
|
15
|
+
return (permissions as any).__AnyOf__ === true;
|
|
16
|
+
}
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import { Dialog, DialogPanel, Transition, TransitionChild } from '@headlessui/react'
|
|
2
|
+
import { X } from 'lucide-react'
|
|
3
|
+
import clsx from 'clsx'
|
|
4
|
+
import { Fragment, useEffect, useState } from 'react'
|
|
5
|
+
// import { FullHeightLayout } from './FullHeightLayout.js'
|
|
6
|
+
import { Navbar } from './Navbar.js'
|
|
7
|
+
import { Sidebar } from './Sidebar.js'
|
|
8
|
+
import { SidebarContext } from './SidebarContext.js'
|
|
9
|
+
|
|
10
|
+
interface AppLayoutProps {
|
|
11
|
+
title?: string;
|
|
12
|
+
children: React.ReactNode | React.ReactNode[]
|
|
13
|
+
logo?: React.ReactNode
|
|
14
|
+
navbar?: React.ReactNode | React.ReactNode[]
|
|
15
|
+
sidebar?: React.ReactNode | React.ReactNode[]
|
|
16
|
+
mainNav?: React.ReactNode
|
|
17
|
+
className?: string // will be forwarded to the main page element
|
|
18
|
+
sidebarClassName?: string // will be forwarded to the sidebar element
|
|
19
|
+
}
|
|
20
|
+
export function AppLayout({ sidebarClassName, className, title, children, logo, navbar, sidebar, mainNav }: AppLayoutProps) {
|
|
21
|
+
|
|
22
|
+
if (localStorage.getItem('desktopSidebarOpen') === null) {
|
|
23
|
+
localStorage.setItem('desktopSidebarOpen', 'true');
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
const [sidebarOpen, setSidebarOpen] = useState(false)
|
|
27
|
+
const [desktopSidebarOpen, setDesktopSidebarOpen] = useState(localStorage.getItem('desktopSidebarOpen') === 'true')
|
|
28
|
+
const [isLargeScreen, setIsLargeScreen] = useState(window.innerWidth >= 1024)
|
|
29
|
+
|
|
30
|
+
useEffect(() => {
|
|
31
|
+
const handleResize = () => {
|
|
32
|
+
setIsLargeScreen(window.innerWidth >= 1024)
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
window.addEventListener('resize', handleResize)
|
|
36
|
+
return () => window.removeEventListener('resize', handleResize)
|
|
37
|
+
}, [])
|
|
38
|
+
|
|
39
|
+
const sidebarContextValue = {
|
|
40
|
+
isOpen: isLargeScreen ? desktopSidebarOpen : sidebarOpen,
|
|
41
|
+
toggleDesktop: (value?: boolean) => {
|
|
42
|
+
if (value === undefined) {
|
|
43
|
+
setDesktopSidebarOpen(!desktopSidebarOpen)
|
|
44
|
+
} else {
|
|
45
|
+
setDesktopSidebarOpen(value)
|
|
46
|
+
}
|
|
47
|
+
localStorage.setItem('desktopSidebarOpen', JSON.stringify(!desktopSidebarOpen))
|
|
48
|
+
},
|
|
49
|
+
toggleMobile: (value?: boolean) => {
|
|
50
|
+
if (value === undefined) {
|
|
51
|
+
setSidebarOpen(!sidebarOpen)
|
|
52
|
+
} else {
|
|
53
|
+
setSidebarOpen(value)
|
|
54
|
+
}
|
|
55
|
+
},
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
return (
|
|
59
|
+
<>
|
|
60
|
+
<div className='flex flex-col h-screen overflow-y-hidden'>
|
|
61
|
+
|
|
62
|
+
<SidebarContext.Provider value={sidebarContextValue}>
|
|
63
|
+
<div className='w-full'>
|
|
64
|
+
{mainNav}
|
|
65
|
+
</div>
|
|
66
|
+
|
|
67
|
+
<div className='flex h-full overflow-y-auto w-full'>
|
|
68
|
+
|
|
69
|
+
<Transition show={sidebarOpen} as={Fragment}>
|
|
70
|
+
<Dialog as="div" className="relative z-50 lg:hidden" onClose={setSidebarOpen}>
|
|
71
|
+
{/* Backdrop layer for the semi-transparent */}
|
|
72
|
+
<TransitionChild
|
|
73
|
+
as={Fragment}
|
|
74
|
+
enter="transition-opacity ease-linear duration-300"
|
|
75
|
+
enterFrom="opacity-0"
|
|
76
|
+
enterTo="opacity-100"
|
|
77
|
+
leave="transition-opacity ease-linear duration-300"
|
|
78
|
+
leaveFrom="opacity-100"
|
|
79
|
+
leaveTo="opacity-0"
|
|
80
|
+
>
|
|
81
|
+
<div className="fixed inset-0 bg-gray-900/80" />
|
|
82
|
+
</TransitionChild>
|
|
83
|
+
|
|
84
|
+
<div className="fixed inset-0 flex">
|
|
85
|
+
<TransitionChild
|
|
86
|
+
as={Fragment}
|
|
87
|
+
enter="transition ease-in-out duration-300 transform"
|
|
88
|
+
enterFrom="-translate-x-full"
|
|
89
|
+
enterTo="translate-x-0"
|
|
90
|
+
leave="transition ease-in-out duration-300 transform"
|
|
91
|
+
leaveFrom="translate-x-0"
|
|
92
|
+
leaveTo="-translate-x-full"
|
|
93
|
+
>
|
|
94
|
+
<DialogPanel className="relative flex w-full max-w-xs flex-1">
|
|
95
|
+
{/* Sidebar component, swap this element with another sidebar if you like */}
|
|
96
|
+
<Sidebar logo={logo} className={sidebarClassName}>{sidebar}</Sidebar>
|
|
97
|
+
|
|
98
|
+
{/* close button */}
|
|
99
|
+
<div className="flex w-16 justify-center pt-5 items-start">
|
|
100
|
+
<button type="button" className="-m-2.5 p-2.5" onClick={() => setSidebarOpen(false)}>
|
|
101
|
+
<span className="sr-only">Close sidebar</span>
|
|
102
|
+
<X className="size-6 text-white" aria-hidden="true" />
|
|
103
|
+
</button>
|
|
104
|
+
</div>
|
|
105
|
+
</DialogPanel>
|
|
106
|
+
</TransitionChild>
|
|
107
|
+
</div>
|
|
108
|
+
</Dialog>
|
|
109
|
+
</Transition>
|
|
110
|
+
|
|
111
|
+
{/* Static sidebar for desktop */}
|
|
112
|
+
<div className={`hidden lg:block relative transition-all duration-300 ${desktopSidebarOpen ? 'w-72' : 'w-12'}`}>
|
|
113
|
+
{/* Sidebar component, swap this element with another sidebar if you like */}
|
|
114
|
+
<Sidebar logo={logo} className={sidebarClassName}>{sidebar}</Sidebar>
|
|
115
|
+
</div>
|
|
116
|
+
|
|
117
|
+
<div className="w-full h-full overflow-y-hidden">
|
|
118
|
+
{navbar ? (
|
|
119
|
+
<Navbar title={title} logo={logo}>
|
|
120
|
+
{navbar}
|
|
121
|
+
</Navbar>
|
|
122
|
+
) : null}
|
|
123
|
+
<main className={clsx("flex-1 h-full w-full relative flex flex-col", className)}>
|
|
124
|
+
{children}
|
|
125
|
+
</main>
|
|
126
|
+
</div>
|
|
127
|
+
</div>
|
|
128
|
+
</SidebarContext.Provider>
|
|
129
|
+
</div>
|
|
130
|
+
</>
|
|
131
|
+
)
|
|
132
|
+
}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import clsx from 'clsx';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
|
|
4
|
+
interface FlexibleHeightLayoutProps {
|
|
5
|
+
children: (React.ReactElement | undefined | null) | (React.ReactElement | undefined | null)[];
|
|
6
|
+
className?: string;
|
|
7
|
+
}
|
|
8
|
+
export function FullHeightLayout({ className, children }: FlexibleHeightLayoutProps) {
|
|
9
|
+
return (
|
|
10
|
+
<div
|
|
11
|
+
className={clsx(
|
|
12
|
+
"flex flex-col",
|
|
13
|
+
"h-full",
|
|
14
|
+
"overflow-y-auto",
|
|
15
|
+
// "dark:bg-slate-900 text-slate-950 dark:text-slate-200",
|
|
16
|
+
className
|
|
17
|
+
)}
|
|
18
|
+
>
|
|
19
|
+
{children}
|
|
20
|
+
</div>
|
|
21
|
+
);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
interface FixedProps {
|
|
25
|
+
children: React.ReactNode;
|
|
26
|
+
heightClass: string;
|
|
27
|
+
className?: string;
|
|
28
|
+
}
|
|
29
|
+
FullHeightLayout.Fixed = function Fixed({ heightClass, className, children }: FixedProps) {
|
|
30
|
+
return (
|
|
31
|
+
<div
|
|
32
|
+
className={clsx(
|
|
33
|
+
"w-full",
|
|
34
|
+
heightClass,
|
|
35
|
+
className
|
|
36
|
+
)}
|
|
37
|
+
>
|
|
38
|
+
{children}
|
|
39
|
+
</div>
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
interface BodyProps {
|
|
44
|
+
children: React.ReactNode;
|
|
45
|
+
className?: string;
|
|
46
|
+
}
|
|
47
|
+
FullHeightLayout.Body = function Body({ className, children }: BodyProps) {
|
|
48
|
+
return (
|
|
49
|
+
<div
|
|
50
|
+
className={clsx(
|
|
51
|
+
"grow overflow-auto",
|
|
52
|
+
"min-h-0",
|
|
53
|
+
"p-4",
|
|
54
|
+
className
|
|
55
|
+
)}
|
|
56
|
+
>
|
|
57
|
+
{children}
|
|
58
|
+
</div>
|
|
59
|
+
);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
interface VDividerProps { }
|
|
63
|
+
FullHeightLayout.VR = function VDivider({ }: VDividerProps) {
|
|
64
|
+
return (
|
|
65
|
+
<div className="w-[1px] border border-red-200"></div>
|
|
66
|
+
);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
interface HDividerProps { }
|
|
70
|
+
FullHeightLayout.HR = function HDivider({ }: HDividerProps) {
|
|
71
|
+
return (
|
|
72
|
+
<div className="w-full h-1 border-b border-red-200"></div>
|
|
73
|
+
);
|
|
74
|
+
}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import React from 'react'
|
|
2
|
+
import { Menu, Search } from 'lucide-react'
|
|
3
|
+
import { Button, HeroIcon } from '@vertesia/ui/core'
|
|
4
|
+
import { useSidebarToggle } from './SidebarContext.js'
|
|
5
|
+
import { TitleBar } from './TitleBar.js'
|
|
6
|
+
|
|
7
|
+
interface NavbarProps {
|
|
8
|
+
title?: string
|
|
9
|
+
onSearch?: (query: string) => void
|
|
10
|
+
logo?: React.ReactNode
|
|
11
|
+
children: React.ReactNode | React.ReactNode[]
|
|
12
|
+
}
|
|
13
|
+
export function Navbar({ children, logo, onSearch, title }: NavbarProps) {
|
|
14
|
+
return (
|
|
15
|
+
<div className="sticky top-0 z-40 flex h-16 shrink-0 items-center gap-x-4 border-b px-4 shadow-2xs sm:gap-x-6 sm:px-6 lg:px-8">
|
|
16
|
+
<HamburgerButton />
|
|
17
|
+
|
|
18
|
+
<div className="lg:hidden">{logo}</div>
|
|
19
|
+
|
|
20
|
+
{/* Separator shown only if search is displayed in mobile */}
|
|
21
|
+
{onSearch && <NavbarSeparator visible='mobile' />}
|
|
22
|
+
|
|
23
|
+
<div className="flex flex-1 gap-x-4 self-stretch lg:gap-x-6">
|
|
24
|
+
<TitleBar title={title} />
|
|
25
|
+
{onSearch && <SearchBox onSearch={onSearch} />}
|
|
26
|
+
|
|
27
|
+
<div className="flex items-center gap-x-4 lg:gap-x-6 ml-auto">
|
|
28
|
+
{children}
|
|
29
|
+
</div>
|
|
30
|
+
</div>
|
|
31
|
+
</div>
|
|
32
|
+
|
|
33
|
+
)
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
interface SearchBoxProps {
|
|
38
|
+
onSearch?: (query: string) => void
|
|
39
|
+
}
|
|
40
|
+
function SearchBox({ }: SearchBoxProps) {
|
|
41
|
+
return (
|
|
42
|
+
<form className="relative flex flex-1" action="#" method="GET">
|
|
43
|
+
<label htmlFor="search-field" className="sr-only">
|
|
44
|
+
Search
|
|
45
|
+
</label>
|
|
46
|
+
<Search
|
|
47
|
+
className="pointer-events-none absolute inset-y-0 left-0 h-full w-5 text-gray-400"
|
|
48
|
+
aria-hidden="true"
|
|
49
|
+
/>
|
|
50
|
+
<input
|
|
51
|
+
id="search-field"
|
|
52
|
+
className="block h-full w-full border-0 py-0 pl-8 pr-0 text-gray-900 placeholder:text-gray-400 focus:ring-0 sm:text-sm"
|
|
53
|
+
placeholder="Search..."
|
|
54
|
+
type="search"
|
|
55
|
+
name="search"
|
|
56
|
+
/>
|
|
57
|
+
</form>
|
|
58
|
+
)
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
|
|
62
|
+
export function HamburgerButton() {
|
|
63
|
+
const { toggleDesktop, toggleMobile } = useSidebarToggle();
|
|
64
|
+
const toggle = () => {
|
|
65
|
+
if (window.innerWidth < 1024) {
|
|
66
|
+
toggleMobile();
|
|
67
|
+
} else {
|
|
68
|
+
toggleDesktop();
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
return (
|
|
72
|
+
<>
|
|
73
|
+
<Button variant='ghost' size='icon' onClick={() => toggle()} //alt='sidebar toggle'
|
|
74
|
+
className="p-2 rounded-full transition-colors w-full text-center ">
|
|
75
|
+
<Menu aria-hidden="true" size={24} />
|
|
76
|
+
</Button>
|
|
77
|
+
</>
|
|
78
|
+
)
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
|
|
82
|
+
interface NavbarSeparatorProps {
|
|
83
|
+
visible?: "mobile" | "desktop"
|
|
84
|
+
}
|
|
85
|
+
export function NavbarSeparator({ visible }: NavbarSeparatorProps) {
|
|
86
|
+
let visibility = "";
|
|
87
|
+
if (visible) {
|
|
88
|
+
visibility = visible === "mobile" ? "lg:hidden" : "hidden lg:block"
|
|
89
|
+
}
|
|
90
|
+
return (
|
|
91
|
+
<div className={`h-6 w-px bg-gray-900/10 dark:bg-slate-900/0.1 ${visibility}`} aria-hidden="true" />
|
|
92
|
+
)
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
interface NavbarIconButtonProps {
|
|
96
|
+
title: string,
|
|
97
|
+
icon: HeroIcon,
|
|
98
|
+
onClick?: (ev: React.MouseEvent<HTMLButtonElement, MouseEvent>) => void;
|
|
99
|
+
}
|
|
100
|
+
export function NavbarIconButton({ title, icon: Icon, onClick }: NavbarIconButtonProps) {
|
|
101
|
+
return (
|
|
102
|
+
<button type="button" className="-m-2.5 p-2.5 text-gray-400 dark:text-slate-50 hover:text-gray-500" onClick={onClick}>
|
|
103
|
+
<span className="sr-only">{title}</span>
|
|
104
|
+
<Icon className="size-6" aria-hidden="true" title={title} />
|
|
105
|
+
</button>
|
|
106
|
+
)
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
interface NavbarButtonProps {
|
|
110
|
+
children: React.ReactNode | React.ReactNode[]
|
|
111
|
+
onClick?: (ev: React.MouseEvent<HTMLButtonElement, MouseEvent>) => void;
|
|
112
|
+
}
|
|
113
|
+
export function NavbarButton({ children, onClick }: NavbarButtonProps) {
|
|
114
|
+
return (
|
|
115
|
+
<Button onClick={onClick}>{children}</Button>
|
|
116
|
+
)
|
|
117
|
+
}
|
|
118
|
+
interface NavbarLinkProps {
|
|
119
|
+
href: string
|
|
120
|
+
children: React.ReactNode | React.ReactNode[]
|
|
121
|
+
onClick?: (ev: React.MouseEvent<HTMLAnchorElement, MouseEvent>) => void;
|
|
122
|
+
}
|
|
123
|
+
export function NavbarLink({ href, onClick, children }: NavbarLinkProps) {
|
|
124
|
+
return (
|
|
125
|
+
<a className="dark:text-slate-50" href={href} onClick={onClick}>{children}</a>
|
|
126
|
+
)
|
|
127
|
+
}
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import clsx from 'clsx';
|
|
2
|
+
import { useSidebarToggle } from './SidebarContext';
|
|
3
|
+
import { Dot } from 'lucide-react';
|
|
4
|
+
import { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider } from '@vertesia/ui/core';
|
|
5
|
+
import { Nav } from "@vertesia/ui/router";
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
interface SidebarProps {
|
|
9
|
+
children: React.ReactNode | React.ReactNode[]
|
|
10
|
+
logo?: React.ReactNode
|
|
11
|
+
className?: string
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export function Sidebar({ children, logo, className }: SidebarProps) {
|
|
15
|
+
return (
|
|
16
|
+
<div className={clsx(className || "bg-indigo-600 dark:bg-indigo-950",
|
|
17
|
+
"flex flex-col h-full"
|
|
18
|
+
)}>
|
|
19
|
+
{logo &&
|
|
20
|
+
<div className="-mx-2 flex h-auto my-4 shrink-0 self-start">
|
|
21
|
+
{logo}
|
|
22
|
+
</div>
|
|
23
|
+
}
|
|
24
|
+
<div className="flex-1 min-h-0 overflow-hidden px-2">
|
|
25
|
+
<nav className="h-full flex flex-col">
|
|
26
|
+
<ul role="list" className="flex flex-col gap-y-2 overflow-y-auto h-full">
|
|
27
|
+
{children}
|
|
28
|
+
</ul>
|
|
29
|
+
</nav>
|
|
30
|
+
</div>
|
|
31
|
+
</div>
|
|
32
|
+
)
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
interface SidebarSectionProps {
|
|
36
|
+
children: React.ReactNode | React.ReactNode[]
|
|
37
|
+
title?: React.ReactNode
|
|
38
|
+
action?: React.ReactNode
|
|
39
|
+
isFooter?: boolean
|
|
40
|
+
}
|
|
41
|
+
export function SidebarSection({ children, title, action, isFooter = false }: SidebarSectionProps) {
|
|
42
|
+
const { isOpen } = useSidebarToggle();
|
|
43
|
+
|
|
44
|
+
let header = isOpen ? <>
|
|
45
|
+
{title || ""}
|
|
46
|
+
{action}
|
|
47
|
+
</> : <Dot className='size-6' />
|
|
48
|
+
|
|
49
|
+
return (
|
|
50
|
+
<li className={isFooter ? 'mt-auto' : ''}>
|
|
51
|
+
{title && <div className="text-xs font-medium h-8 flex items-center gap-x-2 px-2 text-sidebar-foreground/70">
|
|
52
|
+
{header}
|
|
53
|
+
</div>}
|
|
54
|
+
<ul data-sidebar="menu" className="flex w-full min-w-0 flex-col gap-1">
|
|
55
|
+
{children}
|
|
56
|
+
</ul>
|
|
57
|
+
</li>
|
|
58
|
+
)
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
export function SidebarTooltip({ children, text }: { children: React.ReactNode, text?: string }) {
|
|
62
|
+
const { isOpen } = useSidebarToggle();
|
|
63
|
+
return (
|
|
64
|
+
isOpen ? <>{children}</> :
|
|
65
|
+
<TooltipProvider>
|
|
66
|
+
<Tooltip>
|
|
67
|
+
<TooltipTrigger asChild>
|
|
68
|
+
{children}
|
|
69
|
+
</TooltipTrigger>
|
|
70
|
+
<TooltipContent side='right'>
|
|
71
|
+
{text}
|
|
72
|
+
</TooltipContent>
|
|
73
|
+
</Tooltip>
|
|
74
|
+
</TooltipProvider>
|
|
75
|
+
)
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
export interface SidebarItemProps {
|
|
79
|
+
href: string
|
|
80
|
+
icon?: React.ComponentType<React.HTMLAttributes<Element>>
|
|
81
|
+
current?: boolean
|
|
82
|
+
onClick?: (event: React.MouseEvent<HTMLAnchorElement, MouseEvent>) => void
|
|
83
|
+
children: React.ReactNode | React.ReactNode[]
|
|
84
|
+
tools?: React.ReactNode
|
|
85
|
+
className?: string;
|
|
86
|
+
id?: string; //HTML ID of the element
|
|
87
|
+
}
|
|
88
|
+
export function SidebarItem({ className, tools, children, icon: Icon, href, current, onClick }: SidebarItemProps) {
|
|
89
|
+
const { toggleMobile } = useSidebarToggle();
|
|
90
|
+
const _closeSideBar = () => {
|
|
91
|
+
setTimeout(() => {
|
|
92
|
+
toggleMobile(false)
|
|
93
|
+
}, 100);
|
|
94
|
+
}
|
|
95
|
+
return (
|
|
96
|
+
<li>
|
|
97
|
+
<Nav onClick={_closeSideBar}>
|
|
98
|
+
<SidebarTooltip text={children as string}>
|
|
99
|
+
<a
|
|
100
|
+
href={href}
|
|
101
|
+
onClick={onClick}
|
|
102
|
+
className={clsx(
|
|
103
|
+
current
|
|
104
|
+
? 'bg-sidebar-accent text-sidebar-accent-foreground'
|
|
105
|
+
: 'text-sidebar-foreground hover:text-sidebar-accent-foreground hover:bg-sidebar-accent',
|
|
106
|
+
'group flex gap-x-3 rounded-md px-2 py-1.5 text-sm items-center h-8',
|
|
107
|
+
className
|
|
108
|
+
)}
|
|
109
|
+
>
|
|
110
|
+
{Icon &&
|
|
111
|
+
<Icon
|
|
112
|
+
className={clsx(
|
|
113
|
+
current
|
|
114
|
+
? 'bg-sidebar-accent text-sidebar-accent-foreground'
|
|
115
|
+
: 'text-sidebar-foreground hover:text-sidebar-accent-foreground hover:bg-sidebar-accent',
|
|
116
|
+
'size-4 shrink-0'
|
|
117
|
+
)}
|
|
118
|
+
aria-hidden="true"
|
|
119
|
+
/>
|
|
120
|
+
}
|
|
121
|
+
{children}
|
|
122
|
+
{tools && <div className='flex items-center ml-auto'>{tools}</div>}
|
|
123
|
+
</a>
|
|
124
|
+
</SidebarTooltip>
|
|
125
|
+
</Nav>
|
|
126
|
+
</li>
|
|
127
|
+
|
|
128
|
+
)
|
|
129
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { createContext, useContext } from "react";
|
|
2
|
+
|
|
3
|
+
interface SidebarContextType {
|
|
4
|
+
isOpen: boolean;
|
|
5
|
+
toggleMobile: (isOpen?: boolean) => void;
|
|
6
|
+
toggleDesktop: (isOpen?: boolean) => void;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export const SidebarContext = createContext<SidebarContextType>({
|
|
10
|
+
isOpen: false,
|
|
11
|
+
toggleMobile: () => void 0,
|
|
12
|
+
toggleDesktop: () => void 0,
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
export function useSidebarToggle() {
|
|
16
|
+
return useContext(SidebarContext);
|
|
17
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { useEffect, useRef } from "react";
|
|
2
|
+
import { BASE_PATH } from "./HistoryNavigator";
|
|
3
|
+
|
|
4
|
+
interface FixLinksProps {
|
|
5
|
+
basePath: string;
|
|
6
|
+
children: React.ReactNode | React.ReactNode[];
|
|
7
|
+
}
|
|
8
|
+
export function FixLinks({ basePath, children }: FixLinksProps) {
|
|
9
|
+
const ref = useRef<HTMLDivElement>(null);
|
|
10
|
+
useEffect(() => {
|
|
11
|
+
if (ref.current) {
|
|
12
|
+
const divElem = ref.current;
|
|
13
|
+
const listener = (ev: MouseEvent) => {
|
|
14
|
+
const elem = ev.target as HTMLElement;
|
|
15
|
+
if (elem.tagName.toLowerCase() === 'a') {
|
|
16
|
+
(ev as any)[BASE_PATH] = basePath;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
divElem.addEventListener('click', listener);
|
|
20
|
+
return () => {
|
|
21
|
+
divElem.removeEventListener('click', listener);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}, [ref.current]);
|
|
25
|
+
return (
|
|
26
|
+
<div ref={ref} className="h-full w-full">{children}</div>
|
|
27
|
+
)
|
|
28
|
+
}
|