@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.
- package/dist/api/client.d.ts +12 -0
- package/dist/api/client.js +68 -0
- package/dist/api/mutations/clubs.d.ts +47 -0
- package/dist/api/mutations/clubs.js +95 -0
- package/dist/api/mutations/conversations.d.ts +45 -0
- package/dist/api/mutations/conversations.js +110 -0
- package/dist/api/mutations/index.d.ts +13 -0
- package/dist/api/mutations/index.js +38 -0
- package/dist/api/mutations/notifications.d.ts +38 -0
- package/dist/api/mutations/notifications.js +64 -0
- package/dist/api/mutations/orders.d.ts +73 -0
- package/dist/api/mutations/orders.js +116 -0
- package/dist/api/mutations/posts.d.ts +123 -0
- package/dist/api/mutations/posts.js +229 -0
- package/dist/api/mutations/products.d.ts +81 -0
- package/dist/api/mutations/products.js +102 -0
- package/dist/api/mutations/spots.d.ts +59 -0
- package/dist/api/mutations/spots.js +129 -0
- package/dist/api/mutations/users.d.ts +71 -0
- package/dist/api/mutations/users.js +173 -0
- package/dist/api/queries/auth.d.ts +37 -0
- package/dist/api/queries/auth.js +61 -0
- package/dist/api/queries/clubs.d.ts +52 -0
- package/dist/api/queries/clubs.js +116 -0
- package/dist/api/queries/conversations.d.ts +52 -0
- package/dist/api/queries/conversations.js +83 -0
- package/dist/api/queries/index.d.ts +26 -0
- package/dist/api/queries/index.js +65 -0
- package/dist/api/queries/misc.d.ts +54 -0
- package/dist/api/queries/misc.js +129 -0
- package/dist/api/queries/notifications.d.ts +34 -0
- package/dist/api/queries/notifications.js +62 -0
- package/dist/api/queries/orders.d.ts +45 -0
- package/dist/api/queries/orders.js +93 -0
- package/dist/api/queries/posts.d.ts +55 -0
- package/dist/api/queries/posts.js +130 -0
- package/dist/api/queries/products.d.ts +52 -0
- package/dist/api/queries/products.js +89 -0
- package/dist/api/queries/spots.d.ts +78 -0
- package/dist/api/queries/spots.js +168 -0
- package/dist/api/queries/templates.d.ts +42 -0
- package/dist/api/queries/templates.js +86 -0
- package/dist/api/queries/users.d.ts +90 -0
- package/dist/api/queries/users.js +187 -0
- package/dist/api/services/index.d.ts +2 -0
- package/dist/api/services/index.js +8 -0
- package/dist/api/services/marketplace.d.ts +129 -0
- package/dist/api/services/marketplace.js +168 -0
- package/dist/api/types.d.ts +54 -0
- package/dist/api/types.js +34 -0
- package/dist/index.d.ts +38 -0
- package/dist/index.js +73 -0
- package/package.json +57 -0
- package/src/api/client.ts +78 -0
- package/src/api/mutations/clubs.ts +107 -0
- package/src/api/mutations/conversations.ts +124 -0
- package/src/api/mutations/index.ts +29 -0
- package/src/api/mutations/notifications.ts +70 -0
- package/src/api/mutations/orders.ts +174 -0
- package/src/api/mutations/posts.ts +278 -0
- package/src/api/mutations/products.ts +160 -0
- package/src/api/mutations/spots.ts +146 -0
- package/src/api/mutations/users.ts +197 -0
- package/src/api/queries/auth.ts +67 -0
- package/src/api/queries/clubs.ts +135 -0
- package/src/api/queries/conversations.ts +94 -0
- package/src/api/queries/index.ts +48 -0
- package/src/api/queries/misc.ts +140 -0
- package/src/api/queries/notifications.ts +66 -0
- package/src/api/queries/orders.ts +119 -0
- package/src/api/queries/posts.ts +142 -0
- package/src/api/queries/products.ts +123 -0
- package/src/api/queries/spots.ts +201 -0
- package/src/api/queries/templates.ts +95 -0
- package/src/api/queries/users.ts +206 -0
- package/src/api/services/index.ts +6 -0
- package/src/api/services/marketplace.ts +265 -0
- package/src/api/types.ts +144 -0
- 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
|
+
}>;
|