@growsober/sdk 1.0.0
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/README.md +276 -0
- package/dist/__tests__/e2e.test.d.ts +7 -0
- package/dist/__tests__/e2e.test.js +472 -0
- package/dist/api/client.d.ts +11 -0
- package/dist/api/client.js +61 -0
- package/dist/api/mutations/admin.d.ts +167 -0
- package/dist/api/mutations/admin.js +326 -0
- package/dist/api/mutations/ambassadors.d.ts +52 -0
- package/dist/api/mutations/ambassadors.js +148 -0
- package/dist/api/mutations/auth.d.ts +267 -0
- package/dist/api/mutations/auth.js +332 -0
- package/dist/api/mutations/bookings.d.ts +59 -0
- package/dist/api/mutations/bookings.js +143 -0
- package/dist/api/mutations/event-chat.d.ts +35 -0
- package/dist/api/mutations/event-chat.js +147 -0
- package/dist/api/mutations/events.d.ts +87 -0
- package/dist/api/mutations/events.js +205 -0
- package/dist/api/mutations/grow90.d.ts +36 -0
- package/dist/api/mutations/grow90.js +132 -0
- package/dist/api/mutations/hubs.d.ts +111 -0
- package/dist/api/mutations/hubs.js +240 -0
- package/dist/api/mutations/index.d.ts +22 -0
- package/dist/api/mutations/index.js +39 -0
- package/dist/api/mutations/jack.d.ts +61 -0
- package/dist/api/mutations/jack.js +104 -0
- package/dist/api/mutations/library.d.ts +67 -0
- package/dist/api/mutations/library.js +168 -0
- package/dist/api/mutations/map.d.ts +153 -0
- package/dist/api/mutations/map.js +181 -0
- package/dist/api/mutations/matching.d.ts +130 -0
- package/dist/api/mutations/matching.js +204 -0
- package/dist/api/mutations/notifications.d.ts +63 -0
- package/dist/api/mutations/notifications.js +106 -0
- package/dist/api/mutations/offers.d.ts +26 -0
- package/dist/api/mutations/offers.js +47 -0
- package/dist/api/mutations/subscriptions.d.ts +127 -0
- package/dist/api/mutations/subscriptions.js +140 -0
- package/dist/api/mutations/support.d.ts +165 -0
- package/dist/api/mutations/support.js +307 -0
- package/dist/api/mutations/users.d.ts +211 -0
- package/dist/api/mutations/users.js +261 -0
- package/dist/api/queries/admin.d.ts +257 -0
- package/dist/api/queries/admin.js +320 -0
- package/dist/api/queries/ambassadors.d.ts +53 -0
- package/dist/api/queries/ambassadors.js +98 -0
- package/dist/api/queries/auth.d.ts +16 -0
- package/dist/api/queries/auth.js +25 -0
- package/dist/api/queries/bookings.d.ts +91 -0
- package/dist/api/queries/bookings.js +102 -0
- package/dist/api/queries/businesses.d.ts +212 -0
- package/dist/api/queries/businesses.js +154 -0
- package/dist/api/queries/event-chat.d.ts +19 -0
- package/dist/api/queries/event-chat.js +75 -0
- package/dist/api/queries/events.d.ts +322 -0
- package/dist/api/queries/events.js +221 -0
- package/dist/api/queries/grow90.d.ts +26 -0
- package/dist/api/queries/grow90.js +85 -0
- package/dist/api/queries/hubs.d.ts +165 -0
- package/dist/api/queries/hubs.js +143 -0
- package/dist/api/queries/index.d.ts +23 -0
- package/dist/api/queries/index.js +40 -0
- package/dist/api/queries/jack.d.ts +63 -0
- package/dist/api/queries/jack.js +92 -0
- package/dist/api/queries/library.d.ts +132 -0
- package/dist/api/queries/library.js +120 -0
- package/dist/api/queries/map.d.ts +216 -0
- package/dist/api/queries/map.js +278 -0
- package/dist/api/queries/matching.d.ts +136 -0
- package/dist/api/queries/matching.js +161 -0
- package/dist/api/queries/notifications.d.ts +78 -0
- package/dist/api/queries/notifications.js +88 -0
- package/dist/api/queries/offers.d.ts +91 -0
- package/dist/api/queries/offers.js +103 -0
- package/dist/api/queries/subscriptions.d.ts +56 -0
- package/dist/api/queries/subscriptions.js +73 -0
- package/dist/api/queries/support.d.ts +106 -0
- package/dist/api/queries/support.js +202 -0
- package/dist/api/queries/users.d.ts +293 -0
- package/dist/api/queries/users.js +370 -0
- package/dist/api/types.d.ts +464 -0
- package/dist/api/types.js +9 -0
- package/dist/hooks/useAuth.d.ts +5 -0
- package/dist/hooks/useAuth.js +39 -0
- package/dist/hooks/useUser.d.ts +43 -0
- package/dist/hooks/useUser.js +44 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.js +67 -0
- package/package.json +62 -0
- package/src/__tests__/e2e.test.ts +502 -0
- package/src/api/client.ts +71 -0
- package/src/api/mutations/admin.ts +531 -0
- package/src/api/mutations/ambassadors.ts +185 -0
- package/src/api/mutations/auth.ts +350 -0
- package/src/api/mutations/bookings.ts +190 -0
- package/src/api/mutations/event-chat.ts +177 -0
- package/src/api/mutations/events.ts +273 -0
- package/src/api/mutations/grow90.ts +169 -0
- package/src/api/mutations/hubs.ts +385 -0
- package/src/api/mutations/index.ts +23 -0
- package/src/api/mutations/jack.ts +130 -0
- package/src/api/mutations/library.ts +212 -0
- package/src/api/mutations/map.ts +230 -0
- package/src/api/mutations/matching.ts +271 -0
- package/src/api/mutations/notifications.ts +114 -0
- package/src/api/mutations/offers.ts +73 -0
- package/src/api/mutations/subscriptions.ts +162 -0
- package/src/api/mutations/support.ts +390 -0
- package/src/api/mutations/users.ts +271 -0
- package/src/api/queries/admin.ts +480 -0
- package/src/api/queries/ambassadors.ts +139 -0
- package/src/api/queries/auth.ts +24 -0
- package/src/api/queries/bookings.ts +135 -0
- package/src/api/queries/businesses.ts +203 -0
- package/src/api/queries/event-chat.ts +78 -0
- package/src/api/queries/events.ts +272 -0
- package/src/api/queries/grow90.ts +98 -0
- package/src/api/queries/hubs.ts +211 -0
- package/src/api/queries/index.ts +24 -0
- package/src/api/queries/jack.ts +127 -0
- package/src/api/queries/library.ts +166 -0
- package/src/api/queries/map.ts +331 -0
- package/src/api/queries/matching.ts +238 -0
- package/src/api/queries/notifications.ts +103 -0
- package/src/api/queries/offers.ts +136 -0
- package/src/api/queries/subscriptions.ts +91 -0
- package/src/api/queries/support.ts +235 -0
- package/src/api/queries/users.ts +393 -0
- package/src/api/types.ts +596 -0
- package/src/index.ts +57 -0
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useMarkNotificationRead = useMarkNotificationRead;
|
|
4
|
+
exports.useMarkAllNotificationsRead = useMarkAllNotificationsRead;
|
|
5
|
+
exports.useDeleteNotification = useDeleteNotification;
|
|
6
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
7
|
+
const client_1 = require("../client");
|
|
8
|
+
const notifications_1 = require("../queries/notifications");
|
|
9
|
+
// ============================================================================
|
|
10
|
+
// MUTATION HOOKS
|
|
11
|
+
// ============================================================================
|
|
12
|
+
/**
|
|
13
|
+
* Mark a notification as read
|
|
14
|
+
*
|
|
15
|
+
* @param options - TanStack Query mutation options
|
|
16
|
+
*
|
|
17
|
+
* @example
|
|
18
|
+
* ```tsx
|
|
19
|
+
* const { mutate: markAsRead } = useMarkNotificationRead();
|
|
20
|
+
*
|
|
21
|
+
* const handleNotificationClick = (notificationId: string) => {
|
|
22
|
+
* markAsRead(notificationId);
|
|
23
|
+
* };
|
|
24
|
+
* ```
|
|
25
|
+
*/
|
|
26
|
+
function useMarkNotificationRead(options) {
|
|
27
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
28
|
+
return (0, react_query_1.useMutation)({
|
|
29
|
+
mutationFn: async (id) => {
|
|
30
|
+
const client = (0, client_1.getApiClient)();
|
|
31
|
+
const response = await client.patch(`/api/v1/notifications/${id}/read`);
|
|
32
|
+
return response.data;
|
|
33
|
+
},
|
|
34
|
+
onSuccess: (data, id, context) => {
|
|
35
|
+
// Update notification in cache
|
|
36
|
+
queryClient.setQueryData(notifications_1.notificationKeys.detail(id), data);
|
|
37
|
+
// Invalidate lists to refetch
|
|
38
|
+
queryClient.invalidateQueries({ queryKey: notifications_1.notificationKeys.list() });
|
|
39
|
+
queryClient.invalidateQueries({ queryKey: notifications_1.notificationKeys.unreadCount() });
|
|
40
|
+
// User's onSuccess is handled by spreading options
|
|
41
|
+
},
|
|
42
|
+
...options,
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Mark all notifications as read
|
|
47
|
+
*
|
|
48
|
+
* @param options - TanStack Query mutation options
|
|
49
|
+
*
|
|
50
|
+
* @example
|
|
51
|
+
* ```tsx
|
|
52
|
+
* const { mutate: markAllRead, isPending } = useMarkAllNotificationsRead();
|
|
53
|
+
*
|
|
54
|
+
* const handleMarkAllRead = () => {
|
|
55
|
+
* markAllRead();
|
|
56
|
+
* };
|
|
57
|
+
* ```
|
|
58
|
+
*/
|
|
59
|
+
function useMarkAllNotificationsRead(options) {
|
|
60
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
61
|
+
return (0, react_query_1.useMutation)({
|
|
62
|
+
mutationFn: async () => {
|
|
63
|
+
const client = (0, client_1.getApiClient)();
|
|
64
|
+
await client.patch('/api/v1/notifications/read-all');
|
|
65
|
+
},
|
|
66
|
+
onSuccess: (data, variables, context) => {
|
|
67
|
+
// Invalidate all notification queries
|
|
68
|
+
queryClient.invalidateQueries({ queryKey: notifications_1.notificationKeys.all });
|
|
69
|
+
// User's onSuccess is handled by spreading options
|
|
70
|
+
},
|
|
71
|
+
...options,
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Delete a notification
|
|
76
|
+
*
|
|
77
|
+
* @param options - TanStack Query mutation options
|
|
78
|
+
*
|
|
79
|
+
* @example
|
|
80
|
+
* ```tsx
|
|
81
|
+
* const { mutate: deleteNotification } = useDeleteNotification();
|
|
82
|
+
*
|
|
83
|
+
* const handleDelete = (notificationId: string) => {
|
|
84
|
+
* deleteNotification(notificationId);
|
|
85
|
+
* };
|
|
86
|
+
* ```
|
|
87
|
+
*/
|
|
88
|
+
function useDeleteNotification(options) {
|
|
89
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
90
|
+
return (0, react_query_1.useMutation)({
|
|
91
|
+
mutationFn: async (id) => {
|
|
92
|
+
const client = (0, client_1.getApiClient)();
|
|
93
|
+
await client.delete(`/api/v1/notifications/${id}`);
|
|
94
|
+
},
|
|
95
|
+
onSuccess: (data, id, context) => {
|
|
96
|
+
// Remove from cache
|
|
97
|
+
queryClient.removeQueries({ queryKey: notifications_1.notificationKeys.detail(id) });
|
|
98
|
+
// Invalidate lists to refetch
|
|
99
|
+
queryClient.invalidateQueries({ queryKey: notifications_1.notificationKeys.list() });
|
|
100
|
+
queryClient.invalidateQueries({ queryKey: notifications_1.notificationKeys.unreadCount() });
|
|
101
|
+
// User's onSuccess is handled by spreading options
|
|
102
|
+
},
|
|
103
|
+
...options,
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvbXV0YXRpb25zL25vdGlmaWNhdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUF1QkEsMERBcUJDO0FBZ0JELGtFQWlCQztBQWdCRCxzREFvQkM7QUFqSEQsdURBQXdGO0FBQ3hGLHNDQUF5QztBQUN6Qyw0REFBNEQ7QUFHNUQsK0VBQStFO0FBQy9FLGlCQUFpQjtBQUNqQiwrRUFBK0U7QUFFL0U7Ozs7Ozs7Ozs7Ozs7R0FhRztBQUNILFNBQWdCLHVCQUF1QixDQUNyQyxPQUFxRjtJQUVyRixNQUFNLFdBQVcsR0FBRyxJQUFBLDRCQUFjLEdBQUUsQ0FBQztJQUVyQyxPQUFPLElBQUEseUJBQVcsRUFBQztRQUNqQixVQUFVLEVBQUUsS0FBSyxFQUFFLEVBQVUsRUFBaUMsRUFBRTtZQUM5RCxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQztZQUM5QixNQUFNLFFBQVEsR0FBRyxNQUFNLE1BQU0sQ0FBQyxLQUFLLENBQUMseUJBQXlCLEVBQUUsT0FBTyxDQUFDLENBQUM7WUFDeEUsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDO1FBQ3ZCLENBQUM7UUFDRCxTQUFTLEVBQUUsQ0FBQyxJQUFJLEVBQUUsRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFFO1lBQy9CLCtCQUErQjtZQUMvQixXQUFXLENBQUMsWUFBWSxDQUFDLGdDQUFnQixDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztZQUM1RCw4QkFBOEI7WUFDOUIsV0FBVyxDQUFDLGlCQUFpQixDQUFDLEVBQUUsUUFBUSxFQUFFLGdDQUFnQixDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQztZQUNyRSxXQUFXLENBQUMsaUJBQWlCLENBQUMsRUFBRSxRQUFRLEVBQUUsZ0NBQWdCLENBQUMsV0FBVyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQzVFLG1EQUFtRDtRQUNyRCxDQUFDO1FBQ0QsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQUVEOzs7Ozs7Ozs7Ozs7O0dBYUc7QUFDSCxTQUFnQiwyQkFBMkIsQ0FDekMsT0FBbUU7SUFFbkUsTUFBTSxXQUFXLEdBQUcsSUFBQSw0QkFBYyxHQUFFLENBQUM7SUFFckMsT0FBTyxJQUFBLHlCQUFXLEVBQUM7UUFDakIsVUFBVSxFQUFFLEtBQUssSUFBbUIsRUFBRTtZQUNwQyxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQztZQUM5QixNQUFNLE1BQU0sQ0FBQyxLQUFLLENBQUMsZ0NBQWdDLENBQUMsQ0FBQztRQUN2RCxDQUFDO1FBQ0QsU0FBUyxFQUFFLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsRUFBRTtZQUN0QyxzQ0FBc0M7WUFDdEMsV0FBVyxDQUFDLGlCQUFpQixDQUFDLEVBQUUsUUFBUSxFQUFFLGdDQUFnQixDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUM7WUFDbEUsbURBQW1EO1FBQ3JELENBQUM7UUFDRCxHQUFHLE9BQU87S0FDWCxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQ7Ozs7Ozs7Ozs7Ozs7R0FhRztBQUNILFNBQWdCLHFCQUFxQixDQUNuQyxPQUFxRTtJQUVyRSxNQUFNLFdBQVcsR0FBRyxJQUFBLDRCQUFjLEdBQUUsQ0FBQztJQUVyQyxPQUFPLElBQUEseUJBQVcsRUFBQztRQUNqQixVQUFVLEVBQUUsS0FBSyxFQUFFLEVBQVUsRUFBaUIsRUFBRTtZQUM5QyxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQztZQUM5QixNQUFNLE1BQU0sQ0FBQyxNQUFNLENBQUMseUJBQXlCLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDckQsQ0FBQztRQUNELFNBQVMsRUFBRSxDQUFDLElBQUksRUFBRSxFQUFFLEVBQUUsT0FBTyxFQUFFLEVBQUU7WUFDL0Isb0JBQW9CO1lBQ3BCLFdBQVcsQ0FBQyxhQUFhLENBQUMsRUFBRSxRQUFRLEVBQUUsZ0NBQWdCLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztZQUNyRSw4QkFBOEI7WUFDOUIsV0FBVyxDQUFDLGlCQUFpQixDQUFDLEVBQUUsUUFBUSxFQUFFLGdDQUFnQixDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQztZQUNyRSxXQUFXLENBQUMsaUJBQWlCLENBQUMsRUFBRSxRQUFRLEVBQUUsZ0NBQWdCLENBQUMsV0FBVyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQzVFLG1EQUFtRDtRQUNyRCxDQUFDO1FBQ0QsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZU11dGF0aW9uLCB1c2VRdWVyeUNsaWVudCwgVXNlTXV0YXRpb25PcHRpb25zIH0gZnJvbSAnQHRhbnN0YWNrL3JlYWN0LXF1ZXJ5JztcbmltcG9ydCB7IGdldEFwaUNsaWVudCB9IGZyb20gJy4uL2NsaWVudCc7XG5pbXBvcnQgeyBub3RpZmljYXRpb25LZXlzIH0gZnJvbSAnLi4vcXVlcmllcy9ub3RpZmljYXRpb25zJztcbmltcG9ydCB0eXBlIHsgTm90aWZpY2F0aW9uUmVzcG9uc2UgfSBmcm9tICcuLi90eXBlcyc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIE1VVEFUSU9OIEhPT0tTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogTWFyayBhIG5vdGlmaWNhdGlvbiBhcyByZWFkXG4gKlxuICogQHBhcmFtIG9wdGlvbnMgLSBUYW5TdGFjayBRdWVyeSBtdXRhdGlvbiBvcHRpb25zXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzeFxuICogY29uc3QgeyBtdXRhdGU6IG1hcmtBc1JlYWQgfSA9IHVzZU1hcmtOb3RpZmljYXRpb25SZWFkKCk7XG4gKlxuICogY29uc3QgaGFuZGxlTm90aWZpY2F0aW9uQ2xpY2sgPSAobm90aWZpY2F0aW9uSWQ6IHN0cmluZykgPT4ge1xuICogICBtYXJrQXNSZWFkKG5vdGlmaWNhdGlvbklkKTtcbiAqIH07XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZU1hcmtOb3RpZmljYXRpb25SZWFkKFxuICBvcHRpb25zPzogT21pdDxVc2VNdXRhdGlvbk9wdGlvbnM8Tm90aWZpY2F0aW9uUmVzcG9uc2UsIEVycm9yLCBzdHJpbmc+LCAnbXV0YXRpb25Gbic+XG4pIHtcbiAgY29uc3QgcXVlcnlDbGllbnQgPSB1c2VRdWVyeUNsaWVudCgpO1xuXG4gIHJldHVybiB1c2VNdXRhdGlvbih7XG4gICAgbXV0YXRpb25GbjogYXN5bmMgKGlkOiBzdHJpbmcpOiBQcm9taXNlPE5vdGlmaWNhdGlvblJlc3BvbnNlPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LnBhdGNoKGAvYXBpL3YxL25vdGlmaWNhdGlvbnMvJHtpZH0vcmVhZGApO1xuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGE7XG4gICAgfSxcbiAgICBvblN1Y2Nlc3M6IChkYXRhLCBpZCwgY29udGV4dCkgPT4ge1xuICAgICAgLy8gVXBkYXRlIG5vdGlmaWNhdGlvbiBpbiBjYWNoZVxuICAgICAgcXVlcnlDbGllbnQuc2V0UXVlcnlEYXRhKG5vdGlmaWNhdGlvbktleXMuZGV0YWlsKGlkKSwgZGF0YSk7XG4gICAgICAvLyBJbnZhbGlkYXRlIGxpc3RzIHRvIHJlZmV0Y2hcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHsgcXVlcnlLZXk6IG5vdGlmaWNhdGlvbktleXMubGlzdCgpIH0pO1xuICAgICAgcXVlcnlDbGllbnQuaW52YWxpZGF0ZVF1ZXJpZXMoeyBxdWVyeUtleTogbm90aWZpY2F0aW9uS2V5cy51bnJlYWRDb3VudCgpIH0pO1xuICAgICAgLy8gVXNlcidzIG9uU3VjY2VzcyBpcyBoYW5kbGVkIGJ5IHNwcmVhZGluZyBvcHRpb25zXG4gICAgfSxcbiAgICAuLi5vcHRpb25zLFxuICB9KTtcbn1cblxuLyoqXG4gKiBNYXJrIGFsbCBub3RpZmljYXRpb25zIGFzIHJlYWRcbiAqXG4gKiBAcGFyYW0gb3B0aW9ucyAtIFRhblN0YWNrIFF1ZXJ5IG11dGF0aW9uIG9wdGlvbnNcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHN4XG4gKiBjb25zdCB7IG11dGF0ZTogbWFya0FsbFJlYWQsIGlzUGVuZGluZyB9ID0gdXNlTWFya0FsbE5vdGlmaWNhdGlvbnNSZWFkKCk7XG4gKlxuICogY29uc3QgaGFuZGxlTWFya0FsbFJlYWQgPSAoKSA9PiB7XG4gKiAgIG1hcmtBbGxSZWFkKCk7XG4gKiB9O1xuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VNYXJrQWxsTm90aWZpY2F0aW9uc1JlYWQoXG4gIG9wdGlvbnM/OiBPbWl0PFVzZU11dGF0aW9uT3B0aW9uczx2b2lkLCBFcnJvciwgdm9pZD4sICdtdXRhdGlvbkZuJz5cbikge1xuICBjb25zdCBxdWVyeUNsaWVudCA9IHVzZVF1ZXJ5Q2xpZW50KCk7XG5cbiAgcmV0dXJuIHVzZU11dGF0aW9uKHtcbiAgICBtdXRhdGlvbkZuOiBhc3luYyAoKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGF3YWl0IGNsaWVudC5wYXRjaCgnL2FwaS92MS9ub3RpZmljYXRpb25zL3JlYWQtYWxsJyk7XG4gICAgfSxcbiAgICBvblN1Y2Nlc3M6IChkYXRhLCB2YXJpYWJsZXMsIGNvbnRleHQpID0+IHtcbiAgICAgIC8vIEludmFsaWRhdGUgYWxsIG5vdGlmaWNhdGlvbiBxdWVyaWVzXG4gICAgICBxdWVyeUNsaWVudC5pbnZhbGlkYXRlUXVlcmllcyh7IHF1ZXJ5S2V5OiBub3RpZmljYXRpb25LZXlzLmFsbCB9KTtcbiAgICAgIC8vIFVzZXIncyBvblN1Y2Nlc3MgaXMgaGFuZGxlZCBieSBzcHJlYWRpbmcgb3B0aW9uc1xuICAgIH0sXG4gICAgLi4ub3B0aW9ucyxcbiAgfSk7XG59XG5cbi8qKlxuICogRGVsZXRlIGEgbm90aWZpY2F0aW9uXG4gKlxuICogQHBhcmFtIG9wdGlvbnMgLSBUYW5TdGFjayBRdWVyeSBtdXRhdGlvbiBvcHRpb25zXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzeFxuICogY29uc3QgeyBtdXRhdGU6IGRlbGV0ZU5vdGlmaWNhdGlvbiB9ID0gdXNlRGVsZXRlTm90aWZpY2F0aW9uKCk7XG4gKlxuICogY29uc3QgaGFuZGxlRGVsZXRlID0gKG5vdGlmaWNhdGlvbklkOiBzdHJpbmcpID0+IHtcbiAqICAgZGVsZXRlTm90aWZpY2F0aW9uKG5vdGlmaWNhdGlvbklkKTtcbiAqIH07XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZURlbGV0ZU5vdGlmaWNhdGlvbihcbiAgb3B0aW9ucz86IE9taXQ8VXNlTXV0YXRpb25PcHRpb25zPHZvaWQsIEVycm9yLCBzdHJpbmc+LCAnbXV0YXRpb25Gbic+XG4pIHtcbiAgY29uc3QgcXVlcnlDbGllbnQgPSB1c2VRdWVyeUNsaWVudCgpO1xuXG4gIHJldHVybiB1c2VNdXRhdGlvbih7XG4gICAgbXV0YXRpb25GbjogYXN5bmMgKGlkOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+ID0+IHtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGdldEFwaUNsaWVudCgpO1xuICAgICAgYXdhaXQgY2xpZW50LmRlbGV0ZShgL2FwaS92MS9ub3RpZmljYXRpb25zLyR7aWR9YCk7XG4gICAgfSxcbiAgICBvblN1Y2Nlc3M6IChkYXRhLCBpZCwgY29udGV4dCkgPT4ge1xuICAgICAgLy8gUmVtb3ZlIGZyb20gY2FjaGVcbiAgICAgIHF1ZXJ5Q2xpZW50LnJlbW92ZVF1ZXJpZXMoeyBxdWVyeUtleTogbm90aWZpY2F0aW9uS2V5cy5kZXRhaWwoaWQpIH0pO1xuICAgICAgLy8gSW52YWxpZGF0ZSBsaXN0cyB0byByZWZldGNoXG4gICAgICBxdWVyeUNsaWVudC5pbnZhbGlkYXRlUXVlcmllcyh7IHF1ZXJ5S2V5OiBub3RpZmljYXRpb25LZXlzLmxpc3QoKSB9KTtcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHsgcXVlcnlLZXk6IG5vdGlmaWNhdGlvbktleXMudW5yZWFkQ291bnQoKSB9KTtcbiAgICAgIC8vIFVzZXIncyBvblN1Y2Nlc3MgaXMgaGFuZGxlZCBieSBzcHJlYWRpbmcgb3B0aW9uc1xuICAgIH0sXG4gICAgLi4ub3B0aW9ucyxcbiAgfSk7XG59XG4iXX0=
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
|
|
2
|
+
import type { OfferResponse, RedeemOfferRequest } from '../types';
|
|
3
|
+
/**
|
|
4
|
+
* Redeem an offer
|
|
5
|
+
*
|
|
6
|
+
* @param options - TanStack Query mutation options
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```tsx
|
|
10
|
+
* const { mutate, isPending } = useRedeemOffer();
|
|
11
|
+
*
|
|
12
|
+
* mutate({
|
|
13
|
+
* id: 'offer-123',
|
|
14
|
+
* data: {
|
|
15
|
+
* // Add any required fields from RedeemOfferRequest
|
|
16
|
+
* }
|
|
17
|
+
* });
|
|
18
|
+
* ```
|
|
19
|
+
*/
|
|
20
|
+
export declare function useRedeemOffer(options?: Omit<UseMutationOptions<OfferResponse, Error, {
|
|
21
|
+
id: string;
|
|
22
|
+
data?: RedeemOfferRequest;
|
|
23
|
+
}>, 'mutationFn'>): UseMutationResult<OfferResponse, Error, {
|
|
24
|
+
id: string;
|
|
25
|
+
data?: RedeemOfferRequest;
|
|
26
|
+
}>;
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useRedeemOffer = useRedeemOffer;
|
|
4
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
5
|
+
const client_1 = require("../client");
|
|
6
|
+
const offers_1 = require("../queries/offers");
|
|
7
|
+
// ============================================================================
|
|
8
|
+
// MUTATION HOOKS
|
|
9
|
+
// ============================================================================
|
|
10
|
+
/**
|
|
11
|
+
* Redeem an offer
|
|
12
|
+
*
|
|
13
|
+
* @param options - TanStack Query mutation options
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```tsx
|
|
17
|
+
* const { mutate, isPending } = useRedeemOffer();
|
|
18
|
+
*
|
|
19
|
+
* mutate({
|
|
20
|
+
* id: 'offer-123',
|
|
21
|
+
* data: {
|
|
22
|
+
* // Add any required fields from RedeemOfferRequest
|
|
23
|
+
* }
|
|
24
|
+
* });
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
function useRedeemOffer(options) {
|
|
28
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
29
|
+
return (0, react_query_1.useMutation)({
|
|
30
|
+
mutationFn: async ({ id, data, }) => {
|
|
31
|
+
const client = (0, client_1.getApiClient)();
|
|
32
|
+
const response = await client.post(`/api/v1/offers/${id}/redeem`, data);
|
|
33
|
+
return response.data;
|
|
34
|
+
},
|
|
35
|
+
onSuccess: (redeemedOffer, variables, context) => {
|
|
36
|
+
// Update the specific offer in cache
|
|
37
|
+
queryClient.setQueryData(offers_1.offerKeys.detail(variables.id), redeemedOffer);
|
|
38
|
+
// Invalidate the can-redeem check for this offer
|
|
39
|
+
queryClient.invalidateQueries({ queryKey: offers_1.offerKeys.canRedeem(variables.id) });
|
|
40
|
+
// Invalidate offer lists to reflect redemption counts
|
|
41
|
+
queryClient.invalidateQueries({ queryKey: offers_1.offerKeys.lists() });
|
|
42
|
+
// Call user's onSuccess if provided
|
|
43
|
+
},
|
|
44
|
+
...options,
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2ZmZXJzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwaS9tdXRhdGlvbnMvb2ZmZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBK0JBLHdDQXlDQztBQXhFRCx1REFLK0I7QUFDL0Isc0NBQXlDO0FBRXpDLDhDQUE4QztBQUU5QywrRUFBK0U7QUFDL0UsaUJBQWlCO0FBQ2pCLCtFQUErRTtBQUUvRTs7Ozs7Ozs7Ozs7Ozs7OztHQWdCRztBQUNILFNBQWdCLGNBQWMsQ0FDNUIsT0FPQztJQUVELE1BQU0sV0FBVyxHQUFHLElBQUEsNEJBQWMsR0FBRSxDQUFDO0lBRXJDLE9BQU8sSUFBQSx5QkFBVyxFQUFDO1FBQ2pCLFVBQVUsRUFBRSxLQUFLLEVBQUUsRUFDakIsRUFBRSxFQUNGLElBQUksR0FJTCxFQUEwQixFQUFFO1lBQzNCLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFDO1lBQzlCLE1BQU0sUUFBUSxHQUFHLE1BQU0sTUFBTSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxTQUFTLEVBQUUsSUFBSSxDQUFDLENBQUM7WUFDeEUsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDO1FBQ3ZCLENBQUM7UUFDRCxTQUFTLEVBQUUsQ0FBQyxhQUFhLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxFQUFFO1lBQy9DLHFDQUFxQztZQUNyQyxXQUFXLENBQUMsWUFBWSxDQUN0QixrQkFBUyxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLEVBQzlCLGFBQWEsQ0FDZCxDQUFDO1lBRUYsaURBQWlEO1lBQ2pELFdBQVcsQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLFFBQVEsRUFBRSxrQkFBUyxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1lBRS9FLHNEQUFzRDtZQUN0RCxXQUFXLENBQUMsaUJBQWlCLENBQUMsRUFBRSxRQUFRLEVBQUUsa0JBQVMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFFL0Qsb0NBQW9DO1FBQ3RDLENBQUM7UUFDRCxHQUFHLE9BQU87S0FDWCxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdXNlTXV0YXRpb24sXG4gIHVzZVF1ZXJ5Q2xpZW50LFxuICBVc2VNdXRhdGlvbk9wdGlvbnMsXG4gIFVzZU11dGF0aW9uUmVzdWx0LFxufSBmcm9tICdAdGFuc3RhY2svcmVhY3QtcXVlcnknO1xuaW1wb3J0IHsgZ2V0QXBpQ2xpZW50IH0gZnJvbSAnLi4vY2xpZW50JztcbmltcG9ydCB0eXBlIHsgT2ZmZXJSZXNwb25zZSwgUmVkZWVtT2ZmZXJSZXF1ZXN0IH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgb2ZmZXJLZXlzIH0gZnJvbSAnLi4vcXVlcmllcy9vZmZlcnMnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBNVVRBVElPTiBIT09LU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKipcbiAqIFJlZGVlbSBhbiBvZmZlclxuICpcbiAqIEBwYXJhbSBvcHRpb25zIC0gVGFuU3RhY2sgUXVlcnkgbXV0YXRpb24gb3B0aW9uc1xuICpcbiAqIEBleGFtcGxlXG4gKiBgYGB0c3hcbiAqIGNvbnN0IHsgbXV0YXRlLCBpc1BlbmRpbmcgfSA9IHVzZVJlZGVlbU9mZmVyKCk7XG4gKlxuICogbXV0YXRlKHtcbiAqICAgaWQ6ICdvZmZlci0xMjMnLFxuICogICBkYXRhOiB7XG4gKiAgICAgLy8gQWRkIGFueSByZXF1aXJlZCBmaWVsZHMgZnJvbSBSZWRlZW1PZmZlclJlcXVlc3RcbiAqICAgfVxuICogfSk7XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVJlZGVlbU9mZmVyKFxuICBvcHRpb25zPzogT21pdDxcbiAgICBVc2VNdXRhdGlvbk9wdGlvbnM8XG4gICAgICBPZmZlclJlc3BvbnNlLFxuICAgICAgRXJyb3IsXG4gICAgICB7IGlkOiBzdHJpbmc7IGRhdGE/OiBSZWRlZW1PZmZlclJlcXVlc3QgfVxuICAgID4sXG4gICAgJ211dGF0aW9uRm4nXG4gID5cbik6IFVzZU11dGF0aW9uUmVzdWx0PE9mZmVyUmVzcG9uc2UsIEVycm9yLCB7IGlkOiBzdHJpbmc7IGRhdGE/OiBSZWRlZW1PZmZlclJlcXVlc3QgfT4ge1xuICBjb25zdCBxdWVyeUNsaWVudCA9IHVzZVF1ZXJ5Q2xpZW50KCk7XG5cbiAgcmV0dXJuIHVzZU11dGF0aW9uKHtcbiAgICBtdXRhdGlvbkZuOiBhc3luYyAoe1xuICAgICAgaWQsXG4gICAgICBkYXRhLFxuICAgIH06IHtcbiAgICAgIGlkOiBzdHJpbmc7XG4gICAgICBkYXRhPzogUmVkZWVtT2ZmZXJSZXF1ZXN0O1xuICAgIH0pOiBQcm9taXNlPE9mZmVyUmVzcG9uc2U+ID0+IHtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGdldEFwaUNsaWVudCgpO1xuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQucG9zdChgL2FwaS92MS9vZmZlcnMvJHtpZH0vcmVkZWVtYCwgZGF0YSk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YTtcbiAgICB9LFxuICAgIG9uU3VjY2VzczogKHJlZGVlbWVkT2ZmZXIsIHZhcmlhYmxlcywgY29udGV4dCkgPT4ge1xuICAgICAgLy8gVXBkYXRlIHRoZSBzcGVjaWZpYyBvZmZlciBpbiBjYWNoZVxuICAgICAgcXVlcnlDbGllbnQuc2V0UXVlcnlEYXRhKFxuICAgICAgICBvZmZlcktleXMuZGV0YWlsKHZhcmlhYmxlcy5pZCksXG4gICAgICAgIHJlZGVlbWVkT2ZmZXJcbiAgICAgICk7XG5cbiAgICAgIC8vIEludmFsaWRhdGUgdGhlIGNhbi1yZWRlZW0gY2hlY2sgZm9yIHRoaXMgb2ZmZXJcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHsgcXVlcnlLZXk6IG9mZmVyS2V5cy5jYW5SZWRlZW0odmFyaWFibGVzLmlkKSB9KTtcblxuICAgICAgLy8gSW52YWxpZGF0ZSBvZmZlciBsaXN0cyB0byByZWZsZWN0IHJlZGVtcHRpb24gY291bnRzXG4gICAgICBxdWVyeUNsaWVudC5pbnZhbGlkYXRlUXVlcmllcyh7IHF1ZXJ5S2V5OiBvZmZlcktleXMubGlzdHMoKSB9KTtcblxuICAgICAgLy8gQ2FsbCB1c2VyJ3Mgb25TdWNjZXNzIGlmIHByb3ZpZGVkXG4gICAgfSxcbiAgICAuLi5vcHRpb25zLFxuICB9KTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { UseMutationOptions } from '@tanstack/react-query';
|
|
2
|
+
import type { CreateCheckoutRequest, SubscriptionResponse } from '../types';
|
|
3
|
+
export interface CheckoutSession {
|
|
4
|
+
sessionId: string;
|
|
5
|
+
url: string;
|
|
6
|
+
}
|
|
7
|
+
export interface CustomerPortalSession {
|
|
8
|
+
url: string;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Create a Stripe checkout session for subscription
|
|
12
|
+
*
|
|
13
|
+
* @param options - TanStack Query mutation options
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```tsx
|
|
17
|
+
* const { mutate: createCheckout, isPending } = useCreateCheckout();
|
|
18
|
+
*
|
|
19
|
+
* const handleUpgrade = () => {
|
|
20
|
+
* createCheckout(
|
|
21
|
+
* { tier: 'PREMIUM', successUrl: '/success', cancelUrl: '/cancel' },
|
|
22
|
+
* {
|
|
23
|
+
* onSuccess: (session) => {
|
|
24
|
+
* window.location.href = session.url;
|
|
25
|
+
* },
|
|
26
|
+
* }
|
|
27
|
+
* );
|
|
28
|
+
* };
|
|
29
|
+
* ```
|
|
30
|
+
*/
|
|
31
|
+
export declare function useCreateCheckout(options?: Omit<UseMutationOptions<CheckoutSession, Error, CreateCheckoutRequest>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<CheckoutSession, Error, {
|
|
32
|
+
tier: "FREE" | "PREMIUM";
|
|
33
|
+
successUrl?: string;
|
|
34
|
+
cancelUrl?: string;
|
|
35
|
+
priceId?: string;
|
|
36
|
+
}, unknown>;
|
|
37
|
+
/**
|
|
38
|
+
* Get Stripe customer portal URL for managing subscription
|
|
39
|
+
*
|
|
40
|
+
* @param options - TanStack Query mutation options
|
|
41
|
+
*
|
|
42
|
+
* @example
|
|
43
|
+
* ```tsx
|
|
44
|
+
* const { mutate: getPortal, isPending } = useCustomerPortal();
|
|
45
|
+
*
|
|
46
|
+
* const handleManageSubscription = () => {
|
|
47
|
+
* getPortal(undefined, {
|
|
48
|
+
* onSuccess: (session) => {
|
|
49
|
+
* window.location.href = session.url;
|
|
50
|
+
* },
|
|
51
|
+
* });
|
|
52
|
+
* };
|
|
53
|
+
* ```
|
|
54
|
+
*/
|
|
55
|
+
export declare function useCustomerPortal(options?: Omit<UseMutationOptions<CustomerPortalSession, Error, void>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<CustomerPortalSession, Error, void, unknown>;
|
|
56
|
+
/**
|
|
57
|
+
* Cancel current subscription
|
|
58
|
+
*
|
|
59
|
+
* @param options - TanStack Query mutation options
|
|
60
|
+
*
|
|
61
|
+
* @example
|
|
62
|
+
* ```tsx
|
|
63
|
+
* const { mutate: cancelSubscription, isPending } = useCancelSubscription();
|
|
64
|
+
*
|
|
65
|
+
* const handleCancel = () => {
|
|
66
|
+
* cancelSubscription(undefined, {
|
|
67
|
+
* onSuccess: () => {
|
|
68
|
+
* // Subscription will be cancelled at period end
|
|
69
|
+
* },
|
|
70
|
+
* });
|
|
71
|
+
* };
|
|
72
|
+
* ```
|
|
73
|
+
*/
|
|
74
|
+
export declare function useCancelSubscription(options?: Omit<UseMutationOptions<SubscriptionResponse, Error, void>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
|
|
75
|
+
id: string;
|
|
76
|
+
userId: string;
|
|
77
|
+
tier: "FREE" | "PREMIUM";
|
|
78
|
+
status: "ACTIVE" | "TRIALING" | "PAST_DUE" | "CANCELLED" | "PAUSED";
|
|
79
|
+
stripeCustomerId?: Record<string, never>;
|
|
80
|
+
stripeSubscriptionId?: Record<string, never>;
|
|
81
|
+
stripePriceId?: Record<string, never>;
|
|
82
|
+
currentPeriodStart?: Record<string, never>;
|
|
83
|
+
currentPeriodEnd?: Record<string, never>;
|
|
84
|
+
cancelAtPeriodEnd: boolean;
|
|
85
|
+
cancelledAt?: Record<string, never>;
|
|
86
|
+
trialStart?: Record<string, never>;
|
|
87
|
+
trialEnd?: Record<string, never>;
|
|
88
|
+
hadTrial: boolean;
|
|
89
|
+
createdAt: string;
|
|
90
|
+
updatedAt: string;
|
|
91
|
+
}, Error, void, unknown>;
|
|
92
|
+
/**
|
|
93
|
+
* Resume a cancelled subscription (before period end)
|
|
94
|
+
*
|
|
95
|
+
* @param options - TanStack Query mutation options
|
|
96
|
+
*
|
|
97
|
+
* @example
|
|
98
|
+
* ```tsx
|
|
99
|
+
* const { mutate: resumeSubscription, isPending } = useResumeSubscription();
|
|
100
|
+
*
|
|
101
|
+
* const handleResume = () => {
|
|
102
|
+
* resumeSubscription(undefined, {
|
|
103
|
+
* onSuccess: () => {
|
|
104
|
+
* // Subscription resumed
|
|
105
|
+
* },
|
|
106
|
+
* });
|
|
107
|
+
* };
|
|
108
|
+
* ```
|
|
109
|
+
*/
|
|
110
|
+
export declare function useResumeSubscription(options?: Omit<UseMutationOptions<SubscriptionResponse, Error, void>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
|
|
111
|
+
id: string;
|
|
112
|
+
userId: string;
|
|
113
|
+
tier: "FREE" | "PREMIUM";
|
|
114
|
+
status: "ACTIVE" | "TRIALING" | "PAST_DUE" | "CANCELLED" | "PAUSED";
|
|
115
|
+
stripeCustomerId?: Record<string, never>;
|
|
116
|
+
stripeSubscriptionId?: Record<string, never>;
|
|
117
|
+
stripePriceId?: Record<string, never>;
|
|
118
|
+
currentPeriodStart?: Record<string, never>;
|
|
119
|
+
currentPeriodEnd?: Record<string, never>;
|
|
120
|
+
cancelAtPeriodEnd: boolean;
|
|
121
|
+
cancelledAt?: Record<string, never>;
|
|
122
|
+
trialStart?: Record<string, never>;
|
|
123
|
+
trialEnd?: Record<string, never>;
|
|
124
|
+
hadTrial: boolean;
|
|
125
|
+
createdAt: string;
|
|
126
|
+
updatedAt: string;
|
|
127
|
+
}, Error, void, unknown>;
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useCreateCheckout = useCreateCheckout;
|
|
4
|
+
exports.useCustomerPortal = useCustomerPortal;
|
|
5
|
+
exports.useCancelSubscription = useCancelSubscription;
|
|
6
|
+
exports.useResumeSubscription = useResumeSubscription;
|
|
7
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
8
|
+
const client_1 = require("../client");
|
|
9
|
+
const subscriptions_1 = require("../queries/subscriptions");
|
|
10
|
+
// ============================================================================
|
|
11
|
+
// MUTATION HOOKS
|
|
12
|
+
// ============================================================================
|
|
13
|
+
/**
|
|
14
|
+
* Create a Stripe checkout session for subscription
|
|
15
|
+
*
|
|
16
|
+
* @param options - TanStack Query mutation options
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* ```tsx
|
|
20
|
+
* const { mutate: createCheckout, isPending } = useCreateCheckout();
|
|
21
|
+
*
|
|
22
|
+
* const handleUpgrade = () => {
|
|
23
|
+
* createCheckout(
|
|
24
|
+
* { tier: 'PREMIUM', successUrl: '/success', cancelUrl: '/cancel' },
|
|
25
|
+
* {
|
|
26
|
+
* onSuccess: (session) => {
|
|
27
|
+
* window.location.href = session.url;
|
|
28
|
+
* },
|
|
29
|
+
* }
|
|
30
|
+
* );
|
|
31
|
+
* };
|
|
32
|
+
* ```
|
|
33
|
+
*/
|
|
34
|
+
function useCreateCheckout(options) {
|
|
35
|
+
return (0, react_query_1.useMutation)({
|
|
36
|
+
mutationFn: async (data) => {
|
|
37
|
+
const client = (0, client_1.getApiClient)();
|
|
38
|
+
const response = await client.post('/api/v1/subscriptions/checkout', data);
|
|
39
|
+
return response.data;
|
|
40
|
+
},
|
|
41
|
+
...options,
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Get Stripe customer portal URL for managing subscription
|
|
46
|
+
*
|
|
47
|
+
* @param options - TanStack Query mutation options
|
|
48
|
+
*
|
|
49
|
+
* @example
|
|
50
|
+
* ```tsx
|
|
51
|
+
* const { mutate: getPortal, isPending } = useCustomerPortal();
|
|
52
|
+
*
|
|
53
|
+
* const handleManageSubscription = () => {
|
|
54
|
+
* getPortal(undefined, {
|
|
55
|
+
* onSuccess: (session) => {
|
|
56
|
+
* window.location.href = session.url;
|
|
57
|
+
* },
|
|
58
|
+
* });
|
|
59
|
+
* };
|
|
60
|
+
* ```
|
|
61
|
+
*/
|
|
62
|
+
function useCustomerPortal(options) {
|
|
63
|
+
return (0, react_query_1.useMutation)({
|
|
64
|
+
mutationFn: async () => {
|
|
65
|
+
const client = (0, client_1.getApiClient)();
|
|
66
|
+
const response = await client.post('/api/v1/subscriptions/portal');
|
|
67
|
+
return response.data;
|
|
68
|
+
},
|
|
69
|
+
...options,
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Cancel current subscription
|
|
74
|
+
*
|
|
75
|
+
* @param options - TanStack Query mutation options
|
|
76
|
+
*
|
|
77
|
+
* @example
|
|
78
|
+
* ```tsx
|
|
79
|
+
* const { mutate: cancelSubscription, isPending } = useCancelSubscription();
|
|
80
|
+
*
|
|
81
|
+
* const handleCancel = () => {
|
|
82
|
+
* cancelSubscription(undefined, {
|
|
83
|
+
* onSuccess: () => {
|
|
84
|
+
* // Subscription will be cancelled at period end
|
|
85
|
+
* },
|
|
86
|
+
* });
|
|
87
|
+
* };
|
|
88
|
+
* ```
|
|
89
|
+
*/
|
|
90
|
+
function useCancelSubscription(options) {
|
|
91
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
92
|
+
return (0, react_query_1.useMutation)({
|
|
93
|
+
mutationFn: async () => {
|
|
94
|
+
const client = (0, client_1.getApiClient)();
|
|
95
|
+
const response = await client.post('/api/v1/subscriptions/cancel');
|
|
96
|
+
return response.data;
|
|
97
|
+
},
|
|
98
|
+
onSuccess: (data, variables, context) => {
|
|
99
|
+
// Update subscription in cache
|
|
100
|
+
queryClient.setQueryData(subscriptions_1.subscriptionKeys.mine(), data);
|
|
101
|
+
// User's onSuccess is handled by spreading options
|
|
102
|
+
},
|
|
103
|
+
...options,
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Resume a cancelled subscription (before period end)
|
|
108
|
+
*
|
|
109
|
+
* @param options - TanStack Query mutation options
|
|
110
|
+
*
|
|
111
|
+
* @example
|
|
112
|
+
* ```tsx
|
|
113
|
+
* const { mutate: resumeSubscription, isPending } = useResumeSubscription();
|
|
114
|
+
*
|
|
115
|
+
* const handleResume = () => {
|
|
116
|
+
* resumeSubscription(undefined, {
|
|
117
|
+
* onSuccess: () => {
|
|
118
|
+
* // Subscription resumed
|
|
119
|
+
* },
|
|
120
|
+
* });
|
|
121
|
+
* };
|
|
122
|
+
* ```
|
|
123
|
+
*/
|
|
124
|
+
function useResumeSubscription(options) {
|
|
125
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
126
|
+
return (0, react_query_1.useMutation)({
|
|
127
|
+
mutationFn: async () => {
|
|
128
|
+
const client = (0, client_1.getApiClient)();
|
|
129
|
+
const response = await client.post('/api/v1/subscriptions/resume');
|
|
130
|
+
return response.data;
|
|
131
|
+
},
|
|
132
|
+
onSuccess: (data, variables, context) => {
|
|
133
|
+
// Update subscription in cache
|
|
134
|
+
queryClient.setQueryData(subscriptions_1.subscriptionKeys.mine(), data);
|
|
135
|
+
// User's onSuccess is handled by spreading options
|
|
136
|
+
},
|
|
137
|
+
...options,
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"subscriptions.js","sourceRoot":"","sources":["../../../src/api/mutations/subscriptions.ts"],"names":[],"mappings":";;AA2CA,8CAWC;AAoBD,8CAWC;AAoBD,sDAkBC;AAoBD,sDAkBC;AAjKD,uDAAwF;AACxF,sCAAyC;AACzC,4DAA4D;AAgB5D,+EAA+E;AAC/E,iBAAiB;AACjB,+EAA+E;AAE/E;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,SAAgB,iBAAiB,CAC/B,OAA+F;IAE/F,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,IAA2B,EAA4B,EAAE;YAC1E,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,gCAAgC,EAAE,IAAI,CAAC,CAAC;YAC3E,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,SAAgB,iBAAiB,CAC/B,OAAoF;IAEpF,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,IAAoC,EAAE;YACrD,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;YACnE,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,SAAgB,qBAAqB,CACnC,OAAmF;IAEnF,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,IAAmC,EAAE;YACpD,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;YACnE,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,CAAC,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;YACtC,+BAA+B;YAC/B,WAAW,CAAC,YAAY,CAAC,gCAAgB,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,CAAC;YACxD,mDAAmD;QACrD,CAAC;QACD,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,SAAgB,qBAAqB,CACnC,OAAmF;IAEnF,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,IAAmC,EAAE;YACpD,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;YACnE,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,CAAC,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE;YACtC,+BAA+B;YAC/B,WAAW,CAAC,YAAY,CAAC,gCAAgB,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,CAAC;YACxD,mDAAmD;QACrD,CAAC;QACD,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC","sourcesContent":["import { useMutation, useQueryClient, UseMutationOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { subscriptionKeys } from '../queries/subscriptions';\nimport type { CreateCheckoutRequest, SubscriptionResponse } from '../types';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface CheckoutSession {\n  sessionId: string;\n  url: string;\n}\n\nexport interface CustomerPortalSession {\n  url: string;\n}\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a Stripe checkout session for subscription\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate: createCheckout, isPending } = useCreateCheckout();\n *\n * const handleUpgrade = () => {\n *   createCheckout(\n *     { tier: 'PREMIUM', successUrl: '/success', cancelUrl: '/cancel' },\n *     {\n *       onSuccess: (session) => {\n *         window.location.href = session.url;\n *       },\n *     }\n *   );\n * };\n * ```\n */\nexport function useCreateCheckout(\n  options?: Omit<UseMutationOptions<CheckoutSession, Error, CreateCheckoutRequest>, 'mutationFn'>\n) {\n  return useMutation({\n    mutationFn: async (data: CreateCheckoutRequest): Promise<CheckoutSession> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/subscriptions/checkout', data);\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get Stripe customer portal URL for managing subscription\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate: getPortal, isPending } = useCustomerPortal();\n *\n * const handleManageSubscription = () => {\n *   getPortal(undefined, {\n *     onSuccess: (session) => {\n *       window.location.href = session.url;\n *     },\n *   });\n * };\n * ```\n */\nexport function useCustomerPortal(\n  options?: Omit<UseMutationOptions<CustomerPortalSession, Error, void>, 'mutationFn'>\n) {\n  return useMutation({\n    mutationFn: async (): Promise<CustomerPortalSession> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/subscriptions/portal');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Cancel current subscription\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate: cancelSubscription, isPending } = useCancelSubscription();\n *\n * const handleCancel = () => {\n *   cancelSubscription(undefined, {\n *     onSuccess: () => {\n *       // Subscription will be cancelled at period end\n *     },\n *   });\n * };\n * ```\n */\nexport function useCancelSubscription(\n  options?: Omit<UseMutationOptions<SubscriptionResponse, Error, void>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (): Promise<SubscriptionResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/subscriptions/cancel');\n      return response.data;\n    },\n    onSuccess: (data, variables, context) => {\n      // Update subscription in cache\n      queryClient.setQueryData(subscriptionKeys.mine(), data);\n      // User's onSuccess is handled by spreading options\n    },\n    ...options,\n  });\n}\n\n/**\n * Resume a cancelled subscription (before period end)\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate: resumeSubscription, isPending } = useResumeSubscription();\n *\n * const handleResume = () => {\n *   resumeSubscription(undefined, {\n *     onSuccess: () => {\n *       // Subscription resumed\n *     },\n *   });\n * };\n * ```\n */\nexport function useResumeSubscription(\n  options?: Omit<UseMutationOptions<SubscriptionResponse, Error, void>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (): Promise<SubscriptionResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/subscriptions/resume');\n      return response.data;\n    },\n    onSuccess: (data, variables, context) => {\n      // Update subscription in cache\n      queryClient.setQueryData(subscriptionKeys.mine(), data);\n      // User's onSuccess is handled by spreading options\n    },\n    ...options,\n  });\n}\n"]}
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
import { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
|
|
2
|
+
import type { DailyCheckInResponse, CreateCheckInRequest, UpdateCheckInRequest, MoodLogResponse, CreateMoodLogRequest, WinResponse, CreateWinRequest, HabitResponse, CreateHabitRequest, UpdateHabitRequest, ReflectionResponse, CreateReflectionRequest } from '../types';
|
|
3
|
+
/**
|
|
4
|
+
* Create a daily check-in
|
|
5
|
+
*
|
|
6
|
+
* @param options - TanStack Query mutation options
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```tsx
|
|
10
|
+
* const { mutate, isPending } = useCreateCheckIn();
|
|
11
|
+
*
|
|
12
|
+
* mutate({
|
|
13
|
+
* mood: 8,
|
|
14
|
+
* notes: 'Feeling great today!',
|
|
15
|
+
* triggers: ['stress'],
|
|
16
|
+
* gratitude: ['My support group']
|
|
17
|
+
* });
|
|
18
|
+
* ```
|
|
19
|
+
*/
|
|
20
|
+
export declare function useCreateCheckIn(options?: Omit<UseMutationOptions<DailyCheckInResponse, Error, CreateCheckInRequest>, 'mutationFn'>): UseMutationResult<DailyCheckInResponse, Error, CreateCheckInRequest>;
|
|
21
|
+
/**
|
|
22
|
+
* Update a daily check-in
|
|
23
|
+
*
|
|
24
|
+
* @param options - TanStack Query mutation options
|
|
25
|
+
*
|
|
26
|
+
* @example
|
|
27
|
+
* ```tsx
|
|
28
|
+
* const { mutate, isPending } = useUpdateCheckIn();
|
|
29
|
+
*
|
|
30
|
+
* mutate({
|
|
31
|
+
* id: 'checkin-123',
|
|
32
|
+
* data: {
|
|
33
|
+
* mood: 4,
|
|
34
|
+
* notes: 'Updated notes',
|
|
35
|
+
* }
|
|
36
|
+
* });
|
|
37
|
+
* ```
|
|
38
|
+
*/
|
|
39
|
+
export declare function useUpdateCheckIn(options?: Omit<UseMutationOptions<DailyCheckInResponse, Error, {
|
|
40
|
+
id: string;
|
|
41
|
+
data: UpdateCheckInRequest;
|
|
42
|
+
}>, 'mutationFn'>): UseMutationResult<DailyCheckInResponse, Error, {
|
|
43
|
+
id: string;
|
|
44
|
+
data: UpdateCheckInRequest;
|
|
45
|
+
}>;
|
|
46
|
+
/**
|
|
47
|
+
* Create a mood log
|
|
48
|
+
*
|
|
49
|
+
* @param options - TanStack Query mutation options
|
|
50
|
+
*
|
|
51
|
+
* @example
|
|
52
|
+
* ```tsx
|
|
53
|
+
* const { mutate, isPending } = useCreateMoodLog();
|
|
54
|
+
*
|
|
55
|
+
* mutate({
|
|
56
|
+
* mood: 7,
|
|
57
|
+
* notes: 'Feeling optimistic',
|
|
58
|
+
* activities: ['exercise', 'meditation']
|
|
59
|
+
* });
|
|
60
|
+
* ```
|
|
61
|
+
*/
|
|
62
|
+
export declare function useCreateMoodLog(options?: Omit<UseMutationOptions<MoodLogResponse, Error, CreateMoodLogRequest>, 'mutationFn'>): UseMutationResult<MoodLogResponse, Error, CreateMoodLogRequest>;
|
|
63
|
+
/**
|
|
64
|
+
* Create a win
|
|
65
|
+
*
|
|
66
|
+
* @param options - TanStack Query mutation options
|
|
67
|
+
*
|
|
68
|
+
* @example
|
|
69
|
+
* ```tsx
|
|
70
|
+
* const { mutate, isPending } = useCreateWin();
|
|
71
|
+
*
|
|
72
|
+
* mutate({
|
|
73
|
+
* title: '30 days sober!',
|
|
74
|
+
* description: 'Hit my first milestone',
|
|
75
|
+
* category: 'sobriety'
|
|
76
|
+
* });
|
|
77
|
+
* ```
|
|
78
|
+
*/
|
|
79
|
+
export declare function useCreateWin(options?: Omit<UseMutationOptions<WinResponse, Error, CreateWinRequest>, 'mutationFn'>): UseMutationResult<WinResponse, Error, CreateWinRequest>;
|
|
80
|
+
/**
|
|
81
|
+
* Create a habit
|
|
82
|
+
*
|
|
83
|
+
* @param options - TanStack Query mutation options
|
|
84
|
+
*
|
|
85
|
+
* @example
|
|
86
|
+
* ```tsx
|
|
87
|
+
* const { mutate, isPending } = useCreateHabit();
|
|
88
|
+
*
|
|
89
|
+
* mutate({
|
|
90
|
+
* name: 'Morning meditation',
|
|
91
|
+
* description: '10 minutes of mindfulness',
|
|
92
|
+
* frequency: 'daily',
|
|
93
|
+
* targetDays: 7
|
|
94
|
+
* });
|
|
95
|
+
* ```
|
|
96
|
+
*/
|
|
97
|
+
export declare function useCreateHabit(options?: Omit<UseMutationOptions<HabitResponse, Error, CreateHabitRequest>, 'mutationFn'>): UseMutationResult<HabitResponse, Error, CreateHabitRequest>;
|
|
98
|
+
/**
|
|
99
|
+
* Update a habit
|
|
100
|
+
*
|
|
101
|
+
* @param options - TanStack Query mutation options
|
|
102
|
+
*
|
|
103
|
+
* @example
|
|
104
|
+
* ```tsx
|
|
105
|
+
* const { mutate, isPending } = useUpdateHabit();
|
|
106
|
+
*
|
|
107
|
+
* mutate({
|
|
108
|
+
* id: 'habit-123',
|
|
109
|
+
* data: {
|
|
110
|
+
* name: 'Evening meditation',
|
|
111
|
+
* targetDays: 14
|
|
112
|
+
* }
|
|
113
|
+
* });
|
|
114
|
+
* ```
|
|
115
|
+
*/
|
|
116
|
+
export declare function useUpdateHabit(options?: Omit<UseMutationOptions<HabitResponse, Error, {
|
|
117
|
+
id: string;
|
|
118
|
+
data: UpdateHabitRequest;
|
|
119
|
+
}>, 'mutationFn'>): UseMutationResult<HabitResponse, Error, {
|
|
120
|
+
id: string;
|
|
121
|
+
data: UpdateHabitRequest;
|
|
122
|
+
}>;
|
|
123
|
+
/**
|
|
124
|
+
* Delete a habit
|
|
125
|
+
*
|
|
126
|
+
* @param options - TanStack Query mutation options
|
|
127
|
+
*
|
|
128
|
+
* @example
|
|
129
|
+
* ```tsx
|
|
130
|
+
* const { mutate, isPending } = useDeleteHabit();
|
|
131
|
+
*
|
|
132
|
+
* mutate('habit-123');
|
|
133
|
+
* ```
|
|
134
|
+
*/
|
|
135
|
+
export declare function useDeleteHabit(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
|
|
136
|
+
/**
|
|
137
|
+
* Complete a habit for today
|
|
138
|
+
*
|
|
139
|
+
* @param options - TanStack Query mutation options
|
|
140
|
+
*
|
|
141
|
+
* @example
|
|
142
|
+
* ```tsx
|
|
143
|
+
* const { mutate, isPending } = useCompleteHabit();
|
|
144
|
+
*
|
|
145
|
+
* mutate('habit-123');
|
|
146
|
+
* ```
|
|
147
|
+
*/
|
|
148
|
+
export declare function useCompleteHabit(options?: Omit<UseMutationOptions<HabitResponse, Error, string>, 'mutationFn'>): UseMutationResult<HabitResponse, Error, string>;
|
|
149
|
+
/**
|
|
150
|
+
* Create a reflection
|
|
151
|
+
*
|
|
152
|
+
* @param options - TanStack Query mutation options
|
|
153
|
+
*
|
|
154
|
+
* @example
|
|
155
|
+
* ```tsx
|
|
156
|
+
* const { mutate, isPending } = useCreateReflection();
|
|
157
|
+
*
|
|
158
|
+
* mutate({
|
|
159
|
+
* content: 'Today I learned...',
|
|
160
|
+
* category: 'growth',
|
|
161
|
+
* mood: 8
|
|
162
|
+
* });
|
|
163
|
+
* ```
|
|
164
|
+
*/
|
|
165
|
+
export declare function useCreateReflection(options?: Omit<UseMutationOptions<ReflectionResponse, Error, CreateReflectionRequest>, 'mutationFn'>): UseMutationResult<ReflectionResponse, Error, CreateReflectionRequest>;
|