@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
@@ -3,6 +3,11 @@
3
3
  *
4
4
  * All types are derived from the @growsober/types package which is auto-generated
5
5
  * from the API OpenAPI specification. This ensures single source of truth from Prisma.
6
+ *
7
+ * To regenerate types:
8
+ * 1. Start the API: cd ../growsober-api && npm run start:dev
9
+ * 2. Generate types: cd ../growsober-types && npm run generate && npm run build
10
+ * 3. Rebuild SDK: npm run build
6
11
  */
7
12
  import type { paths, components } from '@growsober/types';
8
13
  /**
@@ -43,6 +48,18 @@ export type PathParams<Path extends keyof paths, Method extends keyof paths[Path
43
48
  path: infer P;
44
49
  };
45
50
  } ? P : Record<string, never>;
51
+ export type BusinessType = components['schemas']['BusinessResponseDto']['type'];
52
+ export type VenueOwnerRole = components['schemas']['VenueOwnerResponseDto']['role'];
53
+ export type BrandOwnerRole = components['schemas']['BrandOwnerResponseDto']['role'];
54
+ export type GatheringType = NonNullable<components['schemas']['EventResponseDto']['gatheringType']>;
55
+ export type EventVisibility = components['schemas']['EventResponseDto']['visibility'];
56
+ export type EventStatus = components['schemas']['EventResponseDto']['status'];
57
+ export type ChatMemberRole = components['schemas']['ChatMemberResponseDto']['role'];
58
+ export type ContentStatus = components['schemas']['LibraryContentResponseDto']['contentStatus'];
59
+ export type BadgeType = components['schemas']['BadgeResponseDto']['type'];
60
+ export type NotificationType = components['schemas']['NotificationResponseDto']['type'];
61
+ export type StreakType = components['schemas']['StreakResponseDto']['type'];
62
+ export type CravingTrigger = NonNullable<components['schemas']['CravingLogResponseDto']['triggerType']>;
46
63
  export type RegisterRequest = components['schemas']['RegisterDto'];
47
64
  export type AuthResponse = components['schemas']['AuthResponseDto'];
48
65
  export type LoginRequest = components['schemas']['LoginDto'];
@@ -67,9 +84,91 @@ export type CreateBookingRequest = components['schemas']['CreateBookingDto'];
67
84
  export type LibraryContentResponse = components['schemas']['LibraryContentResponseDto'];
68
85
  export type LibraryContentDetailResponse = components['schemas']['LibraryContentDetailResponseDto'];
69
86
  export type LibraryProgressResponse = components['schemas']['LibraryProgressResponseDto'];
87
+ export type ContentType = components['schemas']['LibraryContentResponseDto']['type'];
70
88
  export type BusinessResponse = components['schemas']['BusinessResponseDto'];
71
89
  export type OfferResponse = components['schemas']['OfferResponseDto'];
72
90
  export type RedeemOfferRequest = components['schemas']['RedeemOfferDto'];
91
+ export type VenueResponse = components['schemas']['VenueResponseDto'];
92
+ export type VenueOwnerResponse = components['schemas']['VenueOwnerResponseDto'];
93
+ export interface CreateVenueRequest {
94
+ name: string;
95
+ slug: string;
96
+ description?: string;
97
+ type: BusinessType;
98
+ hasAfDrinks?: boolean;
99
+ isAfVenue?: boolean;
100
+ afHighlights?: string[];
101
+ address?: string;
102
+ cityId?: string;
103
+ locationLat?: number;
104
+ locationLong?: number;
105
+ phone?: string;
106
+ email?: string;
107
+ website?: string;
108
+ instagram?: string;
109
+ profileImage?: string;
110
+ bannerImage?: string;
111
+ photos?: string[];
112
+ openingHours?: Record<string, string>;
113
+ }
114
+ export interface UpdateVenueRequest extends Partial<CreateVenueRequest> {
115
+ }
116
+ export interface AddVenueOwnerRequest {
117
+ userId: string;
118
+ role: VenueOwnerRole;
119
+ }
120
+ export type CreatorResponse = components['schemas']['CreatorResponseDto'];
121
+ export type CreatorAvailabilityResponse = components['schemas']['CreatorAvailabilityResponseDto'];
122
+ export interface CreateCreatorRequest {
123
+ slug: string;
124
+ displayName: string;
125
+ bio?: string;
126
+ avatarUrl?: string;
127
+ cityIds?: string[];
128
+ canFacilitate?: boolean;
129
+ canCreateContent?: boolean;
130
+ isInfluencer?: boolean;
131
+ specialties?: string[];
132
+ certifications?: string[];
133
+ sessionRate?: number;
134
+ }
135
+ export interface UpdateCreatorRequest extends Partial<CreateCreatorRequest> {
136
+ }
137
+ export interface CreateAvailabilityRequest {
138
+ dayOfWeek?: number;
139
+ startTime: string;
140
+ endTime: string;
141
+ timezone: string;
142
+ isRecurring?: boolean;
143
+ specificDate?: string;
144
+ }
145
+ export type BrandResponse = components['schemas']['BrandResponseDto'];
146
+ export type BrandOwnerResponse = components['schemas']['BrandOwnerResponseDto'];
147
+ export type BrandCreatorResponse = components['schemas']['BrandCreatorResponseDto'];
148
+ export interface CreateBrandRequest {
149
+ slug: string;
150
+ name: string;
151
+ description?: string;
152
+ logoUrl?: string;
153
+ bannerUrl?: string;
154
+ primaryColor?: string;
155
+ website?: string;
156
+ email?: string;
157
+ instagram?: string;
158
+ }
159
+ export interface UpdateBrandRequest extends Partial<CreateBrandRequest> {
160
+ }
161
+ export interface AddBrandOwnerRequest {
162
+ userId: string;
163
+ role: BrandOwnerRole;
164
+ }
165
+ export interface AddBrandCreatorRequest {
166
+ creatorId: string;
167
+ commissionRate?: number;
168
+ isActive?: boolean;
169
+ startDate?: string;
170
+ endDate?: string;
171
+ }
73
172
  export type SubscriptionResponse = components['schemas']['SubscriptionResponseDto'];
74
173
  export type CreateCheckoutRequest = components['schemas']['CreateCheckoutDto'];
75
174
  export type NotificationResponse = components['schemas']['NotificationResponseDto'];
@@ -97,6 +196,9 @@ export type HabitCompletionResponse = components['schemas']['HabitCompletionResp
97
196
  export type ReflectionResponse = components['schemas']['ReflectionResponseDto'];
98
197
  export type CreateReflectionRequest = components['schemas']['CreateReflectionDto'];
99
198
  export type UpdateReflectionRequest = components['schemas']['UpdateReflectionDto'];
199
+ export type CravingLogResponse = components['schemas']['CravingLogResponseDto'];
200
+ export type LogCravingRequest = components['schemas']['LogCravingDto'];
201
+ export type CravingStatsResponse = components['schemas']['CravingStatsDto'];
100
202
  export type MapMemberResponse = components['schemas']['MapMemberDto'];
101
203
  export type MapHubResponse = components['schemas']['MapHubDto'];
102
204
  export type MapEventResponse = components['schemas']['MapEventDto'];
@@ -131,4 +233,147 @@ export type AdminUpdateEventRequest = components['schemas']['AdminUpdateEventDto
131
233
  export type AdminCreateContentRequest = components['schemas']['AdminCreateContentDto'];
132
234
  export type AdminCreateBusinessRequest = components['schemas']['AdminCreateBusinessDto'];
133
235
  export type AdminOverviewStatsResponse = components['schemas']['AdminOverviewStatsDto'];
236
+ export type BadgeResponse = components['schemas']['BadgeResponseDto'];
237
+ export type UserBadgeResponse = components['schemas']['UserBadgeResponseDto'];
238
+ export type BadgeProgressResponse = components['schemas']['BadgeProgressDto'];
239
+ export interface BadgeWithProgress {
240
+ badge: BadgeResponse;
241
+ currentProgress: number;
242
+ requiredProgress: number;
243
+ percentComplete: number;
244
+ isEarned: boolean;
245
+ }
246
+ export type RedeemType = 'IN_PERSON' | 'ONLINE' | 'BOTH';
247
+ export interface RewardResponse {
248
+ id: string;
249
+ venueId: string | null;
250
+ brandId: string | null;
251
+ badgeId: string;
252
+ title: string;
253
+ description: string | null;
254
+ code: string | null;
255
+ redeemType: RedeemType;
256
+ maxRedemptions: number | null;
257
+ redemptionsUsed: number;
258
+ perUserLimit: number;
259
+ validFrom: string | null;
260
+ validUntil: string | null;
261
+ isActive: boolean;
262
+ createdAt: string;
263
+ badge: {
264
+ id: string;
265
+ name: string;
266
+ slug: string;
267
+ icon: string | null;
268
+ };
269
+ venue?: {
270
+ id: string;
271
+ name: string;
272
+ slug: string;
273
+ profileImage: string | null;
274
+ address: string | null;
275
+ } | null;
276
+ brand?: {
277
+ id: string;
278
+ name: string;
279
+ slug: string;
280
+ logoUrl: string | null;
281
+ } | null;
282
+ }
283
+ export interface RewardRedemptionResponse {
284
+ id: string;
285
+ userId: string;
286
+ rewardId: string;
287
+ redeemedAt: string;
288
+ verifiedAt: string | null;
289
+ verifiedBy: string | null;
290
+ codeUsed: string | null;
291
+ reward: RewardResponse;
292
+ }
293
+ export interface CreateRewardRequest {
294
+ badgeId: string;
295
+ title: string;
296
+ description?: string;
297
+ code?: string;
298
+ redeemType?: RedeemType;
299
+ maxRedemptions?: number;
300
+ perUserLimit?: number;
301
+ validFrom?: string;
302
+ validUntil?: string;
303
+ }
304
+ export interface UpdateRewardRequest {
305
+ title?: string;
306
+ description?: string;
307
+ code?: string;
308
+ redeemType?: RedeemType;
309
+ maxRedemptions?: number;
310
+ perUserLimit?: number;
311
+ validFrom?: string;
312
+ validUntil?: string;
313
+ isActive?: boolean;
314
+ }
315
+ export interface UserWalletResponse {
316
+ badges: Array<{
317
+ id: string;
318
+ badgeId: string;
319
+ userId: string;
320
+ awardedAt: string;
321
+ badge: BadgeResponse;
322
+ availableRewards: RewardResponse[];
323
+ redeemedRewards: Array<RewardRedemptionResponse & {
324
+ qrToken: string;
325
+ }>;
326
+ }>;
327
+ stats: {
328
+ totalBadges: number;
329
+ totalAvailableRewards: number;
330
+ totalRedeemedRewards: number;
331
+ };
332
+ }
333
+ /** @deprecated Use RewardResponse instead */
334
+ export interface PartnerRewardResponse {
335
+ id: string;
336
+ businessId: string;
337
+ badgeId: string;
338
+ title: string;
339
+ description: string | null;
340
+ code: string | null;
341
+ maxRedemptions: number | null;
342
+ redemptionsUsed: number;
343
+ perUserLimit: number;
344
+ validFrom: string;
345
+ validUntil: string | null;
346
+ isActive: boolean;
347
+ createdAt: string;
348
+ badge: {
349
+ id: string;
350
+ name: string;
351
+ slug: string;
352
+ icon: string | null;
353
+ };
354
+ business: {
355
+ id: string;
356
+ name: string;
357
+ profileImage: string | null;
358
+ };
359
+ }
360
+ /** @deprecated Use RewardRedemptionResponse instead */
361
+ export interface PartnerRewardRedemptionResponse {
362
+ id: string;
363
+ userId: string;
364
+ partnerRewardId: string;
365
+ redeemedAt: string;
366
+ verifiedAt: string | null;
367
+ partnerReward: PartnerRewardResponse;
368
+ }
369
+ /** @deprecated Use CreateRewardRequest instead */
370
+ export interface CreatePartnerRewardRequest {
371
+ badgeId: string;
372
+ title: string;
373
+ description?: string;
374
+ code?: string;
375
+ maxRedemptions?: number;
376
+ perUserLimit?: number;
377
+ validUntil?: string;
378
+ }
134
379
  export type { paths, components };
package/dist/api/types.js CHANGED
@@ -4,6 +4,11 @@
4
4
  *
5
5
  * All types are derived from the @growsober/types package which is auto-generated
6
6
  * from the API OpenAPI specification. This ensures single source of truth from Prisma.
7
+ *
8
+ * To regenerate types:
9
+ * 1. Start the API: cd ../growsober-api && npm run start:dev
10
+ * 2. Generate types: cd ../growsober-types && npm run generate && npm run build
11
+ * 3. Rebuild SDK: npm run build
7
12
  */
8
13
  Object.defineProperty(exports, "__esModule", { value: true });
9
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/api/types.ts"],"names":[],"mappings":";AAAA;;;;;GAKG","sourcesContent":["/**\n * GrowSober SDK Types\n *\n * All types are derived from the @growsober/types package which is auto-generated\n * from the API OpenAPI specification. This ensures single source of truth from Prisma.\n */\n\nimport type { paths, components } from '@growsober/types';\n\n// ============================================================================\n// TYPE EXTRACTION HELPERS\n// ============================================================================\n\n/**\n * Extract request body type for a given endpoint and method\n */\nexport type RequestBody<\n  Path extends keyof paths,\n  Method extends keyof paths[Path]\n> = paths[Path][Method] extends { requestBody: { content: { 'application/json': infer T } } }\n  ? T\n  : never;\n\n/**\n * Extract response type for a given endpoint, method, and status code\n */\nexport type ResponseBody<\n  Path extends keyof paths,\n  Method extends keyof paths[Path],\n  Status extends number = 200\n> = paths[Path][Method] extends { responses: { [K in Status]: { content: { 'application/json': infer T } } } }\n  ? T\n  : never;\n\n/**\n * Extract query parameters type for a given endpoint and method\n */\nexport type QueryParams<\n  Path extends keyof paths,\n  Method extends keyof paths[Path]\n> = paths[Path][Method] extends { parameters: { query?: infer Q } }\n  ? Q\n  : Record<string, never>;\n\n/**\n * Extract path parameters type for a given endpoint and method\n */\nexport type PathParams<\n  Path extends keyof paths,\n  Method extends keyof paths[Path]\n> = paths[Path][Method] extends { parameters: { path: infer P } }\n  ? P\n  : Record<string, never>;\n\n// ============================================================================\n// AUTH TYPES\n// ============================================================================\n\nexport type RegisterRequest = components['schemas']['RegisterDto'];\nexport type AuthResponse = components['schemas']['AuthResponseDto'];\nexport type LoginRequest = components['schemas']['LoginDto'];\nexport type RefreshTokenRequest = components['schemas']['RefreshTokenDto'];\nexport type TokenResponse = components['schemas']['TokenResponseDto'];\nexport type FirebaseAuthRequest = components['schemas']['FirebaseAuthDto'];\nexport type SendOtpRequest = components['schemas']['SendOtpDto'];\nexport type OtpSentResponse = components['schemas']['OtpSentResponseDto'];\nexport type VerifyOtpRequest = components['schemas']['VerifyOtpDto'];\n\n// ============================================================================\n// USER TYPES\n// ============================================================================\n\nexport type UserResponse = components['schemas']['UserResponseDto'];\nexport type UserPublicResponse = components['schemas']['UserPublicResponseDto'];\nexport type CreateUserRequest = components['schemas']['CreateUserDto'];\nexport type UpdateUserRequest = components['schemas']['UpdateUserDto'];\n\n// ============================================================================\n// HUB TYPES\n// ============================================================================\n\nexport type HubResponse = components['schemas']['HubResponseDto'];\nexport type CreateHubRequest = components['schemas']['CreateHubDto'];\nexport type UpdateHubRequest = components['schemas']['UpdateHubDto'];\n\n// ============================================================================\n// EVENT TYPES\n// ============================================================================\n\nexport type EventResponse = components['schemas']['EventResponseDto'];\nexport type CreateEventRequest = components['schemas']['CreateEventDto'];\nexport type UpdateEventRequest = components['schemas']['UpdateEventDto'];\n\n// ============================================================================\n// BOOKING TYPES\n// ============================================================================\n\nexport type BookingResponse = components['schemas']['BookingResponseDto'];\nexport type CreateBookingRequest = components['schemas']['CreateBookingDto'];\n\n// ============================================================================\n// LIBRARY TYPES\n// ============================================================================\n\nexport type LibraryContentResponse = components['schemas']['LibraryContentResponseDto'];\nexport type LibraryContentDetailResponse = components['schemas']['LibraryContentDetailResponseDto'];\nexport type LibraryProgressResponse = components['schemas']['LibraryProgressResponseDto'];\n\n// ============================================================================\n// BUSINESS & OFFER TYPES\n// ============================================================================\n\nexport type BusinessResponse = components['schemas']['BusinessResponseDto'];\nexport type OfferResponse = components['schemas']['OfferResponseDto'];\nexport type RedeemOfferRequest = components['schemas']['RedeemOfferDto'];\n\n// ============================================================================\n// SUBSCRIPTION TYPES\n// ============================================================================\n\nexport type SubscriptionResponse = components['schemas']['SubscriptionResponseDto'];\nexport type CreateCheckoutRequest = components['schemas']['CreateCheckoutDto'];\n\n// ============================================================================\n// NOTIFICATION TYPES\n// ============================================================================\n\nexport type NotificationResponse = components['schemas']['NotificationResponseDto'];\n\n// ============================================================================\n// DEVICE TOKEN TYPES\n// ============================================================================\n\nexport type RegisterDeviceTokenRequest = components['schemas']['RegisterDeviceDto'];\n\n// ============================================================================\n// SUPPORT TYPES\n// ============================================================================\n\n// Check-ins\nexport type CheckInResponse = components['schemas']['CheckInResponseDto'];\nexport type CreateCheckInRequest = components['schemas']['CreateCheckInDto'];\nexport type UpdateCheckInRequest = components['schemas']['UpdateCheckInDto'];\nexport type CheckInStreakResponse = components['schemas']['CheckInStreakDto'];\n\n// Wins\nexport type WinResponse = components['schemas']['WinResponseDto'];\nexport type CreateWinRequest = components['schemas']['CreateWinDto'];\nexport type WinCountResponse = components['schemas']['WinCountDto'];\n\n// Jack AI Conversations\nexport type ConversationResponse = components['schemas']['ConversationResponseDto'];\nexport type ConversationWithMessagesResponse = components['schemas']['ConversationWithMessagesDto'];\nexport type CreateConversationRequest = components['schemas']['CreateConversationDto'];\nexport type JackMessageResponse = components['schemas']['MessageResponseDto'];\nexport type SendJackMessageRequest = components['schemas']['SendMessageDto'];\n\n// Mood Logs\nexport type MoodLogResponse = components['schemas']['MoodLogResponseDto'];\nexport type LogMoodRequest = components['schemas']['LogMoodDto'];\nexport type MoodStatsResponse = components['schemas']['MoodStatsDto'];\n\n// Habits\nexport type HabitResponse = components['schemas']['HabitResponseDto'];\nexport type CreateHabitRequest = components['schemas']['CreateHabitDto'];\nexport type UpdateHabitRequest = components['schemas']['UpdateHabitDto'];\nexport type CompleteHabitRequest = components['schemas']['CompleteHabitDto'];\nexport type HabitCompletionResponse = components['schemas']['HabitCompletionResponseDto'];\n\n// Reflections\nexport type ReflectionResponse = components['schemas']['ReflectionResponseDto'];\nexport type CreateReflectionRequest = components['schemas']['CreateReflectionDto'];\nexport type UpdateReflectionRequest = components['schemas']['UpdateReflectionDto'];\n\n// ============================================================================\n// MAP TYPES\n// ============================================================================\n\nexport type MapMemberResponse = components['schemas']['MapMemberDto'];\nexport type MapHubResponse = components['schemas']['MapHubDto'];\nexport type MapEventResponse = components['schemas']['MapEventDto'];\n\n// ============================================================================\n// AMBASSADOR TYPES\n// ============================================================================\n\nexport type AmbassadorResponse = components['schemas']['AmbassadorResponseDto'];\nexport type ApplyAmbassadorRequest = components['schemas']['ApplyAmbassadorDto'];\nexport type UpdateAmbassadorRequest = components['schemas']['UpdateAmbassadorDto'];\n\n// ============================================================================\n// GROW90 TYPES\n// ============================================================================\n\nexport type Grow90EnrollmentResponse = components['schemas']['Grow90EnrollmentResponseDto'];\nexport type Grow90ProgressResponse = components['schemas']['Grow90ProgressResponseDto'];\nexport type Grow90TodayResponse = components['schemas']['Grow90TodayResponseDto'];\nexport type Grow90StatsResponse = components['schemas']['Grow90StatsResponseDto'];\nexport type EnrollGrow90Request = components['schemas']['EnrollGrow90Dto'];\nexport type UpdateGrow90ProgressRequest = components['schemas']['UpdateProgressDto'];\nexport type UpdateGrow90SettingsRequest = components['schemas']['UpdateSettingsDto'];\n\n// ============================================================================\n// MATCHING TYPES\n// ============================================================================\n\nexport type CreateMatchRequest = components['schemas']['CreateMatchDto'];\nexport type UpdateMatchRequest = components['schemas']['UpdateMatchDto'];\nexport type CreateBuddyRequest = components['schemas']['CreateBuddyRequestDto'];\nexport type UpdateBuddyRequest = components['schemas']['UpdateBuddyDto'];\nexport type LogBuddyActivityRequest = components['schemas']['LogBuddyActivityDto'];\n\n// ============================================================================\n// EVENT CHAT TYPES\n// ============================================================================\n\nexport type EventChatResponse = components['schemas']['EventChatResponseDto'];\nexport type ChatMemberResponse = components['schemas']['ChatMemberResponseDto'];\nexport type ChatMessageResponse = components['schemas']['MessageResponseDto'];\nexport type PaginatedMessagesResponse = components['schemas']['PaginatedMessagesDto'];\nexport type SendChatMessageRequest = components['schemas']['SendMessageDto'];\nexport type UpdateChatMessageRequest = components['schemas']['UpdateMessageDto'];\nexport type UpdateChatSettingsRequest = components['schemas']['UpdateChatSettingsDto'];\nexport type UpdateMemberSettingsRequest = components['schemas']['UpdateMemberSettingsDto'];\n\n// ============================================================================\n// ADMIN TYPES\n// ============================================================================\n\nexport type AdminLoginRequest = components['schemas']['AdminLoginDto'];\nexport type AdminTokensResponse = components['schemas']['AdminTokensDto'];\nexport type AdminUpdateUserRequest = components['schemas']['AdminUpdateUserDto'];\nexport type AdminCreateHubRequest = components['schemas']['AdminCreateHubDto'];\nexport type AdminUpdateEventRequest = components['schemas']['AdminUpdateEventDto'];\nexport type AdminCreateContentRequest = components['schemas']['AdminCreateContentDto'];\nexport type AdminCreateBusinessRequest = components['schemas']['AdminCreateBusinessDto'];\nexport type AdminOverviewStatsResponse = components['schemas']['AdminOverviewStatsDto'];\n\n// ============================================================================\n// RE-EXPORTS\n// ============================================================================\n\n// Re-export paths and components for advanced usage\nexport type { paths, components };\n"]}
14
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/api/types.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;GAUG","sourcesContent":["/**\n * GrowSober SDK Types\n *\n * All types are derived from the @growsober/types package which is auto-generated\n * from the API OpenAPI specification. This ensures single source of truth from Prisma.\n *\n * To regenerate types:\n * 1. Start the API: cd ../growsober-api && npm run start:dev\n * 2. Generate types: cd ../growsober-types && npm run generate && npm run build\n * 3. Rebuild SDK: npm run build\n */\n\nimport type { paths, components } from '@growsober/types';\n\n// ============================================================================\n// TYPE EXTRACTION HELPERS\n// ============================================================================\n\n/**\n * Extract request body type for a given endpoint and method\n */\nexport type RequestBody<\n  Path extends keyof paths,\n  Method extends keyof paths[Path]\n> = paths[Path][Method] extends { requestBody: { content: { 'application/json': infer T } } }\n  ? T\n  : never;\n\n/**\n * Extract response type for a given endpoint, method, and status code\n */\nexport type ResponseBody<\n  Path extends keyof paths,\n  Method extends keyof paths[Path],\n  Status extends number = 200\n> = paths[Path][Method] extends { responses: { [K in Status]: { content: { 'application/json': infer T } } } }\n  ? T\n  : never;\n\n/**\n * Extract query parameters type for a given endpoint and method\n */\nexport type QueryParams<\n  Path extends keyof paths,\n  Method extends keyof paths[Path]\n> = paths[Path][Method] extends { parameters: { query?: infer Q } }\n  ? Q\n  : Record<string, never>;\n\n/**\n * Extract path parameters type for a given endpoint and method\n */\nexport type PathParams<\n  Path extends keyof paths,\n  Method extends keyof paths[Path]\n> = paths[Path][Method] extends { parameters: { path: infer P } }\n  ? P\n  : Record<string, never>;\n\n// ============================================================================\n// ENUM TYPES (extracted from generated schemas - single source of truth)\n// ============================================================================\n\n// Business/Venue type (used for both Business and Venue models)\nexport type BusinessType = components['schemas']['BusinessResponseDto']['type'];\n\n// Ownership roles\nexport type VenueOwnerRole = components['schemas']['VenueOwnerResponseDto']['role'];\nexport type BrandOwnerRole = components['schemas']['BrandOwnerResponseDto']['role'];\n\n// Event types\nexport type GatheringType = NonNullable<components['schemas']['EventResponseDto']['gatheringType']>;\nexport type EventVisibility = components['schemas']['EventResponseDto']['visibility'];\nexport type EventStatus = components['schemas']['EventResponseDto']['status'];\n\n// Chat roles\nexport type ChatMemberRole = components['schemas']['ChatMemberResponseDto']['role'];\n\n// Content status\nexport type ContentStatus = components['schemas']['LibraryContentResponseDto']['contentStatus'];\n\n// Badge types\nexport type BadgeType = components['schemas']['BadgeResponseDto']['type'];\n\n// Notification types\nexport type NotificationType = components['schemas']['NotificationResponseDto']['type'];\n\n// Streak types\nexport type StreakType = components['schemas']['StreakResponseDto']['type'];\n\n// Craving triggers\nexport type CravingTrigger = NonNullable<components['schemas']['CravingLogResponseDto']['triggerType']>;\n\n// ============================================================================\n// AUTH TYPES\n// ============================================================================\n\nexport type RegisterRequest = components['schemas']['RegisterDto'];\nexport type AuthResponse = components['schemas']['AuthResponseDto'];\nexport type LoginRequest = components['schemas']['LoginDto'];\nexport type RefreshTokenRequest = components['schemas']['RefreshTokenDto'];\nexport type TokenResponse = components['schemas']['TokenResponseDto'];\nexport type FirebaseAuthRequest = components['schemas']['FirebaseAuthDto'];\nexport type SendOtpRequest = components['schemas']['SendOtpDto'];\nexport type OtpSentResponse = components['schemas']['OtpSentResponseDto'];\nexport type VerifyOtpRequest = components['schemas']['VerifyOtpDto'];\n\n// ============================================================================\n// USER TYPES\n// ============================================================================\n\nexport type UserResponse = components['schemas']['UserResponseDto'];\nexport type UserPublicResponse = components['schemas']['UserPublicResponseDto'];\nexport type CreateUserRequest = components['schemas']['CreateUserDto'];\nexport type UpdateUserRequest = components['schemas']['UpdateUserDto'];\n\n// ============================================================================\n// HUB TYPES\n// ============================================================================\n\nexport type HubResponse = components['schemas']['HubResponseDto'];\nexport type CreateHubRequest = components['schemas']['CreateHubDto'];\nexport type UpdateHubRequest = components['schemas']['UpdateHubDto'];\n\n// ============================================================================\n// EVENT TYPES\n// ============================================================================\n\nexport type EventResponse = components['schemas']['EventResponseDto'];\nexport type CreateEventRequest = components['schemas']['CreateEventDto'];\nexport type UpdateEventRequest = components['schemas']['UpdateEventDto'];\n\n// ============================================================================\n// BOOKING TYPES\n// ============================================================================\n\nexport type BookingResponse = components['schemas']['BookingResponseDto'];\nexport type CreateBookingRequest = components['schemas']['CreateBookingDto'];\n\n// ============================================================================\n// LIBRARY TYPES\n// ============================================================================\n\nexport type LibraryContentResponse = components['schemas']['LibraryContentResponseDto'];\nexport type LibraryContentDetailResponse = components['schemas']['LibraryContentDetailResponseDto'];\nexport type LibraryProgressResponse = components['schemas']['LibraryProgressResponseDto'];\nexport type ContentType = components['schemas']['LibraryContentResponseDto']['type'];\n\n// ============================================================================\n// BUSINESS & OFFER TYPES (Legacy)\n// ============================================================================\n\nexport type BusinessResponse = components['schemas']['BusinessResponseDto'];\nexport type OfferResponse = components['schemas']['OfferResponseDto'];\nexport type RedeemOfferRequest = components['schemas']['RedeemOfferDto'];\n\n// ============================================================================\n// VENUE TYPES (from generated OpenAPI types)\n// ============================================================================\n\nexport type VenueResponse = components['schemas']['VenueResponseDto'];\nexport type VenueOwnerResponse = components['schemas']['VenueOwnerResponseDto'];\n\n// Request types for venue operations\nexport interface CreateVenueRequest {\n  name: string;\n  slug: string;\n  description?: string;\n  type: BusinessType;\n  hasAfDrinks?: boolean;\n  isAfVenue?: boolean;\n  afHighlights?: string[];\n  address?: string;\n  cityId?: string;\n  locationLat?: number;\n  locationLong?: number;\n  phone?: string;\n  email?: string;\n  website?: string;\n  instagram?: string;\n  profileImage?: string;\n  bannerImage?: string;\n  photos?: string[];\n  openingHours?: Record<string, string>;\n}\n\nexport interface UpdateVenueRequest extends Partial<CreateVenueRequest> {}\n\nexport interface AddVenueOwnerRequest {\n  userId: string;\n  role: VenueOwnerRole;\n}\n\n// ============================================================================\n// CREATOR TYPES (from generated OpenAPI types)\n// ============================================================================\n\nexport type CreatorResponse = components['schemas']['CreatorResponseDto'];\nexport type CreatorAvailabilityResponse = components['schemas']['CreatorAvailabilityResponseDto'];\n\nexport interface CreateCreatorRequest {\n  slug: string;\n  displayName: string;\n  bio?: string;\n  avatarUrl?: string;\n  cityIds?: string[];\n  canFacilitate?: boolean;\n  canCreateContent?: boolean;\n  isInfluencer?: boolean;\n  specialties?: string[];\n  certifications?: string[];\n  sessionRate?: number;\n}\n\nexport interface UpdateCreatorRequest extends Partial<CreateCreatorRequest> {}\n\nexport interface CreateAvailabilityRequest {\n  dayOfWeek?: number;\n  startTime: string;\n  endTime: string;\n  timezone: string;\n  isRecurring?: boolean;\n  specificDate?: string;\n}\n\n// ============================================================================\n// BRAND TYPES (from generated OpenAPI types)\n// ============================================================================\n\nexport type BrandResponse = components['schemas']['BrandResponseDto'];\nexport type BrandOwnerResponse = components['schemas']['BrandOwnerResponseDto'];\nexport type BrandCreatorResponse = components['schemas']['BrandCreatorResponseDto'];\n\nexport interface CreateBrandRequest {\n  slug: string;\n  name: string;\n  description?: string;\n  logoUrl?: string;\n  bannerUrl?: string;\n  primaryColor?: string;\n  website?: string;\n  email?: string;\n  instagram?: string;\n}\n\nexport interface UpdateBrandRequest extends Partial<CreateBrandRequest> {}\n\nexport interface AddBrandOwnerRequest {\n  userId: string;\n  role: BrandOwnerRole;\n}\n\nexport interface AddBrandCreatorRequest {\n  creatorId: string;\n  commissionRate?: number;\n  isActive?: boolean;\n  startDate?: string;\n  endDate?: string;\n}\n\n// ============================================================================\n// SUBSCRIPTION TYPES\n// ============================================================================\n\nexport type SubscriptionResponse = components['schemas']['SubscriptionResponseDto'];\nexport type CreateCheckoutRequest = components['schemas']['CreateCheckoutDto'];\n\n// ============================================================================\n// NOTIFICATION TYPES\n// ============================================================================\n\nexport type NotificationResponse = components['schemas']['NotificationResponseDto'];\n\n// ============================================================================\n// DEVICE TOKEN TYPES\n// ============================================================================\n\nexport type RegisterDeviceTokenRequest = components['schemas']['RegisterDeviceDto'];\n\n// ============================================================================\n// SUPPORT TYPES\n// ============================================================================\n\n// Check-ins\nexport type CheckInResponse = components['schemas']['CheckInResponseDto'];\nexport type CreateCheckInRequest = components['schemas']['CreateCheckInDto'];\nexport type UpdateCheckInRequest = components['schemas']['UpdateCheckInDto'];\nexport type CheckInStreakResponse = components['schemas']['CheckInStreakDto'];\n\n// Wins\nexport type WinResponse = components['schemas']['WinResponseDto'];\nexport type CreateWinRequest = components['schemas']['CreateWinDto'];\nexport type WinCountResponse = components['schemas']['WinCountDto'];\n\n// Jack AI Conversations\nexport type ConversationResponse = components['schemas']['ConversationResponseDto'];\nexport type ConversationWithMessagesResponse = components['schemas']['ConversationWithMessagesDto'];\nexport type CreateConversationRequest = components['schemas']['CreateConversationDto'];\nexport type JackMessageResponse = components['schemas']['MessageResponseDto'];\nexport type SendJackMessageRequest = components['schemas']['SendMessageDto'];\n\n// Mood Logs\nexport type MoodLogResponse = components['schemas']['MoodLogResponseDto'];\nexport type LogMoodRequest = components['schemas']['LogMoodDto'];\nexport type MoodStatsResponse = components['schemas']['MoodStatsDto'];\n\n// Habits\nexport type HabitResponse = components['schemas']['HabitResponseDto'];\nexport type CreateHabitRequest = components['schemas']['CreateHabitDto'];\nexport type UpdateHabitRequest = components['schemas']['UpdateHabitDto'];\nexport type CompleteHabitRequest = components['schemas']['CompleteHabitDto'];\nexport type HabitCompletionResponse = components['schemas']['HabitCompletionResponseDto'];\n\n// Reflections\nexport type ReflectionResponse = components['schemas']['ReflectionResponseDto'];\nexport type CreateReflectionRequest = components['schemas']['CreateReflectionDto'];\nexport type UpdateReflectionRequest = components['schemas']['UpdateReflectionDto'];\n\n// Cravings\nexport type CravingLogResponse = components['schemas']['CravingLogResponseDto'];\nexport type LogCravingRequest = components['schemas']['LogCravingDto'];\nexport type CravingStatsResponse = components['schemas']['CravingStatsDto'];\n\n// ============================================================================\n// MAP TYPES\n// ============================================================================\n\nexport type MapMemberResponse = components['schemas']['MapMemberDto'];\nexport type MapHubResponse = components['schemas']['MapHubDto'];\nexport type MapEventResponse = components['schemas']['MapEventDto'];\n\n// ============================================================================\n// AMBASSADOR TYPES\n// ============================================================================\n\nexport type AmbassadorResponse = components['schemas']['AmbassadorResponseDto'];\nexport type ApplyAmbassadorRequest = components['schemas']['ApplyAmbassadorDto'];\nexport type UpdateAmbassadorRequest = components['schemas']['UpdateAmbassadorDto'];\n\n// ============================================================================\n// GROW90 TYPES\n// ============================================================================\n\nexport type Grow90EnrollmentResponse = components['schemas']['Grow90EnrollmentResponseDto'];\nexport type Grow90ProgressResponse = components['schemas']['Grow90ProgressResponseDto'];\nexport type Grow90TodayResponse = components['schemas']['Grow90TodayResponseDto'];\nexport type Grow90StatsResponse = components['schemas']['Grow90StatsResponseDto'];\nexport type EnrollGrow90Request = components['schemas']['EnrollGrow90Dto'];\nexport type UpdateGrow90ProgressRequest = components['schemas']['UpdateProgressDto'];\nexport type UpdateGrow90SettingsRequest = components['schemas']['UpdateSettingsDto'];\n\n// ============================================================================\n// MATCHING TYPES\n// ============================================================================\n\nexport type CreateMatchRequest = components['schemas']['CreateMatchDto'];\nexport type UpdateMatchRequest = components['schemas']['UpdateMatchDto'];\nexport type CreateBuddyRequest = components['schemas']['CreateBuddyRequestDto'];\nexport type UpdateBuddyRequest = components['schemas']['UpdateBuddyDto'];\nexport type LogBuddyActivityRequest = components['schemas']['LogBuddyActivityDto'];\n\n// ============================================================================\n// EVENT CHAT TYPES\n// ============================================================================\n\nexport type EventChatResponse = components['schemas']['EventChatResponseDto'];\nexport type ChatMemberResponse = components['schemas']['ChatMemberResponseDto'];\nexport type ChatMessageResponse = components['schemas']['MessageResponseDto'];\nexport type PaginatedMessagesResponse = components['schemas']['PaginatedMessagesDto'];\nexport type SendChatMessageRequest = components['schemas']['SendMessageDto'];\nexport type UpdateChatMessageRequest = components['schemas']['UpdateMessageDto'];\nexport type UpdateChatSettingsRequest = components['schemas']['UpdateChatSettingsDto'];\nexport type UpdateMemberSettingsRequest = components['schemas']['UpdateMemberSettingsDto'];\n\n// ============================================================================\n// ADMIN TYPES\n// ============================================================================\n\nexport type AdminLoginRequest = components['schemas']['AdminLoginDto'];\nexport type AdminTokensResponse = components['schemas']['AdminTokensDto'];\nexport type AdminUpdateUserRequest = components['schemas']['AdminUpdateUserDto'];\nexport type AdminCreateHubRequest = components['schemas']['AdminCreateHubDto'];\nexport type AdminUpdateEventRequest = components['schemas']['AdminUpdateEventDto'];\nexport type AdminCreateContentRequest = components['schemas']['AdminCreateContentDto'];\nexport type AdminCreateBusinessRequest = components['schemas']['AdminCreateBusinessDto'];\nexport type AdminOverviewStatsResponse = components['schemas']['AdminOverviewStatsDto'];\n\n// ============================================================================\n// BADGE TYPES (from generated OpenAPI types)\n// ============================================================================\n\nexport type BadgeResponse = components['schemas']['BadgeResponseDto'];\nexport type UserBadgeResponse = components['schemas']['UserBadgeResponseDto'];\nexport type BadgeProgressResponse = components['schemas']['BadgeProgressDto'];\n\n// Alias for SDK consistency\nexport interface BadgeWithProgress {\n  badge: BadgeResponse;\n  currentProgress: number;\n  requiredProgress: number;\n  percentComplete: number;\n  isEarned: boolean;\n}\n\n// ============================================================================\n// UNIFIED REWARD TYPES\n// ============================================================================\n\n// RedeemType enum - extracted from Prisma via API\nexport type RedeemType = 'IN_PERSON' | 'ONLINE' | 'BOTH';\n\n// Reward response with relations\nexport interface RewardResponse {\n  id: string;\n  venueId: string | null;\n  brandId: string | null;\n  badgeId: string;\n  title: string;\n  description: string | null;\n  code: string | null;\n  redeemType: RedeemType;\n  maxRedemptions: number | null;\n  redemptionsUsed: number;\n  perUserLimit: number;\n  validFrom: string | null;\n  validUntil: string | null;\n  isActive: boolean;\n  createdAt: string;\n  badge: {\n    id: string;\n    name: string;\n    slug: string;\n    icon: string | null;\n  };\n  venue?: {\n    id: string;\n    name: string;\n    slug: string;\n    profileImage: string | null;\n    address: string | null;\n  } | null;\n  brand?: {\n    id: string;\n    name: string;\n    slug: string;\n    logoUrl: string | null;\n  } | null;\n}\n\nexport interface RewardRedemptionResponse {\n  id: string;\n  userId: string;\n  rewardId: string;\n  redeemedAt: string;\n  verifiedAt: string | null;\n  verifiedBy: string | null;\n  codeUsed: string | null;\n  reward: RewardResponse;\n}\n\nexport interface CreateRewardRequest {\n  badgeId: string;\n  title: string;\n  description?: string;\n  code?: string;\n  redeemType?: RedeemType;\n  maxRedemptions?: number;\n  perUserLimit?: number;\n  validFrom?: string;\n  validUntil?: string;\n}\n\nexport interface UpdateRewardRequest {\n  title?: string;\n  description?: string;\n  code?: string;\n  redeemType?: RedeemType;\n  maxRedemptions?: number;\n  perUserLimit?: number;\n  validFrom?: string;\n  validUntil?: string;\n  isActive?: boolean;\n}\n\nexport interface UserWalletResponse {\n  badges: Array<{\n    id: string;\n    badgeId: string;\n    userId: string;\n    awardedAt: string;\n    badge: BadgeResponse;\n    availableRewards: RewardResponse[];\n    redeemedRewards: Array<RewardRedemptionResponse & { qrToken: string }>;\n  }>;\n  stats: {\n    totalBadges: number;\n    totalAvailableRewards: number;\n    totalRedeemedRewards: number;\n  };\n}\n\n// ============================================================================\n// LEGACY TYPES (deprecated - use unified types)\n// ============================================================================\n\n/** @deprecated Use RewardResponse instead */\nexport interface PartnerRewardResponse {\n  id: string;\n  businessId: string;\n  badgeId: string;\n  title: string;\n  description: string | null;\n  code: string | null;\n  maxRedemptions: number | null;\n  redemptionsUsed: number;\n  perUserLimit: number;\n  validFrom: string;\n  validUntil: string | null;\n  isActive: boolean;\n  createdAt: string;\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  };\n}\n\n/** @deprecated Use RewardRedemptionResponse instead */\nexport interface PartnerRewardRedemptionResponse {\n  id: string;\n  userId: string;\n  partnerRewardId: string;\n  redeemedAt: string;\n  verifiedAt: string | null;\n  partnerReward: PartnerRewardResponse;\n}\n\n/** @deprecated Use CreateRewardRequest instead */\nexport interface CreatePartnerRewardRequest {\n  badgeId: string;\n  title: string;\n  description?: string;\n  code?: string;\n  maxRedemptions?: number;\n  perUserLimit?: number;\n  validUntil?: string;\n}\n\n// ============================================================================\n// RE-EXPORTS\n// ============================================================================\n\n// Re-export paths and components for advanced usage\nexport type { paths, components };\n"]}
@@ -0,0 +1,104 @@
1
+ /**
2
+ * Event Grouping Utilities
3
+ *
4
+ * Utilities for organizing events by time of day.
5
+ * Used in the Gatherings screen to show events grouped by
6
+ * Morning, Afternoon, and Evening.
7
+ *
8
+ * @module api/utils/eventGrouping
9
+ */
10
+ import { EventResponse } from '../types';
11
+ export type TimeOfDay = 'MORNING' | 'AFTERNOON' | 'EVENING';
12
+ export interface GroupedEvents {
13
+ morning: EventResponse[];
14
+ afternoon: EventResponse[];
15
+ evening: EventResponse[];
16
+ }
17
+ export interface TimeOfDayInfo {
18
+ key: TimeOfDay;
19
+ label: string;
20
+ emoji: string;
21
+ hours: {
22
+ start: number;
23
+ end: number;
24
+ };
25
+ }
26
+ export declare const TIME_OF_DAY_CONFIG: Record<TimeOfDay, TimeOfDayInfo>;
27
+ /**
28
+ * Get time of day for a given date
29
+ *
30
+ * @param date - Date string or Date object
31
+ * @returns TimeOfDay - MORNING, AFTERNOON, or EVENING
32
+ *
33
+ * @example
34
+ * ```tsx
35
+ * const timeOfDay = getTimeOfDay('2024-03-15T10:00:00Z');
36
+ * console.log(timeOfDay); // 'MORNING'
37
+ * ```
38
+ */
39
+ export declare function getTimeOfDay(date: Date | string): TimeOfDay;
40
+ /**
41
+ * Get label for time of day
42
+ *
43
+ * @param timeOfDay - TimeOfDay enum value
44
+ * @returns Human-readable label
45
+ *
46
+ * @example
47
+ * ```tsx
48
+ * const label = getTimeOfDayLabel('MORNING');
49
+ * console.log(label); // 'Morning'
50
+ * ```
51
+ */
52
+ export declare function getTimeOfDayLabel(timeOfDay: TimeOfDay): string;
53
+ /**
54
+ * Group events by time of day
55
+ *
56
+ * @param events - Array of events to group
57
+ * @returns GroupedEvents object with morning, afternoon, and evening arrays
58
+ *
59
+ * @example
60
+ * ```tsx
61
+ * import { useUpcomingEvents, groupEventsByTimeOfDay } from '@growsober/sdk';
62
+ *
63
+ * function GatheringsList() {
64
+ * const { data: events } = useUpcomingEvents(30);
65
+ * const grouped = useMemo(() => {
66
+ * if (!events) return null;
67
+ * return groupEventsByTimeOfDay(events);
68
+ * }, [events]);
69
+ *
70
+ * return (
71
+ * <SectionList
72
+ * sections={[
73
+ * { title: 'Morning', data: grouped?.morning || [] },
74
+ * { title: 'Afternoon', data: grouped?.afternoon || [] },
75
+ * { title: 'Evening', data: grouped?.evening || [] },
76
+ * ]}
77
+ * ...
78
+ * />
79
+ * );
80
+ * }
81
+ * ```
82
+ */
83
+ export declare function groupEventsByTimeOfDay(events: EventResponse[]): GroupedEvents;
84
+ /**
85
+ * Convert grouped events to section list data format
86
+ *
87
+ * @param events - Array of events to group
88
+ * @returns Array of sections with title and data
89
+ *
90
+ * @example
91
+ * ```tsx
92
+ * const sections = getEventSections(events);
93
+ * // [
94
+ * // { title: 'Morning', data: [...] },
95
+ * // { title: 'Afternoon', data: [...] },
96
+ * // { title: 'Evening', data: [...] },
97
+ * // ]
98
+ * ```
99
+ */
100
+ export declare function getEventSections(events: EventResponse[]): Array<{
101
+ title: string;
102
+ timeOfDay: TimeOfDay;
103
+ data: EventResponse[];
104
+ }>;
@@ -0,0 +1,155 @@
1
+ "use strict";
2
+ /**
3
+ * Event Grouping Utilities
4
+ *
5
+ * Utilities for organizing events by time of day.
6
+ * Used in the Gatherings screen to show events grouped by
7
+ * Morning, Afternoon, and Evening.
8
+ *
9
+ * @module api/utils/eventGrouping
10
+ */
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.TIME_OF_DAY_CONFIG = void 0;
13
+ exports.getTimeOfDay = getTimeOfDay;
14
+ exports.getTimeOfDayLabel = getTimeOfDayLabel;
15
+ exports.groupEventsByTimeOfDay = groupEventsByTimeOfDay;
16
+ exports.getEventSections = getEventSections;
17
+ // ============================================================================
18
+ // CONSTANTS
19
+ // ============================================================================
20
+ exports.TIME_OF_DAY_CONFIG = {
21
+ MORNING: {
22
+ key: 'MORNING',
23
+ label: 'Morning',
24
+ emoji: '',
25
+ hours: { start: 5, end: 11 }, // 5:00 AM - 11:59 AM
26
+ },
27
+ AFTERNOON: {
28
+ key: 'AFTERNOON',
29
+ label: 'Afternoon',
30
+ emoji: '',
31
+ hours: { start: 12, end: 16 }, // 12:00 PM - 4:59 PM
32
+ },
33
+ EVENING: {
34
+ key: 'EVENING',
35
+ label: 'Evening',
36
+ emoji: '',
37
+ hours: { start: 17, end: 4 }, // 5:00 PM - 4:59 AM (next day)
38
+ },
39
+ };
40
+ // ============================================================================
41
+ // FUNCTIONS
42
+ // ============================================================================
43
+ /**
44
+ * Get time of day for a given date
45
+ *
46
+ * @param date - Date string or Date object
47
+ * @returns TimeOfDay - MORNING, AFTERNOON, or EVENING
48
+ *
49
+ * @example
50
+ * ```tsx
51
+ * const timeOfDay = getTimeOfDay('2024-03-15T10:00:00Z');
52
+ * console.log(timeOfDay); // 'MORNING'
53
+ * ```
54
+ */
55
+ function getTimeOfDay(date) {
56
+ const d = typeof date === 'string' ? new Date(date) : date;
57
+ const hour = d.getHours();
58
+ if (hour >= 5 && hour < 12)
59
+ return 'MORNING';
60
+ if (hour >= 12 && hour < 17)
61
+ return 'AFTERNOON';
62
+ return 'EVENING';
63
+ }
64
+ /**
65
+ * Get label for time of day
66
+ *
67
+ * @param timeOfDay - TimeOfDay enum value
68
+ * @returns Human-readable label
69
+ *
70
+ * @example
71
+ * ```tsx
72
+ * const label = getTimeOfDayLabel('MORNING');
73
+ * console.log(label); // 'Morning'
74
+ * ```
75
+ */
76
+ function getTimeOfDayLabel(timeOfDay) {
77
+ return exports.TIME_OF_DAY_CONFIG[timeOfDay].label;
78
+ }
79
+ /**
80
+ * Group events by time of day
81
+ *
82
+ * @param events - Array of events to group
83
+ * @returns GroupedEvents object with morning, afternoon, and evening arrays
84
+ *
85
+ * @example
86
+ * ```tsx
87
+ * import { useUpcomingEvents, groupEventsByTimeOfDay } from '@growsober/sdk';
88
+ *
89
+ * function GatheringsList() {
90
+ * const { data: events } = useUpcomingEvents(30);
91
+ * const grouped = useMemo(() => {
92
+ * if (!events) return null;
93
+ * return groupEventsByTimeOfDay(events);
94
+ * }, [events]);
95
+ *
96
+ * return (
97
+ * <SectionList
98
+ * sections={[
99
+ * { title: 'Morning', data: grouped?.morning || [] },
100
+ * { title: 'Afternoon', data: grouped?.afternoon || [] },
101
+ * { title: 'Evening', data: grouped?.evening || [] },
102
+ * ]}
103
+ * ...
104
+ * />
105
+ * );
106
+ * }
107
+ * ```
108
+ */
109
+ function groupEventsByTimeOfDay(events) {
110
+ const grouped = {
111
+ morning: [],
112
+ afternoon: [],
113
+ evening: [],
114
+ };
115
+ for (const event of events) {
116
+ const timeOfDay = getTimeOfDay(event.startDate);
117
+ switch (timeOfDay) {
118
+ case 'MORNING':
119
+ grouped.morning.push(event);
120
+ break;
121
+ case 'AFTERNOON':
122
+ grouped.afternoon.push(event);
123
+ break;
124
+ case 'EVENING':
125
+ grouped.evening.push(event);
126
+ break;
127
+ }
128
+ }
129
+ return grouped;
130
+ }
131
+ /**
132
+ * Convert grouped events to section list data format
133
+ *
134
+ * @param events - Array of events to group
135
+ * @returns Array of sections with title and data
136
+ *
137
+ * @example
138
+ * ```tsx
139
+ * const sections = getEventSections(events);
140
+ * // [
141
+ * // { title: 'Morning', data: [...] },
142
+ * // { title: 'Afternoon', data: [...] },
143
+ * // { title: 'Evening', data: [...] },
144
+ * // ]
145
+ * ```
146
+ */
147
+ function getEventSections(events) {
148
+ const grouped = groupEventsByTimeOfDay(events);
149
+ return [
150
+ { title: 'Morning', timeOfDay: 'MORNING', data: grouped.morning },
151
+ { title: 'Afternoon', timeOfDay: 'AFTERNOON', data: grouped.afternoon },
152
+ { title: 'Evening', timeOfDay: 'EVENING', data: grouped.evening },
153
+ ].filter(section => section.data.length > 0);
154
+ }
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eventGrouping.js","sourceRoot":"","sources":["../../../src/api/utils/eventGrouping.ts"],"names":[],"mappings":";AAAA;;;;;;;;GAQG;;;AAgEH,oCAOC;AAcD,8CAEC;AAgCD,wDAuBC;AAkBD,4CAYC;AArJD,+EAA+E;AAC/E,YAAY;AACZ,+EAA+E;AAElE,QAAA,kBAAkB,GAAqC;IAClE,OAAO,EAAE;QACP,GAAG,EAAE,SAAS;QACd,KAAK,EAAE,SAAS;QAChB,KAAK,EAAE,EAAE;QACT,KAAK,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,qBAAqB;KACpD;IACD,SAAS,EAAE;QACT,GAAG,EAAE,WAAW;QAChB,KAAK,EAAE,WAAW;QAClB,KAAK,EAAE,EAAE;QACT,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,qBAAqB;KACrD;IACD,OAAO,EAAE;QACP,GAAG,EAAE,SAAS;QACd,KAAK,EAAE,SAAS;QAChB,KAAK,EAAE,EAAE;QACT,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE,+BAA+B;KAC9D;CACF,CAAC;AAEF,+EAA+E;AAC/E,YAAY;AACZ,+EAA+E;AAE/E;;;;;;;;;;;GAWG;AACH,SAAgB,YAAY,CAAC,IAAmB;IAC9C,MAAM,CAAC,GAAG,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC3D,MAAM,IAAI,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;IAE1B,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,GAAG,EAAE;QAAE,OAAO,SAAS,CAAC;IAC7C,IAAI,IAAI,IAAI,EAAE,IAAI,IAAI,GAAG,EAAE;QAAE,OAAO,WAAW,CAAC;IAChD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED;;;;;;;;;;;GAWG;AACH,SAAgB,iBAAiB,CAAC,SAAoB;IACpD,OAAO,0BAAkB,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC;AAC7C,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AACH,SAAgB,sBAAsB,CAAC,MAAuB;IAC5D,MAAM,OAAO,GAAkB;QAC7B,OAAO,EAAE,EAAE;QACX,SAAS,EAAE,EAAE;QACb,OAAO,EAAE,EAAE;KACZ,CAAC;IAEF,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QAC3B,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAChD,QAAQ,SAAS,EAAE,CAAC;YAClB,KAAK,SAAS;gBACZ,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC5B,MAAM;YACR,KAAK,WAAW;gBACd,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC9B,MAAM;YACR,KAAK,SAAS;gBACZ,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC5B,MAAM;QACV,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC;AAED;;;;;;;;;;;;;;;GAeG;AACH,SAAgB,gBAAgB,CAAC,MAAuB;IAKtD,MAAM,OAAO,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC;IAE/C,OAAO;QACL,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,SAAsB,EAAE,IAAI,EAAE,OAAO,CAAC,OAAO,EAAE;QAC9E,EAAE,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,WAAwB,EAAE,IAAI,EAAE,OAAO,CAAC,SAAS,EAAE;QACpF,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,SAAsB,EAAE,IAAI,EAAE,OAAO,CAAC,OAAO,EAAE;KAC/E,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AAC/C,CAAC","sourcesContent":["/**\n * Event Grouping Utilities\n *\n * Utilities for organizing events by time of day.\n * Used in the Gatherings screen to show events grouped by\n * Morning, Afternoon, and Evening.\n *\n * @module api/utils/eventGrouping\n */\n\nimport { EventResponse } from '../types';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport type TimeOfDay = 'MORNING' | 'AFTERNOON' | 'EVENING';\n\nexport interface GroupedEvents {\n  morning: EventResponse[];\n  afternoon: EventResponse[];\n  evening: EventResponse[];\n}\n\nexport interface TimeOfDayInfo {\n  key: TimeOfDay;\n  label: string;\n  emoji: string;\n  hours: { start: number; end: number };\n}\n\n// ============================================================================\n// CONSTANTS\n// ============================================================================\n\nexport const TIME_OF_DAY_CONFIG: Record<TimeOfDay, TimeOfDayInfo> = {\n  MORNING: {\n    key: 'MORNING',\n    label: 'Morning',\n    emoji: '',\n    hours: { start: 5, end: 11 }, // 5:00 AM - 11:59 AM\n  },\n  AFTERNOON: {\n    key: 'AFTERNOON',\n    label: 'Afternoon',\n    emoji: '',\n    hours: { start: 12, end: 16 }, // 12:00 PM - 4:59 PM\n  },\n  EVENING: {\n    key: 'EVENING',\n    label: 'Evening',\n    emoji: '',\n    hours: { start: 17, end: 4 }, // 5:00 PM - 4:59 AM (next day)\n  },\n};\n\n// ============================================================================\n// FUNCTIONS\n// ============================================================================\n\n/**\n * Get time of day for a given date\n *\n * @param date - Date string or Date object\n * @returns TimeOfDay - MORNING, AFTERNOON, or EVENING\n *\n * @example\n * ```tsx\n * const timeOfDay = getTimeOfDay('2024-03-15T10:00:00Z');\n * console.log(timeOfDay); // 'MORNING'\n * ```\n */\nexport function getTimeOfDay(date: Date | string): TimeOfDay {\n  const d = typeof date === 'string' ? new Date(date) : date;\n  const hour = d.getHours();\n\n  if (hour >= 5 && hour < 12) return 'MORNING';\n  if (hour >= 12 && hour < 17) return 'AFTERNOON';\n  return 'EVENING';\n}\n\n/**\n * Get label for time of day\n *\n * @param timeOfDay - TimeOfDay enum value\n * @returns Human-readable label\n *\n * @example\n * ```tsx\n * const label = getTimeOfDayLabel('MORNING');\n * console.log(label); // 'Morning'\n * ```\n */\nexport function getTimeOfDayLabel(timeOfDay: TimeOfDay): string {\n  return TIME_OF_DAY_CONFIG[timeOfDay].label;\n}\n\n/**\n * Group events by time of day\n *\n * @param events - Array of events to group\n * @returns GroupedEvents object with morning, afternoon, and evening arrays\n *\n * @example\n * ```tsx\n * import { useUpcomingEvents, groupEventsByTimeOfDay } from '@growsober/sdk';\n *\n * function GatheringsList() {\n *   const { data: events } = useUpcomingEvents(30);\n *   const grouped = useMemo(() => {\n *     if (!events) return null;\n *     return groupEventsByTimeOfDay(events);\n *   }, [events]);\n *\n *   return (\n *     <SectionList\n *       sections={[\n *         { title: 'Morning', data: grouped?.morning || [] },\n *         { title: 'Afternoon', data: grouped?.afternoon || [] },\n *         { title: 'Evening', data: grouped?.evening || [] },\n *       ]}\n *       ...\n *     />\n *   );\n * }\n * ```\n */\nexport function groupEventsByTimeOfDay(events: EventResponse[]): GroupedEvents {\n  const grouped: GroupedEvents = {\n    morning: [],\n    afternoon: [],\n    evening: [],\n  };\n\n  for (const event of events) {\n    const timeOfDay = getTimeOfDay(event.startDate);\n    switch (timeOfDay) {\n      case 'MORNING':\n        grouped.morning.push(event);\n        break;\n      case 'AFTERNOON':\n        grouped.afternoon.push(event);\n        break;\n      case 'EVENING':\n        grouped.evening.push(event);\n        break;\n    }\n  }\n\n  return grouped;\n}\n\n/**\n * Convert grouped events to section list data format\n *\n * @param events - Array of events to group\n * @returns Array of sections with title and data\n *\n * @example\n * ```tsx\n * const sections = getEventSections(events);\n * // [\n * //   { title: 'Morning', data: [...] },\n * //   { title: 'Afternoon', data: [...] },\n * //   { title: 'Evening', data: [...] },\n * // ]\n * ```\n */\nexport function getEventSections(events: EventResponse[]): Array<{\n  title: string;\n  timeOfDay: TimeOfDay;\n  data: EventResponse[];\n}> {\n  const grouped = groupEventsByTimeOfDay(events);\n\n  return [\n    { title: 'Morning', timeOfDay: 'MORNING' as TimeOfDay, data: grouped.morning },\n    { title: 'Afternoon', timeOfDay: 'AFTERNOON' as TimeOfDay, data: grouped.afternoon },\n    { title: 'Evening', timeOfDay: 'EVENING' as TimeOfDay, data: grouped.evening },\n  ].filter(section => section.data.length > 0);\n}\n"]}
package/dist/index.d.ts CHANGED
@@ -34,3 +34,4 @@ export type { SDKConfig } from './api/client';
34
34
  export * from './api/types';
35
35
  export * from './api/queries';
36
36
  export * from './api/mutations';
37
+ export * from './api/utils/eventGrouping';