@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,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>;
|