@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.
Files changed (79) hide show
  1. package/dist/api/client.d.ts +12 -0
  2. package/dist/api/client.js +68 -0
  3. package/dist/api/mutations/clubs.d.ts +47 -0
  4. package/dist/api/mutations/clubs.js +95 -0
  5. package/dist/api/mutations/conversations.d.ts +45 -0
  6. package/dist/api/mutations/conversations.js +110 -0
  7. package/dist/api/mutations/index.d.ts +13 -0
  8. package/dist/api/mutations/index.js +38 -0
  9. package/dist/api/mutations/notifications.d.ts +38 -0
  10. package/dist/api/mutations/notifications.js +64 -0
  11. package/dist/api/mutations/orders.d.ts +73 -0
  12. package/dist/api/mutations/orders.js +116 -0
  13. package/dist/api/mutations/posts.d.ts +123 -0
  14. package/dist/api/mutations/posts.js +229 -0
  15. package/dist/api/mutations/products.d.ts +81 -0
  16. package/dist/api/mutations/products.js +102 -0
  17. package/dist/api/mutations/spots.d.ts +59 -0
  18. package/dist/api/mutations/spots.js +129 -0
  19. package/dist/api/mutations/users.d.ts +71 -0
  20. package/dist/api/mutations/users.js +173 -0
  21. package/dist/api/queries/auth.d.ts +37 -0
  22. package/dist/api/queries/auth.js +61 -0
  23. package/dist/api/queries/clubs.d.ts +52 -0
  24. package/dist/api/queries/clubs.js +116 -0
  25. package/dist/api/queries/conversations.d.ts +52 -0
  26. package/dist/api/queries/conversations.js +83 -0
  27. package/dist/api/queries/index.d.ts +26 -0
  28. package/dist/api/queries/index.js +65 -0
  29. package/dist/api/queries/misc.d.ts +54 -0
  30. package/dist/api/queries/misc.js +129 -0
  31. package/dist/api/queries/notifications.d.ts +34 -0
  32. package/dist/api/queries/notifications.js +62 -0
  33. package/dist/api/queries/orders.d.ts +45 -0
  34. package/dist/api/queries/orders.js +93 -0
  35. package/dist/api/queries/posts.d.ts +55 -0
  36. package/dist/api/queries/posts.js +130 -0
  37. package/dist/api/queries/products.d.ts +52 -0
  38. package/dist/api/queries/products.js +89 -0
  39. package/dist/api/queries/spots.d.ts +78 -0
  40. package/dist/api/queries/spots.js +168 -0
  41. package/dist/api/queries/templates.d.ts +42 -0
  42. package/dist/api/queries/templates.js +86 -0
  43. package/dist/api/queries/users.d.ts +90 -0
  44. package/dist/api/queries/users.js +187 -0
  45. package/dist/api/services/index.d.ts +2 -0
  46. package/dist/api/services/index.js +8 -0
  47. package/dist/api/services/marketplace.d.ts +129 -0
  48. package/dist/api/services/marketplace.js +168 -0
  49. package/dist/api/types.d.ts +54 -0
  50. package/dist/api/types.js +34 -0
  51. package/dist/index.d.ts +38 -0
  52. package/dist/index.js +73 -0
  53. package/package.json +57 -0
  54. package/src/api/client.ts +78 -0
  55. package/src/api/mutations/clubs.ts +107 -0
  56. package/src/api/mutations/conversations.ts +124 -0
  57. package/src/api/mutations/index.ts +29 -0
  58. package/src/api/mutations/notifications.ts +70 -0
  59. package/src/api/mutations/orders.ts +174 -0
  60. package/src/api/mutations/posts.ts +278 -0
  61. package/src/api/mutations/products.ts +160 -0
  62. package/src/api/mutations/spots.ts +146 -0
  63. package/src/api/mutations/users.ts +197 -0
  64. package/src/api/queries/auth.ts +67 -0
  65. package/src/api/queries/clubs.ts +135 -0
  66. package/src/api/queries/conversations.ts +94 -0
  67. package/src/api/queries/index.ts +48 -0
  68. package/src/api/queries/misc.ts +140 -0
  69. package/src/api/queries/notifications.ts +66 -0
  70. package/src/api/queries/orders.ts +119 -0
  71. package/src/api/queries/posts.ts +142 -0
  72. package/src/api/queries/products.ts +123 -0
  73. package/src/api/queries/spots.ts +201 -0
  74. package/src/api/queries/templates.ts +95 -0
  75. package/src/api/queries/users.ts +206 -0
  76. package/src/api/services/index.ts +6 -0
  77. package/src/api/services/marketplace.ts +265 -0
  78. package/src/api/types.ts +144 -0
  79. 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":"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","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