convex-cms 0.0.3 → 0.0.5-alpha.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 (142) hide show
  1. package/README.md +109 -13
  2. package/admin-dist/nitro.json +1 -1
  3. package/admin-dist/public/assets/{CmsEmptyState-CRswfTzk.js → CmsEmptyState-CiMQwSQV.js} +2 -2
  4. package/admin-dist/public/assets/{CmsPageHeader-CirpXndm.js → CmsPageHeader-ohOq0luT.js} +1 -1
  5. package/admin-dist/public/assets/{CmsStatusBadge-CbEUpQu-.js → CmsStatusBadge-BdNf0V9v.js} +1 -1
  6. package/admin-dist/public/assets/CmsSurface-CWup6Jh7.js +1 -0
  7. package/admin-dist/public/assets/{CmsToolbar-BI2nZOXp.js → CmsToolbar-cEBlCHa3.js} +1 -1
  8. package/admin-dist/public/assets/{ContentEntryEditor-CBeCyK_m.js → ContentEntryEditor-BY5ypfUs.js} +1 -1
  9. package/admin-dist/public/assets/{ErrorState-BIVaWmom.js → ErrorState-C4nJ-ml4.js} +1 -1
  10. package/admin-dist/public/assets/{TaxonomyFilter-ChaY6Y_x.js → TaxonomyFilter-BgE_SR_O.js} +1 -1
  11. package/admin-dist/public/assets/{_contentTypeId-DQ8k_Rvw.js → _contentTypeId-DtZectcC.js} +1 -1
  12. package/admin-dist/public/assets/{_entryId-CKU_glsK.js → _entryId-BpSmrfAm.js} +1 -1
  13. package/admin-dist/public/assets/alert-Bf2l8kxw.js +1 -0
  14. package/admin-dist/public/assets/{badge-hvUOzpVZ.js → badge-qPrc4AUM.js} +1 -1
  15. package/admin-dist/public/assets/{circle-check-big-CF_pR17r.js → circle-check-big-Dgozy3vV.js} +1 -1
  16. package/admin-dist/public/assets/{command-DU82cJlt.js → command-QOmNhlb0.js} +1 -1
  17. package/admin-dist/public/assets/content-OEBGlxg1.js +1 -0
  18. package/admin-dist/public/assets/content-types-CjQliqVV.js +2 -0
  19. package/admin-dist/public/assets/{globals-CS6BZ0zp.css → globals-hAmgC66w.css} +1 -1
  20. package/admin-dist/public/assets/index-BH_ECMhv.js +1 -0
  21. package/admin-dist/public/assets/{label-KNtpL71g.js → label-DCsUdvFh.js} +1 -1
  22. package/admin-dist/public/assets/{link-2-Bw2aI4V4.js → link-2-Czw1N61H.js} +1 -1
  23. package/admin-dist/public/assets/{list-sYepHjt_.js → list-DtCsXj8-.js} +1 -1
  24. package/admin-dist/public/assets/{main-CKj5yfEi.js → main-CXgkZMhe.js} +3 -3
  25. package/admin-dist/public/assets/{media-Bkrkffm7.js → media-DTJ3-ViE.js} +1 -1
  26. package/admin-dist/public/assets/{new._contentTypeId-C3LstjNs.js → new._contentTypeId-CoTDxKzf.js} +1 -1
  27. package/admin-dist/public/assets/{plus-DUn8v_Xf.js → plus-xCFJK0RC.js} +1 -1
  28. package/admin-dist/public/assets/{rotate-ccw-DJEoHcRI.js → rotate-ccw-DIqK63wY.js} +1 -1
  29. package/admin-dist/public/assets/scroll-area-B-yrE66a.js +1 -0
  30. package/admin-dist/public/assets/{search-MuAUDJKR.js → search-CbCbboeU.js} +1 -1
  31. package/admin-dist/public/assets/select-Co3TZFJb.js +1 -0
  32. package/admin-dist/public/assets/settings-BspTTv_o.js +1 -0
  33. package/admin-dist/public/assets/switch-CfavASmR.js +1 -0
  34. package/admin-dist/public/assets/tabs-CN5s5u2W.js +1 -0
  35. package/admin-dist/public/assets/tanstack-adapter-npeE3RdY.js +1 -0
  36. package/admin-dist/public/assets/taxonomies-CgG46fIF.js +1 -0
  37. package/admin-dist/public/assets/{textarea-BTy7nwzR.js → textarea-BJ0XFZpT.js} +1 -1
  38. package/admin-dist/public/assets/trash-B3daldm5.js +1 -0
  39. package/admin-dist/public/assets/{triangle-alert-E52Vfeuh.js → triangle-alert-BZRcqsUg.js} +1 -1
  40. package/admin-dist/public/assets/useBreadcrumbLabel-DwZlwvFF.js +1 -0
  41. package/admin-dist/public/assets/{usePermissions-Basjs9BT.js → usePermissions-C1JQhfqb.js} +1 -1
  42. package/admin-dist/server/_chunks/_libs/@tanstack/react-router.mjs +7 -0
  43. package/admin-dist/server/_ssr/{badge-6BsP37vG.mjs → CmsButton-B45JAKR1.mjs} +33 -33
  44. package/admin-dist/server/_ssr/{CmsEmptyState-DU7-7-mV.mjs → CmsEmptyState-D_BQFAVR.mjs} +2 -2
  45. package/admin-dist/server/_ssr/{CmsPageHeader-CseW0AHm.mjs → CmsPageHeader-CrUZA59A.mjs} +1 -1
  46. package/admin-dist/server/_ssr/{CmsStatusBadge-B_pi4KCp.mjs → CmsStatusBadge-B-sj6yaj.mjs} +2 -2
  47. package/admin-dist/server/_ssr/CmsSurface-DKJZhpjk.mjs +44 -0
  48. package/admin-dist/server/_ssr/{CmsToolbar-X75ex6ek.mjs → CmsToolbar-ByaW5iXf.mjs} +2 -2
  49. package/admin-dist/server/_ssr/{ContentEntryEditor-CepusRsA.mjs → ContentEntryEditor-D3_Jb1dq.mjs} +11 -11
  50. package/admin-dist/server/_ssr/{TaxonomyFilter-Bwrq0-cz.mjs → TaxonomyFilter-BRJkuCtA.mjs} +4 -4
  51. package/admin-dist/server/_ssr/{_contentTypeId-BqYKEcLr.mjs → _contentTypeId-B9kA6CaM.mjs} +11 -11
  52. package/admin-dist/server/_ssr/{_entryId-CRfnqeDf.mjs → _entryId-BddcMkZN.mjs} +14 -14
  53. package/admin-dist/server/_ssr/_tanstack-start-manifest_v-Dd7AmelK.mjs +4 -0
  54. package/admin-dist/server/_ssr/{command-fy8epIKf.mjs → command-CGtVr8Gb.mjs} +1 -1
  55. package/admin-dist/server/_ssr/{content-B5RhL7uW.mjs → content-D1tbeOd0.mjs} +201 -86
  56. package/admin-dist/server/_ssr/{content-types-BIOqCQYN.mjs → content-types-BZqY_BER.mjs} +279 -103
  57. package/admin-dist/server/_ssr/{index-DHSHDPt1.mjs → index-BIdq4xaC.mjs} +88 -17
  58. package/admin-dist/server/_ssr/index.mjs +2 -2
  59. package/admin-dist/server/_ssr/{label-C8Dko1j7.mjs → label-T-QNKAr6.mjs} +1 -1
  60. package/admin-dist/server/_ssr/{media-CSx3XttC.mjs → media-C-xqjBrl.mjs} +40 -40
  61. package/admin-dist/server/_ssr/{new._contentTypeId-DzanEZQM.mjs → new._contentTypeId-DWic9cRq.mjs} +13 -13
  62. package/admin-dist/server/_ssr/{router-DDWcF-kt.mjs → router-D1BMAMJT.mjs} +11 -11
  63. package/admin-dist/server/_ssr/{scroll-area-bjPYwhXN.mjs → scroll-area-C0pic_WA.mjs} +1 -1
  64. package/admin-dist/server/_ssr/{select-BUhDDf4T.mjs → select-CqmuN2F6.mjs} +1 -1
  65. package/admin-dist/server/_ssr/{settings-DAsxnw2q.mjs → settings-CAkncGGV.mjs} +211 -129
  66. package/admin-dist/server/_ssr/{switch-BgyRtQ1Z.mjs → switch-CgmuJkT9.mjs} +1 -1
  67. package/admin-dist/server/_ssr/{tabs-DzMdRB1A.mjs → tabs-CnMj0aRy.mjs} +5 -3
  68. package/admin-dist/server/_ssr/tanstack-adapter-BXZrMauE.mjs +119 -0
  69. package/admin-dist/server/_ssr/{taxonomies-C8j8g5Q5.mjs → taxonomies-thl3BfVm.mjs} +168 -68
  70. package/admin-dist/server/_ssr/{textarea-9jNeYJSc.mjs → textarea-4K5OJgeh.mjs} +1 -1
  71. package/admin-dist/server/_ssr/{trash-DYMxwhZB.mjs → trash-B40Gx5zP.mjs} +206 -86
  72. package/admin-dist/server/_ssr/{useBreadcrumbLabel-FNSAr2Ha.mjs → useBreadcrumbLabel-rn-fL4zV.mjs} +1 -1
  73. package/admin-dist/server/_ssr/{usePermissions-BJGGahrJ.mjs → usePermissions-CKeM6_Vw.mjs} +1 -1
  74. package/admin-dist/server/index.mjs +194 -180
  75. package/dist/cli/commands/init.d.ts +6 -0
  76. package/dist/cli/commands/init.d.ts.map +1 -0
  77. package/dist/cli/commands/init.js +156 -0
  78. package/dist/cli/commands/init.js.map +1 -0
  79. package/dist/cli/index.js +6 -0
  80. package/dist/cli/index.js.map +1 -1
  81. package/dist/client/admin-config.d.ts +2 -2
  82. package/dist/client/admin-config.js +2 -2
  83. package/dist/client/adminApi.d.ts +1877 -1851
  84. package/dist/client/adminApi.d.ts.map +1 -1
  85. package/dist/client/adminApi.js +649 -629
  86. package/dist/client/adminApi.js.map +1 -1
  87. package/dist/client/agentTools.d.ts +7 -17
  88. package/dist/client/agentTools.d.ts.map +1 -1
  89. package/dist/client/agentTools.js +4 -4
  90. package/dist/client/index.d.ts +4 -4
  91. package/dist/client/index.d.ts.map +1 -1
  92. package/dist/client/index.js +4 -4
  93. package/dist/client/index.js.map +1 -1
  94. package/dist/client/schema/codegen.d.ts +2 -2
  95. package/dist/client/schema/codegen.d.ts.map +1 -1
  96. package/dist/client/schema/codegen.js +3 -3
  97. package/dist/client/schema/codegen.js.map +1 -1
  98. package/dist/client/schema/defineContentType.d.ts +3 -3
  99. package/dist/client/schema/defineContentType.js +3 -3
  100. package/dist/client/schema/index.d.ts +7 -7
  101. package/dist/client/schema/index.d.ts.map +1 -1
  102. package/dist/client/schema/index.js +5 -5
  103. package/dist/client/schema/index.js.map +1 -1
  104. package/dist/client/schema/schemaDrift.d.ts +1 -1
  105. package/dist/client/schema/schemaDrift.js +1 -1
  106. package/dist/client/schema/typedClient.d.ts +2 -2
  107. package/dist/client/schema/typedClient.js +2 -2
  108. package/dist/client/schema/types.d.ts +1 -1
  109. package/dist/client/schema/types.js +1 -1
  110. package/dist/client/wrapper.d.ts +108 -65
  111. package/dist/client/wrapper.d.ts.map +1 -1
  112. package/dist/client/wrapper.js +22 -22
  113. package/dist/client/wrapper.js.map +1 -1
  114. package/dist/component/convex.config.d.ts +2 -2
  115. package/dist/component/convex.config.js +2 -2
  116. package/dist/component/index.d.ts +1 -1
  117. package/dist/component/index.js +1 -1
  118. package/dist/component/lib/ragContentChunker.d.ts +1 -1
  119. package/dist/component/lib/ragContentChunker.js +1 -1
  120. package/dist/component/roles.d.ts +1 -1
  121. package/dist/component/roles.js +1 -1
  122. package/dist/react/index.d.ts +2 -2
  123. package/dist/react/index.d.ts.map +1 -1
  124. package/dist/react/index.js +13 -7
  125. package/dist/react/index.js.map +1 -1
  126. package/dist/test.d.ts +2 -2
  127. package/dist/test.js +2 -2
  128. package/package.json +31 -11
  129. package/admin-dist/public/assets/alert-BXjTqrwQ.js +0 -1
  130. package/admin-dist/public/assets/content-_LXl3pp7.js +0 -1
  131. package/admin-dist/public/assets/content-types-KjxaXGxY.js +0 -2
  132. package/admin-dist/public/assets/index-DNGIZHL-.js +0 -1
  133. package/admin-dist/public/assets/scroll-area-DfIlT0in.js +0 -1
  134. package/admin-dist/public/assets/select-BD29IXCI.js +0 -1
  135. package/admin-dist/public/assets/settings-DmMyn_6A.js +0 -1
  136. package/admin-dist/public/assets/switch-h3Rrnl5i.js +0 -1
  137. package/admin-dist/public/assets/tabs-imc8h-Dp.js +0 -1
  138. package/admin-dist/public/assets/taxonomies-dAsrT65H.js +0 -1
  139. package/admin-dist/public/assets/trash-SAWKZZHv.js +0 -1
  140. package/admin-dist/public/assets/useBreadcrumbLabel-BECBMCzM.js +0 -1
  141. package/admin-dist/server/_ssr/_tanstack-start-manifest_v-BwDlABVk.mjs +0 -4
  142. package/admin-dist/server/_ssr/alert-CVt45UUP.mjs +0 -92
@@ -1,11 +1,12 @@
1
- import { r as reactExports, j as jsxRuntimeExports } from "../_chunks/_libs/react.mjs";
2
- import { a as api, c as cn } from "./router-DDWcF-kt.mjs";
3
- import { C as CmsPageHeader } from "./CmsPageHeader-CseW0AHm.mjs";
4
- import { C as CmsToolbar } from "./CmsToolbar-X75ex6ek.mjs";
5
- import { I as Input, C as CmsEmptyState, a as Checkbox, b as CmsConfirmDialog } from "./CmsEmptyState-DU7-7-mV.mjs";
6
- import { C as CmsSurface, A as Alert, a as AlertDescription } from "./alert-CVt45UUP.mjs";
7
- import { C as CmsButton, B as Badge } from "./badge-6BsP37vG.mjs";
8
- import { S as Select, a as SelectTrigger, b as SelectValue, c as SelectContent, d as SelectItem } from "./select-BUhDDf4T.mjs";
1
+ import { j as jsxRuntimeExports, r as reactExports } from "../_chunks/_libs/react.mjs";
2
+ import { a as api, c as cn } from "./router-D1BMAMJT.mjs";
3
+ import { C as CmsButton, B as Badge } from "./CmsButton-B45JAKR1.mjs";
4
+ import { u as useTanStackNavigation, A as Alert, a as AlertDescription } from "./tanstack-adapter-BXZrMauE.mjs";
5
+ import { C as CmsPageHeader } from "./CmsPageHeader-CrUZA59A.mjs";
6
+ import { C as CmsToolbar } from "./CmsToolbar-ByaW5iXf.mjs";
7
+ import { I as Input, C as CmsEmptyState, a as Checkbox, b as CmsConfirmDialog } from "./CmsEmptyState-D_BQFAVR.mjs";
8
+ import { C as CmsSurface } from "./CmsSurface-DKJZhpjk.mjs";
9
+ import { S as Select, a as SelectTrigger, b as SelectValue, c as SelectContent, d as SelectItem } from "./select-CqmuN2F6.mjs";
9
10
  import { u as useQuery, d as useMutation } from "../_libs/convex.mjs";
10
11
  import { w as Trash2, N as Search, O as TriangleAlert, X, R as RotateCcw } from "../_libs/lucide-react.mjs";
11
12
  import "../_chunks/_libs/@tanstack/react-router.mjs";
@@ -83,7 +84,7 @@ import "../_chunks/_libs/@radix-ui/react-use-previous.mjs";
83
84
  import "../_chunks/_libs/@radix-ui/react-select.mjs";
84
85
  import "../_chunks/_libs/@radix-ui/number.mjs";
85
86
  import "../_chunks/_libs/@radix-ui/react-visually-hidden.mjs";
86
- function TrashPage() {
87
+ function TrashPage({ api: api2, navigation: _navigation }) {
87
88
  const [selectedContentType, setSelectedContentType] = reactExports.useState("");
88
89
  const [searchQuery, setSearchQuery] = reactExports.useState("");
89
90
  const [selectedItems, setSelectedItems] = reactExports.useState(/* @__PURE__ */ new Set());
@@ -92,20 +93,17 @@ function TrashPage() {
92
93
  const [showEmptyConfirm, setShowEmptyConfirm] = reactExports.useState(false);
93
94
  const [isEmptying, setIsEmptying] = reactExports.useState(false);
94
95
  const [emptyError, setEmptyError] = reactExports.useState(null);
95
- const trashQuery = useQuery(api.trash.list, {
96
+ const trashQuery = useQuery(api2.trash.list, {
96
97
  contentTypeId: selectedContentType || void 0,
97
98
  search: searchQuery || void 0,
98
- paginationOpts: {
99
- numItems: 50,
100
- cursor: null
101
- }
99
+ paginationOpts: { numItems: 50, cursor: null }
102
100
  });
103
- const configQuery = useQuery(api.trash.getConfig, {});
104
- const statsQuery = useQuery(api.trash.getStats, {});
105
- const contentTypesQuery = useQuery(api.contentTypes.list, {});
101
+ const configQuery = useQuery(api2.trash.getConfig, {});
102
+ const statsQuery = useQuery(api2.trash.getStats, {});
103
+ const contentTypesQuery = useQuery(api2.contentTypes.list, {});
106
104
  const contentTypes = contentTypesQuery?.page ?? [];
107
- const restoreMutation = useMutation(api.bulkOperations.bulkRestore);
108
- const emptyMutation = useMutation(api.trash.empty);
105
+ const restoreMutation = useMutation(api2.bulkOperations.bulkRestore);
106
+ const emptyMutation = useMutation(api2.trash.empty);
109
107
  const trashItems = trashQuery?.page ?? [];
110
108
  const isLoading = trashQuery === void 0;
111
109
  const config = configQuery;
@@ -128,25 +126,26 @@ function TrashPage() {
128
126
  setSelectedItems(new Set(trashItems.map((item) => item._id)));
129
127
  }
130
128
  }, [selectedItems.size, trashItems]);
131
- const handleRestore = reactExports.useCallback(async (ids) => {
132
- setIsRestoring(true);
133
- setRestoreError(null);
134
- try {
135
- await restoreMutation({
136
- ids
137
- });
138
- setSelectedItems((prev) => {
139
- const next = new Set(prev);
140
- ids.forEach((id) => next.delete(id));
141
- return next;
142
- });
143
- } catch (error) {
144
- const message = error instanceof Error ? error.message : "Failed to restore";
145
- setRestoreError(message);
146
- } finally {
147
- setIsRestoring(false);
148
- }
149
- }, [restoreMutation]);
129
+ const handleRestore = reactExports.useCallback(
130
+ async (ids) => {
131
+ setIsRestoring(true);
132
+ setRestoreError(null);
133
+ try {
134
+ await restoreMutation({ ids });
135
+ setSelectedItems((prev) => {
136
+ const next = new Set(prev);
137
+ ids.forEach((id) => next.delete(id));
138
+ return next;
139
+ });
140
+ } catch (error) {
141
+ const message = error instanceof Error ? error.message : "Failed to restore";
142
+ setRestoreError(message);
143
+ } finally {
144
+ setIsRestoring(false);
145
+ }
146
+ },
147
+ [restoreMutation]
148
+ );
150
149
  const handleEmptyTrash = reactExports.useCallback(async () => {
151
150
  setIsEmptying(true);
152
151
  setEmptyError(null);
@@ -187,7 +186,13 @@ function TrashPage() {
187
186
  };
188
187
  return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "space-y-6 p-6", children: [
189
188
  /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "flex items-start justify-between", children: [
190
- /* @__PURE__ */ jsxRuntimeExports.jsx(CmsPageHeader, { title: "Trash", description: `Deleted items are kept for ${config?.retentionDays ?? 30} days before permanent deletion` }),
189
+ /* @__PURE__ */ jsxRuntimeExports.jsx(
190
+ CmsPageHeader,
191
+ {
192
+ title: "Trash",
193
+ description: `Deleted items are kept for ${config?.retentionDays ?? 30} days before permanent deletion`
194
+ }
195
+ ),
191
196
  trashItems.length > 0 && /* @__PURE__ */ jsxRuntimeExports.jsxs(CmsButton, { variant: "danger", onClick: () => setShowEmptyConfirm(true), children: [
192
197
  /* @__PURE__ */ jsxRuntimeExports.jsx(Trash2, { className: "size-4" }),
193
198
  "Empty Trash"
@@ -203,31 +208,68 @@ function TrashPage() {
203
208
  /* @__PURE__ */ jsxRuntimeExports.jsx("p", { className: "text-sm text-muted-foreground", children: "Expired" })
204
209
  ] })
205
210
  ] }),
206
- /* @__PURE__ */ jsxRuntimeExports.jsx(CmsToolbar, { left: /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "flex items-center gap-3", children: [
207
- /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "relative", children: [
208
- /* @__PURE__ */ jsxRuntimeExports.jsx(Search, { className: "absolute left-3 top-1/2 size-4 -translate-y-1/2 text-muted-foreground" }),
209
- /* @__PURE__ */ jsxRuntimeExports.jsx(Input, { type: "text", placeholder: "Search deleted items...", value: searchQuery, onChange: (e) => setSearchQuery(e.target.value), className: "w-64 pl-9" })
210
- ] }),
211
- /* @__PURE__ */ jsxRuntimeExports.jsxs(Select, { value: selectedContentType || "all", onValueChange: (v) => setSelectedContentType(v === "all" ? "" : v), children: [
212
- /* @__PURE__ */ jsxRuntimeExports.jsx(SelectTrigger, { className: "w-48", children: /* @__PURE__ */ jsxRuntimeExports.jsx(SelectValue, { placeholder: "All Content Types" }) }),
213
- /* @__PURE__ */ jsxRuntimeExports.jsxs(SelectContent, { children: [
214
- /* @__PURE__ */ jsxRuntimeExports.jsx(SelectItem, { value: "all", children: "All Content Types" }),
215
- contentTypes.map((type) => /* @__PURE__ */ jsxRuntimeExports.jsx(SelectItem, { value: type._id, children: type.displayName }, type._id))
211
+ /* @__PURE__ */ jsxRuntimeExports.jsx(
212
+ CmsToolbar,
213
+ {
214
+ left: /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "flex items-center gap-3", children: [
215
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "relative", children: [
216
+ /* @__PURE__ */ jsxRuntimeExports.jsx(Search, { className: "absolute left-3 top-1/2 size-4 -translate-y-1/2 text-muted-foreground" }),
217
+ /* @__PURE__ */ jsxRuntimeExports.jsx(
218
+ Input,
219
+ {
220
+ type: "text",
221
+ placeholder: "Search deleted items...",
222
+ value: searchQuery,
223
+ onChange: (e) => setSearchQuery(e.target.value),
224
+ className: "w-64 pl-9"
225
+ }
226
+ )
227
+ ] }),
228
+ /* @__PURE__ */ jsxRuntimeExports.jsxs(
229
+ Select,
230
+ {
231
+ value: selectedContentType || "all",
232
+ onValueChange: (v) => setSelectedContentType(v === "all" ? "" : v),
233
+ children: [
234
+ /* @__PURE__ */ jsxRuntimeExports.jsx(SelectTrigger, { className: "w-48", children: /* @__PURE__ */ jsxRuntimeExports.jsx(SelectValue, { placeholder: "All Content Types" }) }),
235
+ /* @__PURE__ */ jsxRuntimeExports.jsxs(SelectContent, { children: [
236
+ /* @__PURE__ */ jsxRuntimeExports.jsx(SelectItem, { value: "all", children: "All Content Types" }),
237
+ contentTypes.map((type) => /* @__PURE__ */ jsxRuntimeExports.jsx(SelectItem, { value: type._id, children: type.displayName }, type._id))
238
+ ] })
239
+ ]
240
+ }
241
+ )
216
242
  ] })
217
- ] })
218
- ] }) }),
243
+ }
244
+ ),
219
245
  restoreError && /* @__PURE__ */ jsxRuntimeExports.jsxs(Alert, { variant: "destructive", children: [
220
246
  /* @__PURE__ */ jsxRuntimeExports.jsx(TriangleAlert, { className: "size-4" }),
221
247
  /* @__PURE__ */ jsxRuntimeExports.jsxs(AlertDescription, { className: "flex items-center justify-between", children: [
222
248
  restoreError,
223
- /* @__PURE__ */ jsxRuntimeExports.jsx(CmsButton, { variant: "ghost", size: "icon-sm", onClick: () => setRestoreError(null), children: /* @__PURE__ */ jsxRuntimeExports.jsx(X, { className: "size-4" }) })
249
+ /* @__PURE__ */ jsxRuntimeExports.jsx(
250
+ CmsButton,
251
+ {
252
+ variant: "ghost",
253
+ size: "icon-sm",
254
+ onClick: () => setRestoreError(null),
255
+ children: /* @__PURE__ */ jsxRuntimeExports.jsx(X, { className: "size-4" })
256
+ }
257
+ )
224
258
  ] })
225
259
  ] }),
226
260
  emptyError && /* @__PURE__ */ jsxRuntimeExports.jsxs(Alert, { variant: "destructive", children: [
227
261
  /* @__PURE__ */ jsxRuntimeExports.jsx(TriangleAlert, { className: "size-4" }),
228
262
  /* @__PURE__ */ jsxRuntimeExports.jsxs(AlertDescription, { className: "flex items-center justify-between", children: [
229
263
  emptyError,
230
- /* @__PURE__ */ jsxRuntimeExports.jsx(CmsButton, { variant: "ghost", size: "icon-sm", onClick: () => setEmptyError(null), children: /* @__PURE__ */ jsxRuntimeExports.jsx(X, { className: "size-4" }) })
264
+ /* @__PURE__ */ jsxRuntimeExports.jsx(
265
+ CmsButton,
266
+ {
267
+ variant: "ghost",
268
+ size: "icon-sm",
269
+ onClick: () => setEmptyError(null),
270
+ children: /* @__PURE__ */ jsxRuntimeExports.jsx(X, { className: "size-4" })
271
+ }
272
+ )
231
273
  ] })
232
274
  ] }),
233
275
  selectedItems.size > 0 && /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "flex items-center gap-3 rounded-lg border border-primary/20 bg-primary/5 p-3", children: [
@@ -237,18 +279,48 @@ function TrashPage() {
237
279
  selectedItems.size === 1 ? "item" : "items",
238
280
  " selected"
239
281
  ] }),
240
- /* @__PURE__ */ jsxRuntimeExports.jsxs(CmsButton, { variant: "primary", size: "sm", onClick: () => handleRestore(Array.from(selectedItems)), loading: isRestoring, children: [
241
- /* @__PURE__ */ jsxRuntimeExports.jsx(RotateCcw, { className: "size-4" }),
242
- "Restore Selected"
243
- ] }),
244
- /* @__PURE__ */ jsxRuntimeExports.jsx(CmsButton, { variant: "secondary", size: "sm", onClick: () => setSelectedItems(/* @__PURE__ */ new Set()), children: "Clear Selection" })
282
+ /* @__PURE__ */ jsxRuntimeExports.jsxs(
283
+ CmsButton,
284
+ {
285
+ variant: "primary",
286
+ size: "sm",
287
+ onClick: () => handleRestore(Array.from(selectedItems)),
288
+ loading: isRestoring,
289
+ children: [
290
+ /* @__PURE__ */ jsxRuntimeExports.jsx(RotateCcw, { className: "size-4" }),
291
+ "Restore Selected"
292
+ ]
293
+ }
294
+ ),
295
+ /* @__PURE__ */ jsxRuntimeExports.jsx(
296
+ CmsButton,
297
+ {
298
+ variant: "secondary",
299
+ size: "sm",
300
+ onClick: () => setSelectedItems(/* @__PURE__ */ new Set()),
301
+ children: "Clear Selection"
302
+ }
303
+ )
245
304
  ] }),
246
305
  isLoading ? /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "flex flex-col items-center justify-center py-12", children: [
247
306
  /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "size-8 animate-spin rounded-full border-2 border-muted border-t-primary" }),
248
307
  /* @__PURE__ */ jsxRuntimeExports.jsx("p", { className: "mt-4 text-sm text-muted-foreground", children: "Loading trash..." })
249
- ] }) : trashItems.length === 0 ? /* @__PURE__ */ jsxRuntimeExports.jsx(CmsEmptyState, { icon: /* @__PURE__ */ jsxRuntimeExports.jsx(Trash2, { className: "size-6" }), title: "Trash is empty", description: "Deleted items will appear here" }) : /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "rounded-lg border bg-card", children: /* @__PURE__ */ jsxRuntimeExports.jsxs("table", { className: "w-full", children: [
308
+ ] }) : trashItems.length === 0 ? /* @__PURE__ */ jsxRuntimeExports.jsx(
309
+ CmsEmptyState,
310
+ {
311
+ icon: /* @__PURE__ */ jsxRuntimeExports.jsx(Trash2, { className: "size-6" }),
312
+ title: "Trash is empty",
313
+ description: "Deleted items will appear here"
314
+ }
315
+ ) : /* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "rounded-lg border bg-card", children: /* @__PURE__ */ jsxRuntimeExports.jsxs("table", { className: "w-full", children: [
250
316
  /* @__PURE__ */ jsxRuntimeExports.jsx("thead", { children: /* @__PURE__ */ jsxRuntimeExports.jsxs("tr", { className: "border-b", children: [
251
- /* @__PURE__ */ jsxRuntimeExports.jsx("th", { className: "w-10 p-3 text-left", children: /* @__PURE__ */ jsxRuntimeExports.jsx(Checkbox, { checked: selectedItems.size === trashItems.length && trashItems.length > 0, onCheckedChange: handleSelectAll }) }),
317
+ /* @__PURE__ */ jsxRuntimeExports.jsx("th", { className: "w-10 p-3 text-left", children: /* @__PURE__ */ jsxRuntimeExports.jsx(
318
+ Checkbox,
319
+ {
320
+ checked: selectedItems.size === trashItems.length && trashItems.length > 0,
321
+ onCheckedChange: handleSelectAll
322
+ }
323
+ ) }),
252
324
  /* @__PURE__ */ jsxRuntimeExports.jsx("th", { className: "p-3 text-left text-sm font-medium text-muted-foreground", children: "Name" }),
253
325
  /* @__PURE__ */ jsxRuntimeExports.jsx("th", { className: "p-3 text-left text-sm font-medium text-muted-foreground", children: "Type" }),
254
326
  /* @__PURE__ */ jsxRuntimeExports.jsx("th", { className: "p-3 text-left text-sm font-medium text-muted-foreground", children: "Deleted" }),
@@ -257,35 +329,83 @@ function TrashPage() {
257
329
  ] }) }),
258
330
  /* @__PURE__ */ jsxRuntimeExports.jsx("tbody", { children: trashItems.map((item) => {
259
331
  const daysLeft = getDaysUntilDeletion(item.deletedAt);
260
- return /* @__PURE__ */ jsxRuntimeExports.jsxs("tr", { className: cn("border-b last:border-0 transition-colors hover:bg-muted/50", selectedItems.has(item._id) && "bg-primary/5"), children: [
261
- /* @__PURE__ */ jsxRuntimeExports.jsx("td", { className: "p-3", children: /* @__PURE__ */ jsxRuntimeExports.jsx(Checkbox, { checked: selectedItems.has(item._id), onCheckedChange: (checked) => handleSelectItem(item._id, checked) }) }),
262
- /* @__PURE__ */ jsxRuntimeExports.jsxs("td", { className: "p-3", children: [
263
- /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: "font-medium text-foreground", children: getItemTitle(item) }),
264
- item.slug && /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: "block text-xs text-muted-foreground", children: item.slug })
265
- ] }),
266
- /* @__PURE__ */ jsxRuntimeExports.jsx("td", { className: "p-3 text-sm text-muted-foreground", children: item.contentTypeName || "Unknown" }),
267
- /* @__PURE__ */ jsxRuntimeExports.jsxs("td", { className: "p-3", children: [
268
- /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: "text-sm text-muted-foreground", children: formatDate(item.deletedAt) }),
269
- item.deletedBy && /* @__PURE__ */ jsxRuntimeExports.jsxs("span", { className: "block text-xs text-muted-foreground", children: [
270
- "by ",
271
- item.deletedBy
272
- ] })
273
- ] }),
274
- /* @__PURE__ */ jsxRuntimeExports.jsx("td", { className: "p-3", children: daysLeft !== null && /* @__PURE__ */ jsxRuntimeExports.jsxs(Badge, { variant: daysLeft <= 3 ? "destructive" : "secondary", className: "font-normal", children: [
275
- daysLeft,
276
- " ",
277
- daysLeft === 1 ? "day" : "days"
278
- ] }) }),
279
- /* @__PURE__ */ jsxRuntimeExports.jsx("td", { className: "p-3", children: /* @__PURE__ */ jsxRuntimeExports.jsxs(CmsButton, { variant: "outline", size: "sm", onClick: () => handleRestore([item._id]), loading: isRestoring, children: [
280
- /* @__PURE__ */ jsxRuntimeExports.jsx(RotateCcw, { className: "size-4" }),
281
- "Restore"
282
- ] }) })
283
- ] }, item._id);
332
+ return /* @__PURE__ */ jsxRuntimeExports.jsxs(
333
+ "tr",
334
+ {
335
+ className: cn(
336
+ "border-b last:border-0 transition-colors hover:bg-muted/50",
337
+ selectedItems.has(item._id) && "bg-primary/5"
338
+ ),
339
+ children: [
340
+ /* @__PURE__ */ jsxRuntimeExports.jsx("td", { className: "p-3", children: /* @__PURE__ */ jsxRuntimeExports.jsx(
341
+ Checkbox,
342
+ {
343
+ checked: selectedItems.has(item._id),
344
+ onCheckedChange: (checked) => handleSelectItem(item._id, checked)
345
+ }
346
+ ) }),
347
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("td", { className: "p-3", children: [
348
+ /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: "font-medium text-foreground", children: getItemTitle(item) }),
349
+ item.slug && /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: "block text-xs text-muted-foreground", children: item.slug })
350
+ ] }),
351
+ /* @__PURE__ */ jsxRuntimeExports.jsx("td", { className: "p-3 text-sm text-muted-foreground", children: item.contentTypeName || "Unknown" }),
352
+ /* @__PURE__ */ jsxRuntimeExports.jsxs("td", { className: "p-3", children: [
353
+ /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: "text-sm text-muted-foreground", children: formatDate(item.deletedAt) }),
354
+ item.deletedBy && /* @__PURE__ */ jsxRuntimeExports.jsxs("span", { className: "block text-xs text-muted-foreground", children: [
355
+ "by ",
356
+ item.deletedBy
357
+ ] })
358
+ ] }),
359
+ /* @__PURE__ */ jsxRuntimeExports.jsx("td", { className: "p-3", children: daysLeft !== null && /* @__PURE__ */ jsxRuntimeExports.jsxs(
360
+ Badge,
361
+ {
362
+ variant: daysLeft <= 3 ? "destructive" : "secondary",
363
+ className: "font-normal",
364
+ children: [
365
+ daysLeft,
366
+ " ",
367
+ daysLeft === 1 ? "day" : "days"
368
+ ]
369
+ }
370
+ ) }),
371
+ /* @__PURE__ */ jsxRuntimeExports.jsx("td", { className: "p-3", children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
372
+ CmsButton,
373
+ {
374
+ variant: "outline",
375
+ size: "sm",
376
+ onClick: () => handleRestore([item._id]),
377
+ loading: isRestoring,
378
+ children: [
379
+ /* @__PURE__ */ jsxRuntimeExports.jsx(RotateCcw, { className: "size-4" }),
380
+ "Restore"
381
+ ]
382
+ }
383
+ ) })
384
+ ]
385
+ },
386
+ item._id
387
+ );
284
388
  }) })
285
389
  ] }) }),
286
- /* @__PURE__ */ jsxRuntimeExports.jsx(CmsConfirmDialog, { open: showEmptyConfirm, onOpenChange: setShowEmptyConfirm, title: "Empty Trash", description: "This will permanently delete all items in the trash. This action cannot be undone.", confirmLabel: isEmptying ? "Deleting..." : "Empty Trash", onConfirm: handleEmptyTrash, variant: "danger", loading: isEmptying })
390
+ /* @__PURE__ */ jsxRuntimeExports.jsx(
391
+ CmsConfirmDialog,
392
+ {
393
+ open: showEmptyConfirm,
394
+ onOpenChange: setShowEmptyConfirm,
395
+ title: "Empty Trash",
396
+ description: "This will permanently delete all items in the trash. This action cannot be undone.",
397
+ confirmLabel: isEmptying ? "Deleting..." : "Empty Trash",
398
+ onConfirm: handleEmptyTrash,
399
+ variant: "danger",
400
+ loading: isEmptying
401
+ }
402
+ )
287
403
  ] });
288
404
  }
405
+ function TrashRoute() {
406
+ const navigation = useTanStackNavigation();
407
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(TrashPage, { api, navigation });
408
+ }
289
409
  export {
290
- TrashPage as component
410
+ TrashRoute as component
291
411
  };
@@ -1,5 +1,5 @@
1
1
  import { r as reactExports } from "../_chunks/_libs/react.mjs";
2
- import { r as useBreadcrumbContext } from "./router-DDWcF-kt.mjs";
2
+ import { r as useBreadcrumbContext } from "./router-D1BMAMJT.mjs";
3
3
  function useBreadcrumbLabel(path, label) {
4
4
  const { setOverride, clearOverride } = useBreadcrumbContext();
5
5
  reactExports.useEffect(() => {
@@ -1,5 +1,5 @@
1
1
  import { r as reactExports } from "../_chunks/_libs/react.mjs";
2
- import { l as useAuth, m as getResourcePermissions, n as canAccessResource, o as hasPermission } from "./router-DDWcF-kt.mjs";
2
+ import { l as useAuth, m as getResourcePermissions, n as canAccessResource, o as hasPermission } from "./router-D1BMAMJT.mjs";
3
3
  function usePermissions() {
4
4
  const { role } = useAuth();
5
5
  return reactExports.useMemo(() => {