@growsober/sdk 1.0.5 → 1.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/__tests__/e2e.test.d.ts +30 -0
- package/dist/__tests__/e2e.test.js +959 -63
- package/dist/api/mutations/badges.d.ts +116 -0
- package/dist/api/mutations/badges.js +177 -0
- package/dist/api/mutations/brands.d.ts +251 -0
- package/dist/api/mutations/brands.js +242 -0
- package/dist/api/mutations/creators.d.ts +131 -0
- package/dist/api/mutations/creators.js +129 -0
- package/dist/api/mutations/event-chat.d.ts +2 -2
- package/dist/api/mutations/event-chat.js +9 -9
- package/dist/api/mutations/index.d.ts +4 -0
- package/dist/api/mutations/index.js +5 -1
- package/dist/api/mutations/jack.d.ts +29 -0
- package/dist/api/mutations/jack.js +41 -1
- package/dist/api/mutations/products.d.ts +175 -0
- package/dist/api/mutations/products.js +226 -0
- package/dist/api/mutations/support.d.ts +20 -1
- package/dist/api/mutations/support.js +36 -1
- package/dist/api/queries/badges.d.ts +221 -0
- package/dist/api/queries/badges.js +290 -0
- package/dist/api/queries/bookings.d.ts +1 -1
- package/dist/api/queries/brands.d.ts +248 -0
- package/dist/api/queries/brands.js +226 -0
- package/dist/api/queries/businesses.d.ts +61 -1
- package/dist/api/queries/businesses.js +27 -1
- package/dist/api/queries/creators.d.ts +332 -0
- package/dist/api/queries/creators.js +249 -0
- package/dist/api/queries/event-chat.d.ts +1 -1
- package/dist/api/queries/event-chat.js +4 -4
- package/dist/api/queries/events.d.ts +45 -0
- package/dist/api/queries/index.d.ts +5 -0
- package/dist/api/queries/index.js +6 -1
- package/dist/api/queries/jack.d.ts +80 -0
- package/dist/api/queries/jack.js +98 -1
- package/dist/api/queries/library.d.ts +8 -0
- package/dist/api/queries/products.d.ts +185 -0
- package/dist/api/queries/products.js +203 -0
- package/dist/api/queries/support.d.ts +46 -1
- package/dist/api/queries/support.js +48 -1
- package/dist/api/queries/venues.d.ts +304 -0
- package/dist/api/queries/venues.js +211 -0
- package/dist/api/types.d.ts +245 -0
- package/dist/api/types.js +6 -1
- package/dist/api/utils/eventGrouping.d.ts +104 -0
- package/dist/api/utils/eventGrouping.js +155 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +5 -1
- package/package.json +5 -2
- package/src/__tests__/e2e.test.ts +996 -64
- package/src/api/mutations/badges.ts +228 -0
- package/src/api/mutations/brands.ts +376 -0
- package/src/api/mutations/creators.ts +171 -0
- package/src/api/mutations/event-chat.ts +8 -8
- package/src/api/mutations/index.ts +4 -0
- package/src/api/mutations/jack.ts +50 -1
- package/src/api/mutations/products.ts +336 -0
- package/src/api/mutations/support.ts +44 -0
- package/src/api/queries/badges.ts +385 -0
- package/src/api/queries/brands.ts +281 -0
- package/src/api/queries/businesses.ts +30 -1
- package/src/api/queries/creators.ts +308 -0
- package/src/api/queries/event-chat.ts +3 -3
- package/src/api/queries/index.ts +5 -0
- package/src/api/queries/jack.ts +139 -1
- package/src/api/queries/products.ts +312 -0
- package/src/api/queries/support.ts +54 -0
- package/src/api/queries/venues.ts +271 -0
- package/src/api/types.ts +317 -1
- package/src/api/utils/eventGrouping.ts +181 -0
- package/src/index.ts +6 -0
|
@@ -0,0 +1,226 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useCreateProduct = useCreateProduct;
|
|
4
|
+
exports.useUpdateProduct = useUpdateProduct;
|
|
5
|
+
exports.useDeleteProduct = useDeleteProduct;
|
|
6
|
+
exports.useBookProduct = useBookProduct;
|
|
7
|
+
exports.useUpdateProductBooking = useUpdateProductBooking;
|
|
8
|
+
exports.useCancelProductBooking = useCancelProductBooking;
|
|
9
|
+
exports.useCompleteProductBooking = useCompleteProductBooking;
|
|
10
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
11
|
+
const client_1 = require("../client");
|
|
12
|
+
const products_1 = require("../queries/products");
|
|
13
|
+
// ============================================================================
|
|
14
|
+
// MUTATION HOOKS - PRODUCTS
|
|
15
|
+
// ============================================================================
|
|
16
|
+
/**
|
|
17
|
+
* Create a new product for a creator
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* ```tsx
|
|
21
|
+
* const { mutate: createProduct, isLoading } = useCreateProduct();
|
|
22
|
+
*
|
|
23
|
+
* createProduct({
|
|
24
|
+
* creatorId: 'creator-123',
|
|
25
|
+
* data: {
|
|
26
|
+
* title: '1-on-1 Coaching Session',
|
|
27
|
+
* description: 'Personal coaching session',
|
|
28
|
+
* type: 'SESSION_1ON1',
|
|
29
|
+
* price: 5000,
|
|
30
|
+
* durationMinutes: 60,
|
|
31
|
+
* },
|
|
32
|
+
* });
|
|
33
|
+
* ```
|
|
34
|
+
*/
|
|
35
|
+
function useCreateProduct() {
|
|
36
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
37
|
+
return (0, react_query_1.useMutation)({
|
|
38
|
+
mutationFn: async ({ creatorId, data, }) => {
|
|
39
|
+
const client = (0, client_1.getApiClient)();
|
|
40
|
+
const response = await client.post(`/api/v1/creators/${creatorId}/products`, data);
|
|
41
|
+
return response.data;
|
|
42
|
+
},
|
|
43
|
+
onSuccess: (_, { creatorId }) => {
|
|
44
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.byCreator(creatorId) });
|
|
45
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.lists() });
|
|
46
|
+
},
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Update an existing product
|
|
51
|
+
*
|
|
52
|
+
* @example
|
|
53
|
+
* ```tsx
|
|
54
|
+
* const { mutate: updateProduct, isLoading } = useUpdateProduct();
|
|
55
|
+
*
|
|
56
|
+
* updateProduct({
|
|
57
|
+
* creatorId: 'creator-123',
|
|
58
|
+
* productId: 'product-456',
|
|
59
|
+
* data: {
|
|
60
|
+
* price: 6000,
|
|
61
|
+
* isActive: true,
|
|
62
|
+
* },
|
|
63
|
+
* });
|
|
64
|
+
* ```
|
|
65
|
+
*/
|
|
66
|
+
function useUpdateProduct() {
|
|
67
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
68
|
+
return (0, react_query_1.useMutation)({
|
|
69
|
+
mutationFn: async ({ creatorId, productId, data, }) => {
|
|
70
|
+
const client = (0, client_1.getApiClient)();
|
|
71
|
+
const response = await client.put(`/api/v1/creators/${creatorId}/products/${productId}`, data);
|
|
72
|
+
return response.data;
|
|
73
|
+
},
|
|
74
|
+
onSuccess: (_, { creatorId, productId }) => {
|
|
75
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.detail(productId) });
|
|
76
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.byCreator(creatorId) });
|
|
77
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.lists() });
|
|
78
|
+
},
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Delete a product
|
|
83
|
+
*
|
|
84
|
+
* @example
|
|
85
|
+
* ```tsx
|
|
86
|
+
* const { mutate: deleteProduct, isLoading } = useDeleteProduct();
|
|
87
|
+
*
|
|
88
|
+
* deleteProduct({
|
|
89
|
+
* creatorId: 'creator-123',
|
|
90
|
+
* productId: 'product-456',
|
|
91
|
+
* });
|
|
92
|
+
* ```
|
|
93
|
+
*/
|
|
94
|
+
function useDeleteProduct() {
|
|
95
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
96
|
+
return (0, react_query_1.useMutation)({
|
|
97
|
+
mutationFn: async ({ creatorId, productId, }) => {
|
|
98
|
+
const client = (0, client_1.getApiClient)();
|
|
99
|
+
await client.delete(`/api/v1/creators/${creatorId}/products/${productId}`);
|
|
100
|
+
},
|
|
101
|
+
onSuccess: (_, { creatorId, productId }) => {
|
|
102
|
+
queryClient.removeQueries({ queryKey: products_1.productKeys.detail(productId) });
|
|
103
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.byCreator(creatorId) });
|
|
104
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.lists() });
|
|
105
|
+
},
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
// ============================================================================
|
|
109
|
+
// MUTATION HOOKS - BOOKINGS
|
|
110
|
+
// ============================================================================
|
|
111
|
+
/**
|
|
112
|
+
* Book a product/session
|
|
113
|
+
*
|
|
114
|
+
* @example
|
|
115
|
+
* ```tsx
|
|
116
|
+
* const { mutate: bookProduct, isLoading } = useBookProduct();
|
|
117
|
+
*
|
|
118
|
+
* bookProduct({
|
|
119
|
+
* productId: 'product-123',
|
|
120
|
+
* data: {
|
|
121
|
+
* scheduledAt: '2024-03-15T10:00:00Z',
|
|
122
|
+
* timezone: 'Europe/London',
|
|
123
|
+
* clientNotes: 'Looking forward to the session!',
|
|
124
|
+
* },
|
|
125
|
+
* });
|
|
126
|
+
* ```
|
|
127
|
+
*/
|
|
128
|
+
function useBookProduct() {
|
|
129
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
130
|
+
return (0, react_query_1.useMutation)({
|
|
131
|
+
mutationFn: async ({ productId, data, }) => {
|
|
132
|
+
const client = (0, client_1.getApiClient)();
|
|
133
|
+
const response = await client.post(`/api/v1/products/${productId}/book`, data);
|
|
134
|
+
return response.data;
|
|
135
|
+
},
|
|
136
|
+
onSuccess: () => {
|
|
137
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.myBookings() });
|
|
138
|
+
},
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
/**
|
|
142
|
+
* Update a product booking
|
|
143
|
+
*
|
|
144
|
+
* @example
|
|
145
|
+
* ```tsx
|
|
146
|
+
* const { mutate: updateBooking, isLoading } = useUpdateProductBooking();
|
|
147
|
+
*
|
|
148
|
+
* updateBooking({
|
|
149
|
+
* bookingId: 'booking-123',
|
|
150
|
+
* data: {
|
|
151
|
+
* scheduledAt: '2024-03-16T14:00:00Z',
|
|
152
|
+
* clientNotes: 'Rescheduled due to conflict',
|
|
153
|
+
* },
|
|
154
|
+
* });
|
|
155
|
+
* ```
|
|
156
|
+
*/
|
|
157
|
+
function useUpdateProductBooking() {
|
|
158
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
159
|
+
return (0, react_query_1.useMutation)({
|
|
160
|
+
mutationFn: async ({ bookingId, data, }) => {
|
|
161
|
+
const client = (0, client_1.getApiClient)();
|
|
162
|
+
const response = await client.put(`/api/v1/users/me/product-bookings/${bookingId}`, data);
|
|
163
|
+
return response.data;
|
|
164
|
+
},
|
|
165
|
+
onSuccess: (_, { bookingId }) => {
|
|
166
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.bookingDetail(bookingId) });
|
|
167
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.myBookings() });
|
|
168
|
+
// Also invalidate creator bookings as they see this
|
|
169
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.bookings() });
|
|
170
|
+
},
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Cancel a product booking
|
|
175
|
+
*
|
|
176
|
+
* @example
|
|
177
|
+
* ```tsx
|
|
178
|
+
* const { mutate: cancelBooking, isLoading } = useCancelProductBooking();
|
|
179
|
+
*
|
|
180
|
+
* cancelBooking({
|
|
181
|
+
* bookingId: 'booking-123',
|
|
182
|
+
* data: { reason: 'Schedule conflict' },
|
|
183
|
+
* });
|
|
184
|
+
* ```
|
|
185
|
+
*/
|
|
186
|
+
function useCancelProductBooking() {
|
|
187
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
188
|
+
return (0, react_query_1.useMutation)({
|
|
189
|
+
mutationFn: async ({ bookingId, data, }) => {
|
|
190
|
+
const client = (0, client_1.getApiClient)();
|
|
191
|
+
const response = await client.delete(`/api/v1/users/me/product-bookings/${bookingId}`, { data });
|
|
192
|
+
return response.data;
|
|
193
|
+
},
|
|
194
|
+
onSuccess: (_, { bookingId }) => {
|
|
195
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.bookingDetail(bookingId) });
|
|
196
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.myBookings() });
|
|
197
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.bookings() });
|
|
198
|
+
},
|
|
199
|
+
});
|
|
200
|
+
}
|
|
201
|
+
/**
|
|
202
|
+
* Mark a booking as completed (creator only)
|
|
203
|
+
*
|
|
204
|
+
* @example
|
|
205
|
+
* ```tsx
|
|
206
|
+
* const { mutate: completeBooking, isLoading } = useCompleteProductBooking();
|
|
207
|
+
*
|
|
208
|
+
* completeBooking({ bookingId: 'booking-123' });
|
|
209
|
+
* ```
|
|
210
|
+
*/
|
|
211
|
+
function useCompleteProductBooking() {
|
|
212
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
213
|
+
return (0, react_query_1.useMutation)({
|
|
214
|
+
mutationFn: async ({ bookingId, }) => {
|
|
215
|
+
const client = (0, client_1.getApiClient)();
|
|
216
|
+
const response = await client.post(`/api/v1/users/me/product-bookings/${bookingId}/complete`);
|
|
217
|
+
return response.data;
|
|
218
|
+
},
|
|
219
|
+
onSuccess: (_, { bookingId }) => {
|
|
220
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.bookingDetail(bookingId) });
|
|
221
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.myBookings() });
|
|
222
|
+
queryClient.invalidateQueries({ queryKey: products_1.productKeys.bookings() });
|
|
223
|
+
},
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.js","sourceRoot":"","sources":["../../../src/api/mutations/products.ts"],"names":[],"mappings":";;AA8EA,4CAoBC;AAmBD,4CA0BC;AAeD,4CAoBC;AAuBD,wCAmBC;AAkBD,0DAyBC;AAeD,0DAwBC;AAYD,8DAqBC;AA/UD,uDAAoE;AACpE,sCAAyC;AACzC,kDAA+H;AAqD/H,+EAA+E;AAC/E,4BAA4B;AAC5B,+EAA+E;AAE/E;;;;;;;;;;;;;;;;;;GAkBG;AACH,SAAgB,gBAAgB;IAC9B,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,EACT,IAAI,GAIL,EAAmC,EAAE;YACpC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,oBAAoB,SAAS,WAAW,EAAE,IAAI,CAAC,CAAC;YACnF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;YAC9B,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAC9E,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACnE,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,SAAgB,gBAAgB;IAC9B,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,EACT,SAAS,EACT,IAAI,GAKL,EAAmC,EAAE;YACpC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,oBAAoB,SAAS,aAAa,SAAS,EAAE,EACrD,IAAI,CACL,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,EAAE;YACzC,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAC3E,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAC9E,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACnE,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,SAAgB,gBAAgB;IAC9B,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,EACT,SAAS,GAIV,EAAiB,EAAE;YAClB,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,MAAM,CAAC,MAAM,CAAC,oBAAoB,SAAS,aAAa,SAAS,EAAE,CAAC,CAAC;QAC7E,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,EAAE;YACzC,WAAW,CAAC,aAAa,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YACvE,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAC9E,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACnE,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED,+EAA+E;AAC/E,4BAA4B;AAC5B,+EAA+E;AAE/E;;;;;;;;;;;;;;;;GAgBG;AACH,SAAgB,cAAc;IAC5B,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,EACT,IAAI,GAIL,EAAmC,EAAE;YACpC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,oBAAoB,SAAS,OAAO,EAAE,IAAI,CAAC,CAAC;YAC/E,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,GAAG,EAAE;YACd,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;QACxE,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;;;;GAeG;AACH,SAAgB,uBAAuB;IACrC,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,EACT,IAAI,GAIL,EAAmC,EAAE;YACpC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,qCAAqC,SAAS,EAAE,EAChD,IAAI,CACL,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;YAC9B,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAClF,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;YACtE,oDAAoD;YACpD,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QACtE,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,SAAgB,uBAAuB;IACrC,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,EACT,IAAI,GAIL,EAAmC,EAAE;YACpC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,MAAM,CAClC,qCAAqC,SAAS,EAAE,EAChD,EAAE,IAAI,EAAE,CACT,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;YAC9B,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAClF,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;YACtE,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QACtE,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,yBAAyB;IACvC,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,GAGV,EAAmC,EAAE;YACpC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAChC,qCAAqC,SAAS,WAAW,CAC1D,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;YAC9B,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAClF,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;YACtE,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QACtE,CAAC;KACF,CAAC,CAAC;AACL,CAAC","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"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
|
|
2
|
-
import type { CheckInResponse, CreateCheckInRequest, UpdateCheckInRequest, MoodLogResponse, LogMoodRequest, WinResponse, CreateWinRequest, HabitResponse, CreateHabitRequest, UpdateHabitRequest, ReflectionResponse, CreateReflectionRequest } from '../types';
|
|
2
|
+
import type { CheckInResponse, CreateCheckInRequest, UpdateCheckInRequest, MoodLogResponse, LogMoodRequest, WinResponse, CreateWinRequest, HabitResponse, CreateHabitRequest, UpdateHabitRequest, ReflectionResponse, CreateReflectionRequest, CravingLogResponse, LogCravingRequest } from '../types';
|
|
3
3
|
/**
|
|
4
4
|
* Create a daily check-in
|
|
5
5
|
*
|
|
@@ -163,3 +163,22 @@ export declare function useCompleteHabit(options?: Omit<UseMutationOptions<Habit
|
|
|
163
163
|
* ```
|
|
164
164
|
*/
|
|
165
165
|
export declare function useCreateReflection(options?: Omit<UseMutationOptions<ReflectionResponse, Error, CreateReflectionRequest>, 'mutationFn'>): UseMutationResult<ReflectionResponse, Error, CreateReflectionRequest>;
|
|
166
|
+
/**
|
|
167
|
+
* Log a craving
|
|
168
|
+
*
|
|
169
|
+
* @param options - TanStack Query mutation options
|
|
170
|
+
*
|
|
171
|
+
* @example
|
|
172
|
+
* ```tsx
|
|
173
|
+
* const { mutate, isPending } = useLogCraving();
|
|
174
|
+
*
|
|
175
|
+
* mutate({
|
|
176
|
+
* intensity: 4,
|
|
177
|
+
* trigger: 'Saw a beer ad',
|
|
178
|
+
* triggerType: 'ENVIRONMENT',
|
|
179
|
+
* copingUsed: ['deep_breathing', 'called_friend'],
|
|
180
|
+
* didResist: true
|
|
181
|
+
* });
|
|
182
|
+
* ```
|
|
183
|
+
*/
|
|
184
|
+
export declare function useLogCraving(options?: Omit<UseMutationOptions<CravingLogResponse, Error, LogCravingRequest>, 'mutationFn'>): UseMutationResult<CravingLogResponse, Error, LogCravingRequest>;
|
|
@@ -9,6 +9,7 @@ exports.useUpdateHabit = useUpdateHabit;
|
|
|
9
9
|
exports.useDeleteHabit = useDeleteHabit;
|
|
10
10
|
exports.useCompleteHabit = useCompleteHabit;
|
|
11
11
|
exports.useCreateReflection = useCreateReflection;
|
|
12
|
+
exports.useLogCraving = useLogCraving;
|
|
12
13
|
const react_query_1 = require("@tanstack/react-query");
|
|
13
14
|
const client_1 = require("../client");
|
|
14
15
|
const support_1 = require("../queries/support");
|
|
@@ -304,4 +305,38 @@ function useCreateReflection(options) {
|
|
|
304
305
|
...options,
|
|
305
306
|
});
|
|
306
307
|
}
|
|
307
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"support.js","sourceRoot":"","sources":["../../../src/api/mutations/support.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  useMutation,\n  useQueryClient,\n  UseMutationOptions,\n  UseMutationResult,\n} from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type {\n  CheckInResponse,\n  CreateCheckInRequest,\n  UpdateCheckInRequest,\n  MoodLogResponse,\n  LogMoodRequest,\n  WinResponse,\n  CreateWinRequest,\n  HabitResponse,\n  CreateHabitRequest,\n  UpdateHabitRequest,\n  ReflectionResponse,\n  CreateReflectionRequest,\n} from '../types';\nimport { supportKeys } from '../queries/support';\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a daily check-in\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCreateCheckIn();\n *\n * mutate({\n *   mood: 8,\n *   notes: 'Feeling great today!',\n *   triggers: ['stress'],\n *   gratitude: ['My support group']\n * });\n * ```\n */\nexport function useCreateCheckIn(\n  options?: Omit<\n    UseMutationOptions<CheckInResponse, Error, CreateCheckInRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<CheckInResponse, Error, CreateCheckInRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateCheckInRequest): Promise<CheckInResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/check-ins', data);\n      return response.data;\n    },\n    onSuccess: (newCheckIn, variables, context) => {\n      // Invalidate check-ins list and today's check-in\n      queryClient.invalidateQueries({ queryKey: supportKeys.checkIns() });\n      queryClient.invalidateQueries({ queryKey: supportKeys.checkInToday() });\n      queryClient.invalidateQueries({ queryKey: supportKeys.checkInStreak() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a daily check-in\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useUpdateCheckIn();\n *\n * mutate({\n *   id: 'checkin-123',\n *   data: {\n *     mood: 4,\n *     notes: 'Updated notes',\n *   }\n * });\n * ```\n */\nexport function useUpdateCheckIn(\n  options?: Omit<\n    UseMutationOptions<CheckInResponse, Error, { id: string; data: UpdateCheckInRequest }>,\n    'mutationFn'\n  >\n): UseMutationResult<CheckInResponse, Error, { id: string; data: UpdateCheckInRequest }> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ id, data }: { id: string; data: UpdateCheckInRequest }): Promise<CheckInResponse> => {\n      const client = getApiClient();\n      const response = await client.put(`/api/v1/support/check-ins/${id}`, data);\n      return response.data;\n    },\n    onSuccess: (updatedCheckIn, variables, context) => {\n      // Invalidate check-ins list and today's check-in\n      queryClient.invalidateQueries({ queryKey: supportKeys.checkIns() });\n      queryClient.invalidateQueries({ queryKey: supportKeys.checkInToday() });\n      queryClient.invalidateQueries({ queryKey: supportKeys.checkInStreak() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a mood log\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCreateMoodLog();\n *\n * mutate({\n *   mood: 7,\n *   notes: 'Feeling optimistic',\n *   activities: ['exercise', 'meditation']\n * });\n * ```\n */\nexport function useCreateMoodLog(\n  options?: Omit<\n    UseMutationOptions<MoodLogResponse, Error, LogMoodRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<MoodLogResponse, Error, LogMoodRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: LogMoodRequest): Promise<MoodLogResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/mood', data);\n      return response.data;\n    },\n    onSuccess: (newMoodLog, variables, context) => {\n      // Invalidate mood logs list\n      queryClient.invalidateQueries({ queryKey: supportKeys.moodLogs() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a win\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCreateWin();\n *\n * mutate({\n *   title: '30 days sober!',\n *   description: 'Hit my first milestone',\n *   category: 'sobriety'\n * });\n * ```\n */\nexport function useCreateWin(\n  options?: Omit<\n    UseMutationOptions<WinResponse, Error, CreateWinRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<WinResponse, Error, CreateWinRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateWinRequest): Promise<WinResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/wins', data);\n      return response.data;\n    },\n    onSuccess: (newWin, variables, context) => {\n      // Invalidate wins lists\n      queryClient.invalidateQueries({ queryKey: supportKeys.wins() });\n      queryClient.invalidateQueries({ queryKey: supportKeys.winsByCategory() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a habit\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCreateHabit();\n *\n * mutate({\n *   name: 'Morning meditation',\n *   description: '10 minutes of mindfulness',\n *   frequency: 'daily',\n *   targetDays: 7\n * });\n * ```\n */\nexport function useCreateHabit(\n  options?: Omit<\n    UseMutationOptions<HabitResponse, Error, CreateHabitRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<HabitResponse, Error, CreateHabitRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateHabitRequest): Promise<HabitResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/habits', data);\n      return response.data;\n    },\n    onSuccess: (newHabit, variables, context) => {\n      // Invalidate habits list\n      queryClient.invalidateQueries({ queryKey: supportKeys.habits() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a habit\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useUpdateHabit();\n *\n * mutate({\n *   id: 'habit-123',\n *   data: {\n *     name: 'Evening meditation',\n *     targetDays: 14\n *   }\n * });\n * ```\n */\nexport function useUpdateHabit(\n  options?: Omit<\n    UseMutationOptions<\n      HabitResponse,\n      Error,\n      { id: string; data: UpdateHabitRequest }\n    >,\n    'mutationFn'\n  >\n): UseMutationResult<HabitResponse, Error, { id: string; data: UpdateHabitRequest }> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      id,\n      data,\n    }: {\n      id: string;\n      data: UpdateHabitRequest;\n    }): Promise<HabitResponse> => {\n      const client = getApiClient();\n      const response = await client.put(`/api/v1/support/habits/${id}`, data);\n      return response.data;\n    },\n    onSuccess: (updatedHabit, variables, context) => {\n      // Invalidate habits list\n      queryClient.invalidateQueries({ queryKey: supportKeys.habits() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Delete a habit\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useDeleteHabit();\n *\n * mutate('habit-123');\n * ```\n */\nexport function useDeleteHabit(\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>\n): UseMutationResult<void, Error, string> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (id: string): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/support/habits/${id}`);\n    },\n    onSuccess: (data, habitId, context) => {\n      // Invalidate habits list\n      queryClient.invalidateQueries({ queryKey: supportKeys.habits() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Complete a habit for today\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCompleteHabit();\n *\n * mutate('habit-123');\n * ```\n */\nexport function useCompleteHabit(\n  options?: Omit<UseMutationOptions<HabitResponse, Error, string>, 'mutationFn'>\n): UseMutationResult<HabitResponse, Error, string> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (id: string): Promise<HabitResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/support/habits/${id}/complete`);\n      return response.data;\n    },\n    onSuccess: (completedHabit, habitId, context) => {\n      // Invalidate habits list to show updated completion status\n      queryClient.invalidateQueries({ queryKey: supportKeys.habits() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a reflection\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCreateReflection();\n *\n * mutate({\n *   content: 'Today I learned...',\n *   category: 'growth',\n *   mood: 8\n * });\n * ```\n */\nexport function useCreateReflection(\n  options?: Omit<\n    UseMutationOptions<ReflectionResponse, Error, CreateReflectionRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<ReflectionResponse, Error, CreateReflectionRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateReflectionRequest): Promise<ReflectionResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/reflections', data);\n      return response.data;\n    },\n    onSuccess: (newReflection, variables, context) => {\n      // Invalidate reflections list\n      queryClient.invalidateQueries({ queryKey: supportKeys.reflections() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n"]}
|
|
308
|
+
/**
|
|
309
|
+
* Log a craving
|
|
310
|
+
*
|
|
311
|
+
* @param options - TanStack Query mutation options
|
|
312
|
+
*
|
|
313
|
+
* @example
|
|
314
|
+
* ```tsx
|
|
315
|
+
* const { mutate, isPending } = useLogCraving();
|
|
316
|
+
*
|
|
317
|
+
* mutate({
|
|
318
|
+
* intensity: 4,
|
|
319
|
+
* trigger: 'Saw a beer ad',
|
|
320
|
+
* triggerType: 'ENVIRONMENT',
|
|
321
|
+
* copingUsed: ['deep_breathing', 'called_friend'],
|
|
322
|
+
* didResist: true
|
|
323
|
+
* });
|
|
324
|
+
* ```
|
|
325
|
+
*/
|
|
326
|
+
function useLogCraving(options) {
|
|
327
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
328
|
+
return (0, react_query_1.useMutation)({
|
|
329
|
+
mutationFn: async (data) => {
|
|
330
|
+
const client = (0, client_1.getApiClient)();
|
|
331
|
+
const response = await client.post('/api/v1/support/cravings', data);
|
|
332
|
+
return response.data;
|
|
333
|
+
},
|
|
334
|
+
onSuccess: (newCraving, variables, context) => {
|
|
335
|
+
// Invalidate cravings list and stats
|
|
336
|
+
queryClient.invalidateQueries({ queryKey: support_1.supportKeys.cravings() });
|
|
337
|
+
// Call user's onSuccess if provided
|
|
338
|
+
},
|
|
339
|
+
...options,
|
|
340
|
+
});
|
|
341
|
+
}
|
|
342
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"support.js","sourceRoot":"","sources":["../../../src/api/mutations/support.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  useMutation,\n  useQueryClient,\n  UseMutationOptions,\n  UseMutationResult,\n} from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type {\n  CheckInResponse,\n  CreateCheckInRequest,\n  UpdateCheckInRequest,\n  MoodLogResponse,\n  LogMoodRequest,\n  WinResponse,\n  CreateWinRequest,\n  HabitResponse,\n  CreateHabitRequest,\n  UpdateHabitRequest,\n  ReflectionResponse,\n  CreateReflectionRequest,\n  CravingLogResponse,\n  LogCravingRequest,\n} from '../types';\nimport { supportKeys } from '../queries/support';\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a daily check-in\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCreateCheckIn();\n *\n * mutate({\n *   mood: 8,\n *   notes: 'Feeling great today!',\n *   triggers: ['stress'],\n *   gratitude: ['My support group']\n * });\n * ```\n */\nexport function useCreateCheckIn(\n  options?: Omit<\n    UseMutationOptions<CheckInResponse, Error, CreateCheckInRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<CheckInResponse, Error, CreateCheckInRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateCheckInRequest): Promise<CheckInResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/check-ins', data);\n      return response.data;\n    },\n    onSuccess: (newCheckIn, variables, context) => {\n      // Invalidate check-ins list and today's check-in\n      queryClient.invalidateQueries({ queryKey: supportKeys.checkIns() });\n      queryClient.invalidateQueries({ queryKey: supportKeys.checkInToday() });\n      queryClient.invalidateQueries({ queryKey: supportKeys.checkInStreak() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a daily check-in\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useUpdateCheckIn();\n *\n * mutate({\n *   id: 'checkin-123',\n *   data: {\n *     mood: 4,\n *     notes: 'Updated notes',\n *   }\n * });\n * ```\n */\nexport function useUpdateCheckIn(\n  options?: Omit<\n    UseMutationOptions<CheckInResponse, Error, { id: string; data: UpdateCheckInRequest }>,\n    'mutationFn'\n  >\n): UseMutationResult<CheckInResponse, Error, { id: string; data: UpdateCheckInRequest }> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ id, data }: { id: string; data: UpdateCheckInRequest }): Promise<CheckInResponse> => {\n      const client = getApiClient();\n      const response = await client.put(`/api/v1/support/check-ins/${id}`, data);\n      return response.data;\n    },\n    onSuccess: (updatedCheckIn, variables, context) => {\n      // Invalidate check-ins list and today's check-in\n      queryClient.invalidateQueries({ queryKey: supportKeys.checkIns() });\n      queryClient.invalidateQueries({ queryKey: supportKeys.checkInToday() });\n      queryClient.invalidateQueries({ queryKey: supportKeys.checkInStreak() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a mood log\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCreateMoodLog();\n *\n * mutate({\n *   mood: 7,\n *   notes: 'Feeling optimistic',\n *   activities: ['exercise', 'meditation']\n * });\n * ```\n */\nexport function useCreateMoodLog(\n  options?: Omit<\n    UseMutationOptions<MoodLogResponse, Error, LogMoodRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<MoodLogResponse, Error, LogMoodRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: LogMoodRequest): Promise<MoodLogResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/mood', data);\n      return response.data;\n    },\n    onSuccess: (newMoodLog, variables, context) => {\n      // Invalidate mood logs list\n      queryClient.invalidateQueries({ queryKey: supportKeys.moodLogs() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a win\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCreateWin();\n *\n * mutate({\n *   title: '30 days sober!',\n *   description: 'Hit my first milestone',\n *   category: 'sobriety'\n * });\n * ```\n */\nexport function useCreateWin(\n  options?: Omit<\n    UseMutationOptions<WinResponse, Error, CreateWinRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<WinResponse, Error, CreateWinRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateWinRequest): Promise<WinResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/wins', data);\n      return response.data;\n    },\n    onSuccess: (newWin, variables, context) => {\n      // Invalidate wins lists\n      queryClient.invalidateQueries({ queryKey: supportKeys.wins() });\n      queryClient.invalidateQueries({ queryKey: supportKeys.winsByCategory() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a habit\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCreateHabit();\n *\n * mutate({\n *   name: 'Morning meditation',\n *   description: '10 minutes of mindfulness',\n *   frequency: 'daily',\n *   targetDays: 7\n * });\n * ```\n */\nexport function useCreateHabit(\n  options?: Omit<\n    UseMutationOptions<HabitResponse, Error, CreateHabitRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<HabitResponse, Error, CreateHabitRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateHabitRequest): Promise<HabitResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/habits', data);\n      return response.data;\n    },\n    onSuccess: (newHabit, variables, context) => {\n      // Invalidate habits list\n      queryClient.invalidateQueries({ queryKey: supportKeys.habits() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a habit\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useUpdateHabit();\n *\n * mutate({\n *   id: 'habit-123',\n *   data: {\n *     name: 'Evening meditation',\n *     targetDays: 14\n *   }\n * });\n * ```\n */\nexport function useUpdateHabit(\n  options?: Omit<\n    UseMutationOptions<\n      HabitResponse,\n      Error,\n      { id: string; data: UpdateHabitRequest }\n    >,\n    'mutationFn'\n  >\n): UseMutationResult<HabitResponse, Error, { id: string; data: UpdateHabitRequest }> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      id,\n      data,\n    }: {\n      id: string;\n      data: UpdateHabitRequest;\n    }): Promise<HabitResponse> => {\n      const client = getApiClient();\n      const response = await client.put(`/api/v1/support/habits/${id}`, data);\n      return response.data;\n    },\n    onSuccess: (updatedHabit, variables, context) => {\n      // Invalidate habits list\n      queryClient.invalidateQueries({ queryKey: supportKeys.habits() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Delete a habit\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useDeleteHabit();\n *\n * mutate('habit-123');\n * ```\n */\nexport function useDeleteHabit(\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>\n): UseMutationResult<void, Error, string> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (id: string): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/support/habits/${id}`);\n    },\n    onSuccess: (data, habitId, context) => {\n      // Invalidate habits list\n      queryClient.invalidateQueries({ queryKey: supportKeys.habits() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Complete a habit for today\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCompleteHabit();\n *\n * mutate('habit-123');\n * ```\n */\nexport function useCompleteHabit(\n  options?: Omit<UseMutationOptions<HabitResponse, Error, string>, 'mutationFn'>\n): UseMutationResult<HabitResponse, Error, string> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (id: string): Promise<HabitResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/support/habits/${id}/complete`);\n      return response.data;\n    },\n    onSuccess: (completedHabit, habitId, context) => {\n      // Invalidate habits list to show updated completion status\n      queryClient.invalidateQueries({ queryKey: supportKeys.habits() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a reflection\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCreateReflection();\n *\n * mutate({\n *   content: 'Today I learned...',\n *   category: 'growth',\n *   mood: 8\n * });\n * ```\n */\nexport function useCreateReflection(\n  options?: Omit<\n    UseMutationOptions<ReflectionResponse, Error, CreateReflectionRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<ReflectionResponse, Error, CreateReflectionRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateReflectionRequest): Promise<ReflectionResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/reflections', data);\n      return response.data;\n    },\n    onSuccess: (newReflection, variables, context) => {\n      // Invalidate reflections list\n      queryClient.invalidateQueries({ queryKey: supportKeys.reflections() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Log a craving\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useLogCraving();\n *\n * mutate({\n *   intensity: 4,\n *   trigger: 'Saw a beer ad',\n *   triggerType: 'ENVIRONMENT',\n *   copingUsed: ['deep_breathing', 'called_friend'],\n *   didResist: true\n * });\n * ```\n */\nexport function useLogCraving(\n  options?: Omit<\n    UseMutationOptions<CravingLogResponse, Error, LogCravingRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<CravingLogResponse, Error, LogCravingRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: LogCravingRequest): Promise<CravingLogResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/support/cravings', data);\n      return response.data;\n    },\n    onSuccess: (newCraving, variables, context) => {\n      // Invalidate cravings list and stats\n      queryClient.invalidateQueries({ queryKey: supportKeys.cravings() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n"]}
|
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
import { UseQueryOptions } from '@tanstack/react-query';
|
|
2
|
+
import type { BadgeResponse, UserBadgeResponse, BadgeWithProgress, PartnerRewardResponse, PartnerRewardRedemptionResponse, RewardResponse, UserWalletResponse } from '../types';
|
|
3
|
+
export declare const badgeKeys: {
|
|
4
|
+
all: readonly ["badges"];
|
|
5
|
+
lists: () => readonly ["badges", "list"];
|
|
6
|
+
list: (userId?: string) => readonly ["badges", "list", string | undefined];
|
|
7
|
+
detail: (id: string) => readonly ["badges", "detail", string];
|
|
8
|
+
user: (userId: string) => readonly ["badges", "user", string];
|
|
9
|
+
next: (userId: string) => readonly ["badges", "next", string];
|
|
10
|
+
};
|
|
11
|
+
export declare const rewardKeys: {
|
|
12
|
+
all: readonly ["rewards"];
|
|
13
|
+
available: () => readonly ["rewards", "available"];
|
|
14
|
+
forBadge: (badgeId: string) => readonly ["rewards", "badge", string];
|
|
15
|
+
forBusiness: (businessId: string) => readonly ["rewards", "business", string];
|
|
16
|
+
forVenue: (venueId: string) => readonly ["rewards", "venue", string];
|
|
17
|
+
forBrand: (brandId: string) => readonly ["rewards", "brand", string];
|
|
18
|
+
redeemed: () => readonly ["rewards", "redeemed"];
|
|
19
|
+
wallet: () => readonly ["rewards", "wallet"];
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* Get all available badges
|
|
23
|
+
*
|
|
24
|
+
* @example
|
|
25
|
+
* ```tsx
|
|
26
|
+
* const { data: badges } = useBadges();
|
|
27
|
+
* ```
|
|
28
|
+
*/
|
|
29
|
+
export declare function useBadges(options?: Omit<UseQueryOptions<BadgeResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
30
|
+
id: string;
|
|
31
|
+
appId: string;
|
|
32
|
+
name: string;
|
|
33
|
+
slug: string;
|
|
34
|
+
description?: Record<string, never>;
|
|
35
|
+
icon?: Record<string, never>;
|
|
36
|
+
type: "SOBRIETY_DAYS" | "EVENTS_ATTENDED" | "EVENTS_HOSTED" | "UNIQUE_VENUES" | "CHECK_IN_STREAK" | "WINS_LOGGED" | "REFLECTIONS_COUNT" | "JOURNALS_COUNT" | "MOOD_LOGS_COUNT" | "UNIQUE_WIN_CATEGORIES" | "SHORTCUTS_USED" | "ANY_ACTIVITY_STREAK" | "JACK_MESSAGES" | "VOICE_CALLS" | "MEMBER_SINCE" | "COMMUNITY_BUILDER" | "GROW90_GRADUATE" | "CUSTOM";
|
|
37
|
+
threshold?: Record<string, never>;
|
|
38
|
+
color?: Record<string, never>;
|
|
39
|
+
sortOrder: number;
|
|
40
|
+
isActive: boolean;
|
|
41
|
+
isSecret: boolean;
|
|
42
|
+
createdAt: string;
|
|
43
|
+
updatedAt: string;
|
|
44
|
+
}[], Error>;
|
|
45
|
+
/**
|
|
46
|
+
* Get a single badge by ID
|
|
47
|
+
*
|
|
48
|
+
* @param id - Badge ID
|
|
49
|
+
* @example
|
|
50
|
+
* ```tsx
|
|
51
|
+
* const { data: badge } = useBadge('badge-123');
|
|
52
|
+
* ```
|
|
53
|
+
*/
|
|
54
|
+
export declare function useBadge(id: string, options?: Omit<UseQueryOptions<BadgeResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
55
|
+
id: string;
|
|
56
|
+
appId: string;
|
|
57
|
+
name: string;
|
|
58
|
+
slug: string;
|
|
59
|
+
description?: Record<string, never>;
|
|
60
|
+
icon?: Record<string, never>;
|
|
61
|
+
type: "SOBRIETY_DAYS" | "EVENTS_ATTENDED" | "EVENTS_HOSTED" | "UNIQUE_VENUES" | "CHECK_IN_STREAK" | "WINS_LOGGED" | "REFLECTIONS_COUNT" | "JOURNALS_COUNT" | "MOOD_LOGS_COUNT" | "UNIQUE_WIN_CATEGORIES" | "SHORTCUTS_USED" | "ANY_ACTIVITY_STREAK" | "JACK_MESSAGES" | "VOICE_CALLS" | "MEMBER_SINCE" | "COMMUNITY_BUILDER" | "GROW90_GRADUATE" | "CUSTOM";
|
|
62
|
+
threshold?: Record<string, never>;
|
|
63
|
+
color?: Record<string, never>;
|
|
64
|
+
sortOrder: number;
|
|
65
|
+
isActive: boolean;
|
|
66
|
+
isSecret: boolean;
|
|
67
|
+
createdAt: string;
|
|
68
|
+
updatedAt: string;
|
|
69
|
+
}, Error>;
|
|
70
|
+
/**
|
|
71
|
+
* Get current user's earned badges
|
|
72
|
+
*
|
|
73
|
+
* @example
|
|
74
|
+
* ```tsx
|
|
75
|
+
* const { data: myBadges } = useMyBadges();
|
|
76
|
+
* ```
|
|
77
|
+
*/
|
|
78
|
+
export declare function useMyBadges(options?: Omit<UseQueryOptions<UserBadgeResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
79
|
+
id: string;
|
|
80
|
+
userId: string;
|
|
81
|
+
badgeId: string;
|
|
82
|
+
awardedAt: string;
|
|
83
|
+
note?: Record<string, never>;
|
|
84
|
+
badge: import("@growsober/types/dist/generated").components["schemas"]["BadgeResponseDto"];
|
|
85
|
+
}[], Error>;
|
|
86
|
+
/**
|
|
87
|
+
* Get next badges user can earn (with progress)
|
|
88
|
+
*
|
|
89
|
+
* @example
|
|
90
|
+
* ```tsx
|
|
91
|
+
* const { data: nextBadges } = useNextBadges();
|
|
92
|
+
* // nextBadges = [{ badge: {...}, currentProgress: 5, requiredProgress: 10, percentComplete: 50 }, ...]
|
|
93
|
+
* ```
|
|
94
|
+
*/
|
|
95
|
+
export declare function useNextBadges(options?: Omit<UseQueryOptions<BadgeWithProgress[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<BadgeWithProgress[], Error>;
|
|
96
|
+
/**
|
|
97
|
+
* Get all rewards available to the current user (based on earned badges)
|
|
98
|
+
*
|
|
99
|
+
* @example
|
|
100
|
+
* ```tsx
|
|
101
|
+
* const { data: rewards } = useAvailableRewards();
|
|
102
|
+
* ```
|
|
103
|
+
*/
|
|
104
|
+
export declare function useAvailableRewards(options?: Omit<UseQueryOptions<PartnerRewardResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PartnerRewardResponse[], Error>;
|
|
105
|
+
/**
|
|
106
|
+
* Get rewards for a specific badge
|
|
107
|
+
*
|
|
108
|
+
* @param badgeId - Badge ID
|
|
109
|
+
* @example
|
|
110
|
+
* ```tsx
|
|
111
|
+
* const { data: rewards } = useRewardsForBadge('badge-123');
|
|
112
|
+
* ```
|
|
113
|
+
*/
|
|
114
|
+
export declare function useRewardsForBadge(badgeId: string, options?: Omit<UseQueryOptions<PartnerRewardResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PartnerRewardResponse[], Error>;
|
|
115
|
+
/**
|
|
116
|
+
* Get rewards offered by a specific business
|
|
117
|
+
*
|
|
118
|
+
* @param businessId - Business ID
|
|
119
|
+
* @example
|
|
120
|
+
* ```tsx
|
|
121
|
+
* const { data: rewards } = useBusinessRewards('business-123');
|
|
122
|
+
* ```
|
|
123
|
+
*/
|
|
124
|
+
export declare function useBusinessRewards(businessId: string, options?: Omit<UseQueryOptions<PartnerRewardResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PartnerRewardResponse[], Error>;
|
|
125
|
+
/**
|
|
126
|
+
* Get user's redeemed rewards
|
|
127
|
+
*
|
|
128
|
+
* @example
|
|
129
|
+
* ```tsx
|
|
130
|
+
* const { data: redeemed } = useRedeemedRewards();
|
|
131
|
+
* ```
|
|
132
|
+
*/
|
|
133
|
+
export declare function useRedeemedRewards(options?: Omit<UseQueryOptions<PartnerRewardRedemptionResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PartnerRewardRedemptionResponse[], Error>;
|
|
134
|
+
/**
|
|
135
|
+
* Wallet reward card with QR token for redemption
|
|
136
|
+
*/
|
|
137
|
+
export interface WalletReward {
|
|
138
|
+
id: string;
|
|
139
|
+
title: string;
|
|
140
|
+
description: string | null;
|
|
141
|
+
code: string | null;
|
|
142
|
+
validUntil: string | null;
|
|
143
|
+
badge: {
|
|
144
|
+
id: string;
|
|
145
|
+
name: string;
|
|
146
|
+
slug: string;
|
|
147
|
+
icon: string | null;
|
|
148
|
+
};
|
|
149
|
+
business: {
|
|
150
|
+
id: string;
|
|
151
|
+
name: string;
|
|
152
|
+
profileImage: string | null;
|
|
153
|
+
address: string | null;
|
|
154
|
+
};
|
|
155
|
+
}
|
|
156
|
+
export interface WalletRedemption {
|
|
157
|
+
id: string;
|
|
158
|
+
redeemedAt: string;
|
|
159
|
+
verifiedAt: string | null;
|
|
160
|
+
qrToken: string;
|
|
161
|
+
partnerReward: WalletReward;
|
|
162
|
+
}
|
|
163
|
+
export interface WalletBadge {
|
|
164
|
+
id: string;
|
|
165
|
+
badgeId: string;
|
|
166
|
+
userId: string;
|
|
167
|
+
awardedAt: string;
|
|
168
|
+
note: string | null;
|
|
169
|
+
badge: BadgeResponse;
|
|
170
|
+
availableRewards: WalletReward[];
|
|
171
|
+
redeemedRewards: WalletRedemption[];
|
|
172
|
+
}
|
|
173
|
+
export interface WalletResponse {
|
|
174
|
+
badges: WalletBadge[];
|
|
175
|
+
stats: {
|
|
176
|
+
totalBadges: number;
|
|
177
|
+
totalAvailableRewards: number;
|
|
178
|
+
totalRedeemedRewards: number;
|
|
179
|
+
};
|
|
180
|
+
}
|
|
181
|
+
/**
|
|
182
|
+
* Get user's wallet - all earned badges with available and redeemed rewards
|
|
183
|
+
* This is the main data source for the Rewards tab
|
|
184
|
+
*
|
|
185
|
+
* @example
|
|
186
|
+
* ```tsx
|
|
187
|
+
* const { data: wallet } = useRewardsWallet();
|
|
188
|
+
* // wallet.badges = [{ badge: {...}, availableRewards: [...], redeemedRewards: [...] }, ...]
|
|
189
|
+
* // wallet.stats = { totalBadges: 5, totalAvailableRewards: 3, totalRedeemedRewards: 2 }
|
|
190
|
+
* ```
|
|
191
|
+
*/
|
|
192
|
+
export declare function useRewardsWallet(options?: Omit<UseQueryOptions<WalletResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<WalletResponse, Error>;
|
|
193
|
+
/**
|
|
194
|
+
* Get rewards for a specific venue (unified reward model)
|
|
195
|
+
*
|
|
196
|
+
* @param venueId - Venue ID
|
|
197
|
+
* @example
|
|
198
|
+
* ```tsx
|
|
199
|
+
* const { data: rewards } = useVenueRewards('venue-123');
|
|
200
|
+
* ```
|
|
201
|
+
*/
|
|
202
|
+
export declare function useVenueRewards(venueId: string, options?: Omit<UseQueryOptions<RewardResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<RewardResponse[], Error>;
|
|
203
|
+
/**
|
|
204
|
+
* Get rewards for a specific brand (unified reward model)
|
|
205
|
+
*
|
|
206
|
+
* @param brandId - Brand ID
|
|
207
|
+
* @example
|
|
208
|
+
* ```tsx
|
|
209
|
+
* const { data: rewards } = useBrandRewardsQuery('brand-123');
|
|
210
|
+
* ```
|
|
211
|
+
*/
|
|
212
|
+
export declare function useBrandRewardsQuery(brandId: string, options?: Omit<UseQueryOptions<RewardResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<RewardResponse[], Error>;
|
|
213
|
+
/**
|
|
214
|
+
* Get unified wallet with venue and brand rewards
|
|
215
|
+
*
|
|
216
|
+
* @example
|
|
217
|
+
* ```tsx
|
|
218
|
+
* const { data: wallet } = useUnifiedWallet();
|
|
219
|
+
* ```
|
|
220
|
+
*/
|
|
221
|
+
export declare function useUnifiedWallet(options?: Omit<UseQueryOptions<UserWalletResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<UserWalletResponse, Error>;
|