@spotsdev/sdk 1.4.0 → 1.5.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +2166 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +1656 -0
- package/dist/index.d.ts +1655 -36
- package/dist/index.js +2021 -64
- package/dist/index.js.map +1 -0
- package/package.json +22 -6
- package/src/api/entities.ts +171 -170
- package/src/api/mutations/products.ts +18 -2
- package/src/api/queries/index.ts +4 -0
- package/src/api/queries/payments.ts +67 -0
- package/dist/api/client.d.ts +0 -12
- package/dist/api/client.js +0 -72
- package/dist/api/entities.d.ts +0 -305
- package/dist/api/entities.js +0 -13
- package/dist/api/mutations/clubs.d.ts +0 -47
- package/dist/api/mutations/clubs.js +0 -97
- package/dist/api/mutations/conversations.d.ts +0 -45
- package/dist/api/mutations/conversations.js +0 -114
- package/dist/api/mutations/index.d.ts +0 -14
- package/dist/api/mutations/index.js +0 -40
- package/dist/api/mutations/notifications.d.ts +0 -38
- package/dist/api/mutations/notifications.js +0 -64
- package/dist/api/mutations/orders.d.ts +0 -73
- package/dist/api/mutations/orders.js +0 -114
- package/dist/api/mutations/posts.d.ts +0 -123
- package/dist/api/mutations/posts.js +0 -242
- package/dist/api/mutations/products.d.ts +0 -81
- package/dist/api/mutations/products.js +0 -98
- package/dist/api/mutations/redemptions.d.ts +0 -33
- package/dist/api/mutations/redemptions.js +0 -63
- package/dist/api/mutations/spots.d.ts +0 -93
- package/dist/api/mutations/spots.js +0 -167
- package/dist/api/mutations/users.d.ts +0 -73
- package/dist/api/mutations/users.js +0 -175
- package/dist/api/queries/auth.d.ts +0 -37
- package/dist/api/queries/auth.js +0 -61
- package/dist/api/queries/clubs.d.ts +0 -52
- package/dist/api/queries/clubs.js +0 -116
- package/dist/api/queries/conversations.d.ts +0 -52
- package/dist/api/queries/conversations.js +0 -83
- package/dist/api/queries/index.d.ts +0 -28
- package/dist/api/queries/index.js +0 -69
- package/dist/api/queries/misc.d.ts +0 -30
- package/dist/api/queries/misc.js +0 -91
- package/dist/api/queries/notifications.d.ts +0 -34
- package/dist/api/queries/notifications.js +0 -62
- package/dist/api/queries/orders.d.ts +0 -45
- package/dist/api/queries/orders.js +0 -93
- package/dist/api/queries/posts.d.ts +0 -92
- package/dist/api/queries/posts.js +0 -233
- package/dist/api/queries/products.d.ts +0 -48
- package/dist/api/queries/products.js +0 -87
- package/dist/api/queries/spots.d.ts +0 -93
- package/dist/api/queries/spots.js +0 -250
- package/dist/api/queries/templates.d.ts +0 -39
- package/dist/api/queries/templates.js +0 -81
- package/dist/api/queries/users.d.ts +0 -104
- package/dist/api/queries/users.js +0 -235
- package/dist/api/queries/wallet.d.ts +0 -109
- package/dist/api/queries/wallet.js +0 -136
- package/dist/api/services/index.d.ts +0 -2
- package/dist/api/services/index.js +0 -8
- package/dist/api/services/marketplace.d.ts +0 -129
- package/dist/api/services/marketplace.js +0 -168
- package/dist/api/types.d.ts +0 -57
- package/dist/api/types.js +0 -33
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Spots Mutation Hooks
|
|
3
|
-
*
|
|
4
|
-
* TanStack Query hooks for spot mutation operations.
|
|
5
|
-
*/
|
|
6
|
-
import { type UseMutationOptions, type UseMutationResult } from '@tanstack/react-query';
|
|
7
|
-
import { type ClaimSpotRequest, type Spot } from '../types';
|
|
8
|
-
/**
|
|
9
|
-
* Create a new spot
|
|
10
|
-
*
|
|
11
|
-
* @endpoint POST /spots
|
|
12
|
-
*/
|
|
13
|
-
export declare function useCreateSpot(options?: Omit<UseMutationOptions<Spot, Error, Partial<Spot>>, 'mutationFn'>): UseMutationResult<Spot, Error, Partial<Spot>>;
|
|
14
|
-
/**
|
|
15
|
-
* Update a spot
|
|
16
|
-
*
|
|
17
|
-
* @endpoint PUT /spots/{spotId}
|
|
18
|
-
*/
|
|
19
|
-
export declare function useUpdateSpot(options?: Omit<UseMutationOptions<Spot, Error, {
|
|
20
|
-
spotId: string;
|
|
21
|
-
} & Partial<Spot>>, 'mutationFn'>): UseMutationResult<Spot, Error, {
|
|
22
|
-
spotId: string;
|
|
23
|
-
} & Partial<Spot>>;
|
|
24
|
-
/**
|
|
25
|
-
* Claim a spot (for business owners)
|
|
26
|
-
*
|
|
27
|
-
* @endpoint POST /spots/{spotId}/claim
|
|
28
|
-
*/
|
|
29
|
-
export declare function useClaimSpot(options?: Omit<UseMutationOptions<{
|
|
30
|
-
claimId: string;
|
|
31
|
-
}, Error, {
|
|
32
|
-
spotId: string;
|
|
33
|
-
} & ClaimSpotRequest>, 'mutationFn'>): UseMutationResult<{
|
|
34
|
-
claimId: string;
|
|
35
|
-
}, Error, {
|
|
36
|
-
spotId: string;
|
|
37
|
-
} & ClaimSpotRequest>;
|
|
38
|
-
/**
|
|
39
|
-
* Subscribe to a spot
|
|
40
|
-
*
|
|
41
|
-
* @endpoint POST /spots/{spotId}/subscribe
|
|
42
|
-
*/
|
|
43
|
-
export declare function useSubscribeToSpot(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
|
|
44
|
-
/**
|
|
45
|
-
* Unsubscribe from a spot
|
|
46
|
-
*
|
|
47
|
-
* @endpoint DELETE /spots/{spotId}/subscribe
|
|
48
|
-
*/
|
|
49
|
-
export declare function useUnsubscribeFromSpot(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
|
|
50
|
-
/**
|
|
51
|
-
* Toggle favorite status on a spot
|
|
52
|
-
*
|
|
53
|
-
* @endpoint POST /spots/{spotId}/favorite
|
|
54
|
-
*/
|
|
55
|
-
export declare function useFavoriteSpot(options?: Omit<UseMutationOptions<{
|
|
56
|
-
isFavorite: boolean;
|
|
57
|
-
}, Error, string>, 'mutationFn'>): UseMutationResult<{
|
|
58
|
-
isFavorite: boolean;
|
|
59
|
-
}, Error, string>;
|
|
60
|
-
/**
|
|
61
|
-
* Rate a spot
|
|
62
|
-
*
|
|
63
|
-
* @endpoint POST /spots/{spotId}/rate
|
|
64
|
-
*/
|
|
65
|
-
export declare function useRateSpot(options?: Omit<UseMutationOptions<{
|
|
66
|
-
rating: number;
|
|
67
|
-
}, Error, {
|
|
68
|
-
spotId: string;
|
|
69
|
-
rating: number;
|
|
70
|
-
}>, 'mutationFn'>): UseMutationResult<{
|
|
71
|
-
rating: number;
|
|
72
|
-
}, Error, {
|
|
73
|
-
spotId: string;
|
|
74
|
-
rating: number;
|
|
75
|
-
}>;
|
|
76
|
-
/**
|
|
77
|
-
* Report a spot
|
|
78
|
-
*
|
|
79
|
-
* @endpoint POST /spots/{spotId}/report
|
|
80
|
-
*/
|
|
81
|
-
export declare function useReportSpot(options?: Omit<UseMutationOptions<{
|
|
82
|
-
success: boolean;
|
|
83
|
-
}, Error, {
|
|
84
|
-
spotId: string;
|
|
85
|
-
reason: string;
|
|
86
|
-
details?: string;
|
|
87
|
-
}>, 'mutationFn'>): UseMutationResult<{
|
|
88
|
-
success: boolean;
|
|
89
|
-
}, Error, {
|
|
90
|
-
spotId: string;
|
|
91
|
-
reason: string;
|
|
92
|
-
details?: string;
|
|
93
|
-
}>;
|
|
@@ -1,167 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* Spots Mutation Hooks
|
|
4
|
-
*
|
|
5
|
-
* TanStack Query hooks for spot mutation operations.
|
|
6
|
-
*/
|
|
7
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
-
exports.useCreateSpot = useCreateSpot;
|
|
9
|
-
exports.useUpdateSpot = useUpdateSpot;
|
|
10
|
-
exports.useClaimSpot = useClaimSpot;
|
|
11
|
-
exports.useSubscribeToSpot = useSubscribeToSpot;
|
|
12
|
-
exports.useUnsubscribeFromSpot = useUnsubscribeFromSpot;
|
|
13
|
-
exports.useFavoriteSpot = useFavoriteSpot;
|
|
14
|
-
exports.useRateSpot = useRateSpot;
|
|
15
|
-
exports.useReportSpot = useReportSpot;
|
|
16
|
-
const react_query_1 = require("@tanstack/react-query");
|
|
17
|
-
const client_1 = require("../client");
|
|
18
|
-
const spots_1 = require("../queries/spots");
|
|
19
|
-
const users_1 = require("../queries/users");
|
|
20
|
-
// ============================================================================
|
|
21
|
-
// MUTATION HOOKS
|
|
22
|
-
// ============================================================================
|
|
23
|
-
/**
|
|
24
|
-
* Create a new spot
|
|
25
|
-
*
|
|
26
|
-
* @endpoint POST /spots
|
|
27
|
-
*/
|
|
28
|
-
function useCreateSpot(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('/spots', data);
|
|
34
|
-
return response.data.data;
|
|
35
|
-
},
|
|
36
|
-
onSuccess: () => {
|
|
37
|
-
queryClient.invalidateQueries({ queryKey: spots_1.spotKeys.lists() });
|
|
38
|
-
},
|
|
39
|
-
...options,
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
/**
|
|
43
|
-
* Update a spot
|
|
44
|
-
*
|
|
45
|
-
* @endpoint PUT /spots/{spotId}
|
|
46
|
-
*/
|
|
47
|
-
function useUpdateSpot(options) {
|
|
48
|
-
const queryClient = (0, react_query_1.useQueryClient)();
|
|
49
|
-
return (0, react_query_1.useMutation)({
|
|
50
|
-
mutationFn: async ({ spotId, ...data }) => {
|
|
51
|
-
const client = (0, client_1.getApiClient)();
|
|
52
|
-
const response = await client.put(`/spots/${spotId}`, data);
|
|
53
|
-
return response.data.data;
|
|
54
|
-
},
|
|
55
|
-
onSuccess: (data, variables) => {
|
|
56
|
-
queryClient.setQueryData(spots_1.spotKeys.detail(variables.spotId), data);
|
|
57
|
-
},
|
|
58
|
-
...options,
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
|
-
/**
|
|
62
|
-
* Claim a spot (for business owners)
|
|
63
|
-
*
|
|
64
|
-
* @endpoint POST /spots/{spotId}/claim
|
|
65
|
-
*/
|
|
66
|
-
function useClaimSpot(options) {
|
|
67
|
-
return (0, react_query_1.useMutation)({
|
|
68
|
-
mutationFn: async ({ spotId, ...data }) => {
|
|
69
|
-
const client = (0, client_1.getApiClient)();
|
|
70
|
-
const response = await client.post(`/spots/${spotId}/claim`, data);
|
|
71
|
-
return response.data.data;
|
|
72
|
-
},
|
|
73
|
-
...options,
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
/**
|
|
77
|
-
* Subscribe to a spot
|
|
78
|
-
*
|
|
79
|
-
* @endpoint POST /spots/{spotId}/subscribe
|
|
80
|
-
*/
|
|
81
|
-
function useSubscribeToSpot(options) {
|
|
82
|
-
const queryClient = (0, react_query_1.useQueryClient)();
|
|
83
|
-
return (0, react_query_1.useMutation)({
|
|
84
|
-
mutationFn: async (spotId) => {
|
|
85
|
-
const client = (0, client_1.getApiClient)();
|
|
86
|
-
await client.post(`/spots/${spotId}/subscribe`);
|
|
87
|
-
},
|
|
88
|
-
onSuccess: () => {
|
|
89
|
-
queryClient.invalidateQueries({ queryKey: users_1.userKeys.subscriptions() });
|
|
90
|
-
},
|
|
91
|
-
...options,
|
|
92
|
-
});
|
|
93
|
-
}
|
|
94
|
-
/**
|
|
95
|
-
* Unsubscribe from a spot
|
|
96
|
-
*
|
|
97
|
-
* @endpoint DELETE /spots/{spotId}/subscribe
|
|
98
|
-
*/
|
|
99
|
-
function useUnsubscribeFromSpot(options) {
|
|
100
|
-
const queryClient = (0, react_query_1.useQueryClient)();
|
|
101
|
-
return (0, react_query_1.useMutation)({
|
|
102
|
-
mutationFn: async (spotId) => {
|
|
103
|
-
const client = (0, client_1.getApiClient)();
|
|
104
|
-
await client.delete(`/spots/${spotId}/subscribe`);
|
|
105
|
-
},
|
|
106
|
-
onSuccess: () => {
|
|
107
|
-
queryClient.invalidateQueries({ queryKey: users_1.userKeys.subscriptions() });
|
|
108
|
-
},
|
|
109
|
-
...options,
|
|
110
|
-
});
|
|
111
|
-
}
|
|
112
|
-
/**
|
|
113
|
-
* Toggle favorite status on a spot
|
|
114
|
-
*
|
|
115
|
-
* @endpoint POST /spots/{spotId}/favorite
|
|
116
|
-
*/
|
|
117
|
-
function useFavoriteSpot(options) {
|
|
118
|
-
const queryClient = (0, react_query_1.useQueryClient)();
|
|
119
|
-
return (0, react_query_1.useMutation)({
|
|
120
|
-
mutationFn: async (spotId) => {
|
|
121
|
-
const client = (0, client_1.getApiClient)();
|
|
122
|
-
const response = await client.post(`/spots/${spotId}/favorite`);
|
|
123
|
-
return response.data.data;
|
|
124
|
-
},
|
|
125
|
-
onSuccess: () => {
|
|
126
|
-
queryClient.invalidateQueries({ queryKey: users_1.userKeys.favorites() });
|
|
127
|
-
},
|
|
128
|
-
...options,
|
|
129
|
-
});
|
|
130
|
-
}
|
|
131
|
-
/**
|
|
132
|
-
* Rate a spot
|
|
133
|
-
*
|
|
134
|
-
* @endpoint POST /spots/{spotId}/rate
|
|
135
|
-
*/
|
|
136
|
-
function useRateSpot(options) {
|
|
137
|
-
const queryClient = (0, react_query_1.useQueryClient)();
|
|
138
|
-
return (0, react_query_1.useMutation)({
|
|
139
|
-
mutationFn: async ({ spotId, rating, }) => {
|
|
140
|
-
const client = (0, client_1.getApiClient)();
|
|
141
|
-
const response = await client.post(`/spots/${spotId}/rate`, { rating });
|
|
142
|
-
return response.data.data;
|
|
143
|
-
},
|
|
144
|
-
onSuccess: (_, variables) => {
|
|
145
|
-
queryClient.invalidateQueries({
|
|
146
|
-
queryKey: spots_1.spotKeys.detail(variables.spotId),
|
|
147
|
-
});
|
|
148
|
-
},
|
|
149
|
-
...options,
|
|
150
|
-
});
|
|
151
|
-
}
|
|
152
|
-
/**
|
|
153
|
-
* Report a spot
|
|
154
|
-
*
|
|
155
|
-
* @endpoint POST /spots/{spotId}/report
|
|
156
|
-
*/
|
|
157
|
-
function useReportSpot(options) {
|
|
158
|
-
return (0, react_query_1.useMutation)({
|
|
159
|
-
mutationFn: async ({ spotId, reason, details, }) => {
|
|
160
|
-
const client = (0, client_1.getApiClient)();
|
|
161
|
-
const response = await client.post(`/spots/${spotId}/report`, { reason, details });
|
|
162
|
-
return response.data.data;
|
|
163
|
-
},
|
|
164
|
-
...options,
|
|
165
|
-
});
|
|
166
|
-
}
|
|
167
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"spots.js","sourceRoot":"","sources":["../../../src/api/mutations/spots.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Spots Mutation Hooks\n *\n * TanStack Query hooks for spot mutation operations.\n */\n\nimport {\n  useMutation,\n  type UseMutationOptions,\n  type UseMutationResult,\n  useQueryClient,\n} from '@tanstack/react-query'\n\nimport {getApiClient} from '../client'\nimport {spotKeys} from '../queries/spots'\nimport {userKeys} from '../queries/users'\nimport {type ApiResponse, type ClaimSpotRequest, type Spot} from '../types'\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a new spot\n *\n * @endpoint POST /spots\n */\nexport function useCreateSpot(\n  options?: Omit<UseMutationOptions<Spot, Error, Partial<Spot>>, 'mutationFn'>,\n): UseMutationResult<Spot, Error, Partial<Spot>> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (data: Partial<Spot>): Promise<Spot> => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<Spot>>('/spots', data)\n      return response.data.data\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({queryKey: spotKeys.lists()})\n    },\n    ...options,\n  })\n}\n\n/**\n * Update a spot\n *\n * @endpoint PUT /spots/{spotId}\n */\nexport function useUpdateSpot(\n  options?: Omit<\n    UseMutationOptions<Spot, Error, {spotId: string} & Partial<Spot>>,\n    'mutationFn'\n  >,\n): UseMutationResult<Spot, Error, {spotId: string} & Partial<Spot>> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({spotId, ...data}): Promise<Spot> => {\n      const client = getApiClient()\n      const response = await client.put<ApiResponse<Spot>>(\n        `/spots/${spotId}`,\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: (data, variables) => {\n      queryClient.setQueryData(spotKeys.detail(variables.spotId), data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Claim a spot (for business owners)\n *\n * @endpoint POST /spots/{spotId}/claim\n */\nexport function useClaimSpot(\n  options?: Omit<\n    UseMutationOptions<\n      {claimId: string},\n      Error,\n      {spotId: string} & ClaimSpotRequest\n    >,\n    'mutationFn'\n  >,\n): UseMutationResult<\n  {claimId: string},\n  Error,\n  {spotId: string} & ClaimSpotRequest\n> {\n  return useMutation({\n    mutationFn: async ({spotId, ...data}): Promise<{claimId: string}> => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<{claimId: string}>>(\n        `/spots/${spotId}/claim`,\n        data,\n      )\n      return response.data.data\n    },\n    ...options,\n  })\n}\n\n/**\n * Subscribe to a spot\n *\n * @endpoint POST /spots/{spotId}/subscribe\n */\nexport function useSubscribeToSpot(\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>,\n): UseMutationResult<void, Error, string> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (spotId: string): Promise<void> => {\n      const client = getApiClient()\n      await client.post(`/spots/${spotId}/subscribe`)\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({queryKey: userKeys.subscriptions()})\n    },\n    ...options,\n  })\n}\n\n/**\n * Unsubscribe from a spot\n *\n * @endpoint DELETE /spots/{spotId}/subscribe\n */\nexport function useUnsubscribeFromSpot(\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>,\n): UseMutationResult<void, Error, string> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (spotId: string): Promise<void> => {\n      const client = getApiClient()\n      await client.delete(`/spots/${spotId}/subscribe`)\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({queryKey: userKeys.subscriptions()})\n    },\n    ...options,\n  })\n}\n\n/**\n * Toggle favorite status on a spot\n *\n * @endpoint POST /spots/{spotId}/favorite\n */\nexport function useFavoriteSpot(\n  options?: Omit<\n    UseMutationOptions<{isFavorite: boolean}, Error, string>,\n    'mutationFn'\n  >,\n): UseMutationResult<{isFavorite: boolean}, Error, string> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (spotId: string): Promise<{isFavorite: boolean}> => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<{isFavorite: boolean}>>(\n        `/spots/${spotId}/favorite`,\n      )\n      return response.data.data\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({queryKey: userKeys.favorites()})\n    },\n    ...options,\n  })\n}\n\n/**\n * Rate a spot\n *\n * @endpoint POST /spots/{spotId}/rate\n */\nexport function useRateSpot(\n  options?: Omit<\n    UseMutationOptions<\n      {rating: number},\n      Error,\n      {spotId: string; rating: number}\n    >,\n    'mutationFn'\n  >,\n): UseMutationResult<\n  {rating: number},\n  Error,\n  {spotId: string; rating: number}\n> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({\n      spotId,\n      rating,\n    }: {\n      spotId: string\n      rating: number\n    }): Promise<{rating: number}> => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<{rating: number}>>(\n        `/spots/${spotId}/rate`,\n        {rating},\n      )\n      return response.data.data\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({\n        queryKey: spotKeys.detail(variables.spotId),\n      })\n    },\n    ...options,\n  })\n}\n\n/**\n * Report a spot\n *\n * @endpoint POST /spots/{spotId}/report\n */\nexport function useReportSpot(\n  options?: Omit<\n    UseMutationOptions<\n      {success: boolean},\n      Error,\n      {spotId: string; reason: string; details?: string}\n    >,\n    'mutationFn'\n  >,\n): UseMutationResult<\n  {success: boolean},\n  Error,\n  {spotId: string; reason: string; details?: string}\n> {\n  return useMutation({\n    mutationFn: async ({\n      spotId,\n      reason,\n      details,\n    }): Promise<{success: boolean}> => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<{success: boolean}>>(\n        `/spots/${spotId}/report`,\n        {reason, details},\n      )\n      return response.data.data\n    },\n    ...options,\n  })\n}\n"]}
|
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Users Mutation Hooks
|
|
3
|
-
*
|
|
4
|
-
* TanStack Query hooks for user mutation operations.
|
|
5
|
-
*/
|
|
6
|
-
import { type UseMutationOptions, type UseMutationResult } from '@tanstack/react-query';
|
|
7
|
-
import { type UpdateProfileRequest, type User } from '../types';
|
|
8
|
-
/**
|
|
9
|
-
* Update current user's profile
|
|
10
|
-
*
|
|
11
|
-
* @endpoint PUT /users/me
|
|
12
|
-
*/
|
|
13
|
-
export declare function useUpdateProfile(options?: Omit<UseMutationOptions<User, Error, UpdateProfileRequest>, 'mutationFn'>): UseMutationResult<User, Error, UpdateProfileRequest>;
|
|
14
|
-
/**
|
|
15
|
-
* Upload avatar
|
|
16
|
-
*
|
|
17
|
-
* Uploads avatar file and updates user profile in one request.
|
|
18
|
-
*
|
|
19
|
-
* @endpoint POST /users/me/avatar
|
|
20
|
-
*/
|
|
21
|
-
export declare function useUploadAvatar(options?: Omit<UseMutationOptions<{
|
|
22
|
-
avatarUrl: string;
|
|
23
|
-
}, Error, FormData>, 'mutationFn'>): UseMutationResult<{
|
|
24
|
-
avatarUrl: string;
|
|
25
|
-
}, Error, FormData>;
|
|
26
|
-
/**
|
|
27
|
-
* Delete current user's account
|
|
28
|
-
*
|
|
29
|
-
* @endpoint DELETE /users/me
|
|
30
|
-
*/
|
|
31
|
-
export declare function useDeleteAccount(options?: Omit<UseMutationOptions<void, Error, void>, 'mutationFn'>): UseMutationResult<void, Error, void>;
|
|
32
|
-
/**
|
|
33
|
-
* Update user vibes
|
|
34
|
-
*
|
|
35
|
-
* @endpoint PUT /users/me/vibes
|
|
36
|
-
*/
|
|
37
|
-
export declare function useUpdateVibes(options?: Omit<UseMutationOptions<User, Error, {
|
|
38
|
-
vibes: string[];
|
|
39
|
-
}>, 'mutationFn'>): UseMutationResult<User, Error, {
|
|
40
|
-
vibes: string[];
|
|
41
|
-
}>;
|
|
42
|
-
/**
|
|
43
|
-
* Update user interests
|
|
44
|
-
*
|
|
45
|
-
* @endpoint PUT /user/me/interests
|
|
46
|
-
*/
|
|
47
|
-
export declare function useUpdateInterests(options?: Omit<UseMutationOptions<User, Error, {
|
|
48
|
-
interests: string[];
|
|
49
|
-
}>, 'mutationFn'>): UseMutationResult<User, Error, {
|
|
50
|
-
interests: string[];
|
|
51
|
-
}>;
|
|
52
|
-
/**
|
|
53
|
-
* Complete onboarding step
|
|
54
|
-
*
|
|
55
|
-
* @endpoint POST /user/me/onboarding-step
|
|
56
|
-
*/
|
|
57
|
-
export declare function useCompleteOnboardingStep(options?: Omit<UseMutationOptions<User, Error, {
|
|
58
|
-
step: number;
|
|
59
|
-
}>, 'mutationFn'>): UseMutationResult<User, Error, {
|
|
60
|
-
step: number;
|
|
61
|
-
}>;
|
|
62
|
-
/**
|
|
63
|
-
* Block a user
|
|
64
|
-
*
|
|
65
|
-
* @endpoint POST /users/{id}/block
|
|
66
|
-
*/
|
|
67
|
-
export declare function useBlockUser(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
|
|
68
|
-
/**
|
|
69
|
-
* Unblock a user
|
|
70
|
-
*
|
|
71
|
-
* @endpoint DELETE /users/{id}/block
|
|
72
|
-
*/
|
|
73
|
-
export declare function useUnblockUser(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
|
|
@@ -1,175 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* Users Mutation Hooks
|
|
4
|
-
*
|
|
5
|
-
* TanStack Query hooks for user mutation operations.
|
|
6
|
-
*/
|
|
7
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
-
exports.useUpdateProfile = useUpdateProfile;
|
|
9
|
-
exports.useUploadAvatar = useUploadAvatar;
|
|
10
|
-
exports.useDeleteAccount = useDeleteAccount;
|
|
11
|
-
exports.useUpdateVibes = useUpdateVibes;
|
|
12
|
-
exports.useUpdateInterests = useUpdateInterests;
|
|
13
|
-
exports.useCompleteOnboardingStep = useCompleteOnboardingStep;
|
|
14
|
-
exports.useBlockUser = useBlockUser;
|
|
15
|
-
exports.useUnblockUser = useUnblockUser;
|
|
16
|
-
const react_query_1 = require("@tanstack/react-query");
|
|
17
|
-
const client_1 = require("../client");
|
|
18
|
-
const users_1 = require("../queries/users");
|
|
19
|
-
// ============================================================================
|
|
20
|
-
// MUTATION HOOKS
|
|
21
|
-
// ============================================================================
|
|
22
|
-
/**
|
|
23
|
-
* Update current user's profile
|
|
24
|
-
*
|
|
25
|
-
* @endpoint PUT /users/me
|
|
26
|
-
*/
|
|
27
|
-
function useUpdateProfile(options) {
|
|
28
|
-
const queryClient = (0, react_query_1.useQueryClient)();
|
|
29
|
-
return (0, react_query_1.useMutation)({
|
|
30
|
-
mutationFn: async (data) => {
|
|
31
|
-
const client = (0, client_1.getApiClient)();
|
|
32
|
-
const response = await client.put('/users/me', data);
|
|
33
|
-
return response.data.data;
|
|
34
|
-
},
|
|
35
|
-
onSuccess: data => {
|
|
36
|
-
queryClient.setQueryData(users_1.userKeys.me(), data);
|
|
37
|
-
},
|
|
38
|
-
...options,
|
|
39
|
-
});
|
|
40
|
-
}
|
|
41
|
-
/**
|
|
42
|
-
* Upload avatar
|
|
43
|
-
*
|
|
44
|
-
* Uploads avatar file and updates user profile in one request.
|
|
45
|
-
*
|
|
46
|
-
* @endpoint POST /users/me/avatar
|
|
47
|
-
*/
|
|
48
|
-
function useUploadAvatar(options) {
|
|
49
|
-
const queryClient = (0, react_query_1.useQueryClient)();
|
|
50
|
-
return (0, react_query_1.useMutation)({
|
|
51
|
-
mutationFn: async (formData) => {
|
|
52
|
-
const client = (0, client_1.getApiClient)();
|
|
53
|
-
const response = await client.post('/users/me/avatar', formData, {
|
|
54
|
-
headers: { 'Content-Type': 'multipart/form-data' },
|
|
55
|
-
});
|
|
56
|
-
return response.data.data;
|
|
57
|
-
},
|
|
58
|
-
onSuccess: () => {
|
|
59
|
-
queryClient.invalidateQueries({ queryKey: users_1.userKeys.me() });
|
|
60
|
-
},
|
|
61
|
-
...options,
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
/**
|
|
65
|
-
* Delete current user's account
|
|
66
|
-
*
|
|
67
|
-
* @endpoint DELETE /users/me
|
|
68
|
-
*/
|
|
69
|
-
function useDeleteAccount(options) {
|
|
70
|
-
const queryClient = (0, react_query_1.useQueryClient)();
|
|
71
|
-
return (0, react_query_1.useMutation)({
|
|
72
|
-
mutationFn: async () => {
|
|
73
|
-
const client = (0, client_1.getApiClient)();
|
|
74
|
-
await client.delete('/users/me');
|
|
75
|
-
},
|
|
76
|
-
onSuccess: () => {
|
|
77
|
-
queryClient.clear();
|
|
78
|
-
},
|
|
79
|
-
...options,
|
|
80
|
-
});
|
|
81
|
-
}
|
|
82
|
-
/**
|
|
83
|
-
* Update user vibes
|
|
84
|
-
*
|
|
85
|
-
* @endpoint PUT /users/me/vibes
|
|
86
|
-
*/
|
|
87
|
-
function useUpdateVibes(options) {
|
|
88
|
-
const queryClient = (0, react_query_1.useQueryClient)();
|
|
89
|
-
return (0, react_query_1.useMutation)({
|
|
90
|
-
mutationFn: async (data) => {
|
|
91
|
-
const client = (0, client_1.getApiClient)();
|
|
92
|
-
const response = await client.put('/users/me/vibes', data);
|
|
93
|
-
return response.data.data;
|
|
94
|
-
},
|
|
95
|
-
onSuccess: () => {
|
|
96
|
-
queryClient.invalidateQueries({ queryKey: users_1.userKeys.me() });
|
|
97
|
-
},
|
|
98
|
-
...options,
|
|
99
|
-
});
|
|
100
|
-
}
|
|
101
|
-
/**
|
|
102
|
-
* Update user interests
|
|
103
|
-
*
|
|
104
|
-
* @endpoint PUT /user/me/interests
|
|
105
|
-
*/
|
|
106
|
-
function useUpdateInterests(options) {
|
|
107
|
-
const queryClient = (0, react_query_1.useQueryClient)();
|
|
108
|
-
return (0, react_query_1.useMutation)({
|
|
109
|
-
mutationFn: async (data) => {
|
|
110
|
-
const client = (0, client_1.getApiClient)();
|
|
111
|
-
const response = await client.put('/user/me/interests', data);
|
|
112
|
-
return response.data.data;
|
|
113
|
-
},
|
|
114
|
-
onSuccess: () => {
|
|
115
|
-
queryClient.invalidateQueries({ queryKey: users_1.userKeys.me() });
|
|
116
|
-
},
|
|
117
|
-
...options,
|
|
118
|
-
});
|
|
119
|
-
}
|
|
120
|
-
/**
|
|
121
|
-
* Complete onboarding step
|
|
122
|
-
*
|
|
123
|
-
* @endpoint POST /user/me/onboarding-step
|
|
124
|
-
*/
|
|
125
|
-
function useCompleteOnboardingStep(options) {
|
|
126
|
-
const queryClient = (0, react_query_1.useQueryClient)();
|
|
127
|
-
return (0, react_query_1.useMutation)({
|
|
128
|
-
mutationFn: async (data) => {
|
|
129
|
-
const client = (0, client_1.getApiClient)();
|
|
130
|
-
const response = await client.post('/user/me/onboarding-step', data);
|
|
131
|
-
return response.data.data;
|
|
132
|
-
},
|
|
133
|
-
onSuccess: () => {
|
|
134
|
-
queryClient.invalidateQueries({ queryKey: users_1.userKeys.me() });
|
|
135
|
-
},
|
|
136
|
-
...options,
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
/**
|
|
140
|
-
* Block a user
|
|
141
|
-
*
|
|
142
|
-
* @endpoint POST /users/{id}/block
|
|
143
|
-
*/
|
|
144
|
-
function useBlockUser(options) {
|
|
145
|
-
const queryClient = (0, react_query_1.useQueryClient)();
|
|
146
|
-
return (0, react_query_1.useMutation)({
|
|
147
|
-
mutationFn: async (userId) => {
|
|
148
|
-
const client = (0, client_1.getApiClient)();
|
|
149
|
-
await client.post(`/users/${userId}/block`);
|
|
150
|
-
},
|
|
151
|
-
onSuccess: () => {
|
|
152
|
-
queryClient.invalidateQueries({ queryKey: users_1.userKeys.blocked() });
|
|
153
|
-
},
|
|
154
|
-
...options,
|
|
155
|
-
});
|
|
156
|
-
}
|
|
157
|
-
/**
|
|
158
|
-
* Unblock a user
|
|
159
|
-
*
|
|
160
|
-
* @endpoint DELETE /users/{id}/block
|
|
161
|
-
*/
|
|
162
|
-
function useUnblockUser(options) {
|
|
163
|
-
const queryClient = (0, react_query_1.useQueryClient)();
|
|
164
|
-
return (0, react_query_1.useMutation)({
|
|
165
|
-
mutationFn: async (userId) => {
|
|
166
|
-
const client = (0, client_1.getApiClient)();
|
|
167
|
-
await client.delete(`/users/${userId}/block`);
|
|
168
|
-
},
|
|
169
|
-
onSuccess: () => {
|
|
170
|
-
queryClient.invalidateQueries({ queryKey: users_1.userKeys.blocked() });
|
|
171
|
-
},
|
|
172
|
-
...options,
|
|
173
|
-
});
|
|
174
|
-
}
|
|
175
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"users.js","sourceRoot":"","sources":["../../../src/api/mutations/users.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Users Mutation Hooks\n *\n * TanStack Query hooks for user mutation operations.\n */\n\nimport {\n  useMutation,\n  type UseMutationOptions,\n  type UseMutationResult,\n  useQueryClient,\n} from '@tanstack/react-query'\n\nimport {getApiClient} from '../client'\nimport {userKeys} from '../queries/users'\nimport {type ApiResponse, type UpdateProfileRequest, type User} from '../types'\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Update current user's profile\n *\n * @endpoint PUT /users/me\n */\nexport function useUpdateProfile(\n  options?: Omit<\n    UseMutationOptions<User, Error, UpdateProfileRequest>,\n    'mutationFn'\n  >,\n): UseMutationResult<User, Error, UpdateProfileRequest> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (data: UpdateProfileRequest): Promise<User> => {\n      const client = getApiClient()\n      const response = await client.put<ApiResponse<User>>('/users/me', data)\n      return response.data.data\n    },\n    onSuccess: data => {\n      queryClient.setQueryData(userKeys.me(), data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Upload avatar\n *\n * Uploads avatar file and updates user profile in one request.\n *\n * @endpoint POST /users/me/avatar\n */\nexport function useUploadAvatar(\n  options?: Omit<\n    UseMutationOptions<{avatarUrl: string}, Error, FormData>,\n    'mutationFn'\n  >,\n): UseMutationResult<{avatarUrl: string}, Error, FormData> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (formData: FormData): Promise<{avatarUrl: string}> => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<{avatarUrl: string}>>(\n        '/users/me/avatar',\n        formData,\n        {\n          headers: {'Content-Type': 'multipart/form-data'},\n        },\n      )\n      return response.data.data\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({queryKey: userKeys.me()})\n    },\n    ...options,\n  })\n}\n\n/**\n * Delete current user's account\n *\n * @endpoint DELETE /users/me\n */\nexport function useDeleteAccount(\n  options?: Omit<UseMutationOptions<void, Error, void>, 'mutationFn'>,\n): UseMutationResult<void, Error, void> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (): Promise<void> => {\n      const client = getApiClient()\n      await client.delete('/users/me')\n    },\n    onSuccess: () => {\n      queryClient.clear()\n    },\n    ...options,\n  })\n}\n\n/**\n * Update user vibes\n *\n * @endpoint PUT /users/me/vibes\n */\nexport function useUpdateVibes(\n  options?: Omit<\n    UseMutationOptions<User, Error, {vibes: string[]}>,\n    'mutationFn'\n  >,\n): UseMutationResult<User, Error, {vibes: string[]}> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (data: {vibes: string[]}): Promise<User> => {\n      const client = getApiClient()\n      const response = await client.put<ApiResponse<User>>(\n        '/users/me/vibes',\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({queryKey: userKeys.me()})\n    },\n    ...options,\n  })\n}\n\n/**\n * Update user interests\n *\n * @endpoint PUT /user/me/interests\n */\nexport function useUpdateInterests(\n  options?: Omit<\n    UseMutationOptions<User, Error, {interests: string[]}>,\n    'mutationFn'\n  >,\n): UseMutationResult<User, Error, {interests: string[]}> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (data: {interests: string[]}): Promise<User> => {\n      const client = getApiClient()\n      const response = await client.put<ApiResponse<User>>(\n        '/user/me/interests',\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({queryKey: userKeys.me()})\n    },\n    ...options,\n  })\n}\n\n/**\n * Complete onboarding step\n *\n * @endpoint POST /user/me/onboarding-step\n */\nexport function useCompleteOnboardingStep(\n  options?: Omit<UseMutationOptions<User, Error, {step: number}>, 'mutationFn'>,\n): UseMutationResult<User, Error, {step: number}> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (data: {step: number}): Promise<User> => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<User>>(\n        '/user/me/onboarding-step',\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({queryKey: userKeys.me()})\n    },\n    ...options,\n  })\n}\n\n/**\n * Block a user\n *\n * @endpoint POST /users/{id}/block\n */\nexport function useBlockUser(\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>,\n): UseMutationResult<void, Error, string> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (userId: string): Promise<void> => {\n      const client = getApiClient()\n      await client.post(`/users/${userId}/block`)\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({queryKey: userKeys.blocked()})\n    },\n    ...options,\n  })\n}\n\n/**\n * Unblock a user\n *\n * @endpoint DELETE /users/{id}/block\n */\nexport function useUnblockUser(\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>,\n): UseMutationResult<void, Error, string> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (userId: string): Promise<void> => {\n      const client = getApiClient()\n      await client.delete(`/users/${userId}/block`)\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({queryKey: userKeys.blocked()})\n    },\n    ...options,\n  })\n}\n"]}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Auth Mutation Hooks
|
|
3
|
-
*
|
|
4
|
-
* TanStack Query hooks for authentication operations.
|
|
5
|
-
*/
|
|
6
|
-
import { type UseMutationOptions, type UseMutationResult } from '@tanstack/react-query';
|
|
7
|
-
import { type ApiResponse, type AuthResponse, type SendOtpRequest, type VerifyOtpRequest } from '../types';
|
|
8
|
-
/**
|
|
9
|
-
* Send OTP to phone number
|
|
10
|
-
*
|
|
11
|
-
* @endpoint POST /auth/send-otp
|
|
12
|
-
*/
|
|
13
|
-
export declare function useSendOtp(options?: Omit<UseMutationOptions<ApiResponse<{
|
|
14
|
-
sent: boolean;
|
|
15
|
-
}>, Error, SendOtpRequest>, 'mutationFn'>): UseMutationResult<ApiResponse<{
|
|
16
|
-
sent: boolean;
|
|
17
|
-
}>, Error, SendOtpRequest>;
|
|
18
|
-
/**
|
|
19
|
-
* Verify OTP and authenticate
|
|
20
|
-
*
|
|
21
|
-
* @endpoint POST /auth/verify-otp
|
|
22
|
-
*/
|
|
23
|
-
export declare function useVerifyOtp(options?: Omit<UseMutationOptions<AuthResponse, Error, VerifyOtpRequest>, 'mutationFn'>): UseMutationResult<AuthResponse, Error, VerifyOtpRequest>;
|
|
24
|
-
/**
|
|
25
|
-
* Refresh access token
|
|
26
|
-
*
|
|
27
|
-
* @endpoint POST /auth/refresh
|
|
28
|
-
*/
|
|
29
|
-
export declare function useRefreshToken(options?: Omit<UseMutationOptions<{
|
|
30
|
-
accessToken: string;
|
|
31
|
-
}, Error, {
|
|
32
|
-
refreshToken: string;
|
|
33
|
-
}>, 'mutationFn'>): UseMutationResult<{
|
|
34
|
-
accessToken: string;
|
|
35
|
-
}, Error, {
|
|
36
|
-
refreshToken: string;
|
|
37
|
-
}>;
|
package/dist/api/queries/auth.js
DELETED
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* Auth Mutation Hooks
|
|
4
|
-
*
|
|
5
|
-
* TanStack Query hooks for authentication operations.
|
|
6
|
-
*/
|
|
7
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
-
exports.useSendOtp = useSendOtp;
|
|
9
|
-
exports.useVerifyOtp = useVerifyOtp;
|
|
10
|
-
exports.useRefreshToken = useRefreshToken;
|
|
11
|
-
const react_query_1 = require("@tanstack/react-query");
|
|
12
|
-
const client_1 = require("../client");
|
|
13
|
-
// ============================================================================
|
|
14
|
-
// MUTATION HOOKS
|
|
15
|
-
// ============================================================================
|
|
16
|
-
/**
|
|
17
|
-
* Send OTP to phone number
|
|
18
|
-
*
|
|
19
|
-
* @endpoint POST /auth/send-otp
|
|
20
|
-
*/
|
|
21
|
-
function useSendOtp(options) {
|
|
22
|
-
return (0, react_query_1.useMutation)({
|
|
23
|
-
mutationFn: async (data) => {
|
|
24
|
-
const client = (0, client_1.getApiClient)();
|
|
25
|
-
const response = await client.post('/auth/send-otp', data);
|
|
26
|
-
return response.data;
|
|
27
|
-
},
|
|
28
|
-
...options,
|
|
29
|
-
});
|
|
30
|
-
}
|
|
31
|
-
/**
|
|
32
|
-
* Verify OTP and authenticate
|
|
33
|
-
*
|
|
34
|
-
* @endpoint POST /auth/verify-otp
|
|
35
|
-
*/
|
|
36
|
-
function useVerifyOtp(options) {
|
|
37
|
-
return (0, react_query_1.useMutation)({
|
|
38
|
-
mutationFn: async (data) => {
|
|
39
|
-
const client = (0, client_1.getApiClient)();
|
|
40
|
-
const response = await client.post('/auth/verify-otp', data);
|
|
41
|
-
return response.data;
|
|
42
|
-
},
|
|
43
|
-
...options,
|
|
44
|
-
});
|
|
45
|
-
}
|
|
46
|
-
/**
|
|
47
|
-
* Refresh access token
|
|
48
|
-
*
|
|
49
|
-
* @endpoint POST /auth/refresh
|
|
50
|
-
*/
|
|
51
|
-
function useRefreshToken(options) {
|
|
52
|
-
return (0, react_query_1.useMutation)({
|
|
53
|
-
mutationFn: async (data) => {
|
|
54
|
-
const client = (0, client_1.getApiClient)();
|
|
55
|
-
const response = await client.post('/auth/refresh', data);
|
|
56
|
-
return response.data;
|
|
57
|
-
},
|
|
58
|
-
...options,
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvcXVlcmllcy9hdXRoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7OztHQUlHOztBQXlCSCxnQ0FpQkM7QUFPRCxvQ0FjQztBQU9ELDBDQWlCQztBQXJGRCx1REFJOEI7QUFFOUIsc0NBQXNDO0FBUXRDLCtFQUErRTtBQUMvRSxpQkFBaUI7QUFDakIsK0VBQStFO0FBRS9FOzs7O0dBSUc7QUFDSCxTQUFnQixVQUFVLENBQ3hCLE9BR0M7SUFFRCxPQUFPLElBQUEseUJBQVcsRUFBQztRQUNqQixVQUFVLEVBQUUsS0FBSyxFQUFFLElBQW9CLEVBQUUsRUFBRTtZQUN6QyxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQTtZQUM3QixNQUFNLFFBQVEsR0FBRyxNQUFNLE1BQU0sQ0FBQyxJQUFJLENBQ2hDLGdCQUFnQixFQUNoQixJQUFJLENBQ0wsQ0FBQTtZQUNELE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQTtRQUN0QixDQUFDO1FBQ0QsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFBO0FBQ0osQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQixZQUFZLENBQzFCLE9BR0M7SUFFRCxPQUFPLElBQUEseUJBQVcsRUFBQztRQUNqQixVQUFVLEVBQUUsS0FBSyxFQUFFLElBQXNCLEVBQUUsRUFBRTtZQUMzQyxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQTtZQUM3QixNQUFNLFFBQVEsR0FBRyxNQUFNLE1BQU0sQ0FBQyxJQUFJLENBQWUsa0JBQWtCLEVBQUUsSUFBSSxDQUFDLENBQUE7WUFDMUUsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFBO1FBQ3RCLENBQUM7UUFDRCxHQUFHLE9BQU87S0FDWCxDQUFDLENBQUE7QUFDSixDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLGVBQWUsQ0FDN0IsT0FHQztJQUVELE9BQU8sSUFBQSx5QkFBVyxFQUFDO1FBQ2pCLFVBQVUsRUFBRSxLQUFLLEVBQUUsSUFBNEIsRUFBRSxFQUFFO1lBQ2pELE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFBO1lBQzdCLE1BQU0sUUFBUSxHQUFHLE1BQU0sTUFBTSxDQUFDLElBQUksQ0FDaEMsZUFBZSxFQUNmLElBQUksQ0FDTCxDQUFBO1lBQ0QsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFBO1FBQ3RCLENBQUM7UUFDRCxHQUFHLE9BQU87S0FDWCxDQUFDLENBQUE7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBBdXRoIE11dGF0aW9uIEhvb2tzXG4gKlxuICogVGFuU3RhY2sgUXVlcnkgaG9va3MgZm9yIGF1dGhlbnRpY2F0aW9uIG9wZXJhdGlvbnMuXG4gKi9cblxuaW1wb3J0IHtcbiAgdXNlTXV0YXRpb24sXG4gIHR5cGUgVXNlTXV0YXRpb25PcHRpb25zLFxuICB0eXBlIFVzZU11dGF0aW9uUmVzdWx0LFxufSBmcm9tICdAdGFuc3RhY2svcmVhY3QtcXVlcnknXG5cbmltcG9ydCB7Z2V0QXBpQ2xpZW50fSBmcm9tICcuLi9jbGllbnQnXG5pbXBvcnQge1xuICB0eXBlIEFwaVJlc3BvbnNlLFxuICB0eXBlIEF1dGhSZXNwb25zZSxcbiAgdHlwZSBTZW5kT3RwUmVxdWVzdCxcbiAgdHlwZSBWZXJpZnlPdHBSZXF1ZXN0LFxufSBmcm9tICcuLi90eXBlcydcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gTVVUQVRJT04gSE9PS1Ncbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBTZW5kIE9UUCB0byBwaG9uZSBudW1iZXJcbiAqXG4gKiBAZW5kcG9pbnQgUE9TVCAvYXV0aC9zZW5kLW90cFxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlU2VuZE90cChcbiAgb3B0aW9ucz86IE9taXQ8XG4gICAgVXNlTXV0YXRpb25PcHRpb25zPEFwaVJlc3BvbnNlPHtzZW50OiBib29sZWFufT4sIEVycm9yLCBTZW5kT3RwUmVxdWVzdD4sXG4gICAgJ211dGF0aW9uRm4nXG4gID4sXG4pOiBVc2VNdXRhdGlvblJlc3VsdDxBcGlSZXNwb25zZTx7c2VudDogYm9vbGVhbn0+LCBFcnJvciwgU2VuZE90cFJlcXVlc3Q+IHtcbiAgcmV0dXJuIHVzZU11dGF0aW9uKHtcbiAgICBtdXRhdGlvbkZuOiBhc3luYyAoZGF0YTogU2VuZE90cFJlcXVlc3QpID0+IHtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGdldEFwaUNsaWVudCgpXG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5wb3N0PEFwaVJlc3BvbnNlPHtzZW50OiBib29sZWFufT4+KFxuICAgICAgICAnL2F1dGgvc2VuZC1vdHAnLFxuICAgICAgICBkYXRhLFxuICAgICAgKVxuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGFcbiAgICB9LFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pXG59XG5cbi8qKlxuICogVmVyaWZ5IE9UUCBhbmQgYXV0aGVudGljYXRlXG4gKlxuICogQGVuZHBvaW50IFBPU1QgL2F1dGgvdmVyaWZ5LW90cFxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlVmVyaWZ5T3RwKFxuICBvcHRpb25zPzogT21pdDxcbiAgICBVc2VNdXRhdGlvbk9wdGlvbnM8QXV0aFJlc3BvbnNlLCBFcnJvciwgVmVyaWZ5T3RwUmVxdWVzdD4sXG4gICAgJ211dGF0aW9uRm4nXG4gID4sXG4pOiBVc2VNdXRhdGlvblJlc3VsdDxBdXRoUmVzcG9uc2UsIEVycm9yLCBWZXJpZnlPdHBSZXF1ZXN0PiB7XG4gIHJldHVybiB1c2VNdXRhdGlvbih7XG4gICAgbXV0YXRpb25GbjogYXN5bmMgKGRhdGE6IFZlcmlmeU90cFJlcXVlc3QpID0+IHtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGdldEFwaUNsaWVudCgpXG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5wb3N0PEF1dGhSZXNwb25zZT4oJy9hdXRoL3ZlcmlmeS1vdHAnLCBkYXRhKVxuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGFcbiAgICB9LFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pXG59XG5cbi8qKlxuICogUmVmcmVzaCBhY2Nlc3MgdG9rZW5cbiAqXG4gKiBAZW5kcG9pbnQgUE9TVCAvYXV0aC9yZWZyZXNoXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VSZWZyZXNoVG9rZW4oXG4gIG9wdGlvbnM/OiBPbWl0PFxuICAgIFVzZU11dGF0aW9uT3B0aW9uczx7YWNjZXNzVG9rZW46IHN0cmluZ30sIEVycm9yLCB7cmVmcmVzaFRva2VuOiBzdHJpbmd9PixcbiAgICAnbXV0YXRpb25GbidcbiAgPixcbik6IFVzZU11dGF0aW9uUmVzdWx0PHthY2Nlc3NUb2tlbjogc3RyaW5nfSwgRXJyb3IsIHtyZWZyZXNoVG9rZW46IHN0cmluZ30+IHtcbiAgcmV0dXJuIHVzZU11dGF0aW9uKHtcbiAgICBtdXRhdGlvbkZuOiBhc3luYyAoZGF0YToge3JlZnJlc2hUb2tlbjogc3RyaW5nfSkgPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KClcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LnBvc3Q8e2FjY2Vzc1Rva2VuOiBzdHJpbmd9PihcbiAgICAgICAgJy9hdXRoL3JlZnJlc2gnLFxuICAgICAgICBkYXRhLFxuICAgICAgKVxuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGFcbiAgICB9LFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pXG59XG4iXX0=
|