@lumeweb/portal-framework-ui 0.0.1 → 0.1.1
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/LICENSE +9 -0
- package/README.md +1 -45
- package/dist/esm/components/Copyable.d.ts +43 -0
- package/dist/esm/components/Copyable.js +50 -0
- package/dist/esm/components/Copyable.js.map +1 -0
- package/dist/esm/components/FilterChip.d.ts +16 -0
- package/dist/esm/components/FilterChip.js +47 -0
- package/dist/esm/components/FilterChip.js.map +1 -0
- package/dist/esm/components/Forms.d.ts +55 -0
- package/dist/esm/components/Forms.js +123 -0
- package/dist/esm/components/Forms.js.map +1 -0
- package/dist/esm/components/InlineAuthLinkBanner.d.ts +18 -0
- package/dist/esm/components/InlineAuthLinkBanner.js +23 -0
- package/dist/esm/components/InlineAuthLinkBanner.js.map +1 -0
- package/dist/esm/components/KeyboardShortcutDialog.d.ts +12 -0
- package/dist/esm/components/KeyboardShortcutDialog.js +48 -0
- package/dist/esm/components/KeyboardShortcutDialog.js.map +1 -0
- package/dist/esm/components/Loading.d.ts +13 -0
- package/dist/esm/components/Loading.js +38 -0
- package/dist/esm/components/Loading.js.map +1 -0
- package/dist/esm/components/LumeLogo.d.ts +12 -0
- package/dist/esm/components/LumeLogo.js +22 -0
- package/dist/esm/components/LumeLogo.js.map +1 -0
- package/dist/esm/components/MainNavigation.d.ts +11 -0
- package/dist/esm/components/MainNavigation.js +227 -0
- package/dist/esm/components/MainNavigation.js.map +1 -0
- package/dist/esm/components/SkeletonLoader.d.ts +25 -0
- package/dist/esm/components/SkeletonLoader.js +78 -0
- package/dist/esm/components/SkeletonLoader.js.map +1 -0
- package/dist/esm/components/TableActionsDropdown.d.ts +18 -0
- package/dist/esm/components/TableActionsDropdown.js +34 -0
- package/dist/esm/components/TableActionsDropdown.js.map +1 -0
- package/dist/esm/components/TableContainer.d.ts +13 -0
- package/dist/esm/components/TableContainer.js +15 -0
- package/dist/esm/components/TableContainer.js.map +1 -0
- package/dist/esm/components/ThemeSwitcher.d.ts +7 -0
- package/dist/esm/components/ThemeSwitcher.js +38 -0
- package/dist/esm/components/ThemeSwitcher.js.map +1 -0
- package/dist/esm/components/ThemedBadge.d.ts +23 -0
- package/dist/esm/components/ThemedBadge.js +20 -0
- package/dist/esm/components/ThemedBadge.js.map +1 -0
- package/dist/esm/components/actions/ActionListRenderer.d.ts +15 -0
- package/dist/esm/components/actions/ActionListRenderer.js +38 -0
- package/dist/esm/components/actions/ActionListRenderer.js.map +1 -0
- package/dist/esm/components/actions/actionHelpers.d.ts +127 -0
- package/dist/esm/components/actions/actionHelpers.js +205 -0
- package/dist/esm/components/actions/actionHelpers.js.map +1 -0
- package/dist/esm/components/actions/index.d.ts +6 -0
- package/dist/esm/components/actions/index.js +7 -0
- package/dist/esm/components/actions/items/ButtonActionItem.d.ts +9 -0
- package/dist/esm/components/actions/items/ButtonActionItem.js +23 -0
- package/dist/esm/components/actions/items/ButtonActionItem.js.map +1 -0
- package/dist/esm/components/actions/items/CancelActionItem.d.ts +9 -0
- package/dist/esm/components/actions/items/CancelActionItem.js +28 -0
- package/dist/esm/components/actions/items/CancelActionItem.js.map +1 -0
- package/dist/esm/components/actions/items/CustomActionItem.d.ts +9 -0
- package/dist/esm/components/actions/items/CustomActionItem.js +27 -0
- package/dist/esm/components/actions/items/CustomActionItem.js.map +1 -0
- package/dist/esm/components/actions/items/LinkActionItem.d.ts +9 -0
- package/dist/esm/components/actions/items/LinkActionItem.js +33 -0
- package/dist/esm/components/actions/items/LinkActionItem.js.map +1 -0
- package/dist/esm/components/actions/items/RetryActionItem.d.ts +9 -0
- package/dist/esm/components/actions/items/RetryActionItem.js +23 -0
- package/dist/esm/components/actions/items/RetryActionItem.js.map +1 -0
- package/dist/esm/components/actions/items/SubmitActionItem.d.ts +9 -0
- package/dist/esm/components/actions/items/SubmitActionItem.js +26 -0
- package/dist/esm/components/actions/items/SubmitActionItem.js.map +1 -0
- package/dist/esm/components/actions/register.d.ts +5 -0
- package/dist/esm/components/actions/register.js +20 -0
- package/dist/esm/components/actions/register.js.map +1 -0
- package/dist/esm/components/actions/registry.d.ts +14 -0
- package/dist/esm/components/actions/registry.js +20 -0
- package/dist/esm/components/actions/registry.js.map +1 -0
- package/dist/esm/components/actions/types.d.ts +132 -0
- package/dist/esm/components/actions/types.js +29 -0
- package/dist/esm/components/actions/types.js.map +1 -0
- package/dist/esm/components/app/AppComponent.d.ts +17 -0
- package/dist/esm/components/app/AppComponent.js +179 -0
- package/dist/esm/components/app/AppComponent.js.map +1 -0
- package/dist/esm/components/data-table/BaseTable.d.ts +86 -0
- package/dist/esm/components/data-table/BaseTable.js +123 -0
- package/dist/esm/components/data-table/BaseTable.js.map +1 -0
- package/dist/esm/components/data-table/BaseTableContent.d.ts +48 -0
- package/dist/esm/components/data-table/BaseTableContent.js +38 -0
- package/dist/esm/components/data-table/BaseTableContent.js.map +1 -0
- package/dist/esm/components/data-table/BaseTableInner.d.ts +11 -0
- package/dist/esm/components/data-table/BaseTableInner.js +35 -0
- package/dist/esm/components/data-table/BaseTableInner.js.map +1 -0
- package/dist/esm/components/data-table/BaseTableStackedLayout.d.ts +31 -0
- package/dist/esm/components/data-table/BaseTableStackedLayout.js +137 -0
- package/dist/esm/components/data-table/BaseTableStackedLayout.js.map +1 -0
- package/dist/esm/components/data-table/DataTable.d.ts +18 -0
- package/dist/esm/components/data-table/DataTable.js +97 -0
- package/dist/esm/components/data-table/DataTable.js.map +1 -0
- package/dist/esm/components/data-table/DataTable.types.d.ts +203 -0
- package/dist/esm/components/data-table/DataTable.types.js +25 -0
- package/dist/esm/components/data-table/DataTable.types.js.map +1 -0
- package/dist/esm/components/data-table/DataTableController.d.ts +19 -0
- package/dist/esm/components/data-table/DataTableController.js +31 -0
- package/dist/esm/components/data-table/DataTableController.js.map +1 -0
- package/dist/esm/components/data-table/DefaultPagination.d.ts +7 -0
- package/dist/esm/components/data-table/DefaultPagination.js +62 -0
- package/dist/esm/components/data-table/DefaultPagination.js.map +1 -0
- package/dist/esm/components/data-table/DefaultTableLayout.d.ts +28 -0
- package/dist/esm/components/data-table/DefaultTableLayout.js +70 -0
- package/dist/esm/components/data-table/DefaultTableLayout.js.map +1 -0
- package/dist/esm/components/data-table/EmptyState.d.ts +19 -0
- package/dist/esm/components/data-table/EmptyState.js +16 -0
- package/dist/esm/components/data-table/EmptyState.js.map +1 -0
- package/dist/esm/components/data-table/LoadingState.d.ts +19 -0
- package/dist/esm/components/data-table/LoadingState.js +34 -0
- package/dist/esm/components/data-table/LoadingState.js.map +1 -0
- package/dist/esm/components/data-table/TableAction.d.ts +21 -0
- package/dist/esm/components/data-table/TableAction.js +26 -0
- package/dist/esm/components/data-table/TableAction.js.map +1 -0
- package/dist/esm/components/data-table/TableActionMenu.d.ts +20 -0
- package/dist/esm/components/data-table/TableActionMenu.js +31 -0
- package/dist/esm/components/data-table/TableActionMenu.js.map +1 -0
- package/dist/esm/components/data-table/TableLayoutRenderer.d.ts +48 -0
- package/dist/esm/components/data-table/TableLayoutRenderer.js +45 -0
- package/dist/esm/components/data-table/TableLayoutRenderer.js.map +1 -0
- package/dist/esm/components/data-table/Toolbar.d.ts +17 -0
- package/dist/esm/components/data-table/Toolbar.js +176 -0
- package/dist/esm/components/data-table/Toolbar.js.map +1 -0
- package/dist/esm/components/data-table/ToolbarRegistry.d.ts +66 -0
- package/dist/esm/components/data-table/ToolbarRegistry.js +89 -0
- package/dist/esm/components/data-table/ToolbarRegistry.js.map +1 -0
- package/dist/esm/components/data-table/ToolbarRenderer.d.ts +45 -0
- package/dist/esm/components/data-table/ToolbarRenderer.js +137 -0
- package/dist/esm/components/data-table/ToolbarRenderer.js.map +1 -0
- package/dist/esm/components/data-table/contexts/FilterHelpers.d.ts +30 -0
- package/dist/esm/components/data-table/contexts/FilterHelpers.js +60 -0
- package/dist/esm/components/data-table/contexts/FilterHelpers.js.map +1 -0
- package/dist/esm/components/data-table/contexts/RefineTable.d.ts +25 -0
- package/dist/esm/components/data-table/contexts/RefineTable.js +69 -0
- package/dist/esm/components/data-table/contexts/RefineTable.js.map +1 -0
- package/dist/esm/components/data-table/contexts/TableConfig.d.ts +24 -0
- package/dist/esm/components/data-table/contexts/TableConfig.js +29 -0
- package/dist/esm/components/data-table/contexts/TableConfig.js.map +1 -0
- package/dist/esm/components/data-table/contexts/TableInstance.d.ts +20 -0
- package/dist/esm/components/data-table/contexts/TableInstance.js +21 -0
- package/dist/esm/components/data-table/contexts/TableInstance.js.map +1 -0
- package/dist/esm/components/data-table/contexts/index.d.ts +5 -0
- package/dist/esm/components/data-table/contexts/index.js +6 -0
- package/dist/esm/components/data-table/filterColumnsForMobile.d.ts +16 -0
- package/dist/esm/components/data-table/filterColumnsForMobile.js +31 -0
- package/dist/esm/components/data-table/filterColumnsForMobile.js.map +1 -0
- package/dist/esm/components/data-table/index.d.ts +50 -0
- package/dist/esm/components/data-table/index.js +39 -0
- package/dist/esm/components/data-table/register.d.ts +1 -0
- package/dist/esm/components/data-table/register.js +1 -0
- package/dist/esm/components/data-table/tableOptions.d.ts +18 -0
- package/dist/esm/components/data-table/tableOptions.js +40 -0
- package/dist/esm/components/data-table/tableOptions.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/FilterGroup.d.ts +18 -0
- package/dist/esm/components/data-table/toolbarItems/FilterGroup.js +105 -0
- package/dist/esm/components/data-table/toolbarItems/FilterGroup.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/FilterResolver.d.ts +22 -0
- package/dist/esm/components/data-table/toolbarItems/FilterResolver.js +74 -0
- package/dist/esm/components/data-table/toolbarItems/FilterResolver.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/BaseFilter.d.ts +27 -0
- package/dist/esm/components/data-table/toolbarItems/filters/BaseFilter.js +29 -0
- package/dist/esm/components/data-table/toolbarItems/filters/BaseFilter.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/FilterRegistry.d.ts +52 -0
- package/dist/esm/components/data-table/toolbarItems/filters/FilterRegistry.js +57 -0
- package/dist/esm/components/data-table/toolbarItems/filters/FilterRegistry.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/BooleanFilter.d.ts +12 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/BooleanFilter.js +34 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/BooleanFilter.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/DateFilter.d.ts +12 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/DateFilter.js +25 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/DateFilter.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/MultiSelectFilter.d.ts +13 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/MultiSelectFilter.js +44 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/MultiSelectFilter.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/NumberFilter.d.ts +12 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/NumberFilter.js +29 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/NumberFilter.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/RangeFilter.d.ts +16 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/RangeFilter.js +61 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/RangeFilter.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/SearchFilter.d.ts +12 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/SearchFilter.js +33 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/SearchFilter.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/SelectFilter.d.ts +13 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/SelectFilter.js +95 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/SelectFilter.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/TextFilter.d.ts +12 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/TextFilter.js +25 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/TextFilter.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/index.d.ts +9 -0
- package/dist/esm/components/data-table/toolbarItems/filters/components/index.js +10 -0
- package/dist/esm/components/data-table/toolbarItems/filters/hooks/useFilterOperators.d.ts +43 -0
- package/dist/esm/components/data-table/toolbarItems/filters/hooks/useFilterOperators.js +102 -0
- package/dist/esm/components/data-table/toolbarItems/filters/hooks/useFilterOperators.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/hooks/useFilterTooltip.d.ts +19 -0
- package/dist/esm/components/data-table/toolbarItems/filters/hooks/useFilterTooltip.js +34 -0
- package/dist/esm/components/data-table/toolbarItems/filters/hooks/useFilterTooltip.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/index.d.ts +11 -0
- package/dist/esm/components/data-table/toolbarItems/filters/index.js +13 -0
- package/dist/esm/components/data-table/toolbarItems/filters/register.d.ts +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/register.js +8 -0
- package/dist/esm/components/data-table/toolbarItems/filters/types.d.ts +140 -0
- package/dist/esm/components/data-table/toolbarItems/filters/types.js +58 -0
- package/dist/esm/components/data-table/toolbarItems/filters/types.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/filters/util.d.ts +24 -0
- package/dist/esm/components/data-table/toolbarItems/filters/util.js +43 -0
- package/dist/esm/components/data-table/toolbarItems/filters/util.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/index.d.ts +17 -0
- package/dist/esm/components/data-table/toolbarItems/index.js +18 -0
- package/dist/esm/components/data-table/toolbarItems/items/custom.d.ts +15 -0
- package/dist/esm/components/data-table/toolbarItems/items/custom.js +19 -0
- package/dist/esm/components/data-table/toolbarItems/items/custom.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/items/index.d.ts +6 -0
- package/dist/esm/components/data-table/toolbarItems/items/index.js +6 -0
- package/dist/esm/components/data-table/toolbarItems/items/refresh.d.ts +7 -0
- package/dist/esm/components/data-table/toolbarItems/items/refresh.js +36 -0
- package/dist/esm/components/data-table/toolbarItems/items/refresh.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/items/search.d.ts +7 -0
- package/dist/esm/components/data-table/toolbarItems/items/search.js +66 -0
- package/dist/esm/components/data-table/toolbarItems/items/search.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/items/separator.d.ts +16 -0
- package/dist/esm/components/data-table/toolbarItems/items/separator.js +20 -0
- package/dist/esm/components/data-table/toolbarItems/items/separator.js.map +1 -0
- package/dist/esm/components/data-table/toolbarItems/register.d.ts +24 -0
- package/dist/esm/components/data-table/toolbarItems/register.js +119 -0
- package/dist/esm/components/data-table/toolbarItems/register.js.map +1 -0
- package/dist/esm/components/data-table/useMobileDetection.d.ts +18 -0
- package/dist/esm/components/data-table/useMobileDetection.js +32 -0
- package/dist/esm/components/data-table/useMobileDetection.js.map +1 -0
- package/dist/esm/components/data-table/useTableHandlers.d.ts +57 -0
- package/dist/esm/components/data-table/useTableHandlers.js +69 -0
- package/dist/esm/components/data-table/useTableHandlers.js.map +1 -0
- package/dist/esm/components/data-table/useTableLayoutSelector.d.ts +16 -0
- package/dist/esm/components/data-table/useTableLayoutSelector.js +12 -0
- package/dist/esm/components/data-table/useTableLayoutSelector.js.map +1 -0
- package/dist/esm/components/dialog/Dialog.context.d.ts +18 -0
- package/dist/esm/components/dialog/Dialog.context.js +80 -0
- package/dist/esm/components/dialog/Dialog.context.js.map +1 -0
- package/dist/esm/components/dialog/Dialog.registry.d.ts +22 -0
- package/dist/esm/components/dialog/Dialog.registry.js +24 -0
- package/dist/esm/components/dialog/Dialog.registry.js.map +1 -0
- package/dist/esm/components/dialog/Dialog.renderer.d.ts +9 -0
- package/dist/esm/components/dialog/Dialog.renderer.js +63 -0
- package/dist/esm/components/dialog/Dialog.renderer.js.map +1 -0
- package/dist/esm/components/dialog/Dialog.types.d.ts +273 -0
- package/dist/esm/components/dialog/Dialog.types.js +233 -0
- package/dist/esm/components/dialog/Dialog.types.js.map +1 -0
- package/dist/esm/components/dialog/DialogActions.context.d.ts +13 -0
- package/dist/esm/components/dialog/DialogActions.context.js +13 -0
- package/dist/esm/components/dialog/DialogActions.context.js.map +1 -0
- package/dist/esm/components/dialog/DialogContainer.d.ts +15 -0
- package/dist/esm/components/dialog/DialogContainer.js +37 -0
- package/dist/esm/components/dialog/DialogContainer.js.map +1 -0
- package/dist/esm/components/dialog/DialogContent.d.ts +14 -0
- package/dist/esm/components/dialog/DialogContent.js +18 -0
- package/dist/esm/components/dialog/DialogContent.js.map +1 -0
- package/dist/esm/components/dialog/DialogFooterContent.d.ts +14 -0
- package/dist/esm/components/dialog/DialogFooterContent.js +20 -0
- package/dist/esm/components/dialog/DialogFooterContent.js.map +1 -0
- package/dist/esm/components/dialog/DialogHeaderContent.d.ts +12 -0
- package/dist/esm/components/dialog/DialogHeaderContent.js +24 -0
- package/dist/esm/components/dialog/DialogHeaderContent.js.map +1 -0
- package/dist/esm/components/dialog/DialogState.context.d.ts +11 -0
- package/dist/esm/components/dialog/DialogState.context.js +11 -0
- package/dist/esm/components/dialog/DialogState.context.js.map +1 -0
- package/dist/esm/components/dialog/index.d.ts +6 -0
- package/dist/esm/components/dialog/index.js +8 -0
- package/dist/esm/components/dialog/types/AlertDialog.d.ts +19 -0
- package/dist/esm/components/dialog/types/AlertDialog.js +29 -0
- package/dist/esm/components/dialog/types/AlertDialog.js.map +1 -0
- package/dist/esm/components/dialog/types/ConfirmDialog.d.ts +17 -0
- package/dist/esm/components/dialog/types/ConfirmDialog.js +24 -0
- package/dist/esm/components/dialog/types/ConfirmDialog.js.map +1 -0
- package/dist/esm/components/dialog/types/CustomDialog.d.ts +28 -0
- package/dist/esm/components/dialog/types/CustomDialog.js +17 -0
- package/dist/esm/components/dialog/types/CustomDialog.js.map +1 -0
- package/dist/esm/components/dialog/types/FormDialog.d.ts +22 -0
- package/dist/esm/components/dialog/types/FormDialog.js +46 -0
- package/dist/esm/components/dialog/types/FormDialog.js.map +1 -0
- package/dist/esm/components/dialog/types/WizardDialog.d.ts +29 -0
- package/dist/esm/components/dialog/types/WizardDialog.js +43 -0
- package/dist/esm/components/dialog/types/WizardDialog.js.map +1 -0
- package/dist/esm/components/dialog/utils/dialogClasses.d.ts +7 -0
- package/dist/esm/components/dialog/utils/dialogClasses.js +14 -0
- package/dist/esm/components/dialog/utils/dialogClasses.js.map +1 -0
- package/dist/esm/components/dialog/utils/dialogDetection.d.ts +32 -0
- package/dist/esm/components/dialog/utils/dialogDetection.js +47 -0
- package/dist/esm/components/dialog/utils/dialogDetection.js.map +1 -0
- package/dist/esm/components/dialog/utils/index.d.ts +3 -0
- package/dist/esm/components/dialog/utils/index.js +4 -0
- package/dist/esm/components/editor/BlockTypeDropdown.d.ts +12 -0
- package/dist/esm/components/editor/BlockTypeDropdown.js +57 -0
- package/dist/esm/components/editor/BlockTypeDropdown.js.map +1 -0
- package/dist/esm/components/editor/Editor.d.ts +7 -0
- package/dist/esm/components/editor/Editor.js +17 -0
- package/dist/esm/components/editor/Editor.js.map +1 -0
- package/dist/esm/components/editor/EditorInner.d.ts +14 -0
- package/dist/esm/components/editor/EditorInner.js +107 -0
- package/dist/esm/components/editor/EditorInner.js.map +1 -0
- package/dist/esm/components/editor/Preview.d.ts +5 -0
- package/dist/esm/components/editor/Preview.js +18 -0
- package/dist/esm/components/editor/Preview.js.map +1 -0
- package/dist/esm/components/editor/ToolbarContext.d.ts +39 -0
- package/dist/esm/components/editor/ToolbarContext.js +54 -0
- package/dist/esm/components/editor/ToolbarContext.js.map +1 -0
- package/dist/esm/components/editor/ToolbarPlugin.d.ts +20 -0
- package/dist/esm/components/editor/ToolbarPlugin.js +194 -0
- package/dist/esm/components/editor/ToolbarPlugin.js.map +1 -0
- package/dist/esm/components/editor/formatting.d.ts +15 -0
- package/dist/esm/components/editor/formatting.js +117 -0
- package/dist/esm/components/editor/formatting.js.map +1 -0
- package/dist/esm/components/editor/index.d.ts +3 -0
- package/dist/esm/components/editor/index.js +3 -0
- package/dist/esm/components/form/FormGroup.d.ts +18 -0
- package/dist/esm/components/form/FormGroup.js +28 -0
- package/dist/esm/components/form/FormGroup.js.map +1 -0
- package/dist/esm/components/form/FormRenderer.d.ts +14 -0
- package/dist/esm/components/form/FormRenderer.js +179 -0
- package/dist/esm/components/form/FormRenderer.js.map +1 -0
- package/dist/esm/components/form/SchemaForm.d.ts +18 -0
- package/dist/esm/components/form/SchemaForm.js +172 -0
- package/dist/esm/components/form/SchemaForm.js.map +1 -0
- package/dist/esm/components/form/StepControlContext.d.ts +199 -0
- package/dist/esm/components/form/StepControlContext.js +249 -0
- package/dist/esm/components/form/StepControlContext.js.map +1 -0
- package/dist/esm/components/form/StepSchemaForm.d.ts +22 -0
- package/dist/esm/components/form/StepSchemaForm.js +176 -0
- package/dist/esm/components/form/StepSchemaForm.js.map +1 -0
- package/dist/esm/components/form/WizardForm.d.ts +16 -0
- package/dist/esm/components/form/WizardForm.js +126 -0
- package/dist/esm/components/form/WizardForm.js.map +1 -0
- package/dist/esm/components/form/WizardStepContent.d.ts +26 -0
- package/dist/esm/components/form/WizardStepContent.js +46 -0
- package/dist/esm/components/form/WizardStepContent.js.map +1 -0
- package/dist/esm/components/form/__mocks__/@hookform/resolvers/zod.d.ts +8 -0
- package/dist/esm/components/form/adapters.d.ts +23 -0
- package/dist/esm/components/form/adapters.js +43 -0
- package/dist/esm/components/form/adapters.js.map +1 -0
- package/dist/esm/components/form/autocomplete/index.d.ts +3 -0
- package/dist/esm/components/form/autocomplete/index.js +4 -0
- package/dist/esm/components/form/autocomplete/register.d.ts +8 -0
- package/dist/esm/components/form/autocomplete/register.js +161 -0
- package/dist/esm/components/form/autocomplete/register.js.map +1 -0
- package/dist/esm/components/form/autocomplete/rules.d.ts +15 -0
- package/dist/esm/components/form/autocomplete/rules.js +198 -0
- package/dist/esm/components/form/autocomplete/rules.js.map +1 -0
- package/dist/esm/components/form/context.d.ts +29 -0
- package/dist/esm/components/form/context.js +25 -0
- package/dist/esm/components/form/context.js.map +1 -0
- package/dist/esm/components/form/fields/Checkbox.d.ts +6 -0
- package/dist/esm/components/form/fields/Checkbox.js +33 -0
- package/dist/esm/components/form/fields/Checkbox.js.map +1 -0
- package/dist/esm/components/form/fields/DatePicker.d.ts +6 -0
- package/dist/esm/components/form/fields/DatePicker.js +29 -0
- package/dist/esm/components/form/fields/DatePicker.js.map +1 -0
- package/dist/esm/components/form/fields/EmailInput.d.ts +6 -0
- package/dist/esm/components/form/fields/EmailInput.js +25 -0
- package/dist/esm/components/form/fields/EmailInput.js.map +1 -0
- package/dist/esm/components/form/fields/FileInput.d.ts +6 -0
- package/dist/esm/components/form/fields/FileInput.js +28 -0
- package/dist/esm/components/form/fields/FileInput.js.map +1 -0
- package/dist/esm/components/form/fields/Input.d.ts +6 -0
- package/dist/esm/components/form/fields/Input.js +30 -0
- package/dist/esm/components/form/fields/Input.js.map +1 -0
- package/dist/esm/components/form/fields/RadioGroup.d.ts +6 -0
- package/dist/esm/components/form/fields/RadioGroup.js +42 -0
- package/dist/esm/components/form/fields/RadioGroup.js.map +1 -0
- package/dist/esm/components/form/fields/RichText.d.ts +6 -0
- package/dist/esm/components/form/fields/RichText.js +30 -0
- package/dist/esm/components/form/fields/RichText.js.map +1 -0
- package/dist/esm/components/form/fields/Select.d.ts +6 -0
- package/dist/esm/components/form/fields/Select.js +37 -0
- package/dist/esm/components/form/fields/Select.js.map +1 -0
- package/dist/esm/components/form/fields/Slider.d.ts +6 -0
- package/dist/esm/components/form/fields/Slider.js +29 -0
- package/dist/esm/components/form/fields/Slider.js.map +1 -0
- package/dist/esm/components/form/fields/Switch.d.ts +6 -0
- package/dist/esm/components/form/fields/Switch.js +33 -0
- package/dist/esm/components/form/fields/Switch.js.map +1 -0
- package/dist/esm/components/form/fields/Textarea.d.ts +6 -0
- package/dist/esm/components/form/fields/Textarea.js +28 -0
- package/dist/esm/components/form/fields/Textarea.js.map +1 -0
- package/dist/esm/components/form/fields/index.d.ts +13 -0
- package/dist/esm/components/form/fields/index.js +14 -0
- package/dist/esm/components/form/fields/registry.d.ts +11 -0
- package/dist/esm/components/form/fields/registry.js +15 -0
- package/dist/esm/components/form/fields/registry.js.map +1 -0
- package/dist/esm/components/form/fields/types.d.ts +37 -0
- package/dist/esm/components/form/fields/types.js +21 -0
- package/dist/esm/components/form/fields/types.js.map +1 -0
- package/dist/esm/components/form/handlers/core.d.ts +19 -0
- package/dist/esm/components/form/handlers/core.js +51 -0
- package/dist/esm/components/form/handlers/core.js.map +1 -0
- package/dist/esm/components/form/handlers/step.d.ts +19 -0
- package/dist/esm/components/form/handlers/step.js +40 -0
- package/dist/esm/components/form/handlers/step.js.map +1 -0
- package/dist/esm/components/form/index.d.ts +26 -0
- package/dist/esm/components/form/index.js +28 -0
- package/dist/esm/components/form/register.d.ts +5 -0
- package/dist/esm/components/form/register.js +31 -0
- package/dist/esm/components/form/register.js.map +1 -0
- package/dist/esm/components/form/types.d.ts +521 -0
- package/dist/esm/components/form/types.js +69 -0
- package/dist/esm/components/form/types.js.map +1 -0
- package/dist/esm/components/form/utils/animationUtils.d.ts +14 -0
- package/dist/esm/components/form/utils/animationUtils.js +20 -0
- package/dist/esm/components/form/utils/animationUtils.js.map +1 -0
- package/dist/esm/components/form/utils/autoSave.d.ts +8 -0
- package/dist/esm/components/form/utils/autoSave.js +17 -0
- package/dist/esm/components/form/utils/autoSave.js.map +1 -0
- package/dist/esm/components/form/utils/index.d.ts +4 -0
- package/dist/esm/components/form/utils/index.js +5 -0
- package/dist/esm/components/form/utils/stepRetry.d.ts +12 -0
- package/dist/esm/components/form/utils/stepRetry.js +16 -0
- package/dist/esm/components/form/utils/stepRetry.js.map +1 -0
- package/dist/esm/components/index.d.ts +126 -0
- package/dist/esm/components/index.js +130 -0
- package/dist/esm/components/layout/DesktopSidebar.d.ts +5 -0
- package/dist/esm/components/layout/DesktopSidebar.js +51 -0
- package/dist/esm/components/layout/DesktopSidebar.js.map +1 -0
- package/dist/esm/components/layout/GeneralLayout.d.ts +5 -0
- package/dist/esm/components/layout/GeneralLayout.js +34 -0
- package/dist/esm/components/layout/GeneralLayout.js.map +1 -0
- package/dist/esm/components/layout/MobileMenu.d.ts +5 -0
- package/dist/esm/components/layout/MobileMenu.js +48 -0
- package/dist/esm/components/layout/MobileMenu.js.map +1 -0
- package/dist/esm/components/layout/PageHeader.d.ts +16 -0
- package/dist/esm/components/layout/PageHeader.js +20 -0
- package/dist/esm/components/layout/PageHeader.js.map +1 -0
- package/dist/esm/components/layout/SidebarContext.d.ts +10 -0
- package/dist/esm/components/layout/SidebarContext.js +27 -0
- package/dist/esm/components/layout/SidebarContext.js.map +1 -0
- package/dist/esm/components/layout/SidebarToggle.d.ts +12 -0
- package/dist/esm/components/layout/SidebarToggle.js +23 -0
- package/dist/esm/components/layout/SidebarToggle.js.map +1 -0
- package/dist/esm/components/layout/UserNav.d.ts +5 -0
- package/dist/esm/components/layout/UserNav.js +110 -0
- package/dist/esm/components/layout/UserNav.js.map +1 -0
- package/dist/esm/components/layout/index.d.ts +7 -0
- package/dist/esm/components/layout/index.js +9 -0
- package/dist/esm/components/screen-reader/ScreenReaderAnnouncement.d.ts +23 -0
- package/dist/esm/components/screen-reader/ScreenReaderAnnouncement.js +28 -0
- package/dist/esm/components/screen-reader/ScreenReaderAnnouncement.js.map +1 -0
- package/dist/esm/components/screen-reader/hooks/useScreenReaderAnnouncement.d.ts +10 -0
- package/dist/esm/components/screen-reader/hooks/useScreenReaderAnnouncement.js +30 -0
- package/dist/esm/components/screen-reader/hooks/useScreenReaderAnnouncement.js.map +1 -0
- package/dist/esm/components/shared/UnifiedFooter.d.ts +17 -0
- package/dist/esm/components/shared/UnifiedFooter.js +210 -0
- package/dist/esm/components/shared/UnifiedFooter.js.map +1 -0
- package/dist/esm/components/shared/UnifiedHeader.d.ts +17 -0
- package/dist/esm/components/shared/UnifiedHeader.js +48 -0
- package/dist/esm/components/shared/UnifiedHeader.js.map +1 -0
- package/dist/esm/components/shared/context/FooterContext.d.ts +18 -0
- package/dist/esm/components/shared/context/FooterContext.js +24 -0
- package/dist/esm/components/shared/context/FooterContext.js.map +1 -0
- package/dist/esm/components/shared/context/HeaderContext.d.ts +18 -0
- package/dist/esm/components/shared/context/HeaderContext.js +23 -0
- package/dist/esm/components/shared/context/HeaderContext.js.map +1 -0
- package/dist/esm/components/shared/context/index.d.ts +3 -0
- package/dist/esm/components/shared/context/index.js +4 -0
- package/dist/esm/components/shared/environment/builders.d.ts +95 -0
- package/dist/esm/components/shared/environment/builders.js +163 -0
- package/dist/esm/components/shared/environment/builders.js.map +1 -0
- package/dist/esm/components/shared/environment/index.d.ts +7 -0
- package/dist/esm/components/shared/environment/index.js +3 -0
- package/dist/esm/components/shared/footers/ActionsFooter.d.ts +11 -0
- package/dist/esm/components/shared/footers/ActionsFooter.js +19 -0
- package/dist/esm/components/shared/footers/ActionsFooter.js.map +1 -0
- package/dist/esm/components/shared/footers/DefaultFooter.d.ts +13 -0
- package/dist/esm/components/shared/footers/DefaultFooter.js +20 -0
- package/dist/esm/components/shared/footers/DefaultFooter.js.map +1 -0
- package/dist/esm/components/shared/footers/FormFooter.d.ts +15 -0
- package/dist/esm/components/shared/footers/FormFooter.js +28 -0
- package/dist/esm/components/shared/footers/FormFooter.js.map +1 -0
- package/dist/esm/components/shared/footers/StepFormFooter.d.ts +15 -0
- package/dist/esm/components/shared/footers/StepFormFooter.js +28 -0
- package/dist/esm/components/shared/footers/StepFormFooter.js.map +1 -0
- package/dist/esm/components/shared/footers/WizardFooter.d.ts +12 -0
- package/dist/esm/components/shared/footers/WizardFooter.js +72 -0
- package/dist/esm/components/shared/footers/WizardFooter.js.map +1 -0
- package/dist/esm/components/shared/footers/index.d.ts +6 -0
- package/dist/esm/components/shared/footers/index.js +7 -0
- package/dist/esm/components/shared/headers/DefaultHeader.d.ts +13 -0
- package/dist/esm/components/shared/headers/DefaultHeader.js +30 -0
- package/dist/esm/components/shared/headers/DefaultHeader.js.map +1 -0
- package/dist/esm/components/shared/headers/FormHeader.d.ts +12 -0
- package/dist/esm/components/shared/headers/FormHeader.js +31 -0
- package/dist/esm/components/shared/headers/FormHeader.js.map +1 -0
- package/dist/esm/components/shared/headers/WizardHeader.d.ts +9 -0
- package/dist/esm/components/shared/headers/WizardHeader.js +116 -0
- package/dist/esm/components/shared/headers/WizardHeader.js.map +1 -0
- package/dist/esm/components/shared/headers/index.d.ts +4 -0
- package/dist/esm/components/shared/headers/index.js +5 -0
- package/dist/esm/components/shared/hooks/index.d.ts +3 -0
- package/dist/esm/components/shared/hooks/index.js +4 -0
- package/dist/esm/components/shared/hooks/useEnvironmentSync.d.ts +17 -0
- package/dist/esm/components/shared/hooks/useEnvironmentSync.js +17 -0
- package/dist/esm/components/shared/hooks/useEnvironmentSync.js.map +1 -0
- package/dist/esm/components/shared/hooks/useForceRerender.d.ts +17 -0
- package/dist/esm/components/shared/hooks/useForceRerender.js +26 -0
- package/dist/esm/components/shared/hooks/useForceRerender.js.map +1 -0
- package/dist/esm/components/shared/index.d.ts +31 -0
- package/dist/esm/components/shared/index.js +36 -0
- package/dist/esm/components/shared/registry/FooterRegistry.d.ts +15 -0
- package/dist/esm/components/shared/registry/FooterRegistry.js +47 -0
- package/dist/esm/components/shared/registry/FooterRegistry.js.map +1 -0
- package/dist/esm/components/shared/registry/HeaderRegistry.d.ts +15 -0
- package/dist/esm/components/shared/registry/HeaderRegistry.js +41 -0
- package/dist/esm/components/shared/registry/HeaderRegistry.js.map +1 -0
- package/dist/esm/components/shared/registry/index.d.ts +4 -0
- package/dist/esm/components/shared/registry/index.js +5 -0
- package/dist/esm/components/shared/registry/types.d.ts +23 -0
- package/dist/esm/components/shared/registry/types.js +21 -0
- package/dist/esm/components/shared/registry/types.js.map +1 -0
- package/dist/esm/components/shared/types/container.d.ts +70 -0
- package/dist/esm/components/shared/types/container.js +35 -0
- package/dist/esm/components/shared/types/container.js.map +1 -0
- package/dist/esm/components/shared/types/environment.d.ts +25 -0
- package/dist/esm/components/shared/types/environment.js +0 -0
- package/dist/esm/components/shared/types/footer.d.ts +121 -0
- package/dist/esm/components/shared/types/footer.js +58 -0
- package/dist/esm/components/shared/types/footer.js.map +1 -0
- package/dist/esm/components/shared/types/form.d.ts +120 -0
- package/dist/esm/components/shared/types/form.js +47 -0
- package/dist/esm/components/shared/types/form.js.map +1 -0
- package/dist/esm/components/shared/types/header.d.ts +81 -0
- package/dist/esm/components/shared/types/header.js +38 -0
- package/dist/esm/components/shared/types/header.js.map +1 -0
- package/dist/esm/components/shared/types/index.d.ts +8 -0
- package/dist/esm/components/shared/types/index.js +7 -0
- package/dist/esm/components/shared/types/navigation.d.ts +9 -0
- package/dist/esm/components/shared/types/navigation.js +0 -0
- package/dist/esm/components/shared/types/step.d.ts +104 -0
- package/dist/esm/components/shared/types/step.js +31 -0
- package/dist/esm/components/shared/types/step.js.map +1 -0
- package/dist/esm/components/shared/utils/createEnvironmentReceiver.d.ts +23 -0
- package/dist/esm/components/shared/utils/createEnvironmentReceiver.js +30 -0
- package/dist/esm/components/shared/utils/createEnvironmentReceiver.js.map +1 -0
- package/dist/esm/components/shared/utils/createForceRerenderReceiver.d.ts +22 -0
- package/dist/esm/components/shared/utils/createForceRerenderReceiver.js +30 -0
- package/dist/esm/components/shared/utils/createForceRerenderReceiver.js.map +1 -0
- package/dist/esm/components/shared/utils/index.d.ts +6 -0
- package/dist/esm/components/shared/utils/index.js +7 -0
- package/dist/esm/components/shared/utils/renderFooter.d.ts +37 -0
- package/dist/esm/components/shared/utils/renderFooter.js +99 -0
- package/dist/esm/components/shared/utils/renderFooter.js.map +1 -0
- package/dist/esm/components/shared/utils/renderHeader.d.ts +39 -0
- package/dist/esm/components/shared/utils/renderHeader.js +120 -0
- package/dist/esm/components/shared/utils/renderHeader.js.map +1 -0
- package/dist/esm/components/shared/utils/stepState.d.ts +36 -0
- package/dist/esm/components/shared/utils/stepState.js +61 -0
- package/dist/esm/components/shared/utils/stepState.js.map +1 -0
- package/dist/esm/components/sizing/index.d.ts +97 -0
- package/dist/esm/components/sizing/index.js +79 -0
- package/dist/esm/components/sizing/index.js.map +1 -0
- package/dist/esm/hooks/index.d.ts +16 -0
- package/dist/esm/hooks/index.js +17 -0
- package/dist/esm/hooks/useAccountSubdomain.d.ts +5 -0
- package/dist/esm/hooks/useAccountSubdomain.js +11 -0
- package/dist/esm/hooks/useAccountSubdomain.js.map +1 -0
- package/dist/esm/hooks/useAccountUrl.d.ts +5 -0
- package/dist/esm/hooks/useAccountUrl.js +27 -0
- package/dist/esm/hooks/useAccountUrl.js.map +1 -0
- package/dist/esm/hooks/useApiUrl.d.ts +5 -0
- package/dist/esm/hooks/useApiUrl.js +14 -0
- package/dist/esm/hooks/useApiUrl.js.map +1 -0
- package/dist/esm/hooks/useAvatar.d.ts +10 -0
- package/dist/esm/hooks/useAvatar.js +20 -0
- package/dist/esm/hooks/useAvatar.js.map +1 -0
- package/dist/esm/hooks/useFeatureFlag.d.ts +5 -0
- package/dist/esm/hooks/useFeatureFlag.js +10 -0
- package/dist/esm/hooks/useFeatureFlag.js.map +1 -0
- package/dist/esm/hooks/useLoginUrl.d.ts +5 -0
- package/dist/esm/hooks/useLoginUrl.js +10 -0
- package/dist/esm/hooks/useLoginUrl.js.map +1 -0
- package/dist/esm/hooks/useMenuItems.d.ts +12 -0
- package/dist/esm/hooks/useMenuItems.js +16 -0
- package/dist/esm/hooks/useMenuItems.js.map +1 -0
- package/dist/esm/hooks/usePluginMeta.d.ts +5 -0
- package/dist/esm/hooks/usePluginMeta.js +11 -0
- package/dist/esm/hooks/usePluginMeta.js.map +1 -0
- package/dist/esm/hooks/usePortalMeta.d.ts +7 -0
- package/dist/esm/hooks/usePortalMeta.js +10 -0
- package/dist/esm/hooks/usePortalMeta.js.map +1 -0
- package/dist/esm/hooks/usePortalUrl.d.ts +5 -0
- package/dist/esm/hooks/usePortalUrl.js +20 -0
- package/dist/esm/hooks/usePortalUrl.js.map +1 -0
- package/dist/esm/hooks/useProtocolDomain.d.ts +5 -0
- package/dist/esm/hooks/useProtocolDomain.js +12 -0
- package/dist/esm/hooks/useProtocolDomain.js.map +1 -0
- package/dist/esm/hooks/useRegisterUrl.d.ts +5 -0
- package/dist/esm/hooks/useRegisterUrl.js +10 -0
- package/dist/esm/hooks/useRegisterUrl.js.map +1 -0
- package/dist/esm/hooks/useResetPasswordUrl.d.ts +5 -0
- package/dist/esm/hooks/useResetPasswordUrl.js +10 -0
- package/dist/esm/hooks/useResetPasswordUrl.js.map +1 -0
- package/dist/esm/hooks/useSdk.d.ts +8 -0
- package/dist/esm/hooks/useSdk.js +33 -0
- package/dist/esm/hooks/useSdk.js.map +1 -0
- package/dist/esm/hooks/useTheme.d.ts +41 -0
- package/dist/esm/hooks/useTheme.js +79 -0
- package/dist/esm/hooks/useTheme.js.map +1 -0
- package/dist/esm/image.d.ts +6 -0
- package/dist/esm/images/account-banner-image.js +6 -0
- package/dist/esm/images/account-banner-image.js.map +1 -0
- package/dist/esm/images/discord-logo.js +6 -0
- package/dist/esm/images/discord-logo.js.map +1 -0
- package/dist/esm/images/lume-bg-image.js +6 -0
- package/dist/esm/images/lume-bg-image.js.map +1 -0
- package/dist/esm/images/lume-bg-login.js +6 -0
- package/dist/esm/images/lume-bg-login.js.map +1 -0
- package/dist/esm/images/lume-color-logo.js +6 -0
- package/dist/esm/images/lume-color-logo.js.map +1 -0
- package/dist/esm/images/lume-logo.js +6 -0
- package/dist/esm/images/lume-logo.js.map +1 -0
- package/dist/esm/images.d.ts +11 -0
- package/dist/esm/images.js +19 -0
- package/dist/esm/images.js.map +1 -0
- package/dist/esm/index.d.ts +150 -0
- package/dist/esm/index.js +149 -0
- package/dist/esm/store/appStore.d.ts +50 -0
- package/dist/esm/store/appStore.js +139 -0
- package/dist/esm/store/appStore.js.map +1 -0
- package/dist/esm/store/index.d.ts +5 -0
- package/dist/esm/store/index.js +6 -0
- package/dist/esm/store/portalStore.d.ts +33 -0
- package/dist/esm/store/portalStore.js +58 -0
- package/dist/esm/store/portalStore.js.map +1 -0
- package/dist/esm/store/saved-filters.d.ts +54 -0
- package/dist/esm/store/saved-filters.js +158 -0
- package/dist/esm/store/saved-filters.js.map +1 -0
- package/dist/esm/store/uiStore.d.ts +11 -0
- package/dist/esm/store/uiStore.js +16 -0
- package/dist/esm/store/uiStore.js.map +1 -0
- package/dist/esm/tests/portalMetaMocks.d.ts +16 -0
- package/dist/esm/tests/portalMetaMocks.js +15 -0
- package/dist/esm/tests/portalMetaMocks.js.map +1 -0
- package/dist/esm/types/badge.d.ts +16 -0
- package/dist/esm/types/badge.js +42 -0
- package/dist/esm/types/badge.js.map +1 -0
- package/dist/esm/types/index.d.ts +3 -0
- package/dist/esm/types/index.js +3 -0
- package/dist/esm/types/theme.d.ts +35 -0
- package/dist/esm/types/theme.js +0 -0
- package/dist/esm/utils/asyncUtils.d.ts +5 -0
- package/dist/esm/utils/asyncUtils.js +9 -0
- package/dist/esm/utils/asyncUtils.js.map +1 -0
- package/dist/esm/utils/fileSize.d.ts +5 -0
- package/dist/esm/utils/fileSize.js +18 -0
- package/dist/esm/utils/fileSize.js.map +1 -0
- package/dist/esm/utils/index.d.ts +4 -0
- package/dist/esm/utils/index.js +5 -0
- package/dist/esm/utils/theme.d.ts +197 -0
- package/dist/esm/utils/theme.js +689 -0
- package/dist/esm/utils/theme.js.map +1 -0
- package/package.json +75 -8
package/LICENSE
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2024-2026 Hammer Technologies LLC
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
|
6
|
+
|
|
7
|
+
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
8
|
+
|
|
9
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
package/README.md
CHANGED
|
@@ -1,45 +1 @@
|
|
|
1
|
-
#
|
|
2
|
-
|
|
3
|
-
## ⚠️ IMPORTANT NOTICE ⚠️
|
|
4
|
-
|
|
5
|
-
**This package is created solely for the purpose of setting up OIDC (OpenID Connect) trusted publishing with npm.**
|
|
6
|
-
|
|
7
|
-
This is **NOT** a functional package and contains **NO** code or functionality beyond the OIDC setup configuration.
|
|
8
|
-
|
|
9
|
-
## Purpose
|
|
10
|
-
|
|
11
|
-
This package exists to:
|
|
12
|
-
1. Configure OIDC trusted publishing for the package name `@lumeweb/portal-framework-ui`
|
|
13
|
-
2. Enable secure, token-less publishing from CI/CD workflows
|
|
14
|
-
3. Establish provenance for packages published under this name
|
|
15
|
-
|
|
16
|
-
## What is OIDC Trusted Publishing?
|
|
17
|
-
|
|
18
|
-
OIDC trusted publishing allows package maintainers to publish packages directly from their CI/CD workflows without needing to manage npm access tokens. Instead, it uses OpenID Connect to establish trust between the CI/CD provider (like GitHub Actions) and npm.
|
|
19
|
-
|
|
20
|
-
## Setup Instructions
|
|
21
|
-
|
|
22
|
-
To properly configure OIDC trusted publishing for this package:
|
|
23
|
-
|
|
24
|
-
1. Go to [npmjs.com](https://www.npmjs.com/) and navigate to your package settings
|
|
25
|
-
2. Configure the trusted publisher (e.g., GitHub Actions)
|
|
26
|
-
3. Specify the repository and workflow that should be allowed to publish
|
|
27
|
-
4. Use the configured workflow to publish your actual package
|
|
28
|
-
|
|
29
|
-
## DO NOT USE THIS PACKAGE
|
|
30
|
-
|
|
31
|
-
This package is a placeholder for OIDC configuration only. It:
|
|
32
|
-
- Contains no executable code
|
|
33
|
-
- Provides no functionality
|
|
34
|
-
- Should not be installed as a dependency
|
|
35
|
-
- Exists only for administrative purposes
|
|
36
|
-
|
|
37
|
-
## More Information
|
|
38
|
-
|
|
39
|
-
For more details about npm's trusted publishing feature, see:
|
|
40
|
-
- [npm Trusted Publishing Documentation](https://docs.npmjs.com/generating-provenance-statements)
|
|
41
|
-
- [GitHub Actions OIDC Documentation](https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/about-security-hardening-with-openid-connect)
|
|
42
|
-
|
|
43
|
-
---
|
|
44
|
-
|
|
45
|
-
**Maintained for OIDC setup purposes only**
|
|
1
|
+
# `@lumeweb/portal-framework-ui`
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
//#region src/components/Copyable.d.ts
|
|
2
|
+
interface CopyableProps {
|
|
3
|
+
/**
|
|
4
|
+
* The text to be copied
|
|
5
|
+
*/
|
|
6
|
+
text: string;
|
|
7
|
+
/**
|
|
8
|
+
* The display text (if different from the copied text)
|
|
9
|
+
*/
|
|
10
|
+
displayText?: string;
|
|
11
|
+
/**
|
|
12
|
+
* Maximum length before truncating (default: 20)
|
|
13
|
+
*/
|
|
14
|
+
maxLength?: number;
|
|
15
|
+
/**
|
|
16
|
+
* Additional CSS classes
|
|
17
|
+
*/
|
|
18
|
+
className?: string;
|
|
19
|
+
/**
|
|
20
|
+
* Tooltip text for copy action (default: "Copy")
|
|
21
|
+
*/
|
|
22
|
+
copyTooltip?: string;
|
|
23
|
+
/**
|
|
24
|
+
* Tooltip text when copied (default: "Copied!")
|
|
25
|
+
*/
|
|
26
|
+
copiedTooltip?: string;
|
|
27
|
+
/**
|
|
28
|
+
* Whether to show the copy icon (default: true)
|
|
29
|
+
*/
|
|
30
|
+
showIcon?: boolean;
|
|
31
|
+
}
|
|
32
|
+
declare function Copyable({
|
|
33
|
+
text,
|
|
34
|
+
displayText,
|
|
35
|
+
maxLength,
|
|
36
|
+
className,
|
|
37
|
+
copyTooltip,
|
|
38
|
+
copiedTooltip,
|
|
39
|
+
showIcon
|
|
40
|
+
}: CopyableProps): any;
|
|
41
|
+
//#endregion
|
|
42
|
+
export { Copyable };
|
|
43
|
+
//# sourceMappingURL=Copyable.d.ts.map
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { Tooltip, TooltipContent, TooltipProvider, TooltipTrigger, cn } from "@lumeweb/portal-framework-ui-core";
|
|
2
|
+
import React, { useEffect, useRef, useState } from "react";
|
|
3
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
4
|
+
import { Check, Copy } from "lucide-react";
|
|
5
|
+
|
|
6
|
+
//#region src/components/Copyable.tsx
|
|
7
|
+
function Copyable({ text, displayText, maxLength = 20, className, copyTooltip = "Copy", copiedTooltip = "Copied!", showIcon = true }) {
|
|
8
|
+
const [isCopied, setIsCopied] = useState(false);
|
|
9
|
+
const timerRef = useRef(null);
|
|
10
|
+
useEffect(() => {
|
|
11
|
+
return () => {
|
|
12
|
+
if (timerRef.current) clearTimeout(timerRef.current);
|
|
13
|
+
};
|
|
14
|
+
}, []);
|
|
15
|
+
const handleCopy = async () => {
|
|
16
|
+
try {
|
|
17
|
+
await navigator.clipboard.writeText(text);
|
|
18
|
+
setIsCopied(true);
|
|
19
|
+
if (timerRef.current) clearTimeout(timerRef.current);
|
|
20
|
+
timerRef.current = setTimeout(() => {
|
|
21
|
+
setIsCopied(false);
|
|
22
|
+
timerRef.current = null;
|
|
23
|
+
}, 2e3);
|
|
24
|
+
} catch (err) {
|
|
25
|
+
console.error("Failed to copy text: ", err);
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
const textToDisplay = displayText || text;
|
|
29
|
+
const truncatedText = textToDisplay.length > maxLength ? `${textToDisplay.substring(0, maxLength)}...` : textToDisplay;
|
|
30
|
+
return /* @__PURE__ */ jsx(TooltipProvider, { children: /* @__PURE__ */ jsxs(Tooltip, { children: [/* @__PURE__ */ jsx(TooltipTrigger, {
|
|
31
|
+
asChild: true,
|
|
32
|
+
children: /* @__PURE__ */ jsxs("button", {
|
|
33
|
+
type: "button",
|
|
34
|
+
onClick: handleCopy,
|
|
35
|
+
"aria-label": isCopied ? copiedTooltip : copyTooltip,
|
|
36
|
+
className: cn("inline-flex items-center gap-1 text-sm hover:bg-muted/50 rounded px-2 py-1 transition-colors", "focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2", className),
|
|
37
|
+
children: [/* @__PURE__ */ jsx("span", {
|
|
38
|
+
className: "font-mono",
|
|
39
|
+
children: truncatedText
|
|
40
|
+
}), showIcon && /* @__PURE__ */ jsx("span", {
|
|
41
|
+
className: "text-muted-foreground",
|
|
42
|
+
children: isCopied ? /* @__PURE__ */ jsx(Check, { className: "h-3 w-3" }) : /* @__PURE__ */ jsx(Copy, { className: "h-3 w-3" })
|
|
43
|
+
})]
|
|
44
|
+
})
|
|
45
|
+
}), /* @__PURE__ */ jsx(TooltipContent, { children: /* @__PURE__ */ jsx("p", { children: isCopied ? copiedTooltip : copyTooltip }) })] }) });
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
//#endregion
|
|
49
|
+
export { Copyable };
|
|
50
|
+
//# sourceMappingURL=Copyable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Copyable.js","names":[],"sources":["../../../src/components/Copyable.tsx"],"sourcesContent":["import React, { useState, useRef, useEffect } from \"react\";\nimport { Copy, Check } from \"lucide-react\";\nimport { cn, Tooltip, TooltipContent, TooltipProvider, TooltipTrigger } from \"@lumeweb/portal-framework-ui-core\";\n\ninterface CopyableProps {\n /**\n * The text to be copied\n */\n text: string;\n /**\n * The display text (if different from the copied text)\n */\n displayText?: string;\n /**\n * Maximum length before truncating (default: 20)\n */\n maxLength?: number;\n /**\n * Additional CSS classes\n */\n className?: string;\n /**\n * Tooltip text for copy action (default: \"Copy\")\n */\n copyTooltip?: string;\n /**\n * Tooltip text when copied (default: \"Copied!\")\n */\n copiedTooltip?: string;\n /**\n * Whether to show the copy icon (default: true)\n */\n showIcon?: boolean;\n}\n\nexport function Copyable({\n text,\n displayText,\n maxLength = 20,\n className,\n copyTooltip = \"Copy\",\n copiedTooltip = \"Copied!\",\n showIcon = true,\n}: CopyableProps) {\n const [isCopied, setIsCopied] = useState(false);\n const timerRef = useRef<NodeJS.Timeout | null>(null);\n\n useEffect(() => {\n return () => {\n if (timerRef.current) {\n clearTimeout(timerRef.current);\n }\n };\n }, []);\n\n const handleCopy = async () => {\n try {\n await navigator.clipboard.writeText(text);\n setIsCopied(true);\n \n // Clear any existing timer before setting a new one\n if (timerRef.current) {\n clearTimeout(timerRef.current);\n }\n \n // Set new timer and store its ID in the ref\n timerRef.current = setTimeout(() => {\n setIsCopied(false);\n timerRef.current = null;\n }, 2000);\n } catch (err) {\n console.error(\"Failed to copy text: \", err);\n }\n };\n\n const textToDisplay = displayText || text;\n const truncatedText = textToDisplay.length > maxLength \n ? `${textToDisplay.substring(0, maxLength)}...` \n : textToDisplay;\n\n return (\n <TooltipProvider>\n <Tooltip>\n <TooltipTrigger asChild>\n <button\n type=\"button\"\n onClick={handleCopy}\n aria-label={isCopied ? copiedTooltip : copyTooltip}\n className={cn(\n \"inline-flex items-center gap-1 text-sm hover:bg-muted/50 rounded px-2 py-1 transition-colors\",\n \"focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2\",\n className\n )}\n >\n <span className=\"font-mono\">{truncatedText}</span>\n {showIcon && (\n <span className=\"text-muted-foreground\">\n {isCopied ? (\n <Check className=\"h-3 w-3\" />\n ) : (\n <Copy className=\"h-3 w-3\" />\n )}\n </span>\n )}\n </button>\n </TooltipTrigger>\n <TooltipContent>\n <p>{isCopied ? copiedTooltip : copyTooltip}</p>\n </TooltipContent>\n </Tooltip>\n </TooltipProvider>\n );\n}\n"],"mappings":";;;;;;AAmCA,SAAgB,SAAS,EACvB,MACA,aACA,YAAY,IACZ,WACA,cAAc,QACd,gBAAgB,WAChB,WAAW,QACK;CAChB,MAAM,CAAC,UAAU,eAAe,SAAS,MAAM;CAC/C,MAAM,WAAW,OAA8B,KAAK;AAEpD,iBAAgB;AACd,eAAa;AACX,OAAI,SAAS,QACX,cAAa,SAAS,QAAQ;;IAGjC,EAAE,CAAC;CAEN,MAAM,aAAa,YAAY;AAC7B,MAAI;AACF,SAAM,UAAU,UAAU,UAAU,KAAK;AACzC,eAAY,KAAK;AAGjB,OAAI,SAAS,QACX,cAAa,SAAS,QAAQ;AAIhC,YAAS,UAAU,iBAAiB;AAClC,gBAAY,MAAM;AAClB,aAAS,UAAU;MAClB,IAAK;WACD,KAAK;AACZ,WAAQ,MAAM,yBAAyB,IAAI;;;CAI/C,MAAM,gBAAgB,eAAe;CACrC,MAAM,gBAAgB,cAAc,SAAS,YACzC,GAAG,cAAc,UAAU,GAAG,UAAU,CAAC,OACzC;AAEJ,QACE,oBAAC,iBAAD,YACE,qBAAC,SAAD,aACE,oBAAC,gBAAD;EAAgB;YACd,qBAAC,UAAD;GACE,MAAK;GACL,SAAS;GACT,cAAY,WAAW,gBAAgB;GACvC,WAAW,GACT,gGACA,uEACA,UACD;aARH,CAUE,oBAAC,QAAD;IAAM,WAAU;cAAa;IAAqB,GACjD,YACC,oBAAC,QAAD;IAAM,WAAU;cACb,WACC,oBAAC,OAAD,EAAO,WAAU,WAAY,IAE7B,oBAAC,MAAD,EAAM,WAAU,WAAY;IAEzB,EAEF;;EACM,GACjB,oBAAC,gBAAD,YACE,oBAAC,KAAD,YAAI,WAAW,gBAAgB,aAAgB,GAChC,EACT,KACM"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
//#region src/components/FilterChip.d.ts
|
|
2
|
+
type FilterChipVariant = "date" | "default" | "numeric" | "text";
|
|
3
|
+
declare function FilterChip({
|
|
4
|
+
className,
|
|
5
|
+
label,
|
|
6
|
+
onRemove,
|
|
7
|
+
variant
|
|
8
|
+
}: {
|
|
9
|
+
className?: string;
|
|
10
|
+
label: string;
|
|
11
|
+
onRemove: () => void;
|
|
12
|
+
variant?: FilterChipVariant;
|
|
13
|
+
}): any;
|
|
14
|
+
//#endregion
|
|
15
|
+
export { FilterChip };
|
|
16
|
+
//# sourceMappingURL=FilterChip.d.ts.map
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { ThemedBadge } from "./ThemedBadge.js";
|
|
2
|
+
import { Button, cn } from "@lumeweb/portal-framework-ui-core";
|
|
3
|
+
import React from "react";
|
|
4
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
5
|
+
import { X } from "lucide-react";
|
|
6
|
+
|
|
7
|
+
//#region src/components/FilterChip.tsx
|
|
8
|
+
const FILTER_CHIP_THEME = {
|
|
9
|
+
date: {
|
|
10
|
+
base: "bg-blue-100 text-blue-800",
|
|
11
|
+
dark: "dark:bg-blue-900/20 dark:text-blue-200",
|
|
12
|
+
hover: "hover:bg-blue-200/80 dark:hover:bg-blue-800/80"
|
|
13
|
+
},
|
|
14
|
+
default: {
|
|
15
|
+
base: "bg-muted/40 text-muted-foreground",
|
|
16
|
+
dark: "dark:bg-gray-700 dark:text-gray-300",
|
|
17
|
+
hover: "hover:bg-muted/60 dark:hover:bg-gray-600"
|
|
18
|
+
},
|
|
19
|
+
numeric: {
|
|
20
|
+
base: "bg-purple-100 text-purple-800",
|
|
21
|
+
dark: "dark:bg-purple-900/20 dark:text-purple-200",
|
|
22
|
+
hover: "hover:bg-purple-200/80 dark:hover:bg-purple-800/80"
|
|
23
|
+
},
|
|
24
|
+
text: {
|
|
25
|
+
base: "bg-green-100 text-green-800",
|
|
26
|
+
dark: "dark:bg-green-900/20 dark:text-green-200",
|
|
27
|
+
hover: "hover:bg-green-200/80 dark:hover:bg-green-800/80"
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
function FilterChip({ className, label, onRemove, variant = "default" }) {
|
|
31
|
+
return /* @__PURE__ */ jsxs(ThemedBadge, {
|
|
32
|
+
className: cn("gap-1 pr-1.5", className),
|
|
33
|
+
config: FILTER_CHIP_THEME,
|
|
34
|
+
value: variant,
|
|
35
|
+
children: [/* @__PURE__ */ jsx("span", { children: label }), /* @__PURE__ */ jsx(Button, {
|
|
36
|
+
"aria-label": `Remove ${label} filter`,
|
|
37
|
+
className: "ml-1 h-5 w-5 p-0 hover:bg-transparent",
|
|
38
|
+
onClick: onRemove,
|
|
39
|
+
variant: "ghost",
|
|
40
|
+
children: /* @__PURE__ */ jsx(X, { className: "h-3.5 w-3.5" })
|
|
41
|
+
})]
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
//#endregion
|
|
46
|
+
export { FilterChip };
|
|
47
|
+
//# sourceMappingURL=FilterChip.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FilterChip.js","names":[],"sources":["../../../src/components/FilterChip.tsx"],"sourcesContent":["import { Button, cn } from \"@lumeweb/portal-framework-ui-core\";\nimport { X } from \"lucide-react\";\nimport React from \"react\";\n\nimport { ThemedBadge } from \"@/components/ThemedBadge\";\nimport { type BadgeConfig } from \"@/types\";\n\ntype FilterChipVariant = \"date\" | \"default\" | \"numeric\" | \"text\";\n\nconst FILTER_CHIP_THEME: BadgeConfig<FilterChipVariant> = {\n date: {\n base: \"bg-blue-100 text-blue-800\",\n dark: \"dark:bg-blue-900/20 dark:text-blue-200\",\n hover: \"hover:bg-blue-200/80 dark:hover:bg-blue-800/80\",\n },\n default: {\n base: \"bg-muted/40 text-muted-foreground\",\n dark: \"dark:bg-gray-700 dark:text-gray-300\",\n hover: \"hover:bg-muted/60 dark:hover:bg-gray-600\",\n },\n numeric: {\n base: \"bg-purple-100 text-purple-800\",\n dark: \"dark:bg-purple-900/20 dark:text-purple-200\",\n hover: \"hover:bg-purple-200/80 dark:hover:bg-purple-800/80\",\n },\n text: {\n base: \"bg-green-100 text-green-800\",\n dark: \"dark:bg-green-900/20 dark:text-green-200\",\n hover: \"hover:bg-green-200/80 dark:hover:bg-green-800/80\",\n },\n};\n\nexport function FilterChip({\n className,\n label,\n onRemove,\n variant = \"default\",\n}: {\n className?: string;\n label: string;\n onRemove: () => void;\n variant?: FilterChipVariant;\n}) {\n return (\n <ThemedBadge\n className={cn(\"gap-1 pr-1.5\", className)}\n config={FILTER_CHIP_THEME}\n value={variant}>\n <span>{label}</span>\n <Button\n aria-label={`Remove ${label} filter`}\n className=\"ml-1 h-5 w-5 p-0 hover:bg-transparent\"\n onClick={onRemove}\n variant=\"ghost\">\n <X className=\"h-3.5 w-3.5\" />\n </Button>\n </ThemedBadge>\n );\n}\n"],"mappings":";;;;;;;AASA,MAAM,oBAAoD;CACxD,MAAM;EACJ,MAAM;EACN,MAAM;EACN,OAAO;EACR;CACD,SAAS;EACP,MAAM;EACN,MAAM;EACN,OAAO;EACR;CACD,SAAS;EACP,MAAM;EACN,MAAM;EACN,OAAO;EACR;CACD,MAAM;EACJ,MAAM;EACN,MAAM;EACN,OAAO;EACR;CACF;AAED,SAAgB,WAAW,EACzB,WACA,OACA,UACA,UAAU,aAMT;AACD,QACE,qBAAC,aAAD;EACE,WAAW,GAAG,gBAAgB,UAAU;EACxC,QAAQ;EACR,OAAO;YAHT,CAIE,oBAAC,QAAD,YAAO,OAAa,GACpB,oBAAC,QAAD;GACE,cAAY,UAAU,MAAM;GAC5B,WAAU;GACV,SAAS;GACT,SAAQ;aACR,oBAAC,GAAD,EAAG,WAAU,eAAgB;GACtB,EACG"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Checkbox } from "@lumeweb/portal-framework-ui-core";
|
|
2
|
+
import React from "react";
|
|
3
|
+
import { FieldName } from "@conform-to/react";
|
|
4
|
+
|
|
5
|
+
//#region src/components/Forms.d.ts
|
|
6
|
+
declare const Field: ({
|
|
7
|
+
className,
|
|
8
|
+
errors,
|
|
9
|
+
inputProps,
|
|
10
|
+
labelProps
|
|
11
|
+
}: {
|
|
12
|
+
className?: string;
|
|
13
|
+
errors?: ListOfErrors;
|
|
14
|
+
inputProps: React.HTMLProps<HTMLInputElement> & {
|
|
15
|
+
name: FieldName<string>;
|
|
16
|
+
};
|
|
17
|
+
labelProps: React.LabelHTMLAttributes<HTMLLabelElement>;
|
|
18
|
+
}) => any;
|
|
19
|
+
declare const FieldCheckbox: ({
|
|
20
|
+
className,
|
|
21
|
+
errors,
|
|
22
|
+
inputProps,
|
|
23
|
+
labelProps
|
|
24
|
+
}: {
|
|
25
|
+
className?: string;
|
|
26
|
+
errors?: ListOfErrors;
|
|
27
|
+
inputProps: React.ComponentPropsWithoutRef<typeof Checkbox> & {
|
|
28
|
+
form: string;
|
|
29
|
+
name: string;
|
|
30
|
+
value?: string;
|
|
31
|
+
};
|
|
32
|
+
labelProps: React.LabelHTMLAttributes<HTMLLabelElement>;
|
|
33
|
+
}) => any;
|
|
34
|
+
type ListOfErrors = (null | string | undefined)[] | null | undefined;
|
|
35
|
+
declare function ErrorList({
|
|
36
|
+
errors,
|
|
37
|
+
id
|
|
38
|
+
}: {
|
|
39
|
+
errors?: ListOfErrors;
|
|
40
|
+
id?: string;
|
|
41
|
+
}): any;
|
|
42
|
+
declare function TextareaField({
|
|
43
|
+
className,
|
|
44
|
+
errors,
|
|
45
|
+
labelProps,
|
|
46
|
+
textareaProps
|
|
47
|
+
}: {
|
|
48
|
+
className?: string;
|
|
49
|
+
errors?: ListOfErrors;
|
|
50
|
+
labelProps: React.LabelHTMLAttributes<HTMLLabelElement>;
|
|
51
|
+
textareaProps: React.TextareaHTMLAttributes<HTMLTextAreaElement>;
|
|
52
|
+
}): any;
|
|
53
|
+
//#endregion
|
|
54
|
+
export { ErrorList, Field, FieldCheckbox, ListOfErrors, TextareaField };
|
|
55
|
+
//# sourceMappingURL=Forms.d.ts.map
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { Checkbox, Input, Label, Textarea, cn } from "@lumeweb/portal-framework-ui-core";
|
|
2
|
+
import React, { useId } from "react";
|
|
3
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
4
|
+
import { useInputControl } from "@conform-to/react";
|
|
5
|
+
|
|
6
|
+
//#region src/components/Forms.tsx
|
|
7
|
+
const Field = ({ className, errors, inputProps, labelProps }) => {
|
|
8
|
+
const fallbackId = useId();
|
|
9
|
+
const id = inputProps.id ?? fallbackId;
|
|
10
|
+
const errorId = errors?.length ? `${id}-error` : void 0;
|
|
11
|
+
return /* @__PURE__ */ jsxs("div", {
|
|
12
|
+
className,
|
|
13
|
+
children: [
|
|
14
|
+
/* @__PURE__ */ jsx(Label, {
|
|
15
|
+
...labelProps,
|
|
16
|
+
className: "text-secondary-foreground text-sm font-semibold",
|
|
17
|
+
htmlFor: id
|
|
18
|
+
}),
|
|
19
|
+
/* @__PURE__ */ jsx(Input, {
|
|
20
|
+
...inputProps,
|
|
21
|
+
"aria-describedby": errorId,
|
|
22
|
+
"aria-invalid": errorId ? true : void 0,
|
|
23
|
+
className: "bg-input border-border placeholder-input-placeholder mt-4",
|
|
24
|
+
id
|
|
25
|
+
}),
|
|
26
|
+
/* @__PURE__ */ jsx("div", {
|
|
27
|
+
className: "min-h-[32px] px-4 pb-3 pt-1",
|
|
28
|
+
children: errorId ? /* @__PURE__ */ jsx(ErrorList, {
|
|
29
|
+
errors,
|
|
30
|
+
id: errorId
|
|
31
|
+
}) : null
|
|
32
|
+
})
|
|
33
|
+
]
|
|
34
|
+
});
|
|
35
|
+
};
|
|
36
|
+
const FieldCheckbox = ({ className, errors, inputProps, labelProps }) => {
|
|
37
|
+
const { defaultChecked, key, ...checkboxProps } = inputProps;
|
|
38
|
+
const checkedValue = inputProps.value ?? "on";
|
|
39
|
+
const input = useInputControl({
|
|
40
|
+
formId: inputProps.form,
|
|
41
|
+
initialValue: defaultChecked ? checkedValue : void 0,
|
|
42
|
+
key,
|
|
43
|
+
name: inputProps.name
|
|
44
|
+
});
|
|
45
|
+
const fallbackId = useId();
|
|
46
|
+
const id = inputProps.id ?? fallbackId;
|
|
47
|
+
const errorId = errors?.length ? `${id}-error` : void 0;
|
|
48
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsxs("div", {
|
|
49
|
+
className: cn("text-foreground flex items-center space-x-2", className),
|
|
50
|
+
children: [/* @__PURE__ */ jsx(Checkbox, {
|
|
51
|
+
...checkboxProps,
|
|
52
|
+
"aria-describedby": errorId,
|
|
53
|
+
"aria-invalid": errorId ? true : void 0,
|
|
54
|
+
checked: input.value === checkedValue,
|
|
55
|
+
id,
|
|
56
|
+
onBlur: (event) => {
|
|
57
|
+
input.blur();
|
|
58
|
+
inputProps.onBlur?.(event);
|
|
59
|
+
},
|
|
60
|
+
onCheckedChange: (state) => {
|
|
61
|
+
input.change(state.valueOf() ? checkedValue : "");
|
|
62
|
+
inputProps.onCheckedChange?.(state);
|
|
63
|
+
},
|
|
64
|
+
onFocus: (event) => {
|
|
65
|
+
input.focus();
|
|
66
|
+
inputProps.onFocus?.(event);
|
|
67
|
+
},
|
|
68
|
+
type: "button"
|
|
69
|
+
}), /* @__PURE__ */ jsx(Label, {
|
|
70
|
+
...labelProps,
|
|
71
|
+
htmlFor: id
|
|
72
|
+
})]
|
|
73
|
+
}), /* @__PURE__ */ jsx("div", {
|
|
74
|
+
className: "min-h-[32px] px-4 pb-3 pt-1",
|
|
75
|
+
children: errorId ? /* @__PURE__ */ jsx(ErrorList, {
|
|
76
|
+
errors,
|
|
77
|
+
id: errorId
|
|
78
|
+
}) : null
|
|
79
|
+
})] });
|
|
80
|
+
};
|
|
81
|
+
function ErrorList({ errors, id }) {
|
|
82
|
+
const errorsToRender = errors?.filter(Boolean);
|
|
83
|
+
if (!errorsToRender?.length) return null;
|
|
84
|
+
return /* @__PURE__ */ jsx("ul", {
|
|
85
|
+
className: "flex flex-col gap-1",
|
|
86
|
+
id,
|
|
87
|
+
children: errorsToRender.map((e) => /* @__PURE__ */ jsx("li", {
|
|
88
|
+
className: "text-destructive-foreground text-[12px]",
|
|
89
|
+
children: e
|
|
90
|
+
}, e))
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
function TextareaField({ className, errors, labelProps, textareaProps }) {
|
|
94
|
+
const fallbackId = useId();
|
|
95
|
+
const id = textareaProps.id ?? textareaProps.name ?? fallbackId;
|
|
96
|
+
const errorId = errors?.length ? `${id}-error` : void 0;
|
|
97
|
+
return /* @__PURE__ */ jsxs("div", {
|
|
98
|
+
className,
|
|
99
|
+
children: [
|
|
100
|
+
/* @__PURE__ */ jsx(Label, {
|
|
101
|
+
htmlFor: id,
|
|
102
|
+
...labelProps
|
|
103
|
+
}),
|
|
104
|
+
/* @__PURE__ */ jsx(Textarea, {
|
|
105
|
+
"aria-describedby": errorId,
|
|
106
|
+
"aria-invalid": errorId ? true : void 0,
|
|
107
|
+
id,
|
|
108
|
+
...textareaProps
|
|
109
|
+
}),
|
|
110
|
+
/* @__PURE__ */ jsx("div", {
|
|
111
|
+
className: "min-h-[32px] pb-1 pt-1",
|
|
112
|
+
children: errorId ? /* @__PURE__ */ jsx(ErrorList, {
|
|
113
|
+
errors,
|
|
114
|
+
id: errorId
|
|
115
|
+
}) : null
|
|
116
|
+
})
|
|
117
|
+
]
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
//#endregion
|
|
122
|
+
export { ErrorList, Field, FieldCheckbox, TextareaField };
|
|
123
|
+
//# sourceMappingURL=Forms.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Forms.js","names":[],"sources":["../../../src/components/Forms.tsx"],"sourcesContent":["import { type FieldName, useInputControl } from \"@conform-to/react\";\nimport {\n Checkbox,\n cn,\n Input,\n Label,\n Textarea,\n} from \"@lumeweb/portal-framework-ui-core\";\nimport React, { useId } from \"react\";\n\nexport const Field = ({\n className,\n errors,\n inputProps,\n labelProps,\n}: {\n className?: string;\n errors?: ListOfErrors;\n inputProps: React.HTMLProps<HTMLInputElement> & {\n name: FieldName<string>;\n };\n labelProps: React.LabelHTMLAttributes<HTMLLabelElement>;\n}) => {\n const fallbackId = useId();\n const id = inputProps.id ?? fallbackId;\n const errorId = errors?.length ? `${id}-error` : undefined;\n return (\n <div className={className}>\n <Label\n {...labelProps}\n className=\"text-secondary-foreground text-sm font-semibold\"\n htmlFor={id}\n />\n <Input\n {...inputProps}\n aria-describedby={errorId}\n aria-invalid={errorId ? true : undefined}\n className=\"bg-input border-border placeholder-input-placeholder mt-4\"\n id={id}\n />\n <div className=\"min-h-[32px] px-4 pb-3 pt-1\">\n {errorId ? <ErrorList errors={errors} id={errorId} /> : null}\n </div>\n </div>\n );\n};\n\nexport const FieldCheckbox = ({\n className,\n errors,\n inputProps,\n labelProps,\n}: {\n className?: string;\n errors?: ListOfErrors;\n inputProps: React.ComponentPropsWithoutRef<typeof Checkbox> & {\n form: string;\n name: string;\n value?: string;\n };\n labelProps: React.LabelHTMLAttributes<HTMLLabelElement>;\n}) => {\n const { defaultChecked, key, ...checkboxProps } = inputProps;\n const checkedValue = inputProps.value ?? \"on\";\n const input = useInputControl({\n formId: inputProps.form,\n initialValue: defaultChecked ? checkedValue : undefined,\n key,\n name: inputProps.name,\n });\n const fallbackId = useId();\n const id = inputProps.id ?? fallbackId;\n const errorId = errors?.length ? `${id}-error` : undefined;\n return (\n <>\n <div\n className={cn(\n \"text-foreground flex items-center space-x-2\",\n className,\n )}>\n <Checkbox\n {...checkboxProps}\n aria-describedby={errorId}\n aria-invalid={errorId ? true : undefined}\n checked={input.value === checkedValue}\n id={id}\n onBlur={(event) => {\n input.blur();\n inputProps.onBlur?.(event);\n }}\n onCheckedChange={(state) => {\n input.change(state.valueOf() ? checkedValue : \"\");\n inputProps.onCheckedChange?.(state);\n }}\n onFocus={(event) => {\n input.focus();\n inputProps.onFocus?.(event);\n }}\n type=\"button\"\n />\n <Label {...labelProps} htmlFor={id} />\n </div>\n <div className=\"min-h-[32px] px-4 pb-3 pt-1\">\n {errorId ? <ErrorList errors={errors} id={errorId} /> : null}\n </div>\n </>\n );\n};\n\nexport type ListOfErrors = (null | string | undefined)[] | null | undefined;\n\nexport function ErrorList({\n errors,\n id,\n}: {\n errors?: ListOfErrors;\n id?: string;\n}) {\n const errorsToRender = errors?.filter(Boolean);\n if (!errorsToRender?.length) return null;\n return (\n <ul className=\"flex flex-col gap-1\" id={id}>\n {errorsToRender.map((e) => (\n <li className=\"text-destructive-foreground text-[12px]\" key={e}>\n {e}\n </li>\n ))}\n </ul>\n );\n}\nexport function TextareaField({\n className,\n errors,\n labelProps,\n textareaProps,\n}: {\n className?: string;\n errors?: ListOfErrors;\n labelProps: React.LabelHTMLAttributes<HTMLLabelElement>;\n textareaProps: React.TextareaHTMLAttributes<HTMLTextAreaElement>;\n}) {\n const fallbackId = useId();\n const id = textareaProps.id ?? textareaProps.name ?? fallbackId;\n const errorId = errors?.length ? `${id}-error` : undefined;\n return (\n <div className={className}>\n <Label htmlFor={id} {...labelProps} />\n <Textarea\n aria-describedby={errorId}\n aria-invalid={errorId ? true : undefined}\n id={id}\n {...textareaProps}\n />\n <div className=\"min-h-[32px] pb-1 pt-1\">\n {errorId ? <ErrorList errors={errors} id={errorId} /> : null}\n </div>\n </div>\n );\n}\n"],"mappings":";;;;;;AAUA,MAAa,SAAS,EACpB,WACA,QACA,YACA,iBAQI;CACJ,MAAM,aAAa,OAAO;CAC1B,MAAM,KAAK,WAAW,MAAM;CAC5B,MAAM,UAAU,QAAQ,SAAS,GAAG,GAAG,UAAU;AACjD,QACE,qBAAC,OAAD;EAAgB;YAAhB;GACE,oBAAC,OAAD;IACE,GAAI;IACJ,WAAU;IACV,SAAS;IACT;GACF,oBAAC,OAAD;IACE,GAAI;IACJ,oBAAkB;IAClB,gBAAc,UAAU,OAAO;IAC/B,WAAU;IACN;IACJ;GACF,oBAAC,OAAD;IAAK,WAAU;cACZ,UAAU,oBAAC,WAAD;KAAmB;KAAQ,IAAI;KAAW,IAAG;IACpD;GACF;;;AAIV,MAAa,iBAAiB,EAC5B,WACA,QACA,YACA,iBAUI;CACJ,MAAM,EAAE,gBAAgB,KAAK,GAAG,kBAAkB;CAClD,MAAM,eAAe,WAAW,SAAS;CACzC,MAAM,QAAQ,gBAAgB;EAC5B,QAAQ,WAAW;EACnB,cAAc,iBAAiB,eAAe;EAC9C;EACA,MAAM,WAAW;EAClB,CAAC;CACF,MAAM,aAAa,OAAO;CAC1B,MAAM,KAAK,WAAW,MAAM;CAC5B,MAAM,UAAU,QAAQ,SAAS,GAAG,GAAG,UAAU;AACjD,QACE,4CACE,qBAAC,OAAD;EACE,WAAW,GACT,+CACA,UACD;YAJH,CAKE,oBAAC,UAAD;GACE,GAAI;GACJ,oBAAkB;GAClB,gBAAc,UAAU,OAAO;GAC/B,SAAS,MAAM,UAAU;GACrB;GACJ,SAAS,UAAU;AACjB,UAAM,MAAM;AACZ,eAAW,SAAS,MAAM;;GAE5B,kBAAkB,UAAU;AAC1B,UAAM,OAAO,MAAM,SAAS,GAAG,eAAe,GAAG;AACjD,eAAW,kBAAkB,MAAM;;GAErC,UAAU,UAAU;AAClB,UAAM,OAAO;AACb,eAAW,UAAU,MAAM;;GAE7B,MAAK;GACL,GACF,oBAAC,OAAD;GAAO,GAAI;GAAY,SAAS;GAAM,EAClC;KACN,oBAAC,OAAD;EAAK,WAAU;YACZ,UAAU,oBAAC,WAAD;GAAmB;GAAQ,IAAI;GAAW,IAAG;EACpD,EACL;;AAMP,SAAgB,UAAU,EACxB,QACA,MAIC;CACD,MAAM,iBAAiB,QAAQ,OAAO,QAAQ;AAC9C,KAAI,CAAC,gBAAgB,OAAQ,QAAO;AACpC,QACE,oBAAC,MAAD;EAAI,WAAU;EAA0B;YACrC,eAAe,KAAK,MACnB,oBAAC,MAAD;GAAI,WAAU;aACX;GACE,EAFwD,EAExD,CACL;EACC;;AAGT,SAAgB,cAAc,EAC5B,WACA,QACA,YACA,iBAMC;CACD,MAAM,aAAa,OAAO;CAC1B,MAAM,KAAK,cAAc,MAAM,cAAc,QAAQ;CACrD,MAAM,UAAU,QAAQ,SAAS,GAAG,GAAG,UAAU;AACjD,QACE,qBAAC,OAAD;EAAgB;YAAhB;GACE,oBAAC,OAAD;IAAO,SAAS;IAAI,GAAI;IAAc;GACtC,oBAAC,UAAD;IACE,oBAAkB;IAClB,gBAAc,UAAU,OAAO;IAC3B;IACJ,GAAI;IACJ;GACF,oBAAC,OAAD;IAAK,WAAU;cACZ,UAAU,oBAAC,WAAD;KAAmB;KAAQ,IAAI;KAAW,IAAG;IACpD;GACF"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
//#region src/components/InlineAuthLinkBanner.d.ts
|
|
2
|
+
interface InlineAuthLinkBannerProps {
|
|
3
|
+
className?: string;
|
|
4
|
+
label: string;
|
|
5
|
+
linkClassName?: string;
|
|
6
|
+
linkLabel?: string;
|
|
7
|
+
to: string;
|
|
8
|
+
}
|
|
9
|
+
declare function InlineAuthLinkBanner({
|
|
10
|
+
className,
|
|
11
|
+
label,
|
|
12
|
+
linkClassName,
|
|
13
|
+
linkLabel,
|
|
14
|
+
to
|
|
15
|
+
}: InlineAuthLinkBannerProps): any;
|
|
16
|
+
//#endregion
|
|
17
|
+
export { InlineAuthLinkBanner };
|
|
18
|
+
//# sourceMappingURL=InlineAuthLinkBanner.d.ts.map
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { cn } from "@lumeweb/portal-framework-ui-core";
|
|
2
|
+
import React from "react";
|
|
3
|
+
import { Link } from "react-router";
|
|
4
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
5
|
+
|
|
6
|
+
//#region src/components/InlineAuthLinkBanner.tsx
|
|
7
|
+
function InlineAuthLinkBanner({ className, label, linkClassName, linkLabel, to }) {
|
|
8
|
+
return /* @__PURE__ */ jsxs("p", {
|
|
9
|
+
className: cn("text-foreground bg-secondary flex w-fit items-center gap-2 rounded-lg p-3 text-left text-sm", className),
|
|
10
|
+
children: [/* @__PURE__ */ jsx("span", {
|
|
11
|
+
className: "text-foreground/80 whitespace-nowrap",
|
|
12
|
+
children: label
|
|
13
|
+
}), /* @__PURE__ */ jsx(Link, {
|
|
14
|
+
className: cn("text-foreground mx-auto whitespace-nowrap hover:underline hover:underline-offset-4", linkClassName),
|
|
15
|
+
to,
|
|
16
|
+
children: linkLabel ?? "Login here →"
|
|
17
|
+
})]
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
//#endregion
|
|
22
|
+
export { InlineAuthLinkBanner };
|
|
23
|
+
//# sourceMappingURL=InlineAuthLinkBanner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InlineAuthLinkBanner.js","names":[],"sources":["../../../src/components/InlineAuthLinkBanner.tsx"],"sourcesContent":["import { cn } from \"@lumeweb/portal-framework-ui-core\";\nimport React from \"react\";\nimport { Link } from \"react-router\";\n\ninterface InlineAuthLinkBannerProps {\n className?: string;\n label: string;\n linkClassName?: string;\n linkLabel?: string;\n to: string;\n}\n\nfunction InlineAuthLinkBanner({\n className,\n label,\n linkClassName,\n linkLabel,\n to,\n}: InlineAuthLinkBannerProps) {\n return (\n <p\n className={cn(\n \"text-foreground bg-secondary flex w-fit items-center gap-2 rounded-lg p-3 text-left text-sm\",\n className,\n )}>\n <span className=\"text-foreground/80 whitespace-nowrap\">{label}</span>\n <Link\n className={cn(\n \"text-foreground mx-auto whitespace-nowrap hover:underline hover:underline-offset-4\",\n linkClassName,\n )}\n to={to}>\n {linkLabel ?? \"Login here →\"}\n </Link>\n </p>\n );\n}\n\nexport { InlineAuthLinkBanner };\n"],"mappings":";;;;;;AAYA,SAAS,qBAAqB,EAC5B,WACA,OACA,eACA,WACA,MAC4B;AAC5B,QACE,qBAAC,KAAD;EACE,WAAW,GACT,+FACA,UACD;YAJH,CAKE,oBAAC,QAAD;GAAM,WAAU;aAAwC;GAAa,GACrE,oBAAC,MAAD;GACE,WAAW,GACT,sFACA,cACD;GACG;aACH,aAAa;GACT,EACL"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { FunctionComponent } from "react";
|
|
2
|
+
|
|
3
|
+
//#region src/components/KeyboardShortcutDialog.d.ts
|
|
4
|
+
interface KeyboardShortcutDialogProps {
|
|
5
|
+
onOpenChange: (open: boolean) => void;
|
|
6
|
+
open: boolean;
|
|
7
|
+
shortcuts: Record<string, string | string[]>;
|
|
8
|
+
}
|
|
9
|
+
declare const KeyboardShortcutDialog: FunctionComponent<KeyboardShortcutDialogProps>;
|
|
10
|
+
//#endregion
|
|
11
|
+
export { KeyboardShortcutDialog };
|
|
12
|
+
//# sourceMappingURL=KeyboardShortcutDialog.d.ts.map
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { Badge, Button, Dialog, DialogContent, DialogHeader, DialogTitle } from "@lumeweb/portal-framework-ui-core";
|
|
2
|
+
import React from "react";
|
|
3
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
4
|
+
import { X } from "lucide-react";
|
|
5
|
+
|
|
6
|
+
//#region src/components/KeyboardShortcutDialog.tsx
|
|
7
|
+
const KeyboardShortcutDialog = ({ onOpenChange, open, shortcuts }) => {
|
|
8
|
+
return /* @__PURE__ */ jsx(Dialog, {
|
|
9
|
+
onOpenChange,
|
|
10
|
+
open,
|
|
11
|
+
children: /* @__PURE__ */ jsxs(DialogContent, {
|
|
12
|
+
className: "max-w-md",
|
|
13
|
+
children: [
|
|
14
|
+
/* @__PURE__ */ jsx("div", {
|
|
15
|
+
className: "absolute right-4 top-4",
|
|
16
|
+
children: /* @__PURE__ */ jsx(Button, {
|
|
17
|
+
className: "h-8 w-8",
|
|
18
|
+
onClick: () => onOpenChange(false),
|
|
19
|
+
size: "icon",
|
|
20
|
+
variant: "ghost",
|
|
21
|
+
children: /* @__PURE__ */ jsx(X, { className: "h-4 w-4" })
|
|
22
|
+
})
|
|
23
|
+
}),
|
|
24
|
+
/* @__PURE__ */ jsx(DialogHeader, { children: /* @__PURE__ */ jsx(DialogTitle, { children: "Keyboard Shortcuts" }) }),
|
|
25
|
+
/* @__PURE__ */ jsx("div", {
|
|
26
|
+
className: "grid gap-2",
|
|
27
|
+
children: Object.entries(shortcuts).map(([action, keys]) => /* @__PURE__ */ jsxs("div", {
|
|
28
|
+
className: "flex items-center justify-between",
|
|
29
|
+
children: [/* @__PURE__ */ jsx("span", {
|
|
30
|
+
className: "text-muted-foreground text-sm",
|
|
31
|
+
children: action
|
|
32
|
+
}), /* @__PURE__ */ jsx("div", {
|
|
33
|
+
className: "flex gap-1",
|
|
34
|
+
children: (Array.isArray(keys) ? keys : [keys]).map((key) => /* @__PURE__ */ jsx(Badge, {
|
|
35
|
+
variant: "outline",
|
|
36
|
+
children: key
|
|
37
|
+
}, key))
|
|
38
|
+
})]
|
|
39
|
+
}, action))
|
|
40
|
+
})
|
|
41
|
+
]
|
|
42
|
+
})
|
|
43
|
+
});
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
//#endregion
|
|
47
|
+
export { KeyboardShortcutDialog };
|
|
48
|
+
//# sourceMappingURL=KeyboardShortcutDialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"KeyboardShortcutDialog.js","names":[],"sources":["../../../src/components/KeyboardShortcutDialog.tsx"],"sourcesContent":["import {\n Badge,\n Button,\n Dialog,\n DialogContent,\n DialogHeader,\n DialogTitle,\n} from \"@lumeweb/portal-framework-ui-core\";\nimport { X } from \"lucide-react\";\nimport React, { type FunctionComponent } from \"react\";\n\ninterface KeyboardShortcutDialogProps {\n onOpenChange: (open: boolean) => void;\n open: boolean;\n shortcuts: Record<string, string | string[]>;\n}\n\nexport const KeyboardShortcutDialog: FunctionComponent<\n KeyboardShortcutDialogProps\n> = ({ onOpenChange, open, shortcuts }) => {\n return (\n <Dialog onOpenChange={onOpenChange} open={open}>\n <DialogContent className=\"max-w-md\">\n <div className=\"absolute right-4 top-4\">\n <Button\n className=\"h-8 w-8\"\n onClick={() => onOpenChange(false)}\n size=\"icon\"\n variant=\"ghost\">\n <X className=\"h-4 w-4\" />\n </Button>\n </div>\n <DialogHeader>\n <DialogTitle>Keyboard Shortcuts</DialogTitle>\n </DialogHeader>\n <div className=\"grid gap-2\">\n {Object.entries(shortcuts).map(([action, keys]) => (\n <div className=\"flex items-center justify-between\" key={action}>\n <span className=\"text-muted-foreground text-sm\">{action}</span>\n <div className=\"flex gap-1\">\n {(Array.isArray(keys) ? keys : [keys]).map((key) => (\n <Badge key={key} variant=\"outline\">\n {key}\n </Badge>\n ))}\n </div>\n </div>\n ))}\n </div>\n </DialogContent>\n </Dialog>\n );\n};\n"],"mappings":";;;;;;AAiBA,MAAa,0BAER,EAAE,cAAc,MAAM,gBAAgB;AACzC,QACE,oBAAC,QAAD;EAAsB;EAAoB;YACxC,qBAAC,eAAD;GAAe,WAAU;aAAzB;IACE,oBAAC,OAAD;KAAK,WAAU;eACb,oBAAC,QAAD;MACE,WAAU;MACV,eAAe,aAAa,MAAM;MAClC,MAAK;MACL,SAAQ;gBACR,oBAAC,GAAD,EAAG,WAAU,WAAY;MAClB;KACL;IACN,oBAAC,cAAD,YACE,oBAAC,aAAD,YAAa,sBAAgC,GAChC;IACf,oBAAC,OAAD;KAAK,WAAU;eACZ,OAAO,QAAQ,UAAU,CAAC,KAAK,CAAC,QAAQ,UACvC,qBAAC,OAAD;MAAK,WAAU;gBAAf,CACE,oBAAC,QAAD;OAAM,WAAU;iBAAiC;OAAc,GAC/D,oBAAC,OAAD;OAAK,WAAU;kBACX,MAAM,QAAQ,KAAK,GAAG,OAAO,CAAC,KAAK,EAAE,KAAK,QAC1C,oBAAC,OAAD;QAAiB,SAAQ;kBACtB;QACK,EAFI,IAEJ,CACR;OACE,EACF;QATkD,OASlD,CACN;KACE;IACQ;;EACT"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { HTMLAttributes, ReactNode } from "react";
|
|
2
|
+
|
|
3
|
+
//#region src/components/Loading.d.ts
|
|
4
|
+
declare function Loading({
|
|
5
|
+
children,
|
|
6
|
+
className,
|
|
7
|
+
...rest
|
|
8
|
+
}: HTMLAttributes<HTMLDivElement> & {
|
|
9
|
+
children?: ReactNode;
|
|
10
|
+
}): JSX.Element;
|
|
11
|
+
//#endregion
|
|
12
|
+
export { Loading };
|
|
13
|
+
//# sourceMappingURL=Loading.d.ts.map
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
|
+
|
|
3
|
+
//#region src/components/Loading.tsx
|
|
4
|
+
function Loading({ children, className, ...rest }) {
|
|
5
|
+
return /* @__PURE__ */ jsx("div", {
|
|
6
|
+
...rest,
|
|
7
|
+
"aria-busy": "true",
|
|
8
|
+
className: `bg-background fixed inset-0 z-50 transition-opacity duration-300 ${className ?? ""}`,
|
|
9
|
+
role: "status",
|
|
10
|
+
children: /* @__PURE__ */ jsxs("div", {
|
|
11
|
+
className: "flex min-h-screen flex-col items-center justify-center p-8",
|
|
12
|
+
children: [/* @__PURE__ */ jsx("div", {
|
|
13
|
+
className: "mb-8",
|
|
14
|
+
children: /* @__PURE__ */ jsx("div", {
|
|
15
|
+
className: "bg-primary flex h-16 w-16 items-center justify-center rounded-2xl",
|
|
16
|
+
children: /* @__PURE__ */ jsx("svg", {
|
|
17
|
+
"aria-hidden": "true",
|
|
18
|
+
className: "text-primary-foreground h-8 w-8 motion-safe:animate-spin motion-reduce:animate-none",
|
|
19
|
+
fill: "currentColor",
|
|
20
|
+
focusable: "false",
|
|
21
|
+
viewBox: "0 0 24 24",
|
|
22
|
+
children: /* @__PURE__ */ jsx("path", { d: "M12 15.5A3.5 3.5 0 0 1 8.5 12A3.5 3.5 0 0 1 12 8.5a3.5 3.5 0 0 1 3.5 3.5 3.5 3.5 0 0 1-3.5 3.5m7.43-2.53c.04-.32.07-.64.07-.97 0-.33-.03-.66-.07-1l2.11-1.63c.19-.15.24-.42.12-.64l-2-3.46c-.12-.22-.39-.31-.61-.22l-2.49 1c-.52-.39-1.06-.73-1.69-.98l-.37-2.65A.506.506 0 0 0 14 2h-4c-.25 0-.46.18-.5.42l-.37 2.65c-.63.25-1.17.59-1.69.98l-2.49-1c-.22-.09-.49 0-.61.22l-2 3.46c-.13.22-.07.49.12.64L4.57 11c-.04.34-.07.67-.07 1 0 .33.03.65.07.97l-2.11 1.66c-.19.15-.25.42-.12.64l2 3.46c.12.22.39.3.61.22l2.49-1.01c.52.4 1.06.74 1.69.99l.37 2.65c.04.24.25.42.5.42h4c.25 0 .46-.18.5-.42l.37-2.65c.63-.26 1.17-.59 1.69-.99l2.49 1.01c.22.08.49 0 .61-.22l2-3.46c.12-.22.07-.49-.12-.64l-2.11-1.66Z" })
|
|
23
|
+
})
|
|
24
|
+
})
|
|
25
|
+
}), /* @__PURE__ */ jsx("div", {
|
|
26
|
+
className: "text-center",
|
|
27
|
+
children: children ?? /* @__PURE__ */ jsx("p", {
|
|
28
|
+
className: "text-muted-foreground",
|
|
29
|
+
children: "Loading page..."
|
|
30
|
+
})
|
|
31
|
+
})]
|
|
32
|
+
})
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
//#endregion
|
|
37
|
+
export { Loading };
|
|
38
|
+
//# sourceMappingURL=Loading.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Loading.js","names":[],"sources":["../../../src/components/Loading.tsx"],"sourcesContent":["import type { HTMLAttributes, ReactNode } from \"react\";\n\nfunction Loading({\n children,\n className,\n ...rest\n}: HTMLAttributes<HTMLDivElement> & { children?: ReactNode }): JSX.Element {\n return (\n <div\n {...rest}\n aria-busy=\"true\"\n className={`bg-background fixed inset-0 z-50 transition-opacity duration-300 ${className ?? \"\"}`}\n role=\"status\">\n <div className=\"flex min-h-screen flex-col items-center justify-center p-8\">\n {/* App Logo/Icon */}\n <div className=\"mb-8\">\n <div className=\"bg-primary flex h-16 w-16 items-center justify-center rounded-2xl\">\n <svg\n aria-hidden=\"true\"\n className=\"text-primary-foreground h-8 w-8 motion-safe:animate-spin motion-reduce:animate-none\"\n fill=\"currentColor\"\n focusable=\"false\"\n viewBox=\"0 0 24 24\">\n <path d=\"M12 15.5A3.5 3.5 0 0 1 8.5 12A3.5 3.5 0 0 1 12 8.5a3.5 3.5 0 0 1 3.5 3.5 3.5 3.5 0 0 1-3.5 3.5m7.43-2.53c.04-.32.07-.64.07-.97 0-.33-.03-.66-.07-1l2.11-1.63c.19-.15.24-.42.12-.64l-2-3.46c-.12-.22-.39-.31-.61-.22l-2.49 1c-.52-.39-1.06-.73-1.69-.98l-.37-2.65A.506.506 0 0 0 14 2h-4c-.25 0-.46.18-.5.42l-.37 2.65c-.63.25-1.17.59-1.69.98l-2.49-1c-.22-.09-.49 0-.61.22l-2 3.46c-.13.22-.07.49.12.64L4.57 11c-.04.34-.07.67-.07 1 0 .33.03.65.07.97l-2.11 1.66c-.19.15-.25.42-.12.64l2 3.46c.12.22.39.3.61.22l2.49-1.01c.52.4 1.06.74 1.69.99l.37 2.65c.04.24.25.42.5.42h4c.25 0 .46-.18.5-.42l.37-2.65c.63-.26 1.17-.59 1.69-.99l2.49 1.01c.22.08.49 0 .61-.22l2-3.46c.12-.22.07-.49-.12-.64l-2.11-1.66Z\" />\n </svg>\n </div>\n </div>\n\n {/* Loading Message */}\n <div className=\"text-center\">\n {children ?? <p className=\"text-muted-foreground\">Loading page...</p>}\n </div>\n </div>\n </div>\n );\n}\n\nexport { Loading };\n"],"mappings":";;;AAEA,SAAS,QAAQ,EACf,UACA,WACA,GAAG,QACsE;AACzE,QACE,oBAAC,OAAD;EACE,GAAI;EACJ,aAAU;EACV,WAAW,oEAAoE,aAAa;EAC5F,MAAK;YACL,qBAAC,OAAD;GAAK,WAAU;aAAf,CAEE,oBAAC,OAAD;IAAK,WAAU;cACb,oBAAC,OAAD;KAAK,WAAU;eACb,oBAAC,OAAD;MACE,eAAY;MACZ,WAAU;MACV,MAAK;MACL,WAAU;MACV,SAAQ;gBACR,oBAAC,QAAD,EAAM,GAAE,irBAAkrB;MACtrB;KACF;IACF,GAGN,oBAAC,OAAD;IAAK,WAAU;cACZ,YAAY,oBAAC,KAAD;KAAG,WAAU;eAAwB;KAAmB;IACjE,EACF;;EACF"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
//#region src/components/LumeLogo.d.ts
|
|
2
|
+
interface LumeLogoProps {
|
|
3
|
+
className?: string;
|
|
4
|
+
imageClassName?: string;
|
|
5
|
+
}
|
|
6
|
+
declare function LumeLogo({
|
|
7
|
+
className,
|
|
8
|
+
imageClassName
|
|
9
|
+
}: LumeLogoProps): any;
|
|
10
|
+
//#endregion
|
|
11
|
+
export { LumeLogo };
|
|
12
|
+
//# sourceMappingURL=LumeLogo.d.ts.map
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { logoPng } from "../images.js";
|
|
2
|
+
import { cn } from "@lumeweb/portal-framework-ui-core";
|
|
3
|
+
import React from "react";
|
|
4
|
+
import { Link } from "react-router";
|
|
5
|
+
import { jsx } from "react/jsx-runtime";
|
|
6
|
+
|
|
7
|
+
//#region src/components/LumeLogo.tsx
|
|
8
|
+
function LumeLogo({ className, imageClassName }) {
|
|
9
|
+
return /* @__PURE__ */ jsx(Link, {
|
|
10
|
+
className: cn("flex items-center space-x-2", className),
|
|
11
|
+
to: "/",
|
|
12
|
+
children: /* @__PURE__ */ jsx("img", {
|
|
13
|
+
alt: "Lume logo",
|
|
14
|
+
className: cn("h-10", imageClassName),
|
|
15
|
+
src: logoPng
|
|
16
|
+
})
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
//#endregion
|
|
21
|
+
export { LumeLogo };
|
|
22
|
+
//# sourceMappingURL=LumeLogo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LumeLogo.js","names":[],"sources":["../../../src/components/LumeLogo.tsx"],"sourcesContent":["import { cn } from \"@lumeweb/portal-framework-ui-core\";\nimport React from \"react\";\nimport { Link } from \"react-router\";\n\n// @ts-ignore\nimport { logoPng } from \"@/images\";\n\ninterface LumeLogoProps {\n className?: string;\n imageClassName?: string;\n}\n\nexport function LumeLogo({ className, imageClassName }: LumeLogoProps) {\n return (\n <Link className={cn(\"flex items-center space-x-2\", className)} to=\"/\">\n <img\n alt=\"Lume logo\"\n className={cn(\"h-10\", imageClassName)}\n src={logoPng}\n />\n </Link>\n );\n}\n"],"mappings":";;;;;;;AAYA,SAAgB,SAAS,EAAE,WAAW,kBAAiC;AACrE,QACE,oBAAC,MAAD;EAAM,WAAW,GAAG,+BAA+B,UAAU;EAAE,IAAG;YAChE,oBAAC,OAAD;GACE,KAAI;GACJ,WAAW,GAAG,QAAQ,eAAe;GACrC,KAAK;GACL;EACG"}
|