@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
|
@@ -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: "
|
|
29
|
+
role: "ATTENDEE" | "CREATOR" | "VENUE_REP" | "BRAND_REP" | "ADMIN" | "MODERATOR";
|
|
30
30
|
nickname?: string;
|
|
31
31
|
isMuted: boolean;
|
|
32
32
|
lastReadAt?: string;
|