convex-cms 0.0.5-alpha.0 → 0.0.5-alpha.2

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 (323) hide show
  1. package/README.md +95 -144
  2. package/admin/README.md +99 -0
  3. package/admin/src/components/AdminLayout.tsx +22 -0
  4. package/admin/src/components/BreakingChangesWarningDialog.tsx +81 -0
  5. package/admin/src/components/BulkActionBar.tsx +190 -0
  6. package/admin/src/components/BulkOperationModal.tsx +177 -0
  7. package/admin/src/components/ContentEntryEditor.tsx +1104 -0
  8. package/admin/src/components/ContentTypeFormModal.tsx +1012 -0
  9. package/admin/src/components/ErrorBoundary.tsx +83 -0
  10. package/admin/src/components/ErrorState.tsx +147 -0
  11. package/admin/src/components/Header.tsx +294 -0
  12. package/admin/src/components/RouteGuard.tsx +264 -0
  13. package/admin/src/components/Sidebar.tsx +90 -0
  14. package/admin/src/components/TaxonomyEditor.tsx +348 -0
  15. package/admin/src/components/TermTree.tsx +533 -0
  16. package/admin/src/components/UploadDropzone.tsx +383 -0
  17. package/admin/src/components/VersionCompare.tsx +250 -0
  18. package/admin/src/components/VersionHistory.tsx +279 -0
  19. package/admin/src/components/VersionRollbackModal.tsx +79 -0
  20. package/admin/src/components/cmsds/CmsButton.tsx +101 -0
  21. package/admin/src/components/cmsds/CmsDialog.tsx +139 -0
  22. package/admin/src/components/cmsds/CmsDropdown.tsx +62 -0
  23. package/admin/src/components/cmsds/CmsEmptyState.tsx +54 -0
  24. package/admin/src/components/cmsds/CmsField.tsx +47 -0
  25. package/admin/src/components/cmsds/CmsPageHeader.tsx +35 -0
  26. package/admin/src/components/cmsds/CmsStatusBadge.tsx +153 -0
  27. package/admin/src/components/cmsds/CmsSurface.tsx +52 -0
  28. package/admin/src/components/cmsds/CmsTable.tsx +164 -0
  29. package/admin/src/components/cmsds/CmsToolbar.tsx +58 -0
  30. package/admin/src/components/cmsds/index.ts +10 -0
  31. package/admin/src/components/fields/BooleanField.tsx +74 -0
  32. package/admin/src/components/fields/CategoryField.tsx +394 -0
  33. package/admin/src/components/fields/DateField.tsx +173 -0
  34. package/admin/src/components/fields/DefaultFieldRenderer.tsx +74 -0
  35. package/admin/src/components/fields/FieldRenderer.tsx +180 -0
  36. package/admin/src/components/fields/FieldWrapper.tsx +57 -0
  37. package/admin/src/components/fields/JsonField.tsx +172 -0
  38. package/admin/src/components/fields/MediaField.tsx +367 -0
  39. package/admin/src/components/fields/MultiSelectField.tsx +118 -0
  40. package/admin/src/components/fields/NumberField.tsx +77 -0
  41. package/admin/src/components/fields/ReferenceField.tsx +386 -0
  42. package/admin/src/components/fields/RichTextField.tsx +171 -0
  43. package/admin/src/components/fields/SelectField.tsx +62 -0
  44. package/admin/src/components/fields/TagField.tsx +325 -0
  45. package/admin/src/components/fields/TextAreaField.tsx +68 -0
  46. package/admin/src/components/fields/TextField.tsx +56 -0
  47. package/admin/src/components/fields/index.ts +54 -0
  48. package/admin/src/components/fields/registry.ts +64 -0
  49. package/admin/src/components/fields/types.ts +217 -0
  50. package/admin/src/components/filters/TaxonomyFilter.tsx +254 -0
  51. package/admin/src/components/filters/index.ts +1 -0
  52. package/admin/src/components/index.ts +8 -0
  53. package/admin/src/components/media/MediaAssetActions.tsx +115 -0
  54. package/admin/src/components/media/MediaAssetEditDialog.tsx +217 -0
  55. package/admin/src/components/media/MediaBulkActionBar.tsx +51 -0
  56. package/admin/src/components/media/MediaFolderActions.tsx +69 -0
  57. package/admin/src/components/media/MediaFolderEditDialog.tsx +126 -0
  58. package/admin/src/components/media/MediaMoveModal.tsx +179 -0
  59. package/admin/src/components/media/MediaPreviewModal.tsx +370 -0
  60. package/admin/src/components/media/MediaTaxonomyPicker.tsx +304 -0
  61. package/admin/src/components/media/MediaTrashBulkActionBar.tsx +59 -0
  62. package/admin/src/components/ui/accordion.tsx +64 -0
  63. package/admin/src/components/ui/alert-dialog.tsx +155 -0
  64. package/admin/src/components/ui/alert.tsx +66 -0
  65. package/admin/src/components/ui/avatar.tsx +53 -0
  66. package/admin/src/components/ui/badge.tsx +46 -0
  67. package/admin/src/components/ui/breadcrumb.tsx +109 -0
  68. package/admin/src/components/ui/button.tsx +62 -0
  69. package/admin/src/components/ui/calendar.tsx +220 -0
  70. package/admin/src/components/ui/card.tsx +92 -0
  71. package/admin/src/components/ui/checkbox.tsx +30 -0
  72. package/admin/src/components/ui/command.tsx +182 -0
  73. package/admin/src/components/ui/dialog.tsx +143 -0
  74. package/admin/src/components/ui/dropdown-menu.tsx +257 -0
  75. package/admin/src/components/ui/form.tsx +167 -0
  76. package/admin/src/components/ui/input.tsx +21 -0
  77. package/admin/src/components/ui/label.tsx +24 -0
  78. package/admin/src/components/ui/popover.tsx +46 -0
  79. package/admin/src/components/ui/scroll-area.tsx +56 -0
  80. package/admin/src/components/ui/select.tsx +190 -0
  81. package/admin/src/components/ui/separator.tsx +26 -0
  82. package/admin/src/components/ui/sheet.tsx +137 -0
  83. package/admin/src/components/ui/sidebar.tsx +724 -0
  84. package/admin/src/components/ui/skeleton.tsx +13 -0
  85. package/admin/src/components/ui/sonner.tsx +38 -0
  86. package/admin/src/components/ui/switch.tsx +31 -0
  87. package/admin/src/components/ui/table.tsx +114 -0
  88. package/admin/src/components/ui/tabs.tsx +66 -0
  89. package/admin/src/components/ui/textarea.tsx +18 -0
  90. package/admin/src/components/ui/tooltip.tsx +61 -0
  91. package/admin/src/contexts/AdminConfigContext.tsx +30 -0
  92. package/admin/src/contexts/AuthContext.tsx +330 -0
  93. package/admin/src/contexts/BreadcrumbContext.tsx +49 -0
  94. package/admin/src/contexts/SettingsConfigContext.tsx +57 -0
  95. package/admin/src/contexts/ThemeContext.tsx +91 -0
  96. package/admin/src/contexts/index.ts +20 -0
  97. package/admin/src/embed/components/EmbedHeader.tsx +103 -0
  98. package/admin/src/embed/components/EmbedLayout.tsx +29 -0
  99. package/admin/src/embed/components/EmbedSidebar.tsx +119 -0
  100. package/admin/src/embed/components/index.ts +3 -0
  101. package/admin/src/embed/contexts/ApiContext.tsx +32 -0
  102. package/admin/src/embed/index.tsx +184 -0
  103. package/admin/src/embed/navigation.tsx +202 -0
  104. package/admin/src/embed/pages/Content.tsx +19 -0
  105. package/admin/src/embed/pages/ContentTypes.tsx +19 -0
  106. package/admin/src/embed/pages/Dashboard.tsx +19 -0
  107. package/admin/src/embed/pages/Media.tsx +19 -0
  108. package/admin/src/embed/pages/Settings.tsx +22 -0
  109. package/admin/src/embed/pages/Taxonomies.tsx +22 -0
  110. package/admin/src/embed/pages/Trash.tsx +22 -0
  111. package/admin/src/embed/pages/index.ts +7 -0
  112. package/admin/src/embed/types.ts +24 -0
  113. package/admin/src/hooks/index.ts +2 -0
  114. package/admin/src/hooks/use-mobile.ts +19 -0
  115. package/admin/src/hooks/useBreadcrumbLabel.ts +15 -0
  116. package/admin/src/hooks/usePermissions.ts +211 -0
  117. package/admin/src/lib/admin-config.ts +111 -0
  118. package/admin/src/lib/cn.ts +6 -0
  119. package/admin/src/lib/config.server.ts +56 -0
  120. package/admin/src/lib/convex.ts +26 -0
  121. package/admin/src/lib/embed-adapter.ts +80 -0
  122. package/admin/src/lib/icons.tsx +96 -0
  123. package/admin/src/lib/loadAdminConfig.ts +92 -0
  124. package/admin/src/lib/motion.ts +29 -0
  125. package/admin/src/lib/navigation.ts +43 -0
  126. package/admin/src/lib/tanstack-adapter.ts +82 -0
  127. package/admin/src/pages/ContentPage.tsx +337 -0
  128. package/admin/src/pages/ContentTypesPage.tsx +457 -0
  129. package/admin/src/pages/DashboardPage.tsx +163 -0
  130. package/admin/src/pages/MediaPage.tsx +34 -0
  131. package/admin/src/pages/SettingsPage.tsx +486 -0
  132. package/admin/src/pages/TaxonomiesPage.tsx +289 -0
  133. package/admin/src/pages/TrashPage.tsx +421 -0
  134. package/admin/src/pages/index.ts +14 -0
  135. package/admin/src/routeTree.gen.ts +262 -0
  136. package/admin/src/router.tsx +22 -0
  137. package/admin/src/routes/__root.tsx +250 -0
  138. package/admin/src/routes/content-types.tsx +20 -0
  139. package/admin/src/routes/content.tsx +20 -0
  140. package/admin/src/routes/entries/$entryId.tsx +107 -0
  141. package/admin/src/routes/entries/new.$contentTypeId.tsx +69 -0
  142. package/admin/src/routes/entries/type/$contentTypeId.tsx +503 -0
  143. package/admin/src/routes/index.tsx +20 -0
  144. package/admin/src/routes/media.tsx +1095 -0
  145. package/admin/src/routes/settings.tsx +20 -0
  146. package/admin/src/routes/taxonomies.tsx +20 -0
  147. package/admin/src/routes/trash.tsx +20 -0
  148. package/admin/src/styles/globals.css +69 -0
  149. package/admin/src/styles/tailwind-config.css +74 -0
  150. package/admin/src/styles/theme.css +73 -0
  151. package/admin/src/types/index.ts +221 -0
  152. package/admin/src/utils/errorParsing.ts +163 -0
  153. package/admin/src/utils/index.ts +5 -0
  154. package/admin/src/vite-env.d.ts +14 -0
  155. package/admin/tailwind.preset.cjs +102 -0
  156. package/admin-dist/nitro.json +1 -1
  157. package/admin-dist/public/assets/{CmsEmptyState-CiMQwSQV.js → CmsEmptyState-CkqBIab3.js} +1 -1
  158. package/admin-dist/public/assets/{CmsPageHeader-ohOq0luT.js → CmsPageHeader-CUtl5MMG.js} +1 -1
  159. package/admin-dist/public/assets/{CmsStatusBadge-BdNf0V9v.js → CmsStatusBadge-CUYFgEe-.js} +1 -1
  160. package/admin-dist/public/assets/{CmsSurface-CWup6Jh7.js → CmsSurface-CsJfAVa3.js} +1 -1
  161. package/admin-dist/public/assets/{CmsToolbar-cEBlCHa3.js → CmsToolbar-CnfbcxeP.js} +1 -1
  162. package/admin-dist/public/assets/{ContentEntryEditor-BY5ypfUs.js → ContentEntryEditor-BU220CCy.js} +1 -1
  163. package/admin-dist/public/assets/TaxonomyFilter-CWCxC5HZ.js +1 -0
  164. package/admin-dist/public/assets/_contentTypeId-DK8cskRt.js +1 -0
  165. package/admin-dist/public/assets/{_entryId-BpSmrfAm.js → _entryId-CuVMExbb.js} +1 -1
  166. package/admin-dist/public/assets/{alert-Bf2l8kxw.js → alert-CF1BSzGR.js} +1 -1
  167. package/admin-dist/public/assets/{badge-qPrc4AUM.js → badge-CmuOIVKp.js} +1 -1
  168. package/admin-dist/public/assets/{circle-check-big-Dgozy3vV.js → circle-check-big-BKDVG6DU.js} +1 -1
  169. package/admin-dist/public/assets/{command-QOmNhlb0.js → command-XJxnF2Sd.js} +1 -1
  170. package/admin-dist/public/assets/content-QBUxdxbS.js +1 -0
  171. package/admin-dist/public/assets/content-types-CrNEm8Hf.js +2 -0
  172. package/admin-dist/public/assets/globals-B7Wsfh_v.css +1 -0
  173. package/admin-dist/public/assets/index-C7xOwudI.js +1 -0
  174. package/admin-dist/public/assets/{label-DCsUdvFh.js → label-CHCnXeBk.js} +1 -1
  175. package/admin-dist/public/assets/{link-2-Czw1N61H.js → link-2-Bb34judH.js} +1 -1
  176. package/admin-dist/public/assets/{list-DtCsXj8-.js → list-9Pzt48ld.js} +1 -1
  177. package/admin-dist/public/assets/{main-CXgkZMhe.js → main-CjQ2VI9L.js} +3 -3
  178. package/admin-dist/public/assets/media-Dc5PWt2Q.js +1 -0
  179. package/admin-dist/public/assets/{new._contentTypeId-CoTDxKzf.js → new._contentTypeId-C_I4YxIa.js} +1 -1
  180. package/admin-dist/public/assets/{plus-xCFJK0RC.js → plus-Ceef7DHk.js} +1 -1
  181. package/admin-dist/public/assets/{rotate-ccw-DIqK63wY.js → rotate-ccw-7k7-4VUq.js} +1 -1
  182. package/admin-dist/public/assets/{scroll-area-B-yrE66a.js → scroll-area-CC6wujnp.js} +1 -1
  183. package/admin-dist/public/assets/{search-CbCbboeU.js → search-DwoUV2pv.js} +1 -1
  184. package/admin-dist/public/assets/{select-Co3TZFJb.js → select-hOZTp8aC.js} +1 -1
  185. package/admin-dist/public/assets/{settings-BspTTv_o.js → settings-t2PbCZh4.js} +1 -1
  186. package/admin-dist/public/assets/{switch-CfavASmR.js → switch-jX2pDaNU.js} +1 -1
  187. package/admin-dist/public/assets/{tabs-CN5s5u2W.js → tabs-q4EbZk7c.js} +1 -1
  188. package/admin-dist/public/assets/{tanstack-adapter-npeE3RdY.js → tanstack-adapter-B-Glm4kH.js} +1 -1
  189. package/admin-dist/public/assets/taxonomies-kyk5P4ZW.js +1 -0
  190. package/admin-dist/public/assets/{textarea-BJ0XFZpT.js → textarea-B6SfBmr0.js} +1 -1
  191. package/admin-dist/public/assets/trash-BOCnIznD.js +1 -0
  192. package/admin-dist/public/assets/{triangle-alert-BZRcqsUg.js → triangle-alert-CXFIO_Gu.js} +1 -1
  193. package/admin-dist/public/assets/{useBreadcrumbLabel-DwZlwvFF.js → useBreadcrumbLabel-_6qBagc3.js} +1 -1
  194. package/admin-dist/public/assets/{usePermissions-C1JQhfqb.js → usePermissions-M1ijZ7a6.js} +1 -1
  195. package/admin-dist/server/_ssr/{CmsButton-B45JAKR1.mjs → CmsButton-DOiTVKQq.mjs} +1 -1
  196. package/admin-dist/server/_ssr/{CmsEmptyState-D_BQFAVR.mjs → CmsEmptyState-fbnGt3LD.mjs} +2 -2
  197. package/admin-dist/server/_ssr/{CmsPageHeader-CrUZA59A.mjs → CmsPageHeader-DHRrdOZa.mjs} +1 -1
  198. package/admin-dist/server/_ssr/{CmsStatusBadge-B-sj6yaj.mjs → CmsStatusBadge-s7obWbKZ.mjs} +2 -2
  199. package/admin-dist/server/_ssr/{CmsSurface-DKJZhpjk.mjs → CmsSurface-rFoYjb62.mjs} +1 -1
  200. package/admin-dist/server/_ssr/{CmsToolbar-ByaW5iXf.mjs → CmsToolbar-zTE45z2q.mjs} +2 -2
  201. package/admin-dist/server/_ssr/{ContentEntryEditor-D3_Jb1dq.mjs → ContentEntryEditor-BLoEjT_m.mjs} +12 -12
  202. package/admin-dist/server/_ssr/{TaxonomyFilter-BRJkuCtA.mjs → TaxonomyFilter-XAtaJC2z.mjs} +5 -5
  203. package/admin-dist/server/_ssr/{_contentTypeId-B9kA6CaM.mjs → _contentTypeId-Csl4822C.mjs} +13 -13
  204. package/admin-dist/server/_ssr/{_entryId-BddcMkZN.mjs → _entryId-D8alLFBx.mjs} +15 -15
  205. package/admin-dist/server/_ssr/_tanstack-start-manifest_v-BffZedId.mjs +4 -0
  206. package/admin-dist/server/_ssr/{command-CGtVr8Gb.mjs → command-C0Di14--.mjs} +1 -1
  207. package/admin-dist/server/_ssr/{content-D1tbeOd0.mjs → content-CT-FPsmV.mjs} +12 -55
  208. package/admin-dist/server/_ssr/{content-types-BZqY_BER.mjs → content-types-C8cBFdzE.mjs} +15 -46
  209. package/admin-dist/server/_ssr/{index-BIdq4xaC.mjs → index-BJtcrEc-.mjs} +5 -5
  210. package/admin-dist/server/_ssr/index.mjs +2 -2
  211. package/admin-dist/server/_ssr/{label-T-QNKAr6.mjs → label-qn2Afwl4.mjs} +1 -1
  212. package/admin-dist/server/_ssr/{media-C-xqjBrl.mjs → media-qv5IAsMZ.mjs} +14 -14
  213. package/admin-dist/server/_ssr/{new._contentTypeId-DWic9cRq.mjs → new._contentTypeId-DdGyrhqs.mjs} +13 -13
  214. package/admin-dist/server/_ssr/{router-D1BMAMJT.mjs → router-nSVkxb6Y.mjs} +11 -11
  215. package/admin-dist/server/_ssr/{scroll-area-C0pic_WA.mjs → scroll-area-BCinP455.mjs} +1 -1
  216. package/admin-dist/server/_ssr/{select-CqmuN2F6.mjs → select-BKQlQScw.mjs} +1 -1
  217. package/admin-dist/server/_ssr/{settings-CAkncGGV.mjs → settings-BCr2KQlk.mjs} +55 -40
  218. package/admin-dist/server/_ssr/{switch-CgmuJkT9.mjs → switch-BaOi42fE.mjs} +1 -1
  219. package/admin-dist/server/_ssr/{tabs-CnMj0aRy.mjs → tabs-DYXEi9kq.mjs} +2 -2
  220. package/admin-dist/server/_ssr/{tanstack-adapter-BXZrMauE.mjs → tanstack-adapter-Bsz8kha-.mjs} +1 -1
  221. package/admin-dist/server/_ssr/{taxonomies-thl3BfVm.mjs → taxonomies-CueMHTbE.mjs} +30 -19
  222. package/admin-dist/server/_ssr/{textarea-4K5OJgeh.mjs → textarea-CI0Jqx2x.mjs} +1 -1
  223. package/admin-dist/server/_ssr/{trash-B40Gx5zP.mjs → trash-DE6W8GoX.mjs} +20 -17
  224. package/admin-dist/server/_ssr/{useBreadcrumbLabel-rn-fL4zV.mjs → useBreadcrumbLabel-B5Yi72lM.mjs} +1 -1
  225. package/admin-dist/server/_ssr/{usePermissions-CKeM6_Vw.mjs → usePermissions-C3nZ-Izm.mjs} +1 -1
  226. package/admin-dist/server/index.mjs +183 -190
  227. package/dist/client/admin/bulk.d.ts +79 -0
  228. package/dist/client/admin/bulk.d.ts.map +1 -0
  229. package/dist/client/admin/bulk.js +72 -0
  230. package/dist/client/admin/bulk.js.map +1 -0
  231. package/dist/client/admin/contentLock.d.ts +118 -0
  232. package/dist/client/admin/contentLock.d.ts.map +1 -0
  233. package/dist/client/admin/contentLock.js +81 -0
  234. package/dist/client/admin/contentLock.js.map +1 -0
  235. package/dist/client/{adminApi.d.ts → admin/contentTypes.d.ts} +39 -1134
  236. package/dist/client/admin/contentTypes.d.ts.map +1 -0
  237. package/dist/client/admin/contentTypes.js +122 -0
  238. package/dist/client/admin/contentTypes.js.map +1 -0
  239. package/dist/client/admin/dashboard.d.ts +16 -0
  240. package/dist/client/admin/dashboard.d.ts.map +1 -0
  241. package/dist/client/admin/dashboard.js +33 -0
  242. package/dist/client/admin/dashboard.js.map +1 -0
  243. package/dist/client/admin/entries.d.ts +358 -0
  244. package/dist/client/admin/entries.d.ts.map +1 -0
  245. package/dist/client/admin/entries.js +220 -0
  246. package/dist/client/admin/entries.js.map +1 -0
  247. package/dist/client/admin/index.d.ts +6568 -0
  248. package/dist/client/admin/index.d.ts.map +1 -0
  249. package/dist/client/admin/index.js +305 -0
  250. package/dist/client/admin/index.js.map +1 -0
  251. package/dist/client/admin/media.d.ts +1038 -0
  252. package/dist/client/admin/media.d.ts.map +1 -0
  253. package/dist/client/admin/media.js +489 -0
  254. package/dist/client/admin/media.js.map +1 -0
  255. package/dist/client/admin/taxonomies.d.ts +339 -0
  256. package/dist/client/admin/taxonomies.d.ts.map +1 -0
  257. package/dist/client/admin/taxonomies.js +364 -0
  258. package/dist/client/admin/taxonomies.js.map +1 -0
  259. package/dist/client/admin/trash.d.ts +91 -0
  260. package/dist/client/admin/trash.d.ts.map +1 -0
  261. package/dist/client/admin/trash.js +71 -0
  262. package/dist/client/admin/trash.js.map +1 -0
  263. package/dist/client/admin/types.d.ts +320 -0
  264. package/dist/client/admin/types.d.ts.map +1 -0
  265. package/dist/client/admin/types.js +7 -0
  266. package/dist/client/admin/types.js.map +1 -0
  267. package/dist/client/admin/validators.d.ts +3886 -0
  268. package/dist/client/admin/validators.d.ts.map +1 -0
  269. package/dist/client/admin/validators.js +322 -0
  270. package/dist/client/admin/validators.js.map +1 -0
  271. package/dist/client/admin/versions.d.ts +106 -0
  272. package/dist/client/admin/versions.d.ts.map +1 -0
  273. package/dist/client/admin/versions.js +57 -0
  274. package/dist/client/admin/versions.js.map +1 -0
  275. package/dist/client/adminApiTypes.d.ts +27 -0
  276. package/dist/client/adminApiTypes.d.ts.map +1 -0
  277. package/dist/client/adminApiTypes.js +12 -0
  278. package/dist/client/adminApiTypes.js.map +1 -0
  279. package/dist/client/{admin-config.d.ts → adminConfig.d.ts} +2 -2
  280. package/dist/client/adminConfig.d.ts.map +1 -0
  281. package/dist/client/{admin-config.js → adminConfig.js} +1 -1
  282. package/dist/client/adminConfig.js.map +1 -0
  283. package/dist/client/agentTools.d.ts +4 -4
  284. package/dist/client/index.d.ts +2 -2
  285. package/dist/client/index.d.ts.map +1 -1
  286. package/dist/client/index.js +15 -2
  287. package/dist/client/index.js.map +1 -1
  288. package/dist/component/contentEntries.d.ts +4 -4
  289. package/dist/component/contentEntryMutations.d.ts +46 -0
  290. package/dist/component/contentEntryMutations.d.ts.map +1 -1
  291. package/dist/component/contentEntryMutations.js +1 -1
  292. package/dist/component/contentEntryMutations.js.map +1 -1
  293. package/dist/component/contentTypeMigration.d.ts +1 -1
  294. package/dist/component/contentTypeMutations.d.ts +22 -0
  295. package/dist/component/contentTypeMutations.d.ts.map +1 -1
  296. package/dist/component/contentTypeMutations.js +1 -1
  297. package/dist/component/contentTypeMutations.js.map +1 -1
  298. package/dist/component/mediaAssetMutations.d.ts +47 -0
  299. package/dist/component/mediaAssetMutations.d.ts.map +1 -1
  300. package/dist/component/mediaAssetMutations.js +1 -1
  301. package/dist/component/mediaAssetMutations.js.map +1 -1
  302. package/dist/component/schema.d.ts +9 -0
  303. package/dist/component/schema.d.ts.map +1 -1
  304. package/dist/component/schema.js +1 -1
  305. package/dist/component/schema.js.map +1 -1
  306. package/package.json +85 -3
  307. package/admin-dist/public/assets/ErrorState-C4nJ-ml4.js +0 -1
  308. package/admin-dist/public/assets/TaxonomyFilter-BgE_SR_O.js +0 -1
  309. package/admin-dist/public/assets/_contentTypeId-DtZectcC.js +0 -1
  310. package/admin-dist/public/assets/content-OEBGlxg1.js +0 -1
  311. package/admin-dist/public/assets/content-types-CjQliqVV.js +0 -2
  312. package/admin-dist/public/assets/globals-hAmgC66w.css +0 -1
  313. package/admin-dist/public/assets/index-BH_ECMhv.js +0 -1
  314. package/admin-dist/public/assets/media-DTJ3-ViE.js +0 -1
  315. package/admin-dist/public/assets/taxonomies-CgG46fIF.js +0 -1
  316. package/admin-dist/public/assets/trash-B3daldm5.js +0 -1
  317. package/admin-dist/server/_ssr/ErrorState-cI-bKLez.mjs +0 -89
  318. package/admin-dist/server/_ssr/_tanstack-start-manifest_v-Dd7AmelK.mjs +0 -4
  319. package/dist/client/admin-config.d.ts.map +0 -1
  320. package/dist/client/admin-config.js.map +0 -1
  321. package/dist/client/adminApi.d.ts.map +0 -1
  322. package/dist/client/adminApi.js +0 -736
  323. package/dist/client/adminApi.js.map +0 -1
@@ -1,736 +0,0 @@
1
- /**
2
- * Admin API Helper for Convex CMS
3
- *
4
- * This module provides the `defineAdminAPI` function that creates typed
5
- * Convex functions for the admin UI to call. Users export these functions
6
- * from their `convex/` directory, which the admin UI then calls.
7
- *
8
- * This follows the standard Convex component pattern used by:
9
- * - @convex-dev/agent's `definePlaygroundAPI`
10
- * - template-component's `exposeApi`
11
- * - @dodopayments/convex's class-based API
12
- *
13
- * @example
14
- * ```typescript
15
- * // convex/admin.ts
16
- * import { defineAdminAPI } from "convex-cms";
17
- * import { components } from "./_generated/api";
18
- *
19
- * export const {
20
- * // Content Types
21
- * listContentTypes,
22
- * getContentType,
23
- * createContentType,
24
- * updateContentType,
25
- * deleteContentType,
26
- * // Entries
27
- * listEntries,
28
- * getEntry,
29
- * createEntry,
30
- * updateEntry,
31
- * publishEntry,
32
- * unpublishEntry,
33
- * deleteEntry,
34
- * duplicateEntry,
35
- * scheduleEntry,
36
- * cancelScheduledEntry,
37
- * getScheduledEntries,
38
- * // Media
39
- * listMediaAssets,
40
- * getMediaAsset,
41
- * createMediaAsset,
42
- * updateMediaAsset,
43
- * deleteMediaAsset,
44
- * restoreMediaAsset,
45
- * moveMediaAssets,
46
- * listMediaFolders,
47
- * getMediaFolder,
48
- * getMediaFolderTree,
49
- * createMediaFolder,
50
- * updateMediaFolder,
51
- * moveMediaFolder,
52
- * deleteMediaFolder,
53
- * restoreMediaFolder,
54
- * generateUploadUrl,
55
- * // Stats
56
- * getDashboardStats,
57
- * } = defineAdminAPI(components.convexCms, {
58
- * auth: async (ctx, operation) => {
59
- * // Optional: validate user has admin access
60
- * const identity = await ctx.auth.getUserIdentity();
61
- * if (!identity) throw new Error("Unauthorized");
62
- * return identity.subject;
63
- * },
64
- * });
65
- * ```
66
- */
67
- import { queryGeneric, mutationGeneric, } from "convex/server";
68
- import { v } from "convex/values";
69
- import { fieldDefinitionValidator, contentStatusValidator, mediaTypeValidator, } from "../component/schema.js";
70
- // =============================================================================
71
- // Validators (reused across functions)
72
- // =============================================================================
73
- const paginationOptsValidator = v.object({
74
- numItems: v.number(),
75
- cursor: v.union(v.string(), v.null()),
76
- });
77
- // =============================================================================
78
- // defineAdminAPI
79
- // =============================================================================
80
- /**
81
- * Creates typed Convex functions for the CMS admin UI.
82
- *
83
- * This function returns an object containing query and mutation functions
84
- * that the admin UI calls. Users export these from their `convex/` directory.
85
- *
86
- * @param component - The CMS component API from `components.convexCms`
87
- * @param options - Optional configuration including auth callback
88
- * @returns Object with namespaced admin functions
89
- *
90
- * @example
91
- * ```typescript
92
- * // convex/admin.ts
93
- * import { defineAdminAPI } from "convex-cms";
94
- * import { components } from "./_generated/api";
95
- *
96
- * export const { contentTypes, entries, media, stats } = defineAdminAPI(
97
- * components.convexCms
98
- * );
99
- * ```
100
- */
101
- export function defineAdminAPI(component, options = {}) {
102
- const { auth } = options;
103
- // Helper to run auth check if configured
104
- const checkAuth = async (ctx, operation) => {
105
- if (auth) {
106
- return await auth(ctx, operation);
107
- }
108
- return null;
109
- };
110
- return {
111
- // =========================================================================
112
- // Content Types
113
- // =========================================================================
114
- listContentTypes: queryGeneric({
115
- args: {
116
- isActive: v.optional(v.boolean()),
117
- },
118
- returns: v.any(),
119
- handler: async (ctx, args) => {
120
- await checkAuth(ctx, { type: "listContentTypes" });
121
- return await ctx.runQuery(component.contentTypes.list, {
122
- isActive: args.isActive,
123
- });
124
- },
125
- }),
126
- getContentType: queryGeneric({
127
- args: {
128
- id: v.optional(v.string()),
129
- name: v.optional(v.string()),
130
- },
131
- returns: v.union(v.any(), v.null()),
132
- handler: async (ctx, args) => {
133
- await checkAuth(ctx, { type: "getContentType", id: args.id ?? "" });
134
- return await ctx.runQuery(component.contentTypes.get, {
135
- id: args.id,
136
- name: args.name,
137
- });
138
- },
139
- }),
140
- createContentType: mutationGeneric({
141
- args: {
142
- name: v.string(),
143
- displayName: v.string(),
144
- fields: v.array(fieldDefinitionValidator),
145
- description: v.optional(v.string()),
146
- icon: v.optional(v.string()),
147
- singleton: v.optional(v.boolean()),
148
- slugField: v.optional(v.string()),
149
- titleField: v.optional(v.string()),
150
- sortOrder: v.optional(v.number()),
151
- createdBy: v.string(),
152
- },
153
- returns: v.any(),
154
- handler: async (ctx, args) => {
155
- await checkAuth(ctx, { type: "createContentType" });
156
- return await ctx.runMutation(component.contentTypeMutations.createContentType, {
157
- name: args.name,
158
- displayName: args.displayName,
159
- fields: args.fields,
160
- description: args.description,
161
- icon: args.icon,
162
- singleton: args.singleton,
163
- slugField: args.slugField,
164
- titleField: args.titleField,
165
- sortOrder: args.sortOrder,
166
- createdBy: args.createdBy,
167
- });
168
- },
169
- }),
170
- updateContentType: mutationGeneric({
171
- args: {
172
- id: v.string(),
173
- displayName: v.optional(v.string()),
174
- fields: v.optional(v.array(fieldDefinitionValidator)),
175
- description: v.optional(v.string()),
176
- icon: v.optional(v.string()),
177
- singleton: v.optional(v.boolean()),
178
- slugField: v.optional(v.string()),
179
- titleField: v.optional(v.string()),
180
- sortOrder: v.optional(v.number()),
181
- isActive: v.optional(v.boolean()),
182
- updatedBy: v.optional(v.string()),
183
- },
184
- returns: v.any(),
185
- handler: async (ctx, args) => {
186
- await checkAuth(ctx, { type: "updateContentType", id: args.id });
187
- return await ctx.runMutation(component.contentTypeMutations.updateContentType, {
188
- id: args.id,
189
- displayName: args.displayName,
190
- fields: args.fields,
191
- description: args.description,
192
- icon: args.icon,
193
- singleton: args.singleton,
194
- slugField: args.slugField,
195
- titleField: args.titleField,
196
- sortOrder: args.sortOrder,
197
- isActive: args.isActive,
198
- updatedBy: args.updatedBy,
199
- });
200
- },
201
- }),
202
- deleteContentType: mutationGeneric({
203
- args: {
204
- id: v.string(),
205
- cascade: v.optional(v.boolean()),
206
- hardDelete: v.optional(v.boolean()),
207
- deletedBy: v.optional(v.string()),
208
- },
209
- returns: v.any(),
210
- handler: async (ctx, args) => {
211
- await checkAuth(ctx, { type: "deleteContentType", id: args.id });
212
- return await ctx.runMutation(component.contentTypeMutations.deleteContentType, {
213
- id: args.id,
214
- cascade: args.cascade,
215
- hardDelete: args.hardDelete,
216
- deletedBy: args.deletedBy,
217
- });
218
- },
219
- }),
220
- // =========================================================================
221
- // Content Entries
222
- // =========================================================================
223
- listEntries: queryGeneric({
224
- args: {
225
- contentTypeId: v.optional(v.string()),
226
- status: v.optional(contentStatusValidator),
227
- search: v.optional(v.string()),
228
- locale: v.optional(v.string()),
229
- paginationOpts: paginationOptsValidator,
230
- },
231
- returns: v.any(),
232
- handler: async (ctx, args) => {
233
- await checkAuth(ctx, {
234
- type: "listEntries",
235
- contentTypeId: args.contentTypeId ?? "",
236
- });
237
- return await ctx.runQuery(component.contentEntries.list, {
238
- contentTypeId: args.contentTypeId,
239
- status: args.status,
240
- search: args.search,
241
- locale: args.locale,
242
- paginationOpts: args.paginationOpts,
243
- });
244
- },
245
- }),
246
- getEntry: queryGeneric({
247
- args: {
248
- id: v.string(),
249
- },
250
- returns: v.union(v.any(), v.null()),
251
- handler: async (ctx, args) => {
252
- await checkAuth(ctx, { type: "getEntry", id: args.id });
253
- return await ctx.runQuery(component.contentEntries.get, {
254
- id: args.id,
255
- });
256
- },
257
- }),
258
- createEntry: mutationGeneric({
259
- args: {
260
- contentTypeId: v.string(),
261
- data: v.any(),
262
- slug: v.optional(v.string()),
263
- status: v.optional(contentStatusValidator),
264
- locale: v.optional(v.string()),
265
- primaryEntryId: v.optional(v.string()),
266
- createdBy: v.optional(v.string()),
267
- },
268
- returns: v.any(),
269
- handler: async (ctx, args) => {
270
- await checkAuth(ctx, {
271
- type: "createEntry",
272
- contentTypeId: args.contentTypeId,
273
- });
274
- return await ctx.runMutation(component.contentEntryMutations.createEntry, {
275
- contentTypeId: args.contentTypeId,
276
- data: args.data,
277
- slug: args.slug,
278
- status: args.status,
279
- locale: args.locale,
280
- primaryEntryId: args.primaryEntryId,
281
- createdBy: args.createdBy,
282
- });
283
- },
284
- }),
285
- updateEntry: mutationGeneric({
286
- args: {
287
- id: v.string(),
288
- data: v.optional(v.any()),
289
- slug: v.optional(v.string()),
290
- status: v.optional(contentStatusValidator),
291
- scheduledPublishAt: v.optional(v.number()),
292
- updatedBy: v.optional(v.string()),
293
- regenerateSlug: v.optional(v.boolean()),
294
- },
295
- returns: v.any(),
296
- handler: async (ctx, args) => {
297
- await checkAuth(ctx, { type: "updateEntry", id: args.id });
298
- return await ctx.runMutation(component.contentEntryMutations.updateEntry, {
299
- id: args.id,
300
- data: args.data,
301
- slug: args.slug,
302
- status: args.status,
303
- scheduledPublishAt: args.scheduledPublishAt,
304
- updatedBy: args.updatedBy,
305
- regenerateSlug: args.regenerateSlug,
306
- });
307
- },
308
- }),
309
- publishEntry: mutationGeneric({
310
- args: {
311
- id: v.string(),
312
- changeDescription: v.optional(v.string()),
313
- updatedBy: v.optional(v.string()),
314
- },
315
- returns: v.any(),
316
- handler: async (ctx, args) => {
317
- await checkAuth(ctx, { type: "publishEntry", id: args.id });
318
- return await ctx.runMutation(component.contentEntryMutations.publishEntry, {
319
- id: args.id,
320
- changeDescription: args.changeDescription,
321
- updatedBy: args.updatedBy,
322
- });
323
- },
324
- }),
325
- unpublishEntry: mutationGeneric({
326
- args: {
327
- id: v.string(),
328
- updatedBy: v.optional(v.string()),
329
- },
330
- returns: v.any(),
331
- handler: async (ctx, args) => {
332
- await checkAuth(ctx, { type: "unpublishEntry", id: args.id });
333
- return await ctx.runMutation(component.contentEntryMutations.unpublishEntry, {
334
- id: args.id,
335
- updatedBy: args.updatedBy,
336
- });
337
- },
338
- }),
339
- deleteEntry: mutationGeneric({
340
- args: {
341
- id: v.string(),
342
- hardDelete: v.optional(v.boolean()),
343
- deletedBy: v.optional(v.string()),
344
- },
345
- returns: v.any(),
346
- handler: async (ctx, args) => {
347
- await checkAuth(ctx, { type: "deleteEntry", id: args.id });
348
- return await ctx.runMutation(component.contentEntryMutations.deleteEntry, {
349
- id: args.id,
350
- hardDelete: args.hardDelete,
351
- deletedBy: args.deletedBy,
352
- });
353
- },
354
- }),
355
- duplicateEntry: mutationGeneric({
356
- args: {
357
- id: v.string(),
358
- copyMediaReferences: v.optional(v.boolean()),
359
- createdBy: v.optional(v.string()),
360
- },
361
- returns: v.any(),
362
- handler: async (ctx, args) => {
363
- await checkAuth(ctx, { type: "duplicateEntry", id: args.id });
364
- return await ctx.runMutation(component.contentEntryMutations.duplicateEntry, {
365
- sourceEntryId: args.id,
366
- copyMediaReferences: args.copyMediaReferences,
367
- createdBy: args.createdBy,
368
- });
369
- },
370
- }),
371
- scheduleEntry: mutationGeneric({
372
- args: {
373
- id: v.string(),
374
- publishAt: v.number(),
375
- updatedBy: v.optional(v.string()),
376
- },
377
- returns: v.any(),
378
- handler: async (ctx, args) => {
379
- await checkAuth(ctx, { type: "scheduleEntry", id: args.id });
380
- return await ctx.runMutation(component.scheduledPublish.scheduleEntry, {
381
- id: args.id,
382
- publishAt: args.publishAt,
383
- updatedBy: args.updatedBy,
384
- });
385
- },
386
- }),
387
- cancelScheduledEntry: mutationGeneric({
388
- args: {
389
- id: v.string(),
390
- updatedBy: v.optional(v.string()),
391
- },
392
- returns: v.any(),
393
- handler: async (ctx, args) => {
394
- await checkAuth(ctx, { type: "cancelScheduledEntry", id: args.id });
395
- return await ctx.runMutation(component.scheduledPublish.cancelScheduledPublish, {
396
- id: args.id,
397
- updatedBy: args.updatedBy,
398
- });
399
- },
400
- }),
401
- getScheduledEntries: queryGeneric({
402
- args: {},
403
- returns: v.array(v.any()),
404
- handler: async (ctx) => {
405
- await checkAuth(ctx, { type: "getScheduledEntries" });
406
- return await ctx.runQuery(component.scheduledPublish.getScheduledEntries, {});
407
- },
408
- }),
409
- // =========================================================================
410
- // Media Assets
411
- // =========================================================================
412
- listMediaAssets: queryGeneric({
413
- args: {
414
- folderId: v.optional(v.string()),
415
- type: v.optional(mediaTypeValidator),
416
- search: v.optional(v.string()),
417
- paginationOpts: paginationOptsValidator,
418
- },
419
- returns: v.any(),
420
- handler: async (ctx, args) => {
421
- await checkAuth(ctx, { type: "listMediaAssets" });
422
- return await ctx.runQuery(component.mediaAssets.list, {
423
- folderId: args.folderId,
424
- type: args.type,
425
- search: args.search,
426
- paginationOpts: args.paginationOpts,
427
- });
428
- },
429
- }),
430
- getMediaAsset: queryGeneric({
431
- args: {
432
- id: v.string(),
433
- },
434
- returns: v.union(v.any(), v.null()),
435
- handler: async (ctx, args) => {
436
- await checkAuth(ctx, { type: "getMediaAsset", id: args.id });
437
- return await ctx.runQuery(component.mediaAssets.get, {
438
- id: args.id,
439
- });
440
- },
441
- }),
442
- createMediaAsset: mutationGeneric({
443
- args: {
444
- storageId: v.string(),
445
- name: v.string(),
446
- mimeType: v.string(),
447
- size: v.number(),
448
- parentId: v.optional(v.string()),
449
- width: v.optional(v.number()),
450
- height: v.optional(v.number()),
451
- title: v.optional(v.string()),
452
- description: v.optional(v.string()),
453
- altText: v.optional(v.string()),
454
- createdBy: v.optional(v.string()),
455
- },
456
- returns: v.any(),
457
- handler: async (ctx, args) => {
458
- await checkAuth(ctx, { type: "createMediaAsset" });
459
- return await ctx.runMutation(component.mediaAssetMutations.createMediaAsset, {
460
- storageId: args.storageId,
461
- name: args.name,
462
- mimeType: args.mimeType,
463
- size: args.size,
464
- parentId: args.parentId,
465
- width: args.width,
466
- height: args.height,
467
- title: args.title,
468
- description: args.description,
469
- altText: args.altText,
470
- createdBy: args.createdBy,
471
- });
472
- },
473
- }),
474
- updateMediaAsset: mutationGeneric({
475
- args: {
476
- id: v.string(),
477
- name: v.optional(v.string()),
478
- title: v.optional(v.string()),
479
- description: v.optional(v.string()),
480
- altText: v.optional(v.string()),
481
- parentId: v.optional(v.string()),
482
- tags: v.optional(v.array(v.string())),
483
- },
484
- returns: v.any(),
485
- handler: async (ctx, args) => {
486
- await checkAuth(ctx, { type: "updateMediaAsset", id: args.id });
487
- return await ctx.runMutation(component.mediaAssetMutations.updateMediaAsset, {
488
- id: args.id,
489
- name: args.name,
490
- title: args.title,
491
- description: args.description,
492
- altText: args.altText,
493
- parentId: args.parentId,
494
- tags: args.tags,
495
- });
496
- },
497
- }),
498
- deleteMediaAsset: mutationGeneric({
499
- args: {
500
- id: v.string(),
501
- hardDelete: v.optional(v.boolean()),
502
- deletedBy: v.optional(v.string()),
503
- },
504
- returns: v.any(),
505
- handler: async (ctx, args) => {
506
- await checkAuth(ctx, { type: "deleteMediaAsset", id: args.id });
507
- return await ctx.runMutation(component.mediaAssetMutations.deleteMediaAsset, {
508
- id: args.id,
509
- hardDelete: args.hardDelete,
510
- deletedBy: args.deletedBy,
511
- });
512
- },
513
- }),
514
- restoreMediaAsset: mutationGeneric({
515
- args: {
516
- id: v.string(),
517
- },
518
- returns: v.any(),
519
- handler: async (ctx, args) => {
520
- await checkAuth(ctx, { type: "restoreMediaAsset", id: args.id });
521
- return await ctx.runMutation(component.mediaAssetMutations.restoreMediaAsset, {
522
- id: args.id,
523
- });
524
- },
525
- }),
526
- moveMediaAssets: mutationGeneric({
527
- args: {
528
- assetIds: v.array(v.string()),
529
- targetFolderId: v.optional(v.string()),
530
- },
531
- returns: v.any(),
532
- handler: async (ctx, args) => {
533
- await checkAuth(ctx, { type: "moveMediaAssets" });
534
- return await ctx.runMutation(component.mediaAssetMutations.moveMediaAssets, {
535
- assetIds: args.assetIds,
536
- targetFolderId: args.targetFolderId,
537
- });
538
- },
539
- }),
540
- // =========================================================================
541
- // Media Folders
542
- // =========================================================================
543
- listMediaFolders: queryGeneric({
544
- args: {
545
- parentId: v.optional(v.string()),
546
- },
547
- returns: v.array(v.any()),
548
- handler: async (ctx, args) => {
549
- await checkAuth(ctx, { type: "listMediaFolders" });
550
- return await ctx.runQuery(component.mediaFolderMutations.listMediaFolders, {
551
- parentId: args.parentId,
552
- });
553
- },
554
- }),
555
- getMediaFolder: queryGeneric({
556
- args: {
557
- id: v.string(),
558
- },
559
- returns: v.union(v.any(), v.null()),
560
- handler: async (ctx, args) => {
561
- await checkAuth(ctx, { type: "getMediaFolder", id: args.id });
562
- return await ctx.runQuery(component.mediaFolderMutations.getMediaFolder, {
563
- id: args.id,
564
- });
565
- },
566
- }),
567
- getMediaFolderTree: queryGeneric({
568
- args: {},
569
- returns: v.array(v.any()),
570
- handler: async (ctx) => {
571
- await checkAuth(ctx, { type: "getMediaFolderTree" });
572
- return await ctx.runQuery(component.mediaFolderMutations.getFolderTree, {});
573
- },
574
- }),
575
- createMediaFolder: mutationGeneric({
576
- args: {
577
- name: v.string(),
578
- parentId: v.optional(v.string()),
579
- description: v.optional(v.string()),
580
- createdBy: v.optional(v.string()),
581
- },
582
- returns: v.any(),
583
- handler: async (ctx, args) => {
584
- await checkAuth(ctx, { type: "createMediaFolder" });
585
- return await ctx.runMutation(component.mediaFolderMutations.createMediaFolder, {
586
- name: args.name,
587
- parentId: args.parentId,
588
- description: args.description,
589
- createdBy: args.createdBy,
590
- });
591
- },
592
- }),
593
- updateMediaFolder: mutationGeneric({
594
- args: {
595
- id: v.string(),
596
- name: v.optional(v.string()),
597
- description: v.optional(v.string()),
598
- sortOrder: v.optional(v.number()),
599
- },
600
- returns: v.any(),
601
- handler: async (ctx, args) => {
602
- await checkAuth(ctx, { type: "updateMediaFolder", id: args.id });
603
- return await ctx.runMutation(component.mediaFolderMutations.updateMediaFolder, {
604
- id: args.id,
605
- name: args.name,
606
- description: args.description,
607
- sortOrder: args.sortOrder,
608
- });
609
- },
610
- }),
611
- moveMediaFolder: mutationGeneric({
612
- args: {
613
- id: v.string(),
614
- newParentId: v.optional(v.string()),
615
- },
616
- returns: v.any(),
617
- handler: async (ctx, args) => {
618
- await checkAuth(ctx, { type: "moveMediaFolder", id: args.id });
619
- return await ctx.runMutation(component.mediaFolderMutations.moveMediaFolder, {
620
- id: args.id,
621
- newParentId: args.newParentId,
622
- });
623
- },
624
- }),
625
- deleteMediaFolder: mutationGeneric({
626
- args: {
627
- id: v.string(),
628
- recursive: v.optional(v.boolean()),
629
- hardDelete: v.optional(v.boolean()),
630
- deletedBy: v.optional(v.string()),
631
- },
632
- returns: v.any(),
633
- handler: async (ctx, args) => {
634
- await checkAuth(ctx, { type: "deleteMediaFolder", id: args.id });
635
- return await ctx.runMutation(component.mediaFolderMutations.deleteMediaFolder, {
636
- id: args.id,
637
- recursive: args.recursive,
638
- hardDelete: args.hardDelete,
639
- deletedBy: args.deletedBy,
640
- });
641
- },
642
- }),
643
- restoreMediaFolder: mutationGeneric({
644
- args: {
645
- id: v.string(),
646
- recursive: v.optional(v.boolean()),
647
- },
648
- returns: v.any(),
649
- handler: async (ctx, args) => {
650
- await checkAuth(ctx, { type: "restoreMediaFolder", id: args.id });
651
- return await ctx.runMutation(component.mediaFolderMutations.restoreMediaFolder, {
652
- id: args.id,
653
- recursive: args.recursive,
654
- });
655
- },
656
- }),
657
- // =========================================================================
658
- // Upload
659
- // =========================================================================
660
- generateUploadUrl: mutationGeneric({
661
- args: {},
662
- returns: v.string(),
663
- handler: async (ctx) => {
664
- await checkAuth(ctx, { type: "generateUploadUrl" });
665
- return await ctx.storage.generateUploadUrl();
666
- },
667
- }),
668
- // =========================================================================
669
- // Dashboard Stats
670
- // =========================================================================
671
- getDashboardStats: queryGeneric({
672
- args: {},
673
- returns: v.object({
674
- contentTypes: v.object({
675
- total: v.number(),
676
- active: v.number(),
677
- }),
678
- entries: v.object({
679
- total: v.number(),
680
- published: v.number(),
681
- draft: v.number(),
682
- scheduled: v.number(),
683
- }),
684
- media: v.object({
685
- total: v.number(),
686
- images: v.number(),
687
- videos: v.number(),
688
- documents: v.number(),
689
- }),
690
- }),
691
- handler: async (ctx) => {
692
- await checkAuth(ctx, { type: "getDashboardStats" });
693
- const contentTypesResult = await ctx.runQuery(component.contentTypes.list, {});
694
- const contentTypes = contentTypesResult.page || [];
695
- const entriesResult = await ctx.runQuery(component.contentEntries.list, {
696
- paginationOpts: { numItems: 1000, cursor: null },
697
- });
698
- const mediaResult = await ctx.runQuery(component.mediaAssets.list, {
699
- paginationOpts: { numItems: 1000, cursor: null },
700
- });
701
- const activeContentTypes = contentTypes.filter((ct) => ct.isActive).length;
702
- const entries = entriesResult.page || [];
703
- const publishedEntries = entries.filter((e) => e.status === "published").length;
704
- const draftEntries = entries.filter((e) => e.status === "draft").length;
705
- const scheduledEntries = entries.filter((e) => e.status === "scheduled").length;
706
- const mediaAssets = (mediaResult.page || []);
707
- const assets = mediaAssets.filter((m) => m.kind === "asset");
708
- const images = assets.filter((m) => m.mimeType?.startsWith("image/")).length;
709
- const videos = assets.filter((m) => m.mimeType?.startsWith("video/")).length;
710
- const documents = assets.filter((m) => m.mimeType?.startsWith("application/pdf") ||
711
- m.mimeType?.includes("document") ||
712
- m.mimeType?.includes("sheet") ||
713
- m.mimeType?.includes("presentation")).length;
714
- return {
715
- contentTypes: {
716
- total: contentTypes.length,
717
- active: activeContentTypes,
718
- },
719
- entries: {
720
- total: entries.length,
721
- published: publishedEntries,
722
- draft: draftEntries,
723
- scheduled: scheduledEntries,
724
- },
725
- media: {
726
- total: mediaAssets.length,
727
- images,
728
- videos,
729
- documents,
730
- },
731
- };
732
- },
733
- }),
734
- };
735
- }
736
- //# sourceMappingURL=adminApi.js.map