@growsober/sdk 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (129) hide show
  1. package/README.md +276 -0
  2. package/dist/__tests__/e2e.test.d.ts +7 -0
  3. package/dist/__tests__/e2e.test.js +472 -0
  4. package/dist/api/client.d.ts +11 -0
  5. package/dist/api/client.js +61 -0
  6. package/dist/api/mutations/admin.d.ts +167 -0
  7. package/dist/api/mutations/admin.js +326 -0
  8. package/dist/api/mutations/ambassadors.d.ts +52 -0
  9. package/dist/api/mutations/ambassadors.js +148 -0
  10. package/dist/api/mutations/auth.d.ts +267 -0
  11. package/dist/api/mutations/auth.js +332 -0
  12. package/dist/api/mutations/bookings.d.ts +59 -0
  13. package/dist/api/mutations/bookings.js +143 -0
  14. package/dist/api/mutations/event-chat.d.ts +35 -0
  15. package/dist/api/mutations/event-chat.js +147 -0
  16. package/dist/api/mutations/events.d.ts +87 -0
  17. package/dist/api/mutations/events.js +205 -0
  18. package/dist/api/mutations/grow90.d.ts +36 -0
  19. package/dist/api/mutations/grow90.js +132 -0
  20. package/dist/api/mutations/hubs.d.ts +111 -0
  21. package/dist/api/mutations/hubs.js +240 -0
  22. package/dist/api/mutations/index.d.ts +22 -0
  23. package/dist/api/mutations/index.js +39 -0
  24. package/dist/api/mutations/jack.d.ts +61 -0
  25. package/dist/api/mutations/jack.js +104 -0
  26. package/dist/api/mutations/library.d.ts +67 -0
  27. package/dist/api/mutations/library.js +168 -0
  28. package/dist/api/mutations/map.d.ts +153 -0
  29. package/dist/api/mutations/map.js +181 -0
  30. package/dist/api/mutations/matching.d.ts +130 -0
  31. package/dist/api/mutations/matching.js +204 -0
  32. package/dist/api/mutations/notifications.d.ts +63 -0
  33. package/dist/api/mutations/notifications.js +106 -0
  34. package/dist/api/mutations/offers.d.ts +26 -0
  35. package/dist/api/mutations/offers.js +47 -0
  36. package/dist/api/mutations/subscriptions.d.ts +127 -0
  37. package/dist/api/mutations/subscriptions.js +140 -0
  38. package/dist/api/mutations/support.d.ts +165 -0
  39. package/dist/api/mutations/support.js +307 -0
  40. package/dist/api/mutations/users.d.ts +211 -0
  41. package/dist/api/mutations/users.js +261 -0
  42. package/dist/api/queries/admin.d.ts +257 -0
  43. package/dist/api/queries/admin.js +320 -0
  44. package/dist/api/queries/ambassadors.d.ts +53 -0
  45. package/dist/api/queries/ambassadors.js +98 -0
  46. package/dist/api/queries/auth.d.ts +16 -0
  47. package/dist/api/queries/auth.js +25 -0
  48. package/dist/api/queries/bookings.d.ts +91 -0
  49. package/dist/api/queries/bookings.js +102 -0
  50. package/dist/api/queries/businesses.d.ts +212 -0
  51. package/dist/api/queries/businesses.js +154 -0
  52. package/dist/api/queries/event-chat.d.ts +19 -0
  53. package/dist/api/queries/event-chat.js +75 -0
  54. package/dist/api/queries/events.d.ts +322 -0
  55. package/dist/api/queries/events.js +221 -0
  56. package/dist/api/queries/grow90.d.ts +26 -0
  57. package/dist/api/queries/grow90.js +85 -0
  58. package/dist/api/queries/hubs.d.ts +165 -0
  59. package/dist/api/queries/hubs.js +143 -0
  60. package/dist/api/queries/index.d.ts +23 -0
  61. package/dist/api/queries/index.js +40 -0
  62. package/dist/api/queries/jack.d.ts +63 -0
  63. package/dist/api/queries/jack.js +92 -0
  64. package/dist/api/queries/library.d.ts +132 -0
  65. package/dist/api/queries/library.js +120 -0
  66. package/dist/api/queries/map.d.ts +216 -0
  67. package/dist/api/queries/map.js +278 -0
  68. package/dist/api/queries/matching.d.ts +136 -0
  69. package/dist/api/queries/matching.js +161 -0
  70. package/dist/api/queries/notifications.d.ts +78 -0
  71. package/dist/api/queries/notifications.js +88 -0
  72. package/dist/api/queries/offers.d.ts +91 -0
  73. package/dist/api/queries/offers.js +103 -0
  74. package/dist/api/queries/subscriptions.d.ts +56 -0
  75. package/dist/api/queries/subscriptions.js +73 -0
  76. package/dist/api/queries/support.d.ts +106 -0
  77. package/dist/api/queries/support.js +202 -0
  78. package/dist/api/queries/users.d.ts +293 -0
  79. package/dist/api/queries/users.js +370 -0
  80. package/dist/api/types.d.ts +464 -0
  81. package/dist/api/types.js +9 -0
  82. package/dist/hooks/useAuth.d.ts +5 -0
  83. package/dist/hooks/useAuth.js +39 -0
  84. package/dist/hooks/useUser.d.ts +43 -0
  85. package/dist/hooks/useUser.js +44 -0
  86. package/dist/index.d.ts +36 -0
  87. package/dist/index.js +67 -0
  88. package/package.json +62 -0
  89. package/src/__tests__/e2e.test.ts +502 -0
  90. package/src/api/client.ts +71 -0
  91. package/src/api/mutations/admin.ts +531 -0
  92. package/src/api/mutations/ambassadors.ts +185 -0
  93. package/src/api/mutations/auth.ts +350 -0
  94. package/src/api/mutations/bookings.ts +190 -0
  95. package/src/api/mutations/event-chat.ts +177 -0
  96. package/src/api/mutations/events.ts +273 -0
  97. package/src/api/mutations/grow90.ts +169 -0
  98. package/src/api/mutations/hubs.ts +385 -0
  99. package/src/api/mutations/index.ts +23 -0
  100. package/src/api/mutations/jack.ts +130 -0
  101. package/src/api/mutations/library.ts +212 -0
  102. package/src/api/mutations/map.ts +230 -0
  103. package/src/api/mutations/matching.ts +271 -0
  104. package/src/api/mutations/notifications.ts +114 -0
  105. package/src/api/mutations/offers.ts +73 -0
  106. package/src/api/mutations/subscriptions.ts +162 -0
  107. package/src/api/mutations/support.ts +390 -0
  108. package/src/api/mutations/users.ts +271 -0
  109. package/src/api/queries/admin.ts +480 -0
  110. package/src/api/queries/ambassadors.ts +139 -0
  111. package/src/api/queries/auth.ts +24 -0
  112. package/src/api/queries/bookings.ts +135 -0
  113. package/src/api/queries/businesses.ts +203 -0
  114. package/src/api/queries/event-chat.ts +78 -0
  115. package/src/api/queries/events.ts +272 -0
  116. package/src/api/queries/grow90.ts +98 -0
  117. package/src/api/queries/hubs.ts +211 -0
  118. package/src/api/queries/index.ts +24 -0
  119. package/src/api/queries/jack.ts +127 -0
  120. package/src/api/queries/library.ts +166 -0
  121. package/src/api/queries/map.ts +331 -0
  122. package/src/api/queries/matching.ts +238 -0
  123. package/src/api/queries/notifications.ts +103 -0
  124. package/src/api/queries/offers.ts +136 -0
  125. package/src/api/queries/subscriptions.ts +91 -0
  126. package/src/api/queries/support.ts +235 -0
  127. package/src/api/queries/users.ts +393 -0
  128. package/src/api/types.ts +596 -0
  129. package/src/index.ts +57 -0
@@ -0,0 +1,147 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useUpdateChatSettings = useUpdateChatSettings;
4
+ exports.useJoinEventChat = useJoinEventChat;
5
+ exports.useLeaveEventChat = useLeaveEventChat;
6
+ exports.useUpdateMemberSettings = useUpdateMemberSettings;
7
+ exports.useMarkMessagesAsRead = useMarkMessagesAsRead;
8
+ exports.useSendEventChatMessage = useSendEventChatMessage;
9
+ exports.useUpdateEventChatMessage = useUpdateEventChatMessage;
10
+ exports.useDeleteEventChatMessage = useDeleteEventChatMessage;
11
+ const react_query_1 = require("@tanstack/react-query");
12
+ const client_1 = require("../client");
13
+ const event_chat_1 = require("../queries/event-chat");
14
+ // ============================================================================
15
+ // CHAT MANAGEMENT
16
+ // ============================================================================
17
+ /**
18
+ * Update chat settings (hosts only)
19
+ */
20
+ function useUpdateChatSettings(eventId) {
21
+ const queryClient = (0, react_query_1.useQueryClient)();
22
+ return (0, react_query_1.useMutation)({
23
+ mutationFn: async (data) => {
24
+ const client = (0, client_1.getApiClient)();
25
+ const response = await client.put(`/events/${eventId}/chat/settings`, data);
26
+ return response.data;
27
+ },
28
+ onSuccess: () => {
29
+ queryClient.invalidateQueries({ queryKey: event_chat_1.eventChatKeys.chat(eventId) });
30
+ },
31
+ });
32
+ }
33
+ // ============================================================================
34
+ // MEMBER MANAGEMENT
35
+ // ============================================================================
36
+ /**
37
+ * Join event chat
38
+ */
39
+ function useJoinEventChat(eventId) {
40
+ const queryClient = (0, react_query_1.useQueryClient)();
41
+ return (0, react_query_1.useMutation)({
42
+ mutationFn: async () => {
43
+ const client = (0, client_1.getApiClient)();
44
+ const response = await client.post(`/events/${eventId}/chat/join`);
45
+ return response.data;
46
+ },
47
+ onSuccess: () => {
48
+ queryClient.invalidateQueries({ queryKey: event_chat_1.eventChatKeys.chat(eventId) });
49
+ queryClient.invalidateQueries({ queryKey: event_chat_1.eventChatKeys.members(eventId) });
50
+ },
51
+ });
52
+ }
53
+ /**
54
+ * Leave event chat
55
+ */
56
+ function useLeaveEventChat(eventId) {
57
+ const queryClient = (0, react_query_1.useQueryClient)();
58
+ return (0, react_query_1.useMutation)({
59
+ mutationFn: async () => {
60
+ const client = (0, client_1.getApiClient)();
61
+ await client.post(`/events/${eventId}/chat/leave`);
62
+ },
63
+ onSuccess: () => {
64
+ queryClient.invalidateQueries({ queryKey: event_chat_1.eventChatKeys.chat(eventId) });
65
+ queryClient.invalidateQueries({ queryKey: event_chat_1.eventChatKeys.members(eventId) });
66
+ },
67
+ });
68
+ }
69
+ /**
70
+ * Update member settings (mute, nickname)
71
+ */
72
+ function useUpdateMemberSettings(eventId) {
73
+ const queryClient = (0, react_query_1.useQueryClient)();
74
+ return (0, react_query_1.useMutation)({
75
+ mutationFn: async (data) => {
76
+ const client = (0, client_1.getApiClient)();
77
+ const response = await client.put(`/events/${eventId}/chat/settings/me`, data);
78
+ return response.data;
79
+ },
80
+ onSuccess: () => {
81
+ queryClient.invalidateQueries({ queryKey: event_chat_1.eventChatKeys.members(eventId) });
82
+ },
83
+ });
84
+ }
85
+ /**
86
+ * Mark messages as read
87
+ */
88
+ function useMarkMessagesAsRead(eventId) {
89
+ return (0, react_query_1.useMutation)({
90
+ mutationFn: async () => {
91
+ const client = (0, client_1.getApiClient)();
92
+ await client.post(`/events/${eventId}/chat/read`);
93
+ },
94
+ });
95
+ }
96
+ // ============================================================================
97
+ // MESSAGES
98
+ // ============================================================================
99
+ /**
100
+ * Send a message
101
+ */
102
+ function useSendEventChatMessage(eventId) {
103
+ const queryClient = (0, react_query_1.useQueryClient)();
104
+ return (0, react_query_1.useMutation)({
105
+ mutationFn: async (data) => {
106
+ const client = (0, client_1.getApiClient)();
107
+ const response = await client.post(`/events/${eventId}/chat/messages`, data);
108
+ return response.data;
109
+ },
110
+ onSuccess: () => {
111
+ queryClient.invalidateQueries({ queryKey: event_chat_1.eventChatKeys.messages(eventId) });
112
+ queryClient.invalidateQueries({ queryKey: event_chat_1.eventChatKeys.chat(eventId) });
113
+ },
114
+ });
115
+ }
116
+ /**
117
+ * Update a message
118
+ */
119
+ function useUpdateEventChatMessage(eventId) {
120
+ const queryClient = (0, react_query_1.useQueryClient)();
121
+ return (0, react_query_1.useMutation)({
122
+ mutationFn: async ({ messageId, content }) => {
123
+ const client = (0, client_1.getApiClient)();
124
+ const response = await client.put(`/events/${eventId}/chat/messages/${messageId}`, { content });
125
+ return response.data;
126
+ },
127
+ onSuccess: () => {
128
+ queryClient.invalidateQueries({ queryKey: event_chat_1.eventChatKeys.messages(eventId) });
129
+ },
130
+ });
131
+ }
132
+ /**
133
+ * Delete a message
134
+ */
135
+ function useDeleteEventChatMessage(eventId) {
136
+ const queryClient = (0, react_query_1.useQueryClient)();
137
+ return (0, react_query_1.useMutation)({
138
+ mutationFn: async (messageId) => {
139
+ const client = (0, client_1.getApiClient)();
140
+ await client.delete(`/events/${eventId}/chat/messages/${messageId}`);
141
+ },
142
+ onSuccess: () => {
143
+ queryClient.invalidateQueries({ queryKey: event_chat_1.eventChatKeys.messages(eventId) });
144
+ },
145
+ });
146
+ }
147
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event-chat.js","sourceRoot":"","sources":["../../../src/api/mutations/event-chat.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { eventChatKeys } from '../queries/event-chat';\nimport type {\n  ChatMemberResponse,\n  MessageResponse,\n  EventChatResponse,\n  SendMessageRequest,\n  UpdateMessageRequest,\n  UpdateChatSettingsRequest,\n  UpdateMemberSettingsRequest,\n} from '../types';\n\n// ============================================================================\n// CHAT MANAGEMENT\n// ============================================================================\n\n/**\n * Update chat settings (hosts only)\n */\nexport function useUpdateChatSettings(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: UpdateChatSettingsRequest) => {\n      const client = getApiClient();\n      const response = await client.put<EventChatResponse>(\n        `/events/${eventId}/chat/settings`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.chat(eventId) });\n    },\n  });\n}\n\n// ============================================================================\n// MEMBER MANAGEMENT\n// ============================================================================\n\n/**\n * Join event chat\n */\nexport function useJoinEventChat(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async () => {\n      const client = getApiClient();\n      const response = await client.post<ChatMemberResponse>(\n        `/events/${eventId}/chat/join`\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.chat(eventId) });\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.members(eventId) });\n    },\n  });\n}\n\n/**\n * Leave event chat\n */\nexport function useLeaveEventChat(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async () => {\n      const client = getApiClient();\n      await client.post(`/events/${eventId}/chat/leave`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.chat(eventId) });\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.members(eventId) });\n    },\n  });\n}\n\n/**\n * Update member settings (mute, nickname)\n */\nexport function useUpdateMemberSettings(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: UpdateMemberSettingsRequest) => {\n      const client = getApiClient();\n      const response = await client.put<ChatMemberResponse>(\n        `/events/${eventId}/chat/settings/me`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.members(eventId) });\n    },\n  });\n}\n\n/**\n * Mark messages as read\n */\nexport function useMarkMessagesAsRead(eventId: string) {\n  return useMutation({\n    mutationFn: async () => {\n      const client = getApiClient();\n      await client.post(`/events/${eventId}/chat/read`);\n    },\n  });\n}\n\n// ============================================================================\n// MESSAGES\n// ============================================================================\n\n/**\n * Send a message\n */\nexport function useSendEventChatMessage(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: SendMessageRequest) => {\n      const client = getApiClient();\n      const response = await client.post<MessageResponse>(\n        `/events/${eventId}/chat/messages`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.messages(eventId) });\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.chat(eventId) });\n    },\n  });\n}\n\n/**\n * Update a message\n */\nexport function useUpdateEventChatMessage(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ messageId, content }: { messageId: string } & UpdateMessageRequest) => {\n      const client = getApiClient();\n      const response = await client.put<MessageResponse>(\n        `/events/${eventId}/chat/messages/${messageId}`,\n        { content }\n      );\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.messages(eventId) });\n    },\n  });\n}\n\n/**\n * Delete a message\n */\nexport function useDeleteEventChatMessage(eventId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (messageId: string) => {\n      const client = getApiClient();\n      await client.delete(`/events/${eventId}/chat/messages/${messageId}`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: eventChatKeys.messages(eventId) });\n    },\n  });\n}\n"]}
@@ -0,0 +1,87 @@
1
+ import { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
2
+ import type { EventResponse, CreateEventRequest, UpdateEventRequest } from '../types';
3
+ /**
4
+ * Create a new event
5
+ *
6
+ * @param options - TanStack Query mutation options
7
+ *
8
+ * @example
9
+ * ```tsx
10
+ * const { mutate, isPending } = useCreateEvent();
11
+ *
12
+ * mutate({
13
+ * title: 'Yoga in the Park',
14
+ * description: 'Join us for morning yoga',
15
+ * startDate: new Date('2025-01-15T10:00:00Z'),
16
+ * // ... other fields
17
+ * });
18
+ * ```
19
+ */
20
+ export declare function useCreateEvent(options?: Omit<UseMutationOptions<EventResponse, Error, CreateEventRequest>, 'mutationFn'>): UseMutationResult<EventResponse, Error, CreateEventRequest>;
21
+ /**
22
+ * Update an existing event
23
+ *
24
+ * @param options - TanStack Query mutation options
25
+ *
26
+ * @example
27
+ * ```tsx
28
+ * const { mutate, isPending } = useUpdateEvent();
29
+ *
30
+ * mutate({
31
+ * id: 'event-123',
32
+ * data: {
33
+ * title: 'Updated Event Title',
34
+ * isFeatured: true,
35
+ * }
36
+ * });
37
+ * ```
38
+ */
39
+ export declare function useUpdateEvent(options?: Omit<UseMutationOptions<EventResponse, Error, {
40
+ id: string;
41
+ data: UpdateEventRequest;
42
+ }>, 'mutationFn'>): UseMutationResult<EventResponse, Error, {
43
+ id: string;
44
+ data: UpdateEventRequest;
45
+ }>;
46
+ /**
47
+ * Delete an event
48
+ *
49
+ * @param options - TanStack Query mutation options
50
+ *
51
+ * @example
52
+ * ```tsx
53
+ * const { mutate, isPending } = useDeleteEvent();
54
+ *
55
+ * mutate('event-123');
56
+ * ```
57
+ */
58
+ export declare function useDeleteEvent(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
59
+ /**
60
+ * Cancel an event
61
+ *
62
+ * @param options - TanStack Query mutation options
63
+ *
64
+ * @example
65
+ * ```tsx
66
+ * const { mutate, isPending } = useCancelEvent();
67
+ *
68
+ * mutate('event-123');
69
+ * ```
70
+ */
71
+ export declare function useCancelEvent(options?: Omit<UseMutationOptions<EventResponse, Error, string>, 'mutationFn'>): UseMutationResult<EventResponse, Error, string>;
72
+ /**
73
+ * Publish an event
74
+ *
75
+ * Note: This mutation is provided for future compatibility.
76
+ * The API endpoint exists but may require specific permissions.
77
+ *
78
+ * @param options - TanStack Query mutation options
79
+ *
80
+ * @example
81
+ * ```tsx
82
+ * const { mutate, isPending } = usePublishEvent();
83
+ *
84
+ * mutate('event-123');
85
+ * ```
86
+ */
87
+ export declare function usePublishEvent(options?: Omit<UseMutationOptions<EventResponse, Error, string>, 'mutationFn'>): UseMutationResult<EventResponse, Error, string>;
@@ -0,0 +1,205 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useCreateEvent = useCreateEvent;
4
+ exports.useUpdateEvent = useUpdateEvent;
5
+ exports.useDeleteEvent = useDeleteEvent;
6
+ exports.useCancelEvent = useCancelEvent;
7
+ exports.usePublishEvent = usePublishEvent;
8
+ const react_query_1 = require("@tanstack/react-query");
9
+ const client_1 = require("../client");
10
+ const events_1 = require("../queries/events");
11
+ // ============================================================================
12
+ // MUTATION HOOKS
13
+ // ============================================================================
14
+ /**
15
+ * Create a new event
16
+ *
17
+ * @param options - TanStack Query mutation options
18
+ *
19
+ * @example
20
+ * ```tsx
21
+ * const { mutate, isPending } = useCreateEvent();
22
+ *
23
+ * mutate({
24
+ * title: 'Yoga in the Park',
25
+ * description: 'Join us for morning yoga',
26
+ * startDate: new Date('2025-01-15T10:00:00Z'),
27
+ * // ... other fields
28
+ * });
29
+ * ```
30
+ */
31
+ function useCreateEvent(options) {
32
+ const queryClient = (0, react_query_1.useQueryClient)();
33
+ return (0, react_query_1.useMutation)({
34
+ mutationFn: async (data) => {
35
+ const client = (0, client_1.getApiClient)();
36
+ const response = await client.post('/api/v1/events', data);
37
+ return response.data;
38
+ },
39
+ onSuccess: (newEvent, variables, context) => {
40
+ // Invalidate all event lists to include the new event
41
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.lists() });
42
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.upcoming() });
43
+ // If the event is featured, invalidate featured events
44
+ if (newEvent.isFeatured) {
45
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.featured() });
46
+ }
47
+ // Call user's onSuccess if provided
48
+ },
49
+ ...options,
50
+ });
51
+ }
52
+ /**
53
+ * Update an existing event
54
+ *
55
+ * @param options - TanStack Query mutation options
56
+ *
57
+ * @example
58
+ * ```tsx
59
+ * const { mutate, isPending } = useUpdateEvent();
60
+ *
61
+ * mutate({
62
+ * id: 'event-123',
63
+ * data: {
64
+ * title: 'Updated Event Title',
65
+ * isFeatured: true,
66
+ * }
67
+ * });
68
+ * ```
69
+ */
70
+ function useUpdateEvent(options) {
71
+ const queryClient = (0, react_query_1.useQueryClient)();
72
+ return (0, react_query_1.useMutation)({
73
+ mutationFn: async ({ id, data, }) => {
74
+ const client = (0, client_1.getApiClient)();
75
+ const response = await client.put(`/api/v1/events/${id}`, data);
76
+ return response.data;
77
+ },
78
+ onSuccess: (updatedEvent, variables, context) => {
79
+ // Update the specific event in cache
80
+ queryClient.setQueryData(events_1.eventKeys.detail(variables.id), updatedEvent);
81
+ // If the event has a slug, update the slug-based query too
82
+ if (updatedEvent.slug && typeof updatedEvent.slug === 'string') {
83
+ queryClient.setQueryData(events_1.eventKeys.detailBySlug(updatedEvent.slug), updatedEvent);
84
+ }
85
+ // Invalidate lists to reflect changes in ordering/filtering
86
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.lists() });
87
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.upcoming() });
88
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.featured() });
89
+ // Call user's onSuccess if provided
90
+ },
91
+ ...options,
92
+ });
93
+ }
94
+ /**
95
+ * Delete an event
96
+ *
97
+ * @param options - TanStack Query mutation options
98
+ *
99
+ * @example
100
+ * ```tsx
101
+ * const { mutate, isPending } = useDeleteEvent();
102
+ *
103
+ * mutate('event-123');
104
+ * ```
105
+ */
106
+ function useDeleteEvent(options) {
107
+ const queryClient = (0, react_query_1.useQueryClient)();
108
+ return (0, react_query_1.useMutation)({
109
+ mutationFn: async (id) => {
110
+ const client = (0, client_1.getApiClient)();
111
+ await client.delete(`/api/v1/events/${id}`);
112
+ },
113
+ onSuccess: (data, eventId, context) => {
114
+ // Remove the event from cache
115
+ queryClient.removeQueries({ queryKey: events_1.eventKeys.detail(eventId) });
116
+ // Invalidate all lists
117
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.lists() });
118
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.upcoming() });
119
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.featured() });
120
+ // Call user's onSuccess if provided
121
+ },
122
+ ...options,
123
+ });
124
+ }
125
+ /**
126
+ * Cancel an event
127
+ *
128
+ * @param options - TanStack Query mutation options
129
+ *
130
+ * @example
131
+ * ```tsx
132
+ * const { mutate, isPending } = useCancelEvent();
133
+ *
134
+ * mutate('event-123');
135
+ * ```
136
+ */
137
+ function useCancelEvent(options) {
138
+ const queryClient = (0, react_query_1.useQueryClient)();
139
+ return (0, react_query_1.useMutation)({
140
+ mutationFn: async (id) => {
141
+ const client = (0, client_1.getApiClient)();
142
+ const response = await client.post(`/api/v1/events/${id}/cancel`);
143
+ return response.data;
144
+ },
145
+ onSuccess: (cancelledEvent, eventId, context) => {
146
+ // Update the specific event in cache
147
+ queryClient.setQueryData(events_1.eventKeys.detail(eventId), cancelledEvent);
148
+ // If the event has a slug, update the slug-based query too
149
+ if (cancelledEvent.slug && typeof cancelledEvent.slug === 'string') {
150
+ queryClient.setQueryData(events_1.eventKeys.detailBySlug(cancelledEvent.slug), cancelledEvent);
151
+ }
152
+ // Invalidate lists to reflect the cancelled status
153
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.lists() });
154
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.upcoming() });
155
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.featured() });
156
+ // Invalidate bookings for this event
157
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.bookings(eventId) });
158
+ // Call user's onSuccess if provided
159
+ },
160
+ ...options,
161
+ });
162
+ }
163
+ /**
164
+ * Publish an event
165
+ *
166
+ * Note: This mutation is provided for future compatibility.
167
+ * The API endpoint exists but may require specific permissions.
168
+ *
169
+ * @param options - TanStack Query mutation options
170
+ *
171
+ * @example
172
+ * ```tsx
173
+ * const { mutate, isPending } = usePublishEvent();
174
+ *
175
+ * mutate('event-123');
176
+ * ```
177
+ */
178
+ function usePublishEvent(options) {
179
+ const queryClient = (0, react_query_1.useQueryClient)();
180
+ return (0, react_query_1.useMutation)({
181
+ mutationFn: async (id) => {
182
+ const client = (0, client_1.getApiClient)();
183
+ const response = await client.post(`/api/v1/events/${id}/publish`);
184
+ return response.data;
185
+ },
186
+ onSuccess: (publishedEvent, eventId, context) => {
187
+ // Update the specific event in cache
188
+ queryClient.setQueryData(events_1.eventKeys.detail(eventId), publishedEvent);
189
+ // If the event has a slug, update the slug-based query too
190
+ if (publishedEvent.slug && typeof publishedEvent.slug === 'string') {
191
+ queryClient.setQueryData(events_1.eventKeys.detailBySlug(publishedEvent.slug), publishedEvent);
192
+ }
193
+ // Invalidate lists to reflect the published status
194
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.lists() });
195
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.upcoming() });
196
+ // If the event is featured, invalidate featured events
197
+ if (publishedEvent.isFeatured) {
198
+ queryClient.invalidateQueries({ queryKey: events_1.eventKeys.featured() });
199
+ }
200
+ // Call user's onSuccess if provided
201
+ },
202
+ ...options,
203
+ });
204
+ }
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"events.js","sourceRoot":"","sources":["../../../src/api/mutations/events.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  useMutation,\n  useQueryClient,\n  UseMutationOptions,\n  UseMutationResult,\n} from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { EventResponse, CreateEventRequest, UpdateEventRequest } from '../types';\nimport { eventKeys } from '../queries/events';\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a new event\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCreateEvent();\n *\n * mutate({\n *   title: 'Yoga in the Park',\n *   description: 'Join us for morning yoga',\n *   startDate: new Date('2025-01-15T10:00:00Z'),\n *   // ... other fields\n * });\n * ```\n */\nexport function useCreateEvent(\n  options?: Omit<\n    UseMutationOptions<EventResponse, Error, CreateEventRequest>,\n    'mutationFn'\n  >\n): UseMutationResult<EventResponse, Error, CreateEventRequest> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateEventRequest): Promise<EventResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/events', data);\n      return response.data;\n    },\n    onSuccess: (newEvent, variables, context) => {\n      // Invalidate all event lists to include the new event\n      queryClient.invalidateQueries({ queryKey: eventKeys.lists() });\n      queryClient.invalidateQueries({ queryKey: eventKeys.upcoming() });\n\n      // If the event is featured, invalidate featured events\n      if (newEvent.isFeatured) {\n        queryClient.invalidateQueries({ queryKey: eventKeys.featured() });\n      }\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Update an existing event\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useUpdateEvent();\n *\n * mutate({\n *   id: 'event-123',\n *   data: {\n *     title: 'Updated Event Title',\n *     isFeatured: true,\n *   }\n * });\n * ```\n */\nexport function useUpdateEvent(\n  options?: Omit<\n    UseMutationOptions<\n      EventResponse,\n      Error,\n      { id: string; data: UpdateEventRequest }\n    >,\n    'mutationFn'\n  >\n): UseMutationResult<EventResponse, Error, { id: string; data: UpdateEventRequest }> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      id,\n      data,\n    }: {\n      id: string;\n      data: UpdateEventRequest;\n    }): Promise<EventResponse> => {\n      const client = getApiClient();\n      const response = await client.put(`/api/v1/events/${id}`, data);\n      return response.data;\n    },\n    onSuccess: (updatedEvent, variables, context) => {\n      // Update the specific event in cache\n      queryClient.setQueryData(\n        eventKeys.detail(variables.id),\n        updatedEvent\n      );\n\n      // If the event has a slug, update the slug-based query too\n      if (updatedEvent.slug && typeof updatedEvent.slug === 'string') {\n        queryClient.setQueryData(\n          eventKeys.detailBySlug(updatedEvent.slug),\n          updatedEvent\n        );\n      }\n\n      // Invalidate lists to reflect changes in ordering/filtering\n      queryClient.invalidateQueries({ queryKey: eventKeys.lists() });\n      queryClient.invalidateQueries({ queryKey: eventKeys.upcoming() });\n      queryClient.invalidateQueries({ queryKey: eventKeys.featured() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Delete an event\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useDeleteEvent();\n *\n * mutate('event-123');\n * ```\n */\nexport function useDeleteEvent(\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>\n): UseMutationResult<void, Error, string> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (id: string): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/events/${id}`);\n    },\n    onSuccess: (data, eventId, context) => {\n      // Remove the event from cache\n      queryClient.removeQueries({ queryKey: eventKeys.detail(eventId) });\n\n      // Invalidate all lists\n      queryClient.invalidateQueries({ queryKey: eventKeys.lists() });\n      queryClient.invalidateQueries({ queryKey: eventKeys.upcoming() });\n      queryClient.invalidateQueries({ queryKey: eventKeys.featured() });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Cancel an event\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = useCancelEvent();\n *\n * mutate('event-123');\n * ```\n */\nexport function useCancelEvent(\n  options?: Omit<UseMutationOptions<EventResponse, Error, string>, 'mutationFn'>\n): UseMutationResult<EventResponse, Error, string> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (id: string): Promise<EventResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/events/${id}/cancel`);\n      return response.data;\n    },\n    onSuccess: (cancelledEvent, eventId, context) => {\n      // Update the specific event in cache\n      queryClient.setQueryData(\n        eventKeys.detail(eventId),\n        cancelledEvent\n      );\n\n      // If the event has a slug, update the slug-based query too\n      if (cancelledEvent.slug && typeof cancelledEvent.slug === 'string') {\n        queryClient.setQueryData(\n          eventKeys.detailBySlug(cancelledEvent.slug),\n          cancelledEvent\n        );\n      }\n\n      // Invalidate lists to reflect the cancelled status\n      queryClient.invalidateQueries({ queryKey: eventKeys.lists() });\n      queryClient.invalidateQueries({ queryKey: eventKeys.upcoming() });\n      queryClient.invalidateQueries({ queryKey: eventKeys.featured() });\n\n      // Invalidate bookings for this event\n      queryClient.invalidateQueries({ queryKey: eventKeys.bookings(eventId) });\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n\n/**\n * Publish an event\n *\n * Note: This mutation is provided for future compatibility.\n * The API endpoint exists but may require specific permissions.\n *\n * @param options - TanStack Query mutation options\n *\n * @example\n * ```tsx\n * const { mutate, isPending } = usePublishEvent();\n *\n * mutate('event-123');\n * ```\n */\nexport function usePublishEvent(\n  options?: Omit<UseMutationOptions<EventResponse, Error, string>, 'mutationFn'>\n): UseMutationResult<EventResponse, Error, string> {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (id: string): Promise<EventResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/events/${id}/publish`);\n      return response.data;\n    },\n    onSuccess: (publishedEvent, eventId, context) => {\n      // Update the specific event in cache\n      queryClient.setQueryData(\n        eventKeys.detail(eventId),\n        publishedEvent\n      );\n\n      // If the event has a slug, update the slug-based query too\n      if (publishedEvent.slug && typeof publishedEvent.slug === 'string') {\n        queryClient.setQueryData(\n          eventKeys.detailBySlug(publishedEvent.slug),\n          publishedEvent\n        );\n      }\n\n      // Invalidate lists to reflect the published status\n      queryClient.invalidateQueries({ queryKey: eventKeys.lists() });\n      queryClient.invalidateQueries({ queryKey: eventKeys.upcoming() });\n\n      // If the event is featured, invalidate featured events\n      if (publishedEvent.isFeatured) {\n        queryClient.invalidateQueries({ queryKey: eventKeys.featured() });\n      }\n\n      // Call user's onSuccess if provided\n    },\n    ...options,\n  });\n}\n"]}
@@ -0,0 +1,36 @@
1
+ import { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
2
+ import type { Grow90EnrollmentResponse, Grow90ProgressResponse, EnrollGrow90Request, UpdateGrow90ProgressRequest, UpdateGrow90SettingsRequest } from '../types';
3
+ /**
4
+ * Enroll in GROW90 program
5
+ */
6
+ export declare function useEnrollGrow90(options?: Omit<UseMutationOptions<Grow90EnrollmentResponse, Error, EnrollGrow90Request>, 'mutationFn'>): UseMutationResult<Grow90EnrollmentResponse, Error, EnrollGrow90Request>;
7
+ /**
8
+ * Update progress for a specific day
9
+ */
10
+ export declare function useUpdateGrow90Progress(options?: Omit<UseMutationOptions<Grow90ProgressResponse, Error, {
11
+ day: number;
12
+ data: UpdateGrow90ProgressRequest;
13
+ }>, 'mutationFn'>): UseMutationResult<Grow90ProgressResponse, Error, {
14
+ day: number;
15
+ data: UpdateGrow90ProgressRequest;
16
+ }>;
17
+ /**
18
+ * Update GROW90 settings
19
+ */
20
+ export declare function useUpdateGrow90Settings(options?: Omit<UseMutationOptions<Grow90EnrollmentResponse, Error, UpdateGrow90SettingsRequest>, 'mutationFn'>): UseMutationResult<Grow90EnrollmentResponse, Error, UpdateGrow90SettingsRequest>;
21
+ /**
22
+ * Pause GROW90 program
23
+ */
24
+ export declare function usePauseGrow90(options?: Omit<UseMutationOptions<Grow90EnrollmentResponse, Error, void>, 'mutationFn'>): UseMutationResult<Grow90EnrollmentResponse, Error, void>;
25
+ /**
26
+ * Resume GROW90 program
27
+ */
28
+ export declare function useResumeGrow90(options?: Omit<UseMutationOptions<Grow90EnrollmentResponse, Error, void>, 'mutationFn'>): UseMutationResult<Grow90EnrollmentResponse, Error, void>;
29
+ /**
30
+ * Abandon GROW90 program
31
+ */
32
+ export declare function useAbandonGrow90(options?: Omit<UseMutationOptions<{
33
+ success: boolean;
34
+ }, Error, void>, 'mutationFn'>): UseMutationResult<{
35
+ success: boolean;
36
+ }, Error, void>;