@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.
Files changed (129) hide show
  1. package/README.md +276 -0
  2. package/dist/__tests__/e2e.test.d.ts +7 -0
  3. package/dist/__tests__/e2e.test.js +472 -0
  4. package/dist/api/client.d.ts +11 -0
  5. package/dist/api/client.js +61 -0
  6. package/dist/api/mutations/admin.d.ts +167 -0
  7. package/dist/api/mutations/admin.js +326 -0
  8. package/dist/api/mutations/ambassadors.d.ts +52 -0
  9. package/dist/api/mutations/ambassadors.js +148 -0
  10. package/dist/api/mutations/auth.d.ts +267 -0
  11. package/dist/api/mutations/auth.js +332 -0
  12. package/dist/api/mutations/bookings.d.ts +59 -0
  13. package/dist/api/mutations/bookings.js +143 -0
  14. package/dist/api/mutations/event-chat.d.ts +35 -0
  15. package/dist/api/mutations/event-chat.js +147 -0
  16. package/dist/api/mutations/events.d.ts +87 -0
  17. package/dist/api/mutations/events.js +205 -0
  18. package/dist/api/mutations/grow90.d.ts +36 -0
  19. package/dist/api/mutations/grow90.js +132 -0
  20. package/dist/api/mutations/hubs.d.ts +111 -0
  21. package/dist/api/mutations/hubs.js +240 -0
  22. package/dist/api/mutations/index.d.ts +22 -0
  23. package/dist/api/mutations/index.js +39 -0
  24. package/dist/api/mutations/jack.d.ts +61 -0
  25. package/dist/api/mutations/jack.js +104 -0
  26. package/dist/api/mutations/library.d.ts +67 -0
  27. package/dist/api/mutations/library.js +168 -0
  28. package/dist/api/mutations/map.d.ts +153 -0
  29. package/dist/api/mutations/map.js +181 -0
  30. package/dist/api/mutations/matching.d.ts +130 -0
  31. package/dist/api/mutations/matching.js +204 -0
  32. package/dist/api/mutations/notifications.d.ts +63 -0
  33. package/dist/api/mutations/notifications.js +106 -0
  34. package/dist/api/mutations/offers.d.ts +26 -0
  35. package/dist/api/mutations/offers.js +47 -0
  36. package/dist/api/mutations/subscriptions.d.ts +127 -0
  37. package/dist/api/mutations/subscriptions.js +140 -0
  38. package/dist/api/mutations/support.d.ts +165 -0
  39. package/dist/api/mutations/support.js +307 -0
  40. package/dist/api/mutations/users.d.ts +211 -0
  41. package/dist/api/mutations/users.js +261 -0
  42. package/dist/api/queries/admin.d.ts +257 -0
  43. package/dist/api/queries/admin.js +320 -0
  44. package/dist/api/queries/ambassadors.d.ts +53 -0
  45. package/dist/api/queries/ambassadors.js +98 -0
  46. package/dist/api/queries/auth.d.ts +16 -0
  47. package/dist/api/queries/auth.js +25 -0
  48. package/dist/api/queries/bookings.d.ts +91 -0
  49. package/dist/api/queries/bookings.js +102 -0
  50. package/dist/api/queries/businesses.d.ts +212 -0
  51. package/dist/api/queries/businesses.js +154 -0
  52. package/dist/api/queries/event-chat.d.ts +19 -0
  53. package/dist/api/queries/event-chat.js +75 -0
  54. package/dist/api/queries/events.d.ts +322 -0
  55. package/dist/api/queries/events.js +221 -0
  56. package/dist/api/queries/grow90.d.ts +26 -0
  57. package/dist/api/queries/grow90.js +85 -0
  58. package/dist/api/queries/hubs.d.ts +165 -0
  59. package/dist/api/queries/hubs.js +143 -0
  60. package/dist/api/queries/index.d.ts +23 -0
  61. package/dist/api/queries/index.js +40 -0
  62. package/dist/api/queries/jack.d.ts +63 -0
  63. package/dist/api/queries/jack.js +92 -0
  64. package/dist/api/queries/library.d.ts +132 -0
  65. package/dist/api/queries/library.js +120 -0
  66. package/dist/api/queries/map.d.ts +216 -0
  67. package/dist/api/queries/map.js +278 -0
  68. package/dist/api/queries/matching.d.ts +136 -0
  69. package/dist/api/queries/matching.js +161 -0
  70. package/dist/api/queries/notifications.d.ts +78 -0
  71. package/dist/api/queries/notifications.js +88 -0
  72. package/dist/api/queries/offers.d.ts +91 -0
  73. package/dist/api/queries/offers.js +103 -0
  74. package/dist/api/queries/subscriptions.d.ts +56 -0
  75. package/dist/api/queries/subscriptions.js +73 -0
  76. package/dist/api/queries/support.d.ts +106 -0
  77. package/dist/api/queries/support.js +202 -0
  78. package/dist/api/queries/users.d.ts +293 -0
  79. package/dist/api/queries/users.js +370 -0
  80. package/dist/api/types.d.ts +464 -0
  81. package/dist/api/types.js +9 -0
  82. package/dist/hooks/useAuth.d.ts +5 -0
  83. package/dist/hooks/useAuth.js +39 -0
  84. package/dist/hooks/useUser.d.ts +43 -0
  85. package/dist/hooks/useUser.js +44 -0
  86. package/dist/index.d.ts +36 -0
  87. package/dist/index.js +67 -0
  88. package/package.json +62 -0
  89. package/src/__tests__/e2e.test.ts +502 -0
  90. package/src/api/client.ts +71 -0
  91. package/src/api/mutations/admin.ts +531 -0
  92. package/src/api/mutations/ambassadors.ts +185 -0
  93. package/src/api/mutations/auth.ts +350 -0
  94. package/src/api/mutations/bookings.ts +190 -0
  95. package/src/api/mutations/event-chat.ts +177 -0
  96. package/src/api/mutations/events.ts +273 -0
  97. package/src/api/mutations/grow90.ts +169 -0
  98. package/src/api/mutations/hubs.ts +385 -0
  99. package/src/api/mutations/index.ts +23 -0
  100. package/src/api/mutations/jack.ts +130 -0
  101. package/src/api/mutations/library.ts +212 -0
  102. package/src/api/mutations/map.ts +230 -0
  103. package/src/api/mutations/matching.ts +271 -0
  104. package/src/api/mutations/notifications.ts +114 -0
  105. package/src/api/mutations/offers.ts +73 -0
  106. package/src/api/mutations/subscriptions.ts +162 -0
  107. package/src/api/mutations/support.ts +390 -0
  108. package/src/api/mutations/users.ts +271 -0
  109. package/src/api/queries/admin.ts +480 -0
  110. package/src/api/queries/ambassadors.ts +139 -0
  111. package/src/api/queries/auth.ts +24 -0
  112. package/src/api/queries/bookings.ts +135 -0
  113. package/src/api/queries/businesses.ts +203 -0
  114. package/src/api/queries/event-chat.ts +78 -0
  115. package/src/api/queries/events.ts +272 -0
  116. package/src/api/queries/grow90.ts +98 -0
  117. package/src/api/queries/hubs.ts +211 -0
  118. package/src/api/queries/index.ts +24 -0
  119. package/src/api/queries/jack.ts +127 -0
  120. package/src/api/queries/library.ts +166 -0
  121. package/src/api/queries/map.ts +331 -0
  122. package/src/api/queries/matching.ts +238 -0
  123. package/src/api/queries/notifications.ts +103 -0
  124. package/src/api/queries/offers.ts +136 -0
  125. package/src/api/queries/subscriptions.ts +91 -0
  126. package/src/api/queries/support.ts +235 -0
  127. package/src/api/queries/users.ts +393 -0
  128. package/src/api/types.ts +596 -0
  129. package/src/index.ts +57 -0
@@ -0,0 +1,181 @@
1
+ "use strict";
2
+ /**
3
+ * Map Mutation Hooks
4
+ *
5
+ * TanStack Query mutation hooks for map-related write operations.
6
+ * These hooks handle updating user location and visibility settings.
7
+ *
8
+ * @module api/mutations/map
9
+ */
10
+ Object.defineProperty(exports, "__esModule", { value: true });
11
+ exports.useUpdateLocation = useUpdateLocation;
12
+ exports.useUpdateOpenToMeet = useUpdateOpenToMeet;
13
+ const react_query_1 = require("@tanstack/react-query");
14
+ const client_1 = require("../client");
15
+ const map_1 = require("../queries/map");
16
+ const users_1 = require("../queries/users");
17
+ // ============================================================================
18
+ // MUTATION HOOKS
19
+ // ============================================================================
20
+ /**
21
+ * Update current user's location
22
+ *
23
+ * @description
24
+ * Updates the authenticated user's location for display on the member map.
25
+ * Location is only visible to other users if the user has enabled "open to meet".
26
+ *
27
+ * @endpoint PUT /api/v1/map/location
28
+ *
29
+ * @example
30
+ * ```tsx
31
+ * import { useUpdateLocation } from '@growsober/sdk';
32
+ *
33
+ * function LocationUpdater() {
34
+ * const updateLocation = useUpdateLocation();
35
+ *
36
+ * const handleLocationUpdate = async () => {
37
+ * // Get current position from device
38
+ * navigator.geolocation.getCurrentPosition(
39
+ * async (position) => {
40
+ * await updateLocation.mutateAsync({
41
+ * lat: position.coords.latitude,
42
+ * lng: position.coords.longitude,
43
+ * });
44
+ * },
45
+ * (error) => console.error('Location error:', error)
46
+ * );
47
+ * };
48
+ *
49
+ * return (
50
+ * <button onClick={handleLocationUpdate} disabled={updateLocation.isPending}>
51
+ * Update My Location
52
+ * </button>
53
+ * );
54
+ * }
55
+ * ```
56
+ *
57
+ * @example
58
+ * With Expo Location:
59
+ * ```tsx
60
+ * import * as Location from 'expo-location';
61
+ * import { useUpdateLocation } from '@growsober/sdk';
62
+ *
63
+ * function App() {
64
+ * const updateLocation = useUpdateLocation();
65
+ *
66
+ * useEffect(() => {
67
+ * (async () => {
68
+ * const { status } = await Location.requestForegroundPermissionsAsync();
69
+ * if (status === 'granted') {
70
+ * const location = await Location.getCurrentPositionAsync({});
71
+ * updateLocation.mutate({
72
+ * lat: location.coords.latitude,
73
+ * lng: location.coords.longitude,
74
+ * });
75
+ * }
76
+ * })();
77
+ * }, []);
78
+ * }
79
+ * ```
80
+ *
81
+ * @param options - TanStack Query mutation options
82
+ * @returns TanStack Query mutation result
83
+ */
84
+ function useUpdateLocation(options) {
85
+ const queryClient = (0, react_query_1.useQueryClient)();
86
+ return (0, react_query_1.useMutation)({
87
+ mutationFn: async (data) => {
88
+ const client = (0, client_1.getApiClient)();
89
+ const response = await client.put('/api/v1/map/location', data);
90
+ return response.data;
91
+ },
92
+ onSuccess: () => {
93
+ // Invalidate map queries to reflect new location
94
+ queryClient.invalidateQueries({ queryKey: map_1.mapKeys.members() });
95
+ // Also invalidate user data as location is stored on user
96
+ queryClient.invalidateQueries({ queryKey: users_1.userKeys.me() });
97
+ },
98
+ ...options,
99
+ });
100
+ }
101
+ /**
102
+ * Toggle "open to meet" status
103
+ *
104
+ * @description
105
+ * Updates the user's "open to meet" visibility setting.
106
+ * When enabled, the user's location will be visible to other premium members on the map.
107
+ * Premium feature.
108
+ *
109
+ * @endpoint PUT /api/v1/map/open-to-meet
110
+ *
111
+ * @example
112
+ * ```tsx
113
+ * import { useUpdateOpenToMeet } from '@growsober/sdk';
114
+ *
115
+ * function OpenToMeetToggle() {
116
+ * const updateOpenToMeet = useUpdateOpenToMeet();
117
+ * const [isOpen, setIsOpen] = useState(false);
118
+ *
119
+ * const handleToggle = async () => {
120
+ * const newValue = !isOpen;
121
+ * await updateOpenToMeet.mutateAsync({ openToMeet: newValue });
122
+ * setIsOpen(newValue);
123
+ * };
124
+ *
125
+ * return (
126
+ * <Switch
127
+ * checked={isOpen}
128
+ * onChange={handleToggle}
129
+ * disabled={updateOpenToMeet.isPending}
130
+ * />
131
+ * );
132
+ * }
133
+ * ```
134
+ *
135
+ * @example
136
+ * With user state:
137
+ * ```tsx
138
+ * import { useCurrentUser, useUpdateOpenToMeet } from '@growsober/sdk';
139
+ *
140
+ * function OpenToMeetSetting() {
141
+ * const { data: user } = useCurrentUser();
142
+ * const updateOpenToMeet = useUpdateOpenToMeet({
143
+ * onSuccess: (data) => {
144
+ * console.log(data.openToMeet ? 'Now visible on map!' : 'Hidden from map');
145
+ * },
146
+ * });
147
+ *
148
+ * return (
149
+ * <div>
150
+ * <label>Open to Meet</label>
151
+ * <Switch
152
+ * checked={user?.openToMeet}
153
+ * onChange={(checked) => updateOpenToMeet.mutate({ openToMeet: checked })}
154
+ * />
155
+ * <p>Show your location to other members</p>
156
+ * </div>
157
+ * );
158
+ * }
159
+ * ```
160
+ *
161
+ * @param options - TanStack Query mutation options
162
+ * @returns TanStack Query mutation result
163
+ */
164
+ function useUpdateOpenToMeet(options) {
165
+ const queryClient = (0, react_query_1.useQueryClient)();
166
+ return (0, react_query_1.useMutation)({
167
+ mutationFn: async (data) => {
168
+ const client = (0, client_1.getApiClient)();
169
+ const response = await client.put('/api/v1/map/open-to-meet', data);
170
+ return response.data;
171
+ },
172
+ onSuccess: () => {
173
+ // Invalidate user data to reflect new setting
174
+ queryClient.invalidateQueries({ queryKey: users_1.userKeys.me() });
175
+ // Invalidate map queries as visibility has changed
176
+ queryClient.invalidateQueries({ queryKey: map_1.mapKeys.members() });
177
+ },
178
+ ...options,
179
+ });
180
+ }
181
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map.js","sourceRoot":"","sources":["../../../src/api/mutations/map.ts"],"names":[],"mappings":";AAAA;;;;;;;GAOG;;AA2GH,8CAyBC;AAiED,kDAyBC;AA5ND,uDAK+B;AAC/B,sCAAyC;AACzC,wCAAyC;AACzC,4CAA4C;AA6B5C,+EAA+E;AAC/E,iBAAiB;AACjB,+EAA+E;AAE/E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+DG;AACH,SAAgB,iBAAiB,CAC/B,OAGC;IAED,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,IAA2B,EAAmC,EAAE;YACjF,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,sBAAsB,EACtB,IAAI,CACL,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,GAAG,EAAE;YACd,iDAAiD;YACjD,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,aAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;YAC/D,0DAA0D;YAC1D,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,gBAAQ,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QAC7D,CAAC;QACD,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8DG;AACH,SAAgB,mBAAmB,CACjC,OAGC;IAED,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,IAA6B,EAA+B,EAAE;YAC/E,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,0BAA0B,EAC1B,IAAI,CACL,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,GAAG,EAAE;YACd,8CAA8C;YAC9C,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,gBAAQ,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;YAC3D,mDAAmD;YACnD,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,aAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QACjE,CAAC;QACD,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC","sourcesContent":["/**\n * Map Mutation Hooks\n *\n * TanStack Query mutation hooks for map-related write operations.\n * These hooks handle updating user location and visibility settings.\n *\n * @module api/mutations/map\n */\n\nimport {\n  useMutation,\n  UseMutationOptions,\n  UseMutationResult,\n  useQueryClient,\n} from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { mapKeys } from '../queries/map';\nimport { userKeys } from '../queries/users';\n\n// ============================================================================\n// REQUEST TYPES\n// ============================================================================\n\nexport interface UpdateLocationRequest {\n  lat: number;\n  lng: number;\n}\n\nexport interface UpdateOpenToMeetRequest {\n  openToMeet: boolean;\n}\n\n// ============================================================================\n// RESPONSE TYPES\n// ============================================================================\n\nexport interface LocationUpdateResponse {\n  success: boolean;\n  message: string;\n}\n\nexport interface OpenToMeetResponse {\n  openToMeet: boolean;\n  message: string;\n}\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Update current user's location\n *\n * @description\n * Updates the authenticated user's location for display on the member map.\n * Location is only visible to other users if the user has enabled \"open to meet\".\n *\n * @endpoint PUT /api/v1/map/location\n *\n * @example\n * ```tsx\n * import { useUpdateLocation } from '@growsober/sdk';\n *\n * function LocationUpdater() {\n *   const updateLocation = useUpdateLocation();\n *\n *   const handleLocationUpdate = async () => {\n *     // Get current position from device\n *     navigator.geolocation.getCurrentPosition(\n *       async (position) => {\n *         await updateLocation.mutateAsync({\n *           lat: position.coords.latitude,\n *           lng: position.coords.longitude,\n *         });\n *       },\n *       (error) => console.error('Location error:', error)\n *     );\n *   };\n *\n *   return (\n *     <button onClick={handleLocationUpdate} disabled={updateLocation.isPending}>\n *       Update My Location\n *     </button>\n *   );\n * }\n * ```\n *\n * @example\n * With Expo Location:\n * ```tsx\n * import * as Location from 'expo-location';\n * import { useUpdateLocation } from '@growsober/sdk';\n *\n * function App() {\n *   const updateLocation = useUpdateLocation();\n *\n *   useEffect(() => {\n *     (async () => {\n *       const { status } = await Location.requestForegroundPermissionsAsync();\n *       if (status === 'granted') {\n *         const location = await Location.getCurrentPositionAsync({});\n *         updateLocation.mutate({\n *           lat: location.coords.latitude,\n *           lng: location.coords.longitude,\n *         });\n *       }\n *     })();\n *   }, []);\n * }\n * ```\n *\n * @param options - TanStack Query mutation options\n * @returns TanStack Query mutation result\n */\nexport function useUpdateLocation(\n  options?: Omit<\n    UseMutationOptions<LocationUpdateResponse, Error, UpdateLocationRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<LocationUpdateResponse, Error, UpdateLocationRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: UpdateLocationRequest): Promise<LocationUpdateResponse> => {\n      const client = getApiClient();\n      const response = await client.put<LocationUpdateResponse>(\n        '/api/v1/map/location',\n        data\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      // Invalidate map queries to reflect new location\n      queryClient.invalidateQueries({ queryKey: mapKeys.members() });\n      // Also invalidate user data as location is stored on user\n      queryClient.invalidateQueries({ queryKey: userKeys.me() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Toggle \"open to meet\" status\n *\n * @description\n * Updates the user's \"open to meet\" visibility setting.\n * When enabled, the user's location will be visible to other premium members on the map.\n * Premium feature.\n *\n * @endpoint PUT /api/v1/map/open-to-meet\n *\n * @example\n * ```tsx\n * import { useUpdateOpenToMeet } from '@growsober/sdk';\n *\n * function OpenToMeetToggle() {\n *   const updateOpenToMeet = useUpdateOpenToMeet();\n *   const [isOpen, setIsOpen] = useState(false);\n *\n *   const handleToggle = async () => {\n *     const newValue = !isOpen;\n *     await updateOpenToMeet.mutateAsync({ openToMeet: newValue });\n *     setIsOpen(newValue);\n *   };\n *\n *   return (\n *     <Switch\n *       checked={isOpen}\n *       onChange={handleToggle}\n *       disabled={updateOpenToMeet.isPending}\n *     />\n *   );\n * }\n * ```\n *\n * @example\n * With user state:\n * ```tsx\n * import { useCurrentUser, useUpdateOpenToMeet } from '@growsober/sdk';\n *\n * function OpenToMeetSetting() {\n *   const { data: user } = useCurrentUser();\n *   const updateOpenToMeet = useUpdateOpenToMeet({\n *     onSuccess: (data) => {\n *       console.log(data.openToMeet ? 'Now visible on map!' : 'Hidden from map');\n *     },\n *   });\n *\n *   return (\n *     <div>\n *       <label>Open to Meet</label>\n *       <Switch\n *         checked={user?.openToMeet}\n *         onChange={(checked) => updateOpenToMeet.mutate({ openToMeet: checked })}\n *       />\n *       <p>Show your location to other members</p>\n *     </div>\n *   );\n * }\n * ```\n *\n * @param options - TanStack Query mutation options\n * @returns TanStack Query mutation result\n */\nexport function useUpdateOpenToMeet(\n  options?: Omit<\n    UseMutationOptions<OpenToMeetResponse, Error, UpdateOpenToMeetRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<OpenToMeetResponse, Error, UpdateOpenToMeetRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: UpdateOpenToMeetRequest): Promise<OpenToMeetResponse> => {\n      const client = getApiClient();\n      const response = await client.put<OpenToMeetResponse>(\n        '/api/v1/map/open-to-meet',\n        data\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      // Invalidate user data to reflect new setting\n      queryClient.invalidateQueries({ queryKey: userKeys.me() });\n      // Invalidate map queries as visibility has changed\n      queryClient.invalidateQueries({ queryKey: mapKeys.members() });\n    },\n    ...options,\n  });\n}\n"]}
@@ -0,0 +1,130 @@
1
+ import { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
2
+ import { MatchResponse, BuddyResponse } from '../queries/matching';
3
+ export interface CreateMatchRequest {
4
+ matchedUserId: string;
5
+ message?: string;
6
+ }
7
+ export interface UpdateMatchRequest {
8
+ status: 'ACCEPTED' | 'DECLINED' | 'BLOCKED';
9
+ }
10
+ export interface CreateBuddyRequest {
11
+ buddyId: string;
12
+ message?: string;
13
+ }
14
+ export interface UpdateBuddyRequest {
15
+ status: 'ACCEPTED' | 'DECLINED' | 'ENDED';
16
+ }
17
+ export interface LogBuddyActivityRequest {
18
+ type: 'CHECK_IN' | 'MESSAGE' | 'SUPPORT';
19
+ note?: string;
20
+ }
21
+ /**
22
+ * Create a new match request
23
+ *
24
+ * @endpoint POST /api/v1/matching/matches
25
+ *
26
+ * @example
27
+ * ```tsx
28
+ * const createMatch = useCreateMatch();
29
+ * await createMatch.mutateAsync({ matchedUserId: 'user-123' });
30
+ * ```
31
+ */
32
+ export declare function useCreateMatch(options?: Omit<UseMutationOptions<MatchResponse, Error, CreateMatchRequest>, 'mutationFn'>): UseMutationResult<MatchResponse, Error, CreateMatchRequest>;
33
+ /**
34
+ * Update match status (accept/decline/block)
35
+ *
36
+ * @endpoint PUT /api/v1/matching/matches/:matchId
37
+ *
38
+ * @example
39
+ * ```tsx
40
+ * const updateMatch = useUpdateMatch();
41
+ * await updateMatch.mutateAsync({ matchId: 'match-123', status: 'ACCEPTED' });
42
+ * ```
43
+ */
44
+ export declare function useUpdateMatch(options?: Omit<UseMutationOptions<MatchResponse, Error, {
45
+ matchId: string;
46
+ data: UpdateMatchRequest;
47
+ }>, 'mutationFn'>): UseMutationResult<MatchResponse, Error, {
48
+ matchId: string;
49
+ data: UpdateMatchRequest;
50
+ }>;
51
+ /**
52
+ * Accept a match (convenience hook)
53
+ *
54
+ * @example
55
+ * ```tsx
56
+ * const acceptMatch = useAcceptMatch();
57
+ * await acceptMatch.mutateAsync('match-123');
58
+ * ```
59
+ */
60
+ export declare function useAcceptMatch(options?: Omit<UseMutationOptions<MatchResponse, Error, string>, 'mutationFn'>): UseMutationResult<MatchResponse, Error, string>;
61
+ /**
62
+ * Decline a match (convenience hook)
63
+ *
64
+ * @example
65
+ * ```tsx
66
+ * const declineMatch = useDeclineMatch();
67
+ * await declineMatch.mutateAsync('match-123');
68
+ * ```
69
+ */
70
+ export declare function useDeclineMatch(options?: Omit<UseMutationOptions<MatchResponse, Error, string>, 'mutationFn'>): UseMutationResult<MatchResponse, Error, string>;
71
+ /**
72
+ * Delete a match
73
+ *
74
+ * @endpoint DELETE /api/v1/matching/matches/:matchId
75
+ *
76
+ * @example
77
+ * ```tsx
78
+ * const deleteMatch = useDeleteMatch();
79
+ * await deleteMatch.mutateAsync('match-123');
80
+ * ```
81
+ */
82
+ export declare function useDeleteMatch(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
83
+ /**
84
+ * Request someone as accountability buddy
85
+ *
86
+ * @endpoint POST /api/v1/matching/buddies
87
+ *
88
+ * @example
89
+ * ```tsx
90
+ * const requestBuddy = useRequestBuddy();
91
+ * await requestBuddy.mutateAsync({ buddyId: 'user-123' });
92
+ * ```
93
+ */
94
+ export declare function useRequestBuddy(options?: Omit<UseMutationOptions<BuddyResponse, Error, CreateBuddyRequest>, 'mutationFn'>): UseMutationResult<BuddyResponse, Error, CreateBuddyRequest>;
95
+ /**
96
+ * Update buddy request (accept/decline/end)
97
+ *
98
+ * @endpoint PUT /api/v1/matching/buddies/:buddyId
99
+ *
100
+ * @example
101
+ * ```tsx
102
+ * const updateBuddy = useUpdateBuddy();
103
+ * await updateBuddy.mutateAsync({ buddyId: 'buddy-123', data: { status: 'ACCEPTED' } });
104
+ * ```
105
+ */
106
+ export declare function useUpdateBuddy(options?: Omit<UseMutationOptions<BuddyResponse, Error, {
107
+ buddyId: string;
108
+ data: UpdateBuddyRequest;
109
+ }>, 'mutationFn'>): UseMutationResult<BuddyResponse, Error, {
110
+ buddyId: string;
111
+ data: UpdateBuddyRequest;
112
+ }>;
113
+ /**
114
+ * Log activity with buddy (check-in, message)
115
+ *
116
+ * @endpoint POST /api/v1/matching/buddies/:buddyId/activity
117
+ *
118
+ * @example
119
+ * ```tsx
120
+ * const logActivity = useLogBuddyActivity();
121
+ * await logActivity.mutateAsync({ buddyId: 'buddy-123', data: { type: 'CHECK_IN' } });
122
+ * ```
123
+ */
124
+ export declare function useLogBuddyActivity(options?: Omit<UseMutationOptions<void, Error, {
125
+ buddyId: string;
126
+ data: LogBuddyActivityRequest;
127
+ }>, 'mutationFn'>): UseMutationResult<void, Error, {
128
+ buddyId: string;
129
+ data: LogBuddyActivityRequest;
130
+ }>;
@@ -0,0 +1,204 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useCreateMatch = useCreateMatch;
4
+ exports.useUpdateMatch = useUpdateMatch;
5
+ exports.useAcceptMatch = useAcceptMatch;
6
+ exports.useDeclineMatch = useDeclineMatch;
7
+ exports.useDeleteMatch = useDeleteMatch;
8
+ exports.useRequestBuddy = useRequestBuddy;
9
+ exports.useUpdateBuddy = useUpdateBuddy;
10
+ exports.useLogBuddyActivity = useLogBuddyActivity;
11
+ const react_query_1 = require("@tanstack/react-query");
12
+ const client_1 = require("../client");
13
+ const matching_1 = require("../queries/matching");
14
+ // ============================================================================
15
+ // MUTATION HOOKS
16
+ // ============================================================================
17
+ /**
18
+ * Create a new match request
19
+ *
20
+ * @endpoint POST /api/v1/matching/matches
21
+ *
22
+ * @example
23
+ * ```tsx
24
+ * const createMatch = useCreateMatch();
25
+ * await createMatch.mutateAsync({ matchedUserId: 'user-123' });
26
+ * ```
27
+ */
28
+ function useCreateMatch(options) {
29
+ const queryClient = (0, react_query_1.useQueryClient)();
30
+ return (0, react_query_1.useMutation)({
31
+ mutationFn: async (data) => {
32
+ const client = (0, client_1.getApiClient)();
33
+ const response = await client.post('/api/v1/matching/matches', data);
34
+ return response.data?.data || response.data;
35
+ },
36
+ onSuccess: () => {
37
+ queryClient.invalidateQueries({ queryKey: matching_1.matchingKeys.matches() });
38
+ queryClient.invalidateQueries({ queryKey: matching_1.matchingKeys.stats() });
39
+ },
40
+ ...options,
41
+ });
42
+ }
43
+ /**
44
+ * Update match status (accept/decline/block)
45
+ *
46
+ * @endpoint PUT /api/v1/matching/matches/:matchId
47
+ *
48
+ * @example
49
+ * ```tsx
50
+ * const updateMatch = useUpdateMatch();
51
+ * await updateMatch.mutateAsync({ matchId: 'match-123', status: 'ACCEPTED' });
52
+ * ```
53
+ */
54
+ function useUpdateMatch(options) {
55
+ const queryClient = (0, react_query_1.useQueryClient)();
56
+ return (0, react_query_1.useMutation)({
57
+ mutationFn: async ({ matchId, data }) => {
58
+ const client = (0, client_1.getApiClient)();
59
+ const response = await client.put(`/api/v1/matching/matches/${matchId}`, data);
60
+ return response.data?.data || response.data;
61
+ },
62
+ onSuccess: () => {
63
+ queryClient.invalidateQueries({ queryKey: matching_1.matchingKeys.matches() });
64
+ queryClient.invalidateQueries({ queryKey: matching_1.matchingKeys.stats() });
65
+ },
66
+ ...options,
67
+ });
68
+ }
69
+ /**
70
+ * Accept a match (convenience hook)
71
+ *
72
+ * @example
73
+ * ```tsx
74
+ * const acceptMatch = useAcceptMatch();
75
+ * await acceptMatch.mutateAsync('match-123');
76
+ * ```
77
+ */
78
+ function useAcceptMatch(options) {
79
+ const updateMatch = useUpdateMatch();
80
+ return {
81
+ ...updateMatch,
82
+ mutate: (matchId, mutateOptions) => updateMatch.mutate({ matchId, data: { status: 'ACCEPTED' } }, mutateOptions),
83
+ mutateAsync: (matchId) => updateMatch.mutateAsync({ matchId, data: { status: 'ACCEPTED' } }),
84
+ };
85
+ }
86
+ /**
87
+ * Decline a match (convenience hook)
88
+ *
89
+ * @example
90
+ * ```tsx
91
+ * const declineMatch = useDeclineMatch();
92
+ * await declineMatch.mutateAsync('match-123');
93
+ * ```
94
+ */
95
+ function useDeclineMatch(options) {
96
+ const updateMatch = useUpdateMatch();
97
+ return {
98
+ ...updateMatch,
99
+ mutate: (matchId, mutateOptions) => updateMatch.mutate({ matchId, data: { status: 'DECLINED' } }, mutateOptions),
100
+ mutateAsync: (matchId) => updateMatch.mutateAsync({ matchId, data: { status: 'DECLINED' } }),
101
+ };
102
+ }
103
+ /**
104
+ * Delete a match
105
+ *
106
+ * @endpoint DELETE /api/v1/matching/matches/:matchId
107
+ *
108
+ * @example
109
+ * ```tsx
110
+ * const deleteMatch = useDeleteMatch();
111
+ * await deleteMatch.mutateAsync('match-123');
112
+ * ```
113
+ */
114
+ function useDeleteMatch(options) {
115
+ const queryClient = (0, react_query_1.useQueryClient)();
116
+ return (0, react_query_1.useMutation)({
117
+ mutationFn: async (matchId) => {
118
+ const client = (0, client_1.getApiClient)();
119
+ await client.delete(`/api/v1/matching/matches/${matchId}`);
120
+ },
121
+ onSuccess: () => {
122
+ queryClient.invalidateQueries({ queryKey: matching_1.matchingKeys.matches() });
123
+ queryClient.invalidateQueries({ queryKey: matching_1.matchingKeys.stats() });
124
+ },
125
+ ...options,
126
+ });
127
+ }
128
+ /**
129
+ * Request someone as accountability buddy
130
+ *
131
+ * @endpoint POST /api/v1/matching/buddies
132
+ *
133
+ * @example
134
+ * ```tsx
135
+ * const requestBuddy = useRequestBuddy();
136
+ * await requestBuddy.mutateAsync({ buddyId: 'user-123' });
137
+ * ```
138
+ */
139
+ function useRequestBuddy(options) {
140
+ const queryClient = (0, react_query_1.useQueryClient)();
141
+ return (0, react_query_1.useMutation)({
142
+ mutationFn: async (data) => {
143
+ const client = (0, client_1.getApiClient)();
144
+ const response = await client.post('/api/v1/matching/buddies', data);
145
+ return response.data?.data || response.data;
146
+ },
147
+ onSuccess: () => {
148
+ queryClient.invalidateQueries({ queryKey: matching_1.matchingKeys.buddies() });
149
+ queryClient.invalidateQueries({ queryKey: matching_1.matchingKeys.buddyRequests() });
150
+ },
151
+ ...options,
152
+ });
153
+ }
154
+ /**
155
+ * Update buddy request (accept/decline/end)
156
+ *
157
+ * @endpoint PUT /api/v1/matching/buddies/:buddyId
158
+ *
159
+ * @example
160
+ * ```tsx
161
+ * const updateBuddy = useUpdateBuddy();
162
+ * await updateBuddy.mutateAsync({ buddyId: 'buddy-123', data: { status: 'ACCEPTED' } });
163
+ * ```
164
+ */
165
+ function useUpdateBuddy(options) {
166
+ const queryClient = (0, react_query_1.useQueryClient)();
167
+ return (0, react_query_1.useMutation)({
168
+ mutationFn: async ({ buddyId, data }) => {
169
+ const client = (0, client_1.getApiClient)();
170
+ const response = await client.put(`/api/v1/matching/buddies/${buddyId}`, data);
171
+ return response.data?.data || response.data;
172
+ },
173
+ onSuccess: () => {
174
+ queryClient.invalidateQueries({ queryKey: matching_1.matchingKeys.buddies() });
175
+ queryClient.invalidateQueries({ queryKey: matching_1.matchingKeys.buddyRequests() });
176
+ },
177
+ ...options,
178
+ });
179
+ }
180
+ /**
181
+ * Log activity with buddy (check-in, message)
182
+ *
183
+ * @endpoint POST /api/v1/matching/buddies/:buddyId/activity
184
+ *
185
+ * @example
186
+ * ```tsx
187
+ * const logActivity = useLogBuddyActivity();
188
+ * await logActivity.mutateAsync({ buddyId: 'buddy-123', data: { type: 'CHECK_IN' } });
189
+ * ```
190
+ */
191
+ function useLogBuddyActivity(options) {
192
+ const queryClient = (0, react_query_1.useQueryClient)();
193
+ return (0, react_query_1.useMutation)({
194
+ mutationFn: async ({ buddyId, data }) => {
195
+ const client = (0, client_1.getApiClient)();
196
+ await client.post(`/api/v1/matching/buddies/${buddyId}/activity`, data);
197
+ },
198
+ onSuccess: () => {
199
+ queryClient.invalidateQueries({ queryKey: matching_1.matchingKeys.buddies() });
200
+ },
201
+ ...options,
202
+ });
203
+ }
204
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"matching.js","sourceRoot":"","sources":["../../../src/api/mutations/matching.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 { matchingKeys, MatchResponse, BuddyResponse } from '../queries/matching';\n\n// ============================================================================\n// REQUEST TYPES\n// ============================================================================\n\nexport interface CreateMatchRequest {\n  matchedUserId: string;\n  message?: string;\n}\n\nexport interface UpdateMatchRequest {\n  status: 'ACCEPTED' | 'DECLINED' | 'BLOCKED';\n}\n\nexport interface CreateBuddyRequest {\n  buddyId: string;\n  message?: string;\n}\n\nexport interface UpdateBuddyRequest {\n  status: 'ACCEPTED' | 'DECLINED' | 'ENDED';\n}\n\nexport interface LogBuddyActivityRequest {\n  type: 'CHECK_IN' | 'MESSAGE' | 'SUPPORT';\n  note?: string;\n}\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a new match request\n *\n * @endpoint POST /api/v1/matching/matches\n *\n * @example\n * ```tsx\n * const createMatch = useCreateMatch();\n * await createMatch.mutateAsync({ matchedUserId: 'user-123' });\n * ```\n */\nexport function useCreateMatch(\n  options?: Omit<UseMutationOptions<MatchResponse, Error, CreateMatchRequest>, 'mutationFn'>\n): UseMutationResult<MatchResponse, Error, CreateMatchRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateMatchRequest): Promise<MatchResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/matching/matches', data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: matchingKeys.matches() });\n      queryClient.invalidateQueries({ queryKey: matchingKeys.stats() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Update match status (accept/decline/block)\n *\n * @endpoint PUT /api/v1/matching/matches/:matchId\n *\n * @example\n * ```tsx\n * const updateMatch = useUpdateMatch();\n * await updateMatch.mutateAsync({ matchId: 'match-123', status: 'ACCEPTED' });\n * ```\n */\nexport function useUpdateMatch(\n  options?: Omit<\n    UseMutationOptions<MatchResponse, Error, { matchId: string; data: UpdateMatchRequest }>,\n    'mutationFn'\n  >\n): UseMutationResult<MatchResponse, Error, { matchId: string; data: UpdateMatchRequest }> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ matchId, data }): Promise<MatchResponse> => {\n      const client = getApiClient();\n      const response = await client.put(`/api/v1/matching/matches/${matchId}`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: matchingKeys.matches() });\n      queryClient.invalidateQueries({ queryKey: matchingKeys.stats() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Accept a match (convenience hook)\n *\n * @example\n * ```tsx\n * const acceptMatch = useAcceptMatch();\n * await acceptMatch.mutateAsync('match-123');\n * ```\n */\nexport function useAcceptMatch(\n  options?: Omit<UseMutationOptions<MatchResponse, Error, string>, 'mutationFn'>\n): UseMutationResult<MatchResponse, Error, string> {\n  const updateMatch = useUpdateMatch();\n\n  return {\n    ...updateMatch,\n    mutate: (matchId: string, mutateOptions?: any) =>\n      updateMatch.mutate({ matchId, data: { status: 'ACCEPTED' } }, mutateOptions),\n    mutateAsync: (matchId: string) =>\n      updateMatch.mutateAsync({ matchId, data: { status: 'ACCEPTED' } }),\n  } as UseMutationResult<MatchResponse, Error, string>;\n}\n\n/**\n * Decline a match (convenience hook)\n *\n * @example\n * ```tsx\n * const declineMatch = useDeclineMatch();\n * await declineMatch.mutateAsync('match-123');\n * ```\n */\nexport function useDeclineMatch(\n  options?: Omit<UseMutationOptions<MatchResponse, Error, string>, 'mutationFn'>\n): UseMutationResult<MatchResponse, Error, string> {\n  const updateMatch = useUpdateMatch();\n\n  return {\n    ...updateMatch,\n    mutate: (matchId: string, mutateOptions?: any) =>\n      updateMatch.mutate({ matchId, data: { status: 'DECLINED' } }, mutateOptions),\n    mutateAsync: (matchId: string) =>\n      updateMatch.mutateAsync({ matchId, data: { status: 'DECLINED' } }),\n  } as UseMutationResult<MatchResponse, Error, string>;\n}\n\n/**\n * Delete a match\n *\n * @endpoint DELETE /api/v1/matching/matches/:matchId\n *\n * @example\n * ```tsx\n * const deleteMatch = useDeleteMatch();\n * await deleteMatch.mutateAsync('match-123');\n * ```\n */\nexport function useDeleteMatch(\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>\n): UseMutationResult<void, Error, string> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (matchId: string): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/matching/matches/${matchId}`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: matchingKeys.matches() });\n      queryClient.invalidateQueries({ queryKey: matchingKeys.stats() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Request someone as accountability buddy\n *\n * @endpoint POST /api/v1/matching/buddies\n *\n * @example\n * ```tsx\n * const requestBuddy = useRequestBuddy();\n * await requestBuddy.mutateAsync({ buddyId: 'user-123' });\n * ```\n */\nexport function useRequestBuddy(\n  options?: Omit<UseMutationOptions<BuddyResponse, Error, CreateBuddyRequest>, 'mutationFn'>\n): UseMutationResult<BuddyResponse, Error, CreateBuddyRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateBuddyRequest): Promise<BuddyResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/matching/buddies', data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: matchingKeys.buddies() });\n      queryClient.invalidateQueries({ queryKey: matchingKeys.buddyRequests() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Update buddy request (accept/decline/end)\n *\n * @endpoint PUT /api/v1/matching/buddies/:buddyId\n *\n * @example\n * ```tsx\n * const updateBuddy = useUpdateBuddy();\n * await updateBuddy.mutateAsync({ buddyId: 'buddy-123', data: { status: 'ACCEPTED' } });\n * ```\n */\nexport function useUpdateBuddy(\n  options?: Omit<\n    UseMutationOptions<BuddyResponse, Error, { buddyId: string; data: UpdateBuddyRequest }>,\n    'mutationFn'\n  >\n): UseMutationResult<BuddyResponse, Error, { buddyId: string; data: UpdateBuddyRequest }> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ buddyId, data }): Promise<BuddyResponse> => {\n      const client = getApiClient();\n      const response = await client.put(`/api/v1/matching/buddies/${buddyId}`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: matchingKeys.buddies() });\n      queryClient.invalidateQueries({ queryKey: matchingKeys.buddyRequests() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Log activity with buddy (check-in, message)\n *\n * @endpoint POST /api/v1/matching/buddies/:buddyId/activity\n *\n * @example\n * ```tsx\n * const logActivity = useLogBuddyActivity();\n * await logActivity.mutateAsync({ buddyId: 'buddy-123', data: { type: 'CHECK_IN' } });\n * ```\n */\nexport function useLogBuddyActivity(\n  options?: Omit<\n    UseMutationOptions<void, Error, { buddyId: string; data: LogBuddyActivityRequest }>,\n    'mutationFn'\n  >\n): UseMutationResult<void, Error, { buddyId: string; data: LogBuddyActivityRequest }> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ buddyId, data }): Promise<void> => {\n      const client = getApiClient();\n      await client.post(`/api/v1/matching/buddies/${buddyId}/activity`, data);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: matchingKeys.buddies() });\n    },\n    ...options,\n  });\n}\n"]}
@@ -0,0 +1,63 @@
1
+ import { UseMutationOptions } from '@tanstack/react-query';
2
+ import type { NotificationResponse } from '../types';
3
+ /**
4
+ * Mark a notification as read
5
+ *
6
+ * @param options - TanStack Query mutation options
7
+ *
8
+ * @example
9
+ * ```tsx
10
+ * const { mutate: markAsRead } = useMarkNotificationRead();
11
+ *
12
+ * const handleNotificationClick = (notificationId: string) => {
13
+ * markAsRead(notificationId);
14
+ * };
15
+ * ```
16
+ */
17
+ export declare function useMarkNotificationRead(options?: Omit<UseMutationOptions<NotificationResponse, Error, string>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
18
+ id: string;
19
+ userId: string;
20
+ type: "EVENT_REMINDER" | "EVENT_CANCELLED" | "EVENT_UPDATED" | "NEW_EVENT" | "HUB_WELCOME" | "NEW_MEMBER" | "STREAK_MILESTONE" | "DAILY_REMINDER" | "JACK_RESPONSE" | "WEEKLY_REFLECTION" | "BADGE_EARNED" | "SYSTEM_UPDATE";
21
+ title: string;
22
+ body?: Record<string, never>;
23
+ data?: Record<string, never>;
24
+ imageUrl?: Record<string, never>;
25
+ channel: "APP" | "EMAIL" | "PUSH" | "SMS" | "WHATSAPP";
26
+ isRead: boolean;
27
+ sentAt?: Record<string, never>;
28
+ readAt?: Record<string, never>;
29
+ actionUrl?: Record<string, never>;
30
+ deliveryStatus: "PENDING" | "SENT" | "DELIVERED" | "FAILED";
31
+ errorMessage?: Record<string, never>;
32
+ createdAt: string;
33
+ }, Error, string, unknown>;
34
+ /**
35
+ * Mark all notifications as read
36
+ *
37
+ * @param options - TanStack Query mutation options
38
+ *
39
+ * @example
40
+ * ```tsx
41
+ * const { mutate: markAllRead, isPending } = useMarkAllNotificationsRead();
42
+ *
43
+ * const handleMarkAllRead = () => {
44
+ * markAllRead();
45
+ * };
46
+ * ```
47
+ */
48
+ export declare function useMarkAllNotificationsRead(options?: Omit<UseMutationOptions<void, Error, void>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<void, Error, void, unknown>;
49
+ /**
50
+ * Delete a notification
51
+ *
52
+ * @param options - TanStack Query mutation options
53
+ *
54
+ * @example
55
+ * ```tsx
56
+ * const { mutate: deleteNotification } = useDeleteNotification();
57
+ *
58
+ * const handleDelete = (notificationId: string) => {
59
+ * deleteNotification(notificationId);
60
+ * };
61
+ * ```
62
+ */
63
+ export declare function useDeleteNotification(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<void, Error, string, unknown>;