@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
|
@@ -28,7 +28,7 @@ function useEventChat(eventId) {
|
|
|
28
28
|
if (!eventId)
|
|
29
29
|
throw new Error('Event ID is required');
|
|
30
30
|
const client = (0, client_1.getApiClient)();
|
|
31
|
-
const response = await client.get(`/events/${eventId}/chat`);
|
|
31
|
+
const response = await client.get(`/api/v1/events/${eventId}/chat`);
|
|
32
32
|
return response.data;
|
|
33
33
|
},
|
|
34
34
|
enabled: !!eventId,
|
|
@@ -44,7 +44,7 @@ function useEventChatMembers(eventId) {
|
|
|
44
44
|
if (!eventId)
|
|
45
45
|
throw new Error('Event ID is required');
|
|
46
46
|
const client = (0, client_1.getApiClient)();
|
|
47
|
-
const response = await client.get(`/events/${eventId}/chat/members`);
|
|
47
|
+
const response = await client.get(`/api/v1/events/${eventId}/chat/members`);
|
|
48
48
|
return response.data;
|
|
49
49
|
},
|
|
50
50
|
enabled: !!eventId,
|
|
@@ -64,7 +64,7 @@ function useEventChatMessages(eventId, limit = 50) {
|
|
|
64
64
|
if (pageParam) {
|
|
65
65
|
params.append('cursor', pageParam);
|
|
66
66
|
}
|
|
67
|
-
const response = await client.get(`/events/${eventId}/chat/messages?${params.toString()}`);
|
|
67
|
+
const response = await client.get(`/api/v1/events/${eventId}/chat/messages?${params.toString()}`);
|
|
68
68
|
return response.data;
|
|
69
69
|
},
|
|
70
70
|
initialPageParam: undefined,
|
|
@@ -72,4 +72,4 @@ function useEventChatMessages(eventId, limit = 50) {
|
|
|
72
72
|
enabled: !!eventId,
|
|
73
73
|
});
|
|
74
74
|
}
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtY2hhdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvcXVlcmllcy9ldmVudC1jaGF0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQTBCQSxvQ0FXQztBQUtELGtEQVdDO0FBS0Qsb0RBbUJDO0FBN0VELHVEQUFtRTtBQUNuRSxzQ0FBeUM7QUFPekMsK0VBQStFO0FBQy9FLGFBQWE7QUFDYiwrRUFBK0U7QUFFbEUsUUFBQSxhQUFhLEdBQUc7SUFDM0IsR0FBRyxFQUFFLENBQUMsWUFBWSxDQUFVO0lBQzVCLElBQUksRUFBRSxDQUFDLE9BQWUsRUFBRSxFQUFFLENBQUMsQ0FBQyxHQUFHLHFCQUFhLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxPQUFPLENBQVU7SUFDM0UsT0FBTyxFQUFFLENBQUMsT0FBZSxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcscUJBQWEsQ0FBQyxHQUFHLEVBQUUsU0FBUyxFQUFFLE9BQU8sQ0FBVTtJQUNqRixRQUFRLEVBQUUsQ0FBQyxPQUFlLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyxxQkFBYSxDQUFDLEdBQUcsRUFBRSxVQUFVLEVBQUUsT0FBTyxDQUFVO0NBQ3BGLENBQUM7QUFFRiwrRUFBK0U7QUFDL0UsUUFBUTtBQUNSLCtFQUErRTtBQUUvRTs7R0FFRztBQUNILFNBQWdCLFlBQVksQ0FBQyxPQUEyQjtJQUN0RCxPQUFPLElBQUEsc0JBQVEsRUFBQztRQUNkLFFBQVEsRUFBRSxxQkFBYSxDQUFDLElBQUksQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDO1FBQzNDLE9BQU8sRUFBRSxLQUFLLElBQUksRUFBRTtZQUNsQixJQUFJLENBQUMsT0FBTztnQkFBRSxNQUFNLElBQUksS0FBSyxDQUFDLHNCQUFzQixDQUFDLENBQUM7WUFDdEQsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUM7WUFDOUIsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUFvQixrQkFBa0IsT0FBTyxPQUFPLENBQUMsQ0FBQztZQUN2RixPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUM7UUFDdkIsQ0FBQztRQUNELE9BQU8sRUFBRSxDQUFDLENBQUMsT0FBTztLQUNuQixDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixtQkFBbUIsQ0FBQyxPQUEyQjtJQUM3RCxPQUFPLElBQUEsc0JBQVEsRUFBQztRQUNkLFFBQVEsRUFBRSxxQkFBYSxDQUFDLE9BQU8sQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDO1FBQzlDLE9BQU8sRUFBRSxLQUFLLElBQUksRUFBRTtZQUNsQixJQUFJLENBQUMsT0FBTztnQkFBRSxNQUFNLElBQUksS0FBSyxDQUFDLHNCQUFzQixDQUFDLENBQUM7WUFDdEQsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUM7WUFDOUIsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUF1QixrQkFBa0IsT0FBTyxlQUFlLENBQUMsQ0FBQztZQUNsRyxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUM7UUFDdkIsQ0FBQztRQUNELE9BQU8sRUFBRSxDQUFDLENBQUMsT0FBTztLQUNuQixDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQ7O0dBRUc7QUFDSCxTQUFnQixvQkFBb0IsQ0FBQyxPQUEyQixFQUFFLEtBQUssR0FBRyxFQUFFO0lBQzFFLE9BQU8sSUFBQSw4QkFBZ0IsRUFBQztRQUN0QixRQUFRLEVBQUUscUJBQWEsQ0FBQyxRQUFRLENBQUMsT0FBTyxJQUFJLEVBQUUsQ0FBQztRQUMvQyxPQUFPLEVBQUUsS0FBSyxFQUFFLEVBQUUsU0FBUyxFQUFFLEVBQUUsRUFBRTtZQUMvQixJQUFJLENBQUMsT0FBTztnQkFBRSxNQUFNLElBQUksS0FBSyxDQUFDLHNCQUFzQixDQUFDLENBQUM7WUFDdEQsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUM7WUFDOUIsTUFBTSxNQUFNLEdBQUcsSUFBSSxlQUFlLENBQUMsRUFBRSxLQUFLLEVBQUUsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztZQUM3RCxJQUFJLFNBQVMsRUFBRSxDQUFDO2dCQUNkLE1BQU0sQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDO1lBQ3JDLENBQUM7WUFDRCxNQUFNLFFBQVEsR0FBRyxNQUFNLE1BQU0sQ0FBQyxHQUFHLENBQy9CLGtCQUFrQixPQUFPLGtCQUFrQixNQUFNLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FDL0QsQ0FBQztZQUNGLE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQztRQUN2QixDQUFDO1FBQ0QsZ0JBQWdCLEVBQUUsU0FBK0I7UUFDakQsZ0JBQWdCLEVBQUUsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxVQUFVO1FBQ25ELE9BQU8sRUFBRSxDQUFDLENBQUMsT0FBTztLQUNuQixDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlUXVlcnksIHVzZUluZmluaXRlUXVlcnkgfSBmcm9tICdAdGFuc3RhY2svcmVhY3QtcXVlcnknO1xuaW1wb3J0IHsgZ2V0QXBpQ2xpZW50IH0gZnJvbSAnLi4vY2xpZW50JztcbmltcG9ydCB0eXBlIHtcbiAgRXZlbnRDaGF0UmVzcG9uc2UsXG4gIENoYXRNZW1iZXJSZXNwb25zZSxcbiAgUGFnaW5hdGVkTWVzc2FnZXNSZXNwb25zZSxcbn0gZnJvbSAnLi4vdHlwZXMnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBRVUVSWSBLRVlTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBjb25zdCBldmVudENoYXRLZXlzID0ge1xuICBhbGw6IFsnZXZlbnQtY2hhdCddIGFzIGNvbnN0LFxuICBjaGF0OiAoZXZlbnRJZDogc3RyaW5nKSA9PiBbLi4uZXZlbnRDaGF0S2V5cy5hbGwsICdjaGF0JywgZXZlbnRJZF0gYXMgY29uc3QsXG4gIG1lbWJlcnM6IChldmVudElkOiBzdHJpbmcpID0+IFsuLi5ldmVudENoYXRLZXlzLmFsbCwgJ21lbWJlcnMnLCBldmVudElkXSBhcyBjb25zdCxcbiAgbWVzc2FnZXM6IChldmVudElkOiBzdHJpbmcpID0+IFsuLi5ldmVudENoYXRLZXlzLmFsbCwgJ21lc3NhZ2VzJywgZXZlbnRJZF0gYXMgY29uc3QsXG59O1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBIT09LU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKipcbiAqIEdldCBvciBjcmVhdGUgY2hhdCBmb3IgYW4gZXZlbnRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZUV2ZW50Q2hhdChldmVudElkOiBzdHJpbmcgfCB1bmRlZmluZWQpIHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogZXZlbnRDaGF0S2V5cy5jaGF0KGV2ZW50SWQgfHwgJycpLFxuICAgIHF1ZXJ5Rm46IGFzeW5jICgpID0+IHtcbiAgICAgIGlmICghZXZlbnRJZCkgdGhyb3cgbmV3IEVycm9yKCdFdmVudCBJRCBpcyByZXF1aXJlZCcpO1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KCk7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5nZXQ8RXZlbnRDaGF0UmVzcG9uc2U+KGAvYXBpL3YxL2V2ZW50cy8ke2V2ZW50SWR9L2NoYXRgKTtcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhO1xuICAgIH0sXG4gICAgZW5hYmxlZDogISFldmVudElkLFxuICB9KTtcbn1cblxuLyoqXG4gKiBHZXQgY2hhdCBtZW1iZXJzXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VFdmVudENoYXRNZW1iZXJzKGV2ZW50SWQ6IHN0cmluZyB8IHVuZGVmaW5lZCkge1xuICByZXR1cm4gdXNlUXVlcnkoe1xuICAgIHF1ZXJ5S2V5OiBldmVudENoYXRLZXlzLm1lbWJlcnMoZXZlbnRJZCB8fCAnJyksXG4gICAgcXVlcnlGbjogYXN5bmMgKCkgPT4ge1xuICAgICAgaWYgKCFldmVudElkKSB0aHJvdyBuZXcgRXJyb3IoJ0V2ZW50IElEIGlzIHJlcXVpcmVkJyk7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldDxDaGF0TWVtYmVyUmVzcG9uc2VbXT4oYC9hcGkvdjEvZXZlbnRzLyR7ZXZlbnRJZH0vY2hhdC9tZW1iZXJzYCk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YTtcbiAgICB9LFxuICAgIGVuYWJsZWQ6ICEhZXZlbnRJZCxcbiAgfSk7XG59XG5cbi8qKlxuICogR2V0IGNoYXQgbWVzc2FnZXMgd2l0aCBpbmZpbml0ZSBzY3JvbGwgcGFnaW5hdGlvblxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlRXZlbnRDaGF0TWVzc2FnZXMoZXZlbnRJZDogc3RyaW5nIHwgdW5kZWZpbmVkLCBsaW1pdCA9IDUwKSB7XG4gIHJldHVybiB1c2VJbmZpbml0ZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogZXZlbnRDaGF0S2V5cy5tZXNzYWdlcyhldmVudElkIHx8ICcnKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoeyBwYWdlUGFyYW0gfSkgPT4ge1xuICAgICAgaWYgKCFldmVudElkKSB0aHJvdyBuZXcgRXJyb3IoJ0V2ZW50IElEIGlzIHJlcXVpcmVkJyk7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHBhcmFtcyA9IG5ldyBVUkxTZWFyY2hQYXJhbXMoeyBsaW1pdDogU3RyaW5nKGxpbWl0KSB9KTtcbiAgICAgIGlmIChwYWdlUGFyYW0pIHtcbiAgICAgICAgcGFyYW1zLmFwcGVuZCgnY3Vyc29yJywgcGFnZVBhcmFtKTtcbiAgICAgIH1cbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldDxQYWdpbmF0ZWRNZXNzYWdlc1Jlc3BvbnNlPihcbiAgICAgICAgYC9hcGkvdjEvZXZlbnRzLyR7ZXZlbnRJZH0vY2hhdC9tZXNzYWdlcz8ke3BhcmFtcy50b1N0cmluZygpfWBcbiAgICAgICk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YTtcbiAgICB9LFxuICAgIGluaXRpYWxQYWdlUGFyYW06IHVuZGVmaW5lZCBhcyBzdHJpbmcgfCB1bmRlZmluZWQsXG4gICAgZ2V0TmV4dFBhZ2VQYXJhbTogKGxhc3RQYWdlKSA9PiBsYXN0UGFnZS5uZXh0Q3Vyc29yLFxuICAgIGVuYWJsZWQ6ICEhZXZlbnRJZCxcbiAgfSk7XG59XG4iXX0=
|
|
@@ -87,6 +87,10 @@ export declare function useEvent(id: string, options?: Omit<UseQueryOptions<Even
|
|
|
87
87
|
price?: Record<string, never>;
|
|
88
88
|
currency: string;
|
|
89
89
|
hubId?: Record<string, never>;
|
|
90
|
+
venueId?: Record<string, never>;
|
|
91
|
+
creatorId?: Record<string, never>;
|
|
92
|
+
sponsorBrandId?: Record<string, never>;
|
|
93
|
+
gatheringType?: "FACILITATOR_LED" | "COMMUNITY" | "SOCIAL" | "ONLINE";
|
|
90
94
|
visibility: "PUBLIC" | "MEMBERS_ONLY" | "INVITE_ONLY";
|
|
91
95
|
requiresApproval: boolean;
|
|
92
96
|
allowWaitlist: boolean;
|
|
@@ -97,6 +101,11 @@ export declare function useEvent(id: string, options?: Omit<UseQueryOptions<Even
|
|
|
97
101
|
isCancelled: boolean;
|
|
98
102
|
isAmbient: boolean;
|
|
99
103
|
ambientCategory?: Record<string, never>;
|
|
104
|
+
vibe?: "CHILL" | "ACTIVE" | "SOCIAL" | "CREATIVE" | "DEEP_TALK" | "ADVENTURE";
|
|
105
|
+
city?: import("@growsober/types/dist/generated").components["schemas"]["EventCityDto"];
|
|
106
|
+
venue?: import("@growsober/types/dist/generated").components["schemas"]["EventVenueDto"];
|
|
107
|
+
creator?: import("@growsober/types/dist/generated").components["schemas"]["EventCreatorDto"];
|
|
108
|
+
sponsorBrand?: import("@growsober/types/dist/generated").components["schemas"]["EventBrandDto"];
|
|
100
109
|
bookingCount: number;
|
|
101
110
|
checkinCount: number;
|
|
102
111
|
createdAt: string;
|
|
@@ -137,6 +146,10 @@ export declare function useEventBySlug(slug: string, options?: Omit<UseQueryOpti
|
|
|
137
146
|
price?: Record<string, never>;
|
|
138
147
|
currency: string;
|
|
139
148
|
hubId?: Record<string, never>;
|
|
149
|
+
venueId?: Record<string, never>;
|
|
150
|
+
creatorId?: Record<string, never>;
|
|
151
|
+
sponsorBrandId?: Record<string, never>;
|
|
152
|
+
gatheringType?: "FACILITATOR_LED" | "COMMUNITY" | "SOCIAL" | "ONLINE";
|
|
140
153
|
visibility: "PUBLIC" | "MEMBERS_ONLY" | "INVITE_ONLY";
|
|
141
154
|
requiresApproval: boolean;
|
|
142
155
|
allowWaitlist: boolean;
|
|
@@ -147,6 +160,11 @@ export declare function useEventBySlug(slug: string, options?: Omit<UseQueryOpti
|
|
|
147
160
|
isCancelled: boolean;
|
|
148
161
|
isAmbient: boolean;
|
|
149
162
|
ambientCategory?: Record<string, never>;
|
|
163
|
+
vibe?: "CHILL" | "ACTIVE" | "SOCIAL" | "CREATIVE" | "DEEP_TALK" | "ADVENTURE";
|
|
164
|
+
city?: import("@growsober/types/dist/generated").components["schemas"]["EventCityDto"];
|
|
165
|
+
venue?: import("@growsober/types/dist/generated").components["schemas"]["EventVenueDto"];
|
|
166
|
+
creator?: import("@growsober/types/dist/generated").components["schemas"]["EventCreatorDto"];
|
|
167
|
+
sponsorBrand?: import("@growsober/types/dist/generated").components["schemas"]["EventBrandDto"];
|
|
150
168
|
bookingCount: number;
|
|
151
169
|
checkinCount: number;
|
|
152
170
|
createdAt: string;
|
|
@@ -187,6 +205,10 @@ export declare function useUpcomingEvents(limit?: number, options?: Omit<UseQuer
|
|
|
187
205
|
price?: Record<string, never>;
|
|
188
206
|
currency: string;
|
|
189
207
|
hubId?: Record<string, never>;
|
|
208
|
+
venueId?: Record<string, never>;
|
|
209
|
+
creatorId?: Record<string, never>;
|
|
210
|
+
sponsorBrandId?: Record<string, never>;
|
|
211
|
+
gatheringType?: "FACILITATOR_LED" | "COMMUNITY" | "SOCIAL" | "ONLINE";
|
|
190
212
|
visibility: "PUBLIC" | "MEMBERS_ONLY" | "INVITE_ONLY";
|
|
191
213
|
requiresApproval: boolean;
|
|
192
214
|
allowWaitlist: boolean;
|
|
@@ -197,6 +219,11 @@ export declare function useUpcomingEvents(limit?: number, options?: Omit<UseQuer
|
|
|
197
219
|
isCancelled: boolean;
|
|
198
220
|
isAmbient: boolean;
|
|
199
221
|
ambientCategory?: Record<string, never>;
|
|
222
|
+
vibe?: "CHILL" | "ACTIVE" | "SOCIAL" | "CREATIVE" | "DEEP_TALK" | "ADVENTURE";
|
|
223
|
+
city?: import("@growsober/types/dist/generated").components["schemas"]["EventCityDto"];
|
|
224
|
+
venue?: import("@growsober/types/dist/generated").components["schemas"]["EventVenueDto"];
|
|
225
|
+
creator?: import("@growsober/types/dist/generated").components["schemas"]["EventCreatorDto"];
|
|
226
|
+
sponsorBrand?: import("@growsober/types/dist/generated").components["schemas"]["EventBrandDto"];
|
|
200
227
|
bookingCount: number;
|
|
201
228
|
checkinCount: number;
|
|
202
229
|
createdAt: string;
|
|
@@ -239,6 +266,10 @@ export declare function useFeaturedEvents(limit?: number, options?: Omit<UseQuer
|
|
|
239
266
|
price?: Record<string, never>;
|
|
240
267
|
currency: string;
|
|
241
268
|
hubId?: Record<string, never>;
|
|
269
|
+
venueId?: Record<string, never>;
|
|
270
|
+
creatorId?: Record<string, never>;
|
|
271
|
+
sponsorBrandId?: Record<string, never>;
|
|
272
|
+
gatheringType?: "FACILITATOR_LED" | "COMMUNITY" | "SOCIAL" | "ONLINE";
|
|
242
273
|
visibility: "PUBLIC" | "MEMBERS_ONLY" | "INVITE_ONLY";
|
|
243
274
|
requiresApproval: boolean;
|
|
244
275
|
allowWaitlist: boolean;
|
|
@@ -249,6 +280,11 @@ export declare function useFeaturedEvents(limit?: number, options?: Omit<UseQuer
|
|
|
249
280
|
isCancelled: boolean;
|
|
250
281
|
isAmbient: boolean;
|
|
251
282
|
ambientCategory?: Record<string, never>;
|
|
283
|
+
vibe?: "CHILL" | "ACTIVE" | "SOCIAL" | "CREATIVE" | "DEEP_TALK" | "ADVENTURE";
|
|
284
|
+
city?: import("@growsober/types/dist/generated").components["schemas"]["EventCityDto"];
|
|
285
|
+
venue?: import("@growsober/types/dist/generated").components["schemas"]["EventVenueDto"];
|
|
286
|
+
creator?: import("@growsober/types/dist/generated").components["schemas"]["EventCreatorDto"];
|
|
287
|
+
sponsorBrand?: import("@growsober/types/dist/generated").components["schemas"]["EventBrandDto"];
|
|
252
288
|
bookingCount: number;
|
|
253
289
|
checkinCount: number;
|
|
254
290
|
createdAt: string;
|
|
@@ -289,6 +325,10 @@ export declare function useAmbientEvents(filters?: AmbientEventFilters, options?
|
|
|
289
325
|
price?: Record<string, never>;
|
|
290
326
|
currency: string;
|
|
291
327
|
hubId?: Record<string, never>;
|
|
328
|
+
venueId?: Record<string, never>;
|
|
329
|
+
creatorId?: Record<string, never>;
|
|
330
|
+
sponsorBrandId?: Record<string, never>;
|
|
331
|
+
gatheringType?: "FACILITATOR_LED" | "COMMUNITY" | "SOCIAL" | "ONLINE";
|
|
292
332
|
visibility: "PUBLIC" | "MEMBERS_ONLY" | "INVITE_ONLY";
|
|
293
333
|
requiresApproval: boolean;
|
|
294
334
|
allowWaitlist: boolean;
|
|
@@ -299,6 +339,11 @@ export declare function useAmbientEvents(filters?: AmbientEventFilters, options?
|
|
|
299
339
|
isCancelled: boolean;
|
|
300
340
|
isAmbient: boolean;
|
|
301
341
|
ambientCategory?: Record<string, never>;
|
|
342
|
+
vibe?: "CHILL" | "ACTIVE" | "SOCIAL" | "CREATIVE" | "DEEP_TALK" | "ADVENTURE";
|
|
343
|
+
city?: import("@growsober/types/dist/generated").components["schemas"]["EventCityDto"];
|
|
344
|
+
venue?: import("@growsober/types/dist/generated").components["schemas"]["EventVenueDto"];
|
|
345
|
+
creator?: import("@growsober/types/dist/generated").components["schemas"]["EventCreatorDto"];
|
|
346
|
+
sponsorBrand?: import("@growsober/types/dist/generated").components["schemas"]["EventBrandDto"];
|
|
302
347
|
bookingCount: number;
|
|
303
348
|
checkinCount: number;
|
|
304
349
|
createdAt: string;
|
|
@@ -23,3 +23,8 @@ export * from './grow90';
|
|
|
23
23
|
export * from './matching';
|
|
24
24
|
export * from './event-chat';
|
|
25
25
|
export * from './user-pins';
|
|
26
|
+
export * from './badges';
|
|
27
|
+
export * from './venues';
|
|
28
|
+
export * from './creators';
|
|
29
|
+
export * from './brands';
|
|
30
|
+
export * from './products';
|
|
@@ -39,4 +39,9 @@ __exportStar(require("./grow90"), exports);
|
|
|
39
39
|
__exportStar(require("./matching"), exports);
|
|
40
40
|
__exportStar(require("./event-chat"), exports);
|
|
41
41
|
__exportStar(require("./user-pins"), exports);
|
|
42
|
-
|
|
42
|
+
__exportStar(require("./badges"), exports);
|
|
43
|
+
__exportStar(require("./venues"), exports);
|
|
44
|
+
__exportStar(require("./creators"), exports);
|
|
45
|
+
__exportStar(require("./brands"), exports);
|
|
46
|
+
__exportStar(require("./products"), exports);
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3F1ZXJpZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7O0dBSUc7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFSCwwQ0FBd0I7QUFDeEIseUNBQXVCO0FBQ3ZCLDZDQUEyQjtBQUMzQiwrQ0FBNkI7QUFDN0IsMkNBQXlCO0FBQ3pCLDJDQUF5QjtBQUN6Qix5Q0FBdUI7QUFDdkIsNENBQTBCO0FBQzFCLHdDQUFzQjtBQUN0QixrREFBZ0M7QUFDaEMsMkNBQXlCO0FBQ3pCLGtEQUFnQztBQUNoQyw0Q0FBMEI7QUFDMUIsMENBQXdCO0FBQ3hCLHlDQUF1QjtBQUN2QixnREFBOEI7QUFDOUIsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQiwrQ0FBNkI7QUFDN0IsOENBQTRCO0FBQzVCLDJDQUF5QjtBQUN6QiwyQ0FBeUI7QUFDekIsNkNBQTJCO0FBQzNCLDJDQUF5QjtBQUN6Qiw2Q0FBMkIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFF1ZXJ5IEhvb2tzXG4gKlxuICogUmUtZXhwb3J0cyBhbGwgcXVlcnkgaG9va3MgZm9yIEFQSSBlbmRwb2ludHMuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9hZG1pbic7XG5leHBvcnQgKiBmcm9tICcuL2F1dGgnO1xuZXhwb3J0ICogZnJvbSAnLi9ib29raW5ncyc7XG5leHBvcnQgKiBmcm9tICcuL2J1c2luZXNzZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9jaXRpZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9ldmVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9odWJzJztcbmV4cG9ydCAqIGZyb20gJy4vbGlicmFyeSc7XG5leHBvcnQgKiBmcm9tICcuL21hcCc7XG5leHBvcnQgKiBmcm9tICcuL25vdGlmaWNhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9vZmZlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdWJzY3JpcHRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vc3VwcG9ydCc7XG5leHBvcnQgKiBmcm9tICcuL3VzZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vamFjayc7XG5leHBvcnQgKiBmcm9tICcuL2FtYmFzc2Fkb3JzJztcbmV4cG9ydCAqIGZyb20gJy4vZ3JvdzkwJztcbmV4cG9ydCAqIGZyb20gJy4vbWF0Y2hpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi9ldmVudC1jaGF0JztcbmV4cG9ydCAqIGZyb20gJy4vdXNlci1waW5zJztcbmV4cG9ydCAqIGZyb20gJy4vYmFkZ2VzJztcbmV4cG9ydCAqIGZyb20gJy4vdmVudWVzJztcbmV4cG9ydCAqIGZyb20gJy4vY3JlYXRvcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9icmFuZHMnO1xuZXhwb3J0ICogZnJvbSAnLi9wcm9kdWN0cyc7XG4iXX0=
|
|
@@ -4,6 +4,8 @@ export declare const jackKeys: {
|
|
|
4
4
|
conversations: () => readonly ["jack", "conversations"];
|
|
5
5
|
conversation: (id: string) => readonly ["jack", "conversation", string];
|
|
6
6
|
history: () => readonly ["jack", "history"];
|
|
7
|
+
timeline: (cursor?: string) => readonly ["jack", "timeline", string | undefined];
|
|
8
|
+
stats: (days?: number) => readonly ["jack", "stats", number | undefined];
|
|
7
9
|
};
|
|
8
10
|
export interface JackConversation {
|
|
9
11
|
id: string;
|
|
@@ -23,6 +25,31 @@ export interface JackMessage {
|
|
|
23
25
|
completionTokens?: number;
|
|
24
26
|
createdAt: string;
|
|
25
27
|
}
|
|
28
|
+
export type JackEntryType = 'MESSAGE' | 'CHECK_IN' | 'REFLECTION' | 'MOOD_LOG' | 'WIN' | 'JOURNAL' | 'HABIT';
|
|
29
|
+
export interface JackTimelineEntry {
|
|
30
|
+
id: string;
|
|
31
|
+
role: string;
|
|
32
|
+
content: string;
|
|
33
|
+
entryType: JackEntryType;
|
|
34
|
+
metadata: Record<string, any> | null;
|
|
35
|
+
createdAt: string;
|
|
36
|
+
}
|
|
37
|
+
export interface JackTimelineResponse {
|
|
38
|
+
entries: JackTimelineEntry[];
|
|
39
|
+
hasMore: boolean;
|
|
40
|
+
nextCursor?: string;
|
|
41
|
+
}
|
|
42
|
+
export interface JackStats {
|
|
43
|
+
totalMessages: number;
|
|
44
|
+
checkInsCount: number;
|
|
45
|
+
reflectionsCount: number;
|
|
46
|
+
moodLogsCount: number;
|
|
47
|
+
winsCount: number;
|
|
48
|
+
journalsCount: number;
|
|
49
|
+
habitsCount: number;
|
|
50
|
+
checkInStreak: number;
|
|
51
|
+
lastCheckInDate: string | null;
|
|
52
|
+
}
|
|
26
53
|
export interface JackConversationWithMessages extends JackConversation {
|
|
27
54
|
messages: JackMessage[];
|
|
28
55
|
}
|
|
@@ -61,3 +88,56 @@ export declare function useJackConversation(conversationId: string, options?: Om
|
|
|
61
88
|
* ```
|
|
62
89
|
*/
|
|
63
90
|
export declare function useJackHistory(options?: Omit<UseQueryOptions<JackConversationWithMessages | null>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<JackConversationWithMessages | null, Error>;
|
|
91
|
+
/**
|
|
92
|
+
* Get paginated timeline entries (messages, check-ins, reflections, etc.)
|
|
93
|
+
*
|
|
94
|
+
* @param limit - Number of entries to return (default: 20)
|
|
95
|
+
* @param before - Cursor for pagination (entry ID to fetch before)
|
|
96
|
+
* @param options - TanStack Query options
|
|
97
|
+
*
|
|
98
|
+
* @example
|
|
99
|
+
* ```tsx
|
|
100
|
+
* const { data: timeline, fetchNextPage } = useJackTimeline();
|
|
101
|
+
* ```
|
|
102
|
+
*/
|
|
103
|
+
export declare function useJackTimeline(limit?: number, before?: string, options?: Omit<UseQueryOptions<JackTimelineResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<JackTimelineResponse, Error>;
|
|
104
|
+
/**
|
|
105
|
+
* Get paginated timeline entries with infinite scroll support
|
|
106
|
+
*
|
|
107
|
+
* @param limit - Number of entries per page (default: 20)
|
|
108
|
+
* @param options - TanStack Query infinite query options
|
|
109
|
+
*
|
|
110
|
+
* @example
|
|
111
|
+
* ```tsx
|
|
112
|
+
* const {
|
|
113
|
+
* data,
|
|
114
|
+
* fetchNextPage,
|
|
115
|
+
* hasNextPage,
|
|
116
|
+
* isFetchingNextPage,
|
|
117
|
+
* } = useInfiniteJackTimeline(20);
|
|
118
|
+
*
|
|
119
|
+
* // Flatten all pages into single array
|
|
120
|
+
* const entries = data?.pages.flatMap(page => page.entries) ?? [];
|
|
121
|
+
*
|
|
122
|
+
* // Load more when user scrolls to top
|
|
123
|
+
* const onEndReached = () => {
|
|
124
|
+
* if (hasNextPage && !isFetchingNextPage) {
|
|
125
|
+
* fetchNextPage();
|
|
126
|
+
* }
|
|
127
|
+
* };
|
|
128
|
+
* ```
|
|
129
|
+
*/
|
|
130
|
+
export declare function useInfiniteJackTimeline(limit?: number): import("@tanstack/react-query").UseInfiniteQueryResult<import("@tanstack/react-query").InfiniteData<JackTimelineResponse, unknown>, Error>;
|
|
131
|
+
/**
|
|
132
|
+
* Get stats for rewards tracking
|
|
133
|
+
*
|
|
134
|
+
* @param days - Number of days to include in stats (default: 30)
|
|
135
|
+
* @param options - TanStack Query options
|
|
136
|
+
*
|
|
137
|
+
* @example
|
|
138
|
+
* ```tsx
|
|
139
|
+
* const { data: stats } = useJackStats();
|
|
140
|
+
* console.log('Check-in streak:', stats?.checkInStreak);
|
|
141
|
+
* ```
|
|
142
|
+
*/
|
|
143
|
+
export declare function useJackStats(days?: number, options?: Omit<UseQueryOptions<JackStats>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<JackStats, Error>;
|
package/dist/api/queries/jack.js
CHANGED
|
@@ -4,6 +4,9 @@ exports.jackKeys = void 0;
|
|
|
4
4
|
exports.useJackConversations = useJackConversations;
|
|
5
5
|
exports.useJackConversation = useJackConversation;
|
|
6
6
|
exports.useJackHistory = useJackHistory;
|
|
7
|
+
exports.useJackTimeline = useJackTimeline;
|
|
8
|
+
exports.useInfiniteJackTimeline = useInfiniteJackTimeline;
|
|
9
|
+
exports.useJackStats = useJackStats;
|
|
7
10
|
const react_query_1 = require("@tanstack/react-query");
|
|
8
11
|
const client_1 = require("../client");
|
|
9
12
|
// ============================================================================
|
|
@@ -14,6 +17,8 @@ exports.jackKeys = {
|
|
|
14
17
|
conversations: () => [...exports.jackKeys.all, 'conversations'],
|
|
15
18
|
conversation: (id) => [...exports.jackKeys.all, 'conversation', id],
|
|
16
19
|
history: () => [...exports.jackKeys.all, 'history'],
|
|
20
|
+
timeline: (cursor) => [...exports.jackKeys.all, 'timeline', cursor],
|
|
21
|
+
stats: (days) => [...exports.jackKeys.all, 'stats', days],
|
|
17
22
|
};
|
|
18
23
|
// ============================================================================
|
|
19
24
|
// QUERY HOOKS
|
|
@@ -89,4 +94,96 @@ function useJackHistory(options) {
|
|
|
89
94
|
...options,
|
|
90
95
|
});
|
|
91
96
|
}
|
|
92
|
-
|
|
97
|
+
/**
|
|
98
|
+
* Get paginated timeline entries (messages, check-ins, reflections, etc.)
|
|
99
|
+
*
|
|
100
|
+
* @param limit - Number of entries to return (default: 20)
|
|
101
|
+
* @param before - Cursor for pagination (entry ID to fetch before)
|
|
102
|
+
* @param options - TanStack Query options
|
|
103
|
+
*
|
|
104
|
+
* @example
|
|
105
|
+
* ```tsx
|
|
106
|
+
* const { data: timeline, fetchNextPage } = useJackTimeline();
|
|
107
|
+
* ```
|
|
108
|
+
*/
|
|
109
|
+
function useJackTimeline(limit = 20, before, options) {
|
|
110
|
+
return (0, react_query_1.useQuery)({
|
|
111
|
+
queryKey: exports.jackKeys.timeline(before),
|
|
112
|
+
queryFn: async () => {
|
|
113
|
+
const client = (0, client_1.getApiClient)();
|
|
114
|
+
const params = { limit };
|
|
115
|
+
if (before)
|
|
116
|
+
params.before = before;
|
|
117
|
+
const response = await client.get('/api/v1/support/jack/timeline', { params });
|
|
118
|
+
return response.data?.data || response.data;
|
|
119
|
+
},
|
|
120
|
+
...options,
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Get paginated timeline entries with infinite scroll support
|
|
125
|
+
*
|
|
126
|
+
* @param limit - Number of entries per page (default: 20)
|
|
127
|
+
* @param options - TanStack Query infinite query options
|
|
128
|
+
*
|
|
129
|
+
* @example
|
|
130
|
+
* ```tsx
|
|
131
|
+
* const {
|
|
132
|
+
* data,
|
|
133
|
+
* fetchNextPage,
|
|
134
|
+
* hasNextPage,
|
|
135
|
+
* isFetchingNextPage,
|
|
136
|
+
* } = useInfiniteJackTimeline(20);
|
|
137
|
+
*
|
|
138
|
+
* // Flatten all pages into single array
|
|
139
|
+
* const entries = data?.pages.flatMap(page => page.entries) ?? [];
|
|
140
|
+
*
|
|
141
|
+
* // Load more when user scrolls to top
|
|
142
|
+
* const onEndReached = () => {
|
|
143
|
+
* if (hasNextPage && !isFetchingNextPage) {
|
|
144
|
+
* fetchNextPage();
|
|
145
|
+
* }
|
|
146
|
+
* };
|
|
147
|
+
* ```
|
|
148
|
+
*/
|
|
149
|
+
function useInfiniteJackTimeline(limit = 20) {
|
|
150
|
+
return (0, react_query_1.useInfiniteQuery)({
|
|
151
|
+
queryKey: [...exports.jackKeys.all, 'timeline-infinite', limit],
|
|
152
|
+
queryFn: async ({ pageParam }) => {
|
|
153
|
+
const client = (0, client_1.getApiClient)();
|
|
154
|
+
const params = { limit };
|
|
155
|
+
if (pageParam)
|
|
156
|
+
params.before = pageParam;
|
|
157
|
+
const response = await client.get('/api/v1/support/jack/timeline', { params });
|
|
158
|
+
return response.data?.data || response.data;
|
|
159
|
+
},
|
|
160
|
+
initialPageParam: undefined,
|
|
161
|
+
getNextPageParam: (lastPage) => lastPage.hasMore ? lastPage.nextCursor : undefined,
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* Get stats for rewards tracking
|
|
166
|
+
*
|
|
167
|
+
* @param days - Number of days to include in stats (default: 30)
|
|
168
|
+
* @param options - TanStack Query options
|
|
169
|
+
*
|
|
170
|
+
* @example
|
|
171
|
+
* ```tsx
|
|
172
|
+
* const { data: stats } = useJackStats();
|
|
173
|
+
* console.log('Check-in streak:', stats?.checkInStreak);
|
|
174
|
+
* ```
|
|
175
|
+
*/
|
|
176
|
+
function useJackStats(days = 30, options) {
|
|
177
|
+
return (0, react_query_1.useQuery)({
|
|
178
|
+
queryKey: exports.jackKeys.stats(days),
|
|
179
|
+
queryFn: async () => {
|
|
180
|
+
const client = (0, client_1.getApiClient)();
|
|
181
|
+
const response = await client.get('/api/v1/support/jack/stats', {
|
|
182
|
+
params: { days },
|
|
183
|
+
});
|
|
184
|
+
return response.data?.data || response.data;
|
|
185
|
+
},
|
|
186
|
+
...options,
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jack.js","sourceRoot":"","sources":["../../../src/api/queries/jack.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, useInfiniteQuery, UseQueryOptions, UseInfiniteQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const jackKeys = {\n  all: ['jack'] as const,\n  conversations: () => [...jackKeys.all, 'conversations'] as const,\n  conversation: (id: string) => [...jackKeys.all, 'conversation', id] as const,\n  history: () => [...jackKeys.all, 'history'] as const,\n  timeline: (cursor?: string) => [...jackKeys.all, 'timeline', cursor] as const,\n  stats: (days?: number) => [...jackKeys.all, 'stats', days] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface JackConversation {\n  id: string;\n  title: string;\n  messageCount: number;\n  lastMessageAt: string | null;\n  createdAt: string;\n  isArchived: boolean;\n}\n\nexport interface JackMessage {\n  id: string;\n  conversationId: string;\n  role: 'USER' | 'ASSISTANT' | 'SYSTEM';\n  content: string;\n  model?: string;\n  promptTokens?: number;\n  completionTokens?: number;\n  createdAt: string;\n}\n\nexport type JackEntryType =\n  | 'MESSAGE'\n  | 'CHECK_IN'\n  | 'REFLECTION'\n  | 'MOOD_LOG'\n  | 'WIN'\n  | 'JOURNAL'\n  | 'HABIT';\n\nexport interface JackTimelineEntry {\n  id: string;\n  role: string;\n  content: string;\n  entryType: JackEntryType;\n  metadata: Record<string, any> | null;\n  createdAt: string;\n}\n\nexport interface JackTimelineResponse {\n  entries: JackTimelineEntry[];\n  hasMore: boolean;\n  nextCursor?: string;\n}\n\nexport interface JackStats {\n  totalMessages: number;\n  checkInsCount: number;\n  reflectionsCount: number;\n  moodLogsCount: number;\n  winsCount: number;\n  journalsCount: number;\n  habitsCount: number;\n  checkInStreak: number;\n  lastCheckInDate: string | null;\n}\n\nexport interface JackConversationWithMessages extends JackConversation {\n  messages: JackMessage[];\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get all conversations with Jack\n *\n * @param limit - Maximum conversations to return (default: 20)\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data: conversations } = useJackConversations();\n * ```\n */\nexport function useJackConversations(\n  limit = 20,\n  options?: Omit<UseQueryOptions<JackConversation[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: jackKeys.conversations(),\n    queryFn: async (): Promise<JackConversation[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/jack/conversations', {\n        params: { limit },\n      });\n      // API wraps response in { data: {...}, meta: {...} }\n      return response.data?.data || response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get a specific conversation with messages\n *\n * @param conversationId - The conversation ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data: conversation } = useJackConversation('conv-123');\n * ```\n */\nexport function useJackConversation(\n  conversationId: string,\n  options?: Omit<UseQueryOptions<JackConversationWithMessages | null>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: jackKeys.conversation(conversationId),\n    queryFn: async (): Promise<JackConversationWithMessages | null> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/support/jack/conversations/${conversationId}`);\n      // API wraps response in { data: {...}, meta: {...} }\n      return response.data?.data || response.data;\n    },\n    enabled: !!conversationId,\n    ...options,\n  });\n}\n\n/**\n * Get the most recent active conversation with Jack\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data: history } = useJackHistory();\n * ```\n */\nexport function useJackHistory(\n  options?: Omit<UseQueryOptions<JackConversationWithMessages | null>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: jackKeys.history(),\n    queryFn: async (): Promise<JackConversationWithMessages | null> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/jack/history');\n      // API wraps response in { data: {...}, meta: {...} }\n      return response.data?.data || response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get paginated timeline entries (messages, check-ins, reflections, etc.)\n *\n * @param limit - Number of entries to return (default: 20)\n * @param before - Cursor for pagination (entry ID to fetch before)\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data: timeline, fetchNextPage } = useJackTimeline();\n * ```\n */\nexport function useJackTimeline(\n  limit = 20,\n  before?: string,\n  options?: Omit<UseQueryOptions<JackTimelineResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: jackKeys.timeline(before),\n    queryFn: async (): Promise<JackTimelineResponse> => {\n      const client = getApiClient();\n      const params: Record<string, any> = { limit };\n      if (before) params.before = before;\n      const response = await client.get('/api/v1/support/jack/timeline', { params });\n      return response.data?.data || response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get paginated timeline entries with infinite scroll support\n *\n * @param limit - Number of entries per page (default: 20)\n * @param options - TanStack Query infinite query options\n *\n * @example\n * ```tsx\n * const {\n *   data,\n *   fetchNextPage,\n *   hasNextPage,\n *   isFetchingNextPage,\n * } = useInfiniteJackTimeline(20);\n *\n * // Flatten all pages into single array\n * const entries = data?.pages.flatMap(page => page.entries) ?? [];\n *\n * // Load more when user scrolls to top\n * const onEndReached = () => {\n *   if (hasNextPage && !isFetchingNextPage) {\n *     fetchNextPage();\n *   }\n * };\n * ```\n */\nexport function useInfiniteJackTimeline(limit = 20) {\n  return useInfiniteQuery({\n    queryKey: [...jackKeys.all, 'timeline-infinite', limit] as const,\n    queryFn: async ({ pageParam }: { pageParam: string | undefined }): Promise<JackTimelineResponse> => {\n      const client = getApiClient();\n      const params: Record<string, any> = { limit };\n      if (pageParam) params.before = pageParam;\n      const response = await client.get('/api/v1/support/jack/timeline', { params });\n      return response.data?.data || response.data;\n    },\n    initialPageParam: undefined as string | undefined,\n    getNextPageParam: (lastPage: JackTimelineResponse) => lastPage.hasMore ? lastPage.nextCursor : undefined,\n  });\n}\n\n/**\n * Get stats for rewards tracking\n *\n * @param days - Number of days to include in stats (default: 30)\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data: stats } = useJackStats();\n * console.log('Check-in streak:', stats?.checkInStreak);\n * ```\n */\nexport function useJackStats(\n  days = 30,\n  options?: Omit<UseQueryOptions<JackStats>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: jackKeys.stats(days),\n    queryFn: async (): Promise<JackStats> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/jack/stats', {\n        params: { days },\n      });\n      return response.data?.data || response.data;\n    },\n    ...options,\n  });\n}\n"]}
|
|
@@ -81,6 +81,10 @@ export declare function useFeaturedContent(options?: Omit<UseQueryOptions<Librar
|
|
|
81
81
|
likeCount: number;
|
|
82
82
|
authorName?: Record<string, never>;
|
|
83
83
|
authorImage?: Record<string, never>;
|
|
84
|
+
creatorId?: Record<string, never>;
|
|
85
|
+
creator?: import("@growsober/types/dist/generated").components["schemas"]["ContentCreatorDto"];
|
|
86
|
+
contentStatus: "DRAFT" | "PENDING_REVIEW" | "APPROVED" | "PUBLISHED" | "REJECTED";
|
|
87
|
+
rejectionReason?: Record<string, never>;
|
|
84
88
|
createdAt: string;
|
|
85
89
|
updatedAt: string;
|
|
86
90
|
publishedAt?: Record<string, never>;
|
|
@@ -125,6 +129,10 @@ export declare function useLibraryItem(id: string, options?: Omit<UseQueryOption
|
|
|
125
129
|
likeCount: number;
|
|
126
130
|
authorName?: Record<string, never>;
|
|
127
131
|
authorImage?: Record<string, never>;
|
|
132
|
+
creatorId?: Record<string, never>;
|
|
133
|
+
creator?: import("@growsober/types/dist/generated").components["schemas"]["ContentCreatorDto"];
|
|
134
|
+
contentStatus: "DRAFT" | "PENDING_REVIEW" | "APPROVED" | "PUBLISHED" | "REJECTED";
|
|
135
|
+
rejectionReason?: Record<string, never>;
|
|
128
136
|
createdAt: string;
|
|
129
137
|
updatedAt: string;
|
|
130
138
|
publishedAt?: Record<string, never>;
|