@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.
Files changed (67) hide show
  1. package/dist/index.cjs +2166 -0
  2. package/dist/index.cjs.map +1 -0
  3. package/dist/index.d.cts +1656 -0
  4. package/dist/index.d.ts +1655 -36
  5. package/dist/index.js +2021 -64
  6. package/dist/index.js.map +1 -0
  7. package/package.json +22 -6
  8. package/src/api/entities.ts +171 -170
  9. package/src/api/mutations/products.ts +18 -2
  10. package/src/api/queries/index.ts +4 -0
  11. package/src/api/queries/payments.ts +67 -0
  12. package/dist/api/client.d.ts +0 -12
  13. package/dist/api/client.js +0 -72
  14. package/dist/api/entities.d.ts +0 -305
  15. package/dist/api/entities.js +0 -13
  16. package/dist/api/mutations/clubs.d.ts +0 -47
  17. package/dist/api/mutations/clubs.js +0 -97
  18. package/dist/api/mutations/conversations.d.ts +0 -45
  19. package/dist/api/mutations/conversations.js +0 -114
  20. package/dist/api/mutations/index.d.ts +0 -14
  21. package/dist/api/mutations/index.js +0 -40
  22. package/dist/api/mutations/notifications.d.ts +0 -38
  23. package/dist/api/mutations/notifications.js +0 -64
  24. package/dist/api/mutations/orders.d.ts +0 -73
  25. package/dist/api/mutations/orders.js +0 -114
  26. package/dist/api/mutations/posts.d.ts +0 -123
  27. package/dist/api/mutations/posts.js +0 -242
  28. package/dist/api/mutations/products.d.ts +0 -81
  29. package/dist/api/mutations/products.js +0 -98
  30. package/dist/api/mutations/redemptions.d.ts +0 -33
  31. package/dist/api/mutations/redemptions.js +0 -63
  32. package/dist/api/mutations/spots.d.ts +0 -93
  33. package/dist/api/mutations/spots.js +0 -167
  34. package/dist/api/mutations/users.d.ts +0 -73
  35. package/dist/api/mutations/users.js +0 -175
  36. package/dist/api/queries/auth.d.ts +0 -37
  37. package/dist/api/queries/auth.js +0 -61
  38. package/dist/api/queries/clubs.d.ts +0 -52
  39. package/dist/api/queries/clubs.js +0 -116
  40. package/dist/api/queries/conversations.d.ts +0 -52
  41. package/dist/api/queries/conversations.js +0 -83
  42. package/dist/api/queries/index.d.ts +0 -28
  43. package/dist/api/queries/index.js +0 -69
  44. package/dist/api/queries/misc.d.ts +0 -30
  45. package/dist/api/queries/misc.js +0 -91
  46. package/dist/api/queries/notifications.d.ts +0 -34
  47. package/dist/api/queries/notifications.js +0 -62
  48. package/dist/api/queries/orders.d.ts +0 -45
  49. package/dist/api/queries/orders.js +0 -93
  50. package/dist/api/queries/posts.d.ts +0 -92
  51. package/dist/api/queries/posts.js +0 -233
  52. package/dist/api/queries/products.d.ts +0 -48
  53. package/dist/api/queries/products.js +0 -87
  54. package/dist/api/queries/spots.d.ts +0 -93
  55. package/dist/api/queries/spots.js +0 -250
  56. package/dist/api/queries/templates.d.ts +0 -39
  57. package/dist/api/queries/templates.js +0 -81
  58. package/dist/api/queries/users.d.ts +0 -104
  59. package/dist/api/queries/users.js +0 -235
  60. package/dist/api/queries/wallet.d.ts +0 -109
  61. package/dist/api/queries/wallet.js +0 -136
  62. package/dist/api/services/index.d.ts +0 -2
  63. package/dist/api/services/index.js +0 -8
  64. package/dist/api/services/marketplace.d.ts +0 -129
  65. package/dist/api/services/marketplace.js +0 -168
  66. package/dist/api/types.d.ts +0 -57
  67. package/dist/api/types.js +0 -33
@@ -1,87 +0,0 @@
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 /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(`/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 /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(`/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 /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(`/spots/${spotId}/products/slug/${slug}`);
81
- return response.data.data;
82
- },
83
- enabled: !!spotId && !!slug,
84
- ...options,
85
- });
86
- }
87
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.js","sourceRoot":"","sources":["../../../src/api/queries/products.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Products Query Hooks\n *\n * TanStack Query hooks for product-related operations.\n */\n\nimport {useQuery, type UseQueryOptions, type UseQueryResult} from '@tanstack/react-query'\nimport {getApiClient} from '../client'\nimport type {\n  Product,\n  ApiResponse,\n  PaginatedResponse,\n  ProductType,\n  ProductStatus,\n  Spot,\n} 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>) =>\n    [...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) =>\n    [...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: Pick<Spot, 'id' | 'name' | 'slug'>\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get products for a spot (public browse)\n *\n * @endpoint GET /spots/{spotId}/products\n */\nexport function useSpotProducts(\n  spotId: string,\n  params?: {type?: ProductType; limit?: number; page?: number},\n  options?: Omit<\n    UseQueryOptions<PaginatedResponse<Product>>,\n    'queryKey' | 'queryFn'\n  >,\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        `/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 /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>>(\n        `/products/${productId}`,\n      )\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 /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        `/spots/${spotId}/products/slug/${slug}`,\n      )\n      return response.data.data\n    },\n    enabled: !!spotId && !!slug,\n    ...options,\n  })\n}\n"]}
@@ -1,93 +0,0 @@
1
- /**
2
- * Spots Query Hooks
3
- *
4
- * TanStack Query hooks for spot-related operations.
5
- */
6
- import { type UseQueryOptions, type UseQueryResult, type UseInfiniteQueryOptions, type UseInfiniteQueryResult } from '@tanstack/react-query';
7
- import { type PaginatedResponse, type Spot, type SpotImage } 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
20
- *
21
- * @endpoint GET /spots
22
- */
23
- export declare function useSpots(params?: {
24
- limit?: number;
25
- city?: string;
26
- type?: string;
27
- lat?: number;
28
- lng?: number;
29
- radius?: number;
30
- search?: string;
31
- vibes?: string;
32
- cityId?: string;
33
- page?: number;
34
- }, options?: Omit<UseQueryOptions<Spot[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Spot[]>;
35
- /**
36
- * Get a spot by ID
37
- *
38
- * @endpoint GET /spots/{spotId}
39
- */
40
- export declare function useSpot(spotId: string, options?: Omit<UseQueryOptions<Spot>, 'queryKey' | 'queryFn'>): UseQueryResult<Spot>;
41
- /**
42
- * Get a spot by slug
43
- *
44
- * @endpoint GET /spots/slug/{slug}
45
- */
46
- export declare function useSpotBySlug(slug: string, options?: Omit<UseQueryOptions<Spot>, 'queryKey' | 'queryFn'>): UseQueryResult<Spot>;
47
- /**
48
- * Get a spot by QR code
49
- *
50
- * @endpoint GET /spots/qr/{qrCode}
51
- */
52
- export declare function useSpotByQR(qrCode: string, options?: Omit<UseQueryOptions<Spot>, 'queryKey' | 'queryFn'>): UseQueryResult<Spot>;
53
- /**
54
- * Get images for a spot
55
- *
56
- * @endpoint GET /spots/{spotId}/images
57
- */
58
- export declare function useSpotImages(spotId: string, options?: Omit<UseQueryOptions<SpotImage[]>, 'queryKey' | 'queryFn'>): UseQueryResult<SpotImage[]>;
59
- /**
60
- * Check if a spot is favorited by the current user
61
- *
62
- * @endpoint GET /spots/{spotId}/favorite
63
- */
64
- export declare function useSpotFavoriteStatus(spotId: string, options?: Omit<UseQueryOptions<{
65
- isFavorite: boolean;
66
- }>, 'queryKey' | 'queryFn'>): UseQueryResult<{
67
- isFavorite: boolean;
68
- }>;
69
- /**
70
- * Params for infinite spots query
71
- */
72
- export interface InfiniteSpotsParams {
73
- limit?: number;
74
- city?: string;
75
- cityId?: string;
76
- type?: string;
77
- templateSlugs?: string[];
78
- vibeIds?: string[];
79
- search?: string;
80
- }
81
- /**
82
- * Infinite scroll query for spots
83
- *
84
- * @endpoint GET /spots (paginated)
85
- * @returns Infinite query with pages of spots
86
- */
87
- export declare function useInfiniteSpots(params?: InfiniteSpotsParams, options?: Omit<UseInfiniteQueryOptions<PaginatedResponse<Spot>, Error, {
88
- pages: PaginatedResponse<Spot>[];
89
- pageParams: number[];
90
- }>, 'queryKey' | 'queryFn' | 'getNextPageParam' | 'initialPageParam'>): UseInfiniteQueryResult<{
91
- pages: PaginatedResponse<Spot>[];
92
- pageParams: number[];
93
- }, Error>;
@@ -1,250 +0,0 @@
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.useSpotFavoriteStatus = useSpotFavoriteStatus;
15
- exports.useInfiniteSpots = useInfiniteSpots;
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 (Array.isArray(data)) {
27
- return data;
28
- }
29
- if (data && typeof data === 'object' && 'data' in data) {
30
- const nested = data.data;
31
- if (Array.isArray(nested)) {
32
- return nested;
33
- }
34
- }
35
- return [];
36
- }
37
- /**
38
- * Extract single object data from API response
39
- */
40
- function extractObjectData(data) {
41
- if (data &&
42
- typeof data === 'object' &&
43
- 'data' in data &&
44
- !Array.isArray(data)) {
45
- const nested = data.data;
46
- if (nested &&
47
- typeof nested === 'object' &&
48
- 'data' in nested &&
49
- !Array.isArray(nested)) {
50
- return nested.data;
51
- }
52
- return nested;
53
- }
54
- return data;
55
- }
56
- // ============================================================================
57
- // QUERY KEYS
58
- // ============================================================================
59
- exports.spotKeys = {
60
- all: ['spots'],
61
- lists: () => [...exports.spotKeys.all, 'list'],
62
- list: (filters) => [...exports.spotKeys.lists(), filters],
63
- details: () => [...exports.spotKeys.all, 'detail'],
64
- detail: (id) => [...exports.spotKeys.details(), id],
65
- bySlug: (slug) => [...exports.spotKeys.all, 'slug', slug],
66
- byQR: (qrCode) => [...exports.spotKeys.all, 'qr', qrCode],
67
- images: (spotId) => [...exports.spotKeys.detail(spotId), 'images'],
68
- };
69
- // ============================================================================
70
- // QUERY HOOKS
71
- // ============================================================================
72
- /**
73
- * Get all spots
74
- *
75
- * @endpoint GET /spots
76
- */
77
- function useSpots(params, options) {
78
- return (0, react_query_1.useQuery)({
79
- queryKey: exports.spotKeys.list(params),
80
- queryFn: async () => {
81
- const client = (0, client_1.getApiClient)();
82
- const queryParams = new URLSearchParams();
83
- if (params?.limit)
84
- queryParams.set('limit', String(params.limit));
85
- if (params?.city)
86
- queryParams.set('city', params.city);
87
- if (params?.type)
88
- queryParams.set('type', params.type);
89
- if (params?.lat)
90
- queryParams.set('lat', String(params.lat));
91
- if (params?.lng)
92
- queryParams.set('lng', String(params.lng));
93
- if (params?.radius)
94
- queryParams.set('radius', String(params.radius));
95
- if (params?.search)
96
- queryParams.set('search', params.search);
97
- if (params?.vibes)
98
- queryParams.set('vibeIds', params.vibes);
99
- if (params?.cityId)
100
- queryParams.set('cityId', params.cityId);
101
- if (params?.page)
102
- queryParams.set('page', String(params.page));
103
- const response = await client.get(`/spots?${queryParams}`);
104
- return extractArrayData(response.data.data);
105
- },
106
- ...options,
107
- });
108
- }
109
- /**
110
- * Get a spot by ID
111
- *
112
- * @endpoint GET /spots/{spotId}
113
- */
114
- function useSpot(spotId, options) {
115
- return (0, react_query_1.useQuery)({
116
- queryKey: exports.spotKeys.detail(spotId),
117
- queryFn: async () => {
118
- const client = (0, client_1.getApiClient)();
119
- const response = await client.get(`/spots/${spotId}`);
120
- return extractObjectData(response.data.data);
121
- },
122
- enabled: !!spotId,
123
- ...options,
124
- });
125
- }
126
- /**
127
- * Get a spot by slug
128
- *
129
- * @endpoint GET /spots/slug/{slug}
130
- */
131
- function useSpotBySlug(slug, options) {
132
- return (0, react_query_1.useQuery)({
133
- queryKey: exports.spotKeys.bySlug(slug),
134
- queryFn: async () => {
135
- const client = (0, client_1.getApiClient)();
136
- const response = await client.get(`/spots/slug/${slug}`);
137
- return extractObjectData(response.data.data);
138
- },
139
- enabled: !!slug,
140
- ...options,
141
- });
142
- }
143
- /**
144
- * Get a spot by QR code
145
- *
146
- * @endpoint GET /spots/qr/{qrCode}
147
- */
148
- function useSpotByQR(qrCode, options) {
149
- return (0, react_query_1.useQuery)({
150
- queryKey: exports.spotKeys.byQR(qrCode),
151
- queryFn: async () => {
152
- const client = (0, client_1.getApiClient)();
153
- const response = await client.get(`/spots/qr/${qrCode}`);
154
- return extractObjectData(response.data.data);
155
- },
156
- enabled: !!qrCode,
157
- ...options,
158
- });
159
- }
160
- /**
161
- * Get images for a spot
162
- *
163
- * @endpoint GET /spots/{spotId}/images
164
- */
165
- function useSpotImages(spotId, options) {
166
- return (0, react_query_1.useQuery)({
167
- queryKey: exports.spotKeys.images(spotId),
168
- queryFn: async () => {
169
- const client = (0, client_1.getApiClient)();
170
- const response = await client.get(`/spots/${spotId}/images`);
171
- return extractArrayData(response.data.data);
172
- },
173
- enabled: !!spotId,
174
- ...options,
175
- });
176
- }
177
- /**
178
- * Check if a spot is favorited by the current user
179
- *
180
- * @endpoint GET /spots/{spotId}/favorite
181
- */
182
- function useSpotFavoriteStatus(spotId, options) {
183
- return (0, react_query_1.useQuery)({
184
- queryKey: [...exports.spotKeys.detail(spotId), 'favorite'],
185
- queryFn: async () => {
186
- const client = (0, client_1.getApiClient)();
187
- const response = await client.get(`/spots/${spotId}/favorite`);
188
- return extractObjectData(response.data.data);
189
- },
190
- enabled: !!spotId,
191
- ...options,
192
- });
193
- }
194
- /**
195
- * Infinite scroll query for spots
196
- *
197
- * @endpoint GET /spots (paginated)
198
- * @returns Infinite query with pages of spots
199
- */
200
- function useInfiniteSpots(params, options) {
201
- return (0, react_query_1.useInfiniteQuery)({
202
- queryKey: [...exports.spotKeys.lists(), 'infinite', params],
203
- queryFn: async ({ pageParam = 1 }) => {
204
- const client = (0, client_1.getApiClient)();
205
- const queryParams = new URLSearchParams();
206
- queryParams.set('page', String(pageParam));
207
- if (params?.limit)
208
- queryParams.set('limit', String(params.limit));
209
- if (params?.city)
210
- queryParams.set('city', params.city);
211
- if (params?.cityId)
212
- queryParams.set('cityId', params.cityId);
213
- if (params?.type && params.type !== 'All')
214
- queryParams.set('type', params.type);
215
- if (params?.search?.trim())
216
- queryParams.set('search', params.search.trim());
217
- if (params?.templateSlugs) {
218
- params.templateSlugs.forEach((slug) => queryParams.append('templateSlugs', slug));
219
- }
220
- if (params?.vibeIds) {
221
- params.vibeIds.forEach((id) => queryParams.append('vibeIds', id));
222
- }
223
- const response = await client.get(`/spots?${queryParams}`);
224
- // Handle nested response structure
225
- const data = response.data.data;
226
- if (data && typeof data === 'object' && 'data' in data) {
227
- return data;
228
- }
229
- // Fallback for array response
230
- const page = pageParam;
231
- return {
232
- data: extractArrayData(data),
233
- meta: {
234
- total: 0,
235
- page,
236
- limit: params?.limit || 20,
237
- totalPages: 1,
238
- hasNextPage: false,
239
- hasPreviousPage: page > 1,
240
- },
241
- };
242
- },
243
- initialPageParam: 1,
244
- getNextPageParam: (lastPage) => {
245
- return lastPage.meta.hasNextPage ? lastPage.meta.page + 1 : undefined;
246
- },
247
- ...options,
248
- });
249
- }
250
- //# 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 {\n  useQuery,\n  useInfiniteQuery,\n  type UseQueryOptions,\n  type UseQueryResult,\n  type UseInfiniteQueryOptions,\n  type UseInfiniteQueryResult,\n} from '@tanstack/react-query'\n\nimport {getApiClient} from '../client'\nimport {type ApiResponse, type PaginatedResponse, type Spot, type SpotImage} 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 (Array.isArray(data)) {\n    return data\n  }\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 */\nfunction extractObjectData<T>(data: unknown): T {\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    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 spotKeys = {\n  all: ['spots'] as const,\n  lists: () => [...spotKeys.all, 'list'] as const,\n  list: (filters?: Record<string, unknown>) =>\n    [...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\n *\n * @endpoint GET /spots\n */\nexport function useSpots(\n  params?: {\n    limit?: number\n    city?: string\n    type?: string\n    lat?: number\n    lng?: number\n    radius?: number\n    search?: string\n    vibes?: string\n    cityId?: string\n    page?: number\n  },\n  options?: Omit<UseQueryOptions<Spot[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Spot[]> {\n  return useQuery({\n    queryKey: spotKeys.list(params),\n    queryFn: async (): Promise<Spot[]> => {\n      const client = getApiClient()\n      const queryParams = new URLSearchParams()\n      if (params?.limit) queryParams.set('limit', String(params.limit))\n      if (params?.city) queryParams.set('city', params.city)\n      if (params?.type) queryParams.set('type', params.type)\n      if (params?.lat) queryParams.set('lat', String(params.lat))\n      if (params?.lng) queryParams.set('lng', String(params.lng))\n      if (params?.radius) queryParams.set('radius', String(params.radius))\n      if (params?.search) queryParams.set('search', params.search)\n      if (params?.vibes) queryParams.set('vibeIds', params.vibes)\n      if (params?.cityId) queryParams.set('cityId', params.cityId)\n      if (params?.page) queryParams.set('page', String(params.page))\n      const response = await client.get<ApiResponse<unknown>>(\n        `/spots?${queryParams}`,\n      )\n      return extractArrayData<Spot>(response.data.data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Get a spot by ID\n *\n * @endpoint GET /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<unknown>>(\n        `/spots/${spotId}`,\n      )\n      return extractObjectData<Spot>(response.data.data)\n    },\n    enabled: !!spotId,\n    ...options,\n  })\n}\n\n/**\n * Get a spot by slug\n *\n * @endpoint GET /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<unknown>>(\n        `/spots/slug/${slug}`,\n      )\n      return extractObjectData<Spot>(response.data.data)\n    },\n    enabled: !!slug,\n    ...options,\n  })\n}\n\n/**\n * Get a spot by QR code\n *\n * @endpoint GET /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<unknown>>(\n        `/spots/qr/${qrCode}`,\n      )\n      return extractObjectData<Spot>(response.data.data)\n    },\n    enabled: !!qrCode,\n    ...options,\n  })\n}\n\n/**\n * Get images for a spot\n *\n * @endpoint GET /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<unknown>>(\n        `/spots/${spotId}/images`,\n      )\n      return extractArrayData<SpotImage>(response.data.data)\n    },\n    enabled: !!spotId,\n    ...options,\n  })\n}\n\n/**\n * Check if a spot is favorited by the current user\n *\n * @endpoint GET /spots/{spotId}/favorite\n */\nexport function useSpotFavoriteStatus(\n  spotId: string,\n  options?: Omit<\n    UseQueryOptions<{isFavorite: boolean}>,\n    'queryKey' | 'queryFn'\n  >,\n): UseQueryResult<{isFavorite: boolean}> {\n  return useQuery({\n    queryKey: [...spotKeys.detail(spotId), 'favorite'] as const,\n    queryFn: async (): Promise<{isFavorite: boolean}> => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<{isFavorite: boolean}>>(\n        `/spots/${spotId}/favorite`,\n      )\n      return extractObjectData<{isFavorite: boolean}>(response.data.data)\n    },\n    enabled: !!spotId,\n    ...options,\n  })\n}\n\n// ============================================================================\n// INFINITE QUERY HOOKS\n// ============================================================================\n\n/**\n * Params for infinite spots query\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\n/**\n * Infinite scroll query for spots\n *\n * @endpoint GET /spots (paginated)\n * @returns Infinite query with pages of spots\n */\nexport function useInfiniteSpots(\n  params?: InfiniteSpotsParams,\n  options?: Omit<\n    UseInfiniteQueryOptions<\n      PaginatedResponse<Spot>,\n      Error,\n      {pages: PaginatedResponse<Spot>[]; pageParams: number[]}\n    >,\n    'queryKey' | 'queryFn' | 'getNextPageParam' | 'initialPageParam'\n  >,\n): UseInfiniteQueryResult<\n  {pages: PaginatedResponse<Spot>[]; pageParams: number[]},\n  Error\n> {\n  return useInfiniteQuery({\n    queryKey: [...spotKeys.lists(), 'infinite', params] as const,\n    queryFn: async ({pageParam = 1}): 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')\n        queryParams.set('type', params.type)\n      if (params?.search?.trim())\n        queryParams.set('search', params.search.trim())\n      if (params?.templateSlugs) {\n        params.templateSlugs.forEach((slug) =>\n          queryParams.append('templateSlugs', slug),\n        )\n      }\n      if (params?.vibeIds) {\n        params.vibeIds.forEach((id) => queryParams.append('vibeIds', id))\n      }\n      const response = await client.get<ApiResponse<PaginatedResponse<Spot>>>(\n        `/spots?${queryParams}`,\n      )\n      // Handle nested response structure\n      const data = response.data.data\n      if (data && typeof data === 'object' && 'data' in data) {\n        return data as PaginatedResponse<Spot>\n      }\n      // Fallback for array response\n      const page = pageParam as number\n      return {\n        data: extractArrayData<Spot>(data),\n        meta: {\n          total: 0,\n          page,\n          limit: params?.limit || 20,\n          totalPages: 1,\n          hasNextPage: false,\n          hasPreviousPage: page > 1,\n        },\n      }\n    },\n    initialPageParam: 1,\n    getNextPageParam: (lastPage) => {\n      return lastPage.meta.hasNextPage ? lastPage.meta.page + 1 : undefined\n    },\n    ...options,\n  })\n}\n"]}
@@ -1,39 +0,0 @@
1
- /**
2
- * Templates Query Hooks
3
- *
4
- * TanStack Query hooks for post template operations.
5
- */
6
- import { type UseQueryOptions, type UseQueryResult } from '@tanstack/react-query';
7
- import { type Template } from '../types';
8
- export declare const templateKeys: {
9
- all: readonly ["templates"];
10
- lists: () => readonly ["templates", "list"];
11
- list: (filters?: {
12
- spotType?: string;
13
- }) => readonly ["templates", "list", {
14
- spotType?: string;
15
- } | undefined];
16
- details: () => readonly ["templates", "detail"];
17
- detail: (id: string) => readonly ["templates", "detail", string];
18
- bySlug: (slug: string) => readonly ["templates", "slug", string];
19
- };
20
- /**
21
- * Get all templates
22
- *
23
- * @endpoint GET /templates
24
- */
25
- export declare function useTemplates(params?: {
26
- spotType?: string;
27
- }, options?: Omit<UseQueryOptions<Template[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Template[]>;
28
- /**
29
- * Get a template by ID
30
- *
31
- * @endpoint GET /templates/{templateId}
32
- */
33
- export declare function useTemplate(templateId: string, options?: Omit<UseQueryOptions<Template>, 'queryKey' | 'queryFn'>): UseQueryResult<Template>;
34
- /**
35
- * Get a template by slug
36
- *
37
- * @endpoint GET /templates/slug/{slug}
38
- */
39
- export declare function useTemplateBySlug(slug: string, options?: Omit<UseQueryOptions<Template>, 'queryKey' | 'queryFn'>): UseQueryResult<Template>;
@@ -1,81 +0,0 @@
1
- "use strict";
2
- /**
3
- * Templates Query Hooks
4
- *
5
- * TanStack Query hooks for post template operations.
6
- */
7
- Object.defineProperty(exports, "__esModule", { value: true });
8
- exports.templateKeys = void 0;
9
- exports.useTemplates = useTemplates;
10
- exports.useTemplate = useTemplate;
11
- exports.useTemplateBySlug = useTemplateBySlug;
12
- const react_query_1 = require("@tanstack/react-query");
13
- const client_1 = require("../client");
14
- // ============================================================================
15
- // QUERY KEYS
16
- // ============================================================================
17
- exports.templateKeys = {
18
- all: ['templates'],
19
- lists: () => [...exports.templateKeys.all, 'list'],
20
- list: (filters) => [...exports.templateKeys.lists(), filters],
21
- details: () => [...exports.templateKeys.all, 'detail'],
22
- detail: (id) => [...exports.templateKeys.details(), id],
23
- bySlug: (slug) => [...exports.templateKeys.all, 'slug', slug],
24
- };
25
- // ============================================================================
26
- // QUERY HOOKS
27
- // ============================================================================
28
- /**
29
- * Get all templates
30
- *
31
- * @endpoint GET /templates
32
- */
33
- function useTemplates(params, options) {
34
- return (0, react_query_1.useQuery)({
35
- queryKey: exports.templateKeys.list(params),
36
- queryFn: async () => {
37
- const client = (0, client_1.getApiClient)();
38
- const queryParams = new URLSearchParams();
39
- if (params?.spotType)
40
- queryParams.set('spotType', params.spotType);
41
- const response = await client.get(`/templates?${queryParams}`);
42
- return response.data.data;
43
- },
44
- ...options,
45
- });
46
- }
47
- /**
48
- * Get a template by ID
49
- *
50
- * @endpoint GET /templates/{templateId}
51
- */
52
- function useTemplate(templateId, options) {
53
- return (0, react_query_1.useQuery)({
54
- queryKey: exports.templateKeys.detail(templateId),
55
- queryFn: async () => {
56
- const client = (0, client_1.getApiClient)();
57
- const response = await client.get(`/templates/${templateId}`);
58
- return response.data.data;
59
- },
60
- enabled: !!templateId,
61
- ...options,
62
- });
63
- }
64
- /**
65
- * Get a template by slug
66
- *
67
- * @endpoint GET /templates/slug/{slug}
68
- */
69
- function useTemplateBySlug(slug, options) {
70
- return (0, react_query_1.useQuery)({
71
- queryKey: exports.templateKeys.bySlug(slug),
72
- queryFn: async () => {
73
- const client = (0, client_1.getApiClient)();
74
- const response = await client.get(`/templates/slug/${slug}`);
75
- return response.data.data;
76
- },
77
- enabled: !!slug,
78
- ...options,
79
- });
80
- }
81
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwaS9xdWVyaWVzL3RlbXBsYXRlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7R0FJRzs7O0FBa0NILG9DQWlCQztBQU9ELGtDQWdCQztBQU9ELDhDQWdCQztBQS9GRCx1REFJOEI7QUFFOUIsc0NBQXNDO0FBR3RDLCtFQUErRTtBQUMvRSxhQUFhO0FBQ2IsK0VBQStFO0FBRWxFLFFBQUEsWUFBWSxHQUFHO0lBQzFCLEdBQUcsRUFBRSxDQUFDLFdBQVcsQ0FBVTtJQUMzQixLQUFLLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxHQUFHLG9CQUFZLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBVTtJQUNuRCxJQUFJLEVBQUUsQ0FBQyxPQUE2QixFQUFFLEVBQUUsQ0FDdEMsQ0FBQyxHQUFHLG9CQUFZLENBQUMsS0FBSyxFQUFFLEVBQUUsT0FBTyxDQUFVO0lBQzdDLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLEdBQUcsb0JBQVksQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFVO0lBQ3ZELE1BQU0sRUFBRSxDQUFDLEVBQVUsRUFBRSxFQUFFLENBQUMsQ0FBQyxHQUFHLG9CQUFZLENBQUMsT0FBTyxFQUFFLEVBQUUsRUFBRSxDQUFVO0lBQ2hFLE1BQU0sRUFBRSxDQUFDLElBQVksRUFBRSxFQUFFLENBQUMsQ0FBQyxHQUFHLG9CQUFZLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQVU7Q0FDdkUsQ0FBQTtBQUVELCtFQUErRTtBQUMvRSxjQUFjO0FBQ2QsK0VBQStFO0FBRS9FOzs7O0dBSUc7QUFDSCxTQUFnQixZQUFZLENBQzFCLE1BQTRCLEVBQzVCLE9BQW1FO0lBRW5FLE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLG9CQUFZLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUNuQyxPQUFPLEVBQUUsS0FBSyxJQUF5QixFQUFFO1lBQ3ZDLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFBO1lBQzdCLE1BQU0sV0FBVyxHQUFHLElBQUksZUFBZSxFQUFFLENBQUE7WUFDekMsSUFBSSxNQUFNLEVBQUUsUUFBUTtnQkFBRSxXQUFXLENBQUMsR0FBRyxDQUFDLFVBQVUsRUFBRSxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUE7WUFDbEUsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUMvQixjQUFjLFdBQVcsRUFBRSxDQUM1QixDQUFBO1lBQ0QsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQTtRQUMzQixDQUFDO1FBQ0QsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFBO0FBQ0osQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQixXQUFXLENBQ3pCLFVBQWtCLEVBQ2xCLE9BQWlFO0lBRWpFLE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLG9CQUFZLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQztRQUN6QyxPQUFPLEVBQUUsS0FBSyxJQUF1QixFQUFFO1lBQ3JDLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFBO1lBQzdCLE1BQU0sUUFBUSxHQUFHLE1BQU0sTUFBTSxDQUFDLEdBQUcsQ0FDL0IsY0FBYyxVQUFVLEVBQUUsQ0FDM0IsQ0FBQTtZQUNELE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUE7UUFDM0IsQ0FBQztRQUNELE9BQU8sRUFBRSxDQUFDLENBQUMsVUFBVTtRQUNyQixHQUFHLE9BQU87S0FDWCxDQUFDLENBQUE7QUFDSixDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLGlCQUFpQixDQUMvQixJQUFZLEVBQ1osT0FBaUU7SUFFakUsT0FBTyxJQUFBLHNCQUFRLEVBQUM7UUFDZCxRQUFRLEVBQUUsb0JBQVksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDO1FBQ25DLE9BQU8sRUFBRSxLQUFLLElBQXVCLEVBQUU7WUFDckMsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUE7WUFDN0IsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUMvQixtQkFBbUIsSUFBSSxFQUFFLENBQzFCLENBQUE7WUFDRCxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFBO1FBQzNCLENBQUM7UUFDRCxPQUFPLEVBQUUsQ0FBQyxDQUFDLElBQUk7UUFDZixHQUFHLE9BQU87S0FDWCxDQUFDLENBQUE7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBUZW1wbGF0ZXMgUXVlcnkgSG9va3NcbiAqXG4gKiBUYW5TdGFjayBRdWVyeSBob29rcyBmb3IgcG9zdCB0ZW1wbGF0ZSBvcGVyYXRpb25zLlxuICovXG5cbmltcG9ydCB7XG4gIHVzZVF1ZXJ5LFxuICB0eXBlIFVzZVF1ZXJ5T3B0aW9ucyxcbiAgdHlwZSBVc2VRdWVyeVJlc3VsdCxcbn0gZnJvbSAnQHRhbnN0YWNrL3JlYWN0LXF1ZXJ5J1xuXG5pbXBvcnQge2dldEFwaUNsaWVudH0gZnJvbSAnLi4vY2xpZW50J1xuaW1wb3J0IHt0eXBlIEFwaVJlc3BvbnNlLCB0eXBlIFRlbXBsYXRlfSBmcm9tICcuLi90eXBlcydcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gUVVFUlkgS0VZU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5leHBvcnQgY29uc3QgdGVtcGxhdGVLZXlzID0ge1xuICBhbGw6IFsndGVtcGxhdGVzJ10gYXMgY29uc3QsXG4gIGxpc3RzOiAoKSA9PiBbLi4udGVtcGxhdGVLZXlzLmFsbCwgJ2xpc3QnXSBhcyBjb25zdCxcbiAgbGlzdDogKGZpbHRlcnM/OiB7c3BvdFR5cGU/OiBzdHJpbmd9KSA9PlxuICAgIFsuLi50ZW1wbGF0ZUtleXMubGlzdHMoKSwgZmlsdGVyc10gYXMgY29uc3QsXG4gIGRldGFpbHM6ICgpID0+IFsuLi50ZW1wbGF0ZUtleXMuYWxsLCAnZGV0YWlsJ10gYXMgY29uc3QsXG4gIGRldGFpbDogKGlkOiBzdHJpbmcpID0+IFsuLi50ZW1wbGF0ZUtleXMuZGV0YWlscygpLCBpZF0gYXMgY29uc3QsXG4gIGJ5U2x1ZzogKHNsdWc6IHN0cmluZykgPT4gWy4uLnRlbXBsYXRlS2V5cy5hbGwsICdzbHVnJywgc2x1Z10gYXMgY29uc3QsXG59XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFFVRVJZIEhPT0tTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogR2V0IGFsbCB0ZW1wbGF0ZXNcbiAqXG4gKiBAZW5kcG9pbnQgR0VUIC90ZW1wbGF0ZXNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVRlbXBsYXRlcyhcbiAgcGFyYW1zPzoge3Nwb3RUeXBlPzogc3RyaW5nfSxcbiAgb3B0aW9ucz86IE9taXQ8VXNlUXVlcnlPcHRpb25zPFRlbXBsYXRlW10+LCAncXVlcnlLZXknIHwgJ3F1ZXJ5Rm4nPixcbik6IFVzZVF1ZXJ5UmVzdWx0PFRlbXBsYXRlW10+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogdGVtcGxhdGVLZXlzLmxpc3QocGFyYW1zKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxUZW1wbGF0ZVtdPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKVxuICAgICAgY29uc3QgcXVlcnlQYXJhbXMgPSBuZXcgVVJMU2VhcmNoUGFyYW1zKClcbiAgICAgIGlmIChwYXJhbXM/LnNwb3RUeXBlKSBxdWVyeVBhcmFtcy5zZXQoJ3Nwb3RUeXBlJywgcGFyYW1zLnNwb3RUeXBlKVxuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0PEFwaVJlc3BvbnNlPFRlbXBsYXRlW10+PihcbiAgICAgICAgYC90ZW1wbGF0ZXM/JHtxdWVyeVBhcmFtc31gLFxuICAgICAgKVxuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGEuZGF0YVxuICAgIH0sXG4gICAgLi4ub3B0aW9ucyxcbiAgfSlcbn1cblxuLyoqXG4gKiBHZXQgYSB0ZW1wbGF0ZSBieSBJRFxuICpcbiAqIEBlbmRwb2ludCBHRVQgL3RlbXBsYXRlcy97dGVtcGxhdGVJZH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVRlbXBsYXRlKFxuICB0ZW1wbGF0ZUlkOiBzdHJpbmcsXG4gIG9wdGlvbnM/OiBPbWl0PFVzZVF1ZXJ5T3B0aW9uczxUZW1wbGF0ZT4sICdxdWVyeUtleScgfCAncXVlcnlGbic+LFxuKTogVXNlUXVlcnlSZXN1bHQ8VGVtcGxhdGU+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogdGVtcGxhdGVLZXlzLmRldGFpbCh0ZW1wbGF0ZUlkKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxUZW1wbGF0ZT4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KClcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldDxBcGlSZXNwb25zZTxUZW1wbGF0ZT4+KFxuICAgICAgICBgL3RlbXBsYXRlcy8ke3RlbXBsYXRlSWR9YCxcbiAgICAgIClcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhLmRhdGFcbiAgICB9LFxuICAgIGVuYWJsZWQ6ICEhdGVtcGxhdGVJZCxcbiAgICAuLi5vcHRpb25zLFxuICB9KVxufVxuXG4vKipcbiAqIEdldCBhIHRlbXBsYXRlIGJ5IHNsdWdcbiAqXG4gKiBAZW5kcG9pbnQgR0VUIC90ZW1wbGF0ZXMvc2x1Zy97c2x1Z31cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVRlbXBsYXRlQnlTbHVnKFxuICBzbHVnOiBzdHJpbmcsXG4gIG9wdGlvbnM/OiBPbWl0PFVzZVF1ZXJ5T3B0aW9uczxUZW1wbGF0ZT4sICdxdWVyeUtleScgfCAncXVlcnlGbic+LFxuKTogVXNlUXVlcnlSZXN1bHQ8VGVtcGxhdGU+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogdGVtcGxhdGVLZXlzLmJ5U2x1ZyhzbHVnKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxUZW1wbGF0ZT4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KClcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldDxBcGlSZXNwb25zZTxUZW1wbGF0ZT4+KFxuICAgICAgICBgL3RlbXBsYXRlcy9zbHVnLyR7c2x1Z31gLFxuICAgICAgKVxuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGEuZGF0YVxuICAgIH0sXG4gICAgZW5hYmxlZDogISFzbHVnLFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pXG59XG4iXX0=