@growsober/sdk 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +276 -0
- package/dist/__tests__/e2e.test.d.ts +7 -0
- package/dist/__tests__/e2e.test.js +472 -0
- package/dist/api/client.d.ts +11 -0
- package/dist/api/client.js +61 -0
- package/dist/api/mutations/admin.d.ts +167 -0
- package/dist/api/mutations/admin.js +326 -0
- package/dist/api/mutations/ambassadors.d.ts +52 -0
- package/dist/api/mutations/ambassadors.js +148 -0
- package/dist/api/mutations/auth.d.ts +267 -0
- package/dist/api/mutations/auth.js +332 -0
- package/dist/api/mutations/bookings.d.ts +59 -0
- package/dist/api/mutations/bookings.js +143 -0
- package/dist/api/mutations/event-chat.d.ts +35 -0
- package/dist/api/mutations/event-chat.js +147 -0
- package/dist/api/mutations/events.d.ts +87 -0
- package/dist/api/mutations/events.js +205 -0
- package/dist/api/mutations/grow90.d.ts +36 -0
- package/dist/api/mutations/grow90.js +132 -0
- package/dist/api/mutations/hubs.d.ts +111 -0
- package/dist/api/mutations/hubs.js +240 -0
- package/dist/api/mutations/index.d.ts +22 -0
- package/dist/api/mutations/index.js +39 -0
- package/dist/api/mutations/jack.d.ts +61 -0
- package/dist/api/mutations/jack.js +104 -0
- package/dist/api/mutations/library.d.ts +67 -0
- package/dist/api/mutations/library.js +168 -0
- package/dist/api/mutations/map.d.ts +153 -0
- package/dist/api/mutations/map.js +181 -0
- package/dist/api/mutations/matching.d.ts +130 -0
- package/dist/api/mutations/matching.js +204 -0
- package/dist/api/mutations/notifications.d.ts +63 -0
- package/dist/api/mutations/notifications.js +106 -0
- package/dist/api/mutations/offers.d.ts +26 -0
- package/dist/api/mutations/offers.js +47 -0
- package/dist/api/mutations/subscriptions.d.ts +127 -0
- package/dist/api/mutations/subscriptions.js +140 -0
- package/dist/api/mutations/support.d.ts +165 -0
- package/dist/api/mutations/support.js +307 -0
- package/dist/api/mutations/users.d.ts +211 -0
- package/dist/api/mutations/users.js +261 -0
- package/dist/api/queries/admin.d.ts +257 -0
- package/dist/api/queries/admin.js +320 -0
- package/dist/api/queries/ambassadors.d.ts +53 -0
- package/dist/api/queries/ambassadors.js +98 -0
- package/dist/api/queries/auth.d.ts +16 -0
- package/dist/api/queries/auth.js +25 -0
- package/dist/api/queries/bookings.d.ts +91 -0
- package/dist/api/queries/bookings.js +102 -0
- package/dist/api/queries/businesses.d.ts +212 -0
- package/dist/api/queries/businesses.js +154 -0
- package/dist/api/queries/event-chat.d.ts +19 -0
- package/dist/api/queries/event-chat.js +75 -0
- package/dist/api/queries/events.d.ts +322 -0
- package/dist/api/queries/events.js +221 -0
- package/dist/api/queries/grow90.d.ts +26 -0
- package/dist/api/queries/grow90.js +85 -0
- package/dist/api/queries/hubs.d.ts +165 -0
- package/dist/api/queries/hubs.js +143 -0
- package/dist/api/queries/index.d.ts +23 -0
- package/dist/api/queries/index.js +40 -0
- package/dist/api/queries/jack.d.ts +63 -0
- package/dist/api/queries/jack.js +92 -0
- package/dist/api/queries/library.d.ts +132 -0
- package/dist/api/queries/library.js +120 -0
- package/dist/api/queries/map.d.ts +216 -0
- package/dist/api/queries/map.js +278 -0
- package/dist/api/queries/matching.d.ts +136 -0
- package/dist/api/queries/matching.js +161 -0
- package/dist/api/queries/notifications.d.ts +78 -0
- package/dist/api/queries/notifications.js +88 -0
- package/dist/api/queries/offers.d.ts +91 -0
- package/dist/api/queries/offers.js +103 -0
- package/dist/api/queries/subscriptions.d.ts +56 -0
- package/dist/api/queries/subscriptions.js +73 -0
- package/dist/api/queries/support.d.ts +106 -0
- package/dist/api/queries/support.js +202 -0
- package/dist/api/queries/users.d.ts +293 -0
- package/dist/api/queries/users.js +370 -0
- package/dist/api/types.d.ts +464 -0
- package/dist/api/types.js +9 -0
- package/dist/hooks/useAuth.d.ts +5 -0
- package/dist/hooks/useAuth.js +39 -0
- package/dist/hooks/useUser.d.ts +43 -0
- package/dist/hooks/useUser.js +44 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.js +67 -0
- package/package.json +62 -0
- package/src/__tests__/e2e.test.ts +502 -0
- package/src/api/client.ts +71 -0
- package/src/api/mutations/admin.ts +531 -0
- package/src/api/mutations/ambassadors.ts +185 -0
- package/src/api/mutations/auth.ts +350 -0
- package/src/api/mutations/bookings.ts +190 -0
- package/src/api/mutations/event-chat.ts +177 -0
- package/src/api/mutations/events.ts +273 -0
- package/src/api/mutations/grow90.ts +169 -0
- package/src/api/mutations/hubs.ts +385 -0
- package/src/api/mutations/index.ts +23 -0
- package/src/api/mutations/jack.ts +130 -0
- package/src/api/mutations/library.ts +212 -0
- package/src/api/mutations/map.ts +230 -0
- package/src/api/mutations/matching.ts +271 -0
- package/src/api/mutations/notifications.ts +114 -0
- package/src/api/mutations/offers.ts +73 -0
- package/src/api/mutations/subscriptions.ts +162 -0
- package/src/api/mutations/support.ts +390 -0
- package/src/api/mutations/users.ts +271 -0
- package/src/api/queries/admin.ts +480 -0
- package/src/api/queries/ambassadors.ts +139 -0
- package/src/api/queries/auth.ts +24 -0
- package/src/api/queries/bookings.ts +135 -0
- package/src/api/queries/businesses.ts +203 -0
- package/src/api/queries/event-chat.ts +78 -0
- package/src/api/queries/events.ts +272 -0
- package/src/api/queries/grow90.ts +98 -0
- package/src/api/queries/hubs.ts +211 -0
- package/src/api/queries/index.ts +24 -0
- package/src/api/queries/jack.ts +127 -0
- package/src/api/queries/library.ts +166 -0
- package/src/api/queries/map.ts +331 -0
- package/src/api/queries/matching.ts +238 -0
- package/src/api/queries/notifications.ts +103 -0
- package/src/api/queries/offers.ts +136 -0
- package/src/api/queries/subscriptions.ts +91 -0
- package/src/api/queries/support.ts +235 -0
- package/src/api/queries/users.ts +393 -0
- package/src/api/types.ts +596 -0
- package/src/index.ts +57 -0
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { UseQueryOptions } from '@tanstack/react-query';
|
|
2
|
+
import type { BookingResponse } from '../types';
|
|
3
|
+
export declare const bookingKeys: {
|
|
4
|
+
all: readonly ["bookings"];
|
|
5
|
+
lists: () => readonly ["bookings", "list"];
|
|
6
|
+
list: (filters?: BookingFilters) => readonly ["bookings", "list", BookingFilters | undefined];
|
|
7
|
+
details: () => readonly ["bookings", "detail"];
|
|
8
|
+
detail: (id: string) => readonly ["bookings", "detail", string];
|
|
9
|
+
mine: (filters?: BookingFilters) => readonly ["bookings", "mine", BookingFilters | undefined];
|
|
10
|
+
qrCode: (id: string) => readonly ["bookings", "detail", string, "qr"];
|
|
11
|
+
};
|
|
12
|
+
export interface BookingFilters {
|
|
13
|
+
page?: number;
|
|
14
|
+
limit?: number;
|
|
15
|
+
status?: 'CONFIRMED' | 'WAITLISTED' | 'CANCELLED';
|
|
16
|
+
eventId?: string;
|
|
17
|
+
}
|
|
18
|
+
export interface PaginatedBookingsResponse {
|
|
19
|
+
bookings: BookingResponse[];
|
|
20
|
+
total: number;
|
|
21
|
+
page: number;
|
|
22
|
+
limit: number;
|
|
23
|
+
totalPages: number;
|
|
24
|
+
}
|
|
25
|
+
export interface QrCodeResponse {
|
|
26
|
+
qrCode: string;
|
|
27
|
+
bookingId: string;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Get a single booking by ID
|
|
31
|
+
*
|
|
32
|
+
* @param id - Booking ID
|
|
33
|
+
* @param options - TanStack Query options
|
|
34
|
+
*
|
|
35
|
+
* @example
|
|
36
|
+
* ```tsx
|
|
37
|
+
* const { data, isLoading } = useBooking('booking-123');
|
|
38
|
+
* ```
|
|
39
|
+
*/
|
|
40
|
+
export declare function useBooking(id: string, options?: Omit<UseQueryOptions<BookingResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
41
|
+
id: string;
|
|
42
|
+
eventId: string;
|
|
43
|
+
userId?: Record<string, never>;
|
|
44
|
+
guestName?: Record<string, never>;
|
|
45
|
+
guestEmail?: Record<string, never>;
|
|
46
|
+
guestPhone?: Record<string, never>;
|
|
47
|
+
ticketCount: number;
|
|
48
|
+
totalPrice?: Record<string, never>;
|
|
49
|
+
status: "PENDING" | "CONFIRMED" | "WAITLISTED" | "CANCELLED" | "NO_SHOW";
|
|
50
|
+
waitlistPosition?: Record<string, never>;
|
|
51
|
+
isCheckedIn: boolean;
|
|
52
|
+
checkedInAt?: Record<string, never>;
|
|
53
|
+
checkedInBy?: Record<string, never>;
|
|
54
|
+
paymentId?: Record<string, never>;
|
|
55
|
+
paymentStatus?: "PENDING" | "COMPLETED" | "FAILED" | "REFUNDED";
|
|
56
|
+
qrCode?: Record<string, never>;
|
|
57
|
+
notes?: Record<string, never>;
|
|
58
|
+
createdAt: string;
|
|
59
|
+
updatedAt: string;
|
|
60
|
+
cancelledAt?: Record<string, never>;
|
|
61
|
+
}, Error>;
|
|
62
|
+
/**
|
|
63
|
+
* Get current user's bookings with optional filters
|
|
64
|
+
*
|
|
65
|
+
* @param filters - Query parameters for filtering and pagination
|
|
66
|
+
* @param options - TanStack Query options
|
|
67
|
+
*
|
|
68
|
+
* @example
|
|
69
|
+
* ```tsx
|
|
70
|
+
* const { data, isLoading } = useMyBookings({
|
|
71
|
+
* page: 1,
|
|
72
|
+
* limit: 20,
|
|
73
|
+
* status: 'CONFIRMED',
|
|
74
|
+
* eventId: 'event-123'
|
|
75
|
+
* });
|
|
76
|
+
* ```
|
|
77
|
+
*/
|
|
78
|
+
export declare function useMyBookings(filters?: BookingFilters, options?: Omit<UseQueryOptions<PaginatedBookingsResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PaginatedBookingsResponse, Error>;
|
|
79
|
+
/**
|
|
80
|
+
* Get QR code for a specific booking
|
|
81
|
+
*
|
|
82
|
+
* @param id - Booking ID
|
|
83
|
+
* @param options - TanStack Query options
|
|
84
|
+
*
|
|
85
|
+
* @example
|
|
86
|
+
* ```tsx
|
|
87
|
+
* const { data, isLoading } = useBookingQrCode('booking-123');
|
|
88
|
+
* // data.qrCode contains the QR code string for display
|
|
89
|
+
* ```
|
|
90
|
+
*/
|
|
91
|
+
export declare function useBookingQrCode(id: string, options?: Omit<UseQueryOptions<QrCodeResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<QrCodeResponse, Error>;
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.bookingKeys = void 0;
|
|
4
|
+
exports.useBooking = useBooking;
|
|
5
|
+
exports.useMyBookings = useMyBookings;
|
|
6
|
+
exports.useBookingQrCode = useBookingQrCode;
|
|
7
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
8
|
+
const client_1 = require("../client");
|
|
9
|
+
// ============================================================================
|
|
10
|
+
// QUERY KEY FACTORY
|
|
11
|
+
// ============================================================================
|
|
12
|
+
exports.bookingKeys = {
|
|
13
|
+
all: ['bookings'],
|
|
14
|
+
lists: () => [...exports.bookingKeys.all, 'list'],
|
|
15
|
+
list: (filters) => [...exports.bookingKeys.lists(), filters],
|
|
16
|
+
details: () => [...exports.bookingKeys.all, 'detail'],
|
|
17
|
+
detail: (id) => [...exports.bookingKeys.details(), id],
|
|
18
|
+
mine: (filters) => [...exports.bookingKeys.all, 'mine', filters],
|
|
19
|
+
qrCode: (id) => [...exports.bookingKeys.detail(id), 'qr'],
|
|
20
|
+
};
|
|
21
|
+
// ============================================================================
|
|
22
|
+
// QUERY HOOKS
|
|
23
|
+
// ============================================================================
|
|
24
|
+
/**
|
|
25
|
+
* Get a single booking by ID
|
|
26
|
+
*
|
|
27
|
+
* @param id - Booking ID
|
|
28
|
+
* @param options - TanStack Query options
|
|
29
|
+
*
|
|
30
|
+
* @example
|
|
31
|
+
* ```tsx
|
|
32
|
+
* const { data, isLoading } = useBooking('booking-123');
|
|
33
|
+
* ```
|
|
34
|
+
*/
|
|
35
|
+
function useBooking(id, options) {
|
|
36
|
+
return (0, react_query_1.useQuery)({
|
|
37
|
+
queryKey: exports.bookingKeys.detail(id),
|
|
38
|
+
queryFn: async () => {
|
|
39
|
+
const client = (0, client_1.getApiClient)();
|
|
40
|
+
const response = await client.get(`/api/v1/bookings/${id}`);
|
|
41
|
+
return response.data;
|
|
42
|
+
},
|
|
43
|
+
enabled: !!id,
|
|
44
|
+
...options,
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Get current user's bookings 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 } = useMyBookings({
|
|
56
|
+
* page: 1,
|
|
57
|
+
* limit: 20,
|
|
58
|
+
* status: 'CONFIRMED',
|
|
59
|
+
* eventId: 'event-123'
|
|
60
|
+
* });
|
|
61
|
+
* ```
|
|
62
|
+
*/
|
|
63
|
+
function useMyBookings(filters, options) {
|
|
64
|
+
return (0, react_query_1.useQuery)({
|
|
65
|
+
queryKey: exports.bookingKeys.mine(filters),
|
|
66
|
+
queryFn: async () => {
|
|
67
|
+
const client = (0, client_1.getApiClient)();
|
|
68
|
+
// Use /users/me/bookings - the existing API endpoint
|
|
69
|
+
const response = await client.get('/api/v1/users/me/bookings', {
|
|
70
|
+
params: filters,
|
|
71
|
+
});
|
|
72
|
+
// API returns { data: { bookings: [...] }, meta: {...} }
|
|
73
|
+
return response.data.data || response.data;
|
|
74
|
+
},
|
|
75
|
+
...options,
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Get QR code for a specific booking
|
|
80
|
+
*
|
|
81
|
+
* @param id - Booking ID
|
|
82
|
+
* @param options - TanStack Query options
|
|
83
|
+
*
|
|
84
|
+
* @example
|
|
85
|
+
* ```tsx
|
|
86
|
+
* const { data, isLoading } = useBookingQrCode('booking-123');
|
|
87
|
+
* // data.qrCode contains the QR code string for display
|
|
88
|
+
* ```
|
|
89
|
+
*/
|
|
90
|
+
function useBookingQrCode(id, options) {
|
|
91
|
+
return (0, react_query_1.useQuery)({
|
|
92
|
+
queryKey: exports.bookingKeys.qrCode(id),
|
|
93
|
+
queryFn: async () => {
|
|
94
|
+
const client = (0, client_1.getApiClient)();
|
|
95
|
+
const response = await client.get(`/api/v1/bookings/${id}/qr`);
|
|
96
|
+
return response.data;
|
|
97
|
+
},
|
|
98
|
+
enabled: !!id,
|
|
99
|
+
...options,
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bookings.js","sourceRoot":"","sources":["../../../src/api/queries/bookings.ts"],"names":[],"mappings":";;;AAyDA,gCAcC;AAkBD,sCAiBC;AAcD,4CAcC;AAtID,uDAAkE;AAClE,sCAAyC;AAGzC,+EAA+E;AAC/E,oBAAoB;AACpB,+EAA+E;AAElE,QAAA,WAAW,GAAG;IACzB,GAAG,EAAE,CAAC,UAAU,CAAU;IAC1B,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,mBAAW,CAAC,GAAG,EAAE,MAAM,CAAU;IAClD,IAAI,EAAE,CAAC,OAAwB,EAAE,EAAE,CAAC,CAAC,GAAG,mBAAW,CAAC,KAAK,EAAE,EAAE,OAAO,CAAU;IAC9E,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,mBAAW,CAAC,GAAG,EAAE,QAAQ,CAAU;IACtD,MAAM,EAAE,CAAC,EAAU,EAAE,EAAE,CAAC,CAAC,GAAG,mBAAW,CAAC,OAAO,EAAE,EAAE,EAAE,CAAU;IAC/D,IAAI,EAAE,CAAC,OAAwB,EAAE,EAAE,CAAC,CAAC,GAAG,mBAAW,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAU;IAClF,MAAM,EAAE,CAAC,EAAU,EAAE,EAAE,CAAC,CAAC,GAAG,mBAAW,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,IAAI,CAAU;CACnE,CAAC;AA0BF,+EAA+E;AAC/E,cAAc;AACd,+EAA+E;AAE/E;;;;;;;;;;GAUG;AACH,SAAgB,UAAU,CACxB,EAAU,EACV,OAAwE;IAExE,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,mBAAW,CAAC,MAAM,CAAC,EAAE,CAAC;QAChC,OAAO,EAAE,KAAK,IAA8B,EAAE;YAC5C,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,oBAAoB,EAAE,EAAE,CAAC,CAAC;YAC5D,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,EAAE;QACb,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;;;;GAeG;AACH,SAAgB,aAAa,CAC3B,OAAwB,EACxB,OAAkF;IAElF,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,mBAAW,CAAC,IAAI,CAAC,OAAO,CAAC;QACnC,OAAO,EAAE,KAAK,IAAwC,EAAE;YACtD,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,qDAAqD;YACrD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,2BAA2B,EAAE;gBAC7D,MAAM,EAAE,OAAO;aAChB,CAAC,CAAC;YACH,yDAAyD;YACzD,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,IAAI,QAAQ,CAAC,IAAI,CAAC;QAC7C,CAAC;QACD,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;GAWG;AACH,SAAgB,gBAAgB,CAC9B,EAAU,EACV,OAAuE;IAEvE,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,mBAAW,CAAC,MAAM,CAAC,EAAE,CAAC;QAChC,OAAO,EAAE,KAAK,IAA6B,EAAE;YAC3C,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,oBAAoB,EAAE,KAAK,CAAC,CAAC;YAC/D,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,EAAE;QACb,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { BookingResponse } from '../types';\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const bookingKeys = {\n  all: ['bookings'] as const,\n  lists: () => [...bookingKeys.all, 'list'] as const,\n  list: (filters?: BookingFilters) => [...bookingKeys.lists(), filters] as const,\n  details: () => [...bookingKeys.all, 'detail'] as const,\n  detail: (id: string) => [...bookingKeys.details(), id] as const,\n  mine: (filters?: BookingFilters) => [...bookingKeys.all, 'mine', filters] as const,\n  qrCode: (id: string) => [...bookingKeys.detail(id), 'qr'] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface BookingFilters {\n  page?: number;\n  limit?: number;\n  status?: 'CONFIRMED' | 'WAITLISTED' | 'CANCELLED';\n  eventId?: string;\n}\n\nexport interface PaginatedBookingsResponse {\n  bookings: BookingResponse[];\n  total: number;\n  page: number;\n  limit: number;\n  totalPages: number;\n}\n\nexport interface QrCodeResponse {\n  qrCode: string;\n  bookingId: string;\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get a single booking by ID\n *\n * @param id - Booking ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useBooking('booking-123');\n * ```\n */\nexport function useBooking(\n  id: string,\n  options?: Omit<UseQueryOptions<BookingResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: bookingKeys.detail(id),\n    queryFn: async (): Promise<BookingResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/bookings/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\n/**\n * Get current user's bookings 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 } = useMyBookings({\n *   page: 1,\n *   limit: 20,\n *   status: 'CONFIRMED',\n *   eventId: 'event-123'\n * });\n * ```\n */\nexport function useMyBookings(\n  filters?: BookingFilters,\n  options?: Omit<UseQueryOptions<PaginatedBookingsResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: bookingKeys.mine(filters),\n    queryFn: async (): Promise<PaginatedBookingsResponse> => {\n      const client = getApiClient();\n      // Use /users/me/bookings - the existing API endpoint\n      const response = await client.get('/api/v1/users/me/bookings', {\n        params: filters,\n      });\n      // API returns { data: { bookings: [...] }, meta: {...} }\n      return response.data.data || response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get QR code for a specific booking\n *\n * @param id - Booking ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useBookingQrCode('booking-123');\n * // data.qrCode contains the QR code string for display\n * ```\n */\nexport function useBookingQrCode(\n  id: string,\n  options?: Omit<UseQueryOptions<QrCodeResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: bookingKeys.qrCode(id),\n    queryFn: async (): Promise<QrCodeResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/bookings/${id}/qr`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n"]}
|
|
@@ -0,0 +1,212 @@
|
|
|
1
|
+
import { UseQueryOptions } from '@tanstack/react-query';
|
|
2
|
+
import type { BusinessResponse, OfferResponse } from '../types';
|
|
3
|
+
export declare const businessKeys: {
|
|
4
|
+
all: readonly ["businesses"];
|
|
5
|
+
lists: () => readonly ["businesses", "list"];
|
|
6
|
+
list: (filters?: BusinessFilters) => readonly ["businesses", "list", BusinessFilters | undefined];
|
|
7
|
+
details: () => readonly ["businesses", "detail"];
|
|
8
|
+
detail: (id: string) => readonly ["businesses", "detail", string];
|
|
9
|
+
featured: () => readonly ["businesses", "featured"];
|
|
10
|
+
nearby: (params?: NearbyBusinessParams) => readonly ["businesses", "nearby", NearbyBusinessParams | undefined];
|
|
11
|
+
offers: (businessId: string) => readonly ["businesses", "detail", string, "offers"];
|
|
12
|
+
};
|
|
13
|
+
export interface BusinessFilters {
|
|
14
|
+
page?: number;
|
|
15
|
+
limit?: number;
|
|
16
|
+
search?: string;
|
|
17
|
+
cityId?: string;
|
|
18
|
+
type?: string;
|
|
19
|
+
hasAfDrinks?: boolean;
|
|
20
|
+
isAfVenue?: boolean;
|
|
21
|
+
isFeatured?: boolean;
|
|
22
|
+
isPartner?: boolean;
|
|
23
|
+
lat?: number;
|
|
24
|
+
long?: number;
|
|
25
|
+
radius?: number;
|
|
26
|
+
sortBy?: string;
|
|
27
|
+
sortOrder?: 'asc' | 'desc';
|
|
28
|
+
}
|
|
29
|
+
export interface NearbyBusinessParams {
|
|
30
|
+
lat: number;
|
|
31
|
+
long: number;
|
|
32
|
+
radius?: number;
|
|
33
|
+
}
|
|
34
|
+
export interface PaginatedBusinessesResponse {
|
|
35
|
+
businesses: BusinessResponse[];
|
|
36
|
+
total: number;
|
|
37
|
+
page: number;
|
|
38
|
+
limit: number;
|
|
39
|
+
totalPages: number;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Get paginated list of businesses with optional filters
|
|
43
|
+
*
|
|
44
|
+
* @param filters - Query parameters for filtering and pagination
|
|
45
|
+
* @param options - TanStack Query options
|
|
46
|
+
*
|
|
47
|
+
* @example
|
|
48
|
+
* ```tsx
|
|
49
|
+
* const { data, isLoading } = useBusinesses({
|
|
50
|
+
* page: 1,
|
|
51
|
+
* limit: 20,
|
|
52
|
+
* cityId: 'city-123',
|
|
53
|
+
* hasAfDrinks: true,
|
|
54
|
+
* sortBy: 'name',
|
|
55
|
+
* sortOrder: 'asc'
|
|
56
|
+
* });
|
|
57
|
+
* ```
|
|
58
|
+
*/
|
|
59
|
+
export declare function useBusinesses(filters?: BusinessFilters, options?: Omit<UseQueryOptions<PaginatedBusinessesResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PaginatedBusinessesResponse, Error>;
|
|
60
|
+
/**
|
|
61
|
+
* Get featured businesses
|
|
62
|
+
*
|
|
63
|
+
* @param options - TanStack Query options
|
|
64
|
+
*
|
|
65
|
+
* @example
|
|
66
|
+
* ```tsx
|
|
67
|
+
* const { data, isLoading } = useFeaturedBusinesses();
|
|
68
|
+
* ```
|
|
69
|
+
*/
|
|
70
|
+
export declare function useFeaturedBusinesses(options?: Omit<UseQueryOptions<BusinessResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
71
|
+
id: string;
|
|
72
|
+
appId: string;
|
|
73
|
+
name: string;
|
|
74
|
+
slug?: Record<string, never>;
|
|
75
|
+
description?: Record<string, never>;
|
|
76
|
+
type: "COFFEE_SHOP" | "RESTAURANT" | "BAR" | "WELLNESS" | "VENUE" | "ACTIVITY" | "RETAIL" | "OTHER";
|
|
77
|
+
hasAfDrinks: boolean;
|
|
78
|
+
isAfVenue: boolean;
|
|
79
|
+
afHighlights: string[];
|
|
80
|
+
address?: Record<string, never>;
|
|
81
|
+
cityId?: Record<string, never>;
|
|
82
|
+
locationLat?: Record<string, never>;
|
|
83
|
+
locationLong?: Record<string, never>;
|
|
84
|
+
phone?: Record<string, never>;
|
|
85
|
+
email?: Record<string, never>;
|
|
86
|
+
website?: Record<string, never>;
|
|
87
|
+
instagramUrl?: Record<string, never>;
|
|
88
|
+
profileImage?: Record<string, never>;
|
|
89
|
+
bannerImage?: Record<string, never>;
|
|
90
|
+
photos: string[];
|
|
91
|
+
openingHours?: Record<string, never>;
|
|
92
|
+
isActive: boolean;
|
|
93
|
+
isVerified: boolean;
|
|
94
|
+
isFeatured: boolean;
|
|
95
|
+
isPartner: boolean;
|
|
96
|
+
createdAt: string;
|
|
97
|
+
updatedAt: string;
|
|
98
|
+
}[], Error>;
|
|
99
|
+
/**
|
|
100
|
+
* Get nearby businesses based on location
|
|
101
|
+
*
|
|
102
|
+
* @param params - Location parameters (latitude, longitude, radius)
|
|
103
|
+
* @param options - TanStack Query options
|
|
104
|
+
*
|
|
105
|
+
* @example
|
|
106
|
+
* ```tsx
|
|
107
|
+
* const { data, isLoading } = useNearbyBusinesses({
|
|
108
|
+
* lat: 51.5074,
|
|
109
|
+
* long: -0.1278,
|
|
110
|
+
* radius: 5000 // 5km radius
|
|
111
|
+
* });
|
|
112
|
+
* ```
|
|
113
|
+
*/
|
|
114
|
+
export declare function useNearbyBusinesses(params: NearbyBusinessParams, options?: Omit<UseQueryOptions<BusinessResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
115
|
+
id: string;
|
|
116
|
+
appId: string;
|
|
117
|
+
name: string;
|
|
118
|
+
slug?: Record<string, never>;
|
|
119
|
+
description?: Record<string, never>;
|
|
120
|
+
type: "COFFEE_SHOP" | "RESTAURANT" | "BAR" | "WELLNESS" | "VENUE" | "ACTIVITY" | "RETAIL" | "OTHER";
|
|
121
|
+
hasAfDrinks: boolean;
|
|
122
|
+
isAfVenue: boolean;
|
|
123
|
+
afHighlights: string[];
|
|
124
|
+
address?: Record<string, never>;
|
|
125
|
+
cityId?: Record<string, never>;
|
|
126
|
+
locationLat?: Record<string, never>;
|
|
127
|
+
locationLong?: Record<string, never>;
|
|
128
|
+
phone?: Record<string, never>;
|
|
129
|
+
email?: Record<string, never>;
|
|
130
|
+
website?: Record<string, never>;
|
|
131
|
+
instagramUrl?: Record<string, never>;
|
|
132
|
+
profileImage?: Record<string, never>;
|
|
133
|
+
bannerImage?: Record<string, never>;
|
|
134
|
+
photos: string[];
|
|
135
|
+
openingHours?: Record<string, never>;
|
|
136
|
+
isActive: boolean;
|
|
137
|
+
isVerified: boolean;
|
|
138
|
+
isFeatured: boolean;
|
|
139
|
+
isPartner: boolean;
|
|
140
|
+
createdAt: string;
|
|
141
|
+
updatedAt: string;
|
|
142
|
+
}[], Error>;
|
|
143
|
+
/**
|
|
144
|
+
* Get a single business by ID
|
|
145
|
+
*
|
|
146
|
+
* @param id - Business ID
|
|
147
|
+
* @param options - TanStack Query options
|
|
148
|
+
*
|
|
149
|
+
* @example
|
|
150
|
+
* ```tsx
|
|
151
|
+
* const { data, isLoading } = useBusiness('business-123');
|
|
152
|
+
* ```
|
|
153
|
+
*/
|
|
154
|
+
export declare function useBusiness(id: string, options?: Omit<UseQueryOptions<BusinessResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
155
|
+
id: string;
|
|
156
|
+
appId: string;
|
|
157
|
+
name: string;
|
|
158
|
+
slug?: Record<string, never>;
|
|
159
|
+
description?: Record<string, never>;
|
|
160
|
+
type: "COFFEE_SHOP" | "RESTAURANT" | "BAR" | "WELLNESS" | "VENUE" | "ACTIVITY" | "RETAIL" | "OTHER";
|
|
161
|
+
hasAfDrinks: boolean;
|
|
162
|
+
isAfVenue: boolean;
|
|
163
|
+
afHighlights: string[];
|
|
164
|
+
address?: Record<string, never>;
|
|
165
|
+
cityId?: Record<string, never>;
|
|
166
|
+
locationLat?: Record<string, never>;
|
|
167
|
+
locationLong?: Record<string, never>;
|
|
168
|
+
phone?: Record<string, never>;
|
|
169
|
+
email?: Record<string, never>;
|
|
170
|
+
website?: Record<string, never>;
|
|
171
|
+
instagramUrl?: Record<string, never>;
|
|
172
|
+
profileImage?: Record<string, never>;
|
|
173
|
+
bannerImage?: Record<string, never>;
|
|
174
|
+
photos: string[];
|
|
175
|
+
openingHours?: Record<string, never>;
|
|
176
|
+
isActive: boolean;
|
|
177
|
+
isVerified: boolean;
|
|
178
|
+
isFeatured: boolean;
|
|
179
|
+
isPartner: boolean;
|
|
180
|
+
createdAt: string;
|
|
181
|
+
updatedAt: string;
|
|
182
|
+
}, Error>;
|
|
183
|
+
/**
|
|
184
|
+
* Get all offers for a specific business
|
|
185
|
+
*
|
|
186
|
+
* @param businessId - Business ID
|
|
187
|
+
* @param options - TanStack Query options
|
|
188
|
+
*
|
|
189
|
+
* @example
|
|
190
|
+
* ```tsx
|
|
191
|
+
* const { data, isLoading } = useBusinessOffers('business-123');
|
|
192
|
+
* ```
|
|
193
|
+
*/
|
|
194
|
+
export declare function useBusinessOffers(businessId: string, options?: Omit<UseQueryOptions<OfferResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
195
|
+
id: string;
|
|
196
|
+
businessId: string;
|
|
197
|
+
title: string;
|
|
198
|
+
description?: Record<string, never>;
|
|
199
|
+
discountType?: "PERCENTAGE" | "FIXED_AMOUNT" | "FREE_ITEM" | "BOGO";
|
|
200
|
+
discountValue?: Record<string, never>;
|
|
201
|
+
discountCode?: Record<string, never>;
|
|
202
|
+
validFrom: string;
|
|
203
|
+
validTo?: Record<string, never>;
|
|
204
|
+
terms?: Record<string, never>;
|
|
205
|
+
maxRedemptions?: Record<string, never>;
|
|
206
|
+
redemptionCount: number;
|
|
207
|
+
perUserLimit?: Record<string, never>;
|
|
208
|
+
premiumOnly: boolean;
|
|
209
|
+
isActive: boolean;
|
|
210
|
+
createdAt: string;
|
|
211
|
+
updatedAt: string;
|
|
212
|
+
}[], Error>;
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.businessKeys = void 0;
|
|
4
|
+
exports.useBusinesses = useBusinesses;
|
|
5
|
+
exports.useFeaturedBusinesses = useFeaturedBusinesses;
|
|
6
|
+
exports.useNearbyBusinesses = useNearbyBusinesses;
|
|
7
|
+
exports.useBusiness = useBusiness;
|
|
8
|
+
exports.useBusinessOffers = useBusinessOffers;
|
|
9
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
10
|
+
const client_1 = require("../client");
|
|
11
|
+
// ============================================================================
|
|
12
|
+
// QUERY KEY FACTORY
|
|
13
|
+
// ============================================================================
|
|
14
|
+
exports.businessKeys = {
|
|
15
|
+
all: ['businesses'],
|
|
16
|
+
lists: () => [...exports.businessKeys.all, 'list'],
|
|
17
|
+
list: (filters) => [...exports.businessKeys.lists(), filters],
|
|
18
|
+
details: () => [...exports.businessKeys.all, 'detail'],
|
|
19
|
+
detail: (id) => [...exports.businessKeys.details(), id],
|
|
20
|
+
featured: () => [...exports.businessKeys.all, 'featured'],
|
|
21
|
+
nearby: (params) => [...exports.businessKeys.all, 'nearby', params],
|
|
22
|
+
offers: (businessId) => [...exports.businessKeys.detail(businessId), 'offers'],
|
|
23
|
+
};
|
|
24
|
+
// ============================================================================
|
|
25
|
+
// QUERY HOOKS
|
|
26
|
+
// ============================================================================
|
|
27
|
+
/**
|
|
28
|
+
* Get paginated list of businesses with optional filters
|
|
29
|
+
*
|
|
30
|
+
* @param filters - Query parameters for filtering and pagination
|
|
31
|
+
* @param options - TanStack Query options
|
|
32
|
+
*
|
|
33
|
+
* @example
|
|
34
|
+
* ```tsx
|
|
35
|
+
* const { data, isLoading } = useBusinesses({
|
|
36
|
+
* page: 1,
|
|
37
|
+
* limit: 20,
|
|
38
|
+
* cityId: 'city-123',
|
|
39
|
+
* hasAfDrinks: true,
|
|
40
|
+
* sortBy: 'name',
|
|
41
|
+
* sortOrder: 'asc'
|
|
42
|
+
* });
|
|
43
|
+
* ```
|
|
44
|
+
*/
|
|
45
|
+
function useBusinesses(filters, options) {
|
|
46
|
+
return (0, react_query_1.useQuery)({
|
|
47
|
+
queryKey: exports.businessKeys.list(filters),
|
|
48
|
+
queryFn: async () => {
|
|
49
|
+
const client = (0, client_1.getApiClient)();
|
|
50
|
+
const response = await client.get('/api/v1/businesses', {
|
|
51
|
+
params: filters,
|
|
52
|
+
});
|
|
53
|
+
return response.data;
|
|
54
|
+
},
|
|
55
|
+
...options,
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Get featured businesses
|
|
60
|
+
*
|
|
61
|
+
* @param options - TanStack Query options
|
|
62
|
+
*
|
|
63
|
+
* @example
|
|
64
|
+
* ```tsx
|
|
65
|
+
* const { data, isLoading } = useFeaturedBusinesses();
|
|
66
|
+
* ```
|
|
67
|
+
*/
|
|
68
|
+
function useFeaturedBusinesses(options) {
|
|
69
|
+
return (0, react_query_1.useQuery)({
|
|
70
|
+
queryKey: exports.businessKeys.featured(),
|
|
71
|
+
queryFn: async () => {
|
|
72
|
+
const client = (0, client_1.getApiClient)();
|
|
73
|
+
const response = await client.get('/api/v1/businesses/featured');
|
|
74
|
+
return response.data;
|
|
75
|
+
},
|
|
76
|
+
...options,
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Get nearby businesses based on location
|
|
81
|
+
*
|
|
82
|
+
* @param params - Location parameters (latitude, longitude, radius)
|
|
83
|
+
* @param options - TanStack Query options
|
|
84
|
+
*
|
|
85
|
+
* @example
|
|
86
|
+
* ```tsx
|
|
87
|
+
* const { data, isLoading } = useNearbyBusinesses({
|
|
88
|
+
* lat: 51.5074,
|
|
89
|
+
* long: -0.1278,
|
|
90
|
+
* radius: 5000 // 5km radius
|
|
91
|
+
* });
|
|
92
|
+
* ```
|
|
93
|
+
*/
|
|
94
|
+
function useNearbyBusinesses(params, options) {
|
|
95
|
+
return (0, react_query_1.useQuery)({
|
|
96
|
+
queryKey: exports.businessKeys.nearby(params),
|
|
97
|
+
queryFn: async () => {
|
|
98
|
+
const client = (0, client_1.getApiClient)();
|
|
99
|
+
const response = await client.get('/api/v1/businesses/nearby', {
|
|
100
|
+
params,
|
|
101
|
+
});
|
|
102
|
+
return response.data;
|
|
103
|
+
},
|
|
104
|
+
enabled: !!params.lat && !!params.long,
|
|
105
|
+
...options,
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Get a single business by ID
|
|
110
|
+
*
|
|
111
|
+
* @param id - Business ID
|
|
112
|
+
* @param options - TanStack Query options
|
|
113
|
+
*
|
|
114
|
+
* @example
|
|
115
|
+
* ```tsx
|
|
116
|
+
* const { data, isLoading } = useBusiness('business-123');
|
|
117
|
+
* ```
|
|
118
|
+
*/
|
|
119
|
+
function useBusiness(id, options) {
|
|
120
|
+
return (0, react_query_1.useQuery)({
|
|
121
|
+
queryKey: exports.businessKeys.detail(id),
|
|
122
|
+
queryFn: async () => {
|
|
123
|
+
const client = (0, client_1.getApiClient)();
|
|
124
|
+
const response = await client.get(`/api/v1/businesses/${id}`);
|
|
125
|
+
return response.data;
|
|
126
|
+
},
|
|
127
|
+
enabled: !!id,
|
|
128
|
+
...options,
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Get all offers for a specific business
|
|
133
|
+
*
|
|
134
|
+
* @param businessId - Business ID
|
|
135
|
+
* @param options - TanStack Query options
|
|
136
|
+
*
|
|
137
|
+
* @example
|
|
138
|
+
* ```tsx
|
|
139
|
+
* const { data, isLoading } = useBusinessOffers('business-123');
|
|
140
|
+
* ```
|
|
141
|
+
*/
|
|
142
|
+
function useBusinessOffers(businessId, options) {
|
|
143
|
+
return (0, react_query_1.useQuery)({
|
|
144
|
+
queryKey: exports.businessKeys.offers(businessId),
|
|
145
|
+
queryFn: async () => {
|
|
146
|
+
const client = (0, client_1.getApiClient)();
|
|
147
|
+
const response = await client.get(`/api/v1/businesses/${businessId}/offers`);
|
|
148
|
+
return response.data;
|
|
149
|
+
},
|
|
150
|
+
enabled: !!businessId,
|
|
151
|
+
...options,
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"businesses.js","sourceRoot":"","sources":["../../../src/api/queries/businesses.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { BusinessResponse, OfferResponse } from '../types';\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const businessKeys = {\n  all: ['businesses'] as const,\n  lists: () => [...businessKeys.all, 'list'] as const,\n  list: (filters?: BusinessFilters) => [...businessKeys.lists(), filters] as const,\n  details: () => [...businessKeys.all, 'detail'] as const,\n  detail: (id: string) => [...businessKeys.details(), id] as const,\n  featured: () => [...businessKeys.all, 'featured'] as const,\n  nearby: (params?: NearbyBusinessParams) => [...businessKeys.all, 'nearby', params] as const,\n  offers: (businessId: string) => [...businessKeys.detail(businessId), 'offers'] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface BusinessFilters {\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  isPartner?: boolean;\n  lat?: number;\n  long?: number;\n  radius?: number;\n  sortBy?: string;\n  sortOrder?: 'asc' | 'desc';\n}\n\nexport interface NearbyBusinessParams {\n  lat: number;\n  long: number;\n  radius?: number;\n}\n\nexport interface PaginatedBusinessesResponse {\n  businesses: BusinessResponse[];\n  total: number;\n  page: number;\n  limit: number;\n  totalPages: number;\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get paginated list of businesses 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 } = useBusinesses({\n *   page: 1,\n *   limit: 20,\n *   cityId: 'city-123',\n *   hasAfDrinks: true,\n *   sortBy: 'name',\n *   sortOrder: 'asc'\n * });\n * ```\n */\nexport function useBusinesses(\n  filters?: BusinessFilters,\n  options?: Omit<UseQueryOptions<PaginatedBusinessesResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: businessKeys.list(filters),\n    queryFn: async (): Promise<PaginatedBusinessesResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/businesses', {\n        params: filters,\n      });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get featured businesses\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useFeaturedBusinesses();\n * ```\n */\nexport function useFeaturedBusinesses(\n  options?: Omit<UseQueryOptions<BusinessResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: businessKeys.featured(),\n    queryFn: async (): Promise<BusinessResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/businesses/featured');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get nearby businesses 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 } = useNearbyBusinesses({\n *   lat: 51.5074,\n *   long: -0.1278,\n *   radius: 5000 // 5km radius\n * });\n * ```\n */\nexport function useNearbyBusinesses(\n  params: NearbyBusinessParams,\n  options?: Omit<UseQueryOptions<BusinessResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: businessKeys.nearby(params),\n    queryFn: async (): Promise<BusinessResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/businesses/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 business by ID\n *\n * @param id - Business ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useBusiness('business-123');\n * ```\n */\nexport function useBusiness(\n  id: string,\n  options?: Omit<UseQueryOptions<BusinessResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: businessKeys.detail(id),\n    queryFn: async (): Promise<BusinessResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/businesses/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\n/**\n * Get all offers for a specific business\n *\n * @param businessId - Business ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useBusinessOffers('business-123');\n * ```\n */\nexport function useBusinessOffers(\n  businessId: string,\n  options?: Omit<UseQueryOptions<OfferResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: businessKeys.offers(businessId),\n    queryFn: async (): Promise<OfferResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/businesses/${businessId}/offers`);\n      return response.data;\n    },\n    enabled: !!businessId,\n    ...options,\n  });\n}\n"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { EventChatResponse, ChatMemberResponse, PaginatedMessagesResponse } from '../types';
|
|
2
|
+
export declare const eventChatKeys: {
|
|
3
|
+
all: readonly ["event-chat"];
|
|
4
|
+
chat: (eventId: string) => readonly ["event-chat", "chat", string];
|
|
5
|
+
members: (eventId: string) => readonly ["event-chat", "members", string];
|
|
6
|
+
messages: (eventId: string) => readonly ["event-chat", "messages", string];
|
|
7
|
+
};
|
|
8
|
+
/**
|
|
9
|
+
* Get or create chat for an event
|
|
10
|
+
*/
|
|
11
|
+
export declare function useEventChat(eventId: string | undefined): import("@tanstack/react-query").UseQueryResult<EventChatResponse, Error>;
|
|
12
|
+
/**
|
|
13
|
+
* Get chat members
|
|
14
|
+
*/
|
|
15
|
+
export declare function useEventChatMembers(eventId: string | undefined): import("@tanstack/react-query").UseQueryResult<ChatMemberResponse[], Error>;
|
|
16
|
+
/**
|
|
17
|
+
* Get chat messages with infinite scroll pagination
|
|
18
|
+
*/
|
|
19
|
+
export declare function useEventChatMessages(eventId: string | undefined, limit?: number): import("@tanstack/react-query").UseInfiniteQueryResult<import("@tanstack/react-query").InfiniteData<PaginatedMessagesResponse, unknown>, Error>;
|