@growsober/sdk 1.0.9 → 1.0.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/api/mutations/badges.d.ts +89 -0
- package/dist/api/mutations/badges.js +130 -1
- package/dist/api/mutations/index.d.ts +1 -0
- package/dist/api/mutations/index.js +2 -1
- package/dist/api/mutations/venues.d.ts +126 -0
- package/dist/api/mutations/venues.js +110 -0
- package/package.json +1 -1
- package/src/api/mutations/badges.ts +168 -0
- package/src/api/mutations/index.ts +1 -0
- package/src/api/mutations/venues.ts +127 -0
|
@@ -113,4 +113,93 @@ export declare function useUpdatePartnerReward(businessId: string, options?: Omi
|
|
|
113
113
|
isActive: boolean;
|
|
114
114
|
}>;
|
|
115
115
|
}, unknown>;
|
|
116
|
+
interface UpdateRewardRequest {
|
|
117
|
+
isActive?: boolean;
|
|
118
|
+
title?: string;
|
|
119
|
+
description?: string;
|
|
120
|
+
code?: string;
|
|
121
|
+
redeemType?: 'IN_PERSON' | 'ONLINE' | 'BOTH';
|
|
122
|
+
maxRedemptions?: number;
|
|
123
|
+
perUserLimit?: number;
|
|
124
|
+
validFrom?: string;
|
|
125
|
+
validUntil?: string;
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Update a venue reward
|
|
129
|
+
*
|
|
130
|
+
* @param venueId - Venue ID
|
|
131
|
+
*
|
|
132
|
+
* @example
|
|
133
|
+
* ```tsx
|
|
134
|
+
* const updateReward = useUpdateVenueReward('venue-123');
|
|
135
|
+
*
|
|
136
|
+
* const handleUpdate = async (rewardId: string) => {
|
|
137
|
+
* await updateReward.mutateAsync({
|
|
138
|
+
* id: rewardId,
|
|
139
|
+
* data: { isActive: false },
|
|
140
|
+
* });
|
|
141
|
+
* };
|
|
142
|
+
* ```
|
|
143
|
+
*/
|
|
144
|
+
export declare function useUpdateVenueReward(venueId: string, options?: Omit<UseMutationOptions<unknown, Error, {
|
|
145
|
+
id: string;
|
|
146
|
+
data: UpdateRewardRequest;
|
|
147
|
+
}>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<unknown, Error, {
|
|
148
|
+
id: string;
|
|
149
|
+
data: UpdateRewardRequest;
|
|
150
|
+
}, unknown>;
|
|
151
|
+
/**
|
|
152
|
+
* Delete a venue reward
|
|
153
|
+
*
|
|
154
|
+
* @param venueId - Venue ID
|
|
155
|
+
*
|
|
156
|
+
* @example
|
|
157
|
+
* ```tsx
|
|
158
|
+
* const deleteReward = useDeleteVenueReward('venue-123');
|
|
159
|
+
*
|
|
160
|
+
* const handleDelete = async (rewardId: string) => {
|
|
161
|
+
* await deleteReward.mutateAsync(rewardId);
|
|
162
|
+
* };
|
|
163
|
+
* ```
|
|
164
|
+
*/
|
|
165
|
+
export declare function useDeleteVenueReward(venueId: string, options?: Omit<UseMutationOptions<unknown, Error, string>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<unknown, Error, string, unknown>;
|
|
166
|
+
/**
|
|
167
|
+
* Update a brand reward
|
|
168
|
+
*
|
|
169
|
+
* @param brandId - Brand ID
|
|
170
|
+
*
|
|
171
|
+
* @example
|
|
172
|
+
* ```tsx
|
|
173
|
+
* const updateReward = useUpdateBrandReward('brand-123');
|
|
174
|
+
*
|
|
175
|
+
* const handleUpdate = async (rewardId: string) => {
|
|
176
|
+
* await updateReward.mutateAsync({
|
|
177
|
+
* id: rewardId,
|
|
178
|
+
* data: { isActive: false },
|
|
179
|
+
* });
|
|
180
|
+
* };
|
|
181
|
+
* ```
|
|
182
|
+
*/
|
|
183
|
+
export declare function useUpdateBrandReward(brandId: string, options?: Omit<UseMutationOptions<unknown, Error, {
|
|
184
|
+
id: string;
|
|
185
|
+
data: UpdateRewardRequest;
|
|
186
|
+
}>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<unknown, Error, {
|
|
187
|
+
id: string;
|
|
188
|
+
data: UpdateRewardRequest;
|
|
189
|
+
}, unknown>;
|
|
190
|
+
/**
|
|
191
|
+
* Delete a brand reward
|
|
192
|
+
*
|
|
193
|
+
* @param brandId - Brand ID
|
|
194
|
+
*
|
|
195
|
+
* @example
|
|
196
|
+
* ```tsx
|
|
197
|
+
* const deleteReward = useDeleteBrandReward('brand-123');
|
|
198
|
+
*
|
|
199
|
+
* const handleDelete = async (rewardId: string) => {
|
|
200
|
+
* await deleteReward.mutateAsync(rewardId);
|
|
201
|
+
* };
|
|
202
|
+
* ```
|
|
203
|
+
*/
|
|
204
|
+
export declare function useDeleteBrandReward(brandId: string, options?: Omit<UseMutationOptions<unknown, Error, string>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<unknown, Error, string, unknown>;
|
|
116
205
|
export {};
|
|
@@ -5,6 +5,10 @@ exports.useCreatePartnerReward = useCreatePartnerReward;
|
|
|
5
5
|
exports.useCreateVenueReward = useCreateVenueReward;
|
|
6
6
|
exports.useCreateBrandReward = useCreateBrandReward;
|
|
7
7
|
exports.useUpdatePartnerReward = useUpdatePartnerReward;
|
|
8
|
+
exports.useUpdateVenueReward = useUpdateVenueReward;
|
|
9
|
+
exports.useDeleteVenueReward = useDeleteVenueReward;
|
|
10
|
+
exports.useUpdateBrandReward = useUpdateBrandReward;
|
|
11
|
+
exports.useDeleteBrandReward = useDeleteBrandReward;
|
|
8
12
|
const react_query_1 = require("@tanstack/react-query");
|
|
9
13
|
const client_1 = require("../client");
|
|
10
14
|
const badges_1 = require("../queries/badges");
|
|
@@ -174,4 +178,129 @@ function useUpdatePartnerReward(businessId, options) {
|
|
|
174
178
|
...options,
|
|
175
179
|
});
|
|
176
180
|
}
|
|
177
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badges.js","sourceRoot":"","sources":["../../../src/api/mutations/badges.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient, UseMutationOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { badgeKeys, rewardKeys } from '../queries/badges';\nimport type {\n  PartnerRewardResponse,\n  PartnerRewardRedemptionResponse,\n  CreatePartnerRewardRequest,\n} from '../types';\n\n// ============================================================================\n// REWARD MUTATION HOOKS\n// ============================================================================\n\n/**\n * Redeem a partner reward\n *\n * @example\n * ```tsx\n * const redeemReward = useRedeemReward();\n *\n * const handleRedeem = async (rewardId: string) => {\n *   await redeemReward.mutateAsync(rewardId);\n *   // Show success message\n * };\n * ```\n */\nexport function useRedeemReward(\n  options?: Omit<UseMutationOptions<PartnerRewardRedemptionResponse, Error, string>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (rewardId: string): Promise<PartnerRewardRedemptionResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/rewards/${rewardId}/redeem`);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      // Invalidate wallet, available and redeemed rewards\n      queryClient.invalidateQueries({ queryKey: rewardKeys.wallet() });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.redeemed() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a partner reward (for business dashboard)\n *\n * @param businessId - Business ID creating the reward\n *\n * @example\n * ```tsx\n * const createReward = useCreatePartnerReward('business-123');\n *\n * const handleCreate = async () => {\n *   await createReward.mutateAsync({\n *     badgeId: 'badge-week-warrior',\n *     title: 'Free Coffee',\n *     description: 'Show your badge for a free coffee',\n *   });\n * };\n * ```\n */\nexport function useCreatePartnerReward(\n  businessId: string,\n  options?: Omit<UseMutationOptions<PartnerRewardResponse, Error, CreatePartnerRewardRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreatePartnerRewardRequest): Promise<PartnerRewardResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/businesses/${businessId}/rewards`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forBusiness(businessId) });\n    },\n    ...options,\n  });\n}\n\n// ============================================================================\n// UNIFIED REWARD MUTATIONS (Venue & Brand)\n// ============================================================================\n\ninterface CreateRewardRequest {\n  badgeId: string;\n  title: string;\n  description?: string;\n  code?: string;\n  redeemType?: 'IN_PERSON' | 'ONLINE' | 'BOTH';\n  maxRedemptions?: number;\n  perUserLimit?: number;\n  validFrom?: string;\n  validUntil?: string;\n}\n\n/**\n * Create a reward for a venue\n *\n * @param venueId - Venue ID\n *\n * @example\n * ```tsx\n * const createReward = useCreateVenueReward('venue-123');\n *\n * const handleCreate = async () => {\n *   await createReward.mutateAsync({\n *     badgeId: 'badge-week-warrior',\n *     title: 'Free Coffee',\n *     description: 'Show your badge for a free coffee',\n *     redeemType: 'IN_PERSON',\n *   });\n * };\n * ```\n */\nexport function useCreateVenueReward(\n  venueId: string,\n  options?: Omit<UseMutationOptions<unknown, Error, CreateRewardRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateRewardRequest) => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/venues/${venueId}/rewards`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forVenue(venueId) });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a reward for a brand\n *\n * @param brandId - Brand ID\n *\n * @example\n * ```tsx\n * const createReward = useCreateBrandReward('brand-123');\n *\n * const handleCreate = async () => {\n *   await createReward.mutateAsync({\n *     badgeId: 'badge-week-warrior',\n *     title: '10% Off',\n *     description: 'Use code at checkout',\n *     code: 'SOBER10',\n *     redeemType: 'ONLINE',\n *   });\n * };\n * ```\n */\nexport function useCreateBrandReward(\n  brandId: string,\n  options?: Omit<UseMutationOptions<unknown, Error, CreateRewardRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateRewardRequest) => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/brands/${brandId}/rewards`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forBrand(brandId) });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a partner reward (for business dashboard)\n *\n * @param businessId - Business ID\n *\n * @example\n * ```tsx\n * const updateReward = useUpdatePartnerReward('business-123');\n *\n * const handleUpdate = async (rewardId: string) => {\n *   await updateReward.mutateAsync({\n *     id: rewardId,\n *     data: { title: 'Updated Title', isActive: false },\n *   });\n * };\n * ```\n */\nexport function useUpdatePartnerReward(\n  businessId: string,\n  options?: Omit<\n    UseMutationOptions<\n      PartnerRewardResponse,\n      Error,\n      { id: string; data: Partial<CreatePartnerRewardRequest & { isActive: boolean }> }\n    >,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      id,\n      data,\n    }: {\n      id: string;\n      data: Partial<CreatePartnerRewardRequest & { isActive: boolean }>;\n    }): Promise<PartnerRewardResponse> => {\n      const client = getApiClient();\n      const response = await client.patch(`/api/v1/businesses/${businessId}/rewards/${id}`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forBusiness(businessId) });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n    },\n    ...options,\n  });\n}\n"]}
|
|
181
|
+
/**
|
|
182
|
+
* Update a venue reward
|
|
183
|
+
*
|
|
184
|
+
* @param venueId - Venue ID
|
|
185
|
+
*
|
|
186
|
+
* @example
|
|
187
|
+
* ```tsx
|
|
188
|
+
* const updateReward = useUpdateVenueReward('venue-123');
|
|
189
|
+
*
|
|
190
|
+
* const handleUpdate = async (rewardId: string) => {
|
|
191
|
+
* await updateReward.mutateAsync({
|
|
192
|
+
* id: rewardId,
|
|
193
|
+
* data: { isActive: false },
|
|
194
|
+
* });
|
|
195
|
+
* };
|
|
196
|
+
* ```
|
|
197
|
+
*/
|
|
198
|
+
function useUpdateVenueReward(venueId, options) {
|
|
199
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
200
|
+
return (0, react_query_1.useMutation)({
|
|
201
|
+
mutationFn: async ({ id, data }) => {
|
|
202
|
+
const client = (0, client_1.getApiClient)();
|
|
203
|
+
const response = await client.patch(`/api/v1/venues/${venueId}/rewards/${id}`, data);
|
|
204
|
+
return response.data?.data || response.data;
|
|
205
|
+
},
|
|
206
|
+
onSuccess: () => {
|
|
207
|
+
queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.forVenue(venueId) });
|
|
208
|
+
queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.available() });
|
|
209
|
+
},
|
|
210
|
+
...options,
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
/**
|
|
214
|
+
* Delete a venue reward
|
|
215
|
+
*
|
|
216
|
+
* @param venueId - Venue ID
|
|
217
|
+
*
|
|
218
|
+
* @example
|
|
219
|
+
* ```tsx
|
|
220
|
+
* const deleteReward = useDeleteVenueReward('venue-123');
|
|
221
|
+
*
|
|
222
|
+
* const handleDelete = async (rewardId: string) => {
|
|
223
|
+
* await deleteReward.mutateAsync(rewardId);
|
|
224
|
+
* };
|
|
225
|
+
* ```
|
|
226
|
+
*/
|
|
227
|
+
function useDeleteVenueReward(venueId, options) {
|
|
228
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
229
|
+
return (0, react_query_1.useMutation)({
|
|
230
|
+
mutationFn: async (rewardId) => {
|
|
231
|
+
const client = (0, client_1.getApiClient)();
|
|
232
|
+
const response = await client.delete(`/api/v1/venues/${venueId}/rewards/${rewardId}`);
|
|
233
|
+
return response.data?.data || response.data;
|
|
234
|
+
},
|
|
235
|
+
onSuccess: () => {
|
|
236
|
+
queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.forVenue(venueId) });
|
|
237
|
+
queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.available() });
|
|
238
|
+
},
|
|
239
|
+
...options,
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
// ============================================================================
|
|
243
|
+
// BRAND REWARD MUTATIONS
|
|
244
|
+
// ============================================================================
|
|
245
|
+
/**
|
|
246
|
+
* Update a brand reward
|
|
247
|
+
*
|
|
248
|
+
* @param brandId - Brand ID
|
|
249
|
+
*
|
|
250
|
+
* @example
|
|
251
|
+
* ```tsx
|
|
252
|
+
* const updateReward = useUpdateBrandReward('brand-123');
|
|
253
|
+
*
|
|
254
|
+
* const handleUpdate = async (rewardId: string) => {
|
|
255
|
+
* await updateReward.mutateAsync({
|
|
256
|
+
* id: rewardId,
|
|
257
|
+
* data: { isActive: false },
|
|
258
|
+
* });
|
|
259
|
+
* };
|
|
260
|
+
* ```
|
|
261
|
+
*/
|
|
262
|
+
function useUpdateBrandReward(brandId, options) {
|
|
263
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
264
|
+
return (0, react_query_1.useMutation)({
|
|
265
|
+
mutationFn: async ({ id, data }) => {
|
|
266
|
+
const client = (0, client_1.getApiClient)();
|
|
267
|
+
const response = await client.patch(`/api/v1/brands/${brandId}/rewards/${id}`, data);
|
|
268
|
+
return response.data?.data || response.data;
|
|
269
|
+
},
|
|
270
|
+
onSuccess: () => {
|
|
271
|
+
queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.forBrand(brandId) });
|
|
272
|
+
queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.available() });
|
|
273
|
+
},
|
|
274
|
+
...options,
|
|
275
|
+
});
|
|
276
|
+
}
|
|
277
|
+
/**
|
|
278
|
+
* Delete a brand reward
|
|
279
|
+
*
|
|
280
|
+
* @param brandId - Brand ID
|
|
281
|
+
*
|
|
282
|
+
* @example
|
|
283
|
+
* ```tsx
|
|
284
|
+
* const deleteReward = useDeleteBrandReward('brand-123');
|
|
285
|
+
*
|
|
286
|
+
* const handleDelete = async (rewardId: string) => {
|
|
287
|
+
* await deleteReward.mutateAsync(rewardId);
|
|
288
|
+
* };
|
|
289
|
+
* ```
|
|
290
|
+
*/
|
|
291
|
+
function useDeleteBrandReward(brandId, options) {
|
|
292
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
293
|
+
return (0, react_query_1.useMutation)({
|
|
294
|
+
mutationFn: async (rewardId) => {
|
|
295
|
+
const client = (0, client_1.getApiClient)();
|
|
296
|
+
const response = await client.delete(`/api/v1/brands/${brandId}/rewards/${rewardId}`);
|
|
297
|
+
return response.data?.data || response.data;
|
|
298
|
+
},
|
|
299
|
+
onSuccess: () => {
|
|
300
|
+
queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.forBrand(brandId) });
|
|
301
|
+
queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.available() });
|
|
302
|
+
},
|
|
303
|
+
...options,
|
|
304
|
+
});
|
|
305
|
+
}
|
|
306
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badges.js","sourceRoot":"","sources":["../../../src/api/mutations/badges.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient, UseMutationOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { badgeKeys, rewardKeys } from '../queries/badges';\nimport type {\n  PartnerRewardResponse,\n  PartnerRewardRedemptionResponse,\n  CreatePartnerRewardRequest,\n} from '../types';\n\n// ============================================================================\n// REWARD MUTATION HOOKS\n// ============================================================================\n\n/**\n * Redeem a partner reward\n *\n * @example\n * ```tsx\n * const redeemReward = useRedeemReward();\n *\n * const handleRedeem = async (rewardId: string) => {\n *   await redeemReward.mutateAsync(rewardId);\n *   // Show success message\n * };\n * ```\n */\nexport function useRedeemReward(\n  options?: Omit<UseMutationOptions<PartnerRewardRedemptionResponse, Error, string>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (rewardId: string): Promise<PartnerRewardRedemptionResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/rewards/${rewardId}/redeem`);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      // Invalidate wallet, available and redeemed rewards\n      queryClient.invalidateQueries({ queryKey: rewardKeys.wallet() });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.redeemed() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a partner reward (for business dashboard)\n *\n * @param businessId - Business ID creating the reward\n *\n * @example\n * ```tsx\n * const createReward = useCreatePartnerReward('business-123');\n *\n * const handleCreate = async () => {\n *   await createReward.mutateAsync({\n *     badgeId: 'badge-week-warrior',\n *     title: 'Free Coffee',\n *     description: 'Show your badge for a free coffee',\n *   });\n * };\n * ```\n */\nexport function useCreatePartnerReward(\n  businessId: string,\n  options?: Omit<UseMutationOptions<PartnerRewardResponse, Error, CreatePartnerRewardRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreatePartnerRewardRequest): Promise<PartnerRewardResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/businesses/${businessId}/rewards`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forBusiness(businessId) });\n    },\n    ...options,\n  });\n}\n\n// ============================================================================\n// UNIFIED REWARD MUTATIONS (Venue & Brand)\n// ============================================================================\n\ninterface CreateRewardRequest {\n  badgeId: string;\n  title: string;\n  description?: string;\n  code?: string;\n  redeemType?: 'IN_PERSON' | 'ONLINE' | 'BOTH';\n  maxRedemptions?: number;\n  perUserLimit?: number;\n  validFrom?: string;\n  validUntil?: string;\n}\n\n/**\n * Create a reward for a venue\n *\n * @param venueId - Venue ID\n *\n * @example\n * ```tsx\n * const createReward = useCreateVenueReward('venue-123');\n *\n * const handleCreate = async () => {\n *   await createReward.mutateAsync({\n *     badgeId: 'badge-week-warrior',\n *     title: 'Free Coffee',\n *     description: 'Show your badge for a free coffee',\n *     redeemType: 'IN_PERSON',\n *   });\n * };\n * ```\n */\nexport function useCreateVenueReward(\n  venueId: string,\n  options?: Omit<UseMutationOptions<unknown, Error, CreateRewardRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateRewardRequest) => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/venues/${venueId}/rewards`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forVenue(venueId) });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a reward for a brand\n *\n * @param brandId - Brand ID\n *\n * @example\n * ```tsx\n * const createReward = useCreateBrandReward('brand-123');\n *\n * const handleCreate = async () => {\n *   await createReward.mutateAsync({\n *     badgeId: 'badge-week-warrior',\n *     title: '10% Off',\n *     description: 'Use code at checkout',\n *     code: 'SOBER10',\n *     redeemType: 'ONLINE',\n *   });\n * };\n * ```\n */\nexport function useCreateBrandReward(\n  brandId: string,\n  options?: Omit<UseMutationOptions<unknown, Error, CreateRewardRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateRewardRequest) => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/brands/${brandId}/rewards`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forBrand(brandId) });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a partner reward (for business dashboard)\n *\n * @param businessId - Business ID\n *\n * @example\n * ```tsx\n * const updateReward = useUpdatePartnerReward('business-123');\n *\n * const handleUpdate = async (rewardId: string) => {\n *   await updateReward.mutateAsync({\n *     id: rewardId,\n *     data: { title: 'Updated Title', isActive: false },\n *   });\n * };\n * ```\n */\nexport function useUpdatePartnerReward(\n  businessId: string,\n  options?: Omit<\n    UseMutationOptions<\n      PartnerRewardResponse,\n      Error,\n      { id: string; data: Partial<CreatePartnerRewardRequest & { isActive: boolean }> }\n    >,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      id,\n      data,\n    }: {\n      id: string;\n      data: Partial<CreatePartnerRewardRequest & { isActive: boolean }>;\n    }): Promise<PartnerRewardResponse> => {\n      const client = getApiClient();\n      const response = await client.patch(`/api/v1/businesses/${businessId}/rewards/${id}`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forBusiness(businessId) });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n    },\n    ...options,\n  });\n}\n\n// ============================================================================\n// VENUE REWARD MUTATIONS\n// ============================================================================\n\ninterface UpdateRewardRequest {\n  isActive?: boolean;\n  title?: string;\n  description?: string;\n  code?: string;\n  redeemType?: 'IN_PERSON' | 'ONLINE' | 'BOTH';\n  maxRedemptions?: number;\n  perUserLimit?: number;\n  validFrom?: string;\n  validUntil?: string;\n}\n\n/**\n * Update a venue reward\n *\n * @param venueId - Venue ID\n *\n * @example\n * ```tsx\n * const updateReward = useUpdateVenueReward('venue-123');\n *\n * const handleUpdate = async (rewardId: string) => {\n *   await updateReward.mutateAsync({\n *     id: rewardId,\n *     data: { isActive: false },\n *   });\n * };\n * ```\n */\nexport function useUpdateVenueReward(\n  venueId: string,\n  options?: Omit<\n    UseMutationOptions<unknown, Error, { id: string; data: UpdateRewardRequest }>,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ id, data }: { id: string; data: UpdateRewardRequest }) => {\n      const client = getApiClient();\n      const response = await client.patch(`/api/v1/venues/${venueId}/rewards/${id}`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forVenue(venueId) });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Delete a venue reward\n *\n * @param venueId - Venue ID\n *\n * @example\n * ```tsx\n * const deleteReward = useDeleteVenueReward('venue-123');\n *\n * const handleDelete = async (rewardId: string) => {\n *   await deleteReward.mutateAsync(rewardId);\n * };\n * ```\n */\nexport function useDeleteVenueReward(\n  venueId: string,\n  options?: Omit<UseMutationOptions<unknown, Error, string>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (rewardId: string) => {\n      const client = getApiClient();\n      const response = await client.delete(`/api/v1/venues/${venueId}/rewards/${rewardId}`);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forVenue(venueId) });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n    },\n    ...options,\n  });\n}\n\n// ============================================================================\n// BRAND REWARD MUTATIONS\n// ============================================================================\n\n/**\n * Update a brand reward\n *\n * @param brandId - Brand ID\n *\n * @example\n * ```tsx\n * const updateReward = useUpdateBrandReward('brand-123');\n *\n * const handleUpdate = async (rewardId: string) => {\n *   await updateReward.mutateAsync({\n *     id: rewardId,\n *     data: { isActive: false },\n *   });\n * };\n * ```\n */\nexport function useUpdateBrandReward(\n  brandId: string,\n  options?: Omit<\n    UseMutationOptions<unknown, Error, { id: string; data: UpdateRewardRequest }>,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ id, data }: { id: string; data: UpdateRewardRequest }) => {\n      const client = getApiClient();\n      const response = await client.patch(`/api/v1/brands/${brandId}/rewards/${id}`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forBrand(brandId) });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Delete a brand reward\n *\n * @param brandId - Brand ID\n *\n * @example\n * ```tsx\n * const deleteReward = useDeleteBrandReward('brand-123');\n *\n * const handleDelete = async (rewardId: string) => {\n *   await deleteReward.mutateAsync(rewardId);\n * };\n * ```\n */\nexport function useDeleteBrandReward(\n  brandId: string,\n  options?: Omit<UseMutationOptions<unknown, Error, string>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (rewardId: string) => {\n      const client = getApiClient();\n      const response = await client.delete(`/api/v1/brands/${brandId}/rewards/${rewardId}`);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forBrand(brandId) });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n    },\n    ...options,\n  });\n}\n"]}
|
|
@@ -41,4 +41,5 @@ __exportStar(require("./badges"), exports);
|
|
|
41
41
|
__exportStar(require("./creators"), exports);
|
|
42
42
|
__exportStar(require("./brands"), exports);
|
|
43
43
|
__exportStar(require("./products"), exports);
|
|
44
|
-
|
|
44
|
+
__exportStar(require("./venues"), exports);
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL211dGF0aW9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7R0FJRzs7Ozs7Ozs7Ozs7Ozs7OztBQUVILDBDQUF3QjtBQUN4Qix5Q0FBdUI7QUFDdkIsNkNBQTJCO0FBQzNCLDJDQUF5QjtBQUN6Qix5Q0FBdUI7QUFDdkIsNENBQTBCO0FBQzFCLHdDQUFzQjtBQUN0QixrREFBZ0M7QUFDaEMsMkNBQXlCO0FBQ3pCLGtEQUFnQztBQUNoQyw0Q0FBMEI7QUFDMUIsMENBQXdCO0FBQ3hCLHlDQUF1QjtBQUN2QixnREFBOEI7QUFDOUIsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQiwrQ0FBNkI7QUFDN0IsOENBQTRCO0FBQzVCLDJDQUF5QjtBQUN6Qiw2Q0FBMkI7QUFDM0IsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQiwyQ0FBeUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIE11dGF0aW9uIEhvb2tzXG4gKlxuICogUmUtZXhwb3J0cyBhbGwgbXV0YXRpb24gaG9va3MgZm9yIEFQSSBlbmRwb2ludHMuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9hZG1pbic7XG5leHBvcnQgKiBmcm9tICcuL2F1dGgnO1xuZXhwb3J0ICogZnJvbSAnLi9ib29raW5ncyc7XG5leHBvcnQgKiBmcm9tICcuL2V2ZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2h1YnMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWJyYXJ5JztcbmV4cG9ydCAqIGZyb20gJy4vbWFwJztcbmV4cG9ydCAqIGZyb20gJy4vbm90aWZpY2F0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL29mZmVycyc7XG5leHBvcnQgKiBmcm9tICcuL3N1YnNjcmlwdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdXBwb3J0JztcbmV4cG9ydCAqIGZyb20gJy4vdXNlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9qYWNrJztcbmV4cG9ydCAqIGZyb20gJy4vYW1iYXNzYWRvcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9ncm93OTAnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXRjaGluZyc7XG5leHBvcnQgKiBmcm9tICcuL2V2ZW50LWNoYXQnO1xuZXhwb3J0ICogZnJvbSAnLi91c2VyLXBpbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9iYWRnZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9jcmVhdG9ycyc7XG5leHBvcnQgKiBmcm9tICcuL2JyYW5kcyc7XG5leHBvcnQgKiBmcm9tICcuL3Byb2R1Y3RzJztcbmV4cG9ydCAqIGZyb20gJy4vdmVudWVzJztcbiJdfQ==
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { UseMutationOptions } from '@tanstack/react-query';
|
|
2
|
+
import type { VenueResponse, CreateVenueRequest, UpdateVenueRequest } from '../types';
|
|
3
|
+
/**
|
|
4
|
+
* Update a venue
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* ```tsx
|
|
8
|
+
* const updateVenue = useUpdateVenue({
|
|
9
|
+
* onSuccess: () => toast.success('Venue updated'),
|
|
10
|
+
* });
|
|
11
|
+
*
|
|
12
|
+
* const handleSave = () => {
|
|
13
|
+
* updateVenue.mutate({
|
|
14
|
+
* id: venueId,
|
|
15
|
+
* data: { name: 'Updated Name', hasAfDrinks: true },
|
|
16
|
+
* });
|
|
17
|
+
* };
|
|
18
|
+
* ```
|
|
19
|
+
*/
|
|
20
|
+
export declare function useUpdateVenue(options?: Omit<UseMutationOptions<VenueResponse, Error, {
|
|
21
|
+
id: string;
|
|
22
|
+
data: UpdateVenueRequest;
|
|
23
|
+
}>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
|
|
24
|
+
id: string;
|
|
25
|
+
appId: string;
|
|
26
|
+
name: string;
|
|
27
|
+
slug: string;
|
|
28
|
+
description?: Record<string, never>;
|
|
29
|
+
type: "COFFEE_SHOP" | "RESTAURANT" | "BAR" | "WELLNESS" | "VENUE" | "ACTIVITY" | "RETAIL" | "OTHER";
|
|
30
|
+
hasAfDrinks: boolean;
|
|
31
|
+
isAfVenue: boolean;
|
|
32
|
+
afHighlights: string[];
|
|
33
|
+
address?: Record<string, never>;
|
|
34
|
+
cityId?: Record<string, never>;
|
|
35
|
+
locationLat?: Record<string, never>;
|
|
36
|
+
locationLong?: Record<string, never>;
|
|
37
|
+
phone?: Record<string, never>;
|
|
38
|
+
email?: Record<string, never>;
|
|
39
|
+
website?: Record<string, never>;
|
|
40
|
+
instagram?: Record<string, never>;
|
|
41
|
+
profileImage?: Record<string, never>;
|
|
42
|
+
bannerImage?: Record<string, never>;
|
|
43
|
+
photos: string[];
|
|
44
|
+
openingHours?: Record<string, never>;
|
|
45
|
+
rating?: Record<string, never>;
|
|
46
|
+
reviewCount: number;
|
|
47
|
+
isActive: boolean;
|
|
48
|
+
isVerified: boolean;
|
|
49
|
+
isFeatured: boolean;
|
|
50
|
+
isFoundingPartner: boolean;
|
|
51
|
+
createdAt: string;
|
|
52
|
+
updatedAt: string;
|
|
53
|
+
}, Error, {
|
|
54
|
+
id: string;
|
|
55
|
+
data: UpdateVenueRequest;
|
|
56
|
+
}, unknown>;
|
|
57
|
+
/**
|
|
58
|
+
* Create a venue
|
|
59
|
+
*
|
|
60
|
+
* @example
|
|
61
|
+
* ```tsx
|
|
62
|
+
* const createVenue = useCreateVenue({
|
|
63
|
+
* onSuccess: (venue) => {
|
|
64
|
+
* toast.success('Venue created');
|
|
65
|
+
* router.push(`/venues/${venue.id}`);
|
|
66
|
+
* },
|
|
67
|
+
* });
|
|
68
|
+
*
|
|
69
|
+
* const handleCreate = () => {
|
|
70
|
+
* createVenue.mutate({
|
|
71
|
+
* name: 'My Venue',
|
|
72
|
+
* address: '123 Main St',
|
|
73
|
+
* hasAfDrinks: true,
|
|
74
|
+
* });
|
|
75
|
+
* };
|
|
76
|
+
* ```
|
|
77
|
+
*/
|
|
78
|
+
export declare function useCreateVenue(options?: Omit<UseMutationOptions<VenueResponse, Error, CreateVenueRequest>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
|
|
79
|
+
id: string;
|
|
80
|
+
appId: string;
|
|
81
|
+
name: string;
|
|
82
|
+
slug: string;
|
|
83
|
+
description?: Record<string, never>;
|
|
84
|
+
type: "COFFEE_SHOP" | "RESTAURANT" | "BAR" | "WELLNESS" | "VENUE" | "ACTIVITY" | "RETAIL" | "OTHER";
|
|
85
|
+
hasAfDrinks: boolean;
|
|
86
|
+
isAfVenue: boolean;
|
|
87
|
+
afHighlights: string[];
|
|
88
|
+
address?: Record<string, never>;
|
|
89
|
+
cityId?: Record<string, never>;
|
|
90
|
+
locationLat?: Record<string, never>;
|
|
91
|
+
locationLong?: Record<string, never>;
|
|
92
|
+
phone?: Record<string, never>;
|
|
93
|
+
email?: Record<string, never>;
|
|
94
|
+
website?: Record<string, never>;
|
|
95
|
+
instagram?: Record<string, never>;
|
|
96
|
+
profileImage?: Record<string, never>;
|
|
97
|
+
bannerImage?: Record<string, never>;
|
|
98
|
+
photos: string[];
|
|
99
|
+
openingHours?: Record<string, never>;
|
|
100
|
+
rating?: Record<string, never>;
|
|
101
|
+
reviewCount: number;
|
|
102
|
+
isActive: boolean;
|
|
103
|
+
isVerified: boolean;
|
|
104
|
+
isFeatured: boolean;
|
|
105
|
+
isFoundingPartner: boolean;
|
|
106
|
+
createdAt: string;
|
|
107
|
+
updatedAt: string;
|
|
108
|
+
}, Error, CreateVenueRequest, unknown>;
|
|
109
|
+
/**
|
|
110
|
+
* Delete a venue
|
|
111
|
+
*
|
|
112
|
+
* @example
|
|
113
|
+
* ```tsx
|
|
114
|
+
* const deleteVenue = useDeleteVenue({
|
|
115
|
+
* onSuccess: () => {
|
|
116
|
+
* toast.success('Venue deleted');
|
|
117
|
+
* router.push('/venues');
|
|
118
|
+
* },
|
|
119
|
+
* });
|
|
120
|
+
*
|
|
121
|
+
* const handleDelete = (venueId: string) => {
|
|
122
|
+
* deleteVenue.mutate(venueId);
|
|
123
|
+
* };
|
|
124
|
+
* ```
|
|
125
|
+
*/
|
|
126
|
+
export declare function useDeleteVenue(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<void, Error, string, unknown>;
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useUpdateVenue = useUpdateVenue;
|
|
4
|
+
exports.useCreateVenue = useCreateVenue;
|
|
5
|
+
exports.useDeleteVenue = useDeleteVenue;
|
|
6
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
7
|
+
const client_1 = require("../client");
|
|
8
|
+
const venues_1 = require("../queries/venues");
|
|
9
|
+
// ============================================================================
|
|
10
|
+
// VENUE MUTATION HOOKS
|
|
11
|
+
// ============================================================================
|
|
12
|
+
/**
|
|
13
|
+
* Update a venue
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```tsx
|
|
17
|
+
* const updateVenue = useUpdateVenue({
|
|
18
|
+
* onSuccess: () => toast.success('Venue updated'),
|
|
19
|
+
* });
|
|
20
|
+
*
|
|
21
|
+
* const handleSave = () => {
|
|
22
|
+
* updateVenue.mutate({
|
|
23
|
+
* id: venueId,
|
|
24
|
+
* data: { name: 'Updated Name', hasAfDrinks: true },
|
|
25
|
+
* });
|
|
26
|
+
* };
|
|
27
|
+
* ```
|
|
28
|
+
*/
|
|
29
|
+
function useUpdateVenue(options) {
|
|
30
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
31
|
+
return (0, react_query_1.useMutation)({
|
|
32
|
+
mutationFn: async ({ id, data, }) => {
|
|
33
|
+
const client = (0, client_1.getApiClient)();
|
|
34
|
+
const response = await client.patch(`/api/v1/venues/${id}`, data);
|
|
35
|
+
return response.data?.data || response.data;
|
|
36
|
+
},
|
|
37
|
+
onSuccess: (_, variables) => {
|
|
38
|
+
queryClient.invalidateQueries({ queryKey: venues_1.venueKeys.detail(variables.id) });
|
|
39
|
+
queryClient.invalidateQueries({ queryKey: venues_1.venueKeys.lists() });
|
|
40
|
+
},
|
|
41
|
+
...options,
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Create a venue
|
|
46
|
+
*
|
|
47
|
+
* @example
|
|
48
|
+
* ```tsx
|
|
49
|
+
* const createVenue = useCreateVenue({
|
|
50
|
+
* onSuccess: (venue) => {
|
|
51
|
+
* toast.success('Venue created');
|
|
52
|
+
* router.push(`/venues/${venue.id}`);
|
|
53
|
+
* },
|
|
54
|
+
* });
|
|
55
|
+
*
|
|
56
|
+
* const handleCreate = () => {
|
|
57
|
+
* createVenue.mutate({
|
|
58
|
+
* name: 'My Venue',
|
|
59
|
+
* address: '123 Main St',
|
|
60
|
+
* hasAfDrinks: true,
|
|
61
|
+
* });
|
|
62
|
+
* };
|
|
63
|
+
* ```
|
|
64
|
+
*/
|
|
65
|
+
function useCreateVenue(options) {
|
|
66
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
67
|
+
return (0, react_query_1.useMutation)({
|
|
68
|
+
mutationFn: async (data) => {
|
|
69
|
+
const client = (0, client_1.getApiClient)();
|
|
70
|
+
const response = await client.post('/api/v1/venues', data);
|
|
71
|
+
return response.data?.data || response.data;
|
|
72
|
+
},
|
|
73
|
+
onSuccess: () => {
|
|
74
|
+
queryClient.invalidateQueries({ queryKey: venues_1.venueKeys.lists() });
|
|
75
|
+
},
|
|
76
|
+
...options,
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Delete a venue
|
|
81
|
+
*
|
|
82
|
+
* @example
|
|
83
|
+
* ```tsx
|
|
84
|
+
* const deleteVenue = useDeleteVenue({
|
|
85
|
+
* onSuccess: () => {
|
|
86
|
+
* toast.success('Venue deleted');
|
|
87
|
+
* router.push('/venues');
|
|
88
|
+
* },
|
|
89
|
+
* });
|
|
90
|
+
*
|
|
91
|
+
* const handleDelete = (venueId: string) => {
|
|
92
|
+
* deleteVenue.mutate(venueId);
|
|
93
|
+
* };
|
|
94
|
+
* ```
|
|
95
|
+
*/
|
|
96
|
+
function useDeleteVenue(options) {
|
|
97
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
98
|
+
return (0, react_query_1.useMutation)({
|
|
99
|
+
mutationFn: async (venueId) => {
|
|
100
|
+
const client = (0, client_1.getApiClient)();
|
|
101
|
+
await client.delete(`/api/v1/venues/${venueId}`);
|
|
102
|
+
},
|
|
103
|
+
onSuccess: (_, venueId) => {
|
|
104
|
+
queryClient.invalidateQueries({ queryKey: venues_1.venueKeys.detail(venueId) });
|
|
105
|
+
queryClient.invalidateQueries({ queryKey: venues_1.venueKeys.lists() });
|
|
106
|
+
},
|
|
107
|
+
...options,
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVudWVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwaS9tdXRhdGlvbnMvdmVudWVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBMEJBLHdDQTBCQztBQXVCRCx3Q0FnQkM7QUFtQkQsd0NBZ0JDO0FBOUhELHVEQUF3RjtBQUN4RixzQ0FBeUM7QUFDekMsOENBQThDO0FBRzlDLCtFQUErRTtBQUMvRSx1QkFBdUI7QUFDdkIsK0VBQStFO0FBRS9FOzs7Ozs7Ozs7Ozs7Ozs7O0dBZ0JHO0FBQ0gsU0FBZ0IsY0FBYyxDQUM1QixPQUdDO0lBRUQsTUFBTSxXQUFXLEdBQUcsSUFBQSw0QkFBYyxHQUFFLENBQUM7SUFFckMsT0FBTyxJQUFBLHlCQUFXLEVBQUM7UUFDakIsVUFBVSxFQUFFLEtBQUssRUFBRSxFQUNqQixFQUFFLEVBQ0YsSUFBSSxHQUlMLEVBQTBCLEVBQUU7WUFDM0IsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUM7WUFDOUIsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsS0FBSyxDQUFDLGtCQUFrQixFQUFFLEVBQUUsRUFBRSxJQUFJLENBQUMsQ0FBQztZQUNsRSxPQUFPLFFBQVEsQ0FBQyxJQUFJLEVBQUUsSUFBSSxJQUFJLFFBQVEsQ0FBQyxJQUFJLENBQUM7UUFDOUMsQ0FBQztRQUNELFNBQVMsRUFBRSxDQUFDLENBQUMsRUFBRSxTQUFTLEVBQUUsRUFBRTtZQUMxQixXQUFXLENBQUMsaUJBQWlCLENBQUMsRUFBRSxRQUFRLEVBQUUsa0JBQVMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztZQUM1RSxXQUFXLENBQUMsaUJBQWlCLENBQUMsRUFBRSxRQUFRLEVBQUUsa0JBQVMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDakUsQ0FBQztRQUNELEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQkc7QUFDSCxTQUFnQixjQUFjLENBQzVCLE9BQTBGO0lBRTFGLE1BQU0sV0FBVyxHQUFHLElBQUEsNEJBQWMsR0FBRSxDQUFDO0lBRXJDLE9BQU8sSUFBQSx5QkFBVyxFQUFDO1FBQ2pCLFVBQVUsRUFBRSxLQUFLLEVBQUUsSUFBd0IsRUFBMEIsRUFBRTtZQUNyRSxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQztZQUM5QixNQUFNLFFBQVEsR0FBRyxNQUFNLE1BQU0sQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLENBQUM7WUFDM0QsT0FBTyxRQUFRLENBQUMsSUFBSSxFQUFFLElBQUksSUFBSSxRQUFRLENBQUMsSUFBSSxDQUFDO1FBQzlDLENBQUM7UUFDRCxTQUFTLEVBQUUsR0FBRyxFQUFFO1lBQ2QsV0FBVyxDQUFDLGlCQUFpQixDQUFDLEVBQUUsUUFBUSxFQUFFLGtCQUFTLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pFLENBQUM7UUFDRCxHQUFHLE9BQU87S0FDWCxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQ7Ozs7Ozs7Ozs7Ozs7Ozs7R0FnQkc7QUFDSCxTQUFnQixjQUFjLENBQzVCLE9BQXFFO0lBRXJFLE1BQU0sV0FBVyxHQUFHLElBQUEsNEJBQWMsR0FBRSxDQUFDO0lBRXJDLE9BQU8sSUFBQSx5QkFBVyxFQUFDO1FBQ2pCLFVBQVUsRUFBRSxLQUFLLEVBQUUsT0FBZSxFQUFpQixFQUFFO1lBQ25ELE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFDO1lBQzlCLE1BQU0sTUFBTSxDQUFDLE1BQU0sQ0FBQyxrQkFBa0IsT0FBTyxFQUFFLENBQUMsQ0FBQztRQUNuRCxDQUFDO1FBQ0QsU0FBUyxFQUFFLENBQUMsQ0FBQyxFQUFFLE9BQU8sRUFBRSxFQUFFO1lBQ3hCLFdBQVcsQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLFFBQVEsRUFBRSxrQkFBUyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDdkUsV0FBVyxDQUFDLGlCQUFpQixDQUFDLEVBQUUsUUFBUSxFQUFFLGtCQUFTLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pFLENBQUM7UUFDRCxHQUFHLE9BQU87S0FDWCxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlTXV0YXRpb24sIHVzZVF1ZXJ5Q2xpZW50LCBVc2VNdXRhdGlvbk9wdGlvbnMgfSBmcm9tICdAdGFuc3RhY2svcmVhY3QtcXVlcnknO1xuaW1wb3J0IHsgZ2V0QXBpQ2xpZW50IH0gZnJvbSAnLi4vY2xpZW50JztcbmltcG9ydCB7IHZlbnVlS2V5cyB9IGZyb20gJy4uL3F1ZXJpZXMvdmVudWVzJztcbmltcG9ydCB0eXBlIHsgVmVudWVSZXNwb25zZSwgQ3JlYXRlVmVudWVSZXF1ZXN0LCBVcGRhdGVWZW51ZVJlcXVlc3QgfSBmcm9tICcuLi90eXBlcyc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFZFTlVFIE1VVEFUSU9OIEhPT0tTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogVXBkYXRlIGEgdmVudWVcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHN4XG4gKiBjb25zdCB1cGRhdGVWZW51ZSA9IHVzZVVwZGF0ZVZlbnVlKHtcbiAqICAgb25TdWNjZXNzOiAoKSA9PiB0b2FzdC5zdWNjZXNzKCdWZW51ZSB1cGRhdGVkJyksXG4gKiB9KTtcbiAqXG4gKiBjb25zdCBoYW5kbGVTYXZlID0gKCkgPT4ge1xuICogICB1cGRhdGVWZW51ZS5tdXRhdGUoe1xuICogICAgIGlkOiB2ZW51ZUlkLFxuICogICAgIGRhdGE6IHsgbmFtZTogJ1VwZGF0ZWQgTmFtZScsIGhhc0FmRHJpbmtzOiB0cnVlIH0sXG4gKiAgIH0pO1xuICogfTtcbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlVXBkYXRlVmVudWUoXG4gIG9wdGlvbnM/OiBPbWl0PFxuICAgIFVzZU11dGF0aW9uT3B0aW9uczxWZW51ZVJlc3BvbnNlLCBFcnJvciwgeyBpZDogc3RyaW5nOyBkYXRhOiBVcGRhdGVWZW51ZVJlcXVlc3QgfT4sXG4gICAgJ211dGF0aW9uRm4nXG4gID5cbikge1xuICBjb25zdCBxdWVyeUNsaWVudCA9IHVzZVF1ZXJ5Q2xpZW50KCk7XG5cbiAgcmV0dXJuIHVzZU11dGF0aW9uKHtcbiAgICBtdXRhdGlvbkZuOiBhc3luYyAoe1xuICAgICAgaWQsXG4gICAgICBkYXRhLFxuICAgIH06IHtcbiAgICAgIGlkOiBzdHJpbmc7XG4gICAgICBkYXRhOiBVcGRhdGVWZW51ZVJlcXVlc3Q7XG4gICAgfSk6IFByb21pc2U8VmVudWVSZXNwb25zZT4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KCk7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5wYXRjaChgL2FwaS92MS92ZW51ZXMvJHtpZH1gLCBkYXRhKTtcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhPy5kYXRhIHx8IHJlc3BvbnNlLmRhdGE7XG4gICAgfSxcbiAgICBvblN1Y2Nlc3M6IChfLCB2YXJpYWJsZXMpID0+IHtcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHsgcXVlcnlLZXk6IHZlbnVlS2V5cy5kZXRhaWwodmFyaWFibGVzLmlkKSB9KTtcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHsgcXVlcnlLZXk6IHZlbnVlS2V5cy5saXN0cygpIH0pO1xuICAgIH0sXG4gICAgLi4ub3B0aW9ucyxcbiAgfSk7XG59XG5cbi8qKlxuICogQ3JlYXRlIGEgdmVudWVcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHN4XG4gKiBjb25zdCBjcmVhdGVWZW51ZSA9IHVzZUNyZWF0ZVZlbnVlKHtcbiAqICAgb25TdWNjZXNzOiAodmVudWUpID0+IHtcbiAqICAgICB0b2FzdC5zdWNjZXNzKCdWZW51ZSBjcmVhdGVkJyk7XG4gKiAgICAgcm91dGVyLnB1c2goYC92ZW51ZXMvJHt2ZW51ZS5pZH1gKTtcbiAqICAgfSxcbiAqIH0pO1xuICpcbiAqIGNvbnN0IGhhbmRsZUNyZWF0ZSA9ICgpID0+IHtcbiAqICAgY3JlYXRlVmVudWUubXV0YXRlKHtcbiAqICAgICBuYW1lOiAnTXkgVmVudWUnLFxuICogICAgIGFkZHJlc3M6ICcxMjMgTWFpbiBTdCcsXG4gKiAgICAgaGFzQWZEcmlua3M6IHRydWUsXG4gKiAgIH0pO1xuICogfTtcbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlQ3JlYXRlVmVudWUoXG4gIG9wdGlvbnM/OiBPbWl0PFVzZU11dGF0aW9uT3B0aW9uczxWZW51ZVJlc3BvbnNlLCBFcnJvciwgQ3JlYXRlVmVudWVSZXF1ZXN0PiwgJ211dGF0aW9uRm4nPlxuKSB7XG4gIGNvbnN0IHF1ZXJ5Q2xpZW50ID0gdXNlUXVlcnlDbGllbnQoKTtcblxuICByZXR1cm4gdXNlTXV0YXRpb24oe1xuICAgIG11dGF0aW9uRm46IGFzeW5jIChkYXRhOiBDcmVhdGVWZW51ZVJlcXVlc3QpOiBQcm9taXNlPFZlbnVlUmVzcG9uc2U+ID0+IHtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGdldEFwaUNsaWVudCgpO1xuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQucG9zdCgnL2FwaS92MS92ZW51ZXMnLCBkYXRhKTtcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhPy5kYXRhIHx8IHJlc3BvbnNlLmRhdGE7XG4gICAgfSxcbiAgICBvblN1Y2Nlc3M6ICgpID0+IHtcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHsgcXVlcnlLZXk6IHZlbnVlS2V5cy5saXN0cygpIH0pO1xuICAgIH0sXG4gICAgLi4ub3B0aW9ucyxcbiAgfSk7XG59XG5cbi8qKlxuICogRGVsZXRlIGEgdmVudWVcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHN4XG4gKiBjb25zdCBkZWxldGVWZW51ZSA9IHVzZURlbGV0ZVZlbnVlKHtcbiAqICAgb25TdWNjZXNzOiAoKSA9PiB7XG4gKiAgICAgdG9hc3Quc3VjY2VzcygnVmVudWUgZGVsZXRlZCcpO1xuICogICAgIHJvdXRlci5wdXNoKCcvdmVudWVzJyk7XG4gKiAgIH0sXG4gKiB9KTtcbiAqXG4gKiBjb25zdCBoYW5kbGVEZWxldGUgPSAodmVudWVJZDogc3RyaW5nKSA9PiB7XG4gKiAgIGRlbGV0ZVZlbnVlLm11dGF0ZSh2ZW51ZUlkKTtcbiAqIH07XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZURlbGV0ZVZlbnVlKFxuICBvcHRpb25zPzogT21pdDxVc2VNdXRhdGlvbk9wdGlvbnM8dm9pZCwgRXJyb3IsIHN0cmluZz4sICdtdXRhdGlvbkZuJz5cbikge1xuICBjb25zdCBxdWVyeUNsaWVudCA9IHVzZVF1ZXJ5Q2xpZW50KCk7XG5cbiAgcmV0dXJuIHVzZU11dGF0aW9uKHtcbiAgICBtdXRhdGlvbkZuOiBhc3luYyAodmVudWVJZDogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGF3YWl0IGNsaWVudC5kZWxldGUoYC9hcGkvdjEvdmVudWVzLyR7dmVudWVJZH1gKTtcbiAgICB9LFxuICAgIG9uU3VjY2VzczogKF8sIHZlbnVlSWQpID0+IHtcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHsgcXVlcnlLZXk6IHZlbnVlS2V5cy5kZXRhaWwodmVudWVJZCkgfSk7XG4gICAgICBxdWVyeUNsaWVudC5pbnZhbGlkYXRlUXVlcmllcyh7IHF1ZXJ5S2V5OiB2ZW51ZUtleXMubGlzdHMoKSB9KTtcbiAgICB9LFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pO1xufVxuIl19
|
package/package.json
CHANGED
|
@@ -226,3 +226,171 @@ export function useUpdatePartnerReward(
|
|
|
226
226
|
...options,
|
|
227
227
|
});
|
|
228
228
|
}
|
|
229
|
+
|
|
230
|
+
// ============================================================================
|
|
231
|
+
// VENUE REWARD MUTATIONS
|
|
232
|
+
// ============================================================================
|
|
233
|
+
|
|
234
|
+
interface UpdateRewardRequest {
|
|
235
|
+
isActive?: boolean;
|
|
236
|
+
title?: string;
|
|
237
|
+
description?: string;
|
|
238
|
+
code?: string;
|
|
239
|
+
redeemType?: 'IN_PERSON' | 'ONLINE' | 'BOTH';
|
|
240
|
+
maxRedemptions?: number;
|
|
241
|
+
perUserLimit?: number;
|
|
242
|
+
validFrom?: string;
|
|
243
|
+
validUntil?: string;
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
/**
|
|
247
|
+
* Update a venue reward
|
|
248
|
+
*
|
|
249
|
+
* @param venueId - Venue ID
|
|
250
|
+
*
|
|
251
|
+
* @example
|
|
252
|
+
* ```tsx
|
|
253
|
+
* const updateReward = useUpdateVenueReward('venue-123');
|
|
254
|
+
*
|
|
255
|
+
* const handleUpdate = async (rewardId: string) => {
|
|
256
|
+
* await updateReward.mutateAsync({
|
|
257
|
+
* id: rewardId,
|
|
258
|
+
* data: { isActive: false },
|
|
259
|
+
* });
|
|
260
|
+
* };
|
|
261
|
+
* ```
|
|
262
|
+
*/
|
|
263
|
+
export function useUpdateVenueReward(
|
|
264
|
+
venueId: string,
|
|
265
|
+
options?: Omit<
|
|
266
|
+
UseMutationOptions<unknown, Error, { id: string; data: UpdateRewardRequest }>,
|
|
267
|
+
'mutationFn'
|
|
268
|
+
>
|
|
269
|
+
) {
|
|
270
|
+
const queryClient = useQueryClient();
|
|
271
|
+
|
|
272
|
+
return useMutation({
|
|
273
|
+
mutationFn: async ({ id, data }: { id: string; data: UpdateRewardRequest }) => {
|
|
274
|
+
const client = getApiClient();
|
|
275
|
+
const response = await client.patch(`/api/v1/venues/${venueId}/rewards/${id}`, data);
|
|
276
|
+
return response.data?.data || response.data;
|
|
277
|
+
},
|
|
278
|
+
onSuccess: () => {
|
|
279
|
+
queryClient.invalidateQueries({ queryKey: rewardKeys.forVenue(venueId) });
|
|
280
|
+
queryClient.invalidateQueries({ queryKey: rewardKeys.available() });
|
|
281
|
+
},
|
|
282
|
+
...options,
|
|
283
|
+
});
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
/**
|
|
287
|
+
* Delete a venue reward
|
|
288
|
+
*
|
|
289
|
+
* @param venueId - Venue ID
|
|
290
|
+
*
|
|
291
|
+
* @example
|
|
292
|
+
* ```tsx
|
|
293
|
+
* const deleteReward = useDeleteVenueReward('venue-123');
|
|
294
|
+
*
|
|
295
|
+
* const handleDelete = async (rewardId: string) => {
|
|
296
|
+
* await deleteReward.mutateAsync(rewardId);
|
|
297
|
+
* };
|
|
298
|
+
* ```
|
|
299
|
+
*/
|
|
300
|
+
export function useDeleteVenueReward(
|
|
301
|
+
venueId: string,
|
|
302
|
+
options?: Omit<UseMutationOptions<unknown, Error, string>, 'mutationFn'>
|
|
303
|
+
) {
|
|
304
|
+
const queryClient = useQueryClient();
|
|
305
|
+
|
|
306
|
+
return useMutation({
|
|
307
|
+
mutationFn: async (rewardId: string) => {
|
|
308
|
+
const client = getApiClient();
|
|
309
|
+
const response = await client.delete(`/api/v1/venues/${venueId}/rewards/${rewardId}`);
|
|
310
|
+
return response.data?.data || response.data;
|
|
311
|
+
},
|
|
312
|
+
onSuccess: () => {
|
|
313
|
+
queryClient.invalidateQueries({ queryKey: rewardKeys.forVenue(venueId) });
|
|
314
|
+
queryClient.invalidateQueries({ queryKey: rewardKeys.available() });
|
|
315
|
+
},
|
|
316
|
+
...options,
|
|
317
|
+
});
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
// ============================================================================
|
|
321
|
+
// BRAND REWARD MUTATIONS
|
|
322
|
+
// ============================================================================
|
|
323
|
+
|
|
324
|
+
/**
|
|
325
|
+
* Update a brand reward
|
|
326
|
+
*
|
|
327
|
+
* @param brandId - Brand ID
|
|
328
|
+
*
|
|
329
|
+
* @example
|
|
330
|
+
* ```tsx
|
|
331
|
+
* const updateReward = useUpdateBrandReward('brand-123');
|
|
332
|
+
*
|
|
333
|
+
* const handleUpdate = async (rewardId: string) => {
|
|
334
|
+
* await updateReward.mutateAsync({
|
|
335
|
+
* id: rewardId,
|
|
336
|
+
* data: { isActive: false },
|
|
337
|
+
* });
|
|
338
|
+
* };
|
|
339
|
+
* ```
|
|
340
|
+
*/
|
|
341
|
+
export function useUpdateBrandReward(
|
|
342
|
+
brandId: string,
|
|
343
|
+
options?: Omit<
|
|
344
|
+
UseMutationOptions<unknown, Error, { id: string; data: UpdateRewardRequest }>,
|
|
345
|
+
'mutationFn'
|
|
346
|
+
>
|
|
347
|
+
) {
|
|
348
|
+
const queryClient = useQueryClient();
|
|
349
|
+
|
|
350
|
+
return useMutation({
|
|
351
|
+
mutationFn: async ({ id, data }: { id: string; data: UpdateRewardRequest }) => {
|
|
352
|
+
const client = getApiClient();
|
|
353
|
+
const response = await client.patch(`/api/v1/brands/${brandId}/rewards/${id}`, data);
|
|
354
|
+
return response.data?.data || response.data;
|
|
355
|
+
},
|
|
356
|
+
onSuccess: () => {
|
|
357
|
+
queryClient.invalidateQueries({ queryKey: rewardKeys.forBrand(brandId) });
|
|
358
|
+
queryClient.invalidateQueries({ queryKey: rewardKeys.available() });
|
|
359
|
+
},
|
|
360
|
+
...options,
|
|
361
|
+
});
|
|
362
|
+
}
|
|
363
|
+
|
|
364
|
+
/**
|
|
365
|
+
* Delete a brand reward
|
|
366
|
+
*
|
|
367
|
+
* @param brandId - Brand ID
|
|
368
|
+
*
|
|
369
|
+
* @example
|
|
370
|
+
* ```tsx
|
|
371
|
+
* const deleteReward = useDeleteBrandReward('brand-123');
|
|
372
|
+
*
|
|
373
|
+
* const handleDelete = async (rewardId: string) => {
|
|
374
|
+
* await deleteReward.mutateAsync(rewardId);
|
|
375
|
+
* };
|
|
376
|
+
* ```
|
|
377
|
+
*/
|
|
378
|
+
export function useDeleteBrandReward(
|
|
379
|
+
brandId: string,
|
|
380
|
+
options?: Omit<UseMutationOptions<unknown, Error, string>, 'mutationFn'>
|
|
381
|
+
) {
|
|
382
|
+
const queryClient = useQueryClient();
|
|
383
|
+
|
|
384
|
+
return useMutation({
|
|
385
|
+
mutationFn: async (rewardId: string) => {
|
|
386
|
+
const client = getApiClient();
|
|
387
|
+
const response = await client.delete(`/api/v1/brands/${brandId}/rewards/${rewardId}`);
|
|
388
|
+
return response.data?.data || response.data;
|
|
389
|
+
},
|
|
390
|
+
onSuccess: () => {
|
|
391
|
+
queryClient.invalidateQueries({ queryKey: rewardKeys.forBrand(brandId) });
|
|
392
|
+
queryClient.invalidateQueries({ queryKey: rewardKeys.available() });
|
|
393
|
+
},
|
|
394
|
+
...options,
|
|
395
|
+
});
|
|
396
|
+
}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { useMutation, useQueryClient, UseMutationOptions } from '@tanstack/react-query';
|
|
2
|
+
import { getApiClient } from '../client';
|
|
3
|
+
import { venueKeys } from '../queries/venues';
|
|
4
|
+
import type { VenueResponse, CreateVenueRequest, UpdateVenueRequest } from '../types';
|
|
5
|
+
|
|
6
|
+
// ============================================================================
|
|
7
|
+
// VENUE MUTATION HOOKS
|
|
8
|
+
// ============================================================================
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Update a venue
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* ```tsx
|
|
15
|
+
* const updateVenue = useUpdateVenue({
|
|
16
|
+
* onSuccess: () => toast.success('Venue updated'),
|
|
17
|
+
* });
|
|
18
|
+
*
|
|
19
|
+
* const handleSave = () => {
|
|
20
|
+
* updateVenue.mutate({
|
|
21
|
+
* id: venueId,
|
|
22
|
+
* data: { name: 'Updated Name', hasAfDrinks: true },
|
|
23
|
+
* });
|
|
24
|
+
* };
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
export function useUpdateVenue(
|
|
28
|
+
options?: Omit<
|
|
29
|
+
UseMutationOptions<VenueResponse, Error, { id: string; data: UpdateVenueRequest }>,
|
|
30
|
+
'mutationFn'
|
|
31
|
+
>
|
|
32
|
+
) {
|
|
33
|
+
const queryClient = useQueryClient();
|
|
34
|
+
|
|
35
|
+
return useMutation({
|
|
36
|
+
mutationFn: async ({
|
|
37
|
+
id,
|
|
38
|
+
data,
|
|
39
|
+
}: {
|
|
40
|
+
id: string;
|
|
41
|
+
data: UpdateVenueRequest;
|
|
42
|
+
}): Promise<VenueResponse> => {
|
|
43
|
+
const client = getApiClient();
|
|
44
|
+
const response = await client.patch(`/api/v1/venues/${id}`, data);
|
|
45
|
+
return response.data?.data || response.data;
|
|
46
|
+
},
|
|
47
|
+
onSuccess: (_, variables) => {
|
|
48
|
+
queryClient.invalidateQueries({ queryKey: venueKeys.detail(variables.id) });
|
|
49
|
+
queryClient.invalidateQueries({ queryKey: venueKeys.lists() });
|
|
50
|
+
},
|
|
51
|
+
...options,
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Create a venue
|
|
57
|
+
*
|
|
58
|
+
* @example
|
|
59
|
+
* ```tsx
|
|
60
|
+
* const createVenue = useCreateVenue({
|
|
61
|
+
* onSuccess: (venue) => {
|
|
62
|
+
* toast.success('Venue created');
|
|
63
|
+
* router.push(`/venues/${venue.id}`);
|
|
64
|
+
* },
|
|
65
|
+
* });
|
|
66
|
+
*
|
|
67
|
+
* const handleCreate = () => {
|
|
68
|
+
* createVenue.mutate({
|
|
69
|
+
* name: 'My Venue',
|
|
70
|
+
* address: '123 Main St',
|
|
71
|
+
* hasAfDrinks: true,
|
|
72
|
+
* });
|
|
73
|
+
* };
|
|
74
|
+
* ```
|
|
75
|
+
*/
|
|
76
|
+
export function useCreateVenue(
|
|
77
|
+
options?: Omit<UseMutationOptions<VenueResponse, Error, CreateVenueRequest>, 'mutationFn'>
|
|
78
|
+
) {
|
|
79
|
+
const queryClient = useQueryClient();
|
|
80
|
+
|
|
81
|
+
return useMutation({
|
|
82
|
+
mutationFn: async (data: CreateVenueRequest): Promise<VenueResponse> => {
|
|
83
|
+
const client = getApiClient();
|
|
84
|
+
const response = await client.post('/api/v1/venues', data);
|
|
85
|
+
return response.data?.data || response.data;
|
|
86
|
+
},
|
|
87
|
+
onSuccess: () => {
|
|
88
|
+
queryClient.invalidateQueries({ queryKey: venueKeys.lists() });
|
|
89
|
+
},
|
|
90
|
+
...options,
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
/**
|
|
95
|
+
* Delete a venue
|
|
96
|
+
*
|
|
97
|
+
* @example
|
|
98
|
+
* ```tsx
|
|
99
|
+
* const deleteVenue = useDeleteVenue({
|
|
100
|
+
* onSuccess: () => {
|
|
101
|
+
* toast.success('Venue deleted');
|
|
102
|
+
* router.push('/venues');
|
|
103
|
+
* },
|
|
104
|
+
* });
|
|
105
|
+
*
|
|
106
|
+
* const handleDelete = (venueId: string) => {
|
|
107
|
+
* deleteVenue.mutate(venueId);
|
|
108
|
+
* };
|
|
109
|
+
* ```
|
|
110
|
+
*/
|
|
111
|
+
export function useDeleteVenue(
|
|
112
|
+
options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>
|
|
113
|
+
) {
|
|
114
|
+
const queryClient = useQueryClient();
|
|
115
|
+
|
|
116
|
+
return useMutation({
|
|
117
|
+
mutationFn: async (venueId: string): Promise<void> => {
|
|
118
|
+
const client = getApiClient();
|
|
119
|
+
await client.delete(`/api/v1/venues/${venueId}`);
|
|
120
|
+
},
|
|
121
|
+
onSuccess: (_, venueId) => {
|
|
122
|
+
queryClient.invalidateQueries({ queryKey: venueKeys.detail(venueId) });
|
|
123
|
+
queryClient.invalidateQueries({ queryKey: venueKeys.lists() });
|
|
124
|
+
},
|
|
125
|
+
...options,
|
|
126
|
+
});
|
|
127
|
+
}
|