@growsober/sdk 1.0.23 → 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"]}
@@ -1,6 +1,9 @@
1
1
  import { UseQueryOptions } from '@tanstack/react-query';
2
- export type ProductType = 'SESSION_1ON1' | 'SESSION_GROUP' | 'PACKAGE' | 'WORKSHOP' | 'CONSULTATION';
3
- export type DeliveryMethod = 'VIDEO_CALL' | 'PHONE_CALL' | 'IN_PERSON' | 'HYBRID';
2
+ import type { components } from '@growsober/types';
3
+ export type CreateProductDto = components['schemas']['CreateProductDto'];
4
+ export type UpdateProductDto = components['schemas']['UpdateProductDto'];
5
+ export type ProductType = CreateProductDto['type'];
6
+ export type DeliveryMethod = CreateProductDto['deliveryMethod'];
4
7
  export type BookingStatus = 'PENDING' | 'CONFIRMED' | 'CANCELLED' | 'COMPLETED';
5
8
  export type PaymentStatus = 'PENDING' | 'PAID' | 'REFUNDED' | 'FAILED';
6
9
  export interface CreatorProductResponse {
@@ -10,6 +13,8 @@ export interface CreatorProductResponse {
10
13
  slug: string;
11
14
  description: string | null;
12
15
  imageUrl: string | null;
16
+ category: string | null;
17
+ tags: string[];
13
18
  type: ProductType;
14
19
  price: number;
15
20
  currency: string;
@@ -19,6 +24,8 @@ export interface CreatorProductResponse {
19
24
  locationDetails: string | null;
20
25
  isActive: boolean;
21
26
  isFeatured: boolean;
27
+ stripeProductId?: string | null;
28
+ stripePriceId?: string | null;
22
29
  createdAt: string;
23
30
  updatedAt: string;
24
31
  creator?: {
@@ -91,95 +98,10 @@ export declare const productKeys: {
91
98
  creatorBookings: (creatorId: string) => readonly ["products", "bookings", "creator", string];
92
99
  bookingDetail: (bookingId: string) => readonly ["products", "bookings", "detail", string];
93
100
  };
94
- /**
95
- * Get paginated list of all active products
96
- *
97
- * @param filters - Query parameters for filtering and pagination
98
- * @param options - TanStack Query options
99
- *
100
- * @example
101
- * ```tsx
102
- * const { data, isLoading } = useProducts({
103
- * page: 1,
104
- * limit: 20,
105
- * type: 'SESSION_1ON1',
106
- * });
107
- * ```
108
- */
109
101
  export declare function useProducts(filters?: ProductFilters, options?: Omit<UseQueryOptions<PaginatedProductsResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PaginatedProductsResponse, Error>;
110
- /**
111
- * Get a single product by ID
112
- *
113
- * @param id - Product ID
114
- * @param options - TanStack Query options
115
- *
116
- * @example
117
- * ```tsx
118
- * const { data, isLoading } = useProduct('product-123');
119
- * ```
120
- */
121
102
  export declare function useProduct(id: string, options?: Omit<UseQueryOptions<CreatorProductResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<CreatorProductResponse, Error>;
122
- /**
123
- * Get a product by its slug
124
- *
125
- * @param slug - Product slug
126
- * @param options - TanStack Query options
127
- *
128
- * @example
129
- * ```tsx
130
- * const { data, isLoading } = useProductBySlug('1-on-1-coaching-abc123');
131
- * ```
132
- */
133
103
  export declare function useProductBySlug(slug: string, options?: Omit<UseQueryOptions<CreatorProductResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<CreatorProductResponse, Error>;
134
- /**
135
- * Get products for a specific creator
136
- *
137
- * @param creatorId - Creator ID
138
- * @param filters - Query parameters for filtering
139
- * @param options - TanStack Query options
140
- *
141
- * @example
142
- * ```tsx
143
- * const { data, isLoading } = useCreatorProducts('creator-123', {
144
- * type: 'SESSION_1ON1',
145
- * isActive: true,
146
- * });
147
- * ```
148
- */
149
104
  export declare function useCreatorProducts(creatorId: string, filters?: ProductFilters, options?: Omit<UseQueryOptions<PaginatedProductsResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PaginatedProductsResponse, Error>;
150
- /**
151
- * Get current user's product bookings
152
- *
153
- * @param options - TanStack Query options
154
- *
155
- * @example
156
- * ```tsx
157
- * const { data, isLoading } = useMyProductBookings();
158
- * ```
159
- */
160
105
  export declare function useMyProductBookings(options?: Omit<UseQueryOptions<ProductBookingResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<ProductBookingResponse[], Error>;
161
- /**
162
- * Get a single product booking by ID
163
- *
164
- * @param bookingId - Booking ID
165
- * @param options - TanStack Query options
166
- *
167
- * @example
168
- * ```tsx
169
- * const { data, isLoading } = useProductBooking('booking-123');
170
- * ```
171
- */
172
106
  export declare function useProductBooking(bookingId: string, options?: Omit<UseQueryOptions<ProductBookingResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<ProductBookingResponse, Error>;
173
- /**
174
- * Get bookings for a creator's products (creator dashboard)
175
- *
176
- * @param creatorId - Creator ID
177
- * @param options - TanStack Query options
178
- *
179
- * @example
180
- * ```tsx
181
- * // For creator dashboard - see all bookings for their products
182
- * const { data, isLoading } = useCreatorBookings('creator-123');
183
- * ```
184
- */
185
107
  export declare function useCreatorBookings(creatorId: string, options?: Omit<UseQueryOptions<ProductBookingResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<ProductBookingResponse[], Error>;
@@ -29,21 +29,6 @@ exports.productKeys = {
29
29
  // ============================================================================
30
30
  // QUERY HOOKS
31
31
  // ============================================================================
32
- /**
33
- * Get paginated list of all active products
34
- *
35
- * @param filters - Query parameters for filtering and pagination
36
- * @param options - TanStack Query options
37
- *
38
- * @example
39
- * ```tsx
40
- * const { data, isLoading } = useProducts({
41
- * page: 1,
42
- * limit: 20,
43
- * type: 'SESSION_1ON1',
44
- * });
45
- * ```
46
- */
47
32
  function useProducts(filters, options) {
48
33
  return (0, react_query_1.useQuery)({
49
34
  queryKey: exports.productKeys.list(filters),
@@ -57,17 +42,6 @@ function useProducts(filters, options) {
57
42
  ...options,
58
43
  });
59
44
  }
60
- /**
61
- * Get a single product by ID
62
- *
63
- * @param id - Product ID
64
- * @param options - TanStack Query options
65
- *
66
- * @example
67
- * ```tsx
68
- * const { data, isLoading } = useProduct('product-123');
69
- * ```
70
- */
71
45
  function useProduct(id, options) {
72
46
  return (0, react_query_1.useQuery)({
73
47
  queryKey: exports.productKeys.detail(id),
@@ -80,17 +54,6 @@ function useProduct(id, options) {
80
54
  ...options,
81
55
  });
82
56
  }
83
- /**
84
- * Get a product by its slug
85
- *
86
- * @param slug - Product slug
87
- * @param options - TanStack Query options
88
- *
89
- * @example
90
- * ```tsx
91
- * const { data, isLoading } = useProductBySlug('1-on-1-coaching-abc123');
92
- * ```
93
- */
94
57
  function useProductBySlug(slug, options) {
95
58
  return (0, react_query_1.useQuery)({
96
59
  queryKey: exports.productKeys.slug(slug),
@@ -103,21 +66,6 @@ function useProductBySlug(slug, options) {
103
66
  ...options,
104
67
  });
105
68
  }
106
- /**
107
- * Get products for a specific creator
108
- *
109
- * @param creatorId - Creator ID
110
- * @param filters - Query parameters for filtering
111
- * @param options - TanStack Query options
112
- *
113
- * @example
114
- * ```tsx
115
- * const { data, isLoading } = useCreatorProducts('creator-123', {
116
- * type: 'SESSION_1ON1',
117
- * isActive: true,
118
- * });
119
- * ```
120
- */
121
69
  function useCreatorProducts(creatorId, filters, options) {
122
70
  return (0, react_query_1.useQuery)({
123
71
  queryKey: exports.productKeys.byCreator(creatorId, filters),
@@ -132,16 +80,6 @@ function useCreatorProducts(creatorId, filters, options) {
132
80
  ...options,
133
81
  });
134
82
  }
135
- /**
136
- * Get current user's product bookings
137
- *
138
- * @param options - TanStack Query options
139
- *
140
- * @example
141
- * ```tsx
142
- * const { data, isLoading } = useMyProductBookings();
143
- * ```
144
- */
145
83
  function useMyProductBookings(options) {
146
84
  return (0, react_query_1.useQuery)({
147
85
  queryKey: exports.productKeys.myBookings(),
@@ -153,17 +91,6 @@ function useMyProductBookings(options) {
153
91
  ...options,
154
92
  });
155
93
  }
156
- /**
157
- * Get a single product booking by ID
158
- *
159
- * @param bookingId - Booking ID
160
- * @param options - TanStack Query options
161
- *
162
- * @example
163
- * ```tsx
164
- * const { data, isLoading } = useProductBooking('booking-123');
165
- * ```
166
- */
167
94
  function useProductBooking(bookingId, options) {
168
95
  return (0, react_query_1.useQuery)({
169
96
  queryKey: exports.productKeys.bookingDetail(bookingId),
@@ -176,18 +103,6 @@ function useProductBooking(bookingId, options) {
176
103
  ...options,
177
104
  });
178
105
  }
179
- /**
180
- * Get bookings for a creator's products (creator dashboard)
181
- *
182
- * @param creatorId - Creator ID
183
- * @param options - TanStack Query options
184
- *
185
- * @example
186
- * ```tsx
187
- * // For creator dashboard - see all bookings for their products
188
- * const { data, isLoading } = useCreatorBookings('creator-123');
189
- * ```
190
- */
191
106
  function useCreatorBookings(creatorId, options) {
192
107
  return (0, react_query_1.useQuery)({
193
108
  queryKey: exports.productKeys.creatorBookings(creatorId),
@@ -200,4 +115,4 @@ function useCreatorBookings(creatorId, options) {
200
115
  ...options,
201
116
  });
202
117
  }
203
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.js","sourceRoot":"","sources":["../../../src/api/queries/products.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport type ProductType = 'SESSION_1ON1' | 'SESSION_GROUP' | 'PACKAGE' | 'WORKSHOP' | 'CONSULTATION';\nexport type DeliveryMethod = 'VIDEO_CALL' | 'PHONE_CALL' | 'IN_PERSON' | 'HYBRID';\nexport type BookingStatus = 'PENDING' | 'CONFIRMED' | 'CANCELLED' | 'COMPLETED';\nexport type PaymentStatus = 'PENDING' | 'PAID' | 'REFUNDED' | 'FAILED';\n\nexport interface CreatorProductResponse {\n  id: string;\n  creatorId: string;\n  title: string;\n  slug: string;\n  description: string | null;\n  imageUrl: string | null;\n  type: ProductType;\n  price: number;\n  currency: string;\n  durationMinutes: number;\n  maxParticipants: number;\n  deliveryMethod: DeliveryMethod;\n  locationDetails: string | null;\n  isActive: boolean;\n  isFeatured: boolean;\n  createdAt: string;\n  updatedAt: string;\n  creator?: {\n    id: string;\n    displayName: string;\n    slug: string;\n    avatarUrl: string | null;\n    specialties?: string[];\n    certifications?: string[];\n  };\n}\n\nexport interface ProductBookingResponse {\n  id: string;\n  productId: string;\n  userId: string;\n  scheduledAt: string;\n  timezone: string;\n  status: BookingStatus;\n  paymentStatus: PaymentStatus | null;\n  stripePaymentIntentId: string | null;\n  amountPaid: number | null;\n  currency: string;\n  clientNotes: string | null;\n  creatorNotes: string | null;\n  meetingLink: string | null;\n  isCompleted: boolean;\n  completedAt: string | null;\n  isCancelled: boolean;\n  cancelledAt: string | null;\n  cancelledBy: string | null;\n  cancellationReason: string | null;\n  createdAt: string;\n  updatedAt: string;\n  product?: CreatorProductResponse;\n  user?: {\n    id: string;\n    name: string;\n    profileImage: string | null;\n    email: string;\n  };\n}\n\nexport interface ProductFilters {\n  page?: number;\n  limit?: number;\n  type?: ProductType;\n  deliveryMethod?: DeliveryMethod;\n  minPrice?: number;\n  maxPrice?: number;\n  isActive?: boolean;\n}\n\nexport interface PaginatedProductsResponse {\n  products: CreatorProductResponse[];\n  meta: {\n    total: number;\n    page: number;\n    limit: number;\n    totalPages: number;\n  };\n}\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const productKeys = {\n  all: ['products'] as const,\n  lists: () => [...productKeys.all, 'list'] as const,\n  list: (filters?: ProductFilters) => [...productKeys.lists(), filters] as const,\n  details: () => [...productKeys.all, 'detail'] as const,\n  detail: (id: string) => [...productKeys.details(), id] as const,\n  slug: (slug: string) => [...productKeys.all, 'slug', slug] as const,\n  byCreator: (creatorId: string, filters?: ProductFilters) =>\n    [...productKeys.all, 'creator', creatorId, filters] as const,\n  bookings: () => [...productKeys.all, 'bookings'] as const,\n  myBookings: () => [...productKeys.bookings(), 'me'] as const,\n  creatorBookings: (creatorId: string) => [...productKeys.bookings(), 'creator', creatorId] as const,\n  bookingDetail: (bookingId: string) => [...productKeys.bookings(), 'detail', bookingId] as const,\n};\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get paginated list of all active products\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 } = useProducts({\n *   page: 1,\n *   limit: 20,\n *   type: 'SESSION_1ON1',\n * });\n * ```\n */\nexport function useProducts(\n  filters?: ProductFilters,\n  options?: Omit<UseQueryOptions<PaginatedProductsResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.list(filters),\n    queryFn: async (): Promise<PaginatedProductsResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/products', {\n        params: filters,\n      });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get a single product by ID\n *\n * @param id - Product ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useProduct('product-123');\n * ```\n */\nexport function useProduct(\n  id: string,\n  options?: Omit<UseQueryOptions<CreatorProductResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.detail(id),\n    queryFn: async (): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/products/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\n/**\n * Get a product by its slug\n *\n * @param slug - Product slug\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useProductBySlug('1-on-1-coaching-abc123');\n * ```\n */\nexport function useProductBySlug(\n  slug: string,\n  options?: Omit<UseQueryOptions<CreatorProductResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.slug(slug),\n    queryFn: async (): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/products/slug/${slug}`);\n      return response.data;\n    },\n    enabled: !!slug,\n    ...options,\n  });\n}\n\n/**\n * Get products for a specific creator\n *\n * @param creatorId - Creator ID\n * @param filters - Query parameters for filtering\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCreatorProducts('creator-123', {\n *   type: 'SESSION_1ON1',\n *   isActive: true,\n * });\n * ```\n */\nexport function useCreatorProducts(\n  creatorId: string,\n  filters?: ProductFilters,\n  options?: Omit<UseQueryOptions<PaginatedProductsResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.byCreator(creatorId, filters),\n    queryFn: async (): Promise<PaginatedProductsResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/products`, {\n        params: filters,\n      });\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n\n/**\n * Get current user's product bookings\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useMyProductBookings();\n * ```\n */\nexport function useMyProductBookings(\n  options?: Omit<UseQueryOptions<ProductBookingResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.myBookings(),\n    queryFn: async (): Promise<ProductBookingResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/users/me/product-bookings');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get a single product booking by ID\n *\n * @param bookingId - Booking ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useProductBooking('booking-123');\n * ```\n */\nexport function useProductBooking(\n  bookingId: string,\n  options?: Omit<UseQueryOptions<ProductBookingResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.bookingDetail(bookingId),\n    queryFn: async (): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/users/me/product-bookings/${bookingId}`);\n      return response.data;\n    },\n    enabled: !!bookingId,\n    ...options,\n  });\n}\n\n/**\n * Get bookings for a creator's products (creator dashboard)\n *\n * @param creatorId - Creator ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * // For creator dashboard - see all bookings for their products\n * const { data, isLoading } = useCreatorBookings('creator-123');\n * ```\n */\nexport function useCreatorBookings(\n  creatorId: string,\n  options?: Omit<UseQueryOptions<ProductBookingResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.creatorBookings(creatorId),\n    queryFn: async (): Promise<ProductBookingResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/products/bookings`);\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n"]}
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.js","sourceRoot":"","sources":["../../../src/api/queries/products.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { components } from '@growsober/types';\n\n// ============================================================================\n// TYPES — derived from auto-generated OpenAPI types\n// ============================================================================\n\nexport type CreateProductDto = components['schemas']['CreateProductDto'];\nexport type UpdateProductDto = components['schemas']['UpdateProductDto'];\n\nexport type ProductType = CreateProductDto['type'];\nexport type DeliveryMethod = CreateProductDto['deliveryMethod'];\nexport type BookingStatus = 'PENDING' | 'CONFIRMED' | 'CANCELLED' | 'COMPLETED';\nexport type PaymentStatus = 'PENDING' | 'PAID' | 'REFUNDED' | 'FAILED';\n\nexport interface CreatorProductResponse {\n  id: string;\n  creatorId: string;\n  title: string;\n  slug: string;\n  description: string | null;\n  imageUrl: string | null;\n  category: string | null;\n  tags: string[];\n  type: ProductType;\n  price: number;\n  currency: string;\n  durationMinutes: number;\n  maxParticipants: number;\n  deliveryMethod: DeliveryMethod;\n  locationDetails: string | null;\n  isActive: boolean;\n  isFeatured: boolean;\n  stripeProductId?: string | null;\n  stripePriceId?: string | null;\n  createdAt: string;\n  updatedAt: string;\n  creator?: {\n    id: string;\n    displayName: string;\n    slug: string;\n    avatarUrl: string | null;\n    specialties?: string[];\n    certifications?: string[];\n  };\n}\n\nexport interface ProductBookingResponse {\n  id: string;\n  productId: string;\n  userId: string;\n  scheduledAt: string;\n  timezone: string;\n  status: BookingStatus;\n  paymentStatus: PaymentStatus | null;\n  stripePaymentIntentId: string | null;\n  amountPaid: number | null;\n  currency: string;\n  clientNotes: string | null;\n  creatorNotes: string | null;\n  meetingLink: string | null;\n  isCompleted: boolean;\n  completedAt: string | null;\n  isCancelled: boolean;\n  cancelledAt: string | null;\n  cancelledBy: string | null;\n  cancellationReason: string | null;\n  createdAt: string;\n  updatedAt: string;\n  product?: CreatorProductResponse;\n  user?: {\n    id: string;\n    name: string;\n    profileImage: string | null;\n    email: string;\n  };\n}\n\nexport interface ProductFilters {\n  page?: number;\n  limit?: number;\n  type?: ProductType;\n  deliveryMethod?: DeliveryMethod;\n  minPrice?: number;\n  maxPrice?: number;\n  isActive?: boolean;\n}\n\nexport interface PaginatedProductsResponse {\n  products: CreatorProductResponse[];\n  meta: {\n    total: number;\n    page: number;\n    limit: number;\n    totalPages: number;\n  };\n}\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const productKeys = {\n  all: ['products'] as const,\n  lists: () => [...productKeys.all, 'list'] as const,\n  list: (filters?: ProductFilters) => [...productKeys.lists(), filters] as const,\n  details: () => [...productKeys.all, 'detail'] as const,\n  detail: (id: string) => [...productKeys.details(), id] as const,\n  slug: (slug: string) => [...productKeys.all, 'slug', slug] as const,\n  byCreator: (creatorId: string, filters?: ProductFilters) =>\n    [...productKeys.all, 'creator', creatorId, filters] as const,\n  bookings: () => [...productKeys.all, 'bookings'] as const,\n  myBookings: () => [...productKeys.bookings(), 'me'] as const,\n  creatorBookings: (creatorId: string) => [...productKeys.bookings(), 'creator', creatorId] as const,\n  bookingDetail: (bookingId: string) => [...productKeys.bookings(), 'detail', bookingId] as const,\n};\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\nexport function useProducts(\n  filters?: ProductFilters,\n  options?: Omit<UseQueryOptions<PaginatedProductsResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.list(filters),\n    queryFn: async (): Promise<PaginatedProductsResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/products', {\n        params: filters,\n      });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\nexport function useProduct(\n  id: string,\n  options?: Omit<UseQueryOptions<CreatorProductResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.detail(id),\n    queryFn: async (): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/products/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\nexport function useProductBySlug(\n  slug: string,\n  options?: Omit<UseQueryOptions<CreatorProductResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.slug(slug),\n    queryFn: async (): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/products/slug/${slug}`);\n      return response.data;\n    },\n    enabled: !!slug,\n    ...options,\n  });\n}\n\nexport function useCreatorProducts(\n  creatorId: string,\n  filters?: ProductFilters,\n  options?: Omit<UseQueryOptions<PaginatedProductsResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.byCreator(creatorId, filters),\n    queryFn: async (): Promise<PaginatedProductsResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/products`, {\n        params: filters,\n      });\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n\nexport function useMyProductBookings(\n  options?: Omit<UseQueryOptions<ProductBookingResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.myBookings(),\n    queryFn: async (): Promise<ProductBookingResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/users/me/product-bookings');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\nexport function useProductBooking(\n  bookingId: string,\n  options?: Omit<UseQueryOptions<ProductBookingResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.bookingDetail(bookingId),\n    queryFn: async (): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/users/me/product-bookings/${bookingId}`);\n      return response.data;\n    },\n    enabled: !!bookingId,\n    ...options,\n  });\n}\n\nexport function useCreatorBookings(\n  creatorId: string,\n  options?: Omit<UseQueryOptions<ProductBookingResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.creatorBookings(creatorId),\n    queryFn: async (): Promise<ProductBookingResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/products/bookings`);\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@growsober/sdk",
3
- "version": "1.0.23",
3
+ "version": "1.0.24",
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",
@@ -1,40 +1,14 @@
1
1
  import { useMutation, useQueryClient } from '@tanstack/react-query';
2
2
  import { getApiClient } from '../client';
3
- import { productKeys, CreatorProductResponse, ProductBookingResponse, ProductType, DeliveryMethod } from '../queries/products';
3
+ import { productKeys, CreatorProductResponse, ProductBookingResponse, CreateProductDto, UpdateProductDto } from '../queries/products';
4
4
  import { creatorKeys } from '../queries/creators';
5
5
 
6
6
  // ============================================================================
7
- // TYPES
7
+ // TYPES — request types derived from auto-generated OpenAPI DTOs
8
8
  // ============================================================================
9
9
 
10
- export interface CreateProductRequest {
11
- title: string;
12
- description?: string;
13
- imageUrl?: string;
14
- type?: ProductType;
15
- price: number;
16
- currency?: string;
17
- durationMinutes?: number;
18
- maxParticipants?: number;
19
- deliveryMethod?: DeliveryMethod;
20
- locationDetails?: string;
21
- slug?: string;
22
- }
23
-
24
- export interface UpdateProductRequest {
25
- title?: string;
26
- description?: string;
27
- imageUrl?: string;
28
- type?: ProductType;
29
- price?: number;
30
- currency?: string;
31
- durationMinutes?: number;
32
- maxParticipants?: number;
33
- deliveryMethod?: DeliveryMethod;
34
- locationDetails?: string;
35
- isActive?: boolean;
36
- isFeatured?: boolean;
37
- }
10
+ export type CreateProductRequest = CreateProductDto;
11
+ export type UpdateProductRequest = UpdateProductDto;
38
12
 
39
13
  export interface BookProductRequest {
40
14
  scheduledAt: string;
@@ -57,25 +31,6 @@ export interface CancelBookingRequest {
57
31
  // MUTATION HOOKS - PRODUCTS
58
32
  // ============================================================================
59
33
 
60
- /**
61
- * Create a new product for a creator
62
- *
63
- * @example
64
- * ```tsx
65
- * const { mutate: createProduct, isLoading } = useCreateProduct();
66
- *
67
- * createProduct({
68
- * creatorId: 'creator-123',
69
- * data: {
70
- * title: '1-on-1 Coaching Session',
71
- * description: 'Personal coaching session',
72
- * type: 'SESSION_1ON1',
73
- * price: 5000,
74
- * durationMinutes: 60,
75
- * },
76
- * });
77
- * ```
78
- */
79
34
  export function useCreateProduct() {
80
35
  const queryClient = useQueryClient();
81
36
 
@@ -98,23 +53,6 @@ export function useCreateProduct() {
98
53
  });
99
54
  }
100
55
 
101
- /**
102
- * Update an existing product
103
- *
104
- * @example
105
- * ```tsx
106
- * const { mutate: updateProduct, isLoading } = useUpdateProduct();
107
- *
108
- * updateProduct({
109
- * creatorId: 'creator-123',
110
- * productId: 'product-456',
111
- * data: {
112
- * price: 6000,
113
- * isActive: true,
114
- * },
115
- * });
116
- * ```
117
- */
118
56
  export function useUpdateProduct() {
119
57
  const queryClient = useQueryClient();
120
58
 
@@ -143,19 +81,6 @@ export function useUpdateProduct() {
143
81
  });
144
82
  }
145
83
 
146
- /**
147
- * Delete a product
148
- *
149
- * @example
150
- * ```tsx
151
- * const { mutate: deleteProduct, isLoading } = useDeleteProduct();
152
- *
153
- * deleteProduct({
154
- * creatorId: 'creator-123',
155
- * productId: 'product-456',
156
- * });
157
- * ```
158
- */
159
84
  export function useDeleteProduct() {
160
85
  const queryClient = useQueryClient();
161
86
 
@@ -182,23 +107,6 @@ export function useDeleteProduct() {
182
107
  // MUTATION HOOKS - BOOKINGS
183
108
  // ============================================================================
184
109
 
185
- /**
186
- * Book a product/session
187
- *
188
- * @example
189
- * ```tsx
190
- * const { mutate: bookProduct, isLoading } = useBookProduct();
191
- *
192
- * bookProduct({
193
- * productId: 'product-123',
194
- * data: {
195
- * scheduledAt: '2024-03-15T10:00:00Z',
196
- * timezone: 'Europe/London',
197
- * clientNotes: 'Looking forward to the session!',
198
- * },
199
- * });
200
- * ```
201
- */
202
110
  export function useBookProduct() {
203
111
  const queryClient = useQueryClient();
204
112
 
@@ -220,22 +128,6 @@ export function useBookProduct() {
220
128
  });
221
129
  }
222
130
 
223
- /**
224
- * Update a product booking
225
- *
226
- * @example
227
- * ```tsx
228
- * const { mutate: updateBooking, isLoading } = useUpdateProductBooking();
229
- *
230
- * updateBooking({
231
- * bookingId: 'booking-123',
232
- * data: {
233
- * scheduledAt: '2024-03-16T14:00:00Z',
234
- * clientNotes: 'Rescheduled due to conflict',
235
- * },
236
- * });
237
- * ```
238
- */
239
131
  export function useUpdateProductBooking() {
240
132
  const queryClient = useQueryClient();
241
133
 
@@ -257,25 +149,11 @@ export function useUpdateProductBooking() {
257
149
  onSuccess: (_, { bookingId }) => {
258
150
  queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });
259
151
  queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });
260
- // Also invalidate creator bookings as they see this
261
152
  queryClient.invalidateQueries({ queryKey: productKeys.bookings() });
262
153
  },
263
154
  });
264
155
  }
265
156
 
266
- /**
267
- * Cancel a product booking
268
- *
269
- * @example
270
- * ```tsx
271
- * const { mutate: cancelBooking, isLoading } = useCancelProductBooking();
272
- *
273
- * cancelBooking({
274
- * bookingId: 'booking-123',
275
- * data: { reason: 'Schedule conflict' },
276
- * });
277
- * ```
278
- */
279
157
  export function useCancelProductBooking() {
280
158
  const queryClient = useQueryClient();
281
159
 
@@ -302,16 +180,6 @@ export function useCancelProductBooking() {
302
180
  });
303
181
  }
304
182
 
305
- /**
306
- * Mark a booking as completed (creator only)
307
- *
308
- * @example
309
- * ```tsx
310
- * const { mutate: completeBooking, isLoading } = useCompleteProductBooking();
311
- *
312
- * completeBooking({ bookingId: 'booking-123' });
313
- * ```
314
- */
315
183
  export function useCompleteProductBooking() {
316
184
  const queryClient = useQueryClient();
317
185
 
@@ -344,23 +212,6 @@ export interface PaymentIntentResponse {
344
212
  paymentIntentId: string;
345
213
  }
346
214
 
347
- /**
348
- * Create a payment intent for a product booking
349
- * Use this with Stripe Elements to process payment
350
- *
351
- * @example
352
- * ```tsx
353
- * const { mutate: createPaymentIntent, data, isLoading } = useCreateProductPaymentIntent();
354
- *
355
- * // Create payment intent
356
- * createPaymentIntent({ bookingId: 'booking-123' });
357
- *
358
- * // Use clientSecret with Stripe Elements
359
- * if (data?.clientSecret) {
360
- * // Pass to Stripe PaymentElement
361
- * }
362
- * ```
363
- */
364
215
  export function useCreateProductPaymentIntent() {
365
216
  return useMutation({
366
217
  mutationFn: async ({
@@ -1,12 +1,16 @@
1
1
  import { useQuery, UseQueryOptions } from '@tanstack/react-query';
2
2
  import { getApiClient } from '../client';
3
+ import type { components } from '@growsober/types';
3
4
 
4
5
  // ============================================================================
5
- // TYPES
6
+ // TYPES — derived from auto-generated OpenAPI types
6
7
  // ============================================================================
7
8
 
8
- export type ProductType = 'SESSION_1ON1' | 'SESSION_GROUP' | 'PACKAGE' | 'WORKSHOP' | 'CONSULTATION';
9
- export type DeliveryMethod = 'VIDEO_CALL' | 'PHONE_CALL' | 'IN_PERSON' | 'HYBRID';
9
+ export type CreateProductDto = components['schemas']['CreateProductDto'];
10
+ export type UpdateProductDto = components['schemas']['UpdateProductDto'];
11
+
12
+ export type ProductType = CreateProductDto['type'];
13
+ export type DeliveryMethod = CreateProductDto['deliveryMethod'];
10
14
  export type BookingStatus = 'PENDING' | 'CONFIRMED' | 'CANCELLED' | 'COMPLETED';
11
15
  export type PaymentStatus = 'PENDING' | 'PAID' | 'REFUNDED' | 'FAILED';
12
16
 
@@ -17,6 +21,8 @@ export interface CreatorProductResponse {
17
21
  slug: string;
18
22
  description: string | null;
19
23
  imageUrl: string | null;
24
+ category: string | null;
25
+ tags: string[];
20
26
  type: ProductType;
21
27
  price: number;
22
28
  currency: string;
@@ -26,6 +32,8 @@ export interface CreatorProductResponse {
26
32
  locationDetails: string | null;
27
33
  isActive: boolean;
28
34
  isFeatured: boolean;
35
+ stripeProductId?: string | null;
36
+ stripePriceId?: string | null;
29
37
  createdAt: string;
30
38
  updatedAt: string;
31
39
  creator?: {
@@ -112,21 +120,6 @@ export const productKeys = {
112
120
  // QUERY HOOKS
113
121
  // ============================================================================
114
122
 
115
- /**
116
- * Get paginated list of all active products
117
- *
118
- * @param filters - Query parameters for filtering and pagination
119
- * @param options - TanStack Query options
120
- *
121
- * @example
122
- * ```tsx
123
- * const { data, isLoading } = useProducts({
124
- * page: 1,
125
- * limit: 20,
126
- * type: 'SESSION_1ON1',
127
- * });
128
- * ```
129
- */
130
123
  export function useProducts(
131
124
  filters?: ProductFilters,
132
125
  options?: Omit<UseQueryOptions<PaginatedProductsResponse>, 'queryKey' | 'queryFn'>
@@ -144,17 +137,6 @@ export function useProducts(
144
137
  });
145
138
  }
146
139
 
147
- /**
148
- * Get a single product by ID
149
- *
150
- * @param id - Product ID
151
- * @param options - TanStack Query options
152
- *
153
- * @example
154
- * ```tsx
155
- * const { data, isLoading } = useProduct('product-123');
156
- * ```
157
- */
158
140
  export function useProduct(
159
141
  id: string,
160
142
  options?: Omit<UseQueryOptions<CreatorProductResponse>, 'queryKey' | 'queryFn'>
@@ -171,17 +153,6 @@ export function useProduct(
171
153
  });
172
154
  }
173
155
 
174
- /**
175
- * Get a product by its slug
176
- *
177
- * @param slug - Product slug
178
- * @param options - TanStack Query options
179
- *
180
- * @example
181
- * ```tsx
182
- * const { data, isLoading } = useProductBySlug('1-on-1-coaching-abc123');
183
- * ```
184
- */
185
156
  export function useProductBySlug(
186
157
  slug: string,
187
158
  options?: Omit<UseQueryOptions<CreatorProductResponse>, 'queryKey' | 'queryFn'>
@@ -198,21 +169,6 @@ export function useProductBySlug(
198
169
  });
199
170
  }
200
171
 
201
- /**
202
- * Get products for a specific creator
203
- *
204
- * @param creatorId - Creator ID
205
- * @param filters - Query parameters for filtering
206
- * @param options - TanStack Query options
207
- *
208
- * @example
209
- * ```tsx
210
- * const { data, isLoading } = useCreatorProducts('creator-123', {
211
- * type: 'SESSION_1ON1',
212
- * isActive: true,
213
- * });
214
- * ```
215
- */
216
172
  export function useCreatorProducts(
217
173
  creatorId: string,
218
174
  filters?: ProductFilters,
@@ -232,16 +188,6 @@ export function useCreatorProducts(
232
188
  });
233
189
  }
234
190
 
235
- /**
236
- * Get current user's product bookings
237
- *
238
- * @param options - TanStack Query options
239
- *
240
- * @example
241
- * ```tsx
242
- * const { data, isLoading } = useMyProductBookings();
243
- * ```
244
- */
245
191
  export function useMyProductBookings(
246
192
  options?: Omit<UseQueryOptions<ProductBookingResponse[]>, 'queryKey' | 'queryFn'>
247
193
  ) {
@@ -256,17 +202,6 @@ export function useMyProductBookings(
256
202
  });
257
203
  }
258
204
 
259
- /**
260
- * Get a single product booking by ID
261
- *
262
- * @param bookingId - Booking ID
263
- * @param options - TanStack Query options
264
- *
265
- * @example
266
- * ```tsx
267
- * const { data, isLoading } = useProductBooking('booking-123');
268
- * ```
269
- */
270
205
  export function useProductBooking(
271
206
  bookingId: string,
272
207
  options?: Omit<UseQueryOptions<ProductBookingResponse>, 'queryKey' | 'queryFn'>
@@ -283,18 +218,6 @@ export function useProductBooking(
283
218
  });
284
219
  }
285
220
 
286
- /**
287
- * Get bookings for a creator's products (creator dashboard)
288
- *
289
- * @param creatorId - Creator ID
290
- * @param options - TanStack Query options
291
- *
292
- * @example
293
- * ```tsx
294
- * // For creator dashboard - see all bookings for their products
295
- * const { data, isLoading } = useCreatorBookings('creator-123');
296
- * ```
297
- */
298
221
  export function useCreatorBookings(
299
222
  creatorId: string,
300
223
  options?: Omit<UseQueryOptions<ProductBookingResponse[]>, 'queryKey' | 'queryFn'>