@spotsdev/sdk 1.3.3 → 1.5.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 (64) hide show
  1. package/dist/index.cjs +2139 -0
  2. package/dist/index.cjs.map +1 -0
  3. package/dist/index.d.cts +1718 -0
  4. package/dist/index.d.ts +1717 -36
  5. package/dist/index.js +1996 -64
  6. package/dist/index.js.map +1 -0
  7. package/package.json +22 -6
  8. package/src/api/entities.ts +28 -84
  9. package/dist/api/client.d.ts +0 -12
  10. package/dist/api/client.js +0 -72
  11. package/dist/api/entities.d.ts +0 -326
  12. package/dist/api/entities.js +0 -9
  13. package/dist/api/mutations/clubs.d.ts +0 -47
  14. package/dist/api/mutations/clubs.js +0 -97
  15. package/dist/api/mutations/conversations.d.ts +0 -45
  16. package/dist/api/mutations/conversations.js +0 -114
  17. package/dist/api/mutations/index.d.ts +0 -14
  18. package/dist/api/mutations/index.js +0 -40
  19. package/dist/api/mutations/notifications.d.ts +0 -38
  20. package/dist/api/mutations/notifications.js +0 -64
  21. package/dist/api/mutations/orders.d.ts +0 -73
  22. package/dist/api/mutations/orders.js +0 -114
  23. package/dist/api/mutations/posts.d.ts +0 -123
  24. package/dist/api/mutations/posts.js +0 -242
  25. package/dist/api/mutations/products.d.ts +0 -81
  26. package/dist/api/mutations/products.js +0 -98
  27. package/dist/api/mutations/redemptions.d.ts +0 -33
  28. package/dist/api/mutations/redemptions.js +0 -63
  29. package/dist/api/mutations/spots.d.ts +0 -93
  30. package/dist/api/mutations/spots.js +0 -167
  31. package/dist/api/mutations/users.d.ts +0 -73
  32. package/dist/api/mutations/users.js +0 -175
  33. package/dist/api/queries/auth.d.ts +0 -37
  34. package/dist/api/queries/auth.js +0 -61
  35. package/dist/api/queries/clubs.d.ts +0 -52
  36. package/dist/api/queries/clubs.js +0 -116
  37. package/dist/api/queries/conversations.d.ts +0 -52
  38. package/dist/api/queries/conversations.js +0 -83
  39. package/dist/api/queries/index.d.ts +0 -28
  40. package/dist/api/queries/index.js +0 -69
  41. package/dist/api/queries/misc.d.ts +0 -30
  42. package/dist/api/queries/misc.js +0 -91
  43. package/dist/api/queries/notifications.d.ts +0 -34
  44. package/dist/api/queries/notifications.js +0 -62
  45. package/dist/api/queries/orders.d.ts +0 -45
  46. package/dist/api/queries/orders.js +0 -93
  47. package/dist/api/queries/posts.d.ts +0 -92
  48. package/dist/api/queries/posts.js +0 -233
  49. package/dist/api/queries/products.d.ts +0 -48
  50. package/dist/api/queries/products.js +0 -87
  51. package/dist/api/queries/spots.d.ts +0 -93
  52. package/dist/api/queries/spots.js +0 -250
  53. package/dist/api/queries/templates.d.ts +0 -39
  54. package/dist/api/queries/templates.js +0 -81
  55. package/dist/api/queries/users.d.ts +0 -104
  56. package/dist/api/queries/users.js +0 -235
  57. package/dist/api/queries/wallet.d.ts +0 -109
  58. package/dist/api/queries/wallet.js +0 -136
  59. package/dist/api/services/index.d.ts +0 -2
  60. package/dist/api/services/index.js +0 -8
  61. package/dist/api/services/marketplace.d.ts +0 -129
  62. package/dist/api/services/marketplace.js +0 -168
  63. package/dist/api/types.d.ts +0 -57
  64. package/dist/api/types.js +0 -33
@@ -1,233 +0,0 @@
1
- "use strict";
2
- /**
3
- * Posts Query Hooks
4
- *
5
- * TanStack Query hooks for post/board operations.
6
- */
7
- Object.defineProperty(exports, "__esModule", { value: true });
8
- exports.postKeys = void 0;
9
- exports.useSpotPosts = useSpotPosts;
10
- exports.usePost = usePost;
11
- exports.usePostResponses = usePostResponses;
12
- exports.usePosts = usePosts;
13
- exports.usePostStatus = usePostStatus;
14
- exports.usePostUpvotes = usePostUpvotes;
15
- exports.usePostsFeed = usePostsFeed;
16
- const react_query_1 = require("@tanstack/react-query");
17
- const client_1 = require("../client");
18
- // ============================================================================
19
- // HELPER FUNCTIONS
20
- // ============================================================================
21
- /**
22
- * Extract array data from API response
23
- * API returns { success, data: { data: [...], meta: {...} } } or { success, data: [...] }
24
- */
25
- function extractArrayData(data) {
26
- // If already an array, return it
27
- if (Array.isArray(data)) {
28
- return data;
29
- }
30
- // If it's an object with nested data property, extract it
31
- if (data && typeof data === 'object' && 'data' in data) {
32
- const nested = data.data;
33
- if (Array.isArray(nested)) {
34
- return nested;
35
- }
36
- }
37
- return [];
38
- }
39
- /**
40
- * Extract single object data from API response
41
- * API returns { success, data: { data: {...} } } or { success, data: {...} }
42
- */
43
- function extractObjectData(data) {
44
- // If it's an object with nested data property (not an array), extract it
45
- if (data &&
46
- typeof data === 'object' &&
47
- 'data' in data &&
48
- !Array.isArray(data)) {
49
- const nested = data.data;
50
- // Check if nested also has a data property (double-wrapped)
51
- if (nested &&
52
- typeof nested === 'object' &&
53
- 'data' in nested &&
54
- !Array.isArray(nested)) {
55
- return nested.data;
56
- }
57
- return nested;
58
- }
59
- return data;
60
- }
61
- // ============================================================================
62
- // QUERY KEYS
63
- // ============================================================================
64
- exports.postKeys = {
65
- all: ['posts'],
66
- lists: () => [...exports.postKeys.all, 'list'],
67
- list: (filters) => [...exports.postKeys.lists(), filters],
68
- bySpot: (spotId, filters) => [...exports.postKeys.all, 'spot', spotId, filters],
69
- details: () => [...exports.postKeys.all, 'detail'],
70
- detail: (id) => [...exports.postKeys.details(), id],
71
- responses: (postId) => [...exports.postKeys.detail(postId), 'responses'],
72
- status: (postId) => [...exports.postKeys.detail(postId), 'status'],
73
- upvotes: (postId, filters) => [...exports.postKeys.detail(postId), 'upvotes', filters],
74
- };
75
- // ============================================================================
76
- // QUERY HOOKS
77
- // ============================================================================
78
- /**
79
- * Get posts for a spot
80
- *
81
- * @endpoint GET /spots/{spotId}/posts
82
- */
83
- function useSpotPosts(spotId, params, options) {
84
- return (0, react_query_1.useQuery)({
85
- queryKey: exports.postKeys.bySpot(spotId, params),
86
- queryFn: async () => {
87
- const client = (0, client_1.getApiClient)();
88
- const queryParams = new URLSearchParams();
89
- if (params?.postType)
90
- queryParams.set('postType', params.postType);
91
- if (params?.status)
92
- queryParams.set('status', params.status);
93
- if (params?.page)
94
- queryParams.set('page', String(params.page));
95
- if (params?.limit)
96
- queryParams.set('limit', String(params.limit));
97
- const response = await client.get(`/spots/${spotId}/posts?${queryParams}`);
98
- return extractArrayData(response.data.data);
99
- },
100
- enabled: !!spotId,
101
- ...options,
102
- });
103
- }
104
- /**
105
- * Get a single post by ID
106
- *
107
- * @endpoint GET /posts/{postId}
108
- */
109
- function usePost(postId, options) {
110
- return (0, react_query_1.useQuery)({
111
- queryKey: exports.postKeys.detail(postId),
112
- queryFn: async () => {
113
- const client = (0, client_1.getApiClient)();
114
- const response = await client.get(`/posts/${postId}`);
115
- return extractObjectData(response.data.data);
116
- },
117
- enabled: !!postId,
118
- ...options,
119
- });
120
- }
121
- /**
122
- * Get responses for a post
123
- *
124
- * @endpoint GET /posts/{postId}/responses
125
- */
126
- function usePostResponses(postId, options) {
127
- return (0, react_query_1.useQuery)({
128
- queryKey: exports.postKeys.responses(postId),
129
- queryFn: async () => {
130
- const client = (0, client_1.getApiClient)();
131
- const response = await client.get(`/posts/${postId}/responses`);
132
- return extractArrayData(response.data.data);
133
- },
134
- enabled: !!postId,
135
- ...options,
136
- });
137
- }
138
- /**
139
- * Get all posts (with filters)
140
- *
141
- * @endpoint GET /posts
142
- */
143
- function usePosts(params, options) {
144
- return (0, react_query_1.useQuery)({
145
- queryKey: exports.postKeys.list(params),
146
- queryFn: async () => {
147
- const client = (0, client_1.getApiClient)();
148
- const queryParams = new URLSearchParams();
149
- if (params?.postType)
150
- queryParams.set('postType', params.postType);
151
- if (params?.limit)
152
- queryParams.set('limit', String(params.limit));
153
- const response = await client.get(`/posts?${queryParams}`);
154
- return extractArrayData(response.data.data);
155
- },
156
- ...options,
157
- });
158
- }
159
- /**
160
- * Get user's status for a post (read/hidden/pinned)
161
- *
162
- * @endpoint GET /posts/{postId}/status
163
- */
164
- function usePostStatus(postId, options) {
165
- return (0, react_query_1.useQuery)({
166
- queryKey: exports.postKeys.status(postId),
167
- queryFn: async () => {
168
- const client = (0, client_1.getApiClient)();
169
- const response = await client.get(`/posts/${postId}/status`);
170
- return extractObjectData(response.data.data);
171
- },
172
- enabled: !!postId,
173
- ...options,
174
- });
175
- }
176
- /**
177
- * Get upvotes for a post (list of users who upvoted)
178
- *
179
- * @endpoint GET /posts/{postId}/upvotes
180
- */
181
- function usePostUpvotes(postId, params, options) {
182
- return (0, react_query_1.useQuery)({
183
- queryKey: exports.postKeys.upvotes(postId, params),
184
- queryFn: async () => {
185
- const client = (0, client_1.getApiClient)();
186
- const queryParams = new URLSearchParams();
187
- if (params?.limit)
188
- queryParams.set('limit', String(params.limit));
189
- if (params?.offset)
190
- queryParams.set('offset', String(params.offset));
191
- const queryString = queryParams.toString();
192
- const response = await client.get(`/posts/${postId}/upvotes${queryString ? `?${queryString}` : ''}`);
193
- // Response structure: { success, data: { data: [...], meta: {...} } }
194
- return response.data.data;
195
- },
196
- enabled: !!postId,
197
- ...options,
198
- });
199
- }
200
- /**
201
- * Get nearby posts feed
202
- *
203
- * @endpoint GET /posts/feed
204
- */
205
- function usePostsFeed(params, options) {
206
- return (0, react_query_1.useQuery)({
207
- queryKey: [...exports.postKeys.lists(), 'feed', params],
208
- queryFn: async () => {
209
- const client = (0, client_1.getApiClient)();
210
- const queryParams = new URLSearchParams();
211
- queryParams.set('lat', String(params.lat));
212
- queryParams.set('lng', String(params.lng));
213
- if (params.radius)
214
- queryParams.set('radius', String(params.radius));
215
- if (params.postType)
216
- queryParams.set('postType', params.postType);
217
- if (params.cursor)
218
- queryParams.set('cursor', params.cursor);
219
- if (params.limit)
220
- queryParams.set('limit', String(params.limit));
221
- const response = await client.get(`/posts/feed?${queryParams}`);
222
- const data = response.data.data;
223
- return {
224
- posts: data.posts ?? extractArrayData(data),
225
- hasMore: data.hasMore ?? false,
226
- nextCursor: data.nextCursor,
227
- };
228
- },
229
- enabled: params.lat !== 0 && params.lng !== 0,
230
- ...options,
231
- });
232
- }
233
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"posts.js","sourceRoot":"","sources":["../../../src/api/queries/posts.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;;AAgGH,oCAsBC;AAOD,0BAgBC;AAOD,4CAgBC;AAOD,4BAkBC;AAOD,sCAgBC;AAOD,wCAsBC;AAOD,oCA4CC;AAlSD,uDAI8B;AAE9B,sCAAsC;AAStC,+EAA+E;AAC/E,mBAAmB;AACnB,+EAA+E;AAE/E;;;GAGG;AACH,SAAS,gBAAgB,CAAI,IAAa;IACxC,iCAAiC;IACjC,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;QACxB,OAAO,IAAI,CAAA;IACb,CAAC;IACD,0DAA0D;IAC1D,IAAI,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,MAAM,IAAI,IAAI,EAAE,CAAC;QACvD,MAAM,MAAM,GAAI,IAAwB,CAAC,IAAI,CAAA;QAC7C,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YAC1B,OAAO,MAAM,CAAA;QACf,CAAC;IACH,CAAC;IACD,OAAO,EAAE,CAAA;AACX,CAAC;AAED;;;GAGG;AACH,SAAS,iBAAiB,CAAI,IAAa;IACzC,yEAAyE;IACzE,IACE,IAAI;QACJ,OAAO,IAAI,KAAK,QAAQ;QACxB,MAAM,IAAI,IAAI;QACd,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EACpB,CAAC;QACD,MAAM,MAAM,GAAI,IAAwB,CAAC,IAAI,CAAA;QAC7C,4DAA4D;QAC5D,IACE,MAAM;YACN,OAAO,MAAM,KAAK,QAAQ;YAC1B,MAAM,IAAI,MAAM;YAChB,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EACtB,CAAC;YACD,OAAQ,MAAoB,CAAC,IAAI,CAAA;QACnC,CAAC;QACD,OAAO,MAAW,CAAA;IACpB,CAAC;IACD,OAAO,IAAS,CAAA;AAClB,CAAC;AAED,+EAA+E;AAC/E,aAAa;AACb,+EAA+E;AAElE,QAAA,QAAQ,GAAG;IACtB,GAAG,EAAE,CAAC,OAAO,CAAU;IACvB,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,gBAAQ,CAAC,GAAG,EAAE,MAAM,CAAU;IAC/C,IAAI,EAAE,CAAC,OAAiC,EAAE,EAAE,CAC1C,CAAC,GAAG,gBAAQ,CAAC,KAAK,EAAE,EAAE,OAAO,CAAU;IACzC,MAAM,EAAE,CAAC,MAAc,EAAE,OAAiC,EAAE,EAAE,CAC5D,CAAC,GAAG,gBAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAU;IACrD,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,gBAAQ,CAAC,GAAG,EAAE,QAAQ,CAAU;IACnD,MAAM,EAAE,CAAC,EAAU,EAAE,EAAE,CAAC,CAAC,GAAG,gBAAQ,CAAC,OAAO,EAAE,EAAE,EAAE,CAAU;IAC5D,SAAS,EAAE,CAAC,MAAc,EAAE,EAAE,CAC5B,CAAC,GAAG,gBAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,WAAW,CAAU;IACpD,MAAM,EAAE,CAAC,MAAc,EAAE,EAAE,CAAC,CAAC,GAAG,gBAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,QAAQ,CAAU;IAC3E,OAAO,EAAE,CAAC,MAAc,EAAE,OAA2C,EAAE,EAAE,CACvE,CAAC,GAAG,gBAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,SAAS,EAAE,OAAO,CAAU;CAC5D,CAAA;AAED,+EAA+E;AAC/E,cAAc;AACd,+EAA+E;AAE/E;;;;GAIG;AACH,SAAgB,YAAY,CAC1B,MAAc,EACd,MAA4E,EAC5E,OAA+D;IAE/D,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,gBAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC;QACzC,OAAO,EAAE,KAAK,IAAqB,EAAE;YACnC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAA;YAC7B,MAAM,WAAW,GAAG,IAAI,eAAe,EAAE,CAAA;YACzC,IAAI,MAAM,EAAE,QAAQ;gBAAE,WAAW,CAAC,GAAG,CAAC,UAAU,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAA;YAClE,IAAI,MAAM,EAAE,MAAM;gBAAE,WAAW,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,CAAA;YAC5D,IAAI,MAAM,EAAE,IAAI;gBAAE,WAAW,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAA;YAC9D,IAAI,MAAM,EAAE,KAAK;gBAAE,WAAW,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;YACjE,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,UAAU,MAAM,UAAU,WAAW,EAAE,CACxC,CAAA;YACD,OAAO,gBAAgB,CAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACnD,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,MAAM;QACjB,GAAG,OAAO;KACX,CAAC,CAAA;AACJ,CAAC;AAED;;;;GAIG;AACH,SAAgB,OAAO,CACrB,MAAc,EACd,OAA6D;IAE7D,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,gBAAQ,CAAC,MAAM,CAAC,MAAM,CAAC;QACjC,OAAO,EAAE,KAAK,IAAmB,EAAE;YACjC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAA;YAC7B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,UAAU,MAAM,EAAE,CACnB,CAAA;YACD,OAAO,iBAAiB,CAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACpD,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,MAAM;QACjB,GAAG,OAAO;KACX,CAAC,CAAA;AACJ,CAAC;AAED;;;;GAIG;AACH,SAAgB,gBAAgB,CAC9B,MAAc,EACd,OAAuE;IAEvE,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,gBAAQ,CAAC,SAAS,CAAC,MAAM,CAAC;QACpC,OAAO,EAAE,KAAK,IAA6B,EAAE;YAC3C,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAA;YAC7B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,UAAU,MAAM,YAAY,CAC7B,CAAA;YACD,OAAO,gBAAgB,CAAe,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAC3D,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,MAAM;QACjB,GAAG,OAAO;KACX,CAAC,CAAA;AACJ,CAAC;AAED;;;;GAIG;AACH,SAAgB,QAAQ,CACtB,MAA4C,EAC5C,OAA+D;IAE/D,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,gBAAQ,CAAC,IAAI,CAAC,MAAM,CAAC;QAC/B,OAAO,EAAE,KAAK,IAAqB,EAAE;YACnC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAA;YAC7B,MAAM,WAAW,GAAG,IAAI,eAAe,EAAE,CAAA;YACzC,IAAI,MAAM,EAAE,QAAQ;gBAAE,WAAW,CAAC,GAAG,CAAC,UAAU,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAA;YAClE,IAAI,MAAM,EAAE,KAAK;gBAAE,WAAW,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;YACjE,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,UAAU,WAAW,EAAE,CACxB,CAAA;YACD,OAAO,gBAAgB,CAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACnD,CAAC;QACD,GAAG,OAAO;KACX,CAAC,CAAA;AACJ,CAAC;AAED;;;;GAIG;AACH,SAAgB,aAAa,CAC3B,MAAc,EACd,OAAsE;IAEtE,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,gBAAQ,CAAC,MAAM,CAAC,MAAM,CAAC;QACjC,OAAO,EAAE,KAAK,IAA4B,EAAE;YAC1C,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAA;YAC7B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,UAAU,MAAM,SAAS,CAC1B,CAAA;YACD,OAAO,iBAAiB,CAAgB,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAC7D,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,MAAM;QACjB,GAAG,OAAO;KACX,CAAC,CAAA;AACJ,CAAC;AAED;;;;GAIG;AACH,SAAgB,cAAc,CAC5B,MAAc,EACd,MAA0C,EAC1C,OAA4E;IAE5E,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,gBAAQ,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC;QAC1C,OAAO,EAAE,KAAK,IAAkC,EAAE;YAChD,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAA;YAC7B,MAAM,WAAW,GAAG,IAAI,eAAe,EAAE,CAAA;YACzC,IAAI,MAAM,EAAE,KAAK;gBAAE,WAAW,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;YACjE,IAAI,MAAM,EAAE,MAAM;gBAAE,WAAW,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAA;YACpE,MAAM,WAAW,GAAG,WAAW,CAAC,QAAQ,EAAE,CAAA;YAC1C,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,UAAU,MAAM,WAAW,WAAW,CAAC,CAAC,CAAC,IAAI,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAClE,CAAA;YACD,sEAAsE;YACtE,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAA;QAC3B,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,MAAM;QACjB,GAAG,OAAO;KACX,CAAC,CAAA;AACJ,CAAC;AAED;;;;GAIG;AACH,SAAgB,YAAY,CAC1B,MAOC,EACD,OAGC;IAED,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,CAAC,GAAG,gBAAQ,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,MAAM,CAAU;QACxD,OAAO,EAAE,KAAK,IAIX,EAAE;YACH,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAA;YAC7B,MAAM,WAAW,GAAG,IAAI,eAAe,EAAE,CAAA;YACzC,WAAW,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAA;YAC1C,WAAW,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAA;YAC1C,IAAI,MAAM,CAAC,MAAM;gBAAE,WAAW,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAA;YACnE,IAAI,MAAM,CAAC,QAAQ;gBAAE,WAAW,CAAC,GAAG,CAAC,UAAU,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAA;YACjE,IAAI,MAAM,CAAC,MAAM;gBAAE,WAAW,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,CAAA;YAC3D,IAAI,MAAM,CAAC,KAAK;gBAAE,WAAW,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;YAEhE,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAE/B,eAAe,WAAW,EAAE,CAAC,CAAA;YAE/B,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAA;YAC/B,OAAO;gBACL,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,gBAAgB,CAAO,IAAI,CAAC;gBACjD,OAAO,EAAE,IAAI,CAAC,OAAO,IAAI,KAAK;gBAC9B,UAAU,EAAE,IAAI,CAAC,UAAU;aAC5B,CAAA;QACH,CAAC;QACD,OAAO,EAAE,MAAM,CAAC,GAAG,KAAK,CAAC,IAAI,MAAM,CAAC,GAAG,KAAK,CAAC;QAC7C,GAAG,OAAO;KACX,CAAC,CAAA;AACJ,CAAC","sourcesContent":["/**\n * Posts Query Hooks\n *\n * TanStack Query hooks for post/board operations.\n */\n\nimport {\n  useQuery,\n  type UseQueryOptions,\n  type UseQueryResult,\n} from '@tanstack/react-query'\n\nimport {getApiClient} from '../client'\nimport {\n  type ApiResponse,\n  type Post,\n  type PostResponse,\n  type PostStatusDto,\n  type PostUpvotesResponse,\n} from '../types'\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Extract array data from API response\n * API returns { success, data: { data: [...], meta: {...} } } or { success, data: [...] }\n */\nfunction extractArrayData<T>(data: unknown): T[] {\n  // If already an array, return it\n  if (Array.isArray(data)) {\n    return data\n  }\n  // If it's an object with nested data property, extract it\n  if (data && typeof data === 'object' && 'data' in data) {\n    const nested = (data as {data: unknown}).data\n    if (Array.isArray(nested)) {\n      return nested\n    }\n  }\n  return []\n}\n\n/**\n * Extract single object data from API response\n * API returns { success, data: { data: {...} } } or { success, data: {...} }\n */\nfunction extractObjectData<T>(data: unknown): T {\n  // If it's an object with nested data property (not an array), extract it\n  if (\n    data &&\n    typeof data === 'object' &&\n    'data' in data &&\n    !Array.isArray(data)\n  ) {\n    const nested = (data as {data: unknown}).data\n    // Check if nested also has a data property (double-wrapped)\n    if (\n      nested &&\n      typeof nested === 'object' &&\n      'data' in nested &&\n      !Array.isArray(nested)\n    ) {\n      return (nested as {data: T}).data\n    }\n    return nested as T\n  }\n  return data as T\n}\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const postKeys = {\n  all: ['posts'] as const,\n  lists: () => [...postKeys.all, 'list'] as const,\n  list: (filters?: Record<string, unknown>) =>\n    [...postKeys.lists(), filters] as const,\n  bySpot: (spotId: string, filters?: Record<string, unknown>) =>\n    [...postKeys.all, 'spot', spotId, filters] as const,\n  details: () => [...postKeys.all, 'detail'] as const,\n  detail: (id: string) => [...postKeys.details(), id] as const,\n  responses: (postId: string) =>\n    [...postKeys.detail(postId), 'responses'] as const,\n  status: (postId: string) => [...postKeys.detail(postId), 'status'] as const,\n  upvotes: (postId: string, filters?: {limit?: number; offset?: number}) =>\n    [...postKeys.detail(postId), 'upvotes', filters] as const,\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get posts for a spot\n *\n * @endpoint GET /spots/{spotId}/posts\n */\nexport function useSpotPosts(\n  spotId: string,\n  params?: {postType?: string; status?: string; page?: number; limit?: number},\n  options?: Omit<UseQueryOptions<Post[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Post[]> {\n  return useQuery({\n    queryKey: postKeys.bySpot(spotId, params),\n    queryFn: async (): Promise<Post[]> => {\n      const client = getApiClient()\n      const queryParams = new URLSearchParams()\n      if (params?.postType) queryParams.set('postType', params.postType)\n      if (params?.status) queryParams.set('status', params.status)\n      if (params?.page) queryParams.set('page', String(params.page))\n      if (params?.limit) queryParams.set('limit', String(params.limit))\n      const response = await client.get<ApiResponse<unknown>>(\n        `/spots/${spotId}/posts?${queryParams}`,\n      )\n      return extractArrayData<Post>(response.data.data)\n    },\n    enabled: !!spotId,\n    ...options,\n  })\n}\n\n/**\n * Get a single post by ID\n *\n * @endpoint GET /posts/{postId}\n */\nexport function usePost(\n  postId: string,\n  options?: Omit<UseQueryOptions<Post>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Post> {\n  return useQuery({\n    queryKey: postKeys.detail(postId),\n    queryFn: async (): Promise<Post> => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<unknown>>(\n        `/posts/${postId}`,\n      )\n      return extractObjectData<Post>(response.data.data)\n    },\n    enabled: !!postId,\n    ...options,\n  })\n}\n\n/**\n * Get responses for a post\n *\n * @endpoint GET /posts/{postId}/responses\n */\nexport function usePostResponses(\n  postId: string,\n  options?: Omit<UseQueryOptions<PostResponse[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<PostResponse[]> {\n  return useQuery({\n    queryKey: postKeys.responses(postId),\n    queryFn: async (): Promise<PostResponse[]> => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<unknown>>(\n        `/posts/${postId}/responses`,\n      )\n      return extractArrayData<PostResponse>(response.data.data)\n    },\n    enabled: !!postId,\n    ...options,\n  })\n}\n\n/**\n * Get all posts (with filters)\n *\n * @endpoint GET /posts\n */\nexport function usePosts(\n  params?: {postType?: string; limit?: number},\n  options?: Omit<UseQueryOptions<Post[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Post[]> {\n  return useQuery({\n    queryKey: postKeys.list(params),\n    queryFn: async (): Promise<Post[]> => {\n      const client = getApiClient()\n      const queryParams = new URLSearchParams()\n      if (params?.postType) queryParams.set('postType', params.postType)\n      if (params?.limit) queryParams.set('limit', String(params.limit))\n      const response = await client.get<ApiResponse<unknown>>(\n        `/posts?${queryParams}`,\n      )\n      return extractArrayData<Post>(response.data.data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Get user's status for a post (read/hidden/pinned)\n *\n * @endpoint GET /posts/{postId}/status\n */\nexport function usePostStatus(\n  postId: string,\n  options?: Omit<UseQueryOptions<PostStatusDto>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<PostStatusDto> {\n  return useQuery({\n    queryKey: postKeys.status(postId),\n    queryFn: async (): Promise<PostStatusDto> => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<unknown>>(\n        `/posts/${postId}/status`,\n      )\n      return extractObjectData<PostStatusDto>(response.data.data)\n    },\n    enabled: !!postId,\n    ...options,\n  })\n}\n\n/**\n * Get upvotes for a post (list of users who upvoted)\n *\n * @endpoint GET /posts/{postId}/upvotes\n */\nexport function usePostUpvotes(\n  postId: string,\n  params?: {limit?: number; offset?: number},\n  options?: Omit<UseQueryOptions<PostUpvotesResponse>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<PostUpvotesResponse> {\n  return useQuery({\n    queryKey: postKeys.upvotes(postId, params),\n    queryFn: async (): Promise<PostUpvotesResponse> => {\n      const client = getApiClient()\n      const queryParams = new URLSearchParams()\n      if (params?.limit) queryParams.set('limit', String(params.limit))\n      if (params?.offset) queryParams.set('offset', String(params.offset))\n      const queryString = queryParams.toString()\n      const response = await client.get<ApiResponse<PostUpvotesResponse>>(\n        `/posts/${postId}/upvotes${queryString ? `?${queryString}` : ''}`,\n      )\n      // Response structure: { success, data: { data: [...], meta: {...} } }\n      return response.data.data\n    },\n    enabled: !!postId,\n    ...options,\n  })\n}\n\n/**\n * Get nearby posts feed\n *\n * @endpoint GET /posts/feed\n */\nexport function usePostsFeed(\n  params: {\n    lat: number\n    lng: number\n    radius?: number\n    postType?: string\n    cursor?: string\n    limit?: number\n  },\n  options?: Omit<\n    UseQueryOptions<{posts: Post[]; hasMore: boolean; nextCursor?: string}>,\n    'queryKey' | 'queryFn'\n  >,\n): UseQueryResult<{posts: Post[]; hasMore: boolean; nextCursor?: string}> {\n  return useQuery({\n    queryKey: [...postKeys.lists(), 'feed', params] as const,\n    queryFn: async (): Promise<{\n      posts: Post[]\n      hasMore: boolean\n      nextCursor?: string\n    }> => {\n      const client = getApiClient()\n      const queryParams = new URLSearchParams()\n      queryParams.set('lat', String(params.lat))\n      queryParams.set('lng', String(params.lng))\n      if (params.radius) queryParams.set('radius', String(params.radius))\n      if (params.postType) queryParams.set('postType', params.postType)\n      if (params.cursor) queryParams.set('cursor', params.cursor)\n      if (params.limit) queryParams.set('limit', String(params.limit))\n\n      const response = await client.get<\n        ApiResponse<{posts: Post[]; hasMore: boolean; nextCursor?: string}>\n      >(`/posts/feed?${queryParams}`)\n\n      const data = response.data.data\n      return {\n        posts: data.posts ?? extractArrayData<Post>(data),\n        hasMore: data.hasMore ?? false,\n        nextCursor: data.nextCursor,\n      }\n    },\n    enabled: params.lat !== 0 && params.lng !== 0,\n    ...options,\n  })\n}\n"]}
@@ -1,48 +0,0 @@
1
- /**
2
- * Products Query Hooks
3
- *
4
- * TanStack Query hooks for product-related operations.
5
- */
6
- import { type UseQueryOptions, type UseQueryResult } from '@tanstack/react-query';
7
- import type { Product, PaginatedResponse, ProductType, ProductStatus, Spot } from '../types';
8
- export declare const productKeys: {
9
- all: readonly ["products"];
10
- lists: () => readonly ["products", "list"];
11
- list: (filters?: Record<string, unknown>) => readonly ["products", "list", Record<string, unknown> | undefined];
12
- details: () => readonly ["products", "detail"];
13
- detail: (id: string) => readonly ["products", "detail", string];
14
- bySlug: (spotId: string, slug: string) => readonly ["products", "slug", string, string];
15
- bySpot: (spotId: string) => readonly ["products", "spot", string];
16
- };
17
- export interface ProductFilters {
18
- spotId?: string;
19
- type?: ProductType;
20
- status?: ProductStatus;
21
- limit?: number;
22
- page?: number;
23
- }
24
- export interface ProductWithSpot extends Product {
25
- spot: Pick<Spot, 'id' | 'name' | 'slug'>;
26
- }
27
- /**
28
- * Get products for a spot (public browse)
29
- *
30
- * @endpoint GET /spots/{spotId}/products
31
- */
32
- export declare function useSpotProducts(spotId: string, params?: {
33
- type?: ProductType;
34
- limit?: number;
35
- page?: number;
36
- }, options?: Omit<UseQueryOptions<PaginatedResponse<Product>>, 'queryKey' | 'queryFn'>): UseQueryResult<PaginatedResponse<Product>>;
37
- /**
38
- * Get a product by ID
39
- *
40
- * @endpoint GET /products/{productId}
41
- */
42
- export declare function useProduct(productId: string, options?: Omit<UseQueryOptions<ProductWithSpot>, 'queryKey' | 'queryFn'>): UseQueryResult<ProductWithSpot>;
43
- /**
44
- * Get a product by slug (within a spot)
45
- *
46
- * @endpoint GET /spots/{spotId}/products/slug/{slug}
47
- */
48
- export declare function useProductBySlug(spotId: string, slug: string, options?: Omit<UseQueryOptions<ProductWithSpot>, 'queryKey' | 'queryFn'>): UseQueryResult<ProductWithSpot>;
@@ -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>;