@btst/stack 2.6.2 → 2.8.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 (309) hide show
  1. package/README.md +1 -0
  2. package/dist/api/index.d.cts +2 -2
  3. package/dist/api/index.d.mts +2 -2
  4. package/dist/api/index.d.ts +2 -2
  5. package/dist/client/index.d.cts +2 -2
  6. package/dist/client/index.d.mts +2 -2
  7. package/dist/client/index.d.ts +2 -2
  8. package/dist/components/auto-form/index.d.cts +2 -2
  9. package/dist/components/auto-form/index.d.mts +2 -2
  10. package/dist/components/auto-form/index.d.ts +2 -2
  11. package/dist/components/form-builder/index.d.cts +1 -1
  12. package/dist/components/form-builder/index.d.mts +1 -1
  13. package/dist/components/form-builder/index.d.ts +1 -1
  14. package/dist/components/stepped-auto-form/index.d.cts +1 -1
  15. package/dist/components/stepped-auto-form/index.d.mts +1 -1
  16. package/dist/components/stepped-auto-form/index.d.ts +1 -1
  17. package/dist/index.d.cts +1 -1
  18. package/dist/index.d.mts +1 -1
  19. package/dist/index.d.ts +1 -1
  20. package/dist/packages/stack/src/plugins/blog/client/components/loading/post-navigation-skeleton.cjs +13 -0
  21. package/dist/packages/stack/src/plugins/blog/client/components/loading/post-navigation-skeleton.mjs +11 -0
  22. package/dist/packages/stack/src/plugins/blog/client/components/loading/recent-posts-carousel-skeleton.cjs +17 -0
  23. package/dist/packages/stack/src/plugins/blog/client/components/loading/recent-posts-carousel-skeleton.mjs +15 -0
  24. package/dist/packages/stack/src/plugins/blog/client/components/pages/post-page.internal.cjs +18 -7
  25. package/dist/packages/stack/src/plugins/blog/client/components/pages/post-page.internal.mjs +18 -7
  26. package/dist/packages/stack/src/plugins/blog/client/components/shared/post-navigation.cjs +48 -52
  27. package/dist/packages/stack/src/plugins/blog/client/components/shared/post-navigation.mjs +49 -53
  28. package/dist/packages/stack/src/plugins/blog/client/components/shared/recent-posts-carousel.cjs +34 -37
  29. package/dist/packages/stack/src/plugins/blog/client/components/shared/recent-posts-carousel.mjs +35 -38
  30. package/dist/packages/stack/src/plugins/blog/client/hooks/blog-hooks.cjs +4 -21
  31. package/dist/packages/stack/src/plugins/blog/client/hooks/blog-hooks.mjs +4 -21
  32. package/dist/packages/stack/src/plugins/comments/api/getters.cjs +284 -0
  33. package/dist/packages/stack/src/plugins/comments/api/getters.mjs +280 -0
  34. package/dist/packages/stack/src/plugins/comments/api/mutations.cjs +118 -0
  35. package/dist/packages/stack/src/plugins/comments/api/mutations.mjs +112 -0
  36. package/dist/packages/stack/src/plugins/comments/api/plugin.cjs +335 -0
  37. package/dist/packages/stack/src/plugins/comments/api/plugin.mjs +333 -0
  38. package/dist/packages/stack/src/plugins/comments/api/query-key-defs.cjs +60 -0
  39. package/dist/packages/stack/src/plugins/comments/api/query-key-defs.mjs +55 -0
  40. package/dist/packages/stack/src/plugins/comments/api/serializers.cjs +23 -0
  41. package/dist/packages/stack/src/plugins/comments/api/serializers.mjs +21 -0
  42. package/dist/packages/stack/src/plugins/comments/client/components/comment-count.cjs +46 -0
  43. package/dist/packages/stack/src/plugins/comments/client/components/comment-count.mjs +44 -0
  44. package/dist/packages/stack/src/plugins/comments/client/components/comment-form.cjs +86 -0
  45. package/dist/packages/stack/src/plugins/comments/client/components/comment-form.mjs +84 -0
  46. package/dist/packages/stack/src/plugins/comments/client/components/comment-thread.cjs +540 -0
  47. package/dist/packages/stack/src/plugins/comments/client/components/comment-thread.mjs +538 -0
  48. package/dist/packages/stack/src/plugins/comments/client/components/pages/moderation-page.cjs +64 -0
  49. package/dist/packages/stack/src/plugins/comments/client/components/pages/moderation-page.internal.cjs +426 -0
  50. package/dist/packages/stack/src/plugins/comments/client/components/pages/moderation-page.internal.mjs +424 -0
  51. package/dist/packages/stack/src/plugins/comments/client/components/pages/moderation-page.mjs +62 -0
  52. package/dist/packages/stack/src/plugins/comments/client/components/pages/my-comments-page.cjs +66 -0
  53. package/dist/packages/stack/src/plugins/comments/client/components/pages/my-comments-page.internal.cjs +256 -0
  54. package/dist/packages/stack/src/plugins/comments/client/components/pages/my-comments-page.internal.mjs +254 -0
  55. package/dist/packages/stack/src/plugins/comments/client/components/pages/my-comments-page.mjs +64 -0
  56. package/dist/packages/stack/src/plugins/comments/client/components/pages/resource-comments-page.cjs +86 -0
  57. package/dist/packages/stack/src/plugins/comments/client/components/pages/resource-comments-page.internal.cjs +191 -0
  58. package/dist/packages/stack/src/plugins/comments/client/components/pages/resource-comments-page.internal.mjs +189 -0
  59. package/dist/packages/stack/src/plugins/comments/client/components/pages/resource-comments-page.mjs +84 -0
  60. package/dist/packages/stack/src/plugins/comments/client/components/shared/page-wrapper.cjs +27 -0
  61. package/dist/packages/stack/src/plugins/comments/client/components/shared/page-wrapper.mjs +25 -0
  62. package/dist/packages/stack/src/plugins/comments/client/components/shared/pagination.cjs +37 -0
  63. package/dist/packages/stack/src/plugins/comments/client/components/shared/pagination.mjs +35 -0
  64. package/dist/packages/stack/src/plugins/comments/client/hooks/use-comments.cjs +476 -0
  65. package/dist/packages/stack/src/plugins/comments/client/hooks/use-comments.mjs +464 -0
  66. package/dist/packages/stack/src/plugins/comments/client/localization/comments-moderation.cjs +67 -0
  67. package/dist/packages/stack/src/plugins/comments/client/localization/comments-moderation.mjs +65 -0
  68. package/dist/packages/stack/src/plugins/comments/client/localization/comments-my.cjs +27 -0
  69. package/dist/packages/stack/src/plugins/comments/client/localization/comments-my.mjs +25 -0
  70. package/dist/packages/stack/src/plugins/comments/client/localization/comments-thread.cjs +30 -0
  71. package/dist/packages/stack/src/plugins/comments/client/localization/comments-thread.mjs +28 -0
  72. package/dist/packages/stack/src/plugins/comments/client/localization/index.cjs +13 -0
  73. package/dist/packages/stack/src/plugins/comments/client/localization/index.mjs +11 -0
  74. package/dist/packages/stack/src/plugins/comments/client/plugin.cjs +116 -0
  75. package/dist/packages/stack/src/plugins/comments/client/plugin.mjs +114 -0
  76. package/dist/packages/stack/src/plugins/comments/client/utils.cjs +41 -0
  77. package/dist/packages/stack/src/plugins/comments/client/utils.mjs +37 -0
  78. package/dist/packages/stack/src/plugins/comments/db.cjs +75 -0
  79. package/dist/packages/stack/src/plugins/comments/db.mjs +73 -0
  80. package/dist/packages/stack/src/plugins/comments/schemas.cjs +45 -0
  81. package/dist/packages/stack/src/plugins/comments/schemas.mjs +38 -0
  82. package/dist/packages/stack/src/plugins/kanban/api/plugin.cjs +5 -4
  83. package/dist/packages/stack/src/plugins/kanban/api/plugin.mjs +5 -4
  84. package/dist/packages/stack/src/plugins/kanban/client/components/forms/task-form.cjs +0 -1
  85. package/dist/packages/stack/src/plugins/kanban/client/components/forms/task-form.mjs +0 -1
  86. package/dist/packages/stack/src/plugins/kanban/client/components/pages/board-page.internal.cjs +39 -22
  87. package/dist/packages/stack/src/plugins/kanban/client/components/pages/board-page.internal.mjs +40 -23
  88. package/dist/packages/ui/src/components/avatar.mjs +1 -1
  89. package/dist/packages/ui/src/components/pagination-controls.cjs +64 -0
  90. package/dist/packages/ui/src/components/pagination-controls.mjs +62 -0
  91. package/dist/packages/ui/src/components/when-visible.cjs +39 -0
  92. package/dist/packages/ui/src/components/when-visible.mjs +37 -0
  93. package/dist/plugins/ai-chat/api/index.d.cts +4 -6
  94. package/dist/plugins/ai-chat/api/index.d.mts +4 -6
  95. package/dist/plugins/ai-chat/api/index.d.ts +4 -6
  96. package/dist/plugins/ai-chat/client/hooks/index.d.cts +1 -3
  97. package/dist/plugins/ai-chat/client/hooks/index.d.mts +1 -3
  98. package/dist/plugins/ai-chat/client/hooks/index.d.ts +1 -3
  99. package/dist/plugins/ai-chat/query-keys.d.cts +1 -3
  100. package/dist/plugins/ai-chat/query-keys.d.mts +1 -3
  101. package/dist/plugins/ai-chat/query-keys.d.ts +1 -3
  102. package/dist/plugins/api/index.d.cts +3 -3
  103. package/dist/plugins/api/index.d.mts +3 -3
  104. package/dist/plugins/api/index.d.ts +3 -3
  105. package/dist/plugins/blog/api/index.d.cts +3 -3
  106. package/dist/plugins/blog/api/index.d.mts +3 -3
  107. package/dist/plugins/blog/api/index.d.ts +3 -3
  108. package/dist/plugins/blog/client/hooks/index.d.cts +2 -2
  109. package/dist/plugins/blog/client/hooks/index.d.mts +2 -2
  110. package/dist/plugins/blog/client/hooks/index.d.ts +2 -2
  111. package/dist/plugins/blog/client/index.d.cts +25 -3
  112. package/dist/plugins/blog/client/index.d.mts +25 -3
  113. package/dist/plugins/blog/client/index.d.ts +25 -3
  114. package/dist/plugins/blog/query-keys.d.cts +3 -3
  115. package/dist/plugins/blog/query-keys.d.mts +3 -3
  116. package/dist/plugins/blog/query-keys.d.ts +3 -3
  117. package/dist/plugins/client/index.d.cts +2 -2
  118. package/dist/plugins/client/index.d.mts +2 -2
  119. package/dist/plugins/client/index.d.ts +2 -2
  120. package/dist/plugins/cms/api/index.d.cts +1 -1
  121. package/dist/plugins/cms/api/index.d.mts +1 -1
  122. package/dist/plugins/cms/api/index.d.ts +1 -1
  123. package/dist/plugins/cms/client/index.d.cts +1 -1
  124. package/dist/plugins/cms/client/index.d.mts +1 -1
  125. package/dist/plugins/cms/client/index.d.ts +1 -1
  126. package/dist/plugins/cms/query-keys.d.cts +1 -1
  127. package/dist/plugins/cms/query-keys.d.mts +1 -1
  128. package/dist/plugins/cms/query-keys.d.ts +1 -1
  129. package/dist/plugins/comments/api/index.cjs +21 -0
  130. package/dist/plugins/comments/api/index.d.cts +126 -0
  131. package/dist/plugins/comments/api/index.d.mts +126 -0
  132. package/dist/plugins/comments/api/index.d.ts +126 -0
  133. package/dist/plugins/comments/api/index.mjs +5 -0
  134. package/dist/plugins/comments/client/components/index.cjs +15 -0
  135. package/dist/plugins/comments/client/components/index.d.cts +125 -0
  136. package/dist/plugins/comments/client/components/index.d.mts +125 -0
  137. package/dist/plugins/comments/client/components/index.d.ts +125 -0
  138. package/dist/plugins/comments/client/components/index.mjs +5 -0
  139. package/dist/plugins/comments/client/hooks/index.cjs +17 -0
  140. package/dist/plugins/comments/client/hooks/index.d.cts +200 -0
  141. package/dist/plugins/comments/client/hooks/index.d.mts +200 -0
  142. package/dist/plugins/comments/client/hooks/index.d.ts +200 -0
  143. package/dist/plugins/comments/client/hooks/index.mjs +1 -0
  144. package/dist/plugins/comments/client/index.cjs +9 -0
  145. package/dist/plugins/comments/client/index.d.cts +262 -0
  146. package/dist/plugins/comments/client/index.d.mts +262 -0
  147. package/dist/plugins/comments/client/index.d.ts +262 -0
  148. package/dist/plugins/comments/client/index.mjs +2 -0
  149. package/dist/plugins/comments/client.css +2 -0
  150. package/dist/plugins/comments/query-keys.cjs +113 -0
  151. package/dist/plugins/comments/query-keys.d.cts +71 -0
  152. package/dist/plugins/comments/query-keys.d.mts +71 -0
  153. package/dist/plugins/comments/query-keys.d.ts +71 -0
  154. package/dist/plugins/comments/query-keys.mjs +111 -0
  155. package/dist/plugins/comments/style.css +15 -0
  156. package/dist/plugins/form-builder/api/index.d.cts +2 -2
  157. package/dist/plugins/form-builder/api/index.d.mts +2 -2
  158. package/dist/plugins/form-builder/api/index.d.ts +2 -2
  159. package/dist/plugins/form-builder/client/components/index.d.cts +1 -1
  160. package/dist/plugins/form-builder/client/components/index.d.mts +1 -1
  161. package/dist/plugins/form-builder/client/components/index.d.ts +1 -1
  162. package/dist/plugins/form-builder/client/index.d.cts +1 -1
  163. package/dist/plugins/form-builder/client/index.d.mts +1 -1
  164. package/dist/plugins/form-builder/client/index.d.ts +1 -1
  165. package/dist/plugins/form-builder/query-keys.d.cts +1 -1
  166. package/dist/plugins/form-builder/query-keys.d.mts +1 -1
  167. package/dist/plugins/form-builder/query-keys.d.ts +1 -1
  168. package/dist/plugins/kanban/api/index.d.cts +2 -2
  169. package/dist/plugins/kanban/api/index.d.mts +2 -2
  170. package/dist/plugins/kanban/api/index.d.ts +2 -2
  171. package/dist/plugins/kanban/client/hooks/index.d.cts +1 -1
  172. package/dist/plugins/kanban/client/hooks/index.d.mts +1 -1
  173. package/dist/plugins/kanban/client/hooks/index.d.ts +1 -1
  174. package/dist/plugins/kanban/client/index.d.cts +1 -1
  175. package/dist/plugins/kanban/client/index.d.mts +1 -1
  176. package/dist/plugins/kanban/client/index.d.ts +1 -1
  177. package/dist/plugins/kanban/query-keys.d.cts +2 -2
  178. package/dist/plugins/kanban/query-keys.d.mts +2 -2
  179. package/dist/plugins/kanban/query-keys.d.ts +2 -2
  180. package/dist/plugins/open-api/api/index.d.cts +3 -3
  181. package/dist/plugins/open-api/api/index.d.mts +3 -3
  182. package/dist/plugins/open-api/api/index.d.ts +3 -3
  183. package/dist/plugins/route-docs/client/index.d.cts +1 -1
  184. package/dist/plugins/route-docs/client/index.d.mts +1 -1
  185. package/dist/plugins/route-docs/client/index.d.ts +1 -1
  186. package/dist/plugins/ui-builder/client/components/index.d.cts +2 -2
  187. package/dist/plugins/ui-builder/client/components/index.d.mts +2 -2
  188. package/dist/plugins/ui-builder/client/components/index.d.ts +2 -2
  189. package/dist/plugins/ui-builder/client/hooks/index.d.cts +3 -3
  190. package/dist/plugins/ui-builder/client/hooks/index.d.mts +3 -3
  191. package/dist/plugins/ui-builder/client/hooks/index.d.ts +3 -3
  192. package/dist/plugins/ui-builder/client/index.d.cts +3 -3
  193. package/dist/plugins/ui-builder/client/index.d.mts +3 -3
  194. package/dist/plugins/ui-builder/client/index.d.ts +3 -3
  195. package/dist/plugins/ui-builder/index.d.cts +3 -3
  196. package/dist/plugins/ui-builder/index.d.mts +3 -3
  197. package/dist/plugins/ui-builder/index.d.ts +3 -3
  198. package/dist/shared/{stack.B1srlBud.d.mts → stack.BFoBvGML.d.mts} +1 -1
  199. package/dist/shared/{stack.DmpPDPxA.d.cts → stack.BOCvd9HK.d.cts} +1 -1
  200. package/dist/shared/{stack.n1_i1p2B.d.cts → stack.BOokfhZD.d.cts} +170 -110
  201. package/dist/shared/{stack.DXnclTG7.d.ts → stack.BSqJrCTM.d.cts} +120 -59
  202. package/dist/shared/{stack.B58oHdqm.d.mts → stack.BX7MHi0J.d.mts} +90 -45
  203. package/dist/shared/{stack.cfCkioTe.d.mts → stack.BXxrFL9R.d.ts} +120 -59
  204. package/dist/shared/{stack.CSx98K5H.d.cts → stack.BYN8wCV6.d.cts} +87 -58
  205. package/dist/shared/{stack.FVWf2JhZ.d.mts → stack.BgQrdSlo.d.mts} +60 -45
  206. package/dist/shared/{stack.BK9Z2dcL.d.ts → stack.BmMB0LNC.d.ts} +1 -1
  207. package/dist/shared/{stack.j75TpKh2.d.ts → stack.BvCR4-9H.d.ts} +170 -110
  208. package/dist/shared/{stack.FeaWkglm.d.ts → stack.BxFl46lB.d.cts} +24 -1
  209. package/dist/shared/stack.C-b3Sn8j.d.cts +142 -0
  210. package/dist/shared/stack.C-b3Sn8j.d.mts +142 -0
  211. package/dist/shared/stack.C-b3Sn8j.d.ts +142 -0
  212. package/dist/shared/{stack.CFECM0ew.d.cts → stack.C1nXGBr6.d.cts} +1 -1
  213. package/dist/shared/{stack.C9Mg2Q46.d.cts → stack.C9zoS1TN.d.cts} +90 -45
  214. package/dist/shared/stack.CJE9sAjV.d.ts +335 -0
  215. package/dist/shared/{stack.fdi94T4S.d.mts → stack.CPsYC2-Z.d.cts} +7 -7
  216. package/dist/shared/{stack.fdi94T4S.d.ts → stack.CPsYC2-Z.d.mts} +7 -7
  217. package/dist/shared/{stack.fdi94T4S.d.cts → stack.CPsYC2-Z.d.ts} +7 -7
  218. package/dist/shared/{stack.7n9Y_u7N.d.cts → stack.CQnwAN7x.d.cts} +6 -6
  219. package/dist/shared/{stack.7n9Y_u7N.d.mts → stack.CQnwAN7x.d.mts} +6 -6
  220. package/dist/shared/{stack.7n9Y_u7N.d.ts → stack.CQnwAN7x.d.ts} +6 -6
  221. package/dist/shared/{stack.CxaFNQCV.d.mts → stack.CWxAl9K3.d.mts} +170 -110
  222. package/dist/shared/{stack.D-b5zbPm.d.cts → stack.Cbsrl06u.d.cts} +60 -45
  223. package/dist/shared/stack.CmHRdhl8.d.cts +335 -0
  224. package/dist/shared/{stack.BgTmujxW.d.mts → stack.D88yU4FT.d.mts} +87 -58
  225. package/dist/shared/{stack.DVtk5CNw.d.mts → stack.DLPa6Gzm.d.mts} +1 -1
  226. package/dist/shared/{stack.BAT540yW.d.ts → stack.DOZ1EXjM.d.mts} +9 -15
  227. package/dist/shared/{stack.FeaWkglm.d.mts → stack.DRpeDS6X.d.ts} +24 -1
  228. package/dist/shared/{stack.B8vT-Yt4.d.mts → stack.DX-tQ93o.d.cts} +9 -15
  229. package/dist/shared/stack.Dcz6636A.d.mts +335 -0
  230. package/dist/shared/{stack.ASwEoINr.d.ts → stack.DxJ-tHLt.d.ts} +1 -1
  231. package/dist/shared/{stack.DaZM10cp.d.cts → stack.DzOhpIYM.d.mts} +120 -59
  232. package/dist/shared/{stack.CTDVxbrA.d.ts → stack.Fl2Kl_bt.d.ts} +60 -45
  233. package/dist/shared/{stack.FeaWkglm.d.cts → stack.Jb0kQDJC.d.mts} +24 -1
  234. package/dist/shared/stack.Ldfkr5b2.d.cts +112 -0
  235. package/dist/shared/stack.Ldfkr5b2.d.mts +112 -0
  236. package/dist/shared/stack.Ldfkr5b2.d.ts +112 -0
  237. package/dist/shared/{stack.CLQuVdwK.d.ts → stack.RuQ9JCLo.d.ts} +87 -58
  238. package/dist/shared/{stack.BwA7trxA.d.cts → stack.VF6FhyZw.d.ts} +9 -15
  239. package/dist/shared/{stack.sO33ZDhK.d.ts → stack.fQjVhw5a.d.ts} +90 -45
  240. package/package.json +70 -5
  241. package/src/__tests__/plugins.test.tsx +5 -1
  242. package/src/__tests__/stack-api.test.ts +1 -1
  243. package/src/plugins/ai-chat/__tests__/getters.test.ts +1 -1
  244. package/src/plugins/ai-chat/api/getters.ts +1 -1
  245. package/src/plugins/ai-chat/api/plugin.ts +1 -1
  246. package/src/plugins/api/index.ts +5 -1
  247. package/src/plugins/blog/__tests__/getters.test.ts +1 -1
  248. package/src/plugins/blog/api/getters.ts +1 -1
  249. package/src/plugins/blog/api/plugin.ts +1 -1
  250. package/src/plugins/blog/client/components/loading/post-navigation-skeleton.tsx +10 -0
  251. package/src/plugins/blog/client/components/loading/recent-posts-carousel-skeleton.tsx +18 -0
  252. package/src/plugins/blog/client/components/pages/post-page.internal.tsx +23 -8
  253. package/src/plugins/blog/client/components/shared/post-navigation.tsx +0 -5
  254. package/src/plugins/blog/client/components/shared/recent-posts-carousel.tsx +1 -5
  255. package/src/plugins/blog/client/hooks/blog-hooks.tsx +8 -33
  256. package/src/plugins/blog/client/overrides.ts +26 -1
  257. package/src/plugins/cms/__tests__/getters.test.ts +1 -1
  258. package/src/plugins/cms/api/getters.ts +1 -1
  259. package/src/plugins/cms/api/mutations.ts +1 -1
  260. package/src/plugins/cms/api/plugin.ts +1 -1
  261. package/src/plugins/cms/client/components/shared/pagination.tsx +14 -42
  262. package/src/plugins/comments/api/getters.ts +444 -0
  263. package/src/plugins/comments/api/index.ts +21 -0
  264. package/src/plugins/comments/api/mutations.ts +206 -0
  265. package/src/plugins/comments/api/plugin.ts +628 -0
  266. package/src/plugins/comments/api/query-key-defs.ts +143 -0
  267. package/src/plugins/comments/api/serializers.ts +37 -0
  268. package/src/plugins/comments/client/components/comment-count.tsx +66 -0
  269. package/src/plugins/comments/client/components/comment-form.tsx +112 -0
  270. package/src/plugins/comments/client/components/comment-thread.tsx +799 -0
  271. package/src/plugins/comments/client/components/index.tsx +11 -0
  272. package/src/plugins/comments/client/components/pages/moderation-page.internal.tsx +550 -0
  273. package/src/plugins/comments/client/components/pages/moderation-page.tsx +70 -0
  274. package/src/plugins/comments/client/components/pages/my-comments-page.internal.tsx +367 -0
  275. package/src/plugins/comments/client/components/pages/my-comments-page.tsx +72 -0
  276. package/src/plugins/comments/client/components/pages/resource-comments-page.internal.tsx +225 -0
  277. package/src/plugins/comments/client/components/pages/resource-comments-page.tsx +97 -0
  278. package/src/plugins/comments/client/components/shared/page-wrapper.tsx +32 -0
  279. package/src/plugins/comments/client/components/shared/pagination.tsx +44 -0
  280. package/src/plugins/comments/client/hooks/index.tsx +13 -0
  281. package/src/plugins/comments/client/hooks/use-comments.tsx +717 -0
  282. package/src/plugins/comments/client/index.ts +14 -0
  283. package/src/plugins/comments/client/localization/comments-moderation.ts +75 -0
  284. package/src/plugins/comments/client/localization/comments-my.ts +32 -0
  285. package/src/plugins/comments/client/localization/comments-thread.ts +32 -0
  286. package/src/plugins/comments/client/localization/index.ts +11 -0
  287. package/src/plugins/comments/client/overrides.ts +164 -0
  288. package/src/plugins/comments/client/plugin.tsx +195 -0
  289. package/src/plugins/comments/client/utils.ts +67 -0
  290. package/src/plugins/comments/client.css +2 -0
  291. package/src/plugins/comments/db.ts +77 -0
  292. package/src/plugins/comments/query-keys.ts +189 -0
  293. package/src/plugins/comments/schemas.ts +72 -0
  294. package/src/plugins/comments/style.css +15 -0
  295. package/src/plugins/comments/types.ts +73 -0
  296. package/src/plugins/form-builder/__tests__/getters.test.ts +1 -1
  297. package/src/plugins/form-builder/api/getters.ts +1 -1
  298. package/src/plugins/form-builder/api/plugin.ts +1 -1
  299. package/src/plugins/kanban/__tests__/getters.test.ts +1 -1
  300. package/src/plugins/kanban/api/getters.ts +1 -1
  301. package/src/plugins/kanban/api/mutations.ts +1 -1
  302. package/src/plugins/kanban/api/plugin.ts +6 -5
  303. package/src/plugins/kanban/client/components/forms/task-form.tsx +0 -1
  304. package/src/plugins/kanban/client/components/pages/board-page.internal.tsx +46 -27
  305. package/src/plugins/kanban/client/overrides.ts +27 -1
  306. package/src/types.ts +5 -1
  307. package/dist/shared/{stack.BQmuNl5p.d.mts → stack.BWp0hcm9.d.cts} +3 -3
  308. package/dist/shared/{stack.BQmuNl5p.d.ts → stack.BWp0hcm9.d.mts} +3 -3
  309. package/dist/shared/{stack.BQmuNl5p.d.cts → stack.BWp0hcm9.d.ts} +3 -3
@@ -0,0 +1,280 @@
1
+ async function resolveAuthors(authorIds, resolveUser) {
2
+ const unique = [...new Set(authorIds)];
3
+ const map = /* @__PURE__ */ new Map();
4
+ if (!resolveUser || unique.length === 0) {
5
+ for (const id of unique) {
6
+ map.set(id, { name: "[deleted]", avatarUrl: null });
7
+ }
8
+ return map;
9
+ }
10
+ await Promise.all(
11
+ unique.map(async (id) => {
12
+ try {
13
+ const result = await resolveUser(id);
14
+ map.set(id, {
15
+ name: result?.name ?? "[deleted]",
16
+ avatarUrl: result?.avatarUrl ?? null
17
+ });
18
+ } catch {
19
+ map.set(id, { name: "[deleted]", avatarUrl: null });
20
+ }
21
+ })
22
+ );
23
+ return map;
24
+ }
25
+ function enrichComment(comment, authorMap, likedCommentIds, replyCount = 0) {
26
+ const author = authorMap.get(comment.authorId) ?? {
27
+ name: "[deleted]",
28
+ avatarUrl: null
29
+ };
30
+ return {
31
+ id: comment.id,
32
+ resourceId: comment.resourceId,
33
+ resourceType: comment.resourceType,
34
+ parentId: comment.parentId ?? null,
35
+ authorId: comment.authorId,
36
+ resolvedAuthorName: author.name,
37
+ resolvedAvatarUrl: author.avatarUrl,
38
+ body: comment.body,
39
+ status: comment.status,
40
+ likes: comment.likes,
41
+ isLikedByCurrentUser: likedCommentIds.has(comment.id),
42
+ editedAt: comment.editedAt?.toISOString() ?? null,
43
+ createdAt: comment.createdAt.toISOString(),
44
+ updatedAt: comment.updatedAt.toISOString(),
45
+ replyCount
46
+ };
47
+ }
48
+ function buildBaseConditions(params) {
49
+ const conditions = [];
50
+ if (params.resourceId) {
51
+ conditions.push({
52
+ field: "resourceId",
53
+ value: params.resourceId,
54
+ operator: "eq"
55
+ });
56
+ }
57
+ if (params.resourceType) {
58
+ conditions.push({
59
+ field: "resourceType",
60
+ value: params.resourceType,
61
+ operator: "eq"
62
+ });
63
+ }
64
+ if (params.parentId !== void 0) {
65
+ const parentValue = params.parentId === null || params.parentId === "null" ? null : params.parentId;
66
+ conditions.push({ field: "parentId", value: parentValue, operator: "eq" });
67
+ }
68
+ if (params.authorId) {
69
+ conditions.push({
70
+ field: "authorId",
71
+ value: params.authorId,
72
+ operator: "eq"
73
+ });
74
+ }
75
+ return conditions;
76
+ }
77
+ async function listComments(adapter, params, resolveUser) {
78
+ const limit = params.limit ?? 20;
79
+ const offset = params.offset ?? 0;
80
+ const sortDirection = params.sort ?? "asc";
81
+ const omitStatusFilter = !!params.authorId && !params.status;
82
+ const statusFilter = omitStatusFilter ? null : params.status ?? "approved";
83
+ const baseConditions = buildBaseConditions(params);
84
+ let comments;
85
+ let total;
86
+ if (!omitStatusFilter && statusFilter === "approved" && params.currentUserId) {
87
+ const [ownPendingAll, approvedCount] = await Promise.all([
88
+ adapter.findMany({
89
+ model: "comment",
90
+ where: [
91
+ ...baseConditions,
92
+ { field: "status", value: "pending", operator: "eq" },
93
+ { field: "authorId", value: params.currentUserId, operator: "eq" }
94
+ ],
95
+ sortBy: { field: "createdAt", direction: sortDirection }
96
+ }),
97
+ adapter.count({
98
+ model: "comment",
99
+ where: [
100
+ ...baseConditions,
101
+ { field: "status", value: "approved", operator: "eq" }
102
+ ]
103
+ })
104
+ ]);
105
+ total = approvedCount + ownPendingAll.length;
106
+ if (ownPendingAll.length === 0) {
107
+ comments = await adapter.findMany({
108
+ model: "comment",
109
+ limit,
110
+ offset,
111
+ where: [
112
+ ...baseConditions,
113
+ { field: "status", value: "approved", operator: "eq" }
114
+ ],
115
+ sortBy: { field: "createdAt", direction: sortDirection }
116
+ });
117
+ } else {
118
+ const dateOp = sortDirection === "asc" ? "lt" : "gt";
119
+ const pendingWithPositions = await Promise.all(
120
+ ownPendingAll.map(async (p, i) => {
121
+ const approvedBefore = await adapter.count({
122
+ model: "comment",
123
+ where: [
124
+ ...baseConditions,
125
+ { field: "status", value: "approved", operator: "eq" },
126
+ {
127
+ field: "createdAt",
128
+ value: p.createdAt,
129
+ operator: dateOp
130
+ }
131
+ ]
132
+ });
133
+ return { comment: p, mergedPosition: approvedBefore + i };
134
+ })
135
+ );
136
+ const pendingInWindow = pendingWithPositions.filter(
137
+ ({ mergedPosition }) => mergedPosition >= offset && mergedPosition < offset + limit
138
+ );
139
+ const countPendingBeforeWindow = pendingWithPositions.filter(
140
+ ({ mergedPosition }) => mergedPosition < offset
141
+ ).length;
142
+ const approvedOffset = Math.max(0, offset - countPendingBeforeWindow);
143
+ const approvedLimit = limit - pendingInWindow.length;
144
+ const approvedPage = approvedLimit > 0 ? await adapter.findMany({
145
+ model: "comment",
146
+ limit: approvedLimit,
147
+ offset: approvedOffset,
148
+ where: [
149
+ ...baseConditions,
150
+ { field: "status", value: "approved", operator: "eq" }
151
+ ],
152
+ sortBy: { field: "createdAt", direction: sortDirection }
153
+ }) : [];
154
+ const merged = [
155
+ ...approvedPage,
156
+ ...pendingInWindow.map(({ comment }) => comment)
157
+ ];
158
+ merged.sort((a, b) => {
159
+ const diff = a.createdAt.getTime() - b.createdAt.getTime();
160
+ return sortDirection === "desc" ? -diff : diff;
161
+ });
162
+ comments = merged;
163
+ }
164
+ } else {
165
+ const where = [...baseConditions];
166
+ if (statusFilter !== null) {
167
+ where.push({
168
+ field: "status",
169
+ value: statusFilter,
170
+ operator: "eq"
171
+ });
172
+ }
173
+ const [found, count] = await Promise.all([
174
+ adapter.findMany({
175
+ model: "comment",
176
+ limit,
177
+ offset,
178
+ where,
179
+ sortBy: { field: "createdAt", direction: sortDirection }
180
+ }),
181
+ adapter.count({ model: "comment", where })
182
+ ]);
183
+ comments = found;
184
+ total = count;
185
+ }
186
+ const authorIds = comments.map((c) => c.authorId);
187
+ const authorMap = await resolveAuthors(authorIds, resolveUser);
188
+ const likedCommentIds = /* @__PURE__ */ new Set();
189
+ if (params.currentUserId && comments.length > 0) {
190
+ const commentIds = comments.map((c) => c.id);
191
+ const likes = await Promise.all(
192
+ commentIds.map(
193
+ (commentId) => adapter.findOne({
194
+ model: "commentLike",
195
+ where: [
196
+ { field: "commentId", value: commentId, operator: "eq" },
197
+ {
198
+ field: "authorId",
199
+ value: params.currentUserId,
200
+ operator: "eq"
201
+ }
202
+ ]
203
+ })
204
+ )
205
+ );
206
+ likes.forEach((like, i) => {
207
+ if (like) likedCommentIds.add(commentIds[i]);
208
+ });
209
+ }
210
+ const replyCounts = /* @__PURE__ */ new Map();
211
+ const isTopLevelQuery = params.parentId === null || params.parentId === "null";
212
+ if (isTopLevelQuery && comments.length > 0) {
213
+ await Promise.all(
214
+ comments.map(async (c) => {
215
+ const approvedCount = await adapter.count({
216
+ model: "comment",
217
+ where: [
218
+ { field: "parentId", value: c.id, operator: "eq" },
219
+ { field: "status", value: "approved", operator: "eq" }
220
+ ]
221
+ });
222
+ let ownPendingCount = 0;
223
+ if (params.currentUserId) {
224
+ ownPendingCount = await adapter.count({
225
+ model: "comment",
226
+ where: [
227
+ { field: "parentId", value: c.id, operator: "eq" },
228
+ { field: "status", value: "pending", operator: "eq" },
229
+ {
230
+ field: "authorId",
231
+ value: params.currentUserId,
232
+ operator: "eq"
233
+ }
234
+ ]
235
+ });
236
+ }
237
+ replyCounts.set(c.id, approvedCount + ownPendingCount);
238
+ })
239
+ );
240
+ }
241
+ const items = comments.map(
242
+ (c) => enrichComment(c, authorMap, likedCommentIds, replyCounts.get(c.id) ?? 0)
243
+ );
244
+ return { items, total, limit, offset };
245
+ }
246
+ async function getCommentById(adapter, id, resolveUser, currentUserId) {
247
+ const comment = await adapter.findOne({
248
+ model: "comment",
249
+ where: [{ field: "id", value: id, operator: "eq" }]
250
+ });
251
+ if (!comment) return null;
252
+ const authorMap = await resolveAuthors([comment.authorId], resolveUser);
253
+ const likedCommentIds = /* @__PURE__ */ new Set();
254
+ if (currentUserId) {
255
+ const like = await adapter.findOne({
256
+ model: "commentLike",
257
+ where: [
258
+ { field: "commentId", value: id, operator: "eq" },
259
+ { field: "authorId", value: currentUserId, operator: "eq" }
260
+ ]
261
+ });
262
+ if (like) likedCommentIds.add(id);
263
+ }
264
+ return enrichComment(comment, authorMap, likedCommentIds);
265
+ }
266
+ async function getCommentCount(adapter, params) {
267
+ const whereConditions = [
268
+ { field: "resourceId", value: params.resourceId, operator: "eq" },
269
+ { field: "resourceType", value: params.resourceType, operator: "eq" }
270
+ ];
271
+ const statusFilter = params.status ?? "approved";
272
+ whereConditions.push({
273
+ field: "status",
274
+ value: statusFilter,
275
+ operator: "eq"
276
+ });
277
+ return adapter.count({ model: "comment", where: whereConditions });
278
+ }
279
+
280
+ export { getCommentById, getCommentCount, listComments };
@@ -0,0 +1,118 @@
1
+ 'use strict';
2
+
3
+ async function createComment(adapter, input) {
4
+ return adapter.create({
5
+ model: "comment",
6
+ data: {
7
+ resourceId: input.resourceId,
8
+ resourceType: input.resourceType,
9
+ parentId: input.parentId ?? null,
10
+ authorId: input.authorId,
11
+ body: input.body,
12
+ status: input.status ?? "pending",
13
+ likes: 0,
14
+ createdAt: /* @__PURE__ */ new Date(),
15
+ updatedAt: /* @__PURE__ */ new Date()
16
+ }
17
+ });
18
+ }
19
+ async function updateComment(adapter, id, body) {
20
+ const existing = await adapter.findOne({
21
+ model: "comment",
22
+ where: [{ field: "id", value: id, operator: "eq" }]
23
+ });
24
+ if (!existing) return null;
25
+ return adapter.update({
26
+ model: "comment",
27
+ where: [{ field: "id", value: id, operator: "eq" }],
28
+ update: {
29
+ body,
30
+ editedAt: /* @__PURE__ */ new Date(),
31
+ updatedAt: /* @__PURE__ */ new Date()
32
+ }
33
+ });
34
+ }
35
+ async function updateCommentStatus(adapter, id, status) {
36
+ const existing = await adapter.findOne({
37
+ model: "comment",
38
+ where: [{ field: "id", value: id, operator: "eq" }]
39
+ });
40
+ if (!existing) return null;
41
+ return adapter.update({
42
+ model: "comment",
43
+ where: [{ field: "id", value: id, operator: "eq" }],
44
+ update: { status, updatedAt: /* @__PURE__ */ new Date() }
45
+ });
46
+ }
47
+ async function deleteComment(adapter, id) {
48
+ const existing = await adapter.findOne({
49
+ model: "comment",
50
+ where: [{ field: "id", value: id, operator: "eq" }]
51
+ });
52
+ if (!existing) return false;
53
+ await adapter.transaction(async (tx) => {
54
+ await tx.delete({
55
+ model: "comment",
56
+ where: [{ field: "parentId", value: id, operator: "eq" }]
57
+ });
58
+ await tx.delete({
59
+ model: "comment",
60
+ where: [{ field: "id", value: id, operator: "eq" }]
61
+ });
62
+ });
63
+ return true;
64
+ }
65
+ async function toggleCommentLike(adapter, commentId, authorId) {
66
+ return adapter.transaction(async (tx) => {
67
+ const comment = await tx.findOne({
68
+ model: "comment",
69
+ where: [{ field: "id", value: commentId, operator: "eq" }]
70
+ });
71
+ if (!comment) {
72
+ throw new Error("Comment not found");
73
+ }
74
+ const existingLike = await tx.findOne({
75
+ model: "commentLike",
76
+ where: [
77
+ { field: "commentId", value: commentId, operator: "eq" },
78
+ { field: "authorId", value: authorId, operator: "eq" }
79
+ ]
80
+ });
81
+ let newLikes;
82
+ let isLiked;
83
+ if (existingLike) {
84
+ await tx.delete({
85
+ model: "commentLike",
86
+ where: [
87
+ { field: "commentId", value: commentId, operator: "eq" },
88
+ { field: "authorId", value: authorId, operator: "eq" }
89
+ ]
90
+ });
91
+ newLikes = Math.max(0, comment.likes - 1);
92
+ isLiked = false;
93
+ } else {
94
+ await tx.create({
95
+ model: "commentLike",
96
+ data: {
97
+ commentId,
98
+ authorId,
99
+ createdAt: /* @__PURE__ */ new Date()
100
+ }
101
+ });
102
+ newLikes = comment.likes + 1;
103
+ isLiked = true;
104
+ }
105
+ await tx.update({
106
+ model: "comment",
107
+ where: [{ field: "id", value: commentId, operator: "eq" }],
108
+ update: { likes: newLikes, updatedAt: /* @__PURE__ */ new Date() }
109
+ });
110
+ return { likes: newLikes, isLiked };
111
+ });
112
+ }
113
+
114
+ exports.createComment = createComment;
115
+ exports.deleteComment = deleteComment;
116
+ exports.toggleCommentLike = toggleCommentLike;
117
+ exports.updateComment = updateComment;
118
+ exports.updateCommentStatus = updateCommentStatus;
@@ -0,0 +1,112 @@
1
+ async function createComment(adapter, input) {
2
+ return adapter.create({
3
+ model: "comment",
4
+ data: {
5
+ resourceId: input.resourceId,
6
+ resourceType: input.resourceType,
7
+ parentId: input.parentId ?? null,
8
+ authorId: input.authorId,
9
+ body: input.body,
10
+ status: input.status ?? "pending",
11
+ likes: 0,
12
+ createdAt: /* @__PURE__ */ new Date(),
13
+ updatedAt: /* @__PURE__ */ new Date()
14
+ }
15
+ });
16
+ }
17
+ async function updateComment(adapter, id, body) {
18
+ const existing = await adapter.findOne({
19
+ model: "comment",
20
+ where: [{ field: "id", value: id, operator: "eq" }]
21
+ });
22
+ if (!existing) return null;
23
+ return adapter.update({
24
+ model: "comment",
25
+ where: [{ field: "id", value: id, operator: "eq" }],
26
+ update: {
27
+ body,
28
+ editedAt: /* @__PURE__ */ new Date(),
29
+ updatedAt: /* @__PURE__ */ new Date()
30
+ }
31
+ });
32
+ }
33
+ async function updateCommentStatus(adapter, id, status) {
34
+ const existing = await adapter.findOne({
35
+ model: "comment",
36
+ where: [{ field: "id", value: id, operator: "eq" }]
37
+ });
38
+ if (!existing) return null;
39
+ return adapter.update({
40
+ model: "comment",
41
+ where: [{ field: "id", value: id, operator: "eq" }],
42
+ update: { status, updatedAt: /* @__PURE__ */ new Date() }
43
+ });
44
+ }
45
+ async function deleteComment(adapter, id) {
46
+ const existing = await adapter.findOne({
47
+ model: "comment",
48
+ where: [{ field: "id", value: id, operator: "eq" }]
49
+ });
50
+ if (!existing) return false;
51
+ await adapter.transaction(async (tx) => {
52
+ await tx.delete({
53
+ model: "comment",
54
+ where: [{ field: "parentId", value: id, operator: "eq" }]
55
+ });
56
+ await tx.delete({
57
+ model: "comment",
58
+ where: [{ field: "id", value: id, operator: "eq" }]
59
+ });
60
+ });
61
+ return true;
62
+ }
63
+ async function toggleCommentLike(adapter, commentId, authorId) {
64
+ return adapter.transaction(async (tx) => {
65
+ const comment = await tx.findOne({
66
+ model: "comment",
67
+ where: [{ field: "id", value: commentId, operator: "eq" }]
68
+ });
69
+ if (!comment) {
70
+ throw new Error("Comment not found");
71
+ }
72
+ const existingLike = await tx.findOne({
73
+ model: "commentLike",
74
+ where: [
75
+ { field: "commentId", value: commentId, operator: "eq" },
76
+ { field: "authorId", value: authorId, operator: "eq" }
77
+ ]
78
+ });
79
+ let newLikes;
80
+ let isLiked;
81
+ if (existingLike) {
82
+ await tx.delete({
83
+ model: "commentLike",
84
+ where: [
85
+ { field: "commentId", value: commentId, operator: "eq" },
86
+ { field: "authorId", value: authorId, operator: "eq" }
87
+ ]
88
+ });
89
+ newLikes = Math.max(0, comment.likes - 1);
90
+ isLiked = false;
91
+ } else {
92
+ await tx.create({
93
+ model: "commentLike",
94
+ data: {
95
+ commentId,
96
+ authorId,
97
+ createdAt: /* @__PURE__ */ new Date()
98
+ }
99
+ });
100
+ newLikes = comment.likes + 1;
101
+ isLiked = true;
102
+ }
103
+ await tx.update({
104
+ model: "comment",
105
+ where: [{ field: "id", value: commentId, operator: "eq" }],
106
+ update: { likes: newLikes, updatedAt: /* @__PURE__ */ new Date() }
107
+ });
108
+ return { likes: newLikes, isLiked };
109
+ });
110
+ }
111
+
112
+ export { createComment, deleteComment, toggleCommentLike, updateComment, updateCommentStatus };