@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.
Files changed (387) hide show
  1. package/README.md +562 -0
  2. package/dist/collection/access/isAuth.d.ts +3 -0
  3. package/dist/collection/access/isAuth.d.ts.map +1 -0
  4. package/dist/collection/access/isAuth.js +8 -0
  5. package/dist/collection/access/isAuth.js.map +1 -0
  6. package/dist/collection/hooks/setAuthorBeforeCreate.d.ts +3 -0
  7. package/dist/collection/hooks/setAuthorBeforeCreate.d.ts.map +1 -0
  8. package/dist/collection/hooks/setAuthorBeforeCreate.js +10 -0
  9. package/dist/collection/hooks/setAuthorBeforeCreate.js.map +1 -0
  10. package/dist/collection/hooks/setTenantBeforeCreate.d.ts +3 -0
  11. package/dist/collection/hooks/setTenantBeforeCreate.d.ts.map +1 -0
  12. package/dist/collection/hooks/setTenantBeforeCreate.js +24 -0
  13. package/dist/collection/hooks/setTenantBeforeCreate.js.map +1 -0
  14. package/dist/collection/index.d.ts +4 -0
  15. package/dist/collection/index.d.ts.map +1 -0
  16. package/dist/collection/index.js +139 -0
  17. package/dist/collection/index.js.map +1 -0
  18. package/dist/components/Avatar/index.d.ts +11 -0
  19. package/dist/components/Avatar/index.d.ts.map +1 -0
  20. package/dist/components/Avatar/index.js +11 -0
  21. package/dist/components/Avatar/index.js.map +1 -0
  22. package/dist/components/CommentEditor/ActionPanel.d.ts +8 -0
  23. package/dist/components/CommentEditor/ActionPanel.d.ts.map +1 -0
  24. package/dist/components/CommentEditor/ActionPanel.js +17 -0
  25. package/dist/components/CommentEditor/ActionPanel.js.map +1 -0
  26. package/dist/components/CommentEditor/index.d.ts +23 -0
  27. package/dist/components/CommentEditor/index.d.ts.map +1 -0
  28. package/dist/components/CommentEditor/index.js +265 -0
  29. package/dist/components/CommentEditor/index.js.map +1 -0
  30. package/dist/components/CommentItem/ToolsPanel.d.ts +9 -0
  31. package/dist/components/CommentItem/ToolsPanel.d.ts.map +1 -0
  32. package/dist/components/CommentItem/ToolsPanel.js +22 -0
  33. package/dist/components/CommentItem/ToolsPanel.js.map +1 -0
  34. package/dist/components/CommentItem/index.d.ts +8 -0
  35. package/dist/components/CommentItem/index.d.ts.map +1 -0
  36. package/dist/components/CommentItem/index.js +65 -0
  37. package/dist/components/CommentItem/index.js.map +1 -0
  38. package/dist/components/CommentsDrawer/components/Header.d.ts +6 -0
  39. package/dist/components/CommentsDrawer/components/Header.d.ts.map +1 -0
  40. package/dist/components/CommentsDrawer/components/Header.js +46 -0
  41. package/dist/components/CommentsDrawer/components/Header.js.map +1 -0
  42. package/dist/components/CommentsDrawer/index.d.ts +6 -0
  43. package/dist/components/CommentsDrawer/index.d.ts.map +1 -0
  44. package/dist/components/CommentsDrawer/index.js +30 -0
  45. package/dist/components/CommentsDrawer/index.js.map +1 -0
  46. package/dist/components/CommentsHeaderButton/index.d.ts +2 -0
  47. package/dist/components/CommentsHeaderButton/index.d.ts.map +1 -0
  48. package/dist/components/CommentsHeaderButton/index.js +19 -0
  49. package/dist/components/CommentsHeaderButton/index.js.map +1 -0
  50. package/dist/components/CommentsPanel/components/CollapsibleGroup.d.ts +10 -0
  51. package/dist/components/CommentsPanel/components/CollapsibleGroup.d.ts.map +1 -0
  52. package/dist/components/CommentsPanel/components/CollapsibleGroup.js +68 -0
  53. package/dist/components/CommentsPanel/components/CollapsibleGroup.js.map +1 -0
  54. package/dist/components/CommentsPanel/components/DocumentView.d.ts +9 -0
  55. package/dist/components/CommentsPanel/components/DocumentView.d.ts.map +1 -0
  56. package/dist/components/CommentsPanel/components/DocumentView.js +20 -0
  57. package/dist/components/CommentsPanel/components/DocumentView.js.map +1 -0
  58. package/dist/components/CommentsPanel/components/FieldGroupSection.d.ts +11 -0
  59. package/dist/components/CommentsPanel/components/FieldGroupSection.d.ts.map +1 -0
  60. package/dist/components/CommentsPanel/components/FieldGroupSection.js +62 -0
  61. package/dist/components/CommentsPanel/components/FieldGroupSection.js.map +1 -0
  62. package/dist/components/CommentsPanel/components/GlobalDocumentView.d.ts +9 -0
  63. package/dist/components/CommentsPanel/components/GlobalDocumentView.d.ts.map +1 -0
  64. package/dist/components/CommentsPanel/components/GlobalDocumentView.js +20 -0
  65. package/dist/components/CommentsPanel/components/GlobalDocumentView.js.map +1 -0
  66. package/dist/components/CommentsPanel/components/GlobalView.d.ts +9 -0
  67. package/dist/components/CommentsPanel/components/GlobalView.d.ts.map +1 -0
  68. package/dist/components/CommentsPanel/components/GlobalView.js +62 -0
  69. package/dist/components/CommentsPanel/components/GlobalView.js.map +1 -0
  70. package/dist/components/CommentsPanel/constants.d.ts +3 -0
  71. package/dist/components/CommentsPanel/constants.d.ts.map +1 -0
  72. package/dist/components/CommentsPanel/constants.js +9 -0
  73. package/dist/components/CommentsPanel/constants.js.map +1 -0
  74. package/dist/components/CommentsPanel/hooks/useCollapseState.d.ts +2 -0
  75. package/dist/components/CommentsPanel/hooks/useCollapseState.d.ts.map +1 -0
  76. package/dist/components/CommentsPanel/hooks/useCollapseState.js +44 -0
  77. package/dist/components/CommentsPanel/hooks/useCollapseState.js.map +1 -0
  78. package/dist/components/CommentsPanel/hooks/useScrollToTargetFieldGroup.d.ts +2 -0
  79. package/dist/components/CommentsPanel/hooks/useScrollToTargetFieldGroup.d.ts.map +1 -0
  80. package/dist/components/CommentsPanel/hooks/useScrollToTargetFieldGroup.js +35 -0
  81. package/dist/components/CommentsPanel/hooks/useScrollToTargetFieldGroup.js.map +1 -0
  82. package/dist/components/CommentsPanel/index.d.ts +6 -0
  83. package/dist/components/CommentsPanel/index.d.ts.map +1 -0
  84. package/dist/components/CommentsPanel/index.js +32 -0
  85. package/dist/components/CommentsPanel/index.js.map +1 -0
  86. package/dist/components/CommentsPanel/types.d.ts +4 -0
  87. package/dist/components/CommentsPanel/types.d.ts.map +1 -0
  88. package/dist/components/CommentsPanel/types.js +1 -0
  89. package/dist/components/CommentsPanel/types.js.map +1 -0
  90. package/dist/components/CommentsPanel/utils/createCollapsibleGroupKey.d.ts +10 -0
  91. package/dist/components/CommentsPanel/utils/createCollapsibleGroupKey.d.ts.map +1 -0
  92. package/dist/components/CommentsPanel/utils/createCollapsibleGroupKey.js +15 -0
  93. package/dist/components/CommentsPanel/utils/createCollapsibleGroupKey.js.map +1 -0
  94. package/dist/components/CommentsPanel/utils/filterComments.d.ts +9 -0
  95. package/dist/components/CommentsPanel/utils/filterComments.d.ts.map +1 -0
  96. package/dist/components/CommentsPanel/utils/filterComments.js +17 -0
  97. package/dist/components/CommentsPanel/utils/filterComments.js.map +1 -0
  98. package/dist/components/CommentsPanel/utils/groupCommentsByFieldPath.d.ts +4 -0
  99. package/dist/components/CommentsPanel/utils/groupCommentsByFieldPath.d.ts.map +1 -0
  100. package/dist/components/CommentsPanel/utils/groupCommentsByFieldPath.js +14 -0
  101. package/dist/components/CommentsPanel/utils/groupCommentsByFieldPath.js.map +1 -0
  102. package/dist/components/CommentsPanel/utils/groupCommentsGlobally.d.ts +18 -0
  103. package/dist/components/CommentsPanel/utils/groupCommentsGlobally.d.ts.map +1 -0
  104. package/dist/components/CommentsPanel/utils/groupCommentsGlobally.js +58 -0
  105. package/dist/components/CommentsPanel/utils/groupCommentsGlobally.js.map +1 -0
  106. package/dist/components/CommentsPanel/utils/resolveEntityLabel.d.ts +3 -0
  107. package/dist/components/CommentsPanel/utils/resolveEntityLabel.d.ts.map +1 -0
  108. package/dist/components/CommentsPanel/utils/resolveEntityLabel.js +14 -0
  109. package/dist/components/CommentsPanel/utils/resolveEntityLabel.js.map +1 -0
  110. package/dist/components/CommentsPanel/utils/resolveFieldLabel.d.ts +11 -0
  111. package/dist/components/CommentsPanel/utils/resolveFieldLabel.d.ts.map +1 -0
  112. package/dist/components/CommentsPanel/utils/resolveFieldLabel.js +9 -0
  113. package/dist/components/CommentsPanel/utils/resolveFieldLabel.js.map +1 -0
  114. package/dist/components/CommentsPanel/utils/sortGroupsByCreatedAt.d.ts +4 -0
  115. package/dist/components/CommentsPanel/utils/sortGroupsByCreatedAt.d.ts.map +1 -0
  116. package/dist/components/CommentsPanel/utils/sortGroupsByCreatedAt.js +11 -0
  117. package/dist/components/CommentsPanel/utils/sortGroupsByCreatedAt.js.map +1 -0
  118. package/dist/components/FieldCommentLabel/AddCommentPopup.d.ts +8 -0
  119. package/dist/components/FieldCommentLabel/AddCommentPopup.d.ts.map +1 -0
  120. package/dist/components/FieldCommentLabel/AddCommentPopup.js +50 -0
  121. package/dist/components/FieldCommentLabel/AddCommentPopup.js.map +1 -0
  122. package/dist/components/FieldCommentLabel/hooks/useStablePath.d.ts +2 -0
  123. package/dist/components/FieldCommentLabel/hooks/useStablePath.d.ts.map +1 -0
  124. package/dist/components/FieldCommentLabel/hooks/useStablePath.js +12 -0
  125. package/dist/components/FieldCommentLabel/hooks/useStablePath.js.map +1 -0
  126. package/dist/components/FieldCommentLabel/index.d.ts +11 -0
  127. package/dist/components/FieldCommentLabel/index.d.ts.map +1 -0
  128. package/dist/components/FieldCommentLabel/index.js +64 -0
  129. package/dist/components/FieldCommentLabel/index.js.map +1 -0
  130. package/dist/components/FieldCommentLabel/types.d.ts +4 -0
  131. package/dist/components/FieldCommentLabel/types.d.ts.map +1 -0
  132. package/dist/components/FieldCommentLabel/types.js +1 -0
  133. package/dist/components/FieldCommentLabel/types.js.map +1 -0
  134. package/dist/components/FieldCommentLabel/utils/buildStablePath.d.ts +2 -0
  135. package/dist/components/FieldCommentLabel/utils/buildStablePath.d.ts.map +1 -0
  136. package/dist/components/FieldCommentLabel/utils/buildStablePath.js +19 -0
  137. package/dist/components/FieldCommentLabel/utils/buildStablePath.js.map +1 -0
  138. package/dist/components/FieldCommentLabel/utils/exludeComments.d.ts +3 -0
  139. package/dist/components/FieldCommentLabel/utils/exludeComments.d.ts.map +1 -0
  140. package/dist/components/FieldCommentLabel/utils/exludeComments.js +12 -0
  141. package/dist/components/FieldCommentLabel/utils/exludeComments.js.map +1 -0
  142. package/dist/components/FieldCommentLabel/utils/resolveLabel.d.ts +3 -0
  143. package/dist/components/FieldCommentLabel/utils/resolveLabel.d.ts.map +1 -0
  144. package/dist/components/FieldCommentLabel/utils/resolveLabel.js +9 -0
  145. package/dist/components/FieldCommentLabel/utils/resolveLabel.js.map +1 -0
  146. package/dist/components/IconButton/index.d.ts +12 -0
  147. package/dist/components/IconButton/index.d.ts.map +1 -0
  148. package/dist/components/IconButton/index.js +38 -0
  149. package/dist/components/IconButton/index.js.map +1 -0
  150. package/dist/components/MentionDropdown.d.ts +11 -0
  151. package/dist/components/MentionDropdown.d.ts.map +1 -0
  152. package/dist/components/MentionDropdown.js +53 -0
  153. package/dist/components/MentionDropdown.js.map +1 -0
  154. package/dist/components/MentionLabel/index.d.ts +7 -0
  155. package/dist/components/MentionLabel/index.d.ts.map +1 -0
  156. package/dist/components/MentionLabel/index.js +21 -0
  157. package/dist/components/MentionLabel/index.js.map +1 -0
  158. package/dist/config.d.ts +4 -0
  159. package/dist/config.d.ts.map +1 -0
  160. package/dist/config.js +17 -0
  161. package/dist/config.js.map +1 -0
  162. package/dist/constants.d.ts +9 -0
  163. package/dist/constants.d.ts.map +1 -0
  164. package/dist/constants.js +22 -0
  165. package/dist/constants.js.map +1 -0
  166. package/dist/hooks/useRelativeDate.d.ts +2 -0
  167. package/dist/hooks/useRelativeDate.d.ts.map +1 -0
  168. package/dist/hooks/useRelativeDate.js +11 -0
  169. package/dist/hooks/useRelativeDate.js.map +1 -0
  170. package/dist/index.d.ts +5 -0
  171. package/dist/index.d.ts.map +1 -0
  172. package/dist/index.js +7 -0
  173. package/dist/index.js.map +1 -0
  174. package/dist/plugin.d.ts +4 -0
  175. package/dist/plugin.d.ts.map +1 -0
  176. package/dist/plugin.js +60 -0
  177. package/dist/plugin.js.map +1 -0
  178. package/dist/providers/CommentsDrawerProvider/index.d.ts +14 -0
  179. package/dist/providers/CommentsDrawerProvider/index.d.ts.map +1 -0
  180. package/dist/providers/CommentsDrawerProvider/index.js +28 -0
  181. package/dist/providers/CommentsDrawerProvider/index.js.map +1 -0
  182. package/dist/providers/CommentsProvider/index.d.ts +39 -0
  183. package/dist/providers/CommentsProvider/index.d.ts.map +1 -0
  184. package/dist/providers/CommentsProvider/index.js +237 -0
  185. package/dist/providers/CommentsProvider/index.js.map +1 -0
  186. package/dist/providers/CommentsProvider/mergeDocumentTitles.d.ts +3 -0
  187. package/dist/providers/CommentsProvider/mergeDocumentTitles.d.ts.map +1 -0
  188. package/dist/providers/CommentsProvider/mergeDocumentTitles.js +10 -0
  189. package/dist/providers/CommentsProvider/mergeDocumentTitles.js.map +1 -0
  190. package/dist/providers/CommentsProviderWrapper/index.d.ts +7 -0
  191. package/dist/providers/CommentsProviderWrapper/index.d.ts.map +1 -0
  192. package/dist/providers/CommentsProviderWrapper/index.js +16 -0
  193. package/dist/providers/CommentsProviderWrapper/index.js.map +1 -0
  194. package/dist/providers/GlobalCommentsLoader/GlobalCommentsHydrator.d.ts +13 -0
  195. package/dist/providers/GlobalCommentsLoader/GlobalCommentsHydrator.d.ts.map +1 -0
  196. package/dist/providers/GlobalCommentsLoader/GlobalCommentsHydrator.js +22 -0
  197. package/dist/providers/GlobalCommentsLoader/GlobalCommentsHydrator.js.map +1 -0
  198. package/dist/providers/GlobalCommentsLoader/index.d.ts +10 -0
  199. package/dist/providers/GlobalCommentsLoader/index.d.ts.map +1 -0
  200. package/dist/providers/GlobalCommentsLoader/index.js +31 -0
  201. package/dist/providers/GlobalCommentsLoader/index.js.map +1 -0
  202. package/dist/services/createComment.d.ts +12 -0
  203. package/dist/services/createComment.d.ts.map +1 -0
  204. package/dist/services/createComment.js +83 -0
  205. package/dist/services/createComment.js.map +1 -0
  206. package/dist/services/deleteComment.d.ts +3 -0
  207. package/dist/services/deleteComment.d.ts.map +1 -0
  208. package/dist/services/deleteComment.js +34 -0
  209. package/dist/services/deleteComment.js.map +1 -0
  210. package/dist/services/fetchMentionableUsers.d.ts +3 -0
  211. package/dist/services/fetchMentionableUsers.d.ts.map +1 -0
  212. package/dist/services/fetchMentionableUsers.js +46 -0
  213. package/dist/services/fetchMentionableUsers.js.map +1 -0
  214. package/dist/services/fieldLabels/fetchFieldLabels.d.ts +3 -0
  215. package/dist/services/fieldLabels/fetchFieldLabels.d.ts.map +1 -0
  216. package/dist/services/fieldLabels/fetchFieldLabels.js +74 -0
  217. package/dist/services/fieldLabels/fetchFieldLabels.js.map +1 -0
  218. package/dist/services/fieldLabels/utils/groupFieldPathsByDocument.d.ts +5 -0
  219. package/dist/services/fieldLabels/utils/groupFieldPathsByDocument.d.ts.map +1 -0
  220. package/dist/services/fieldLabels/utils/groupFieldPathsByDocument.js +21 -0
  221. package/dist/services/fieldLabels/utils/groupFieldPathsByDocument.js.map +1 -0
  222. package/dist/services/fieldLabels/utils/resolveFieldPath.d.ts +4 -0
  223. package/dist/services/fieldLabels/utils/resolveFieldPath.d.ts.map +1 -0
  224. package/dist/services/fieldLabels/utils/resolveFieldPath.js +66 -0
  225. package/dist/services/fieldLabels/utils/resolveFieldPath.js.map +1 -0
  226. package/dist/services/fieldLabels/utils/schemaUtils.d.ts +6 -0
  227. package/dist/services/fieldLabels/utils/schemaUtils.d.ts.map +1 -0
  228. package/dist/services/fieldLabels/utils/schemaUtils.js +60 -0
  229. package/dist/services/fieldLabels/utils/schemaUtils.js.map +1 -0
  230. package/dist/services/findAllComments.d.ts +11 -0
  231. package/dist/services/findAllComments.d.ts.map +1 -0
  232. package/dist/services/findAllComments.js +47 -0
  233. package/dist/services/findAllComments.js.map +1 -0
  234. package/dist/services/getCurrentTenantId.d.ts +3 -0
  235. package/dist/services/getCurrentTenantId.d.ts.map +1 -0
  236. package/dist/services/getCurrentTenantId.js +13 -0
  237. package/dist/services/getCurrentTenantId.js.map +1 -0
  238. package/dist/services/getDocumentTitles.d.ts +3 -0
  239. package/dist/services/getDocumentTitles.d.ts.map +1 -0
  240. package/dist/services/getDocumentTitles.js +61 -0
  241. package/dist/services/getDocumentTitles.js.map +1 -0
  242. package/dist/services/getEntitiesLabels.d.ts +3 -0
  243. package/dist/services/getEntitiesLabels.d.ts.map +1 -0
  244. package/dist/services/getEntitiesLabels.js +14 -0
  245. package/dist/services/getEntitiesLabels.js.map +1 -0
  246. package/dist/services/resolveComment.d.ts +3 -0
  247. package/dist/services/resolveComment.d.ts.map +1 -0
  248. package/dist/services/resolveComment.js +41 -0
  249. package/dist/services/resolveComment.js.map +1 -0
  250. package/dist/services/sendMentionEmails.d.ts +11 -0
  251. package/dist/services/sendMentionEmails.d.ts.map +1 -0
  252. package/dist/services/sendMentionEmails.js +73 -0
  253. package/dist/services/sendMentionEmails.js.map +1 -0
  254. package/dist/services/syncAllCommentsData.d.ts +12 -0
  255. package/dist/services/syncAllCommentsData.d.ts.map +1 -0
  256. package/dist/services/syncAllCommentsData.js +48 -0
  257. package/dist/services/syncAllCommentsData.js.map +1 -0
  258. package/dist/styles.css +2 -0
  259. package/dist/translations/en.d.ts +5 -0
  260. package/dist/translations/en.d.ts.map +1 -0
  261. package/dist/translations/en.js +36 -0
  262. package/dist/translations/en.js.map +1 -0
  263. package/dist/translations/types.d.ts +32 -0
  264. package/dist/translations/types.d.ts.map +1 -0
  265. package/dist/translations/types.js +1 -0
  266. package/dist/translations/types.js.map +1 -0
  267. package/dist/types/base.d.ts +10 -0
  268. package/dist/types/base.d.ts.map +1 -0
  269. package/dist/types/base.js +1 -0
  270. package/dist/types/base.js.map +1 -0
  271. package/dist/types/collection.d.ts +2 -0
  272. package/dist/types/collection.d.ts.map +1 -0
  273. package/dist/types/collection.js +1 -0
  274. package/dist/types/collection.js.map +1 -0
  275. package/dist/types/comment.d.ts +23 -0
  276. package/dist/types/comment.d.ts.map +1 -0
  277. package/dist/types/comment.js +1 -0
  278. package/dist/types/comment.js.map +1 -0
  279. package/dist/types/config.d.ts +112 -0
  280. package/dist/types/config.d.ts.map +1 -0
  281. package/dist/types/config.js +1 -0
  282. package/dist/types/config.js.map +1 -0
  283. package/dist/types/entity.d.ts +15 -0
  284. package/dist/types/entity.d.ts.map +1 -0
  285. package/dist/types/entity.js +1 -0
  286. package/dist/types/entity.js.map +1 -0
  287. package/dist/types/general.d.ts +10 -0
  288. package/dist/types/general.d.ts.map +1 -0
  289. package/dist/types/general.js +1 -0
  290. package/dist/types/general.js.map +1 -0
  291. package/dist/types/index.d.ts +8 -0
  292. package/dist/types/index.d.ts.map +1 -0
  293. package/dist/types/index.js +1 -0
  294. package/dist/types/index.js.map +1 -0
  295. package/dist/types/user.d.ts +6 -0
  296. package/dist/types/user.d.ts.map +1 -0
  297. package/dist/types/user.js +1 -0
  298. package/dist/types/user.js.map +1 -0
  299. package/dist/utils/comment/extractVisibleComments.d.ts +13 -0
  300. package/dist/utils/comment/extractVisibleComments.d.ts.map +1 -0
  301. package/dist/utils/comment/extractVisibleComments.js +17 -0
  302. package/dist/utils/comment/extractVisibleComments.js.map +1 -0
  303. package/dist/utils/comment/filterCommentsByLocale.d.ts +3 -0
  304. package/dist/utils/comment/filterCommentsByLocale.d.ts.map +1 -0
  305. package/dist/utils/comment/filterCommentsByLocale.js +12 -0
  306. package/dist/utils/comment/filterCommentsByLocale.js.map +1 -0
  307. package/dist/utils/comment/renderCommentText.d.ts +12 -0
  308. package/dist/utils/comment/renderCommentText.d.ts.map +1 -0
  309. package/dist/utils/comment/renderCommentText.js +38 -0
  310. package/dist/utils/comment/renderCommentText.js.map +1 -0
  311. package/dist/utils/comment/serializeEditor.d.ts +2 -0
  312. package/dist/utils/comment/serializeEditor.d.ts.map +1 -0
  313. package/dist/utils/comment/serializeEditor.js +30 -0
  314. package/dist/utils/comment/serializeEditor.js.map +1 -0
  315. package/dist/utils/config/injectFieldCommentComponents.d.ts +4 -0
  316. package/dist/utils/config/injectFieldCommentComponents.d.ts.map +1 -0
  317. package/dist/utils/config/injectFieldCommentComponents.js +80 -0
  318. package/dist/utils/config/injectFieldCommentComponents.js.map +1 -0
  319. package/dist/utils/config/mergeTranslations.d.ts +3 -0
  320. package/dist/utils/config/mergeTranslations.d.ts.map +1 -0
  321. package/dist/utils/config/mergeTranslations.js +29 -0
  322. package/dist/utils/config/mergeTranslations.js.map +1 -0
  323. package/dist/utils/config/normalizeCollections.d.ts +7 -0
  324. package/dist/utils/config/normalizeCollections.d.ts.map +1 -0
  325. package/dist/utils/config/normalizeCollections.js +15 -0
  326. package/dist/utils/config/normalizeCollections.js.map +1 -0
  327. package/dist/utils/config/overrideCollections.d.ts +3 -0
  328. package/dist/utils/config/overrideCollections.d.ts.map +1 -0
  329. package/dist/utils/config/overrideCollections.js +38 -0
  330. package/dist/utils/config/overrideCollections.js.map +1 -0
  331. package/dist/utils/config/overrideCommentsCollection.d.ts +4 -0
  332. package/dist/utils/config/overrideCommentsCollection.d.ts.map +1 -0
  333. package/dist/utils/config/overrideCommentsCollection.js +14 -0
  334. package/dist/utils/config/overrideCommentsCollection.js.map +1 -0
  335. package/dist/utils/config/overrideGlobals.d.ts +3 -0
  336. package/dist/utils/config/overrideGlobals.d.ts.map +1 -0
  337. package/dist/utils/config/overrideGlobals.js +8 -0
  338. package/dist/utils/config/overrideGlobals.js.map +1 -0
  339. package/dist/utils/error/getDefaultErrorMessage.d.ts +2 -0
  340. package/dist/utils/error/getDefaultErrorMessage.d.ts.map +1 -0
  341. package/dist/utils/error/getDefaultErrorMessage.js +9 -0
  342. package/dist/utils/error/getDefaultErrorMessage.js.map +1 -0
  343. package/dist/utils/general/cn.d.ts +3 -0
  344. package/dist/utils/general/cn.d.ts.map +1 -0
  345. package/dist/utils/general/cn.js +9 -0
  346. package/dist/utils/general/cn.js.map +1 -0
  347. package/dist/utils/general/formatRelativeDate.d.ts +2 -0
  348. package/dist/utils/general/formatRelativeDate.d.ts.map +1 -0
  349. package/dist/utils/general/formatRelativeDate.js +28 -0
  350. package/dist/utils/general/formatRelativeDate.js.map +1 -0
  351. package/dist/utils/general/getURL.d.ts +2 -0
  352. package/dist/utils/general/getURL.d.ts.map +1 -0
  353. package/dist/utils/general/getURL.js +13 -0
  354. package/dist/utils/general/getURL.js.map +1 -0
  355. package/dist/utils/general/getValueByPath.d.ts +4 -0
  356. package/dist/utils/general/getValueByPath.d.ts.map +1 -0
  357. package/dist/utils/general/getValueByPath.js +19 -0
  358. package/dist/utils/general/getValueByPath.js.map +1 -0
  359. package/dist/utils/mention/isSelfMention.d.ts +4 -0
  360. package/dist/utils/mention/isSelfMention.d.ts.map +1 -0
  361. package/dist/utils/mention/isSelfMention.js +7 -0
  362. package/dist/utils/mention/isSelfMention.js.map +1 -0
  363. package/dist/utils/mention/parseMentionIds.d.ts +2 -0
  364. package/dist/utils/mention/parseMentionIds.d.ts.map +1 -0
  365. package/dist/utils/mention/parseMentionIds.js +13 -0
  366. package/dist/utils/mention/parseMentionIds.js.map +1 -0
  367. package/dist/utils/mode/defineModeByPathname.d.ts +11 -0
  368. package/dist/utils/mode/defineModeByPathname.d.ts.map +1 -0
  369. package/dist/utils/mode/defineModeByPathname.js +39 -0
  370. package/dist/utils/mode/defineModeByPathname.js.map +1 -0
  371. package/dist/utils/path/detectPluginBasePath.d.ts +2 -0
  372. package/dist/utils/path/detectPluginBasePath.d.ts.map +1 -0
  373. package/dist/utils/path/detectPluginBasePath.js +8 -0
  374. package/dist/utils/path/detectPluginBasePath.js.map +1 -0
  375. package/dist/utils/path/getComponentPath.d.ts +15 -0
  376. package/dist/utils/path/getComponentPath.d.ts.map +1 -0
  377. package/dist/utils/path/getComponentPath.js +22 -0
  378. package/dist/utils/path/getComponentPath.js.map +1 -0
  379. package/dist/utils/payload/extractPayload.d.ts +3 -0
  380. package/dist/utils/payload/extractPayload.d.ts.map +1 -0
  381. package/dist/utils/payload/extractPayload.js +9 -0
  382. package/dist/utils/payload/extractPayload.js.map +1 -0
  383. package/dist/utils/user/resolveUsername.d.ts +4 -0
  384. package/dist/utils/user/resolveUsername.d.ts.map +1 -0
  385. package/dist/utils/user/resolveUsername.js +14 -0
  386. package/dist/utils/user/resolveUsername.js.map +1 -0
  387. 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,3 @@
1
+ import type { DocumentTitles } from "../../types";
2
+ export declare function mergeDocumentTitles(prev: DocumentTitles, incoming: DocumentTitles): DocumentTitles;
3
+ //# sourceMappingURL=mergeDocumentTitles.d.ts.map
@@ -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,7 @@
1
+ import type { ReactNode } from "react";
2
+ interface Props {
3
+ children: ReactNode;
4
+ }
5
+ export declare function CommentsProviderWrapper({ children }: Props): import("react/jsx-runtime").JSX.Element;
6
+ export {};
7
+ //# sourceMappingURL=index.d.ts.map
@@ -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,3 @@
1
+ import type { BaseServiceOptions, Response, Comment } from "../types";
2
+ export declare function deleteComment(id: number | string, options?: BaseServiceOptions): Promise<Response<Comment>>;
3
+ //# sourceMappingURL=deleteComment.d.ts.map
@@ -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