@growsober/sdk 1.0.22 → 1.0.24

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.
@@ -1,31 +1,6 @@
1
- import { CreatorProductResponse, ProductBookingResponse, ProductType, DeliveryMethod } from '../queries/products';
2
- export interface CreateProductRequest {
3
- title: string;
4
- description?: string;
5
- imageUrl?: string;
6
- type?: ProductType;
7
- price: number;
8
- currency?: string;
9
- durationMinutes?: number;
10
- maxParticipants?: number;
11
- deliveryMethod?: DeliveryMethod;
12
- locationDetails?: string;
13
- slug?: string;
14
- }
15
- export interface UpdateProductRequest {
16
- title?: string;
17
- description?: string;
18
- imageUrl?: string;
19
- type?: ProductType;
20
- price?: number;
21
- currency?: string;
22
- durationMinutes?: number;
23
- maxParticipants?: number;
24
- deliveryMethod?: DeliveryMethod;
25
- locationDetails?: string;
26
- isActive?: boolean;
27
- isFeatured?: boolean;
28
- }
1
+ import { CreatorProductResponse, ProductBookingResponse, CreateProductDto, UpdateProductDto } from '../queries/products';
2
+ export type CreateProductRequest = CreateProductDto;
3
+ export type UpdateProductRequest = UpdateProductDto;
29
4
  export interface BookProductRequest {
30
5
  scheduledAt: string;
31
6
  timezone?: string;
@@ -40,136 +15,31 @@ export interface UpdateBookingRequest {
40
15
  export interface CancelBookingRequest {
41
16
  reason?: string;
42
17
  }
43
- /**
44
- * Create a new product for a creator
45
- *
46
- * @example
47
- * ```tsx
48
- * const { mutate: createProduct, isLoading } = useCreateProduct();
49
- *
50
- * createProduct({
51
- * creatorId: 'creator-123',
52
- * data: {
53
- * title: '1-on-1 Coaching Session',
54
- * description: 'Personal coaching session',
55
- * type: 'SESSION_1ON1',
56
- * price: 5000,
57
- * durationMinutes: 60,
58
- * },
59
- * });
60
- * ```
61
- */
62
18
  export declare function useCreateProduct(): import("@tanstack/react-query").UseMutationResult<CreatorProductResponse, Error, {
63
19
  creatorId: string;
64
20
  data: CreateProductRequest;
65
21
  }, unknown>;
66
- /**
67
- * Update an existing product
68
- *
69
- * @example
70
- * ```tsx
71
- * const { mutate: updateProduct, isLoading } = useUpdateProduct();
72
- *
73
- * updateProduct({
74
- * creatorId: 'creator-123',
75
- * productId: 'product-456',
76
- * data: {
77
- * price: 6000,
78
- * isActive: true,
79
- * },
80
- * });
81
- * ```
82
- */
83
22
  export declare function useUpdateProduct(): import("@tanstack/react-query").UseMutationResult<CreatorProductResponse, Error, {
84
23
  creatorId: string;
85
24
  productId: string;
86
25
  data: UpdateProductRequest;
87
26
  }, unknown>;
88
- /**
89
- * Delete a product
90
- *
91
- * @example
92
- * ```tsx
93
- * const { mutate: deleteProduct, isLoading } = useDeleteProduct();
94
- *
95
- * deleteProduct({
96
- * creatorId: 'creator-123',
97
- * productId: 'product-456',
98
- * });
99
- * ```
100
- */
101
27
  export declare function useDeleteProduct(): import("@tanstack/react-query").UseMutationResult<void, Error, {
102
28
  creatorId: string;
103
29
  productId: string;
104
30
  }, unknown>;
105
- /**
106
- * Book a product/session
107
- *
108
- * @example
109
- * ```tsx
110
- * const { mutate: bookProduct, isLoading } = useBookProduct();
111
- *
112
- * bookProduct({
113
- * productId: 'product-123',
114
- * data: {
115
- * scheduledAt: '2024-03-15T10:00:00Z',
116
- * timezone: 'Europe/London',
117
- * clientNotes: 'Looking forward to the session!',
118
- * },
119
- * });
120
- * ```
121
- */
122
31
  export declare function useBookProduct(): import("@tanstack/react-query").UseMutationResult<ProductBookingResponse, Error, {
123
32
  productId: string;
124
33
  data: BookProductRequest;
125
34
  }, unknown>;
126
- /**
127
- * Update a product booking
128
- *
129
- * @example
130
- * ```tsx
131
- * const { mutate: updateBooking, isLoading } = useUpdateProductBooking();
132
- *
133
- * updateBooking({
134
- * bookingId: 'booking-123',
135
- * data: {
136
- * scheduledAt: '2024-03-16T14:00:00Z',
137
- * clientNotes: 'Rescheduled due to conflict',
138
- * },
139
- * });
140
- * ```
141
- */
142
35
  export declare function useUpdateProductBooking(): import("@tanstack/react-query").UseMutationResult<ProductBookingResponse, Error, {
143
36
  bookingId: string;
144
37
  data: UpdateBookingRequest;
145
38
  }, unknown>;
146
- /**
147
- * Cancel a product booking
148
- *
149
- * @example
150
- * ```tsx
151
- * const { mutate: cancelBooking, isLoading } = useCancelProductBooking();
152
- *
153
- * cancelBooking({
154
- * bookingId: 'booking-123',
155
- * data: { reason: 'Schedule conflict' },
156
- * });
157
- * ```
158
- */
159
39
  export declare function useCancelProductBooking(): import("@tanstack/react-query").UseMutationResult<ProductBookingResponse, Error, {
160
40
  bookingId: string;
161
41
  data?: CancelBookingRequest;
162
42
  }, unknown>;
163
- /**
164
- * Mark a booking as completed (creator only)
165
- *
166
- * @example
167
- * ```tsx
168
- * const { mutate: completeBooking, isLoading } = useCompleteProductBooking();
169
- *
170
- * completeBooking({ bookingId: 'booking-123' });
171
- * ```
172
- */
173
43
  export declare function useCompleteProductBooking(): import("@tanstack/react-query").UseMutationResult<ProductBookingResponse, Error, {
174
44
  bookingId: string;
175
45
  }, unknown>;
@@ -177,23 +47,6 @@ export interface PaymentIntentResponse {
177
47
  clientSecret: string;
178
48
  paymentIntentId: string;
179
49
  }
180
- /**
181
- * Create a payment intent for a product booking
182
- * Use this with Stripe Elements to process payment
183
- *
184
- * @example
185
- * ```tsx
186
- * const { mutate: createPaymentIntent, data, isLoading } = useCreateProductPaymentIntent();
187
- *
188
- * // Create payment intent
189
- * createPaymentIntent({ bookingId: 'booking-123' });
190
- *
191
- * // Use clientSecret with Stripe Elements
192
- * if (data?.clientSecret) {
193
- * // Pass to Stripe PaymentElement
194
- * }
195
- * ```
196
- */
197
50
  export declare function useCreateProductPaymentIntent(): import("@tanstack/react-query").UseMutationResult<PaymentIntentResponse, Error, {
198
51
  bookingId: string;
199
52
  }, unknown>;
@@ -14,25 +14,6 @@ const products_1 = require("../queries/products");
14
14
  // ============================================================================
15
15
  // MUTATION HOOKS - PRODUCTS
16
16
  // ============================================================================
17
- /**
18
- * Create a new product for a creator
19
- *
20
- * @example
21
- * ```tsx
22
- * const { mutate: createProduct, isLoading } = useCreateProduct();
23
- *
24
- * createProduct({
25
- * creatorId: 'creator-123',
26
- * data: {
27
- * title: '1-on-1 Coaching Session',
28
- * description: 'Personal coaching session',
29
- * type: 'SESSION_1ON1',
30
- * price: 5000,
31
- * durationMinutes: 60,
32
- * },
33
- * });
34
- * ```
35
- */
36
17
  function useCreateProduct() {
37
18
  const queryClient = (0, react_query_1.useQueryClient)();
38
19
  return (0, react_query_1.useMutation)({
@@ -47,23 +28,6 @@ function useCreateProduct() {
47
28
  },
48
29
  });
49
30
  }
50
- /**
51
- * Update an existing product
52
- *
53
- * @example
54
- * ```tsx
55
- * const { mutate: updateProduct, isLoading } = useUpdateProduct();
56
- *
57
- * updateProduct({
58
- * creatorId: 'creator-123',
59
- * productId: 'product-456',
60
- * data: {
61
- * price: 6000,
62
- * isActive: true,
63
- * },
64
- * });
65
- * ```
66
- */
67
31
  function useUpdateProduct() {
68
32
  const queryClient = (0, react_query_1.useQueryClient)();
69
33
  return (0, react_query_1.useMutation)({
@@ -79,19 +43,6 @@ function useUpdateProduct() {
79
43
  },
80
44
  });
81
45
  }
82
- /**
83
- * Delete a product
84
- *
85
- * @example
86
- * ```tsx
87
- * const { mutate: deleteProduct, isLoading } = useDeleteProduct();
88
- *
89
- * deleteProduct({
90
- * creatorId: 'creator-123',
91
- * productId: 'product-456',
92
- * });
93
- * ```
94
- */
95
46
  function useDeleteProduct() {
96
47
  const queryClient = (0, react_query_1.useQueryClient)();
97
48
  return (0, react_query_1.useMutation)({
@@ -109,23 +60,6 @@ function useDeleteProduct() {
109
60
  // ============================================================================
110
61
  // MUTATION HOOKS - BOOKINGS
111
62
  // ============================================================================
112
- /**
113
- * Book a product/session
114
- *
115
- * @example
116
- * ```tsx
117
- * const { mutate: bookProduct, isLoading } = useBookProduct();
118
- *
119
- * bookProduct({
120
- * productId: 'product-123',
121
- * data: {
122
- * scheduledAt: '2024-03-15T10:00:00Z',
123
- * timezone: 'Europe/London',
124
- * clientNotes: 'Looking forward to the session!',
125
- * },
126
- * });
127
- * ```
128
- */
129
63
  function useBookProduct() {
130
64
  const queryClient = (0, react_query_1.useQueryClient)();
131
65
  return (0, react_query_1.useMutation)({
@@ -139,22 +73,6 @@ function useBookProduct() {
139
73
  },
140
74
  });
141
75
  }
142
- /**
143
- * Update a product booking
144
- *
145
- * @example
146
- * ```tsx
147
- * const { mutate: updateBooking, isLoading } = useUpdateProductBooking();
148
- *
149
- * updateBooking({
150
- * bookingId: 'booking-123',
151
- * data: {
152
- * scheduledAt: '2024-03-16T14:00:00Z',
153
- * clientNotes: 'Rescheduled due to conflict',
154
- * },
155
- * });
156
- * ```
157
- */
158
76
  function useUpdateProductBooking() {
159
77
  const queryClient = (0, react_query_1.useQueryClient)();
160
78
  return (0, react_query_1.useMutation)({
@@ -166,24 +84,10 @@ function useUpdateProductBooking() {
166
84
  onSuccess: (_, { bookingId }) => {
167
85
  queryClient.invalidateQueries({ queryKey: products_1.productKeys.bookingDetail(bookingId) });
168
86
  queryClient.invalidateQueries({ queryKey: products_1.productKeys.myBookings() });
169
- // Also invalidate creator bookings as they see this
170
87
  queryClient.invalidateQueries({ queryKey: products_1.productKeys.bookings() });
171
88
  },
172
89
  });
173
90
  }
174
- /**
175
- * Cancel a product booking
176
- *
177
- * @example
178
- * ```tsx
179
- * const { mutate: cancelBooking, isLoading } = useCancelProductBooking();
180
- *
181
- * cancelBooking({
182
- * bookingId: 'booking-123',
183
- * data: { reason: 'Schedule conflict' },
184
- * });
185
- * ```
186
- */
187
91
  function useCancelProductBooking() {
188
92
  const queryClient = (0, react_query_1.useQueryClient)();
189
93
  return (0, react_query_1.useMutation)({
@@ -199,16 +103,6 @@ function useCancelProductBooking() {
199
103
  },
200
104
  });
201
105
  }
202
- /**
203
- * Mark a booking as completed (creator only)
204
- *
205
- * @example
206
- * ```tsx
207
- * const { mutate: completeBooking, isLoading } = useCompleteProductBooking();
208
- *
209
- * completeBooking({ bookingId: 'booking-123' });
210
- * ```
211
- */
212
106
  function useCompleteProductBooking() {
213
107
  const queryClient = (0, react_query_1.useQueryClient)();
214
108
  return (0, react_query_1.useMutation)({
@@ -224,23 +118,6 @@ function useCompleteProductBooking() {
224
118
  },
225
119
  });
226
120
  }
227
- /**
228
- * Create a payment intent for a product booking
229
- * Use this with Stripe Elements to process payment
230
- *
231
- * @example
232
- * ```tsx
233
- * const { mutate: createPaymentIntent, data, isLoading } = useCreateProductPaymentIntent();
234
- *
235
- * // Create payment intent
236
- * createPaymentIntent({ bookingId: 'booking-123' });
237
- *
238
- * // Use clientSecret with Stripe Elements
239
- * if (data?.clientSecret) {
240
- * // Pass to Stripe PaymentElement
241
- * }
242
- * ```
243
- */
244
121
  function useCreateProductPaymentIntent() {
245
122
  return (0, react_query_1.useMutation)({
246
123
  mutationFn: async ({ bookingId, }) => {
@@ -250,4 +127,4 @@ function useCreateProductPaymentIntent() {
250
127
  },
251
128
  });
252
129
  }
253
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.js","sourceRoot":"","sources":["../../../src/api/mutations/products.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { productKeys, CreatorProductResponse, ProductBookingResponse, ProductType, DeliveryMethod } from '../queries/products';\nimport { creatorKeys } from '../queries/creators';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface CreateProductRequest {\n  title: string;\n  description?: string;\n  imageUrl?: string;\n  type?: ProductType;\n  price: number;\n  currency?: string;\n  durationMinutes?: number;\n  maxParticipants?: number;\n  deliveryMethod?: DeliveryMethod;\n  locationDetails?: string;\n  slug?: string;\n}\n\nexport interface UpdateProductRequest {\n  title?: string;\n  description?: string;\n  imageUrl?: string;\n  type?: ProductType;\n  price?: number;\n  currency?: string;\n  durationMinutes?: number;\n  maxParticipants?: number;\n  deliveryMethod?: DeliveryMethod;\n  locationDetails?: string;\n  isActive?: boolean;\n  isFeatured?: boolean;\n}\n\nexport interface BookProductRequest {\n  scheduledAt: string;\n  timezone?: string;\n  clientNotes?: string;\n}\n\nexport interface UpdateBookingRequest {\n  scheduledAt?: string;\n  clientNotes?: string;\n  creatorNotes?: string;\n  meetingLink?: string;\n}\n\nexport interface CancelBookingRequest {\n  reason?: string;\n}\n\n// ============================================================================\n// MUTATION HOOKS - PRODUCTS\n// ============================================================================\n\n/**\n * Create a new product for a creator\n *\n * @example\n * ```tsx\n * const { mutate: createProduct, isLoading } = useCreateProduct();\n *\n * createProduct({\n *   creatorId: 'creator-123',\n *   data: {\n *     title: '1-on-1 Coaching Session',\n *     description: 'Personal coaching session',\n *     type: 'SESSION_1ON1',\n *     price: 5000,\n *     durationMinutes: 60,\n *   },\n * });\n * ```\n */\nexport function useCreateProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      data,\n    }: {\n      creatorId: string;\n      data: CreateProductRequest;\n    }): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/products`, data);\n      return response.data;\n    },\n    onSuccess: (_, { creatorId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\n/**\n * Update an existing product\n *\n * @example\n * ```tsx\n * const { mutate: updateProduct, isLoading } = useUpdateProduct();\n *\n * updateProduct({\n *   creatorId: 'creator-123',\n *   productId: 'product-456',\n *   data: {\n *     price: 6000,\n *     isActive: true,\n *   },\n * });\n * ```\n */\nexport function useUpdateProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      productId,\n      data,\n    }: {\n      creatorId: string;\n      productId: string;\n      data: UpdateProductRequest;\n    }): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/creators/${creatorId}/products/${productId}`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: (_, { creatorId, productId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.detail(productId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\n/**\n * Delete a product\n *\n * @example\n * ```tsx\n * const { mutate: deleteProduct, isLoading } = useDeleteProduct();\n *\n * deleteProduct({\n *   creatorId: 'creator-123',\n *   productId: 'product-456',\n * });\n * ```\n */\nexport function useDeleteProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      productId,\n    }: {\n      creatorId: string;\n      productId: string;\n    }): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/creators/${creatorId}/products/${productId}`);\n    },\n    onSuccess: (_, { creatorId, productId }) => {\n      queryClient.removeQueries({ queryKey: productKeys.detail(productId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\n// ============================================================================\n// MUTATION HOOKS - BOOKINGS\n// ============================================================================\n\n/**\n * Book a product/session\n *\n * @example\n * ```tsx\n * const { mutate: bookProduct, isLoading } = useBookProduct();\n *\n * bookProduct({\n *   productId: 'product-123',\n *   data: {\n *     scheduledAt: '2024-03-15T10:00:00Z',\n *     timezone: 'Europe/London',\n *     clientNotes: 'Looking forward to the session!',\n *   },\n * });\n * ```\n */\nexport function useBookProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      productId,\n      data,\n    }: {\n      productId: string;\n      data: BookProductRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/products/${productId}/book`, data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n    },\n  });\n}\n\n/**\n * Update a product booking\n *\n * @example\n * ```tsx\n * const { mutate: updateBooking, isLoading } = useUpdateProductBooking();\n *\n * updateBooking({\n *   bookingId: 'booking-123',\n *   data: {\n *     scheduledAt: '2024-03-16T14:00:00Z',\n *     clientNotes: 'Rescheduled due to conflict',\n *   },\n * });\n * ```\n */\nexport function useUpdateProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n      data,\n    }: {\n      bookingId: string;\n      data: UpdateBookingRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/users/me/product-bookings/${bookingId}`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      // Also invalidate creator bookings as they see this\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\n/**\n * Cancel a product booking\n *\n * @example\n * ```tsx\n * const { mutate: cancelBooking, isLoading } = useCancelProductBooking();\n *\n * cancelBooking({\n *   bookingId: 'booking-123',\n *   data: { reason: 'Schedule conflict' },\n * });\n * ```\n */\nexport function useCancelProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n      data,\n    }: {\n      bookingId: string;\n      data?: CancelBookingRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.delete(\n        `/api/v1/users/me/product-bookings/${bookingId}`,\n        { data }\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\n/**\n * Mark a booking as completed (creator only)\n *\n * @example\n * ```tsx\n * const { mutate: completeBooking, isLoading } = useCompleteProductBooking();\n *\n * completeBooking({ bookingId: 'booking-123' });\n * ```\n */\nexport function useCompleteProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n    }: {\n      bookingId: string;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/users/me/product-bookings/${bookingId}/complete`\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\n// ============================================================================\n// MUTATION HOOKS - PAYMENTS\n// ============================================================================\n\nexport interface PaymentIntentResponse {\n  clientSecret: string;\n  paymentIntentId: string;\n}\n\n/**\n * Create a payment intent for a product booking\n * Use this with Stripe Elements to process payment\n *\n * @example\n * ```tsx\n * const { mutate: createPaymentIntent, data, isLoading } = useCreateProductPaymentIntent();\n *\n * // Create payment intent\n * createPaymentIntent({ bookingId: 'booking-123' });\n *\n * // Use clientSecret with Stripe Elements\n * if (data?.clientSecret) {\n *   // Pass to Stripe PaymentElement\n * }\n * ```\n */\nexport function useCreateProductPaymentIntent() {\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n    }: {\n      bookingId: string;\n    }): Promise<PaymentIntentResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/users/me/product-bookings/${bookingId}/payment-intent`\n      );\n      return response.data;\n    },\n  });\n}\n"]}
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.js","sourceRoot":"","sources":["../../../src/api/mutations/products.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { productKeys, CreatorProductResponse, ProductBookingResponse, CreateProductDto, UpdateProductDto } from '../queries/products';\nimport { creatorKeys } from '../queries/creators';\n\n// ============================================================================\n// TYPES — request types derived from auto-generated OpenAPI DTOs\n// ============================================================================\n\nexport type CreateProductRequest = CreateProductDto;\nexport type UpdateProductRequest = UpdateProductDto;\n\nexport interface BookProductRequest {\n  scheduledAt: string;\n  timezone?: string;\n  clientNotes?: string;\n}\n\nexport interface UpdateBookingRequest {\n  scheduledAt?: string;\n  clientNotes?: string;\n  creatorNotes?: string;\n  meetingLink?: string;\n}\n\nexport interface CancelBookingRequest {\n  reason?: string;\n}\n\n// ============================================================================\n// MUTATION HOOKS - PRODUCTS\n// ============================================================================\n\nexport function useCreateProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      data,\n    }: {\n      creatorId: string;\n      data: CreateProductRequest;\n    }): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/products`, data);\n      return response.data;\n    },\n    onSuccess: (_, { creatorId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\nexport function useUpdateProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      productId,\n      data,\n    }: {\n      creatorId: string;\n      productId: string;\n      data: UpdateProductRequest;\n    }): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/creators/${creatorId}/products/${productId}`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: (_, { creatorId, productId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.detail(productId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\nexport function useDeleteProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      productId,\n    }: {\n      creatorId: string;\n      productId: string;\n    }): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/creators/${creatorId}/products/${productId}`);\n    },\n    onSuccess: (_, { creatorId, productId }) => {\n      queryClient.removeQueries({ queryKey: productKeys.detail(productId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\n// ============================================================================\n// MUTATION HOOKS - BOOKINGS\n// ============================================================================\n\nexport function useBookProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      productId,\n      data,\n    }: {\n      productId: string;\n      data: BookProductRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/products/${productId}/book`, data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n    },\n  });\n}\n\nexport function useUpdateProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n      data,\n    }: {\n      bookingId: string;\n      data: UpdateBookingRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/users/me/product-bookings/${bookingId}`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\nexport function useCancelProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n      data,\n    }: {\n      bookingId: string;\n      data?: CancelBookingRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.delete(\n        `/api/v1/users/me/product-bookings/${bookingId}`,\n        { data }\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\nexport function useCompleteProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n    }: {\n      bookingId: string;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/users/me/product-bookings/${bookingId}/complete`\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\n// ============================================================================\n// MUTATION HOOKS - PAYMENTS\n// ============================================================================\n\nexport interface PaymentIntentResponse {\n  clientSecret: string;\n  paymentIntentId: string;\n}\n\nexport function useCreateProductPaymentIntent() {\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n    }: {\n      bookingId: string;\n    }): Promise<PaymentIntentResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/users/me/product-bookings/${bookingId}/payment-intent`\n      );\n      return response.data;\n    },\n  });\n}\n"]}
@@ -10,6 +10,8 @@ export declare const creatorKeys: {
10
10
  byUser: (userId: string) => readonly ["creators", "user", string];
11
11
  me: () => readonly ["creators", "me"];
12
12
  availability: (creatorId: string) => readonly ["creators", "detail", string, "availability"];
13
+ availableDates: (creatorId: string, from: string, to: string) => readonly ["creators", "detail", string, "available-dates", string, string];
14
+ availableSlots: (creatorId: string, date: string, durationMinutes: number) => readonly ["creators", "detail", string, "available-slots", string, number];
13
15
  content: (creatorId: string) => readonly ["creators", "detail", string, "content"];
14
16
  allContent: (creatorId: string) => readonly ["creators", "detail", string, "content", "all"];
15
17
  events: (creatorId: string) => readonly ["creators", "detail", string, "events"];
@@ -199,6 +201,36 @@ export declare function useCreatorAvailability(creatorId: string, options?: Omit
199
201
  isRecurring: boolean;
200
202
  specificDate?: string;
201
203
  }[], Error>;
204
+ export interface AvailableDateEntry {
205
+ date: string;
206
+ hasAvailability: boolean;
207
+ }
208
+ export interface AvailableDatesResponse {
209
+ dates: AvailableDateEntry[];
210
+ }
211
+ export interface AvailableSlotEntry {
212
+ startTime: string;
213
+ endTime: string;
214
+ available: boolean;
215
+ }
216
+ export interface AvailableSlotsResponse {
217
+ date: string;
218
+ slots: AvailableSlotEntry[];
219
+ }
220
+ /**
221
+ * Get dates with availability for a creator in a date range
222
+ */
223
+ export declare function useCreatorAvailableDates(creatorId: string, params: {
224
+ from: string;
225
+ to: string;
226
+ }, options?: Omit<UseQueryOptions<AvailableDatesResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<AvailableDatesResponse, Error>;
227
+ /**
228
+ * Get available time slots for a creator on a specific date
229
+ */
230
+ export declare function useCreatorAvailableSlots(creatorId: string, params: {
231
+ date: string;
232
+ durationMinutes?: number;
233
+ }, options?: Omit<UseQueryOptions<AvailableSlotsResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<AvailableSlotsResponse, Error>;
202
234
  /**
203
235
  * Get a creator's published library content
204
236
  *