@spotsdev/sdk 1.0.0 → 1.2.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 +1 -1
- package/dist/api/client.js +7 -3
- package/dist/api/entities.d.ts +318 -0
- package/dist/api/entities.js +9 -0
- package/dist/api/mutations/clubs.d.ts +6 -6
- package/dist/api/mutations/clubs.js +12 -10
- package/dist/api/mutations/conversations.d.ts +7 -7
- package/dist/api/mutations/conversations.js +17 -13
- package/dist/api/mutations/index.js +1 -1
- package/dist/api/mutations/notifications.d.ts +4 -4
- package/dist/api/mutations/notifications.js +7 -7
- package/dist/api/mutations/orders.d.ts +7 -7
- package/dist/api/mutations/orders.js +11 -13
- package/dist/api/mutations/posts.d.ts +13 -13
- package/dist/api/mutations/posts.js +41 -29
- package/dist/api/mutations/products.d.ts +5 -5
- package/dist/api/mutations/products.js +9 -13
- package/dist/api/mutations/spots.d.ts +42 -8
- package/dist/api/mutations/spots.js +51 -13
- package/dist/api/mutations/users.d.ts +12 -10
- package/dist/api/mutations/users.js +20 -18
- package/dist/api/queries/auth.d.ts +5 -5
- package/dist/api/queries/auth.js +7 -7
- package/dist/api/queries/clubs.d.ts +7 -7
- package/dist/api/queries/clubs.js +11 -11
- package/dist/api/queries/conversations.d.ts +5 -5
- package/dist/api/queries/conversations.js +7 -7
- package/dist/api/queries/index.js +1 -1
- package/dist/api/queries/misc.d.ts +8 -32
- package/dist/api/queries/misc.js +28 -66
- package/dist/api/queries/notifications.d.ts +4 -4
- package/dist/api/queries/notifications.js +5 -5
- package/dist/api/queries/orders.d.ts +4 -4
- package/dist/api/queries/orders.js +7 -7
- package/dist/api/queries/posts.d.ts +44 -7
- package/dist/api/queries/posts.js +118 -15
- package/dist/api/queries/products.d.ts +6 -10
- package/dist/api/queries/products.js +7 -9
- package/dist/api/queries/spots.d.ts +31 -16
- package/dist/api/queries/spots.js +113 -31
- package/dist/api/queries/templates.d.ts +6 -9
- package/dist/api/queries/templates.js +8 -13
- package/dist/api/queries/users.d.ts +25 -11
- package/dist/api/queries/users.js +75 -27
- package/dist/api/types.d.ts +36 -33
- package/dist/api/types.js +6 -7
- package/dist/index.d.ts +1 -2
- package/dist/index.js +1 -8
- package/package.json +6 -21
- package/src/api/client.ts +45 -30
- package/src/api/entities.ts +424 -0
- package/src/api/mutations/clubs.ts +73 -40
- package/src/api/mutations/conversations.ts +91 -47
- package/src/api/mutations/index.ts +8 -8
- package/src/api/mutations/notifications.ts +48 -25
- package/src/api/mutations/orders.ts +101 -70
- package/src/api/mutations/posts.ts +229 -118
- package/src/api/mutations/products.ts +120 -81
- package/src/api/mutations/spots.ts +167 -55
- package/src/api/mutations/users.ts +109 -76
- package/src/api/queries/auth.ts +49 -24
- package/src/api/queries/clubs.ts +53 -38
- package/src/api/queries/conversations.ts +48 -30
- package/src/api/queries/index.ts +21 -21
- package/src/api/queries/misc.ts +53 -82
- package/src/api/queries/notifications.ts +32 -21
- package/src/api/queries/orders.ts +59 -42
- package/src/api/queries/posts.ts +203 -48
- package/src/api/queries/products.ts +51 -44
- package/src/api/queries/spots.ts +216 -85
- package/src/api/queries/templates.ts +39 -32
- package/src/api/queries/users.ts +157 -64
- package/src/api/types.ts +72 -118
- package/src/index.ts +5 -11
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
*
|
|
4
4
|
* TanStack Query hooks for order-related operations.
|
|
5
5
|
*/
|
|
6
|
-
import { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
|
|
6
|
+
import { type UseQueryOptions, type UseQueryResult } from '@tanstack/react-query';
|
|
7
7
|
import type { Order, OrderItem, Product, Spot, OrderStatus, PaginatedResponse } from '../types';
|
|
8
8
|
export declare const orderKeys: {
|
|
9
9
|
all: readonly ["orders"];
|
|
@@ -28,18 +28,18 @@ export interface OrderFilters {
|
|
|
28
28
|
/**
|
|
29
29
|
* Get current user's orders (purchases)
|
|
30
30
|
*
|
|
31
|
-
* @endpoint GET /
|
|
31
|
+
* @endpoint GET /users/me/orders
|
|
32
32
|
*/
|
|
33
33
|
export declare function useMyOrders(params?: OrderFilters, options?: Omit<UseQueryOptions<PaginatedResponse<OrderWithDetails>>, 'queryKey' | 'queryFn'>): UseQueryResult<PaginatedResponse<OrderWithDetails>>;
|
|
34
34
|
/**
|
|
35
35
|
* Get a single order by ID
|
|
36
36
|
*
|
|
37
|
-
* @endpoint GET /
|
|
37
|
+
* @endpoint GET /orders/{orderId}
|
|
38
38
|
*/
|
|
39
39
|
export declare function useOrder(orderId: string, options?: Omit<UseQueryOptions<OrderWithDetails>, 'queryKey' | 'queryFn'>): UseQueryResult<OrderWithDetails>;
|
|
40
40
|
/**
|
|
41
41
|
* Get orders for a spot (seller view)
|
|
42
42
|
*
|
|
43
|
-
* @endpoint GET /
|
|
43
|
+
* @endpoint GET /seller/spots/{spotId}/orders
|
|
44
44
|
*/
|
|
45
45
|
export declare function useSpotOrders(spotId: string, params?: OrderFilters, options?: Omit<UseQueryOptions<PaginatedResponse<OrderWithDetails>>, 'queryKey' | 'queryFn'>): UseQueryResult<PaginatedResponse<OrderWithDetails>>;
|
|
@@ -29,7 +29,7 @@ exports.orderKeys = {
|
|
|
29
29
|
/**
|
|
30
30
|
* Get current user's orders (purchases)
|
|
31
31
|
*
|
|
32
|
-
* @endpoint GET /
|
|
32
|
+
* @endpoint GET /users/me/orders
|
|
33
33
|
*/
|
|
34
34
|
function useMyOrders(params, options) {
|
|
35
35
|
return (0, react_query_1.useQuery)({
|
|
@@ -43,7 +43,7 @@ function useMyOrders(params, options) {
|
|
|
43
43
|
queryParams.set('limit', String(params.limit));
|
|
44
44
|
if (params?.page)
|
|
45
45
|
queryParams.set('page', String(params.page));
|
|
46
|
-
const response = await client.get(`/
|
|
46
|
+
const response = await client.get(`/users/me/orders?${queryParams}`);
|
|
47
47
|
return response.data.data;
|
|
48
48
|
},
|
|
49
49
|
...options,
|
|
@@ -52,14 +52,14 @@ function useMyOrders(params, options) {
|
|
|
52
52
|
/**
|
|
53
53
|
* Get a single order by ID
|
|
54
54
|
*
|
|
55
|
-
* @endpoint GET /
|
|
55
|
+
* @endpoint GET /orders/{orderId}
|
|
56
56
|
*/
|
|
57
57
|
function useOrder(orderId, options) {
|
|
58
58
|
return (0, react_query_1.useQuery)({
|
|
59
59
|
queryKey: exports.orderKeys.detail(orderId),
|
|
60
60
|
queryFn: async () => {
|
|
61
61
|
const client = (0, client_1.getApiClient)();
|
|
62
|
-
const response = await client.get(`/
|
|
62
|
+
const response = await client.get(`/orders/${orderId}`);
|
|
63
63
|
return response.data.data;
|
|
64
64
|
},
|
|
65
65
|
enabled: !!orderId,
|
|
@@ -69,7 +69,7 @@ function useOrder(orderId, options) {
|
|
|
69
69
|
/**
|
|
70
70
|
* Get orders for a spot (seller view)
|
|
71
71
|
*
|
|
72
|
-
* @endpoint GET /
|
|
72
|
+
* @endpoint GET /seller/spots/{spotId}/orders
|
|
73
73
|
*/
|
|
74
74
|
function useSpotOrders(spotId, params, options) {
|
|
75
75
|
return (0, react_query_1.useQuery)({
|
|
@@ -83,11 +83,11 @@ function useSpotOrders(spotId, params, options) {
|
|
|
83
83
|
queryParams.set('limit', String(params.limit));
|
|
84
84
|
if (params?.page)
|
|
85
85
|
queryParams.set('page', String(params.page));
|
|
86
|
-
const response = await client.get(`/
|
|
86
|
+
const response = await client.get(`/seller/spots/${spotId}/orders?${queryParams}`);
|
|
87
87
|
return response.data.data;
|
|
88
88
|
},
|
|
89
89
|
enabled: !!spotId,
|
|
90
90
|
...options,
|
|
91
91
|
});
|
|
92
92
|
}
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orders.js","sourceRoot":"","sources":["../../../src/api/queries/orders.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Orders Query Hooks\n *\n * TanStack Query hooks for order-related operations.\n */\n\nimport {useQuery, type UseQueryOptions, type UseQueryResult} from '@tanstack/react-query'\nimport {getApiClient} from '../client'\nimport type {\n  Order,\n  OrderItem,\n  Product,\n  Spot,\n  OrderStatus,\n  ApiResponse,\n  PaginatedResponse,\n} from '../types'\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const orderKeys = {\n  all: ['orders'] as const,\n  lists: () => [...orderKeys.all, 'list'] as const,\n  list: (filters?: Record<string, unknown>) =>\n    [...orderKeys.lists(), filters] as const,\n  details: () => [...orderKeys.all, 'detail'] as const,\n  detail: (id: string) => [...orderKeys.details(), id] as const,\n  myOrders: () => [...orderKeys.all, 'my'] as const,\n  spotOrders: (spotId: string) => [...orderKeys.all, 'spot', spotId] as const,\n}\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface OrderWithDetails extends Order {\n  items: (OrderItem & {\n    product: Pick<Product, 'id' | 'name' | 'slug' | 'type' | 'imageUrl'>\n  })[]\n  spot: Pick<Spot, 'id' | 'name' | 'slug'>\n}\n\nexport interface OrderFilters {\n  status?: OrderStatus\n  limit?: number\n  page?: number\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get current user's orders (purchases)\n *\n * @endpoint GET /users/me/orders\n */\nexport function useMyOrders(\n  params?: OrderFilters,\n  options?: Omit<\n    UseQueryOptions<PaginatedResponse<OrderWithDetails>>,\n    'queryKey' | 'queryFn'\n  >,\n): UseQueryResult<PaginatedResponse<OrderWithDetails>> {\n  return useQuery({\n    queryKey: orderKeys.list({...params, my: true}),\n    queryFn: async (): Promise<PaginatedResponse<OrderWithDetails>> => {\n      const client = getApiClient()\n      const queryParams = new URLSearchParams()\n      if (params?.status) queryParams.set('status', params.status)\n      if (params?.limit) queryParams.set('limit', String(params.limit))\n      if (params?.page) queryParams.set('page', String(params.page))\n      const response = await client.get<\n        ApiResponse<PaginatedResponse<OrderWithDetails>>\n      >(`/users/me/orders?${queryParams}`)\n      return response.data.data\n    },\n    ...options,\n  })\n}\n\n/**\n * Get a single order by ID\n *\n * @endpoint GET /orders/{orderId}\n */\nexport function useOrder(\n  orderId: string,\n  options?: Omit<UseQueryOptions<OrderWithDetails>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<OrderWithDetails> {\n  return useQuery({\n    queryKey: orderKeys.detail(orderId),\n    queryFn: async (): Promise<OrderWithDetails> => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<OrderWithDetails>>(\n        `/orders/${orderId}`,\n      )\n      return response.data.data\n    },\n    enabled: !!orderId,\n    ...options,\n  })\n}\n\n/**\n * Get orders for a spot (seller view)\n *\n * @endpoint GET /seller/spots/{spotId}/orders\n */\nexport function useSpotOrders(\n  spotId: string,\n  params?: OrderFilters,\n  options?: Omit<\n    UseQueryOptions<PaginatedResponse<OrderWithDetails>>,\n    'queryKey' | 'queryFn'\n  >,\n): UseQueryResult<PaginatedResponse<OrderWithDetails>> {\n  return useQuery({\n    queryKey: orderKeys.spotOrders(spotId),\n    queryFn: async (): Promise<PaginatedResponse<OrderWithDetails>> => {\n      const client = getApiClient()\n      const queryParams = new URLSearchParams()\n      if (params?.status) queryParams.set('status', params.status)\n      if (params?.limit) queryParams.set('limit', String(params.limit))\n      if (params?.page) queryParams.set('page', String(params.page))\n      const response = await client.get<\n        ApiResponse<PaginatedResponse<OrderWithDetails>>\n      >(`/seller/spots/${spotId}/orders?${queryParams}`)\n      return response.data.data\n    },\n    enabled: !!spotId,\n    ...options,\n  })\n}\n"]}
|
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
*
|
|
4
4
|
* TanStack Query hooks for post/board operations.
|
|
5
5
|
*/
|
|
6
|
-
import { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
|
|
7
|
-
import type
|
|
6
|
+
import { type UseQueryOptions, type UseQueryResult } from '@tanstack/react-query';
|
|
7
|
+
import { type Post, type PostResponse, type PostStatusDto, type PostUpvotesResponse } from '../types';
|
|
8
8
|
export declare const postKeys: {
|
|
9
9
|
all: readonly ["posts"];
|
|
10
10
|
lists: () => readonly ["posts", "list"];
|
|
@@ -14,11 +14,18 @@ export declare const postKeys: {
|
|
|
14
14
|
detail: (id: string) => readonly ["posts", "detail", string];
|
|
15
15
|
responses: (postId: string) => readonly ["posts", "detail", string, "responses"];
|
|
16
16
|
status: (postId: string) => readonly ["posts", "detail", string, "status"];
|
|
17
|
+
upvotes: (postId: string, filters?: {
|
|
18
|
+
limit?: number;
|
|
19
|
+
offset?: number;
|
|
20
|
+
}) => readonly ["posts", "detail", string, "upvotes", {
|
|
21
|
+
limit?: number;
|
|
22
|
+
offset?: number;
|
|
23
|
+
} | undefined];
|
|
17
24
|
};
|
|
18
25
|
/**
|
|
19
26
|
* Get posts for a spot
|
|
20
27
|
*
|
|
21
|
-
* @endpoint GET /
|
|
28
|
+
* @endpoint GET /spots/{spotId}/posts
|
|
22
29
|
*/
|
|
23
30
|
export declare function useSpotPosts(spotId: string, params?: {
|
|
24
31
|
postType?: string;
|
|
@@ -29,19 +36,19 @@ export declare function useSpotPosts(spotId: string, params?: {
|
|
|
29
36
|
/**
|
|
30
37
|
* Get a single post by ID
|
|
31
38
|
*
|
|
32
|
-
* @endpoint GET /
|
|
39
|
+
* @endpoint GET /posts/{postId}
|
|
33
40
|
*/
|
|
34
41
|
export declare function usePost(postId: string, options?: Omit<UseQueryOptions<Post>, 'queryKey' | 'queryFn'>): UseQueryResult<Post>;
|
|
35
42
|
/**
|
|
36
43
|
* Get responses for a post
|
|
37
44
|
*
|
|
38
|
-
* @endpoint GET /
|
|
45
|
+
* @endpoint GET /posts/{postId}/responses
|
|
39
46
|
*/
|
|
40
47
|
export declare function usePostResponses(postId: string, options?: Omit<UseQueryOptions<PostResponse[]>, 'queryKey' | 'queryFn'>): UseQueryResult<PostResponse[]>;
|
|
41
48
|
/**
|
|
42
49
|
* Get all posts (with filters)
|
|
43
50
|
*
|
|
44
|
-
* @endpoint GET /
|
|
51
|
+
* @endpoint GET /posts
|
|
45
52
|
*/
|
|
46
53
|
export declare function usePosts(params?: {
|
|
47
54
|
postType?: string;
|
|
@@ -50,6 +57,36 @@ export declare function usePosts(params?: {
|
|
|
50
57
|
/**
|
|
51
58
|
* Get user's status for a post (read/hidden/pinned)
|
|
52
59
|
*
|
|
53
|
-
* @endpoint GET /
|
|
60
|
+
* @endpoint GET /posts/{postId}/status
|
|
54
61
|
*/
|
|
55
62
|
export declare function usePostStatus(postId: string, options?: Omit<UseQueryOptions<PostStatusDto>, 'queryKey' | 'queryFn'>): UseQueryResult<PostStatusDto>;
|
|
63
|
+
/**
|
|
64
|
+
* Get upvotes for a post (list of users who upvoted)
|
|
65
|
+
*
|
|
66
|
+
* @endpoint GET /posts/{postId}/upvotes
|
|
67
|
+
*/
|
|
68
|
+
export declare function usePostUpvotes(postId: string, params?: {
|
|
69
|
+
limit?: number;
|
|
70
|
+
offset?: number;
|
|
71
|
+
}, options?: Omit<UseQueryOptions<PostUpvotesResponse>, 'queryKey' | 'queryFn'>): UseQueryResult<PostUpvotesResponse>;
|
|
72
|
+
/**
|
|
73
|
+
* Get nearby posts feed
|
|
74
|
+
*
|
|
75
|
+
* @endpoint GET /posts/feed
|
|
76
|
+
*/
|
|
77
|
+
export declare function usePostsFeed(params: {
|
|
78
|
+
lat: number;
|
|
79
|
+
lng: number;
|
|
80
|
+
radius?: number;
|
|
81
|
+
postType?: string;
|
|
82
|
+
cursor?: string;
|
|
83
|
+
limit?: number;
|
|
84
|
+
}, options?: Omit<UseQueryOptions<{
|
|
85
|
+
posts: Post[];
|
|
86
|
+
hasMore: boolean;
|
|
87
|
+
nextCursor?: string;
|
|
88
|
+
}>, 'queryKey' | 'queryFn'>): UseQueryResult<{
|
|
89
|
+
posts: Post[];
|
|
90
|
+
hasMore: boolean;
|
|
91
|
+
nextCursor?: string;
|
|
92
|
+
}>;
|
|
@@ -11,9 +11,54 @@ exports.usePost = usePost;
|
|
|
11
11
|
exports.usePostResponses = usePostResponses;
|
|
12
12
|
exports.usePosts = usePosts;
|
|
13
13
|
exports.usePostStatus = usePostStatus;
|
|
14
|
+
exports.usePostUpvotes = usePostUpvotes;
|
|
15
|
+
exports.usePostsFeed = usePostsFeed;
|
|
14
16
|
const react_query_1 = require("@tanstack/react-query");
|
|
15
17
|
const client_1 = require("../client");
|
|
16
18
|
// ============================================================================
|
|
19
|
+
// HELPER FUNCTIONS
|
|
20
|
+
// ============================================================================
|
|
21
|
+
/**
|
|
22
|
+
* Extract array data from API response
|
|
23
|
+
* API returns { success, data: { data: [...], meta: {...} } } or { success, data: [...] }
|
|
24
|
+
*/
|
|
25
|
+
function extractArrayData(data) {
|
|
26
|
+
// If already an array, return it
|
|
27
|
+
if (Array.isArray(data)) {
|
|
28
|
+
return data;
|
|
29
|
+
}
|
|
30
|
+
// If it's an object with nested data property, extract it
|
|
31
|
+
if (data && typeof data === 'object' && 'data' in data) {
|
|
32
|
+
const nested = data.data;
|
|
33
|
+
if (Array.isArray(nested)) {
|
|
34
|
+
return nested;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
return [];
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Extract single object data from API response
|
|
41
|
+
* API returns { success, data: { data: {...} } } or { success, data: {...} }
|
|
42
|
+
*/
|
|
43
|
+
function extractObjectData(data) {
|
|
44
|
+
// If it's an object with nested data property (not an array), extract it
|
|
45
|
+
if (data &&
|
|
46
|
+
typeof data === 'object' &&
|
|
47
|
+
'data' in data &&
|
|
48
|
+
!Array.isArray(data)) {
|
|
49
|
+
const nested = data.data;
|
|
50
|
+
// Check if nested also has a data property (double-wrapped)
|
|
51
|
+
if (nested &&
|
|
52
|
+
typeof nested === 'object' &&
|
|
53
|
+
'data' in nested &&
|
|
54
|
+
!Array.isArray(nested)) {
|
|
55
|
+
return nested.data;
|
|
56
|
+
}
|
|
57
|
+
return nested;
|
|
58
|
+
}
|
|
59
|
+
return data;
|
|
60
|
+
}
|
|
61
|
+
// ============================================================================
|
|
17
62
|
// QUERY KEYS
|
|
18
63
|
// ============================================================================
|
|
19
64
|
exports.postKeys = {
|
|
@@ -25,6 +70,7 @@ exports.postKeys = {
|
|
|
25
70
|
detail: (id) => [...exports.postKeys.details(), id],
|
|
26
71
|
responses: (postId) => [...exports.postKeys.detail(postId), 'responses'],
|
|
27
72
|
status: (postId) => [...exports.postKeys.detail(postId), 'status'],
|
|
73
|
+
upvotes: (postId, filters) => [...exports.postKeys.detail(postId), 'upvotes', filters],
|
|
28
74
|
};
|
|
29
75
|
// ============================================================================
|
|
30
76
|
// QUERY HOOKS
|
|
@@ -32,7 +78,7 @@ exports.postKeys = {
|
|
|
32
78
|
/**
|
|
33
79
|
* Get posts for a spot
|
|
34
80
|
*
|
|
35
|
-
* @endpoint GET /
|
|
81
|
+
* @endpoint GET /spots/{spotId}/posts
|
|
36
82
|
*/
|
|
37
83
|
function useSpotPosts(spotId, params, options) {
|
|
38
84
|
return (0, react_query_1.useQuery)({
|
|
@@ -48,8 +94,8 @@ function useSpotPosts(spotId, params, options) {
|
|
|
48
94
|
queryParams.set('page', String(params.page));
|
|
49
95
|
if (params?.limit)
|
|
50
96
|
queryParams.set('limit', String(params.limit));
|
|
51
|
-
const response = await client.get(`/
|
|
52
|
-
return response.data.data;
|
|
97
|
+
const response = await client.get(`/spots/${spotId}/posts?${queryParams}`);
|
|
98
|
+
return extractArrayData(response.data.data);
|
|
53
99
|
},
|
|
54
100
|
enabled: !!spotId,
|
|
55
101
|
...options,
|
|
@@ -58,15 +104,15 @@ function useSpotPosts(spotId, params, options) {
|
|
|
58
104
|
/**
|
|
59
105
|
* Get a single post by ID
|
|
60
106
|
*
|
|
61
|
-
* @endpoint GET /
|
|
107
|
+
* @endpoint GET /posts/{postId}
|
|
62
108
|
*/
|
|
63
109
|
function usePost(postId, options) {
|
|
64
110
|
return (0, react_query_1.useQuery)({
|
|
65
111
|
queryKey: exports.postKeys.detail(postId),
|
|
66
112
|
queryFn: async () => {
|
|
67
113
|
const client = (0, client_1.getApiClient)();
|
|
68
|
-
const response = await client.get(`/
|
|
69
|
-
return response.data.data;
|
|
114
|
+
const response = await client.get(`/posts/${postId}`);
|
|
115
|
+
return extractObjectData(response.data.data);
|
|
70
116
|
},
|
|
71
117
|
enabled: !!postId,
|
|
72
118
|
...options,
|
|
@@ -75,15 +121,15 @@ function usePost(postId, options) {
|
|
|
75
121
|
/**
|
|
76
122
|
* Get responses for a post
|
|
77
123
|
*
|
|
78
|
-
* @endpoint GET /
|
|
124
|
+
* @endpoint GET /posts/{postId}/responses
|
|
79
125
|
*/
|
|
80
126
|
function usePostResponses(postId, options) {
|
|
81
127
|
return (0, react_query_1.useQuery)({
|
|
82
128
|
queryKey: exports.postKeys.responses(postId),
|
|
83
129
|
queryFn: async () => {
|
|
84
130
|
const client = (0, client_1.getApiClient)();
|
|
85
|
-
const response = await client.get(`/
|
|
86
|
-
return response.data.data;
|
|
131
|
+
const response = await client.get(`/posts/${postId}/responses`);
|
|
132
|
+
return extractArrayData(response.data.data);
|
|
87
133
|
},
|
|
88
134
|
enabled: !!postId,
|
|
89
135
|
...options,
|
|
@@ -92,7 +138,7 @@ function usePostResponses(postId, options) {
|
|
|
92
138
|
/**
|
|
93
139
|
* Get all posts (with filters)
|
|
94
140
|
*
|
|
95
|
-
* @endpoint GET /
|
|
141
|
+
* @endpoint GET /posts
|
|
96
142
|
*/
|
|
97
143
|
function usePosts(params, options) {
|
|
98
144
|
return (0, react_query_1.useQuery)({
|
|
@@ -104,8 +150,8 @@ function usePosts(params, options) {
|
|
|
104
150
|
queryParams.set('postType', params.postType);
|
|
105
151
|
if (params?.limit)
|
|
106
152
|
queryParams.set('limit', String(params.limit));
|
|
107
|
-
const response = await client.get(`/
|
|
108
|
-
return response.data.data;
|
|
153
|
+
const response = await client.get(`/posts?${queryParams}`);
|
|
154
|
+
return extractArrayData(response.data.data);
|
|
109
155
|
},
|
|
110
156
|
...options,
|
|
111
157
|
});
|
|
@@ -113,18 +159,75 @@ function usePosts(params, options) {
|
|
|
113
159
|
/**
|
|
114
160
|
* Get user's status for a post (read/hidden/pinned)
|
|
115
161
|
*
|
|
116
|
-
* @endpoint GET /
|
|
162
|
+
* @endpoint GET /posts/{postId}/status
|
|
117
163
|
*/
|
|
118
164
|
function usePostStatus(postId, options) {
|
|
119
165
|
return (0, react_query_1.useQuery)({
|
|
120
166
|
queryKey: exports.postKeys.status(postId),
|
|
121
167
|
queryFn: async () => {
|
|
122
168
|
const client = (0, client_1.getApiClient)();
|
|
123
|
-
const response = await client.get(`/
|
|
169
|
+
const response = await client.get(`/posts/${postId}/status`);
|
|
170
|
+
return extractObjectData(response.data.data);
|
|
171
|
+
},
|
|
172
|
+
enabled: !!postId,
|
|
173
|
+
...options,
|
|
174
|
+
});
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Get upvotes for a post (list of users who upvoted)
|
|
178
|
+
*
|
|
179
|
+
* @endpoint GET /posts/{postId}/upvotes
|
|
180
|
+
*/
|
|
181
|
+
function usePostUpvotes(postId, params, options) {
|
|
182
|
+
return (0, react_query_1.useQuery)({
|
|
183
|
+
queryKey: exports.postKeys.upvotes(postId, params),
|
|
184
|
+
queryFn: async () => {
|
|
185
|
+
const client = (0, client_1.getApiClient)();
|
|
186
|
+
const queryParams = new URLSearchParams();
|
|
187
|
+
if (params?.limit)
|
|
188
|
+
queryParams.set('limit', String(params.limit));
|
|
189
|
+
if (params?.offset)
|
|
190
|
+
queryParams.set('offset', String(params.offset));
|
|
191
|
+
const queryString = queryParams.toString();
|
|
192
|
+
const response = await client.get(`/posts/${postId}/upvotes${queryString ? `?${queryString}` : ''}`);
|
|
193
|
+
// Response structure: { success, data: { data: [...], meta: {...} } }
|
|
124
194
|
return response.data.data;
|
|
125
195
|
},
|
|
126
196
|
enabled: !!postId,
|
|
127
197
|
...options,
|
|
128
198
|
});
|
|
129
199
|
}
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"posts.js","sourceRoot":"","sources":["../../../src/api/queries/posts.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Posts Query Hooks\n *\n * TanStack Query hooks for post/board operations.\n */\n\nimport { useQuery, UseQueryOptions, UseQueryResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { Post, PostResponse, ApiResponse, PostStatusDto } from '../types';\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const postKeys = {\n  all: ['posts'] as const,\n  lists: () => [...postKeys.all, 'list'] as const,\n  list: (filters?: Record<string, unknown>) => [...postKeys.lists(), filters] as const,\n  bySpot: (spotId: string, filters?: Record<string, unknown>) => [...postKeys.all, 'spot', spotId, filters] as const,\n  details: () => [...postKeys.all, 'detail'] as const,\n  detail: (id: string) => [...postKeys.details(), id] as const,\n  responses: (postId: string) => [...postKeys.detail(postId), 'responses'] as const,\n  status: (postId: string) => [...postKeys.detail(postId), 'status'] as const,\n};\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get posts for a spot\n *\n * @endpoint GET /api/v1/spots/{spotId}/posts\n */\nexport function useSpotPosts(\n  spotId: string,\n  params?: { postType?: string; status?: string; page?: number; limit?: number },\n  options?: Omit<UseQueryOptions<Post[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Post[]> {\n  return useQuery({\n    queryKey: postKeys.bySpot(spotId, params),\n    queryFn: async (): Promise<Post[]> => {\n      const client = getApiClient();\n      const queryParams = new URLSearchParams();\n      if (params?.postType) queryParams.set('postType', params.postType);\n      if (params?.status) queryParams.set('status', params.status);\n      if (params?.page) queryParams.set('page', String(params.page));\n      if (params?.limit) queryParams.set('limit', String(params.limit));\n      const response = await client.get<ApiResponse<Post[]>>(`/api/v1/spots/${spotId}/posts?${queryParams}`);\n      return response.data.data;\n    },\n    enabled: !!spotId,\n    ...options,\n  });\n}\n\n/**\n * Get a single post by ID\n *\n * @endpoint GET /api/v1/posts/{postId}\n */\nexport function usePost(\n  postId: string,\n  options?: Omit<UseQueryOptions<Post>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Post> {\n  return useQuery({\n    queryKey: postKeys.detail(postId),\n    queryFn: async (): Promise<Post> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<Post>>(`/api/v1/posts/${postId}`);\n      return response.data.data;\n    },\n    enabled: !!postId,\n    ...options,\n  });\n}\n\n/**\n * Get responses for a post\n *\n * @endpoint GET /api/v1/posts/{postId}/responses\n */\nexport function usePostResponses(\n  postId: string,\n  options?: Omit<UseQueryOptions<PostResponse[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<PostResponse[]> {\n  return useQuery({\n    queryKey: postKeys.responses(postId),\n    queryFn: async (): Promise<PostResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<PostResponse[]>>(`/api/v1/posts/${postId}/responses`);\n      return response.data.data;\n    },\n    enabled: !!postId,\n    ...options,\n  });\n}\n\n/**\n * Get all posts (with filters)\n *\n * @endpoint GET /api/v1/posts\n */\nexport function usePosts(\n  params?: { postType?: string; limit?: number },\n  options?: Omit<UseQueryOptions<Post[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Post[]> {\n  return useQuery({\n    queryKey: postKeys.list(params),\n    queryFn: async (): Promise<Post[]> => {\n      const client = getApiClient();\n      const queryParams = new URLSearchParams();\n      if (params?.postType) queryParams.set('postType', params.postType);\n      if (params?.limit) queryParams.set('limit', String(params.limit));\n      const response = await client.get<ApiResponse<Post[]>>(`/api/v1/posts?${queryParams}`);\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n\n\n/**\n * Get user's status for a post (read/hidden/pinned)\n *\n * @endpoint GET /api/v1/posts/{postId}/status\n */\nexport function usePostStatus(\n  postId: string,\n  options?: Omit<UseQueryOptions<PostStatusDto>, 'queryKey' | 'queryFn'>\n): UseQueryResult<PostStatusDto> {\n  return useQuery({\n    queryKey: postKeys.status(postId),\n    queryFn: async (): Promise<PostStatusDto> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<PostStatusDto>>(`/api/v1/posts/${postId}/status`);\n      return response.data.data;\n    },\n    enabled: !!postId,\n    ...options,\n  });\n}\n"]}
|
|
200
|
+
/**
|
|
201
|
+
* Get nearby posts feed
|
|
202
|
+
*
|
|
203
|
+
* @endpoint GET /posts/feed
|
|
204
|
+
*/
|
|
205
|
+
function usePostsFeed(params, options) {
|
|
206
|
+
return (0, react_query_1.useQuery)({
|
|
207
|
+
queryKey: [...exports.postKeys.lists(), 'feed', params],
|
|
208
|
+
queryFn: async () => {
|
|
209
|
+
const client = (0, client_1.getApiClient)();
|
|
210
|
+
const queryParams = new URLSearchParams();
|
|
211
|
+
queryParams.set('lat', String(params.lat));
|
|
212
|
+
queryParams.set('lng', String(params.lng));
|
|
213
|
+
if (params.radius)
|
|
214
|
+
queryParams.set('radius', String(params.radius));
|
|
215
|
+
if (params.postType)
|
|
216
|
+
queryParams.set('postType', params.postType);
|
|
217
|
+
if (params.cursor)
|
|
218
|
+
queryParams.set('cursor', params.cursor);
|
|
219
|
+
if (params.limit)
|
|
220
|
+
queryParams.set('limit', String(params.limit));
|
|
221
|
+
const response = await client.get(`/posts/feed?${queryParams}`);
|
|
222
|
+
const data = response.data.data;
|
|
223
|
+
return {
|
|
224
|
+
posts: data.posts ?? extractArrayData(data),
|
|
225
|
+
hasMore: data.hasMore ?? false,
|
|
226
|
+
nextCursor: data.nextCursor,
|
|
227
|
+
};
|
|
228
|
+
},
|
|
229
|
+
enabled: params.lat !== 0 && params.lng !== 0,
|
|
230
|
+
...options,
|
|
231
|
+
});
|
|
232
|
+
}
|
|
233
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"posts.js","sourceRoot":"","sources":["../../../src/api/queries/posts.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Posts Query Hooks\n *\n * TanStack Query hooks for post/board operations.\n */\n\nimport {\n  useQuery,\n  type UseQueryOptions,\n  type UseQueryResult,\n} from '@tanstack/react-query'\n\nimport {getApiClient} from '../client'\nimport {\n  type ApiResponse,\n  type Post,\n  type PostResponse,\n  type PostStatusDto,\n  type PostUpvotesResponse,\n} from '../types'\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Extract array data from API response\n * API returns { success, data: { data: [...], meta: {...} } } or { success, data: [...] }\n */\nfunction extractArrayData<T>(data: unknown): T[] {\n  // If already an array, return it\n  if (Array.isArray(data)) {\n    return data\n  }\n  // If it's an object with nested data property, extract it\n  if (data && typeof data === 'object' && 'data' in data) {\n    const nested = (data as {data: unknown}).data\n    if (Array.isArray(nested)) {\n      return nested\n    }\n  }\n  return []\n}\n\n/**\n * Extract single object data from API response\n * API returns { success, data: { data: {...} } } or { success, data: {...} }\n */\nfunction extractObjectData<T>(data: unknown): T {\n  // If it's an object with nested data property (not an array), extract it\n  if (\n    data &&\n    typeof data === 'object' &&\n    'data' in data &&\n    !Array.isArray(data)\n  ) {\n    const nested = (data as {data: unknown}).data\n    // Check if nested also has a data property (double-wrapped)\n    if (\n      nested &&\n      typeof nested === 'object' &&\n      'data' in nested &&\n      !Array.isArray(nested)\n    ) {\n      return (nested as {data: T}).data\n    }\n    return nested as T\n  }\n  return data as T\n}\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const postKeys = {\n  all: ['posts'] as const,\n  lists: () => [...postKeys.all, 'list'] as const,\n  list: (filters?: Record<string, unknown>) =>\n    [...postKeys.lists(), filters] as const,\n  bySpot: (spotId: string, filters?: Record<string, unknown>) =>\n    [...postKeys.all, 'spot', spotId, filters] as const,\n  details: () => [...postKeys.all, 'detail'] as const,\n  detail: (id: string) => [...postKeys.details(), id] as const,\n  responses: (postId: string) =>\n    [...postKeys.detail(postId), 'responses'] as const,\n  status: (postId: string) => [...postKeys.detail(postId), 'status'] as const,\n  upvotes: (postId: string, filters?: {limit?: number; offset?: number}) =>\n    [...postKeys.detail(postId), 'upvotes', filters] as const,\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get posts for a spot\n *\n * @endpoint GET /spots/{spotId}/posts\n */\nexport function useSpotPosts(\n  spotId: string,\n  params?: {postType?: string; status?: string; page?: number; limit?: number},\n  options?: Omit<UseQueryOptions<Post[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Post[]> {\n  return useQuery({\n    queryKey: postKeys.bySpot(spotId, params),\n    queryFn: async (): Promise<Post[]> => {\n      const client = getApiClient()\n      const queryParams = new URLSearchParams()\n      if (params?.postType) queryParams.set('postType', params.postType)\n      if (params?.status) queryParams.set('status', params.status)\n      if (params?.page) queryParams.set('page', String(params.page))\n      if (params?.limit) queryParams.set('limit', String(params.limit))\n      const response = await client.get<ApiResponse<unknown>>(\n        `/spots/${spotId}/posts?${queryParams}`,\n      )\n      return extractArrayData<Post>(response.data.data)\n    },\n    enabled: !!spotId,\n    ...options,\n  })\n}\n\n/**\n * Get a single post by ID\n *\n * @endpoint GET /posts/{postId}\n */\nexport function usePost(\n  postId: string,\n  options?: Omit<UseQueryOptions<Post>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Post> {\n  return useQuery({\n    queryKey: postKeys.detail(postId),\n    queryFn: async (): Promise<Post> => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<unknown>>(\n        `/posts/${postId}`,\n      )\n      return extractObjectData<Post>(response.data.data)\n    },\n    enabled: !!postId,\n    ...options,\n  })\n}\n\n/**\n * Get responses for a post\n *\n * @endpoint GET /posts/{postId}/responses\n */\nexport function usePostResponses(\n  postId: string,\n  options?: Omit<UseQueryOptions<PostResponse[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<PostResponse[]> {\n  return useQuery({\n    queryKey: postKeys.responses(postId),\n    queryFn: async (): Promise<PostResponse[]> => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<unknown>>(\n        `/posts/${postId}/responses`,\n      )\n      return extractArrayData<PostResponse>(response.data.data)\n    },\n    enabled: !!postId,\n    ...options,\n  })\n}\n\n/**\n * Get all posts (with filters)\n *\n * @endpoint GET /posts\n */\nexport function usePosts(\n  params?: {postType?: string; limit?: number},\n  options?: Omit<UseQueryOptions<Post[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Post[]> {\n  return useQuery({\n    queryKey: postKeys.list(params),\n    queryFn: async (): Promise<Post[]> => {\n      const client = getApiClient()\n      const queryParams = new URLSearchParams()\n      if (params?.postType) queryParams.set('postType', params.postType)\n      if (params?.limit) queryParams.set('limit', String(params.limit))\n      const response = await client.get<ApiResponse<unknown>>(\n        `/posts?${queryParams}`,\n      )\n      return extractArrayData<Post>(response.data.data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Get user's status for a post (read/hidden/pinned)\n *\n * @endpoint GET /posts/{postId}/status\n */\nexport function usePostStatus(\n  postId: string,\n  options?: Omit<UseQueryOptions<PostStatusDto>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<PostStatusDto> {\n  return useQuery({\n    queryKey: postKeys.status(postId),\n    queryFn: async (): Promise<PostStatusDto> => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<unknown>>(\n        `/posts/${postId}/status`,\n      )\n      return extractObjectData<PostStatusDto>(response.data.data)\n    },\n    enabled: !!postId,\n    ...options,\n  })\n}\n\n/**\n * Get upvotes for a post (list of users who upvoted)\n *\n * @endpoint GET /posts/{postId}/upvotes\n */\nexport function usePostUpvotes(\n  postId: string,\n  params?: {limit?: number; offset?: number},\n  options?: Omit<UseQueryOptions<PostUpvotesResponse>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<PostUpvotesResponse> {\n  return useQuery({\n    queryKey: postKeys.upvotes(postId, params),\n    queryFn: async (): Promise<PostUpvotesResponse> => {\n      const client = getApiClient()\n      const queryParams = new URLSearchParams()\n      if (params?.limit) queryParams.set('limit', String(params.limit))\n      if (params?.offset) queryParams.set('offset', String(params.offset))\n      const queryString = queryParams.toString()\n      const response = await client.get<ApiResponse<PostUpvotesResponse>>(\n        `/posts/${postId}/upvotes${queryString ? `?${queryString}` : ''}`,\n      )\n      // Response structure: { success, data: { data: [...], meta: {...} } }\n      return response.data.data\n    },\n    enabled: !!postId,\n    ...options,\n  })\n}\n\n/**\n * Get nearby posts feed\n *\n * @endpoint GET /posts/feed\n */\nexport function usePostsFeed(\n  params: {\n    lat: number\n    lng: number\n    radius?: number\n    postType?: string\n    cursor?: string\n    limit?: number\n  },\n  options?: Omit<\n    UseQueryOptions<{posts: Post[]; hasMore: boolean; nextCursor?: string}>,\n    'queryKey' | 'queryFn'\n  >,\n): UseQueryResult<{posts: Post[]; hasMore: boolean; nextCursor?: string}> {\n  return useQuery({\n    queryKey: [...postKeys.lists(), 'feed', params] as const,\n    queryFn: async (): Promise<{\n      posts: Post[]\n      hasMore: boolean\n      nextCursor?: string\n    }> => {\n      const client = getApiClient()\n      const queryParams = new URLSearchParams()\n      queryParams.set('lat', String(params.lat))\n      queryParams.set('lng', String(params.lng))\n      if (params.radius) queryParams.set('radius', String(params.radius))\n      if (params.postType) queryParams.set('postType', params.postType)\n      if (params.cursor) queryParams.set('cursor', params.cursor)\n      if (params.limit) queryParams.set('limit', String(params.limit))\n\n      const response = await client.get<\n        ApiResponse<{posts: Post[]; hasMore: boolean; nextCursor?: string}>\n      >(`/posts/feed?${queryParams}`)\n\n      const data = response.data.data\n      return {\n        posts: data.posts ?? extractArrayData<Post>(data),\n        hasMore: data.hasMore ?? false,\n        nextCursor: data.nextCursor,\n      }\n    },\n    enabled: params.lat !== 0 && params.lng !== 0,\n    ...options,\n  })\n}\n"]}
|
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
*
|
|
4
4
|
* TanStack Query hooks for product-related operations.
|
|
5
5
|
*/
|
|
6
|
-
import { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
|
|
7
|
-
import type { Product, PaginatedResponse, ProductType, ProductStatus } from '../types';
|
|
6
|
+
import { type UseQueryOptions, type UseQueryResult } from '@tanstack/react-query';
|
|
7
|
+
import type { Product, PaginatedResponse, ProductType, ProductStatus, Spot } from '../types';
|
|
8
8
|
export declare const productKeys: {
|
|
9
9
|
all: readonly ["products"];
|
|
10
10
|
lists: () => readonly ["products", "list"];
|
|
@@ -22,16 +22,12 @@ export interface ProductFilters {
|
|
|
22
22
|
page?: number;
|
|
23
23
|
}
|
|
24
24
|
export interface ProductWithSpot extends Product {
|
|
25
|
-
spot:
|
|
26
|
-
id: string;
|
|
27
|
-
name: string;
|
|
28
|
-
slug: string;
|
|
29
|
-
};
|
|
25
|
+
spot: Pick<Spot, 'id' | 'name' | 'slug'>;
|
|
30
26
|
}
|
|
31
27
|
/**
|
|
32
28
|
* Get products for a spot (public browse)
|
|
33
29
|
*
|
|
34
|
-
* @endpoint GET /
|
|
30
|
+
* @endpoint GET /spots/{spotId}/products
|
|
35
31
|
*/
|
|
36
32
|
export declare function useSpotProducts(spotId: string, params?: {
|
|
37
33
|
type?: ProductType;
|
|
@@ -41,12 +37,12 @@ export declare function useSpotProducts(spotId: string, params?: {
|
|
|
41
37
|
/**
|
|
42
38
|
* Get a product by ID
|
|
43
39
|
*
|
|
44
|
-
* @endpoint GET /
|
|
40
|
+
* @endpoint GET /products/{productId}
|
|
45
41
|
*/
|
|
46
42
|
export declare function useProduct(productId: string, options?: Omit<UseQueryOptions<ProductWithSpot>, 'queryKey' | 'queryFn'>): UseQueryResult<ProductWithSpot>;
|
|
47
43
|
/**
|
|
48
44
|
* Get a product by slug (within a spot)
|
|
49
45
|
*
|
|
50
|
-
* @endpoint GET /
|
|
46
|
+
* @endpoint GET /spots/{spotId}/products/slug/{slug}
|
|
51
47
|
*/
|
|
52
48
|
export declare function useProductBySlug(spotId: string, slug: string, options?: Omit<UseQueryOptions<ProductWithSpot>, 'queryKey' | 'queryFn'>): UseQueryResult<ProductWithSpot>;
|