@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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRvcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3F1ZXJpZXMvY3JlYXRvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBMEVBLGtDQWVDO0FBYUQsZ0NBY0M7QUFhRCw0Q0FjQztBQWFELDRDQWNDO0FBWUQsa0RBWUM7QUFhRCx3REFjQztBQWFELDhDQWNDO0FBY0Qsb0RBY0M7QUFjRCw0Q0FpQkM7QUFuVEQsdURBQWtFO0FBQ2xFLHNDQUF5QztBQVF6QywrRUFBK0U7QUFDL0Usb0JBQW9CO0FBQ3BCLCtFQUErRTtBQUVsRSxRQUFBLFdBQVcsR0FBRztJQUN6QixHQUFHLEVBQUUsQ0FBQyxVQUFVLENBQVU7SUFDMUIsS0FBSyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsR0FBRyxtQkFBVyxDQUFDLEdBQUcsRUFBRSxNQUFNLENBQVU7SUFDbEQsSUFBSSxFQUFFLENBQUMsT0FBd0IsRUFBRSxFQUFFLENBQUMsQ0FBQyxHQUFHLG1CQUFXLENBQUMsS0FBSyxFQUFFLEVBQUUsT0FBTyxDQUFVO0lBQzlFLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLEdBQUcsbUJBQVcsQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFVO0lBQ3RELE1BQU0sRUFBRSxDQUFDLEVBQVUsRUFBRSxFQUFFLENBQUMsQ0FBQyxHQUFHLG1CQUFXLENBQUMsT0FBTyxFQUFFLEVBQUUsRUFBRSxDQUFVO0lBQy9ELElBQUksRUFBRSxDQUFDLElBQVksRUFBRSxFQUFFLENBQUMsQ0FBQyxHQUFHLG1CQUFXLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQVU7SUFDbkUsTUFBTSxFQUFFLENBQUMsTUFBYyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsbUJBQVcsQ0FBQyxHQUFHLEVBQUUsTUFBTSxFQUFFLE1BQU0sQ0FBVTtJQUN6RSxFQUFFLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxHQUFHLG1CQUFXLENBQUMs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QVEsR0FBRyxJQUFJLEVBQ2YsT0FBd0U7SUFFeEUsT0FBTyxJQUFBLHNCQUFRLEVBQUM7UUFDZCxRQUFRLEVBQUUsbUJBQVcsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDO1FBQ3ZDLE9BQU8sRUFBRSxLQUFLLElBQThCLEVBQUU7WUFDNUMsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUM7WUFDOUIsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUFDLG9CQUFvQixTQUFTLFNBQVMsRUFBRTtnQkFDeEUsTUFBTSxFQUFFLEVBQUUsUUFBUSxFQUFFO2FBQ3JCLENBQUMsQ0FBQztZQUNILE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQztRQUN2QixDQUFDO1FBQ0QsT0FBTyxFQUFFLENBQUMsQ0FBQyxTQUFTO1FBQ3BCLEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VRdWVyeSwgVXNlUXVlcnlPcHRpb25zIH0gZnJvbSAnQHRhbnN0YWNrL3JlYWN0LXF1ZXJ5JztcbmltcG9ydCB7IGdldEFwaUNsaWVudCB9IGZyb20gJy4uL2NsaWVudCc7XG5pbXBvcnQgdHlwZSB7XG4gIENyZWF0b3JSZXNwb25zZSxcbiAgQ3JlYXRvckF2YWlsYWJpbGl0eVJlc3BvbnNlLFxuICBFdmVudFJlc3BvbnNlLFxuICBMaWJyYXJ5Q29udGVudFJlc3BvbnNlLFxufSBmcm9tICcuLi90eXBlcyc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFFVRVJZIEtFWSBGQUNUT1JZXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBjb25zdCBjcmVhdG9yS2V5cyA9IHtcbiAgYWxsOiBbJ2NyZWF0b3JzJ10gYXMgY29uc3QsXG4gIGxpc3RzOiAoKSA9PiBbLi4uY3JlYXRvcktleXMuYWxsLCAnbGlzdCddIGFzIGNvbnN0LFxuICBsaXN0OiAoZmlsdGVycz86IENyZWF0b3JGaWx0ZXJzKSA9PiBbLi4uY3JlYXRvcktleXMubGlzdHMoKSwgZmlsdGVyc10gYXMgY29uc3QsXG4gIGRldGFpbHM6ICgpID0+IFsuLi5jcmVhdG9yS2V5cy5hbGwsICdkZXRhaWwnXSBhcyBjb25zdCxcbiAgZGV0YWlsOiAoaWQ6IHN0cmluZykgPT4gWy4uLmNyZWF0b3JLZXlzLmRldGFpbHMoKSwgaWRdIGFzIGNvbnN0LFxuICBzbHVnOiAoc2x1Zzogc3RyaW5nKSA9PiBbLi4uY3JlYXRvcktleXMuYWxsLCAnc2x1ZycsIHNsdWddIGFzIGNvbnN0LFxuICBieVVzZXI6ICh1c2VySWQ6IHN0cmluZykgPT4gWy4uLmNyZWF0b3JLZXlzLmFsbCwgJ3VzZXInLCB1c2VySWRdIGFzIGNvbnN0LFxuICBtZTogKCkgPT4gWy4uLmNyZWF0b3JLZXlzLmFsbCwgJ21lJ10gYXMgY29uc3QsXG4gIGF2YWlsYWJpbGl0eTogKGNyZWF0b3JJZDogc3RyaW5nKSA9PiBbLi4uY3JlYXRvcktleXMuZGV0YWlsKGNyZWF0b3JJZCksICdhdmFpbGFiaWxpdHknXSBhcyBjb25zdCxcbiAgY29udGVudDogKGNyZWF0b3JJZDogc3RyaW5nKSA9PiBbLi4uY3JlYXRvcktleXMuZGV0YWlsKGNyZWF0b3JJZCksICdjb250ZW50J10gYXMgY29uc3QsXG4gIGFsbENvbnRlbnQ6IChjcmVhdG9ySWQ6IHN0cmluZykgPT4gWy4uLmNyZWF0b3JLZXlzLmRldGFpbChjcmVhdG9ySWQpLCAnY29udGVudCcsICdhbGwnXSBhcyBjb25zdCxcbiAgZXZlbnRzOiAoY3JlYXRvcklkOiBzdHJpbmcpID0+IFsuLi5jcmVhdG9yS2V5cy5kZXRhaWwoY3JlYXRvcklkKSwgJ2V2ZW50cyddIGFzIGNvbnN0LFxufTtcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gVFlQRVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGludGVyZmFjZSBDcmVhdG9yRmlsdGVycyB7XG4gIHBhZ2U/OiBudW1iZXI7XG4gIGxpbWl0PzogbnVtYmVyO1xuICBzZWFyY2g/OiBzdHJpbmc7XG4gIGNpdHlJZD86IHN0cmluZztcbiAgY2FuRmFjaWxpdGF0ZT86IGJvb2xlYW47XG4gIGNhbkNyZWF0ZUNvbnRlbnQ/OiBib29sZWFuO1xuICBpc0luZmx1ZW5jZXI/OiBib29sZWFuO1xuICBpc1ZlcmlmaWVkPzogYm9vbGVhbjtcbiAgc29ydEJ5Pzogc3RyaW5nO1xuICBzb3J0T3JkZXI/OiAnYXNjJyB8ICdkZXNjJztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQYWdpbmF0ZWRDcmVhdG9yc1Jlc3BvbnNlIHtcbiAgY3JlYXRvcnM6IENyZWF0b3JSZXNwb25zZVtdO1xuICBtZXRhOiB7XG4gICAgdG90YWw6IG51bWJlcjtcbiAgICBwYWdlOiBudW1iZXI7XG4gICAgbGltaXQ6IG51bWJlcjtcbiAgICB0b3RhbFBhZ2VzOiBudW1iZXI7XG4gIH07XG59XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFFVRVJZIEhPT0tTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogR2V0IHBhZ2luYXRlZCBsaXN0IG9mIGNyZWF0b3JzIHdpdGggb3B0aW9uYWwgZmlsdGVyc1xuICpcbiAqIEBwYXJhbSBmaWx0ZXJzIC0gUXVlcnkgcGFyYW1ldGVycyBmb3IgZmlsdGVyaW5nIGFuZCBwYWdpbmF0aW9uXG4gKiBAcGFyYW0gb3B0aW9ucyAtIFRhblN0YWNrIFF1ZXJ5IG9wdGlvbnNcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHN4XG4gKiBjb25zdCB7IGRhdGEsIGlzTG9hZGluZyB9ID0gdXNlQ3JlYXRvcnMoe1xuICogICBwYWdlOiAxLFxuICogICBsaW1pdDogMjAsXG4gKiAgIGNhbkZhY2lsaXRhdGU6IHRydWUsXG4gKiB9KTtcbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlQ3JlYXRvcnMoXG4gIGZpbHRlcnM/OiBDcmVhdG9yRmlsdGVycyxcbiAgb3B0aW9ucz86IE9taXQ8VXNlUXVlcnlPcHRpb25zPFBhZ2luYXRlZENyZWF0b3JzUmVzcG9uc2U+LCAncXVlcnlLZXknIHwgJ3F1ZXJ5Rm4nPlxuKSB7XG4gIHJldHVybiB1c2VRdWVyeSh7XG4gICAgcXVlcnlLZXk6IGNyZWF0b3JLZXlzLmxpc3QoZmlsdGVycyksXG4gICAgcXVlcnlGbjogYXN5bmMgKCk6IFByb21pc2U8UGFnaW5hdGVkQ3JlYXRvcnNSZXNwb25zZT4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KCk7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5nZXQoJy9hcGkvdjEvY3JlYXRvcnMnLCB7XG4gICAgICAgIHBhcmFtczogZmlsdGVycyxcbiAgICAgIH0pO1xuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGE7XG4gICAgfSxcbiAgICAuLi5vcHRpb25zLFxuICB9KTtcbn1cblxuLyoqXG4gKiBHZXQgYSBzaW5nbGUgY3JlYXRvciBieSBJRFxuICpcbiAqIEBwYXJhbSBpZCAtIENyZWF0b3IgSURcbiAqIEBwYXJhbSBvcHRpb25zIC0gVGFuU3RhY2sgUXVlcnkgb3B0aW9uc1xuICpcbiAqIEBleGFtcGxlXG4gKiBgYGB0c3hcbiAqIGNvbnN0IHsgZGF0YSwgaXNMb2FkaW5nIH0gPSB1c2VDcmVhdG9yKCdjcmVhdG9yLTEyMycpO1xuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VDcmVhdG9yKFxuICBpZDogc3RyaW5nLFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8Q3JlYXRvclJlc3BvbnNlPiwgJ3F1ZXJ5S2V5JyB8ICdxdWVyeUZuJz5cbikge1xuICByZXR1cm4gdXNlUXVlcnkoe1xuICAgIHF1ZXJ5S2V5OiBjcmVhdG9yS2V5cy5kZXRhaWwoaWQpLFxuICAgIHF1ZXJ5Rm46IGFzeW5jICgpOiBQcm9taXNlPENyZWF0b3JSZXNwb25zZT4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KCk7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5nZXQoYC9hcGkvdjEvY3JlYXRvcnMvJHtpZH1gKTtcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhO1xuICAgIH0sXG4gICAgZW5hYmxlZDogISFpZCxcbiAgICAuLi5vcHRpb25zLFxuICB9KTtcbn1cblxuLyoqXG4gKiBHZXQgYSBjcmVhdG9yIGJ5IHRoZWlyIHNsdWdcbiAqXG4gKiBAcGFyYW0gc2x1ZyAtIENyZWF0b3Igc2x1Z1xuICogQHBhcmFtIG9wdGlvbnMgLSBUYW5TdGFjayBRdWVyeSBvcHRpb25zXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzeFxuICogY29uc3QgeyBkYXRhLCBpc0xvYWRpbmcgfSA9IHVzZUNyZWF0b3JCeVNsdWcoJ2pvaG4tZG9lJyk7XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZUNyZWF0b3JCeVNsdWcoXG4gIHNsdWc6IHN0cmluZyxcbiAgb3B0aW9ucz86IE9taXQ8VXNlUXVlcnlPcHRpb25zPENyZWF0b3JSZXNwb25zZT4sICdxdWVyeUtleScgfCAncXVlcnlGbic+XG4pIHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogY3JlYXRvcktleXMuc2x1ZyhzbHVnKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxDcmVhdG9yUmVzcG9uc2U+ID0+IHtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGdldEFwaUNsaWVudCgpO1xuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0KGAvYXBpL3YxL2NyZWF0b3JzL3NsdWcvJHtzbHVnfWApO1xuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGE7XG4gICAgfSxcbiAgICBlbmFibGVkOiAhIXNsdWcsXG4gICAgLi4ub3B0aW9ucyxcbiAgfSk7XG59XG5cbi8qKlxuICogR2V0IGEgY3JlYXRvciBwcm9maWxlIGJ5IHVzZXIgSURcbiAqXG4gKiBAcGFyYW0gdXNlcklkIC0gVXNlciBJRFxuICogQHBhcmFtIG9wdGlvbnMgLSBUYW5TdGFjayBRdWVyeSBvcHRpb25zXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzeFxuICogY29uc3QgeyBkYXRhLCBpc0xvYWRpbmcgfSA9IHVzZUNyZWF0b3JCeVVzZXIoJ3VzZXItMTIzJyk7XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZUNyZWF0b3JCeVVzZXIoXG4gIHVzZXJJZDogc3RyaW5nLFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8Q3JlYXRvclJlc3BvbnNlIHwgbnVsbD4sICdxdWVyeUtleScgfCAncXVlcnlGbic+XG4pIHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogY3JlYXRvcktleXMuYnlVc2VyKHVzZXJJZCksXG4gICAgcXVlcnlGbjogYXN5bmMgKCk6IFByb21pc2U8Q3JlYXRvclJlc3BvbnNlIHwgbnVsbD4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KCk7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5nZXQoYC9hcGkvdjEvY3JlYXRvcnMvdXNlci8ke3VzZXJJZH1gKTtcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhO1xuICAgIH0sXG4gICAgZW5hYmxlZDogISF1c2VySWQsXG4gICAgLi4ub3B0aW9ucyxcbiAgfSk7XG59XG5cbi8qKlxuICogR2V0IHRoZSBjdXJyZW50IHVzZXIncyBjcmVhdG9yIHByb2ZpbGVcbiAqXG4gKiBAcGFyYW0gb3B0aW9ucyAtIFRhblN0YWNrIFF1ZXJ5IG9wdGlvbnNcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHN4XG4gKiBjb25zdCB7IGRhdGEsIGlzTG9hZGluZyB9ID0gdXNlTXlDcmVhdG9yUHJvZmlsZSgpO1xuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VNeUNyZWF0b3JQcm9maWxlKFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8Q3JlYXRvclJlc3BvbnNlIHwgbnVsbD4sICdxdWVyeUtleScgfCAncXVlcnlGbic+XG4pIHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogY3JlYXRvcktleXMubWUoKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxDcmVhdG9yUmVzcG9uc2UgfCBudWxsPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldCgnL2FwaS92MS9jcmVhdG9ycy9tZScpO1xuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGE7XG4gICAgfSxcbiAgICAuLi5vcHRpb25zLFxuICB9KTtcbn1cblxuLyoqXG4gKiBHZXQgY3JlYXRvciBhdmFpbGFiaWxpdHkgc2xvdHNcbiAqXG4gKiBAcGFyYW0gY3JlYXRvcklkIC0gQ3JlYXRvciBJRFxuICogQHBhcmFtIG9wdGlvbnMgLSBUYW5TdGFjayBRdWVyeSBvcHRpb25zXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzeFxuICogY29uc3QgeyBkYXRhLCBpc0xvYWRpbmcgfSA9IHVzZUNyZWF0b3JBdmFpbGFiaWxpdHkoJ2NyZWF0b3ItMTIzJyk7XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZUNyZWF0b3JBdmFpbGFiaWxpdHkoXG4gIGNyZWF0b3JJZDogc3RyaW5nLFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8Q3JlYXRvckF2YWlsYWJpbGl0eVJlc3BvbnNlW10+LCAncXVlcnlLZXknIHwgJ3F1ZXJ5Rm4nPlxuKSB7XG4gIHJldHVybiB1c2VRdWVyeSh7XG4gICAgcXVlcnlLZXk6IGNyZWF0b3JLZXlzLmF2YWlsYWJpbGl0eShjcmVhdG9ySWQpLFxuICAgIHF1ZXJ5Rm46IGFzeW5jICgpOiBQcm9taXNlPENyZWF0b3JBdmFpbGFiaWxpdHlSZXNwb25zZVtdPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldChgL2FwaS92MS9jcmVhdG9ycy8ke2NyZWF0b3JJZH0vYXZhaWxhYmlsaXR5YCk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YTtcbiAgICB9LFxuICAgIGVuYWJsZWQ6ICEhY3JlYXRvcklkLFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pO1xufVxuXG4vKipcbiAqIEdldCBhIGNyZWF0b3IncyBwdWJsaXNoZWQgbGlicmFyeSBjb250ZW50XG4gKlxuICogQHBhcmFtIGNyZWF0b3JJZCAtIENyZWF0b3IgSURcbiAqIEBwYXJhbSBvcHRpb25zIC0gVGFuU3RhY2sgUXVlcnkgb3B0aW9uc1xuICpcbiAqIEBleGFtcGxlXG4gKiBgYGB0c3hcbiAqIGNvbnN0IHsgZGF0YSwgaXNMb2FkaW5nIH0gPSB1c2VDcmVhdG9yQ29udGVudCgnY3JlYXRvci0xMjMnKTtcbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlQ3JlYXRvckNvbnRlbnQoXG4gIGNyZWF0b3JJZDogc3RyaW5nLFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8TGlicmFyeUNvbnRlbnRSZXNwb25zZVtdPiwgJ3F1ZXJ5S2V5JyB8ICdxdWVyeUZuJz5cbikge1xuICByZXR1cm4gdXNlUXVlcnkoe1xuICAgIHF1ZXJ5S2V5OiBjcmVhdG9yS2V5cy5jb250ZW50KGNyZWF0b3JJZCksXG4gICAgcXVlcnlGbjogYXN5bmMgKCk6IFByb21pc2U8TGlicmFyeUNvbnRlbnRSZXNwb25zZVtdPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldChgL2FwaS92MS9jcmVhdG9ycy8ke2NyZWF0b3JJZH0vY29udGVudGApO1xuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGE7XG4gICAgfSxcbiAgICBlbmFibGVkOiAhIWNyZWF0b3JJZCxcbiAgICAuLi5vcHRpb25zLFxuICB9KTtcbn1cblxuLyoqXG4gKiBHZXQgYWxsIG9mIGEgY3JlYXRvcidzIGNvbnRlbnQgaW5jbHVkaW5nIHVucHVibGlzaGVkIChvd25lciBvbmx5KVxuICpcbiAqIEBwYXJhbSBjcmVhdG9ySWQgLSBDcmVhdG9yIElEXG4gKiBAcGFyYW0gb3B0aW9ucyAtIFRhblN0YWNrIFF1ZXJ5IG9wdGlvbnNcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHN4XG4gKiAvLyBGb3IgY3JlYXRvciBkYXNoYm9hcmQgLSBzaG93cyBhbGwgY29udGVudCBzdGF0dXNlc1xuICogY29uc3QgeyBkYXRhLCBpc0xvYWRpbmcgfSA9IHVzZUNyZWF0b3JBbGxDb250ZW50KCdjcmVhdG9yLTEyMycpO1xuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VDcmVhdG9yQWxsQ29udGVudChcbiAgY3JlYXRvcklkOiBzdHJpbmcsXG4gIG9wdGlvbnM/OiBPbWl0PFVzZVF1ZXJ5T3B0aW9uczxMaWJyYXJ5Q29udGVudFJlc3BvbnNlW10+LCAncXVlcnlLZXknIHwgJ3F1ZXJ5Rm4nPlxuKSB7XG4gIHJldHVybiB1c2VRdWVyeSh7XG4gICAgcXVlcnlLZXk6IGNyZWF0b3JLZXlzLmFsbENvbnRlbnQoY3JlYXRvcklkKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxMaWJyYXJ5Q29udGVudFJlc3BvbnNlW10+ID0+IHtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGdldEFwaUNsaWVudCgpO1xuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0KGAvYXBpL3YxL2NyZWF0b3JzLyR7Y3JlYXRvcklkfS9jb250ZW50L2FsbGApO1xuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGE7XG4gICAgfSxcbiAgICBlbmFibGVkOiAhIWNyZWF0b3JJZCxcbiAgICAuLi5vcHRpb25zLFxuICB9KTtcbn1cblxuLyoqXG4gKiBHZXQgYSBjcmVhdG9yJ3MgdXBjb21pbmcgZXZlbnRzXG4gKlxuICogQHBhcmFtIGNyZWF0b3JJZCAtIENyZWF0b3IgSURcbiAqIEBwYXJhbSB1cGNvbWluZyAtIFdoZXRoZXIgdG8gZmlsdGVyIHRvIHVwY29taW5nIGV2ZW50cyBvbmx5IChkZWZhdWx0OiB0cnVlKVxuICogQHBhcmFtIG9wdGlvbnMgLSBUYW5TdGFjayBRdWVyeSBvcHRpb25zXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzeFxuICogY29uc3QgeyBkYXRhLCBpc0xvYWRpbmcgfSA9IHVzZUNyZWF0b3JFdmVudHMoJ2NyZWF0b3ItMTIzJyk7XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZUNyZWF0b3JFdmVudHMoXG4gIGNyZWF0b3JJZDogc3RyaW5nLFxuICB1cGNvbWluZyA9IHRydWUsXG4gIG9wdGlvbnM/OiBPbWl0PFVzZVF1ZXJ5T3B0aW9uczxFdmVudFJlc3BvbnNlW10+LCAncXVlcnlLZXknIHwgJ3F1ZXJ5Rm4nPlxuKSB7XG4gIHJldHVybiB1c2VRdWVyeSh7XG4gICAgcXVlcnlLZXk6IGNyZWF0b3JLZXlzLmV2ZW50cyhjcmVhdG9ySWQpLFxuICAgIHF1ZXJ5Rm46IGFzeW5jICgpOiBQcm9taXNlPEV2ZW50UmVzcG9uc2VbXT4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KCk7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5nZXQoYC9hcGkvdjEvY3JlYXRvcnMvJHtjcmVhdG9ySWR9L2V2ZW50c2AsIHtcbiAgICAgICAgcGFyYW1zOiB7IHVwY29taW5nIH0sXG4gICAgICB9KTtcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhO1xuICAgIH0sXG4gICAgZW5hYmxlZDogISFjcmVhdG9ySWQsXG4gICAgLi4ub3B0aW9ucyxcbiAgfSk7XG59XG4iXX0=
@@ -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;