@spotsdev/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 (79) hide show
  1. package/dist/api/client.d.ts +12 -0
  2. package/dist/api/client.js +68 -0
  3. package/dist/api/mutations/clubs.d.ts +47 -0
  4. package/dist/api/mutations/clubs.js +95 -0
  5. package/dist/api/mutations/conversations.d.ts +45 -0
  6. package/dist/api/mutations/conversations.js +110 -0
  7. package/dist/api/mutations/index.d.ts +13 -0
  8. package/dist/api/mutations/index.js +38 -0
  9. package/dist/api/mutations/notifications.d.ts +38 -0
  10. package/dist/api/mutations/notifications.js +64 -0
  11. package/dist/api/mutations/orders.d.ts +73 -0
  12. package/dist/api/mutations/orders.js +116 -0
  13. package/dist/api/mutations/posts.d.ts +123 -0
  14. package/dist/api/mutations/posts.js +229 -0
  15. package/dist/api/mutations/products.d.ts +81 -0
  16. package/dist/api/mutations/products.js +102 -0
  17. package/dist/api/mutations/spots.d.ts +59 -0
  18. package/dist/api/mutations/spots.js +129 -0
  19. package/dist/api/mutations/users.d.ts +71 -0
  20. package/dist/api/mutations/users.js +173 -0
  21. package/dist/api/queries/auth.d.ts +37 -0
  22. package/dist/api/queries/auth.js +61 -0
  23. package/dist/api/queries/clubs.d.ts +52 -0
  24. package/dist/api/queries/clubs.js +116 -0
  25. package/dist/api/queries/conversations.d.ts +52 -0
  26. package/dist/api/queries/conversations.js +83 -0
  27. package/dist/api/queries/index.d.ts +26 -0
  28. package/dist/api/queries/index.js +65 -0
  29. package/dist/api/queries/misc.d.ts +54 -0
  30. package/dist/api/queries/misc.js +129 -0
  31. package/dist/api/queries/notifications.d.ts +34 -0
  32. package/dist/api/queries/notifications.js +62 -0
  33. package/dist/api/queries/orders.d.ts +45 -0
  34. package/dist/api/queries/orders.js +93 -0
  35. package/dist/api/queries/posts.d.ts +55 -0
  36. package/dist/api/queries/posts.js +130 -0
  37. package/dist/api/queries/products.d.ts +52 -0
  38. package/dist/api/queries/products.js +89 -0
  39. package/dist/api/queries/spots.d.ts +78 -0
  40. package/dist/api/queries/spots.js +168 -0
  41. package/dist/api/queries/templates.d.ts +42 -0
  42. package/dist/api/queries/templates.js +86 -0
  43. package/dist/api/queries/users.d.ts +90 -0
  44. package/dist/api/queries/users.js +187 -0
  45. package/dist/api/services/index.d.ts +2 -0
  46. package/dist/api/services/index.js +8 -0
  47. package/dist/api/services/marketplace.d.ts +129 -0
  48. package/dist/api/services/marketplace.js +168 -0
  49. package/dist/api/types.d.ts +54 -0
  50. package/dist/api/types.js +34 -0
  51. package/dist/index.d.ts +38 -0
  52. package/dist/index.js +73 -0
  53. package/package.json +57 -0
  54. package/src/api/client.ts +78 -0
  55. package/src/api/mutations/clubs.ts +107 -0
  56. package/src/api/mutations/conversations.ts +124 -0
  57. package/src/api/mutations/index.ts +29 -0
  58. package/src/api/mutations/notifications.ts +70 -0
  59. package/src/api/mutations/orders.ts +174 -0
  60. package/src/api/mutations/posts.ts +278 -0
  61. package/src/api/mutations/products.ts +160 -0
  62. package/src/api/mutations/spots.ts +146 -0
  63. package/src/api/mutations/users.ts +197 -0
  64. package/src/api/queries/auth.ts +67 -0
  65. package/src/api/queries/clubs.ts +135 -0
  66. package/src/api/queries/conversations.ts +94 -0
  67. package/src/api/queries/index.ts +48 -0
  68. package/src/api/queries/misc.ts +140 -0
  69. package/src/api/queries/notifications.ts +66 -0
  70. package/src/api/queries/orders.ts +119 -0
  71. package/src/api/queries/posts.ts +142 -0
  72. package/src/api/queries/products.ts +123 -0
  73. package/src/api/queries/spots.ts +201 -0
  74. package/src/api/queries/templates.ts +95 -0
  75. package/src/api/queries/users.ts +206 -0
  76. package/src/api/services/index.ts +6 -0
  77. package/src/api/services/marketplace.ts +265 -0
  78. package/src/api/types.ts +144 -0
  79. package/src/index.ts +63 -0
@@ -0,0 +1,102 @@
1
+ "use strict";
2
+ /**
3
+ * Products Mutation Hooks
4
+ *
5
+ * TanStack Query hooks for product mutation operations.
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.useCreateProduct = useCreateProduct;
9
+ exports.useUpdateProduct = useUpdateProduct;
10
+ exports.useDeleteProduct = useDeleteProduct;
11
+ exports.useAdjustStock = useAdjustStock;
12
+ const react_query_1 = require("@tanstack/react-query");
13
+ const client_1 = require("../client");
14
+ const products_1 = require("../queries/products");
15
+ // ============================================================================
16
+ // MUTATION HOOKS
17
+ // ============================================================================
18
+ /**
19
+ * Create a new product
20
+ *
21
+ * @endpoint POST /api/v1/spots/{spotId}/products
22
+ */
23
+ function useCreateProduct(options) {
24
+ const queryClient = (0, react_query_1.useQueryClient)();
25
+ return (0, react_query_1.useMutation)({
26
+ mutationFn: async (data) => {
27
+ const client = (0, client_1.getApiClient)();
28
+ const { spotId, ...productData } = data;
29
+ const response = await client.post(`/api/v1/spots/${spotId}/products`, productData);
30
+ return response.data.data;
31
+ },
32
+ onSuccess: (_, variables) => {
33
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.bySpot(variables.spotId) });
34
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.list({ my: true }) });
35
+ },
36
+ ...options,
37
+ });
38
+ }
39
+ /**
40
+ * Update a product
41
+ *
42
+ * @endpoint PUT /api/v1/products/{productId}
43
+ */
44
+ function useUpdateProduct(options) {
45
+ const queryClient = (0, react_query_1.useQueryClient)();
46
+ return (0, react_query_1.useMutation)({
47
+ mutationFn: async ({ productId, data }) => {
48
+ const client = (0, client_1.getApiClient)();
49
+ const response = await client.put(`/api/v1/products/${productId}`, data);
50
+ return response.data.data;
51
+ },
52
+ onSuccess: (data) => {
53
+ queryClient.setQueryData(products_1.productKeys.detail(data.id), data);
54
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.bySpot(data.spotId) });
55
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.list({ my: true }) });
56
+ },
57
+ ...options,
58
+ });
59
+ }
60
+ /**
61
+ * Delete a product
62
+ *
63
+ * @endpoint DELETE /api/v1/products/{productId}
64
+ */
65
+ function useDeleteProduct(options) {
66
+ const queryClient = (0, react_query_1.useQueryClient)();
67
+ return (0, react_query_1.useMutation)({
68
+ mutationFn: async (productId) => {
69
+ const client = (0, client_1.getApiClient)();
70
+ await client.delete(`/api/v1/products/${productId}`);
71
+ },
72
+ onSuccess: () => {
73
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.all });
74
+ },
75
+ ...options,
76
+ });
77
+ }
78
+ /**
79
+ * Adjust product stock
80
+ *
81
+ * @endpoint POST /api/v1/products/{productId}/stock
82
+ */
83
+ function useAdjustStock(options) {
84
+ const queryClient = (0, react_query_1.useQueryClient)();
85
+ return (0, react_query_1.useMutation)({
86
+ mutationFn: async ({ productId, quantity, reason, notes }) => {
87
+ const client = (0, client_1.getApiClient)();
88
+ const response = await client.post(`/api/v1/products/${productId}/stock`, {
89
+ quantity,
90
+ reason,
91
+ notes,
92
+ });
93
+ return response.data.data;
94
+ },
95
+ onSuccess: (data) => {
96
+ queryClient.setQueryData(products_1.productKeys.detail(data.id), data);
97
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.bySpot(data.spotId) });
98
+ },
99
+ ...options,
100
+ });
101
+ }
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.js","sourceRoot":"","sources":["../../../src/api/mutations/products.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Products Mutation Hooks\n *\n * TanStack Query hooks for product mutation operations.\n */\n\nimport { useMutation, useQueryClient, UseMutationOptions, UseMutationResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { productKeys } from '../queries/products';\nimport type { Product, ProductType, ProductStatus, ApiResponse } from '../types';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface CreateProductRequest {\n  spotId: string;\n  name: string;\n  description?: string;\n  type: ProductType;\n  price: number;\n  currency?: string;\n  stockQuantity?: number;\n  lowStockThreshold?: number;\n  validFrom?: string;\n  validUntil?: string;\n  deliveryRadiusKm?: number;\n  prepTimeMinutes?: number;\n  maxCapacity?: number;\n  eventDate?: string;\n  imageUrl?: string;\n  metadata?: Record<string, unknown>;\n}\n\nexport interface UpdateProductRequest {\n  name?: string;\n  description?: string;\n  price?: number;\n  stockQuantity?: number;\n  lowStockThreshold?: number;\n  status?: ProductStatus;\n  validFrom?: string;\n  validUntil?: string;\n  deliveryRadiusKm?: number;\n  prepTimeMinutes?: number;\n  maxCapacity?: number;\n  eventDate?: string;\n  imageUrl?: string;\n  metadata?: Record<string, unknown>;\n}\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a new product\n *\n * @endpoint POST /api/v1/spots/{spotId}/products\n */\nexport function useCreateProduct(\n  options?: Omit<UseMutationOptions<Product, Error, CreateProductRequest>, 'mutationFn'>\n): UseMutationResult<Product, Error, CreateProductRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateProductRequest): Promise<Product> => {\n      const client = getApiClient();\n      const { spotId, ...productData } = data;\n      const response = await client.post<ApiResponse<Product>>(\n        `/api/v1/spots/${spotId}/products`,\n        productData\n      );\n      return response.data.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bySpot(variables.spotId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.list({ my: true }) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a product\n *\n * @endpoint PUT /api/v1/products/{productId}\n */\nexport function useUpdateProduct(\n  options?: Omit<UseMutationOptions<Product, Error, { productId: string; data: UpdateProductRequest }>, 'mutationFn'>\n): UseMutationResult<Product, Error, { productId: string; data: UpdateProductRequest }> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ productId, data }): Promise<Product> => {\n      const client = getApiClient();\n      const response = await client.put<ApiResponse<Product>>(`/api/v1/products/${productId}`, data);\n      return response.data.data;\n    },\n    onSuccess: (data) => {\n      queryClient.setQueryData(productKeys.detail(data.id), data);\n      queryClient.invalidateQueries({ queryKey: productKeys.bySpot(data.spotId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.list({ my: true }) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Delete a product\n *\n * @endpoint DELETE /api/v1/products/{productId}\n */\nexport function useDeleteProduct(\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>\n): UseMutationResult<void, Error, string> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (productId: string): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/products/${productId}`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: productKeys.all });\n    },\n    ...options,\n  });\n}\n\n/**\n * Adjust product stock\n *\n * @endpoint POST /api/v1/products/{productId}/stock\n */\nexport function useAdjustStock(\n  options?: Omit<\n    UseMutationOptions<Product, Error, { productId: string; quantity: number; reason: 'RESTOCK' | 'ADJUSTMENT'; notes?: string }>,\n    'mutationFn'\n  >\n): UseMutationResult<Product, Error, { productId: string; quantity: number; reason: 'RESTOCK' | 'ADJUSTMENT'; notes?: string }> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ productId, quantity, reason, notes }): Promise<Product> => {\n      const client = getApiClient();\n      const response = await client.post<ApiResponse<Product>>(`/api/v1/products/${productId}/stock`, {\n        quantity,\n        reason,\n        notes,\n      });\n      return response.data.data;\n    },\n    onSuccess: (data) => {\n      queryClient.setQueryData(productKeys.detail(data.id), data);\n      queryClient.invalidateQueries({ queryKey: productKeys.bySpot(data.spotId) });\n    },\n    ...options,\n  });\n}\n"]}
@@ -0,0 +1,59 @@
1
+ /**
2
+ * Spots Mutation Hooks
3
+ *
4
+ * TanStack Query hooks for spot mutation operations.
5
+ */
6
+ import { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
7
+ import type { Spot, ClaimSpotRequest } from '../types';
8
+ /**
9
+ * Create a new spot
10
+ *
11
+ * @endpoint POST /api/v1/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 /api/v1/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 /api/v1/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 /api/v1/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 /api/v1/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 /api/v1/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>;
@@ -0,0 +1,129 @@
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
+ const react_query_1 = require("@tanstack/react-query");
15
+ const client_1 = require("../client");
16
+ const spots_1 = require("../queries/spots");
17
+ const users_1 = require("../queries/users");
18
+ // ============================================================================
19
+ // MUTATION HOOKS
20
+ // ============================================================================
21
+ /**
22
+ * Create a new spot
23
+ *
24
+ * @endpoint POST /api/v1/spots
25
+ */
26
+ function useCreateSpot(options) {
27
+ const queryClient = (0, react_query_1.useQueryClient)();
28
+ return (0, react_query_1.useMutation)({
29
+ mutationFn: async (data) => {
30
+ const client = (0, client_1.getApiClient)();
31
+ const response = await client.post('/api/v1/spots', data);
32
+ return response.data.data;
33
+ },
34
+ onSuccess: () => {
35
+ queryClient.invalidateQueries({ queryKey: spots_1.spotKeys.lists() });
36
+ },
37
+ ...options,
38
+ });
39
+ }
40
+ /**
41
+ * Update a spot
42
+ *
43
+ * @endpoint PUT /api/v1/spots/{spotId}
44
+ */
45
+ function useUpdateSpot(options) {
46
+ const queryClient = (0, react_query_1.useQueryClient)();
47
+ return (0, react_query_1.useMutation)({
48
+ mutationFn: async ({ spotId, ...data }) => {
49
+ const client = (0, client_1.getApiClient)();
50
+ const response = await client.put(`/api/v1/spots/${spotId}`, data);
51
+ return response.data.data;
52
+ },
53
+ onSuccess: (data, variables) => {
54
+ queryClient.setQueryData(spots_1.spotKeys.detail(variables.spotId), data);
55
+ },
56
+ ...options,
57
+ });
58
+ }
59
+ /**
60
+ * Claim a spot (for business owners)
61
+ *
62
+ * @endpoint POST /api/v1/spots/{spotId}/claim
63
+ */
64
+ function useClaimSpot(options) {
65
+ return (0, react_query_1.useMutation)({
66
+ mutationFn: async ({ spotId, ...data }) => {
67
+ const client = (0, client_1.getApiClient)();
68
+ const response = await client.post(`/api/v1/spots/${spotId}/claim`, data);
69
+ return response.data.data;
70
+ },
71
+ ...options,
72
+ });
73
+ }
74
+ /**
75
+ * Subscribe to a spot
76
+ *
77
+ * @endpoint POST /api/v1/spots/{spotId}/subscribe
78
+ */
79
+ function useSubscribeToSpot(options) {
80
+ const queryClient = (0, react_query_1.useQueryClient)();
81
+ return (0, react_query_1.useMutation)({
82
+ mutationFn: async (spotId) => {
83
+ const client = (0, client_1.getApiClient)();
84
+ await client.post(`/api/v1/spots/${spotId}/subscribe`);
85
+ },
86
+ onSuccess: () => {
87
+ queryClient.invalidateQueries({ queryKey: users_1.userKeys.subscriptions() });
88
+ },
89
+ ...options,
90
+ });
91
+ }
92
+ /**
93
+ * Unsubscribe from a spot
94
+ *
95
+ * @endpoint DELETE /api/v1/spots/{spotId}/subscribe
96
+ */
97
+ function useUnsubscribeFromSpot(options) {
98
+ const queryClient = (0, react_query_1.useQueryClient)();
99
+ return (0, react_query_1.useMutation)({
100
+ mutationFn: async (spotId) => {
101
+ const client = (0, client_1.getApiClient)();
102
+ await client.delete(`/api/v1/spots/${spotId}/subscribe`);
103
+ },
104
+ onSuccess: () => {
105
+ queryClient.invalidateQueries({ queryKey: users_1.userKeys.subscriptions() });
106
+ },
107
+ ...options,
108
+ });
109
+ }
110
+ /**
111
+ * Toggle favorite status on a spot
112
+ *
113
+ * @endpoint POST /api/v1/spots/{spotId}/favorite
114
+ */
115
+ function useFavoriteSpot(options) {
116
+ const queryClient = (0, react_query_1.useQueryClient)();
117
+ return (0, react_query_1.useMutation)({
118
+ mutationFn: async (spotId) => {
119
+ const client = (0, client_1.getApiClient)();
120
+ const response = await client.post(`/api/v1/spots/${spotId}/favorite`);
121
+ return response.data.data;
122
+ },
123
+ onSuccess: () => {
124
+ queryClient.invalidateQueries({ queryKey: users_1.userKeys.favorites() });
125
+ },
126
+ ...options,
127
+ });
128
+ }
129
+ //# 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 { useMutation, useQueryClient, UseMutationOptions, UseMutationResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { spotKeys } from '../queries/spots';\nimport { userKeys } from '../queries/users';\nimport type { Spot, ClaimSpotRequest, ApiResponse } from '../types';\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a new spot\n *\n * @endpoint POST /api/v1/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>>('/api/v1/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 /api/v1/spots/{spotId}\n */\nexport function useUpdateSpot(\n  options?: Omit<UseMutationOptions<Spot, Error, { spotId: string } & Partial<Spot>>, 'mutationFn'>\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>>(`/api/v1/spots/${spotId}`, data);\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 /api/v1/spots/{spotId}/claim\n */\nexport function useClaimSpot(\n  options?: Omit<UseMutationOptions<{ claimId: string }, Error, { spotId: string } & ClaimSpotRequest>, 'mutationFn'>\n): UseMutationResult<{ claimId: string }, Error, { spotId: string } & ClaimSpotRequest> {\n  return useMutation({\n    mutationFn: async ({ spotId, ...data }): Promise<{ claimId: string }> => {\n      const client = getApiClient();\n      const response = await client.post<ApiResponse<{ claimId: string }>>(`/api/v1/spots/${spotId}/claim`, data);\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Subscribe to a spot\n *\n * @endpoint POST /api/v1/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(`/api/v1/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 /api/v1/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(`/api/v1/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 /api/v1/spots/{spotId}/favorite\n */\nexport function useFavoriteSpot(\n  options?: Omit<UseMutationOptions<{ isFavorite: boolean }, Error, string>, 'mutationFn'>\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 }>>(`/api/v1/spots/${spotId}/favorite`);\n      return response.data.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: userKeys.favorites() });\n    },\n    ...options,\n  });\n}\n"]}
@@ -0,0 +1,71 @@
1
+ /**
2
+ * Users Mutation Hooks
3
+ *
4
+ * TanStack Query hooks for user mutation operations.
5
+ */
6
+ import { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
7
+ import type { User, UpdateProfileRequest } from '../types';
8
+ /**
9
+ * Update current user's profile
10
+ *
11
+ * @endpoint PUT /api/v1/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
+ * @endpoint POST /api/v1/users/me/avatar
18
+ */
19
+ export declare function useUploadAvatar(options?: Omit<UseMutationOptions<{
20
+ avatarUrl: string;
21
+ }, Error, FormData>, 'mutationFn'>): UseMutationResult<{
22
+ avatarUrl: string;
23
+ }, Error, FormData>;
24
+ /**
25
+ * Delete current user's account
26
+ *
27
+ * @endpoint DELETE /api/v1/users/me
28
+ */
29
+ export declare function useDeleteAccount(options?: Omit<UseMutationOptions<void, Error, void>, 'mutationFn'>): UseMutationResult<void, Error, void>;
30
+ /**
31
+ * Update user vibes
32
+ *
33
+ * @endpoint PUT /api/v1/user/me/vibes
34
+ */
35
+ export declare function useUpdateVibes(options?: Omit<UseMutationOptions<User, Error, {
36
+ vibes: string[];
37
+ }>, 'mutationFn'>): UseMutationResult<User, Error, {
38
+ vibes: string[];
39
+ }>;
40
+ /**
41
+ * Update user interests
42
+ *
43
+ * @endpoint PUT /api/v1/user/me/interests
44
+ */
45
+ export declare function useUpdateInterests(options?: Omit<UseMutationOptions<User, Error, {
46
+ interests: string[];
47
+ }>, 'mutationFn'>): UseMutationResult<User, Error, {
48
+ interests: string[];
49
+ }>;
50
+ /**
51
+ * Complete onboarding step
52
+ *
53
+ * @endpoint POST /api/v1/user/me/onboarding-step
54
+ */
55
+ export declare function useCompleteOnboardingStep(options?: Omit<UseMutationOptions<User, Error, {
56
+ step: number;
57
+ }>, 'mutationFn'>): UseMutationResult<User, Error, {
58
+ step: number;
59
+ }>;
60
+ /**
61
+ * Block a user
62
+ *
63
+ * @endpoint POST /api/v1/users/{id}/block
64
+ */
65
+ export declare function useBlockUser(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
66
+ /**
67
+ * Unblock a user
68
+ *
69
+ * @endpoint DELETE /api/v1/users/{id}/block
70
+ */
71
+ export declare function useUnblockUser(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
@@ -0,0 +1,173 @@
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 /api/v1/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('/api/v1/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
+ * @endpoint POST /api/v1/users/me/avatar
45
+ */
46
+ function useUploadAvatar(options) {
47
+ const queryClient = (0, react_query_1.useQueryClient)();
48
+ return (0, react_query_1.useMutation)({
49
+ mutationFn: async (formData) => {
50
+ const client = (0, client_1.getApiClient)();
51
+ const response = await client.post('/api/v1/users/me/avatar', formData, {
52
+ headers: { 'Content-Type': 'multipart/form-data' },
53
+ });
54
+ return response.data.data;
55
+ },
56
+ onSuccess: () => {
57
+ queryClient.invalidateQueries({ queryKey: users_1.userKeys.me() });
58
+ },
59
+ ...options,
60
+ });
61
+ }
62
+ /**
63
+ * Delete current user's account
64
+ *
65
+ * @endpoint DELETE /api/v1/users/me
66
+ */
67
+ function useDeleteAccount(options) {
68
+ const queryClient = (0, react_query_1.useQueryClient)();
69
+ return (0, react_query_1.useMutation)({
70
+ mutationFn: async () => {
71
+ const client = (0, client_1.getApiClient)();
72
+ await client.delete('/api/v1/users/me');
73
+ },
74
+ onSuccess: () => {
75
+ queryClient.clear();
76
+ },
77
+ ...options,
78
+ });
79
+ }
80
+ /**
81
+ * Update user vibes
82
+ *
83
+ * @endpoint PUT /api/v1/user/me/vibes
84
+ */
85
+ function useUpdateVibes(options) {
86
+ const queryClient = (0, react_query_1.useQueryClient)();
87
+ return (0, react_query_1.useMutation)({
88
+ mutationFn: async (data) => {
89
+ const client = (0, client_1.getApiClient)();
90
+ const response = await client.put('/api/v1/user/me/vibes', data);
91
+ return response.data.data;
92
+ },
93
+ onSuccess: () => {
94
+ queryClient.invalidateQueries({ queryKey: users_1.userKeys.me() });
95
+ },
96
+ ...options,
97
+ });
98
+ }
99
+ /**
100
+ * Update user interests
101
+ *
102
+ * @endpoint PUT /api/v1/user/me/interests
103
+ */
104
+ function useUpdateInterests(options) {
105
+ const queryClient = (0, react_query_1.useQueryClient)();
106
+ return (0, react_query_1.useMutation)({
107
+ mutationFn: async (data) => {
108
+ const client = (0, client_1.getApiClient)();
109
+ const response = await client.put('/api/v1/user/me/interests', data);
110
+ return response.data.data;
111
+ },
112
+ onSuccess: () => {
113
+ queryClient.invalidateQueries({ queryKey: users_1.userKeys.me() });
114
+ },
115
+ ...options,
116
+ });
117
+ }
118
+ /**
119
+ * Complete onboarding step
120
+ *
121
+ * @endpoint POST /api/v1/user/me/onboarding-step
122
+ */
123
+ function useCompleteOnboardingStep(options) {
124
+ const queryClient = (0, react_query_1.useQueryClient)();
125
+ return (0, react_query_1.useMutation)({
126
+ mutationFn: async (data) => {
127
+ const client = (0, client_1.getApiClient)();
128
+ const response = await client.post('/api/v1/user/me/onboarding-step', data);
129
+ return response.data.data;
130
+ },
131
+ onSuccess: () => {
132
+ queryClient.invalidateQueries({ queryKey: users_1.userKeys.me() });
133
+ },
134
+ ...options,
135
+ });
136
+ }
137
+ /**
138
+ * Block a user
139
+ *
140
+ * @endpoint POST /api/v1/users/{id}/block
141
+ */
142
+ function useBlockUser(options) {
143
+ const queryClient = (0, react_query_1.useQueryClient)();
144
+ return (0, react_query_1.useMutation)({
145
+ mutationFn: async (userId) => {
146
+ const client = (0, client_1.getApiClient)();
147
+ await client.post(`/api/v1/users/${userId}/block`);
148
+ },
149
+ onSuccess: () => {
150
+ queryClient.invalidateQueries({ queryKey: users_1.userKeys.blocked() });
151
+ },
152
+ ...options,
153
+ });
154
+ }
155
+ /**
156
+ * Unblock a user
157
+ *
158
+ * @endpoint DELETE /api/v1/users/{id}/block
159
+ */
160
+ function useUnblockUser(options) {
161
+ const queryClient = (0, react_query_1.useQueryClient)();
162
+ return (0, react_query_1.useMutation)({
163
+ mutationFn: async (userId) => {
164
+ const client = (0, client_1.getApiClient)();
165
+ await client.delete(`/api/v1/users/${userId}/block`);
166
+ },
167
+ onSuccess: () => {
168
+ queryClient.invalidateQueries({ queryKey: users_1.userKeys.blocked() });
169
+ },
170
+ ...options,
171
+ });
172
+ }
173
+ //# 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 { useMutation, useQueryClient, UseMutationOptions, UseMutationResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { userKeys } from '../queries/users';\nimport type { User, UpdateProfileRequest, ApiResponse } from '../types';\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Update current user's profile\n *\n * @endpoint PUT /api/v1/users/me\n */\nexport function useUpdateProfile(\n  options?: Omit<UseMutationOptions<User, Error, UpdateProfileRequest>, 'mutationFn'>\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>>('/api/v1/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 * @endpoint POST /api/v1/users/me/avatar\n */\nexport function useUploadAvatar(\n  options?: Omit<UseMutationOptions<{ avatarUrl: string }, Error, FormData>, 'mutationFn'>\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 }>>('/api/v1/users/me/avatar', formData, {\n        headers: { 'Content-Type': 'multipart/form-data' },\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 /api/v1/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('/api/v1/users/me');\n    },\n    onSuccess: () => {\n      queryClient.clear();\n    },\n    ...options,\n  });\n}\n\n/**\n * Update user vibes\n *\n * @endpoint PUT /api/v1/user/me/vibes\n */\nexport function useUpdateVibes(\n  options?: Omit<UseMutationOptions<User, Error, { vibes: string[] }>, 'mutationFn'>\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>>('/api/v1/user/me/vibes', data);\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 /api/v1/user/me/interests\n */\nexport function useUpdateInterests(\n  options?: Omit<UseMutationOptions<User, Error, { interests: string[] }>, 'mutationFn'>\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>>('/api/v1/user/me/interests', data);\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 /api/v1/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>>('/api/v1/user/me/onboarding-step', data);\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 /api/v1/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(`/api/v1/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 /api/v1/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(`/api/v1/users/${userId}/block`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: userKeys.blocked() });\n    },\n    ...options,\n  });\n}\n"]}
@@ -0,0 +1,37 @@
1
+ /**
2
+ * Auth Mutation Hooks
3
+ *
4
+ * TanStack Query hooks for authentication operations.
5
+ */
6
+ import { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
7
+ import type { SendOtpRequest, VerifyOtpRequest, AuthResponse, ApiResponse } from '../types';
8
+ /**
9
+ * Send OTP to phone number
10
+ *
11
+ * @endpoint POST /api/v1/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 /api/v1/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 /api/v1/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
+ }>;