@growsober/sdk 1.0.5 → 1.0.8
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.
- package/dist/__tests__/e2e.test.d.ts +30 -0
- package/dist/__tests__/e2e.test.js +959 -63
- package/dist/api/mutations/badges.d.ts +116 -0
- package/dist/api/mutations/badges.js +177 -0
- package/dist/api/mutations/brands.d.ts +251 -0
- package/dist/api/mutations/brands.js +242 -0
- package/dist/api/mutations/creators.d.ts +131 -0
- package/dist/api/mutations/creators.js +129 -0
- package/dist/api/mutations/event-chat.d.ts +2 -2
- package/dist/api/mutations/event-chat.js +9 -9
- package/dist/api/mutations/index.d.ts +4 -0
- package/dist/api/mutations/index.js +5 -1
- package/dist/api/mutations/jack.d.ts +29 -0
- package/dist/api/mutations/jack.js +41 -1
- package/dist/api/mutations/products.d.ts +175 -0
- package/dist/api/mutations/products.js +226 -0
- package/dist/api/mutations/support.d.ts +20 -1
- package/dist/api/mutations/support.js +36 -1
- package/dist/api/queries/badges.d.ts +221 -0
- package/dist/api/queries/badges.js +290 -0
- package/dist/api/queries/bookings.d.ts +1 -1
- package/dist/api/queries/brands.d.ts +248 -0
- package/dist/api/queries/brands.js +226 -0
- package/dist/api/queries/businesses.d.ts +61 -1
- package/dist/api/queries/businesses.js +27 -1
- package/dist/api/queries/creators.d.ts +332 -0
- package/dist/api/queries/creators.js +249 -0
- package/dist/api/queries/event-chat.d.ts +1 -1
- package/dist/api/queries/event-chat.js +4 -4
- package/dist/api/queries/events.d.ts +45 -0
- package/dist/api/queries/index.d.ts +5 -0
- package/dist/api/queries/index.js +6 -1
- package/dist/api/queries/jack.d.ts +80 -0
- package/dist/api/queries/jack.js +98 -1
- package/dist/api/queries/library.d.ts +8 -0
- package/dist/api/queries/products.d.ts +185 -0
- package/dist/api/queries/products.js +203 -0
- package/dist/api/queries/support.d.ts +46 -1
- package/dist/api/queries/support.js +48 -1
- package/dist/api/queries/venues.d.ts +304 -0
- package/dist/api/queries/venues.js +211 -0
- package/dist/api/types.d.ts +245 -0
- package/dist/api/types.js +6 -1
- package/dist/api/utils/eventGrouping.d.ts +104 -0
- package/dist/api/utils/eventGrouping.js +155 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +5 -1
- package/package.json +5 -2
- package/src/__tests__/e2e.test.ts +996 -64
- package/src/api/mutations/badges.ts +228 -0
- package/src/api/mutations/brands.ts +376 -0
- package/src/api/mutations/creators.ts +171 -0
- package/src/api/mutations/event-chat.ts +8 -8
- package/src/api/mutations/index.ts +4 -0
- package/src/api/mutations/jack.ts +50 -1
- package/src/api/mutations/products.ts +336 -0
- package/src/api/mutations/support.ts +44 -0
- package/src/api/queries/badges.ts +385 -0
- package/src/api/queries/brands.ts +281 -0
- package/src/api/queries/businesses.ts +30 -1
- package/src/api/queries/creators.ts +308 -0
- package/src/api/queries/event-chat.ts +3 -3
- package/src/api/queries/index.ts +5 -0
- package/src/api/queries/jack.ts +139 -1
- package/src/api/queries/products.ts +312 -0
- package/src/api/queries/support.ts +54 -0
- package/src/api/queries/venues.ts +271 -0
- package/src/api/types.ts +317 -1
- package/src/api/utils/eventGrouping.ts +181 -0
- package/src/index.ts +6 -0
|
@@ -22,7 +22,7 @@ function useUpdateChatSettings(eventId) {
|
|
|
22
22
|
return (0, react_query_1.useMutation)({
|
|
23
23
|
mutationFn: async (data) => {
|
|
24
24
|
const client = (0, client_1.getApiClient)();
|
|
25
|
-
const response = await client.put(`/events/${eventId}/chat/settings`, data);
|
|
25
|
+
const response = await client.put(`/api/v1/events/${eventId}/chat/settings`, data);
|
|
26
26
|
return response.data;
|
|
27
27
|
},
|
|
28
28
|
onSuccess: () => {
|
|
@@ -41,7 +41,7 @@ function useJoinEventChat(eventId) {
|
|
|
41
41
|
return (0, react_query_1.useMutation)({
|
|
42
42
|
mutationFn: async () => {
|
|
43
43
|
const client = (0, client_1.getApiClient)();
|
|
44
|
-
const response = await client.post(`/events/${eventId}/chat/join`);
|
|
44
|
+
const response = await client.post(`/api/v1/events/${eventId}/chat/join`);
|
|
45
45
|
return response.data;
|
|
46
46
|
},
|
|
47
47
|
onSuccess: () => {
|
|
@@ -58,7 +58,7 @@ function useLeaveEventChat(eventId) {
|
|
|
58
58
|
return (0, react_query_1.useMutation)({
|
|
59
59
|
mutationFn: async () => {
|
|
60
60
|
const client = (0, client_1.getApiClient)();
|
|
61
|
-
await client.post(`/events/${eventId}/chat/leave`);
|
|
61
|
+
await client.post(`/api/v1/events/${eventId}/chat/leave`);
|
|
62
62
|
},
|
|
63
63
|
onSuccess: () => {
|
|
64
64
|
queryClient.invalidateQueries({ queryKey: event_chat_1.eventChatKeys.chat(eventId) });
|
|
@@ -74,7 +74,7 @@ function useUpdateMemberSettings(eventId) {
|
|
|
74
74
|
return (0, react_query_1.useMutation)({
|
|
75
75
|
mutationFn: async (data) => {
|
|
76
76
|
const client = (0, client_1.getApiClient)();
|
|
77
|
-
const response = await client.put(`/events/${eventId}/chat/settings/me`, data);
|
|
77
|
+
const response = await client.put(`/api/v1/events/${eventId}/chat/settings/me`, data);
|
|
78
78
|
return response.data;
|
|
79
79
|
},
|
|
80
80
|
onSuccess: () => {
|
|
@@ -89,7 +89,7 @@ function useMarkMessagesAsRead(eventId) {
|
|
|
89
89
|
return (0, react_query_1.useMutation)({
|
|
90
90
|
mutationFn: async () => {
|
|
91
91
|
const client = (0, client_1.getApiClient)();
|
|
92
|
-
await client.post(`/events/${eventId}/chat/read`);
|
|
92
|
+
await client.post(`/api/v1/events/${eventId}/chat/read`);
|
|
93
93
|
},
|
|
94
94
|
});
|
|
95
95
|
}
|
|
@@ -104,7 +104,7 @@ function useSendEventChatMessage(eventId) {
|
|
|
104
104
|
return (0, react_query_1.useMutation)({
|
|
105
105
|
mutationFn: async (data) => {
|
|
106
106
|
const client = (0, client_1.getApiClient)();
|
|
107
|
-
const response = await client.post(`/events/${eventId}/chat/messages`, data);
|
|
107
|
+
const response = await client.post(`/api/v1/events/${eventId}/chat/messages`, data);
|
|
108
108
|
return response.data;
|
|
109
109
|
},
|
|
110
110
|
onSuccess: () => {
|
|
@@ -121,7 +121,7 @@ function useUpdateEventChatMessage(eventId) {
|
|
|
121
121
|
return (0, react_query_1.useMutation)({
|
|
122
122
|
mutationFn: async ({ messageId, content }) => {
|
|
123
123
|
const client = (0, client_1.getApiClient)();
|
|
124
|
-
const response = await client.put(`/events/${eventId}/chat/messages/${messageId}`, { content });
|
|
124
|
+
const response = await client.put(`/api/v1/events/${eventId}/chat/messages/${messageId}`, { content });
|
|
125
125
|
return response.data;
|
|
126
126
|
},
|
|
127
127
|
onSuccess: () => {
|
|
@@ -137,11 +137,11 @@ function useDeleteEventChatMessage(eventId) {
|
|
|
137
137
|
return (0, react_query_1.useMutation)({
|
|
138
138
|
mutationFn: async (messageId) => {
|
|
139
139
|
const client = (0, client_1.getApiClient)();
|
|
140
|
-
await client.delete(`/events/${eventId}/chat/messages/${messageId}`);
|
|
140
|
+
await client.delete(`/api/v1/events/${eventId}/chat/messages/${messageId}`);
|
|
141
141
|
},
|
|
142
142
|
onSuccess: () => {
|
|
143
143
|
queryClient.invalidateQueries({ queryKey: event_chat_1.eventChatKeys.messages(eventId) });
|
|
144
144
|
},
|
|
145
145
|
});
|
|
146
146
|
}
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event-chat.js","sourceRoot":"","sources":["../../../src/api/mutations/event-chat.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { eventChatKeys } from '../queries/event-chat';\nimport type {\n  ChatMemberResponse,\n  ChatMessageResponse,\n  EventChatResponse,\n  SendChatMessageRequest,\n  UpdateChatMessageRequest,\n  UpdateChatSettingsRequest,\n  UpdateMemberSettingsRequest,\n} from '../types';\n\n// ============================================================================\n// CHAT MANAGEMENT\n// ============================================================================\n\n/**\n * Update chat settings (hosts only)\n */\nexport function useUpdateChatSettings(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: UpdateChatSettingsRequest) => {\n      const client = getApiClient();\n      const response = await client.put<EventChatResponse>(\n        `/events/${eventId}/chat/settings`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.chat(eventId) });\n    },\n  });\n}\n\n// ============================================================================\n// MEMBER MANAGEMENT\n// ============================================================================\n\n/**\n * Join event chat\n */\nexport function useJoinEventChat(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async () => {\n      const client = getApiClient();\n      const response = await client.post<ChatMemberResponse>(\n        `/events/${eventId}/chat/join`\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.chat(eventId) });\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.members(eventId) });\n    },\n  });\n}\n\n/**\n * Leave event chat\n */\nexport function useLeaveEventChat(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async () => {\n      const client = getApiClient();\n      await client.post(`/events/${eventId}/chat/leave`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.chat(eventId) });\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.members(eventId) });\n    },\n  });\n}\n\n/**\n * Update member settings (mute, nickname)\n */\nexport function useUpdateMemberSettings(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: UpdateMemberSettingsRequest) => {\n      const client = getApiClient();\n      const response = await client.put<ChatMemberResponse>(\n        `/events/${eventId}/chat/settings/me`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.members(eventId) });\n    },\n  });\n}\n\n/**\n * Mark messages as read\n */\nexport function useMarkMessagesAsRead(eventId: string) {\n  return useMutation({\n    mutationFn: async () => {\n      const client = getApiClient();\n      await client.post(`/events/${eventId}/chat/read`);\n    },\n  });\n}\n\n// ============================================================================\n// MESSAGES\n// ============================================================================\n\n/**\n * Send a message\n */\nexport function useSendEventChatMessage(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: SendChatMessageRequest) => {\n      const client = getApiClient();\n      const response = await client.post<ChatMessageResponse>(\n        `/events/${eventId}/chat/messages`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.messages(eventId) });\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.chat(eventId) });\n    },\n  });\n}\n\n/**\n * Update a message\n */\nexport function useUpdateEventChatMessage(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ messageId, content }: { messageId: string } & UpdateChatMessageRequest) => {\n      const client = getApiClient();\n      const response = await client.put<ChatMessageResponse>(\n        `/events/${eventId}/chat/messages/${messageId}`,\n        { content }\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.messages(eventId) });\n    },\n  });\n}\n\n/**\n * Delete a message\n */\nexport function useDeleteEventChatMessage(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (messageId: string) => {\n      const client = getApiClient();\n      await client.delete(`/events/${eventId}/chat/messages/${messageId}`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.messages(eventId) });\n    },\n  });\n}\n"]}
|
|
147
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event-chat.js","sourceRoot":"","sources":["../../../src/api/mutations/event-chat.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { eventChatKeys } from '../queries/event-chat';\nimport type {\n  ChatMemberResponse,\n  ChatMessageResponse,\n  EventChatResponse,\n  SendChatMessageRequest,\n  UpdateChatMessageRequest,\n  UpdateChatSettingsRequest,\n  UpdateMemberSettingsRequest,\n} from '../types';\n\n// ============================================================================\n// CHAT MANAGEMENT\n// ============================================================================\n\n/**\n * Update chat settings (hosts only)\n */\nexport function useUpdateChatSettings(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: UpdateChatSettingsRequest) => {\n      const client = getApiClient();\n      const response = await client.put<EventChatResponse>(\n        `/api/v1/events/${eventId}/chat/settings`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.chat(eventId) });\n    },\n  });\n}\n\n// ============================================================================\n// MEMBER MANAGEMENT\n// ============================================================================\n\n/**\n * Join event chat\n */\nexport function useJoinEventChat(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async () => {\n      const client = getApiClient();\n      const response = await client.post<ChatMemberResponse>(\n        `/api/v1/events/${eventId}/chat/join`\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.chat(eventId) });\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.members(eventId) });\n    },\n  });\n}\n\n/**\n * Leave event chat\n */\nexport function useLeaveEventChat(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async () => {\n      const client = getApiClient();\n      await client.post(`/api/v1/events/${eventId}/chat/leave`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.chat(eventId) });\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.members(eventId) });\n    },\n  });\n}\n\n/**\n * Update member settings (mute, nickname)\n */\nexport function useUpdateMemberSettings(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: UpdateMemberSettingsRequest) => {\n      const client = getApiClient();\n      const response = await client.put<ChatMemberResponse>(\n        `/api/v1/events/${eventId}/chat/settings/me`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.members(eventId) });\n    },\n  });\n}\n\n/**\n * Mark messages as read\n */\nexport function useMarkMessagesAsRead(eventId: string) {\n  return useMutation({\n    mutationFn: async () => {\n      const client = getApiClient();\n      await client.post(`/api/v1/events/${eventId}/chat/read`);\n    },\n  });\n}\n\n// ============================================================================\n// MESSAGES\n// ============================================================================\n\n/**\n * Send a message\n */\nexport function useSendEventChatMessage(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: SendChatMessageRequest) => {\n      const client = getApiClient();\n      const response = await client.post<ChatMessageResponse>(\n        `/api/v1/events/${eventId}/chat/messages`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.messages(eventId) });\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.chat(eventId) });\n    },\n  });\n}\n\n/**\n * Update a message\n */\nexport function useUpdateEventChatMessage(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ messageId, content }: { messageId: string } & UpdateChatMessageRequest) => {\n      const client = getApiClient();\n      const response = await client.put<ChatMessageResponse>(\n        `/api/v1/events/${eventId}/chat/messages/${messageId}`,\n        { content }\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.messages(eventId) });\n    },\n  });\n}\n\n/**\n * Delete a message\n */\nexport function useDeleteEventChatMessage(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (messageId: string) => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/events/${eventId}/chat/messages/${messageId}`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.messages(eventId) });\n    },\n  });\n}\n"]}
|
|
@@ -37,4 +37,8 @@ __exportStar(require("./grow90"), exports);
|
|
|
37
37
|
__exportStar(require("./matching"), exports);
|
|
38
38
|
__exportStar(require("./event-chat"), exports);
|
|
39
39
|
__exportStar(require("./user-pins"), exports);
|
|
40
|
-
|
|
40
|
+
__exportStar(require("./badges"), exports);
|
|
41
|
+
__exportStar(require("./creators"), exports);
|
|
42
|
+
__exportStar(require("./brands"), exports);
|
|
43
|
+
__exportStar(require("./products"), exports);
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL211dGF0aW9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7R0FJRzs7Ozs7Ozs7Ozs7Ozs7OztBQUVILDBDQUF3QjtBQUN4Qix5Q0FBdUI7QUFDdkIsNkNBQTJCO0FBQzNCLDJDQUF5QjtBQUN6Qix5Q0FBdUI7QUFDdkIsNENBQTBCO0FBQzFCLHdDQUFzQjtBQUN0QixrREFBZ0M7QUFDaEMsMkNBQXlCO0FBQ3pCLGtEQUFnQztBQUNoQyw0Q0FBMEI7QUFDMUIsMENBQXdCO0FBQ3hCLHlDQUF1QjtBQUN2QixnREFBOEI7QUFDOUIsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQiwrQ0FBNkI7QUFDN0IsOENBQTRCO0FBQzVCLDJDQUF5QjtBQUN6Qiw2Q0FBMkI7QUFDM0IsMkNBQXlCO0FBQ3pCLDZDQUEyQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogTXV0YXRpb24gSG9va3NcbiAqXG4gKiBSZS1leHBvcnRzIGFsbCBtdXRhdGlvbiBob29rcyBmb3IgQVBJIGVuZHBvaW50cy5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2FkbWluJztcbmV4cG9ydCAqIGZyb20gJy4vYXV0aCc7XG5leHBvcnQgKiBmcm9tICcuL2Jvb2tpbmdzJztcbmV4cG9ydCAqIGZyb20gJy4vZXZlbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vaHVicyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYnJhcnknO1xuZXhwb3J0ICogZnJvbSAnLi9tYXAnO1xuZXhwb3J0ICogZnJvbSAnLi9ub3RpZmljYXRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vb2ZmZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vc3Vic2NyaXB0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL3N1cHBvcnQnO1xuZXhwb3J0ICogZnJvbSAnLi91c2Vycyc7XG5leHBvcnQgKiBmcm9tICcuL2phY2snO1xuZXhwb3J0ICogZnJvbSAnLi9hbWJhc3NhZG9ycyc7XG5leHBvcnQgKiBmcm9tICcuL2dyb3c5MCc7XG5leHBvcnQgKiBmcm9tICcuL21hdGNoaW5nJztcbmV4cG9ydCAqIGZyb20gJy4vZXZlbnQtY2hhdCc7XG5leHBvcnQgKiBmcm9tICcuL3VzZXItcGlucyc7XG5leHBvcnQgKiBmcm9tICcuL2JhZGdlcyc7XG5leHBvcnQgKiBmcm9tICcuL2NyZWF0b3JzJztcbmV4cG9ydCAqIGZyb20gJy4vYnJhbmRzJztcbmV4cG9ydCAqIGZyb20gJy4vcHJvZHVjdHMnO1xuIl19
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { UseMutationOptions } from '@tanstack/react-query';
|
|
2
|
+
import { JackEntryType, JackTimelineEntry } from '../queries/jack';
|
|
2
3
|
export interface ChatRequest {
|
|
3
4
|
message: string;
|
|
4
5
|
conversationId?: string;
|
|
@@ -11,6 +12,11 @@ export interface ChatResponse {
|
|
|
11
12
|
export interface NewConversationResponse {
|
|
12
13
|
conversationId: string;
|
|
13
14
|
}
|
|
15
|
+
export interface AddEntryRequest {
|
|
16
|
+
entryType: JackEntryType;
|
|
17
|
+
content: string;
|
|
18
|
+
metadata?: Record<string, any>;
|
|
19
|
+
}
|
|
14
20
|
/**
|
|
15
21
|
* Send a message to Jack and get a response
|
|
16
22
|
*
|
|
@@ -59,3 +65,26 @@ export declare function useArchiveJackConversation(options?: Omit<UseMutationOpt
|
|
|
59
65
|
}, Error, string>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
|
|
60
66
|
success: boolean;
|
|
61
67
|
}, Error, string, unknown>;
|
|
68
|
+
/**
|
|
69
|
+
* Add an entry to the Jack timeline (check-in, reflection, mood log, win, journal)
|
|
70
|
+
*
|
|
71
|
+
* @example
|
|
72
|
+
* ```tsx
|
|
73
|
+
* const addEntry = useAddJackEntry();
|
|
74
|
+
*
|
|
75
|
+
* // Add a check-in
|
|
76
|
+
* await addEntry.mutateAsync({
|
|
77
|
+
* entryType: 'CHECK_IN',
|
|
78
|
+
* content: 'Feeling great today! Day 30.',
|
|
79
|
+
* metadata: { moodScore: 4, stayedSober: true },
|
|
80
|
+
* });
|
|
81
|
+
*
|
|
82
|
+
* // Add a win
|
|
83
|
+
* await addEntry.mutateAsync({
|
|
84
|
+
* entryType: 'WIN',
|
|
85
|
+
* content: 'Said no to drinks at dinner!',
|
|
86
|
+
* metadata: { category: 'SOBRIETY' },
|
|
87
|
+
* });
|
|
88
|
+
* ```
|
|
89
|
+
*/
|
|
90
|
+
export declare function useAddJackEntry(options?: Omit<UseMutationOptions<JackTimelineEntry, Error, AddEntryRequest>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<JackTimelineEntry, Error, AddEntryRequest, unknown>;
|
|
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.useChatWithJack = useChatWithJack;
|
|
4
4
|
exports.useStartJackConversation = useStartJackConversation;
|
|
5
5
|
exports.useArchiveJackConversation = useArchiveJackConversation;
|
|
6
|
+
exports.useAddJackEntry = useAddJackEntry;
|
|
6
7
|
const react_query_1 = require("@tanstack/react-query");
|
|
7
8
|
const client_1 = require("../client");
|
|
8
9
|
const jack_1 = require("../queries/jack");
|
|
@@ -101,4 +102,43 @@ function useArchiveJackConversation(options) {
|
|
|
101
102
|
...options,
|
|
102
103
|
});
|
|
103
104
|
}
|
|
104
|
-
|
|
105
|
+
/**
|
|
106
|
+
* Add an entry to the Jack timeline (check-in, reflection, mood log, win, journal)
|
|
107
|
+
*
|
|
108
|
+
* @example
|
|
109
|
+
* ```tsx
|
|
110
|
+
* const addEntry = useAddJackEntry();
|
|
111
|
+
*
|
|
112
|
+
* // Add a check-in
|
|
113
|
+
* await addEntry.mutateAsync({
|
|
114
|
+
* entryType: 'CHECK_IN',
|
|
115
|
+
* content: 'Feeling great today! Day 30.',
|
|
116
|
+
* metadata: { moodScore: 4, stayedSober: true },
|
|
117
|
+
* });
|
|
118
|
+
*
|
|
119
|
+
* // Add a win
|
|
120
|
+
* await addEntry.mutateAsync({
|
|
121
|
+
* entryType: 'WIN',
|
|
122
|
+
* content: 'Said no to drinks at dinner!',
|
|
123
|
+
* metadata: { category: 'SOBRIETY' },
|
|
124
|
+
* });
|
|
125
|
+
* ```
|
|
126
|
+
*/
|
|
127
|
+
function useAddJackEntry(options) {
|
|
128
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
129
|
+
return (0, react_query_1.useMutation)({
|
|
130
|
+
mutationFn: async (data) => {
|
|
131
|
+
const client = (0, client_1.getApiClient)();
|
|
132
|
+
const response = await client.post('/api/v1/support/jack/entry', data);
|
|
133
|
+
return response.data?.data || response.data;
|
|
134
|
+
},
|
|
135
|
+
onSuccess: () => {
|
|
136
|
+
// Invalidate timeline and stats queries
|
|
137
|
+
queryClient.invalidateQueries({ queryKey: jack_1.jackKeys.timeline() });
|
|
138
|
+
queryClient.invalidateQueries({ queryKey: jack_1.jackKeys.stats() });
|
|
139
|
+
queryClient.invalidateQueries({ queryKey: jack_1.jackKeys.history() });
|
|
140
|
+
},
|
|
141
|
+
...options,
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jack.js","sourceRoot":"","sources":["../../../src/api/mutations/jack.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient, UseMutationOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { jackKeys, JackEntryType, JackTimelineEntry } from '../queries/jack';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface ChatRequest {\n  message: string;\n  conversationId?: string;\n}\n\nexport interface ChatResponse {\n  message: string;\n  conversationId: string;\n  messageId: string;\n}\n\nexport interface NewConversationResponse {\n  conversationId: string;\n}\n\nexport interface AddEntryRequest {\n  entryType: JackEntryType;\n  content: string;\n  metadata?: Record<string, any>;\n}\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Send a message to Jack and get a response\n *\n * @example\n * ```tsx\n * const chatMutation = useChatWithJack();\n *\n * const handleSend = async (message: string) => {\n *   const response = await chatMutation.mutateAsync({\n *     message,\n *     conversationId: currentConversationId, // optional\n *   });\n *   console.log('Jack says:', response.message);\n * };\n * ```\n */\nexport function useChatWithJack(\n  options?: Omit<UseMutationOptions<ChatResponse, Error, ChatRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: ChatRequest): Promise<ChatResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/jack/chat', data);\n      // API wraps response in { data: {...}, meta: {...} }\n      return response.data?.data || response.data;\n    },\n    onSuccess: (data) => {\n      // Invalidate conversation queries to refresh the list\n      queryClient.invalidateQueries({ queryKey: jackKeys.conversations() });\n      queryClient.invalidateQueries({ queryKey: jackKeys.history() });\n      if (data.conversationId) {\n        queryClient.invalidateQueries({ queryKey: jackKeys.conversation(data.conversationId) });\n      }\n    },\n    ...options,\n  });\n}\n\n/**\n * Start a new conversation with Jack\n *\n * @example\n * ```tsx\n * const newConversation = useStartJackConversation();\n *\n * const handleNewChat = async () => {\n *   const { conversationId } = await newConversation.mutateAsync();\n *   setCurrentConversationId(conversationId);\n * };\n * ```\n */\nexport function useStartJackConversation(\n  options?: Omit<UseMutationOptions<NewConversationResponse, Error, void>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (): Promise<NewConversationResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/jack/conversations/new');\n      // API wraps response in { data: {...}, meta: {...} }\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: jackKeys.conversations() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Archive a conversation with Jack\n *\n * @example\n * ```tsx\n * const archiveConversation = useArchiveJackConversation();\n *\n * const handleArchive = async (conversationId: string) => {\n *   await archiveConversation.mutateAsync(conversationId);\n * };\n * ```\n */\nexport function useArchiveJackConversation(\n  options?: Omit<UseMutationOptions<{ success: boolean }, Error, string>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (conversationId: string): Promise<{ success: boolean }> => {\n      const client = getApiClient();\n      const response = await client.delete(`/api/v1/support/jack/conversations/${conversationId}`);\n      // API wraps response in { data: {...}, meta: {...} }\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: jackKeys.conversations() });\n      queryClient.invalidateQueries({ queryKey: jackKeys.history() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Add an entry to the Jack timeline (check-in, reflection, mood log, win, journal)\n *\n * @example\n * ```tsx\n * const addEntry = useAddJackEntry();\n *\n * // Add a check-in\n * await addEntry.mutateAsync({\n *   entryType: 'CHECK_IN',\n *   content: 'Feeling great today! Day 30.',\n *   metadata: { moodScore: 4, stayedSober: true },\n * });\n *\n * // Add a win\n * await addEntry.mutateAsync({\n *   entryType: 'WIN',\n *   content: 'Said no to drinks at dinner!',\n *   metadata: { category: 'SOBRIETY' },\n * });\n * ```\n */\nexport function useAddJackEntry(\n  options?: Omit<UseMutationOptions<JackTimelineEntry, Error, AddEntryRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: AddEntryRequest): Promise<JackTimelineEntry> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/jack/entry', data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      // Invalidate timeline and stats queries\n      queryClient.invalidateQueries({ queryKey: jackKeys.timeline() });\n      queryClient.invalidateQueries({ queryKey: jackKeys.stats() });\n      queryClient.invalidateQueries({ queryKey: jackKeys.history() });\n    },\n    ...options,\n  });\n}\n"]}
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
import { CreatorProductResponse, ProductBookingResponse, ProductType, DeliveryMethod } from '../queries/products';
|
|
2
|
+
export interface CreateProductRequest {
|
|
3
|
+
title: string;
|
|
4
|
+
description?: string;
|
|
5
|
+
imageUrl?: string;
|
|
6
|
+
type?: ProductType;
|
|
7
|
+
price: number;
|
|
8
|
+
currency?: string;
|
|
9
|
+
durationMinutes?: number;
|
|
10
|
+
maxParticipants?: number;
|
|
11
|
+
deliveryMethod?: DeliveryMethod;
|
|
12
|
+
locationDetails?: string;
|
|
13
|
+
slug?: string;
|
|
14
|
+
}
|
|
15
|
+
export interface UpdateProductRequest {
|
|
16
|
+
title?: string;
|
|
17
|
+
description?: string;
|
|
18
|
+
imageUrl?: string;
|
|
19
|
+
type?: ProductType;
|
|
20
|
+
price?: number;
|
|
21
|
+
currency?: string;
|
|
22
|
+
durationMinutes?: number;
|
|
23
|
+
maxParticipants?: number;
|
|
24
|
+
deliveryMethod?: DeliveryMethod;
|
|
25
|
+
locationDetails?: string;
|
|
26
|
+
isActive?: boolean;
|
|
27
|
+
isFeatured?: boolean;
|
|
28
|
+
}
|
|
29
|
+
export interface BookProductRequest {
|
|
30
|
+
scheduledAt: string;
|
|
31
|
+
timezone?: string;
|
|
32
|
+
clientNotes?: string;
|
|
33
|
+
}
|
|
34
|
+
export interface UpdateBookingRequest {
|
|
35
|
+
scheduledAt?: string;
|
|
36
|
+
clientNotes?: string;
|
|
37
|
+
creatorNotes?: string;
|
|
38
|
+
meetingLink?: string;
|
|
39
|
+
}
|
|
40
|
+
export interface CancelBookingRequest {
|
|
41
|
+
reason?: string;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Create a new product for a creator
|
|
45
|
+
*
|
|
46
|
+
* @example
|
|
47
|
+
* ```tsx
|
|
48
|
+
* const { mutate: createProduct, isLoading } = useCreateProduct();
|
|
49
|
+
*
|
|
50
|
+
* createProduct({
|
|
51
|
+
* creatorId: 'creator-123',
|
|
52
|
+
* data: {
|
|
53
|
+
* title: '1-on-1 Coaching Session',
|
|
54
|
+
* description: 'Personal coaching session',
|
|
55
|
+
* type: 'SESSION_1ON1',
|
|
56
|
+
* price: 5000,
|
|
57
|
+
* durationMinutes: 60,
|
|
58
|
+
* },
|
|
59
|
+
* });
|
|
60
|
+
* ```
|
|
61
|
+
*/
|
|
62
|
+
export declare function useCreateProduct(): import("@tanstack/react-query").UseMutationResult<CreatorProductResponse, Error, {
|
|
63
|
+
creatorId: string;
|
|
64
|
+
data: CreateProductRequest;
|
|
65
|
+
}, unknown>;
|
|
66
|
+
/**
|
|
67
|
+
* Update an existing product
|
|
68
|
+
*
|
|
69
|
+
* @example
|
|
70
|
+
* ```tsx
|
|
71
|
+
* const { mutate: updateProduct, isLoading } = useUpdateProduct();
|
|
72
|
+
*
|
|
73
|
+
* updateProduct({
|
|
74
|
+
* creatorId: 'creator-123',
|
|
75
|
+
* productId: 'product-456',
|
|
76
|
+
* data: {
|
|
77
|
+
* price: 6000,
|
|
78
|
+
* isActive: true,
|
|
79
|
+
* },
|
|
80
|
+
* });
|
|
81
|
+
* ```
|
|
82
|
+
*/
|
|
83
|
+
export declare function useUpdateProduct(): import("@tanstack/react-query").UseMutationResult<CreatorProductResponse, Error, {
|
|
84
|
+
creatorId: string;
|
|
85
|
+
productId: string;
|
|
86
|
+
data: UpdateProductRequest;
|
|
87
|
+
}, unknown>;
|
|
88
|
+
/**
|
|
89
|
+
* Delete a product
|
|
90
|
+
*
|
|
91
|
+
* @example
|
|
92
|
+
* ```tsx
|
|
93
|
+
* const { mutate: deleteProduct, isLoading } = useDeleteProduct();
|
|
94
|
+
*
|
|
95
|
+
* deleteProduct({
|
|
96
|
+
* creatorId: 'creator-123',
|
|
97
|
+
* productId: 'product-456',
|
|
98
|
+
* });
|
|
99
|
+
* ```
|
|
100
|
+
*/
|
|
101
|
+
export declare function useDeleteProduct(): import("@tanstack/react-query").UseMutationResult<void, Error, {
|
|
102
|
+
creatorId: string;
|
|
103
|
+
productId: string;
|
|
104
|
+
}, unknown>;
|
|
105
|
+
/**
|
|
106
|
+
* Book a product/session
|
|
107
|
+
*
|
|
108
|
+
* @example
|
|
109
|
+
* ```tsx
|
|
110
|
+
* const { mutate: bookProduct, isLoading } = useBookProduct();
|
|
111
|
+
*
|
|
112
|
+
* bookProduct({
|
|
113
|
+
* productId: 'product-123',
|
|
114
|
+
* data: {
|
|
115
|
+
* scheduledAt: '2024-03-15T10:00:00Z',
|
|
116
|
+
* timezone: 'Europe/London',
|
|
117
|
+
* clientNotes: 'Looking forward to the session!',
|
|
118
|
+
* },
|
|
119
|
+
* });
|
|
120
|
+
* ```
|
|
121
|
+
*/
|
|
122
|
+
export declare function useBookProduct(): import("@tanstack/react-query").UseMutationResult<ProductBookingResponse, Error, {
|
|
123
|
+
productId: string;
|
|
124
|
+
data: BookProductRequest;
|
|
125
|
+
}, unknown>;
|
|
126
|
+
/**
|
|
127
|
+
* Update a product booking
|
|
128
|
+
*
|
|
129
|
+
* @example
|
|
130
|
+
* ```tsx
|
|
131
|
+
* const { mutate: updateBooking, isLoading } = useUpdateProductBooking();
|
|
132
|
+
*
|
|
133
|
+
* updateBooking({
|
|
134
|
+
* bookingId: 'booking-123',
|
|
135
|
+
* data: {
|
|
136
|
+
* scheduledAt: '2024-03-16T14:00:00Z',
|
|
137
|
+
* clientNotes: 'Rescheduled due to conflict',
|
|
138
|
+
* },
|
|
139
|
+
* });
|
|
140
|
+
* ```
|
|
141
|
+
*/
|
|
142
|
+
export declare function useUpdateProductBooking(): import("@tanstack/react-query").UseMutationResult<ProductBookingResponse, Error, {
|
|
143
|
+
bookingId: string;
|
|
144
|
+
data: UpdateBookingRequest;
|
|
145
|
+
}, unknown>;
|
|
146
|
+
/**
|
|
147
|
+
* Cancel a product booking
|
|
148
|
+
*
|
|
149
|
+
* @example
|
|
150
|
+
* ```tsx
|
|
151
|
+
* const { mutate: cancelBooking, isLoading } = useCancelProductBooking();
|
|
152
|
+
*
|
|
153
|
+
* cancelBooking({
|
|
154
|
+
* bookingId: 'booking-123',
|
|
155
|
+
* data: { reason: 'Schedule conflict' },
|
|
156
|
+
* });
|
|
157
|
+
* ```
|
|
158
|
+
*/
|
|
159
|
+
export declare function useCancelProductBooking(): import("@tanstack/react-query").UseMutationResult<ProductBookingResponse, Error, {
|
|
160
|
+
bookingId: string;
|
|
161
|
+
data?: CancelBookingRequest;
|
|
162
|
+
}, unknown>;
|
|
163
|
+
/**
|
|
164
|
+
* Mark a booking as completed (creator only)
|
|
165
|
+
*
|
|
166
|
+
* @example
|
|
167
|
+
* ```tsx
|
|
168
|
+
* const { mutate: completeBooking, isLoading } = useCompleteProductBooking();
|
|
169
|
+
*
|
|
170
|
+
* completeBooking({ bookingId: 'booking-123' });
|
|
171
|
+
* ```
|
|
172
|
+
*/
|
|
173
|
+
export declare function useCompleteProductBooking(): import("@tanstack/react-query").UseMutationResult<ProductBookingResponse, Error, {
|
|
174
|
+
bookingId: string;
|
|
175
|
+
}, unknown>;
|