@spotsdev/sdk 1.4.0 → 1.5.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +2166 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +1656 -0
- package/dist/index.d.ts +1655 -36
- package/dist/index.js +2021 -64
- package/dist/index.js.map +1 -0
- package/package.json +22 -6
- package/src/api/entities.ts +171 -170
- package/src/api/mutations/products.ts +18 -2
- package/src/api/queries/index.ts +4 -0
- package/src/api/queries/payments.ts +67 -0
- package/dist/api/client.d.ts +0 -12
- package/dist/api/client.js +0 -72
- package/dist/api/entities.d.ts +0 -305
- package/dist/api/entities.js +0 -13
- package/dist/api/mutations/clubs.d.ts +0 -47
- package/dist/api/mutations/clubs.js +0 -97
- package/dist/api/mutations/conversations.d.ts +0 -45
- package/dist/api/mutations/conversations.js +0 -114
- package/dist/api/mutations/index.d.ts +0 -14
- package/dist/api/mutations/index.js +0 -40
- package/dist/api/mutations/notifications.d.ts +0 -38
- package/dist/api/mutations/notifications.js +0 -64
- package/dist/api/mutations/orders.d.ts +0 -73
- package/dist/api/mutations/orders.js +0 -114
- package/dist/api/mutations/posts.d.ts +0 -123
- package/dist/api/mutations/posts.js +0 -242
- package/dist/api/mutations/products.d.ts +0 -81
- package/dist/api/mutations/products.js +0 -98
- package/dist/api/mutations/redemptions.d.ts +0 -33
- package/dist/api/mutations/redemptions.js +0 -63
- package/dist/api/mutations/spots.d.ts +0 -93
- package/dist/api/mutations/spots.js +0 -167
- package/dist/api/mutations/users.d.ts +0 -73
- package/dist/api/mutations/users.js +0 -175
- package/dist/api/queries/auth.d.ts +0 -37
- package/dist/api/queries/auth.js +0 -61
- package/dist/api/queries/clubs.d.ts +0 -52
- package/dist/api/queries/clubs.js +0 -116
- package/dist/api/queries/conversations.d.ts +0 -52
- package/dist/api/queries/conversations.js +0 -83
- package/dist/api/queries/index.d.ts +0 -28
- package/dist/api/queries/index.js +0 -69
- package/dist/api/queries/misc.d.ts +0 -30
- package/dist/api/queries/misc.js +0 -91
- package/dist/api/queries/notifications.d.ts +0 -34
- package/dist/api/queries/notifications.js +0 -62
- package/dist/api/queries/orders.d.ts +0 -45
- package/dist/api/queries/orders.js +0 -93
- package/dist/api/queries/posts.d.ts +0 -92
- package/dist/api/queries/posts.js +0 -233
- package/dist/api/queries/products.d.ts +0 -48
- package/dist/api/queries/products.js +0 -87
- package/dist/api/queries/spots.d.ts +0 -93
- package/dist/api/queries/spots.js +0 -250
- package/dist/api/queries/templates.d.ts +0 -39
- package/dist/api/queries/templates.js +0 -81
- package/dist/api/queries/users.d.ts +0 -104
- package/dist/api/queries/users.js +0 -235
- package/dist/api/queries/wallet.d.ts +0 -109
- package/dist/api/queries/wallet.js +0 -136
- package/dist/api/services/index.d.ts +0 -2
- package/dist/api/services/index.js +0 -8
- package/dist/api/services/marketplace.d.ts +0 -129
- package/dist/api/services/marketplace.js +0 -168
- package/dist/api/types.d.ts +0 -57
- package/dist/api/types.js +0 -33
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* Notifications Query Hooks
|
|
4
|
-
*
|
|
5
|
-
* TanStack Query hooks for notification operations.
|
|
6
|
-
*/
|
|
7
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
-
exports.notificationKeys = void 0;
|
|
9
|
-
exports.useNotifications = useNotifications;
|
|
10
|
-
exports.useUnreadNotificationCount = useUnreadNotificationCount;
|
|
11
|
-
const react_query_1 = require("@tanstack/react-query");
|
|
12
|
-
const client_1 = require("../client");
|
|
13
|
-
// ============================================================================
|
|
14
|
-
// QUERY KEYS
|
|
15
|
-
// ============================================================================
|
|
16
|
-
exports.notificationKeys = {
|
|
17
|
-
all: ['notifications'],
|
|
18
|
-
lists: () => [...exports.notificationKeys.all, 'list'],
|
|
19
|
-
list: (params) => [...exports.notificationKeys.lists(), params],
|
|
20
|
-
unreadCount: () => [...exports.notificationKeys.all, 'unreadCount'],
|
|
21
|
-
};
|
|
22
|
-
// ============================================================================
|
|
23
|
-
// QUERY HOOKS
|
|
24
|
-
// ============================================================================
|
|
25
|
-
/**
|
|
26
|
-
* Get notifications for current user
|
|
27
|
-
*
|
|
28
|
-
* @endpoint GET /notifications
|
|
29
|
-
*/
|
|
30
|
-
function useNotifications(params, options) {
|
|
31
|
-
return (0, react_query_1.useQuery)({
|
|
32
|
-
queryKey: exports.notificationKeys.list(params),
|
|
33
|
-
queryFn: async () => {
|
|
34
|
-
const client = (0, client_1.getApiClient)();
|
|
35
|
-
const queryParams = new URLSearchParams();
|
|
36
|
-
if (params?.limit)
|
|
37
|
-
queryParams.set('limit', String(params.limit));
|
|
38
|
-
if (params?.unreadOnly)
|
|
39
|
-
queryParams.set('unreadOnly', String(params.unreadOnly));
|
|
40
|
-
const response = await client.get(`/notifications?${queryParams}`);
|
|
41
|
-
return response.data.data;
|
|
42
|
-
},
|
|
43
|
-
...options,
|
|
44
|
-
});
|
|
45
|
-
}
|
|
46
|
-
/**
|
|
47
|
-
* Get unread notification count
|
|
48
|
-
*
|
|
49
|
-
* @endpoint GET /notifications/unread-count
|
|
50
|
-
*/
|
|
51
|
-
function useUnreadNotificationCount(options) {
|
|
52
|
-
return (0, react_query_1.useQuery)({
|
|
53
|
-
queryKey: exports.notificationKeys.unreadCount(),
|
|
54
|
-
queryFn: async () => {
|
|
55
|
-
const client = (0, client_1.getApiClient)();
|
|
56
|
-
const response = await client.get('/notifications/unread-count');
|
|
57
|
-
return response.data.data.count;
|
|
58
|
-
},
|
|
59
|
-
...options,
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvcXVlcmllcy9ub3RpZmljYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7OztHQUlHOzs7QUFnQ0gsNENBbUJDO0FBT0QsZ0VBY0M7QUF0RUQsdURBSThCO0FBRTlCLHNDQUFzQztBQUd0QywrRUFBK0U7QUFDL0UsYUFBYTtBQUNiLCtFQUErRTtBQUVsRSxRQUFBLGdCQUFnQixHQUFHO0lBQzlCLEdBQUcsRUFBRSxDQUFDLGVBQWUsQ0FBVTtJQUMvQixLQUFLLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxHQUFHLHdCQUFnQixDQUFDLEdBQUcsRUFBRSxNQUFNLENBQVU7SUFDdkQsSUFBSSxFQUFFLENBQUMsTUFBK0MsRUFBRSxFQUFFLENBQ3hELENBQUMsR0FBRyx3QkFBZ0IsQ0FBQyxLQUFLLEVBQUUsRUFBRSxNQUFNLENBQVU7SUFDaEQsV0FBVyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsR0FBRyx3QkFBZ0IsQ0FBQyxHQUFHLEVBQUUsYUFBYSxDQUFVO0NBQ3JFLENBQUE7QUFFRCwrRUFBK0U7QUFDL0UsY0FBYztBQUNkLCtFQUErRTtBQUUvRTs7OztHQUlHO0FBQ0gsU0FBZ0IsZ0JBQWdCLENBQzlCLE1BQStDLEVBQy9DLE9BQXVFO0lBRXZFLE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLHdCQUFnQixDQUFDLElBQUksQ0FBQyxNQUFNLENBQUM7UUFDdkMsT0FBTyxFQUFFLEtBQUssSUFBNkIsRUFBRTtZQUMzQyxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQTtZQUM3QixNQUFNLFdBQVcsR0FBRyxJQUFJLGVBQWUsRUFBRSxDQUFBO1lBQ3pDLElBQUksTUFBTSxFQUFFLEtBQUs7Z0JBQUUsV0FBVyxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFBO1lBQ2pFLElBQUksTUFBTSxFQUFFLFVBQVU7Z0JBQ3BCLFdBQVcsQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLE1BQU0sQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQTtZQUMxRCxNQUFNLFFBQVEsR0FBRyxNQUFNLE1BQU0sQ0FBQyxHQUFHLENBQy9CLGtCQUFrQixXQUFXLEVBQUUsQ0FDaEMsQ0FBQTtZQUNELE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUE7UUFDM0IsQ0FBQztRQUNELEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQTtBQUNKLENBQUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsMEJBQTBCLENBQ3hDLE9BQStEO0lBRS9ELE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLHdCQUFnQixDQUFDLFdBQVcsRUFBRTtRQUN4QyxPQUFPLEVBQUUsS0FBSyxJQUFxQixFQUFFO1lBQ25DLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFBO1lBQzdCLE1BQU0sUUFBUSxHQUFHLE1BQU0sTUFBTSxDQUFDLEdBQUcsQ0FDL0IsNkJBQTZCLENBQzlCLENBQUE7WUFDRCxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQTtRQUNqQyxDQUFDO1FBQ0QsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFBO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogTm90aWZpY2F0aW9ucyBRdWVyeSBIb29rc1xuICpcbiAqIFRhblN0YWNrIFF1ZXJ5IGhvb2tzIGZvciBub3RpZmljYXRpb24gb3BlcmF0aW9ucy5cbiAqL1xuXG5pbXBvcnQge1xuICB1c2VRdWVyeSxcbiAgdHlwZSBVc2VRdWVyeU9wdGlvbnMsXG4gIHR5cGUgVXNlUXVlcnlSZXN1bHQsXG59IGZyb20gJ0B0YW5zdGFjay9yZWFjdC1xdWVyeSdcblxuaW1wb3J0IHtnZXRBcGlDbGllbnR9IGZyb20gJy4uL2NsaWVudCdcbmltcG9ydCB7dHlwZSBBcGlSZXNwb25zZSwgdHlwZSBOb3RpZmljYXRpb259IGZyb20gJy4uL3R5cGVzJ1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBRVUVSWSBLRVlTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBjb25zdCBub3RpZmljYXRpb25LZXlzID0ge1xuICBhbGw6IFsnbm90aWZpY2F0aW9ucyddIGFzIGNvbnN0LFxuICBsaXN0czogKCkgPT4gWy4uLm5vdGlmaWNhdGlvbktleXMuYWxsLCAnbGlzdCddIGFzIGNvbnN0LFxuICBsaXN0OiAocGFyYW1zPzoge2xpbWl0PzogbnVtYmVyOyB1bnJlYWRPbmx5PzogYm9vbGVhbn0pID0+XG4gICAgWy4uLm5vdGlmaWNhdGlvbktleXMubGlzdHMoKSwgcGFyYW1zXSBhcyBjb25zdCxcbiAgdW5yZWFkQ291bnQ6ICgpID0+IFsuLi5ub3RpZmljYXRpb25LZXlzLmFsbCwgJ3VucmVhZENvdW50J10gYXMgY29uc3QsXG59XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFFVRVJZIEhPT0tTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogR2V0IG5vdGlmaWNhdGlvbnMgZm9yIGN1cnJlbnQgdXNlclxuICpcbiAqIEBlbmRwb2ludCBHRVQgL25vdGlmaWNhdGlvbnNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZU5vdGlmaWNhdGlvbnMoXG4gIHBhcmFtcz86IHtsaW1pdD86IG51bWJlcjsgdW5yZWFkT25seT86IGJvb2xlYW59LFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8Tm90aWZpY2F0aW9uW10+LCAncXVlcnlLZXknIHwgJ3F1ZXJ5Rm4nPixcbik6IFVzZVF1ZXJ5UmVzdWx0PE5vdGlmaWNhdGlvbltdPiB7XG4gIHJldHVybiB1c2VRdWVyeSh7XG4gICAgcXVlcnlLZXk6IG5vdGlmaWNhdGlvbktleXMubGlzdChwYXJhbXMpLFxuICAgIHF1ZXJ5Rm46IGFzeW5jICgpOiBQcm9taXNlPE5vdGlmaWNhdGlvbltdPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKVxuICAgICAgY29uc3QgcXVlcnlQYXJhbXMgPSBuZXcgVVJMU2VhcmNoUGFyYW1zKClcbiAgICAgIGlmIChwYXJhbXM/LmxpbWl0KSBxdWVyeVBhcmFtcy5zZXQoJ2xpbWl0JywgU3RyaW5nKHBhcmFtcy5saW1pdCkpXG4gICAgICBpZiAocGFyYW1zPy51bnJlYWRPbmx5KVxuICAgICAgICBxdWVyeVBhcmFtcy5zZXQoJ3VucmVhZE9ubHknLCBTdHJpbmcocGFyYW1zLnVucmVhZE9ubHkpKVxuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0PEFwaVJlc3BvbnNlPE5vdGlmaWNhdGlvbltdPj4oXG4gICAgICAgIGAvbm90aWZpY2F0aW9ucz8ke3F1ZXJ5UGFyYW1zfWAsXG4gICAgICApXG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhXG4gICAgfSxcbiAgICAuLi5vcHRpb25zLFxuICB9KVxufVxuXG4vKipcbiAqIEdldCB1bnJlYWQgbm90aWZpY2F0aW9uIGNvdW50XG4gKlxuICogQGVuZHBvaW50IEdFVCAvbm90aWZpY2F0aW9ucy91bnJlYWQtY291bnRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVVucmVhZE5vdGlmaWNhdGlvbkNvdW50KFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8bnVtYmVyPiwgJ3F1ZXJ5S2V5JyB8ICdxdWVyeUZuJz4sXG4pOiBVc2VRdWVyeVJlc3VsdDxudW1iZXI+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogbm90aWZpY2F0aW9uS2V5cy51bnJlYWRDb3VudCgpLFxuICAgIHF1ZXJ5Rm46IGFzeW5jICgpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KClcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldDxBcGlSZXNwb25zZTx7Y291bnQ6IG51bWJlcn0+PihcbiAgICAgICAgJy9ub3RpZmljYXRpb25zL3VucmVhZC1jb3VudCcsXG4gICAgICApXG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhLmNvdW50XG4gICAgfSxcbiAgICAuLi5vcHRpb25zLFxuICB9KVxufVxuIl19
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Orders Query Hooks
|
|
3
|
-
*
|
|
4
|
-
* TanStack Query hooks for order-related operations.
|
|
5
|
-
*/
|
|
6
|
-
import { type UseQueryOptions, type UseQueryResult } from '@tanstack/react-query';
|
|
7
|
-
import type { Order, OrderItem, Product, Spot, OrderStatus, PaginatedResponse } from '../types';
|
|
8
|
-
export declare const orderKeys: {
|
|
9
|
-
all: readonly ["orders"];
|
|
10
|
-
lists: () => readonly ["orders", "list"];
|
|
11
|
-
list: (filters?: Record<string, unknown>) => readonly ["orders", "list", Record<string, unknown> | undefined];
|
|
12
|
-
details: () => readonly ["orders", "detail"];
|
|
13
|
-
detail: (id: string) => readonly ["orders", "detail", string];
|
|
14
|
-
myOrders: () => readonly ["orders", "my"];
|
|
15
|
-
spotOrders: (spotId: string) => readonly ["orders", "spot", string];
|
|
16
|
-
};
|
|
17
|
-
export interface OrderWithDetails extends Order {
|
|
18
|
-
items: (OrderItem & {
|
|
19
|
-
product: Pick<Product, 'id' | 'name' | 'slug' | 'type' | 'imageUrl'>;
|
|
20
|
-
})[];
|
|
21
|
-
spot: Pick<Spot, 'id' | 'name' | 'slug'>;
|
|
22
|
-
}
|
|
23
|
-
export interface OrderFilters {
|
|
24
|
-
status?: OrderStatus;
|
|
25
|
-
limit?: number;
|
|
26
|
-
page?: number;
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* Get current user's orders (purchases)
|
|
30
|
-
*
|
|
31
|
-
* @endpoint GET /users/me/orders
|
|
32
|
-
*/
|
|
33
|
-
export declare function useMyOrders(params?: OrderFilters, options?: Omit<UseQueryOptions<PaginatedResponse<OrderWithDetails>>, 'queryKey' | 'queryFn'>): UseQueryResult<PaginatedResponse<OrderWithDetails>>;
|
|
34
|
-
/**
|
|
35
|
-
* Get a single order by ID
|
|
36
|
-
*
|
|
37
|
-
* @endpoint GET /orders/{orderId}
|
|
38
|
-
*/
|
|
39
|
-
export declare function useOrder(orderId: string, options?: Omit<UseQueryOptions<OrderWithDetails>, 'queryKey' | 'queryFn'>): UseQueryResult<OrderWithDetails>;
|
|
40
|
-
/**
|
|
41
|
-
* Get orders for a spot (seller view)
|
|
42
|
-
*
|
|
43
|
-
* @endpoint GET /seller/spots/{spotId}/orders
|
|
44
|
-
*/
|
|
45
|
-
export declare function useSpotOrders(spotId: string, params?: OrderFilters, options?: Omit<UseQueryOptions<PaginatedResponse<OrderWithDetails>>, 'queryKey' | 'queryFn'>): UseQueryResult<PaginatedResponse<OrderWithDetails>>;
|
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* Orders Query Hooks
|
|
4
|
-
*
|
|
5
|
-
* TanStack Query hooks for order-related operations.
|
|
6
|
-
*/
|
|
7
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
-
exports.orderKeys = void 0;
|
|
9
|
-
exports.useMyOrders = useMyOrders;
|
|
10
|
-
exports.useOrder = useOrder;
|
|
11
|
-
exports.useSpotOrders = useSpotOrders;
|
|
12
|
-
const react_query_1 = require("@tanstack/react-query");
|
|
13
|
-
const client_1 = require("../client");
|
|
14
|
-
// ============================================================================
|
|
15
|
-
// QUERY KEYS
|
|
16
|
-
// ============================================================================
|
|
17
|
-
exports.orderKeys = {
|
|
18
|
-
all: ['orders'],
|
|
19
|
-
lists: () => [...exports.orderKeys.all, 'list'],
|
|
20
|
-
list: (filters) => [...exports.orderKeys.lists(), filters],
|
|
21
|
-
details: () => [...exports.orderKeys.all, 'detail'],
|
|
22
|
-
detail: (id) => [...exports.orderKeys.details(), id],
|
|
23
|
-
myOrders: () => [...exports.orderKeys.all, 'my'],
|
|
24
|
-
spotOrders: (spotId) => [...exports.orderKeys.all, 'spot', spotId],
|
|
25
|
-
};
|
|
26
|
-
// ============================================================================
|
|
27
|
-
// QUERY HOOKS
|
|
28
|
-
// ============================================================================
|
|
29
|
-
/**
|
|
30
|
-
* Get current user's orders (purchases)
|
|
31
|
-
*
|
|
32
|
-
* @endpoint GET /users/me/orders
|
|
33
|
-
*/
|
|
34
|
-
function useMyOrders(params, options) {
|
|
35
|
-
return (0, react_query_1.useQuery)({
|
|
36
|
-
queryKey: exports.orderKeys.list({ ...params, my: true }),
|
|
37
|
-
queryFn: async () => {
|
|
38
|
-
const client = (0, client_1.getApiClient)();
|
|
39
|
-
const queryParams = new URLSearchParams();
|
|
40
|
-
if (params?.status)
|
|
41
|
-
queryParams.set('status', params.status);
|
|
42
|
-
if (params?.limit)
|
|
43
|
-
queryParams.set('limit', String(params.limit));
|
|
44
|
-
if (params?.page)
|
|
45
|
-
queryParams.set('page', String(params.page));
|
|
46
|
-
const response = await client.get(`/users/me/orders?${queryParams}`);
|
|
47
|
-
return response.data.data;
|
|
48
|
-
},
|
|
49
|
-
...options,
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* Get a single order by ID
|
|
54
|
-
*
|
|
55
|
-
* @endpoint GET /orders/{orderId}
|
|
56
|
-
*/
|
|
57
|
-
function useOrder(orderId, options) {
|
|
58
|
-
return (0, react_query_1.useQuery)({
|
|
59
|
-
queryKey: exports.orderKeys.detail(orderId),
|
|
60
|
-
queryFn: async () => {
|
|
61
|
-
const client = (0, client_1.getApiClient)();
|
|
62
|
-
const response = await client.get(`/orders/${orderId}`);
|
|
63
|
-
return response.data.data;
|
|
64
|
-
},
|
|
65
|
-
enabled: !!orderId,
|
|
66
|
-
...options,
|
|
67
|
-
});
|
|
68
|
-
}
|
|
69
|
-
/**
|
|
70
|
-
* Get orders for a spot (seller view)
|
|
71
|
-
*
|
|
72
|
-
* @endpoint GET /seller/spots/{spotId}/orders
|
|
73
|
-
*/
|
|
74
|
-
function useSpotOrders(spotId, params, options) {
|
|
75
|
-
return (0, react_query_1.useQuery)({
|
|
76
|
-
queryKey: exports.orderKeys.spotOrders(spotId),
|
|
77
|
-
queryFn: async () => {
|
|
78
|
-
const client = (0, client_1.getApiClient)();
|
|
79
|
-
const queryParams = new URLSearchParams();
|
|
80
|
-
if (params?.status)
|
|
81
|
-
queryParams.set('status', params.status);
|
|
82
|
-
if (params?.limit)
|
|
83
|
-
queryParams.set('limit', String(params.limit));
|
|
84
|
-
if (params?.page)
|
|
85
|
-
queryParams.set('page', String(params.page));
|
|
86
|
-
const response = await client.get(`/seller/spots/${spotId}/orders?${queryParams}`);
|
|
87
|
-
return response.data.data;
|
|
88
|
-
},
|
|
89
|
-
enabled: !!spotId,
|
|
90
|
-
...options,
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orders.js","sourceRoot":"","sources":["../../../src/api/queries/orders.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;;AAuDH,kCAsBC;AAOD,4BAgBC;AAOD,sCAwBC;AAjID,uDAAyF;AACzF,sCAAsC;AAWtC,+EAA+E;AAC/E,aAAa;AACb,+EAA+E;AAElE,QAAA,SAAS,GAAG;IACvB,GAAG,EAAE,CAAC,QAAQ,CAAU;IACxB,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,iBAAS,CAAC,GAAG,EAAE,MAAM,CAAU;IAChD,IAAI,EAAE,CAAC,OAAiC,EAAE,EAAE,CAC1C,CAAC,GAAG,iBAAS,CAAC,KAAK,EAAE,EAAE,OAAO,CAAU;IAC1C,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,iBAAS,CAAC,GAAG,EAAE,QAAQ,CAAU;IACpD,MAAM,EAAE,CAAC,EAAU,EAAE,EAAE,CAAC,CAAC,GAAG,iBAAS,CAAC,OAAO,EAAE,EAAE,EAAE,CAAU;IAC7D,QAAQ,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,iBAAS,CAAC,GAAG,EAAE,IAAI,CAAU;IACjD,UAAU,EAAE,CAAC,MAAc,EAAE,EAAE,CAAC,CAAC,GAAG,iBAAS,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAU;CAC5E,CAAA;AAmBD,+EAA+E;AAC/E,cAAc;AACd,+EAA+E;AAE/E;;;;GAIG;AACH,SAAgB,WAAW,CACzB,MAAqB,EACrB,OAGC;IAED,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,iBAAS,CAAC,IAAI,CAAC,EAAC,GAAG,MAAM,EAAE,EAAE,EAAE,IAAI,EAAC,CAAC;QAC/C,OAAO,EAAE,KAAK,IAAkD,EAAE;YAChE,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAA;YAC7B,MAAM,WAAW,GAAG,IAAI,eAAe,EAAE,CAAA;YACzC,IAAI,MAAM,EAAE,MAAM;gBAAE,WAAW,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,CAAA;YAC5D,IAAI,MAAM,EAAE,KAAK;gBAAE,WAAW,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;YACjE,IAAI,MAAM,EAAE,IAAI;gBAAE,WAAW,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAA;YAC9D,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAE/B,oBAAoB,WAAW,EAAE,CAAC,CAAA;YACpC,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAA;QAC3B,CAAC;QACD,GAAG,OAAO;KACX,CAAC,CAAA;AACJ,CAAC;AAED;;;;GAIG;AACH,SAAgB,QAAQ,CACtB,OAAe,EACf,OAAyE;IAEzE,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,iBAAS,CAAC,MAAM,CAAC,OAAO,CAAC;QACnC,OAAO,EAAE,KAAK,IAA+B,EAAE;YAC7C,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAA;YAC7B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,WAAW,OAAO,EAAE,CACrB,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAA;QAC3B,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,OAAO;QAClB,GAAG,OAAO;KACX,CAAC,CAAA;AACJ,CAAC;AAED;;;;GAIG;AACH,SAAgB,aAAa,CAC3B,MAAc,EACd,MAAqB,EACrB,OAGC;IAED,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,iBAAS,CAAC,UAAU,CAAC,MAAM,CAAC;QACtC,OAAO,EAAE,KAAK,IAAkD,EAAE;YAChE,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAA;YAC7B,MAAM,WAAW,GAAG,IAAI,eAAe,EAAE,CAAA;YACzC,IAAI,MAAM,EAAE,MAAM;gBAAE,WAAW,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,CAAA;YAC5D,IAAI,MAAM,EAAE,KAAK;gBAAE,WAAW,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;YACjE,IAAI,MAAM,EAAE,IAAI;gBAAE,WAAW,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAA;YAC9D,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAE/B,iBAAiB,MAAM,WAAW,WAAW,EAAE,CAAC,CAAA;YAClD,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAA;QAC3B,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,MAAM;QACjB,GAAG,OAAO;KACX,CAAC,CAAA;AACJ,CAAC","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"]}
|
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Posts Query Hooks
|
|
3
|
-
*
|
|
4
|
-
* TanStack Query hooks for post/board operations.
|
|
5
|
-
*/
|
|
6
|
-
import { type UseQueryOptions, type UseQueryResult } from '@tanstack/react-query';
|
|
7
|
-
import { type Post, type PostResponse, type PostStatusDto, type PostUpvotesResponse } from '../types';
|
|
8
|
-
export declare const postKeys: {
|
|
9
|
-
all: readonly ["posts"];
|
|
10
|
-
lists: () => readonly ["posts", "list"];
|
|
11
|
-
list: (filters?: Record<string, unknown>) => readonly ["posts", "list", Record<string, unknown> | undefined];
|
|
12
|
-
bySpot: (spotId: string, filters?: Record<string, unknown>) => readonly ["posts", "spot", string, Record<string, unknown> | undefined];
|
|
13
|
-
details: () => readonly ["posts", "detail"];
|
|
14
|
-
detail: (id: string) => readonly ["posts", "detail", string];
|
|
15
|
-
responses: (postId: string) => readonly ["posts", "detail", string, "responses"];
|
|
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];
|
|
24
|
-
};
|
|
25
|
-
/**
|
|
26
|
-
* Get posts for a spot
|
|
27
|
-
*
|
|
28
|
-
* @endpoint GET /spots/{spotId}/posts
|
|
29
|
-
*/
|
|
30
|
-
export declare function useSpotPosts(spotId: string, params?: {
|
|
31
|
-
postType?: string;
|
|
32
|
-
status?: string;
|
|
33
|
-
page?: number;
|
|
34
|
-
limit?: number;
|
|
35
|
-
}, options?: Omit<UseQueryOptions<Post[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Post[]>;
|
|
36
|
-
/**
|
|
37
|
-
* Get a single post by ID
|
|
38
|
-
*
|
|
39
|
-
* @endpoint GET /posts/{postId}
|
|
40
|
-
*/
|
|
41
|
-
export declare function usePost(postId: string, options?: Omit<UseQueryOptions<Post>, 'queryKey' | 'queryFn'>): UseQueryResult<Post>;
|
|
42
|
-
/**
|
|
43
|
-
* Get responses for a post
|
|
44
|
-
*
|
|
45
|
-
* @endpoint GET /posts/{postId}/responses
|
|
46
|
-
*/
|
|
47
|
-
export declare function usePostResponses(postId: string, options?: Omit<UseQueryOptions<PostResponse[]>, 'queryKey' | 'queryFn'>): UseQueryResult<PostResponse[]>;
|
|
48
|
-
/**
|
|
49
|
-
* Get all posts (with filters)
|
|
50
|
-
*
|
|
51
|
-
* @endpoint GET /posts
|
|
52
|
-
*/
|
|
53
|
-
export declare function usePosts(params?: {
|
|
54
|
-
postType?: string;
|
|
55
|
-
limit?: number;
|
|
56
|
-
}, options?: Omit<UseQueryOptions<Post[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Post[]>;
|
|
57
|
-
/**
|
|
58
|
-
* Get user's status for a post (read/hidden/pinned)
|
|
59
|
-
*
|
|
60
|
-
* @endpoint GET /posts/{postId}/status
|
|
61
|
-
*/
|
|
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
|
-
}>;
|
|
@@ -1,233 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* Posts Query Hooks
|
|
4
|
-
*
|
|
5
|
-
* TanStack Query hooks for post/board operations.
|
|
6
|
-
*/
|
|
7
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
-
exports.postKeys = void 0;
|
|
9
|
-
exports.useSpotPosts = useSpotPosts;
|
|
10
|
-
exports.usePost = usePost;
|
|
11
|
-
exports.usePostResponses = usePostResponses;
|
|
12
|
-
exports.usePosts = usePosts;
|
|
13
|
-
exports.usePostStatus = usePostStatus;
|
|
14
|
-
exports.usePostUpvotes = usePostUpvotes;
|
|
15
|
-
exports.usePostsFeed = usePostsFeed;
|
|
16
|
-
const react_query_1 = require("@tanstack/react-query");
|
|
17
|
-
const client_1 = require("../client");
|
|
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
|
-
// ============================================================================
|
|
62
|
-
// QUERY KEYS
|
|
63
|
-
// ============================================================================
|
|
64
|
-
exports.postKeys = {
|
|
65
|
-
all: ['posts'],
|
|
66
|
-
lists: () => [...exports.postKeys.all, 'list'],
|
|
67
|
-
list: (filters) => [...exports.postKeys.lists(), filters],
|
|
68
|
-
bySpot: (spotId, filters) => [...exports.postKeys.all, 'spot', spotId, filters],
|
|
69
|
-
details: () => [...exports.postKeys.all, 'detail'],
|
|
70
|
-
detail: (id) => [...exports.postKeys.details(), id],
|
|
71
|
-
responses: (postId) => [...exports.postKeys.detail(postId), 'responses'],
|
|
72
|
-
status: (postId) => [...exports.postKeys.detail(postId), 'status'],
|
|
73
|
-
upvotes: (postId, filters) => [...exports.postKeys.detail(postId), 'upvotes', filters],
|
|
74
|
-
};
|
|
75
|
-
// ============================================================================
|
|
76
|
-
// QUERY HOOKS
|
|
77
|
-
// ============================================================================
|
|
78
|
-
/**
|
|
79
|
-
* Get posts for a spot
|
|
80
|
-
*
|
|
81
|
-
* @endpoint GET /spots/{spotId}/posts
|
|
82
|
-
*/
|
|
83
|
-
function useSpotPosts(spotId, params, options) {
|
|
84
|
-
return (0, react_query_1.useQuery)({
|
|
85
|
-
queryKey: exports.postKeys.bySpot(spotId, params),
|
|
86
|
-
queryFn: async () => {
|
|
87
|
-
const client = (0, client_1.getApiClient)();
|
|
88
|
-
const queryParams = new URLSearchParams();
|
|
89
|
-
if (params?.postType)
|
|
90
|
-
queryParams.set('postType', params.postType);
|
|
91
|
-
if (params?.status)
|
|
92
|
-
queryParams.set('status', params.status);
|
|
93
|
-
if (params?.page)
|
|
94
|
-
queryParams.set('page', String(params.page));
|
|
95
|
-
if (params?.limit)
|
|
96
|
-
queryParams.set('limit', String(params.limit));
|
|
97
|
-
const response = await client.get(`/spots/${spotId}/posts?${queryParams}`);
|
|
98
|
-
return extractArrayData(response.data.data);
|
|
99
|
-
},
|
|
100
|
-
enabled: !!spotId,
|
|
101
|
-
...options,
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
|
-
/**
|
|
105
|
-
* Get a single post by ID
|
|
106
|
-
*
|
|
107
|
-
* @endpoint GET /posts/{postId}
|
|
108
|
-
*/
|
|
109
|
-
function usePost(postId, options) {
|
|
110
|
-
return (0, react_query_1.useQuery)({
|
|
111
|
-
queryKey: exports.postKeys.detail(postId),
|
|
112
|
-
queryFn: async () => {
|
|
113
|
-
const client = (0, client_1.getApiClient)();
|
|
114
|
-
const response = await client.get(`/posts/${postId}`);
|
|
115
|
-
return extractObjectData(response.data.data);
|
|
116
|
-
},
|
|
117
|
-
enabled: !!postId,
|
|
118
|
-
...options,
|
|
119
|
-
});
|
|
120
|
-
}
|
|
121
|
-
/**
|
|
122
|
-
* Get responses for a post
|
|
123
|
-
*
|
|
124
|
-
* @endpoint GET /posts/{postId}/responses
|
|
125
|
-
*/
|
|
126
|
-
function usePostResponses(postId, options) {
|
|
127
|
-
return (0, react_query_1.useQuery)({
|
|
128
|
-
queryKey: exports.postKeys.responses(postId),
|
|
129
|
-
queryFn: async () => {
|
|
130
|
-
const client = (0, client_1.getApiClient)();
|
|
131
|
-
const response = await client.get(`/posts/${postId}/responses`);
|
|
132
|
-
return extractArrayData(response.data.data);
|
|
133
|
-
},
|
|
134
|
-
enabled: !!postId,
|
|
135
|
-
...options,
|
|
136
|
-
});
|
|
137
|
-
}
|
|
138
|
-
/**
|
|
139
|
-
* Get all posts (with filters)
|
|
140
|
-
*
|
|
141
|
-
* @endpoint GET /posts
|
|
142
|
-
*/
|
|
143
|
-
function usePosts(params, options) {
|
|
144
|
-
return (0, react_query_1.useQuery)({
|
|
145
|
-
queryKey: exports.postKeys.list(params),
|
|
146
|
-
queryFn: async () => {
|
|
147
|
-
const client = (0, client_1.getApiClient)();
|
|
148
|
-
const queryParams = new URLSearchParams();
|
|
149
|
-
if (params?.postType)
|
|
150
|
-
queryParams.set('postType', params.postType);
|
|
151
|
-
if (params?.limit)
|
|
152
|
-
queryParams.set('limit', String(params.limit));
|
|
153
|
-
const response = await client.get(`/posts?${queryParams}`);
|
|
154
|
-
return extractArrayData(response.data.data);
|
|
155
|
-
},
|
|
156
|
-
...options,
|
|
157
|
-
});
|
|
158
|
-
}
|
|
159
|
-
/**
|
|
160
|
-
* Get user's status for a post (read/hidden/pinned)
|
|
161
|
-
*
|
|
162
|
-
* @endpoint GET /posts/{postId}/status
|
|
163
|
-
*/
|
|
164
|
-
function usePostStatus(postId, options) {
|
|
165
|
-
return (0, react_query_1.useQuery)({
|
|
166
|
-
queryKey: exports.postKeys.status(postId),
|
|
167
|
-
queryFn: async () => {
|
|
168
|
-
const client = (0, client_1.getApiClient)();
|
|
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: {...} } }
|
|
194
|
-
return response.data.data;
|
|
195
|
-
},
|
|
196
|
-
enabled: !!postId,
|
|
197
|
-
...options,
|
|
198
|
-
});
|
|
199
|
-
}
|
|
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"]}
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Products Query Hooks
|
|
3
|
-
*
|
|
4
|
-
* TanStack Query hooks for product-related operations.
|
|
5
|
-
*/
|
|
6
|
-
import { type UseQueryOptions, type UseQueryResult } from '@tanstack/react-query';
|
|
7
|
-
import type { Product, PaginatedResponse, ProductType, ProductStatus, Spot } from '../types';
|
|
8
|
-
export declare const productKeys: {
|
|
9
|
-
all: readonly ["products"];
|
|
10
|
-
lists: () => readonly ["products", "list"];
|
|
11
|
-
list: (filters?: Record<string, unknown>) => readonly ["products", "list", Record<string, unknown> | undefined];
|
|
12
|
-
details: () => readonly ["products", "detail"];
|
|
13
|
-
detail: (id: string) => readonly ["products", "detail", string];
|
|
14
|
-
bySlug: (spotId: string, slug: string) => readonly ["products", "slug", string, string];
|
|
15
|
-
bySpot: (spotId: string) => readonly ["products", "spot", string];
|
|
16
|
-
};
|
|
17
|
-
export interface ProductFilters {
|
|
18
|
-
spotId?: string;
|
|
19
|
-
type?: ProductType;
|
|
20
|
-
status?: ProductStatus;
|
|
21
|
-
limit?: number;
|
|
22
|
-
page?: number;
|
|
23
|
-
}
|
|
24
|
-
export interface ProductWithSpot extends Product {
|
|
25
|
-
spot: Pick<Spot, 'id' | 'name' | 'slug'>;
|
|
26
|
-
}
|
|
27
|
-
/**
|
|
28
|
-
* Get products for a spot (public browse)
|
|
29
|
-
*
|
|
30
|
-
* @endpoint GET /spots/{spotId}/products
|
|
31
|
-
*/
|
|
32
|
-
export declare function useSpotProducts(spotId: string, params?: {
|
|
33
|
-
type?: ProductType;
|
|
34
|
-
limit?: number;
|
|
35
|
-
page?: number;
|
|
36
|
-
}, options?: Omit<UseQueryOptions<PaginatedResponse<Product>>, 'queryKey' | 'queryFn'>): UseQueryResult<PaginatedResponse<Product>>;
|
|
37
|
-
/**
|
|
38
|
-
* Get a product by ID
|
|
39
|
-
*
|
|
40
|
-
* @endpoint GET /products/{productId}
|
|
41
|
-
*/
|
|
42
|
-
export declare function useProduct(productId: string, options?: Omit<UseQueryOptions<ProductWithSpot>, 'queryKey' | 'queryFn'>): UseQueryResult<ProductWithSpot>;
|
|
43
|
-
/**
|
|
44
|
-
* Get a product by slug (within a spot)
|
|
45
|
-
*
|
|
46
|
-
* @endpoint GET /spots/{spotId}/products/slug/{slug}
|
|
47
|
-
*/
|
|
48
|
-
export declare function useProductBySlug(spotId: string, slug: string, options?: Omit<UseQueryOptions<ProductWithSpot>, 'queryKey' | 'queryFn'>): UseQueryResult<ProductWithSpot>;
|