@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.
Files changed (70) hide show
  1. package/dist/__tests__/e2e.test.d.ts +30 -0
  2. package/dist/__tests__/e2e.test.js +959 -63
  3. package/dist/api/mutations/badges.d.ts +116 -0
  4. package/dist/api/mutations/badges.js +177 -0
  5. package/dist/api/mutations/brands.d.ts +251 -0
  6. package/dist/api/mutations/brands.js +242 -0
  7. package/dist/api/mutations/creators.d.ts +131 -0
  8. package/dist/api/mutations/creators.js +129 -0
  9. package/dist/api/mutations/event-chat.d.ts +2 -2
  10. package/dist/api/mutations/event-chat.js +9 -9
  11. package/dist/api/mutations/index.d.ts +4 -0
  12. package/dist/api/mutations/index.js +5 -1
  13. package/dist/api/mutations/jack.d.ts +29 -0
  14. package/dist/api/mutations/jack.js +41 -1
  15. package/dist/api/mutations/products.d.ts +175 -0
  16. package/dist/api/mutations/products.js +226 -0
  17. package/dist/api/mutations/support.d.ts +20 -1
  18. package/dist/api/mutations/support.js +36 -1
  19. package/dist/api/queries/badges.d.ts +221 -0
  20. package/dist/api/queries/badges.js +290 -0
  21. package/dist/api/queries/bookings.d.ts +1 -1
  22. package/dist/api/queries/brands.d.ts +248 -0
  23. package/dist/api/queries/brands.js +226 -0
  24. package/dist/api/queries/businesses.d.ts +61 -1
  25. package/dist/api/queries/businesses.js +27 -1
  26. package/dist/api/queries/creators.d.ts +332 -0
  27. package/dist/api/queries/creators.js +249 -0
  28. package/dist/api/queries/event-chat.d.ts +1 -1
  29. package/dist/api/queries/event-chat.js +4 -4
  30. package/dist/api/queries/events.d.ts +45 -0
  31. package/dist/api/queries/index.d.ts +5 -0
  32. package/dist/api/queries/index.js +6 -1
  33. package/dist/api/queries/jack.d.ts +80 -0
  34. package/dist/api/queries/jack.js +98 -1
  35. package/dist/api/queries/library.d.ts +8 -0
  36. package/dist/api/queries/products.d.ts +185 -0
  37. package/dist/api/queries/products.js +203 -0
  38. package/dist/api/queries/support.d.ts +46 -1
  39. package/dist/api/queries/support.js +48 -1
  40. package/dist/api/queries/venues.d.ts +304 -0
  41. package/dist/api/queries/venues.js +211 -0
  42. package/dist/api/types.d.ts +245 -0
  43. package/dist/api/types.js +6 -1
  44. package/dist/api/utils/eventGrouping.d.ts +104 -0
  45. package/dist/api/utils/eventGrouping.js +155 -0
  46. package/dist/index.d.ts +1 -0
  47. package/dist/index.js +5 -1
  48. package/package.json +5 -2
  49. package/src/__tests__/e2e.test.ts +996 -64
  50. package/src/api/mutations/badges.ts +228 -0
  51. package/src/api/mutations/brands.ts +376 -0
  52. package/src/api/mutations/creators.ts +171 -0
  53. package/src/api/mutations/event-chat.ts +8 -8
  54. package/src/api/mutations/index.ts +4 -0
  55. package/src/api/mutations/jack.ts +50 -1
  56. package/src/api/mutations/products.ts +336 -0
  57. package/src/api/mutations/support.ts +44 -0
  58. package/src/api/queries/badges.ts +385 -0
  59. package/src/api/queries/brands.ts +281 -0
  60. package/src/api/queries/businesses.ts +30 -1
  61. package/src/api/queries/creators.ts +308 -0
  62. package/src/api/queries/event-chat.ts +3 -3
  63. package/src/api/queries/index.ts +5 -0
  64. package/src/api/queries/jack.ts +139 -1
  65. package/src/api/queries/products.ts +312 -0
  66. package/src/api/queries/support.ts +54 -0
  67. package/src/api/queries/venues.ts +271 -0
  68. package/src/api/types.ts +317 -1
  69. package/src/api/utils/eventGrouping.ts +181 -0
  70. package/src/index.ts +6 -0
@@ -0,0 +1,332 @@
1
+ import { UseQueryOptions } from '@tanstack/react-query';
2
+ import type { CreatorResponse, CreatorAvailabilityResponse, EventResponse, LibraryContentResponse } from '../types';
3
+ export declare const creatorKeys: {
4
+ all: readonly ["creators"];
5
+ lists: () => readonly ["creators", "list"];
6
+ list: (filters?: CreatorFilters) => readonly ["creators", "list", CreatorFilters | undefined];
7
+ details: () => readonly ["creators", "detail"];
8
+ detail: (id: string) => readonly ["creators", "detail", string];
9
+ slug: (slug: string) => readonly ["creators", "slug", string];
10
+ byUser: (userId: string) => readonly ["creators", "user", string];
11
+ me: () => readonly ["creators", "me"];
12
+ availability: (creatorId: string) => readonly ["creators", "detail", string, "availability"];
13
+ content: (creatorId: string) => readonly ["creators", "detail", string, "content"];
14
+ allContent: (creatorId: string) => readonly ["creators", "detail", string, "content", "all"];
15
+ events: (creatorId: string) => readonly ["creators", "detail", string, "events"];
16
+ };
17
+ export interface CreatorFilters {
18
+ page?: number;
19
+ limit?: number;
20
+ search?: string;
21
+ cityId?: string;
22
+ canFacilitate?: boolean;
23
+ canCreateContent?: boolean;
24
+ isInfluencer?: boolean;
25
+ isVerified?: boolean;
26
+ sortBy?: string;
27
+ sortOrder?: 'asc' | 'desc';
28
+ }
29
+ export interface PaginatedCreatorsResponse {
30
+ creators: CreatorResponse[];
31
+ meta: {
32
+ total: number;
33
+ page: number;
34
+ limit: number;
35
+ totalPages: number;
36
+ };
37
+ }
38
+ /**
39
+ * Get paginated list of creators with optional filters
40
+ *
41
+ * @param filters - Query parameters for filtering and pagination
42
+ * @param options - TanStack Query options
43
+ *
44
+ * @example
45
+ * ```tsx
46
+ * const { data, isLoading } = useCreators({
47
+ * page: 1,
48
+ * limit: 20,
49
+ * canFacilitate: true,
50
+ * });
51
+ * ```
52
+ */
53
+ export declare function useCreators(filters?: CreatorFilters, options?: Omit<UseQueryOptions<PaginatedCreatorsResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PaginatedCreatorsResponse, Error>;
54
+ /**
55
+ * Get a single creator by ID
56
+ *
57
+ * @param id - Creator ID
58
+ * @param options - TanStack Query options
59
+ *
60
+ * @example
61
+ * ```tsx
62
+ * const { data, isLoading } = useCreator('creator-123');
63
+ * ```
64
+ */
65
+ export declare function useCreator(id: string, options?: Omit<UseQueryOptions<CreatorResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
66
+ id: string;
67
+ userId: string;
68
+ slug: string;
69
+ displayName: string;
70
+ bio?: Record<string, never>;
71
+ avatarUrl?: Record<string, never>;
72
+ cityIds: string[];
73
+ canFacilitate: boolean;
74
+ canCreateContent: boolean;
75
+ isInfluencer: boolean;
76
+ specialties: string[];
77
+ certifications: string[];
78
+ sessionRate?: number;
79
+ isVerified: boolean;
80
+ isActive: boolean;
81
+ createdAt: string;
82
+ updatedAt: string;
83
+ user?: import("@growsober/types/dist/generated").components["schemas"]["CreatorUserDto"];
84
+ }, Error>;
85
+ /**
86
+ * Get a creator by their slug
87
+ *
88
+ * @param slug - Creator slug
89
+ * @param options - TanStack Query options
90
+ *
91
+ * @example
92
+ * ```tsx
93
+ * const { data, isLoading } = useCreatorBySlug('john-doe');
94
+ * ```
95
+ */
96
+ export declare function useCreatorBySlug(slug: string, options?: Omit<UseQueryOptions<CreatorResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
97
+ id: string;
98
+ userId: string;
99
+ slug: string;
100
+ displayName: string;
101
+ bio?: Record<string, never>;
102
+ avatarUrl?: Record<string, never>;
103
+ cityIds: string[];
104
+ canFacilitate: boolean;
105
+ canCreateContent: boolean;
106
+ isInfluencer: boolean;
107
+ specialties: string[];
108
+ certifications: string[];
109
+ sessionRate?: number;
110
+ isVerified: boolean;
111
+ isActive: boolean;
112
+ createdAt: string;
113
+ updatedAt: string;
114
+ user?: import("@growsober/types/dist/generated").components["schemas"]["CreatorUserDto"];
115
+ }, Error>;
116
+ /**
117
+ * Get a creator profile by user ID
118
+ *
119
+ * @param userId - User ID
120
+ * @param options - TanStack Query options
121
+ *
122
+ * @example
123
+ * ```tsx
124
+ * const { data, isLoading } = useCreatorByUser('user-123');
125
+ * ```
126
+ */
127
+ export declare function useCreatorByUser(userId: string, options?: Omit<UseQueryOptions<CreatorResponse | null>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
128
+ id: string;
129
+ userId: string;
130
+ slug: string;
131
+ displayName: string;
132
+ bio?: Record<string, never>;
133
+ avatarUrl?: Record<string, never>;
134
+ cityIds: string[];
135
+ canFacilitate: boolean;
136
+ canCreateContent: boolean;
137
+ isInfluencer: boolean;
138
+ specialties: string[];
139
+ certifications: string[];
140
+ sessionRate?: number;
141
+ isVerified: boolean;
142
+ isActive: boolean;
143
+ createdAt: string;
144
+ updatedAt: string;
145
+ user?: import("@growsober/types/dist/generated").components["schemas"]["CreatorUserDto"];
146
+ } | null, Error>;
147
+ /**
148
+ * Get the current user's creator profile
149
+ *
150
+ * @param options - TanStack Query options
151
+ *
152
+ * @example
153
+ * ```tsx
154
+ * const { data, isLoading } = useMyCreatorProfile();
155
+ * ```
156
+ */
157
+ export declare function useMyCreatorProfile(options?: Omit<UseQueryOptions<CreatorResponse | null>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
158
+ id: string;
159
+ userId: string;
160
+ slug: string;
161
+ displayName: string;
162
+ bio?: Record<string, never>;
163
+ avatarUrl?: Record<string, never>;
164
+ cityIds: string[];
165
+ canFacilitate: boolean;
166
+ canCreateContent: boolean;
167
+ isInfluencer: boolean;
168
+ specialties: string[];
169
+ certifications: string[];
170
+ sessionRate?: number;
171
+ isVerified: boolean;
172
+ isActive: boolean;
173
+ createdAt: string;
174
+ updatedAt: string;
175
+ user?: import("@growsober/types/dist/generated").components["schemas"]["CreatorUserDto"];
176
+ } | null, Error>;
177
+ /**
178
+ * Get creator availability slots
179
+ *
180
+ * @param creatorId - Creator ID
181
+ * @param options - TanStack Query options
182
+ *
183
+ * @example
184
+ * ```tsx
185
+ * const { data, isLoading } = useCreatorAvailability('creator-123');
186
+ * ```
187
+ */
188
+ export declare function useCreatorAvailability(creatorId: string, options?: Omit<UseQueryOptions<CreatorAvailabilityResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
189
+ id: string;
190
+ creatorId: string;
191
+ dayOfWeek: Record<string, never>;
192
+ startTime: string;
193
+ endTime: string;
194
+ timezone: string;
195
+ isRecurring: boolean;
196
+ specificDate?: string;
197
+ }[], Error>;
198
+ /**
199
+ * Get a creator's published library content
200
+ *
201
+ * @param creatorId - Creator ID
202
+ * @param options - TanStack Query options
203
+ *
204
+ * @example
205
+ * ```tsx
206
+ * const { data, isLoading } = useCreatorContent('creator-123');
207
+ * ```
208
+ */
209
+ export declare function useCreatorContent(creatorId: string, options?: Omit<UseQueryOptions<LibraryContentResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
210
+ id: string;
211
+ title: string;
212
+ slug: string;
213
+ summary?: Record<string, never>;
214
+ coverImage?: Record<string, never>;
215
+ categoryId?: Record<string, never>;
216
+ type: "ARTICLE" | "GUIDE" | "VIDEO" | "PODCAST" | "TOOL" | "WORKSHEET";
217
+ tags: string[];
218
+ readTimeMinutes?: Record<string, never>;
219
+ drinkingIdentities: string[];
220
+ isPremium: boolean;
221
+ isPublished: boolean;
222
+ isFeatured: boolean;
223
+ viewCount: number;
224
+ likeCount: number;
225
+ authorName?: Record<string, never>;
226
+ authorImage?: Record<string, never>;
227
+ creatorId?: Record<string, never>;
228
+ creator?: import("@growsober/types/dist/generated").components["schemas"]["ContentCreatorDto"];
229
+ contentStatus: "DRAFT" | "PENDING_REVIEW" | "APPROVED" | "PUBLISHED" | "REJECTED";
230
+ rejectionReason?: Record<string, never>;
231
+ createdAt: string;
232
+ updatedAt: string;
233
+ publishedAt?: Record<string, never>;
234
+ }[], Error>;
235
+ /**
236
+ * Get all of a creator's content including unpublished (owner only)
237
+ *
238
+ * @param creatorId - Creator ID
239
+ * @param options - TanStack Query options
240
+ *
241
+ * @example
242
+ * ```tsx
243
+ * // For creator dashboard - shows all content statuses
244
+ * const { data, isLoading } = useCreatorAllContent('creator-123');
245
+ * ```
246
+ */
247
+ export declare function useCreatorAllContent(creatorId: string, options?: Omit<UseQueryOptions<LibraryContentResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
248
+ id: string;
249
+ title: string;
250
+ slug: string;
251
+ summary?: Record<string, never>;
252
+ coverImage?: Record<string, never>;
253
+ categoryId?: Record<string, never>;
254
+ type: "ARTICLE" | "GUIDE" | "VIDEO" | "PODCAST" | "TOOL" | "WORKSHEET";
255
+ tags: string[];
256
+ readTimeMinutes?: Record<string, never>;
257
+ drinkingIdentities: string[];
258
+ isPremium: boolean;
259
+ isPublished: boolean;
260
+ isFeatured: boolean;
261
+ viewCount: number;
262
+ likeCount: number;
263
+ authorName?: Record<string, never>;
264
+ authorImage?: Record<string, never>;
265
+ creatorId?: Record<string, never>;
266
+ creator?: import("@growsober/types/dist/generated").components["schemas"]["ContentCreatorDto"];
267
+ contentStatus: "DRAFT" | "PENDING_REVIEW" | "APPROVED" | "PUBLISHED" | "REJECTED";
268
+ rejectionReason?: Record<string, never>;
269
+ createdAt: string;
270
+ updatedAt: string;
271
+ publishedAt?: Record<string, never>;
272
+ }[], Error>;
273
+ /**
274
+ * Get a creator's upcoming events
275
+ *
276
+ * @param creatorId - Creator ID
277
+ * @param upcoming - Whether to filter to upcoming events only (default: true)
278
+ * @param options - TanStack Query options
279
+ *
280
+ * @example
281
+ * ```tsx
282
+ * const { data, isLoading } = useCreatorEvents('creator-123');
283
+ * ```
284
+ */
285
+ export declare function useCreatorEvents(creatorId: string, upcoming?: boolean, options?: Omit<UseQueryOptions<EventResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
286
+ id: string;
287
+ title: string;
288
+ slug?: Record<string, never>;
289
+ description?: Record<string, never>;
290
+ bannerImage?: Record<string, never>;
291
+ startDate: string;
292
+ endDate?: Record<string, never>;
293
+ timezone?: Record<string, never>;
294
+ isRecurring: boolean;
295
+ recurrenceRule?: Record<string, never>;
296
+ locationName?: Record<string, never>;
297
+ locationAddress?: Record<string, never>;
298
+ locationLat?: Record<string, never>;
299
+ locationLong?: Record<string, never>;
300
+ cityId?: Record<string, never>;
301
+ isOnline: boolean;
302
+ onlineUrl?: Record<string, never>;
303
+ totalSpots: number;
304
+ availableSpots: number;
305
+ isFree: boolean;
306
+ price?: Record<string, never>;
307
+ currency: string;
308
+ hubId?: Record<string, never>;
309
+ venueId?: Record<string, never>;
310
+ creatorId?: Record<string, never>;
311
+ sponsorBrandId?: Record<string, never>;
312
+ gatheringType?: "FACILITATOR_LED" | "COMMUNITY" | "SOCIAL" | "ONLINE";
313
+ visibility: "PUBLIC" | "MEMBERS_ONLY" | "INVITE_ONLY";
314
+ requiresApproval: boolean;
315
+ allowWaitlist: boolean;
316
+ whatsappGroup?: Record<string, never>;
317
+ externalUrl?: Record<string, never>;
318
+ status: "DRAFT" | "PUBLISHED" | "CANCELLED" | "COMPLETED";
319
+ isFeatured: boolean;
320
+ isCancelled: boolean;
321
+ isAmbient: boolean;
322
+ ambientCategory?: Record<string, never>;
323
+ vibe?: "CHILL" | "ACTIVE" | "SOCIAL" | "CREATIVE" | "DEEP_TALK" | "ADVENTURE";
324
+ city?: import("@growsober/types/dist/generated").components["schemas"]["EventCityDto"];
325
+ venue?: import("@growsober/types/dist/generated").components["schemas"]["EventVenueDto"];
326
+ creator?: import("@growsober/types/dist/generated").components["schemas"]["EventCreatorDto"];
327
+ sponsorBrand?: import("@growsober/types/dist/generated").components["schemas"]["EventBrandDto"];
328
+ bookingCount: number;
329
+ checkinCount: number;
330
+ createdAt: string;
331
+ publishedAt?: Record<string, never>;
332
+ }[], Error>;
@@ -0,0 +1,249 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.creatorKeys = void 0;
4
+ exports.useCreators = useCreators;
5
+ exports.useCreator = useCreator;
6
+ exports.useCreatorBySlug = useCreatorBySlug;
7
+ exports.useCreatorByUser = useCreatorByUser;
8
+ exports.useMyCreatorProfile = useMyCreatorProfile;
9
+ exports.useCreatorAvailability = useCreatorAvailability;
10
+ exports.useCreatorContent = useCreatorContent;
11
+ exports.useCreatorAllContent = useCreatorAllContent;
12
+ exports.useCreatorEvents = useCreatorEvents;
13
+ const react_query_1 = require("@tanstack/react-query");
14
+ const client_1 = require("../client");
15
+ // ============================================================================
16
+ // QUERY KEY FACTORY
17
+ // ============================================================================
18
+ exports.creatorKeys = {
19
+ all: ['creators'],
20
+ lists: () => [...exports.creatorKeys.all, 'list'],
21
+ list: (filters) => [...exports.creatorKeys.lists(), filters],
22
+ details: () => [...exports.creatorKeys.all, 'detail'],
23
+ detail: (id) => [...exports.creatorKeys.details(), id],
24
+ slug: (slug) => [...exports.creatorKeys.all, 'slug', slug],
25
+ byUser: (userId) => [...exports.creatorKeys.all, 'user', userId],
26
+ me: () => [...exports.creatorKeys.all, 'me'],
27
+ availability: (creatorId) => [...exports.creatorKeys.detail(creatorId), 'availability'],
28
+ content: (creatorId) => [...exports.creatorKeys.detail(creatorId), 'content'],
29
+ allContent: (creatorId) => [...exports.creatorKeys.detail(creatorId), 'content', 'all'],
30
+ events: (creatorId) => [...exports.creatorKeys.detail(creatorId), 'events'],
31
+ };
32
+ // ============================================================================
33
+ // QUERY HOOKS
34
+ // ============================================================================
35
+ /**
36
+ * Get paginated list of creators with optional filters
37
+ *
38
+ * @param filters - Query parameters for filtering and pagination
39
+ * @param options - TanStack Query options
40
+ *
41
+ * @example
42
+ * ```tsx
43
+ * const { data, isLoading } = useCreators({
44
+ * page: 1,
45
+ * limit: 20,
46
+ * canFacilitate: true,
47
+ * });
48
+ * ```
49
+ */
50
+ function useCreators(filters, options) {
51
+ return (0, react_query_1.useQuery)({
52
+ queryKey: exports.creatorKeys.list(filters),
53
+ queryFn: async () => {
54
+ const client = (0, client_1.getApiClient)();
55
+ const response = await client.get('/api/v1/creators', {
56
+ params: filters,
57
+ });
58
+ return response.data;
59
+ },
60
+ ...options,
61
+ });
62
+ }
63
+ /**
64
+ * Get a single creator by ID
65
+ *
66
+ * @param id - Creator ID
67
+ * @param options - TanStack Query options
68
+ *
69
+ * @example
70
+ * ```tsx
71
+ * const { data, isLoading } = useCreator('creator-123');
72
+ * ```
73
+ */
74
+ function useCreator(id, options) {
75
+ return (0, react_query_1.useQuery)({
76
+ queryKey: exports.creatorKeys.detail(id),
77
+ queryFn: async () => {
78
+ const client = (0, client_1.getApiClient)();
79
+ const response = await client.get(`/api/v1/creators/${id}`);
80
+ return response.data;
81
+ },
82
+ enabled: !!id,
83
+ ...options,
84
+ });
85
+ }
86
+ /**
87
+ * Get a creator by their slug
88
+ *
89
+ * @param slug - Creator slug
90
+ * @param options - TanStack Query options
91
+ *
92
+ * @example
93
+ * ```tsx
94
+ * const { data, isLoading } = useCreatorBySlug('john-doe');
95
+ * ```
96
+ */
97
+ function useCreatorBySlug(slug, options) {
98
+ return (0, react_query_1.useQuery)({
99
+ queryKey: exports.creatorKeys.slug(slug),
100
+ queryFn: async () => {
101
+ const client = (0, client_1.getApiClient)();
102
+ const response = await client.get(`/api/v1/creators/slug/${slug}`);
103
+ return response.data;
104
+ },
105
+ enabled: !!slug,
106
+ ...options,
107
+ });
108
+ }
109
+ /**
110
+ * Get a creator profile by user ID
111
+ *
112
+ * @param userId - User ID
113
+ * @param options - TanStack Query options
114
+ *
115
+ * @example
116
+ * ```tsx
117
+ * const { data, isLoading } = useCreatorByUser('user-123');
118
+ * ```
119
+ */
120
+ function useCreatorByUser(userId, options) {
121
+ return (0, react_query_1.useQuery)({
122
+ queryKey: exports.creatorKeys.byUser(userId),
123
+ queryFn: async () => {
124
+ const client = (0, client_1.getApiClient)();
125
+ const response = await client.get(`/api/v1/creators/user/${userId}`);
126
+ return response.data;
127
+ },
128
+ enabled: !!userId,
129
+ ...options,
130
+ });
131
+ }
132
+ /**
133
+ * Get the current user's creator profile
134
+ *
135
+ * @param options - TanStack Query options
136
+ *
137
+ * @example
138
+ * ```tsx
139
+ * const { data, isLoading } = useMyCreatorProfile();
140
+ * ```
141
+ */
142
+ function useMyCreatorProfile(options) {
143
+ return (0, react_query_1.useQuery)({
144
+ queryKey: exports.creatorKeys.me(),
145
+ queryFn: async () => {
146
+ const client = (0, client_1.getApiClient)();
147
+ const response = await client.get('/api/v1/creators/me');
148
+ return response.data;
149
+ },
150
+ ...options,
151
+ });
152
+ }
153
+ /**
154
+ * Get creator availability slots
155
+ *
156
+ * @param creatorId - Creator ID
157
+ * @param options - TanStack Query options
158
+ *
159
+ * @example
160
+ * ```tsx
161
+ * const { data, isLoading } = useCreatorAvailability('creator-123');
162
+ * ```
163
+ */
164
+ function useCreatorAvailability(creatorId, options) {
165
+ return (0, react_query_1.useQuery)({
166
+ queryKey: exports.creatorKeys.availability(creatorId),
167
+ queryFn: async () => {
168
+ const client = (0, client_1.getApiClient)();
169
+ const response = await client.get(`/api/v1/creators/${creatorId}/availability`);
170
+ return response.data;
171
+ },
172
+ enabled: !!creatorId,
173
+ ...options,
174
+ });
175
+ }
176
+ /**
177
+ * Get a creator's published library content
178
+ *
179
+ * @param creatorId - Creator ID
180
+ * @param options - TanStack Query options
181
+ *
182
+ * @example
183
+ * ```tsx
184
+ * const { data, isLoading } = useCreatorContent('creator-123');
185
+ * ```
186
+ */
187
+ function useCreatorContent(creatorId, options) {
188
+ return (0, react_query_1.useQuery)({
189
+ queryKey: exports.creatorKeys.content(creatorId),
190
+ queryFn: async () => {
191
+ const client = (0, client_1.getApiClient)();
192
+ const response = await client.get(`/api/v1/creators/${creatorId}/content`);
193
+ return response.data;
194
+ },
195
+ enabled: !!creatorId,
196
+ ...options,
197
+ });
198
+ }
199
+ /**
200
+ * Get all of a creator's content including unpublished (owner only)
201
+ *
202
+ * @param creatorId - Creator ID
203
+ * @param options - TanStack Query options
204
+ *
205
+ * @example
206
+ * ```tsx
207
+ * // For creator dashboard - shows all content statuses
208
+ * const { data, isLoading } = useCreatorAllContent('creator-123');
209
+ * ```
210
+ */
211
+ function useCreatorAllContent(creatorId, options) {
212
+ return (0, react_query_1.useQuery)({
213
+ queryKey: exports.creatorKeys.allContent(creatorId),
214
+ queryFn: async () => {
215
+ const client = (0, client_1.getApiClient)();
216
+ const response = await client.get(`/api/v1/creators/${creatorId}/content/all`);
217
+ return response.data;
218
+ },
219
+ enabled: !!creatorId,
220
+ ...options,
221
+ });
222
+ }
223
+ /**
224
+ * Get a creator's upcoming events
225
+ *
226
+ * @param creatorId - Creator ID
227
+ * @param upcoming - Whether to filter to upcoming events only (default: true)
228
+ * @param options - TanStack Query options
229
+ *
230
+ * @example
231
+ * ```tsx
232
+ * const { data, isLoading } = useCreatorEvents('creator-123');
233
+ * ```
234
+ */
235
+ function useCreatorEvents(creatorId, upcoming = true, options) {
236
+ return (0, react_query_1.useQuery)({
237
+ queryKey: exports.creatorKeys.events(creatorId),
238
+ queryFn: async () => {
239
+ const client = (0, client_1.getApiClient)();
240
+ const response = await client.get(`/api/v1/creators/${creatorId}/events`, {
241
+ params: { upcoming },
242
+ });
243
+ return response.data;
244
+ },
245
+ enabled: !!creatorId,
246
+ ...options,
247
+ });
248
+ }
249
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"creators.js","sourceRoot":"","sources":["../../../src/api/queries/creators.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type {\n  CreatorResponse,\n  CreatorAvailabilityResponse,\n  EventResponse,\n  LibraryContentResponse,\n} from '../types';\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const creatorKeys = {\n  all: ['creators'] as const,\n  lists: () => [...creatorKeys.all, 'list'] as const,\n  list: (filters?: CreatorFilters) => [...creatorKeys.lists(), filters] as const,\n  details: () => [...creatorKeys.all, 'detail'] as const,\n  detail: (id: string) => [...creatorKeys.details(), id] as const,\n  slug: (slug: string) => [...creatorKeys.all, 'slug', slug] as const,\n  byUser: (userId: string) => [...creatorKeys.all, 'user', userId] as const,\n  me: () => [...creatorKeys.all, 'me'] as const,\n  availability: (creatorId: string) => [...creatorKeys.detail(creatorId), 'availability'] as const,\n  content: (creatorId: string) => [...creatorKeys.detail(creatorId), 'content'] as const,\n  allContent: (creatorId: string) => [...creatorKeys.detail(creatorId), 'content', 'all'] as const,\n  events: (creatorId: string) => [...creatorKeys.detail(creatorId), 'events'] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface CreatorFilters {\n  page?: number;\n  limit?: number;\n  search?: string;\n  cityId?: string;\n  canFacilitate?: boolean;\n  canCreateContent?: boolean;\n  isInfluencer?: boolean;\n  isVerified?: boolean;\n  sortBy?: string;\n  sortOrder?: 'asc' | 'desc';\n}\n\nexport interface PaginatedCreatorsResponse {\n  creators: CreatorResponse[];\n  meta: {\n    total: number;\n    page: number;\n    limit: number;\n    totalPages: number;\n  };\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get paginated list of creators with optional filters\n *\n * @param filters - Query parameters for filtering and pagination\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCreators({\n *   page: 1,\n *   limit: 20,\n *   canFacilitate: true,\n * });\n * ```\n */\nexport function useCreators(\n  filters?: CreatorFilters,\n  options?: Omit<UseQueryOptions<PaginatedCreatorsResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: creatorKeys.list(filters),\n    queryFn: async (): Promise<PaginatedCreatorsResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/creators', {\n        params: filters,\n      });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get a single creator by ID\n *\n * @param id - Creator ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCreator('creator-123');\n * ```\n */\nexport function useCreator(\n  id: string,\n  options?: Omit<UseQueryOptions<CreatorResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: creatorKeys.detail(id),\n    queryFn: async (): Promise<CreatorResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\n/**\n * Get a creator by their slug\n *\n * @param slug - Creator slug\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCreatorBySlug('john-doe');\n * ```\n */\nexport function useCreatorBySlug(\n  slug: string,\n  options?: Omit<UseQueryOptions<CreatorResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: creatorKeys.slug(slug),\n    queryFn: async (): Promise<CreatorResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/slug/${slug}`);\n      return response.data;\n    },\n    enabled: !!slug,\n    ...options,\n  });\n}\n\n/**\n * Get a creator profile by user ID\n *\n * @param userId - User ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCreatorByUser('user-123');\n * ```\n */\nexport function useCreatorByUser(\n  userId: string,\n  options?: Omit<UseQueryOptions<CreatorResponse | null>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: creatorKeys.byUser(userId),\n    queryFn: async (): Promise<CreatorResponse | null> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/user/${userId}`);\n      return response.data;\n    },\n    enabled: !!userId,\n    ...options,\n  });\n}\n\n/**\n * Get the current user's creator profile\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useMyCreatorProfile();\n * ```\n */\nexport function useMyCreatorProfile(\n  options?: Omit<UseQueryOptions<CreatorResponse | null>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: creatorKeys.me(),\n    queryFn: async (): Promise<CreatorResponse | null> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/creators/me');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get creator availability slots\n *\n * @param creatorId - Creator ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCreatorAvailability('creator-123');\n * ```\n */\nexport function useCreatorAvailability(\n  creatorId: string,\n  options?: Omit<UseQueryOptions<CreatorAvailabilityResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: creatorKeys.availability(creatorId),\n    queryFn: async (): Promise<CreatorAvailabilityResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/availability`);\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n\n/**\n * Get a creator's published library content\n *\n * @param creatorId - Creator ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCreatorContent('creator-123');\n * ```\n */\nexport function useCreatorContent(\n  creatorId: string,\n  options?: Omit<UseQueryOptions<LibraryContentResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: creatorKeys.content(creatorId),\n    queryFn: async (): Promise<LibraryContentResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/content`);\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n\n/**\n * Get all of a creator's content including unpublished (owner only)\n *\n * @param creatorId - Creator ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * // For creator dashboard - shows all content statuses\n * const { data, isLoading } = useCreatorAllContent('creator-123');\n * ```\n */\nexport function useCreatorAllContent(\n  creatorId: string,\n  options?: Omit<UseQueryOptions<LibraryContentResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: creatorKeys.allContent(creatorId),\n    queryFn: async (): Promise<LibraryContentResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/content/all`);\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n\n/**\n * Get a creator's upcoming events\n *\n * @param creatorId - Creator ID\n * @param upcoming - Whether to filter to upcoming events only (default: true)\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCreatorEvents('creator-123');\n * ```\n */\nexport function useCreatorEvents(\n  creatorId: string,\n  upcoming = true,\n  options?: Omit<UseQueryOptions<EventResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: creatorKeys.events(creatorId),\n    queryFn: async (): Promise<EventResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/events`, {\n        params: { upcoming },\n      });\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n"]}
@@ -26,7 +26,7 @@ export declare function useEventChatMembers(eventId: string | undefined): import
26
26
  id: string;
27
27
  chatId: string;
28
28
  userId: string;
29
- role: "MEMBER" | "MODERATOR" | "HOST";
29
+ role: "ATTENDEE" | "CREATOR" | "VENUE_REP" | "BRAND_REP" | "ADMIN" | "MODERATOR";
30
30
  nickname?: string;
31
31
  isMuted: boolean;
32
32
  lastReadAt?: string;