@btst/stack 2.1.0 → 2.2.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 (179) hide show
  1. package/dist/api/index.cjs +9 -1
  2. package/dist/api/index.d.cts +4 -4
  3. package/dist/api/index.d.mts +4 -4
  4. package/dist/api/index.d.ts +4 -4
  5. package/dist/api/index.mjs +9 -1
  6. package/dist/client/index.d.cts +2 -2
  7. package/dist/client/index.d.mts +2 -2
  8. package/dist/client/index.d.ts +2 -2
  9. package/dist/index.d.cts +1 -1
  10. package/dist/index.d.mts +1 -1
  11. package/dist/index.d.ts +1 -1
  12. package/dist/packages/stack/src/plugins/ai-chat/api/getters.cjs +42 -0
  13. package/dist/packages/stack/src/plugins/ai-chat/api/getters.mjs +39 -0
  14. package/dist/packages/stack/src/plugins/ai-chat/api/plugin.cjs +5 -0
  15. package/dist/packages/stack/src/plugins/ai-chat/api/plugin.mjs +5 -0
  16. package/dist/packages/stack/src/plugins/blog/api/getters.cjs +131 -0
  17. package/dist/packages/stack/src/plugins/blog/api/getters.mjs +127 -0
  18. package/dist/packages/stack/src/plugins/blog/api/plugin.cjs +9 -107
  19. package/dist/packages/stack/src/plugins/blog/api/plugin.mjs +9 -107
  20. package/dist/packages/stack/src/plugins/blog/client/plugin.cjs +1 -1
  21. package/dist/packages/stack/src/plugins/blog/client/plugin.mjs +1 -1
  22. package/dist/packages/stack/src/plugins/cms/api/getters.cjs +146 -0
  23. package/dist/packages/stack/src/plugins/cms/api/getters.mjs +138 -0
  24. package/dist/packages/stack/src/plugins/cms/api/plugin.cjs +560 -622
  25. package/dist/packages/stack/src/plugins/cms/api/plugin.mjs +559 -621
  26. package/dist/packages/stack/src/plugins/cms/client/components/pages/content-editor-page.internal.cjs +1 -1
  27. package/dist/packages/stack/src/plugins/cms/client/components/pages/content-editor-page.internal.mjs +1 -1
  28. package/dist/packages/stack/src/plugins/cms/client/hooks/cms-hooks.cjs +6 -3
  29. package/dist/packages/stack/src/plugins/cms/client/hooks/cms-hooks.mjs +6 -3
  30. package/dist/packages/stack/src/plugins/form-builder/api/getters.cjs +111 -0
  31. package/dist/packages/stack/src/plugins/form-builder/api/getters.mjs +104 -0
  32. package/dist/packages/stack/src/plugins/form-builder/api/plugin.cjs +16 -88
  33. package/dist/packages/stack/src/plugins/form-builder/api/plugin.mjs +12 -84
  34. package/dist/packages/stack/src/plugins/form-builder/client/components/pages/submissions-page.internal.cjs +1 -1
  35. package/dist/packages/stack/src/plugins/form-builder/client/components/pages/submissions-page.internal.mjs +1 -1
  36. package/dist/packages/stack/src/plugins/kanban/api/getters.cjs +84 -0
  37. package/dist/packages/stack/src/plugins/kanban/api/getters.mjs +81 -0
  38. package/dist/packages/stack/src/plugins/kanban/api/plugin.cjs +9 -123
  39. package/dist/packages/stack/src/plugins/kanban/api/plugin.mjs +9 -123
  40. package/dist/packages/stack/src/plugins/kanban/client/plugin.cjs +1 -1
  41. package/dist/packages/stack/src/plugins/kanban/client/plugin.mjs +1 -1
  42. package/dist/plugins/ai-chat/api/index.cjs +3 -0
  43. package/dist/plugins/ai-chat/api/index.d.cts +27 -4
  44. package/dist/plugins/ai-chat/api/index.d.mts +27 -4
  45. package/dist/plugins/ai-chat/api/index.d.ts +27 -4
  46. package/dist/plugins/ai-chat/api/index.mjs +1 -0
  47. package/dist/plugins/ai-chat/client/hooks/index.d.cts +2 -2
  48. package/dist/plugins/ai-chat/client/hooks/index.d.mts +2 -2
  49. package/dist/plugins/ai-chat/client/hooks/index.d.ts +2 -2
  50. package/dist/plugins/ai-chat/query-keys.d.cts +9 -284
  51. package/dist/plugins/ai-chat/query-keys.d.mts +9 -284
  52. package/dist/plugins/ai-chat/query-keys.d.ts +9 -284
  53. package/dist/plugins/api/index.d.cts +4 -3
  54. package/dist/plugins/api/index.d.mts +4 -3
  55. package/dist/plugins/api/index.d.ts +4 -3
  56. package/dist/plugins/blog/api/index.cjs +4 -0
  57. package/dist/plugins/blog/api/index.d.cts +3 -2
  58. package/dist/plugins/blog/api/index.d.mts +3 -2
  59. package/dist/plugins/blog/api/index.d.ts +3 -2
  60. package/dist/plugins/blog/api/index.mjs +1 -0
  61. package/dist/plugins/blog/client/hooks/index.d.cts +4 -4
  62. package/dist/plugins/blog/client/hooks/index.d.mts +4 -4
  63. package/dist/plugins/blog/client/hooks/index.d.ts +4 -4
  64. package/dist/plugins/blog/client/index.d.cts +1 -1
  65. package/dist/plugins/blog/client/index.d.mts +1 -1
  66. package/dist/plugins/blog/client/index.d.ts +1 -1
  67. package/dist/plugins/blog/query-keys.cjs +7 -4
  68. package/dist/plugins/blog/query-keys.d.cts +81 -27
  69. package/dist/plugins/blog/query-keys.d.mts +81 -27
  70. package/dist/plugins/blog/query-keys.d.ts +81 -27
  71. package/dist/plugins/blog/query-keys.mjs +7 -4
  72. package/dist/plugins/client/index.d.cts +2 -2
  73. package/dist/plugins/client/index.d.mts +2 -2
  74. package/dist/plugins/client/index.d.ts +2 -2
  75. package/dist/plugins/cms/api/index.cjs +4 -0
  76. package/dist/plugins/cms/api/index.d.cts +61 -5
  77. package/dist/plugins/cms/api/index.d.mts +61 -5
  78. package/dist/plugins/cms/api/index.d.ts +61 -5
  79. package/dist/plugins/cms/api/index.mjs +1 -0
  80. package/dist/plugins/cms/client/hooks/index.d.cts +1 -1
  81. package/dist/plugins/cms/client/hooks/index.d.mts +1 -1
  82. package/dist/plugins/cms/client/hooks/index.d.ts +1 -1
  83. package/dist/plugins/cms/query-keys.d.cts +2 -1
  84. package/dist/plugins/cms/query-keys.d.mts +2 -1
  85. package/dist/plugins/cms/query-keys.d.ts +2 -1
  86. package/dist/plugins/form-builder/api/index.cjs +4 -0
  87. package/dist/plugins/form-builder/api/index.d.cts +77 -7
  88. package/dist/plugins/form-builder/api/index.d.mts +77 -7
  89. package/dist/plugins/form-builder/api/index.d.ts +77 -7
  90. package/dist/plugins/form-builder/api/index.mjs +1 -0
  91. package/dist/plugins/form-builder/client/components/index.d.cts +1 -1
  92. package/dist/plugins/form-builder/client/components/index.d.mts +1 -1
  93. package/dist/plugins/form-builder/client/components/index.d.ts +1 -1
  94. package/dist/plugins/form-builder/client/hooks/index.d.cts +1 -1
  95. package/dist/plugins/form-builder/client/hooks/index.d.mts +1 -1
  96. package/dist/plugins/form-builder/client/hooks/index.d.ts +1 -1
  97. package/dist/plugins/form-builder/query-keys.d.cts +2 -1
  98. package/dist/plugins/form-builder/query-keys.d.mts +2 -1
  99. package/dist/plugins/form-builder/query-keys.d.ts +2 -1
  100. package/dist/plugins/kanban/api/index.cjs +3 -0
  101. package/dist/plugins/kanban/api/index.d.cts +40 -43
  102. package/dist/plugins/kanban/api/index.d.mts +40 -43
  103. package/dist/plugins/kanban/api/index.d.ts +40 -43
  104. package/dist/plugins/kanban/api/index.mjs +1 -0
  105. package/dist/plugins/kanban/client/components/index.d.cts +1 -1
  106. package/dist/plugins/kanban/client/components/index.d.mts +1 -1
  107. package/dist/plugins/kanban/client/components/index.d.ts +1 -1
  108. package/dist/plugins/kanban/client/hooks/index.d.cts +1 -1
  109. package/dist/plugins/kanban/client/hooks/index.d.mts +1 -1
  110. package/dist/plugins/kanban/client/hooks/index.d.ts +1 -1
  111. package/dist/plugins/kanban/client/index.d.cts +1 -1
  112. package/dist/plugins/kanban/client/index.d.mts +1 -1
  113. package/dist/plugins/kanban/client/index.d.ts +1 -1
  114. package/dist/plugins/kanban/query-keys.cjs +4 -3
  115. package/dist/plugins/kanban/query-keys.d.cts +2 -1
  116. package/dist/plugins/kanban/query-keys.d.mts +2 -1
  117. package/dist/plugins/kanban/query-keys.d.ts +2 -1
  118. package/dist/plugins/kanban/query-keys.mjs +4 -3
  119. package/dist/plugins/open-api/api/index.d.cts +2 -2
  120. package/dist/plugins/open-api/api/index.d.mts +2 -2
  121. package/dist/plugins/open-api/api/index.d.ts +2 -2
  122. package/dist/plugins/route-docs/client/index.d.cts +1 -1
  123. package/dist/plugins/route-docs/client/index.d.mts +1 -1
  124. package/dist/plugins/route-docs/client/index.d.ts +1 -1
  125. package/dist/plugins/ui-builder/index.d.cts +1 -1
  126. package/dist/plugins/ui-builder/index.d.mts +1 -1
  127. package/dist/plugins/ui-builder/index.d.ts +1 -1
  128. package/dist/shared/{stack.BoA0xkJv.d.cts → stack.7n9Y_u7N.d.cts} +33 -7
  129. package/dist/shared/{stack.BoA0xkJv.d.mts → stack.7n9Y_u7N.d.mts} +33 -7
  130. package/dist/shared/{stack.BoA0xkJv.d.ts → stack.7n9Y_u7N.d.ts} +33 -7
  131. package/dist/shared/stack.BeSm90va.d.ts +289 -0
  132. package/dist/shared/{stack.DzH_wcvr.d.mts → stack.CIrIsc-A.d.cts} +2 -2
  133. package/dist/shared/{stack.DzH_wcvr.d.ts → stack.CIrIsc-A.d.mts} +2 -2
  134. package/dist/shared/{stack.DzH_wcvr.d.cts → stack.CIrIsc-A.d.ts} +2 -2
  135. package/dist/shared/stack.CMh_EdxW.d.cts +289 -0
  136. package/dist/shared/{stack.BsXokfNh.d.mts → stack.CXjzTMsb.d.cts} +1 -1
  137. package/dist/shared/{stack.BsXokfNh.d.ts → stack.CXjzTMsb.d.mts} +1 -1
  138. package/dist/shared/{stack.BsXokfNh.d.cts → stack.CXjzTMsb.d.ts} +1 -1
  139. package/dist/shared/stack.Dg09R0oB.d.mts +289 -0
  140. package/dist/shared/{stack.DKDMI-QO.d.mts → stack.QD1y_7NY.d.cts} +7 -1
  141. package/dist/shared/{stack.DKDMI-QO.d.ts → stack.QD1y_7NY.d.mts} +7 -1
  142. package/dist/shared/{stack.DKDMI-QO.d.cts → stack.QD1y_7NY.d.ts} +7 -1
  143. package/package.json +1 -1
  144. package/src/__tests__/stack-api.test.ts +118 -0
  145. package/src/api/index.ts +15 -1
  146. package/src/plugins/ai-chat/__tests__/getters.test.ts +109 -0
  147. package/src/plugins/ai-chat/api/getters.ts +71 -0
  148. package/src/plugins/ai-chat/api/index.ts +1 -0
  149. package/src/plugins/ai-chat/api/plugin.ts +8 -0
  150. package/src/plugins/api/index.ts +3 -1
  151. package/src/plugins/blog/__tests__/getters.test.ts +540 -0
  152. package/src/plugins/blog/api/getters.ts +243 -0
  153. package/src/plugins/blog/api/index.ts +7 -0
  154. package/src/plugins/blog/api/plugin.ts +13 -141
  155. package/src/plugins/blog/client/plugin.tsx +2 -1
  156. package/src/plugins/blog/query-keys.ts +16 -13
  157. package/src/plugins/cms/__tests__/getters.test.ts +206 -0
  158. package/src/plugins/cms/api/getters.ts +244 -0
  159. package/src/plugins/cms/api/index.ts +5 -0
  160. package/src/plugins/cms/api/plugin.ts +50 -154
  161. package/src/plugins/cms/client/components/pages/content-editor-page.internal.tsx +1 -1
  162. package/src/plugins/cms/client/hooks/cms-hooks.tsx +3 -0
  163. package/src/plugins/cms/types.ts +1 -1
  164. package/src/plugins/form-builder/__tests__/getters.test.ts +159 -0
  165. package/src/plugins/form-builder/api/getters.ts +203 -0
  166. package/src/plugins/form-builder/api/index.ts +1 -0
  167. package/src/plugins/form-builder/api/plugin.ts +22 -115
  168. package/src/plugins/form-builder/client/components/pages/submissions-page.internal.tsx +1 -1
  169. package/src/plugins/form-builder/types.ts +2 -2
  170. package/src/plugins/kanban/__tests__/getters.test.ts +172 -0
  171. package/src/plugins/kanban/api/getters.ts +149 -0
  172. package/src/plugins/kanban/api/index.ts +1 -0
  173. package/src/plugins/kanban/api/plugin.ts +16 -146
  174. package/src/plugins/kanban/client/plugin.tsx +2 -1
  175. package/src/plugins/kanban/query-keys.ts +8 -5
  176. package/src/types.ts +44 -5
  177. package/dist/shared/{stack.CbuN2zVV.d.cts → stack.BkYlUT_8.d.cts} +6 -6
  178. package/dist/shared/{stack.CbuN2zVV.d.mts → stack.BkYlUT_8.d.mts} +6 -6
  179. package/dist/shared/{stack.CbuN2zVV.d.ts → stack.BkYlUT_8.d.ts} +6 -6
@@ -1,284 +1,9 @@
1
- import * as _btst_stack_plugins_api from '@btst/stack/plugins/api';
2
- import * as better_call from 'better-call';
3
- import * as zod_v4_core from 'zod/v4/core';
4
- import * as zod from 'zod';
5
- import { LanguageModel, Tool } from 'ai';
6
- import { M as Message, C as Conversation, S as SerializedConversation, a as SerializedMessage } from '../../shared/stack.Be1QIHEn.js';
7
- import * as _tanstack_react_query from '@tanstack/react-query';
8
- import { createApiClient } from '@btst/stack/plugins/client';
9
-
10
- /**
11
- * Context passed to AI Chat API hooks
12
- */
13
- interface ChatApiContext<TBody = any, TParams = any, TQuery = any> {
14
- body?: TBody;
15
- params?: TParams;
16
- query?: TQuery;
17
- request?: Request;
18
- headers?: Headers;
19
- [key: string]: any;
20
- }
21
- /**
22
- * Configuration hooks for AI Chat backend plugin
23
- * All hooks are optional and allow consumers to customize behavior
24
- */
25
- interface AiChatBackendHooks {
26
- /**
27
- * Called before processing a chat message. Return false to deny access.
28
- * @param messages - Array of messages being sent
29
- * @param context - Request context with headers, etc.
30
- */
31
- onBeforeChat?: (messages: Array<{
32
- role: string;
33
- content: string;
34
- }>, context: ChatApiContext) => Promise<boolean> | boolean;
35
- /**
36
- * Called before listing conversations. Return false to deny access.
37
- * @param context - Request context with headers, etc.
38
- */
39
- onBeforeListConversations?: (context: ChatApiContext) => Promise<boolean> | boolean;
40
- /**
41
- * Called before getting a single conversation. Return false to deny access.
42
- * @param conversationId - ID of the conversation being accessed
43
- * @param context - Request context with headers, etc.
44
- */
45
- onBeforeGetConversation?: (conversationId: string, context: ChatApiContext) => Promise<boolean> | boolean;
46
- /**
47
- * Called before creating a conversation. Return false to deny access.
48
- * @param data - Conversation data being created
49
- * @param context - Request context with headers, etc.
50
- */
51
- onBeforeCreateConversation?: (data: {
52
- id?: string;
53
- title?: string;
54
- }, context: ChatApiContext) => Promise<boolean> | boolean;
55
- /**
56
- * Called before updating a conversation. Return false to deny access.
57
- * @param conversationId - ID of the conversation being updated
58
- * @param data - Updated conversation data
59
- * @param context - Request context with headers, etc.
60
- */
61
- onBeforeUpdateConversation?: (conversationId: string, data: {
62
- title?: string;
63
- }, context: ChatApiContext) => Promise<boolean> | boolean;
64
- /**
65
- * Called before deleting a conversation. Return false to deny access.
66
- * @param conversationId - ID of the conversation being deleted
67
- * @param context - Request context with headers, etc.
68
- */
69
- onBeforeDeleteConversation?: (conversationId: string, context: ChatApiContext) => Promise<boolean> | boolean;
70
- /**
71
- * Called after a chat message is processed successfully
72
- * @param conversationId - ID of the conversation
73
- * @param messages - Array of messages in the conversation
74
- * @param context - Request context
75
- */
76
- onAfterChat?: (conversationId: string, messages: Message[], context: ChatApiContext) => Promise<void> | void;
77
- /**
78
- * Called after conversations are read successfully
79
- * @param conversations - Array of conversations that were read
80
- * @param context - Request context
81
- */
82
- onConversationsRead?: (conversations: Conversation[], context: ChatApiContext) => Promise<void> | void;
83
- /**
84
- * Called after a single conversation is read successfully
85
- * @param conversation - The conversation with messages
86
- * @param context - Request context
87
- */
88
- onConversationRead?: (conversation: Conversation & {
89
- messages: Message[];
90
- }, context: ChatApiContext) => Promise<void> | void;
91
- /**
92
- * Called after a conversation is created successfully
93
- * @param conversation - The created conversation
94
- * @param context - Request context
95
- */
96
- onConversationCreated?: (conversation: Conversation, context: ChatApiContext) => Promise<void> | void;
97
- /**
98
- * Called after a conversation is updated successfully
99
- * @param conversation - The updated conversation
100
- * @param context - Request context
101
- */
102
- onConversationUpdated?: (conversation: Conversation, context: ChatApiContext) => Promise<void> | void;
103
- /**
104
- * Called after a conversation is deleted successfully
105
- * @param conversationId - ID of the deleted conversation
106
- * @param context - Request context
107
- */
108
- onConversationDeleted?: (conversationId: string, context: ChatApiContext) => Promise<void> | void;
109
- /**
110
- * Called when a chat operation fails
111
- * @param error - The error that occurred
112
- * @param context - Request context
113
- */
114
- onChatError?: (error: Error, context: ChatApiContext) => Promise<void> | void;
115
- /**
116
- * Called when listing conversations fails
117
- * @param error - The error that occurred
118
- * @param context - Request context
119
- */
120
- onListConversationsError?: (error: Error, context: ChatApiContext) => Promise<void> | void;
121
- /**
122
- * Called when getting a conversation fails
123
- * @param error - The error that occurred
124
- * @param context - Request context
125
- */
126
- onGetConversationError?: (error: Error, context: ChatApiContext) => Promise<void> | void;
127
- /**
128
- * Called when creating a conversation fails
129
- * @param error - The error that occurred
130
- * @param context - Request context
131
- */
132
- onCreateConversationError?: (error: Error, context: ChatApiContext) => Promise<void> | void;
133
- /**
134
- * Called when updating a conversation fails
135
- * @param error - The error that occurred
136
- * @param context - Request context
137
- */
138
- onUpdateConversationError?: (error: Error, context: ChatApiContext) => Promise<void> | void;
139
- /**
140
- * Called when deleting a conversation fails
141
- * @param error - The error that occurred
142
- * @param context - Request context
143
- */
144
- onDeleteConversationError?: (error: Error, context: ChatApiContext) => Promise<void> | void;
145
- }
146
- /**
147
- * Plugin mode for AI Chat
148
- * - 'authenticated': Conversations persisted with userId (default)
149
- * - 'public': Stateless chat, no persistence (ideal for public chatbots)
150
- */
151
- type AiChatMode = "authenticated" | "public";
152
- /**
153
- * Configuration for AI Chat backend plugin
154
- */
155
- interface AiChatBackendConfig {
156
- /**
157
- * The language model to use for chat completions.
158
- * Supports any model from AI SDK providers (OpenAI, Anthropic, Google, etc.)
159
- */
160
- model: LanguageModel;
161
- /**
162
- * Plugin mode:
163
- * - 'authenticated': Conversations persisted with userId (requires getUserId)
164
- * - 'public': Stateless chat, no persistence (ideal for public chatbots)
165
- * @default 'authenticated'
166
- */
167
- mode?: AiChatMode;
168
- /**
169
- * Extract userId from request context (authenticated mode only).
170
- * Return null/undefined to deny access in authenticated mode.
171
- * This function is called for all conversation operations.
172
- * @example (ctx) => ctx.headers?.get('x-user-id')
173
- */
174
- getUserId?: (context: ChatApiContext) => string | null | undefined | Promise<string | null | undefined>;
175
- /**
176
- * Optional system prompt to prepend to all conversations
177
- */
178
- systemPrompt?: string;
179
- /**
180
- * Optional tools to make available to the model.
181
- * Uses AI SDK v5 tool format.
182
- * @see https://ai-sdk.dev/docs/ai-sdk-core/tools-and-tool-calling
183
- */
184
- tools?: Record<string, Tool>;
185
- /**
186
- * Optional hooks for customizing plugin behavior
187
- */
188
- hooks?: AiChatBackendHooks;
189
- }
190
- /**
191
- * AI Chat backend plugin
192
- * Provides API endpoints for AI-powered chat with conversation history
193
- * Uses AI SDK v5 for model interactions
194
- *
195
- * @param config - Configuration including model, tools, and optional hooks
196
- */
197
- declare const aiChatBackendPlugin: (config: AiChatBackendConfig) => _btst_stack_plugins_api.BackendPlugin<{
198
- chat: better_call.StrictEndpoint<"/chat", {
199
- method: "POST";
200
- body: zod.ZodObject<{
201
- messages: zod.ZodArray<zod.ZodUnion<readonly [zod.ZodObject<{
202
- role: zod.ZodEnum<{
203
- system: "system";
204
- user: "user";
205
- assistant: "assistant";
206
- data: "data";
207
- }>;
208
- content: zod.ZodString;
209
- id: zod.ZodOptional<zod.ZodString>;
210
- }, zod_v4_core.$strip>, zod.ZodObject<{
211
- role: zod.ZodEnum<{
212
- system: "system";
213
- user: "user";
214
- assistant: "assistant";
215
- data: "data";
216
- }>;
217
- parts: zod.ZodArray<zod.ZodObject<{
218
- type: zod.ZodString;
219
- text: zod.ZodOptional<zod.ZodString>;
220
- }, zod_v4_core.$loose>>;
221
- id: zod.ZodOptional<zod.ZodString>;
222
- metadata: zod.ZodOptional<zod.ZodAny>;
223
- }, zod_v4_core.$strip>]>>;
224
- conversationId: zod.ZodOptional<zod.ZodString>;
225
- model: zod.ZodOptional<zod.ZodString>;
226
- }, zod_v4_core.$strip>;
227
- }, Response>;
228
- createConversation: better_call.StrictEndpoint<"/chat/conversations", {
229
- method: "POST";
230
- body: zod.ZodObject<{
231
- id: zod.ZodOptional<zod.ZodString>;
232
- title: zod.ZodOptional<zod.ZodString>;
233
- }, zod_v4_core.$strip>;
234
- }, Conversation>;
235
- listConversations: better_call.StrictEndpoint<"/chat/conversations", {
236
- method: "GET";
237
- }, Conversation[]>;
238
- getConversation: better_call.StrictEndpoint<"/chat/conversations/:id", {
239
- method: "GET";
240
- }, Conversation & {
241
- messages: Message[];
242
- }>;
243
- updateConversation: better_call.StrictEndpoint<"/chat/conversations/:id", {
244
- method: "PUT";
245
- body: zod.ZodObject<{
246
- title: zod.ZodOptional<zod.ZodString>;
247
- }, zod_v4_core.$strip>;
248
- }, Conversation>;
249
- deleteConversation: better_call.StrictEndpoint<"/chat/conversations/:id", {
250
- method: "DELETE";
251
- }, {
252
- success: boolean;
253
- }>;
254
- }>;
255
- type AiChatApiRouter = ReturnType<ReturnType<typeof aiChatBackendPlugin>["routes"]>;
256
-
257
- type ConversationWithMessages = SerializedConversation & {
258
- messages: SerializedMessage[];
259
- };
260
- declare function createAiChatQueryKeys(client: ReturnType<typeof createApiClient<AiChatApiRouter>>, headers?: HeadersInit): {
261
- conversations: {
262
- _def: readonly ["conversations"];
263
- } & {
264
- list: (() => Omit<{
265
- queryKey: readonly ["conversations", "list", string];
266
- queryFn: _tanstack_react_query.QueryFunction<SerializedConversation[], readonly ["conversations", "list", string]>;
267
- } & {
268
- _def: readonly ["conversations", "list"];
269
- }, "_def">) & {
270
- _def: readonly ["conversations", "list"];
271
- };
272
- detail: ((id: string) => Omit<{
273
- queryKey: readonly ["conversations", "detail", string];
274
- queryFn: _tanstack_react_query.QueryFunction<ConversationWithMessages | null, readonly ["conversations", "detail", string]>;
275
- } & {
276
- _def: readonly ["conversations", "detail"];
277
- }, "_def">) & {
278
- _def: readonly ["conversations", "detail"];
279
- };
280
- };
281
- };
282
-
283
- export { aiChatBackendPlugin as c, createAiChatQueryKeys };
284
- export type { AiChatBackendHooks as A, ChatApiContext as C, ConversationWithMessages, AiChatMode as a, AiChatBackendConfig as b, AiChatApiRouter as d };
1
+ import '@tanstack/react-query';
2
+ import '@btst/stack/plugins/client';
3
+ import '../../shared/stack.Be1QIHEn.js';
4
+ export { f as ConversationWithMessages, c as createAiChatQueryKeys } from '../../shared/stack.BeSm90va.js';
5
+ import '@btst/stack/plugins/api';
6
+ import 'better-call';
7
+ import 'zod/v4/core';
8
+ import 'zod';
9
+ import 'ai';
@@ -1,5 +1,5 @@
1
- import { B as BackendPlugin } from '../../shared/stack.BoA0xkJv.cjs';
2
- export { C as ClientPlugin } from '../../shared/stack.BoA0xkJv.cjs';
1
+ import { B as BackendPlugin } from '../../shared/stack.7n9Y_u7N.cjs';
2
+ export { C as ClientPlugin } from '../../shared/stack.7n9Y_u7N.cjs';
3
3
  import { Endpoint } from 'better-call';
4
4
  export { Endpoint, Router, createEndpoint, createRouter } from 'better-call';
5
5
  export { Adapter, DatabaseDefinition, DbPlugin, createDbPlugin } from '@btst/db';
@@ -34,7 +34,8 @@ import '@btst/yar';
34
34
  * ```
35
35
  *
36
36
  * @template TRoutes - The exact shape of routes (auto-inferred from routes function)
37
+ * @template TApi - The shape of the server-side api surface (auto-inferred from api factory)
37
38
  */
38
- declare function defineBackendPlugin<TRoutes extends Record<string, Endpoint> = Record<string, Endpoint>>(plugin: BackendPlugin<TRoutes>): BackendPlugin<TRoutes>;
39
+ declare function defineBackendPlugin<TRoutes extends Record<string, Endpoint> = Record<string, Endpoint>, TApi extends Record<string, (...args: any[]) => any> = never>(plugin: BackendPlugin<TRoutes, TApi>): BackendPlugin<TRoutes, TApi>;
39
40
 
40
41
  export { BackendPlugin, defineBackendPlugin };
@@ -1,5 +1,5 @@
1
- import { B as BackendPlugin } from '../../shared/stack.BoA0xkJv.mjs';
2
- export { C as ClientPlugin } from '../../shared/stack.BoA0xkJv.mjs';
1
+ import { B as BackendPlugin } from '../../shared/stack.7n9Y_u7N.mjs';
2
+ export { C as ClientPlugin } from '../../shared/stack.7n9Y_u7N.mjs';
3
3
  import { Endpoint } from 'better-call';
4
4
  export { Endpoint, Router, createEndpoint, createRouter } from 'better-call';
5
5
  export { Adapter, DatabaseDefinition, DbPlugin, createDbPlugin } from '@btst/db';
@@ -34,7 +34,8 @@ import '@btst/yar';
34
34
  * ```
35
35
  *
36
36
  * @template TRoutes - The exact shape of routes (auto-inferred from routes function)
37
+ * @template TApi - The shape of the server-side api surface (auto-inferred from api factory)
37
38
  */
38
- declare function defineBackendPlugin<TRoutes extends Record<string, Endpoint> = Record<string, Endpoint>>(plugin: BackendPlugin<TRoutes>): BackendPlugin<TRoutes>;
39
+ declare function defineBackendPlugin<TRoutes extends Record<string, Endpoint> = Record<string, Endpoint>, TApi extends Record<string, (...args: any[]) => any> = never>(plugin: BackendPlugin<TRoutes, TApi>): BackendPlugin<TRoutes, TApi>;
39
40
 
40
41
  export { BackendPlugin, defineBackendPlugin };
@@ -1,5 +1,5 @@
1
- import { B as BackendPlugin } from '../../shared/stack.BoA0xkJv.js';
2
- export { C as ClientPlugin } from '../../shared/stack.BoA0xkJv.js';
1
+ import { B as BackendPlugin } from '../../shared/stack.7n9Y_u7N.js';
2
+ export { C as ClientPlugin } from '../../shared/stack.7n9Y_u7N.js';
3
3
  import { Endpoint } from 'better-call';
4
4
  export { Endpoint, Router, createEndpoint, createRouter } from 'better-call';
5
5
  export { Adapter, DatabaseDefinition, DbPlugin, createDbPlugin } from '@btst/db';
@@ -34,7 +34,8 @@ import '@btst/yar';
34
34
  * ```
35
35
  *
36
36
  * @template TRoutes - The exact shape of routes (auto-inferred from routes function)
37
+ * @template TApi - The shape of the server-side api surface (auto-inferred from api factory)
37
38
  */
38
- declare function defineBackendPlugin<TRoutes extends Record<string, Endpoint> = Record<string, Endpoint>>(plugin: BackendPlugin<TRoutes>): BackendPlugin<TRoutes>;
39
+ declare function defineBackendPlugin<TRoutes extends Record<string, Endpoint> = Record<string, Endpoint>, TApi extends Record<string, (...args: any[]) => any> = never>(plugin: BackendPlugin<TRoutes, TApi>): BackendPlugin<TRoutes, TApi>;
39
40
 
40
41
  export { BackendPlugin, defineBackendPlugin };
@@ -1,6 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  const plugin = require('../../../packages/stack/src/plugins/blog/api/plugin.cjs');
4
+ const getters = require('../../../packages/stack/src/plugins/blog/api/getters.cjs');
4
5
  const plugins_blog_queryKeys = require('../query-keys.cjs');
5
6
 
6
7
 
@@ -8,4 +9,7 @@ const plugins_blog_queryKeys = require('../query-keys.cjs');
8
9
  exports.NextPreviousPostsQuerySchema = plugin.NextPreviousPostsQuerySchema;
9
10
  exports.PostListQuerySchema = plugin.PostListQuerySchema;
10
11
  exports.blogBackendPlugin = plugin.blogBackendPlugin;
12
+ exports.getAllPosts = getters.getAllPosts;
13
+ exports.getAllTags = getters.getAllTags;
14
+ exports.getPostBySlug = getters.getPostBySlug;
11
15
  exports.createBlogQueryKeys = plugins_blog_queryKeys.createBlogQueryKeys;
@@ -1,7 +1,8 @@
1
- export { B as BlogApiContext, c as BlogApiRouter, a as BlogBackendHooks, N as NextPreviousPostsQuerySchema, P as PostListQuerySchema, b as blogBackendPlugin, createBlogQueryKeys } from '../query-keys.cjs';
1
+ export { B as BlogApiContext, h as BlogApiRouter, e as BlogBackendHooks, N as NextPreviousPostsQuerySchema, P as PostListParams, d as PostListQuerySchema, c as PostListResult, f as blogBackendPlugin, createBlogQueryKeys, g as getAllPosts, b as getAllTags, a as getPostBySlug } from '../query-keys.cjs';
2
2
  import '@btst/stack/plugins/api';
3
3
  import 'better-call';
4
+ import '@btst/db';
5
+ import '../../../shared/stack.BkYlUT_8.cjs';
4
6
  import 'zod';
5
- import '../../../shared/stack.CbuN2zVV.cjs';
6
7
  import '@tanstack/react-query';
7
8
  import '@btst/stack/plugins/client';
@@ -1,7 +1,8 @@
1
- export { B as BlogApiContext, c as BlogApiRouter, a as BlogBackendHooks, N as NextPreviousPostsQuerySchema, P as PostListQuerySchema, b as blogBackendPlugin, createBlogQueryKeys } from '../query-keys.mjs';
1
+ export { B as BlogApiContext, h as BlogApiRouter, e as BlogBackendHooks, N as NextPreviousPostsQuerySchema, P as PostListParams, d as PostListQuerySchema, c as PostListResult, f as blogBackendPlugin, createBlogQueryKeys, g as getAllPosts, b as getAllTags, a as getPostBySlug } from '../query-keys.mjs';
2
2
  import '@btst/stack/plugins/api';
3
3
  import 'better-call';
4
+ import '@btst/db';
5
+ import '../../../shared/stack.BkYlUT_8.mjs';
4
6
  import 'zod';
5
- import '../../../shared/stack.CbuN2zVV.mjs';
6
7
  import '@tanstack/react-query';
7
8
  import '@btst/stack/plugins/client';
@@ -1,7 +1,8 @@
1
- export { B as BlogApiContext, c as BlogApiRouter, a as BlogBackendHooks, N as NextPreviousPostsQuerySchema, P as PostListQuerySchema, b as blogBackendPlugin, createBlogQueryKeys } from '../query-keys.js';
1
+ export { B as BlogApiContext, h as BlogApiRouter, e as BlogBackendHooks, N as NextPreviousPostsQuerySchema, P as PostListParams, d as PostListQuerySchema, c as PostListResult, f as blogBackendPlugin, createBlogQueryKeys, g as getAllPosts, b as getAllTags, a as getPostBySlug } from '../query-keys.js';
2
2
  import '@btst/stack/plugins/api';
3
3
  import 'better-call';
4
+ import '@btst/db';
5
+ import '../../../shared/stack.BkYlUT_8.js';
4
6
  import 'zod';
5
- import '../../../shared/stack.CbuN2zVV.js';
6
7
  import '@tanstack/react-query';
7
8
  import '@btst/stack/plugins/client';
@@ -1,2 +1,3 @@
1
1
  export { NextPreviousPostsQuerySchema, PostListQuerySchema, blogBackendPlugin } from '../../../packages/stack/src/plugins/blog/api/plugin.mjs';
2
+ export { getAllPosts, getAllTags, getPostBySlug } from '../../../packages/stack/src/plugins/blog/api/getters.mjs';
2
3
  export { createBlogQueryKeys } from '../query-keys.mjs';
@@ -1,5 +1,5 @@
1
1
  import * as _tanstack_react_query from '@tanstack/react-query';
2
- import { S as SerializedPost, c as createPostSchema, u as updatePostSchema, a as SerializedTag } from '../../../../shared/stack.CbuN2zVV.cjs';
2
+ import { S as SerializedPost, c as createPostSchema, u as updatePostSchema, a as SerializedTag } from '../../../../shared/stack.BkYlUT_8.cjs';
3
3
  import { z } from 'zod';
4
4
 
5
5
  /**
@@ -129,8 +129,6 @@ declare function useSuspenseTags(): {
129
129
  /** Create a new post */
130
130
  declare function useCreatePost(): _tanstack_react_query.UseMutationResult<SerializedPost | null, Error, {
131
131
  title: string;
132
- content: string;
133
- excerpt: string;
134
132
  published: boolean;
135
133
  tags: ({
136
134
  name: string;
@@ -139,10 +137,12 @@ declare function useCreatePost(): _tanstack_react_query.UseMutationResult<Serial
139
137
  name: string;
140
138
  slug: string;
141
139
  })[];
140
+ content: string;
141
+ excerpt: string;
142
142
  slug?: string | undefined;
143
- publishedAt?: Date | undefined;
144
143
  createdAt?: Date | undefined;
145
144
  updatedAt?: Date | undefined;
145
+ publishedAt?: Date | undefined;
146
146
  image?: string | undefined;
147
147
  }, unknown>;
148
148
  /** Update an existing post by id */
@@ -1,5 +1,5 @@
1
1
  import * as _tanstack_react_query from '@tanstack/react-query';
2
- import { S as SerializedPost, c as createPostSchema, u as updatePostSchema, a as SerializedTag } from '../../../../shared/stack.CbuN2zVV.mjs';
2
+ import { S as SerializedPost, c as createPostSchema, u as updatePostSchema, a as SerializedTag } from '../../../../shared/stack.BkYlUT_8.mjs';
3
3
  import { z } from 'zod';
4
4
 
5
5
  /**
@@ -129,8 +129,6 @@ declare function useSuspenseTags(): {
129
129
  /** Create a new post */
130
130
  declare function useCreatePost(): _tanstack_react_query.UseMutationResult<SerializedPost | null, Error, {
131
131
  title: string;
132
- content: string;
133
- excerpt: string;
134
132
  published: boolean;
135
133
  tags: ({
136
134
  name: string;
@@ -139,10 +137,12 @@ declare function useCreatePost(): _tanstack_react_query.UseMutationResult<Serial
139
137
  name: string;
140
138
  slug: string;
141
139
  })[];
140
+ content: string;
141
+ excerpt: string;
142
142
  slug?: string | undefined;
143
- publishedAt?: Date | undefined;
144
143
  createdAt?: Date | undefined;
145
144
  updatedAt?: Date | undefined;
145
+ publishedAt?: Date | undefined;
146
146
  image?: string | undefined;
147
147
  }, unknown>;
148
148
  /** Update an existing post by id */
@@ -1,5 +1,5 @@
1
1
  import * as _tanstack_react_query from '@tanstack/react-query';
2
- import { S as SerializedPost, c as createPostSchema, u as updatePostSchema, a as SerializedTag } from '../../../../shared/stack.CbuN2zVV.js';
2
+ import { S as SerializedPost, c as createPostSchema, u as updatePostSchema, a as SerializedTag } from '../../../../shared/stack.BkYlUT_8.js';
3
3
  import { z } from 'zod';
4
4
 
5
5
  /**
@@ -129,8 +129,6 @@ declare function useSuspenseTags(): {
129
129
  /** Create a new post */
130
130
  declare function useCreatePost(): _tanstack_react_query.UseMutationResult<SerializedPost | null, Error, {
131
131
  title: string;
132
- content: string;
133
- excerpt: string;
134
132
  published: boolean;
135
133
  tags: ({
136
134
  name: string;
@@ -139,10 +137,12 @@ declare function useCreatePost(): _tanstack_react_query.UseMutationResult<Serial
139
137
  name: string;
140
138
  slug: string;
141
139
  })[];
140
+ content: string;
141
+ excerpt: string;
142
142
  slug?: string | undefined;
143
- publishedAt?: Date | undefined;
144
143
  createdAt?: Date | undefined;
145
144
  updatedAt?: Date | undefined;
145
+ publishedAt?: Date | undefined;
146
146
  image?: string | undefined;
147
147
  }, unknown>;
148
148
  /** Update an existing post by id */
@@ -3,7 +3,7 @@ import * as react from 'react';
3
3
  import { ComponentType } from 'react';
4
4
  import * as _btst_yar from '@btst/yar';
5
5
  import { QueryClient } from '@tanstack/react-query';
6
- import { P as Post, S as SerializedPost } from '../../../shared/stack.CbuN2zVV.cjs';
6
+ import { P as Post, S as SerializedPost } from '../../../shared/stack.BkYlUT_8.cjs';
7
7
  export { UsePostsOptions, UsePostsResult } from './hooks/index.cjs';
8
8
  import 'zod';
9
9
 
@@ -3,7 +3,7 @@ import * as react from 'react';
3
3
  import { ComponentType } from 'react';
4
4
  import * as _btst_yar from '@btst/yar';
5
5
  import { QueryClient } from '@tanstack/react-query';
6
- import { P as Post, S as SerializedPost } from '../../../shared/stack.CbuN2zVV.mjs';
6
+ import { P as Post, S as SerializedPost } from '../../../shared/stack.BkYlUT_8.mjs';
7
7
  export { UsePostsOptions, UsePostsResult } from './hooks/index.mjs';
8
8
  import 'zod';
9
9
 
@@ -3,7 +3,7 @@ import * as react from 'react';
3
3
  import { ComponentType } from 'react';
4
4
  import * as _btst_yar from '@btst/yar';
5
5
  import { QueryClient } from '@tanstack/react-query';
6
- import { P as Post, S as SerializedPost } from '../../../shared/stack.CbuN2zVV.js';
6
+ import { P as Post, S as SerializedPost } from '../../../shared/stack.BkYlUT_8.js';
7
7
  export { UsePostsOptions, UsePostsResult } from './hooks/index.js';
8
8
  import 'zod';
9
9
 
@@ -52,7 +52,8 @@ function createPostsQueries(client, headers) {
52
52
  const errorResponse = response;
53
53
  throw toError(errorResponse.error);
54
54
  }
55
- return response.data ?? [];
55
+ const dataResponse = response;
56
+ return dataResponse.data?.items ?? [];
56
57
  } catch (error) {
57
58
  throw error;
58
59
  }
@@ -74,7 +75,7 @@ function createPostsQueries(client, headers) {
74
75
  throw toError(errorResponse.error);
75
76
  }
76
77
  const dataResponse = response;
77
- return dataResponse.data?.[0] ?? null;
78
+ return dataResponse.data?.items?.[0] ?? null;
78
79
  } catch (error) {
79
80
  throw error;
80
81
  }
@@ -117,7 +118,8 @@ function createPostsQueries(client, headers) {
117
118
  const errorResponse = response;
118
119
  throw toError(errorResponse.error);
119
120
  }
120
- let posts = response.data ?? [];
121
+ const recentResponse = response;
122
+ let posts = recentResponse.data?.items ?? [];
121
123
  if (params?.excludeSlug) {
122
124
  posts = posts.filter((post) => post.slug !== params.excludeSlug);
123
125
  }
@@ -153,7 +155,8 @@ function createDraftsQueries(client, headers) {
153
155
  const errorResponse = response;
154
156
  throw toError(errorResponse.error);
155
157
  }
156
- return response.data ?? [];
158
+ const draftsResponse = response;
159
+ return draftsResponse.data?.items ?? [];
157
160
  } catch (error) {
158
161
  throw error;
159
162
  }