@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.
Files changed (129) hide show
  1. package/README.md +276 -0
  2. package/dist/__tests__/e2e.test.d.ts +7 -0
  3. package/dist/__tests__/e2e.test.js +472 -0
  4. package/dist/api/client.d.ts +11 -0
  5. package/dist/api/client.js +61 -0
  6. package/dist/api/mutations/admin.d.ts +167 -0
  7. package/dist/api/mutations/admin.js +326 -0
  8. package/dist/api/mutations/ambassadors.d.ts +52 -0
  9. package/dist/api/mutations/ambassadors.js +148 -0
  10. package/dist/api/mutations/auth.d.ts +267 -0
  11. package/dist/api/mutations/auth.js +332 -0
  12. package/dist/api/mutations/bookings.d.ts +59 -0
  13. package/dist/api/mutations/bookings.js +143 -0
  14. package/dist/api/mutations/event-chat.d.ts +35 -0
  15. package/dist/api/mutations/event-chat.js +147 -0
  16. package/dist/api/mutations/events.d.ts +87 -0
  17. package/dist/api/mutations/events.js +205 -0
  18. package/dist/api/mutations/grow90.d.ts +36 -0
  19. package/dist/api/mutations/grow90.js +132 -0
  20. package/dist/api/mutations/hubs.d.ts +111 -0
  21. package/dist/api/mutations/hubs.js +240 -0
  22. package/dist/api/mutations/index.d.ts +22 -0
  23. package/dist/api/mutations/index.js +39 -0
  24. package/dist/api/mutations/jack.d.ts +61 -0
  25. package/dist/api/mutations/jack.js +104 -0
  26. package/dist/api/mutations/library.d.ts +67 -0
  27. package/dist/api/mutations/library.js +168 -0
  28. package/dist/api/mutations/map.d.ts +153 -0
  29. package/dist/api/mutations/map.js +181 -0
  30. package/dist/api/mutations/matching.d.ts +130 -0
  31. package/dist/api/mutations/matching.js +204 -0
  32. package/dist/api/mutations/notifications.d.ts +63 -0
  33. package/dist/api/mutations/notifications.js +106 -0
  34. package/dist/api/mutations/offers.d.ts +26 -0
  35. package/dist/api/mutations/offers.js +47 -0
  36. package/dist/api/mutations/subscriptions.d.ts +127 -0
  37. package/dist/api/mutations/subscriptions.js +140 -0
  38. package/dist/api/mutations/support.d.ts +165 -0
  39. package/dist/api/mutations/support.js +307 -0
  40. package/dist/api/mutations/users.d.ts +211 -0
  41. package/dist/api/mutations/users.js +261 -0
  42. package/dist/api/queries/admin.d.ts +257 -0
  43. package/dist/api/queries/admin.js +320 -0
  44. package/dist/api/queries/ambassadors.d.ts +53 -0
  45. package/dist/api/queries/ambassadors.js +98 -0
  46. package/dist/api/queries/auth.d.ts +16 -0
  47. package/dist/api/queries/auth.js +25 -0
  48. package/dist/api/queries/bookings.d.ts +91 -0
  49. package/dist/api/queries/bookings.js +102 -0
  50. package/dist/api/queries/businesses.d.ts +212 -0
  51. package/dist/api/queries/businesses.js +154 -0
  52. package/dist/api/queries/event-chat.d.ts +19 -0
  53. package/dist/api/queries/event-chat.js +75 -0
  54. package/dist/api/queries/events.d.ts +322 -0
  55. package/dist/api/queries/events.js +221 -0
  56. package/dist/api/queries/grow90.d.ts +26 -0
  57. package/dist/api/queries/grow90.js +85 -0
  58. package/dist/api/queries/hubs.d.ts +165 -0
  59. package/dist/api/queries/hubs.js +143 -0
  60. package/dist/api/queries/index.d.ts +23 -0
  61. package/dist/api/queries/index.js +40 -0
  62. package/dist/api/queries/jack.d.ts +63 -0
  63. package/dist/api/queries/jack.js +92 -0
  64. package/dist/api/queries/library.d.ts +132 -0
  65. package/dist/api/queries/library.js +120 -0
  66. package/dist/api/queries/map.d.ts +216 -0
  67. package/dist/api/queries/map.js +278 -0
  68. package/dist/api/queries/matching.d.ts +136 -0
  69. package/dist/api/queries/matching.js +161 -0
  70. package/dist/api/queries/notifications.d.ts +78 -0
  71. package/dist/api/queries/notifications.js +88 -0
  72. package/dist/api/queries/offers.d.ts +91 -0
  73. package/dist/api/queries/offers.js +103 -0
  74. package/dist/api/queries/subscriptions.d.ts +56 -0
  75. package/dist/api/queries/subscriptions.js +73 -0
  76. package/dist/api/queries/support.d.ts +106 -0
  77. package/dist/api/queries/support.js +202 -0
  78. package/dist/api/queries/users.d.ts +293 -0
  79. package/dist/api/queries/users.js +370 -0
  80. package/dist/api/types.d.ts +464 -0
  81. package/dist/api/types.js +9 -0
  82. package/dist/hooks/useAuth.d.ts +5 -0
  83. package/dist/hooks/useAuth.js +39 -0
  84. package/dist/hooks/useUser.d.ts +43 -0
  85. package/dist/hooks/useUser.js +44 -0
  86. package/dist/index.d.ts +36 -0
  87. package/dist/index.js +67 -0
  88. package/package.json +62 -0
  89. package/src/__tests__/e2e.test.ts +502 -0
  90. package/src/api/client.ts +71 -0
  91. package/src/api/mutations/admin.ts +531 -0
  92. package/src/api/mutations/ambassadors.ts +185 -0
  93. package/src/api/mutations/auth.ts +350 -0
  94. package/src/api/mutations/bookings.ts +190 -0
  95. package/src/api/mutations/event-chat.ts +177 -0
  96. package/src/api/mutations/events.ts +273 -0
  97. package/src/api/mutations/grow90.ts +169 -0
  98. package/src/api/mutations/hubs.ts +385 -0
  99. package/src/api/mutations/index.ts +23 -0
  100. package/src/api/mutations/jack.ts +130 -0
  101. package/src/api/mutations/library.ts +212 -0
  102. package/src/api/mutations/map.ts +230 -0
  103. package/src/api/mutations/matching.ts +271 -0
  104. package/src/api/mutations/notifications.ts +114 -0
  105. package/src/api/mutations/offers.ts +73 -0
  106. package/src/api/mutations/subscriptions.ts +162 -0
  107. package/src/api/mutations/support.ts +390 -0
  108. package/src/api/mutations/users.ts +271 -0
  109. package/src/api/queries/admin.ts +480 -0
  110. package/src/api/queries/ambassadors.ts +139 -0
  111. package/src/api/queries/auth.ts +24 -0
  112. package/src/api/queries/bookings.ts +135 -0
  113. package/src/api/queries/businesses.ts +203 -0
  114. package/src/api/queries/event-chat.ts +78 -0
  115. package/src/api/queries/events.ts +272 -0
  116. package/src/api/queries/grow90.ts +98 -0
  117. package/src/api/queries/hubs.ts +211 -0
  118. package/src/api/queries/index.ts +24 -0
  119. package/src/api/queries/jack.ts +127 -0
  120. package/src/api/queries/library.ts +166 -0
  121. package/src/api/queries/map.ts +331 -0
  122. package/src/api/queries/matching.ts +238 -0
  123. package/src/api/queries/notifications.ts +103 -0
  124. package/src/api/queries/offers.ts +136 -0
  125. package/src/api/queries/subscriptions.ts +91 -0
  126. package/src/api/queries/support.ts +235 -0
  127. package/src/api/queries/users.ts +393 -0
  128. package/src/api/types.ts +596 -0
  129. 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>;