@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.
Files changed (70) hide show
  1. package/dist/__tests__/e2e.test.d.ts +30 -0
  2. package/dist/__tests__/e2e.test.js +959 -63
  3. package/dist/api/mutations/badges.d.ts +116 -0
  4. package/dist/api/mutations/badges.js +177 -0
  5. package/dist/api/mutations/brands.d.ts +251 -0
  6. package/dist/api/mutations/brands.js +242 -0
  7. package/dist/api/mutations/creators.d.ts +131 -0
  8. package/dist/api/mutations/creators.js +129 -0
  9. package/dist/api/mutations/event-chat.d.ts +2 -2
  10. package/dist/api/mutations/event-chat.js +9 -9
  11. package/dist/api/mutations/index.d.ts +4 -0
  12. package/dist/api/mutations/index.js +5 -1
  13. package/dist/api/mutations/jack.d.ts +29 -0
  14. package/dist/api/mutations/jack.js +41 -1
  15. package/dist/api/mutations/products.d.ts +175 -0
  16. package/dist/api/mutations/products.js +226 -0
  17. package/dist/api/mutations/support.d.ts +20 -1
  18. package/dist/api/mutations/support.js +36 -1
  19. package/dist/api/queries/badges.d.ts +221 -0
  20. package/dist/api/queries/badges.js +290 -0
  21. package/dist/api/queries/bookings.d.ts +1 -1
  22. package/dist/api/queries/brands.d.ts +248 -0
  23. package/dist/api/queries/brands.js +226 -0
  24. package/dist/api/queries/businesses.d.ts +61 -1
  25. package/dist/api/queries/businesses.js +27 -1
  26. package/dist/api/queries/creators.d.ts +332 -0
  27. package/dist/api/queries/creators.js +249 -0
  28. package/dist/api/queries/event-chat.d.ts +1 -1
  29. package/dist/api/queries/event-chat.js +4 -4
  30. package/dist/api/queries/events.d.ts +45 -0
  31. package/dist/api/queries/index.d.ts +5 -0
  32. package/dist/api/queries/index.js +6 -1
  33. package/dist/api/queries/jack.d.ts +80 -0
  34. package/dist/api/queries/jack.js +98 -1
  35. package/dist/api/queries/library.d.ts +8 -0
  36. package/dist/api/queries/products.d.ts +185 -0
  37. package/dist/api/queries/products.js +203 -0
  38. package/dist/api/queries/support.d.ts +46 -1
  39. package/dist/api/queries/support.js +48 -1
  40. package/dist/api/queries/venues.d.ts +304 -0
  41. package/dist/api/queries/venues.js +211 -0
  42. package/dist/api/types.d.ts +245 -0
  43. package/dist/api/types.js +6 -1
  44. package/dist/api/utils/eventGrouping.d.ts +104 -0
  45. package/dist/api/utils/eventGrouping.js +155 -0
  46. package/dist/index.d.ts +1 -0
  47. package/dist/index.js +5 -1
  48. package/package.json +5 -2
  49. package/src/__tests__/e2e.test.ts +996 -64
  50. package/src/api/mutations/badges.ts +228 -0
  51. package/src/api/mutations/brands.ts +376 -0
  52. package/src/api/mutations/creators.ts +171 -0
  53. package/src/api/mutations/event-chat.ts +8 -8
  54. package/src/api/mutations/index.ts +4 -0
  55. package/src/api/mutations/jack.ts +50 -1
  56. package/src/api/mutations/products.ts +336 -0
  57. package/src/api/mutations/support.ts +44 -0
  58. package/src/api/queries/badges.ts +385 -0
  59. package/src/api/queries/brands.ts +281 -0
  60. package/src/api/queries/businesses.ts +30 -1
  61. package/src/api/queries/creators.ts +308 -0
  62. package/src/api/queries/event-chat.ts +3 -3
  63. package/src/api/queries/index.ts +5 -0
  64. package/src/api/queries/jack.ts +139 -1
  65. package/src/api/queries/products.ts +312 -0
  66. package/src/api/queries/support.ts +54 -0
  67. package/src/api/queries/venues.ts +271 -0
  68. package/src/api/types.ts +317 -1
  69. package/src/api/utils/eventGrouping.ts +181 -0
  70. package/src/index.ts +6 -0
@@ -0,0 +1,290 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.rewardKeys = exports.badgeKeys = void 0;
4
+ exports.useBadges = useBadges;
5
+ exports.useBadge = useBadge;
6
+ exports.useMyBadges = useMyBadges;
7
+ exports.useNextBadges = useNextBadges;
8
+ exports.useAvailableRewards = useAvailableRewards;
9
+ exports.useRewardsForBadge = useRewardsForBadge;
10
+ exports.useBusinessRewards = useBusinessRewards;
11
+ exports.useRedeemedRewards = useRedeemedRewards;
12
+ exports.useRewardsWallet = useRewardsWallet;
13
+ exports.useVenueRewards = useVenueRewards;
14
+ exports.useBrandRewardsQuery = useBrandRewardsQuery;
15
+ exports.useUnifiedWallet = useUnifiedWallet;
16
+ const react_query_1 = require("@tanstack/react-query");
17
+ const client_1 = require("../client");
18
+ // ============================================================================
19
+ // QUERY KEY FACTORY
20
+ // ============================================================================
21
+ exports.badgeKeys = {
22
+ all: ['badges'],
23
+ lists: () => [...exports.badgeKeys.all, 'list'],
24
+ list: (userId) => [...exports.badgeKeys.lists(), userId],
25
+ detail: (id) => [...exports.badgeKeys.all, 'detail', id],
26
+ user: (userId) => [...exports.badgeKeys.all, 'user', userId],
27
+ next: (userId) => [...exports.badgeKeys.all, 'next', userId],
28
+ };
29
+ exports.rewardKeys = {
30
+ all: ['rewards'],
31
+ available: () => [...exports.rewardKeys.all, 'available'],
32
+ forBadge: (badgeId) => [...exports.rewardKeys.all, 'badge', badgeId],
33
+ forBusiness: (businessId) => [...exports.rewardKeys.all, 'business', businessId],
34
+ forVenue: (venueId) => [...exports.rewardKeys.all, 'venue', venueId],
35
+ forBrand: (brandId) => [...exports.rewardKeys.all, 'brand', brandId],
36
+ redeemed: () => [...exports.rewardKeys.all, 'redeemed'],
37
+ wallet: () => [...exports.rewardKeys.all, 'wallet'],
38
+ };
39
+ // ============================================================================
40
+ // BADGE QUERY HOOKS
41
+ // ============================================================================
42
+ /**
43
+ * Get all available badges
44
+ *
45
+ * @example
46
+ * ```tsx
47
+ * const { data: badges } = useBadges();
48
+ * ```
49
+ */
50
+ function useBadges(options) {
51
+ return (0, react_query_1.useQuery)({
52
+ queryKey: exports.badgeKeys.lists(),
53
+ queryFn: async () => {
54
+ const client = (0, client_1.getApiClient)();
55
+ const response = await client.get('/api/v1/badges');
56
+ return response.data?.data || response.data || [];
57
+ },
58
+ ...options,
59
+ });
60
+ }
61
+ /**
62
+ * Get a single badge by ID
63
+ *
64
+ * @param id - Badge ID
65
+ * @example
66
+ * ```tsx
67
+ * const { data: badge } = useBadge('badge-123');
68
+ * ```
69
+ */
70
+ function useBadge(id, options) {
71
+ return (0, react_query_1.useQuery)({
72
+ queryKey: exports.badgeKeys.detail(id),
73
+ queryFn: async () => {
74
+ const client = (0, client_1.getApiClient)();
75
+ const response = await client.get(`/api/v1/badges/${id}`);
76
+ return response.data?.data || response.data;
77
+ },
78
+ enabled: !!id,
79
+ ...options,
80
+ });
81
+ }
82
+ /**
83
+ * Get current user's earned badges
84
+ *
85
+ * @example
86
+ * ```tsx
87
+ * const { data: myBadges } = useMyBadges();
88
+ * ```
89
+ */
90
+ function useMyBadges(options) {
91
+ return (0, react_query_1.useQuery)({
92
+ queryKey: exports.badgeKeys.user('me'),
93
+ queryFn: async () => {
94
+ const client = (0, client_1.getApiClient)();
95
+ const response = await client.get('/api/v1/badges/me');
96
+ return response.data?.data || response.data || [];
97
+ },
98
+ ...options,
99
+ });
100
+ }
101
+ /**
102
+ * Get next badges user can earn (with progress)
103
+ *
104
+ * @example
105
+ * ```tsx
106
+ * const { data: nextBadges } = useNextBadges();
107
+ * // nextBadges = [{ badge: {...}, currentProgress: 5, requiredProgress: 10, percentComplete: 50 }, ...]
108
+ * ```
109
+ */
110
+ function useNextBadges(options) {
111
+ return (0, react_query_1.useQuery)({
112
+ queryKey: exports.badgeKeys.next('me'),
113
+ queryFn: async () => {
114
+ const client = (0, client_1.getApiClient)();
115
+ const response = await client.get('/api/v1/badges/next');
116
+ return response.data?.data || response.data || [];
117
+ },
118
+ ...options,
119
+ });
120
+ }
121
+ // ============================================================================
122
+ // PARTNER REWARD QUERY HOOKS
123
+ // ============================================================================
124
+ /**
125
+ * Get all rewards available to the current user (based on earned badges)
126
+ *
127
+ * @example
128
+ * ```tsx
129
+ * const { data: rewards } = useAvailableRewards();
130
+ * ```
131
+ */
132
+ function useAvailableRewards(options) {
133
+ return (0, react_query_1.useQuery)({
134
+ queryKey: exports.rewardKeys.available(),
135
+ queryFn: async () => {
136
+ const client = (0, client_1.getApiClient)();
137
+ const response = await client.get('/api/v1/rewards/available');
138
+ return response.data?.data || response.data || [];
139
+ },
140
+ ...options,
141
+ });
142
+ }
143
+ /**
144
+ * Get rewards for a specific badge
145
+ *
146
+ * @param badgeId - Badge ID
147
+ * @example
148
+ * ```tsx
149
+ * const { data: rewards } = useRewardsForBadge('badge-123');
150
+ * ```
151
+ */
152
+ function useRewardsForBadge(badgeId, options) {
153
+ return (0, react_query_1.useQuery)({
154
+ queryKey: exports.rewardKeys.forBadge(badgeId),
155
+ queryFn: async () => {
156
+ const client = (0, client_1.getApiClient)();
157
+ const response = await client.get(`/api/v1/rewards/badge/${badgeId}`);
158
+ return response.data?.data || response.data || [];
159
+ },
160
+ enabled: !!badgeId,
161
+ ...options,
162
+ });
163
+ }
164
+ /**
165
+ * Get rewards offered by a specific business
166
+ *
167
+ * @param businessId - Business ID
168
+ * @example
169
+ * ```tsx
170
+ * const { data: rewards } = useBusinessRewards('business-123');
171
+ * ```
172
+ */
173
+ function useBusinessRewards(businessId, options) {
174
+ return (0, react_query_1.useQuery)({
175
+ queryKey: exports.rewardKeys.forBusiness(businessId),
176
+ queryFn: async () => {
177
+ const client = (0, client_1.getApiClient)();
178
+ const response = await client.get(`/api/v1/rewards/business/${businessId}`);
179
+ return response.data?.data || response.data || [];
180
+ },
181
+ enabled: !!businessId,
182
+ ...options,
183
+ });
184
+ }
185
+ /**
186
+ * Get user's redeemed rewards
187
+ *
188
+ * @example
189
+ * ```tsx
190
+ * const { data: redeemed } = useRedeemedRewards();
191
+ * ```
192
+ */
193
+ function useRedeemedRewards(options) {
194
+ return (0, react_query_1.useQuery)({
195
+ queryKey: exports.rewardKeys.redeemed(),
196
+ queryFn: async () => {
197
+ const client = (0, client_1.getApiClient)();
198
+ const response = await client.get('/api/v1/rewards/redeemed');
199
+ return response.data?.data || response.data || [];
200
+ },
201
+ ...options,
202
+ });
203
+ }
204
+ /**
205
+ * Get user's wallet - all earned badges with available and redeemed rewards
206
+ * This is the main data source for the Rewards tab
207
+ *
208
+ * @example
209
+ * ```tsx
210
+ * const { data: wallet } = useRewardsWallet();
211
+ * // wallet.badges = [{ badge: {...}, availableRewards: [...], redeemedRewards: [...] }, ...]
212
+ * // wallet.stats = { totalBadges: 5, totalAvailableRewards: 3, totalRedeemedRewards: 2 }
213
+ * ```
214
+ */
215
+ function useRewardsWallet(options) {
216
+ return (0, react_query_1.useQuery)({
217
+ queryKey: exports.rewardKeys.wallet(),
218
+ queryFn: async () => {
219
+ const client = (0, client_1.getApiClient)();
220
+ const response = await client.get('/api/v1/rewards/wallet');
221
+ return response.data?.data || response.data;
222
+ },
223
+ ...options,
224
+ });
225
+ }
226
+ // ============================================================================
227
+ // UNIFIED REWARD HOOKS (Venue & Brand)
228
+ // ============================================================================
229
+ /**
230
+ * Get rewards for a specific venue (unified reward model)
231
+ *
232
+ * @param venueId - Venue ID
233
+ * @example
234
+ * ```tsx
235
+ * const { data: rewards } = useVenueRewards('venue-123');
236
+ * ```
237
+ */
238
+ function useVenueRewards(venueId, options) {
239
+ return (0, react_query_1.useQuery)({
240
+ queryKey: exports.rewardKeys.forVenue(venueId),
241
+ queryFn: async () => {
242
+ const client = (0, client_1.getApiClient)();
243
+ const response = await client.get(`/api/v1/rewards/venue/${venueId}`);
244
+ return response.data?.data || response.data || [];
245
+ },
246
+ enabled: !!venueId,
247
+ ...options,
248
+ });
249
+ }
250
+ /**
251
+ * Get rewards for a specific brand (unified reward model)
252
+ *
253
+ * @param brandId - Brand ID
254
+ * @example
255
+ * ```tsx
256
+ * const { data: rewards } = useBrandRewardsQuery('brand-123');
257
+ * ```
258
+ */
259
+ function useBrandRewardsQuery(brandId, options) {
260
+ return (0, react_query_1.useQuery)({
261
+ queryKey: exports.rewardKeys.forBrand(brandId),
262
+ queryFn: async () => {
263
+ const client = (0, client_1.getApiClient)();
264
+ const response = await client.get(`/api/v1/rewards/brand/${brandId}`);
265
+ return response.data?.data || response.data || [];
266
+ },
267
+ enabled: !!brandId,
268
+ ...options,
269
+ });
270
+ }
271
+ /**
272
+ * Get unified wallet with venue and brand rewards
273
+ *
274
+ * @example
275
+ * ```tsx
276
+ * const { data: wallet } = useUnifiedWallet();
277
+ * ```
278
+ */
279
+ function useUnifiedWallet(options) {
280
+ return (0, react_query_1.useQuery)({
281
+ queryKey: [...exports.rewardKeys.wallet(), 'unified'],
282
+ queryFn: async () => {
283
+ const client = (0, client_1.getApiClient)();
284
+ const response = await client.get('/api/v1/rewards/wallet');
285
+ return response.data?.data || response.data;
286
+ },
287
+ ...options,
288
+ });
289
+ }
290
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badges.js","sourceRoot":"","sources":["../../../src/api/queries/badges.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type {\n  BadgeResponse,\n  UserBadgeResponse,\n  BadgeWithProgress,\n  PartnerRewardResponse,\n  PartnerRewardRedemptionResponse,\n  RewardResponse,\n  UserWalletResponse,\n} from '../types';\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const badgeKeys = {\n  all: ['badges'] as const,\n  lists: () => [...badgeKeys.all, 'list'] as const,\n  list: (userId?: string) => [...badgeKeys.lists(), userId] as const,\n  detail: (id: string) => [...badgeKeys.all, 'detail', id] as const,\n  user: (userId: string) => [...badgeKeys.all, 'user', userId] as const,\n  next: (userId: string) => [...badgeKeys.all, 'next', userId] as const,\n};\n\nexport const rewardKeys = {\n  all: ['rewards'] as const,\n  available: () => [...rewardKeys.all, 'available'] as const,\n  forBadge: (badgeId: string) => [...rewardKeys.all, 'badge', badgeId] as const,\n  forBusiness: (businessId: string) => [...rewardKeys.all, 'business', businessId] as const,\n  forVenue: (venueId: string) => [...rewardKeys.all, 'venue', venueId] as const,\n  forBrand: (brandId: string) => [...rewardKeys.all, 'brand', brandId] as const,\n  redeemed: () => [...rewardKeys.all, 'redeemed'] as const,\n  wallet: () => [...rewardKeys.all, 'wallet'] as const,\n};\n\n// ============================================================================\n// BADGE QUERY HOOKS\n// ============================================================================\n\n/**\n * Get all available badges\n *\n * @example\n * ```tsx\n * const { data: badges } = useBadges();\n * ```\n */\nexport function useBadges(\n  options?: Omit<UseQueryOptions<BadgeResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: badgeKeys.lists(),\n    queryFn: async (): Promise<BadgeResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/badges');\n      return response.data?.data || response.data || [];\n    },\n    ...options,\n  });\n}\n\n/**\n * Get a single badge by ID\n *\n * @param id - Badge ID\n * @example\n * ```tsx\n * const { data: badge } = useBadge('badge-123');\n * ```\n */\nexport function useBadge(\n  id: string,\n  options?: Omit<UseQueryOptions<BadgeResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: badgeKeys.detail(id),\n    queryFn: async (): Promise<BadgeResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/badges/${id}`);\n      return response.data?.data || response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\n/**\n * Get current user's earned badges\n *\n * @example\n * ```tsx\n * const { data: myBadges } = useMyBadges();\n * ```\n */\nexport function useMyBadges(\n  options?: Omit<UseQueryOptions<UserBadgeResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: badgeKeys.user('me'),\n    queryFn: async (): Promise<UserBadgeResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/badges/me');\n      return response.data?.data || response.data || [];\n    },\n    ...options,\n  });\n}\n\n/**\n * Get next badges user can earn (with progress)\n *\n * @example\n * ```tsx\n * const { data: nextBadges } = useNextBadges();\n * // nextBadges = [{ badge: {...}, currentProgress: 5, requiredProgress: 10, percentComplete: 50 }, ...]\n * ```\n */\nexport function useNextBadges(\n  options?: Omit<UseQueryOptions<BadgeWithProgress[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: badgeKeys.next('me'),\n    queryFn: async (): Promise<BadgeWithProgress[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/badges/next');\n      return response.data?.data || response.data || [];\n    },\n    ...options,\n  });\n}\n\n// ============================================================================\n// PARTNER REWARD QUERY HOOKS\n// ============================================================================\n\n/**\n * Get all rewards available to the current user (based on earned badges)\n *\n * @example\n * ```tsx\n * const { data: rewards } = useAvailableRewards();\n * ```\n */\nexport function useAvailableRewards(\n  options?: Omit<UseQueryOptions<PartnerRewardResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: rewardKeys.available(),\n    queryFn: async (): Promise<PartnerRewardResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/rewards/available');\n      return response.data?.data || response.data || [];\n    },\n    ...options,\n  });\n}\n\n/**\n * Get rewards for a specific badge\n *\n * @param badgeId - Badge ID\n * @example\n * ```tsx\n * const { data: rewards } = useRewardsForBadge('badge-123');\n * ```\n */\nexport function useRewardsForBadge(\n  badgeId: string,\n  options?: Omit<UseQueryOptions<PartnerRewardResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: rewardKeys.forBadge(badgeId),\n    queryFn: async (): Promise<PartnerRewardResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/rewards/badge/${badgeId}`);\n      return response.data?.data || response.data || [];\n    },\n    enabled: !!badgeId,\n    ...options,\n  });\n}\n\n/**\n * Get rewards offered by a specific business\n *\n * @param businessId - Business ID\n * @example\n * ```tsx\n * const { data: rewards } = useBusinessRewards('business-123');\n * ```\n */\nexport function useBusinessRewards(\n  businessId: string,\n  options?: Omit<UseQueryOptions<PartnerRewardResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: rewardKeys.forBusiness(businessId),\n    queryFn: async (): Promise<PartnerRewardResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/rewards/business/${businessId}`);\n      return response.data?.data || response.data || [];\n    },\n    enabled: !!businessId,\n    ...options,\n  });\n}\n\n/**\n * Get user's redeemed rewards\n *\n * @example\n * ```tsx\n * const { data: redeemed } = useRedeemedRewards();\n * ```\n */\nexport function useRedeemedRewards(\n  options?: Omit<UseQueryOptions<PartnerRewardRedemptionResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: rewardKeys.redeemed(),\n    queryFn: async (): Promise<PartnerRewardRedemptionResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/rewards/redeemed');\n      return response.data?.data || response.data || [];\n    },\n    ...options,\n  });\n}\n\n// ============================================================================\n// WALLET (Combined badges + rewards for Rewards tab)\n// ============================================================================\n\n/**\n * Wallet reward card with QR token for redemption\n */\nexport interface WalletReward {\n  id: string;\n  title: string;\n  description: string | null;\n  code: string | null;\n  validUntil: string | null;\n  badge: {\n    id: string;\n    name: string;\n    slug: string;\n    icon: string | null;\n  };\n  business: {\n    id: string;\n    name: string;\n    profileImage: string | null;\n    address: string | null;\n  };\n}\n\nexport interface WalletRedemption {\n  id: string;\n  redeemedAt: string;\n  verifiedAt: string | null;\n  qrToken: string;\n  partnerReward: WalletReward;\n}\n\nexport interface WalletBadge {\n  id: string;\n  badgeId: string;\n  userId: string;\n  awardedAt: string;\n  note: string | null;\n  badge: BadgeResponse;\n  availableRewards: WalletReward[];\n  redeemedRewards: WalletRedemption[];\n}\n\nexport interface WalletResponse {\n  badges: WalletBadge[];\n  stats: {\n    totalBadges: number;\n    totalAvailableRewards: number;\n    totalRedeemedRewards: number;\n  };\n}\n\n/**\n * Get user's wallet - all earned badges with available and redeemed rewards\n * This is the main data source for the Rewards tab\n *\n * @example\n * ```tsx\n * const { data: wallet } = useRewardsWallet();\n * // wallet.badges = [{ badge: {...}, availableRewards: [...], redeemedRewards: [...] }, ...]\n * // wallet.stats = { totalBadges: 5, totalAvailableRewards: 3, totalRedeemedRewards: 2 }\n * ```\n */\nexport function useRewardsWallet(\n  options?: Omit<UseQueryOptions<WalletResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: rewardKeys.wallet(),\n    queryFn: async (): Promise<WalletResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/rewards/wallet');\n      return response.data?.data || response.data;\n    },\n    ...options,\n  });\n}\n\n// ============================================================================\n// UNIFIED REWARD HOOKS (Venue & Brand)\n// ============================================================================\n\n/**\n * Get rewards for a specific venue (unified reward model)\n *\n * @param venueId - Venue ID\n * @example\n * ```tsx\n * const { data: rewards } = useVenueRewards('venue-123');\n * ```\n */\nexport function useVenueRewards(\n  venueId: string,\n  options?: Omit<UseQueryOptions<RewardResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: rewardKeys.forVenue(venueId),\n    queryFn: async (): Promise<RewardResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/rewards/venue/${venueId}`);\n      return response.data?.data || response.data || [];\n    },\n    enabled: !!venueId,\n    ...options,\n  });\n}\n\n/**\n * Get rewards for a specific brand (unified reward model)\n *\n * @param brandId - Brand ID\n * @example\n * ```tsx\n * const { data: rewards } = useBrandRewardsQuery('brand-123');\n * ```\n */\nexport function useBrandRewardsQuery(\n  brandId: string,\n  options?: Omit<UseQueryOptions<RewardResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: rewardKeys.forBrand(brandId),\n    queryFn: async (): Promise<RewardResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/rewards/brand/${brandId}`);\n      return response.data?.data || response.data || [];\n    },\n    enabled: !!brandId,\n    ...options,\n  });\n}\n\n/**\n * Get unified wallet with venue and brand rewards\n *\n * @example\n * ```tsx\n * const { data: wallet } = useUnifiedWallet();\n * ```\n */\nexport function useUnifiedWallet(\n  options?: Omit<UseQueryOptions<UserWalletResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: [...rewardKeys.wallet(), 'unified'],\n    queryFn: async (): Promise<UserWalletResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/rewards/wallet');\n      return response.data?.data || response.data;\n    },\n    ...options,\n  });\n}\n"]}
@@ -52,7 +52,7 @@ export declare function useBooking(id: string, options?: Omit<UseQueryOptions<Bo
52
52
  checkedInAt?: Record<string, never>;
53
53
  checkedInBy?: Record<string, never>;
54
54
  paymentId?: Record<string, never>;
55
- paymentStatus?: "PENDING" | "COMPLETED" | "FAILED" | "REFUNDED";
55
+ paymentStatus?: "PENDING" | "PROCESSING" | "COMPLETED" | "TRANSFERRED" | "FAILED" | "REFUNDED" | "PARTIALLY_REFUNDED" | "DISPUTED";
56
56
  qrCode?: Record<string, never>;
57
57
  notes?: Record<string, never>;
58
58
  createdAt: string;
@@ -0,0 +1,248 @@
1
+ import { UseQueryOptions } from '@tanstack/react-query';
2
+ import type { BrandResponse, BrandOwnerResponse, BrandCreatorResponse, RewardResponse, EventResponse } from '../types';
3
+ export declare const brandKeys: {
4
+ all: readonly ["brands"];
5
+ lists: () => readonly ["brands", "list"];
6
+ list: (filters?: BrandFilters) => readonly ["brands", "list", BrandFilters | undefined];
7
+ details: () => readonly ["brands", "detail"];
8
+ detail: (id: string) => readonly ["brands", "detail", string];
9
+ slug: (slug: string) => readonly ["brands", "slug", string];
10
+ featured: () => readonly ["brands", "featured"];
11
+ owners: (brandId: string) => readonly ["brands", "detail", string, "owners"];
12
+ creators: (brandId: string) => readonly ["brands", "detail", string, "creators"];
13
+ rewards: (brandId: string) => readonly ["brands", "detail", string, "rewards"];
14
+ events: (brandId: string) => readonly ["brands", "detail", string, "events"];
15
+ };
16
+ export interface BrandFilters {
17
+ page?: number;
18
+ limit?: number;
19
+ search?: string;
20
+ isVerified?: boolean;
21
+ isFeatured?: boolean;
22
+ sortBy?: string;
23
+ sortOrder?: 'asc' | 'desc';
24
+ }
25
+ export interface PaginatedBrandsResponse {
26
+ brands: BrandResponse[];
27
+ meta: {
28
+ total: number;
29
+ page: number;
30
+ limit: number;
31
+ totalPages: number;
32
+ };
33
+ }
34
+ /**
35
+ * Get paginated list of brands with optional filters
36
+ *
37
+ * @param filters - Query parameters for filtering and pagination
38
+ * @param options - TanStack Query options
39
+ *
40
+ * @example
41
+ * ```tsx
42
+ * const { data, isLoading } = useBrands({
43
+ * page: 1,
44
+ * limit: 20,
45
+ * isFeatured: true,
46
+ * });
47
+ * ```
48
+ */
49
+ export declare function useBrands(filters?: BrandFilters, options?: Omit<UseQueryOptions<PaginatedBrandsResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PaginatedBrandsResponse, Error>;
50
+ /**
51
+ * Get a single brand by ID
52
+ *
53
+ * @param id - Brand ID
54
+ * @param options - TanStack Query options
55
+ *
56
+ * @example
57
+ * ```tsx
58
+ * const { data, isLoading } = useBrand('brand-123');
59
+ * ```
60
+ */
61
+ export declare function useBrand(id: string, options?: Omit<UseQueryOptions<BrandResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
62
+ id: string;
63
+ slug: string;
64
+ name: string;
65
+ description?: Record<string, never>;
66
+ logoUrl?: Record<string, never>;
67
+ bannerUrl?: Record<string, never>;
68
+ primaryColor?: Record<string, never>;
69
+ website?: Record<string, never>;
70
+ email?: Record<string, never>;
71
+ instagram?: Record<string, never>;
72
+ isActive: boolean;
73
+ isVerified: boolean;
74
+ isFeatured: boolean;
75
+ createdAt: string;
76
+ updatedAt: string;
77
+ }, Error>;
78
+ /**
79
+ * Get a brand by its slug
80
+ *
81
+ * @param slug - Brand slug
82
+ * @param options - TanStack Query options
83
+ *
84
+ * @example
85
+ * ```tsx
86
+ * const { data, isLoading } = useBrandBySlug('wellness-co');
87
+ * ```
88
+ */
89
+ export declare function useBrandBySlug(slug: string, options?: Omit<UseQueryOptions<BrandResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
90
+ id: string;
91
+ slug: string;
92
+ name: string;
93
+ description?: Record<string, never>;
94
+ logoUrl?: Record<string, never>;
95
+ bannerUrl?: Record<string, never>;
96
+ primaryColor?: Record<string, never>;
97
+ website?: Record<string, never>;
98
+ email?: Record<string, never>;
99
+ instagram?: Record<string, never>;
100
+ isActive: boolean;
101
+ isVerified: boolean;
102
+ isFeatured: boolean;
103
+ createdAt: string;
104
+ updatedAt: string;
105
+ }, Error>;
106
+ /**
107
+ * Get featured brands
108
+ *
109
+ * @param limit - Maximum number of brands to return
110
+ * @param options - TanStack Query options
111
+ *
112
+ * @example
113
+ * ```tsx
114
+ * const { data, isLoading } = useFeaturedBrands(10);
115
+ * ```
116
+ */
117
+ export declare function useFeaturedBrands(limit?: number, options?: Omit<UseQueryOptions<BrandResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
118
+ id: string;
119
+ slug: string;
120
+ name: string;
121
+ description?: Record<string, never>;
122
+ logoUrl?: Record<string, never>;
123
+ bannerUrl?: Record<string, never>;
124
+ primaryColor?: Record<string, never>;
125
+ website?: Record<string, never>;
126
+ email?: Record<string, never>;
127
+ instagram?: Record<string, never>;
128
+ isActive: boolean;
129
+ isVerified: boolean;
130
+ isFeatured: boolean;
131
+ createdAt: string;
132
+ updatedAt: string;
133
+ }[], Error>;
134
+ /**
135
+ * Get brand owners
136
+ *
137
+ * @param brandId - Brand ID
138
+ * @param options - TanStack Query options
139
+ *
140
+ * @example
141
+ * ```tsx
142
+ * const { data, isLoading } = useBrandOwners('brand-123');
143
+ * ```
144
+ */
145
+ export declare function useBrandOwners(brandId: string, options?: Omit<UseQueryOptions<BrandOwnerResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
146
+ id: string;
147
+ brandId: string;
148
+ userId: string;
149
+ role: "OWNER" | "MANAGER" | "MARKETING";
150
+ user?: import("@growsober/types/dist/generated").components["schemas"]["BrandOwnerUserDto"];
151
+ createdAt: string;
152
+ updatedAt: string;
153
+ }[], Error>;
154
+ /**
155
+ * Get brand creator partnerships
156
+ *
157
+ * @param brandId - Brand ID
158
+ * @param options - TanStack Query options
159
+ *
160
+ * @example
161
+ * ```tsx
162
+ * const { data, isLoading } = useBrandCreators('brand-123');
163
+ * ```
164
+ */
165
+ export declare function useBrandCreators(brandId: string, options?: Omit<UseQueryOptions<BrandCreatorResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
166
+ id: string;
167
+ brandId: string;
168
+ creatorId: string;
169
+ startDate?: string;
170
+ endDate?: string;
171
+ isActive: boolean;
172
+ commissionRate?: number;
173
+ creator?: Record<string, never>;
174
+ createdAt: string;
175
+ updatedAt: string;
176
+ }[], Error>;
177
+ /**
178
+ * Get brand rewards
179
+ *
180
+ * @param brandId - Brand ID
181
+ * @param options - TanStack Query options
182
+ *
183
+ * @example
184
+ * ```tsx
185
+ * const { data, isLoading } = useBrandRewards('brand-123');
186
+ * ```
187
+ */
188
+ export declare function useBrandRewards(brandId: string, options?: Omit<UseQueryOptions<RewardResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<RewardResponse[], Error>;
189
+ /**
190
+ * Get events sponsored by a brand
191
+ *
192
+ * @param brandId - Brand ID
193
+ * @param upcoming - Whether to filter to upcoming events only (default: true)
194
+ * @param options - TanStack Query options
195
+ *
196
+ * @example
197
+ * ```tsx
198
+ * const { data, isLoading } = useBrandSponsoredEvents('brand-123');
199
+ * ```
200
+ */
201
+ export declare function useBrandSponsoredEvents(brandId: string, upcoming?: boolean, options?: Omit<UseQueryOptions<EventResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
202
+ id: string;
203
+ title: string;
204
+ slug?: Record<string, never>;
205
+ description?: Record<string, never>;
206
+ bannerImage?: Record<string, never>;
207
+ startDate: string;
208
+ endDate?: Record<string, never>;
209
+ timezone?: Record<string, never>;
210
+ isRecurring: boolean;
211
+ recurrenceRule?: Record<string, never>;
212
+ locationName?: Record<string, never>;
213
+ locationAddress?: Record<string, never>;
214
+ locationLat?: Record<string, never>;
215
+ locationLong?: Record<string, never>;
216
+ cityId?: Record<string, never>;
217
+ isOnline: boolean;
218
+ onlineUrl?: Record<string, never>;
219
+ totalSpots: number;
220
+ availableSpots: number;
221
+ isFree: boolean;
222
+ price?: Record<string, never>;
223
+ currency: string;
224
+ hubId?: Record<string, never>;
225
+ venueId?: Record<string, never>;
226
+ creatorId?: Record<string, never>;
227
+ sponsorBrandId?: Record<string, never>;
228
+ gatheringType?: "FACILITATOR_LED" | "COMMUNITY" | "SOCIAL" | "ONLINE";
229
+ visibility: "PUBLIC" | "MEMBERS_ONLY" | "INVITE_ONLY";
230
+ requiresApproval: boolean;
231
+ allowWaitlist: boolean;
232
+ whatsappGroup?: Record<string, never>;
233
+ externalUrl?: Record<string, never>;
234
+ status: "DRAFT" | "PUBLISHED" | "CANCELLED" | "COMPLETED";
235
+ isFeatured: boolean;
236
+ isCancelled: boolean;
237
+ isAmbient: boolean;
238
+ ambientCategory?: Record<string, never>;
239
+ vibe?: "CHILL" | "ACTIVE" | "SOCIAL" | "CREATIVE" | "DEEP_TALK" | "ADVENTURE";
240
+ city?: import("@growsober/types/dist/generated").components["schemas"]["EventCityDto"];
241
+ venue?: import("@growsober/types/dist/generated").components["schemas"]["EventVenueDto"];
242
+ creator?: import("@growsober/types/dist/generated").components["schemas"]["EventCreatorDto"];
243
+ sponsorBrand?: import("@growsober/types/dist/generated").components["schemas"]["EventBrandDto"];
244
+ bookingCount: number;
245
+ checkinCount: number;
246
+ createdAt: string;
247
+ publishedAt?: Record<string, never>;
248
+ }[], Error>;