@focus-reactive/payload-plugin-comments 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +562 -0
- package/dist/collection/access/isAuth.d.ts +3 -0
- package/dist/collection/access/isAuth.d.ts.map +1 -0
- package/dist/collection/access/isAuth.js +8 -0
- package/dist/collection/access/isAuth.js.map +1 -0
- package/dist/collection/hooks/setAuthorBeforeCreate.d.ts +3 -0
- package/dist/collection/hooks/setAuthorBeforeCreate.d.ts.map +1 -0
- package/dist/collection/hooks/setAuthorBeforeCreate.js +10 -0
- package/dist/collection/hooks/setAuthorBeforeCreate.js.map +1 -0
- package/dist/collection/hooks/setTenantBeforeCreate.d.ts +3 -0
- package/dist/collection/hooks/setTenantBeforeCreate.d.ts.map +1 -0
- package/dist/collection/hooks/setTenantBeforeCreate.js +24 -0
- package/dist/collection/hooks/setTenantBeforeCreate.js.map +1 -0
- package/dist/collection/index.d.ts +4 -0
- package/dist/collection/index.d.ts.map +1 -0
- package/dist/collection/index.js +139 -0
- package/dist/collection/index.js.map +1 -0
- package/dist/components/Avatar/index.d.ts +11 -0
- package/dist/components/Avatar/index.d.ts.map +1 -0
- package/dist/components/Avatar/index.js +11 -0
- package/dist/components/Avatar/index.js.map +1 -0
- package/dist/components/CommentEditor/ActionPanel.d.ts +8 -0
- package/dist/components/CommentEditor/ActionPanel.d.ts.map +1 -0
- package/dist/components/CommentEditor/ActionPanel.js +17 -0
- package/dist/components/CommentEditor/ActionPanel.js.map +1 -0
- package/dist/components/CommentEditor/index.d.ts +23 -0
- package/dist/components/CommentEditor/index.d.ts.map +1 -0
- package/dist/components/CommentEditor/index.js +265 -0
- package/dist/components/CommentEditor/index.js.map +1 -0
- package/dist/components/CommentItem/ToolsPanel.d.ts +9 -0
- package/dist/components/CommentItem/ToolsPanel.d.ts.map +1 -0
- package/dist/components/CommentItem/ToolsPanel.js +22 -0
- package/dist/components/CommentItem/ToolsPanel.js.map +1 -0
- package/dist/components/CommentItem/index.d.ts +8 -0
- package/dist/components/CommentItem/index.d.ts.map +1 -0
- package/dist/components/CommentItem/index.js +65 -0
- package/dist/components/CommentItem/index.js.map +1 -0
- package/dist/components/CommentsDrawer/components/Header.d.ts +6 -0
- package/dist/components/CommentsDrawer/components/Header.d.ts.map +1 -0
- package/dist/components/CommentsDrawer/components/Header.js +46 -0
- package/dist/components/CommentsDrawer/components/Header.js.map +1 -0
- package/dist/components/CommentsDrawer/index.d.ts +6 -0
- package/dist/components/CommentsDrawer/index.d.ts.map +1 -0
- package/dist/components/CommentsDrawer/index.js +30 -0
- package/dist/components/CommentsDrawer/index.js.map +1 -0
- package/dist/components/CommentsHeaderButton/index.d.ts +2 -0
- package/dist/components/CommentsHeaderButton/index.d.ts.map +1 -0
- package/dist/components/CommentsHeaderButton/index.js +19 -0
- package/dist/components/CommentsHeaderButton/index.js.map +1 -0
- package/dist/components/CommentsPanel/components/CollapsibleGroup.d.ts +10 -0
- package/dist/components/CommentsPanel/components/CollapsibleGroup.d.ts.map +1 -0
- package/dist/components/CommentsPanel/components/CollapsibleGroup.js +68 -0
- package/dist/components/CommentsPanel/components/CollapsibleGroup.js.map +1 -0
- package/dist/components/CommentsPanel/components/DocumentView.d.ts +9 -0
- package/dist/components/CommentsPanel/components/DocumentView.d.ts.map +1 -0
- package/dist/components/CommentsPanel/components/DocumentView.js +20 -0
- package/dist/components/CommentsPanel/components/DocumentView.js.map +1 -0
- package/dist/components/CommentsPanel/components/FieldGroupSection.d.ts +11 -0
- package/dist/components/CommentsPanel/components/FieldGroupSection.d.ts.map +1 -0
- package/dist/components/CommentsPanel/components/FieldGroupSection.js +62 -0
- package/dist/components/CommentsPanel/components/FieldGroupSection.js.map +1 -0
- package/dist/components/CommentsPanel/components/GlobalDocumentView.d.ts +9 -0
- package/dist/components/CommentsPanel/components/GlobalDocumentView.d.ts.map +1 -0
- package/dist/components/CommentsPanel/components/GlobalDocumentView.js +20 -0
- package/dist/components/CommentsPanel/components/GlobalDocumentView.js.map +1 -0
- package/dist/components/CommentsPanel/components/GlobalView.d.ts +9 -0
- package/dist/components/CommentsPanel/components/GlobalView.d.ts.map +1 -0
- package/dist/components/CommentsPanel/components/GlobalView.js +62 -0
- package/dist/components/CommentsPanel/components/GlobalView.js.map +1 -0
- package/dist/components/CommentsPanel/constants.d.ts +3 -0
- package/dist/components/CommentsPanel/constants.d.ts.map +1 -0
- package/dist/components/CommentsPanel/constants.js +9 -0
- package/dist/components/CommentsPanel/constants.js.map +1 -0
- package/dist/components/CommentsPanel/hooks/useCollapseState.d.ts +2 -0
- package/dist/components/CommentsPanel/hooks/useCollapseState.d.ts.map +1 -0
- package/dist/components/CommentsPanel/hooks/useCollapseState.js +44 -0
- package/dist/components/CommentsPanel/hooks/useCollapseState.js.map +1 -0
- package/dist/components/CommentsPanel/hooks/useScrollToTargetFieldGroup.d.ts +2 -0
- package/dist/components/CommentsPanel/hooks/useScrollToTargetFieldGroup.d.ts.map +1 -0
- package/dist/components/CommentsPanel/hooks/useScrollToTargetFieldGroup.js +35 -0
- package/dist/components/CommentsPanel/hooks/useScrollToTargetFieldGroup.js.map +1 -0
- package/dist/components/CommentsPanel/index.d.ts +6 -0
- package/dist/components/CommentsPanel/index.d.ts.map +1 -0
- package/dist/components/CommentsPanel/index.js +32 -0
- package/dist/components/CommentsPanel/index.js.map +1 -0
- package/dist/components/CommentsPanel/types.d.ts +4 -0
- package/dist/components/CommentsPanel/types.d.ts.map +1 -0
- package/dist/components/CommentsPanel/types.js +1 -0
- package/dist/components/CommentsPanel/types.js.map +1 -0
- package/dist/components/CommentsPanel/utils/createCollapsibleGroupKey.d.ts +10 -0
- package/dist/components/CommentsPanel/utils/createCollapsibleGroupKey.d.ts.map +1 -0
- package/dist/components/CommentsPanel/utils/createCollapsibleGroupKey.js +15 -0
- package/dist/components/CommentsPanel/utils/createCollapsibleGroupKey.js.map +1 -0
- package/dist/components/CommentsPanel/utils/filterComments.d.ts +9 -0
- package/dist/components/CommentsPanel/utils/filterComments.d.ts.map +1 -0
- package/dist/components/CommentsPanel/utils/filterComments.js +17 -0
- package/dist/components/CommentsPanel/utils/filterComments.js.map +1 -0
- package/dist/components/CommentsPanel/utils/groupCommentsByFieldPath.d.ts +4 -0
- package/dist/components/CommentsPanel/utils/groupCommentsByFieldPath.d.ts.map +1 -0
- package/dist/components/CommentsPanel/utils/groupCommentsByFieldPath.js +14 -0
- package/dist/components/CommentsPanel/utils/groupCommentsByFieldPath.js.map +1 -0
- package/dist/components/CommentsPanel/utils/groupCommentsGlobally.d.ts +18 -0
- package/dist/components/CommentsPanel/utils/groupCommentsGlobally.d.ts.map +1 -0
- package/dist/components/CommentsPanel/utils/groupCommentsGlobally.js +58 -0
- package/dist/components/CommentsPanel/utils/groupCommentsGlobally.js.map +1 -0
- package/dist/components/CommentsPanel/utils/resolveEntityLabel.d.ts +3 -0
- package/dist/components/CommentsPanel/utils/resolveEntityLabel.d.ts.map +1 -0
- package/dist/components/CommentsPanel/utils/resolveEntityLabel.js +14 -0
- package/dist/components/CommentsPanel/utils/resolveEntityLabel.js.map +1 -0
- package/dist/components/CommentsPanel/utils/resolveFieldLabel.d.ts +11 -0
- package/dist/components/CommentsPanel/utils/resolveFieldLabel.d.ts.map +1 -0
- package/dist/components/CommentsPanel/utils/resolveFieldLabel.js +9 -0
- package/dist/components/CommentsPanel/utils/resolveFieldLabel.js.map +1 -0
- package/dist/components/CommentsPanel/utils/sortGroupsByCreatedAt.d.ts +4 -0
- package/dist/components/CommentsPanel/utils/sortGroupsByCreatedAt.d.ts.map +1 -0
- package/dist/components/CommentsPanel/utils/sortGroupsByCreatedAt.js +11 -0
- package/dist/components/CommentsPanel/utils/sortGroupsByCreatedAt.js.map +1 -0
- package/dist/components/FieldCommentLabel/AddCommentPopup.d.ts +8 -0
- package/dist/components/FieldCommentLabel/AddCommentPopup.d.ts.map +1 -0
- package/dist/components/FieldCommentLabel/AddCommentPopup.js +50 -0
- package/dist/components/FieldCommentLabel/AddCommentPopup.js.map +1 -0
- package/dist/components/FieldCommentLabel/hooks/useStablePath.d.ts +2 -0
- package/dist/components/FieldCommentLabel/hooks/useStablePath.d.ts.map +1 -0
- package/dist/components/FieldCommentLabel/hooks/useStablePath.js +12 -0
- package/dist/components/FieldCommentLabel/hooks/useStablePath.js.map +1 -0
- package/dist/components/FieldCommentLabel/index.d.ts +11 -0
- package/dist/components/FieldCommentLabel/index.d.ts.map +1 -0
- package/dist/components/FieldCommentLabel/index.js +64 -0
- package/dist/components/FieldCommentLabel/index.js.map +1 -0
- package/dist/components/FieldCommentLabel/types.d.ts +4 -0
- package/dist/components/FieldCommentLabel/types.d.ts.map +1 -0
- package/dist/components/FieldCommentLabel/types.js +1 -0
- package/dist/components/FieldCommentLabel/types.js.map +1 -0
- package/dist/components/FieldCommentLabel/utils/buildStablePath.d.ts +2 -0
- package/dist/components/FieldCommentLabel/utils/buildStablePath.d.ts.map +1 -0
- package/dist/components/FieldCommentLabel/utils/buildStablePath.js +19 -0
- package/dist/components/FieldCommentLabel/utils/buildStablePath.js.map +1 -0
- package/dist/components/FieldCommentLabel/utils/exludeComments.d.ts +3 -0
- package/dist/components/FieldCommentLabel/utils/exludeComments.d.ts.map +1 -0
- package/dist/components/FieldCommentLabel/utils/exludeComments.js +12 -0
- package/dist/components/FieldCommentLabel/utils/exludeComments.js.map +1 -0
- package/dist/components/FieldCommentLabel/utils/resolveLabel.d.ts +3 -0
- package/dist/components/FieldCommentLabel/utils/resolveLabel.d.ts.map +1 -0
- package/dist/components/FieldCommentLabel/utils/resolveLabel.js +9 -0
- package/dist/components/FieldCommentLabel/utils/resolveLabel.js.map +1 -0
- package/dist/components/IconButton/index.d.ts +12 -0
- package/dist/components/IconButton/index.d.ts.map +1 -0
- package/dist/components/IconButton/index.js +38 -0
- package/dist/components/IconButton/index.js.map +1 -0
- package/dist/components/MentionDropdown.d.ts +11 -0
- package/dist/components/MentionDropdown.d.ts.map +1 -0
- package/dist/components/MentionDropdown.js +53 -0
- package/dist/components/MentionDropdown.js.map +1 -0
- package/dist/components/MentionLabel/index.d.ts +7 -0
- package/dist/components/MentionLabel/index.d.ts.map +1 -0
- package/dist/components/MentionLabel/index.js +21 -0
- package/dist/components/MentionLabel/index.js.map +1 -0
- package/dist/config.d.ts +4 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +17 -0
- package/dist/config.js.map +1 -0
- package/dist/constants.d.ts +9 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +22 -0
- package/dist/constants.js.map +1 -0
- package/dist/hooks/useRelativeDate.d.ts +2 -0
- package/dist/hooks/useRelativeDate.d.ts.map +1 -0
- package/dist/hooks/useRelativeDate.js +11 -0
- package/dist/hooks/useRelativeDate.js.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/plugin.d.ts +4 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +60 -0
- package/dist/plugin.js.map +1 -0
- package/dist/providers/CommentsDrawerProvider/index.d.ts +14 -0
- package/dist/providers/CommentsDrawerProvider/index.d.ts.map +1 -0
- package/dist/providers/CommentsDrawerProvider/index.js +28 -0
- package/dist/providers/CommentsDrawerProvider/index.js.map +1 -0
- package/dist/providers/CommentsProvider/index.d.ts +39 -0
- package/dist/providers/CommentsProvider/index.d.ts.map +1 -0
- package/dist/providers/CommentsProvider/index.js +237 -0
- package/dist/providers/CommentsProvider/index.js.map +1 -0
- package/dist/providers/CommentsProvider/mergeDocumentTitles.d.ts +3 -0
- package/dist/providers/CommentsProvider/mergeDocumentTitles.d.ts.map +1 -0
- package/dist/providers/CommentsProvider/mergeDocumentTitles.js +10 -0
- package/dist/providers/CommentsProvider/mergeDocumentTitles.js.map +1 -0
- package/dist/providers/CommentsProviderWrapper/index.d.ts +7 -0
- package/dist/providers/CommentsProviderWrapper/index.d.ts.map +1 -0
- package/dist/providers/CommentsProviderWrapper/index.js +16 -0
- package/dist/providers/CommentsProviderWrapper/index.js.map +1 -0
- package/dist/providers/GlobalCommentsLoader/GlobalCommentsHydrator.d.ts +13 -0
- package/dist/providers/GlobalCommentsLoader/GlobalCommentsHydrator.d.ts.map +1 -0
- package/dist/providers/GlobalCommentsLoader/GlobalCommentsHydrator.js +22 -0
- package/dist/providers/GlobalCommentsLoader/GlobalCommentsHydrator.js.map +1 -0
- package/dist/providers/GlobalCommentsLoader/index.d.ts +10 -0
- package/dist/providers/GlobalCommentsLoader/index.d.ts.map +1 -0
- package/dist/providers/GlobalCommentsLoader/index.js +31 -0
- package/dist/providers/GlobalCommentsLoader/index.js.map +1 -0
- package/dist/services/createComment.d.ts +12 -0
- package/dist/services/createComment.d.ts.map +1 -0
- package/dist/services/createComment.js +83 -0
- package/dist/services/createComment.js.map +1 -0
- package/dist/services/deleteComment.d.ts +3 -0
- package/dist/services/deleteComment.d.ts.map +1 -0
- package/dist/services/deleteComment.js +34 -0
- package/dist/services/deleteComment.js.map +1 -0
- package/dist/services/fetchMentionableUsers.d.ts +3 -0
- package/dist/services/fetchMentionableUsers.d.ts.map +1 -0
- package/dist/services/fetchMentionableUsers.js +46 -0
- package/dist/services/fetchMentionableUsers.js.map +1 -0
- package/dist/services/fieldLabels/fetchFieldLabels.d.ts +3 -0
- package/dist/services/fieldLabels/fetchFieldLabels.d.ts.map +1 -0
- package/dist/services/fieldLabels/fetchFieldLabels.js +74 -0
- package/dist/services/fieldLabels/fetchFieldLabels.js.map +1 -0
- package/dist/services/fieldLabels/utils/groupFieldPathsByDocument.d.ts +5 -0
- package/dist/services/fieldLabels/utils/groupFieldPathsByDocument.d.ts.map +1 -0
- package/dist/services/fieldLabels/utils/groupFieldPathsByDocument.js +21 -0
- package/dist/services/fieldLabels/utils/groupFieldPathsByDocument.js.map +1 -0
- package/dist/services/fieldLabels/utils/resolveFieldPath.d.ts +4 -0
- package/dist/services/fieldLabels/utils/resolveFieldPath.d.ts.map +1 -0
- package/dist/services/fieldLabels/utils/resolveFieldPath.js +66 -0
- package/dist/services/fieldLabels/utils/resolveFieldPath.js.map +1 -0
- package/dist/services/fieldLabels/utils/schemaUtils.d.ts +6 -0
- package/dist/services/fieldLabels/utils/schemaUtils.d.ts.map +1 -0
- package/dist/services/fieldLabels/utils/schemaUtils.js +60 -0
- package/dist/services/fieldLabels/utils/schemaUtils.js.map +1 -0
- package/dist/services/findAllComments.d.ts +11 -0
- package/dist/services/findAllComments.d.ts.map +1 -0
- package/dist/services/findAllComments.js +47 -0
- package/dist/services/findAllComments.js.map +1 -0
- package/dist/services/getCurrentTenantId.d.ts +3 -0
- package/dist/services/getCurrentTenantId.d.ts.map +1 -0
- package/dist/services/getCurrentTenantId.js +13 -0
- package/dist/services/getCurrentTenantId.js.map +1 -0
- package/dist/services/getDocumentTitles.d.ts +3 -0
- package/dist/services/getDocumentTitles.d.ts.map +1 -0
- package/dist/services/getDocumentTitles.js +61 -0
- package/dist/services/getDocumentTitles.js.map +1 -0
- package/dist/services/getEntitiesLabels.d.ts +3 -0
- package/dist/services/getEntitiesLabels.d.ts.map +1 -0
- package/dist/services/getEntitiesLabels.js +14 -0
- package/dist/services/getEntitiesLabels.js.map +1 -0
- package/dist/services/resolveComment.d.ts +3 -0
- package/dist/services/resolveComment.d.ts.map +1 -0
- package/dist/services/resolveComment.js +41 -0
- package/dist/services/resolveComment.js.map +1 -0
- package/dist/services/sendMentionEmails.d.ts +11 -0
- package/dist/services/sendMentionEmails.d.ts.map +1 -0
- package/dist/services/sendMentionEmails.js +73 -0
- package/dist/services/sendMentionEmails.js.map +1 -0
- package/dist/services/syncAllCommentsData.d.ts +12 -0
- package/dist/services/syncAllCommentsData.d.ts.map +1 -0
- package/dist/services/syncAllCommentsData.js +48 -0
- package/dist/services/syncAllCommentsData.js.map +1 -0
- package/dist/styles.css +2 -0
- package/dist/translations/en.d.ts +5 -0
- package/dist/translations/en.d.ts.map +1 -0
- package/dist/translations/en.js +36 -0
- package/dist/translations/en.js.map +1 -0
- package/dist/translations/types.d.ts +32 -0
- package/dist/translations/types.d.ts.map +1 -0
- package/dist/translations/types.js +1 -0
- package/dist/translations/types.js.map +1 -0
- package/dist/types/base.d.ts +10 -0
- package/dist/types/base.d.ts.map +1 -0
- package/dist/types/base.js +1 -0
- package/dist/types/base.js.map +1 -0
- package/dist/types/collection.d.ts +2 -0
- package/dist/types/collection.d.ts.map +1 -0
- package/dist/types/collection.js +1 -0
- package/dist/types/collection.js.map +1 -0
- package/dist/types/comment.d.ts +23 -0
- package/dist/types/comment.d.ts.map +1 -0
- package/dist/types/comment.js +1 -0
- package/dist/types/comment.js.map +1 -0
- package/dist/types/config.d.ts +112 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/types/config.js +1 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/entity.d.ts +15 -0
- package/dist/types/entity.d.ts.map +1 -0
- package/dist/types/entity.js +1 -0
- package/dist/types/entity.js.map +1 -0
- package/dist/types/general.d.ts +10 -0
- package/dist/types/general.d.ts.map +1 -0
- package/dist/types/general.js +1 -0
- package/dist/types/general.js.map +1 -0
- package/dist/types/index.d.ts +8 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/user.d.ts +6 -0
- package/dist/types/user.d.ts.map +1 -0
- package/dist/types/user.js +1 -0
- package/dist/types/user.js.map +1 -0
- package/dist/utils/comment/extractVisibleComments.d.ts +13 -0
- package/dist/utils/comment/extractVisibleComments.d.ts.map +1 -0
- package/dist/utils/comment/extractVisibleComments.js +17 -0
- package/dist/utils/comment/extractVisibleComments.js.map +1 -0
- package/dist/utils/comment/filterCommentsByLocale.d.ts +3 -0
- package/dist/utils/comment/filterCommentsByLocale.d.ts.map +1 -0
- package/dist/utils/comment/filterCommentsByLocale.js +12 -0
- package/dist/utils/comment/filterCommentsByLocale.js.map +1 -0
- package/dist/utils/comment/renderCommentText.d.ts +12 -0
- package/dist/utils/comment/renderCommentText.d.ts.map +1 -0
- package/dist/utils/comment/renderCommentText.js +38 -0
- package/dist/utils/comment/renderCommentText.js.map +1 -0
- package/dist/utils/comment/serializeEditor.d.ts +2 -0
- package/dist/utils/comment/serializeEditor.d.ts.map +1 -0
- package/dist/utils/comment/serializeEditor.js +30 -0
- package/dist/utils/comment/serializeEditor.js.map +1 -0
- package/dist/utils/config/injectFieldCommentComponents.d.ts +4 -0
- package/dist/utils/config/injectFieldCommentComponents.d.ts.map +1 -0
- package/dist/utils/config/injectFieldCommentComponents.js +80 -0
- package/dist/utils/config/injectFieldCommentComponents.js.map +1 -0
- package/dist/utils/config/mergeTranslations.d.ts +3 -0
- package/dist/utils/config/mergeTranslations.d.ts.map +1 -0
- package/dist/utils/config/mergeTranslations.js +29 -0
- package/dist/utils/config/mergeTranslations.js.map +1 -0
- package/dist/utils/config/normalizeCollections.d.ts +7 -0
- package/dist/utils/config/normalizeCollections.d.ts.map +1 -0
- package/dist/utils/config/normalizeCollections.js +15 -0
- package/dist/utils/config/normalizeCollections.js.map +1 -0
- package/dist/utils/config/overrideCollections.d.ts +3 -0
- package/dist/utils/config/overrideCollections.d.ts.map +1 -0
- package/dist/utils/config/overrideCollections.js +38 -0
- package/dist/utils/config/overrideCollections.js.map +1 -0
- package/dist/utils/config/overrideCommentsCollection.d.ts +4 -0
- package/dist/utils/config/overrideCommentsCollection.d.ts.map +1 -0
- package/dist/utils/config/overrideCommentsCollection.js +14 -0
- package/dist/utils/config/overrideCommentsCollection.js.map +1 -0
- package/dist/utils/config/overrideGlobals.d.ts +3 -0
- package/dist/utils/config/overrideGlobals.d.ts.map +1 -0
- package/dist/utils/config/overrideGlobals.js +8 -0
- package/dist/utils/config/overrideGlobals.js.map +1 -0
- package/dist/utils/error/getDefaultErrorMessage.d.ts +2 -0
- package/dist/utils/error/getDefaultErrorMessage.d.ts.map +1 -0
- package/dist/utils/error/getDefaultErrorMessage.js +9 -0
- package/dist/utils/error/getDefaultErrorMessage.js.map +1 -0
- package/dist/utils/general/cn.d.ts +3 -0
- package/dist/utils/general/cn.d.ts.map +1 -0
- package/dist/utils/general/cn.js +9 -0
- package/dist/utils/general/cn.js.map +1 -0
- package/dist/utils/general/formatRelativeDate.d.ts +2 -0
- package/dist/utils/general/formatRelativeDate.d.ts.map +1 -0
- package/dist/utils/general/formatRelativeDate.js +28 -0
- package/dist/utils/general/formatRelativeDate.js.map +1 -0
- package/dist/utils/general/getURL.d.ts +2 -0
- package/dist/utils/general/getURL.d.ts.map +1 -0
- package/dist/utils/general/getURL.js +13 -0
- package/dist/utils/general/getURL.js.map +1 -0
- package/dist/utils/general/getValueByPath.d.ts +4 -0
- package/dist/utils/general/getValueByPath.d.ts.map +1 -0
- package/dist/utils/general/getValueByPath.js +19 -0
- package/dist/utils/general/getValueByPath.js.map +1 -0
- package/dist/utils/mention/isSelfMention.d.ts +4 -0
- package/dist/utils/mention/isSelfMention.d.ts.map +1 -0
- package/dist/utils/mention/isSelfMention.js +7 -0
- package/dist/utils/mention/isSelfMention.js.map +1 -0
- package/dist/utils/mention/parseMentionIds.d.ts +2 -0
- package/dist/utils/mention/parseMentionIds.d.ts.map +1 -0
- package/dist/utils/mention/parseMentionIds.js +13 -0
- package/dist/utils/mention/parseMentionIds.js.map +1 -0
- package/dist/utils/mode/defineModeByPathname.d.ts +11 -0
- package/dist/utils/mode/defineModeByPathname.d.ts.map +1 -0
- package/dist/utils/mode/defineModeByPathname.js +39 -0
- package/dist/utils/mode/defineModeByPathname.js.map +1 -0
- package/dist/utils/path/detectPluginBasePath.d.ts +2 -0
- package/dist/utils/path/detectPluginBasePath.d.ts.map +1 -0
- package/dist/utils/path/detectPluginBasePath.js +8 -0
- package/dist/utils/path/detectPluginBasePath.js.map +1 -0
- package/dist/utils/path/getComponentPath.d.ts +15 -0
- package/dist/utils/path/getComponentPath.d.ts.map +1 -0
- package/dist/utils/path/getComponentPath.js +22 -0
- package/dist/utils/path/getComponentPath.js.map +1 -0
- package/dist/utils/payload/extractPayload.d.ts +3 -0
- package/dist/utils/payload/extractPayload.d.ts.map +1 -0
- package/dist/utils/payload/extractPayload.js +9 -0
- package/dist/utils/payload/extractPayload.js.map +1 -0
- package/dist/utils/user/resolveUsername.d.ts +4 -0
- package/dist/utils/user/resolveUsername.d.ts.map +1 -0
- package/dist/utils/user/resolveUsername.js +14 -0
- package/dist/utils/user/resolveUsername.js.map +1 -0
- package/package.json +113 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/providers/CommentsDrawerProvider/index.tsx"],"sourcesContent":["\"use client\";\n\nimport { useDrawerSlug, useModal } from \"@payloadcms/ui\";\nimport { createContext, type ReactNode, useContext, useState } from \"react\";\nimport { COMMENTS_DRAWER_BASE_SLUG } from \"../../constants\";\nimport { useComments } from \"../CommentsProvider\";\n\ninterface CommentsDrawerContextProps {\n slug: string;\n scrollTargetPath: string | null;\n open: () => void;\n setScrollTargetPath: (path: string | null) => void;\n}\n\nconst CommentsDrawerContext = createContext<CommentsDrawerContextProps | null>(null);\n\ninterface Props {\n children: ReactNode;\n}\n\nexport function CommentsDrawerProvider({ children }: Props) {\n const [scrollTargetPath, setScrollTargetPath] = useState<string | null>(null);\n const slug = useDrawerSlug(COMMENTS_DRAWER_BASE_SLUG);\n const { openModal } = useModal();\n const { syncComments } = useComments();\n\n const open = () => {\n openModal(slug);\n\n void syncComments();\n };\n\n return (\n <CommentsDrawerContext.Provider value={{ slug, scrollTargetPath, open, setScrollTargetPath }}>\n {children}\n </CommentsDrawerContext.Provider>\n );\n}\n\nexport function useCommentsDrawer() {\n const context = useContext(CommentsDrawerContext);\n\n if (!context) throw new Error(\"useCommentsDrawer must be used within a CommentsProvider\");\n\n return context;\n}\n"],"mappings":";AAiCI;AA/BJ,SAAS,eAAe,gBAAgB;AACxC,SAAS,eAA+B,YAAY,gBAAgB;AACpE,SAAS,iCAAiC;AAC1C,SAAS,mBAAmB;AAS5B,MAAM,wBAAwB,cAAiD,IAAI;AAM5E,SAAS,uBAAuB,EAAE,SAAS,GAAU;AAC1D,QAAM,CAAC,kBAAkB,mBAAmB,IAAI,SAAwB,IAAI;AAC5E,QAAM,OAAO,cAAc,yBAAyB;AACpD,QAAM,EAAE,UAAU,IAAI,SAAS;AAC/B,QAAM,EAAE,aAAa,IAAI,YAAY;AAErC,QAAM,OAAO,MAAM;AACjB,cAAU,IAAI;AAEd,SAAK,aAAa;AAAA,EACpB;AAEA,SACE,oBAAC,sBAAsB,UAAtB,EAA+B,OAAO,EAAE,MAAM,kBAAkB,MAAM,oBAAoB,GACxF,UACH;AAEJ;AAEO,SAAS,oBAAoB;AAClC,QAAM,UAAU,WAAW,qBAAqB;AAEhD,MAAI,CAAC,QAAS,OAAM,IAAI,MAAM,0DAA0D;AAExF,SAAO;AACT;","names":[]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { type Dispatch, type ReactNode, type SetStateAction } from "react";
|
|
2
|
+
import type { Comment, EntityLabelsMap, User } from "../../types";
|
|
3
|
+
import type { FilterMode, GlobalFieldLabelRegistry, LoadingStatus, DocumentTitles, Mode } from "../../types";
|
|
4
|
+
interface MutationResult {
|
|
5
|
+
success: boolean;
|
|
6
|
+
error?: string;
|
|
7
|
+
}
|
|
8
|
+
interface CommentsContextProps {
|
|
9
|
+
allComments: Comment[];
|
|
10
|
+
visibleComments: Comment[];
|
|
11
|
+
documentTitles: DocumentTitles;
|
|
12
|
+
collectionLabels: EntityLabelsMap;
|
|
13
|
+
globalLabels: EntityLabelsMap;
|
|
14
|
+
mode: Mode;
|
|
15
|
+
collectionSlug: string | null | undefined;
|
|
16
|
+
documentId: number | null | undefined;
|
|
17
|
+
globalSlug: string | null;
|
|
18
|
+
mentionUsers: User[];
|
|
19
|
+
loadError: boolean;
|
|
20
|
+
filter: FilterMode;
|
|
21
|
+
fieldLabelRegistry: GlobalFieldLabelRegistry;
|
|
22
|
+
syncCommentsStatus: LoadingStatus;
|
|
23
|
+
usernameFieldPath: string | undefined;
|
|
24
|
+
setFilter: Dispatch<SetStateAction<FilterMode>>;
|
|
25
|
+
hydrateComments: (incoming?: Comment[], incomingTitles?: DocumentTitles, incomingMentionUsers?: User[], fieldLabels?: GlobalFieldLabelRegistry, incomingCollectionLabels?: EntityLabelsMap, nextLoadError?: boolean, incomingGlobalLabels?: EntityLabelsMap) => void;
|
|
26
|
+
syncComments: () => Promise<void>;
|
|
27
|
+
addComment: (text: string, fieldPath?: string | null, documentId?: number, collectionSlug?: string, locale?: string | null, globalSlugOverride?: string) => Promise<MutationResult>;
|
|
28
|
+
removeComment: (id: string | number) => Promise<MutationResult>;
|
|
29
|
+
resolveComment: (id: string | number, resolved: boolean) => Promise<MutationResult>;
|
|
30
|
+
updateDocumentTitle: (collectionSlug: string, documentId: string, value: string) => void;
|
|
31
|
+
}
|
|
32
|
+
interface Props {
|
|
33
|
+
children: ReactNode;
|
|
34
|
+
usernameFieldPath?: string;
|
|
35
|
+
}
|
|
36
|
+
export declare function CommentsProvider({ children, usernameFieldPath }: Props): import("react/jsx-runtime").JSX.Element;
|
|
37
|
+
export declare function useComments(): CommentsContextProps;
|
|
38
|
+
export {};
|
|
39
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/providers/CommentsProvider/index.tsx"],"names":[],"mappings":"AAEA,OAAO,EAEL,KAAK,QAAQ,EACb,KAAK,SAAS,EACd,KAAK,cAAc,EAKpB,MAAM,OAAO,CAAC;AAGf,OAAO,KAAK,EAAE,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAKlE,OAAO,KAAK,EAAE,UAAU,EAAE,wBAAwB,EAAE,aAAa,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAqB7G,UAAU,cAAc;IACtB,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,UAAU,oBAAoB;IAC5B,WAAW,EAAE,OAAO,EAAE,CAAC;IACvB,eAAe,EAAE,OAAO,EAAE,CAAC;IAC3B,cAAc,EAAE,cAAc,CAAC;IAC/B,gBAAgB,EAAE,eAAe,CAAC;IAClC,YAAY,EAAE,eAAe,CAAC;IAC9B,IAAI,EAAE,IAAI,CAAC;IACX,cAAc,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IAC1C,UAAU,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IACtC,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,YAAY,EAAE,IAAI,EAAE,CAAC;IACrB,SAAS,EAAE,OAAO,CAAC;IACnB,MAAM,EAAE,UAAU,CAAC;IACnB,kBAAkB,EAAE,wBAAwB,CAAC;IAC7C,kBAAkB,EAAE,aAAa,CAAC;IAClC,iBAAiB,EAAE,MAAM,GAAG,SAAS,CAAC;IACtC,SAAS,EAAE,QAAQ,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;IAChD,eAAe,EAAE,CACf,QAAQ,CAAC,EAAE,OAAO,EAAE,EACpB,cAAc,CAAC,EAAE,cAAc,EAC/B,oBAAoB,CAAC,EAAE,IAAI,EAAE,EAC7B,WAAW,CAAC,EAAE,wBAAwB,EACtC,wBAAwB,CAAC,EAAE,eAAe,EAC1C,aAAa,CAAC,EAAE,OAAO,EACvB,oBAAoB,CAAC,EAAE,eAAe,KACnC,IAAI,CAAC;IACV,YAAY,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAClC,UAAU,EAAE,CACV,IAAI,EAAE,MAAM,EACZ,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,EACzB,UAAU,CAAC,EAAE,MAAM,EACnB,cAAc,CAAC,EAAE,MAAM,EACvB,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,EACtB,kBAAkB,CAAC,EAAE,MAAM,KACxB,OAAO,CAAC,cAAc,CAAC,CAAC;IAC7B,aAAa,EAAE,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,KAAK,OAAO,CAAC,cAAc,CAAC,CAAC;IAChE,cAAc,EAAE,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,EAAE,QAAQ,EAAE,OAAO,KAAK,OAAO,CAAC,cAAc,CAAC,CAAC;IACpF,mBAAmB,EAAE,CAAC,cAAc,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CAC1F;AAID,UAAU,KAAK;IACb,QAAQ,EAAE,SAAS,CAAC;IACpB,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED,wBAAgB,gBAAgB,CAAC,EAAE,QAAQ,EAAE,iBAAiB,EAAE,EAAE,KAAK,2CA4PtE;AAED,wBAAgB,WAAW,yBAM1B"}
|
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx } from "react/jsx-runtime";
|
|
3
|
+
import {
|
|
4
|
+
createContext,
|
|
5
|
+
useCallback,
|
|
6
|
+
useContext,
|
|
7
|
+
useOptimistic,
|
|
8
|
+
useState
|
|
9
|
+
} from "react";
|
|
10
|
+
import { useAuth, useLocale } from "@payloadcms/ui";
|
|
11
|
+
import { usePathname } from "next/navigation";
|
|
12
|
+
import { createComment } from "../../services/createComment";
|
|
13
|
+
import { deleteComment } from "../../services/deleteComment";
|
|
14
|
+
import { resolveComment as resolveCommentService } from "../../services/resolveComment";
|
|
15
|
+
import { syncAllCommentsData } from "../../services/syncAllCommentsData";
|
|
16
|
+
import { parseMentionIds } from "../../utils/mention/parseMentionIds";
|
|
17
|
+
import { defineModeByPathname } from "../../utils/mode/defineModeByPathname";
|
|
18
|
+
import { extractVisibleComments } from "../../utils/comment/extractVisibleComments";
|
|
19
|
+
function optimisticReducer(state, action) {
|
|
20
|
+
switch (action.type) {
|
|
21
|
+
case "add":
|
|
22
|
+
return [action.comment, ...state];
|
|
23
|
+
case "remove":
|
|
24
|
+
return state.filter(({ id }) => id !== action.id);
|
|
25
|
+
case "update":
|
|
26
|
+
return state.map((c) => c.id === action.comment.id ? action.comment : c);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
const CommentsContext = createContext(null);
|
|
30
|
+
function CommentsProvider({ children, usernameFieldPath }) {
|
|
31
|
+
const { user } = useAuth();
|
|
32
|
+
const pathname = usePathname();
|
|
33
|
+
const { code: currentLocale } = useLocale();
|
|
34
|
+
const [allComments, setAllComments] = useState([]);
|
|
35
|
+
const [optimisticComments, applyOptimistic] = useOptimistic(
|
|
36
|
+
allComments,
|
|
37
|
+
optimisticReducer
|
|
38
|
+
);
|
|
39
|
+
const [documentTitles, setDocumentTitles] = useState({});
|
|
40
|
+
const [collectionLabels, setCollectionLabels] = useState({});
|
|
41
|
+
const [globalLabels, setGlobalLabels] = useState({});
|
|
42
|
+
const [mentionUsers, setMentionUsers] = useState([]);
|
|
43
|
+
const [fieldLabelRegistry, setFieldLabelRegistry] = useState({});
|
|
44
|
+
const [filter, setFilter] = useState("open");
|
|
45
|
+
const [loadError, setLoadError] = useState(false);
|
|
46
|
+
const [syncCommentsStatus, setSyncCommentsStatus] = useState("idle");
|
|
47
|
+
const { mode, collectionSlug, documentId, globalSlug } = defineModeByPathname(pathname);
|
|
48
|
+
const visibleComments = extractVisibleComments({
|
|
49
|
+
comments: optimisticComments,
|
|
50
|
+
mode,
|
|
51
|
+
collectionSlug,
|
|
52
|
+
documentId,
|
|
53
|
+
globalSlug,
|
|
54
|
+
currentLocale
|
|
55
|
+
});
|
|
56
|
+
const hydrateComments = useCallback(
|
|
57
|
+
(incoming, incomingTitles, incomingMentionUsers, fieldLabels, incomingCollectionLabels, nextLoadError = false, incomingGlobalLabels) => {
|
|
58
|
+
if (incoming !== void 0) {
|
|
59
|
+
setAllComments(incoming);
|
|
60
|
+
}
|
|
61
|
+
if (incomingTitles) {
|
|
62
|
+
setDocumentTitles(incomingTitles);
|
|
63
|
+
}
|
|
64
|
+
if (incomingMentionUsers) {
|
|
65
|
+
setMentionUsers(incomingMentionUsers);
|
|
66
|
+
}
|
|
67
|
+
if (fieldLabels) {
|
|
68
|
+
setFieldLabelRegistry(fieldLabels);
|
|
69
|
+
}
|
|
70
|
+
if (incomingCollectionLabels) {
|
|
71
|
+
setCollectionLabels(incomingCollectionLabels);
|
|
72
|
+
}
|
|
73
|
+
if (incomingGlobalLabels) {
|
|
74
|
+
setGlobalLabels(incomingGlobalLabels);
|
|
75
|
+
}
|
|
76
|
+
setLoadError(nextLoadError);
|
|
77
|
+
},
|
|
78
|
+
[]
|
|
79
|
+
);
|
|
80
|
+
const addComment = async (text, fieldPath, documentIdOverride, collectionSlugOverride, locale, globalSlugOverride) => {
|
|
81
|
+
const resolvedGlobalSlug = globalSlugOverride ?? (mode === "global-document" ? globalSlug : null);
|
|
82
|
+
const resolvedDocId = documentIdOverride ?? documentId;
|
|
83
|
+
const resolvedSlug = collectionSlugOverride ?? collectionSlug;
|
|
84
|
+
if (!resolvedGlobalSlug && (!resolvedDocId || !resolvedSlug)) {
|
|
85
|
+
return {
|
|
86
|
+
success: false,
|
|
87
|
+
error: "No document registered"
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
const tempId = -Date.now();
|
|
91
|
+
const mentionIds = parseMentionIds(text);
|
|
92
|
+
const selectedMentionUsers = mentionUsers.filter(({ id }) => mentionIds.includes(id));
|
|
93
|
+
const mentions = selectedMentionUsers.map((user2) => ({ id: null, user: user2 }));
|
|
94
|
+
const optimisticComment = {
|
|
95
|
+
id: tempId,
|
|
96
|
+
text,
|
|
97
|
+
fieldPath,
|
|
98
|
+
locale: locale ?? null,
|
|
99
|
+
documentId: resolvedGlobalSlug ? null : resolvedDocId,
|
|
100
|
+
collectionSlug: resolvedGlobalSlug ? null : resolvedSlug,
|
|
101
|
+
globalSlug: resolvedGlobalSlug ?? null,
|
|
102
|
+
isResolved: false,
|
|
103
|
+
mentions,
|
|
104
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
105
|
+
updatedAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
106
|
+
author: user
|
|
107
|
+
};
|
|
108
|
+
applyOptimistic({ type: "add", comment: optimisticComment });
|
|
109
|
+
const result = await createComment({
|
|
110
|
+
documentId: resolvedGlobalSlug ? null : resolvedDocId,
|
|
111
|
+
collectionSlug: resolvedGlobalSlug ? null : resolvedSlug,
|
|
112
|
+
globalSlug: resolvedGlobalSlug,
|
|
113
|
+
text,
|
|
114
|
+
fieldPath,
|
|
115
|
+
mentionIds,
|
|
116
|
+
locale
|
|
117
|
+
});
|
|
118
|
+
if (result.success) {
|
|
119
|
+
applyOptimistic({ type: "remove", id: tempId });
|
|
120
|
+
setAllComments((prev) => [result.data, ...prev.filter((c) => c.id !== tempId)]);
|
|
121
|
+
return { success: true };
|
|
122
|
+
}
|
|
123
|
+
return {
|
|
124
|
+
success: false,
|
|
125
|
+
error: result.error
|
|
126
|
+
};
|
|
127
|
+
};
|
|
128
|
+
const removeComment = async (id) => {
|
|
129
|
+
applyOptimistic({ type: "remove", id });
|
|
130
|
+
const result = await deleteComment(id);
|
|
131
|
+
if (result.success) {
|
|
132
|
+
setAllComments((prev) => prev.filter((c) => c.id !== id));
|
|
133
|
+
return { success: true };
|
|
134
|
+
}
|
|
135
|
+
return {
|
|
136
|
+
success: false,
|
|
137
|
+
error: result.error
|
|
138
|
+
};
|
|
139
|
+
};
|
|
140
|
+
const syncComments = async () => {
|
|
141
|
+
setSyncCommentsStatus("loading");
|
|
142
|
+
const allCommentsDataResult = await syncAllCommentsData({ locale: currentLocale });
|
|
143
|
+
if (!allCommentsDataResult.success) {
|
|
144
|
+
setSyncCommentsStatus("error");
|
|
145
|
+
return;
|
|
146
|
+
}
|
|
147
|
+
const {
|
|
148
|
+
comments,
|
|
149
|
+
documentTitles: documentTitles2,
|
|
150
|
+
mentionUsers: mentionUsers2,
|
|
151
|
+
fieldLabels,
|
|
152
|
+
collectionLabels: syncedLabels,
|
|
153
|
+
globalLabels: syncedGlobalLabels
|
|
154
|
+
} = allCommentsDataResult.data;
|
|
155
|
+
setAllComments((prev) => {
|
|
156
|
+
const serverIds = new Set(comments.map((c) => c.id));
|
|
157
|
+
const localOnly = prev.filter((c) => c.id > 0 && !serverIds.has(c.id));
|
|
158
|
+
return [...localOnly, ...comments];
|
|
159
|
+
});
|
|
160
|
+
setDocumentTitles(documentTitles2);
|
|
161
|
+
setMentionUsers(mentionUsers2);
|
|
162
|
+
setFieldLabelRegistry(fieldLabels);
|
|
163
|
+
setCollectionLabels(syncedLabels);
|
|
164
|
+
setGlobalLabels(syncedGlobalLabels);
|
|
165
|
+
setSyncCommentsStatus("success");
|
|
166
|
+
};
|
|
167
|
+
const resolveComment = async (id, resolved) => {
|
|
168
|
+
const existing = optimisticComments.find((c) => c.id === id);
|
|
169
|
+
if (existing) {
|
|
170
|
+
applyOptimistic({
|
|
171
|
+
type: "update",
|
|
172
|
+
comment: {
|
|
173
|
+
...existing,
|
|
174
|
+
isResolved: resolved
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
const result = await resolveCommentService(id, resolved);
|
|
179
|
+
if (result.success) {
|
|
180
|
+
setAllComments((prev) => prev.map((c) => c.id === id ? result.data : c));
|
|
181
|
+
return { success: true };
|
|
182
|
+
}
|
|
183
|
+
return {
|
|
184
|
+
success: false,
|
|
185
|
+
error: result.error
|
|
186
|
+
};
|
|
187
|
+
};
|
|
188
|
+
const updateDocumentTitle = (collectionSlug2, documentId2, value) => {
|
|
189
|
+
setDocumentTitles((prev) => ({
|
|
190
|
+
...prev,
|
|
191
|
+
[collectionSlug2]: {
|
|
192
|
+
...prev[collectionSlug2],
|
|
193
|
+
[documentId2]: value
|
|
194
|
+
}
|
|
195
|
+
}));
|
|
196
|
+
};
|
|
197
|
+
return /* @__PURE__ */ jsx(
|
|
198
|
+
CommentsContext.Provider,
|
|
199
|
+
{
|
|
200
|
+
value: {
|
|
201
|
+
allComments: optimisticComments,
|
|
202
|
+
visibleComments,
|
|
203
|
+
documentTitles,
|
|
204
|
+
collectionLabels,
|
|
205
|
+
globalLabels,
|
|
206
|
+
mode,
|
|
207
|
+
collectionSlug,
|
|
208
|
+
documentId,
|
|
209
|
+
globalSlug,
|
|
210
|
+
mentionUsers,
|
|
211
|
+
loadError,
|
|
212
|
+
filter,
|
|
213
|
+
fieldLabelRegistry,
|
|
214
|
+
syncCommentsStatus,
|
|
215
|
+
usernameFieldPath,
|
|
216
|
+
setFilter,
|
|
217
|
+
hydrateComments,
|
|
218
|
+
syncComments,
|
|
219
|
+
addComment,
|
|
220
|
+
removeComment,
|
|
221
|
+
resolveComment,
|
|
222
|
+
updateDocumentTitle
|
|
223
|
+
},
|
|
224
|
+
children
|
|
225
|
+
}
|
|
226
|
+
);
|
|
227
|
+
}
|
|
228
|
+
function useComments() {
|
|
229
|
+
const context = useContext(CommentsContext);
|
|
230
|
+
if (!context) throw new Error("useComments must be used within a CommentsProvider");
|
|
231
|
+
return context;
|
|
232
|
+
}
|
|
233
|
+
export {
|
|
234
|
+
CommentsProvider,
|
|
235
|
+
useComments
|
|
236
|
+
};
|
|
237
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/providers/CommentsProvider/index.tsx"],"sourcesContent":["\"use client\";\n\nimport {\n createContext,\n type Dispatch,\n type ReactNode,\n type SetStateAction,\n useCallback,\n useContext,\n useOptimistic,\n useState,\n} from \"react\";\nimport { useAuth, useLocale } from \"@payloadcms/ui\";\nimport { usePathname } from \"next/navigation\";\nimport type { Comment, EntityLabelsMap, User } from \"../../types\";\nimport { createComment } from \"../../services/createComment\";\nimport { deleteComment } from \"../../services/deleteComment\";\nimport { resolveComment as resolveCommentService } from \"../../services/resolveComment\";\nimport { syncAllCommentsData } from \"../../services/syncAllCommentsData\";\nimport type { FilterMode, GlobalFieldLabelRegistry, LoadingStatus, DocumentTitles, Mode } from \"../../types\";\nimport { parseMentionIds } from \"../../utils/mention/parseMentionIds\";\nimport { defineModeByPathname } from \"../../utils/mode/defineModeByPathname\";\nimport { extractVisibleComments } from \"../../utils/comment/extractVisibleComments\";\n\ntype OptimisticAction =\n | { type: \"add\"; comment: Comment }\n | { type: \"remove\"; id: string | number }\n | { type: \"update\"; comment: Comment };\n\nfunction optimisticReducer(state: Comment[], action: OptimisticAction) {\n switch (action.type) {\n case \"add\":\n return [action.comment, ...state];\n case \"remove\":\n return state.filter(({ id }) => id !== action.id);\n case \"update\":\n return state.map((c) => (c.id === action.comment.id ? action.comment : c));\n }\n}\n\ninterface MutationResult {\n success: boolean;\n error?: string;\n}\n\ninterface CommentsContextProps {\n allComments: Comment[];\n visibleComments: Comment[];\n documentTitles: DocumentTitles;\n collectionLabels: EntityLabelsMap;\n globalLabels: EntityLabelsMap;\n mode: Mode;\n collectionSlug: string | null | undefined;\n documentId: number | null | undefined;\n globalSlug: string | null;\n mentionUsers: User[];\n loadError: boolean;\n filter: FilterMode;\n fieldLabelRegistry: GlobalFieldLabelRegistry;\n syncCommentsStatus: LoadingStatus;\n usernameFieldPath: string | undefined;\n setFilter: Dispatch<SetStateAction<FilterMode>>;\n hydrateComments: (\n incoming?: Comment[],\n incomingTitles?: DocumentTitles,\n incomingMentionUsers?: User[],\n fieldLabels?: GlobalFieldLabelRegistry,\n incomingCollectionLabels?: EntityLabelsMap,\n nextLoadError?: boolean,\n incomingGlobalLabels?: EntityLabelsMap,\n ) => void;\n syncComments: () => Promise<void>;\n addComment: (\n text: string,\n fieldPath?: string | null,\n documentId?: number,\n collectionSlug?: string,\n locale?: string | null,\n globalSlugOverride?: string,\n ) => Promise<MutationResult>;\n removeComment: (id: string | number) => Promise<MutationResult>;\n resolveComment: (id: string | number, resolved: boolean) => Promise<MutationResult>;\n updateDocumentTitle: (collectionSlug: string, documentId: string, value: string) => void;\n}\n\nconst CommentsContext = createContext<CommentsContextProps | null>(null);\n\ninterface Props {\n children: ReactNode;\n usernameFieldPath?: string;\n}\n\nexport function CommentsProvider({ children, usernameFieldPath }: Props) {\n const { user } = useAuth();\n const pathname = usePathname();\n const { code: currentLocale } = useLocale();\n\n const [allComments, setAllComments] = useState<Comment[]>([]);\n const [optimisticComments, applyOptimistic] = useOptimistic<Comment[], OptimisticAction>(\n allComments,\n optimisticReducer,\n );\n\n const [documentTitles, setDocumentTitles] = useState<DocumentTitles>({});\n const [collectionLabels, setCollectionLabels] = useState<EntityLabelsMap>({});\n const [globalLabels, setGlobalLabels] = useState<EntityLabelsMap>({});\n const [mentionUsers, setMentionUsers] = useState<User[]>([]);\n const [fieldLabelRegistry, setFieldLabelRegistry] = useState<GlobalFieldLabelRegistry>({});\n const [filter, setFilter] = useState<FilterMode>(\"open\");\n const [loadError, setLoadError] = useState(false);\n const [syncCommentsStatus, setSyncCommentsStatus] = useState<LoadingStatus>(\"idle\");\n\n const { mode, collectionSlug, documentId, globalSlug } = defineModeByPathname(pathname);\n\n const visibleComments = extractVisibleComments({\n comments: optimisticComments,\n mode,\n collectionSlug,\n documentId,\n globalSlug,\n currentLocale,\n });\n\n const hydrateComments = useCallback(\n (\n incoming?: Comment[],\n incomingTitles?: DocumentTitles,\n incomingMentionUsers?: User[],\n fieldLabels?: GlobalFieldLabelRegistry,\n incomingCollectionLabels?: EntityLabelsMap,\n nextLoadError = false,\n incomingGlobalLabels?: EntityLabelsMap,\n ) => {\n if (incoming !== undefined) {\n setAllComments(incoming);\n }\n\n if (incomingTitles) {\n setDocumentTitles(incomingTitles);\n }\n\n if (incomingMentionUsers) {\n setMentionUsers(incomingMentionUsers);\n }\n\n if (fieldLabels) {\n setFieldLabelRegistry(fieldLabels);\n }\n\n if (incomingCollectionLabels) {\n setCollectionLabels(incomingCollectionLabels);\n }\n\n if (incomingGlobalLabels) {\n setGlobalLabels(incomingGlobalLabels);\n }\n\n setLoadError(nextLoadError);\n },\n [],\n );\n\n const addComment = async (\n text: string,\n fieldPath?: string | null,\n documentIdOverride?: number,\n collectionSlugOverride?: string,\n locale?: string | null,\n globalSlugOverride?: string,\n ): Promise<MutationResult> => {\n const resolvedGlobalSlug = globalSlugOverride ?? (mode === \"global-document\" ? globalSlug : null);\n const resolvedDocId = documentIdOverride ?? documentId;\n const resolvedSlug = collectionSlugOverride ?? collectionSlug;\n\n if (!resolvedGlobalSlug && (!resolvedDocId || !resolvedSlug)) {\n return {\n success: false,\n error: \"No document registered\",\n };\n }\n\n const tempId = -Date.now();\n\n const mentionIds = parseMentionIds(text);\n const selectedMentionUsers = mentionUsers.filter(({ id }) => mentionIds.includes(id));\n const mentions = selectedMentionUsers.map((user) => ({ id: null, user }));\n\n const optimisticComment: Comment = {\n id: tempId,\n text,\n fieldPath,\n locale: locale ?? null,\n documentId: resolvedGlobalSlug ? null : resolvedDocId,\n collectionSlug: resolvedGlobalSlug ? null : resolvedSlug,\n globalSlug: resolvedGlobalSlug ?? null,\n isResolved: false,\n mentions,\n createdAt: new Date().toISOString(),\n updatedAt: new Date().toISOString(),\n author: user as Comment[\"author\"],\n };\n\n applyOptimistic({ type: \"add\", comment: optimisticComment });\n\n const result = await createComment({\n documentId: resolvedGlobalSlug ? null : resolvedDocId,\n collectionSlug: resolvedGlobalSlug ? null : resolvedSlug,\n globalSlug: resolvedGlobalSlug,\n text,\n fieldPath,\n mentionIds,\n locale,\n });\n\n if (result.success) {\n applyOptimistic({ type: \"remove\", id: tempId });\n setAllComments((prev) => [result.data, ...prev.filter((c) => c.id !== tempId)]);\n\n return { success: true };\n }\n\n return {\n success: false,\n error: result.error,\n };\n };\n\n const removeComment = async (id: string | number): Promise<MutationResult> => {\n applyOptimistic({ type: \"remove\", id });\n\n const result = await deleteComment(id);\n\n if (result.success) {\n setAllComments((prev) => prev.filter((c) => c.id !== id));\n\n return { success: true };\n }\n\n return {\n success: false,\n error: result.error,\n };\n };\n\n const syncComments = async () => {\n setSyncCommentsStatus(\"loading\");\n\n const allCommentsDataResult = await syncAllCommentsData({ locale: currentLocale });\n\n if (!allCommentsDataResult.success) {\n setSyncCommentsStatus(\"error\");\n\n return;\n }\n\n const {\n comments,\n documentTitles,\n mentionUsers,\n fieldLabels,\n collectionLabels: syncedLabels,\n globalLabels: syncedGlobalLabels,\n } = allCommentsDataResult.data;\n\n setAllComments((prev) => {\n const serverIds = new Set(comments.map((c) => c.id));\n const localOnly = prev.filter((c) => c.id > 0 && !serverIds.has(c.id));\n\n return [...localOnly, ...comments];\n });\n setDocumentTitles(documentTitles);\n setMentionUsers(mentionUsers);\n setFieldLabelRegistry(fieldLabels);\n setCollectionLabels(syncedLabels);\n setGlobalLabels(syncedGlobalLabels);\n setSyncCommentsStatus(\"success\");\n };\n\n const resolveComment = async (id: string | number, resolved: boolean): Promise<MutationResult> => {\n const existing = optimisticComments.find((c) => c.id === id);\n\n if (existing) {\n applyOptimistic({\n type: \"update\",\n comment: {\n ...existing,\n isResolved: resolved,\n },\n });\n }\n\n const result = await resolveCommentService(id, resolved);\n\n if (result.success) {\n setAllComments((prev) => prev.map((c) => (c.id === id ? result.data : c)));\n\n return { success: true };\n }\n\n return {\n success: false,\n error: result.error,\n };\n };\n\n const updateDocumentTitle = (collectionSlug: string, documentId: string, value: string) => {\n setDocumentTitles((prev) => ({\n ...prev,\n [collectionSlug]: {\n ...prev[collectionSlug],\n [documentId]: value,\n },\n }));\n };\n\n return (\n <CommentsContext.Provider\n value={{\n allComments: optimisticComments,\n visibleComments,\n documentTitles,\n collectionLabels,\n globalLabels,\n mode,\n collectionSlug,\n documentId,\n globalSlug,\n mentionUsers,\n loadError,\n filter,\n fieldLabelRegistry,\n syncCommentsStatus,\n usernameFieldPath,\n setFilter,\n hydrateComments,\n syncComments,\n addComment,\n removeComment,\n resolveComment,\n updateDocumentTitle,\n }}>\n {children}\n </CommentsContext.Provider>\n );\n}\n\nexport function useComments() {\n const context = useContext(CommentsContext);\n\n if (!context) throw new Error(\"useComments must be used within a CommentsProvider\");\n\n return context;\n}\n"],"mappings":"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","names":["user","documentTitles","mentionUsers","collectionSlug","documentId"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mergeDocumentTitles.d.ts","sourceRoot":"","sources":["../../../src/providers/CommentsProvider/mergeDocumentTitles.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAElD,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,cAAc,EAAE,QAAQ,EAAE,cAAc,GAAG,cAAc,CAKlG"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
function mergeDocumentTitles(prev, incoming) {
|
|
2
|
+
return {
|
|
3
|
+
...prev,
|
|
4
|
+
...Object.fromEntries(Object.entries(incoming).map(([slug, ids]) => [slug, { ...prev[slug] ?? {}, ...ids }]))
|
|
5
|
+
};
|
|
6
|
+
}
|
|
7
|
+
export {
|
|
8
|
+
mergeDocumentTitles
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=mergeDocumentTitles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/providers/CommentsProvider/mergeDocumentTitles.ts"],"sourcesContent":["import type { DocumentTitles } from \"../../types\";\n\nexport function mergeDocumentTitles(prev: DocumentTitles, incoming: DocumentTitles): DocumentTitles {\n return {\n ...prev,\n ...Object.fromEntries(Object.entries(incoming).map(([slug, ids]) => [slug, { ...(prev[slug] ?? {}), ...ids }])),\n };\n}\n"],"mappings":"AAEO,SAAS,oBAAoB,MAAsB,UAA0C;AAClG,SAAO;AAAA,IACL,GAAG;AAAA,IACH,GAAG,OAAO,YAAY,OAAO,QAAQ,QAAQ,EAAE,IAAI,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,GAAI,KAAK,IAAI,KAAK,CAAC,GAAI,GAAG,IAAI,CAAC,CAAC,CAAC;AAAA,EAChH;AACF;","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/providers/CommentsProviderWrapper/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAMvC,UAAU,KAAK;IACb,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,wBAAgB,uBAAuB,CAAC,EAAE,QAAQ,EAAE,EAAE,KAAK,2CAY1D"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx } from "react/jsx-runtime";
|
|
3
|
+
import { useConfig } from "@payloadcms/ui";
|
|
4
|
+
import { CommentsDrawerProvider } from "../CommentsDrawerProvider";
|
|
5
|
+
import { CommentsProvider } from "../CommentsProvider";
|
|
6
|
+
function CommentsProviderWrapper({ children }) {
|
|
7
|
+
const { config } = useConfig();
|
|
8
|
+
const pluginConfig = config.admin?.custom?.commentsPlugin;
|
|
9
|
+
const usernameFieldRawPath = pluginConfig?.usernameFieldPath;
|
|
10
|
+
const usernameFieldPath = usernameFieldRawPath === "" ? void 0 : usernameFieldRawPath;
|
|
11
|
+
return /* @__PURE__ */ jsx(CommentsProvider, { usernameFieldPath, children: /* @__PURE__ */ jsx(CommentsDrawerProvider, { children }) });
|
|
12
|
+
}
|
|
13
|
+
export {
|
|
14
|
+
CommentsProviderWrapper
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/providers/CommentsProviderWrapper/index.tsx"],"sourcesContent":["\"use client\";\n\nimport type { ReactNode } from \"react\";\nimport { useConfig } from \"@payloadcms/ui\";\nimport { CommentsDrawerProvider } from \"../CommentsDrawerProvider\";\nimport { CommentsProvider } from \"../CommentsProvider\";\nimport type { CommentsPluginConfigStorage } from \"../../types\";\n\ninterface Props {\n children: ReactNode;\n}\n\nexport function CommentsProviderWrapper({ children }: Props) {\n const { config } = useConfig();\n\n const pluginConfig = config.admin?.custom?.commentsPlugin as CommentsPluginConfigStorage | undefined;\n const usernameFieldRawPath = pluginConfig?.usernameFieldPath;\n const usernameFieldPath = usernameFieldRawPath === \"\" ? undefined : usernameFieldRawPath;\n\n return (\n <CommentsProvider usernameFieldPath={usernameFieldPath}>\n <CommentsDrawerProvider>{children}</CommentsDrawerProvider>\n </CommentsProvider>\n );\n}\n"],"mappings":";AAqBM;AAlBN,SAAS,iBAAiB;AAC1B,SAAS,8BAA8B;AACvC,SAAS,wBAAwB;AAO1B,SAAS,wBAAwB,EAAE,SAAS,GAAU;AAC3D,QAAM,EAAE,OAAO,IAAI,UAAU;AAE7B,QAAM,eAAe,OAAO,OAAO,QAAQ;AAC3C,QAAM,uBAAuB,cAAc;AAC3C,QAAM,oBAAoB,yBAAyB,KAAK,SAAY;AAEpE,SACE,oBAAC,oBAAiB,mBAChB,8BAAC,0BAAwB,UAAS,GACpC;AAEJ;","names":[]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { EntityLabelsMap, Comment, DocumentTitles, GlobalFieldLabelRegistry, User } from "../../types";
|
|
2
|
+
interface Props {
|
|
3
|
+
comments: Comment[];
|
|
4
|
+
documentTitles: DocumentTitles;
|
|
5
|
+
mentionUsers: User[];
|
|
6
|
+
fieldLabels: GlobalFieldLabelRegistry;
|
|
7
|
+
collectionLabels: EntityLabelsMap;
|
|
8
|
+
globalLabels: EntityLabelsMap;
|
|
9
|
+
loadError: boolean;
|
|
10
|
+
}
|
|
11
|
+
export declare function GlobalCommentsHydrator({ comments, documentTitles, mentionUsers, fieldLabels, collectionLabels, globalLabels, loadError, }: Props): null;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=GlobalCommentsHydrator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GlobalCommentsHydrator.d.ts","sourceRoot":"","sources":["../../../src/providers/GlobalCommentsLoader/GlobalCommentsHydrator.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,eAAe,EAAE,OAAO,EAAE,cAAc,EAAE,wBAAwB,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAE5G,UAAU,KAAK;IACb,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,cAAc,EAAE,cAAc,CAAC;IAC/B,YAAY,EAAE,IAAI,EAAE,CAAC;IACrB,WAAW,EAAE,wBAAwB,CAAC;IACtC,gBAAgB,EAAE,eAAe,CAAC;IAClC,YAAY,EAAE,eAAe,CAAC;IAC9B,SAAS,EAAE,OAAO,CAAC;CACpB;AAED,wBAAgB,sBAAsB,CAAC,EACrC,QAAQ,EACR,cAAc,EACd,YAAY,EACZ,WAAW,EACX,gBAAgB,EAChB,YAAY,EACZ,SAAS,GACV,EAAE,KAAK,QAQP"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { useEffect } from "react";
|
|
3
|
+
import { useComments } from "../CommentsProvider";
|
|
4
|
+
function GlobalCommentsHydrator({
|
|
5
|
+
comments,
|
|
6
|
+
documentTitles,
|
|
7
|
+
mentionUsers,
|
|
8
|
+
fieldLabels,
|
|
9
|
+
collectionLabels,
|
|
10
|
+
globalLabels,
|
|
11
|
+
loadError
|
|
12
|
+
}) {
|
|
13
|
+
const { hydrateComments } = useComments();
|
|
14
|
+
useEffect(() => {
|
|
15
|
+
hydrateComments(comments, documentTitles, mentionUsers, fieldLabels, collectionLabels, loadError, globalLabels);
|
|
16
|
+
}, [comments, documentTitles, mentionUsers, fieldLabels, collectionLabels, loadError, globalLabels, hydrateComments]);
|
|
17
|
+
return null;
|
|
18
|
+
}
|
|
19
|
+
export {
|
|
20
|
+
GlobalCommentsHydrator
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=GlobalCommentsHydrator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/providers/GlobalCommentsLoader/GlobalCommentsHydrator.tsx"],"sourcesContent":["\"use client\";\n\nimport { useEffect } from \"react\";\nimport { useComments } from \"../CommentsProvider\";\nimport type { EntityLabelsMap, Comment, DocumentTitles, GlobalFieldLabelRegistry, User } from \"../../types\";\n\ninterface Props {\n comments: Comment[];\n documentTitles: DocumentTitles;\n mentionUsers: User[];\n fieldLabels: GlobalFieldLabelRegistry;\n collectionLabels: EntityLabelsMap;\n globalLabels: EntityLabelsMap;\n loadError: boolean;\n}\n\nexport function GlobalCommentsHydrator({\n comments,\n documentTitles,\n mentionUsers,\n fieldLabels,\n collectionLabels,\n globalLabels,\n loadError,\n}: Props) {\n const { hydrateComments } = useComments();\n\n useEffect(() => {\n hydrateComments(comments, documentTitles, mentionUsers, fieldLabels, collectionLabels, loadError, globalLabels);\n }, [comments, documentTitles, mentionUsers, fieldLabels, collectionLabels, loadError, globalLabels, hydrateComments]);\n\n return null;\n}\n"],"mappings":";AAEA,SAAS,iBAAiB;AAC1B,SAAS,mBAAmB;AAarB,SAAS,uBAAuB;AAAA,EACrC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAU;AACR,QAAM,EAAE,gBAAgB,IAAI,YAAY;AAExC,YAAU,MAAM;AACd,oBAAgB,UAAU,gBAAgB,cAAc,aAAa,kBAAkB,WAAW,YAAY;AAAA,EAChH,GAAG,CAAC,UAAU,gBAAgB,cAAc,aAAa,kBAAkB,WAAW,cAAc,eAAe,CAAC;AAEpH,SAAO;AACT;","names":[]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Payload } from "payload";
|
|
2
|
+
import type { ReactNode } from "react";
|
|
3
|
+
interface Props {
|
|
4
|
+
children: ReactNode;
|
|
5
|
+
payload: Payload;
|
|
6
|
+
locale?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function GlobalCommentsLoader({ children, payload, locale }: Props): Promise<string | number | bigint | boolean | Iterable<ReactNode> | import("react/jsx-runtime").JSX.Element | null | undefined>;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/providers/GlobalCommentsLoader/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AACvC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGvC,UAAU,KAAK;IACb,QAAQ,EAAE,SAAS,CAAC;IACpB,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,wBAAsB,oBAAoB,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,KAAK,kIA0B9E"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { setPayloadConfig } from "../../config";
|
|
3
|
+
import { GlobalCommentsHydrator } from "./GlobalCommentsHydrator";
|
|
4
|
+
import { syncAllCommentsData } from "../../services/syncAllCommentsData";
|
|
5
|
+
async function GlobalCommentsLoader({ children, payload, locale }) {
|
|
6
|
+
setPayloadConfig(payload.config);
|
|
7
|
+
const res = await syncAllCommentsData({ payload, locale });
|
|
8
|
+
if (res.success) {
|
|
9
|
+
const { comments, documentTitles, mentionUsers, fieldLabels, collectionLabels, globalLabels } = res.data;
|
|
10
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
11
|
+
/* @__PURE__ */ jsx(
|
|
12
|
+
GlobalCommentsHydrator,
|
|
13
|
+
{
|
|
14
|
+
comments,
|
|
15
|
+
documentTitles,
|
|
16
|
+
mentionUsers,
|
|
17
|
+
fieldLabels,
|
|
18
|
+
collectionLabels,
|
|
19
|
+
globalLabels,
|
|
20
|
+
loadError: false
|
|
21
|
+
}
|
|
22
|
+
),
|
|
23
|
+
children
|
|
24
|
+
] });
|
|
25
|
+
}
|
|
26
|
+
return children;
|
|
27
|
+
}
|
|
28
|
+
export {
|
|
29
|
+
GlobalCommentsLoader
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/providers/GlobalCommentsLoader/index.tsx"],"sourcesContent":["import { setPayloadConfig } from \"../../config\";\nimport { GlobalCommentsHydrator } from \"./GlobalCommentsHydrator\";\nimport type { Payload } from \"payload\";\nimport type { ReactNode } from \"react\";\nimport { syncAllCommentsData } from \"../../services/syncAllCommentsData\";\n\ninterface Props {\n children: ReactNode;\n payload: Payload;\n locale?: string;\n}\n\nexport async function GlobalCommentsLoader({ children, payload, locale }: Props) {\n setPayloadConfig(payload.config);\n\n const res = await syncAllCommentsData({ payload, locale });\n\n if (res.success) {\n const { comments, documentTitles, mentionUsers, fieldLabels, collectionLabels, globalLabels } = res.data;\n\n return (\n <>\n <GlobalCommentsHydrator\n comments={comments}\n documentTitles={documentTitles}\n mentionUsers={mentionUsers}\n fieldLabels={fieldLabels}\n collectionLabels={collectionLabels}\n globalLabels={globalLabels}\n loadError={false}\n />\n\n {children}\n </>\n );\n }\n\n return children;\n}\n"],"mappings":"AAqBM,mBACE,KADF;AArBN,SAAS,wBAAwB;AACjC,SAAS,8BAA8B;AAGvC,SAAS,2BAA2B;AAQpC,eAAsB,qBAAqB,EAAE,UAAU,SAAS,OAAO,GAAU;AAC/E,mBAAiB,QAAQ,MAAM;AAE/B,QAAM,MAAM,MAAM,oBAAoB,EAAE,SAAS,OAAO,CAAC;AAEzD,MAAI,IAAI,SAAS;AACf,UAAM,EAAE,UAAU,gBAAgB,cAAc,aAAa,kBAAkB,aAAa,IAAI,IAAI;AAEpG,WACE,iCACE;AAAA;AAAA,QAAC;AAAA;AAAA,UACC;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA,WAAW;AAAA;AAAA,MACb;AAAA,MAEC;AAAA,OACH;AAAA,EAEJ;AAEA,SAAO;AACT;","names":[]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { Response, Comment, BaseServiceOptions } from "../types";
|
|
2
|
+
interface Props extends BaseServiceOptions {
|
|
3
|
+
documentId?: number | null;
|
|
4
|
+
collectionSlug?: string | null;
|
|
5
|
+
globalSlug?: string | null;
|
|
6
|
+
text: string;
|
|
7
|
+
fieldPath?: string | null;
|
|
8
|
+
mentionIds?: number[];
|
|
9
|
+
}
|
|
10
|
+
export declare function createComment({ documentId, collectionSlug, globalSlug, text, fieldPath, mentionIds, locale, payload: payloadProp, }: Props): Promise<Response<Comment>>;
|
|
11
|
+
export {};
|
|
12
|
+
//# sourceMappingURL=createComment.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createComment.d.ts","sourceRoot":"","sources":["../../src/services/createComment.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAKtE,UAAU,KAAM,SAAQ,kBAAkB;IACxC,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;CACvB;AAED,wBAAsB,aAAa,CAAC,EAClC,UAAU,EACV,cAAc,EACd,UAAU,EACV,IAAI,EACJ,SAAgB,EAChB,UAAe,EACf,MAAa,EACb,OAAO,EAAE,WAAW,GACrB,EAAE,KAAK,GAAG,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAyEpC"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
"use server";
|
|
2
|
+
import { headers } from "next/headers";
|
|
3
|
+
import { getDefaultErrorMessage } from "../utils/error/getDefaultErrorMessage";
|
|
4
|
+
import { DEFAULT_COLLECTION_SLUG, FALLBACK_USERNAME } from "../constants";
|
|
5
|
+
import { sendMentionEmails } from "./sendMentionEmails";
|
|
6
|
+
import { extractPayload } from "../utils/payload/extractPayload";
|
|
7
|
+
async function createComment({
|
|
8
|
+
documentId,
|
|
9
|
+
collectionSlug,
|
|
10
|
+
globalSlug,
|
|
11
|
+
text,
|
|
12
|
+
fieldPath = null,
|
|
13
|
+
mentionIds = [],
|
|
14
|
+
locale = null,
|
|
15
|
+
payload: payloadProp
|
|
16
|
+
}) {
|
|
17
|
+
try {
|
|
18
|
+
const payload = await extractPayload(payloadProp);
|
|
19
|
+
const { user } = await payload.auth({ headers: await headers() });
|
|
20
|
+
if (!user) {
|
|
21
|
+
return {
|
|
22
|
+
success: false,
|
|
23
|
+
error: "Unauthorized"
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
if (!globalSlug && (!documentId || !collectionSlug)) {
|
|
27
|
+
return {
|
|
28
|
+
success: false,
|
|
29
|
+
error: "No document registered"
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
const mentions = mentionIds.map((id) => ({ user: id }));
|
|
33
|
+
const data = globalSlug ? {
|
|
34
|
+
globalSlug,
|
|
35
|
+
documentId: null,
|
|
36
|
+
collectionSlug: null,
|
|
37
|
+
fieldPath,
|
|
38
|
+
locale,
|
|
39
|
+
text,
|
|
40
|
+
author: user.id,
|
|
41
|
+
isResolved: false,
|
|
42
|
+
mentions
|
|
43
|
+
} : {
|
|
44
|
+
documentId,
|
|
45
|
+
collectionSlug,
|
|
46
|
+
fieldPath,
|
|
47
|
+
locale,
|
|
48
|
+
text,
|
|
49
|
+
author: user.id,
|
|
50
|
+
isResolved: false,
|
|
51
|
+
mentions
|
|
52
|
+
};
|
|
53
|
+
const comment = await payload.create({
|
|
54
|
+
collection: DEFAULT_COLLECTION_SLUG,
|
|
55
|
+
data,
|
|
56
|
+
overrideAccess: false,
|
|
57
|
+
user
|
|
58
|
+
});
|
|
59
|
+
if (mentionIds.length > 0) {
|
|
60
|
+
sendMentionEmails({
|
|
61
|
+
mentionIds,
|
|
62
|
+
authorName: user.name ?? user.email ?? FALLBACK_USERNAME,
|
|
63
|
+
commentText: text,
|
|
64
|
+
collectionSlug: collectionSlug ?? globalSlug ?? "",
|
|
65
|
+
documentId,
|
|
66
|
+
payload
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
return {
|
|
70
|
+
success: true,
|
|
71
|
+
data: comment
|
|
72
|
+
};
|
|
73
|
+
} catch (err) {
|
|
74
|
+
return {
|
|
75
|
+
success: false,
|
|
76
|
+
error: getDefaultErrorMessage(err)
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
export {
|
|
81
|
+
createComment
|
|
82
|
+
};
|
|
83
|
+
//# sourceMappingURL=createComment.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/services/createComment.ts"],"sourcesContent":["\"use server\";\n\nimport { headers } from \"next/headers\";\nimport { getDefaultErrorMessage } from \"../utils/error/getDefaultErrorMessage\";\nimport type { Response, Comment, BaseServiceOptions } from \"../types\";\nimport { DEFAULT_COLLECTION_SLUG, FALLBACK_USERNAME } from \"../constants\";\nimport { sendMentionEmails } from \"./sendMentionEmails\";\nimport { extractPayload } from \"../utils/payload/extractPayload\";\n\ninterface Props extends BaseServiceOptions {\n documentId?: number | null;\n collectionSlug?: string | null;\n globalSlug?: string | null;\n text: string;\n fieldPath?: string | null;\n mentionIds?: number[];\n}\n\nexport async function createComment({\n documentId,\n collectionSlug,\n globalSlug,\n text,\n fieldPath = null,\n mentionIds = [],\n locale = null,\n payload: payloadProp,\n}: Props): Promise<Response<Comment>> {\n try {\n const payload = await extractPayload(payloadProp);\n const { user } = await payload.auth({ headers: await headers() });\n\n if (!user) {\n return {\n success: false,\n error: \"Unauthorized\",\n };\n }\n\n if (!globalSlug && (!documentId || !collectionSlug)) {\n return {\n success: false,\n error: \"No document registered\",\n };\n }\n\n const mentions = mentionIds.map((id) => ({ user: id }));\n\n const data =\n globalSlug ?\n {\n globalSlug,\n documentId: null,\n collectionSlug: null,\n fieldPath,\n locale,\n text,\n author: user.id,\n isResolved: false,\n mentions,\n }\n : {\n documentId,\n collectionSlug,\n fieldPath,\n locale,\n text,\n author: user.id,\n isResolved: false,\n mentions,\n };\n\n const comment = (await payload.create({\n collection: DEFAULT_COLLECTION_SLUG,\n data,\n overrideAccess: false,\n user,\n })) as Comment;\n\n if (mentionIds.length > 0) {\n sendMentionEmails({\n mentionIds,\n authorName: user.name ?? user.email ?? FALLBACK_USERNAME,\n commentText: text,\n collectionSlug: collectionSlug ?? globalSlug ?? \"\",\n documentId: documentId,\n payload,\n });\n }\n\n return {\n success: true,\n data: comment,\n };\n } catch (err) {\n return {\n success: false,\n error: getDefaultErrorMessage(err),\n };\n }\n}\n"],"mappings":";AAEA,SAAS,eAAe;AACxB,SAAS,8BAA8B;AAEvC,SAAS,yBAAyB,yBAAyB;AAC3D,SAAS,yBAAyB;AAClC,SAAS,sBAAsB;AAW/B,eAAsB,cAAc;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,YAAY;AAAA,EACZ,aAAa,CAAC;AAAA,EACd,SAAS;AAAA,EACT,SAAS;AACX,GAAsC;AACpC,MAAI;AACF,UAAM,UAAU,MAAM,eAAe,WAAW;AAChD,UAAM,EAAE,KAAK,IAAI,MAAM,QAAQ,KAAK,EAAE,SAAS,MAAM,QAAQ,EAAE,CAAC;AAEhE,QAAI,CAAC,MAAM;AACT,aAAO;AAAA,QACL,SAAS;AAAA,QACT,OAAO;AAAA,MACT;AAAA,IACF;AAEA,QAAI,CAAC,eAAe,CAAC,cAAc,CAAC,iBAAiB;AACnD,aAAO;AAAA,QACL,SAAS;AAAA,QACT,OAAO;AAAA,MACT;AAAA,IACF;AAEA,UAAM,WAAW,WAAW,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,EAAE;AAEtD,UAAM,OACJ,aACE;AAAA,MACE;AAAA,MACA,YAAY;AAAA,MACZ,gBAAgB;AAAA,MAChB;AAAA,MACA;AAAA,MACA;AAAA,MACA,QAAQ,KAAK;AAAA,MACb,YAAY;AAAA,MACZ;AAAA,IACF,IACA;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,QAAQ,KAAK;AAAA,MACb,YAAY;AAAA,MACZ;AAAA,IACF;AAEJ,UAAM,UAAW,MAAM,QAAQ,OAAO;AAAA,MACpC,YAAY;AAAA,MACZ;AAAA,MACA,gBAAgB;AAAA,MAChB;AAAA,IACF,CAAC;AAED,QAAI,WAAW,SAAS,GAAG;AACzB,wBAAkB;AAAA,QAChB;AAAA,QACA,YAAY,KAAK,QAAQ,KAAK,SAAS;AAAA,QACvC,aAAa;AAAA,QACb,gBAAgB,kBAAkB,cAAc;AAAA,QAChD;AAAA,QACA;AAAA,MACF,CAAC;AAAA,IACH;AAEA,WAAO;AAAA,MACL,SAAS;AAAA,MACT,MAAM;AAAA,IACR;AAAA,EACF,SAAS,KAAK;AACZ,WAAO;AAAA,MACL,SAAS;AAAA,MACT,OAAO,uBAAuB,GAAG;AAAA,IACnC;AAAA,EACF;AACF;","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deleteComment.d.ts","sourceRoot":"","sources":["../../src/services/deleteComment.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,kBAAkB,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AAGtE,wBAAsB,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,EAAE,OAAO,CAAC,EAAE,kBAAkB,GAAG,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CA4BjH"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use server";
|
|
2
|
+
import { headers } from "next/headers";
|
|
3
|
+
import { DEFAULT_COLLECTION_SLUG } from "../constants";
|
|
4
|
+
import { getDefaultErrorMessage } from "../utils/error/getDefaultErrorMessage";
|
|
5
|
+
import { extractPayload } from "../utils/payload/extractPayload";
|
|
6
|
+
async function deleteComment(id, options) {
|
|
7
|
+
try {
|
|
8
|
+
const payload = await extractPayload(options?.payload);
|
|
9
|
+
const { user } = await payload.auth({ headers: await headers() });
|
|
10
|
+
if (!user) {
|
|
11
|
+
return { success: false, error: "Unauthorized" };
|
|
12
|
+
}
|
|
13
|
+
const data = await payload.delete({
|
|
14
|
+
collection: DEFAULT_COLLECTION_SLUG,
|
|
15
|
+
id,
|
|
16
|
+
overrideAccess: false,
|
|
17
|
+
user
|
|
18
|
+
});
|
|
19
|
+
return {
|
|
20
|
+
success: true,
|
|
21
|
+
data
|
|
22
|
+
};
|
|
23
|
+
} catch (e) {
|
|
24
|
+
console.error(`Failed to delete ${id} comment`, e);
|
|
25
|
+
return {
|
|
26
|
+
success: false,
|
|
27
|
+
error: getDefaultErrorMessage(e)
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
export {
|
|
32
|
+
deleteComment
|
|
33
|
+
};
|
|
34
|
+
//# sourceMappingURL=deleteComment.js.map
|