@payloadcms/ui 3.68.0-internal-debug.2eb12b9 → 3.68.0-internal-debug.dafc24d
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/AddNewRelation/index.js +83 -27
- package/dist/elements/AddNewRelation/index.js.map +1 -1
- package/dist/elements/AnimateHeight/index.js +13 -5
- package/dist/elements/AnimateHeight/index.js.map +1 -1
- package/dist/elements/AnimateHeight/usePatchAnimateHeight.js +2 -2
- package/dist/elements/AnimateHeight/usePatchAnimateHeight.js.map +1 -1
- package/dist/elements/AppHeader/index.js +107 -35
- package/dist/elements/AppHeader/index.js.map +1 -1
- package/dist/elements/ArrayAction/index.js +116 -36
- package/dist/elements/ArrayAction/index.js.map +1 -1
- package/dist/elements/Autosave/index.js +19 -6
- package/dist/elements/Autosave/index.js.map +1 -1
- package/dist/elements/Banner/index.js +25 -9
- package/dist/elements/Banner/index.js.map +1 -1
- package/dist/elements/BulkUpload/ActionsBar/index.js +97 -33
- package/dist/elements/BulkUpload/ActionsBar/index.js.map +1 -1
- package/dist/elements/BulkUpload/AddFilesView/index.js +43 -15
- package/dist/elements/BulkUpload/AddFilesView/index.js.map +1 -1
- package/dist/elements/BulkUpload/AddingFilesView/index.js +47 -15
- package/dist/elements/BulkUpload/AddingFilesView/index.js.map +1 -1
- package/dist/elements/BulkUpload/DiscardWithoutSaving/index.js +7 -3
- package/dist/elements/BulkUpload/DiscardWithoutSaving/index.js.map +1 -1
- package/dist/elements/BulkUpload/DrawerCloseButton/index.js +12 -4
- package/dist/elements/BulkUpload/DrawerCloseButton/index.js.map +1 -1
- package/dist/elements/BulkUpload/EditForm/index.js +53 -17
- package/dist/elements/BulkUpload/EditForm/index.js.map +1 -1
- package/dist/elements/BulkUpload/EditMany/DrawerContent.js +90 -30
- package/dist/elements/BulkUpload/EditMany/DrawerContent.js.map +1 -1
- package/dist/elements/BulkUpload/EditMany/index.js +33 -13
- package/dist/elements/BulkUpload/EditMany/index.js.map +1 -1
- package/dist/elements/BulkUpload/FileSidebar/index.js +214 -70
- package/dist/elements/BulkUpload/FileSidebar/index.js.map +1 -1
- package/dist/elements/BulkUpload/FormsManager/index.js +21 -13
- package/dist/elements/BulkUpload/FormsManager/index.js.map +1 -1
- package/dist/elements/BulkUpload/Header/index.js +19 -7
- package/dist/elements/BulkUpload/Header/index.js.map +1 -1
- package/dist/elements/BulkUpload/index.js +70 -19
- package/dist/elements/BulkUpload/index.js.map +1 -1
- package/dist/elements/Button/index.js +103 -35
- package/dist/elements/Button/index.js.map +1 -1
- package/dist/elements/Button/types.js +13 -1
- package/dist/elements/Button/types.js.map +1 -1
- package/dist/elements/Card/index.js +30 -10
- package/dist/elements/Card/index.js.map +1 -1
- package/dist/elements/CheckboxPopup/index.js +19 -7
- package/dist/elements/CheckboxPopup/index.js.map +1 -1
- package/dist/elements/ClipboardAction/ClipboardActionLabel.js +16 -4
- package/dist/elements/ClipboardAction/ClipboardActionLabel.js.map +1 -1
- package/dist/elements/ClipboardAction/index.js +42 -14
- package/dist/elements/ClipboardAction/index.js.map +1 -1
- package/dist/elements/CloseModalButton/index.js +12 -4
- package/dist/elements/CloseModalButton/index.js.map +1 -1
- package/dist/elements/CodeEditor/CodeEditor.js +15 -7
- package/dist/elements/CodeEditor/CodeEditor.js.map +1 -1
- package/dist/elements/CodeEditor/index.js +18 -6
- package/dist/elements/CodeEditor/index.js.map +1 -1
- package/dist/elements/CodeEditor/types.js +3 -1
- package/dist/elements/CodeEditor/types.js.map +1 -1
- package/dist/elements/Collapsible/index.js +92 -29
- package/dist/elements/Collapsible/index.js.map +1 -1
- package/dist/elements/Collapsible/provider.js +7 -3
- package/dist/elements/Collapsible/provider.js.map +1 -1
- package/dist/elements/ColumnSelector/index.js +13 -5
- package/dist/elements/ColumnSelector/index.js.map +1 -1
- package/dist/elements/Combobox/index.js +43 -13
- package/dist/elements/Combobox/index.js.map +1 -1
- package/dist/elements/ConfirmationModal/index.js +49 -17
- package/dist/elements/ConfirmationModal/index.js.map +1 -1
- package/dist/elements/CopyLocaleData/index.js +73 -25
- package/dist/elements/CopyLocaleData/index.js.map +1 -1
- package/dist/elements/CopyToClipboard/index.js +18 -6
- package/dist/elements/CopyToClipboard/index.js.map +1 -1
- package/dist/elements/DatePicker/DatePicker.js +42 -13
- package/dist/elements/DatePicker/DatePicker.js.map +1 -1
- package/dist/elements/DatePicker/getFormattedLocale.js +1 -0
- package/dist/elements/DatePicker/getFormattedLocale.js.map +1 -1
- package/dist/elements/DatePicker/index.js +19 -7
- package/dist/elements/DatePicker/index.js.map +1 -1
- package/dist/elements/DefaultListViewTabs/index.js +25 -9
- package/dist/elements/DefaultListViewTabs/index.js.map +1 -1
- package/dist/elements/DeleteDocument/index.js +49 -17
- package/dist/elements/DeleteDocument/index.js.map +1 -1
- package/dist/elements/DeleteMany/index.js +98 -26
- package/dist/elements/DeleteMany/index.js.map +1 -1
- package/dist/elements/DocumentControls/index.js +304 -96
- package/dist/elements/DocumentControls/index.js.map +1 -1
- package/dist/elements/DocumentDrawer/DrawerContent.js +12 -4
- package/dist/elements/DocumentDrawer/DrawerContent.js.map +1 -1
- package/dist/elements/DocumentDrawer/DrawerHeader/index.js +59 -19
- package/dist/elements/DocumentDrawer/DrawerHeader/index.js.map +1 -1
- package/dist/elements/DocumentDrawer/Provider.js +12 -4
- package/dist/elements/DocumentDrawer/Provider.js.map +1 -1
- package/dist/elements/DocumentDrawer/index.js +32 -10
- package/dist/elements/DocumentDrawer/index.js.map +1 -1
- package/dist/elements/DocumentDrawer/types.js +11 -1
- package/dist/elements/DocumentDrawer/types.js.map +1 -1
- package/dist/elements/DocumentFields/index.js +54 -18
- package/dist/elements/DocumentFields/index.js.map +1 -1
- package/dist/elements/DocumentLocked/index.js +73 -25
- package/dist/elements/DocumentLocked/index.js.map +1 -1
- package/dist/elements/DocumentTakeOver/index.js +49 -17
- package/dist/elements/DocumentTakeOver/index.js.map +1 -1
- package/dist/elements/DraggableSortable/DraggableSortableItem/index.js +7 -3
- package/dist/elements/DraggableSortable/DraggableSortableItem/index.js.map +1 -1
- package/dist/elements/DraggableSortable/index.js +19 -7
- package/dist/elements/DraggableSortable/index.js.map +1 -1
- package/dist/elements/DraggableSortable/useDraggableSortable/index.js +1 -0
- package/dist/elements/DraggableSortable/useDraggableSortable/index.js.map +1 -1
- package/dist/elements/Drawer/index.js +80 -26
- package/dist/elements/Drawer/index.js.map +1 -1
- package/dist/elements/DrawerActionHeader/index.js +37 -13
- package/dist/elements/DrawerActionHeader/index.js.map +1 -1
- package/dist/elements/DrawerContentContainer/index.js +7 -3
- package/dist/elements/DrawerContentContainer/index.js.map +1 -1
- package/dist/elements/Dropzone/index.js +7 -3
- package/dist/elements/Dropzone/index.js.map +1 -1
- package/dist/elements/DuplicateDocument/SelectLocalesDrawer/index.js +61 -21
- package/dist/elements/DuplicateDocument/SelectLocalesDrawer/index.js.map +1 -1
- package/dist/elements/DuplicateDocument/index.js +25 -9
- package/dist/elements/DuplicateDocument/index.js.map +1 -1
- package/dist/elements/EditMany/DrawerContent.js +146 -44
- package/dist/elements/EditMany/DrawerContent.js.map +1 -1
- package/dist/elements/EditMany/index.js +40 -14
- package/dist/elements/EditMany/index.js.map +1 -1
- package/dist/elements/EditUpload/index.js +232 -76
- package/dist/elements/EditUpload/index.js.map +1 -1
- package/dist/elements/EmailAndUsername/index.js +31 -11
- package/dist/elements/EmailAndUsername/index.js.map +1 -1
- package/dist/elements/ErrorPill/index.js +19 -7
- package/dist/elements/ErrorPill/index.js.map +1 -1
- package/dist/elements/FieldDiffContainer/index.js +25 -9
- package/dist/elements/FieldDiffContainer/index.js.map +1 -1
- package/dist/elements/FieldDiffLabel/index.js +7 -3
- package/dist/elements/FieldDiffLabel/index.js.map +1 -1
- package/dist/elements/FieldSelect/index.js +19 -7
- package/dist/elements/FieldSelect/index.js.map +1 -1
- package/dist/elements/FileDetails/DraggableFileDetails/index.js +70 -22
- package/dist/elements/FileDetails/DraggableFileDetails/index.js.map +1 -1
- package/dist/elements/FileDetails/FileMeta/index.js +43 -15
- package/dist/elements/FileDetails/FileMeta/index.js.map +1 -1
- package/dist/elements/FileDetails/StaticFileDetails/index.js +43 -15
- package/dist/elements/FileDetails/StaticFileDetails/index.js.map +1 -1
- package/dist/elements/FileDetails/index.js +13 -5
- package/dist/elements/FileDetails/index.js.map +1 -1
- package/dist/elements/FolderView/Breadcrumbs/index.js +31 -11
- package/dist/elements/FolderView/Breadcrumbs/index.js.map +1 -1
- package/dist/elements/FolderView/BrowseByFolderButton/index.js +12 -4
- package/dist/elements/FolderView/BrowseByFolderButton/index.js.map +1 -1
- package/dist/elements/FolderView/Cell/index.client.js +7 -3
- package/dist/elements/FolderView/Cell/index.client.js.map +1 -1
- package/dist/elements/FolderView/Cell/index.server.js +7 -3
- package/dist/elements/FolderView/Cell/index.server.js.map +1 -1
- package/dist/elements/FolderView/ColoredFolderIcon/index.js +7 -3
- package/dist/elements/FolderView/ColoredFolderIcon/index.js.map +1 -1
- package/dist/elements/FolderView/CurrentFolderActions/index.js +68 -24
- package/dist/elements/FolderView/CurrentFolderActions/index.js.map +1 -1
- package/dist/elements/FolderView/DragOverlaySelection/index.js +31 -11
- package/dist/elements/FolderView/DragOverlaySelection/index.js.map +1 -1
- package/dist/elements/FolderView/DraggableTableRow/index.js +25 -9
- package/dist/elements/FolderView/DraggableTableRow/index.js.map +1 -1
- package/dist/elements/FolderView/DraggableWithClick/index.js +7 -3
- package/dist/elements/FolderView/DraggableWithClick/index.js.map +1 -1
- package/dist/elements/FolderView/Drawers/EditFolderAction/index.js +15 -7
- package/dist/elements/FolderView/Drawers/EditFolderAction/index.js.map +1 -1
- package/dist/elements/FolderView/Drawers/MoveToFolder/index.js +189 -62
- package/dist/elements/FolderView/Drawers/MoveToFolder/index.js.map +1 -1
- package/dist/elements/FolderView/FilterFolderTypePill/index.js +19 -7
- package/dist/elements/FolderView/FilterFolderTypePill/index.js.map +1 -1
- package/dist/elements/FolderView/FolderField/index.server.js +7 -3
- package/dist/elements/FolderView/FolderField/index.server.js.map +1 -1
- package/dist/elements/FolderView/FolderFileCard/index.js +104 -31
- package/dist/elements/FolderView/FolderFileCard/index.js.map +1 -1
- package/dist/elements/FolderView/FolderFileTable/index.js +49 -17
- package/dist/elements/FolderView/FolderFileTable/index.js.map +1 -1
- package/dist/elements/FolderView/FolderTypeField/index.js +7 -3
- package/dist/elements/FolderView/FolderTypeField/index.js.map +1 -1
- package/dist/elements/FolderView/ItemCardGrid/index.js +21 -9
- package/dist/elements/FolderView/ItemCardGrid/index.js.map +1 -1
- package/dist/elements/FolderView/MoveDocToFolder/index.js +28 -13
- package/dist/elements/FolderView/MoveDocToFolder/index.js.map +1 -1
- package/dist/elements/FolderView/SimpleTable/index.js +67 -23
- package/dist/elements/FolderView/SimpleTable/index.js.map +1 -1
- package/dist/elements/FolderView/SortByPill/index.js +86 -30
- package/dist/elements/FolderView/SortByPill/index.js.map +1 -1
- package/dist/elements/FolderView/ToggleViewButtons/index.js +25 -9
- package/dist/elements/FolderView/ToggleViewButtons/index.js.map +1 -1
- package/dist/elements/FullscreenModal/index.js +7 -3
- package/dist/elements/FullscreenModal/index.js.map +1 -1
- package/dist/elements/GenerateConfirmation/index.js +31 -11
- package/dist/elements/GenerateConfirmation/index.js.map +1 -1
- package/dist/elements/GroupByBuilder/index.js +43 -15
- package/dist/elements/GroupByBuilder/index.js.map +1 -1
- package/dist/elements/Gutter/index.js +7 -3
- package/dist/elements/Gutter/index.js.map +1 -1
- package/dist/elements/HTMLDiff/diff/index.js +24 -3
- package/dist/elements/HTMLDiff/diff/index.js.map +1 -1
- package/dist/elements/HTMLDiff/index.js +13 -5
- package/dist/elements/HTMLDiff/index.js.map +1 -1
- package/dist/elements/Hamburger/index.js +35 -11
- package/dist/elements/Hamburger/index.js.map +1 -1
- package/dist/elements/HydrateAuthProvider/index.js +6 -1
- package/dist/elements/HydrateAuthProvider/index.js.map +1 -1
- package/dist/elements/IDLabel/index.js +13 -5
- package/dist/elements/IDLabel/index.js.map +1 -1
- package/dist/elements/LeaveWithoutSaving/index.js +13 -5
- package/dist/elements/LeaveWithoutSaving/index.js.map +1 -1
- package/dist/elements/LeaveWithoutSaving/usePreventLeave.js +3 -1
- package/dist/elements/LeaveWithoutSaving/usePreventLeave.js.map +1 -1
- package/dist/elements/Link/index.js +12 -4
- package/dist/elements/Link/index.js.map +1 -1
- package/dist/elements/ListControls/index.js +126 -42
- package/dist/elements/ListControls/index.js.map +1 -1
- package/dist/elements/ListControls/types.js +7 -1
- package/dist/elements/ListControls/types.js.map +1 -1
- package/dist/elements/ListDrawer/DrawerContent.js +20 -8
- package/dist/elements/ListDrawer/DrawerContent.js.map +1 -1
- package/dist/elements/ListDrawer/Provider.js +15 -4
- package/dist/elements/ListDrawer/Provider.js.map +1 -1
- package/dist/elements/ListDrawer/index.js +34 -11
- package/dist/elements/ListDrawer/index.js.map +1 -1
- package/dist/elements/ListDrawer/types.js +5 -1
- package/dist/elements/ListDrawer/types.js.map +1 -1
- package/dist/elements/ListHeader/DrawerRelationshipSelect/index.js +19 -7
- package/dist/elements/ListHeader/DrawerRelationshipSelect/index.js.map +1 -1
- package/dist/elements/ListHeader/DrawerTitleActions/ListDrawerCreateNewDocButton.js +13 -5
- package/dist/elements/ListHeader/DrawerTitleActions/ListDrawerCreateNewDocButton.js.map +1 -1
- package/dist/elements/ListHeader/TitleActions/ListBulkUploadButton.js +12 -4
- package/dist/elements/ListHeader/TitleActions/ListBulkUploadButton.js.map +1 -1
- package/dist/elements/ListHeader/TitleActions/ListCreateNewDocButton.js +7 -3
- package/dist/elements/ListHeader/TitleActions/ListCreateNewDocButton.js.map +1 -1
- package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.js +48 -16
- package/dist/elements/ListHeader/TitleActions/ListCreateNewDocInFolderButton.js.map +1 -1
- package/dist/elements/ListHeader/TitleActions/ListEmptyTrashButton.js +37 -13
- package/dist/elements/ListHeader/TitleActions/ListEmptyTrashButton.js.map +1 -1
- package/dist/elements/ListHeader/index.js +43 -15
- package/dist/elements/ListHeader/index.js.map +1 -1
- package/dist/elements/ListSelection/index.js +66 -20
- package/dist/elements/ListSelection/index.js.map +1 -1
- package/dist/elements/LivePreview/Device/index.js +13 -5
- package/dist/elements/LivePreview/Device/index.js.map +1 -1
- package/dist/elements/LivePreview/DeviceContainer/index.js +7 -3
- package/dist/elements/LivePreview/DeviceContainer/index.js.map +1 -1
- package/dist/elements/LivePreview/IFrame/index.js +7 -3
- package/dist/elements/LivePreview/IFrame/index.js.map +1 -1
- package/dist/elements/LivePreview/Toggler/index.js +13 -5
- package/dist/elements/LivePreview/Toggler/index.js.map +1 -1
- package/dist/elements/LivePreview/Toolbar/Controls/index.js +137 -45
- package/dist/elements/LivePreview/Toolbar/Controls/index.js.map +1 -1
- package/dist/elements/LivePreview/Toolbar/SizeInput/index.js +7 -3
- package/dist/elements/LivePreview/Toolbar/SizeInput/index.js.map +1 -1
- package/dist/elements/LivePreview/Toolbar/index.js +48 -16
- package/dist/elements/LivePreview/Toolbar/index.js.map +1 -1
- package/dist/elements/LivePreview/ToolbarArea/index.js +7 -3
- package/dist/elements/LivePreview/ToolbarArea/index.js.map +1 -1
- package/dist/elements/LivePreview/Window/index.js +41 -13
- package/dist/elements/LivePreview/Window/index.js.map +1 -1
- package/dist/elements/Loading/index.js +55 -19
- package/dist/elements/Loading/index.js.map +1 -1
- package/dist/elements/LoadingOverlay/index.js +13 -5
- package/dist/elements/LoadingOverlay/index.js.map +1 -1
- package/dist/elements/Localizer/LocalizerLabel/index.js +31 -11
- package/dist/elements/Localizer/LocalizerLabel/index.js.map +1 -1
- package/dist/elements/Localizer/index.js +47 -15
- package/dist/elements/Localizer/index.js.map +1 -1
- package/dist/elements/Locked/index.js +18 -6
- package/dist/elements/Locked/index.js.map +1 -1
- package/dist/elements/Logout/index.js +17 -5
- package/dist/elements/Logout/index.js.map +1 -1
- package/dist/elements/Nav/NavToggler/index.js +7 -3
- package/dist/elements/Nav/NavToggler/index.js.map +1 -1
- package/dist/elements/Nav/context.js +7 -3
- package/dist/elements/Nav/context.js.map +1 -1
- package/dist/elements/NavGroup/index.js +49 -17
- package/dist/elements/NavGroup/index.js.map +1 -1
- package/dist/elements/NoListResults/index.js +19 -7
- package/dist/elements/NoListResults/index.js.map +1 -1
- package/dist/elements/PageControls/GroupByPageControls.js +7 -3
- package/dist/elements/PageControls/GroupByPageControls.js.map +1 -1
- package/dist/elements/PageControls/index.js +37 -13
- package/dist/elements/PageControls/index.js.map +1 -1
- package/dist/elements/Pagination/ClickableArrow/index.js +12 -4
- package/dist/elements/Pagination/ClickableArrow/index.js.map +1 -1
- package/dist/elements/Pagination/Page/index.js +7 -3
- package/dist/elements/Pagination/Page/index.js.map +1 -1
- package/dist/elements/Pagination/Separator/index.js +7 -3
- package/dist/elements/Pagination/Separator/index.js.map +1 -1
- package/dist/elements/Pagination/index.js +19 -7
- package/dist/elements/Pagination/index.js.map +1 -1
- package/dist/elements/PerPage/index.js +61 -21
- package/dist/elements/PerPage/index.js.map +1 -1
- package/dist/elements/PermanentlyDeleteButton/index.js +31 -11
- package/dist/elements/PermanentlyDeleteButton/index.js.map +1 -1
- package/dist/elements/Pill/index.js +42 -15
- package/dist/elements/Pill/index.js.map +1 -1
- package/dist/elements/PillSelector/index.js +34 -10
- package/dist/elements/PillSelector/index.js.map +1 -1
- package/dist/elements/Popup/PopupButtonList/index.js +25 -9
- package/dist/elements/Popup/PopupButtonList/index.js.map +1 -1
- package/dist/elements/Popup/PopupDivider/index.js +7 -3
- package/dist/elements/Popup/PopupDivider/index.js.map +1 -1
- package/dist/elements/Popup/PopupGroupLabel/index.js +7 -3
- package/dist/elements/Popup/PopupGroupLabel/index.js.map +1 -1
- package/dist/elements/Popup/PopupTrigger/index.js +13 -5
- package/dist/elements/Popup/PopupTrigger/index.js.map +1 -1
- package/dist/elements/Popup/index.js +60 -20
- package/dist/elements/Popup/index.js.map +1 -1
- package/dist/elements/PreviewButton/index.js +12 -4
- package/dist/elements/PreviewButton/index.js.map +1 -1
- package/dist/elements/PreviewSizes/index.js +97 -33
- package/dist/elements/PreviewSizes/index.js.map +1 -1
- package/dist/elements/PublishButton/ScheduleDrawer/buildUpcomingColumns.js +67 -23
- package/dist/elements/PublishButton/ScheduleDrawer/buildUpcomingColumns.js.map +1 -1
- package/dist/elements/PublishButton/ScheduleDrawer/index.js +165 -53
- package/dist/elements/PublishButton/ScheduleDrawer/index.js.map +1 -1
- package/dist/elements/PublishButton/index.js +49 -17
- package/dist/elements/PublishButton/index.js.map +1 -1
- package/dist/elements/PublishMany/DrawerContent.js +7 -3
- package/dist/elements/PublishMany/DrawerContent.js.map +1 -1
- package/dist/elements/PublishMany/index.js +28 -10
- package/dist/elements/PublishMany/index.js.map +1 -1
- package/dist/elements/QueryPresets/QueryPresetBar/index.js +109 -38
- package/dist/elements/QueryPresets/QueryPresetBar/index.js.map +1 -1
- package/dist/elements/QueryPresets/QueryPresetToggler/index.js +42 -14
- package/dist/elements/QueryPresets/QueryPresetToggler/index.js.map +1 -1
- package/dist/elements/QueryPresets/cells/AccessCell/index.js +25 -9
- package/dist/elements/QueryPresets/cells/AccessCell/index.js.map +1 -1
- package/dist/elements/QueryPresets/cells/ColumnsCell/index.js +13 -5
- package/dist/elements/QueryPresets/cells/ColumnsCell/index.js.map +1 -1
- package/dist/elements/QueryPresets/cells/GroupByCell/index.js +13 -5
- package/dist/elements/QueryPresets/cells/GroupByCell/index.js.map +1 -1
- package/dist/elements/QueryPresets/cells/WhereCell/index.js +7 -3
- package/dist/elements/QueryPresets/cells/WhereCell/index.js.map +1 -1
- package/dist/elements/QueryPresets/fields/ColumnsField/index.js +25 -9
- package/dist/elements/QueryPresets/fields/ColumnsField/index.js.map +1 -1
- package/dist/elements/QueryPresets/fields/GroupByField/index.js +31 -11
- package/dist/elements/QueryPresets/fields/GroupByField/index.js.map +1 -1
- package/dist/elements/QueryPresets/fields/WhereField/index.js +79 -27
- package/dist/elements/QueryPresets/fields/WhereField/index.js.map +1 -1
- package/dist/elements/ReactSelect/ClearIndicator/index.js +13 -5
- package/dist/elements/ReactSelect/ClearIndicator/index.js.map +1 -1
- package/dist/elements/ReactSelect/Control/index.js +13 -5
- package/dist/elements/ReactSelect/Control/index.js.map +1 -1
- package/dist/elements/ReactSelect/DropdownIndicator/index.js +13 -5
- package/dist/elements/ReactSelect/DropdownIndicator/index.js.map +1 -1
- package/dist/elements/ReactSelect/Input/index.js +13 -5
- package/dist/elements/ReactSelect/Input/index.js.map +1 -1
- package/dist/elements/ReactSelect/MultiValue/index.js +13 -5
- package/dist/elements/ReactSelect/MultiValue/index.js.map +1 -1
- package/dist/elements/ReactSelect/MultiValueLabel/index.js +13 -5
- package/dist/elements/ReactSelect/MultiValueLabel/index.js.map +1 -1
- package/dist/elements/ReactSelect/MultiValueRemove/index.js +19 -7
- package/dist/elements/ReactSelect/MultiValueRemove/index.js.map +1 -1
- package/dist/elements/ReactSelect/SingleValue/index.js +13 -5
- package/dist/elements/ReactSelect/SingleValue/index.js.map +1 -1
- package/dist/elements/ReactSelect/ValueContainer/index.js +19 -7
- package/dist/elements/ReactSelect/ValueContainer/index.js.map +1 -1
- package/dist/elements/ReactSelect/index.js +45 -17
- package/dist/elements/ReactSelect/index.js.map +1 -1
- package/dist/elements/ReactSelect/types.js +8 -1
- package/dist/elements/ReactSelect/types.js.map +1 -1
- package/dist/elements/RelationshipTable/AddNewButton.js +37 -13
- package/dist/elements/RelationshipTable/AddNewButton.js.map +1 -1
- package/dist/elements/RelationshipTable/Pagination.js +7 -3
- package/dist/elements/RelationshipTable/Pagination.js.map +1 -1
- package/dist/elements/RelationshipTable/cells/DrawerLink/index.js +24 -8
- package/dist/elements/RelationshipTable/cells/DrawerLink/index.js.map +1 -1
- package/dist/elements/RelationshipTable/index.js +121 -41
- package/dist/elements/RelationshipTable/index.js.map +1 -1
- package/dist/elements/RenderComponent/index.js +19 -7
- package/dist/elements/RenderComponent/index.js.map +1 -1
- package/dist/elements/RenderIfInViewport/index.js +7 -3
- package/dist/elements/RenderIfInViewport/index.js.map +1 -1
- package/dist/elements/RenderServerComponent/index.js +13 -5
- package/dist/elements/RenderServerComponent/index.js.map +1 -1
- package/dist/elements/RenderTitle/index.js +25 -9
- package/dist/elements/RenderTitle/index.js.map +1 -1
- package/dist/elements/RestoreButton/index.js +49 -17
- package/dist/elements/RestoreButton/index.js.map +1 -1
- package/dist/elements/RestoreMany/index.js +38 -13
- package/dist/elements/RestoreMany/index.js.map +1 -1
- package/dist/elements/SaveButton/index.js +8 -5
- package/dist/elements/SaveButton/index.js.map +1 -1
- package/dist/elements/SaveDraftButton/index.js +8 -5
- package/dist/elements/SaveDraftButton/index.js.map +1 -1
- package/dist/elements/SearchBar/index.js +24 -8
- package/dist/elements/SearchBar/index.js.map +1 -1
- package/dist/elements/SearchFilter/index.js +13 -5
- package/dist/elements/SearchFilter/index.js.map +1 -1
- package/dist/elements/SearchFilter/types.js +19 -1
- package/dist/elements/SearchFilter/types.js.map +1 -1
- package/dist/elements/SelectAll/index.js +7 -3
- package/dist/elements/SelectAll/index.js.map +1 -1
- package/dist/elements/SelectMany/index.js +7 -3
- package/dist/elements/SelectMany/index.js.map +1 -1
- package/dist/elements/SelectRow/index.js +13 -5
- package/dist/elements/SelectRow/index.js.map +1 -1
- package/dist/elements/ShimmerEffect/index.js +31 -11
- package/dist/elements/ShimmerEffect/index.js.map +1 -1
- package/dist/elements/SortColumn/index.js +48 -16
- package/dist/elements/SortColumn/index.js.map +1 -1
- package/dist/elements/SortComplex/index.js +55 -19
- package/dist/elements/SortComplex/index.js.map +1 -1
- package/dist/elements/SortHeader/index.js +24 -8
- package/dist/elements/SortHeader/index.js.map +1 -1
- package/dist/elements/SortRow/index.js +13 -5
- package/dist/elements/SortRow/index.js.map +1 -1
- package/dist/elements/Status/index.js +63 -23
- package/dist/elements/Status/index.js.map +1 -1
- package/dist/elements/StayLoggedIn/index.js +7 -3
- package/dist/elements/StayLoggedIn/index.js.map +1 -1
- package/dist/elements/StepNav/context.js +7 -3
- package/dist/elements/StepNav/context.js.map +1 -1
- package/dist/elements/StepNav/index.js +109 -33
- package/dist/elements/StepNav/index.js.map +1 -1
- package/dist/elements/StickyToolbar/index.js +7 -3
- package/dist/elements/StickyToolbar/index.js.map +1 -1
- package/dist/elements/Table/DefaultCell/fields/Array/index.js +7 -3
- package/dist/elements/Table/DefaultCell/fields/Array/index.js.map +1 -1
- package/dist/elements/Table/DefaultCell/fields/Blocks/index.js +7 -3
- package/dist/elements/Table/DefaultCell/fields/Blocks/index.js.map +1 -1
- package/dist/elements/Table/DefaultCell/fields/Checkbox/index.js +13 -5
- package/dist/elements/Table/DefaultCell/fields/Checkbox/index.js.map +1 -1
- package/dist/elements/Table/DefaultCell/fields/Code/index.js +13 -5
- package/dist/elements/Table/DefaultCell/fields/Code/index.js.map +1 -1
- package/dist/elements/Table/DefaultCell/fields/Date/index.js +7 -3
- package/dist/elements/Table/DefaultCell/fields/Date/index.js.map +1 -1
- package/dist/elements/Table/DefaultCell/fields/File/index.js +21 -9
- package/dist/elements/Table/DefaultCell/fields/File/index.js.map +1 -1
- package/dist/elements/Table/DefaultCell/fields/JSON/index.js +13 -5
- package/dist/elements/Table/DefaultCell/fields/JSON/index.js.map +1 -1
- package/dist/elements/Table/DefaultCell/fields/Relationship/index.js +19 -7
- package/dist/elements/Table/DefaultCell/fields/Relationship/index.js.map +1 -1
- package/dist/elements/Table/DefaultCell/fields/Select/index.js +11 -7
- package/dist/elements/Table/DefaultCell/fields/Select/index.js.map +1 -1
- package/dist/elements/Table/DefaultCell/fields/Textarea/index.js +7 -3
- package/dist/elements/Table/DefaultCell/fields/Textarea/index.js.map +1 -1
- package/dist/elements/Table/DefaultCell/index.js +45 -16
- package/dist/elements/Table/DefaultCell/index.js.map +1 -1
- package/dist/elements/Table/OrderableRow.js +25 -9
- package/dist/elements/Table/OrderableRow.js.map +1 -1
- package/dist/elements/Table/OrderableRowDragPreview.js +19 -7
- package/dist/elements/Table/OrderableRowDragPreview.js.map +1 -1
- package/dist/elements/Table/OrderableTable.js +79 -27
- package/dist/elements/Table/OrderableTable.js.map +1 -1
- package/dist/elements/Table/RelationshipProvider/index.js +10 -3
- package/dist/elements/Table/RelationshipProvider/index.js.map +1 -1
- package/dist/elements/Table/index.js +55 -19
- package/dist/elements/Table/index.js.map +1 -1
- package/dist/elements/Thumbnail/createThumbnail.js +12 -12
- package/dist/elements/Thumbnail/createThumbnail.js.map +1 -1
- package/dist/elements/Thumbnail/index.js +47 -15
- package/dist/elements/Thumbnail/index.js.map +1 -1
- package/dist/elements/ThumbnailCard/index.js +19 -7
- package/dist/elements/ThumbnailCard/index.js.map +1 -1
- package/dist/elements/TimezonePicker/index.js +19 -7
- package/dist/elements/TimezonePicker/index.js.map +1 -1
- package/dist/elements/Toasts/fieldErrors.js +24 -8
- package/dist/elements/Toasts/fieldErrors.js.map +1 -1
- package/dist/elements/Tooltip/index.js +34 -12
- package/dist/elements/Tooltip/index.js.map +1 -1
- package/dist/elements/Translation/index.js +25 -9
- package/dist/elements/Translation/index.js.map +1 -1
- package/dist/elements/TrashBanner/index.js +18 -6
- package/dist/elements/TrashBanner/index.js.map +1 -1
- package/dist/elements/UnpublishMany/DrawerContent.js +7 -3
- package/dist/elements/UnpublishMany/DrawerContent.js.map +1 -1
- package/dist/elements/UnpublishMany/index.js +28 -10
- package/dist/elements/UnpublishMany/index.js.map +1 -1
- package/dist/elements/Upload/index.js +235 -83
- package/dist/elements/Upload/index.js.map +1 -1
- package/dist/elements/ViewDescription/index.js +7 -3
- package/dist/elements/ViewDescription/index.js.map +1 -1
- package/dist/elements/WhereBuilder/Condition/Date/index.js +13 -5
- package/dist/elements/WhereBuilder/Condition/Date/index.js.map +1 -1
- package/dist/elements/WhereBuilder/Condition/DefaultFilter/index.js +37 -13
- package/dist/elements/WhereBuilder/Condition/DefaultFilter/index.js.map +1 -1
- package/dist/elements/WhereBuilder/Condition/Number/index.js +13 -4
- package/dist/elements/WhereBuilder/Condition/Number/index.js.map +1 -1
- package/dist/elements/WhereBuilder/Condition/Relationship/index.js +23 -12
- package/dist/elements/WhereBuilder/Condition/Relationship/index.js.map +1 -1
- package/dist/elements/WhereBuilder/Condition/Select/index.js +7 -3
- package/dist/elements/WhereBuilder/Condition/Select/index.js.map +1 -1
- package/dist/elements/WhereBuilder/Condition/Text/index.js +13 -4
- package/dist/elements/WhereBuilder/Condition/Text/index.js.map +1 -1
- package/dist/elements/WhereBuilder/Condition/index.js +73 -25
- package/dist/elements/WhereBuilder/Condition/index.js.map +1 -1
- package/dist/elements/WhereBuilder/index.js +87 -31
- package/dist/elements/WhereBuilder/index.js.map +1 -1
- package/dist/elements/WithServerSideProps/index.js +7 -3
- package/dist/elements/WithServerSideProps/index.js.map +1 -1
- package/dist/elements/withMergedProps/index.js +7 -3
- package/dist/elements/withMergedProps/index.js.map +1 -1
- package/dist/exports/client/index.js +26 -2
- package/dist/exports/client/index.js.map +1 -1
- package/dist/exports/shared/index.js +2 -1
- package/dist/exports/shared/index.js.map +1 -1
- package/dist/fields/Array/ArrayRow.js +52 -16
- package/dist/fields/Array/ArrayRow.js.map +1 -1
- package/dist/fields/Array/index.js +169 -57
- package/dist/fields/Array/index.js.map +1 -1
- package/dist/fields/Blocks/BlockRow.js +72 -24
- package/dist/fields/Blocks/BlockRow.js.map +1 -1
- package/dist/fields/Blocks/BlockSelector/BlockSearch/index.js +18 -6
- package/dist/fields/Blocks/BlockSelector/BlockSearch/index.js.map +1 -1
- package/dist/fields/Blocks/BlockSelector/index.js +74 -24
- package/dist/fields/Blocks/BlockSelector/index.js.map +1 -1
- package/dist/fields/Blocks/BlocksDrawer/index.js +13 -5
- package/dist/fields/Blocks/BlocksDrawer/index.js.map +1 -1
- package/dist/fields/Blocks/RowActions.js +19 -7
- package/dist/fields/Blocks/RowActions.js.map +1 -1
- package/dist/fields/Blocks/SectionTitle/index.js +13 -5
- package/dist/fields/Blocks/SectionTitle/index.js.map +1 -1
- package/dist/fields/Blocks/index.js +187 -63
- package/dist/fields/Blocks/index.js.map +1 -1
- package/dist/fields/Checkbox/Input.js +47 -15
- package/dist/fields/Checkbox/Input.js.map +1 -1
- package/dist/fields/Checkbox/index.js +37 -13
- package/dist/fields/Checkbox/index.js.map +1 -1
- package/dist/fields/Code/index.js +55 -19
- package/dist/fields/Code/index.js.map +1 -1
- package/dist/fields/Collapsible/index.js +61 -21
- package/dist/fields/Collapsible/index.js.map +1 -1
- package/dist/fields/ConfirmPassword/index.js +31 -11
- package/dist/fields/ConfirmPassword/index.js.map +1 -1
- package/dist/fields/DateTime/index.js +61 -21
- package/dist/fields/DateTime/index.js.map +1 -1
- package/dist/fields/Email/index.js +55 -19
- package/dist/fields/Email/index.js.map +1 -1
- package/dist/fields/FieldDescription/index.js +7 -3
- package/dist/fields/FieldDescription/index.js.map +1 -1
- package/dist/fields/FieldError/index.js +7 -3
- package/dist/fields/FieldError/index.js.map +1 -1
- package/dist/fields/FieldLabel/index.js +19 -7
- package/dist/fields/FieldLabel/index.js.map +1 -1
- package/dist/fields/Group/index.js +78 -26
- package/dist/fields/Group/index.js.map +1 -1
- package/dist/fields/Group/provider.js +7 -3
- package/dist/fields/Group/provider.js.map +1 -1
- package/dist/fields/Hidden/index.js +7 -3
- package/dist/fields/Hidden/index.js.map +1 -1
- package/dist/fields/JSON/index.js +55 -19
- package/dist/fields/JSON/index.js.map +1 -1
- package/dist/fields/Join/index.js +49 -17
- package/dist/fields/Join/index.js.map +1 -1
- package/dist/fields/Number/index.js +71 -25
- package/dist/fields/Number/index.js.map +1 -1
- package/dist/fields/Password/index.js +7 -3
- package/dist/fields/Password/index.js.map +1 -1
- package/dist/fields/Password/input.js +61 -21
- package/dist/fields/Password/input.js.map +1 -1
- package/dist/fields/Password/types.js +11 -1
- package/dist/fields/Password/types.js.map +1 -1
- package/dist/fields/Point/index.js +97 -33
- package/dist/fields/Point/index.js.map +1 -1
- package/dist/fields/RadioGroup/Radio/index.js +31 -11
- package/dist/fields/RadioGroup/Radio/index.js.map +1 -1
- package/dist/fields/RadioGroup/index.js +67 -23
- package/dist/fields/RadioGroup/index.js.map +1 -1
- package/dist/fields/Relationship/Input.js +84 -28
- package/dist/fields/Relationship/Input.js.map +1 -1
- package/dist/fields/Relationship/index.js +7 -3
- package/dist/fields/Relationship/index.js.map +1 -1
- package/dist/fields/Relationship/select-components/MultiValueLabel/index.js +47 -16
- package/dist/fields/Relationship/select-components/MultiValueLabel/index.js.map +1 -1
- package/dist/fields/Relationship/select-components/SingleValue/index.js +52 -17
- package/dist/fields/Relationship/select-components/SingleValue/index.js.map +1 -1
- package/dist/fields/Row/index.js +19 -7
- package/dist/fields/Row/index.js.map +1 -1
- package/dist/fields/Row/provider.js +7 -3
- package/dist/fields/Row/provider.js.map +1 -1
- package/dist/fields/Select/Input.js +55 -19
- package/dist/fields/Select/Input.js.map +1 -1
- package/dist/fields/Select/index.js +7 -3
- package/dist/fields/Select/index.js.map +1 -1
- package/dist/fields/Slug/index.js +37 -13
- package/dist/fields/Slug/index.js.map +1 -1
- package/dist/fields/Tabs/Tab/index.js +25 -9
- package/dist/fields/Tabs/Tab/index.js.map +1 -1
- package/dist/fields/Tabs/index.js +67 -23
- package/dist/fields/Tabs/index.js.map +1 -1
- package/dist/fields/Tabs/provider.js +7 -3
- package/dist/fields/Tabs/provider.js.map +1 -1
- package/dist/fields/Text/Input.js +60 -20
- package/dist/fields/Text/Input.js.map +1 -1
- package/dist/fields/Text/index.js +10 -5
- package/dist/fields/Text/index.js.map +1 -1
- package/dist/fields/Textarea/Input.js +61 -21
- package/dist/fields/Textarea/Input.js.map +1 -1
- package/dist/fields/Textarea/index.js +7 -3
- package/dist/fields/Textarea/index.js.map +1 -1
- package/dist/fields/Upload/HasMany/index.js +48 -16
- package/dist/fields/Upload/HasMany/index.js.map +1 -1
- package/dist/fields/Upload/HasOne/index.js +13 -5
- package/dist/fields/Upload/HasOne/index.js.map +1 -1
- package/dist/fields/Upload/Input.js +154 -56
- package/dist/fields/Upload/Input.js.map +1 -1
- package/dist/fields/Upload/RelationshipContent/index.js +73 -25
- package/dist/fields/Upload/RelationshipContent/index.js.map +1 -1
- package/dist/fields/Upload/UploadCard/index.js +7 -3
- package/dist/fields/Upload/UploadCard/index.js.map +1 -1
- package/dist/fields/Upload/index.js +13 -5
- package/dist/fields/Upload/index.js.map +1 -1
- package/dist/fields/Upload/types.js +1 -0
- package/dist/fields/Upload/types.js.map +1 -1
- package/dist/fields/shared/index.js +2 -3
- package/dist/fields/shared/index.js.map +1 -1
- package/dist/forms/Form/fieldReducer.js +2 -1
- package/dist/forms/Form/fieldReducer.js.map +1 -1
- package/dist/forms/Form/index.js +78 -31
- package/dist/forms/Form/index.js.map +1 -1
- package/dist/forms/Form/mergeServerFormState.js +11 -3
- package/dist/forms/Form/mergeServerFormState.js.map +1 -1
- package/dist/forms/Form/reduceToSerializableFields.js +2 -2
- package/dist/forms/Form/reduceToSerializableFields.js.map +1 -1
- package/dist/forms/Form/types.js +52 -1
- package/dist/forms/Form/types.js.map +1 -1
- package/dist/forms/NullifyField/index.js +15 -6
- package/dist/forms/NullifyField/index.js.map +1 -1
- package/dist/forms/RenderFields/RenderField.js +138 -46
- package/dist/forms/RenderFields/RenderField.js.map +1 -1
- package/dist/forms/RenderFields/index.js +19 -7
- package/dist/forms/RenderFields/index.js.map +1 -1
- package/dist/forms/RowLabel/Context/index.js +7 -3
- package/dist/forms/RowLabel/Context/index.js.map +1 -1
- package/dist/forms/RowLabel/index.js +19 -7
- package/dist/forms/RowLabel/index.js.map +1 -1
- package/dist/forms/Submit/index.js +13 -5
- package/dist/forms/Submit/index.js.map +1 -1
- package/dist/forms/WatchChildErrors/index.js +6 -1
- package/dist/forms/WatchChildErrors/index.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/addFieldStatePromise.js +20 -0
- package/dist/forms/fieldSchemasToFormState/addFieldStatePromise.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/index.js +33 -1
- package/dist/forms/fieldSchemasToFormState/index.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/isRowCollapsed.js +2 -2
- package/dist/forms/fieldSchemasToFormState/isRowCollapsed.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/iterateFields.js +16 -0
- package/dist/forms/fieldSchemasToFormState/iterateFields.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/renderField.js +21 -9
- package/dist/forms/fieldSchemasToFormState/renderField.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/serverFunctions/renderFieldServerFn.js +22 -1
- package/dist/forms/fieldSchemasToFormState/serverFunctions/renderFieldServerFn.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/types.js +5 -1
- package/dist/forms/fieldSchemasToFormState/types.js.map +1 -1
- package/dist/forms/useField/index.js +1 -0
- package/dist/forms/useField/index.js.map +1 -1
- package/dist/forms/useField/types.js +19 -1
- package/dist/forms/useField/types.js.map +1 -1
- package/dist/forms/withCondition/index.js +13 -5
- package/dist/forms/withCondition/index.js.map +1 -1
- package/dist/graphics/Account/Default/index.js +25 -9
- package/dist/graphics/Account/Default/index.js.map +1 -1
- package/dist/graphics/Account/Gravatar/index.js +7 -3
- package/dist/graphics/Account/Gravatar/index.js.map +1 -1
- package/dist/graphics/Account/index.js +12 -4
- package/dist/graphics/Account/index.js.map +1 -1
- package/dist/graphics/DefaultBlockImage/index.js +67 -23
- package/dist/graphics/DefaultBlockImage/index.js.map +1 -1
- package/dist/graphics/File/index.js +19 -7
- package/dist/graphics/File/index.js.map +1 -1
- package/dist/graphics/Icon/index.js +19 -7
- package/dist/graphics/Icon/index.js.map +1 -1
- package/dist/graphics/Logo/index.js +85 -29
- package/dist/graphics/Logo/index.js.map +1 -1
- package/dist/hooks/useControllableState.js +9 -1
- package/dist/hooks/useControllableState.js.map +1 -1
- package/dist/hooks/useDelayedRender.js +3 -1
- package/dist/hooks/useDelayedRender.js.map +1 -1
- package/dist/hooks/useHotkey.js +2 -2
- package/dist/hooks/useHotkey.js.map +1 -1
- package/dist/hooks/usePayloadAPI.js +3 -4
- package/dist/hooks/usePayloadAPI.js.map +1 -1
- package/dist/hooks/usePopupWindow.js +2 -2
- package/dist/hooks/usePopupWindow.js.map +1 -1
- package/dist/hooks/useQueue.js +15 -7
- package/dist/hooks/useQueue.js.map +1 -1
- package/dist/hooks/useResize.js +4 -3
- package/dist/hooks/useResize.js.map +1 -1
- package/dist/icons/Calendar/index.js +13 -5
- package/dist/icons/Calendar/index.js.map +1 -1
- package/dist/icons/Check/index.js +13 -5
- package/dist/icons/Check/index.js.map +1 -1
- package/dist/icons/Chevron/index.js +13 -5
- package/dist/icons/Chevron/index.js.map +1 -1
- package/dist/icons/CloseMenu/index.js +13 -5
- package/dist/icons/CloseMenu/index.js.map +1 -1
- package/dist/icons/CodeBlock/index.js +13 -5
- package/dist/icons/CodeBlock/index.js.map +1 -1
- package/dist/icons/Copy/index.js +13 -5
- package/dist/icons/Copy/index.js.map +1 -1
- package/dist/icons/Document/index.js +13 -5
- package/dist/icons/Document/index.js.map +1 -1
- package/dist/icons/Dots/index.js +22 -6
- package/dist/icons/Dots/index.js.map +1 -1
- package/dist/icons/DragHandle/index.js +43 -15
- package/dist/icons/DragHandle/index.js.map +1 -1
- package/dist/icons/Edit/index.js +13 -5
- package/dist/icons/Edit/index.js.map +1 -1
- package/dist/icons/ExternalLink/index.js +13 -5
- package/dist/icons/ExternalLink/index.js.map +1 -1
- package/dist/icons/Eye/index.js +36 -12
- package/dist/icons/Eye/index.js.map +1 -1
- package/dist/icons/Folder/index.js +13 -5
- package/dist/icons/Folder/index.js.map +1 -1
- package/dist/icons/Gear/index.js +19 -7
- package/dist/icons/Gear/index.js.map +1 -1
- package/dist/icons/GridView/index.js +31 -11
- package/dist/icons/GridView/index.js.map +1 -1
- package/dist/icons/Line/index.js +13 -5
- package/dist/icons/Line/index.js.map +1 -1
- package/dist/icons/Link/index.js +13 -5
- package/dist/icons/Link/index.js.map +1 -1
- package/dist/icons/ListView/index.js +13 -5
- package/dist/icons/ListView/index.js.map +1 -1
- package/dist/icons/Lock/index.js +19 -7
- package/dist/icons/Lock/index.js.map +1 -1
- package/dist/icons/LogOut/index.js +13 -5
- package/dist/icons/LogOut/index.js.map +1 -1
- package/dist/icons/Menu/index.js +13 -5
- package/dist/icons/Menu/index.js.map +1 -1
- package/dist/icons/MinimizeMaximize/index.js +18 -6
- package/dist/icons/MinimizeMaximize/index.js.map +1 -1
- package/dist/icons/More/index.js +25 -9
- package/dist/icons/More/index.js.map +1 -1
- package/dist/icons/MoveFolder/index.js +37 -13
- package/dist/icons/MoveFolder/index.js.map +1 -1
- package/dist/icons/People/index.js +13 -5
- package/dist/icons/People/index.js.map +1 -1
- package/dist/icons/Plus/index.js +13 -5
- package/dist/icons/Plus/index.js.map +1 -1
- package/dist/icons/Search/index.js +13 -5
- package/dist/icons/Search/index.js.map +1 -1
- package/dist/icons/Sort/index.js +25 -9
- package/dist/icons/Sort/index.js.map +1 -1
- package/dist/icons/Swap/index.js +13 -5
- package/dist/icons/Swap/index.js.map +1 -1
- package/dist/icons/ThreeDots/index.js +22 -6
- package/dist/icons/ThreeDots/index.js.map +1 -1
- package/dist/icons/Trash/index.js +13 -5
- package/dist/icons/Trash/index.js.map +1 -1
- package/dist/icons/X/index.js +13 -5
- package/dist/icons/X/index.js.map +1 -1
- package/dist/providers/Actions/index.js +7 -3
- package/dist/providers/Actions/index.js.map +1 -1
- package/dist/providers/Auth/index.js +42 -6
- package/dist/providers/Auth/index.js.map +1 -1
- package/dist/providers/ClickOutside/index.js +7 -3
- package/dist/providers/ClickOutside/index.js.map +1 -1
- package/dist/providers/ClientFunction/index.js +13 -5
- package/dist/providers/ClientFunction/index.js.map +1 -1
- package/dist/providers/Config/index.js +23 -6
- package/dist/providers/Config/index.js.map +1 -1
- package/dist/providers/DocumentEvents/index.js +7 -3
- package/dist/providers/DocumentEvents/index.js.map +1 -1
- package/dist/providers/DocumentInfo/index.js +31 -16
- package/dist/providers/DocumentInfo/index.js.map +1 -1
- package/dist/providers/DocumentInfo/types.js +25 -1
- package/dist/providers/DocumentInfo/types.js.map +1 -1
- package/dist/providers/DocumentTitle/index.js +7 -3
- package/dist/providers/DocumentTitle/index.js.map +1 -1
- package/dist/providers/EditDepth/index.js +7 -3
- package/dist/providers/EditDepth/index.js.map +1 -1
- package/dist/providers/EntityVisibility/index.js +7 -3
- package/dist/providers/EntityVisibility/index.js.map +1 -1
- package/dist/providers/Folders/index.js +51 -5
- package/dist/providers/Folders/index.js.map +1 -1
- package/dist/providers/ListQuery/index.js +13 -5
- package/dist/providers/ListQuery/index.js.map +1 -1
- package/dist/providers/ListQuery/types.js +5 -1
- package/dist/providers/ListQuery/types.js.map +1 -1
- package/dist/providers/LivePreview/context.js +11 -1
- package/dist/providers/LivePreview/context.js.map +1 -1
- package/dist/providers/LivePreview/index.js +20 -9
- package/dist/providers/LivePreview/index.js.map +1 -1
- package/dist/providers/Locale/index.js +13 -5
- package/dist/providers/Locale/index.js.map +1 -1
- package/dist/providers/Operation/index.js +7 -3
- package/dist/providers/Operation/index.js.map +1 -1
- package/dist/providers/Params/index.js +7 -3
- package/dist/providers/Params/index.js.map +1 -1
- package/dist/providers/Preferences/index.js +14 -5
- package/dist/providers/Preferences/index.js.map +1 -1
- package/dist/providers/Root/index.js +154 -50
- package/dist/providers/Root/index.js.map +1 -1
- package/dist/providers/RouteCache/index.js +7 -3
- package/dist/providers/RouteCache/index.js.map +1 -1
- package/dist/providers/RouteTransition/ProgressBar/index.js +13 -5
- package/dist/providers/RouteTransition/ProgressBar/index.js.map +1 -1
- package/dist/providers/RouteTransition/index.js +16 -12
- package/dist/providers/RouteTransition/index.js.map +1 -1
- package/dist/providers/SearchParams/index.js +7 -3
- package/dist/providers/SearchParams/index.js.map +1 -1
- package/dist/providers/Selection/index.js +14 -5
- package/dist/providers/Selection/index.js.map +1 -1
- package/dist/providers/ServerFunctions/index.js +32 -25
- package/dist/providers/ServerFunctions/index.js.map +1 -1
- package/dist/providers/TableColumns/RenderDefaultCell/index.js +13 -5
- package/dist/providers/TableColumns/RenderDefaultCell/index.js.map +1 -1
- package/dist/providers/TableColumns/buildColumnState/index.js +17 -12
- package/dist/providers/TableColumns/buildColumnState/index.js.map +1 -1
- package/dist/providers/TableColumns/buildColumnState/renderCell.js +17 -8
- package/dist/providers/TableColumns/buildColumnState/renderCell.js.map +1 -1
- package/dist/providers/TableColumns/index.js +7 -3
- package/dist/providers/TableColumns/index.js.map +1 -1
- package/dist/providers/TableColumns/types.js +17 -1
- package/dist/providers/TableColumns/types.js.map +1 -1
- package/dist/providers/Theme/index.js +7 -3
- package/dist/providers/Theme/index.js.map +1 -1
- package/dist/providers/ToastContainer/icons/Error.js +19 -7
- package/dist/providers/ToastContainer/icons/Error.js.map +1 -1
- package/dist/providers/ToastContainer/icons/Info.js +19 -7
- package/dist/providers/ToastContainer/icons/Info.js.map +1 -1
- package/dist/providers/ToastContainer/icons/Success.js +19 -7
- package/dist/providers/ToastContainer/icons/Success.js.map +1 -1
- package/dist/providers/ToastContainer/icons/Warning.js +19 -7
- package/dist/providers/ToastContainer/icons/Warning.js.map +1 -1
- package/dist/providers/ToastContainer/index.js +27 -7
- package/dist/providers/ToastContainer/index.js.map +1 -1
- package/dist/providers/Translation/index.js +7 -3
- package/dist/providers/Translation/index.js.map +1 -1
- package/dist/providers/UploadControls/index.js +7 -3
- package/dist/providers/UploadControls/index.js.map +1 -1
- package/dist/providers/UploadEdits/index.js +7 -3
- package/dist/providers/UploadEdits/index.js.map +1 -1
- package/dist/providers/UploadHandlers/index.js +7 -3
- package/dist/providers/UploadHandlers/index.js.map +1 -1
- package/dist/utilities/abortAndIgnore.js +4 -6
- package/dist/utilities/abortAndIgnore.js.map +1 -1
- package/dist/utilities/buildFieldSchemaMap/traverseFields.js +2 -2
- package/dist/utilities/buildFieldSchemaMap/traverseFields.js.map +1 -1
- package/dist/utilities/combineFieldLabel.js +37 -13
- package/dist/utilities/combineFieldLabel.js.map +1 -1
- package/dist/utilities/copyDataFromLocale.js +6 -2
- package/dist/utilities/copyDataFromLocale.js.map +1 -1
- package/dist/utilities/getDisplayedFieldValue.js +8 -8
- package/dist/utilities/getDisplayedFieldValue.js.map +1 -1
- package/dist/utilities/getFolderResultsComponentAndData.js +31 -14
- package/dist/utilities/getFolderResultsComponentAndData.js.map +1 -1
- package/dist/utilities/handleFormStateLocking.js +2 -2
- package/dist/utilities/handleFormStateLocking.js.map +1 -1
- package/dist/utilities/hasSavePermission.js +5 -1
- package/dist/utilities/hasSavePermission.js.map +1 -1
- package/dist/utilities/isURLAllowed.js +6 -6
- package/dist/utilities/isURLAllowed.js.map +1 -1
- package/dist/utilities/renderTable.js +84 -27
- package/dist/utilities/renderTable.js.map +1 -1
- package/dist/utilities/schedulePublishHandler.js +3 -1
- package/dist/utilities/schedulePublishHandler.js.map +1 -1
- package/dist/utilities/upsertPreferences.js +1 -0
- package/dist/utilities/upsertPreferences.js.map +1 -1
- package/dist/views/BrowseByFolder/index.js +168 -56
- package/dist/views/BrowseByFolder/index.js.map +1 -1
- package/dist/views/CollectionFolder/ListSelection/index.js +67 -23
- package/dist/views/CollectionFolder/ListSelection/index.js.map +1 -1
- package/dist/views/CollectionFolder/index.js +147 -47
- package/dist/views/CollectionFolder/index.js.map +1 -1
- package/dist/views/Edit/Auth/APIKey.js +67 -23
- package/dist/views/Edit/Auth/APIKey.js.map +1 -1
- package/dist/views/Edit/Auth/index.js +91 -31
- package/dist/views/Edit/Auth/index.js.map +1 -1
- package/dist/views/Edit/index.js +124 -48
- package/dist/views/Edit/index.js.map +1 -1
- package/dist/views/List/GroupByHeader/index.js +19 -7
- package/dist/views/List/GroupByHeader/index.js.map +1 -1
- package/dist/views/List/ListHeader/index.js +68 -23
- package/dist/views/List/ListHeader/index.js.map +1 -1
- package/dist/views/List/ListSelection/index.js +49 -17
- package/dist/views/List/ListSelection/index.js.map +1 -1
- package/dist/views/List/index.js +162 -54
- package/dist/views/List/index.js.map +1 -1
- package/package.json +7 -6
|
@@ -1,15 +1,31 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { jsxDEV as _jsxDEV } from "react/jsx-dev-runtime";
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import './index.scss';
|
|
4
4
|
export function ThreeDotsIcon({ className = '' }) {
|
|
5
|
-
return /*#__PURE__*/
|
|
5
|
+
return /*#__PURE__*/ _jsxDEV("div", {
|
|
6
6
|
className: `icon icon--dots ${className}`.trim(),
|
|
7
7
|
children: [
|
|
8
|
-
/*#__PURE__*/
|
|
9
|
-
|
|
10
|
-
|
|
8
|
+
/*#__PURE__*/ _jsxDEV("div", {}, void 0, false, {
|
|
9
|
+
fileName: "src/icons/ThreeDots/index.tsx",
|
|
10
|
+
lineNumber: 8,
|
|
11
|
+
columnNumber: 7
|
|
12
|
+
}, this),
|
|
13
|
+
/*#__PURE__*/ _jsxDEV("div", {}, void 0, false, {
|
|
14
|
+
fileName: "src/icons/ThreeDots/index.tsx",
|
|
15
|
+
lineNumber: 9,
|
|
16
|
+
columnNumber: 7
|
|
17
|
+
}, this),
|
|
18
|
+
/*#__PURE__*/ _jsxDEV("div", {}, void 0, false, {
|
|
19
|
+
fileName: "src/icons/ThreeDots/index.tsx",
|
|
20
|
+
lineNumber: 10,
|
|
21
|
+
columnNumber: 7
|
|
22
|
+
}, this)
|
|
11
23
|
]
|
|
12
|
-
}
|
|
24
|
+
}, void 0, true, {
|
|
25
|
+
fileName: "src/icons/ThreeDots/index.tsx",
|
|
26
|
+
lineNumber: 7,
|
|
27
|
+
columnNumber: 5
|
|
28
|
+
}, this);
|
|
13
29
|
}
|
|
14
30
|
|
|
15
31
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/icons/ThreeDots/index.tsx"],"sourcesContent":["import React from 'react'\n\nimport './index.scss'\n\nexport function ThreeDotsIcon({ className = '' }) {\n return (\n <div className={`icon icon--dots ${className}`.trim()}>\n <div />\n <div />\n <div />\n </div>\n )\n}\n"],"names":["React","ThreeDotsIcon","className","div","trim"],"mappings":";AAAA,OAAOA,WAAW,QAAO;AAEzB,OAAO,eAAc;AAErB,OAAO,SAASC,cAAc,EAAEC,YAAY,EAAE,EAAE;IAC9C,qBACE,
|
|
1
|
+
{"version":3,"sources":["../../../src/icons/ThreeDots/index.tsx"],"sourcesContent":["import React from 'react'\n\nimport './index.scss'\n\nexport function ThreeDotsIcon({ className = '' }) {\n return (\n <div className={`icon icon--dots ${className}`.trim()}>\n <div />\n <div />\n <div />\n </div>\n )\n}\n"],"names":["React","ThreeDotsIcon","className","div","trim"],"mappings":";AAAA,OAAOA,WAAW,QAAO;AAEzB,OAAO,eAAc;AAErB,OAAO,SAASC,cAAc,EAAEC,YAAY,EAAE,EAAE;IAC9C,qBACE,QAACC;QAAID,WAAW,CAAC,gBAAgB,EAAEA,WAAW,CAACE,IAAI;;0BACjD,QAACD;;;;;0BACD,QAACA;;;;;0BACD,QAACA;;;;;;;;;;;AAGP"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { jsxDEV as _jsxDEV } from "react/jsx-dev-runtime";
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import './index.scss';
|
|
4
4
|
export function TrashIcon({ className }) {
|
|
5
|
-
return /*#__PURE__*/
|
|
5
|
+
return /*#__PURE__*/ _jsxDEV("svg", {
|
|
6
6
|
className: [
|
|
7
7
|
className,
|
|
8
8
|
'icon icon--trash'
|
|
@@ -12,13 +12,21 @@ export function TrashIcon({ className }) {
|
|
|
12
12
|
viewBox: "0 0 20 20",
|
|
13
13
|
width: "20",
|
|
14
14
|
xmlns: "http://www.w3.org/2000/svg",
|
|
15
|
-
children: /*#__PURE__*/
|
|
15
|
+
children: /*#__PURE__*/ _jsxDEV("path", {
|
|
16
16
|
d: "M4.1499 6.1H15.8499M14.5499 6.1V15.2C14.5499 15.85 13.8999 16.5 13.2499 16.5H6.7499C6.0999 16.5 5.4499 15.85 5.4499 15.2V6.1M7.3999 6.1V4.8C7.3999 4.15 8.0499 3.5 8.6999 3.5H11.2999C11.9499 3.5 12.5999 4.15 12.5999 4.8V6.1M8.6999 9.35V13.25M11.2999 9.35V13.25",
|
|
17
17
|
stroke: "currentColor",
|
|
18
18
|
strokeLinecap: "round",
|
|
19
19
|
strokeLinejoin: "round"
|
|
20
|
-
}
|
|
21
|
-
|
|
20
|
+
}, void 0, false, {
|
|
21
|
+
fileName: "src/icons/Trash/index.tsx",
|
|
22
|
+
lineNumber: 15,
|
|
23
|
+
columnNumber: 7
|
|
24
|
+
}, this)
|
|
25
|
+
}, void 0, false, {
|
|
26
|
+
fileName: "src/icons/Trash/index.tsx",
|
|
27
|
+
lineNumber: 7,
|
|
28
|
+
columnNumber: 5
|
|
29
|
+
}, this);
|
|
22
30
|
}
|
|
23
31
|
|
|
24
32
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/icons/Trash/index.tsx"],"sourcesContent":["import React from 'react'\n\nimport './index.scss'\n\nexport function TrashIcon({ className }: { className?: string }) {\n return (\n <svg\n className={[className, 'icon icon--trash'].filter(Boolean).join(' ')}\n fill=\"none\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n width=\"20\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M4.1499 6.1H15.8499M14.5499 6.1V15.2C14.5499 15.85 13.8999 16.5 13.2499 16.5H6.7499C6.0999 16.5 5.4499 15.85 5.4499 15.2V6.1M7.3999 6.1V4.8C7.3999 4.15 8.0499 3.5 8.6999 3.5H11.2999C11.9499 3.5 12.5999 4.15 12.5999 4.8V6.1M8.6999 9.35V13.25M11.2999 9.35V13.25\"\n stroke=\"currentColor\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n )\n}\n"],"names":["React","TrashIcon","className","svg","filter","Boolean","join","fill","height","viewBox","width","xmlns","path","d","stroke","strokeLinecap","strokeLinejoin"],"mappings":";AAAA,OAAOA,WAAW,QAAO;AAEzB,OAAO,eAAc;AAErB,OAAO,SAASC,UAAU,EAAEC,SAAS,EAA0B;IAC7D,qBACE,
|
|
1
|
+
{"version":3,"sources":["../../../src/icons/Trash/index.tsx"],"sourcesContent":["import React from 'react'\n\nimport './index.scss'\n\nexport function TrashIcon({ className }: { className?: string }) {\n return (\n <svg\n className={[className, 'icon icon--trash'].filter(Boolean).join(' ')}\n fill=\"none\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n width=\"20\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M4.1499 6.1H15.8499M14.5499 6.1V15.2C14.5499 15.85 13.8999 16.5 13.2499 16.5H6.7499C6.0999 16.5 5.4499 15.85 5.4499 15.2V6.1M7.3999 6.1V4.8C7.3999 4.15 8.0499 3.5 8.6999 3.5H11.2999C11.9499 3.5 12.5999 4.15 12.5999 4.8V6.1M8.6999 9.35V13.25M11.2999 9.35V13.25\"\n stroke=\"currentColor\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n )\n}\n"],"names":["React","TrashIcon","className","svg","filter","Boolean","join","fill","height","viewBox","width","xmlns","path","d","stroke","strokeLinecap","strokeLinejoin"],"mappings":";AAAA,OAAOA,WAAW,QAAO;AAEzB,OAAO,eAAc;AAErB,OAAO,SAASC,UAAU,EAAEC,SAAS,EAA0B;IAC7D,qBACE,QAACC;QACCD,WAAW;YAACA;YAAW;SAAmB,CAACE,MAAM,CAACC,SAASC,IAAI,CAAC;QAChEC,MAAK;QACLC,QAAO;QACPC,SAAQ;QACRC,OAAM;QACNC,OAAM;kBAEN,cAAA,QAACC;YACCC,GAAE;YACFC,QAAO;YACPC,eAAc;YACdC,gBAAe;;;;;;;;;;;AAIvB"}
|
package/dist/icons/X/index.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { jsxDEV as _jsxDEV } from "react/jsx-dev-runtime";
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import './index.scss';
|
|
4
|
-
export const XIcon = ({ className })=>/*#__PURE__*/
|
|
4
|
+
export const XIcon = ({ className })=>/*#__PURE__*/ _jsxDEV("svg", {
|
|
5
5
|
className: [
|
|
6
6
|
className,
|
|
7
7
|
'icon icon--x'
|
|
@@ -10,11 +10,19 @@ export const XIcon = ({ className })=>/*#__PURE__*/ _jsx("svg", {
|
|
|
10
10
|
viewBox: "0 0 20 20",
|
|
11
11
|
width: 20,
|
|
12
12
|
xmlns: "http://www.w3.org/2000/svg",
|
|
13
|
-
children: /*#__PURE__*/
|
|
13
|
+
children: /*#__PURE__*/ _jsxDEV("path", {
|
|
14
14
|
className: "stroke",
|
|
15
15
|
d: "M14 6L6 14M6 6L14 14",
|
|
16
16
|
strokeLinecap: "square"
|
|
17
|
-
}
|
|
18
|
-
|
|
17
|
+
}, void 0, false, {
|
|
18
|
+
fileName: "src/icons/X/index.tsx",
|
|
19
|
+
lineNumber: 13,
|
|
20
|
+
columnNumber: 5
|
|
21
|
+
}, this)
|
|
22
|
+
}, void 0, false, {
|
|
23
|
+
fileName: "src/icons/X/index.tsx",
|
|
24
|
+
lineNumber: 6,
|
|
25
|
+
columnNumber: 3
|
|
26
|
+
}, this);
|
|
19
27
|
|
|
20
28
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/icons/X/index.tsx"],"sourcesContent":["import React from 'react'\n\nimport './index.scss'\n\nexport const XIcon: React.FC<{ className?: string }> = ({ className }) => (\n <svg\n className={[className, 'icon icon--x'].filter(Boolean).join(' ')}\n height={20}\n viewBox=\"0 0 20 20\"\n width={20}\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path className=\"stroke\" d=\"M14 6L6 14M6 6L14 14\" strokeLinecap=\"square\" />\n </svg>\n)\n"],"names":["React","XIcon","className","svg","filter","Boolean","join","height","viewBox","width","xmlns","path","d","strokeLinecap"],"mappings":";AAAA,OAAOA,WAAW,QAAO;AAEzB,OAAO,eAAc;AAErB,OAAO,MAAMC,QAA0C,CAAC,EAAEC,SAAS,EAAE,iBACnE,
|
|
1
|
+
{"version":3,"sources":["../../../src/icons/X/index.tsx"],"sourcesContent":["import React from 'react'\n\nimport './index.scss'\n\nexport const XIcon: React.FC<{ className?: string }> = ({ className }) => (\n <svg\n className={[className, 'icon icon--x'].filter(Boolean).join(' ')}\n height={20}\n viewBox=\"0 0 20 20\"\n width={20}\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path className=\"stroke\" d=\"M14 6L6 14M6 6L14 14\" strokeLinecap=\"square\" />\n </svg>\n)\n"],"names":["React","XIcon","className","svg","filter","Boolean","join","height","viewBox","width","xmlns","path","d","strokeLinecap"],"mappings":";AAAA,OAAOA,WAAW,QAAO;AAEzB,OAAO,eAAc;AAErB,OAAO,MAAMC,QAA0C,CAAC,EAAEC,SAAS,EAAE,iBACnE,QAACC;QACCD,WAAW;YAACA;YAAW;SAAe,CAACE,MAAM,CAACC,SAASC,IAAI,CAAC;QAC5DC,QAAQ;QACRC,SAAQ;QACRC,OAAO;QACPC,OAAM;kBAEN,cAAA,QAACC;YAAKT,WAAU;YAASU,GAAE;YAAuBC,eAAc;;;;;;;;;;aAEnE"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
'use client';
|
|
2
|
-
import {
|
|
2
|
+
import { jsxDEV as _jsxDEV } from "react/jsx-dev-runtime";
|
|
3
3
|
import React, { createContext, use, useState } from 'react';
|
|
4
4
|
const ActionsContext = /*#__PURE__*/ createContext({
|
|
5
5
|
Actions: {},
|
|
@@ -8,7 +8,7 @@ const ActionsContext = /*#__PURE__*/ createContext({
|
|
|
8
8
|
export const useActions = ()=>use(ActionsContext);
|
|
9
9
|
export const ActionsProvider = ({ Actions, children })=>{
|
|
10
10
|
const [viewActions, setViewActions] = useState(Actions);
|
|
11
|
-
return /*#__PURE__*/
|
|
11
|
+
return /*#__PURE__*/ _jsxDEV(ActionsContext, {
|
|
12
12
|
value: {
|
|
13
13
|
Actions: {
|
|
14
14
|
...viewActions,
|
|
@@ -17,7 +17,11 @@ export const ActionsProvider = ({ Actions, children })=>{
|
|
|
17
17
|
setViewActions
|
|
18
18
|
},
|
|
19
19
|
children: children
|
|
20
|
-
}
|
|
20
|
+
}, void 0, false, {
|
|
21
|
+
fileName: "src/providers/Actions/index.tsx",
|
|
22
|
+
lineNumber: 28,
|
|
23
|
+
columnNumber: 5
|
|
24
|
+
}, this);
|
|
21
25
|
};
|
|
22
26
|
|
|
23
27
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/providers/Actions/index.tsx"],"sourcesContent":["'use client'\n\nimport React, { createContext, use, useState } from 'react'\n\ntype ActionsContextType = {\n Actions: {\n [key: string]: React.ReactNode\n }\n setViewActions: (actions: ActionsContextType['Actions']) => void\n}\n\nconst ActionsContext = createContext<ActionsContextType>({\n Actions: {},\n setViewActions: () => {},\n})\n\nexport const useActions = () => use(ActionsContext)\n\nexport const ActionsProvider: React.FC<{\n readonly Actions?: {\n [key: string]: React.ReactNode\n }\n readonly children: React.ReactNode\n}> = ({ Actions, children }) => {\n const [viewActions, setViewActions] = useState(Actions)\n\n return (\n <ActionsContext\n value={{\n Actions: {\n ...viewActions,\n ...Actions,\n },\n setViewActions,\n }}\n >\n {children}\n </ActionsContext>\n )\n}\n"],"names":["React","createContext","use","useState","ActionsContext","Actions","setViewActions","useActions","ActionsProvider","children","viewActions","value"],"mappings":"AAAA;;AAEA,OAAOA,SAASC,aAAa,EAAEC,GAAG,EAAEC,QAAQ,QAAQ,QAAO;AAS3D,MAAMC,+BAAiBH,cAAkC;IACvDI,SAAS,CAAC;IACVC,gBAAgB,KAAO;AACzB;AAEA,OAAO,MAAMC,aAAa,IAAML,IAAIE,gBAAe;AAEnD,OAAO,MAAMI,kBAKR,CAAC,EAAEH,OAAO,EAAEI,QAAQ,EAAE;IACzB,MAAM,CAACC,aAAaJ,eAAe,GAAGH,SAASE;IAE/C,qBACE,
|
|
1
|
+
{"version":3,"sources":["../../../src/providers/Actions/index.tsx"],"sourcesContent":["'use client'\n\nimport React, { createContext, use, useState } from 'react'\n\ntype ActionsContextType = {\n Actions: {\n [key: string]: React.ReactNode\n }\n setViewActions: (actions: ActionsContextType['Actions']) => void\n}\n\nconst ActionsContext = createContext<ActionsContextType>({\n Actions: {},\n setViewActions: () => {},\n})\n\nexport const useActions = () => use(ActionsContext)\n\nexport const ActionsProvider: React.FC<{\n readonly Actions?: {\n [key: string]: React.ReactNode\n }\n readonly children: React.ReactNode\n}> = ({ Actions, children }) => {\n const [viewActions, setViewActions] = useState(Actions)\n\n return (\n <ActionsContext\n value={{\n Actions: {\n ...viewActions,\n ...Actions,\n },\n setViewActions,\n }}\n >\n {children}\n </ActionsContext>\n )\n}\n"],"names":["React","createContext","use","useState","ActionsContext","Actions","setViewActions","useActions","ActionsProvider","children","viewActions","value"],"mappings":"AAAA;;AAEA,OAAOA,SAASC,aAAa,EAAEC,GAAG,EAAEC,QAAQ,QAAQ,QAAO;AAS3D,MAAMC,+BAAiBH,cAAkC;IACvDI,SAAS,CAAC;IACVC,gBAAgB,KAAO;AACzB;AAEA,OAAO,MAAMC,aAAa,IAAML,IAAIE,gBAAe;AAEnD,OAAO,MAAMI,kBAKR,CAAC,EAAEH,OAAO,EAAEI,QAAQ,EAAE;IACzB,MAAM,CAACC,aAAaJ,eAAe,GAAGH,SAASE;IAE/C,qBACE,QAACD;QACCO,OAAO;YACLN,SAAS;gBACP,GAAGK,WAAW;gBACd,GAAGL,OAAO;YACZ;YACAC;QACF;kBAECG;;;;;;AAGP,EAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
'use client';
|
|
2
|
-
import {
|
|
2
|
+
import { jsxDEV as _jsxDEV } from "react/jsx-dev-runtime";
|
|
3
3
|
import { useModal } from '@faceless-ui/modal';
|
|
4
4
|
import { usePathname, useRouter } from 'next/navigation.js';
|
|
5
5
|
import { formatAdminURL } from 'payload/shared';
|
|
@@ -12,7 +12,40 @@ import { useTranslation } from '../../providers/Translation/index.js';
|
|
|
12
12
|
import { requests } from '../../utilities/api.js';
|
|
13
13
|
import { useConfig } from '../Config/index.js';
|
|
14
14
|
import { useRouteTransition } from '../RouteTransition/index.js';
|
|
15
|
-
|
|
15
|
+
/** seconds until expiration */ /**
|
|
16
|
+
* These are the permissions for the current user from a global scope.
|
|
17
|
+
*
|
|
18
|
+
* When checking for permissions on document specific level, use the `useDocumentInfo` hook instead.
|
|
19
|
+
*
|
|
20
|
+
* @example
|
|
21
|
+
*
|
|
22
|
+
* ```tsx
|
|
23
|
+
* import { useAuth } from 'payload/ui'
|
|
24
|
+
*
|
|
25
|
+
* const MyComponent: React.FC = () => {
|
|
26
|
+
* const { permissions } = useAuth()
|
|
27
|
+
*
|
|
28
|
+
* if (permissions?.collections?.myCollection?.create) {
|
|
29
|
+
* // user can create documents in 'myCollection'
|
|
30
|
+
* }
|
|
31
|
+
*
|
|
32
|
+
* return null
|
|
33
|
+
* }
|
|
34
|
+
* ```
|
|
35
|
+
*
|
|
36
|
+
* with useDocumentInfo:
|
|
37
|
+
*
|
|
38
|
+
* ```tsx
|
|
39
|
+
* import { useDocumentInfo } from 'payload/ui'
|
|
40
|
+
*
|
|
41
|
+
* const MyComponent: React.FC = () => {
|
|
42
|
+
* const { docPermissions } = useDocumentInfo()
|
|
43
|
+
* if (docPermissions?.create) {
|
|
44
|
+
* // user can create this document
|
|
45
|
+
* }
|
|
46
|
+
* return null
|
|
47
|
+
* } ```
|
|
48
|
+
*/ const Context = /*#__PURE__*/ createContext({});
|
|
16
49
|
const maxTimeoutMs = 2147483647;
|
|
17
50
|
export function AuthProvider({ children, permissions: initialPermissions, user: initialUser }) {
|
|
18
51
|
const pathname = usePathname();
|
|
@@ -157,9 +190,8 @@ export function AuthProvider({ children, permissions: initialPermissions, user:
|
|
|
157
190
|
setNewUser(null);
|
|
158
191
|
await requests.post(`${serverURL}${apiRoute}/${user.collection}/logout`);
|
|
159
192
|
}
|
|
160
|
-
} catch (_) {
|
|
193
|
+
} catch (_) {}
|
|
161
194
|
// fail silently and log the user out in state
|
|
162
|
-
}
|
|
163
195
|
return true;
|
|
164
196
|
}, [
|
|
165
197
|
apiRoute,
|
|
@@ -249,7 +281,7 @@ export function AuthProvider({ children, permissions: initialPermissions, user:
|
|
|
249
281
|
if (!user && !fetchedUserOnMount) {
|
|
250
282
|
return null;
|
|
251
283
|
}
|
|
252
|
-
return /*#__PURE__*/
|
|
284
|
+
return /*#__PURE__*/ _jsxDEV(Context, {
|
|
253
285
|
value: {
|
|
254
286
|
fetchFullUser,
|
|
255
287
|
logOut,
|
|
@@ -264,7 +296,11 @@ export function AuthProvider({ children, permissions: initialPermissions, user:
|
|
|
264
296
|
user
|
|
265
297
|
},
|
|
266
298
|
children: children
|
|
267
|
-
}
|
|
299
|
+
}, void 0, false, {
|
|
300
|
+
fileName: "src/providers/Auth/index.tsx",
|
|
301
|
+
lineNumber: 365,
|
|
302
|
+
columnNumber: 5
|
|
303
|
+
}, this);
|
|
268
304
|
}
|
|
269
305
|
export const useAuth = ()=>use(Context);
|
|
270
306
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/providers/Auth/index.tsx"],"sourcesContent":["'use client'\nimport type { ClientUser, SanitizedPermissions, TypedUser } from 'payload'\n\nimport { useModal } from '@faceless-ui/modal'\nimport { usePathname, useRouter } from 'next/navigation.js'\nimport { formatAdminURL } from 'payload/shared'\nimport * as qs from 'qs-esm'\nimport React, { createContext, use, useCallback, useEffect, useState } from 'react'\nimport { toast } from 'sonner'\n\nimport { stayLoggedInModalSlug } from '../../elements/StayLoggedIn/index.js'\nimport { useEffectEvent } from '../../hooks/useEffectEvent.js'\nimport { useTranslation } from '../../providers/Translation/index.js'\nimport { requests } from '../../utilities/api.js'\nimport { useConfig } from '../Config/index.js'\nimport { useRouteTransition } from '../RouteTransition/index.js'\n\nexport type UserWithToken<T = ClientUser> = {\n /** seconds until expiration */\n exp: number\n token: string\n user: T\n}\n\nexport type AuthContext<T = ClientUser> = {\n fetchFullUser: () => Promise<null | TypedUser>\n logOut: () => Promise<boolean>\n /**\n * These are the permissions for the current user from a global scope.\n *\n * When checking for permissions on document specific level, use the `useDocumentInfo` hook instead.\n *\n * @example\n *\n * ```tsx\n * import { useAuth } from 'payload/ui'\n *\n * const MyComponent: React.FC = () => {\n * const { permissions } = useAuth()\n *\n * if (permissions?.collections?.myCollection?.create) {\n * // user can create documents in 'myCollection'\n * }\n *\n * return null\n * }\n * ```\n *\n * with useDocumentInfo:\n *\n * ```tsx\n * import { useDocumentInfo } from 'payload/ui'\n *\n * const MyComponent: React.FC = () => {\n * const { docPermissions } = useDocumentInfo()\n * if (docPermissions?.create) {\n * // user can create this document\n * }\n * return null\n * } ```\n */\n permissions?: SanitizedPermissions\n refreshCookie: (forceRefresh?: boolean) => void\n refreshCookieAsync: () => Promise<ClientUser>\n refreshPermissions: () => Promise<void>\n setPermissions: (permissions: SanitizedPermissions) => void\n setUser: (user: null | UserWithToken<T>) => void\n strategy?: string\n token?: string\n tokenExpirationMs?: number\n user?: null | T\n}\n\nconst Context = createContext({} as AuthContext)\n\nconst maxTimeoutMs = 2147483647\n\ntype Props = {\n children: React.ReactNode\n permissions?: SanitizedPermissions\n user?: ClientUser | null\n}\n\nexport function AuthProvider({\n children,\n permissions: initialPermissions,\n user: initialUser,\n}: Props) {\n const pathname = usePathname()\n const router = useRouter()\n\n const { config } = useConfig()\n\n const {\n admin: {\n autoLogin,\n autoRefresh,\n routes: { inactivity: logoutInactivityRoute },\n user: userSlug,\n },\n routes: { admin: adminRoute, api: apiRoute },\n serverURL,\n } = config\n\n const { i18n } = useTranslation()\n const { closeAllModals, openModal } = useModal()\n const { startRouteTransition } = useRouteTransition()\n\n const [user, setUserInMemory] = useState<ClientUser | null>(initialUser)\n const [tokenInMemory, setTokenInMemory] = useState<string>()\n const [tokenExpirationMs, setTokenExpirationMs] = useState<number>()\n const [permissions, setPermissions] = useState<SanitizedPermissions>(initialPermissions)\n const [forceLogoutBufferMs, setForceLogoutBufferMs] = useState<number>(120_000)\n const [fetchedUserOnMount, setFetchedUserOnMount] = useState(false)\n\n const refreshTokenTimeoutRef = React.useRef<ReturnType<typeof setTimeout>>(null)\n const reminderTimeoutRef = React.useRef<ReturnType<typeof setTimeout>>(null)\n const forceLogOutTimeoutRef = React.useRef<ReturnType<typeof setTimeout>>(null)\n\n const id = user?.id\n\n const redirectToInactivityRoute = useCallback(() => {\n startRouteTransition(() =>\n router.replace(\n formatAdminURL({\n adminRoute,\n path: `${logoutInactivityRoute}${window.location.pathname.startsWith(adminRoute) ? `?redirect=${encodeURIComponent(window.location.pathname)}` : ''}`,\n }),\n ),\n )\n\n closeAllModals()\n }, [router, adminRoute, logoutInactivityRoute, closeAllModals, startRouteTransition])\n\n const revokeTokenAndExpire = useCallback(() => {\n setUserInMemory(null)\n setTokenInMemory(undefined)\n setTokenExpirationMs(undefined)\n clearTimeout(refreshTokenTimeoutRef.current)\n }, [])\n\n // Handler for reminder timeout - uses useEffectEvent to capture latest autoRefresh value\n const handleReminderTimeout = useEffectEvent(() => {\n if (autoRefresh) {\n refreshCookieEvent()\n } else {\n openModal(stayLoggedInModalSlug)\n }\n })\n\n const setNewUser = useCallback(\n (userResponse: null | UserWithToken) => {\n clearTimeout(reminderTimeoutRef.current)\n clearTimeout(forceLogOutTimeoutRef.current)\n\n if (userResponse?.user) {\n setUserInMemory(userResponse.user)\n setTokenInMemory(userResponse.token)\n setTokenExpirationMs(userResponse.exp * 1000)\n\n const expiresInMs = Math.max(\n 0,\n Math.min((userResponse.exp ?? 0) * 1000 - Date.now(), maxTimeoutMs),\n )\n\n if (expiresInMs) {\n const nextForceLogoutBufferMs = Math.min(60_000, expiresInMs / 2)\n setForceLogoutBufferMs(nextForceLogoutBufferMs)\n\n reminderTimeoutRef.current = setTimeout(\n handleReminderTimeout,\n Math.max(expiresInMs - nextForceLogoutBufferMs, 0),\n )\n\n forceLogOutTimeoutRef.current = setTimeout(() => {\n revokeTokenAndExpire()\n redirectToInactivityRoute()\n }, expiresInMs)\n }\n } else {\n revokeTokenAndExpire()\n }\n },\n [redirectToInactivityRoute, revokeTokenAndExpire],\n )\n\n const refreshCookie = useCallback(\n (forceRefresh?: boolean) => {\n if (!id) {\n return\n }\n\n const expiresInMs = Math.max(0, (tokenExpirationMs ?? 0) - Date.now())\n\n if (forceRefresh || (tokenExpirationMs && expiresInMs < forceLogoutBufferMs * 2)) {\n clearTimeout(refreshTokenTimeoutRef.current)\n refreshTokenTimeoutRef.current = setTimeout(async () => {\n try {\n const request = await requests.post(\n `${serverURL}${apiRoute}/${userSlug}/refresh-token?refresh`,\n {\n headers: {\n 'Accept-Language': i18n.language,\n },\n },\n )\n\n if (request.status === 200) {\n const json: UserWithToken = await request.json()\n setNewUser(json)\n } else {\n setNewUser(null)\n redirectToInactivityRoute()\n }\n } catch (e) {\n toast.error(e.message)\n }\n }, 1000)\n }\n },\n [\n apiRoute,\n i18n.language,\n redirectToInactivityRoute,\n serverURL,\n setNewUser,\n tokenExpirationMs,\n userSlug,\n forceLogoutBufferMs,\n id,\n ],\n )\n\n const refreshCookieAsync = useCallback(\n async (skipSetUser?: boolean): Promise<ClientUser> => {\n try {\n const request = await requests.post(`${serverURL}${apiRoute}/${userSlug}/refresh-token`, {\n headers: {\n 'Accept-Language': i18n.language,\n },\n })\n\n if (request.status === 200) {\n const json: UserWithToken = await request.json()\n if (!skipSetUser) {\n setNewUser(json)\n }\n return json.user\n }\n\n if (user) {\n setNewUser(null)\n redirectToInactivityRoute()\n }\n } catch (e) {\n toast.error(`Refreshing token failed: ${e.message}`)\n }\n return null\n },\n [apiRoute, i18n.language, redirectToInactivityRoute, serverURL, setNewUser, userSlug, user],\n )\n\n const logOut = useCallback(async () => {\n try {\n if (user && user.collection) {\n setNewUser(null)\n await requests.post(`${serverURL}${apiRoute}/${user.collection}/logout`)\n }\n } catch (_) {\n // fail silently and log the user out in state\n }\n\n return true\n }, [apiRoute, serverURL, setNewUser, user])\n\n const refreshPermissions = useCallback(\n async ({ locale }: { locale?: string } = {}) => {\n const params = qs.stringify(\n {\n locale,\n },\n {\n addQueryPrefix: true,\n },\n )\n\n try {\n const request = await requests.get(`${serverURL}${apiRoute}/access${params}`, {\n headers: {\n 'Accept-Language': i18n.language,\n },\n })\n\n if (request.status === 200) {\n const json: SanitizedPermissions = await request.json()\n setPermissions(json)\n } else {\n throw new Error(`Fetching permissions failed with status code ${request.status}`)\n }\n } catch (e) {\n toast.error(`Refreshing permissions failed: ${e.message}`)\n }\n },\n [serverURL, apiRoute, i18n],\n )\n\n const fetchFullUser = React.useCallback(async () => {\n try {\n const request = await requests.get(`${serverURL}${apiRoute}/${userSlug}/me`, {\n credentials: 'include',\n headers: {\n 'Accept-Language': i18n.language,\n },\n })\n\n if (request.status === 200) {\n const json: UserWithToken = await request.json()\n setNewUser(json)\n return json?.user || null\n }\n } catch (e) {\n toast.error(`Fetching user failed: ${e.message}`)\n }\n\n return null\n }, [serverURL, apiRoute, userSlug, i18n.language, setNewUser])\n\n const refreshCookieEvent = useEffectEvent(refreshCookie)\n useEffect(() => {\n // when location changes, refresh cookie\n refreshCookieEvent()\n }, [pathname])\n\n const fetchFullUserEvent = useEffectEvent(fetchFullUser)\n useEffect(() => {\n async function fetchUserOnMount() {\n await fetchFullUserEvent()\n setFetchedUserOnMount(true)\n }\n\n void fetchUserOnMount()\n }, [])\n\n useEffect(() => {\n if (!user && autoLogin && !autoLogin.prefillOnly) {\n void fetchFullUserEvent()\n }\n }, [user, autoLogin])\n\n useEffect(\n () => () => {\n // remove all timeouts on unmount\n clearTimeout(refreshTokenTimeoutRef.current)\n clearTimeout(reminderTimeoutRef.current)\n clearTimeout(forceLogOutTimeoutRef.current)\n },\n [],\n )\n\n if (!user && !fetchedUserOnMount) {\n return null\n }\n\n return (\n <Context\n value={{\n fetchFullUser,\n logOut,\n permissions,\n refreshCookie,\n refreshCookieAsync,\n refreshPermissions,\n setPermissions,\n setUser: setNewUser,\n token: tokenInMemory,\n tokenExpirationMs,\n user,\n }}\n >\n {children}\n </Context>\n )\n}\n\nexport const useAuth = <T = ClientUser,>(): AuthContext<T> => use(Context) as AuthContext<T>\n"],"names":["useModal","usePathname","useRouter","formatAdminURL","qs","React","createContext","use","useCallback","useEffect","useState","toast","stayLoggedInModalSlug","useEffectEvent","useTranslation","requests","useConfig","useRouteTransition","Context","maxTimeoutMs","AuthProvider","children","permissions","initialPermissions","user","initialUser","pathname","router","config","admin","autoLogin","autoRefresh","routes","inactivity","logoutInactivityRoute","userSlug","adminRoute","api","apiRoute","serverURL","i18n","closeAllModals","openModal","startRouteTransition","setUserInMemory","tokenInMemory","setTokenInMemory","tokenExpirationMs","setTokenExpirationMs","setPermissions","forceLogoutBufferMs","setForceLogoutBufferMs","fetchedUserOnMount","setFetchedUserOnMount","refreshTokenTimeoutRef","useRef","reminderTimeoutRef","forceLogOutTimeoutRef","id","redirectToInactivityRoute","replace","path","window","location","startsWith","encodeURIComponent","revokeTokenAndExpire","undefined","clearTimeout","current","handleReminderTimeout","refreshCookieEvent","setNewUser","userResponse","token","exp","expiresInMs","Math","max","min","Date","now","nextForceLogoutBufferMs","setTimeout","refreshCookie","forceRefresh","request","post","headers","language","status","json","e","error","message","refreshCookieAsync","skipSetUser","logOut","collection","_","refreshPermissions","locale","params","stringify","addQueryPrefix","get","Error","fetchFullUser","credentials","fetchFullUserEvent","fetchUserOnMount","prefillOnly","value","setUser","useAuth"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../src/providers/Auth/index.tsx"],"sourcesContent":["'use client'\nimport type { ClientUser, SanitizedPermissions, TypedUser } from 'payload'\n\nimport { useModal } from '@faceless-ui/modal'\nimport { usePathname, useRouter } from 'next/navigation.js'\nimport { formatAdminURL } from 'payload/shared'\nimport * as qs from 'qs-esm'\nimport React, { createContext, use, useCallback, useEffect, useState } from 'react'\nimport { toast } from 'sonner'\n\nimport { stayLoggedInModalSlug } from '../../elements/StayLoggedIn/index.js'\nimport { useEffectEvent } from '../../hooks/useEffectEvent.js'\nimport { useTranslation } from '../../providers/Translation/index.js'\nimport { requests } from '../../utilities/api.js'\nimport { useConfig } from '../Config/index.js'\nimport { useRouteTransition } from '../RouteTransition/index.js'\n\nexport type UserWithToken<T = ClientUser> = {\n /** seconds until expiration */\n exp: number\n token: string\n user: T\n}\n\nexport type AuthContext<T = ClientUser> = {\n fetchFullUser: () => Promise<null | TypedUser>\n logOut: () => Promise<boolean>\n /**\n * These are the permissions for the current user from a global scope.\n *\n * When checking for permissions on document specific level, use the `useDocumentInfo` hook instead.\n *\n * @example\n *\n * ```tsx\n * import { useAuth } from 'payload/ui'\n *\n * const MyComponent: React.FC = () => {\n * const { permissions } = useAuth()\n *\n * if (permissions?.collections?.myCollection?.create) {\n * // user can create documents in 'myCollection'\n * }\n *\n * return null\n * }\n * ```\n *\n * with useDocumentInfo:\n *\n * ```tsx\n * import { useDocumentInfo } from 'payload/ui'\n *\n * const MyComponent: React.FC = () => {\n * const { docPermissions } = useDocumentInfo()\n * if (docPermissions?.create) {\n * // user can create this document\n * }\n * return null\n * } ```\n */\n permissions?: SanitizedPermissions\n refreshCookie: (forceRefresh?: boolean) => void\n refreshCookieAsync: () => Promise<ClientUser>\n refreshPermissions: () => Promise<void>\n setPermissions: (permissions: SanitizedPermissions) => void\n setUser: (user: null | UserWithToken<T>) => void\n strategy?: string\n token?: string\n tokenExpirationMs?: number\n user?: null | T\n}\n\nconst Context = createContext({} as AuthContext)\n\nconst maxTimeoutMs = 2147483647\n\ntype Props = {\n children: React.ReactNode\n permissions?: SanitizedPermissions\n user?: ClientUser | null\n}\n\nexport function AuthProvider({\n children,\n permissions: initialPermissions,\n user: initialUser,\n}: Props) {\n const pathname = usePathname()\n const router = useRouter()\n\n const { config } = useConfig()\n\n const {\n admin: {\n autoLogin,\n autoRefresh,\n routes: { inactivity: logoutInactivityRoute },\n user: userSlug,\n },\n routes: { admin: adminRoute, api: apiRoute },\n serverURL,\n } = config\n\n const { i18n } = useTranslation()\n const { closeAllModals, openModal } = useModal()\n const { startRouteTransition } = useRouteTransition()\n\n const [user, setUserInMemory] = useState<ClientUser | null>(initialUser)\n const [tokenInMemory, setTokenInMemory] = useState<string>()\n const [tokenExpirationMs, setTokenExpirationMs] = useState<number>()\n const [permissions, setPermissions] = useState<SanitizedPermissions>(initialPermissions)\n const [forceLogoutBufferMs, setForceLogoutBufferMs] = useState<number>(120_000)\n const [fetchedUserOnMount, setFetchedUserOnMount] = useState(false)\n\n const refreshTokenTimeoutRef = React.useRef<ReturnType<typeof setTimeout>>(null)\n const reminderTimeoutRef = React.useRef<ReturnType<typeof setTimeout>>(null)\n const forceLogOutTimeoutRef = React.useRef<ReturnType<typeof setTimeout>>(null)\n\n const id = user?.id\n\n const redirectToInactivityRoute = useCallback(() => {\n startRouteTransition(() =>\n router.replace(\n formatAdminURL({\n adminRoute,\n path: `${logoutInactivityRoute}${window.location.pathname.startsWith(adminRoute) ? `?redirect=${encodeURIComponent(window.location.pathname)}` : ''}`,\n }),\n ),\n )\n\n closeAllModals()\n }, [router, adminRoute, logoutInactivityRoute, closeAllModals, startRouteTransition])\n\n const revokeTokenAndExpire = useCallback(() => {\n setUserInMemory(null)\n setTokenInMemory(undefined)\n setTokenExpirationMs(undefined)\n clearTimeout(refreshTokenTimeoutRef.current)\n }, [])\n\n // Handler for reminder timeout - uses useEffectEvent to capture latest autoRefresh value\n const handleReminderTimeout = useEffectEvent(() => {\n if (autoRefresh) {\n refreshCookieEvent()\n } else {\n openModal(stayLoggedInModalSlug)\n }\n })\n\n const setNewUser = useCallback(\n (userResponse: null | UserWithToken) => {\n clearTimeout(reminderTimeoutRef.current)\n clearTimeout(forceLogOutTimeoutRef.current)\n\n if (userResponse?.user) {\n setUserInMemory(userResponse.user)\n setTokenInMemory(userResponse.token)\n setTokenExpirationMs(userResponse.exp * 1000)\n\n const expiresInMs = Math.max(\n 0,\n Math.min((userResponse.exp ?? 0) * 1000 - Date.now(), maxTimeoutMs),\n )\n\n if (expiresInMs) {\n const nextForceLogoutBufferMs = Math.min(60_000, expiresInMs / 2)\n setForceLogoutBufferMs(nextForceLogoutBufferMs)\n\n reminderTimeoutRef.current = setTimeout(\n handleReminderTimeout,\n Math.max(expiresInMs - nextForceLogoutBufferMs, 0),\n )\n\n forceLogOutTimeoutRef.current = setTimeout(() => {\n revokeTokenAndExpire()\n redirectToInactivityRoute()\n }, expiresInMs)\n }\n } else {\n revokeTokenAndExpire()\n }\n },\n [redirectToInactivityRoute, revokeTokenAndExpire],\n )\n\n const refreshCookie = useCallback(\n (forceRefresh?: boolean) => {\n if (!id) {\n return\n }\n\n const expiresInMs = Math.max(0, (tokenExpirationMs ?? 0) - Date.now())\n\n if (forceRefresh || (tokenExpirationMs && expiresInMs < forceLogoutBufferMs * 2)) {\n clearTimeout(refreshTokenTimeoutRef.current)\n refreshTokenTimeoutRef.current = setTimeout(async () => {\n try {\n const request = await requests.post(\n `${serverURL}${apiRoute}/${userSlug}/refresh-token?refresh`,\n {\n headers: {\n 'Accept-Language': i18n.language,\n },\n },\n )\n\n if (request.status === 200) {\n const json: UserWithToken = await request.json()\n setNewUser(json)\n } else {\n setNewUser(null)\n redirectToInactivityRoute()\n }\n } catch (e) {\n toast.error(e.message)\n }\n }, 1000)\n }\n },\n [\n apiRoute,\n i18n.language,\n redirectToInactivityRoute,\n serverURL,\n setNewUser,\n tokenExpirationMs,\n userSlug,\n forceLogoutBufferMs,\n id,\n ],\n )\n\n const refreshCookieAsync = useCallback(\n async (skipSetUser?: boolean): Promise<ClientUser> => {\n try {\n const request = await requests.post(`${serverURL}${apiRoute}/${userSlug}/refresh-token`, {\n headers: {\n 'Accept-Language': i18n.language,\n },\n })\n\n if (request.status === 200) {\n const json: UserWithToken = await request.json()\n if (!skipSetUser) {\n setNewUser(json)\n }\n return json.user\n }\n\n if (user) {\n setNewUser(null)\n redirectToInactivityRoute()\n }\n } catch (e) {\n toast.error(`Refreshing token failed: ${e.message}`)\n }\n return null\n },\n [apiRoute, i18n.language, redirectToInactivityRoute, serverURL, setNewUser, userSlug, user],\n )\n\n const logOut = useCallback(async () => {\n try {\n if (user && user.collection) {\n setNewUser(null)\n await requests.post(`${serverURL}${apiRoute}/${user.collection}/logout`)\n }\n } catch (_) {\n // fail silently and log the user out in state\n }\n\n return true\n }, [apiRoute, serverURL, setNewUser, user])\n\n const refreshPermissions = useCallback(\n async ({ locale }: { locale?: string } = {}) => {\n const params = qs.stringify(\n {\n locale,\n },\n {\n addQueryPrefix: true,\n },\n )\n\n try {\n const request = await requests.get(`${serverURL}${apiRoute}/access${params}`, {\n headers: {\n 'Accept-Language': i18n.language,\n },\n })\n\n if (request.status === 200) {\n const json: SanitizedPermissions = await request.json()\n setPermissions(json)\n } else {\n throw new Error(`Fetching permissions failed with status code ${request.status}`)\n }\n } catch (e) {\n toast.error(`Refreshing permissions failed: ${e.message}`)\n }\n },\n [serverURL, apiRoute, i18n],\n )\n\n const fetchFullUser = React.useCallback(async () => {\n try {\n const request = await requests.get(`${serverURL}${apiRoute}/${userSlug}/me`, {\n credentials: 'include',\n headers: {\n 'Accept-Language': i18n.language,\n },\n })\n\n if (request.status === 200) {\n const json: UserWithToken = await request.json()\n setNewUser(json)\n return json?.user || null\n }\n } catch (e) {\n toast.error(`Fetching user failed: ${e.message}`)\n }\n\n return null\n }, [serverURL, apiRoute, userSlug, i18n.language, setNewUser])\n\n const refreshCookieEvent = useEffectEvent(refreshCookie)\n useEffect(() => {\n // when location changes, refresh cookie\n refreshCookieEvent()\n }, [pathname])\n\n const fetchFullUserEvent = useEffectEvent(fetchFullUser)\n useEffect(() => {\n async function fetchUserOnMount() {\n await fetchFullUserEvent()\n setFetchedUserOnMount(true)\n }\n\n void fetchUserOnMount()\n }, [])\n\n useEffect(() => {\n if (!user && autoLogin && !autoLogin.prefillOnly) {\n void fetchFullUserEvent()\n }\n }, [user, autoLogin])\n\n useEffect(\n () => () => {\n // remove all timeouts on unmount\n clearTimeout(refreshTokenTimeoutRef.current)\n clearTimeout(reminderTimeoutRef.current)\n clearTimeout(forceLogOutTimeoutRef.current)\n },\n [],\n )\n\n if (!user && !fetchedUserOnMount) {\n return null\n }\n\n return (\n <Context\n value={{\n fetchFullUser,\n logOut,\n permissions,\n refreshCookie,\n refreshCookieAsync,\n refreshPermissions,\n setPermissions,\n setUser: setNewUser,\n token: tokenInMemory,\n tokenExpirationMs,\n user,\n }}\n >\n {children}\n </Context>\n )\n}\n\nexport const useAuth = <T = ClientUser,>(): AuthContext<T> => use(Context) as AuthContext<T>\n"],"names":["useModal","usePathname","useRouter","formatAdminURL","qs","React","createContext","use","useCallback","useEffect","useState","toast","stayLoggedInModalSlug","useEffectEvent","useTranslation","requests","useConfig","useRouteTransition","Context","maxTimeoutMs","AuthProvider","children","permissions","initialPermissions","user","initialUser","pathname","router","config","admin","autoLogin","autoRefresh","routes","inactivity","logoutInactivityRoute","userSlug","adminRoute","api","apiRoute","serverURL","i18n","closeAllModals","openModal","startRouteTransition","setUserInMemory","tokenInMemory","setTokenInMemory","tokenExpirationMs","setTokenExpirationMs","setPermissions","forceLogoutBufferMs","setForceLogoutBufferMs","fetchedUserOnMount","setFetchedUserOnMount","refreshTokenTimeoutRef","useRef","reminderTimeoutRef","forceLogOutTimeoutRef","id","redirectToInactivityRoute","replace","path","window","location","startsWith","encodeURIComponent","revokeTokenAndExpire","undefined","clearTimeout","current","handleReminderTimeout","refreshCookieEvent","setNewUser","userResponse","token","exp","expiresInMs","Math","max","min","Date","now","nextForceLogoutBufferMs","setTimeout","refreshCookie","forceRefresh","request","post","headers","language","status","json","e","error","message","refreshCookieAsync","skipSetUser","logOut","collection","_","refreshPermissions","locale","params","stringify","addQueryPrefix","get","Error","fetchFullUser","credentials","fetchFullUserEvent","fetchUserOnMount","prefillOnly","value","setUser","useAuth"],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { jsxDEV as _jsxDEV } from "react/jsx-dev-runtime";
|
|
2
2
|
import React, { createContext, use, useEffect, useRef } from 'react';
|
|
3
3
|
const ClickOutsideContext = /*#__PURE__*/ createContext(null);
|
|
4
4
|
export const ClickOutsideProvider = ({ children })=>{
|
|
@@ -16,13 +16,17 @@ export const ClickOutsideProvider = ({ children })=>{
|
|
|
16
16
|
}, []);
|
|
17
17
|
const register = (listener)=>listeners.current.add(listener);
|
|
18
18
|
const unregister = (listener)=>listeners.current.delete(listener);
|
|
19
|
-
return /*#__PURE__*/
|
|
19
|
+
return /*#__PURE__*/ _jsxDEV(ClickOutsideContext, {
|
|
20
20
|
value: {
|
|
21
21
|
register,
|
|
22
22
|
unregister
|
|
23
23
|
},
|
|
24
24
|
children: children
|
|
25
|
-
}
|
|
25
|
+
}, void 0, false, {
|
|
26
|
+
fileName: "src/providers/ClickOutside/index.tsx",
|
|
27
|
+
lineNumber: 32,
|
|
28
|
+
columnNumber: 10
|
|
29
|
+
}, this);
|
|
26
30
|
};
|
|
27
31
|
export const useClickOutsideContext = ()=>{
|
|
28
32
|
const context = use(ClickOutsideContext);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/providers/ClickOutside/index.tsx"],"sourcesContent":["import React, { createContext, use, useEffect, useRef } from 'react'\n\ntype Listener = {\n handler: () => void\n ref: React.RefObject<HTMLElement>\n}\n\nconst ClickOutsideContext = createContext<{\n register: (listener: Listener) => void\n unregister: (listener: Listener) => void\n} | null>(null)\n\nexport const ClickOutsideProvider: React.FC<{ children: React.ReactNode }> = ({ children }) => {\n const listeners = useRef<Set<Listener>>(new Set())\n\n useEffect(() => {\n const handleClick = (event: MouseEvent) => {\n listeners.current.forEach(({ handler, ref }) => {\n if (ref.current && !ref.current.contains(event.target as Node)) {\n handler()\n }\n })\n }\n\n document.addEventListener('mousedown', handleClick)\n return () => document.removeEventListener('mousedown', handleClick)\n }, [])\n\n const register = (listener: Listener) => listeners.current.add(listener)\n const unregister = (listener: Listener) => listeners.current.delete(listener)\n\n return <ClickOutsideContext value={{ register, unregister }}>{children}</ClickOutsideContext>\n}\n\nexport const useClickOutsideContext = () => {\n const context = use(ClickOutsideContext)\n if (!context) {\n throw new Error('useClickOutside must be used within a ClickOutsideProvider')\n }\n return context\n}\n"],"names":["React","createContext","use","useEffect","useRef","ClickOutsideContext","ClickOutsideProvider","children","listeners","Set","handleClick","event","current","forEach","handler","ref","contains","target","document","addEventListener","removeEventListener","register","listener","add","unregister","delete","value","useClickOutsideContext","context","Error"],"mappings":";AAAA,OAAOA,SAASC,aAAa,EAAEC,GAAG,EAAEC,SAAS,EAAEC,MAAM,QAAQ,QAAO;AAOpE,MAAMC,oCAAsBJ,cAGlB;AAEV,OAAO,MAAMK,uBAAgE,CAAC,EAAEC,QAAQ,EAAE;IACxF,MAAMC,YAAYJ,OAAsB,IAAIK;IAE5CN,UAAU;QACR,MAAMO,cAAc,CAACC;YACnBH,UAAUI,OAAO,CAACC,OAAO,CAAC,CAAC,EAAEC,OAAO,EAAEC,GAAG,EAAE;gBACzC,IAAIA,IAAIH,OAAO,IAAI,CAACG,IAAIH,OAAO,CAACI,QAAQ,CAACL,MAAMM,MAAM,GAAW;oBAC9DH;gBACF;YACF;QACF;QAEAI,SAASC,gBAAgB,CAAC,aAAaT;QACvC,OAAO,IAAMQ,SAASE,mBAAmB,CAAC,aAAaV;IACzD,GAAG,EAAE;IAEL,MAAMW,WAAW,CAACC,WAAuBd,UAAUI,OAAO,CAACW,GAAG,CAACD;IAC/D,MAAME,aAAa,CAACF,WAAuBd,UAAUI,OAAO,CAACa,MAAM,CAACH;IAEpE,qBAAO,
|
|
1
|
+
{"version":3,"sources":["../../../src/providers/ClickOutside/index.tsx"],"sourcesContent":["import React, { createContext, use, useEffect, useRef } from 'react'\n\ntype Listener = {\n handler: () => void\n ref: React.RefObject<HTMLElement>\n}\n\nconst ClickOutsideContext = createContext<{\n register: (listener: Listener) => void\n unregister: (listener: Listener) => void\n} | null>(null)\n\nexport const ClickOutsideProvider: React.FC<{ children: React.ReactNode }> = ({ children }) => {\n const listeners = useRef<Set<Listener>>(new Set())\n\n useEffect(() => {\n const handleClick = (event: MouseEvent) => {\n listeners.current.forEach(({ handler, ref }) => {\n if (ref.current && !ref.current.contains(event.target as Node)) {\n handler()\n }\n })\n }\n\n document.addEventListener('mousedown', handleClick)\n return () => document.removeEventListener('mousedown', handleClick)\n }, [])\n\n const register = (listener: Listener) => listeners.current.add(listener)\n const unregister = (listener: Listener) => listeners.current.delete(listener)\n\n return <ClickOutsideContext value={{ register, unregister }}>{children}</ClickOutsideContext>\n}\n\nexport const useClickOutsideContext = () => {\n const context = use(ClickOutsideContext)\n if (!context) {\n throw new Error('useClickOutside must be used within a ClickOutsideProvider')\n }\n return context\n}\n"],"names":["React","createContext","use","useEffect","useRef","ClickOutsideContext","ClickOutsideProvider","children","listeners","Set","handleClick","event","current","forEach","handler","ref","contains","target","document","addEventListener","removeEventListener","register","listener","add","unregister","delete","value","useClickOutsideContext","context","Error"],"mappings":";AAAA,OAAOA,SAASC,aAAa,EAAEC,GAAG,EAAEC,SAAS,EAAEC,MAAM,QAAQ,QAAO;AAOpE,MAAMC,oCAAsBJ,cAGlB;AAEV,OAAO,MAAMK,uBAAgE,CAAC,EAAEC,QAAQ,EAAE;IACxF,MAAMC,YAAYJ,OAAsB,IAAIK;IAE5CN,UAAU;QACR,MAAMO,cAAc,CAACC;YACnBH,UAAUI,OAAO,CAACC,OAAO,CAAC,CAAC,EAAEC,OAAO,EAAEC,GAAG,EAAE;gBACzC,IAAIA,IAAIH,OAAO,IAAI,CAACG,IAAIH,OAAO,CAACI,QAAQ,CAACL,MAAMM,MAAM,GAAW;oBAC9DH;gBACF;YACF;QACF;QAEAI,SAASC,gBAAgB,CAAC,aAAaT;QACvC,OAAO,IAAMQ,SAASE,mBAAmB,CAAC,aAAaV;IACzD,GAAG,EAAE;IAEL,MAAMW,WAAW,CAACC,WAAuBd,UAAUI,OAAO,CAACW,GAAG,CAACD;IAC/D,MAAME,aAAa,CAACF,WAAuBd,UAAUI,OAAO,CAACa,MAAM,CAACH;IAEpE,qBAAO,QAACjB;QAAoBqB,OAAO;YAAEL;YAAUG;QAAW;kBAAIjB;;;;;;AAChE,EAAC;AAED,OAAO,MAAMoB,yBAAyB;IACpC,MAAMC,UAAU1B,IAAIG;IACpB,IAAI,CAACuB,SAAS;QACZ,MAAM,IAAIC,MAAM;IAClB;IACA,OAAOD;AACT,EAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
'use client';
|
|
2
|
-
import {
|
|
2
|
+
import { jsxDEV as _jsxDEV } from "react/jsx-dev-runtime";
|
|
3
3
|
import React from 'react';
|
|
4
4
|
const ModifyClientFunctionContext = /*#__PURE__*/ React.createContext({
|
|
5
5
|
addClientFunction: ()=>null,
|
|
@@ -26,16 +26,24 @@ export const ClientFunctionProvider = ({ children })=>{
|
|
|
26
26
|
return newState;
|
|
27
27
|
});
|
|
28
28
|
}, []);
|
|
29
|
-
return /*#__PURE__*/
|
|
29
|
+
return /*#__PURE__*/ _jsxDEV(ModifyClientFunctionContext, {
|
|
30
30
|
value: {
|
|
31
31
|
addClientFunction,
|
|
32
32
|
removeClientFunction
|
|
33
33
|
},
|
|
34
|
-
children: /*#__PURE__*/
|
|
34
|
+
children: /*#__PURE__*/ _jsxDEV(ClientFunctionsContext, {
|
|
35
35
|
value: clientFunctions,
|
|
36
36
|
children: children
|
|
37
|
-
}
|
|
38
|
-
|
|
37
|
+
}, void 0, false, {
|
|
38
|
+
fileName: "src/providers/ClientFunction/index.tsx",
|
|
39
|
+
lineNumber: 44,
|
|
40
|
+
columnNumber: 7
|
|
41
|
+
}, this)
|
|
42
|
+
}, void 0, false, {
|
|
43
|
+
fileName: "src/providers/ClientFunction/index.tsx",
|
|
44
|
+
lineNumber: 38,
|
|
45
|
+
columnNumber: 5
|
|
46
|
+
}, this);
|
|
39
47
|
};
|
|
40
48
|
export const useAddClientFunction = (key, func)=>{
|
|
41
49
|
const { addClientFunction, removeClientFunction } = React.use(ModifyClientFunctionContext);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/providers/ClientFunction/index.tsx"],"sourcesContent":["'use client'\nimport React from 'react'\n\ntype ModifyClientFunctionContextType = {\n addClientFunction: (args: ModifyFunctionArgs) => void\n removeClientFunction: (args: ModifyFunctionArgs) => void\n}\ntype ClientFunctionsContextType = Record<string, any>\n\nconst ModifyClientFunctionContext = React.createContext<ModifyClientFunctionContextType>({\n addClientFunction: () => null,\n removeClientFunction: () => null,\n})\nconst ClientFunctionsContext = React.createContext<ClientFunctionsContextType>({})\n\ntype ModifyFunctionArgs = { func: any; key: string }\n\nexport const ClientFunctionProvider: React.FC<{ children: React.ReactNode }> = ({ children }) => {\n const [clientFunctions, setClientFunctions] = React.useState({})\n\n const addClientFunction = React.useCallback((args: ModifyFunctionArgs) => {\n setClientFunctions((state) => {\n const newState = { ...state }\n newState[args.key] = args.func\n return newState\n })\n }, [])\n\n const removeClientFunction = React.useCallback((args: ModifyFunctionArgs) => {\n setClientFunctions((state) => {\n const newState = { ...state }\n delete newState[args.key]\n return newState\n })\n }, [])\n\n return (\n <ModifyClientFunctionContext\n value={{\n addClientFunction,\n removeClientFunction,\n }}\n >\n <ClientFunctionsContext value={clientFunctions}>{children}</ClientFunctionsContext>\n </ModifyClientFunctionContext>\n )\n}\n\nexport const useAddClientFunction = (key: string, func: any) => {\n const { addClientFunction, removeClientFunction } = React.use(ModifyClientFunctionContext)\n\n React.useEffect(() => {\n addClientFunction({\n func,\n key,\n })\n\n return () => {\n removeClientFunction({\n func,\n key,\n })\n }\n }, [func, key, addClientFunction, removeClientFunction])\n}\n\nexport const useClientFunctions = () => {\n return React.use(ClientFunctionsContext)\n}\n"],"names":["React","ModifyClientFunctionContext","createContext","addClientFunction","removeClientFunction","ClientFunctionsContext","ClientFunctionProvider","children","clientFunctions","setClientFunctions","useState","useCallback","args","state","newState","key","func","value","useAddClientFunction","use","useEffect","useClientFunctions"],"mappings":"AAAA;;AACA,OAAOA,WAAW,QAAO;AAQzB,MAAMC,4CAA8BD,MAAME,aAAa,CAAkC;IACvFC,mBAAmB,IAAM;IACzBC,sBAAsB,IAAM;AAC9B;AACA,MAAMC,uCAAyBL,MAAME,aAAa,CAA6B,CAAC;AAIhF,OAAO,MAAMI,yBAAkE,CAAC,EAAEC,QAAQ,EAAE;IAC1F,MAAM,CAACC,iBAAiBC,mBAAmB,GAAGT,MAAMU,QAAQ,CAAC,CAAC;IAE9D,MAAMP,oBAAoBH,MAAMW,WAAW,CAAC,CAACC;QAC3CH,mBAAmB,CAACI;YAClB,MAAMC,WAAW;gBAAE,GAAGD,KAAK;YAAC;YAC5BC,QAAQ,CAACF,KAAKG,GAAG,CAAC,GAAGH,KAAKI,IAAI;YAC9B,OAAOF;QACT;IACF,GAAG,EAAE;IAEL,MAAMV,uBAAuBJ,MAAMW,WAAW,CAAC,CAACC;QAC9CH,mBAAmB,CAACI;YAClB,MAAMC,WAAW;gBAAE,GAAGD,KAAK;YAAC;YAC5B,OAAOC,QAAQ,CAACF,KAAKG,GAAG,CAAC;YACzB,OAAOD;QACT;IACF,GAAG,EAAE;IAEL,qBACE,
|
|
1
|
+
{"version":3,"sources":["../../../src/providers/ClientFunction/index.tsx"],"sourcesContent":["'use client'\nimport React from 'react'\n\ntype ModifyClientFunctionContextType = {\n addClientFunction: (args: ModifyFunctionArgs) => void\n removeClientFunction: (args: ModifyFunctionArgs) => void\n}\ntype ClientFunctionsContextType = Record<string, any>\n\nconst ModifyClientFunctionContext = React.createContext<ModifyClientFunctionContextType>({\n addClientFunction: () => null,\n removeClientFunction: () => null,\n})\nconst ClientFunctionsContext = React.createContext<ClientFunctionsContextType>({})\n\ntype ModifyFunctionArgs = { func: any; key: string }\n\nexport const ClientFunctionProvider: React.FC<{ children: React.ReactNode }> = ({ children }) => {\n const [clientFunctions, setClientFunctions] = React.useState({})\n\n const addClientFunction = React.useCallback((args: ModifyFunctionArgs) => {\n setClientFunctions((state) => {\n const newState = { ...state }\n newState[args.key] = args.func\n return newState\n })\n }, [])\n\n const removeClientFunction = React.useCallback((args: ModifyFunctionArgs) => {\n setClientFunctions((state) => {\n const newState = { ...state }\n delete newState[args.key]\n return newState\n })\n }, [])\n\n return (\n <ModifyClientFunctionContext\n value={{\n addClientFunction,\n removeClientFunction,\n }}\n >\n <ClientFunctionsContext value={clientFunctions}>{children}</ClientFunctionsContext>\n </ModifyClientFunctionContext>\n )\n}\n\nexport const useAddClientFunction = (key: string, func: any) => {\n const { addClientFunction, removeClientFunction } = React.use(ModifyClientFunctionContext)\n\n React.useEffect(() => {\n addClientFunction({\n func,\n key,\n })\n\n return () => {\n removeClientFunction({\n func,\n key,\n })\n }\n }, [func, key, addClientFunction, removeClientFunction])\n}\n\nexport const useClientFunctions = () => {\n return React.use(ClientFunctionsContext)\n}\n"],"names":["React","ModifyClientFunctionContext","createContext","addClientFunction","removeClientFunction","ClientFunctionsContext","ClientFunctionProvider","children","clientFunctions","setClientFunctions","useState","useCallback","args","state","newState","key","func","value","useAddClientFunction","use","useEffect","useClientFunctions"],"mappings":"AAAA;;AACA,OAAOA,WAAW,QAAO;AAQzB,MAAMC,4CAA8BD,MAAME,aAAa,CAAkC;IACvFC,mBAAmB,IAAM;IACzBC,sBAAsB,IAAM;AAC9B;AACA,MAAMC,uCAAyBL,MAAME,aAAa,CAA6B,CAAC;AAIhF,OAAO,MAAMI,yBAAkE,CAAC,EAAEC,QAAQ,EAAE;IAC1F,MAAM,CAACC,iBAAiBC,mBAAmB,GAAGT,MAAMU,QAAQ,CAAC,CAAC;IAE9D,MAAMP,oBAAoBH,MAAMW,WAAW,CAAC,CAACC;QAC3CH,mBAAmB,CAACI;YAClB,MAAMC,WAAW;gBAAE,GAAGD,KAAK;YAAC;YAC5BC,QAAQ,CAACF,KAAKG,GAAG,CAAC,GAAGH,KAAKI,IAAI;YAC9B,OAAOF;QACT;IACF,GAAG,EAAE;IAEL,MAAMV,uBAAuBJ,MAAMW,WAAW,CAAC,CAACC;QAC9CH,mBAAmB,CAACI;YAClB,MAAMC,WAAW;gBAAE,GAAGD,KAAK;YAAC;YAC5B,OAAOC,QAAQ,CAACF,KAAKG,GAAG,CAAC;YACzB,OAAOD;QACT;IACF,GAAG,EAAE;IAEL,qBACE,QAACb;QACCgB,OAAO;YACLd;YACAC;QACF;kBAEA,cAAA,QAACC;YAAuBY,OAAOT;sBAAkBD;;;;;;;;;;;AAGvD,EAAC;AAED,OAAO,MAAMW,uBAAuB,CAACH,KAAaC;IAChD,MAAM,EAAEb,iBAAiB,EAAEC,oBAAoB,EAAE,GAAGJ,MAAMmB,GAAG,CAAClB;IAE9DD,MAAMoB,SAAS,CAAC;QACdjB,kBAAkB;YAChBa;YACAD;QACF;QAEA,OAAO;YACLX,qBAAqB;gBACnBY;gBACAD;YACF;QACF;IACF,GAAG;QAACC;QAAMD;QAAKZ;QAAmBC;KAAqB;AACzD,EAAC;AAED,OAAO,MAAMiB,qBAAqB;IAChC,OAAOrB,MAAMmB,GAAG,CAACd;AACnB,EAAC"}
|
|
@@ -1,9 +1,18 @@
|
|
|
1
1
|
/* eslint-disable perfectionist/sort-object-types */ // Need to disable this rule because the order of the overloads is important
|
|
2
2
|
'use client';
|
|
3
|
-
import {
|
|
3
|
+
import { jsxDEV as _jsxDEV } from "react/jsx-dev-runtime";
|
|
4
4
|
import React, { createContext, use, useCallback, useEffect, useMemo } from 'react';
|
|
5
5
|
import { useControllableState } from '../../hooks/useControllableState.js';
|
|
6
|
-
|
|
6
|
+
// Overload #1: collectionSlug only
|
|
7
|
+
// @todo remove "{} |" in 4.0, which would be a breaking change
|
|
8
|
+
// Overload #2: globalSlug only
|
|
9
|
+
// @todo remove "{} |" in 4.0, which would be a breaking change
|
|
10
|
+
// Overload #3: both/none (fall back to union | null)
|
|
11
|
+
/**
|
|
12
|
+
* Get a collection or global config by its slug. This is preferred over
|
|
13
|
+
* using `config.collections.find` or `config.globals.find`, because
|
|
14
|
+
* getEntityConfig uses a lookup map for O(1) lookups.
|
|
15
|
+
*/ const RootConfigContext = /*#__PURE__*/ createContext(undefined);
|
|
7
16
|
export const ConfigProvider = ({ children, config: configFromProps })=>{
|
|
8
17
|
// Need to update local config state if config from props changes, for HMR.
|
|
9
18
|
// That way, config changes will be updated in the UI immediately without needing a refresh.
|
|
@@ -47,10 +56,14 @@ export const ConfigProvider = ({ children, config: configFromProps })=>{
|
|
|
47
56
|
getEntityConfig,
|
|
48
57
|
setConfig
|
|
49
58
|
]);
|
|
50
|
-
return /*#__PURE__*/
|
|
59
|
+
return /*#__PURE__*/ _jsxDEV(RootConfigContext, {
|
|
51
60
|
value: value,
|
|
52
61
|
children: children
|
|
53
|
-
}
|
|
62
|
+
}, void 0, false, {
|
|
63
|
+
fileName: "src/providers/Config/index.tsx",
|
|
64
|
+
lineNumber: 89,
|
|
65
|
+
columnNumber: 10
|
|
66
|
+
}, this);
|
|
54
67
|
};
|
|
55
68
|
export const useConfig = ()=>use(RootConfigContext);
|
|
56
69
|
/**
|
|
@@ -81,10 +94,14 @@ export const useConfig = ()=>use(RootConfigContext);
|
|
|
81
94
|
// Unfortunately, referential equality alone does not work bc the reference is lost during server/client serialization,
|
|
82
95
|
// so we need to also compare the `unauthenticated` property.
|
|
83
96
|
if (rootConfig !== configFromProps && rootConfig.unauthenticated !== configFromProps.unauthenticated) {
|
|
84
|
-
return /*#__PURE__*/
|
|
97
|
+
return /*#__PURE__*/ _jsxDEV(ConfigProvider, {
|
|
85
98
|
config: configFromProps,
|
|
86
99
|
children: children
|
|
87
|
-
}
|
|
100
|
+
}, void 0, false, {
|
|
101
|
+
fileName: "src/providers/Config/index.tsx",
|
|
102
|
+
lineNumber: 129,
|
|
103
|
+
columnNumber: 12
|
|
104
|
+
}, this);
|
|
88
105
|
}
|
|
89
106
|
return children;
|
|
90
107
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/providers/Config/index.tsx"],"sourcesContent":["/* eslint-disable perfectionist/sort-object-types */ // Need to disable this rule because the order of the overloads is important\n'use client'\nimport type {\n ClientCollectionConfig,\n ClientConfig,\n ClientGlobalConfig,\n CollectionSlug,\n GlobalSlug,\n} from 'payload'\n\nimport React, { createContext, use, useCallback, useEffect, useMemo } from 'react'\n\nimport { useControllableState } from '../../hooks/useControllableState.js'\n\ntype GetEntityConfigFn = {\n // Overload #1: collectionSlug only\n // @todo remove \"{} |\" in 4.0, which would be a breaking change\n (args: { collectionSlug: {} | CollectionSlug; globalSlug?: never }): ClientCollectionConfig\n\n // Overload #2: globalSlug only\n // @todo remove \"{} |\" in 4.0, which would be a breaking change\n (args: { collectionSlug?: never; globalSlug: {} | GlobalSlug }): ClientGlobalConfig\n\n // Overload #3: both/none (fall back to union | null)\n (args: {\n collectionSlug?: {} | CollectionSlug\n globalSlug?: {} | GlobalSlug\n }): ClientCollectionConfig | ClientGlobalConfig | null\n}\n\nexport type ClientConfigContext = {\n config: ClientConfig\n /**\n * Get a collection or global config by its slug. This is preferred over\n * using `config.collections.find` or `config.globals.find`, because\n * getEntityConfig uses a lookup map for O(1) lookups.\n */\n getEntityConfig: GetEntityConfigFn\n setConfig: (config: ClientConfig) => void\n}\n\nconst RootConfigContext = createContext<ClientConfigContext | undefined>(undefined)\n\nexport const ConfigProvider: React.FC<{\n readonly children: React.ReactNode\n readonly config: ClientConfig\n}> = ({ children, config: configFromProps }) => {\n // Need to update local config state if config from props changes, for HMR.\n // That way, config changes will be updated in the UI immediately without needing a refresh.\n // useControllableState handles this for us.\n const [config, setConfig] = useControllableState<ClientConfig>(configFromProps)\n\n // Build lookup maps for collections and globals so we can do O(1) lookups by slug\n const { collectionsBySlug, globalsBySlug } = useMemo(() => {\n const collectionsBySlug: Record<string, ClientCollectionConfig> = {}\n const globalsBySlug: Record<string, ClientGlobalConfig> = {}\n\n for (const collection of config.collections) {\n collectionsBySlug[collection.slug] = collection\n }\n\n for (const global of config.globals) {\n globalsBySlug[global.slug] = global\n }\n\n return { collectionsBySlug, globalsBySlug }\n }, [config])\n\n const getEntityConfig = useCallback<GetEntityConfigFn>(\n (args) => {\n if ('collectionSlug' in args) {\n return collectionsBySlug[args.collectionSlug] ?? null\n }\n\n if ('globalSlug' in args) {\n return globalsBySlug[args.globalSlug] ?? null\n }\n\n return null as any\n },\n [collectionsBySlug, globalsBySlug],\n )\n\n const value = useMemo(\n () => ({ config, getEntityConfig, setConfig }),\n [config, getEntityConfig, setConfig],\n )\n\n return <RootConfigContext value={value}>{children}</RootConfigContext>\n}\n\nexport const useConfig = (): ClientConfigContext => use(RootConfigContext)\n\n/**\n * This provider shadows the `ConfigProvider` on the _page_ level, allowing us to\n * update the config when needed, e.g. after authentication.\n * The layout `ConfigProvider` is not updated on page navigation / authentication,\n * as the layout does not re-render in those cases.\n *\n * If the config here has the same reference as the config from the layout, we\n * simply reuse the context from the layout to avoid unnecessary re-renders.\n *\n * @experimental This component is experimental and may change or be removed in future releases. Use at your own risk.\n */\nexport const PageConfigProvider: React.FC<{\n readonly children: React.ReactNode\n readonly config: ClientConfig\n}> = ({ children, config: configFromProps }) => {\n const { config: rootConfig, setConfig: setRootConfig } = useConfig()\n\n /**\n * This `useEffect` is required in order for the _page_ to be able to refresh the client config,\n * which may have been cached on the _layout_ level, where the `ConfigProvider` is managed.\n * Since the layout does not re-render on page navigation / authentication, we need to manually\n * update the config, as the user may have been authenticated in the process, which affects the client config.\n */\n useEffect(() => {\n setRootConfig(configFromProps)\n }, [configFromProps, setRootConfig])\n\n // If this component receives a different config than what is in context from the layout, it is stale.\n // While stale, we instantiate a new context provider that provides the new config until the root context is updated.\n // Unfortunately, referential equality alone does not work bc the reference is lost during server/client serialization,\n // so we need to also compare the `unauthenticated` property.\n if (\n rootConfig !== configFromProps &&\n rootConfig.unauthenticated !== configFromProps.unauthenticated\n ) {\n return <ConfigProvider config={configFromProps}>{children}</ConfigProvider>\n }\n\n return children\n}\n"],"names":["React","createContext","use","useCallback","useEffect","useMemo","useControllableState","RootConfigContext","undefined","ConfigProvider","children","config","configFromProps","setConfig","collectionsBySlug","globalsBySlug","collection","collections","slug","global","globals","getEntityConfig","args","collectionSlug","globalSlug","value","useConfig","PageConfigProvider","rootConfig","setRootConfig","unauthenticated"],"mappings":"AAAA,mDAAmD,GAAG,4EAA4E;AAClI;;AASA,OAAOA,SAASC,aAAa,EAAEC,GAAG,EAAEC,WAAW,EAAEC,SAAS,EAAEC,OAAO,QAAQ,QAAO;AAElF,SAASC,oBAAoB,QAAQ,sCAAqC;
|
|
1
|
+
{"version":3,"sources":["../../../src/providers/Config/index.tsx"],"sourcesContent":["/* eslint-disable perfectionist/sort-object-types */ // Need to disable this rule because the order of the overloads is important\n'use client'\nimport type {\n ClientCollectionConfig,\n ClientConfig,\n ClientGlobalConfig,\n CollectionSlug,\n GlobalSlug,\n} from 'payload'\n\nimport React, { createContext, use, useCallback, useEffect, useMemo } from 'react'\n\nimport { useControllableState } from '../../hooks/useControllableState.js'\n\ntype GetEntityConfigFn = {\n // Overload #1: collectionSlug only\n // @todo remove \"{} |\" in 4.0, which would be a breaking change\n (args: { collectionSlug: {} | CollectionSlug; globalSlug?: never }): ClientCollectionConfig\n\n // Overload #2: globalSlug only\n // @todo remove \"{} |\" in 4.0, which would be a breaking change\n (args: { collectionSlug?: never; globalSlug: {} | GlobalSlug }): ClientGlobalConfig\n\n // Overload #3: both/none (fall back to union | null)\n (args: {\n collectionSlug?: {} | CollectionSlug\n globalSlug?: {} | GlobalSlug\n }): ClientCollectionConfig | ClientGlobalConfig | null\n}\n\nexport type ClientConfigContext = {\n config: ClientConfig\n /**\n * Get a collection or global config by its slug. This is preferred over\n * using `config.collections.find` or `config.globals.find`, because\n * getEntityConfig uses a lookup map for O(1) lookups.\n */\n getEntityConfig: GetEntityConfigFn\n setConfig: (config: ClientConfig) => void\n}\n\nconst RootConfigContext = createContext<ClientConfigContext | undefined>(undefined)\n\nexport const ConfigProvider: React.FC<{\n readonly children: React.ReactNode\n readonly config: ClientConfig\n}> = ({ children, config: configFromProps }) => {\n // Need to update local config state if config from props changes, for HMR.\n // That way, config changes will be updated in the UI immediately without needing a refresh.\n // useControllableState handles this for us.\n const [config, setConfig] = useControllableState<ClientConfig>(configFromProps)\n\n // Build lookup maps for collections and globals so we can do O(1) lookups by slug\n const { collectionsBySlug, globalsBySlug } = useMemo(() => {\n const collectionsBySlug: Record<string, ClientCollectionConfig> = {}\n const globalsBySlug: Record<string, ClientGlobalConfig> = {}\n\n for (const collection of config.collections) {\n collectionsBySlug[collection.slug] = collection\n }\n\n for (const global of config.globals) {\n globalsBySlug[global.slug] = global\n }\n\n return { collectionsBySlug, globalsBySlug }\n }, [config])\n\n const getEntityConfig = useCallback<GetEntityConfigFn>(\n (args) => {\n if ('collectionSlug' in args) {\n return collectionsBySlug[args.collectionSlug] ?? null\n }\n\n if ('globalSlug' in args) {\n return globalsBySlug[args.globalSlug] ?? null\n }\n\n return null as any\n },\n [collectionsBySlug, globalsBySlug],\n )\n\n const value = useMemo(\n () => ({ config, getEntityConfig, setConfig }),\n [config, getEntityConfig, setConfig],\n )\n\n return <RootConfigContext value={value}>{children}</RootConfigContext>\n}\n\nexport const useConfig = (): ClientConfigContext => use(RootConfigContext)\n\n/**\n * This provider shadows the `ConfigProvider` on the _page_ level, allowing us to\n * update the config when needed, e.g. after authentication.\n * The layout `ConfigProvider` is not updated on page navigation / authentication,\n * as the layout does not re-render in those cases.\n *\n * If the config here has the same reference as the config from the layout, we\n * simply reuse the context from the layout to avoid unnecessary re-renders.\n *\n * @experimental This component is experimental and may change or be removed in future releases. Use at your own risk.\n */\nexport const PageConfigProvider: React.FC<{\n readonly children: React.ReactNode\n readonly config: ClientConfig\n}> = ({ children, config: configFromProps }) => {\n const { config: rootConfig, setConfig: setRootConfig } = useConfig()\n\n /**\n * This `useEffect` is required in order for the _page_ to be able to refresh the client config,\n * which may have been cached on the _layout_ level, where the `ConfigProvider` is managed.\n * Since the layout does not re-render on page navigation / authentication, we need to manually\n * update the config, as the user may have been authenticated in the process, which affects the client config.\n */\n useEffect(() => {\n setRootConfig(configFromProps)\n }, [configFromProps, setRootConfig])\n\n // If this component receives a different config than what is in context from the layout, it is stale.\n // While stale, we instantiate a new context provider that provides the new config until the root context is updated.\n // Unfortunately, referential equality alone does not work bc the reference is lost during server/client serialization,\n // so we need to also compare the `unauthenticated` property.\n if (\n rootConfig !== configFromProps &&\n rootConfig.unauthenticated !== configFromProps.unauthenticated\n ) {\n return <ConfigProvider config={configFromProps}>{children}</ConfigProvider>\n }\n\n return children\n}\n"],"names":["React","createContext","use","useCallback","useEffect","useMemo","useControllableState","RootConfigContext","undefined","ConfigProvider","children","config","configFromProps","setConfig","collectionsBySlug","globalsBySlug","collection","collections","slug","global","globals","getEntityConfig","args","collectionSlug","globalSlug","value","useConfig","PageConfigProvider","rootConfig","setRootConfig","unauthenticated"],"mappings":"AAAA,mDAAmD,GAAG,4EAA4E;AAClI;;AASA,OAAOA,SAASC,aAAa,EAAEC,GAAG,EAAEC,WAAW,EAAEC,SAAS,EAAEC,OAAO,QAAQ,QAAO;AAElF,SAASC,oBAAoB,QAAQ,sCAAqC;AAGxE,mCAAmC;AACnC,+DAA+D;AAG/D,+BAA+B;AAC/B,+DAA+D;AAG/D,qDAAqD;AASrD;;;;GAIC,GAKH,MAAMC,kCAAoBN,cAA+CO;AAEzE,OAAO,MAAMC,iBAGR,CAAC,EAAEC,QAAQ,EAAEC,QAAQC,eAAe,EAAE;IACzC,2EAA2E;IAC3E,4FAA4F;IAC5F,4CAA4C;IAC5C,MAAM,CAACD,QAAQE,UAAU,GAAGP,qBAAmCM;IAE/D,kFAAkF;IAClF,MAAM,EAAEE,iBAAiB,EAAEC,aAAa,EAAE,GAAGV,QAAQ;QACnD,MAAMS,oBAA4D,CAAC;QACnE,MAAMC,gBAAoD,CAAC;QAE3D,KAAK,MAAMC,cAAcL,OAAOM,WAAW,CAAE;YAC3CH,iBAAiB,CAACE,WAAWE,IAAI,CAAC,GAAGF;QACvC;QAEA,KAAK,MAAMG,UAAUR,OAAOS,OAAO,CAAE;YACnCL,aAAa,CAACI,OAAOD,IAAI,CAAC,GAAGC;QAC/B;QAEA,OAAO;YAAEL;YAAmBC;QAAc;IAC5C,GAAG;QAACJ;KAAO;IAEX,MAAMU,kBAAkBlB,YACtB,CAACmB;QACC,IAAI,oBAAoBA,MAAM;YAC5B,OAAOR,iBAAiB,CAACQ,KAAKC,cAAc,CAAC,IAAI;QACnD;QAEA,IAAI,gBAAgBD,MAAM;YACxB,OAAOP,aAAa,CAACO,KAAKE,UAAU,CAAC,IAAI;QAC3C;QAEA,OAAO;IACT,GACA;QAACV;QAAmBC;KAAc;IAGpC,MAAMU,QAAQpB,QACZ,IAAO,CAAA;YAAEM;YAAQU;YAAiBR;QAAU,CAAA,GAC5C;QAACF;QAAQU;QAAiBR;KAAU;IAGtC,qBAAO,QAACN;QAAkBkB,OAAOA;kBAAQf;;;;;;AAC3C,EAAC;AAED,OAAO,MAAMgB,YAAY,IAA2BxB,IAAIK,mBAAkB;AAE1E;;;;;;;;;;CAUC,GACD,OAAO,MAAMoB,qBAGR,CAAC,EAAEjB,QAAQ,EAAEC,QAAQC,eAAe,EAAE;IACzC,MAAM,EAAED,QAAQiB,UAAU,EAAEf,WAAWgB,aAAa,EAAE,GAAGH;IAEzD;;;;;GAKC,GACDtB,UAAU;QACRyB,cAAcjB;IAChB,GAAG;QAACA;QAAiBiB;KAAc;IAEnC,sGAAsG;IACtG,qHAAqH;IACrH,uHAAuH;IACvH,6DAA6D;IAC7D,IACED,eAAehB,mBACfgB,WAAWE,eAAe,KAAKlB,gBAAgBkB,eAAe,EAC9D;QACA,qBAAO,QAACrB;YAAeE,QAAQC;sBAAkBF;;;;;;IACnD;IAEA,OAAOA;AACT,EAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
'use client';
|
|
2
|
-
import {
|
|
2
|
+
import { jsxDEV as _jsxDEV } from "react/jsx-dev-runtime";
|
|
3
3
|
import React, { createContext, use, useState } from 'react';
|
|
4
4
|
const Context = /*#__PURE__*/ createContext({
|
|
5
5
|
mostRecentUpdate: null,
|
|
@@ -7,13 +7,17 @@ const Context = /*#__PURE__*/ createContext({
|
|
|
7
7
|
});
|
|
8
8
|
export const DocumentEventsProvider = ({ children })=>{
|
|
9
9
|
const [mostRecentUpdate, reportUpdate] = useState(null);
|
|
10
|
-
return /*#__PURE__*/
|
|
10
|
+
return /*#__PURE__*/ _jsxDEV(Context, {
|
|
11
11
|
value: {
|
|
12
12
|
mostRecentUpdate,
|
|
13
13
|
reportUpdate
|
|
14
14
|
},
|
|
15
15
|
children: children
|
|
16
|
-
}
|
|
16
|
+
}, void 0, false, {
|
|
17
|
+
fileName: "src/providers/DocumentEvents/index.tsx",
|
|
18
|
+
lineNumber: 17,
|
|
19
|
+
columnNumber: 10
|
|
20
|
+
}, this);
|
|
17
21
|
};
|
|
18
22
|
/**
|
|
19
23
|
* The useDocumentEvents hook provides a way of subscribing to cross-document events,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/providers/DocumentEvents/index.tsx"],"sourcesContent":["'use client'\nimport type { DocumentEvent } from 'payload'\n\nimport React, { createContext, use, useState } from 'react'\n\nconst Context = createContext<{\n mostRecentUpdate: DocumentEvent | null\n reportUpdate: (event: DocumentEvent) => void\n}>({\n mostRecentUpdate: null,\n reportUpdate: () => null,\n})\n\nexport const DocumentEventsProvider: React.FC<{ children: React.ReactNode }> = ({ children }) => {\n const [mostRecentUpdate, reportUpdate] = useState<DocumentEvent>(null)\n\n return <Context value={{ mostRecentUpdate, reportUpdate }}>{children}</Context>\n}\n\n/**\n * The useDocumentEvents hook provides a way of subscribing to cross-document events,\n * such as updates made to nested documents within a drawer.\n * This hook will report document events that are outside the scope of the document currently being edited.\n *\n * @link https://payloadcms.com/docs/admin/react-hooks#usedocumentevents\n */\nexport const useDocumentEvents = () => use(Context)\n"],"names":["React","createContext","use","useState","Context","mostRecentUpdate","reportUpdate","DocumentEventsProvider","children","value","useDocumentEvents"],"mappings":"AAAA;;AAGA,OAAOA,SAASC,aAAa,EAAEC,GAAG,EAAEC,QAAQ,QAAQ,QAAO;AAE3D,MAAMC,wBAAUH,cAGb;IACDI,kBAAkB;IAClBC,cAAc,IAAM;AACtB;AAEA,OAAO,MAAMC,yBAAkE,CAAC,EAAEC,QAAQ,EAAE;IAC1F,MAAM,CAACH,kBAAkBC,aAAa,GAAGH,SAAwB;IAEjE,qBAAO,
|
|
1
|
+
{"version":3,"sources":["../../../src/providers/DocumentEvents/index.tsx"],"sourcesContent":["'use client'\nimport type { DocumentEvent } from 'payload'\n\nimport React, { createContext, use, useState } from 'react'\n\nconst Context = createContext<{\n mostRecentUpdate: DocumentEvent | null\n reportUpdate: (event: DocumentEvent) => void\n}>({\n mostRecentUpdate: null,\n reportUpdate: () => null,\n})\n\nexport const DocumentEventsProvider: React.FC<{ children: React.ReactNode }> = ({ children }) => {\n const [mostRecentUpdate, reportUpdate] = useState<DocumentEvent>(null)\n\n return <Context value={{ mostRecentUpdate, reportUpdate }}>{children}</Context>\n}\n\n/**\n * The useDocumentEvents hook provides a way of subscribing to cross-document events,\n * such as updates made to nested documents within a drawer.\n * This hook will report document events that are outside the scope of the document currently being edited.\n *\n * @link https://payloadcms.com/docs/admin/react-hooks#usedocumentevents\n */\nexport const useDocumentEvents = () => use(Context)\n"],"names":["React","createContext","use","useState","Context","mostRecentUpdate","reportUpdate","DocumentEventsProvider","children","value","useDocumentEvents"],"mappings":"AAAA;;AAGA,OAAOA,SAASC,aAAa,EAAEC,GAAG,EAAEC,QAAQ,QAAQ,QAAO;AAE3D,MAAMC,wBAAUH,cAGb;IACDI,kBAAkB;IAClBC,cAAc,IAAM;AACtB;AAEA,OAAO,MAAMC,yBAAkE,CAAC,EAAEC,QAAQ,EAAE;IAC1F,MAAM,CAACH,kBAAkBC,aAAa,GAAGH,SAAwB;IAEjE,qBAAO,QAACC;QAAQK,OAAO;YAAEJ;YAAkBC;QAAa;kBAAIE;;;;;;AAC9D,EAAC;AAED;;;;;;CAMC,GACD,OAAO,MAAME,oBAAoB,IAAMR,IAAIE,SAAQ"}
|