@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,116 @@
1
+ "use strict";
2
+ /**
3
+ * Orders Mutation Hooks
4
+ *
5
+ * TanStack Query hooks for order mutation operations.
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.useCreateOrder = useCreateOrder;
9
+ exports.useCreateStripeIntent = useCreateStripeIntent;
10
+ exports.useCreateCoinbaseCharge = useCreateCoinbaseCharge;
11
+ exports.useUpdateOrderStatus = useUpdateOrderStatus;
12
+ exports.useCancelOrder = useCancelOrder;
13
+ const react_query_1 = require("@tanstack/react-query");
14
+ const client_1 = require("../client");
15
+ const orders_1 = require("../queries/orders");
16
+ const products_1 = require("../queries/products");
17
+ // ============================================================================
18
+ // MUTATION HOOKS
19
+ // ============================================================================
20
+ /**
21
+ * Create a new order
22
+ *
23
+ * @endpoint POST /api/v1/orders
24
+ */
25
+ function useCreateOrder(options) {
26
+ const queryClient = (0, react_query_1.useQueryClient)();
27
+ return (0, react_query_1.useMutation)({
28
+ mutationFn: async (data) => {
29
+ const client = (0, client_1.getApiClient)();
30
+ const response = await client.post('/api/v1/orders', data);
31
+ return response.data.data;
32
+ },
33
+ onSuccess: (_, variables) => {
34
+ // Invalidate products to reflect updated stock
35
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.bySpot(variables.spotId) });
36
+ // Invalidate my orders list
37
+ queryClient.invalidateQueries({ queryKey: orders_1.orderKeys.list({ my: true }) });
38
+ },
39
+ ...options,
40
+ });
41
+ }
42
+ /**
43
+ * Create Stripe PaymentIntent for an order
44
+ *
45
+ * @endpoint POST /api/v1/payments/stripe/intent/{orderId}
46
+ */
47
+ function useCreateStripeIntent(options) {
48
+ return (0, react_query_1.useMutation)({
49
+ mutationFn: async (orderId) => {
50
+ const client = (0, client_1.getApiClient)();
51
+ const response = await client.post(`/api/v1/payments/stripe/intent/${orderId}`);
52
+ return response.data.data;
53
+ },
54
+ ...options,
55
+ });
56
+ }
57
+ /**
58
+ * Create Coinbase Commerce charge for an order
59
+ *
60
+ * @endpoint POST /api/v1/payments/coinbase/charge/{orderId}
61
+ */
62
+ function useCreateCoinbaseCharge(options) {
63
+ return (0, react_query_1.useMutation)({
64
+ mutationFn: async (orderId) => {
65
+ const client = (0, client_1.getApiClient)();
66
+ const response = await client.post(`/api/v1/payments/coinbase/charge/${orderId}`);
67
+ return response.data.data;
68
+ },
69
+ ...options,
70
+ });
71
+ }
72
+ /**
73
+ * Update order status (seller action)
74
+ *
75
+ * @endpoint PUT /api/v1/orders/{orderId}/status
76
+ */
77
+ function useUpdateOrderStatus(options) {
78
+ const queryClient = (0, react_query_1.useQueryClient)();
79
+ return (0, react_query_1.useMutation)({
80
+ mutationFn: async ({ orderId, status }) => {
81
+ const client = (0, client_1.getApiClient)();
82
+ const response = await client.put(`/api/v1/orders/${orderId}/status`, {
83
+ status,
84
+ });
85
+ return response.data.data;
86
+ },
87
+ onSuccess: (data) => {
88
+ queryClient.setQueryData(orders_1.orderKeys.detail(data.id), data);
89
+ queryClient.invalidateQueries({ queryKey: orders_1.orderKeys.spotOrders(data.spotId) });
90
+ },
91
+ ...options,
92
+ });
93
+ }
94
+ /**
95
+ * Cancel an order (buyer action, only for pending orders)
96
+ *
97
+ * @endpoint POST /api/v1/orders/{orderId}/cancel
98
+ */
99
+ function useCancelOrder(options) {
100
+ const queryClient = (0, react_query_1.useQueryClient)();
101
+ return (0, react_query_1.useMutation)({
102
+ mutationFn: async (orderId) => {
103
+ const client = (0, client_1.getApiClient)();
104
+ const response = await client.post(`/api/v1/orders/${orderId}/cancel`);
105
+ return response.data.data;
106
+ },
107
+ onSuccess: (data) => {
108
+ queryClient.setQueryData(orders_1.orderKeys.detail(data.id), data);
109
+ queryClient.invalidateQueries({ queryKey: orders_1.orderKeys.list({ my: true }) });
110
+ // Restore stock
111
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.bySpot(data.spotId) });
112
+ },
113
+ ...options,
114
+ });
115
+ }
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orders.js","sourceRoot":"","sources":["../../../src/api/mutations/orders.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Orders Mutation Hooks\n *\n * TanStack Query hooks for order mutation operations.\n */\n\nimport { useMutation, useQueryClient, UseMutationOptions, UseMutationResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { orderKeys, OrderWithDetails } from '../queries/orders';\nimport { productKeys } from '../queries/products';\nimport type { Order, OrderStatus, ApiResponse } from '../types';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface CartItem {\n  productId: string;\n  quantity: number;\n}\n\nexport interface CreateOrderRequest {\n  spotId: string;\n  items: CartItem[];\n  notes?: string;\n  deliveryAddress?: string;\n}\n\nexport interface CreateOrderResponse extends Order {\n  items: Array<{\n    id: string;\n    productId: string;\n    productName: string;\n    quantity: number;\n    unitPrice: number;\n    totalPrice: number;\n  }>;\n}\n\nexport interface PaymentIntentResponse {\n  clientSecret: string;\n  paymentIntentId: string;\n}\n\nexport interface CoinbaseChargeResponse {\n  chargeId: string;\n  chargeCode: string;\n  hostedUrl: string;\n}\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a new order\n *\n * @endpoint POST /api/v1/orders\n */\nexport function useCreateOrder(\n  options?: Omit<UseMutationOptions<CreateOrderResponse, Error, CreateOrderRequest>, 'mutationFn'>\n): UseMutationResult<CreateOrderResponse, Error, CreateOrderRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateOrderRequest): Promise<CreateOrderResponse> => {\n      const client = getApiClient();\n      const response = await client.post<ApiResponse<CreateOrderResponse>>('/api/v1/orders', data);\n      return response.data.data;\n    },\n    onSuccess: (_, variables) => {\n      // Invalidate products to reflect updated stock\n      queryClient.invalidateQueries({ queryKey: productKeys.bySpot(variables.spotId) });\n      // Invalidate my orders list\n      queryClient.invalidateQueries({ queryKey: orderKeys.list({ my: true }) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Create Stripe PaymentIntent for an order\n *\n * @endpoint POST /api/v1/payments/stripe/intent/{orderId}\n */\nexport function useCreateStripeIntent(\n  options?: Omit<UseMutationOptions<PaymentIntentResponse, Error, string>, 'mutationFn'>\n): UseMutationResult<PaymentIntentResponse, Error, string> {\n  return useMutation({\n    mutationFn: async (orderId: string): Promise<PaymentIntentResponse> => {\n      const client = getApiClient();\n      const response = await client.post<ApiResponse<PaymentIntentResponse>>(\n        `/api/v1/payments/stripe/intent/${orderId}`\n      );\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Create Coinbase Commerce charge for an order\n *\n * @endpoint POST /api/v1/payments/coinbase/charge/{orderId}\n */\nexport function useCreateCoinbaseCharge(\n  options?: Omit<UseMutationOptions<CoinbaseChargeResponse, Error, string>, 'mutationFn'>\n): UseMutationResult<CoinbaseChargeResponse, Error, string> {\n  return useMutation({\n    mutationFn: async (orderId: string): Promise<CoinbaseChargeResponse> => {\n      const client = getApiClient();\n      const response = await client.post<ApiResponse<CoinbaseChargeResponse>>(\n        `/api/v1/payments/coinbase/charge/${orderId}`\n      );\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Update order status (seller action)\n *\n * @endpoint PUT /api/v1/orders/{orderId}/status\n */\nexport function useUpdateOrderStatus(\n  options?: Omit<\n    UseMutationOptions<OrderWithDetails, Error, { orderId: string; status: OrderStatus }>,\n    'mutationFn'\n  >\n): UseMutationResult<OrderWithDetails, Error, { orderId: string; status: OrderStatus }> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ orderId, status }): Promise<OrderWithDetails> => {\n      const client = getApiClient();\n      const response = await client.put<ApiResponse<OrderWithDetails>>(`/api/v1/orders/${orderId}/status`, {\n        status,\n      });\n      return response.data.data;\n    },\n    onSuccess: (data) => {\n      queryClient.setQueryData(orderKeys.detail(data.id), data);\n      queryClient.invalidateQueries({ queryKey: orderKeys.spotOrders(data.spotId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Cancel an order (buyer action, only for pending orders)\n *\n * @endpoint POST /api/v1/orders/{orderId}/cancel\n */\nexport function useCancelOrder(\n  options?: Omit<UseMutationOptions<OrderWithDetails, Error, string>, 'mutationFn'>\n): UseMutationResult<OrderWithDetails, Error, string> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (orderId: string): Promise<OrderWithDetails> => {\n      const client = getApiClient();\n      const response = await client.post<ApiResponse<OrderWithDetails>>(`/api/v1/orders/${orderId}/cancel`);\n      return response.data.data;\n    },\n    onSuccess: (data) => {\n      queryClient.setQueryData(orderKeys.detail(data.id), data);\n      queryClient.invalidateQueries({ queryKey: orderKeys.list({ my: true }) });\n      // Restore stock\n      queryClient.invalidateQueries({ queryKey: productKeys.bySpot(data.spotId) });\n    },\n    ...options,\n  });\n}\n"]}
@@ -0,0 +1,123 @@
1
+ /**
2
+ * Posts Mutation Hooks
3
+ *
4
+ * TanStack Query hooks for post/board mutation operations.
5
+ */
6
+ import { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
7
+ import type { Post, PostResponse, CreatePostRequest, CreateReplyRequest, RespondToPostRequest, UpdateResponseRequest, UpvoteResponse, PostStatusDto } from '../types';
8
+ /**
9
+ * Create a new post
10
+ *
11
+ * @endpoint POST /api/v1/spots/{spotId}/posts
12
+ */
13
+ export declare function useCreatePost(options?: Omit<UseMutationOptions<Post, Error, {
14
+ spotId: string;
15
+ } & CreatePostRequest>, 'mutationFn'>): UseMutationResult<Post, Error, {
16
+ spotId: string;
17
+ } & CreatePostRequest>;
18
+ /**
19
+ * Update a post
20
+ *
21
+ * @endpoint PUT /api/v1/posts/{postId}
22
+ */
23
+ export declare function useUpdatePost(options?: Omit<UseMutationOptions<Post, Error, {
24
+ postId: string;
25
+ title?: string;
26
+ content?: string;
27
+ }>, 'mutationFn'>): UseMutationResult<Post, Error, {
28
+ postId: string;
29
+ title?: string;
30
+ content?: string;
31
+ }>;
32
+ /**
33
+ * Delete a post
34
+ *
35
+ * @endpoint DELETE /api/v1/posts/{postId}
36
+ */
37
+ export declare function useDeletePost(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
38
+ /**
39
+ * Fulfill a post (mark as fulfilled)
40
+ *
41
+ * @endpoint PUT /api/v1/posts/{postId}/fulfill
42
+ */
43
+ export declare function useFulfillPost(options?: Omit<UseMutationOptions<Post, Error, string>, 'mutationFn'>): UseMutationResult<Post, Error, string>;
44
+ /**
45
+ * Upvote/unupvote a post
46
+ *
47
+ * @endpoint POST /api/v1/posts/{postId}/upvote
48
+ */
49
+ export declare function useUpvotePost(options?: Omit<UseMutationOptions<UpvoteResponse, Error, string>, 'mutationFn'>): UseMutationResult<UpvoteResponse, Error, string>;
50
+ /**
51
+ * Create a reply to a post
52
+ *
53
+ * @endpoint POST /api/v1/posts/{postId}/reply
54
+ */
55
+ export declare function useCreateReply(options?: Omit<UseMutationOptions<unknown, Error, {
56
+ postId: string;
57
+ } & CreateReplyRequest>, 'mutationFn'>): UseMutationResult<unknown, Error, {
58
+ postId: string;
59
+ } & CreateReplyRequest>;
60
+ /**
61
+ * Delete a reply
62
+ *
63
+ * @endpoint DELETE /api/v1/replies/{replyId}
64
+ */
65
+ export declare function useDeleteReply(options?: Omit<UseMutationOptions<void, Error, {
66
+ replyId: string;
67
+ postId: string;
68
+ }>, 'mutationFn'>): UseMutationResult<void, Error, {
69
+ replyId: string;
70
+ postId: string;
71
+ }>;
72
+ /**
73
+ * Respond to a post (express interest)
74
+ *
75
+ * @endpoint POST /api/v1/posts/{postId}/respond
76
+ */
77
+ export declare function useRespondToPost(options?: Omit<UseMutationOptions<PostResponse, Error, {
78
+ postId: string;
79
+ } & RespondToPostRequest>, 'mutationFn'>): UseMutationResult<PostResponse, Error, {
80
+ postId: string;
81
+ } & RespondToPostRequest>;
82
+ /**
83
+ * Accept or decline a response
84
+ *
85
+ * @endpoint PUT /api/v1/responses/{responseId}
86
+ */
87
+ export declare function useUpdateResponse(options?: Omit<UseMutationOptions<PostResponse, Error, {
88
+ responseId: string;
89
+ postId: string;
90
+ } & UpdateResponseRequest>, 'mutationFn'>): UseMutationResult<PostResponse, Error, {
91
+ responseId: string;
92
+ postId: string;
93
+ } & UpdateResponseRequest>;
94
+ /**
95
+ * Report a post
96
+ *
97
+ * @endpoint POST /api/v1/posts/{postId}/report
98
+ */
99
+ export declare function useReportPost(options?: Omit<UseMutationOptions<void, Error, {
100
+ postId: string;
101
+ reason: string;
102
+ details?: string;
103
+ }>, 'mutationFn'>): UseMutationResult<void, Error, {
104
+ postId: string;
105
+ reason: string;
106
+ details?: string;
107
+ }>;
108
+ interface PostStatusUpdate {
109
+ isRead?: boolean;
110
+ isHidden?: boolean;
111
+ isPinned?: boolean;
112
+ }
113
+ /**
114
+ * Update user's status for a post (read/hidden/pinned)
115
+ *
116
+ * @endpoint PUT /api/v1/posts/{postId}/status
117
+ */
118
+ export declare function useUpdatePostStatus(options?: Omit<UseMutationOptions<PostStatusDto, Error, {
119
+ postId: string;
120
+ } & PostStatusUpdate>, 'mutationFn'>): UseMutationResult<PostStatusDto, Error, {
121
+ postId: string;
122
+ } & PostStatusUpdate>;
123
+ export {};
@@ -0,0 +1,229 @@
1
+ "use strict";
2
+ /**
3
+ * Posts Mutation Hooks
4
+ *
5
+ * TanStack Query hooks for post/board mutation operations.
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.useCreatePost = useCreatePost;
9
+ exports.useUpdatePost = useUpdatePost;
10
+ exports.useDeletePost = useDeletePost;
11
+ exports.useFulfillPost = useFulfillPost;
12
+ exports.useUpvotePost = useUpvotePost;
13
+ exports.useCreateReply = useCreateReply;
14
+ exports.useDeleteReply = useDeleteReply;
15
+ exports.useRespondToPost = useRespondToPost;
16
+ exports.useUpdateResponse = useUpdateResponse;
17
+ exports.useReportPost = useReportPost;
18
+ exports.useUpdatePostStatus = useUpdatePostStatus;
19
+ const react_query_1 = require("@tanstack/react-query");
20
+ const client_1 = require("../client");
21
+ const posts_1 = require("../queries/posts");
22
+ // ============================================================================
23
+ // MUTATION HOOKS
24
+ // ============================================================================
25
+ /**
26
+ * Create a new post
27
+ *
28
+ * @endpoint POST /api/v1/spots/{spotId}/posts
29
+ */
30
+ function useCreatePost(options) {
31
+ const queryClient = (0, react_query_1.useQueryClient)();
32
+ return (0, react_query_1.useMutation)({
33
+ mutationFn: async ({ spotId, ...data }) => {
34
+ const client = (0, client_1.getApiClient)();
35
+ const response = await client.post(`/api/v1/spots/${spotId}/posts`, data);
36
+ return response.data.data;
37
+ },
38
+ onSuccess: (_, variables) => {
39
+ queryClient.invalidateQueries({ queryKey: posts_1.postKeys.bySpot(variables.spotId) });
40
+ },
41
+ ...options,
42
+ });
43
+ }
44
+ /**
45
+ * Update a post
46
+ *
47
+ * @endpoint PUT /api/v1/posts/{postId}
48
+ */
49
+ function useUpdatePost(options) {
50
+ const queryClient = (0, react_query_1.useQueryClient)();
51
+ return (0, react_query_1.useMutation)({
52
+ mutationFn: async ({ postId, ...data }) => {
53
+ const client = (0, client_1.getApiClient)();
54
+ const response = await client.put(`/api/v1/posts/${postId}`, data);
55
+ return response.data.data;
56
+ },
57
+ onSuccess: (data, variables) => {
58
+ queryClient.setQueryData(posts_1.postKeys.detail(variables.postId), data);
59
+ },
60
+ ...options,
61
+ });
62
+ }
63
+ /**
64
+ * Delete a post
65
+ *
66
+ * @endpoint DELETE /api/v1/posts/{postId}
67
+ */
68
+ function useDeletePost(options) {
69
+ const queryClient = (0, react_query_1.useQueryClient)();
70
+ return (0, react_query_1.useMutation)({
71
+ mutationFn: async (postId) => {
72
+ const client = (0, client_1.getApiClient)();
73
+ await client.delete(`/api/v1/posts/${postId}`);
74
+ },
75
+ onSuccess: (_, postId) => {
76
+ queryClient.invalidateQueries({ queryKey: posts_1.postKeys.detail(postId) });
77
+ queryClient.invalidateQueries({ queryKey: posts_1.postKeys.lists() });
78
+ },
79
+ ...options,
80
+ });
81
+ }
82
+ /**
83
+ * Fulfill a post (mark as fulfilled)
84
+ *
85
+ * @endpoint PUT /api/v1/posts/{postId}/fulfill
86
+ */
87
+ function useFulfillPost(options) {
88
+ const queryClient = (0, react_query_1.useQueryClient)();
89
+ return (0, react_query_1.useMutation)({
90
+ mutationFn: async (postId) => {
91
+ const client = (0, client_1.getApiClient)();
92
+ const response = await client.put(`/api/v1/posts/${postId}/fulfill`);
93
+ return response.data.data;
94
+ },
95
+ onSuccess: (data, postId) => {
96
+ queryClient.setQueryData(posts_1.postKeys.detail(postId), data);
97
+ },
98
+ ...options,
99
+ });
100
+ }
101
+ /**
102
+ * Upvote/unupvote a post
103
+ *
104
+ * @endpoint POST /api/v1/posts/{postId}/upvote
105
+ */
106
+ function useUpvotePost(options) {
107
+ const queryClient = (0, react_query_1.useQueryClient)();
108
+ return (0, react_query_1.useMutation)({
109
+ mutationFn: async (postId) => {
110
+ const client = (0, client_1.getApiClient)();
111
+ const response = await client.post(`/api/v1/posts/${postId}/upvote`);
112
+ return response.data.data;
113
+ },
114
+ onSuccess: (_, postId) => {
115
+ queryClient.invalidateQueries({ queryKey: posts_1.postKeys.detail(postId) });
116
+ },
117
+ ...options,
118
+ });
119
+ }
120
+ /**
121
+ * Create a reply to a post
122
+ *
123
+ * @endpoint POST /api/v1/posts/{postId}/reply
124
+ */
125
+ function useCreateReply(options) {
126
+ const queryClient = (0, react_query_1.useQueryClient)();
127
+ return (0, react_query_1.useMutation)({
128
+ mutationFn: async ({ postId, ...data }) => {
129
+ const client = (0, client_1.getApiClient)();
130
+ const response = await client.post(`/api/v1/posts/${postId}/reply`, data);
131
+ return response.data.data;
132
+ },
133
+ onSuccess: (_, variables) => {
134
+ queryClient.invalidateQueries({ queryKey: posts_1.postKeys.detail(variables.postId) });
135
+ },
136
+ ...options,
137
+ });
138
+ }
139
+ /**
140
+ * Delete a reply
141
+ *
142
+ * @endpoint DELETE /api/v1/replies/{replyId}
143
+ */
144
+ function useDeleteReply(options) {
145
+ const queryClient = (0, react_query_1.useQueryClient)();
146
+ return (0, react_query_1.useMutation)({
147
+ mutationFn: async ({ replyId }) => {
148
+ const client = (0, client_1.getApiClient)();
149
+ await client.delete(`/api/v1/replies/${replyId}`);
150
+ },
151
+ onSuccess: (_, variables) => {
152
+ queryClient.invalidateQueries({ queryKey: posts_1.postKeys.detail(variables.postId) });
153
+ },
154
+ ...options,
155
+ });
156
+ }
157
+ /**
158
+ * Respond to a post (express interest)
159
+ *
160
+ * @endpoint POST /api/v1/posts/{postId}/respond
161
+ */
162
+ function useRespondToPost(options) {
163
+ const queryClient = (0, react_query_1.useQueryClient)();
164
+ return (0, react_query_1.useMutation)({
165
+ mutationFn: async ({ postId, ...data }) => {
166
+ const client = (0, client_1.getApiClient)();
167
+ const response = await client.post(`/api/v1/posts/${postId}/respond`, data);
168
+ return response.data.data;
169
+ },
170
+ onSuccess: (_, variables) => {
171
+ queryClient.invalidateQueries({ queryKey: posts_1.postKeys.detail(variables.postId) });
172
+ queryClient.invalidateQueries({ queryKey: posts_1.postKeys.responses(variables.postId) });
173
+ },
174
+ ...options,
175
+ });
176
+ }
177
+ /**
178
+ * Accept or decline a response
179
+ *
180
+ * @endpoint PUT /api/v1/responses/{responseId}
181
+ */
182
+ function useUpdateResponse(options) {
183
+ const queryClient = (0, react_query_1.useQueryClient)();
184
+ return (0, react_query_1.useMutation)({
185
+ mutationFn: async ({ responseId, postId: _, ...data }) => {
186
+ const client = (0, client_1.getApiClient)();
187
+ const response = await client.put(`/api/v1/responses/${responseId}`, data);
188
+ return response.data.data;
189
+ },
190
+ onSuccess: (_, variables) => {
191
+ queryClient.invalidateQueries({ queryKey: posts_1.postKeys.responses(variables.postId) });
192
+ },
193
+ ...options,
194
+ });
195
+ }
196
+ /**
197
+ * Report a post
198
+ *
199
+ * @endpoint POST /api/v1/posts/{postId}/report
200
+ */
201
+ function useReportPost(options) {
202
+ return (0, react_query_1.useMutation)({
203
+ mutationFn: async ({ postId, ...data }) => {
204
+ const client = (0, client_1.getApiClient)();
205
+ await client.post(`/api/v1/posts/${postId}/report`, data);
206
+ },
207
+ ...options,
208
+ });
209
+ }
210
+ /**
211
+ * Update user's status for a post (read/hidden/pinned)
212
+ *
213
+ * @endpoint PUT /api/v1/posts/{postId}/status
214
+ */
215
+ function useUpdatePostStatus(options) {
216
+ const queryClient = (0, react_query_1.useQueryClient)();
217
+ return (0, react_query_1.useMutation)({
218
+ mutationFn: async ({ postId, ...data }) => {
219
+ const client = (0, client_1.getApiClient)();
220
+ const response = await client.put(`/api/v1/posts/${postId}/status`, data);
221
+ return response.data.data;
222
+ },
223
+ onSuccess: (data, variables) => {
224
+ queryClient.setQueryData(posts_1.postKeys.status(variables.postId), data);
225
+ },
226
+ ...options,
227
+ });
228
+ }
229
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"posts.js","sourceRoot":"","sources":["../../../src/api/mutations/posts.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Posts Mutation Hooks\n *\n * TanStack Query hooks for post/board mutation operations.\n */\n\nimport { useMutation, useQueryClient, UseMutationOptions, UseMutationResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { postKeys } from '../queries/posts';\nimport type {\n  Post,\n  PostResponse,\n  CreatePostRequest,\n  CreateReplyRequest,\n  RespondToPostRequest,\n  UpdateResponseRequest,\n  ApiResponse,\n  UpvoteResponse,\n  PostStatusDto,\n} from '../types';\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a new post\n *\n * @endpoint POST /api/v1/spots/{spotId}/posts\n */\nexport function useCreatePost(\n  options?: Omit<UseMutationOptions<Post, Error, { spotId: string } & CreatePostRequest>, 'mutationFn'>\n): UseMutationResult<Post, Error, { spotId: string } & CreatePostRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ spotId, ...data }): Promise<Post> => {\n      const client = getApiClient();\n      const response = await client.post<ApiResponse<Post>>(`/api/v1/spots/${spotId}/posts`, data);\n      return response.data.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: postKeys.bySpot(variables.spotId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a post\n *\n * @endpoint PUT /api/v1/posts/{postId}\n */\nexport function useUpdatePost(\n  options?: Omit<UseMutationOptions<Post, Error, { postId: string; title?: string; content?: string }>, 'mutationFn'>\n): UseMutationResult<Post, Error, { postId: string; title?: string; content?: string }> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ postId, ...data }): Promise<Post> => {\n      const client = getApiClient();\n      const response = await client.put<ApiResponse<Post>>(`/api/v1/posts/${postId}`, data);\n      return response.data.data;\n    },\n    onSuccess: (data, variables) => {\n      queryClient.setQueryData(postKeys.detail(variables.postId), data);\n    },\n    ...options,\n  });\n}\n\n/**\n * Delete a post\n *\n * @endpoint DELETE /api/v1/posts/{postId}\n */\nexport function useDeletePost(\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>\n): UseMutationResult<void, Error, string> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (postId: string): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/posts/${postId}`);\n    },\n    onSuccess: (_, postId) => {\n      queryClient.invalidateQueries({ queryKey: postKeys.detail(postId) });\n      queryClient.invalidateQueries({ queryKey: postKeys.lists() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Fulfill a post (mark as fulfilled)\n *\n * @endpoint PUT /api/v1/posts/{postId}/fulfill\n */\nexport function useFulfillPost(\n  options?: Omit<UseMutationOptions<Post, Error, string>, 'mutationFn'>\n): UseMutationResult<Post, Error, string> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (postId: string): Promise<Post> => {\n      const client = getApiClient();\n      const response = await client.put<ApiResponse<Post>>(`/api/v1/posts/${postId}/fulfill`);\n      return response.data.data;\n    },\n    onSuccess: (data, postId) => {\n      queryClient.setQueryData(postKeys.detail(postId), data);\n    },\n    ...options,\n  });\n}\n\n/**\n * Upvote/unupvote a post\n *\n * @endpoint POST /api/v1/posts/{postId}/upvote\n */\nexport function useUpvotePost(\n  options?: Omit<UseMutationOptions<UpvoteResponse, Error, string>, 'mutationFn'>\n): UseMutationResult<UpvoteResponse, Error, string> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (postId: string): Promise<UpvoteResponse> => {\n      const client = getApiClient();\n      const response = await client.post<ApiResponse<UpvoteResponse>>(`/api/v1/posts/${postId}/upvote`);\n      return response.data.data;\n    },\n    onSuccess: (_, postId) => {\n      queryClient.invalidateQueries({ queryKey: postKeys.detail(postId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a reply to a post\n *\n * @endpoint POST /api/v1/posts/{postId}/reply\n */\nexport function useCreateReply(\n  options?: Omit<UseMutationOptions<unknown, Error, { postId: string } & CreateReplyRequest>, 'mutationFn'>\n): UseMutationResult<unknown, Error, { postId: string } & CreateReplyRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ postId, ...data }) => {\n      const client = getApiClient();\n      const response = await client.post<ApiResponse<unknown>>(`/api/v1/posts/${postId}/reply`, data);\n      return response.data.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: postKeys.detail(variables.postId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Delete a reply\n *\n * @endpoint DELETE /api/v1/replies/{replyId}\n */\nexport function useDeleteReply(\n  options?: Omit<UseMutationOptions<void, Error, { replyId: string; postId: string }>, 'mutationFn'>\n): UseMutationResult<void, Error, { replyId: string; postId: string }> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ replyId }): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/replies/${replyId}`);\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: postKeys.detail(variables.postId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Respond to a post (express interest)\n *\n * @endpoint POST /api/v1/posts/{postId}/respond\n */\nexport function useRespondToPost(\n  options?: Omit<UseMutationOptions<PostResponse, Error, { postId: string } & RespondToPostRequest>, 'mutationFn'>\n): UseMutationResult<PostResponse, Error, { postId: string } & RespondToPostRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ postId, ...data }): Promise<PostResponse> => {\n      const client = getApiClient();\n      const response = await client.post<ApiResponse<PostResponse>>(`/api/v1/posts/${postId}/respond`, data);\n      return response.data.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: postKeys.detail(variables.postId) });\n      queryClient.invalidateQueries({ queryKey: postKeys.responses(variables.postId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Accept or decline a response\n *\n * @endpoint PUT /api/v1/responses/{responseId}\n */\nexport function useUpdateResponse(\n  options?: Omit<UseMutationOptions<PostResponse, Error, { responseId: string; postId: string } & UpdateResponseRequest>, 'mutationFn'>\n): UseMutationResult<PostResponse, Error, { responseId: string; postId: string } & UpdateResponseRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ responseId, postId: _, ...data }): Promise<PostResponse> => {\n      const client = getApiClient();\n      const response = await client.put<ApiResponse<PostResponse>>(`/api/v1/responses/${responseId}`, data);\n      return response.data.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: postKeys.responses(variables.postId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Report a post\n *\n * @endpoint POST /api/v1/posts/{postId}/report\n */\nexport function useReportPost(\n  options?: Omit<UseMutationOptions<void, Error, { postId: string; reason: string; details?: string }>, 'mutationFn'>\n): UseMutationResult<void, Error, { postId: string; reason: string; details?: string }> {\n  return useMutation({\n    mutationFn: async ({ postId, ...data }): Promise<void> => {\n      const client = getApiClient();\n      await client.post(`/api/v1/posts/${postId}/report`, data);\n    },\n    ...options,\n  });\n}\n\n// PostStatusUpdate matches partial PostStatusDto for updates\ninterface PostStatusUpdate {\n  isRead?: boolean;\n  isHidden?: boolean;\n  isPinned?: boolean;\n}\n\n/**\n * Update user's status for a post (read/hidden/pinned)\n *\n * @endpoint PUT /api/v1/posts/{postId}/status\n */\nexport function useUpdatePostStatus(\n  options?: Omit<UseMutationOptions<PostStatusDto, Error, { postId: string } & PostStatusUpdate>, 'mutationFn'>\n): UseMutationResult<PostStatusDto, Error, { postId: string } & PostStatusUpdate> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ postId, ...data }): Promise<PostStatusDto> => {\n      const client = getApiClient();\n      const response = await client.put<ApiResponse<PostStatusDto>>(`/api/v1/posts/${postId}/status`, data);\n      return response.data.data;\n    },\n    onSuccess: (data, variables) => {\n      queryClient.setQueryData(postKeys.status(variables.postId), data);\n    },\n    ...options,\n  });\n}\n"]}
@@ -0,0 +1,81 @@
1
+ /**
2
+ * Products Mutation Hooks
3
+ *
4
+ * TanStack Query hooks for product mutation operations.
5
+ */
6
+ import { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
7
+ import type { Product, ProductType, ProductStatus } from '../types';
8
+ export interface CreateProductRequest {
9
+ spotId: string;
10
+ name: string;
11
+ description?: string;
12
+ type: ProductType;
13
+ price: number;
14
+ currency?: string;
15
+ stockQuantity?: number;
16
+ lowStockThreshold?: number;
17
+ validFrom?: string;
18
+ validUntil?: string;
19
+ deliveryRadiusKm?: number;
20
+ prepTimeMinutes?: number;
21
+ maxCapacity?: number;
22
+ eventDate?: string;
23
+ imageUrl?: string;
24
+ metadata?: Record<string, unknown>;
25
+ }
26
+ export interface UpdateProductRequest {
27
+ name?: string;
28
+ description?: string;
29
+ price?: number;
30
+ stockQuantity?: number;
31
+ lowStockThreshold?: number;
32
+ status?: ProductStatus;
33
+ validFrom?: string;
34
+ validUntil?: string;
35
+ deliveryRadiusKm?: number;
36
+ prepTimeMinutes?: number;
37
+ maxCapacity?: number;
38
+ eventDate?: string;
39
+ imageUrl?: string;
40
+ metadata?: Record<string, unknown>;
41
+ }
42
+ /**
43
+ * Create a new product
44
+ *
45
+ * @endpoint POST /api/v1/spots/{spotId}/products
46
+ */
47
+ export declare function useCreateProduct(options?: Omit<UseMutationOptions<Product, Error, CreateProductRequest>, 'mutationFn'>): UseMutationResult<Product, Error, CreateProductRequest>;
48
+ /**
49
+ * Update a product
50
+ *
51
+ * @endpoint PUT /api/v1/products/{productId}
52
+ */
53
+ export declare function useUpdateProduct(options?: Omit<UseMutationOptions<Product, Error, {
54
+ productId: string;
55
+ data: UpdateProductRequest;
56
+ }>, 'mutationFn'>): UseMutationResult<Product, Error, {
57
+ productId: string;
58
+ data: UpdateProductRequest;
59
+ }>;
60
+ /**
61
+ * Delete a product
62
+ *
63
+ * @endpoint DELETE /api/v1/products/{productId}
64
+ */
65
+ export declare function useDeleteProduct(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
66
+ /**
67
+ * Adjust product stock
68
+ *
69
+ * @endpoint POST /api/v1/products/{productId}/stock
70
+ */
71
+ export declare function useAdjustStock(options?: Omit<UseMutationOptions<Product, Error, {
72
+ productId: string;
73
+ quantity: number;
74
+ reason: 'RESTOCK' | 'ADJUSTMENT';
75
+ notes?: string;
76
+ }>, 'mutationFn'>): UseMutationResult<Product, Error, {
77
+ productId: string;
78
+ quantity: number;
79
+ reason: 'RESTOCK' | 'ADJUSTMENT';
80
+ notes?: string;
81
+ }>;