@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,52 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Products Query Hooks
|
|
3
|
+
*
|
|
4
|
+
* TanStack Query hooks for product-related operations.
|
|
5
|
+
*/
|
|
6
|
+
import { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
|
|
7
|
+
import type { Product, PaginatedResponse, ProductType, ProductStatus } 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: {
|
|
26
|
+
id: string;
|
|
27
|
+
name: string;
|
|
28
|
+
slug: string;
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Get products for a spot (public browse)
|
|
33
|
+
*
|
|
34
|
+
* @endpoint GET /api/v1/spots/{spotId}/products
|
|
35
|
+
*/
|
|
36
|
+
export declare function useSpotProducts(spotId: string, params?: {
|
|
37
|
+
type?: ProductType;
|
|
38
|
+
limit?: number;
|
|
39
|
+
page?: number;
|
|
40
|
+
}, options?: Omit<UseQueryOptions<PaginatedResponse<Product>>, 'queryKey' | 'queryFn'>): UseQueryResult<PaginatedResponse<Product>>;
|
|
41
|
+
/**
|
|
42
|
+
* Get a product by ID
|
|
43
|
+
*
|
|
44
|
+
* @endpoint GET /api/v1/products/{productId}
|
|
45
|
+
*/
|
|
46
|
+
export declare function useProduct(productId: string, options?: Omit<UseQueryOptions<ProductWithSpot>, 'queryKey' | 'queryFn'>): UseQueryResult<ProductWithSpot>;
|
|
47
|
+
/**
|
|
48
|
+
* Get a product by slug (within a spot)
|
|
49
|
+
*
|
|
50
|
+
* @endpoint GET /api/v1/spots/{spotId}/products/slug/{slug}
|
|
51
|
+
*/
|
|
52
|
+
export declare function useProductBySlug(spotId: string, slug: string, options?: Omit<UseQueryOptions<ProductWithSpot>, 'queryKey' | 'queryFn'>): UseQueryResult<ProductWithSpot>;
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Products Query Hooks
|
|
4
|
+
*
|
|
5
|
+
* TanStack Query hooks for product-related operations.
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.productKeys = void 0;
|
|
9
|
+
exports.useSpotProducts = useSpotProducts;
|
|
10
|
+
exports.useProduct = useProduct;
|
|
11
|
+
exports.useProductBySlug = useProductBySlug;
|
|
12
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
13
|
+
const client_1 = require("../client");
|
|
14
|
+
// ============================================================================
|
|
15
|
+
// QUERY KEYS
|
|
16
|
+
// ============================================================================
|
|
17
|
+
exports.productKeys = {
|
|
18
|
+
all: ['products'],
|
|
19
|
+
lists: () => [...exports.productKeys.all, 'list'],
|
|
20
|
+
list: (filters) => [...exports.productKeys.lists(), filters],
|
|
21
|
+
details: () => [...exports.productKeys.all, 'detail'],
|
|
22
|
+
detail: (id) => [...exports.productKeys.details(), id],
|
|
23
|
+
bySlug: (spotId, slug) => [...exports.productKeys.all, 'slug', spotId, slug],
|
|
24
|
+
bySpot: (spotId) => [...exports.productKeys.all, 'spot', spotId],
|
|
25
|
+
};
|
|
26
|
+
// ============================================================================
|
|
27
|
+
// QUERY HOOKS
|
|
28
|
+
// ============================================================================
|
|
29
|
+
/**
|
|
30
|
+
* Get products for a spot (public browse)
|
|
31
|
+
*
|
|
32
|
+
* @endpoint GET /api/v1/spots/{spotId}/products
|
|
33
|
+
*/
|
|
34
|
+
function useSpotProducts(spotId, params, options) {
|
|
35
|
+
return (0, react_query_1.useQuery)({
|
|
36
|
+
queryKey: exports.productKeys.bySpot(spotId),
|
|
37
|
+
queryFn: async () => {
|
|
38
|
+
const client = (0, client_1.getApiClient)();
|
|
39
|
+
const queryParams = new URLSearchParams();
|
|
40
|
+
if (params?.limit)
|
|
41
|
+
queryParams.set('limit', String(params.limit));
|
|
42
|
+
if (params?.page)
|
|
43
|
+
queryParams.set('page', String(params.page));
|
|
44
|
+
if (params?.type)
|
|
45
|
+
queryParams.set('type', params.type);
|
|
46
|
+
const response = await client.get(`/api/v1/spots/${spotId}/products?${queryParams}`);
|
|
47
|
+
return response.data.data;
|
|
48
|
+
},
|
|
49
|
+
enabled: !!spotId,
|
|
50
|
+
...options,
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Get a product by ID
|
|
55
|
+
*
|
|
56
|
+
* @endpoint GET /api/v1/products/{productId}
|
|
57
|
+
*/
|
|
58
|
+
function useProduct(productId, options) {
|
|
59
|
+
return (0, react_query_1.useQuery)({
|
|
60
|
+
queryKey: exports.productKeys.detail(productId),
|
|
61
|
+
queryFn: async () => {
|
|
62
|
+
const client = (0, client_1.getApiClient)();
|
|
63
|
+
const response = await client.get(`/api/v1/products/${productId}`);
|
|
64
|
+
return response.data.data;
|
|
65
|
+
},
|
|
66
|
+
enabled: !!productId,
|
|
67
|
+
...options,
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Get a product by slug (within a spot)
|
|
72
|
+
*
|
|
73
|
+
* @endpoint GET /api/v1/spots/{spotId}/products/slug/{slug}
|
|
74
|
+
*/
|
|
75
|
+
function useProductBySlug(spotId, slug, options) {
|
|
76
|
+
return (0, react_query_1.useQuery)({
|
|
77
|
+
queryKey: exports.productKeys.bySlug(spotId, slug),
|
|
78
|
+
queryFn: async () => {
|
|
79
|
+
const client = (0, client_1.getApiClient)();
|
|
80
|
+
const response = await client.get(`/api/v1/spots/${spotId}/products/slug/${slug}`);
|
|
81
|
+
return response.data.data;
|
|
82
|
+
},
|
|
83
|
+
enabled: !!spotId && !!slug,
|
|
84
|
+
...options,
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
// Note: To list products as a seller, use useSpotProducts with your spot ID.
|
|
88
|
+
// There is no cross-spot product listing endpoint currently.
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.js","sourceRoot":"","sources":["../../../src/api/queries/products.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;;AAiDH,0CAqBC;AAOD,gCAcC;AAOD,4CAiBC;AAjHD,uDAAkF;AAClF,sCAAyC;AAGzC,+EAA+E;AAC/E,aAAa;AACb,+EAA+E;AAElE,QAAA,WAAW,GAAG;IACzB,GAAG,EAAE,CAAC,UAAU,CAAU;IAC1B,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,mBAAW,CAAC,GAAG,EAAE,MAAM,CAAU;IAClD,IAAI,EAAE,CAAC,OAAiC,EAAE,EAAE,CAAC,CAAC,GAAG,mBAAW,CAAC,KAAK,EAAE,EAAE,OAAO,CAAU;IACvF,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,mBAAW,CAAC,GAAG,EAAE,QAAQ,CAAU;IACtD,MAAM,EAAE,CAAC,EAAU,EAAE,EAAE,CAAC,CAAC,GAAG,mBAAW,CAAC,OAAO,EAAE,EAAE,EAAE,CAAU;IAC/D,MAAM,EAAE,CAAC,MAAc,EAAE,IAAY,EAAE,EAAE,CAAC,CAAC,GAAG,mBAAW,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,CAAU;IAC7F,MAAM,EAAE,CAAC,MAAc,EAAE,EAAE,CAAC,CAAC,GAAG,mBAAW,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAU;CAC1E,CAAC;AAsBF,+EAA+E;AAC/E,cAAc;AACd,+EAA+E;AAE/E;;;;GAIG;AACH,SAAgB,eAAe,CAC7B,MAAc,EACd,MAA8D,EAC9D,OAAmF;IAEnF,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,mBAAW,CAAC,MAAM,CAAC,MAAM,CAAC;QACpC,OAAO,EAAE,KAAK,IAAyC,EAAE;YACvD,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,WAAW,GAAG,IAAI,eAAe,EAAE,CAAC;YAC1C,IAAI,MAAM,EAAE,KAAK;gBAAE,WAAW,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YAClE,IAAI,MAAM,EAAE,IAAI;gBAAE,WAAW,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;YAC/D,IAAI,MAAM,EAAE,IAAI;gBAAE,WAAW,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;YACvD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,iBAAiB,MAAM,aAAa,WAAW,EAAE,CAClD,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC;QAC5B,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,MAAM;QACjB,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;GAIG;AACH,SAAgB,UAAU,CACxB,SAAiB,EACjB,OAAwE;IAExE,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,mBAAW,CAAC,MAAM,CAAC,SAAS,CAAC;QACvC,OAAO,EAAE,KAAK,IAA8B,EAAE;YAC5C,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAA+B,oBAAoB,SAAS,EAAE,CAAC,CAAC;YACjG,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC;QAC5B,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,SAAS;QACpB,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;GAIG;AACH,SAAgB,gBAAgB,CAC9B,MAAc,EACd,IAAY,EACZ,OAAwE;IAExE,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,mBAAW,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC;QAC1C,OAAO,EAAE,KAAK,IAA8B,EAAE;YAC5C,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,iBAAiB,MAAM,kBAAkB,IAAI,EAAE,CAChD,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC;QAC5B,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,IAAI;QAC3B,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED,6EAA6E;AAC7E,6DAA6D","sourcesContent":["/**\n * Products Query Hooks\n *\n * TanStack Query hooks for product-related operations.\n */\n\nimport { useQuery, UseQueryOptions, UseQueryResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { Product, ApiResponse, PaginatedResponse, ProductType, ProductStatus } from '../types';\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const productKeys = {\n  all: ['products'] as const,\n  lists: () => [...productKeys.all, 'list'] as const,\n  list: (filters?: Record<string, unknown>) => [...productKeys.lists(), filters] as const,\n  details: () => [...productKeys.all, 'detail'] as const,\n  detail: (id: string) => [...productKeys.details(), id] as const,\n  bySlug: (spotId: string, slug: string) => [...productKeys.all, 'slug', spotId, slug] as const,\n  bySpot: (spotId: string) => [...productKeys.all, 'spot', spotId] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface ProductFilters {\n  spotId?: string;\n  type?: ProductType;\n  status?: ProductStatus;\n  limit?: number;\n  page?: number;\n}\n\nexport interface ProductWithSpot extends Product {\n  spot: {\n    id: string;\n    name: string;\n    slug: string;\n  };\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get products for a spot (public browse)\n *\n * @endpoint GET /api/v1/spots/{spotId}/products\n */\nexport function useSpotProducts(\n  spotId: string,\n  params?: { type?: ProductType; limit?: number; page?: number },\n  options?: Omit<UseQueryOptions<PaginatedResponse<Product>>, 'queryKey' | 'queryFn'>\n): UseQueryResult<PaginatedResponse<Product>> {\n  return useQuery({\n    queryKey: productKeys.bySpot(spotId),\n    queryFn: async (): Promise<PaginatedResponse<Product>> => {\n      const client = getApiClient();\n      const queryParams = new URLSearchParams();\n      if (params?.limit) queryParams.set('limit', String(params.limit));\n      if (params?.page) queryParams.set('page', String(params.page));\n      if (params?.type) queryParams.set('type', params.type);\n      const response = await client.get<ApiResponse<PaginatedResponse<Product>>>(\n        `/api/v1/spots/${spotId}/products?${queryParams}`\n      );\n      return response.data.data;\n    },\n    enabled: !!spotId,\n    ...options,\n  });\n}\n\n/**\n * Get a product by ID\n *\n * @endpoint GET /api/v1/products/{productId}\n */\nexport function useProduct(\n  productId: string,\n  options?: Omit<UseQueryOptions<ProductWithSpot>, 'queryKey' | 'queryFn'>\n): UseQueryResult<ProductWithSpot> {\n  return useQuery({\n    queryKey: productKeys.detail(productId),\n    queryFn: async (): Promise<ProductWithSpot> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<ProductWithSpot>>(`/api/v1/products/${productId}`);\n      return response.data.data;\n    },\n    enabled: !!productId,\n    ...options,\n  });\n}\n\n/**\n * Get a product by slug (within a spot)\n *\n * @endpoint GET /api/v1/spots/{spotId}/products/slug/{slug}\n */\nexport function useProductBySlug(\n  spotId: string,\n  slug: string,\n  options?: Omit<UseQueryOptions<ProductWithSpot>, 'queryKey' | 'queryFn'>\n): UseQueryResult<ProductWithSpot> {\n  return useQuery({\n    queryKey: productKeys.bySlug(spotId, slug),\n    queryFn: async (): Promise<ProductWithSpot> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<ProductWithSpot>>(\n        `/api/v1/spots/${spotId}/products/slug/${slug}`\n      );\n      return response.data.data;\n    },\n    enabled: !!spotId && !!slug,\n    ...options,\n  });\n}\n\n// Note: To list products as a seller, use useSpotProducts with your spot ID.\n// There is no cross-spot product listing endpoint currently.\n"]}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Spots Query Hooks
|
|
3
|
+
*
|
|
4
|
+
* TanStack Query hooks for spot-related operations.
|
|
5
|
+
*/
|
|
6
|
+
import { UseQueryOptions, UseQueryResult, UseInfiniteQueryOptions, UseInfiniteQueryResult } from '@tanstack/react-query';
|
|
7
|
+
import type { Spot, SpotImage, PaginatedResponse } from '../types';
|
|
8
|
+
export declare const spotKeys: {
|
|
9
|
+
all: readonly ["spots"];
|
|
10
|
+
lists: () => readonly ["spots", "list"];
|
|
11
|
+
list: (filters?: Record<string, unknown>) => readonly ["spots", "list", Record<string, unknown> | undefined];
|
|
12
|
+
details: () => readonly ["spots", "detail"];
|
|
13
|
+
detail: (id: string) => readonly ["spots", "detail", string];
|
|
14
|
+
bySlug: (slug: string) => readonly ["spots", "slug", string];
|
|
15
|
+
byQR: (qrCode: string) => readonly ["spots", "qr", string];
|
|
16
|
+
images: (spotId: string) => readonly ["spots", "detail", string, "images"];
|
|
17
|
+
};
|
|
18
|
+
/**
|
|
19
|
+
* Get all spots (paginated)
|
|
20
|
+
*
|
|
21
|
+
* @endpoint GET /api/v1/spots
|
|
22
|
+
* @returns PaginatedResponse with spots array and meta
|
|
23
|
+
*/
|
|
24
|
+
export declare function useSpots(params?: {
|
|
25
|
+
limit?: number;
|
|
26
|
+
page?: number;
|
|
27
|
+
city?: string;
|
|
28
|
+
type?: string;
|
|
29
|
+
templateSlugs?: string[];
|
|
30
|
+
vibeIds?: string[];
|
|
31
|
+
search?: string;
|
|
32
|
+
}, options?: Omit<UseQueryOptions<PaginatedResponse<Spot>>, 'queryKey' | 'queryFn'>): UseQueryResult<PaginatedResponse<Spot>>;
|
|
33
|
+
/**
|
|
34
|
+
* Get a spot by ID
|
|
35
|
+
*
|
|
36
|
+
* @endpoint GET /api/v1/spots/{spotId}
|
|
37
|
+
*/
|
|
38
|
+
export declare function useSpot(spotId: string, options?: Omit<UseQueryOptions<Spot>, 'queryKey' | 'queryFn'>): UseQueryResult<Spot>;
|
|
39
|
+
/**
|
|
40
|
+
* Get a spot by slug
|
|
41
|
+
*
|
|
42
|
+
* @endpoint GET /api/v1/spots/slug/{slug}
|
|
43
|
+
*/
|
|
44
|
+
export declare function useSpotBySlug(slug: string, options?: Omit<UseQueryOptions<Spot>, 'queryKey' | 'queryFn'>): UseQueryResult<Spot>;
|
|
45
|
+
/**
|
|
46
|
+
* Get a spot by QR code
|
|
47
|
+
*
|
|
48
|
+
* @endpoint GET /api/v1/spots/qr/{qrCode}
|
|
49
|
+
*/
|
|
50
|
+
export declare function useSpotByQR(qrCode: string, options?: Omit<UseQueryOptions<Spot>, 'queryKey' | 'queryFn'>): UseQueryResult<Spot>;
|
|
51
|
+
/**
|
|
52
|
+
* Get images for a spot
|
|
53
|
+
*
|
|
54
|
+
* @endpoint GET /api/v1/spots/{spotId}/images
|
|
55
|
+
*/
|
|
56
|
+
export declare function useSpotImages(spotId: string, options?: Omit<UseQueryOptions<SpotImage[]>, 'queryKey' | 'queryFn'>): UseQueryResult<SpotImage[]>;
|
|
57
|
+
/**
|
|
58
|
+
* Infinite scroll query for spots
|
|
59
|
+
*
|
|
60
|
+
* @endpoint GET /api/v1/spots (paginated)
|
|
61
|
+
* @returns Infinite query with pages of spots
|
|
62
|
+
*/
|
|
63
|
+
export interface InfiniteSpotsParams {
|
|
64
|
+
limit?: number;
|
|
65
|
+
city?: string;
|
|
66
|
+
cityId?: string;
|
|
67
|
+
type?: string;
|
|
68
|
+
templateSlugs?: string[];
|
|
69
|
+
vibeIds?: string[];
|
|
70
|
+
search?: string;
|
|
71
|
+
}
|
|
72
|
+
export declare function useInfiniteSpots(params?: InfiniteSpotsParams, options?: Omit<UseInfiniteQueryOptions<PaginatedResponse<Spot>, Error, {
|
|
73
|
+
pages: PaginatedResponse<Spot>[];
|
|
74
|
+
pageParams: number[];
|
|
75
|
+
}>, 'queryKey' | 'queryFn' | 'getNextPageParam' | 'initialPageParam'>): UseInfiniteQueryResult<{
|
|
76
|
+
pages: PaginatedResponse<Spot>[];
|
|
77
|
+
pageParams: number[];
|
|
78
|
+
}, Error>;
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Spots Query Hooks
|
|
4
|
+
*
|
|
5
|
+
* TanStack Query hooks for spot-related operations.
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.spotKeys = void 0;
|
|
9
|
+
exports.useSpots = useSpots;
|
|
10
|
+
exports.useSpot = useSpot;
|
|
11
|
+
exports.useSpotBySlug = useSpotBySlug;
|
|
12
|
+
exports.useSpotByQR = useSpotByQR;
|
|
13
|
+
exports.useSpotImages = useSpotImages;
|
|
14
|
+
exports.useInfiniteSpots = useInfiniteSpots;
|
|
15
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
16
|
+
const client_1 = require("../client");
|
|
17
|
+
// ============================================================================
|
|
18
|
+
// QUERY KEYS
|
|
19
|
+
// ============================================================================
|
|
20
|
+
exports.spotKeys = {
|
|
21
|
+
all: ['spots'],
|
|
22
|
+
lists: () => [...exports.spotKeys.all, 'list'],
|
|
23
|
+
list: (filters) => [...exports.spotKeys.lists(), filters],
|
|
24
|
+
details: () => [...exports.spotKeys.all, 'detail'],
|
|
25
|
+
detail: (id) => [...exports.spotKeys.details(), id],
|
|
26
|
+
bySlug: (slug) => [...exports.spotKeys.all, 'slug', slug],
|
|
27
|
+
byQR: (qrCode) => [...exports.spotKeys.all, 'qr', qrCode],
|
|
28
|
+
images: (spotId) => [...exports.spotKeys.detail(spotId), 'images'],
|
|
29
|
+
};
|
|
30
|
+
// ============================================================================
|
|
31
|
+
// QUERY HOOKS
|
|
32
|
+
// ============================================================================
|
|
33
|
+
/**
|
|
34
|
+
* Get all spots (paginated)
|
|
35
|
+
*
|
|
36
|
+
* @endpoint GET /api/v1/spots
|
|
37
|
+
* @returns PaginatedResponse with spots array and meta
|
|
38
|
+
*/
|
|
39
|
+
function useSpots(params, options) {
|
|
40
|
+
return (0, react_query_1.useQuery)({
|
|
41
|
+
queryKey: exports.spotKeys.list(params),
|
|
42
|
+
queryFn: async () => {
|
|
43
|
+
const client = (0, client_1.getApiClient)();
|
|
44
|
+
const queryParams = new URLSearchParams();
|
|
45
|
+
if (params?.limit)
|
|
46
|
+
queryParams.set('limit', String(params.limit));
|
|
47
|
+
if (params?.page)
|
|
48
|
+
queryParams.set('page', String(params.page));
|
|
49
|
+
if (params?.city)
|
|
50
|
+
queryParams.set('city', params.city);
|
|
51
|
+
if (params?.type)
|
|
52
|
+
queryParams.set('type', params.type);
|
|
53
|
+
if (params?.search)
|
|
54
|
+
queryParams.set('search', params.search);
|
|
55
|
+
if (params?.templateSlugs) {
|
|
56
|
+
params.templateSlugs.forEach(slug => queryParams.append('templateSlugs', slug));
|
|
57
|
+
}
|
|
58
|
+
if (params?.vibeIds) {
|
|
59
|
+
params.vibeIds.forEach(id => queryParams.append('vibeIds', id));
|
|
60
|
+
}
|
|
61
|
+
const response = await client.get(`/api/v1/spots?${queryParams}`);
|
|
62
|
+
return response.data.data;
|
|
63
|
+
},
|
|
64
|
+
...options,
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Get a spot by ID
|
|
69
|
+
*
|
|
70
|
+
* @endpoint GET /api/v1/spots/{spotId}
|
|
71
|
+
*/
|
|
72
|
+
function useSpot(spotId, options) {
|
|
73
|
+
return (0, react_query_1.useQuery)({
|
|
74
|
+
queryKey: exports.spotKeys.detail(spotId),
|
|
75
|
+
queryFn: async () => {
|
|
76
|
+
const client = (0, client_1.getApiClient)();
|
|
77
|
+
const response = await client.get(`/api/v1/spots/${spotId}`);
|
|
78
|
+
return response.data.data;
|
|
79
|
+
},
|
|
80
|
+
enabled: !!spotId,
|
|
81
|
+
...options,
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Get a spot by slug
|
|
86
|
+
*
|
|
87
|
+
* @endpoint GET /api/v1/spots/slug/{slug}
|
|
88
|
+
*/
|
|
89
|
+
function useSpotBySlug(slug, options) {
|
|
90
|
+
return (0, react_query_1.useQuery)({
|
|
91
|
+
queryKey: exports.spotKeys.bySlug(slug),
|
|
92
|
+
queryFn: async () => {
|
|
93
|
+
const client = (0, client_1.getApiClient)();
|
|
94
|
+
const response = await client.get(`/api/v1/spots/slug/${slug}`);
|
|
95
|
+
return response.data.data;
|
|
96
|
+
},
|
|
97
|
+
enabled: !!slug,
|
|
98
|
+
...options,
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Get a spot by QR code
|
|
103
|
+
*
|
|
104
|
+
* @endpoint GET /api/v1/spots/qr/{qrCode}
|
|
105
|
+
*/
|
|
106
|
+
function useSpotByQR(qrCode, options) {
|
|
107
|
+
return (0, react_query_1.useQuery)({
|
|
108
|
+
queryKey: exports.spotKeys.byQR(qrCode),
|
|
109
|
+
queryFn: async () => {
|
|
110
|
+
const client = (0, client_1.getApiClient)();
|
|
111
|
+
const response = await client.get(`/api/v1/spots/qr/${qrCode}`);
|
|
112
|
+
return response.data.data;
|
|
113
|
+
},
|
|
114
|
+
enabled: !!qrCode,
|
|
115
|
+
...options,
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* Get images for a spot
|
|
120
|
+
*
|
|
121
|
+
* @endpoint GET /api/v1/spots/{spotId}/images
|
|
122
|
+
*/
|
|
123
|
+
function useSpotImages(spotId, options) {
|
|
124
|
+
return (0, react_query_1.useQuery)({
|
|
125
|
+
queryKey: exports.spotKeys.images(spotId),
|
|
126
|
+
queryFn: async () => {
|
|
127
|
+
const client = (0, client_1.getApiClient)();
|
|
128
|
+
const response = await client.get(`/api/v1/spots/${spotId}/images`);
|
|
129
|
+
return response.data.data;
|
|
130
|
+
},
|
|
131
|
+
enabled: !!spotId,
|
|
132
|
+
...options,
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
function useInfiniteSpots(params, options) {
|
|
136
|
+
return (0, react_query_1.useInfiniteQuery)({
|
|
137
|
+
queryKey: [...exports.spotKeys.lists(), 'infinite', params],
|
|
138
|
+
queryFn: async ({ pageParam }) => {
|
|
139
|
+
const client = (0, client_1.getApiClient)();
|
|
140
|
+
const queryParams = new URLSearchParams();
|
|
141
|
+
queryParams.set('page', String(pageParam));
|
|
142
|
+
if (params?.limit)
|
|
143
|
+
queryParams.set('limit', String(params.limit));
|
|
144
|
+
if (params?.city)
|
|
145
|
+
queryParams.set('city', params.city);
|
|
146
|
+
if (params?.cityId)
|
|
147
|
+
queryParams.set('cityId', params.cityId);
|
|
148
|
+
if (params?.type && params.type !== 'All')
|
|
149
|
+
queryParams.set('type', params.type);
|
|
150
|
+
if (params?.search?.trim())
|
|
151
|
+
queryParams.set('search', params.search.trim());
|
|
152
|
+
if (params?.templateSlugs) {
|
|
153
|
+
params.templateSlugs.forEach(slug => queryParams.append('templateSlugs', slug));
|
|
154
|
+
}
|
|
155
|
+
if (params?.vibeIds) {
|
|
156
|
+
params.vibeIds.forEach(id => queryParams.append('vibeIds', id));
|
|
157
|
+
}
|
|
158
|
+
const response = await client.get(`/api/v1/spots?${queryParams}`);
|
|
159
|
+
return response.data.data;
|
|
160
|
+
},
|
|
161
|
+
initialPageParam: 1,
|
|
162
|
+
getNextPageParam: (lastPage) => {
|
|
163
|
+
return lastPage.meta.hasNextPage ? lastPage.meta.page + 1 : undefined;
|
|
164
|
+
},
|
|
165
|
+
...options,
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"spots.js","sourceRoot":"","sources":["../../../src/api/queries/spots.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Spots Query Hooks\n *\n * TanStack Query hooks for spot-related operations.\n */\n\nimport { useQuery, useInfiniteQuery, UseQueryOptions, UseQueryResult, UseInfiniteQueryOptions, UseInfiniteQueryResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { Spot, SpotImage, ApiResponse, PaginatedResponse } from '../types';\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const spotKeys = {\n  all: ['spots'] as const,\n  lists: () => [...spotKeys.all, 'list'] as const,\n  list: (filters?: Record<string, unknown>) => [...spotKeys.lists(), filters] as const,\n  details: () => [...spotKeys.all, 'detail'] as const,\n  detail: (id: string) => [...spotKeys.details(), id] as const,\n  bySlug: (slug: string) => [...spotKeys.all, 'slug', slug] as const,\n  byQR: (qrCode: string) => [...spotKeys.all, 'qr', qrCode] as const,\n  images: (spotId: string) => [...spotKeys.detail(spotId), 'images'] as const,\n};\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get all spots (paginated)\n *\n * @endpoint GET /api/v1/spots\n * @returns PaginatedResponse with spots array and meta\n */\nexport function useSpots(\n  params?: {\n    limit?: number;\n    page?: number;\n    city?: string;\n    type?: string;\n    templateSlugs?: string[];\n    vibeIds?: string[];\n    search?: string;\n  },\n  options?: Omit<UseQueryOptions<PaginatedResponse<Spot>>, 'queryKey' | 'queryFn'>\n): UseQueryResult<PaginatedResponse<Spot>> {\n  return useQuery({\n    queryKey: spotKeys.list(params),\n    queryFn: async (): Promise<PaginatedResponse<Spot>> => {\n      const client = getApiClient();\n      const queryParams = new URLSearchParams();\n      if (params?.limit) queryParams.set('limit', String(params.limit));\n      if (params?.page) queryParams.set('page', String(params.page));\n      if (params?.city) queryParams.set('city', params.city);\n      if (params?.type) queryParams.set('type', params.type);\n      if (params?.search) queryParams.set('search', params.search);\n      if (params?.templateSlugs) {\n        params.templateSlugs.forEach(slug => queryParams.append('templateSlugs', slug));\n      }\n      if (params?.vibeIds) {\n        params.vibeIds.forEach(id => queryParams.append('vibeIds', id));\n      }\n      const response = await client.get<ApiResponse<PaginatedResponse<Spot>>>(`/api/v1/spots?${queryParams}`);\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get a spot by ID\n *\n * @endpoint GET /api/v1/spots/{spotId}\n */\nexport function useSpot(\n  spotId: string,\n  options?: Omit<UseQueryOptions<Spot>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Spot> {\n  return useQuery({\n    queryKey: spotKeys.detail(spotId),\n    queryFn: async (): Promise<Spot> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<Spot>>(`/api/v1/spots/${spotId}`);\n      return response.data.data;\n    },\n    enabled: !!spotId,\n    ...options,\n  });\n}\n\n/**\n * Get a spot by slug\n *\n * @endpoint GET /api/v1/spots/slug/{slug}\n */\nexport function useSpotBySlug(\n  slug: string,\n  options?: Omit<UseQueryOptions<Spot>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Spot> {\n  return useQuery({\n    queryKey: spotKeys.bySlug(slug),\n    queryFn: async (): Promise<Spot> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<Spot>>(`/api/v1/spots/slug/${slug}`);\n      return response.data.data;\n    },\n    enabled: !!slug,\n    ...options,\n  });\n}\n\n/**\n * Get a spot by QR code\n *\n * @endpoint GET /api/v1/spots/qr/{qrCode}\n */\nexport function useSpotByQR(\n  qrCode: string,\n  options?: Omit<UseQueryOptions<Spot>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Spot> {\n  return useQuery({\n    queryKey: spotKeys.byQR(qrCode),\n    queryFn: async (): Promise<Spot> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<Spot>>(`/api/v1/spots/qr/${qrCode}`);\n      return response.data.data;\n    },\n    enabled: !!qrCode,\n    ...options,\n  });\n}\n\n/**\n * Get images for a spot\n *\n * @endpoint GET /api/v1/spots/{spotId}/images\n */\nexport function useSpotImages(\n  spotId: string,\n  options?: Omit<UseQueryOptions<SpotImage[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<SpotImage[]> {\n  return useQuery({\n    queryKey: spotKeys.images(spotId),\n    queryFn: async (): Promise<SpotImage[]> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<SpotImage[]>>(`/api/v1/spots/${spotId}/images`);\n      return response.data.data;\n    },\n    enabled: !!spotId,\n    ...options,\n  });\n}\n\n/**\n * Infinite scroll query for spots\n *\n * @endpoint GET /api/v1/spots (paginated)\n * @returns Infinite query with pages of spots\n */\nexport interface InfiniteSpotsParams {\n  limit?: number;\n  city?: string;\n  cityId?: string;\n  type?: string;\n  templateSlugs?: string[];\n  vibeIds?: string[];\n  search?: string;\n}\n\nexport function useInfiniteSpots(\n  params?: InfiniteSpotsParams,\n  options?: Omit<UseInfiniteQueryOptions<PaginatedResponse<Spot>, Error, { pages: PaginatedResponse<Spot>[]; pageParams: number[] }>, 'queryKey' | 'queryFn' | 'getNextPageParam' | 'initialPageParam'>\n): UseInfiniteQueryResult<{ pages: PaginatedResponse<Spot>[]; pageParams: number[] }, Error> {\n  return useInfiniteQuery({\n    queryKey: [...spotKeys.lists(), 'infinite', params] as const,\n    queryFn: async ({ pageParam }): Promise<PaginatedResponse<Spot>> => {\n      const client = getApiClient();\n      const queryParams = new URLSearchParams();\n      queryParams.set('page', String(pageParam));\n      if (params?.limit) queryParams.set('limit', String(params.limit));\n      if (params?.city) queryParams.set('city', params.city);\n      if (params?.cityId) queryParams.set('cityId', params.cityId);\n      if (params?.type && params.type !== 'All') queryParams.set('type', params.type);\n      if (params?.search?.trim()) queryParams.set('search', params.search.trim());\n      if (params?.templateSlugs) {\n        params.templateSlugs.forEach(slug => queryParams.append('templateSlugs', slug));\n      }\n      if (params?.vibeIds) {\n        params.vibeIds.forEach(id => queryParams.append('vibeIds', id));\n      }\n      const response = await client.get<ApiResponse<PaginatedResponse<Spot>>>(`/api/v1/spots?${queryParams}`);\n      return response.data.data;\n    },\n    initialPageParam: 1,\n    getNextPageParam: (lastPage) => {\n      return lastPage.meta.hasNextPage ? lastPage.meta.page + 1 : undefined;\n    },\n    ...options,\n  });\n}\n"]}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Templates Query Hooks
|
|
3
|
+
*
|
|
4
|
+
* TanStack Query hooks for post template operations.
|
|
5
|
+
*
|
|
6
|
+
* Templates are reference data (flat array), not paginated.
|
|
7
|
+
*/
|
|
8
|
+
import { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
|
|
9
|
+
import type { Template } from '../types';
|
|
10
|
+
export declare const templateKeys: {
|
|
11
|
+
all: readonly ["templates"];
|
|
12
|
+
lists: () => readonly ["templates", "list"];
|
|
13
|
+
list: (filters?: {
|
|
14
|
+
spotType?: string;
|
|
15
|
+
}) => readonly ["templates", "list", {
|
|
16
|
+
spotType?: string;
|
|
17
|
+
} | undefined];
|
|
18
|
+
details: () => readonly ["templates", "detail"];
|
|
19
|
+
detail: (id: string) => readonly ["templates", "detail", string];
|
|
20
|
+
bySlug: (slug: string) => readonly ["templates", "slug", string];
|
|
21
|
+
};
|
|
22
|
+
/**
|
|
23
|
+
* Get all templates (flat array - reference data)
|
|
24
|
+
*
|
|
25
|
+
* @endpoint GET /api/v1/templates
|
|
26
|
+
* @returns Flat array of templates (not paginated)
|
|
27
|
+
*/
|
|
28
|
+
export declare function useTemplates(params?: {
|
|
29
|
+
spotType?: string;
|
|
30
|
+
}, options?: Omit<UseQueryOptions<Template[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Template[]>;
|
|
31
|
+
/**
|
|
32
|
+
* Get a template by ID
|
|
33
|
+
*
|
|
34
|
+
* @endpoint GET /api/v1/templates/{templateId}
|
|
35
|
+
*/
|
|
36
|
+
export declare function useTemplate(templateId: string, options?: Omit<UseQueryOptions<Template>, 'queryKey' | 'queryFn'>): UseQueryResult<Template>;
|
|
37
|
+
/**
|
|
38
|
+
* Get a template by slug
|
|
39
|
+
*
|
|
40
|
+
* @endpoint GET /api/v1/templates/slug/{slug}
|
|
41
|
+
*/
|
|
42
|
+
export declare function useTemplateBySlug(slug: string, options?: Omit<UseQueryOptions<Template>, 'queryKey' | 'queryFn'>): UseQueryResult<Template>;
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Templates Query Hooks
|
|
4
|
+
*
|
|
5
|
+
* TanStack Query hooks for post template operations.
|
|
6
|
+
*
|
|
7
|
+
* Templates are reference data (flat array), not paginated.
|
|
8
|
+
*/
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.templateKeys = void 0;
|
|
11
|
+
exports.useTemplates = useTemplates;
|
|
12
|
+
exports.useTemplate = useTemplate;
|
|
13
|
+
exports.useTemplateBySlug = useTemplateBySlug;
|
|
14
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
15
|
+
const client_1 = require("../client");
|
|
16
|
+
// ============================================================================
|
|
17
|
+
// QUERY KEYS
|
|
18
|
+
// ============================================================================
|
|
19
|
+
exports.templateKeys = {
|
|
20
|
+
all: ['templates'],
|
|
21
|
+
lists: () => [...exports.templateKeys.all, 'list'],
|
|
22
|
+
list: (filters) => [...exports.templateKeys.lists(), filters],
|
|
23
|
+
details: () => [...exports.templateKeys.all, 'detail'],
|
|
24
|
+
detail: (id) => [...exports.templateKeys.details(), id],
|
|
25
|
+
bySlug: (slug) => [...exports.templateKeys.all, 'slug', slug],
|
|
26
|
+
};
|
|
27
|
+
// ============================================================================
|
|
28
|
+
// QUERY HOOKS
|
|
29
|
+
// ============================================================================
|
|
30
|
+
/**
|
|
31
|
+
* Get all templates (flat array - reference data)
|
|
32
|
+
*
|
|
33
|
+
* @endpoint GET /api/v1/templates
|
|
34
|
+
* @returns Flat array of templates (not paginated)
|
|
35
|
+
*/
|
|
36
|
+
function useTemplates(params, options) {
|
|
37
|
+
return (0, react_query_1.useQuery)({
|
|
38
|
+
queryKey: exports.templateKeys.list(params),
|
|
39
|
+
queryFn: async () => {
|
|
40
|
+
const client = (0, client_1.getApiClient)();
|
|
41
|
+
const queryParams = new URLSearchParams();
|
|
42
|
+
if (params?.spotType)
|
|
43
|
+
queryParams.set('spotType', params.spotType);
|
|
44
|
+
const response = await client.get(`/api/v1/templates?${queryParams}`);
|
|
45
|
+
// Templates endpoint returns flat array: { data: [] }
|
|
46
|
+
return response.data.data;
|
|
47
|
+
},
|
|
48
|
+
staleTime: 1000 * 60 * 60, // Cache for 1 hour (reference data)
|
|
49
|
+
...options,
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Get a template by ID
|
|
54
|
+
*
|
|
55
|
+
* @endpoint GET /api/v1/templates/{templateId}
|
|
56
|
+
*/
|
|
57
|
+
function useTemplate(templateId, options) {
|
|
58
|
+
return (0, react_query_1.useQuery)({
|
|
59
|
+
queryKey: exports.templateKeys.detail(templateId),
|
|
60
|
+
queryFn: async () => {
|
|
61
|
+
const client = (0, client_1.getApiClient)();
|
|
62
|
+
const response = await client.get(`/api/v1/templates/${templateId}`);
|
|
63
|
+
return response.data.data;
|
|
64
|
+
},
|
|
65
|
+
enabled: !!templateId,
|
|
66
|
+
...options,
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Get a template by slug
|
|
71
|
+
*
|
|
72
|
+
* @endpoint GET /api/v1/templates/slug/{slug}
|
|
73
|
+
*/
|
|
74
|
+
function useTemplateBySlug(slug, options) {
|
|
75
|
+
return (0, react_query_1.useQuery)({
|
|
76
|
+
queryKey: exports.templateKeys.bySlug(slug),
|
|
77
|
+
queryFn: async () => {
|
|
78
|
+
const client = (0, client_1.getApiClient)();
|
|
79
|
+
const response = await client.get(`/api/v1/templates/slug/${slug}`);
|
|
80
|
+
return response.data.data;
|
|
81
|
+
},
|
|
82
|
+
enabled: !!slug,
|
|
83
|
+
...options,
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwaS9xdWVyaWVzL3RlbXBsYXRlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7OztHQU1HOzs7QUE2Qkgsb0NBaUJDO0FBT0Qsa0NBY0M7QUFPRCw4Q0FjQztBQXRGRCx1REFBa0Y7QUFDbEYsc0NBQXlDO0FBR3pDLCtFQUErRTtBQUMvRSxhQUFhO0FBQ2IsK0VBQStFO0FBRWxFLFFBQUEsWUFBWSxHQUFHO0lBQzFCLEdBQUcsRUFBRSxDQUFDLFdBQVcsQ0FBVTtJQUMzQixLQUFLLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxHQUFHLG9CQUFZLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBVTtJQUNuRCxJQUFJLEVBQUUsQ0FBQyxPQUErQixFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsb0JBQVksQ0FBQyxLQUFLLEVBQUUsRUFBRSxPQUFPLENBQVU7SUFDdEYsT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsR0FBRyxvQkFBWSxDQUFDLEdBQUcsRUFBRSxRQUFRLENBQVU7SUFDdkQsTUFBTSxFQUFFLENBQUMsRUFBVSxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsb0JBQVksQ0FBQyxPQUFPLEVBQUUsRUFBRSxFQUFFLENBQVU7SUFDaEUsTUFBTSxFQUFFLENBQUMsSUFBWSxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsb0JBQVksQ0FBQyxHQUFHLEVBQUUsTUFBTSxFQUFFLElBQUksQ0FBVTtDQUN2RSxDQUFDO0FBRUYsK0VBQStFO0FBQy9FLGNBQWM7QUFDZCwrRUFBK0U7QUFFL0U7Ozs7O0dBS0c7QUFDSCxTQUFnQixZQUFZLENBQzFCLE1BQThCLEVBQzlCLE9BQW1FO0lBRW5FLE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLG9CQUFZLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUNuQyxPQUFPLEVBQUUsS0FBSyxJQUF5QixFQUFFO1lBQ3ZDLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFDO1lBQzlCLE1BQU0sV0FBVyxHQUFHLElBQUksZUFBZSxFQUFFLENBQUM7WUFDMUMsSUFBSSxNQUFNLEVBQUUsUUFBUTtnQkFBRSxXQUFXLENBQUMsR0FBRyxDQUFDLFVBQVUsRUFBRSxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDbkUsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUEwQixxQkFBcUIsV0FBVyxFQUFFLENBQUMsQ0FBQztZQUMvRixzREFBc0Q7WUFDdEQsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztRQUM1QixDQUFDO1FBQ0QsU0FBUyxFQUFFLElBQUksR0FBRyxFQUFFLEdBQUcsRUFBRSxFQUFFLG9DQUFvQztRQUMvRCxHQUFHLE9BQU87S0FDWCxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLFdBQVcsQ0FDekIsVUFBa0IsRUFDbEIsT0FBaUU7SUFFakUsT0FBTyxJQUFBLHNCQUFRLEVBQUM7UUFDZCxRQUFRLEVBQUUsb0JBQVksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDO1FBQ3pDLE9BQU8sRUFBRSxLQUFLLElBQXVCLEVBQUU7WUFDckMsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUM7WUFDOUIsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUF3QixxQkFBcUIsVUFBVSxFQUFFLENBQUMsQ0FBQztZQUM1RixPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQzVCLENBQUM7UUFDRCxPQUFPLEVBQUUsQ0FBQyxDQUFDLFVBQVU7UUFDckIsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQixpQkFBaUIsQ0FDL0IsSUFBWSxFQUNaLE9BQWlFO0lBRWpFLE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLG9CQUFZLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQztRQUNuQyxPQUFPLEVBQUUsS0FBSyxJQUF1QixFQUFFO1lBQ3JDLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFDO1lBQzlCLE1BQU0sUUFBUSxHQUFHLE1BQU0sTUFBTSxDQUFDLEdBQUcsQ0FBd0IsMEJBQTBCLElBQUksRUFBRSxDQUFDLENBQUM7WUFDM0YsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztRQUM1QixDQUFDO1FBQ0QsT0FBTyxFQUFFLENBQUMsQ0FBQyxJQUFJO1FBQ2YsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVGVtcGxhdGVzIFF1ZXJ5IEhvb2tzXG4gKlxuICogVGFuU3RhY2sgUXVlcnkgaG9va3MgZm9yIHBvc3QgdGVtcGxhdGUgb3BlcmF0aW9ucy5cbiAqXG4gKiBUZW1wbGF0ZXMgYXJlIHJlZmVyZW5jZSBkYXRhIChmbGF0IGFycmF5KSwgbm90IHBhZ2luYXRlZC5cbiAqL1xuXG5pbXBvcnQgeyB1c2VRdWVyeSwgVXNlUXVlcnlPcHRpb25zLCBVc2VRdWVyeVJlc3VsdCB9IGZyb20gJ0B0YW5zdGFjay9yZWFjdC1xdWVyeSc7XG5pbXBvcnQgeyBnZXRBcGlDbGllbnQgfSBmcm9tICcuLi9jbGllbnQnO1xuaW1wb3J0IHR5cGUgeyBUZW1wbGF0ZSwgQXBpUmVzcG9uc2UgfSBmcm9tICcuLi90eXBlcyc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFFVRVJZIEtFWVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGNvbnN0IHRlbXBsYXRlS2V5cyA9IHtcbiAgYWxsOiBbJ3RlbXBsYXRlcyddIGFzIGNvbnN0LFxuICBsaXN0czogKCkgPT4gWy4uLnRlbXBsYXRlS2V5cy5hbGwsICdsaXN0J10gYXMgY29uc3QsXG4gIGxpc3Q6IChmaWx0ZXJzPzogeyBzcG90VHlwZT86IHN0cmluZyB9KSA9PiBbLi4udGVtcGxhdGVLZXlzLmxpc3RzKCksIGZpbHRlcnNdIGFzIGNvbnN0LFxuICBkZXRhaWxzOiAoKSA9PiBbLi4udGVtcGxhdGVLZXlzLmFsbCwgJ2RldGFpbCddIGFzIGNvbnN0LFxuICBkZXRhaWw6IChpZDogc3RyaW5nKSA9PiBbLi4udGVtcGxhdGVLZXlzLmRldGFpbHMoKSwgaWRdIGFzIGNvbnN0LFxuICBieVNsdWc6IChzbHVnOiBzdHJpbmcpID0+IFsuLi50ZW1wbGF0ZUtleXMuYWxsLCAnc2x1ZycsIHNsdWddIGFzIGNvbnN0LFxufTtcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gUVVFUlkgSE9PS1Ncbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBHZXQgYWxsIHRlbXBsYXRlcyAoZmxhdCBhcnJheSAtIHJlZmVyZW5jZSBkYXRhKVxuICpcbiAqIEBlbmRwb2ludCBHRVQgL2FwaS92MS90ZW1wbGF0ZXNcbiAqIEByZXR1cm5zIEZsYXQgYXJyYXkgb2YgdGVtcGxhdGVzIChub3QgcGFnaW5hdGVkKVxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlVGVtcGxhdGVzKFxuICBwYXJhbXM/OiB7IHNwb3RUeXBlPzogc3RyaW5nIH0sXG4gIG9wdGlvbnM/OiBPbWl0PFVzZVF1ZXJ5T3B0aW9uczxUZW1wbGF0ZVtdPiwgJ3F1ZXJ5S2V5JyB8ICdxdWVyeUZuJz5cbik6IFVzZVF1ZXJ5UmVzdWx0PFRlbXBsYXRlW10+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogdGVtcGxhdGVLZXlzLmxpc3QocGFyYW1zKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxUZW1wbGF0ZVtdPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHF1ZXJ5UGFyYW1zID0gbmV3IFVSTFNlYXJjaFBhcmFtcygpO1xuICAgICAgaWYgKHBhcmFtcz8uc3BvdFR5cGUpIHF1ZXJ5UGFyYW1zLnNldCgnc3BvdFR5cGUnLCBwYXJhbXMuc3BvdFR5cGUpO1xuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0PEFwaVJlc3BvbnNlPFRlbXBsYXRlW10+PihgL2FwaS92MS90ZW1wbGF0ZXM/JHtxdWVyeVBhcmFtc31gKTtcbiAgICAgIC8vIFRlbXBsYXRlcyBlbmRwb2ludCByZXR1cm5zIGZsYXQgYXJyYXk6IHsgZGF0YTogW10gfVxuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGEuZGF0YTtcbiAgICB9LFxuICAgIHN0YWxlVGltZTogMTAwMCAqIDYwICogNjAsIC8vIENhY2hlIGZvciAxIGhvdXIgKHJlZmVyZW5jZSBkYXRhKVxuICAgIC4uLm9wdGlvbnMsXG4gIH0pO1xufVxuXG4vKipcbiAqIEdldCBhIHRlbXBsYXRlIGJ5IElEXG4gKlxuICogQGVuZHBvaW50IEdFVCAvYXBpL3YxL3RlbXBsYXRlcy97dGVtcGxhdGVJZH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVRlbXBsYXRlKFxuICB0ZW1wbGF0ZUlkOiBzdHJpbmcsXG4gIG9wdGlvbnM/OiBPbWl0PFVzZVF1ZXJ5T3B0aW9uczxUZW1wbGF0ZT4sICdxdWVyeUtleScgfCAncXVlcnlGbic+XG4pOiBVc2VRdWVyeVJlc3VsdDxUZW1wbGF0ZT4ge1xuICByZXR1cm4gdXNlUXVlcnkoe1xuICAgIHF1ZXJ5S2V5OiB0ZW1wbGF0ZUtleXMuZGV0YWlsKHRlbXBsYXRlSWQpLFxuICAgIHF1ZXJ5Rm46IGFzeW5jICgpOiBQcm9taXNlPFRlbXBsYXRlPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldDxBcGlSZXNwb25zZTxUZW1wbGF0ZT4+KGAvYXBpL3YxL3RlbXBsYXRlcy8ke3RlbXBsYXRlSWR9YCk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhO1xuICAgIH0sXG4gICAgZW5hYmxlZDogISF0ZW1wbGF0ZUlkLFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pO1xufVxuXG4vKipcbiAqIEdldCBhIHRlbXBsYXRlIGJ5IHNsdWdcbiAqXG4gKiBAZW5kcG9pbnQgR0VUIC9hcGkvdjEvdGVtcGxhdGVzL3NsdWcve3NsdWd9XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VUZW1wbGF0ZUJ5U2x1ZyhcbiAgc2x1Zzogc3RyaW5nLFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8VGVtcGxhdGU+LCAncXVlcnlLZXknIHwgJ3F1ZXJ5Rm4nPlxuKTogVXNlUXVlcnlSZXN1bHQ8VGVtcGxhdGU+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogdGVtcGxhdGVLZXlzLmJ5U2x1ZyhzbHVnKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxUZW1wbGF0ZT4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KCk7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5nZXQ8QXBpUmVzcG9uc2U8VGVtcGxhdGU+PihgL2FwaS92MS90ZW1wbGF0ZXMvc2x1Zy8ke3NsdWd9YCk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhO1xuICAgIH0sXG4gICAgZW5hYmxlZDogISFzbHVnLFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pO1xufVxuIl19
|