@growsober/sdk 1.0.5 → 1.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/__tests__/e2e.test.d.ts +30 -0
- package/dist/__tests__/e2e.test.js +959 -63
- package/dist/api/mutations/badges.d.ts +116 -0
- package/dist/api/mutations/badges.js +177 -0
- package/dist/api/mutations/brands.d.ts +251 -0
- package/dist/api/mutations/brands.js +242 -0
- package/dist/api/mutations/creators.d.ts +131 -0
- package/dist/api/mutations/creators.js +129 -0
- package/dist/api/mutations/event-chat.d.ts +2 -2
- package/dist/api/mutations/event-chat.js +9 -9
- package/dist/api/mutations/index.d.ts +4 -0
- package/dist/api/mutations/index.js +5 -1
- package/dist/api/mutations/jack.d.ts +29 -0
- package/dist/api/mutations/jack.js +41 -1
- package/dist/api/mutations/products.d.ts +175 -0
- package/dist/api/mutations/products.js +226 -0
- package/dist/api/mutations/support.d.ts +20 -1
- package/dist/api/mutations/support.js +36 -1
- package/dist/api/queries/badges.d.ts +221 -0
- package/dist/api/queries/badges.js +290 -0
- package/dist/api/queries/bookings.d.ts +1 -1
- package/dist/api/queries/brands.d.ts +248 -0
- package/dist/api/queries/brands.js +226 -0
- package/dist/api/queries/businesses.d.ts +61 -1
- package/dist/api/queries/businesses.js +27 -1
- package/dist/api/queries/creators.d.ts +332 -0
- package/dist/api/queries/creators.js +249 -0
- package/dist/api/queries/event-chat.d.ts +1 -1
- package/dist/api/queries/event-chat.js +4 -4
- package/dist/api/queries/events.d.ts +45 -0
- package/dist/api/queries/index.d.ts +5 -0
- package/dist/api/queries/index.js +6 -1
- package/dist/api/queries/jack.d.ts +80 -0
- package/dist/api/queries/jack.js +98 -1
- package/dist/api/queries/library.d.ts +8 -0
- package/dist/api/queries/products.d.ts +185 -0
- package/dist/api/queries/products.js +203 -0
- package/dist/api/queries/support.d.ts +46 -1
- package/dist/api/queries/support.js +48 -1
- package/dist/api/queries/venues.d.ts +304 -0
- package/dist/api/queries/venues.js +211 -0
- package/dist/api/types.d.ts +245 -0
- package/dist/api/types.js +6 -1
- package/dist/api/utils/eventGrouping.d.ts +104 -0
- package/dist/api/utils/eventGrouping.js +155 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +5 -1
- package/package.json +5 -2
- package/src/__tests__/e2e.test.ts +996 -64
- package/src/api/mutations/badges.ts +228 -0
- package/src/api/mutations/brands.ts +376 -0
- package/src/api/mutations/creators.ts +171 -0
- package/src/api/mutations/event-chat.ts +8 -8
- package/src/api/mutations/index.ts +4 -0
- package/src/api/mutations/jack.ts +50 -1
- package/src/api/mutations/products.ts +336 -0
- package/src/api/mutations/support.ts +44 -0
- package/src/api/queries/badges.ts +385 -0
- package/src/api/queries/brands.ts +281 -0
- package/src/api/queries/businesses.ts +30 -1
- package/src/api/queries/creators.ts +308 -0
- package/src/api/queries/event-chat.ts +3 -3
- package/src/api/queries/index.ts +5 -0
- package/src/api/queries/jack.ts +139 -1
- package/src/api/queries/products.ts +312 -0
- package/src/api/queries/support.ts +54 -0
- package/src/api/queries/venues.ts +271 -0
- package/src/api/types.ts +317 -1
- package/src/api/utils/eventGrouping.ts +181 -0
- package/src/index.ts +6 -0
|
@@ -0,0 +1,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>;
|