@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.
- package/README.md +276 -0
- package/dist/__tests__/e2e.test.d.ts +7 -0
- package/dist/__tests__/e2e.test.js +472 -0
- package/dist/api/client.d.ts +11 -0
- package/dist/api/client.js +61 -0
- package/dist/api/mutations/admin.d.ts +167 -0
- package/dist/api/mutations/admin.js +326 -0
- package/dist/api/mutations/ambassadors.d.ts +52 -0
- package/dist/api/mutations/ambassadors.js +148 -0
- package/dist/api/mutations/auth.d.ts +267 -0
- package/dist/api/mutations/auth.js +332 -0
- package/dist/api/mutations/bookings.d.ts +59 -0
- package/dist/api/mutations/bookings.js +143 -0
- package/dist/api/mutations/event-chat.d.ts +35 -0
- package/dist/api/mutations/event-chat.js +147 -0
- package/dist/api/mutations/events.d.ts +87 -0
- package/dist/api/mutations/events.js +205 -0
- package/dist/api/mutations/grow90.d.ts +36 -0
- package/dist/api/mutations/grow90.js +132 -0
- package/dist/api/mutations/hubs.d.ts +111 -0
- package/dist/api/mutations/hubs.js +240 -0
- package/dist/api/mutations/index.d.ts +22 -0
- package/dist/api/mutations/index.js +39 -0
- package/dist/api/mutations/jack.d.ts +61 -0
- package/dist/api/mutations/jack.js +104 -0
- package/dist/api/mutations/library.d.ts +67 -0
- package/dist/api/mutations/library.js +168 -0
- package/dist/api/mutations/map.d.ts +153 -0
- package/dist/api/mutations/map.js +181 -0
- package/dist/api/mutations/matching.d.ts +130 -0
- package/dist/api/mutations/matching.js +204 -0
- package/dist/api/mutations/notifications.d.ts +63 -0
- package/dist/api/mutations/notifications.js +106 -0
- package/dist/api/mutations/offers.d.ts +26 -0
- package/dist/api/mutations/offers.js +47 -0
- package/dist/api/mutations/subscriptions.d.ts +127 -0
- package/dist/api/mutations/subscriptions.js +140 -0
- package/dist/api/mutations/support.d.ts +165 -0
- package/dist/api/mutations/support.js +307 -0
- package/dist/api/mutations/users.d.ts +211 -0
- package/dist/api/mutations/users.js +261 -0
- package/dist/api/queries/admin.d.ts +257 -0
- package/dist/api/queries/admin.js +320 -0
- package/dist/api/queries/ambassadors.d.ts +53 -0
- package/dist/api/queries/ambassadors.js +98 -0
- package/dist/api/queries/auth.d.ts +16 -0
- package/dist/api/queries/auth.js +25 -0
- package/dist/api/queries/bookings.d.ts +91 -0
- package/dist/api/queries/bookings.js +102 -0
- package/dist/api/queries/businesses.d.ts +212 -0
- package/dist/api/queries/businesses.js +154 -0
- package/dist/api/queries/event-chat.d.ts +19 -0
- package/dist/api/queries/event-chat.js +75 -0
- package/dist/api/queries/events.d.ts +322 -0
- package/dist/api/queries/events.js +221 -0
- package/dist/api/queries/grow90.d.ts +26 -0
- package/dist/api/queries/grow90.js +85 -0
- package/dist/api/queries/hubs.d.ts +165 -0
- package/dist/api/queries/hubs.js +143 -0
- package/dist/api/queries/index.d.ts +23 -0
- package/dist/api/queries/index.js +40 -0
- package/dist/api/queries/jack.d.ts +63 -0
- package/dist/api/queries/jack.js +92 -0
- package/dist/api/queries/library.d.ts +132 -0
- package/dist/api/queries/library.js +120 -0
- package/dist/api/queries/map.d.ts +216 -0
- package/dist/api/queries/map.js +278 -0
- package/dist/api/queries/matching.d.ts +136 -0
- package/dist/api/queries/matching.js +161 -0
- package/dist/api/queries/notifications.d.ts +78 -0
- package/dist/api/queries/notifications.js +88 -0
- package/dist/api/queries/offers.d.ts +91 -0
- package/dist/api/queries/offers.js +103 -0
- package/dist/api/queries/subscriptions.d.ts +56 -0
- package/dist/api/queries/subscriptions.js +73 -0
- package/dist/api/queries/support.d.ts +106 -0
- package/dist/api/queries/support.js +202 -0
- package/dist/api/queries/users.d.ts +293 -0
- package/dist/api/queries/users.js +370 -0
- package/dist/api/types.d.ts +464 -0
- package/dist/api/types.js +9 -0
- package/dist/hooks/useAuth.d.ts +5 -0
- package/dist/hooks/useAuth.js +39 -0
- package/dist/hooks/useUser.d.ts +43 -0
- package/dist/hooks/useUser.js +44 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.js +67 -0
- package/package.json +62 -0
- package/src/__tests__/e2e.test.ts +502 -0
- package/src/api/client.ts +71 -0
- package/src/api/mutations/admin.ts +531 -0
- package/src/api/mutations/ambassadors.ts +185 -0
- package/src/api/mutations/auth.ts +350 -0
- package/src/api/mutations/bookings.ts +190 -0
- package/src/api/mutations/event-chat.ts +177 -0
- package/src/api/mutations/events.ts +273 -0
- package/src/api/mutations/grow90.ts +169 -0
- package/src/api/mutations/hubs.ts +385 -0
- package/src/api/mutations/index.ts +23 -0
- package/src/api/mutations/jack.ts +130 -0
- package/src/api/mutations/library.ts +212 -0
- package/src/api/mutations/map.ts +230 -0
- package/src/api/mutations/matching.ts +271 -0
- package/src/api/mutations/notifications.ts +114 -0
- package/src/api/mutations/offers.ts +73 -0
- package/src/api/mutations/subscriptions.ts +162 -0
- package/src/api/mutations/support.ts +390 -0
- package/src/api/mutations/users.ts +271 -0
- package/src/api/queries/admin.ts +480 -0
- package/src/api/queries/ambassadors.ts +139 -0
- package/src/api/queries/auth.ts +24 -0
- package/src/api/queries/bookings.ts +135 -0
- package/src/api/queries/businesses.ts +203 -0
- package/src/api/queries/event-chat.ts +78 -0
- package/src/api/queries/events.ts +272 -0
- package/src/api/queries/grow90.ts +98 -0
- package/src/api/queries/hubs.ts +211 -0
- package/src/api/queries/index.ts +24 -0
- package/src/api/queries/jack.ts +127 -0
- package/src/api/queries/library.ts +166 -0
- package/src/api/queries/map.ts +331 -0
- package/src/api/queries/matching.ts +238 -0
- package/src/api/queries/notifications.ts +103 -0
- package/src/api/queries/offers.ts +136 -0
- package/src/api/queries/subscriptions.ts +91 -0
- package/src/api/queries/support.ts +235 -0
- package/src/api/queries/users.ts +393 -0
- package/src/api/types.ts +596 -0
- 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":";;AAoBA,sDAgBC;AASD,4CAgBC;AAKD,8CAaC;AAKD,0DAgBC;AAKD,sDAOC;AASD,0DAiBC;AAKD,8DAgBC;AAKD,8DAYC;AAhLD,uDAAoE;AACpE,sCAAyC;AACzC,sDAAsD;AAWtD,+EAA+E;AAC/E,kBAAkB;AAClB,+EAA+E;AAE/E;;GAEG;AACH,SAAgB,qBAAqB,CAAC,OAAe;IACnD,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,IAA+B,EAAE,EAAE;YACpD,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,WAAW,OAAO,gBAAgB,EAClC,IAAI,CACL,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,GAAG,EAAE;YACd,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,0BAAa,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC3E,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED,+EAA+E;AAC/E,oBAAoB;AACpB,+EAA+E;AAE/E;;GAEG;AACH,SAAgB,gBAAgB,CAAC,OAAe;IAC9C,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,IAAI,EAAE;YACrB,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAChC,WAAW,OAAO,YAAY,CAC/B,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,GAAG,EAAE;YACd,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,0BAAa,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YACzE,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,0BAAa,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC9E,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;GAEG;AACH,SAAgB,iBAAiB,CAAC,OAAe;IAC/C,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,IAAI,EAAE;YACrB,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,MAAM,CAAC,IAAI,CAAC,WAAW,OAAO,aAAa,CAAC,CAAC;QACrD,CAAC;QACD,SAAS,EAAE,GAAG,EAAE;YACd,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,0BAAa,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YACzE,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,0BAAa,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC9E,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;GAEG;AACH,SAAgB,uBAAuB,CAAC,OAAe;IACrD,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,IAAiC,EAAE,EAAE;YACtD,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,WAAW,OAAO,mBAAmB,EACrC,IAAI,CACL,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,GAAG,EAAE;YACd,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,0BAAa,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC9E,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;GAEG;AACH,SAAgB,qBAAqB,CAAC,OAAe;IACnD,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,IAAI,EAAE;YACrB,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,MAAM,CAAC,IAAI,CAAC,WAAW,OAAO,YAAY,CAAC,CAAC;QACpD,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED,+EAA+E;AAC/E,WAAW;AACX,+EAA+E;AAE/E;;GAEG;AACH,SAAgB,uBAAuB,CAAC,OAAe;IACrD,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,IAAwB,EAAE,EAAE;YAC7C,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAChC,WAAW,OAAO,gBAAgB,EAClC,IAAI,CACL,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,GAAG,EAAE;YACd,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,0BAAa,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YAC7E,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,0BAAa,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC3E,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;GAEG;AACH,SAAgB,yBAAyB,CAAC,OAAe;IACvD,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EAAE,SAAS,EAAE,OAAO,EAAgD,EAAE,EAAE;YACzF,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,WAAW,OAAO,kBAAkB,SAAS,EAAE,EAC/C,EAAE,OAAO,EAAE,CACZ,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,GAAG,EAAE;YACd,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,0BAAa,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC/E,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;GAEG;AACH,SAAgB,yBAAyB,CAAC,OAAe;IACvD,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,SAAiB,EAAE,EAAE;YACtC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,MAAM,CAAC,MAAM,CAAC,WAAW,OAAO,kBAAkB,SAAS,EAAE,CAAC,CAAC;QACvE,CAAC;QACD,SAAS,EAAE,GAAG,EAAE;YACd,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,0BAAa,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC/E,CAAC;KACF,CAAC,CAAC;AACL,CAAC","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>;
|