@btst/stack 2.2.0 → 2.4.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 (237) hide show
  1. package/dist/packages/stack/src/client/components/compose.cjs +1 -2
  2. package/dist/packages/stack/src/client/components/compose.mjs +1 -2
  3. package/dist/packages/stack/src/plugins/ai-chat/api/page-tools.cjs +71 -0
  4. package/dist/packages/stack/src/plugins/ai-chat/api/page-tools.mjs +68 -0
  5. package/dist/packages/stack/src/plugins/ai-chat/api/plugin.cjs +54 -7
  6. package/dist/packages/stack/src/plugins/ai-chat/api/plugin.mjs +54 -7
  7. package/dist/packages/stack/src/plugins/ai-chat/client/components/chat-input.cjs +2 -2
  8. package/dist/packages/stack/src/plugins/ai-chat/client/components/chat-input.mjs +2 -2
  9. package/dist/packages/stack/src/plugins/ai-chat/client/components/chat-interface.cjs +89 -22
  10. package/dist/packages/stack/src/plugins/ai-chat/client/components/chat-interface.mjs +90 -23
  11. package/dist/packages/stack/src/plugins/ai-chat/client/components/chat-layout.cjs +110 -33
  12. package/dist/packages/stack/src/plugins/ai-chat/client/components/chat-layout.mjs +112 -35
  13. package/dist/packages/stack/src/plugins/ai-chat/client/components/chat-sidebar.cjs +1 -1
  14. package/dist/packages/stack/src/plugins/ai-chat/client/components/chat-sidebar.mjs +1 -1
  15. package/dist/packages/stack/src/plugins/ai-chat/schemas.cjs +17 -1
  16. package/dist/packages/stack/src/plugins/ai-chat/schemas.mjs +17 -1
  17. package/dist/packages/stack/src/plugins/blog/api/plugin.cjs +52 -1
  18. package/dist/packages/stack/src/plugins/blog/api/plugin.mjs +52 -1
  19. package/dist/packages/stack/src/plugins/blog/api/query-key-defs.cjs +18 -0
  20. package/dist/packages/stack/src/plugins/blog/api/query-key-defs.mjs +15 -0
  21. package/dist/packages/stack/src/plugins/blog/api/serializers.cjs +21 -0
  22. package/dist/packages/stack/src/plugins/blog/api/serializers.mjs +18 -0
  23. package/dist/packages/stack/src/plugins/blog/client/components/forms/post-forms.cjs +15 -2
  24. package/dist/packages/stack/src/plugins/blog/client/components/forms/post-forms.mjs +16 -3
  25. package/dist/packages/stack/src/plugins/blog/client/components/pages/edit-post-page.internal.cjs +24 -1
  26. package/dist/packages/stack/src/plugins/blog/client/components/pages/edit-post-page.internal.mjs +24 -1
  27. package/dist/packages/stack/src/plugins/blog/client/components/pages/fill-blog-form-handler.cjs +26 -0
  28. package/dist/packages/stack/src/plugins/blog/client/components/pages/fill-blog-form-handler.mjs +24 -0
  29. package/dist/packages/stack/src/plugins/blog/client/components/pages/new-post-page.internal.cjs +30 -1
  30. package/dist/packages/stack/src/plugins/blog/client/components/pages/new-post-page.internal.mjs +30 -1
  31. package/dist/packages/stack/src/plugins/blog/client/components/pages/post-page.internal.cjs +18 -0
  32. package/dist/packages/stack/src/plugins/blog/client/components/pages/post-page.internal.mjs +18 -0
  33. package/dist/packages/stack/src/plugins/blog/client/plugin.cjs +15 -0
  34. package/dist/packages/stack/src/plugins/blog/client/plugin.mjs +16 -1
  35. package/dist/packages/stack/src/plugins/cms/api/getters.cjs +10 -0
  36. package/dist/packages/stack/src/plugins/cms/api/getters.mjs +10 -1
  37. package/dist/packages/stack/src/plugins/cms/api/mutations.cjs +48 -0
  38. package/dist/packages/stack/src/plugins/cms/api/mutations.mjs +46 -0
  39. package/dist/packages/stack/src/plugins/cms/api/plugin.cjs +75 -0
  40. package/dist/packages/stack/src/plugins/cms/api/plugin.mjs +76 -1
  41. package/dist/packages/stack/src/plugins/cms/api/query-key-defs.cjs +29 -0
  42. package/dist/packages/stack/src/plugins/cms/api/query-key-defs.mjs +26 -0
  43. package/dist/packages/stack/src/plugins/cms/client/plugin.cjs +15 -0
  44. package/dist/packages/stack/src/plugins/cms/client/plugin.mjs +16 -1
  45. package/dist/packages/stack/src/plugins/form-builder/api/getters.cjs +9 -0
  46. package/dist/packages/stack/src/plugins/form-builder/api/getters.mjs +9 -1
  47. package/dist/packages/stack/src/plugins/form-builder/api/plugin.cjs +62 -1
  48. package/dist/packages/stack/src/plugins/form-builder/api/plugin.mjs +63 -2
  49. package/dist/packages/stack/src/plugins/form-builder/api/query-key-defs.cjs +37 -0
  50. package/dist/packages/stack/src/plugins/form-builder/api/query-key-defs.mjs +33 -0
  51. package/dist/packages/stack/src/plugins/form-builder/client/plugin.cjs +15 -0
  52. package/dist/packages/stack/src/plugins/form-builder/client/plugin.mjs +16 -1
  53. package/dist/packages/stack/src/plugins/kanban/api/mutations.cjs +91 -0
  54. package/dist/packages/stack/src/plugins/kanban/api/mutations.mjs +87 -0
  55. package/dist/packages/stack/src/plugins/kanban/api/plugin.cjs +34 -1
  56. package/dist/packages/stack/src/plugins/kanban/api/plugin.mjs +34 -1
  57. package/dist/packages/stack/src/plugins/kanban/api/query-key-defs.cjs +26 -0
  58. package/dist/packages/stack/src/plugins/kanban/api/query-key-defs.mjs +23 -0
  59. package/dist/packages/stack/src/plugins/kanban/api/serializers.cjs +30 -0
  60. package/dist/packages/stack/src/plugins/kanban/api/serializers.mjs +26 -0
  61. package/dist/packages/stack/src/plugins/kanban/client/hooks/kanban-hooks.cjs +7 -3
  62. package/dist/packages/stack/src/plugins/kanban/client/hooks/kanban-hooks.mjs +7 -3
  63. package/dist/packages/stack/src/plugins/kanban/client/plugin.cjs +10 -0
  64. package/dist/packages/stack/src/plugins/kanban/client/plugin.mjs +11 -1
  65. package/dist/packages/stack/src/plugins/ui-builder/client/components/pages/page-builder-page.internal.cjs +89 -0
  66. package/dist/packages/stack/src/plugins/ui-builder/client/components/pages/page-builder-page.internal.mjs +89 -0
  67. package/dist/packages/stack/src/plugins/utils.cjs +6 -0
  68. package/dist/packages/stack/src/plugins/utils.mjs +6 -1
  69. package/dist/plugins/ai-chat/api/index.d.cts +1 -1
  70. package/dist/plugins/ai-chat/api/index.d.mts +1 -1
  71. package/dist/plugins/ai-chat/api/index.d.ts +1 -1
  72. package/dist/plugins/ai-chat/client/components/index.d.cts +1 -1
  73. package/dist/plugins/ai-chat/client/components/index.d.mts +1 -1
  74. package/dist/plugins/ai-chat/client/components/index.d.ts +1 -1
  75. package/dist/plugins/ai-chat/client/context/page-ai-context.cjs +92 -0
  76. package/dist/plugins/ai-chat/client/context/page-ai-context.d.cts +84 -0
  77. package/dist/plugins/ai-chat/client/context/page-ai-context.d.mts +84 -0
  78. package/dist/plugins/ai-chat/client/context/page-ai-context.d.ts +84 -0
  79. package/dist/plugins/ai-chat/client/context/page-ai-context.mjs +88 -0
  80. package/dist/plugins/ai-chat/client/hooks/index.d.cts +1 -1
  81. package/dist/plugins/ai-chat/client/hooks/index.d.mts +1 -1
  82. package/dist/plugins/ai-chat/client/hooks/index.d.ts +1 -1
  83. package/dist/plugins/ai-chat/client/index.d.cts +2 -2
  84. package/dist/plugins/ai-chat/client/index.d.mts +2 -2
  85. package/dist/plugins/ai-chat/client/index.d.ts +2 -2
  86. package/dist/plugins/ai-chat/query-keys.d.cts +1 -1
  87. package/dist/plugins/ai-chat/query-keys.d.mts +1 -1
  88. package/dist/plugins/ai-chat/query-keys.d.ts +1 -1
  89. package/dist/plugins/blog/api/index.cjs +5 -0
  90. package/dist/plugins/blog/api/index.d.cts +19 -4
  91. package/dist/plugins/blog/api/index.d.mts +19 -4
  92. package/dist/plugins/blog/api/index.d.ts +19 -4
  93. package/dist/plugins/blog/api/index.mjs +2 -0
  94. package/dist/plugins/blog/client/hooks/index.d.cts +3 -3
  95. package/dist/plugins/blog/client/hooks/index.d.mts +3 -3
  96. package/dist/plugins/blog/client/hooks/index.d.ts +3 -3
  97. package/dist/plugins/blog/client/index.d.cts +1 -1
  98. package/dist/plugins/blog/client/index.d.mts +1 -1
  99. package/dist/plugins/blog/client/index.d.ts +1 -1
  100. package/dist/plugins/blog/query-keys.cjs +6 -5
  101. package/dist/plugins/blog/query-keys.d.cts +8 -387
  102. package/dist/plugins/blog/query-keys.d.mts +8 -387
  103. package/dist/plugins/blog/query-keys.d.ts +8 -387
  104. package/dist/plugins/blog/query-keys.mjs +6 -5
  105. package/dist/plugins/client/index.cjs +1 -0
  106. package/dist/plugins/client/index.d.cts +8 -1
  107. package/dist/plugins/client/index.d.mts +8 -1
  108. package/dist/plugins/client/index.d.ts +8 -1
  109. package/dist/plugins/client/index.mjs +1 -1
  110. package/dist/plugins/cms/api/index.cjs +8 -0
  111. package/dist/plugins/cms/api/index.d.cts +7 -219
  112. package/dist/plugins/cms/api/index.d.mts +7 -219
  113. package/dist/plugins/cms/api/index.d.ts +7 -219
  114. package/dist/plugins/cms/api/index.mjs +3 -1
  115. package/dist/plugins/cms/client/hooks/index.d.cts +1 -1
  116. package/dist/plugins/cms/client/hooks/index.d.mts +1 -1
  117. package/dist/plugins/cms/client/hooks/index.d.ts +1 -1
  118. package/dist/plugins/cms/query-keys.cjs +2 -1
  119. package/dist/plugins/cms/query-keys.d.cts +5 -9
  120. package/dist/plugins/cms/query-keys.d.mts +5 -9
  121. package/dist/plugins/cms/query-keys.d.ts +5 -9
  122. package/dist/plugins/cms/query-keys.mjs +2 -1
  123. package/dist/plugins/form-builder/api/index.cjs +6 -0
  124. package/dist/plugins/form-builder/api/index.d.cts +7 -211
  125. package/dist/plugins/form-builder/api/index.d.mts +7 -211
  126. package/dist/plugins/form-builder/api/index.d.ts +7 -211
  127. package/dist/plugins/form-builder/api/index.mjs +2 -1
  128. package/dist/plugins/form-builder/client/components/index.d.cts +1 -1
  129. package/dist/plugins/form-builder/client/components/index.d.mts +1 -1
  130. package/dist/plugins/form-builder/client/components/index.d.ts +1 -1
  131. package/dist/plugins/form-builder/client/hooks/index.d.cts +1 -1
  132. package/dist/plugins/form-builder/client/hooks/index.d.mts +1 -1
  133. package/dist/plugins/form-builder/client/hooks/index.d.ts +1 -1
  134. package/dist/plugins/form-builder/query-keys.cjs +3 -2
  135. package/dist/plugins/form-builder/query-keys.d.cts +6 -6
  136. package/dist/plugins/form-builder/query-keys.d.mts +6 -6
  137. package/dist/plugins/form-builder/query-keys.d.ts +6 -6
  138. package/dist/plugins/form-builder/query-keys.mjs +3 -2
  139. package/dist/plugins/kanban/api/index.cjs +10 -0
  140. package/dist/plugins/kanban/api/index.d.cts +17 -392
  141. package/dist/plugins/kanban/api/index.d.mts +17 -392
  142. package/dist/plugins/kanban/api/index.d.ts +17 -392
  143. package/dist/plugins/kanban/api/index.mjs +3 -0
  144. package/dist/plugins/kanban/client/components/index.d.cts +1 -1
  145. package/dist/plugins/kanban/client/components/index.d.mts +1 -1
  146. package/dist/plugins/kanban/client/components/index.d.ts +1 -1
  147. package/dist/plugins/kanban/client/hooks/index.d.cts +1 -1
  148. package/dist/plugins/kanban/client/hooks/index.d.mts +1 -1
  149. package/dist/plugins/kanban/client/hooks/index.d.ts +1 -1
  150. package/dist/plugins/kanban/client/index.d.cts +1 -1
  151. package/dist/plugins/kanban/client/index.d.mts +1 -1
  152. package/dist/plugins/kanban/client/index.d.ts +1 -1
  153. package/dist/plugins/kanban/query-keys.cjs +2 -9
  154. package/dist/plugins/kanban/query-keys.d.cts +4 -16
  155. package/dist/plugins/kanban/query-keys.d.mts +4 -16
  156. package/dist/plugins/kanban/query-keys.d.ts +4 -16
  157. package/dist/plugins/kanban/query-keys.mjs +2 -9
  158. package/dist/plugins/ui-builder/index.d.cts +1 -1
  159. package/dist/plugins/ui-builder/index.d.mts +1 -1
  160. package/dist/plugins/ui-builder/index.d.ts +1 -1
  161. package/dist/shared/stack.B7ONvlD_.d.mts +293 -0
  162. package/dist/shared/{stack.BeSm90va.d.ts → stack.BEn34wW6.d.ts} +60 -2
  163. package/dist/shared/stack.BUkC2EsZ.d.cts +327 -0
  164. package/dist/shared/{stack.DaOcgmrM.d.ts → stack.BV9hnvu4.d.cts} +31 -7
  165. package/dist/shared/{stack.DaOcgmrM.d.cts → stack.BV9hnvu4.d.mts} +31 -7
  166. package/dist/shared/{stack.DaOcgmrM.d.mts → stack.BV9hnvu4.d.ts} +31 -7
  167. package/dist/shared/stack.BepFXT3w.d.mts +500 -0
  168. package/dist/shared/stack.CL8ts1Mu.d.ts +419 -0
  169. package/dist/shared/{stack.CXjzTMsb.d.cts → stack.CVDTkMoO.d.cts} +7 -1
  170. package/dist/shared/{stack.CXjzTMsb.d.mts → stack.CVDTkMoO.d.mts} +7 -1
  171. package/dist/shared/{stack.CXjzTMsb.d.ts → stack.CVDTkMoO.d.ts} +7 -1
  172. package/dist/shared/stack.CczspVn2.d.mts +327 -0
  173. package/dist/shared/stack.CgWzG5jH.d.ts +500 -0
  174. package/dist/shared/stack.D3GB6wKv.d.cts +500 -0
  175. package/dist/shared/stack.DASmUVjX.d.ts +327 -0
  176. package/dist/shared/{stack.QD1y_7NY.d.cts → stack.DJaKVY7v.d.cts} +1 -1
  177. package/dist/shared/{stack.QD1y_7NY.d.mts → stack.DJaKVY7v.d.mts} +1 -1
  178. package/dist/shared/{stack.QD1y_7NY.d.ts → stack.DJaKVY7v.d.ts} +1 -1
  179. package/dist/shared/{stack.Dg09R0oB.d.mts → stack.DTDxgFj8.d.mts} +60 -2
  180. package/dist/shared/{stack.CMh_EdxW.d.cts → stack.DWoCZff7.d.cts} +60 -2
  181. package/dist/shared/{stack.CIrIsc-A.d.cts → stack.DdI5W6MB.d.cts} +7 -1
  182. package/dist/shared/{stack.CIrIsc-A.d.mts → stack.DdI5W6MB.d.mts} +7 -1
  183. package/dist/shared/{stack.CIrIsc-A.d.ts → stack.DdI5W6MB.d.ts} +7 -1
  184. package/dist/shared/stack.Dk5r4W1F.d.mts +419 -0
  185. package/dist/shared/stack.Kq2-QzOC.d.ts +293 -0
  186. package/dist/shared/stack.heOA9gzA.d.cts +419 -0
  187. package/dist/shared/stack.kcdnD4gA.d.cts +293 -0
  188. package/package.json +16 -3
  189. package/src/client/components/compose.tsx +7 -4
  190. package/src/plugins/ai-chat/api/page-tools.ts +111 -0
  191. package/src/plugins/ai-chat/api/plugin.ts +180 -9
  192. package/src/plugins/ai-chat/client/components/chat-input.tsx +2 -2
  193. package/src/plugins/ai-chat/client/components/chat-interface.tsx +154 -58
  194. package/src/plugins/ai-chat/client/components/chat-layout.tsx +166 -32
  195. package/src/plugins/ai-chat/client/components/chat-sidebar.tsx +1 -1
  196. package/src/plugins/ai-chat/client/context/page-ai-context.tsx +240 -0
  197. package/src/plugins/ai-chat/schemas.ts +16 -0
  198. package/src/plugins/blog/api/index.ts +2 -0
  199. package/src/plugins/blog/api/plugin.ts +85 -0
  200. package/src/plugins/blog/api/query-key-defs.ts +46 -0
  201. package/src/plugins/blog/api/serializers.ts +27 -0
  202. package/src/plugins/blog/client/components/forms/post-forms.tsx +29 -2
  203. package/src/plugins/blog/client/components/pages/edit-post-page.internal.tsx +28 -0
  204. package/src/plugins/blog/client/components/pages/fill-blog-form-handler.ts +38 -0
  205. package/src/plugins/blog/client/components/pages/new-post-page.internal.tsx +33 -1
  206. package/src/plugins/blog/client/components/pages/post-page.internal.tsx +20 -0
  207. package/src/plugins/blog/client/plugin.tsx +19 -0
  208. package/src/plugins/blog/query-keys.ts +5 -7
  209. package/src/plugins/client/index.ts +1 -1
  210. package/src/plugins/cms/api/getters.ts +24 -0
  211. package/src/plugins/cms/api/index.ts +14 -1
  212. package/src/plugins/cms/api/mutations.ts +84 -0
  213. package/src/plugins/cms/api/plugin.ts +114 -0
  214. package/src/plugins/cms/api/query-key-defs.ts +53 -0
  215. package/src/plugins/cms/api/serializers.ts +12 -0
  216. package/src/plugins/cms/client/plugin.tsx +19 -0
  217. package/src/plugins/cms/query-keys.ts +2 -1
  218. package/src/plugins/form-builder/api/getters.ts +23 -0
  219. package/src/plugins/form-builder/api/index.ts +15 -2
  220. package/src/plugins/form-builder/api/plugin.ts +91 -0
  221. package/src/plugins/form-builder/api/query-key-defs.ts +79 -0
  222. package/src/plugins/form-builder/api/serializers.ts +12 -0
  223. package/src/plugins/form-builder/client/plugin.tsx +19 -0
  224. package/src/plugins/form-builder/query-keys.ts +6 -2
  225. package/src/plugins/kanban/api/index.ts +9 -0
  226. package/src/plugins/kanban/api/mutations.ts +169 -0
  227. package/src/plugins/kanban/api/plugin.ts +61 -0
  228. package/src/plugins/kanban/api/query-key-defs.ts +54 -0
  229. package/src/plugins/kanban/api/serializers.ts +49 -0
  230. package/src/plugins/kanban/client/hooks/kanban-hooks.tsx +4 -0
  231. package/src/plugins/kanban/client/plugin.tsx +13 -0
  232. package/src/plugins/kanban/query-keys.ts +2 -9
  233. package/src/plugins/ui-builder/client/components/pages/page-builder-page.internal.tsx +132 -0
  234. package/src/plugins/utils.ts +19 -0
  235. package/dist/shared/{stack.BkYlUT_8.d.cts → stack.BQmuNl5p.d.cts} +6 -6
  236. package/dist/shared/{stack.BkYlUT_8.d.mts → stack.BQmuNl5p.d.mts} +6 -6
  237. package/dist/shared/{stack.BkYlUT_8.d.ts → stack.BQmuNl5p.d.ts} +6 -6
@@ -0,0 +1,327 @@
1
+ import * as _btst_stack_plugins_api from '@btst/stack/plugins/api';
2
+ import { a as SerializedContentItemWithType, S as SerializedContentType, b as ContentType, c as ContentItem, d as SerializedContentItem, e as ContentItemWithType, f as CMSBackendConfig, I as InverseRelation } from './stack.CVDTkMoO.cjs';
3
+ import * as better_call from 'better-call';
4
+ import { z } from 'zod';
5
+ import { Adapter } from '@btst/db';
6
+ import { QueryClient } from '@tanstack/react-query';
7
+
8
+ /**
9
+ * Serialize a ContentType for SSR/SSG use (convert dates to strings).
10
+ * Applies lazy migration for legacy schemas (version 1 → 2).
11
+ */
12
+ declare function serializeContentType(ct: ContentType): SerializedContentType;
13
+ /**
14
+ * Serialize a ContentItem for SSR/SSG use (convert dates to strings).
15
+ */
16
+ declare function serializeContentItem(item: ContentItem): SerializedContentItem;
17
+ /**
18
+ * Serialize a ContentItem with parsed data and joined ContentType.
19
+ * Throws a SyntaxError if `item.data` is not valid JSON, so corrupted rows
20
+ * produce a visible, debuggable error rather than silently returning null.
21
+ */
22
+ declare function serializeContentItemWithType(item: ContentItemWithType): SerializedContentItemWithType;
23
+ /**
24
+ * Retrieve all content types.
25
+ * Pure DB function — no hooks, no HTTP context. Safe for SSG and server-side use.
26
+ *
27
+ * @remarks **Security:** Authorization hooks are NOT called. The caller is
28
+ * responsible for any access-control checks before invoking this function.
29
+ *
30
+ * @param adapter - The database adapter
31
+ */
32
+ declare function getAllContentTypes(adapter: Adapter): Promise<SerializedContentType[]>;
33
+ /**
34
+ * Retrieve all content items for a given content type, with optional pagination.
35
+ * Pure DB function — no hooks, no HTTP context. Safe for SSG and server-side use.
36
+ *
37
+ * @remarks **Security:** Authorization hooks (e.g. `onBeforeListItems`) are NOT
38
+ * called. The caller is responsible for any access-control checks before
39
+ * invoking this function.
40
+ *
41
+ * @param adapter - The database adapter
42
+ * @param contentTypeSlug - The slug of the content type to query
43
+ * @param params - Optional filter/pagination parameters
44
+ */
45
+ declare function getAllContentItems(adapter: Adapter, contentTypeSlug: string, params?: {
46
+ slug?: string;
47
+ limit?: number;
48
+ offset?: number;
49
+ }): Promise<{
50
+ items: SerializedContentItemWithType[];
51
+ total: number;
52
+ limit?: number;
53
+ offset?: number;
54
+ }>;
55
+ /**
56
+ * Retrieve a single content item by its ID.
57
+ * Returns null if the item is not found.
58
+ * Pure DB function — no hooks, no HTTP context. Safe for SSG and server-side use.
59
+ *
60
+ * @remarks **Security:** Authorization hooks are NOT called. The caller is
61
+ * responsible for any access-control checks before invoking this function.
62
+ *
63
+ * @param adapter - The database adapter
64
+ * @param id - The content item ID (UUID)
65
+ */
66
+ declare function getContentItemById(adapter: Adapter, id: string): Promise<SerializedContentItemWithType | null>;
67
+ /**
68
+ * Retrieve a single content item by its slug within a content type.
69
+ * Returns null if the content type or item is not found.
70
+ * Pure DB function — no hooks, no HTTP context. Safe for SSG and server-side use.
71
+ *
72
+ * @remarks **Security:** Authorization hooks are NOT called. The caller is
73
+ * responsible for any access-control checks before invoking this function.
74
+ *
75
+ * @param adapter - The database adapter
76
+ * @param contentTypeSlug - The slug of the content type
77
+ * @param slug - The slug of the content item
78
+ */
79
+ declare function getContentItemBySlug(adapter: Adapter, contentTypeSlug: string, slug: string): Promise<SerializedContentItemWithType | null>;
80
+
81
+ /**
82
+ * Input for creating a new CMS content item.
83
+ */
84
+ interface CreateCMSContentItemInput {
85
+ /** URL-safe slug for the item */
86
+ slug: string;
87
+ /** Arbitrary data payload — should match the content type schema */
88
+ data: Record<string, unknown>;
89
+ }
90
+ /**
91
+ * Create a new content item for a content type (looked up by slug).
92
+ *
93
+ * Bypasses Zod schema validation and relation processing — the caller is
94
+ * responsible for providing valid, relation-free data. For relation fields or
95
+ * schema validation, use the HTTP endpoint instead.
96
+ *
97
+ * Throws if the content type is not found or the slug is already taken within
98
+ * that content type.
99
+ *
100
+ * @remarks **Security:** No authorization hooks (`onBeforeCreate`, `onAfterCreate`)
101
+ * are called. The caller is responsible for any access-control checks before
102
+ * invoking this function.
103
+ *
104
+ * @param adapter - The database adapter
105
+ * @param contentTypeSlug - Slug of the target content type
106
+ * @param input - Item slug and data payload
107
+ */
108
+ declare function createCMSContentItem(adapter: Adapter, contentTypeSlug: string, input: CreateCMSContentItemInput): Promise<SerializedContentItem>;
109
+
110
+ /**
111
+ * Route keys for the CMS plugin — matches the keys returned by
112
+ * `stackClient.router.getRoute(path).routeKey`.
113
+ */
114
+ type CMSRouteKey = "dashboard" | "contentList" | "newContent" | "editContent";
115
+ interface CMSPrefetchForRoute {
116
+ (key: "dashboard" | "newContent", qc: QueryClient): Promise<void>;
117
+ (key: "contentList", qc: QueryClient, params: {
118
+ typeSlug: string;
119
+ }): Promise<void>;
120
+ (key: "editContent", qc: QueryClient, params: {
121
+ typeSlug: string;
122
+ id: string;
123
+ }): Promise<void>;
124
+ }
125
+ /**
126
+ * CMS backend plugin
127
+ * Provides API endpoints for managing content types and content items
128
+ *
129
+ * @param config - Configuration with content types and optional hooks
130
+ */
131
+ declare const cmsBackendPlugin: (config: CMSBackendConfig) => _btst_stack_plugins_api.BackendPlugin<{
132
+ listContentTypes: better_call.StrictEndpoint<"/content-types", {
133
+ method: "GET";
134
+ }, {
135
+ itemCount: number;
136
+ createdAt: string;
137
+ updatedAt: string;
138
+ name: string;
139
+ id: string;
140
+ slug: string;
141
+ description?: string | undefined;
142
+ jsonSchema: string;
143
+ fieldConfig?: string | undefined;
144
+ autoFormVersion?: number | undefined;
145
+ }[]>;
146
+ getContentTypeBySlug: better_call.StrictEndpoint<"/content-types/:slug", {
147
+ method: "GET";
148
+ params: z.ZodObject<{
149
+ slug: z.ZodString;
150
+ }, z.core.$strip>;
151
+ }, SerializedContentType>;
152
+ listContentItems: better_call.StrictEndpoint<"/content/:typeSlug", {
153
+ method: "GET";
154
+ params: z.ZodObject<{
155
+ typeSlug: z.ZodString;
156
+ }, z.core.$strip>;
157
+ query: z.ZodObject<{
158
+ slug: z.ZodOptional<z.ZodString>;
159
+ limit: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
160
+ offset: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
161
+ }, z.core.$strip>;
162
+ }, {
163
+ items: SerializedContentItemWithType[];
164
+ total: number;
165
+ limit?: number;
166
+ offset?: number;
167
+ }>;
168
+ getContentItem: better_call.StrictEndpoint<"/content/:typeSlug/:id", {
169
+ method: "GET";
170
+ params: z.ZodObject<{
171
+ typeSlug: z.ZodString;
172
+ id: z.ZodString;
173
+ }, z.core.$strip>;
174
+ }, SerializedContentItemWithType<Record<string, unknown>>>;
175
+ createContentItem: better_call.StrictEndpoint<"/content/:typeSlug", {
176
+ method: "POST";
177
+ params: z.ZodObject<{
178
+ typeSlug: z.ZodString;
179
+ }, z.core.$strip>;
180
+ body: z.ZodObject<{
181
+ slug: z.ZodString;
182
+ data: z.ZodObject<{}, z.core.$loose>;
183
+ }, z.core.$strip>;
184
+ }, {
185
+ parsedData: Record<string, unknown>;
186
+ createdAt: string;
187
+ updatedAt: string;
188
+ id: string;
189
+ slug: string;
190
+ contentTypeId: string;
191
+ data: string;
192
+ authorId?: string | undefined;
193
+ }>;
194
+ updateContentItem: better_call.StrictEndpoint<"/content/:typeSlug/:id", {
195
+ method: "PUT";
196
+ params: z.ZodObject<{
197
+ typeSlug: z.ZodString;
198
+ id: z.ZodString;
199
+ }, z.core.$strip>;
200
+ body: z.ZodObject<{
201
+ slug: z.ZodOptional<z.ZodString>;
202
+ data: z.ZodOptional<z.ZodObject<{}, z.core.$loose>>;
203
+ }, z.core.$strip>;
204
+ }, SerializedContentItemWithType<Record<string, unknown>>>;
205
+ deleteContentItem: better_call.StrictEndpoint<"/content/:typeSlug/:id", {
206
+ method: "DELETE";
207
+ params: z.ZodObject<{
208
+ typeSlug: z.ZodString;
209
+ id: z.ZodString;
210
+ }, z.core.$strip>;
211
+ }, {
212
+ success: boolean;
213
+ }>;
214
+ getContentItemPopulated: better_call.StrictEndpoint<"/content/:typeSlug/:id/populated", {
215
+ method: "GET";
216
+ params: z.ZodObject<{
217
+ typeSlug: z.ZodString;
218
+ id: z.ZodString;
219
+ }, z.core.$strip>;
220
+ }, {
221
+ _relations: Record<string, SerializedContentItemWithType<Record<string, unknown>>[]>;
222
+ parsedData: Record<string, unknown>;
223
+ contentType?: SerializedContentType;
224
+ createdAt: string;
225
+ updatedAt: string;
226
+ id: string;
227
+ slug: string;
228
+ contentTypeId: string;
229
+ data: string;
230
+ authorId?: string | undefined;
231
+ }>;
232
+ listContentByRelation: better_call.StrictEndpoint<"/content/:typeSlug/by-relation", {
233
+ method: "GET";
234
+ params: z.ZodObject<{
235
+ typeSlug: z.ZodString;
236
+ }, z.core.$strip>;
237
+ query: z.ZodObject<{
238
+ field: z.ZodString;
239
+ targetId: z.ZodString;
240
+ limit: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
241
+ offset: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
242
+ }, z.core.$strip>;
243
+ }, {
244
+ items: SerializedContentItemWithType<Record<string, unknown>>[];
245
+ total: number;
246
+ limit: number;
247
+ offset: number;
248
+ }>;
249
+ getInverseRelations: better_call.StrictEndpoint<"/content-types/:slug/inverse-relations", {
250
+ method: "GET";
251
+ params: z.ZodObject<{
252
+ slug: z.ZodString;
253
+ }, z.core.$strip>;
254
+ query: z.ZodObject<{
255
+ itemId: z.ZodOptional<z.ZodString>;
256
+ }, z.core.$strip>;
257
+ }, {
258
+ inverseRelations: InverseRelation[];
259
+ }>;
260
+ listInverseRelationItems: better_call.StrictEndpoint<"/content-types/:slug/inverse-relations/:sourceType", {
261
+ method: "GET";
262
+ params: z.ZodObject<{
263
+ slug: z.ZodString;
264
+ sourceType: z.ZodString;
265
+ }, z.core.$strip>;
266
+ query: z.ZodObject<{
267
+ itemId: z.ZodString;
268
+ fieldName: z.ZodString;
269
+ limit: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
270
+ offset: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
271
+ }, z.core.$strip>;
272
+ }, {
273
+ items: SerializedContentItemWithType<Record<string, unknown>>[];
274
+ total: number;
275
+ limit: number;
276
+ offset: number;
277
+ }>;
278
+ }, {
279
+ getAllContentTypes: () => Promise<SerializedContentType[]>;
280
+ getAllContentItems: (contentTypeSlug: string, params?: Parameters<typeof getAllContentItems>[2]) => Promise<{
281
+ items: SerializedContentItemWithType[];
282
+ total: number;
283
+ limit?: number;
284
+ offset?: number;
285
+ }>;
286
+ getContentItemBySlug: (contentTypeSlug: string, slug: string) => Promise<SerializedContentItemWithType<Record<string, unknown>> | null>;
287
+ getContentItemById: (id: string) => Promise<SerializedContentItemWithType<Record<string, unknown>> | null>;
288
+ prefetchForRoute: CMSPrefetchForRoute;
289
+ createContentItem: (typeSlug: string, input: Parameters<typeof createCMSContentItem>[2]) => Promise<SerializedContentItem>;
290
+ }>;
291
+ type CMSApiRouter = ReturnType<ReturnType<typeof cmsBackendPlugin>["routes"]>;
292
+
293
+ /**
294
+ * Internal query key constants for the CMS plugin.
295
+ * Shared between query-keys.ts (HTTP path) and prefetchForRoute (DB path)
296
+ * to prevent key drift between SSR loaders and SSG prefetching.
297
+ */
298
+ interface ContentListDiscriminator {
299
+ typeSlug: string;
300
+ limit: number;
301
+ offset: number;
302
+ }
303
+ /** Full query key builders — use these with queryClient.setQueryData() */
304
+ declare const CMS_QUERY_KEYS: {
305
+ /**
306
+ * Key for the cmsTypes.list() query.
307
+ * Full key: ["cmsTypes", "list", "list"]
308
+ */
309
+ typesList: () => readonly ["cmsTypes", "list", "list"];
310
+ /**
311
+ * Key for the cmsContent.list({ typeSlug, limit, offset }) query.
312
+ * Full key: ["cmsContent", "list", { typeSlug, limit, offset }]
313
+ */
314
+ contentList: (params: {
315
+ typeSlug: string;
316
+ limit?: number;
317
+ offset?: number;
318
+ }) => readonly ["cmsContent", "list", ContentListDiscriminator];
319
+ /**
320
+ * Key for the cmsContent.detail(typeSlug, id) query.
321
+ * Full key: ["cmsContent", "detail", typeSlug, id]
322
+ */
323
+ contentDetail: (typeSlug: string, id: string) => readonly ["cmsContent", "detail", string, string];
324
+ };
325
+
326
+ export { cmsBackendPlugin as c, getAllContentItems as d, getContentItemBySlug as e, getContentItemById as f, getAllContentTypes as g, serializeContentItem as h, serializeContentItemWithType as i, createCMSContentItem as j, CMS_QUERY_KEYS as l, serializeContentType as s };
327
+ export type { CMSApiRouter as C, ContentListDiscriminator as a, CMSRouteKey as b, CreateCMSContentItemInput as k };
@@ -244,31 +244,55 @@ interface ChatInterfaceProps {
244
244
  }
245
245
  declare function ChatInterface({ apiPath, initialMessages, id, variant, className, onMessagesChange, }: ChatInterfaceProps): react_jsx_runtime.JSX.Element;
246
246
 
247
- interface ChatLayoutProps {
247
+ interface ChatLayoutBaseProps {
248
248
  /** API base URL */
249
249
  apiBaseURL: string;
250
250
  /** API base path */
251
251
  apiBasePath: string;
252
252
  /** Current conversation ID (if viewing existing conversation) */
253
253
  conversationId?: string;
254
- /** Layout mode: 'full' for full page with sidebar, 'widget' for embeddable widget */
255
- layout?: "full" | "widget";
256
254
  /** Additional class name for the container */
257
255
  className?: string;
258
- /** Whether to show the sidebar (default: true for full layout) */
256
+ /** Whether to show the sidebar */
259
257
  showSidebar?: boolean;
260
- /** Height of the widget (only applies to widget layout) */
261
- widgetHeight?: string | number;
262
258
  /** Initial messages to populate the chat (useful for localStorage persistence in public mode) */
263
259
  initialMessages?: UIMessage[];
264
260
  /** Called whenever messages change (for persistence). Only fires in public mode. */
265
261
  onMessagesChange?: (messages: UIMessage[]) => void;
266
262
  }
263
+ interface ChatLayoutWidgetProps extends ChatLayoutBaseProps {
264
+ /** Widget mode: compact embeddable panel with a floating trigger button */
265
+ layout: "widget";
266
+ /** Height of the widget panel. Default: `"600px"` */
267
+ widgetHeight?: string | number;
268
+ /** Width of the widget panel. Default: `"380px"` */
269
+ widgetWidth?: string | number;
270
+ /**
271
+ * Whether the widget panel starts open. Default: `false`.
272
+ * Set to `true` when embedding inside an already-open container such as a
273
+ * Next.js intercepting-route modal — the panel will be immediately visible
274
+ * without the user needing to click the trigger button.
275
+ */
276
+ defaultOpen?: boolean;
277
+ /**
278
+ * Whether to render the built-in floating trigger button. Default: `true`.
279
+ * Set to `false` when you control open/close externally (e.g. a Next.js
280
+ * parallel-route slot, a custom button, or a `router.back()` dismiss action)
281
+ * so that the built-in button does not appear alongside your own UI.
282
+ */
283
+ showTrigger?: boolean;
284
+ }
285
+ interface ChatLayoutFullProps extends ChatLayoutBaseProps {
286
+ /** Full-page mode with sidebar navigation (default) */
287
+ layout?: "full";
288
+ }
289
+ /** Props for the ChatLayout component */
290
+ type ChatLayoutProps = ChatLayoutWidgetProps | ChatLayoutFullProps;
267
291
  /**
268
292
  * ChatLayout component that provides a full-page chat experience with sidebar
269
293
  * or a compact widget mode for embedding.
270
294
  */
271
- declare function ChatLayout({ apiBaseURL, apiBasePath, conversationId, layout, className, showSidebar, widgetHeight, initialMessages, onMessagesChange, }: ChatLayoutProps): react_jsx_runtime.JSX.Element;
295
+ declare function ChatLayout(props: ChatLayoutProps): react_jsx_runtime.JSX.Element;
272
296
 
273
297
  interface ChatSidebarProps {
274
298
  currentConversationId?: string;
@@ -244,31 +244,55 @@ interface ChatInterfaceProps {
244
244
  }
245
245
  declare function ChatInterface({ apiPath, initialMessages, id, variant, className, onMessagesChange, }: ChatInterfaceProps): react_jsx_runtime.JSX.Element;
246
246
 
247
- interface ChatLayoutProps {
247
+ interface ChatLayoutBaseProps {
248
248
  /** API base URL */
249
249
  apiBaseURL: string;
250
250
  /** API base path */
251
251
  apiBasePath: string;
252
252
  /** Current conversation ID (if viewing existing conversation) */
253
253
  conversationId?: string;
254
- /** Layout mode: 'full' for full page with sidebar, 'widget' for embeddable widget */
255
- layout?: "full" | "widget";
256
254
  /** Additional class name for the container */
257
255
  className?: string;
258
- /** Whether to show the sidebar (default: true for full layout) */
256
+ /** Whether to show the sidebar */
259
257
  showSidebar?: boolean;
260
- /** Height of the widget (only applies to widget layout) */
261
- widgetHeight?: string | number;
262
258
  /** Initial messages to populate the chat (useful for localStorage persistence in public mode) */
263
259
  initialMessages?: UIMessage[];
264
260
  /** Called whenever messages change (for persistence). Only fires in public mode. */
265
261
  onMessagesChange?: (messages: UIMessage[]) => void;
266
262
  }
263
+ interface ChatLayoutWidgetProps extends ChatLayoutBaseProps {
264
+ /** Widget mode: compact embeddable panel with a floating trigger button */
265
+ layout: "widget";
266
+ /** Height of the widget panel. Default: `"600px"` */
267
+ widgetHeight?: string | number;
268
+ /** Width of the widget panel. Default: `"380px"` */
269
+ widgetWidth?: string | number;
270
+ /**
271
+ * Whether the widget panel starts open. Default: `false`.
272
+ * Set to `true` when embedding inside an already-open container such as a
273
+ * Next.js intercepting-route modal — the panel will be immediately visible
274
+ * without the user needing to click the trigger button.
275
+ */
276
+ defaultOpen?: boolean;
277
+ /**
278
+ * Whether to render the built-in floating trigger button. Default: `true`.
279
+ * Set to `false` when you control open/close externally (e.g. a Next.js
280
+ * parallel-route slot, a custom button, or a `router.back()` dismiss action)
281
+ * so that the built-in button does not appear alongside your own UI.
282
+ */
283
+ showTrigger?: boolean;
284
+ }
285
+ interface ChatLayoutFullProps extends ChatLayoutBaseProps {
286
+ /** Full-page mode with sidebar navigation (default) */
287
+ layout?: "full";
288
+ }
289
+ /** Props for the ChatLayout component */
290
+ type ChatLayoutProps = ChatLayoutWidgetProps | ChatLayoutFullProps;
267
291
  /**
268
292
  * ChatLayout component that provides a full-page chat experience with sidebar
269
293
  * or a compact widget mode for embedding.
270
294
  */
271
- declare function ChatLayout({ apiBaseURL, apiBasePath, conversationId, layout, className, showSidebar, widgetHeight, initialMessages, onMessagesChange, }: ChatLayoutProps): react_jsx_runtime.JSX.Element;
295
+ declare function ChatLayout(props: ChatLayoutProps): react_jsx_runtime.JSX.Element;
272
296
 
273
297
  interface ChatSidebarProps {
274
298
  currentConversationId?: string;
@@ -244,31 +244,55 @@ interface ChatInterfaceProps {
244
244
  }
245
245
  declare function ChatInterface({ apiPath, initialMessages, id, variant, className, onMessagesChange, }: ChatInterfaceProps): react_jsx_runtime.JSX.Element;
246
246
 
247
- interface ChatLayoutProps {
247
+ interface ChatLayoutBaseProps {
248
248
  /** API base URL */
249
249
  apiBaseURL: string;
250
250
  /** API base path */
251
251
  apiBasePath: string;
252
252
  /** Current conversation ID (if viewing existing conversation) */
253
253
  conversationId?: string;
254
- /** Layout mode: 'full' for full page with sidebar, 'widget' for embeddable widget */
255
- layout?: "full" | "widget";
256
254
  /** Additional class name for the container */
257
255
  className?: string;
258
- /** Whether to show the sidebar (default: true for full layout) */
256
+ /** Whether to show the sidebar */
259
257
  showSidebar?: boolean;
260
- /** Height of the widget (only applies to widget layout) */
261
- widgetHeight?: string | number;
262
258
  /** Initial messages to populate the chat (useful for localStorage persistence in public mode) */
263
259
  initialMessages?: UIMessage[];
264
260
  /** Called whenever messages change (for persistence). Only fires in public mode. */
265
261
  onMessagesChange?: (messages: UIMessage[]) => void;
266
262
  }
263
+ interface ChatLayoutWidgetProps extends ChatLayoutBaseProps {
264
+ /** Widget mode: compact embeddable panel with a floating trigger button */
265
+ layout: "widget";
266
+ /** Height of the widget panel. Default: `"600px"` */
267
+ widgetHeight?: string | number;
268
+ /** Width of the widget panel. Default: `"380px"` */
269
+ widgetWidth?: string | number;
270
+ /**
271
+ * Whether the widget panel starts open. Default: `false`.
272
+ * Set to `true` when embedding inside an already-open container such as a
273
+ * Next.js intercepting-route modal — the panel will be immediately visible
274
+ * without the user needing to click the trigger button.
275
+ */
276
+ defaultOpen?: boolean;
277
+ /**
278
+ * Whether to render the built-in floating trigger button. Default: `true`.
279
+ * Set to `false` when you control open/close externally (e.g. a Next.js
280
+ * parallel-route slot, a custom button, or a `router.back()` dismiss action)
281
+ * so that the built-in button does not appear alongside your own UI.
282
+ */
283
+ showTrigger?: boolean;
284
+ }
285
+ interface ChatLayoutFullProps extends ChatLayoutBaseProps {
286
+ /** Full-page mode with sidebar navigation (default) */
287
+ layout?: "full";
288
+ }
289
+ /** Props for the ChatLayout component */
290
+ type ChatLayoutProps = ChatLayoutWidgetProps | ChatLayoutFullProps;
267
291
  /**
268
292
  * ChatLayout component that provides a full-page chat experience with sidebar
269
293
  * or a compact widget mode for embedding.
270
294
  */
271
- declare function ChatLayout({ apiBaseURL, apiBasePath, conversationId, layout, className, showSidebar, widgetHeight, initialMessages, onMessagesChange, }: ChatLayoutProps): react_jsx_runtime.JSX.Element;
295
+ declare function ChatLayout(props: ChatLayoutProps): react_jsx_runtime.JSX.Element;
272
296
 
273
297
  interface ChatSidebarProps {
274
298
  currentConversationId?: string;