@payloadcms/ui 3.80.0-internal.60d6f94 → 3.80.0-internal.8d9ec7c
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/elements/BulkUpload/EditForm/index.d.ts.map +1 -1
- package/dist/elements/BulkUpload/EditForm/index.js +0 -12
- package/dist/elements/BulkUpload/EditForm/index.js.map +1 -1
- package/dist/elements/Button/index.d.ts.map +1 -1
- package/dist/elements/Button/index.js +5 -3
- package/dist/elements/Button/index.js.map +1 -1
- package/dist/elements/Button/index.scss +38 -5
- package/dist/elements/Button/types.d.ts +1 -1
- package/dist/elements/Button/types.d.ts.map +1 -1
- package/dist/elements/Button/types.js.map +1 -1
- package/dist/elements/CheckboxPopup/index.d.ts.map +1 -1
- package/dist/elements/CheckboxPopup/index.js +0 -1
- package/dist/elements/CheckboxPopup/index.js.map +1 -1
- package/dist/elements/CheckboxPopup/index.scss +1 -0
- package/dist/elements/CreateDocumentButton/index.d.ts +26 -0
- package/dist/elements/CreateDocumentButton/index.d.ts.map +1 -0
- package/dist/elements/CreateDocumentButton/index.js +182 -0
- package/dist/elements/CreateDocumentButton/index.js.map +1 -0
- package/dist/elements/DefaultListViewTabs/index.d.ts.map +1 -1
- package/dist/elements/DefaultListViewTabs/index.js +28 -54
- package/dist/elements/DefaultListViewTabs/index.js.map +1 -1
- package/dist/elements/DelayedSpinner/index.d.ts +23 -0
- package/dist/elements/DelayedSpinner/index.d.ts.map +1 -0
- package/dist/elements/DelayedSpinner/index.js +61 -0
- package/dist/elements/DelayedSpinner/index.js.map +1 -0
- package/dist/elements/DocumentControls/index.d.ts +1 -0
- package/dist/elements/DocumentControls/index.d.ts.map +1 -1
- package/dist/elements/DocumentControls/index.js +6 -10
- package/dist/elements/DocumentControls/index.js.map +1 -1
- package/dist/elements/DocumentControls/index.scss +1 -1
- package/dist/elements/DocumentDrawer/index.d.ts.map +1 -1
- package/dist/elements/DocumentDrawer/index.js +54 -141
- package/dist/elements/DocumentDrawer/index.js.map +1 -1
- package/dist/elements/DocumentDrawer/types.d.ts +7 -1
- package/dist/elements/DocumentDrawer/types.d.ts.map +1 -1
- package/dist/elements/DocumentDrawer/types.js.map +1 -1
- package/dist/elements/DrawerActionHeader/index.d.ts.map +1 -1
- package/dist/elements/DrawerActionHeader/index.js +2 -0
- package/dist/elements/DrawerActionHeader/index.js.map +1 -1
- package/dist/elements/DrawerActionHeader/index.scss +2 -2
- package/dist/elements/HierarchyButton/index.d.ts +11 -0
- package/dist/elements/HierarchyButton/index.d.ts.map +1 -0
- package/dist/elements/HierarchyButton/index.js +126 -0
- package/dist/elements/HierarchyButton/index.js.map +1 -0
- package/dist/elements/{FolderView/MoveDocToFolder → HierarchyButton}/index.scss +7 -1
- package/dist/elements/HierarchyButton/index.server.d.ts +10 -0
- package/dist/elements/HierarchyButton/index.server.d.ts.map +1 -0
- package/dist/elements/HierarchyButton/index.server.js +34 -0
- package/dist/elements/HierarchyButton/index.server.js.map +1 -0
- package/dist/elements/HierarchyColumnBrowser/Column/index.d.ts +5 -0
- package/dist/elements/HierarchyColumnBrowser/Column/index.d.ts.map +1 -0
- package/dist/elements/HierarchyColumnBrowser/Column/index.js +166 -0
- package/dist/elements/HierarchyColumnBrowser/Column/index.js.map +1 -0
- package/dist/elements/HierarchyColumnBrowser/Column/index.scss +63 -0
- package/dist/elements/HierarchyColumnBrowser/ColumnItem/index.d.ts +5 -0
- package/dist/elements/HierarchyColumnBrowser/ColumnItem/index.d.ts.map +1 -0
- package/dist/elements/HierarchyColumnBrowser/ColumnItem/index.js +161 -0
- package/dist/elements/HierarchyColumnBrowser/ColumnItem/index.js.map +1 -0
- package/dist/elements/HierarchyColumnBrowser/ColumnItem/index.scss +105 -0
- package/dist/elements/HierarchyColumnBrowser/index.d.ts +8 -0
- package/dist/elements/HierarchyColumnBrowser/index.d.ts.map +1 -0
- package/dist/elements/HierarchyColumnBrowser/index.js +473 -0
- package/dist/elements/HierarchyColumnBrowser/index.js.map +1 -0
- package/dist/elements/HierarchyColumnBrowser/index.scss +20 -0
- package/dist/elements/HierarchyColumnBrowser/types.d.ts +106 -0
- package/dist/elements/HierarchyColumnBrowser/types.d.ts.map +1 -0
- package/dist/elements/HierarchyColumnBrowser/types.js +2 -0
- package/dist/elements/HierarchyColumnBrowser/types.js.map +1 -0
- package/dist/elements/HierarchyDrawer/Drawer/index.d.ts +20 -0
- package/dist/elements/HierarchyDrawer/Drawer/index.d.ts.map +1 -0
- package/dist/elements/HierarchyDrawer/Drawer/index.js +291 -0
- package/dist/elements/HierarchyDrawer/Drawer/index.js.map +1 -0
- package/dist/elements/HierarchyDrawer/Drawer/index.scss +81 -0
- package/dist/elements/HierarchyDrawer/fetchAncestorPath.d.ts +15 -0
- package/dist/elements/HierarchyDrawer/fetchAncestorPath.d.ts.map +1 -0
- package/dist/elements/HierarchyDrawer/fetchAncestorPath.js +60 -0
- package/dist/elements/HierarchyDrawer/fetchAncestorPath.js.map +1 -0
- package/dist/elements/HierarchyDrawer/index.d.ts +30 -0
- package/dist/elements/HierarchyDrawer/index.d.ts.map +1 -0
- package/dist/elements/HierarchyDrawer/index.js +148 -0
- package/dist/elements/HierarchyDrawer/index.js.map +1 -0
- package/dist/elements/HierarchyDrawer/types.d.ts +68 -0
- package/dist/elements/HierarchyDrawer/types.d.ts.map +1 -0
- package/dist/elements/HierarchyDrawer/types.js +3 -0
- package/dist/elements/HierarchyDrawer/types.js.map +1 -0
- package/dist/elements/HierarchyField/SelectedHierarchies.d.ts +13 -0
- package/dist/elements/HierarchyField/SelectedHierarchies.d.ts.map +1 -0
- package/dist/elements/HierarchyField/SelectedHierarchies.js +194 -0
- package/dist/elements/HierarchyField/SelectedHierarchies.js.map +1 -0
- package/dist/elements/HierarchyField/SelectedHierarchies.scss +78 -0
- package/dist/elements/HierarchyField/index.client.d.ts +8 -0
- package/dist/elements/HierarchyField/index.client.d.ts.map +1 -0
- package/dist/elements/HierarchyField/index.client.js +198 -0
- package/dist/elements/HierarchyField/index.client.js.map +1 -0
- package/dist/elements/HierarchyField/index.scss +35 -0
- package/dist/elements/HierarchyField/index.server.d.ts +3 -0
- package/dist/elements/HierarchyField/index.server.d.ts.map +1 -0
- package/dist/elements/HierarchyField/index.server.js +30 -0
- package/dist/elements/HierarchyField/index.server.js.map +1 -0
- package/dist/elements/HierarchySearch/HierarchySearchInput.d.ts +18 -0
- package/dist/elements/HierarchySearch/HierarchySearchInput.d.ts.map +1 -0
- package/dist/elements/HierarchySearch/HierarchySearchInput.js +115 -0
- package/dist/elements/HierarchySearch/HierarchySearchInput.js.map +1 -0
- package/dist/elements/HierarchySearch/HierarchySearchResultItem.d.ts +13 -0
- package/dist/elements/HierarchySearch/HierarchySearchResultItem.d.ts.map +1 -0
- package/dist/elements/HierarchySearch/HierarchySearchResultItem.js +88 -0
- package/dist/elements/HierarchySearch/HierarchySearchResultItem.js.map +1 -0
- package/dist/elements/HierarchySearch/HierarchySearchResults.d.ts +17 -0
- package/dist/elements/HierarchySearch/HierarchySearchResults.d.ts.map +1 -0
- package/dist/elements/HierarchySearch/HierarchySearchResults.js +85 -0
- package/dist/elements/HierarchySearch/HierarchySearchResults.js.map +1 -0
- package/dist/elements/HierarchySearch/index.d.ts +10 -0
- package/dist/elements/HierarchySearch/index.d.ts.map +1 -0
- package/dist/elements/HierarchySearch/index.js +144 -0
- package/dist/elements/HierarchySearch/index.js.map +1 -0
- package/dist/elements/HierarchySearch/index.scss +212 -0
- package/dist/elements/HierarchySearch/types.d.ts +21 -0
- package/dist/elements/HierarchySearch/types.d.ts.map +1 -0
- package/dist/elements/HierarchySearch/types.js +2 -0
- package/dist/elements/HierarchySearch/types.js.map +1 -0
- package/dist/elements/HierarchySearch/useHierarchySearch.d.ts +20 -0
- package/dist/elements/HierarchySearch/useHierarchySearch.d.ts.map +1 -0
- package/dist/elements/HierarchySearch/useHierarchySearch.js +122 -0
- package/dist/elements/HierarchySearch/useHierarchySearch.js.map +1 -0
- package/dist/elements/HierarchyTree/HierarchySidebarTab.d.ts +21 -0
- package/dist/elements/HierarchyTree/HierarchySidebarTab.d.ts.map +1 -0
- package/dist/elements/HierarchyTree/HierarchySidebarTab.js +167 -0
- package/dist/elements/HierarchyTree/HierarchySidebarTab.js.map +1 -0
- package/dist/elements/HierarchyTree/HierarchySidebarTab.server.d.ts +7 -0
- package/dist/elements/HierarchyTree/HierarchySidebarTab.server.d.ts.map +1 -0
- package/dist/elements/HierarchyTree/HierarchySidebarTab.server.js +176 -0
- package/dist/elements/HierarchyTree/HierarchySidebarTab.server.js.map +1 -0
- package/dist/elements/HierarchyTree/LoadMore/LoadMoreButton.d.ts +8 -0
- package/dist/elements/HierarchyTree/LoadMore/LoadMoreButton.d.ts.map +1 -0
- package/dist/elements/HierarchyTree/LoadMore/LoadMoreButton.js +36 -0
- package/dist/elements/HierarchyTree/LoadMore/LoadMoreButton.js.map +1 -0
- package/dist/elements/HierarchyTree/LoadMore/index.d.ts +12 -0
- package/dist/elements/HierarchyTree/LoadMore/index.d.ts.map +1 -0
- package/dist/elements/HierarchyTree/LoadMore/index.js +29 -0
- package/dist/elements/HierarchyTree/LoadMore/index.js.map +1 -0
- package/dist/elements/HierarchyTree/LoadMore/index.scss +26 -0
- package/dist/elements/HierarchyTree/TreeConnector.d.ts +7 -0
- package/dist/elements/HierarchyTree/TreeConnector.d.ts.map +1 -0
- package/dist/elements/HierarchyTree/TreeConnector.js +23 -0
- package/dist/elements/HierarchyTree/TreeConnector.js.map +1 -0
- package/dist/elements/HierarchyTree/TreeFocusContext.d.ts +28 -0
- package/dist/elements/HierarchyTree/TreeFocusContext.d.ts.map +1 -0
- package/dist/elements/HierarchyTree/TreeFocusContext.js +140 -0
- package/dist/elements/HierarchyTree/TreeFocusContext.js.map +1 -0
- package/dist/elements/HierarchyTree/TreeNode/index.d.ts +5 -0
- package/dist/elements/HierarchyTree/TreeNode/index.d.ts.map +1 -0
- package/dist/elements/HierarchyTree/TreeNode/index.js +201 -0
- package/dist/elements/HierarchyTree/TreeNode/index.js.map +1 -0
- package/dist/elements/HierarchyTree/TreeNode/index.scss +99 -0
- package/dist/elements/HierarchyTree/index.d.ts +4 -0
- package/dist/elements/HierarchyTree/index.d.ts.map +1 -0
- package/dist/elements/HierarchyTree/index.js +66 -0
- package/dist/elements/HierarchyTree/index.js.map +1 -0
- package/dist/elements/HierarchyTree/index.scss +42 -0
- package/dist/elements/HierarchyTree/types.d.ts +57 -0
- package/dist/elements/HierarchyTree/types.d.ts.map +1 -0
- package/dist/elements/HierarchyTree/types.js +2 -0
- package/dist/elements/HierarchyTree/types.js.map +1 -0
- package/dist/elements/HierarchyTree/useChildren.d.ts +26 -0
- package/dist/elements/HierarchyTree/useChildren.d.ts.map +1 -0
- package/dist/elements/HierarchyTree/useChildren.js +150 -0
- package/dist/elements/HierarchyTree/useChildren.js.map +1 -0
- package/dist/elements/HierarchyTree/useTreeState.d.ts +9 -0
- package/dist/elements/HierarchyTree/useTreeState.d.ts.map +1 -0
- package/dist/elements/HierarchyTree/useTreeState.js +50 -0
- package/dist/elements/HierarchyTree/useTreeState.js.map +1 -0
- package/dist/elements/HydrateHierarchyProvider/index.d.ts +4 -0
- package/dist/elements/HydrateHierarchyProvider/index.d.ts.map +1 -0
- package/dist/elements/HydrateHierarchyProvider/index.js +70 -0
- package/dist/elements/HydrateHierarchyProvider/index.js.map +1 -0
- package/dist/elements/Link/index.d.ts +4 -0
- package/dist/elements/Link/index.d.ts.map +1 -1
- package/dist/elements/Link/index.js +5 -0
- package/dist/elements/Link/index.js.map +1 -1
- package/dist/elements/ListHeader/TitleActions/index.d.ts +0 -1
- package/dist/elements/ListHeader/TitleActions/index.d.ts.map +1 -1
- package/dist/elements/ListHeader/TitleActions/index.js +0 -1
- package/dist/elements/ListHeader/TitleActions/index.js.map +1 -1
- package/dist/elements/ListHeader/index.js +2 -2
- package/dist/elements/ListHeader/index.js.map +1 -1
- package/dist/elements/ListSelection/index.scss +2 -1
- package/dist/elements/LoadMoreRow/index.d.ts +15 -0
- package/dist/elements/LoadMoreRow/index.d.ts.map +1 -0
- package/dist/elements/LoadMoreRow/index.js +75 -0
- package/dist/elements/LoadMoreRow/index.js.map +1 -0
- package/dist/elements/LoadMoreRow/index.scss +42 -0
- package/dist/elements/Locked/index.scss +1 -1
- package/dist/elements/MoveMany/index.d.ts +22 -0
- package/dist/elements/MoveMany/index.d.ts.map +1 -0
- package/dist/elements/MoveMany/index.js +278 -0
- package/dist/elements/MoveMany/index.js.map +1 -0
- package/dist/elements/MoveMany/index.scss +7 -0
- package/dist/elements/RelationshipTable/index.d.ts.map +1 -1
- package/dist/elements/RelationshipTable/index.js +12 -17
- package/dist/elements/RelationshipTable/index.js.map +1 -1
- package/dist/elements/Spinner/index.d.ts +16 -0
- package/dist/elements/Spinner/index.d.ts.map +1 -0
- package/dist/elements/Spinner/index.js +49 -0
- package/dist/elements/Spinner/index.js.map +1 -0
- package/dist/elements/Spinner/index.scss +39 -0
- package/dist/elements/StepNav/index.d.ts.map +1 -1
- package/dist/elements/StepNav/index.js +10 -1
- package/dist/elements/StepNav/index.js.map +1 -1
- package/dist/elements/StepNav/types.d.ts +1 -0
- package/dist/elements/StepNav/types.d.ts.map +1 -1
- package/dist/elements/StepNav/types.js.map +1 -1
- package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.d.ts +6 -0
- package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.d.ts.map +1 -0
- package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.js +187 -0
- package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.js.map +1 -0
- package/dist/elements/Table/DefaultCell/fields/Hierarchy/index.scss +29 -0
- package/dist/elements/Table/DefaultCell/index.d.ts.map +1 -1
- package/dist/elements/Table/DefaultCell/index.js +20 -0
- package/dist/elements/Table/DefaultCell/index.js.map +1 -1
- package/dist/elements/Tooltip/index.js +1 -1
- package/dist/elements/Tooltip/index.js.map +1 -1
- package/dist/elements/Tooltip/index.scss +1 -15
- package/dist/elements/Tree/LoadMore/LoadMoreButton.d.ts +8 -0
- package/dist/elements/Tree/LoadMore/LoadMoreButton.d.ts.map +1 -0
- package/dist/elements/Tree/LoadMore/LoadMoreButton.js +36 -0
- package/dist/elements/Tree/LoadMore/LoadMoreButton.js.map +1 -0
- package/dist/elements/Tree/LoadMore/index.d.ts +12 -0
- package/dist/elements/Tree/LoadMore/index.d.ts.map +1 -0
- package/dist/elements/Tree/LoadMore/index.js +29 -0
- package/dist/elements/Tree/LoadMore/index.js.map +1 -0
- package/dist/elements/Tree/LoadMore/index.scss +26 -0
- package/dist/elements/Tree/TreeConnector.d.ts +7 -0
- package/dist/elements/Tree/TreeConnector.d.ts.map +1 -0
- package/dist/elements/Tree/TreeConnector.js +23 -0
- package/dist/elements/Tree/TreeConnector.js.map +1 -0
- package/dist/elements/Tree/TreeFocusContext.d.ts +28 -0
- package/dist/elements/Tree/TreeFocusContext.d.ts.map +1 -0
- package/dist/elements/Tree/TreeFocusContext.js +140 -0
- package/dist/elements/Tree/TreeFocusContext.js.map +1 -0
- package/dist/elements/Tree/TreeNode/index.d.ts +5 -0
- package/dist/elements/Tree/TreeNode/index.d.ts.map +1 -0
- package/dist/elements/Tree/TreeNode/index.js +221 -0
- package/dist/elements/Tree/TreeNode/index.js.map +1 -0
- package/dist/elements/Tree/TreeNode/index.scss +110 -0
- package/dist/elements/Tree/index.d.ts +5 -0
- package/dist/elements/Tree/index.d.ts.map +1 -0
- package/dist/elements/Tree/index.js +270 -0
- package/dist/elements/Tree/index.js.map +1 -0
- package/dist/elements/Tree/index.scss +63 -0
- package/dist/elements/Tree/types.d.ts +70 -0
- package/dist/elements/Tree/types.d.ts.map +1 -0
- package/dist/elements/Tree/types.js +2 -0
- package/dist/elements/Tree/types.js.map +1 -0
- package/dist/elements/Tree/useChildren.d.ts +28 -0
- package/dist/elements/Tree/useChildren.d.ts.map +1 -0
- package/dist/elements/Tree/useChildren.js +213 -0
- package/dist/elements/Tree/useChildren.js.map +1 -0
- package/dist/elements/withMergedProps/index.d.ts +1 -1
- package/dist/elements/withMergedProps/index.js +1 -1
- package/dist/elements/withMergedProps/index.js.map +1 -1
- package/dist/exports/client/index.d.ts +30 -9
- package/dist/exports/client/index.d.ts.map +1 -1
- package/dist/exports/client/index.js +14 -12
- package/dist/exports/client/index.js.map +4 -4
- package/dist/exports/rsc/index.d.ts +3 -3
- package/dist/exports/rsc/index.d.ts.map +1 -1
- package/dist/exports/rsc/index.js +3 -3
- package/dist/exports/rsc/index.js.map +1 -1
- package/dist/exports/shared/index.js.map +1 -1
- package/dist/fields/Join/index.d.ts.map +1 -1
- package/dist/fields/Join/index.js +1 -1
- package/dist/fields/Join/index.js.map +1 -1
- package/dist/fields/Null/index.d.ts +11 -0
- package/dist/fields/Null/index.d.ts.map +1 -0
- package/dist/fields/Null/index.js +13 -0
- package/dist/fields/Null/index.js.map +1 -0
- package/dist/icons/Chevron/index.d.ts.map +1 -1
- package/dist/icons/Chevron/index.js +5 -1
- package/dist/icons/Chevron/index.js.map +1 -1
- package/dist/icons/Document/index.d.ts +3 -1
- package/dist/icons/Document/index.d.ts.map +1 -1
- package/dist/icons/Document/index.js +4 -2
- package/dist/icons/Document/index.js.map +1 -1
- package/dist/icons/Document/index.scss +4 -0
- package/dist/icons/Filter/index.d.ts +4 -0
- package/dist/icons/Filter/index.d.ts.map +1 -0
- package/dist/icons/Filter/index.js +15 -0
- package/dist/icons/Filter/index.js.map +1 -0
- package/dist/icons/Filter/index.scss +13 -0
- package/dist/icons/Folder/index.d.ts +4 -2
- package/dist/icons/Folder/index.d.ts.map +1 -1
- package/dist/icons/Folder/index.js +4 -2
- package/dist/icons/Folder/index.js.map +1 -1
- package/dist/icons/Folder/index.scss +8 -0
- package/dist/icons/Lock/index.scss +1 -1
- package/dist/icons/Plus/index.d.ts.map +1 -1
- package/dist/icons/Plus/index.js +2 -1
- package/dist/icons/Plus/index.js.map +1 -1
- package/dist/icons/Tag/index.d.ts +8 -0
- package/dist/icons/Tag/index.d.ts.map +1 -0
- package/dist/icons/Tag/index.js +22 -0
- package/dist/icons/Tag/index.js.map +1 -0
- package/dist/icons/Tag/index.scss +14 -0
- package/dist/providers/DocumentSelection/index.d.ts +8 -0
- package/dist/providers/DocumentSelection/index.d.ts.map +1 -0
- package/dist/providers/DocumentSelection/index.js +239 -0
- package/dist/providers/DocumentSelection/index.js.map +1 -0
- package/dist/providers/DocumentSelection/types.d.ts +122 -0
- package/dist/providers/DocumentSelection/types.d.ts.map +1 -0
- package/dist/providers/DocumentSelection/types.js +5 -0
- package/dist/providers/DocumentSelection/types.js.map +1 -0
- package/dist/providers/Hierarchy/index.d.ts +5 -0
- package/dist/providers/Hierarchy/index.d.ts.map +1 -0
- package/dist/providers/Hierarchy/index.js +346 -0
- package/dist/providers/Hierarchy/index.js.map +1 -0
- package/dist/providers/Hierarchy/types.d.ts +105 -0
- package/dist/providers/Hierarchy/types.d.ts.map +1 -0
- package/dist/providers/Hierarchy/types.js +2 -0
- package/dist/providers/Hierarchy/types.js.map +1 -0
- package/dist/providers/Root/index.d.ts.map +1 -1
- package/dist/providers/Root/index.js +18 -15
- package/dist/providers/Root/index.js.map +1 -1
- package/dist/providers/ServerFunctions/index.d.ts +1 -6
- package/dist/providers/ServerFunctions/index.d.ts.map +1 -1
- package/dist/providers/ServerFunctions/index.js +0 -18
- package/dist/providers/ServerFunctions/index.js.map +1 -1
- package/dist/providers/TableColumns/buildColumnState/renderCell.d.ts +2 -1
- package/dist/providers/TableColumns/buildColumnState/renderCell.d.ts.map +1 -1
- package/dist/providers/TableColumns/buildColumnState/renderCell.js +34 -1
- package/dist/providers/TableColumns/buildColumnState/renderCell.js.map +1 -1
- package/dist/styles.css +1 -1
- package/dist/utilities/handleLivePreview.d.ts.map +1 -1
- package/dist/utilities/isSuperset.d.ts +6 -0
- package/dist/utilities/isSuperset.d.ts.map +1 -0
- package/dist/utilities/isSuperset.js +10 -0
- package/dist/utilities/isSuperset.js.map +1 -0
- package/dist/utilities/renderTable.d.ts +3 -1
- package/dist/utilities/renderTable.d.ts.map +1 -1
- package/dist/utilities/renderTable.js +9 -3
- package/dist/utilities/renderTable.js.map +1 -1
- package/dist/views/Edit/index.d.ts +1 -1
- package/dist/views/Edit/index.d.ts.map +1 -1
- package/dist/views/Edit/index.js +4 -2
- package/dist/views/Edit/index.js.map +1 -1
- package/dist/views/HierarchyList/DocumentListSelection/index.d.ts +10 -0
- package/dist/views/HierarchyList/DocumentListSelection/index.d.ts.map +1 -0
- package/dist/views/HierarchyList/DocumentListSelection/index.js +135 -0
- package/dist/views/HierarchyList/DocumentListSelection/index.js.map +1 -0
- package/dist/views/HierarchyList/HierarchyListHeader/index.d.ts +21 -0
- package/dist/views/HierarchyList/HierarchyListHeader/index.d.ts.map +1 -0
- package/dist/views/HierarchyList/HierarchyListHeader/index.js +67 -0
- package/dist/views/HierarchyList/HierarchyListHeader/index.js.map +1 -0
- package/dist/views/HierarchyList/HierarchyListHeader/index.scss +9 -0
- package/dist/views/HierarchyList/HierarchyTable/ChildNameCell.d.ts +4 -0
- package/dist/views/HierarchyList/HierarchyTable/ChildNameCell.d.ts.map +1 -0
- package/dist/views/HierarchyList/HierarchyTable/ChildNameCell.js +104 -0
- package/dist/views/HierarchyList/HierarchyTable/ChildNameCell.js.map +1 -0
- package/dist/views/HierarchyList/HierarchyTable/DateCell.d.ts +4 -0
- package/dist/views/HierarchyList/HierarchyTable/DateCell.d.ts.map +1 -0
- package/dist/views/HierarchyList/HierarchyTable/DateCell.js +53 -0
- package/dist/views/HierarchyList/HierarchyTable/DateCell.js.map +1 -0
- package/dist/views/HierarchyList/HierarchyTable/RelatedNameCell.d.ts +4 -0
- package/dist/views/HierarchyList/HierarchyTable/RelatedNameCell.d.ts.map +1 -0
- package/dist/views/HierarchyList/HierarchyTable/RelatedNameCell.js +128 -0
- package/dist/views/HierarchyList/HierarchyTable/RelatedNameCell.js.map +1 -0
- package/dist/views/HierarchyList/HierarchyTable/SlotTable.d.ts +99 -0
- package/dist/views/HierarchyList/HierarchyTable/SlotTable.d.ts.map +1 -0
- package/dist/views/HierarchyList/HierarchyTable/SlotTable.js +118 -0
- package/dist/views/HierarchyList/HierarchyTable/SlotTable.js.map +1 -0
- package/dist/views/HierarchyList/HierarchyTable/SlotTable.scss +214 -0
- package/dist/views/HierarchyList/HierarchyTable/index.d.ts +27 -0
- package/dist/views/HierarchyList/HierarchyTable/index.d.ts.map +1 -0
- package/dist/views/HierarchyList/HierarchyTable/index.js +388 -0
- package/dist/views/HierarchyList/HierarchyTable/index.js.map +1 -0
- package/dist/views/HierarchyList/HierarchyTable/index.scss +148 -0
- package/dist/views/HierarchyList/HierarchyTable/types.d.ts +20 -0
- package/dist/views/HierarchyList/HierarchyTable/types.d.ts.map +1 -0
- package/dist/views/HierarchyList/HierarchyTable/types.js +2 -0
- package/dist/views/HierarchyList/HierarchyTable/types.js.map +1 -0
- package/dist/views/HierarchyList/TypeFilter/index.d.ts +15 -0
- package/dist/views/HierarchyList/TypeFilter/index.d.ts.map +1 -0
- package/dist/views/HierarchyList/TypeFilter/index.js +37 -0
- package/dist/views/HierarchyList/TypeFilter/index.js.map +1 -0
- package/dist/views/HierarchyList/TypeFilter/index.scss +32 -0
- package/dist/views/HierarchyList/index.d.ts +5 -0
- package/dist/views/HierarchyList/index.d.ts.map +1 -0
- package/dist/views/HierarchyList/index.js +305 -0
- package/dist/views/HierarchyList/index.js.map +1 -0
- package/dist/views/HierarchyList/index.scss +72 -0
- package/dist/views/List/index.d.ts.map +1 -1
- package/dist/views/List/index.js +51 -7
- package/dist/views/List/index.js.map +1 -1
- package/package.json +5 -5
- package/dist/elements/FolderView/Breadcrumbs/index.d.ts +0 -19
- package/dist/elements/FolderView/Breadcrumbs/index.d.ts.map +0 -1
- package/dist/elements/FolderView/Breadcrumbs/index.js +0 -96
- package/dist/elements/FolderView/Breadcrumbs/index.js.map +0 -1
- package/dist/elements/FolderView/Breadcrumbs/index.scss +0 -56
- package/dist/elements/FolderView/BrowseByFolderButton/index.d.ts +0 -6
- package/dist/elements/FolderView/BrowseByFolderButton/index.d.ts.map +0 -1
- package/dist/elements/FolderView/BrowseByFolderButton/index.js +0 -40
- package/dist/elements/FolderView/BrowseByFolderButton/index.js.map +0 -1
- package/dist/elements/FolderView/BrowseByFolderButton/index.scss +0 -30
- package/dist/elements/FolderView/Cell/index.client.d.ts +0 -13
- package/dist/elements/FolderView/Cell/index.client.d.ts.map +0 -1
- package/dist/elements/FolderView/Cell/index.client.js +0 -95
- package/dist/elements/FolderView/Cell/index.client.js.map +0 -1
- package/dist/elements/FolderView/Cell/index.server.d.ts +0 -4
- package/dist/elements/FolderView/Cell/index.server.d.ts.map +0 -1
- package/dist/elements/FolderView/Cell/index.server.js +0 -18
- package/dist/elements/FolderView/Cell/index.server.js.map +0 -1
- package/dist/elements/FolderView/ColoredFolderIcon/index.d.ts +0 -3
- package/dist/elements/FolderView/ColoredFolderIcon/index.d.ts.map +0 -1
- package/dist/elements/FolderView/ColoredFolderIcon/index.js +0 -9
- package/dist/elements/FolderView/ColoredFolderIcon/index.js.map +0 -1
- package/dist/elements/FolderView/ColoredFolderIcon/index.scss +0 -5
- package/dist/elements/FolderView/CurrentFolderActions/index.d.ts +0 -7
- package/dist/elements/FolderView/CurrentFolderActions/index.d.ts.map +0 -1
- package/dist/elements/FolderView/CurrentFolderActions/index.js +0 -162
- package/dist/elements/FolderView/CurrentFolderActions/index.js.map +0 -1
- package/dist/elements/FolderView/DragOverlaySelection/index.d.ts +0 -11
- package/dist/elements/FolderView/DragOverlaySelection/index.d.ts.map +0 -1
- package/dist/elements/FolderView/DragOverlaySelection/index.js +0 -62
- package/dist/elements/FolderView/DragOverlaySelection/index.js.map +0 -1
- package/dist/elements/FolderView/DragOverlaySelection/index.scss +0 -35
- package/dist/elements/FolderView/DraggableTableRow/index.d.ts +0 -18
- package/dist/elements/FolderView/DraggableTableRow/index.d.ts.map +0 -1
- package/dist/elements/FolderView/DraggableTableRow/index.js +0 -63
- package/dist/elements/FolderView/DraggableTableRow/index.js.map +0 -1
- package/dist/elements/FolderView/DraggableTableRow/index.scss +0 -135
- package/dist/elements/FolderView/DraggableWithClick/index.d.ts +0 -15
- package/dist/elements/FolderView/DraggableWithClick/index.d.ts.map +0 -1
- package/dist/elements/FolderView/DraggableWithClick/index.js +0 -86
- package/dist/elements/FolderView/DraggableWithClick/index.js.map +0 -1
- package/dist/elements/FolderView/DraggableWithClick/index.scss +0 -5
- package/dist/elements/FolderView/Drawers/EditFolderAction/index.d.ts +0 -7
- package/dist/elements/FolderView/Drawers/EditFolderAction/index.d.ts.map +0 -1
- package/dist/elements/FolderView/Drawers/EditFolderAction/index.js +0 -39
- package/dist/elements/FolderView/Drawers/EditFolderAction/index.js.map +0 -1
- package/dist/elements/FolderView/Drawers/MoveToFolder/index.d.ts +0 -37
- package/dist/elements/FolderView/Drawers/MoveToFolder/index.d.ts.map +0 -1
- package/dist/elements/FolderView/Drawers/MoveToFolder/index.js +0 -609
- package/dist/elements/FolderView/Drawers/MoveToFolder/index.js.map +0 -1
- package/dist/elements/FolderView/Drawers/MoveToFolder/index.scss +0 -30
- package/dist/elements/FolderView/FilterFolderTypePill/index.d.ts +0 -4
- package/dist/elements/FolderView/FilterFolderTypePill/index.d.ts.map +0 -1
- package/dist/elements/FolderView/FilterFolderTypePill/index.js +0 -102
- package/dist/elements/FolderView/FilterFolderTypePill/index.js.map +0 -1
- package/dist/elements/FolderView/FilterFolderTypePill/index.scss +0 -16
- package/dist/elements/FolderView/FolderField/index.scss +0 -12
- package/dist/elements/FolderView/FolderField/index.server.d.ts +0 -4
- package/dist/elements/FolderView/FolderField/index.server.d.ts.map +0 -1
- package/dist/elements/FolderView/FolderField/index.server.js +0 -16
- package/dist/elements/FolderView/FolderField/index.server.js.map +0 -1
- package/dist/elements/FolderView/FolderFileCard/index.d.ts +0 -30
- package/dist/elements/FolderView/FolderFileCard/index.d.ts.map +0 -1
- package/dist/elements/FolderView/FolderFileCard/index.js +0 -209
- package/dist/elements/FolderView/FolderFileCard/index.js.map +0 -1
- package/dist/elements/FolderView/FolderFileCard/index.scss +0 -247
- package/dist/elements/FolderView/FolderFileTable/index.d.ts +0 -8
- package/dist/elements/FolderView/FolderFileTable/index.d.ts.map +0 -1
- package/dist/elements/FolderView/FolderFileTable/index.js +0 -284
- package/dist/elements/FolderView/FolderFileTable/index.js.map +0 -1
- package/dist/elements/FolderView/FolderFileTable/index.scss +0 -11
- package/dist/elements/FolderView/FolderTypeField/index.d.ts +0 -4
- package/dist/elements/FolderView/FolderTypeField/index.d.ts.map +0 -1
- package/dist/elements/FolderView/FolderTypeField/index.js +0 -123
- package/dist/elements/FolderView/FolderTypeField/index.js.map +0 -1
- package/dist/elements/FolderView/ItemCardGrid/index.d.ts +0 -16
- package/dist/elements/FolderView/ItemCardGrid/index.d.ts.map +0 -1
- package/dist/elements/FolderView/ItemCardGrid/index.js +0 -34
- package/dist/elements/FolderView/ItemCardGrid/index.js.map +0 -1
- package/dist/elements/FolderView/ItemCardGrid/index.scss +0 -16
- package/dist/elements/FolderView/MoveDocToFolder/index.d.ts +0 -37
- package/dist/elements/FolderView/MoveDocToFolder/index.d.ts.map +0 -1
- package/dist/elements/FolderView/MoveDocToFolder/index.js +0 -292
- package/dist/elements/FolderView/MoveDocToFolder/index.js.map +0 -1
- package/dist/elements/FolderView/SimpleTable/index.d.ts +0 -19
- package/dist/elements/FolderView/SimpleTable/index.d.ts.map +0 -1
- package/dist/elements/FolderView/SimpleTable/index.js +0 -95
- package/dist/elements/FolderView/SimpleTable/index.js.map +0 -1
- package/dist/elements/FolderView/SimpleTable/index.scss +0 -59
- package/dist/elements/FolderView/SortByPill/index.d.ts +0 -4
- package/dist/elements/FolderView/SortByPill/index.d.ts.map +0 -1
- package/dist/elements/FolderView/SortByPill/index.js +0 -112
- package/dist/elements/FolderView/SortByPill/index.js.map +0 -1
- package/dist/elements/FolderView/SortByPill/index.scss +0 -16
- package/dist/elements/FolderView/ToggleViewButtons/index.d.ts +0 -8
- package/dist/elements/FolderView/ToggleViewButtons/index.d.ts.map +0 -1
- package/dist/elements/FolderView/ToggleViewButtons/index.js +0 -31
- package/dist/elements/FolderView/ToggleViewButtons/index.js.map +0 -1
- package/dist/elements/FolderView/ToggleViewButtons/index.scss +0 -17
- package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.d.ts +0 -15
- package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.d.ts.map +0 -1
- package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.js +0 -182
- package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.js.map +0 -1
- package/dist/providers/Folders/groupItemIDsByRelation.d.ts +0 -3
- package/dist/providers/Folders/groupItemIDsByRelation.d.ts.map +0 -1
- package/dist/providers/Folders/groupItemIDsByRelation.js +0 -10
- package/dist/providers/Folders/groupItemIDsByRelation.js.map +0 -1
- package/dist/providers/Folders/index.d.ts +0 -143
- package/dist/providers/Folders/index.d.ts.map +0 -1
- package/dist/providers/Folders/index.js +0 -641
- package/dist/providers/Folders/index.js.map +0 -1
- package/dist/utilities/getFolderResultsComponentAndData.d.ts +0 -25
- package/dist/utilities/getFolderResultsComponentAndData.d.ts.map +0 -1
- package/dist/utilities/getFolderResultsComponentAndData.js +0 -135
- package/dist/utilities/getFolderResultsComponentAndData.js.map +0 -1
- package/dist/views/BrowseByFolder/index.d.ts +0 -5
- package/dist/views/BrowseByFolder/index.d.ts.map +0 -1
- package/dist/views/BrowseByFolder/index.js +0 -342
- package/dist/views/BrowseByFolder/index.js.map +0 -1
- package/dist/views/BrowseByFolder/index.scss +0 -174
- package/dist/views/CollectionFolder/ListSelection/index.d.ts +0 -9
- package/dist/views/CollectionFolder/ListSelection/index.d.ts.map +0 -1
- package/dist/views/CollectionFolder/ListSelection/index.js +0 -180
- package/dist/views/CollectionFolder/ListSelection/index.js.map +0 -1
- package/dist/views/CollectionFolder/index.d.ts +0 -5
- package/dist/views/CollectionFolder/index.d.ts.map +0 -1
- package/dist/views/CollectionFolder/index.js +0 -325
- package/dist/views/CollectionFolder/index.js.map +0 -1
- package/dist/views/CollectionFolder/index.scss +0 -162
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
4
|
+
import { createElement as _createElement } from "react";
|
|
5
|
+
import { useModal } from '@faceless-ui/modal';
|
|
6
|
+
import React, { useCallback, useId, useMemo, useRef } from 'react';
|
|
7
|
+
export * from './types.js';
|
|
8
|
+
import { useConfig } from '../../providers/Config/index.js';
|
|
9
|
+
import { useEditDepth } from '../../providers/EditDepth/index.js';
|
|
10
|
+
import { useHierarchy } from '../../providers/Hierarchy/index.js';
|
|
11
|
+
import { DrawerToggler } from '../Drawer/index.js';
|
|
12
|
+
import { baseClass, HierarchyDrawer } from './Drawer/index.js';
|
|
13
|
+
export const formatHierarchyDrawerSlug = ({
|
|
14
|
+
depth,
|
|
15
|
+
uuid
|
|
16
|
+
}) => `hierarchy-drawer_${depth}_${uuid}`;
|
|
17
|
+
export const HierarchyDrawerToggler = ({
|
|
18
|
+
children,
|
|
19
|
+
className,
|
|
20
|
+
disabled,
|
|
21
|
+
drawerSlug,
|
|
22
|
+
onClick,
|
|
23
|
+
...rest
|
|
24
|
+
}) => {
|
|
25
|
+
return /*#__PURE__*/_jsx(DrawerToggler, {
|
|
26
|
+
className: [className, `${baseClass}__toggler`].filter(Boolean).join(' '),
|
|
27
|
+
disabled: disabled,
|
|
28
|
+
onClick: onClick,
|
|
29
|
+
slug: drawerSlug,
|
|
30
|
+
...rest,
|
|
31
|
+
children: children
|
|
32
|
+
});
|
|
33
|
+
};
|
|
34
|
+
/**
|
|
35
|
+
* Hook for using a hierarchy drawer for selecting hierarchy items.
|
|
36
|
+
*
|
|
37
|
+
* @example
|
|
38
|
+
* ```tsx
|
|
39
|
+
* const [HierarchyDrawer, HierarchyDrawerToggler, { closeDrawer, openDrawer }] = useHierarchyDrawer({
|
|
40
|
+
* collectionSlug: 'categories',
|
|
41
|
+
* })
|
|
42
|
+
*
|
|
43
|
+
* return (
|
|
44
|
+
* <>
|
|
45
|
+
* <HierarchyDrawer
|
|
46
|
+
* onSave={(selections) => console.log(selections)}
|
|
47
|
+
* hasMany={true}
|
|
48
|
+
* />
|
|
49
|
+
* <HierarchyDrawerToggler>Select Categories</HierarchyDrawerToggler>
|
|
50
|
+
* </>
|
|
51
|
+
* )
|
|
52
|
+
* ```
|
|
53
|
+
*/
|
|
54
|
+
export const useHierarchyDrawer = ({
|
|
55
|
+
disabledIds,
|
|
56
|
+
filterByCollection: filterByCollectionProp,
|
|
57
|
+
hierarchyCollectionSlug,
|
|
58
|
+
Icon
|
|
59
|
+
}) => {
|
|
60
|
+
const {
|
|
61
|
+
getEntityConfig
|
|
62
|
+
} = useConfig();
|
|
63
|
+
const {
|
|
64
|
+
allowedCollections,
|
|
65
|
+
baseFilter
|
|
66
|
+
} = useHierarchy();
|
|
67
|
+
const collectionConfig = getEntityConfig({
|
|
68
|
+
collectionSlug: hierarchyCollectionSlug
|
|
69
|
+
});
|
|
70
|
+
const useAsTitle = collectionConfig?.admin?.useAsTitle;
|
|
71
|
+
const hierarchyConfig = collectionConfig?.hierarchy && typeof collectionConfig.hierarchy === 'object' ? collectionConfig.hierarchy : undefined;
|
|
72
|
+
const parentFieldName = hierarchyConfig?.parentFieldName;
|
|
73
|
+
// Use explicit prop if provided, otherwise fall back to allowedCollections from context
|
|
74
|
+
// - allowedCollections is null/undefined: no filtering (undefined)
|
|
75
|
+
// - allowedCollections is []: folder accepts everything, show only unrestricted destinations ([])
|
|
76
|
+
// - allowedCollections has values: show folders accepting those types
|
|
77
|
+
// Memoize to prevent new array references on every render
|
|
78
|
+
const filterByCollection = useMemo(() => {
|
|
79
|
+
if (filterByCollectionProp !== undefined) {
|
|
80
|
+
return filterByCollectionProp;
|
|
81
|
+
}
|
|
82
|
+
return allowedCollections !== null ? allowedCollections.map(c => c.slug) : undefined;
|
|
83
|
+
}, [filterByCollectionProp, allowedCollections]);
|
|
84
|
+
const drawerDepth = useEditDepth();
|
|
85
|
+
const uuid = useId();
|
|
86
|
+
const {
|
|
87
|
+
closeModal,
|
|
88
|
+
openModal,
|
|
89
|
+
toggleModal
|
|
90
|
+
} = useModal();
|
|
91
|
+
const drawerSlug = formatHierarchyDrawerSlug({
|
|
92
|
+
depth: drawerDepth,
|
|
93
|
+
uuid
|
|
94
|
+
});
|
|
95
|
+
// Store modal functions in refs to ensure stable callbacks
|
|
96
|
+
// This prevents re-renders when other modals (like DocumentDrawer) change state
|
|
97
|
+
const closeModalRef = useRef(closeModal);
|
|
98
|
+
const openModalRef = useRef(openModal);
|
|
99
|
+
const toggleModalRef = useRef(toggleModal);
|
|
100
|
+
closeModalRef.current = closeModal;
|
|
101
|
+
openModalRef.current = openModal;
|
|
102
|
+
toggleModalRef.current = toggleModal;
|
|
103
|
+
// Stable callbacks using refs - these will NEVER change
|
|
104
|
+
const toggleDrawer = useCallback(() => {
|
|
105
|
+
toggleModalRef.current(drawerSlug);
|
|
106
|
+
}, [drawerSlug]);
|
|
107
|
+
const closeDrawer = useCallback(() => {
|
|
108
|
+
closeModalRef.current(drawerSlug);
|
|
109
|
+
}, [drawerSlug]);
|
|
110
|
+
const openDrawer = useCallback(() => {
|
|
111
|
+
openModalRef.current(drawerSlug);
|
|
112
|
+
}, [drawerSlug]);
|
|
113
|
+
const MemoizedDrawer = useMemo(() => {
|
|
114
|
+
const DrawerComponent = props => /*#__PURE__*/_createElement(HierarchyDrawer, {
|
|
115
|
+
...props,
|
|
116
|
+
baseFilter: baseFilter,
|
|
117
|
+
closeDrawer: closeDrawer,
|
|
118
|
+
disabledIds: disabledIds,
|
|
119
|
+
drawerSlug: drawerSlug,
|
|
120
|
+
filterByCollection: filterByCollection,
|
|
121
|
+
hierarchyCollectionSlug: hierarchyCollectionSlug,
|
|
122
|
+
Icon: Icon,
|
|
123
|
+
key: drawerSlug,
|
|
124
|
+
parentFieldName: parentFieldName,
|
|
125
|
+
useAsTitle: useAsTitle
|
|
126
|
+
});
|
|
127
|
+
return DrawerComponent;
|
|
128
|
+
}, [baseFilter, drawerSlug, closeDrawer, disabledIds, filterByCollection, Icon, parentFieldName, hierarchyCollectionSlug, useAsTitle]);
|
|
129
|
+
const MemoizedDrawerToggler = useMemo(() => {
|
|
130
|
+
const TogglerComponent = props_0 => /*#__PURE__*/_jsx(HierarchyDrawerToggler, {
|
|
131
|
+
...props_0,
|
|
132
|
+
drawerSlug: drawerSlug
|
|
133
|
+
});
|
|
134
|
+
return TogglerComponent;
|
|
135
|
+
}, [drawerSlug]);
|
|
136
|
+
const MemoizedDrawerState = useMemo(() => ({
|
|
137
|
+
closeDrawer,
|
|
138
|
+
drawerDepth,
|
|
139
|
+
drawerSlug,
|
|
140
|
+
// Note: Not tracking isDrawerOpen to prevent re-renders when other modals change state
|
|
141
|
+
// Consumers needing this can use useModal() directly
|
|
142
|
+
isDrawerOpen: false,
|
|
143
|
+
openDrawer,
|
|
144
|
+
toggleDrawer
|
|
145
|
+
}), [drawerDepth, drawerSlug, toggleDrawer, closeDrawer, openDrawer]);
|
|
146
|
+
return [MemoizedDrawer, MemoizedDrawerToggler, MemoizedDrawerState];
|
|
147
|
+
};
|
|
148
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","names":["useModal","React","useCallback","useId","useMemo","useRef","useConfig","useEditDepth","useHierarchy","DrawerToggler","baseClass","HierarchyDrawer","formatHierarchyDrawerSlug","depth","uuid","HierarchyDrawerToggler","children","className","disabled","drawerSlug","onClick","rest","_jsx","filter","Boolean","join","slug","useHierarchyDrawer","disabledIds","filterByCollection","filterByCollectionProp","hierarchyCollectionSlug","Icon","getEntityConfig","allowedCollections","baseFilter","collectionConfig","collectionSlug","useAsTitle","admin","hierarchyConfig","hierarchy","undefined","parentFieldName","map","c","drawerDepth","closeModal","openModal","toggleModal","closeModalRef","openModalRef","toggleModalRef","current","toggleDrawer","closeDrawer","openDrawer","MemoizedDrawer","DrawerComponent","props","_createElement","key","MemoizedDrawerToggler","TogglerComponent","MemoizedDrawerState","isDrawerOpen"],"sources":["../../../src/elements/HierarchyDrawer/index.tsx"],"sourcesContent":["'use client'\nimport { useModal } from '@faceless-ui/modal'\nimport React, { useCallback, useId, useMemo, useRef } from 'react'\n\nimport type {\n HierarchyDrawerProps,\n HierarchyDrawerTogglerProps,\n UseHierarchyDrawer,\n} from './types.js'\n\nexport * from './types.js'\n\nimport { useConfig } from '../../providers/Config/index.js'\nimport { useEditDepth } from '../../providers/EditDepth/index.js'\nimport { useHierarchy } from '../../providers/Hierarchy/index.js'\nimport { DrawerToggler } from '../Drawer/index.js'\nimport { baseClass, HierarchyDrawer } from './Drawer/index.js'\n\nexport const formatHierarchyDrawerSlug = ({\n depth,\n uuid,\n}: {\n depth: number\n uuid: string\n}): string => `hierarchy-drawer_${depth}_${uuid}`\n\nexport const HierarchyDrawerToggler: React.FC<HierarchyDrawerTogglerProps> = ({\n children,\n className,\n disabled,\n drawerSlug,\n onClick,\n ...rest\n}) => {\n return (\n <DrawerToggler\n className={[className, `${baseClass}__toggler`].filter(Boolean).join(' ')}\n disabled={disabled}\n onClick={onClick}\n slug={drawerSlug}\n {...rest}\n >\n {children}\n </DrawerToggler>\n )\n}\n\n/**\n * Hook for using a hierarchy drawer for selecting hierarchy items.\n *\n * @example\n * ```tsx\n * const [HierarchyDrawer, HierarchyDrawerToggler, { closeDrawer, openDrawer }] = useHierarchyDrawer({\n * collectionSlug: 'categories',\n * })\n *\n * return (\n * <>\n * <HierarchyDrawer\n * onSave={(selections) => console.log(selections)}\n * hasMany={true}\n * />\n * <HierarchyDrawerToggler>Select Categories</HierarchyDrawerToggler>\n * </>\n * )\n * ```\n */\nexport const useHierarchyDrawer: UseHierarchyDrawer = ({\n disabledIds,\n filterByCollection: filterByCollectionProp,\n hierarchyCollectionSlug,\n Icon,\n}) => {\n const { getEntityConfig } = useConfig()\n const { allowedCollections, baseFilter } = useHierarchy()\n const collectionConfig = getEntityConfig({ collectionSlug: hierarchyCollectionSlug })\n\n const useAsTitle = collectionConfig?.admin?.useAsTitle\n const hierarchyConfig =\n collectionConfig?.hierarchy && typeof collectionConfig.hierarchy === 'object'\n ? collectionConfig.hierarchy\n : undefined\n const parentFieldName = hierarchyConfig?.parentFieldName\n\n // Use explicit prop if provided, otherwise fall back to allowedCollections from context\n // - allowedCollections is null/undefined: no filtering (undefined)\n // - allowedCollections is []: folder accepts everything, show only unrestricted destinations ([])\n // - allowedCollections has values: show folders accepting those types\n // Memoize to prevent new array references on every render\n const filterByCollection = useMemo(() => {\n if (filterByCollectionProp !== undefined) {\n return filterByCollectionProp\n }\n return allowedCollections !== null ? allowedCollections.map((c) => c.slug) : undefined\n }, [filterByCollectionProp, allowedCollections])\n\n const drawerDepth = useEditDepth()\n const uuid = useId()\n const { closeModal, openModal, toggleModal } = useModal()\n\n const drawerSlug = formatHierarchyDrawerSlug({\n depth: drawerDepth,\n uuid,\n })\n\n // Store modal functions in refs to ensure stable callbacks\n // This prevents re-renders when other modals (like DocumentDrawer) change state\n const closeModalRef = useRef(closeModal)\n const openModalRef = useRef(openModal)\n const toggleModalRef = useRef(toggleModal)\n closeModalRef.current = closeModal\n openModalRef.current = openModal\n toggleModalRef.current = toggleModal\n\n // Stable callbacks using refs - these will NEVER change\n const toggleDrawer = useCallback(() => {\n toggleModalRef.current(drawerSlug)\n }, [drawerSlug])\n\n const closeDrawer = useCallback(() => {\n closeModalRef.current(drawerSlug)\n }, [drawerSlug])\n\n const openDrawer = useCallback(() => {\n openModalRef.current(drawerSlug)\n }, [drawerSlug])\n\n const MemoizedDrawer = useMemo(() => {\n const DrawerComponent: React.FC<HierarchyDrawerProps> = (props) => (\n <HierarchyDrawer\n {...props}\n baseFilter={baseFilter}\n closeDrawer={closeDrawer}\n disabledIds={disabledIds}\n drawerSlug={drawerSlug}\n filterByCollection={filterByCollection}\n hierarchyCollectionSlug={hierarchyCollectionSlug}\n Icon={Icon}\n key={drawerSlug}\n parentFieldName={parentFieldName}\n useAsTitle={useAsTitle}\n />\n )\n\n return DrawerComponent\n }, [\n baseFilter,\n drawerSlug,\n closeDrawer,\n disabledIds,\n filterByCollection,\n Icon,\n parentFieldName,\n hierarchyCollectionSlug,\n useAsTitle,\n ])\n\n const MemoizedDrawerToggler = useMemo(() => {\n const TogglerComponent: React.FC<Omit<HierarchyDrawerTogglerProps, 'drawerSlug'>> = (props) => (\n <HierarchyDrawerToggler {...props} drawerSlug={drawerSlug} />\n )\n\n return TogglerComponent\n }, [drawerSlug])\n\n const MemoizedDrawerState = useMemo(\n () => ({\n closeDrawer,\n drawerDepth,\n drawerSlug,\n // Note: Not tracking isDrawerOpen to prevent re-renders when other modals change state\n // Consumers needing this can use useModal() directly\n isDrawerOpen: false,\n openDrawer,\n toggleDrawer,\n }),\n [drawerDepth, drawerSlug, toggleDrawer, closeDrawer, openDrawer],\n )\n\n return [MemoizedDrawer, MemoizedDrawerToggler, MemoizedDrawerState]\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import type { Where } from 'payload';
|
|
2
|
+
import type React from 'react';
|
|
3
|
+
import type { HTMLAttributes } from 'react';
|
|
4
|
+
export type SelectionWithPath = {
|
|
5
|
+
id: number | string;
|
|
6
|
+
path: Array<{
|
|
7
|
+
id: number | string;
|
|
8
|
+
title: string;
|
|
9
|
+
}>;
|
|
10
|
+
};
|
|
11
|
+
export type UseHierarchyDrawerArgs = {
|
|
12
|
+
/** IDs that should be disabled (e.g., items being moved can't be selected as destination) */
|
|
13
|
+
disabledIds?: Set<number | string>;
|
|
14
|
+
/**
|
|
15
|
+
* When provided, filters hierarchy items to only show those that accept these collections.
|
|
16
|
+
* Used with collectionSpecific hierarchy config.
|
|
17
|
+
*/
|
|
18
|
+
filterByCollection?: string[];
|
|
19
|
+
hierarchyCollectionSlug: string;
|
|
20
|
+
Icon?: React.ReactNode;
|
|
21
|
+
};
|
|
22
|
+
export type HierarchyDrawerProps = {
|
|
23
|
+
readonly hasMany?: boolean;
|
|
24
|
+
readonly initialSelections?: (number | string)[];
|
|
25
|
+
readonly onMoveToRoot?: () => void;
|
|
26
|
+
readonly onSave: (params: {
|
|
27
|
+
closeDrawer: () => void;
|
|
28
|
+
selections: Map<number | string, SelectionWithPath>;
|
|
29
|
+
}) => void;
|
|
30
|
+
readonly showMoveToRoot?: boolean;
|
|
31
|
+
};
|
|
32
|
+
export type HierarchyDrawerInternalProps = {
|
|
33
|
+
/** Base filter constraint (e.g., tenant filter) to apply to all queries */
|
|
34
|
+
readonly baseFilter?: null | Where;
|
|
35
|
+
readonly closeDrawer: () => void;
|
|
36
|
+
/** IDs that should be disabled (e.g., items being moved can't be selected as destination) */
|
|
37
|
+
readonly disabledIds?: Set<number | string>;
|
|
38
|
+
readonly drawerSlug: string;
|
|
39
|
+
/**
|
|
40
|
+
* When provided, filters hierarchy items to only show those that accept these collections.
|
|
41
|
+
* Used with collectionSpecific hierarchy config.
|
|
42
|
+
*/
|
|
43
|
+
readonly filterByCollection?: string[];
|
|
44
|
+
readonly hierarchyCollectionSlug: string;
|
|
45
|
+
readonly Icon?: React.ReactNode;
|
|
46
|
+
readonly parentFieldName: string;
|
|
47
|
+
readonly useAsTitle?: string;
|
|
48
|
+
} & HierarchyDrawerProps;
|
|
49
|
+
export type HierarchyDrawerTogglerProps = {
|
|
50
|
+
children?: React.ReactNode;
|
|
51
|
+
className?: string;
|
|
52
|
+
disabled?: boolean;
|
|
53
|
+
drawerSlug?: string;
|
|
54
|
+
} & HTMLAttributes<HTMLButtonElement>;
|
|
55
|
+
export type UseHierarchyDrawer = (args: UseHierarchyDrawerArgs) => [
|
|
56
|
+
React.FC<HierarchyDrawerProps>,
|
|
57
|
+
React.FC<Omit<HierarchyDrawerTogglerProps, 'drawerSlug'>>,
|
|
58
|
+
{
|
|
59
|
+
closeDrawer: () => void;
|
|
60
|
+
drawerDepth: number;
|
|
61
|
+
drawerSlug: string;
|
|
62
|
+
isDrawerOpen: boolean;
|
|
63
|
+
openDrawer: () => void;
|
|
64
|
+
toggleDrawer: () => void;
|
|
65
|
+
}
|
|
66
|
+
];
|
|
67
|
+
export type { ColumnItemData } from '../HierarchyColumnBrowser/types.js';
|
|
68
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/elements/HierarchyDrawer/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","names":[],"sources":["../../../src/elements/HierarchyDrawer/types.ts"],"sourcesContent":["import type { Where } from 'payload'\nimport type React from 'react'\nimport type { HTMLAttributes } from 'react'\n\nexport type SelectionWithPath = {\n id: number | string\n path: Array<{ id: number | string; title: string }>\n}\n\nexport type UseHierarchyDrawerArgs = {\n /** IDs that should be disabled (e.g., items being moved can't be selected as destination) */\n disabledIds?: Set<number | string>\n /**\n * When provided, filters hierarchy items to only show those that accept these collections.\n * Used with collectionSpecific hierarchy config.\n */\n filterByCollection?: string[]\n hierarchyCollectionSlug: string\n Icon?: React.ReactNode\n}\n\nexport type HierarchyDrawerProps = {\n readonly hasMany?: boolean\n readonly initialSelections?: (number | string)[]\n readonly onMoveToRoot?: () => void\n readonly onSave: (params: {\n closeDrawer: () => void\n selections: Map<number | string, SelectionWithPath>\n }) => void\n readonly showMoveToRoot?: boolean\n}\n\nexport type HierarchyDrawerInternalProps = {\n /** Base filter constraint (e.g., tenant filter) to apply to all queries */\n readonly baseFilter?: null | Where\n readonly closeDrawer: () => void\n /** IDs that should be disabled (e.g., items being moved can't be selected as destination) */\n readonly disabledIds?: Set<number | string>\n readonly drawerSlug: string\n /**\n * When provided, filters hierarchy items to only show those that accept these collections.\n * Used with collectionSpecific hierarchy config.\n */\n readonly filterByCollection?: string[]\n readonly hierarchyCollectionSlug: string\n readonly Icon?: React.ReactNode\n readonly parentFieldName: string\n readonly useAsTitle?: string\n} & HierarchyDrawerProps\n\nexport type HierarchyDrawerTogglerProps = {\n children?: React.ReactNode\n className?: string\n disabled?: boolean\n drawerSlug?: string\n} & HTMLAttributes<HTMLButtonElement>\n\nexport type UseHierarchyDrawer = (args: UseHierarchyDrawerArgs) => [\n React.FC<HierarchyDrawerProps>,\n React.FC<Omit<HierarchyDrawerTogglerProps, 'drawerSlug'>>,\n {\n closeDrawer: () => void\n drawerDepth: number\n drawerSlug: string\n isDrawerOpen: boolean\n openDrawer: () => void\n toggleDrawer: () => void\n },\n]\n\n// Re-export column browser types for backwards compatibility\nexport type { ColumnItemData } from '../HierarchyColumnBrowser/types.js'\n"],"mappings":"AAsEA;AACA","ignoreList":[]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import './SelectedHierarchies.scss';
|
|
3
|
+
export type SelectedHierarchiesProps = {
|
|
4
|
+
hierarchySlug: string;
|
|
5
|
+
Icon?: React.ReactNode;
|
|
6
|
+
onRemove: ({ id }: {
|
|
7
|
+
id: number | string;
|
|
8
|
+
}) => void;
|
|
9
|
+
readOnly?: boolean;
|
|
10
|
+
selectedIds: (number | string)[];
|
|
11
|
+
};
|
|
12
|
+
export declare const SelectedHierarchies: React.FC<SelectedHierarchiesProps>;
|
|
13
|
+
//# sourceMappingURL=SelectedHierarchies.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SelectedHierarchies.d.ts","sourceRoot":"","sources":["../../../src/elements/HierarchyField/SelectedHierarchies.tsx"],"names":[],"mappings":"AAIA,OAAO,KAA+C,MAAM,OAAO,CAAA;AAOnE,OAAO,4BAA4B,CAAA;AASnC,MAAM,MAAM,wBAAwB,GAAG;IACrC,aAAa,EAAE,MAAM,CAAA;IACrB,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,QAAQ,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE;QAAE,EAAE,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,KAAK,IAAI,CAAA;IACnD,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,WAAW,EAAE,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,CAAA;CACjC,CAAA;AAED,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,wBAAwB,CAqIlE,CAAA"}
|
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
import { c as _c } from "react/compiler-runtime";
|
|
4
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
5
|
+
import { getTranslation } from '@payloadcms/translations';
|
|
6
|
+
import { formatAdminURL } from 'payload/shared';
|
|
7
|
+
import * as qs from 'qs-esm';
|
|
8
|
+
import React, { useEffect, useMemo, useRef, useState } from 'react';
|
|
9
|
+
import { XIcon } from '../../icons/X/index.js';
|
|
10
|
+
import { useConfig } from '../../providers/Config/index.js';
|
|
11
|
+
import { useTranslation } from '../../providers/Translation/index.js';
|
|
12
|
+
import { Pill } from '../Pill/index.js';
|
|
13
|
+
import { Spinner } from '../Spinner/index.js';
|
|
14
|
+
import './SelectedHierarchies.scss';
|
|
15
|
+
const baseClass = 'selected-hierarchies';
|
|
16
|
+
export const SelectedHierarchies = ({
|
|
17
|
+
hierarchySlug,
|
|
18
|
+
Icon,
|
|
19
|
+
onRemove,
|
|
20
|
+
readOnly = false,
|
|
21
|
+
selectedIds
|
|
22
|
+
}) => {
|
|
23
|
+
const {
|
|
24
|
+
config,
|
|
25
|
+
getEntityConfig
|
|
26
|
+
} = useConfig();
|
|
27
|
+
const {
|
|
28
|
+
i18n,
|
|
29
|
+
t
|
|
30
|
+
} = useTranslation();
|
|
31
|
+
const [items, setItems] = useState([]);
|
|
32
|
+
const [isInitialLoad, setIsInitialLoad] = useState(true);
|
|
33
|
+
const prevSelectedIdsRef = useRef('');
|
|
34
|
+
const {
|
|
35
|
+
routes: {
|
|
36
|
+
api
|
|
37
|
+
},
|
|
38
|
+
serverURL
|
|
39
|
+
} = config;
|
|
40
|
+
const collectionConfig = getEntityConfig({
|
|
41
|
+
collectionSlug: hierarchySlug
|
|
42
|
+
});
|
|
43
|
+
const selectedIdsKey = useMemo(() => selectedIds.slice().sort().join(','), [selectedIds]);
|
|
44
|
+
useEffect(() => {
|
|
45
|
+
if (!selectedIds || selectedIds.length === 0) {
|
|
46
|
+
setItems([]);
|
|
47
|
+
setIsInitialLoad(false);
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
if (prevSelectedIdsRef.current === selectedIdsKey) {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
prevSelectedIdsRef.current = selectedIdsKey;
|
|
54
|
+
const fetchItems = async () => {
|
|
55
|
+
const useAsTitle = collectionConfig?.admin?.useAsTitle || 'id';
|
|
56
|
+
const query = {
|
|
57
|
+
depth: 0,
|
|
58
|
+
limit: selectedIds.length,
|
|
59
|
+
select: {
|
|
60
|
+
[useAsTitle]: true
|
|
61
|
+
},
|
|
62
|
+
where: {
|
|
63
|
+
id: {
|
|
64
|
+
in: selectedIds
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
const queryString = qs.stringify(query);
|
|
69
|
+
try {
|
|
70
|
+
const url = formatAdminURL({
|
|
71
|
+
apiRoute: api,
|
|
72
|
+
path: `/${hierarchySlug}?${queryString}`,
|
|
73
|
+
serverURL
|
|
74
|
+
});
|
|
75
|
+
const response = await fetch(url, {
|
|
76
|
+
credentials: 'include',
|
|
77
|
+
headers: {
|
|
78
|
+
'Accept-Language': i18n.language
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
if (response.ok) {
|
|
82
|
+
const data = await response.json();
|
|
83
|
+
const fetchedItems = data.docs.map(doc => {
|
|
84
|
+
const docId = doc.id;
|
|
85
|
+
const titleValue = doc[useAsTitle] ?? docId;
|
|
86
|
+
const title = typeof titleValue === 'string' || typeof titleValue === 'number' ? String(titleValue) : String(docId);
|
|
87
|
+
return {
|
|
88
|
+
id: docId,
|
|
89
|
+
title
|
|
90
|
+
};
|
|
91
|
+
});
|
|
92
|
+
// Order by selectedIds to preserve selection order
|
|
93
|
+
const orderedItems = selectedIds.map(id => fetchedItems.find(item => item.id === id)).filter(item_0 => item_0 !== undefined);
|
|
94
|
+
setItems(orderedItems);
|
|
95
|
+
}
|
|
96
|
+
} catch {
|
|
97
|
+
// Silently fail - items will remain empty
|
|
98
|
+
} finally {
|
|
99
|
+
setIsInitialLoad(false);
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
void fetchItems();
|
|
103
|
+
}, [selectedIds, selectedIdsKey, hierarchySlug, collectionConfig, serverURL, api, i18n.language]);
|
|
104
|
+
if (isInitialLoad) {
|
|
105
|
+
return /*#__PURE__*/_jsx("div", {
|
|
106
|
+
className: `${baseClass}__loading`,
|
|
107
|
+
children: /*#__PURE__*/_jsx(Spinner, {
|
|
108
|
+
size: "small"
|
|
109
|
+
})
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
if (items.length === 0) {
|
|
113
|
+
const label = collectionConfig?.labels?.plural;
|
|
114
|
+
const translatedLabel = label ? getTranslation(label, i18n) : hierarchySlug;
|
|
115
|
+
return /*#__PURE__*/_jsx("div", {
|
|
116
|
+
className: `${baseClass}__empty`,
|
|
117
|
+
children: t('general:noLabel', {
|
|
118
|
+
label: translatedLabel
|
|
119
|
+
})
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
return /*#__PURE__*/_jsx("div", {
|
|
123
|
+
className: baseClass,
|
|
124
|
+
children: /*#__PURE__*/_jsx("div", {
|
|
125
|
+
className: `${baseClass}__pills`,
|
|
126
|
+
children: items.map(item_1 => /*#__PURE__*/_jsx(SelectedPill, {
|
|
127
|
+
Icon: Icon,
|
|
128
|
+
item: item_1,
|
|
129
|
+
onRemove: onRemove,
|
|
130
|
+
readOnly: readOnly
|
|
131
|
+
}, item_1.id))
|
|
132
|
+
})
|
|
133
|
+
});
|
|
134
|
+
};
|
|
135
|
+
const SelectedPill = t0 => {
|
|
136
|
+
const $ = _c(9);
|
|
137
|
+
const {
|
|
138
|
+
Icon,
|
|
139
|
+
item,
|
|
140
|
+
onRemove,
|
|
141
|
+
readOnly
|
|
142
|
+
} = t0;
|
|
143
|
+
const {
|
|
144
|
+
t
|
|
145
|
+
} = useTranslation();
|
|
146
|
+
let t1;
|
|
147
|
+
if ($[0] !== item.id || $[1] !== onRemove) {
|
|
148
|
+
t1 = e => {
|
|
149
|
+
e.preventDefault();
|
|
150
|
+
e.stopPropagation();
|
|
151
|
+
onRemove({
|
|
152
|
+
id: item.id
|
|
153
|
+
});
|
|
154
|
+
};
|
|
155
|
+
$[0] = item.id;
|
|
156
|
+
$[1] = onRemove;
|
|
157
|
+
$[2] = t1;
|
|
158
|
+
} else {
|
|
159
|
+
t1 = $[2];
|
|
160
|
+
}
|
|
161
|
+
const handleRemove = t1;
|
|
162
|
+
let t2;
|
|
163
|
+
if ($[3] !== Icon || $[4] !== handleRemove || $[5] !== item.title || $[6] !== readOnly || $[7] !== t) {
|
|
164
|
+
t2 = _jsxs(Pill, {
|
|
165
|
+
className: `${baseClass}__pill`,
|
|
166
|
+
pillStyle: "light",
|
|
167
|
+
size: "small",
|
|
168
|
+
children: [Boolean(Icon) && _jsx("span", {
|
|
169
|
+
className: `${baseClass}__pill-icon`,
|
|
170
|
+
children: Icon
|
|
171
|
+
}), _jsx("span", {
|
|
172
|
+
className: `${baseClass}__pill-label`,
|
|
173
|
+
children: item.title
|
|
174
|
+
}), _jsx("button", {
|
|
175
|
+
"aria-label": t("general:remove"),
|
|
176
|
+
className: `${baseClass}__pill-remove`,
|
|
177
|
+
disabled: readOnly,
|
|
178
|
+
onClick: readOnly ? undefined : handleRemove,
|
|
179
|
+
type: "button",
|
|
180
|
+
children: _jsx(XIcon, {})
|
|
181
|
+
})]
|
|
182
|
+
});
|
|
183
|
+
$[3] = Icon;
|
|
184
|
+
$[4] = handleRemove;
|
|
185
|
+
$[5] = item.title;
|
|
186
|
+
$[6] = readOnly;
|
|
187
|
+
$[7] = t;
|
|
188
|
+
$[8] = t2;
|
|
189
|
+
} else {
|
|
190
|
+
t2 = $[8];
|
|
191
|
+
}
|
|
192
|
+
return t2;
|
|
193
|
+
};
|
|
194
|
+
//# sourceMappingURL=SelectedHierarchies.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SelectedHierarchies.js","names":["c","_c","getTranslation","formatAdminURL","qs","React","useEffect","useMemo","useRef","useState","XIcon","useConfig","useTranslation","Pill","Spinner","baseClass","SelectedHierarchies","hierarchySlug","Icon","onRemove","readOnly","selectedIds","config","getEntityConfig","i18n","t","items","setItems","isInitialLoad","setIsInitialLoad","prevSelectedIdsRef","routes","api","serverURL","collectionConfig","collectionSlug","selectedIdsKey","slice","sort","join","length","current","fetchItems","useAsTitle","admin","query","depth","limit","select","where","id","in","queryString","stringify","url","apiRoute","path","response","fetch","credentials","headers","language","ok","data","json","fetchedItems","docs","map","doc","docId","titleValue","title","String","orderedItems","find","item","filter","undefined","_jsx","className","size","label","labels","plural","translatedLabel","SelectedPill","t0","$","t1","e","preventDefault","stopPropagation","handleRemove","t2","_jsxs","pillStyle","children","Boolean","disabled","onClick","type"],"sources":["../../../src/elements/HierarchyField/SelectedHierarchies.tsx"],"sourcesContent":["'use client'\nimport { getTranslation } from '@payloadcms/translations'\nimport { formatAdminURL } from 'payload/shared'\nimport * as qs from 'qs-esm'\nimport React, { useEffect, useMemo, useRef, useState } from 'react'\n\nimport { XIcon } from '../../icons/X/index.js'\nimport { useConfig } from '../../providers/Config/index.js'\nimport { useTranslation } from '../../providers/Translation/index.js'\nimport { Pill } from '../Pill/index.js'\nimport { Spinner } from '../Spinner/index.js'\nimport './SelectedHierarchies.scss'\n\nconst baseClass = 'selected-hierarchies'\n\ntype HierarchyItem = {\n id: number | string\n title: string\n}\n\nexport type SelectedHierarchiesProps = {\n hierarchySlug: string\n Icon?: React.ReactNode\n onRemove: ({ id }: { id: number | string }) => void\n readOnly?: boolean\n selectedIds: (number | string)[]\n}\n\nexport const SelectedHierarchies: React.FC<SelectedHierarchiesProps> = ({\n hierarchySlug,\n Icon,\n onRemove,\n readOnly = false,\n selectedIds,\n}) => {\n const { config, getEntityConfig } = useConfig()\n const { i18n, t } = useTranslation()\n const [items, setItems] = useState<HierarchyItem[]>([])\n const [isInitialLoad, setIsInitialLoad] = useState(true)\n\n const prevSelectedIdsRef = useRef<string>('')\n\n const {\n routes: { api },\n serverURL,\n } = config\n\n const collectionConfig = getEntityConfig({ collectionSlug: hierarchySlug })\n\n const selectedIdsKey = useMemo(() => selectedIds.slice().sort().join(','), [selectedIds])\n\n useEffect(() => {\n if (!selectedIds || selectedIds.length === 0) {\n setItems([])\n setIsInitialLoad(false)\n return\n }\n\n if (prevSelectedIdsRef.current === selectedIdsKey) {\n return\n }\n prevSelectedIdsRef.current = selectedIdsKey\n\n const fetchItems = async () => {\n const useAsTitle = collectionConfig?.admin?.useAsTitle || 'id'\n\n const query = {\n depth: 0,\n limit: selectedIds.length,\n select: {\n [useAsTitle]: true,\n },\n where: {\n id: {\n in: selectedIds,\n },\n },\n }\n\n const queryString = qs.stringify(query)\n\n try {\n const url = formatAdminURL({\n apiRoute: api,\n path: `/${hierarchySlug}?${queryString}`,\n serverURL,\n })\n\n const response = await fetch(url, {\n credentials: 'include',\n headers: {\n 'Accept-Language': i18n.language,\n },\n })\n\n if (response.ok) {\n const data = await response.json()\n const fetchedItems: HierarchyItem[] = data.docs.map((doc: Record<string, unknown>) => {\n const docId = doc.id as number | string\n const titleValue = doc[useAsTitle] ?? docId\n const title =\n typeof titleValue === 'string' || typeof titleValue === 'number'\n ? String(titleValue)\n : String(docId)\n return {\n id: docId,\n title,\n }\n })\n\n // Order by selectedIds to preserve selection order\n const orderedItems = selectedIds\n .map((id) => fetchedItems.find((item) => item.id === id))\n .filter((item): item is HierarchyItem => item !== undefined)\n\n setItems(orderedItems)\n }\n } catch {\n // Silently fail - items will remain empty\n } finally {\n setIsInitialLoad(false)\n }\n }\n\n void fetchItems()\n }, [selectedIds, selectedIdsKey, hierarchySlug, collectionConfig, serverURL, api, i18n.language])\n\n if (isInitialLoad) {\n return (\n <div className={`${baseClass}__loading`}>\n <Spinner size=\"small\" />\n </div>\n )\n }\n\n if (items.length === 0) {\n const label = collectionConfig?.labels?.plural\n const translatedLabel = label ? getTranslation(label, i18n) : hierarchySlug\n\n return (\n <div className={`${baseClass}__empty`}>\n {t('general:noLabel', { label: translatedLabel })}\n </div>\n )\n }\n\n return (\n <div className={baseClass}>\n <div className={`${baseClass}__pills`}>\n {items.map((item) => (\n <SelectedPill\n Icon={Icon}\n item={item}\n key={item.id}\n onRemove={onRemove}\n readOnly={readOnly}\n />\n ))}\n </div>\n </div>\n )\n}\n\ntype SelectedPillProps = {\n Icon?: React.ReactNode\n item: HierarchyItem\n onRemove: ({ id }: { id: number | string }) => void\n readOnly: boolean\n}\n\nconst SelectedPill: React.FC<SelectedPillProps> = ({ Icon, item, onRemove, readOnly }) => {\n const { t } = useTranslation()\n\n const handleRemove = (e: React.MouseEvent) => {\n e.preventDefault()\n e.stopPropagation()\n onRemove({ id: item.id })\n }\n\n return (\n <Pill className={`${baseClass}__pill`} pillStyle=\"light\" size=\"small\">\n {Boolean(Icon) && <span className={`${baseClass}__pill-icon`}>{Icon}</span>}\n <span className={`${baseClass}__pill-label`}>{item.title}</span>\n <button\n aria-label={t('general:remove')}\n className={`${baseClass}__pill-remove`}\n disabled={readOnly}\n onClick={readOnly ? undefined : handleRemove}\n type=\"button\"\n >\n <XIcon />\n </button>\n </Pill>\n )\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
@import '../../scss/styles.scss';
|
|
2
|
+
|
|
3
|
+
@layer payload-default {
|
|
4
|
+
.selected-hierarchies {
|
|
5
|
+
&__pills {
|
|
6
|
+
display: flex;
|
|
7
|
+
flex-wrap: wrap;
|
|
8
|
+
gap: calc(var(--base) * 0.5);
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
&__pill {
|
|
12
|
+
display: inline-flex;
|
|
13
|
+
align-items: center;
|
|
14
|
+
gap: calc(var(--base) * 0.25);
|
|
15
|
+
align-items: center;
|
|
16
|
+
background-color: var(--theme-elevation-50);
|
|
17
|
+
border: 1px solid var(--theme-elevation-150);
|
|
18
|
+
padding-inline-end: calc(var(--base) * 0.2);
|
|
19
|
+
|
|
20
|
+
.pill__label {
|
|
21
|
+
display: flex;
|
|
22
|
+
align-items: center;
|
|
23
|
+
gap: 4px;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
&__pill-label {
|
|
28
|
+
white-space: nowrap;
|
|
29
|
+
overflow: hidden;
|
|
30
|
+
text-overflow: ellipsis;
|
|
31
|
+
max-width: 200px;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
&__pill-remove {
|
|
35
|
+
display: inline-flex;
|
|
36
|
+
align-items: center;
|
|
37
|
+
justify-content: center;
|
|
38
|
+
padding: 0;
|
|
39
|
+
margin: 0;
|
|
40
|
+
border: none;
|
|
41
|
+
background: none;
|
|
42
|
+
border-radius: $style-radius-s;
|
|
43
|
+
color: inherit;
|
|
44
|
+
position: relative;
|
|
45
|
+
|
|
46
|
+
&:disabled {
|
|
47
|
+
cursor: not-allowed;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
&:hover {
|
|
51
|
+
background: var(--theme-elevation-200);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
.icon {
|
|
55
|
+
width: calc(var(--base) * 0.8);
|
|
56
|
+
height: calc(var(--base) * 0.8);
|
|
57
|
+
color: var(--theme-elevation-500);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
&__pill-tooltip {
|
|
62
|
+
white-space: nowrap;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
&__empty {
|
|
66
|
+
color: var(--theme-elevation-500);
|
|
67
|
+
font-style: italic;
|
|
68
|
+
padding: calc(var(--base) * 0.25) 0;
|
|
69
|
+
height: 26px;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
&__loading {
|
|
73
|
+
color: var(--theme-elevation-500);
|
|
74
|
+
padding: calc(var(--base) * 0.25) 0;
|
|
75
|
+
height: 26px;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { RelationshipFieldClientProps } from 'payload';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import './index.scss';
|
|
4
|
+
export type HierarchyFieldClientProps = {
|
|
5
|
+
Icon?: React.ReactNode;
|
|
6
|
+
} & RelationshipFieldClientProps;
|
|
7
|
+
export declare const HierarchyFieldClient: React.FC<HierarchyFieldClientProps>;
|
|
8
|
+
//# sourceMappingURL=index.client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.client.d.ts","sourceRoot":"","sources":["../../../src/elements/HierarchyField/index.client.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,4BAA4B,EAAE,MAAM,SAAS,CAAA;AAG3D,OAAO,KAA+B,MAAM,OAAO,CAAA;AAiBnD,OAAO,cAAc,CAAA;AAMrB,MAAM,MAAM,yBAAyB,GAAG;IACtC,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;CACvB,GAAG,4BAA4B,CAAA;AAEhC,eAAO,MAAM,oBAAoB,EAAE,KAAK,CAAC,EAAE,CAAC,yBAAyB,CAyMpE,CAAA"}
|