@growsober/sdk 1.0.16 → 1.0.17
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/api/mutations/creators.d.ts +156 -1
- package/dist/api/mutations/creators.js +146 -1
- package/dist/api/queries/creators.d.ts +61 -1
- package/dist/api/queries/creators.js +54 -1
- package/dist/api/types.d.ts +3 -0
- package/dist/api/types.js +1 -1
- package/package.json +2 -2
- package/src/api/mutations/creators.ts +162 -0
- package/src/api/queries/creators.ts +61 -0
- package/src/api/types.ts +8 -0
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { UseMutationOptions } from '@tanstack/react-query';
|
|
2
|
-
import type { CreatorResponse, CreatorAvailabilityResponse, CreateCreatorRequest, UpdateCreatorRequest, CreateAvailabilityRequest } from '../types';
|
|
2
|
+
import type { CreatorResponse, CreatorAvailabilityResponse, CreateCreatorRequest, UpdateCreatorRequest, CreateAvailabilityRequest, UpdateGatheringTypeRequest } from '../types';
|
|
3
3
|
/**
|
|
4
4
|
* Create a new creator profile for the current user
|
|
5
5
|
*
|
|
@@ -207,3 +207,158 @@ export declare function useUpdateCreatorReward(creatorId: string, options?: Omit
|
|
|
207
207
|
* ```
|
|
208
208
|
*/
|
|
209
209
|
export declare function useDeleteCreatorReward(creatorId: string, options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<void, Error, string, unknown>;
|
|
210
|
+
/**
|
|
211
|
+
* Create a new gathering type for a creator
|
|
212
|
+
*
|
|
213
|
+
* @param creatorId - Creator ID
|
|
214
|
+
*
|
|
215
|
+
* @example
|
|
216
|
+
* ```tsx
|
|
217
|
+
* const createGatheringType = useCreateGatheringType(creatorId);
|
|
218
|
+
*
|
|
219
|
+
* await createGatheringType.mutateAsync({
|
|
220
|
+
* name: 'Morning Yoga in the Park',
|
|
221
|
+
* description: 'Gentle 45-minute yoga session',
|
|
222
|
+
* duration: 45,
|
|
223
|
+
* vibes: ['Mindful', 'Chill'],
|
|
224
|
+
* category: 'MOVEMENT',
|
|
225
|
+
* });
|
|
226
|
+
* ```
|
|
227
|
+
*/
|
|
228
|
+
export declare function useCreateGatheringType(creatorId: string): import("@tanstack/react-query").UseMutationResult<{
|
|
229
|
+
id: string;
|
|
230
|
+
creatorId: string;
|
|
231
|
+
name: string;
|
|
232
|
+
description?: Record<string, never> | null;
|
|
233
|
+
duration: number;
|
|
234
|
+
vibes: string[];
|
|
235
|
+
category?: "WALK" | "COFFEE" | "MOVEMENT" | "CONVERSATION" | "CREATIVE" | "COWORKING" | null;
|
|
236
|
+
suggestedPrice?: Record<string, never> | null;
|
|
237
|
+
currency: string;
|
|
238
|
+
isAiGenerated: boolean;
|
|
239
|
+
isApproved: boolean;
|
|
240
|
+
aiPromptContext?: Record<string, never> | null;
|
|
241
|
+
defaultVenueId?: Record<string, never> | null;
|
|
242
|
+
defaultVenue?: Record<string, never> | null;
|
|
243
|
+
createdAt: string;
|
|
244
|
+
updatedAt: string;
|
|
245
|
+
}, Error, {
|
|
246
|
+
name: string;
|
|
247
|
+
description?: string;
|
|
248
|
+
duration: number;
|
|
249
|
+
vibes?: string[];
|
|
250
|
+
category?: "WALK" | "COFFEE" | "MOVEMENT" | "CONVERSATION" | "CREATIVE" | "COWORKING";
|
|
251
|
+
suggestedPrice?: number;
|
|
252
|
+
currency: string;
|
|
253
|
+
defaultVenueId?: string;
|
|
254
|
+
}, unknown>;
|
|
255
|
+
/**
|
|
256
|
+
* Update a gathering type
|
|
257
|
+
*
|
|
258
|
+
* @param creatorId - Creator ID
|
|
259
|
+
*
|
|
260
|
+
* @example
|
|
261
|
+
* ```tsx
|
|
262
|
+
* const updateGatheringType = useUpdateGatheringType(creatorId);
|
|
263
|
+
*
|
|
264
|
+
* await updateGatheringType.mutateAsync({
|
|
265
|
+
* id: 'gathering-type-123',
|
|
266
|
+
* data: { description: 'Updated description' },
|
|
267
|
+
* });
|
|
268
|
+
* ```
|
|
269
|
+
*/
|
|
270
|
+
export declare function useUpdateGatheringType(creatorId: string): import("@tanstack/react-query").UseMutationResult<{
|
|
271
|
+
id: string;
|
|
272
|
+
creatorId: string;
|
|
273
|
+
name: string;
|
|
274
|
+
description?: Record<string, never> | null;
|
|
275
|
+
duration: number;
|
|
276
|
+
vibes: string[];
|
|
277
|
+
category?: "WALK" | "COFFEE" | "MOVEMENT" | "CONVERSATION" | "CREATIVE" | "COWORKING" | null;
|
|
278
|
+
suggestedPrice?: Record<string, never> | null;
|
|
279
|
+
currency: string;
|
|
280
|
+
isAiGenerated: boolean;
|
|
281
|
+
isApproved: boolean;
|
|
282
|
+
aiPromptContext?: Record<string, never> | null;
|
|
283
|
+
defaultVenueId?: Record<string, never> | null;
|
|
284
|
+
defaultVenue?: Record<string, never> | null;
|
|
285
|
+
createdAt: string;
|
|
286
|
+
updatedAt: string;
|
|
287
|
+
}, Error, {
|
|
288
|
+
id: string;
|
|
289
|
+
data: UpdateGatheringTypeRequest;
|
|
290
|
+
}, unknown>;
|
|
291
|
+
/**
|
|
292
|
+
* Approve a gathering type (for AI-suggested types)
|
|
293
|
+
*
|
|
294
|
+
* @param creatorId - Creator ID
|
|
295
|
+
*
|
|
296
|
+
* @example
|
|
297
|
+
* ```tsx
|
|
298
|
+
* const approveGatheringType = useApproveGatheringType(creatorId);
|
|
299
|
+
*
|
|
300
|
+
* await approveGatheringType.mutateAsync('gathering-type-123');
|
|
301
|
+
* ```
|
|
302
|
+
*/
|
|
303
|
+
export declare function useApproveGatheringType(creatorId: string): import("@tanstack/react-query").UseMutationResult<{
|
|
304
|
+
id: string;
|
|
305
|
+
creatorId: string;
|
|
306
|
+
name: string;
|
|
307
|
+
description?: Record<string, never> | null;
|
|
308
|
+
duration: number;
|
|
309
|
+
vibes: string[];
|
|
310
|
+
category?: "WALK" | "COFFEE" | "MOVEMENT" | "CONVERSATION" | "CREATIVE" | "COWORKING" | null;
|
|
311
|
+
suggestedPrice?: Record<string, never> | null;
|
|
312
|
+
currency: string;
|
|
313
|
+
isAiGenerated: boolean;
|
|
314
|
+
isApproved: boolean;
|
|
315
|
+
aiPromptContext?: Record<string, never> | null;
|
|
316
|
+
defaultVenueId?: Record<string, never> | null;
|
|
317
|
+
defaultVenue?: Record<string, never> | null;
|
|
318
|
+
createdAt: string;
|
|
319
|
+
updatedAt: string;
|
|
320
|
+
}, Error, string, unknown>;
|
|
321
|
+
/**
|
|
322
|
+
* Delete a gathering type
|
|
323
|
+
*
|
|
324
|
+
* @param creatorId - Creator ID
|
|
325
|
+
*
|
|
326
|
+
* @example
|
|
327
|
+
* ```tsx
|
|
328
|
+
* const deleteGatheringType = useDeleteGatheringType(creatorId);
|
|
329
|
+
*
|
|
330
|
+
* await deleteGatheringType.mutateAsync('gathering-type-123');
|
|
331
|
+
* ```
|
|
332
|
+
*/
|
|
333
|
+
export declare function useDeleteGatheringType(creatorId: string): import("@tanstack/react-query").UseMutationResult<void, Error, string, unknown>;
|
|
334
|
+
/**
|
|
335
|
+
* Generate AI suggestions for gathering types based on facilitator profile
|
|
336
|
+
*
|
|
337
|
+
* @param creatorId - Creator ID
|
|
338
|
+
*
|
|
339
|
+
* @example
|
|
340
|
+
* ```tsx
|
|
341
|
+
* const generateSuggestions = useGenerateGatheringTypeSuggestions(creatorId);
|
|
342
|
+
*
|
|
343
|
+
* await generateSuggestions.mutateAsync();
|
|
344
|
+
* // Returns the newly created (unapproved) gathering types
|
|
345
|
+
* ```
|
|
346
|
+
*/
|
|
347
|
+
export declare function useGenerateGatheringTypeSuggestions(creatorId: string): import("@tanstack/react-query").UseMutationResult<{
|
|
348
|
+
id: string;
|
|
349
|
+
creatorId: string;
|
|
350
|
+
name: string;
|
|
351
|
+
description?: Record<string, never> | null;
|
|
352
|
+
duration: number;
|
|
353
|
+
vibes: string[];
|
|
354
|
+
category?: "WALK" | "COFFEE" | "MOVEMENT" | "CONVERSATION" | "CREATIVE" | "COWORKING" | null;
|
|
355
|
+
suggestedPrice?: Record<string, never> | null;
|
|
356
|
+
currency: string;
|
|
357
|
+
isAiGenerated: boolean;
|
|
358
|
+
isApproved: boolean;
|
|
359
|
+
aiPromptContext?: Record<string, never> | null;
|
|
360
|
+
defaultVenueId?: Record<string, never> | null;
|
|
361
|
+
defaultVenue?: Record<string, never> | null;
|
|
362
|
+
createdAt: string;
|
|
363
|
+
updatedAt: string;
|
|
364
|
+
}[], Error, void, unknown>;
|
|
@@ -7,6 +7,11 @@ exports.useRemoveCreatorAvailability = useRemoveCreatorAvailability;
|
|
|
7
7
|
exports.useCreateCreatorReward = useCreateCreatorReward;
|
|
8
8
|
exports.useUpdateCreatorReward = useUpdateCreatorReward;
|
|
9
9
|
exports.useDeleteCreatorReward = useDeleteCreatorReward;
|
|
10
|
+
exports.useCreateGatheringType = useCreateGatheringType;
|
|
11
|
+
exports.useUpdateGatheringType = useUpdateGatheringType;
|
|
12
|
+
exports.useApproveGatheringType = useApproveGatheringType;
|
|
13
|
+
exports.useDeleteGatheringType = useDeleteGatheringType;
|
|
14
|
+
exports.useGenerateGatheringTypeSuggestions = useGenerateGatheringTypeSuggestions;
|
|
10
15
|
const react_query_1 = require("@tanstack/react-query");
|
|
11
16
|
const client_1 = require("../client");
|
|
12
17
|
const creators_1 = require("../queries/creators");
|
|
@@ -208,4 +213,144 @@ function useDeleteCreatorReward(creatorId, options) {
|
|
|
208
213
|
...options,
|
|
209
214
|
});
|
|
210
215
|
}
|
|
211
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"creators.js","sourceRoot":"","sources":["../../../src/api/mutations/creators.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient, UseMutationOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { creatorKeys } from '../queries/creators';\nimport type {\n  CreatorResponse,\n  CreatorAvailabilityResponse,\n  CreateCreatorRequest,\n  UpdateCreatorRequest,\n  CreateAvailabilityRequest,\n} from '../types';\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a new creator profile for the current user\n *\n * @example\n * ```tsx\n * const { mutateAsync: createCreator } = useCreateCreator();\n *\n * await createCreator({\n *   slug: 'john-doe',\n *   displayName: 'John Doe',\n *   bio: 'Wellness facilitator',\n *   canFacilitate: true,\n * });\n * ```\n */\nexport function useCreateCreator(\n  options?: Omit<UseMutationOptions<CreatorResponse, Error, CreateCreatorRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateCreatorRequest): Promise<CreatorResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/creators', data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.all });\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a creator profile\n *\n * @example\n * ```tsx\n * const { mutateAsync: updateCreator } = useUpdateCreator();\n *\n * await updateCreator({\n *   id: 'creator-123',\n *   data: { bio: 'Updated bio' },\n * });\n * ```\n */\nexport function useUpdateCreator(\n  options?: Omit<\n    UseMutationOptions<CreatorResponse, Error, { id: string; data: UpdateCreatorRequest }>,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ id, data }: { id: string; data: UpdateCreatorRequest }): Promise<CreatorResponse> => {\n      const client = getApiClient();\n      const response = await client.patch(`/api/v1/creators/${id}`, data);\n      return response.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.detail(variables.id) });\n      queryClient.invalidateQueries({ queryKey: creatorKeys.me() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Add an availability slot for a creator\n *\n * @example\n * ```tsx\n * const { mutateAsync: addAvailability } = useAddCreatorAvailability();\n *\n * await addAvailability({\n *   creatorId: 'creator-123',\n *   data: {\n *     dayOfWeek: 1, // Monday\n *     startTime: '09:00',\n *     endTime: '17:00',\n *     timezone: 'Europe/London',\n *     isRecurring: true,\n *   },\n * });\n * ```\n */\nexport function useAddCreatorAvailability(\n  options?: Omit<\n    UseMutationOptions<\n      CreatorAvailabilityResponse,\n      Error,\n      { creatorId: string; data: CreateAvailabilityRequest }\n    >,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      data,\n    }: {\n      creatorId: string;\n      data: CreateAvailabilityRequest;\n    }): Promise<CreatorAvailabilityResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/availability`, data);\n      return response.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.availability(variables.creatorId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Remove an availability slot for a creator\n *\n * @example\n * ```tsx\n * const { mutateAsync: removeAvailability } = useRemoveCreatorAvailability();\n *\n * await removeAvailability({\n *   creatorId: 'creator-123',\n *   availabilityId: 'availability-456',\n * });\n * ```\n */\nexport function useRemoveCreatorAvailability(\n  options?: Omit<\n    UseMutationOptions<void, Error, { creatorId: string; availabilityId: string }>,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      availabilityId,\n    }: {\n      creatorId: string;\n      availabilityId: string;\n    }): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/creators/${creatorId}/availability/${availabilityId}`);\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.availability(variables.creatorId) });\n    },\n    ...options,\n  });\n}\n\n// ============================================================================\n// CREATOR REWARDS\n// ============================================================================\n\nexport interface CreateCreatorRewardRequest {\n  badgeId: string;\n  title: string;\n  description: string;\n  redeemType: 'IN_PERSON' | 'ONLINE' | 'BOTH';\n  code?: string;\n  maxRedemptions?: number;\n  validUntil?: string;\n}\n\nexport interface CreatorRewardResponse {\n  id: string;\n  creatorId: string;\n  badgeId: string;\n  title: string;\n  description: string;\n  redeemType: 'IN_PERSON' | 'ONLINE' | 'BOTH';\n  code?: string;\n  maxRedemptions?: number;\n  validUntil?: string;\n  createdAt: string;\n  updatedAt: string;\n}\n\nexport interface UpdateCreatorRewardRequest {\n  title?: string;\n  description?: string;\n  redeemType?: 'IN_PERSON' | 'ONLINE' | 'BOTH';\n  code?: string;\n  maxRedemptions?: number;\n  validUntil?: string;\n  isActive?: boolean;\n}\n\n/**\n * Create a new reward for a creator\n *\n * @example\n * ```tsx\n * const createReward = useCreateCreatorReward(creatorId);\n *\n * await createReward.mutateAsync({\n *   badgeId: 'badge-123',\n *   title: 'Free Session',\n *   description: 'Get a free 30-minute session',\n *   redeemType: 'IN_PERSON',\n * });\n * ```\n */\nexport function useCreateCreatorReward(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateCreatorRewardRequest): Promise<CreatorRewardResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/rewards`, data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.detail(creatorId) });\n      queryClient.invalidateQueries({ queryKey: creatorKeys.rewards(creatorId) });\n    },\n  });\n}\n\n/**\n * Update an existing reward for a creator\n *\n * @example\n * ```tsx\n * const updateReward = useUpdateCreatorReward(creatorId);\n *\n * await updateReward.mutateAsync({\n *   id: 'reward-123',\n *   data: { isActive: false },\n * });\n * ```\n */\nexport function useUpdateCreatorReward(\n  creatorId: string,\n  options?: Omit<\n    UseMutationOptions<CreatorRewardResponse, Error, { id: string; data: UpdateCreatorRewardRequest }>,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ id, data }: { id: string; data: UpdateCreatorRewardRequest }): Promise<CreatorRewardResponse> => {\n      const client = getApiClient();\n      const response = await client.patch(`/api/v1/creators/${creatorId}/rewards/${id}`, data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.rewards(creatorId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Delete a reward for a creator\n *\n * @example\n * ```tsx\n * const deleteReward = useDeleteCreatorReward(creatorId);\n *\n * await deleteReward.mutateAsync('reward-123');\n * ```\n */\nexport function useDeleteCreatorReward(\n  creatorId: string,\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (rewardId: string): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/creators/${creatorId}/rewards/${rewardId}`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.rewards(creatorId) });\n    },\n    ...options,\n  });\n}\n"]}
|
|
216
|
+
// ============================================================================
|
|
217
|
+
// GATHERING TYPE MUTATIONS
|
|
218
|
+
// ============================================================================
|
|
219
|
+
/**
|
|
220
|
+
* Create a new gathering type for a creator
|
|
221
|
+
*
|
|
222
|
+
* @param creatorId - Creator ID
|
|
223
|
+
*
|
|
224
|
+
* @example
|
|
225
|
+
* ```tsx
|
|
226
|
+
* const createGatheringType = useCreateGatheringType(creatorId);
|
|
227
|
+
*
|
|
228
|
+
* await createGatheringType.mutateAsync({
|
|
229
|
+
* name: 'Morning Yoga in the Park',
|
|
230
|
+
* description: 'Gentle 45-minute yoga session',
|
|
231
|
+
* duration: 45,
|
|
232
|
+
* vibes: ['Mindful', 'Chill'],
|
|
233
|
+
* category: 'MOVEMENT',
|
|
234
|
+
* });
|
|
235
|
+
* ```
|
|
236
|
+
*/
|
|
237
|
+
function useCreateGatheringType(creatorId) {
|
|
238
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
239
|
+
return (0, react_query_1.useMutation)({
|
|
240
|
+
mutationFn: async (data) => {
|
|
241
|
+
const client = (0, client_1.getApiClient)();
|
|
242
|
+
const response = await client.post(`/api/v1/creators/${creatorId}/gathering-types`, data);
|
|
243
|
+
return response.data;
|
|
244
|
+
},
|
|
245
|
+
onSuccess: () => {
|
|
246
|
+
queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.gatheringTypes(creatorId) });
|
|
247
|
+
},
|
|
248
|
+
});
|
|
249
|
+
}
|
|
250
|
+
/**
|
|
251
|
+
* Update a gathering type
|
|
252
|
+
*
|
|
253
|
+
* @param creatorId - Creator ID
|
|
254
|
+
*
|
|
255
|
+
* @example
|
|
256
|
+
* ```tsx
|
|
257
|
+
* const updateGatheringType = useUpdateGatheringType(creatorId);
|
|
258
|
+
*
|
|
259
|
+
* await updateGatheringType.mutateAsync({
|
|
260
|
+
* id: 'gathering-type-123',
|
|
261
|
+
* data: { description: 'Updated description' },
|
|
262
|
+
* });
|
|
263
|
+
* ```
|
|
264
|
+
*/
|
|
265
|
+
function useUpdateGatheringType(creatorId) {
|
|
266
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
267
|
+
return (0, react_query_1.useMutation)({
|
|
268
|
+
mutationFn: async ({ id, data, }) => {
|
|
269
|
+
const client = (0, client_1.getApiClient)();
|
|
270
|
+
const response = await client.put(`/api/v1/creators/${creatorId}/gathering-types/${id}`, data);
|
|
271
|
+
return response.data;
|
|
272
|
+
},
|
|
273
|
+
onSuccess: () => {
|
|
274
|
+
queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.gatheringTypes(creatorId) });
|
|
275
|
+
queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.approvedGatheringTypes(creatorId) });
|
|
276
|
+
},
|
|
277
|
+
});
|
|
278
|
+
}
|
|
279
|
+
/**
|
|
280
|
+
* Approve a gathering type (for AI-suggested types)
|
|
281
|
+
*
|
|
282
|
+
* @param creatorId - Creator ID
|
|
283
|
+
*
|
|
284
|
+
* @example
|
|
285
|
+
* ```tsx
|
|
286
|
+
* const approveGatheringType = useApproveGatheringType(creatorId);
|
|
287
|
+
*
|
|
288
|
+
* await approveGatheringType.mutateAsync('gathering-type-123');
|
|
289
|
+
* ```
|
|
290
|
+
*/
|
|
291
|
+
function useApproveGatheringType(creatorId) {
|
|
292
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
293
|
+
return (0, react_query_1.useMutation)({
|
|
294
|
+
mutationFn: async (gatheringTypeId) => {
|
|
295
|
+
const client = (0, client_1.getApiClient)();
|
|
296
|
+
const response = await client.put(`/api/v1/creators/${creatorId}/gathering-types/${gatheringTypeId}/approve`);
|
|
297
|
+
return response.data;
|
|
298
|
+
},
|
|
299
|
+
onSuccess: () => {
|
|
300
|
+
queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.gatheringTypes(creatorId) });
|
|
301
|
+
queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.approvedGatheringTypes(creatorId) });
|
|
302
|
+
},
|
|
303
|
+
});
|
|
304
|
+
}
|
|
305
|
+
/**
|
|
306
|
+
* Delete a gathering type
|
|
307
|
+
*
|
|
308
|
+
* @param creatorId - Creator ID
|
|
309
|
+
*
|
|
310
|
+
* @example
|
|
311
|
+
* ```tsx
|
|
312
|
+
* const deleteGatheringType = useDeleteGatheringType(creatorId);
|
|
313
|
+
*
|
|
314
|
+
* await deleteGatheringType.mutateAsync('gathering-type-123');
|
|
315
|
+
* ```
|
|
316
|
+
*/
|
|
317
|
+
function useDeleteGatheringType(creatorId) {
|
|
318
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
319
|
+
return (0, react_query_1.useMutation)({
|
|
320
|
+
mutationFn: async (gatheringTypeId) => {
|
|
321
|
+
const client = (0, client_1.getApiClient)();
|
|
322
|
+
await client.delete(`/api/v1/creators/${creatorId}/gathering-types/${gatheringTypeId}`);
|
|
323
|
+
},
|
|
324
|
+
onSuccess: () => {
|
|
325
|
+
queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.gatheringTypes(creatorId) });
|
|
326
|
+
queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.approvedGatheringTypes(creatorId) });
|
|
327
|
+
},
|
|
328
|
+
});
|
|
329
|
+
}
|
|
330
|
+
/**
|
|
331
|
+
* Generate AI suggestions for gathering types based on facilitator profile
|
|
332
|
+
*
|
|
333
|
+
* @param creatorId - Creator ID
|
|
334
|
+
*
|
|
335
|
+
* @example
|
|
336
|
+
* ```tsx
|
|
337
|
+
* const generateSuggestions = useGenerateGatheringTypeSuggestions(creatorId);
|
|
338
|
+
*
|
|
339
|
+
* await generateSuggestions.mutateAsync();
|
|
340
|
+
* // Returns the newly created (unapproved) gathering types
|
|
341
|
+
* ```
|
|
342
|
+
*/
|
|
343
|
+
function useGenerateGatheringTypeSuggestions(creatorId) {
|
|
344
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
345
|
+
return (0, react_query_1.useMutation)({
|
|
346
|
+
mutationFn: async () => {
|
|
347
|
+
const client = (0, client_1.getApiClient)();
|
|
348
|
+
const response = await client.post(`/api/v1/creators/${creatorId}/gathering-types/generate`);
|
|
349
|
+
return response.data;
|
|
350
|
+
},
|
|
351
|
+
onSuccess: () => {
|
|
352
|
+
queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.gatheringTypes(creatorId) });
|
|
353
|
+
},
|
|
354
|
+
});
|
|
355
|
+
}
|
|
356
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"creators.js","sourceRoot":"","sources":["../../../src/api/mutations/creators.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient, UseMutationOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { creatorKeys } from '../queries/creators';\nimport type {\n  CreatorResponse,\n  CreatorAvailabilityResponse,\n  CreateCreatorRequest,\n  UpdateCreatorRequest,\n  CreateAvailabilityRequest,\n  GatheringTypeResponse,\n  CreateGatheringTypeRequest,\n  UpdateGatheringTypeRequest,\n} from '../types';\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a new creator profile for the current user\n *\n * @example\n * ```tsx\n * const { mutateAsync: createCreator } = useCreateCreator();\n *\n * await createCreator({\n *   slug: 'john-doe',\n *   displayName: 'John Doe',\n *   bio: 'Wellness facilitator',\n *   canFacilitate: true,\n * });\n * ```\n */\nexport function useCreateCreator(\n  options?: Omit<UseMutationOptions<CreatorResponse, Error, CreateCreatorRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateCreatorRequest): Promise<CreatorResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/creators', data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.all });\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a creator profile\n *\n * @example\n * ```tsx\n * const { mutateAsync: updateCreator } = useUpdateCreator();\n *\n * await updateCreator({\n *   id: 'creator-123',\n *   data: { bio: 'Updated bio' },\n * });\n * ```\n */\nexport function useUpdateCreator(\n  options?: Omit<\n    UseMutationOptions<CreatorResponse, Error, { id: string; data: UpdateCreatorRequest }>,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ id, data }: { id: string; data: UpdateCreatorRequest }): Promise<CreatorResponse> => {\n      const client = getApiClient();\n      const response = await client.patch(`/api/v1/creators/${id}`, data);\n      return response.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.detail(variables.id) });\n      queryClient.invalidateQueries({ queryKey: creatorKeys.me() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Add an availability slot for a creator\n *\n * @example\n * ```tsx\n * const { mutateAsync: addAvailability } = useAddCreatorAvailability();\n *\n * await addAvailability({\n *   creatorId: 'creator-123',\n *   data: {\n *     dayOfWeek: 1, // Monday\n *     startTime: '09:00',\n *     endTime: '17:00',\n *     timezone: 'Europe/London',\n *     isRecurring: true,\n *   },\n * });\n * ```\n */\nexport function useAddCreatorAvailability(\n  options?: Omit<\n    UseMutationOptions<\n      CreatorAvailabilityResponse,\n      Error,\n      { creatorId: string; data: CreateAvailabilityRequest }\n    >,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      data,\n    }: {\n      creatorId: string;\n      data: CreateAvailabilityRequest;\n    }): Promise<CreatorAvailabilityResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/availability`, data);\n      return response.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.availability(variables.creatorId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Remove an availability slot for a creator\n *\n * @example\n * ```tsx\n * const { mutateAsync: removeAvailability } = useRemoveCreatorAvailability();\n *\n * await removeAvailability({\n *   creatorId: 'creator-123',\n *   availabilityId: 'availability-456',\n * });\n * ```\n */\nexport function useRemoveCreatorAvailability(\n  options?: Omit<\n    UseMutationOptions<void, Error, { creatorId: string; availabilityId: string }>,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      availabilityId,\n    }: {\n      creatorId: string;\n      availabilityId: string;\n    }): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/creators/${creatorId}/availability/${availabilityId}`);\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.availability(variables.creatorId) });\n    },\n    ...options,\n  });\n}\n\n// ============================================================================\n// CREATOR REWARDS\n// ============================================================================\n\nexport interface CreateCreatorRewardRequest {\n  badgeId: string;\n  title: string;\n  description: string;\n  redeemType: 'IN_PERSON' | 'ONLINE' | 'BOTH';\n  code?: string;\n  maxRedemptions?: number;\n  validUntil?: string;\n}\n\nexport interface CreatorRewardResponse {\n  id: string;\n  creatorId: string;\n  badgeId: string;\n  title: string;\n  description: string;\n  redeemType: 'IN_PERSON' | 'ONLINE' | 'BOTH';\n  code?: string;\n  maxRedemptions?: number;\n  validUntil?: string;\n  createdAt: string;\n  updatedAt: string;\n}\n\nexport interface UpdateCreatorRewardRequest {\n  title?: string;\n  description?: string;\n  redeemType?: 'IN_PERSON' | 'ONLINE' | 'BOTH';\n  code?: string;\n  maxRedemptions?: number;\n  validUntil?: string;\n  isActive?: boolean;\n}\n\n/**\n * Create a new reward for a creator\n *\n * @example\n * ```tsx\n * const createReward = useCreateCreatorReward(creatorId);\n *\n * await createReward.mutateAsync({\n *   badgeId: 'badge-123',\n *   title: 'Free Session',\n *   description: 'Get a free 30-minute session',\n *   redeemType: 'IN_PERSON',\n * });\n * ```\n */\nexport function useCreateCreatorReward(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateCreatorRewardRequest): Promise<CreatorRewardResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/rewards`, data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.detail(creatorId) });\n      queryClient.invalidateQueries({ queryKey: creatorKeys.rewards(creatorId) });\n    },\n  });\n}\n\n/**\n * Update an existing reward for a creator\n *\n * @example\n * ```tsx\n * const updateReward = useUpdateCreatorReward(creatorId);\n *\n * await updateReward.mutateAsync({\n *   id: 'reward-123',\n *   data: { isActive: false },\n * });\n * ```\n */\nexport function useUpdateCreatorReward(\n  creatorId: string,\n  options?: Omit<\n    UseMutationOptions<CreatorRewardResponse, Error, { id: string; data: UpdateCreatorRewardRequest }>,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ id, data }: { id: string; data: UpdateCreatorRewardRequest }): Promise<CreatorRewardResponse> => {\n      const client = getApiClient();\n      const response = await client.patch(`/api/v1/creators/${creatorId}/rewards/${id}`, data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.rewards(creatorId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Delete a reward for a creator\n *\n * @example\n * ```tsx\n * const deleteReward = useDeleteCreatorReward(creatorId);\n *\n * await deleteReward.mutateAsync('reward-123');\n * ```\n */\nexport function useDeleteCreatorReward(\n  creatorId: string,\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (rewardId: string): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/creators/${creatorId}/rewards/${rewardId}`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.rewards(creatorId) });\n    },\n    ...options,\n  });\n}\n\n// ============================================================================\n// GATHERING TYPE MUTATIONS\n// ============================================================================\n\n/**\n * Create a new gathering type for a creator\n *\n * @param creatorId - Creator ID\n *\n * @example\n * ```tsx\n * const createGatheringType = useCreateGatheringType(creatorId);\n *\n * await createGatheringType.mutateAsync({\n *   name: 'Morning Yoga in the Park',\n *   description: 'Gentle 45-minute yoga session',\n *   duration: 45,\n *   vibes: ['Mindful', 'Chill'],\n *   category: 'MOVEMENT',\n * });\n * ```\n */\nexport function useCreateGatheringType(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateGatheringTypeRequest): Promise<GatheringTypeResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/gathering-types`, data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.gatheringTypes(creatorId) });\n    },\n  });\n}\n\n/**\n * Update a gathering type\n *\n * @param creatorId - Creator ID\n *\n * @example\n * ```tsx\n * const updateGatheringType = useUpdateGatheringType(creatorId);\n *\n * await updateGatheringType.mutateAsync({\n *   id: 'gathering-type-123',\n *   data: { description: 'Updated description' },\n * });\n * ```\n */\nexport function useUpdateGatheringType(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      id,\n      data,\n    }: {\n      id: string;\n      data: UpdateGatheringTypeRequest;\n    }): Promise<GatheringTypeResponse> => {\n      const client = getApiClient();\n      const response = await client.put(`/api/v1/creators/${creatorId}/gathering-types/${id}`, data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.gatheringTypes(creatorId) });\n      queryClient.invalidateQueries({ queryKey: creatorKeys.approvedGatheringTypes(creatorId) });\n    },\n  });\n}\n\n/**\n * Approve a gathering type (for AI-suggested types)\n *\n * @param creatorId - Creator ID\n *\n * @example\n * ```tsx\n * const approveGatheringType = useApproveGatheringType(creatorId);\n *\n * await approveGatheringType.mutateAsync('gathering-type-123');\n * ```\n */\nexport function useApproveGatheringType(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (gatheringTypeId: string): Promise<GatheringTypeResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/creators/${creatorId}/gathering-types/${gatheringTypeId}/approve`\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.gatheringTypes(creatorId) });\n      queryClient.invalidateQueries({ queryKey: creatorKeys.approvedGatheringTypes(creatorId) });\n    },\n  });\n}\n\n/**\n * Delete a gathering type\n *\n * @param creatorId - Creator ID\n *\n * @example\n * ```tsx\n * const deleteGatheringType = useDeleteGatheringType(creatorId);\n *\n * await deleteGatheringType.mutateAsync('gathering-type-123');\n * ```\n */\nexport function useDeleteGatheringType(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (gatheringTypeId: string): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/creators/${creatorId}/gathering-types/${gatheringTypeId}`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.gatheringTypes(creatorId) });\n      queryClient.invalidateQueries({ queryKey: creatorKeys.approvedGatheringTypes(creatorId) });\n    },\n  });\n}\n\n/**\n * Generate AI suggestions for gathering types based on facilitator profile\n *\n * @param creatorId - Creator ID\n *\n * @example\n * ```tsx\n * const generateSuggestions = useGenerateGatheringTypeSuggestions(creatorId);\n *\n * await generateSuggestions.mutateAsync();\n * // Returns the newly created (unapproved) gathering types\n * ```\n */\nexport function useGenerateGatheringTypeSuggestions(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (): Promise<GatheringTypeResponse[]> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/gathering-types/generate`);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.gatheringTypes(creatorId) });\n    },\n  });\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { UseQueryOptions } from '@tanstack/react-query';
|
|
2
|
-
import type { CreatorResponse, CreatorAvailabilityResponse, EventResponse, LibraryContentResponse, RewardResponse } from '../types';
|
|
2
|
+
import type { CreatorResponse, CreatorAvailabilityResponse, EventResponse, LibraryContentResponse, RewardResponse, GatheringTypeResponse } from '../types';
|
|
3
3
|
export declare const creatorKeys: {
|
|
4
4
|
all: readonly ["creators"];
|
|
5
5
|
lists: () => readonly ["creators", "list"];
|
|
@@ -14,6 +14,8 @@ export declare const creatorKeys: {
|
|
|
14
14
|
allContent: (creatorId: string) => readonly ["creators", "detail", string, "content", "all"];
|
|
15
15
|
events: (creatorId: string) => readonly ["creators", "detail", string, "events"];
|
|
16
16
|
rewards: (creatorId: string) => readonly ["creators", "detail", string, "rewards"];
|
|
17
|
+
gatheringTypes: (creatorId: string) => readonly ["creators", "detail", string, "gathering-types"];
|
|
18
|
+
approvedGatheringTypes: (creatorId: string) => readonly ["creators", "detail", string, "gathering-types", "approved"];
|
|
17
19
|
};
|
|
18
20
|
export interface CreatorFilters {
|
|
19
21
|
page?: number;
|
|
@@ -344,3 +346,61 @@ export declare function useCreatorEvents(creatorId: string, upcoming?: boolean,
|
|
|
344
346
|
* ```
|
|
345
347
|
*/
|
|
346
348
|
export declare function useCreatorRewards(creatorId: string, options?: Omit<UseQueryOptions<RewardResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<RewardResponse[], Error>;
|
|
349
|
+
/**
|
|
350
|
+
* Get all gathering types for a creator (including unapproved AI suggestions)
|
|
351
|
+
*
|
|
352
|
+
* @param creatorId - Creator ID
|
|
353
|
+
* @param options - TanStack Query options
|
|
354
|
+
*
|
|
355
|
+
* @example
|
|
356
|
+
* ```tsx
|
|
357
|
+
* const { data, isLoading } = useCreatorGatheringTypes('creator-123');
|
|
358
|
+
* ```
|
|
359
|
+
*/
|
|
360
|
+
export declare function useCreatorGatheringTypes(creatorId: string, options?: Omit<UseQueryOptions<GatheringTypeResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
361
|
+
id: string;
|
|
362
|
+
creatorId: string;
|
|
363
|
+
name: string;
|
|
364
|
+
description?: Record<string, never> | null;
|
|
365
|
+
duration: number;
|
|
366
|
+
vibes: string[];
|
|
367
|
+
category?: "WALK" | "COFFEE" | "MOVEMENT" | "CONVERSATION" | "CREATIVE" | "COWORKING" | null;
|
|
368
|
+
suggestedPrice?: Record<string, never> | null;
|
|
369
|
+
currency: string;
|
|
370
|
+
isAiGenerated: boolean;
|
|
371
|
+
isApproved: boolean;
|
|
372
|
+
aiPromptContext?: Record<string, never> | null;
|
|
373
|
+
defaultVenueId?: Record<string, never> | null;
|
|
374
|
+
defaultVenue?: Record<string, never> | null;
|
|
375
|
+
createdAt: string;
|
|
376
|
+
updatedAt: string;
|
|
377
|
+
}[], Error>;
|
|
378
|
+
/**
|
|
379
|
+
* Get approved gathering types for a creator
|
|
380
|
+
*
|
|
381
|
+
* @param creatorId - Creator ID
|
|
382
|
+
* @param options - TanStack Query options
|
|
383
|
+
*
|
|
384
|
+
* @example
|
|
385
|
+
* ```tsx
|
|
386
|
+
* const { data, isLoading } = useCreatorApprovedGatheringTypes('creator-123');
|
|
387
|
+
* ```
|
|
388
|
+
*/
|
|
389
|
+
export declare function useCreatorApprovedGatheringTypes(creatorId: string, options?: Omit<UseQueryOptions<GatheringTypeResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
390
|
+
id: string;
|
|
391
|
+
creatorId: string;
|
|
392
|
+
name: string;
|
|
393
|
+
description?: Record<string, never> | null;
|
|
394
|
+
duration: number;
|
|
395
|
+
vibes: string[];
|
|
396
|
+
category?: "WALK" | "COFFEE" | "MOVEMENT" | "CONVERSATION" | "CREATIVE" | "COWORKING" | null;
|
|
397
|
+
suggestedPrice?: Record<string, never> | null;
|
|
398
|
+
currency: string;
|
|
399
|
+
isAiGenerated: boolean;
|
|
400
|
+
isApproved: boolean;
|
|
401
|
+
aiPromptContext?: Record<string, never> | null;
|
|
402
|
+
defaultVenueId?: Record<string, never> | null;
|
|
403
|
+
defaultVenue?: Record<string, never> | null;
|
|
404
|
+
createdAt: string;
|
|
405
|
+
updatedAt: string;
|
|
406
|
+
}[], Error>;
|
|
@@ -11,6 +11,8 @@ exports.useCreatorContent = useCreatorContent;
|
|
|
11
11
|
exports.useCreatorAllContent = useCreatorAllContent;
|
|
12
12
|
exports.useCreatorEvents = useCreatorEvents;
|
|
13
13
|
exports.useCreatorRewards = useCreatorRewards;
|
|
14
|
+
exports.useCreatorGatheringTypes = useCreatorGatheringTypes;
|
|
15
|
+
exports.useCreatorApprovedGatheringTypes = useCreatorApprovedGatheringTypes;
|
|
14
16
|
const react_query_1 = require("@tanstack/react-query");
|
|
15
17
|
const client_1 = require("../client");
|
|
16
18
|
// ============================================================================
|
|
@@ -30,6 +32,8 @@ exports.creatorKeys = {
|
|
|
30
32
|
allContent: (creatorId) => [...exports.creatorKeys.detail(creatorId), 'content', 'all'],
|
|
31
33
|
events: (creatorId) => [...exports.creatorKeys.detail(creatorId), 'events'],
|
|
32
34
|
rewards: (creatorId) => [...exports.creatorKeys.detail(creatorId), 'rewards'],
|
|
35
|
+
gatheringTypes: (creatorId) => [...exports.creatorKeys.detail(creatorId), 'gathering-types'],
|
|
36
|
+
approvedGatheringTypes: (creatorId) => [...exports.creatorKeys.detail(creatorId), 'gathering-types', 'approved'],
|
|
33
37
|
};
|
|
34
38
|
// ============================================================================
|
|
35
39
|
// QUERY HOOKS
|
|
@@ -271,4 +275,53 @@ function useCreatorRewards(creatorId, options) {
|
|
|
271
275
|
...options,
|
|
272
276
|
});
|
|
273
277
|
}
|
|
274
|
-
//# 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  RewardResponse,\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  rewards: (creatorId: string) => [...creatorKeys.detail(creatorId), 'rewards'] 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// Re-export RewardResponse from types for convenience\nexport type { RewardResponse } from '../types';\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\n/**\n * Get a creator's rewards\n *\n * @param creatorId - Creator ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCreatorRewards('creator-123');\n * ```\n */\nexport function useCreatorRewards(\n  creatorId: string,\n  options?: Omit<UseQueryOptions<RewardResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: creatorKeys.rewards(creatorId),\n    queryFn: async (): Promise<RewardResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/rewards`);\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n"]}
|
|
278
|
+
// ============================================================================
|
|
279
|
+
// GATHERING TYPE QUERIES
|
|
280
|
+
// ============================================================================
|
|
281
|
+
/**
|
|
282
|
+
* Get all gathering types for a creator (including unapproved AI suggestions)
|
|
283
|
+
*
|
|
284
|
+
* @param creatorId - Creator ID
|
|
285
|
+
* @param options - TanStack Query options
|
|
286
|
+
*
|
|
287
|
+
* @example
|
|
288
|
+
* ```tsx
|
|
289
|
+
* const { data, isLoading } = useCreatorGatheringTypes('creator-123');
|
|
290
|
+
* ```
|
|
291
|
+
*/
|
|
292
|
+
function useCreatorGatheringTypes(creatorId, options) {
|
|
293
|
+
return (0, react_query_1.useQuery)({
|
|
294
|
+
queryKey: exports.creatorKeys.gatheringTypes(creatorId),
|
|
295
|
+
queryFn: async () => {
|
|
296
|
+
const client = (0, client_1.getApiClient)();
|
|
297
|
+
const response = await client.get(`/api/v1/creators/${creatorId}/gathering-types`);
|
|
298
|
+
return response.data;
|
|
299
|
+
},
|
|
300
|
+
enabled: !!creatorId,
|
|
301
|
+
...options,
|
|
302
|
+
});
|
|
303
|
+
}
|
|
304
|
+
/**
|
|
305
|
+
* Get approved gathering types for a creator
|
|
306
|
+
*
|
|
307
|
+
* @param creatorId - Creator ID
|
|
308
|
+
* @param options - TanStack Query options
|
|
309
|
+
*
|
|
310
|
+
* @example
|
|
311
|
+
* ```tsx
|
|
312
|
+
* const { data, isLoading } = useCreatorApprovedGatheringTypes('creator-123');
|
|
313
|
+
* ```
|
|
314
|
+
*/
|
|
315
|
+
function useCreatorApprovedGatheringTypes(creatorId, options) {
|
|
316
|
+
return (0, react_query_1.useQuery)({
|
|
317
|
+
queryKey: exports.creatorKeys.approvedGatheringTypes(creatorId),
|
|
318
|
+
queryFn: async () => {
|
|
319
|
+
const client = (0, client_1.getApiClient)();
|
|
320
|
+
const response = await client.get(`/api/v1/creators/${creatorId}/gathering-types/approved`);
|
|
321
|
+
return response.data;
|
|
322
|
+
},
|
|
323
|
+
enabled: !!creatorId,
|
|
324
|
+
...options,
|
|
325
|
+
});
|
|
326
|
+
}
|
|
327
|
+
//# 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  RewardResponse,\n  GatheringTypeResponse,\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  rewards: (creatorId: string) => [...creatorKeys.detail(creatorId), 'rewards'] as const,\n  gatheringTypes: (creatorId: string) => [...creatorKeys.detail(creatorId), 'gathering-types'] as const,\n  approvedGatheringTypes: (creatorId: string) => [...creatorKeys.detail(creatorId), 'gathering-types', 'approved'] 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// Re-export RewardResponse from types for convenience\nexport type { RewardResponse } from '../types';\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\n/**\n * Get a creator's rewards\n *\n * @param creatorId - Creator ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCreatorRewards('creator-123');\n * ```\n */\nexport function useCreatorRewards(\n  creatorId: string,\n  options?: Omit<UseQueryOptions<RewardResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: creatorKeys.rewards(creatorId),\n    queryFn: async (): Promise<RewardResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/rewards`);\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n\n// ============================================================================\n// GATHERING TYPE QUERIES\n// ============================================================================\n\n/**\n * Get all gathering types for a creator (including unapproved AI suggestions)\n *\n * @param creatorId - Creator ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCreatorGatheringTypes('creator-123');\n * ```\n */\nexport function useCreatorGatheringTypes(\n  creatorId: string,\n  options?: Omit<UseQueryOptions<GatheringTypeResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: creatorKeys.gatheringTypes(creatorId),\n    queryFn: async (): Promise<GatheringTypeResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/gathering-types`);\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n\n/**\n * Get approved gathering types for a creator\n *\n * @param creatorId - Creator ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCreatorApprovedGatheringTypes('creator-123');\n * ```\n */\nexport function useCreatorApprovedGatheringTypes(\n  creatorId: string,\n  options?: Omit<UseQueryOptions<GatheringTypeResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: creatorKeys.approvedGatheringTypes(creatorId),\n    queryFn: async (): Promise<GatheringTypeResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/gathering-types/approved`);\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n"]}
|
package/dist/api/types.d.ts
CHANGED
|
@@ -142,6 +142,9 @@ export interface CreateAvailabilityRequest {
|
|
|
142
142
|
isRecurring?: boolean;
|
|
143
143
|
specificDate?: string;
|
|
144
144
|
}
|
|
145
|
+
export type GatheringTypeResponse = components['schemas']['GatheringTypeResponseDto'];
|
|
146
|
+
export type CreateGatheringTypeRequest = components['schemas']['CreateGatheringTypeDto'];
|
|
147
|
+
export type UpdateGatheringTypeRequest = components['schemas']['UpdateGatheringTypeDto'];
|
|
145
148
|
export type BrandResponse = components['schemas']['BrandResponseDto'];
|
|
146
149
|
export type BrandOwnerResponse = components['schemas']['BrandOwnerResponseDto'];
|
|
147
150
|
export type BrandCreatorResponse = components['schemas']['BrandCreatorResponseDto'];
|
package/dist/api/types.js
CHANGED
|
@@ -11,4 +11,4 @@
|
|
|
11
11
|
* 3. Rebuild SDK: npm run build
|
|
12
12
|
*/
|
|
13
13
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/api/types.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;GAUG","sourcesContent":["/**\n * GrowSober SDK Types\n *\n * All types are derived from the @growsober/types package which is auto-generated\n * from the API OpenAPI specification. This ensures single source of truth from Prisma.\n *\n * To regenerate types:\n * 1. Start the API: cd ../growsober-api && npm run start:dev\n * 2. Generate types: cd ../growsober-types && npm run generate && npm run build\n * 3. Rebuild SDK: npm run build\n */\n\nimport type { paths, components } from '@growsober/types';\n\n// ============================================================================\n// TYPE EXTRACTION HELPERS\n// ============================================================================\n\n/**\n * Extract request body type for a given endpoint and method\n */\nexport type RequestBody<\n  Path extends keyof paths,\n  Method extends keyof paths[Path]\n> = paths[Path][Method] extends { requestBody: { content: { 'application/json': infer T } } }\n  ? T\n  : never;\n\n/**\n * Extract response type for a given endpoint, method, and status code\n */\nexport type ResponseBody<\n  Path extends keyof paths,\n  Method extends keyof paths[Path],\n  Status extends number = 200\n> = paths[Path][Method] extends { responses: { [K in Status]: { content: { 'application/json': infer T } } } }\n  ? T\n  : never;\n\n/**\n * Extract query parameters type for a given endpoint and method\n */\nexport type QueryParams<\n  Path extends keyof paths,\n  Method extends keyof paths[Path]\n> = paths[Path][Method] extends { parameters: { query?: infer Q } }\n  ? Q\n  : Record<string, never>;\n\n/**\n * Extract path parameters type for a given endpoint and method\n */\nexport type PathParams<\n  Path extends keyof paths,\n  Method extends keyof paths[Path]\n> = paths[Path][Method] extends { parameters: { path: infer P } }\n  ? P\n  : Record<string, never>;\n\n// ============================================================================\n// ENUM TYPES (extracted from generated schemas - single source of truth)\n// ============================================================================\n\n// Business/Venue type (used for both Business and Venue models)\nexport type BusinessType = components['schemas']['BusinessResponseDto']['type'];\n\n// Ownership roles\nexport type VenueOwnerRole = components['schemas']['VenueOwnerResponseDto']['role'];\nexport type BrandOwnerRole = components['schemas']['BrandOwnerResponseDto']['role'];\n\n// Event types\nexport type GatheringType = NonNullable<components['schemas']['EventResponseDto']['gatheringType']>;\nexport type EventVisibility = components['schemas']['EventResponseDto']['visibility'];\nexport type EventStatus = components['schemas']['EventResponseDto']['status'];\n\n// Chat roles\nexport type ChatMemberRole = components['schemas']['ChatMemberResponseDto']['role'];\n\n// Content status\nexport type ContentStatus = components['schemas']['LibraryContentResponseDto']['contentStatus'];\n\n// Badge types\nexport type BadgeType = components['schemas']['BadgeResponseDto']['type'];\n\n// Notification types\nexport type NotificationType = components['schemas']['NotificationResponseDto']['type'];\n\n// Streak types\nexport type StreakType = components['schemas']['StreakResponseDto']['type'];\n\n// Craving triggers\nexport type CravingTrigger = NonNullable<components['schemas']['CravingLogResponseDto']['triggerType']>;\n\n// ============================================================================\n// AUTH TYPES\n// ============================================================================\n\nexport type RegisterRequest = components['schemas']['RegisterDto'];\nexport type AuthResponse = components['schemas']['AuthResponseDto'];\nexport type LoginRequest = components['schemas']['LoginDto'];\nexport type RefreshTokenRequest = components['schemas']['RefreshTokenDto'];\nexport type TokenResponse = components['schemas']['TokenResponseDto'];\nexport type FirebaseAuthRequest = components['schemas']['FirebaseAuthDto'];\nexport type SendOtpRequest = components['schemas']['SendOtpDto'];\nexport type OtpSentResponse = components['schemas']['OtpSentResponseDto'];\nexport type VerifyOtpRequest = components['schemas']['VerifyOtpDto'];\n\n// ============================================================================\n// USER TYPES\n// ============================================================================\n\nexport type UserResponse = components['schemas']['UserResponseDto'];\nexport type UserPublicResponse = components['schemas']['UserPublicResponseDto'];\nexport type CreateUserRequest = components['schemas']['CreateUserDto'];\nexport type UpdateUserRequest = components['schemas']['UpdateUserDto'];\n\n// ============================================================================\n// HUB TYPES\n// ============================================================================\n\nexport type HubResponse = components['schemas']['HubResponseDto'];\nexport type CreateHubRequest = components['schemas']['CreateHubDto'];\nexport type UpdateHubRequest = components['schemas']['UpdateHubDto'];\n\n// ============================================================================\n// EVENT TYPES\n// ============================================================================\n\nexport type EventResponse = components['schemas']['EventResponseDto'];\nexport type CreateEventRequest = components['schemas']['CreateEventDto'];\nexport type UpdateEventRequest = components['schemas']['UpdateEventDto'];\n\n// ============================================================================\n// BOOKING TYPES\n// ============================================================================\n\nexport type BookingResponse = components['schemas']['BookingResponseDto'];\nexport type CreateBookingRequest = components['schemas']['CreateBookingDto'];\n\n// ============================================================================\n// LIBRARY TYPES\n// ============================================================================\n\nexport type LibraryContentResponse = components['schemas']['LibraryContentResponseDto'];\nexport type LibraryContentDetailResponse = components['schemas']['LibraryContentDetailResponseDto'];\nexport type LibraryProgressResponse = components['schemas']['LibraryProgressResponseDto'];\nexport type ContentType = components['schemas']['LibraryContentResponseDto']['type'];\n\n// ============================================================================\n// BUSINESS & OFFER TYPES (Legacy)\n// ============================================================================\n\nexport type BusinessResponse = components['schemas']['BusinessResponseDto'];\nexport type OfferResponse = components['schemas']['OfferResponseDto'];\nexport type RedeemOfferRequest = components['schemas']['RedeemOfferDto'];\n\n// ============================================================================\n// VENUE TYPES (from generated OpenAPI types)\n// ============================================================================\n\nexport type VenueResponse = components['schemas']['VenueResponseDto'];\nexport type VenueOwnerResponse = components['schemas']['VenueOwnerResponseDto'];\n\n// Request types for venue operations\nexport interface CreateVenueRequest {\n  name: string;\n  slug: string;\n  description?: string;\n  type: BusinessType;\n  hasAfDrinks?: boolean;\n  isAfVenue?: boolean;\n  afHighlights?: string[];\n  address?: string;\n  cityId?: string;\n  locationLat?: number;\n  locationLong?: number;\n  phone?: string;\n  email?: string;\n  website?: string;\n  instagram?: string;\n  profileImage?: string;\n  bannerImage?: string;\n  photos?: string[];\n  openingHours?: Record<string, string>;\n}\n\nexport interface UpdateVenueRequest extends Partial<CreateVenueRequest> {}\n\nexport interface AddVenueOwnerRequest {\n  userId: string;\n  role: VenueOwnerRole;\n}\n\n// ============================================================================\n// CREATOR TYPES (from generated OpenAPI types)\n// ============================================================================\n\nexport type CreatorResponse = components['schemas']['CreatorResponseDto'];\nexport type CreatorAvailabilityResponse = components['schemas']['CreatorAvailabilityResponseDto'];\n\nexport interface CreateCreatorRequest {\n  slug: string;\n  displayName: string;\n  bio?: string;\n  avatarUrl?: string;\n  cityIds?: string[];\n  canFacilitate?: boolean;\n  canCreateContent?: boolean;\n  isInfluencer?: boolean;\n  specialties?: string[];\n  certifications?: string[];\n  sessionRate?: number;\n}\n\nexport interface UpdateCreatorRequest extends Partial<CreateCreatorRequest> {}\n\nexport interface CreateAvailabilityRequest {\n  dayOfWeek?: number;\n  startTime: string;\n  endTime: string;\n  timezone: string;\n  isRecurring?: boolean;\n  specificDate?: string;\n}\n\n// ============================================================================\n// BRAND TYPES (from generated OpenAPI types)\n// ============================================================================\n\nexport type BrandResponse = components['schemas']['BrandResponseDto'];\nexport type BrandOwnerResponse = components['schemas']['BrandOwnerResponseDto'];\nexport type BrandCreatorResponse = components['schemas']['BrandCreatorResponseDto'];\n\nexport interface CreateBrandRequest {\n  slug: string;\n  name: string;\n  description?: string;\n  logoUrl?: string;\n  bannerUrl?: string;\n  primaryColor?: string;\n  website?: string;\n  email?: string;\n  instagram?: string;\n}\n\nexport interface UpdateBrandRequest extends Partial<CreateBrandRequest> {}\n\nexport interface AddBrandOwnerRequest {\n  userId: string;\n  role: BrandOwnerRole;\n}\n\nexport interface AddBrandCreatorRequest {\n  creatorId: string;\n  commissionRate?: number;\n  isActive?: boolean;\n  startDate?: string;\n  endDate?: string;\n}\n\n// ============================================================================\n// SUBSCRIPTION TYPES\n// ============================================================================\n\nexport type SubscriptionResponse = components['schemas']['SubscriptionResponseDto'];\nexport type CreateCheckoutRequest = components['schemas']['CreateCheckoutDto'];\n\n// ============================================================================\n// NOTIFICATION TYPES\n// ============================================================================\n\nexport type NotificationResponse = components['schemas']['NotificationResponseDto'];\n\n// ============================================================================\n// DEVICE TOKEN TYPES\n// ============================================================================\n\nexport type RegisterDeviceTokenRequest = components['schemas']['RegisterDeviceDto'];\n\n// ============================================================================\n// SUPPORT TYPES\n// ============================================================================\n\n// Check-ins\nexport type CheckInResponse = components['schemas']['CheckInResponseDto'];\nexport type CreateCheckInRequest = components['schemas']['CreateCheckInDto'];\nexport type UpdateCheckInRequest = components['schemas']['UpdateCheckInDto'];\nexport type CheckInStreakResponse = components['schemas']['CheckInStreakDto'];\n\n// Wins\nexport type WinResponse = components['schemas']['WinResponseDto'];\nexport type CreateWinRequest = components['schemas']['CreateWinDto'];\nexport type WinCountResponse = components['schemas']['WinCountDto'];\n\n// Jack AI Conversations\nexport type ConversationResponse = components['schemas']['ConversationResponseDto'];\nexport type ConversationWithMessagesResponse = components['schemas']['JackConversationWithMessagesDto'];\nexport type CreateConversationRequest = components['schemas']['CreateConversationDto'];\nexport type JackMessageResponse = components['schemas']['JackMessageResponseDto'];\nexport type SendJackMessageRequest = components['schemas']['SendJackMessageDto'];\n\n// Mood Logs\nexport type MoodLogResponse = components['schemas']['MoodLogResponseDto'];\nexport type LogMoodRequest = components['schemas']['LogMoodDto'];\nexport type MoodStatsResponse = components['schemas']['MoodStatsDto'];\n\n// Habits\nexport type HabitResponse = components['schemas']['HabitResponseDto'];\nexport type CreateHabitRequest = components['schemas']['CreateHabitDto'];\nexport type UpdateHabitRequest = components['schemas']['UpdateHabitDto'];\nexport type CompleteHabitRequest = components['schemas']['CompleteHabitDto'];\nexport type HabitCompletionResponse = components['schemas']['HabitCompletionResponseDto'];\n\n// Reflections\nexport type ReflectionResponse = components['schemas']['ReflectionResponseDto'];\nexport type CreateReflectionRequest = components['schemas']['CreateReflectionDto'];\nexport type UpdateReflectionRequest = components['schemas']['UpdateReflectionDto'];\n\n// Cravings\nexport type CravingLogResponse = components['schemas']['CravingLogResponseDto'];\nexport type LogCravingRequest = components['schemas']['LogCravingDto'];\nexport type CravingStatsResponse = components['schemas']['CravingStatsDto'];\n\n// ============================================================================\n// MAP TYPES\n// ============================================================================\n\nexport type MapMemberResponse = components['schemas']['MapMemberDto'];\nexport type MapHubResponse = components['schemas']['MapHubDto'];\nexport type MapEventResponse = components['schemas']['MapEventDto'];\n\n// ============================================================================\n// AMBASSADOR TYPES\n// ============================================================================\n\nexport type AmbassadorResponse = components['schemas']['AmbassadorResponseDto'];\nexport type ApplyAmbassadorRequest = components['schemas']['ApplyAmbassadorDto'];\nexport type UpdateAmbassadorRequest = components['schemas']['UpdateAmbassadorDto'];\n\n// ============================================================================\n// GROW90 TYPES\n// ============================================================================\n\nexport type Grow90EnrollmentResponse = components['schemas']['Grow90EnrollmentResponseDto'];\nexport type Grow90ProgressResponse = components['schemas']['Grow90ProgressResponseDto'];\nexport type Grow90TodayResponse = components['schemas']['Grow90TodayResponseDto'];\nexport type Grow90StatsResponse = components['schemas']['Grow90StatsResponseDto'];\nexport type EnrollGrow90Request = components['schemas']['EnrollGrow90Dto'];\nexport type UpdateGrow90ProgressRequest = components['schemas']['UpdateProgressDto'];\nexport type UpdateGrow90SettingsRequest = components['schemas']['UpdateSettingsDto'];\n\n// ============================================================================\n// MATCHING TYPES\n// ============================================================================\n\nexport type CreateMatchRequest = components['schemas']['CreateMatchDto'];\nexport type UpdateMatchRequest = components['schemas']['UpdateMatchDto'];\nexport type CreateBuddyRequest = components['schemas']['CreateBuddyRequestDto'];\nexport type UpdateBuddyRequest = components['schemas']['UpdateBuddyDto'];\nexport type LogBuddyActivityRequest = components['schemas']['LogBuddyActivityDto'];\n\n// ============================================================================\n// EVENT CHAT TYPES\n// ============================================================================\n\nexport type EventChatResponse = components['schemas']['EventChatResponseDto'];\nexport type ChatMemberResponse = components['schemas']['ChatMemberResponseDto'];\nexport type ChatMessageResponse = components['schemas']['EventChatMessageResponseDto'];\nexport type PaginatedMessagesResponse = components['schemas']['PaginatedEventChatMessagesDto'];\nexport type SendChatMessageRequest = components['schemas']['SendEventChatMessageDto'];\nexport type UpdateChatMessageRequest = components['schemas']['UpdateEventChatMessageDto'];\nexport type UpdateChatSettingsRequest = components['schemas']['UpdateChatSettingsDto'];\nexport type UpdateMemberSettingsRequest = components['schemas']['UpdateMemberSettingsDto'];\n\n// ============================================================================\n// ADMIN TYPES\n// ============================================================================\n\nexport type AdminLoginRequest = components['schemas']['AdminLoginDto'];\nexport type AdminTokensResponse = components['schemas']['AdminTokensDto'];\nexport type AdminUpdateUserRequest = components['schemas']['AdminUpdateUserDto'];\nexport type AdminCreateHubRequest = components['schemas']['AdminCreateHubDto'];\nexport type AdminUpdateEventRequest = components['schemas']['AdminUpdateEventDto'];\nexport type AdminCreateContentRequest = components['schemas']['AdminCreateContentDto'];\nexport type AdminCreateBusinessRequest = components['schemas']['AdminCreateBusinessDto'];\nexport type AdminOverviewStatsResponse = components['schemas']['AdminOverviewStatsDto'];\n\n// ============================================================================\n// BADGE TYPES (from generated OpenAPI types)\n// ============================================================================\n\nexport type BadgeResponse = components['schemas']['BadgeResponseDto'];\nexport type UserBadgeResponse = components['schemas']['UserBadgeResponseDto'];\nexport type BadgeProgressResponse = components['schemas']['BadgeProgressDto'];\n\n// Alias for SDK consistency\nexport interface BadgeWithProgress {\n  badge: BadgeResponse;\n  currentProgress: number;\n  requiredProgress: number;\n  percentComplete: number;\n  isEarned: boolean;\n}\n\n// ============================================================================\n// UNIFIED REWARD TYPES\n// ============================================================================\n\n// RedeemType enum - extracted from Prisma via API\nexport type RedeemType = 'IN_PERSON' | 'ONLINE' | 'BOTH';\n\n// Reward response with relations\nexport interface RewardResponse {\n  id: string;\n  venueId: string | null;\n  brandId: string | null;\n  badgeId: string;\n  title: string;\n  description: string | null;\n  code: string | null;\n  redeemType: RedeemType;\n  maxRedemptions: number | null;\n  redemptionsUsed: number;\n  perUserLimit: number;\n  validFrom: string | null;\n  validUntil: string | null;\n  isActive: boolean;\n  createdAt: string;\n  badge: {\n    id: string;\n    name: string;\n    slug: string;\n    icon: string | null;\n  };\n  venue?: {\n    id: string;\n    name: string;\n    slug: string;\n    profileImage: string | null;\n    address: string | null;\n  } | null;\n  brand?: {\n    id: string;\n    name: string;\n    slug: string;\n    logoUrl: string | null;\n  } | null;\n}\n\nexport interface RewardRedemptionResponse {\n  id: string;\n  userId: string;\n  rewardId: string;\n  redeemedAt: string;\n  verifiedAt: string | null;\n  verifiedBy: string | null;\n  codeUsed: string | null;\n  reward: RewardResponse;\n}\n\nexport interface CreateRewardRequest {\n  badgeId: string;\n  title: string;\n  description?: string;\n  code?: string;\n  redeemType?: RedeemType;\n  maxRedemptions?: number;\n  perUserLimit?: number;\n  validFrom?: string;\n  validUntil?: string;\n}\n\nexport interface UpdateRewardRequest {\n  title?: string;\n  description?: string;\n  code?: string;\n  redeemType?: RedeemType;\n  maxRedemptions?: number;\n  perUserLimit?: number;\n  validFrom?: string;\n  validUntil?: string;\n  isActive?: boolean;\n}\n\nexport interface UserWalletResponse {\n  badges: Array<{\n    id: string;\n    badgeId: string;\n    userId: string;\n    awardedAt: string;\n    badge: BadgeResponse;\n    availableRewards: RewardResponse[];\n    redeemedRewards: Array<RewardRedemptionResponse & { qrToken: string }>;\n  }>;\n  stats: {\n    totalBadges: number;\n    totalAvailableRewards: number;\n    totalRedeemedRewards: number;\n  };\n}\n\n// ============================================================================\n// LEGACY TYPES (deprecated - use unified types)\n// ============================================================================\n\n/** @deprecated Use RewardResponse instead */\nexport interface PartnerRewardResponse {\n  id: string;\n  businessId: string;\n  badgeId: string;\n  title: string;\n  description: string | null;\n  code: string | null;\n  maxRedemptions: number | null;\n  redemptionsUsed: number;\n  perUserLimit: number;\n  validFrom: string;\n  validUntil: string | null;\n  isActive: boolean;\n  createdAt: string;\n  badge: {\n    id: string;\n    name: string;\n    slug: string;\n    icon: string | null;\n  };\n  business: {\n    id: string;\n    name: string;\n    profileImage: string | null;\n  };\n}\n\n/** @deprecated Use RewardRedemptionResponse instead */\nexport interface PartnerRewardRedemptionResponse {\n  id: string;\n  userId: string;\n  partnerRewardId: string;\n  redeemedAt: string;\n  verifiedAt: string | null;\n  partnerReward: PartnerRewardResponse;\n}\n\n/** @deprecated Use CreateRewardRequest instead */\nexport interface CreatePartnerRewardRequest {\n  badgeId: string;\n  title: string;\n  description?: string;\n  code?: string;\n  maxRedemptions?: number;\n  perUserLimit?: number;\n  validUntil?: string;\n}\n\n// ============================================================================\n// RE-EXPORTS\n// ============================================================================\n\n// Re-export paths and components for advanced usage\nexport type { paths, components };\n"]}
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/api/types.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;GAUG","sourcesContent":["/**\n * GrowSober SDK Types\n *\n * All types are derived from the @growsober/types package which is auto-generated\n * from the API OpenAPI specification. This ensures single source of truth from Prisma.\n *\n * To regenerate types:\n * 1. Start the API: cd ../growsober-api && npm run start:dev\n * 2. Generate types: cd ../growsober-types && npm run generate && npm run build\n * 3. Rebuild SDK: npm run build\n */\n\nimport type { paths, components } from '@growsober/types';\n\n// ============================================================================\n// TYPE EXTRACTION HELPERS\n// ============================================================================\n\n/**\n * Extract request body type for a given endpoint and method\n */\nexport type RequestBody<\n  Path extends keyof paths,\n  Method extends keyof paths[Path]\n> = paths[Path][Method] extends { requestBody: { content: { 'application/json': infer T } } }\n  ? T\n  : never;\n\n/**\n * Extract response type for a given endpoint, method, and status code\n */\nexport type ResponseBody<\n  Path extends keyof paths,\n  Method extends keyof paths[Path],\n  Status extends number = 200\n> = paths[Path][Method] extends { responses: { [K in Status]: { content: { 'application/json': infer T } } } }\n  ? T\n  : never;\n\n/**\n * Extract query parameters type for a given endpoint and method\n */\nexport type QueryParams<\n  Path extends keyof paths,\n  Method extends keyof paths[Path]\n> = paths[Path][Method] extends { parameters: { query?: infer Q } }\n  ? Q\n  : Record<string, never>;\n\n/**\n * Extract path parameters type for a given endpoint and method\n */\nexport type PathParams<\n  Path extends keyof paths,\n  Method extends keyof paths[Path]\n> = paths[Path][Method] extends { parameters: { path: infer P } }\n  ? P\n  : Record<string, never>;\n\n// ============================================================================\n// ENUM TYPES (extracted from generated schemas - single source of truth)\n// ============================================================================\n\n// Business/Venue type (used for both Business and Venue models)\nexport type BusinessType = components['schemas']['BusinessResponseDto']['type'];\n\n// Ownership roles\nexport type VenueOwnerRole = components['schemas']['VenueOwnerResponseDto']['role'];\nexport type BrandOwnerRole = components['schemas']['BrandOwnerResponseDto']['role'];\n\n// Event types\nexport type GatheringType = NonNullable<components['schemas']['EventResponseDto']['gatheringType']>;\nexport type EventVisibility = components['schemas']['EventResponseDto']['visibility'];\nexport type EventStatus = components['schemas']['EventResponseDto']['status'];\n\n// Chat roles\nexport type ChatMemberRole = components['schemas']['ChatMemberResponseDto']['role'];\n\n// Content status\nexport type ContentStatus = components['schemas']['LibraryContentResponseDto']['contentStatus'];\n\n// Badge types\nexport type BadgeType = components['schemas']['BadgeResponseDto']['type'];\n\n// Notification types\nexport type NotificationType = components['schemas']['NotificationResponseDto']['type'];\n\n// Streak types\nexport type StreakType = components['schemas']['StreakResponseDto']['type'];\n\n// Craving triggers\nexport type CravingTrigger = NonNullable<components['schemas']['CravingLogResponseDto']['triggerType']>;\n\n// ============================================================================\n// AUTH TYPES\n// ============================================================================\n\nexport type RegisterRequest = components['schemas']['RegisterDto'];\nexport type AuthResponse = components['schemas']['AuthResponseDto'];\nexport type LoginRequest = components['schemas']['LoginDto'];\nexport type RefreshTokenRequest = components['schemas']['RefreshTokenDto'];\nexport type TokenResponse = components['schemas']['TokenResponseDto'];\nexport type FirebaseAuthRequest = components['schemas']['FirebaseAuthDto'];\nexport type SendOtpRequest = components['schemas']['SendOtpDto'];\nexport type OtpSentResponse = components['schemas']['OtpSentResponseDto'];\nexport type VerifyOtpRequest = components['schemas']['VerifyOtpDto'];\n\n// ============================================================================\n// USER TYPES\n// ============================================================================\n\nexport type UserResponse = components['schemas']['UserResponseDto'];\nexport type UserPublicResponse = components['schemas']['UserPublicResponseDto'];\nexport type CreateUserRequest = components['schemas']['CreateUserDto'];\nexport type UpdateUserRequest = components['schemas']['UpdateUserDto'];\n\n// ============================================================================\n// HUB TYPES\n// ============================================================================\n\nexport type HubResponse = components['schemas']['HubResponseDto'];\nexport type CreateHubRequest = components['schemas']['CreateHubDto'];\nexport type UpdateHubRequest = components['schemas']['UpdateHubDto'];\n\n// ============================================================================\n// EVENT TYPES\n// ============================================================================\n\nexport type EventResponse = components['schemas']['EventResponseDto'];\nexport type CreateEventRequest = components['schemas']['CreateEventDto'];\nexport type UpdateEventRequest = components['schemas']['UpdateEventDto'];\n\n// ============================================================================\n// BOOKING TYPES\n// ============================================================================\n\nexport type BookingResponse = components['schemas']['BookingResponseDto'];\nexport type CreateBookingRequest = components['schemas']['CreateBookingDto'];\n\n// ============================================================================\n// LIBRARY TYPES\n// ============================================================================\n\nexport type LibraryContentResponse = components['schemas']['LibraryContentResponseDto'];\nexport type LibraryContentDetailResponse = components['schemas']['LibraryContentDetailResponseDto'];\nexport type LibraryProgressResponse = components['schemas']['LibraryProgressResponseDto'];\nexport type ContentType = components['schemas']['LibraryContentResponseDto']['type'];\n\n// ============================================================================\n// BUSINESS & OFFER TYPES (Legacy)\n// ============================================================================\n\nexport type BusinessResponse = components['schemas']['BusinessResponseDto'];\nexport type OfferResponse = components['schemas']['OfferResponseDto'];\nexport type RedeemOfferRequest = components['schemas']['RedeemOfferDto'];\n\n// ============================================================================\n// VENUE TYPES (from generated OpenAPI types)\n// ============================================================================\n\nexport type VenueResponse = components['schemas']['VenueResponseDto'];\nexport type VenueOwnerResponse = components['schemas']['VenueOwnerResponseDto'];\n\n// Request types for venue operations\nexport interface CreateVenueRequest {\n  name: string;\n  slug: string;\n  description?: string;\n  type: BusinessType;\n  hasAfDrinks?: boolean;\n  isAfVenue?: boolean;\n  afHighlights?: string[];\n  address?: string;\n  cityId?: string;\n  locationLat?: number;\n  locationLong?: number;\n  phone?: string;\n  email?: string;\n  website?: string;\n  instagram?: string;\n  profileImage?: string;\n  bannerImage?: string;\n  photos?: string[];\n  openingHours?: Record<string, string>;\n}\n\nexport interface UpdateVenueRequest extends Partial<CreateVenueRequest> {}\n\nexport interface AddVenueOwnerRequest {\n  userId: string;\n  role: VenueOwnerRole;\n}\n\n// ============================================================================\n// CREATOR TYPES (from generated OpenAPI types)\n// ============================================================================\n\nexport type CreatorResponse = components['schemas']['CreatorResponseDto'];\nexport type CreatorAvailabilityResponse = components['schemas']['CreatorAvailabilityResponseDto'];\n\nexport interface CreateCreatorRequest {\n  slug: string;\n  displayName: string;\n  bio?: string;\n  avatarUrl?: string;\n  cityIds?: string[];\n  canFacilitate?: boolean;\n  canCreateContent?: boolean;\n  isInfluencer?: boolean;\n  specialties?: string[];\n  certifications?: string[];\n  sessionRate?: number;\n}\n\nexport interface UpdateCreatorRequest extends Partial<CreateCreatorRequest> {}\n\nexport interface CreateAvailabilityRequest {\n  dayOfWeek?: number;\n  startTime: string;\n  endTime: string;\n  timezone: string;\n  isRecurring?: boolean;\n  specificDate?: string;\n}\n\n// ============================================================================\n// GATHERING TYPE TEMPLATES (for facilitator event types)\n// ============================================================================\n\nexport type GatheringTypeResponse = components['schemas']['GatheringTypeResponseDto'];\nexport type CreateGatheringTypeRequest = components['schemas']['CreateGatheringTypeDto'];\nexport type UpdateGatheringTypeRequest = components['schemas']['UpdateGatheringTypeDto'];\n\n// ============================================================================\n// BRAND TYPES (from generated OpenAPI types)\n// ============================================================================\n\nexport type BrandResponse = components['schemas']['BrandResponseDto'];\nexport type BrandOwnerResponse = components['schemas']['BrandOwnerResponseDto'];\nexport type BrandCreatorResponse = components['schemas']['BrandCreatorResponseDto'];\n\nexport interface CreateBrandRequest {\n  slug: string;\n  name: string;\n  description?: string;\n  logoUrl?: string;\n  bannerUrl?: string;\n  primaryColor?: string;\n  website?: string;\n  email?: string;\n  instagram?: string;\n}\n\nexport interface UpdateBrandRequest extends Partial<CreateBrandRequest> {}\n\nexport interface AddBrandOwnerRequest {\n  userId: string;\n  role: BrandOwnerRole;\n}\n\nexport interface AddBrandCreatorRequest {\n  creatorId: string;\n  commissionRate?: number;\n  isActive?: boolean;\n  startDate?: string;\n  endDate?: string;\n}\n\n// ============================================================================\n// SUBSCRIPTION TYPES\n// ============================================================================\n\nexport type SubscriptionResponse = components['schemas']['SubscriptionResponseDto'];\nexport type CreateCheckoutRequest = components['schemas']['CreateCheckoutDto'];\n\n// ============================================================================\n// NOTIFICATION TYPES\n// ============================================================================\n\nexport type NotificationResponse = components['schemas']['NotificationResponseDto'];\n\n// ============================================================================\n// DEVICE TOKEN TYPES\n// ============================================================================\n\nexport type RegisterDeviceTokenRequest = components['schemas']['RegisterDeviceDto'];\n\n// ============================================================================\n// SUPPORT TYPES\n// ============================================================================\n\n// Check-ins\nexport type CheckInResponse = components['schemas']['CheckInResponseDto'];\nexport type CreateCheckInRequest = components['schemas']['CreateCheckInDto'];\nexport type UpdateCheckInRequest = components['schemas']['UpdateCheckInDto'];\nexport type CheckInStreakResponse = components['schemas']['CheckInStreakDto'];\n\n// Wins\nexport type WinResponse = components['schemas']['WinResponseDto'];\nexport type CreateWinRequest = components['schemas']['CreateWinDto'];\nexport type WinCountResponse = components['schemas']['WinCountDto'];\n\n// Jack AI Conversations\nexport type ConversationResponse = components['schemas']['ConversationResponseDto'];\nexport type ConversationWithMessagesResponse = components['schemas']['JackConversationWithMessagesDto'];\nexport type CreateConversationRequest = components['schemas']['CreateConversationDto'];\nexport type JackMessageResponse = components['schemas']['JackMessageResponseDto'];\nexport type SendJackMessageRequest = components['schemas']['SendJackMessageDto'];\n\n// Mood Logs\nexport type MoodLogResponse = components['schemas']['MoodLogResponseDto'];\nexport type LogMoodRequest = components['schemas']['LogMoodDto'];\nexport type MoodStatsResponse = components['schemas']['MoodStatsDto'];\n\n// Habits\nexport type HabitResponse = components['schemas']['HabitResponseDto'];\nexport type CreateHabitRequest = components['schemas']['CreateHabitDto'];\nexport type UpdateHabitRequest = components['schemas']['UpdateHabitDto'];\nexport type CompleteHabitRequest = components['schemas']['CompleteHabitDto'];\nexport type HabitCompletionResponse = components['schemas']['HabitCompletionResponseDto'];\n\n// Reflections\nexport type ReflectionResponse = components['schemas']['ReflectionResponseDto'];\nexport type CreateReflectionRequest = components['schemas']['CreateReflectionDto'];\nexport type UpdateReflectionRequest = components['schemas']['UpdateReflectionDto'];\n\n// Cravings\nexport type CravingLogResponse = components['schemas']['CravingLogResponseDto'];\nexport type LogCravingRequest = components['schemas']['LogCravingDto'];\nexport type CravingStatsResponse = components['schemas']['CravingStatsDto'];\n\n// ============================================================================\n// MAP TYPES\n// ============================================================================\n\nexport type MapMemberResponse = components['schemas']['MapMemberDto'];\nexport type MapHubResponse = components['schemas']['MapHubDto'];\nexport type MapEventResponse = components['schemas']['MapEventDto'];\n\n// ============================================================================\n// AMBASSADOR TYPES\n// ============================================================================\n\nexport type AmbassadorResponse = components['schemas']['AmbassadorResponseDto'];\nexport type ApplyAmbassadorRequest = components['schemas']['ApplyAmbassadorDto'];\nexport type UpdateAmbassadorRequest = components['schemas']['UpdateAmbassadorDto'];\n\n// ============================================================================\n// GROW90 TYPES\n// ============================================================================\n\nexport type Grow90EnrollmentResponse = components['schemas']['Grow90EnrollmentResponseDto'];\nexport type Grow90ProgressResponse = components['schemas']['Grow90ProgressResponseDto'];\nexport type Grow90TodayResponse = components['schemas']['Grow90TodayResponseDto'];\nexport type Grow90StatsResponse = components['schemas']['Grow90StatsResponseDto'];\nexport type EnrollGrow90Request = components['schemas']['EnrollGrow90Dto'];\nexport type UpdateGrow90ProgressRequest = components['schemas']['UpdateProgressDto'];\nexport type UpdateGrow90SettingsRequest = components['schemas']['UpdateSettingsDto'];\n\n// ============================================================================\n// MATCHING TYPES\n// ============================================================================\n\nexport type CreateMatchRequest = components['schemas']['CreateMatchDto'];\nexport type UpdateMatchRequest = components['schemas']['UpdateMatchDto'];\nexport type CreateBuddyRequest = components['schemas']['CreateBuddyRequestDto'];\nexport type UpdateBuddyRequest = components['schemas']['UpdateBuddyDto'];\nexport type LogBuddyActivityRequest = components['schemas']['LogBuddyActivityDto'];\n\n// ============================================================================\n// EVENT CHAT TYPES\n// ============================================================================\n\nexport type EventChatResponse = components['schemas']['EventChatResponseDto'];\nexport type ChatMemberResponse = components['schemas']['ChatMemberResponseDto'];\nexport type ChatMessageResponse = components['schemas']['EventChatMessageResponseDto'];\nexport type PaginatedMessagesResponse = components['schemas']['PaginatedEventChatMessagesDto'];\nexport type SendChatMessageRequest = components['schemas']['SendEventChatMessageDto'];\nexport type UpdateChatMessageRequest = components['schemas']['UpdateEventChatMessageDto'];\nexport type UpdateChatSettingsRequest = components['schemas']['UpdateChatSettingsDto'];\nexport type UpdateMemberSettingsRequest = components['schemas']['UpdateMemberSettingsDto'];\n\n// ============================================================================\n// ADMIN TYPES\n// ============================================================================\n\nexport type AdminLoginRequest = components['schemas']['AdminLoginDto'];\nexport type AdminTokensResponse = components['schemas']['AdminTokensDto'];\nexport type AdminUpdateUserRequest = components['schemas']['AdminUpdateUserDto'];\nexport type AdminCreateHubRequest = components['schemas']['AdminCreateHubDto'];\nexport type AdminUpdateEventRequest = components['schemas']['AdminUpdateEventDto'];\nexport type AdminCreateContentRequest = components['schemas']['AdminCreateContentDto'];\nexport type AdminCreateBusinessRequest = components['schemas']['AdminCreateBusinessDto'];\nexport type AdminOverviewStatsResponse = components['schemas']['AdminOverviewStatsDto'];\n\n// ============================================================================\n// BADGE TYPES (from generated OpenAPI types)\n// ============================================================================\n\nexport type BadgeResponse = components['schemas']['BadgeResponseDto'];\nexport type UserBadgeResponse = components['schemas']['UserBadgeResponseDto'];\nexport type BadgeProgressResponse = components['schemas']['BadgeProgressDto'];\n\n// Alias for SDK consistency\nexport interface BadgeWithProgress {\n  badge: BadgeResponse;\n  currentProgress: number;\n  requiredProgress: number;\n  percentComplete: number;\n  isEarned: boolean;\n}\n\n// ============================================================================\n// UNIFIED REWARD TYPES\n// ============================================================================\n\n// RedeemType enum - extracted from Prisma via API\nexport type RedeemType = 'IN_PERSON' | 'ONLINE' | 'BOTH';\n\n// Reward response with relations\nexport interface RewardResponse {\n  id: string;\n  venueId: string | null;\n  brandId: string | null;\n  badgeId: string;\n  title: string;\n  description: string | null;\n  code: string | null;\n  redeemType: RedeemType;\n  maxRedemptions: number | null;\n  redemptionsUsed: number;\n  perUserLimit: number;\n  validFrom: string | null;\n  validUntil: string | null;\n  isActive: boolean;\n  createdAt: string;\n  badge: {\n    id: string;\n    name: string;\n    slug: string;\n    icon: string | null;\n  };\n  venue?: {\n    id: string;\n    name: string;\n    slug: string;\n    profileImage: string | null;\n    address: string | null;\n  } | null;\n  brand?: {\n    id: string;\n    name: string;\n    slug: string;\n    logoUrl: string | null;\n  } | null;\n}\n\nexport interface RewardRedemptionResponse {\n  id: string;\n  userId: string;\n  rewardId: string;\n  redeemedAt: string;\n  verifiedAt: string | null;\n  verifiedBy: string | null;\n  codeUsed: string | null;\n  reward: RewardResponse;\n}\n\nexport interface CreateRewardRequest {\n  badgeId: string;\n  title: string;\n  description?: string;\n  code?: string;\n  redeemType?: RedeemType;\n  maxRedemptions?: number;\n  perUserLimit?: number;\n  validFrom?: string;\n  validUntil?: string;\n}\n\nexport interface UpdateRewardRequest {\n  title?: string;\n  description?: string;\n  code?: string;\n  redeemType?: RedeemType;\n  maxRedemptions?: number;\n  perUserLimit?: number;\n  validFrom?: string;\n  validUntil?: string;\n  isActive?: boolean;\n}\n\nexport interface UserWalletResponse {\n  badges: Array<{\n    id: string;\n    badgeId: string;\n    userId: string;\n    awardedAt: string;\n    badge: BadgeResponse;\n    availableRewards: RewardResponse[];\n    redeemedRewards: Array<RewardRedemptionResponse & { qrToken: string }>;\n  }>;\n  stats: {\n    totalBadges: number;\n    totalAvailableRewards: number;\n    totalRedeemedRewards: number;\n  };\n}\n\n// ============================================================================\n// LEGACY TYPES (deprecated - use unified types)\n// ============================================================================\n\n/** @deprecated Use RewardResponse instead */\nexport interface PartnerRewardResponse {\n  id: string;\n  businessId: string;\n  badgeId: string;\n  title: string;\n  description: string | null;\n  code: string | null;\n  maxRedemptions: number | null;\n  redemptionsUsed: number;\n  perUserLimit: number;\n  validFrom: string;\n  validUntil: string | null;\n  isActive: boolean;\n  createdAt: string;\n  badge: {\n    id: string;\n    name: string;\n    slug: string;\n    icon: string | null;\n  };\n  business: {\n    id: string;\n    name: string;\n    profileImage: string | null;\n  };\n}\n\n/** @deprecated Use RewardRedemptionResponse instead */\nexport interface PartnerRewardRedemptionResponse {\n  id: string;\n  userId: string;\n  partnerRewardId: string;\n  redeemedAt: string;\n  verifiedAt: string | null;\n  partnerReward: PartnerRewardResponse;\n}\n\n/** @deprecated Use CreateRewardRequest instead */\nexport interface CreatePartnerRewardRequest {\n  badgeId: string;\n  title: string;\n  description?: string;\n  code?: string;\n  maxRedemptions?: number;\n  perUserLimit?: number;\n  validUntil?: string;\n}\n\n// ============================================================================\n// RE-EXPORTS\n// ============================================================================\n\n// Re-export paths and components for advanced usage\nexport type { paths, components };\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@growsober/sdk",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.17",
|
|
4
4
|
"description": "Shared TypeScript SDK for GrowSober API - TanStack Query hooks, API client, and utilities",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"module": "dist/index.js",
|
|
@@ -50,7 +50,7 @@
|
|
|
50
50
|
"zod": "^3.0.0"
|
|
51
51
|
},
|
|
52
52
|
"dependencies": {
|
|
53
|
-
"@growsober/types": "^1.0.
|
|
53
|
+
"@growsober/types": "^1.0.7"
|
|
54
54
|
},
|
|
55
55
|
"devDependencies": {
|
|
56
56
|
"@tanstack/react-query": "^5.90.16",
|
|
@@ -7,6 +7,9 @@ import type {
|
|
|
7
7
|
CreateCreatorRequest,
|
|
8
8
|
UpdateCreatorRequest,
|
|
9
9
|
CreateAvailabilityRequest,
|
|
10
|
+
GatheringTypeResponse,
|
|
11
|
+
CreateGatheringTypeRequest,
|
|
12
|
+
UpdateGatheringTypeRequest,
|
|
10
13
|
} from '../types';
|
|
11
14
|
|
|
12
15
|
// ============================================================================
|
|
@@ -301,3 +304,162 @@ export function useDeleteCreatorReward(
|
|
|
301
304
|
...options,
|
|
302
305
|
});
|
|
303
306
|
}
|
|
307
|
+
|
|
308
|
+
// ============================================================================
|
|
309
|
+
// GATHERING TYPE MUTATIONS
|
|
310
|
+
// ============================================================================
|
|
311
|
+
|
|
312
|
+
/**
|
|
313
|
+
* Create a new gathering type for a creator
|
|
314
|
+
*
|
|
315
|
+
* @param creatorId - Creator ID
|
|
316
|
+
*
|
|
317
|
+
* @example
|
|
318
|
+
* ```tsx
|
|
319
|
+
* const createGatheringType = useCreateGatheringType(creatorId);
|
|
320
|
+
*
|
|
321
|
+
* await createGatheringType.mutateAsync({
|
|
322
|
+
* name: 'Morning Yoga in the Park',
|
|
323
|
+
* description: 'Gentle 45-minute yoga session',
|
|
324
|
+
* duration: 45,
|
|
325
|
+
* vibes: ['Mindful', 'Chill'],
|
|
326
|
+
* category: 'MOVEMENT',
|
|
327
|
+
* });
|
|
328
|
+
* ```
|
|
329
|
+
*/
|
|
330
|
+
export function useCreateGatheringType(creatorId: string) {
|
|
331
|
+
const queryClient = useQueryClient();
|
|
332
|
+
|
|
333
|
+
return useMutation({
|
|
334
|
+
mutationFn: async (data: CreateGatheringTypeRequest): Promise<GatheringTypeResponse> => {
|
|
335
|
+
const client = getApiClient();
|
|
336
|
+
const response = await client.post(`/api/v1/creators/${creatorId}/gathering-types`, data);
|
|
337
|
+
return response.data;
|
|
338
|
+
},
|
|
339
|
+
onSuccess: () => {
|
|
340
|
+
queryClient.invalidateQueries({ queryKey: creatorKeys.gatheringTypes(creatorId) });
|
|
341
|
+
},
|
|
342
|
+
});
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
/**
|
|
346
|
+
* Update a gathering type
|
|
347
|
+
*
|
|
348
|
+
* @param creatorId - Creator ID
|
|
349
|
+
*
|
|
350
|
+
* @example
|
|
351
|
+
* ```tsx
|
|
352
|
+
* const updateGatheringType = useUpdateGatheringType(creatorId);
|
|
353
|
+
*
|
|
354
|
+
* await updateGatheringType.mutateAsync({
|
|
355
|
+
* id: 'gathering-type-123',
|
|
356
|
+
* data: { description: 'Updated description' },
|
|
357
|
+
* });
|
|
358
|
+
* ```
|
|
359
|
+
*/
|
|
360
|
+
export function useUpdateGatheringType(creatorId: string) {
|
|
361
|
+
const queryClient = useQueryClient();
|
|
362
|
+
|
|
363
|
+
return useMutation({
|
|
364
|
+
mutationFn: async ({
|
|
365
|
+
id,
|
|
366
|
+
data,
|
|
367
|
+
}: {
|
|
368
|
+
id: string;
|
|
369
|
+
data: UpdateGatheringTypeRequest;
|
|
370
|
+
}): Promise<GatheringTypeResponse> => {
|
|
371
|
+
const client = getApiClient();
|
|
372
|
+
const response = await client.put(`/api/v1/creators/${creatorId}/gathering-types/${id}`, data);
|
|
373
|
+
return response.data;
|
|
374
|
+
},
|
|
375
|
+
onSuccess: () => {
|
|
376
|
+
queryClient.invalidateQueries({ queryKey: creatorKeys.gatheringTypes(creatorId) });
|
|
377
|
+
queryClient.invalidateQueries({ queryKey: creatorKeys.approvedGatheringTypes(creatorId) });
|
|
378
|
+
},
|
|
379
|
+
});
|
|
380
|
+
}
|
|
381
|
+
|
|
382
|
+
/**
|
|
383
|
+
* Approve a gathering type (for AI-suggested types)
|
|
384
|
+
*
|
|
385
|
+
* @param creatorId - Creator ID
|
|
386
|
+
*
|
|
387
|
+
* @example
|
|
388
|
+
* ```tsx
|
|
389
|
+
* const approveGatheringType = useApproveGatheringType(creatorId);
|
|
390
|
+
*
|
|
391
|
+
* await approveGatheringType.mutateAsync('gathering-type-123');
|
|
392
|
+
* ```
|
|
393
|
+
*/
|
|
394
|
+
export function useApproveGatheringType(creatorId: string) {
|
|
395
|
+
const queryClient = useQueryClient();
|
|
396
|
+
|
|
397
|
+
return useMutation({
|
|
398
|
+
mutationFn: async (gatheringTypeId: string): Promise<GatheringTypeResponse> => {
|
|
399
|
+
const client = getApiClient();
|
|
400
|
+
const response = await client.put(
|
|
401
|
+
`/api/v1/creators/${creatorId}/gathering-types/${gatheringTypeId}/approve`
|
|
402
|
+
);
|
|
403
|
+
return response.data;
|
|
404
|
+
},
|
|
405
|
+
onSuccess: () => {
|
|
406
|
+
queryClient.invalidateQueries({ queryKey: creatorKeys.gatheringTypes(creatorId) });
|
|
407
|
+
queryClient.invalidateQueries({ queryKey: creatorKeys.approvedGatheringTypes(creatorId) });
|
|
408
|
+
},
|
|
409
|
+
});
|
|
410
|
+
}
|
|
411
|
+
|
|
412
|
+
/**
|
|
413
|
+
* Delete a gathering type
|
|
414
|
+
*
|
|
415
|
+
* @param creatorId - Creator ID
|
|
416
|
+
*
|
|
417
|
+
* @example
|
|
418
|
+
* ```tsx
|
|
419
|
+
* const deleteGatheringType = useDeleteGatheringType(creatorId);
|
|
420
|
+
*
|
|
421
|
+
* await deleteGatheringType.mutateAsync('gathering-type-123');
|
|
422
|
+
* ```
|
|
423
|
+
*/
|
|
424
|
+
export function useDeleteGatheringType(creatorId: string) {
|
|
425
|
+
const queryClient = useQueryClient();
|
|
426
|
+
|
|
427
|
+
return useMutation({
|
|
428
|
+
mutationFn: async (gatheringTypeId: string): Promise<void> => {
|
|
429
|
+
const client = getApiClient();
|
|
430
|
+
await client.delete(`/api/v1/creators/${creatorId}/gathering-types/${gatheringTypeId}`);
|
|
431
|
+
},
|
|
432
|
+
onSuccess: () => {
|
|
433
|
+
queryClient.invalidateQueries({ queryKey: creatorKeys.gatheringTypes(creatorId) });
|
|
434
|
+
queryClient.invalidateQueries({ queryKey: creatorKeys.approvedGatheringTypes(creatorId) });
|
|
435
|
+
},
|
|
436
|
+
});
|
|
437
|
+
}
|
|
438
|
+
|
|
439
|
+
/**
|
|
440
|
+
* Generate AI suggestions for gathering types based on facilitator profile
|
|
441
|
+
*
|
|
442
|
+
* @param creatorId - Creator ID
|
|
443
|
+
*
|
|
444
|
+
* @example
|
|
445
|
+
* ```tsx
|
|
446
|
+
* const generateSuggestions = useGenerateGatheringTypeSuggestions(creatorId);
|
|
447
|
+
*
|
|
448
|
+
* await generateSuggestions.mutateAsync();
|
|
449
|
+
* // Returns the newly created (unapproved) gathering types
|
|
450
|
+
* ```
|
|
451
|
+
*/
|
|
452
|
+
export function useGenerateGatheringTypeSuggestions(creatorId: string) {
|
|
453
|
+
const queryClient = useQueryClient();
|
|
454
|
+
|
|
455
|
+
return useMutation({
|
|
456
|
+
mutationFn: async (): Promise<GatheringTypeResponse[]> => {
|
|
457
|
+
const client = getApiClient();
|
|
458
|
+
const response = await client.post(`/api/v1/creators/${creatorId}/gathering-types/generate`);
|
|
459
|
+
return response.data;
|
|
460
|
+
},
|
|
461
|
+
onSuccess: () => {
|
|
462
|
+
queryClient.invalidateQueries({ queryKey: creatorKeys.gatheringTypes(creatorId) });
|
|
463
|
+
},
|
|
464
|
+
});
|
|
465
|
+
}
|
|
@@ -6,6 +6,7 @@ import type {
|
|
|
6
6
|
EventResponse,
|
|
7
7
|
LibraryContentResponse,
|
|
8
8
|
RewardResponse,
|
|
9
|
+
GatheringTypeResponse,
|
|
9
10
|
} from '../types';
|
|
10
11
|
|
|
11
12
|
// ============================================================================
|
|
@@ -26,6 +27,8 @@ export const creatorKeys = {
|
|
|
26
27
|
allContent: (creatorId: string) => [...creatorKeys.detail(creatorId), 'content', 'all'] as const,
|
|
27
28
|
events: (creatorId: string) => [...creatorKeys.detail(creatorId), 'events'] as const,
|
|
28
29
|
rewards: (creatorId: string) => [...creatorKeys.detail(creatorId), 'rewards'] as const,
|
|
30
|
+
gatheringTypes: (creatorId: string) => [...creatorKeys.detail(creatorId), 'gathering-types'] as const,
|
|
31
|
+
approvedGatheringTypes: (creatorId: string) => [...creatorKeys.detail(creatorId), 'gathering-types', 'approved'] as const,
|
|
29
32
|
};
|
|
30
33
|
|
|
31
34
|
// ============================================================================
|
|
@@ -338,3 +341,61 @@ export function useCreatorRewards(
|
|
|
338
341
|
...options,
|
|
339
342
|
});
|
|
340
343
|
}
|
|
344
|
+
|
|
345
|
+
// ============================================================================
|
|
346
|
+
// GATHERING TYPE QUERIES
|
|
347
|
+
// ============================================================================
|
|
348
|
+
|
|
349
|
+
/**
|
|
350
|
+
* Get all gathering types for a creator (including unapproved AI suggestions)
|
|
351
|
+
*
|
|
352
|
+
* @param creatorId - Creator ID
|
|
353
|
+
* @param options - TanStack Query options
|
|
354
|
+
*
|
|
355
|
+
* @example
|
|
356
|
+
* ```tsx
|
|
357
|
+
* const { data, isLoading } = useCreatorGatheringTypes('creator-123');
|
|
358
|
+
* ```
|
|
359
|
+
*/
|
|
360
|
+
export function useCreatorGatheringTypes(
|
|
361
|
+
creatorId: string,
|
|
362
|
+
options?: Omit<UseQueryOptions<GatheringTypeResponse[]>, 'queryKey' | 'queryFn'>
|
|
363
|
+
) {
|
|
364
|
+
return useQuery({
|
|
365
|
+
queryKey: creatorKeys.gatheringTypes(creatorId),
|
|
366
|
+
queryFn: async (): Promise<GatheringTypeResponse[]> => {
|
|
367
|
+
const client = getApiClient();
|
|
368
|
+
const response = await client.get(`/api/v1/creators/${creatorId}/gathering-types`);
|
|
369
|
+
return response.data;
|
|
370
|
+
},
|
|
371
|
+
enabled: !!creatorId,
|
|
372
|
+
...options,
|
|
373
|
+
});
|
|
374
|
+
}
|
|
375
|
+
|
|
376
|
+
/**
|
|
377
|
+
* Get approved gathering types for a creator
|
|
378
|
+
*
|
|
379
|
+
* @param creatorId - Creator ID
|
|
380
|
+
* @param options - TanStack Query options
|
|
381
|
+
*
|
|
382
|
+
* @example
|
|
383
|
+
* ```tsx
|
|
384
|
+
* const { data, isLoading } = useCreatorApprovedGatheringTypes('creator-123');
|
|
385
|
+
* ```
|
|
386
|
+
*/
|
|
387
|
+
export function useCreatorApprovedGatheringTypes(
|
|
388
|
+
creatorId: string,
|
|
389
|
+
options?: Omit<UseQueryOptions<GatheringTypeResponse[]>, 'queryKey' | 'queryFn'>
|
|
390
|
+
) {
|
|
391
|
+
return useQuery({
|
|
392
|
+
queryKey: creatorKeys.approvedGatheringTypes(creatorId),
|
|
393
|
+
queryFn: async (): Promise<GatheringTypeResponse[]> => {
|
|
394
|
+
const client = getApiClient();
|
|
395
|
+
const response = await client.get(`/api/v1/creators/${creatorId}/gathering-types/approved`);
|
|
396
|
+
return response.data;
|
|
397
|
+
},
|
|
398
|
+
enabled: !!creatorId,
|
|
399
|
+
...options,
|
|
400
|
+
});
|
|
401
|
+
}
|
package/src/api/types.ts
CHANGED
|
@@ -223,6 +223,14 @@ export interface CreateAvailabilityRequest {
|
|
|
223
223
|
specificDate?: string;
|
|
224
224
|
}
|
|
225
225
|
|
|
226
|
+
// ============================================================================
|
|
227
|
+
// GATHERING TYPE TEMPLATES (for facilitator event types)
|
|
228
|
+
// ============================================================================
|
|
229
|
+
|
|
230
|
+
export type GatheringTypeResponse = components['schemas']['GatheringTypeResponseDto'];
|
|
231
|
+
export type CreateGatheringTypeRequest = components['schemas']['CreateGatheringTypeDto'];
|
|
232
|
+
export type UpdateGatheringTypeRequest = components['schemas']['UpdateGatheringTypeDto'];
|
|
233
|
+
|
|
226
234
|
// ============================================================================
|
|
227
235
|
// BRAND TYPES (from generated OpenAPI types)
|
|
228
236
|
// ============================================================================
|