@growsober/sdk 1.0.5 → 1.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/__tests__/e2e.test.d.ts +30 -0
- package/dist/__tests__/e2e.test.js +959 -63
- package/dist/api/mutations/badges.d.ts +116 -0
- package/dist/api/mutations/badges.js +177 -0
- package/dist/api/mutations/brands.d.ts +251 -0
- package/dist/api/mutations/brands.js +242 -0
- package/dist/api/mutations/creators.d.ts +131 -0
- package/dist/api/mutations/creators.js +129 -0
- package/dist/api/mutations/event-chat.d.ts +2 -2
- package/dist/api/mutations/event-chat.js +9 -9
- package/dist/api/mutations/index.d.ts +4 -0
- package/dist/api/mutations/index.js +5 -1
- package/dist/api/mutations/jack.d.ts +29 -0
- package/dist/api/mutations/jack.js +41 -1
- package/dist/api/mutations/products.d.ts +175 -0
- package/dist/api/mutations/products.js +226 -0
- package/dist/api/mutations/support.d.ts +20 -1
- package/dist/api/mutations/support.js +36 -1
- package/dist/api/queries/badges.d.ts +221 -0
- package/dist/api/queries/badges.js +290 -0
- package/dist/api/queries/bookings.d.ts +1 -1
- package/dist/api/queries/brands.d.ts +248 -0
- package/dist/api/queries/brands.js +226 -0
- package/dist/api/queries/businesses.d.ts +61 -1
- package/dist/api/queries/businesses.js +27 -1
- package/dist/api/queries/creators.d.ts +332 -0
- package/dist/api/queries/creators.js +249 -0
- package/dist/api/queries/event-chat.d.ts +1 -1
- package/dist/api/queries/event-chat.js +4 -4
- package/dist/api/queries/events.d.ts +45 -0
- package/dist/api/queries/index.d.ts +5 -0
- package/dist/api/queries/index.js +6 -1
- package/dist/api/queries/jack.d.ts +80 -0
- package/dist/api/queries/jack.js +98 -1
- package/dist/api/queries/library.d.ts +8 -0
- package/dist/api/queries/products.d.ts +185 -0
- package/dist/api/queries/products.js +203 -0
- package/dist/api/queries/support.d.ts +46 -1
- package/dist/api/queries/support.js +48 -1
- package/dist/api/queries/venues.d.ts +304 -0
- package/dist/api/queries/venues.js +211 -0
- package/dist/api/types.d.ts +245 -0
- package/dist/api/types.js +6 -1
- package/dist/api/utils/eventGrouping.d.ts +104 -0
- package/dist/api/utils/eventGrouping.js +155 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +5 -1
- package/package.json +5 -2
- package/src/__tests__/e2e.test.ts +996 -64
- package/src/api/mutations/badges.ts +228 -0
- package/src/api/mutations/brands.ts +376 -0
- package/src/api/mutations/creators.ts +171 -0
- package/src/api/mutations/event-chat.ts +8 -8
- package/src/api/mutations/index.ts +4 -0
- package/src/api/mutations/jack.ts +50 -1
- package/src/api/mutations/products.ts +336 -0
- package/src/api/mutations/support.ts +44 -0
- package/src/api/queries/badges.ts +385 -0
- package/src/api/queries/brands.ts +281 -0
- package/src/api/queries/businesses.ts +30 -1
- package/src/api/queries/creators.ts +308 -0
- package/src/api/queries/event-chat.ts +3 -3
- package/src/api/queries/index.ts +5 -0
- package/src/api/queries/jack.ts +139 -1
- package/src/api/queries/products.ts +312 -0
- package/src/api/queries/support.ts +54 -0
- package/src/api/queries/venues.ts +271 -0
- package/src/api/types.ts +317 -1
- package/src/api/utils/eventGrouping.ts +181 -0
- package/src/index.ts +6 -0
|
@@ -0,0 +1,304 @@
|
|
|
1
|
+
import { UseQueryOptions } from '@tanstack/react-query';
|
|
2
|
+
import type { VenueResponse, VenueOwnerResponse, EventResponse, OfferResponse } from '../types';
|
|
3
|
+
export declare const venueKeys: {
|
|
4
|
+
all: readonly ["venues"];
|
|
5
|
+
lists: () => readonly ["venues", "list"];
|
|
6
|
+
list: (filters?: VenueFilters) => readonly ["venues", "list", VenueFilters | undefined];
|
|
7
|
+
details: () => readonly ["venues", "detail"];
|
|
8
|
+
detail: (id: string) => readonly ["venues", "detail", string];
|
|
9
|
+
featured: () => readonly ["venues", "featured"];
|
|
10
|
+
nearby: (params?: NearbyVenueParams) => readonly ["venues", "nearby", NearbyVenueParams | undefined];
|
|
11
|
+
owners: (venueId: string) => readonly ["venues", "detail", string, "owners"];
|
|
12
|
+
events: (venueId: string) => readonly ["venues", "detail", string, "events"];
|
|
13
|
+
offers: (venueId: string) => readonly ["venues", "detail", string, "offers"];
|
|
14
|
+
rewards: (venueId: string) => readonly ["venues", "detail", string, "rewards"];
|
|
15
|
+
};
|
|
16
|
+
export interface VenueFilters {
|
|
17
|
+
page?: number;
|
|
18
|
+
limit?: number;
|
|
19
|
+
search?: string;
|
|
20
|
+
cityId?: string;
|
|
21
|
+
type?: string;
|
|
22
|
+
hasAfDrinks?: boolean;
|
|
23
|
+
isAfVenue?: boolean;
|
|
24
|
+
isFeatured?: boolean;
|
|
25
|
+
isFoundingPartner?: boolean;
|
|
26
|
+
lat?: number;
|
|
27
|
+
long?: number;
|
|
28
|
+
radius?: number;
|
|
29
|
+
sortBy?: string;
|
|
30
|
+
sortOrder?: 'asc' | 'desc';
|
|
31
|
+
}
|
|
32
|
+
export interface NearbyVenueParams {
|
|
33
|
+
lat: number;
|
|
34
|
+
long: number;
|
|
35
|
+
radius?: number;
|
|
36
|
+
limit?: number;
|
|
37
|
+
}
|
|
38
|
+
export interface PaginatedVenuesResponse {
|
|
39
|
+
venues: VenueResponse[];
|
|
40
|
+
meta: {
|
|
41
|
+
total: number;
|
|
42
|
+
page: number;
|
|
43
|
+
limit: number;
|
|
44
|
+
totalPages: number;
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Get paginated list of venues with optional filters
|
|
49
|
+
*
|
|
50
|
+
* @param filters - Query parameters for filtering and pagination
|
|
51
|
+
* @param options - TanStack Query options
|
|
52
|
+
*
|
|
53
|
+
* @example
|
|
54
|
+
* ```tsx
|
|
55
|
+
* const { data, isLoading } = useVenues({
|
|
56
|
+
* page: 1,
|
|
57
|
+
* limit: 20,
|
|
58
|
+
* cityId: 'city-123',
|
|
59
|
+
* hasAfDrinks: true,
|
|
60
|
+
* });
|
|
61
|
+
* ```
|
|
62
|
+
*/
|
|
63
|
+
export declare function useVenues(filters?: VenueFilters, options?: Omit<UseQueryOptions<PaginatedVenuesResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PaginatedVenuesResponse, Error>;
|
|
64
|
+
/**
|
|
65
|
+
* Get featured venues
|
|
66
|
+
*
|
|
67
|
+
* @param limit - Maximum number of venues to return
|
|
68
|
+
* @param options - TanStack Query options
|
|
69
|
+
*
|
|
70
|
+
* @example
|
|
71
|
+
* ```tsx
|
|
72
|
+
* const { data, isLoading } = useFeaturedVenues(10);
|
|
73
|
+
* ```
|
|
74
|
+
*/
|
|
75
|
+
export declare function useFeaturedVenues(limit?: number, options?: Omit<UseQueryOptions<VenueResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
76
|
+
id: string;
|
|
77
|
+
appId: string;
|
|
78
|
+
name: string;
|
|
79
|
+
slug: string;
|
|
80
|
+
description?: Record<string, never>;
|
|
81
|
+
type: "COFFEE_SHOP" | "RESTAURANT" | "BAR" | "WELLNESS" | "VENUE" | "ACTIVITY" | "RETAIL" | "OTHER";
|
|
82
|
+
hasAfDrinks: boolean;
|
|
83
|
+
isAfVenue: boolean;
|
|
84
|
+
afHighlights: string[];
|
|
85
|
+
address?: Record<string, never>;
|
|
86
|
+
cityId?: Record<string, never>;
|
|
87
|
+
locationLat?: Record<string, never>;
|
|
88
|
+
locationLong?: Record<string, never>;
|
|
89
|
+
phone?: Record<string, never>;
|
|
90
|
+
email?: Record<string, never>;
|
|
91
|
+
website?: Record<string, never>;
|
|
92
|
+
instagram?: Record<string, never>;
|
|
93
|
+
profileImage?: Record<string, never>;
|
|
94
|
+
bannerImage?: Record<string, never>;
|
|
95
|
+
photos: string[];
|
|
96
|
+
openingHours?: Record<string, never>;
|
|
97
|
+
rating?: Record<string, never>;
|
|
98
|
+
reviewCount: number;
|
|
99
|
+
isActive: boolean;
|
|
100
|
+
isVerified: boolean;
|
|
101
|
+
isFeatured: boolean;
|
|
102
|
+
isFoundingPartner: boolean;
|
|
103
|
+
createdAt: string;
|
|
104
|
+
updatedAt: string;
|
|
105
|
+
}[], Error>;
|
|
106
|
+
/**
|
|
107
|
+
* Get nearby venues based on location
|
|
108
|
+
*
|
|
109
|
+
* @param params - Location parameters (latitude, longitude, radius)
|
|
110
|
+
* @param options - TanStack Query options
|
|
111
|
+
*
|
|
112
|
+
* @example
|
|
113
|
+
* ```tsx
|
|
114
|
+
* const { data, isLoading } = useNearbyVenues({
|
|
115
|
+
* lat: 51.5074,
|
|
116
|
+
* long: -0.1278,
|
|
117
|
+
* radius: 5, // 5km radius
|
|
118
|
+
* limit: 20,
|
|
119
|
+
* });
|
|
120
|
+
* ```
|
|
121
|
+
*/
|
|
122
|
+
export declare function useNearbyVenues(params: NearbyVenueParams, options?: Omit<UseQueryOptions<VenueResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
123
|
+
id: string;
|
|
124
|
+
appId: string;
|
|
125
|
+
name: string;
|
|
126
|
+
slug: string;
|
|
127
|
+
description?: Record<string, never>;
|
|
128
|
+
type: "COFFEE_SHOP" | "RESTAURANT" | "BAR" | "WELLNESS" | "VENUE" | "ACTIVITY" | "RETAIL" | "OTHER";
|
|
129
|
+
hasAfDrinks: boolean;
|
|
130
|
+
isAfVenue: boolean;
|
|
131
|
+
afHighlights: string[];
|
|
132
|
+
address?: Record<string, never>;
|
|
133
|
+
cityId?: Record<string, never>;
|
|
134
|
+
locationLat?: Record<string, never>;
|
|
135
|
+
locationLong?: Record<string, never>;
|
|
136
|
+
phone?: Record<string, never>;
|
|
137
|
+
email?: Record<string, never>;
|
|
138
|
+
website?: Record<string, never>;
|
|
139
|
+
instagram?: Record<string, never>;
|
|
140
|
+
profileImage?: Record<string, never>;
|
|
141
|
+
bannerImage?: Record<string, never>;
|
|
142
|
+
photos: string[];
|
|
143
|
+
openingHours?: Record<string, never>;
|
|
144
|
+
rating?: Record<string, never>;
|
|
145
|
+
reviewCount: number;
|
|
146
|
+
isActive: boolean;
|
|
147
|
+
isVerified: boolean;
|
|
148
|
+
isFeatured: boolean;
|
|
149
|
+
isFoundingPartner: boolean;
|
|
150
|
+
createdAt: string;
|
|
151
|
+
updatedAt: string;
|
|
152
|
+
}[], Error>;
|
|
153
|
+
/**
|
|
154
|
+
* Get a single venue by ID
|
|
155
|
+
*
|
|
156
|
+
* @param id - Venue ID
|
|
157
|
+
* @param options - TanStack Query options
|
|
158
|
+
*
|
|
159
|
+
* @example
|
|
160
|
+
* ```tsx
|
|
161
|
+
* const { data, isLoading } = useVenue('venue-123');
|
|
162
|
+
* ```
|
|
163
|
+
*/
|
|
164
|
+
export declare function useVenue(id: string, options?: Omit<UseQueryOptions<VenueResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
165
|
+
id: string;
|
|
166
|
+
appId: string;
|
|
167
|
+
name: string;
|
|
168
|
+
slug: string;
|
|
169
|
+
description?: Record<string, never>;
|
|
170
|
+
type: "COFFEE_SHOP" | "RESTAURANT" | "BAR" | "WELLNESS" | "VENUE" | "ACTIVITY" | "RETAIL" | "OTHER";
|
|
171
|
+
hasAfDrinks: boolean;
|
|
172
|
+
isAfVenue: boolean;
|
|
173
|
+
afHighlights: string[];
|
|
174
|
+
address?: Record<string, never>;
|
|
175
|
+
cityId?: Record<string, never>;
|
|
176
|
+
locationLat?: Record<string, never>;
|
|
177
|
+
locationLong?: Record<string, never>;
|
|
178
|
+
phone?: Record<string, never>;
|
|
179
|
+
email?: Record<string, never>;
|
|
180
|
+
website?: Record<string, never>;
|
|
181
|
+
instagram?: Record<string, never>;
|
|
182
|
+
profileImage?: Record<string, never>;
|
|
183
|
+
bannerImage?: Record<string, never>;
|
|
184
|
+
photos: string[];
|
|
185
|
+
openingHours?: Record<string, never>;
|
|
186
|
+
rating?: Record<string, never>;
|
|
187
|
+
reviewCount: number;
|
|
188
|
+
isActive: boolean;
|
|
189
|
+
isVerified: boolean;
|
|
190
|
+
isFeatured: boolean;
|
|
191
|
+
isFoundingPartner: boolean;
|
|
192
|
+
createdAt: string;
|
|
193
|
+
updatedAt: string;
|
|
194
|
+
}, Error>;
|
|
195
|
+
/**
|
|
196
|
+
* Get venue owners
|
|
197
|
+
*
|
|
198
|
+
* @param venueId - Venue ID
|
|
199
|
+
* @param options - TanStack Query options
|
|
200
|
+
*
|
|
201
|
+
* @example
|
|
202
|
+
* ```tsx
|
|
203
|
+
* const { data, isLoading } = useVenueOwners('venue-123');
|
|
204
|
+
* ```
|
|
205
|
+
*/
|
|
206
|
+
export declare function useVenueOwners(venueId: string, options?: Omit<UseQueryOptions<VenueOwnerResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
207
|
+
id: string;
|
|
208
|
+
venueId: string;
|
|
209
|
+
userId: string;
|
|
210
|
+
role: "OWNER" | "MANAGER";
|
|
211
|
+
user?: import("@growsober/types/dist/generated").components["schemas"]["VenueOwnerUserDto"];
|
|
212
|
+
createdAt: string;
|
|
213
|
+
updatedAt: string;
|
|
214
|
+
}[], Error>;
|
|
215
|
+
/**
|
|
216
|
+
* Get upcoming events at a venue
|
|
217
|
+
*
|
|
218
|
+
* @param venueId - Venue ID
|
|
219
|
+
* @param limit - Maximum number of events to return
|
|
220
|
+
* @param options - TanStack Query options
|
|
221
|
+
*
|
|
222
|
+
* @example
|
|
223
|
+
* ```tsx
|
|
224
|
+
* const { data, isLoading } = useVenueEvents('venue-123', 20);
|
|
225
|
+
* ```
|
|
226
|
+
*/
|
|
227
|
+
export declare function useVenueEvents(venueId: string, limit?: number, options?: Omit<UseQueryOptions<EventResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
228
|
+
id: string;
|
|
229
|
+
title: string;
|
|
230
|
+
slug?: Record<string, never>;
|
|
231
|
+
description?: Record<string, never>;
|
|
232
|
+
bannerImage?: Record<string, never>;
|
|
233
|
+
startDate: string;
|
|
234
|
+
endDate?: Record<string, never>;
|
|
235
|
+
timezone?: Record<string, never>;
|
|
236
|
+
isRecurring: boolean;
|
|
237
|
+
recurrenceRule?: Record<string, never>;
|
|
238
|
+
locationName?: Record<string, never>;
|
|
239
|
+
locationAddress?: Record<string, never>;
|
|
240
|
+
locationLat?: Record<string, never>;
|
|
241
|
+
locationLong?: Record<string, never>;
|
|
242
|
+
cityId?: Record<string, never>;
|
|
243
|
+
isOnline: boolean;
|
|
244
|
+
onlineUrl?: Record<string, never>;
|
|
245
|
+
totalSpots: number;
|
|
246
|
+
availableSpots: number;
|
|
247
|
+
isFree: boolean;
|
|
248
|
+
price?: Record<string, never>;
|
|
249
|
+
currency: string;
|
|
250
|
+
hubId?: Record<string, never>;
|
|
251
|
+
venueId?: Record<string, never>;
|
|
252
|
+
creatorId?: Record<string, never>;
|
|
253
|
+
sponsorBrandId?: Record<string, never>;
|
|
254
|
+
gatheringType?: "FACILITATOR_LED" | "COMMUNITY" | "SOCIAL" | "ONLINE";
|
|
255
|
+
visibility: "PUBLIC" | "MEMBERS_ONLY" | "INVITE_ONLY";
|
|
256
|
+
requiresApproval: boolean;
|
|
257
|
+
allowWaitlist: boolean;
|
|
258
|
+
whatsappGroup?: Record<string, never>;
|
|
259
|
+
externalUrl?: Record<string, never>;
|
|
260
|
+
status: "DRAFT" | "PUBLISHED" | "CANCELLED" | "COMPLETED";
|
|
261
|
+
isFeatured: boolean;
|
|
262
|
+
isCancelled: boolean;
|
|
263
|
+
isAmbient: boolean;
|
|
264
|
+
ambientCategory?: Record<string, never>;
|
|
265
|
+
vibe?: "CHILL" | "ACTIVE" | "SOCIAL" | "CREATIVE" | "DEEP_TALK" | "ADVENTURE";
|
|
266
|
+
city?: import("@growsober/types/dist/generated").components["schemas"]["EventCityDto"];
|
|
267
|
+
venue?: import("@growsober/types/dist/generated").components["schemas"]["EventVenueDto"];
|
|
268
|
+
creator?: import("@growsober/types/dist/generated").components["schemas"]["EventCreatorDto"];
|
|
269
|
+
sponsorBrand?: import("@growsober/types/dist/generated").components["schemas"]["EventBrandDto"];
|
|
270
|
+
bookingCount: number;
|
|
271
|
+
checkinCount: number;
|
|
272
|
+
createdAt: string;
|
|
273
|
+
publishedAt?: Record<string, never>;
|
|
274
|
+
}[], Error>;
|
|
275
|
+
/**
|
|
276
|
+
* Get offers for a venue (from legacy Business model)
|
|
277
|
+
*
|
|
278
|
+
* @param venueId - Venue ID
|
|
279
|
+
* @param options - TanStack Query options
|
|
280
|
+
*
|
|
281
|
+
* @example
|
|
282
|
+
* ```tsx
|
|
283
|
+
* const { data, isLoading } = useVenueOffers('venue-123');
|
|
284
|
+
* ```
|
|
285
|
+
*/
|
|
286
|
+
export declare function useVenueOffers(venueId: string, options?: Omit<UseQueryOptions<OfferResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
287
|
+
id: string;
|
|
288
|
+
businessId: string;
|
|
289
|
+
title: string;
|
|
290
|
+
description?: Record<string, never>;
|
|
291
|
+
discountType?: "PERCENTAGE" | "FIXED_AMOUNT" | "FREE_ITEM" | "BOGO";
|
|
292
|
+
discountValue?: Record<string, never>;
|
|
293
|
+
discountCode?: Record<string, never>;
|
|
294
|
+
validFrom: string;
|
|
295
|
+
validTo?: Record<string, never>;
|
|
296
|
+
terms?: Record<string, never>;
|
|
297
|
+
maxRedemptions?: Record<string, never>;
|
|
298
|
+
redemptionCount: number;
|
|
299
|
+
perUserLimit?: Record<string, never>;
|
|
300
|
+
premiumOnly: boolean;
|
|
301
|
+
isActive: boolean;
|
|
302
|
+
createdAt: string;
|
|
303
|
+
updatedAt: string;
|
|
304
|
+
}[], Error>;
|
|
@@ -0,0 +1,211 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.venueKeys = void 0;
|
|
4
|
+
exports.useVenues = useVenues;
|
|
5
|
+
exports.useFeaturedVenues = useFeaturedVenues;
|
|
6
|
+
exports.useNearbyVenues = useNearbyVenues;
|
|
7
|
+
exports.useVenue = useVenue;
|
|
8
|
+
exports.useVenueOwners = useVenueOwners;
|
|
9
|
+
exports.useVenueEvents = useVenueEvents;
|
|
10
|
+
exports.useVenueOffers = useVenueOffers;
|
|
11
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
12
|
+
const client_1 = require("../client");
|
|
13
|
+
// ============================================================================
|
|
14
|
+
// QUERY KEY FACTORY
|
|
15
|
+
// ============================================================================
|
|
16
|
+
exports.venueKeys = {
|
|
17
|
+
all: ['venues'],
|
|
18
|
+
lists: () => [...exports.venueKeys.all, 'list'],
|
|
19
|
+
list: (filters) => [...exports.venueKeys.lists(), filters],
|
|
20
|
+
details: () => [...exports.venueKeys.all, 'detail'],
|
|
21
|
+
detail: (id) => [...exports.venueKeys.details(), id],
|
|
22
|
+
featured: () => [...exports.venueKeys.all, 'featured'],
|
|
23
|
+
nearby: (params) => [...exports.venueKeys.all, 'nearby', params],
|
|
24
|
+
owners: (venueId) => [...exports.venueKeys.detail(venueId), 'owners'],
|
|
25
|
+
events: (venueId) => [...exports.venueKeys.detail(venueId), 'events'],
|
|
26
|
+
offers: (venueId) => [...exports.venueKeys.detail(venueId), 'offers'],
|
|
27
|
+
rewards: (venueId) => [...exports.venueKeys.detail(venueId), 'rewards'],
|
|
28
|
+
};
|
|
29
|
+
// ============================================================================
|
|
30
|
+
// QUERY HOOKS
|
|
31
|
+
// ============================================================================
|
|
32
|
+
/**
|
|
33
|
+
* Get paginated list of venues with optional filters
|
|
34
|
+
*
|
|
35
|
+
* @param filters - Query parameters for filtering and pagination
|
|
36
|
+
* @param options - TanStack Query options
|
|
37
|
+
*
|
|
38
|
+
* @example
|
|
39
|
+
* ```tsx
|
|
40
|
+
* const { data, isLoading } = useVenues({
|
|
41
|
+
* page: 1,
|
|
42
|
+
* limit: 20,
|
|
43
|
+
* cityId: 'city-123',
|
|
44
|
+
* hasAfDrinks: true,
|
|
45
|
+
* });
|
|
46
|
+
* ```
|
|
47
|
+
*/
|
|
48
|
+
function useVenues(filters, options) {
|
|
49
|
+
return (0, react_query_1.useQuery)({
|
|
50
|
+
queryKey: exports.venueKeys.list(filters),
|
|
51
|
+
queryFn: async () => {
|
|
52
|
+
const client = (0, client_1.getApiClient)();
|
|
53
|
+
const response = await client.get('/api/v1/venues', {
|
|
54
|
+
params: filters,
|
|
55
|
+
});
|
|
56
|
+
return response.data;
|
|
57
|
+
},
|
|
58
|
+
...options,
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Get featured venues
|
|
63
|
+
*
|
|
64
|
+
* @param limit - Maximum number of venues to return
|
|
65
|
+
* @param options - TanStack Query options
|
|
66
|
+
*
|
|
67
|
+
* @example
|
|
68
|
+
* ```tsx
|
|
69
|
+
* const { data, isLoading } = useFeaturedVenues(10);
|
|
70
|
+
* ```
|
|
71
|
+
*/
|
|
72
|
+
function useFeaturedVenues(limit, options) {
|
|
73
|
+
return (0, react_query_1.useQuery)({
|
|
74
|
+
queryKey: exports.venueKeys.featured(),
|
|
75
|
+
queryFn: async () => {
|
|
76
|
+
const client = (0, client_1.getApiClient)();
|
|
77
|
+
const response = await client.get('/api/v1/venues/featured', {
|
|
78
|
+
params: { limit },
|
|
79
|
+
});
|
|
80
|
+
return response.data;
|
|
81
|
+
},
|
|
82
|
+
...options,
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Get nearby venues based on location
|
|
87
|
+
*
|
|
88
|
+
* @param params - Location parameters (latitude, longitude, radius)
|
|
89
|
+
* @param options - TanStack Query options
|
|
90
|
+
*
|
|
91
|
+
* @example
|
|
92
|
+
* ```tsx
|
|
93
|
+
* const { data, isLoading } = useNearbyVenues({
|
|
94
|
+
* lat: 51.5074,
|
|
95
|
+
* long: -0.1278,
|
|
96
|
+
* radius: 5, // 5km radius
|
|
97
|
+
* limit: 20,
|
|
98
|
+
* });
|
|
99
|
+
* ```
|
|
100
|
+
*/
|
|
101
|
+
function useNearbyVenues(params, options) {
|
|
102
|
+
return (0, react_query_1.useQuery)({
|
|
103
|
+
queryKey: exports.venueKeys.nearby(params),
|
|
104
|
+
queryFn: async () => {
|
|
105
|
+
const client = (0, client_1.getApiClient)();
|
|
106
|
+
const response = await client.get('/api/v1/venues/nearby', {
|
|
107
|
+
params,
|
|
108
|
+
});
|
|
109
|
+
return response.data;
|
|
110
|
+
},
|
|
111
|
+
enabled: !!params.lat && !!params.long,
|
|
112
|
+
...options,
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Get a single venue by ID
|
|
117
|
+
*
|
|
118
|
+
* @param id - Venue ID
|
|
119
|
+
* @param options - TanStack Query options
|
|
120
|
+
*
|
|
121
|
+
* @example
|
|
122
|
+
* ```tsx
|
|
123
|
+
* const { data, isLoading } = useVenue('venue-123');
|
|
124
|
+
* ```
|
|
125
|
+
*/
|
|
126
|
+
function useVenue(id, options) {
|
|
127
|
+
return (0, react_query_1.useQuery)({
|
|
128
|
+
queryKey: exports.venueKeys.detail(id),
|
|
129
|
+
queryFn: async () => {
|
|
130
|
+
const client = (0, client_1.getApiClient)();
|
|
131
|
+
const response = await client.get(`/api/v1/venues/${id}`);
|
|
132
|
+
return response.data;
|
|
133
|
+
},
|
|
134
|
+
enabled: !!id,
|
|
135
|
+
...options,
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Get venue owners
|
|
140
|
+
*
|
|
141
|
+
* @param venueId - Venue ID
|
|
142
|
+
* @param options - TanStack Query options
|
|
143
|
+
*
|
|
144
|
+
* @example
|
|
145
|
+
* ```tsx
|
|
146
|
+
* const { data, isLoading } = useVenueOwners('venue-123');
|
|
147
|
+
* ```
|
|
148
|
+
*/
|
|
149
|
+
function useVenueOwners(venueId, options) {
|
|
150
|
+
return (0, react_query_1.useQuery)({
|
|
151
|
+
queryKey: exports.venueKeys.owners(venueId),
|
|
152
|
+
queryFn: async () => {
|
|
153
|
+
const client = (0, client_1.getApiClient)();
|
|
154
|
+
const response = await client.get(`/api/v1/venues/${venueId}/owners`);
|
|
155
|
+
return response.data;
|
|
156
|
+
},
|
|
157
|
+
enabled: !!venueId,
|
|
158
|
+
...options,
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Get upcoming events at a venue
|
|
163
|
+
*
|
|
164
|
+
* @param venueId - Venue ID
|
|
165
|
+
* @param limit - Maximum number of events to return
|
|
166
|
+
* @param options - TanStack Query options
|
|
167
|
+
*
|
|
168
|
+
* @example
|
|
169
|
+
* ```tsx
|
|
170
|
+
* const { data, isLoading } = useVenueEvents('venue-123', 20);
|
|
171
|
+
* ```
|
|
172
|
+
*/
|
|
173
|
+
function useVenueEvents(venueId, limit, options) {
|
|
174
|
+
return (0, react_query_1.useQuery)({
|
|
175
|
+
queryKey: exports.venueKeys.events(venueId),
|
|
176
|
+
queryFn: async () => {
|
|
177
|
+
const client = (0, client_1.getApiClient)();
|
|
178
|
+
const response = await client.get(`/api/v1/venues/${venueId}/events`, {
|
|
179
|
+
params: { limit },
|
|
180
|
+
});
|
|
181
|
+
return response.data?.data || response.data || [];
|
|
182
|
+
},
|
|
183
|
+
enabled: !!venueId,
|
|
184
|
+
...options,
|
|
185
|
+
});
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Get offers for a venue (from legacy Business model)
|
|
189
|
+
*
|
|
190
|
+
* @param venueId - Venue ID
|
|
191
|
+
* @param options - TanStack Query options
|
|
192
|
+
*
|
|
193
|
+
* @example
|
|
194
|
+
* ```tsx
|
|
195
|
+
* const { data, isLoading } = useVenueOffers('venue-123');
|
|
196
|
+
* ```
|
|
197
|
+
*/
|
|
198
|
+
function useVenueOffers(venueId, options) {
|
|
199
|
+
return (0, react_query_1.useQuery)({
|
|
200
|
+
queryKey: exports.venueKeys.offers(venueId),
|
|
201
|
+
queryFn: async () => {
|
|
202
|
+
const client = (0, client_1.getApiClient)();
|
|
203
|
+
// Use businesses endpoint for offers (legacy)
|
|
204
|
+
const response = await client.get(`/api/v1/businesses/${venueId}/offers`);
|
|
205
|
+
return response.data;
|
|
206
|
+
},
|
|
207
|
+
enabled: !!venueId,
|
|
208
|
+
...options,
|
|
209
|
+
});
|
|
210
|
+
}
|
|
211
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"venues.js","sourceRoot":"","sources":["../../../src/api/queries/venues.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { VenueResponse, VenueOwnerResponse, EventResponse, OfferResponse } from '../types';\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const venueKeys = {\n  all: ['venues'] as const,\n  lists: () => [...venueKeys.all, 'list'] as const,\n  list: (filters?: VenueFilters) => [...venueKeys.lists(), filters] as const,\n  details: () => [...venueKeys.all, 'detail'] as const,\n  detail: (id: string) => [...venueKeys.details(), id] as const,\n  featured: () => [...venueKeys.all, 'featured'] as const,\n  nearby: (params?: NearbyVenueParams) => [...venueKeys.all, 'nearby', params] as const,\n  owners: (venueId: string) => [...venueKeys.detail(venueId), 'owners'] as const,\n  events: (venueId: string) => [...venueKeys.detail(venueId), 'events'] as const,\n  offers: (venueId: string) => [...venueKeys.detail(venueId), 'offers'] as const,\n  rewards: (venueId: string) => [...venueKeys.detail(venueId), 'rewards'] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface VenueFilters {\n  page?: number;\n  limit?: number;\n  search?: string;\n  cityId?: string;\n  type?: string;\n  hasAfDrinks?: boolean;\n  isAfVenue?: boolean;\n  isFeatured?: boolean;\n  isFoundingPartner?: boolean;\n  lat?: number;\n  long?: number;\n  radius?: number;\n  sortBy?: string;\n  sortOrder?: 'asc' | 'desc';\n}\n\nexport interface NearbyVenueParams {\n  lat: number;\n  long: number;\n  radius?: number;\n  limit?: number;\n}\n\nexport interface PaginatedVenuesResponse {\n  venues: VenueResponse[];\n  meta: {\n    total: number;\n    page: number;\n    limit: number;\n    totalPages: number;\n  };\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get paginated list of venues with optional filters\n *\n * @param filters - Query parameters for filtering and pagination\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenues({\n *   page: 1,\n *   limit: 20,\n *   cityId: 'city-123',\n *   hasAfDrinks: true,\n * });\n * ```\n */\nexport function useVenues(\n  filters?: VenueFilters,\n  options?: Omit<UseQueryOptions<PaginatedVenuesResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.list(filters),\n    queryFn: async (): Promise<PaginatedVenuesResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/venues', {\n        params: filters,\n      });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get featured venues\n *\n * @param limit - Maximum number of venues to return\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useFeaturedVenues(10);\n * ```\n */\nexport function useFeaturedVenues(\n  limit?: number,\n  options?: Omit<UseQueryOptions<VenueResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.featured(),\n    queryFn: async (): Promise<VenueResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/venues/featured', {\n        params: { limit },\n      });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get nearby venues based on location\n *\n * @param params - Location parameters (latitude, longitude, radius)\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useNearbyVenues({\n *   lat: 51.5074,\n *   long: -0.1278,\n *   radius: 5, // 5km radius\n *   limit: 20,\n * });\n * ```\n */\nexport function useNearbyVenues(\n  params: NearbyVenueParams,\n  options?: Omit<UseQueryOptions<VenueResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.nearby(params),\n    queryFn: async (): Promise<VenueResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/venues/nearby', {\n        params,\n      });\n      return response.data;\n    },\n    enabled: !!params.lat && !!params.long,\n    ...options,\n  });\n}\n\n/**\n * Get a single venue by ID\n *\n * @param id - Venue ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenue('venue-123');\n * ```\n */\nexport function useVenue(\n  id: string,\n  options?: Omit<UseQueryOptions<VenueResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.detail(id),\n    queryFn: async (): Promise<VenueResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/venues/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\n/**\n * Get venue owners\n *\n * @param venueId - Venue ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenueOwners('venue-123');\n * ```\n */\nexport function useVenueOwners(\n  venueId: string,\n  options?: Omit<UseQueryOptions<VenueOwnerResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.owners(venueId),\n    queryFn: async (): Promise<VenueOwnerResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/venues/${venueId}/owners`);\n      return response.data;\n    },\n    enabled: !!venueId,\n    ...options,\n  });\n}\n\n/**\n * Get upcoming events at a venue\n *\n * @param venueId - Venue ID\n * @param limit - Maximum number of events to return\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenueEvents('venue-123', 20);\n * ```\n */\nexport function useVenueEvents(\n  venueId: string,\n  limit?: number,\n  options?: Omit<UseQueryOptions<EventResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.events(venueId),\n    queryFn: async (): Promise<EventResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/venues/${venueId}/events`, {\n        params: { limit },\n      });\n      return response.data?.data || response.data || [];\n    },\n    enabled: !!venueId,\n    ...options,\n  });\n}\n\n/**\n * Get offers for a venue (from legacy Business model)\n *\n * @param venueId - Venue ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenueOffers('venue-123');\n * ```\n */\nexport function useVenueOffers(\n  venueId: string,\n  options?: Omit<UseQueryOptions<OfferResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.offers(venueId),\n    queryFn: async (): Promise<OfferResponse[]> => {\n      const client = getApiClient();\n      // Use businesses endpoint for offers (legacy)\n      const response = await client.get(`/api/v1/businesses/${venueId}/offers`);\n      return response.data;\n    },\n    enabled: !!venueId,\n    ...options,\n  });\n}\n"]}
|