@growsober/sdk 1.0.17 → 1.0.19
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/CLAUDE.md +11 -0
- package/dist/api/mutations/CLAUDE.md +12 -0
- package/dist/api/mutations/creator-community.d.ts +56 -0
- package/dist/api/mutations/creator-community.js +181 -0
- package/dist/api/mutations/creators.d.ts +30 -20
- package/dist/api/mutations/index.d.ts +1 -0
- package/dist/api/mutations/index.js +2 -1
- package/dist/api/mutations/products.d.ts +24 -0
- package/dist/api/mutations/products.js +28 -1
- package/dist/api/queries/creator-community.d.ts +83 -0
- package/dist/api/queries/creator-community.js +77 -0
- package/dist/api/queries/creators.d.ts +21 -17
- package/dist/api/queries/creators.js +6 -5
- package/dist/api/queries/index.d.ts +1 -0
- package/dist/api/queries/index.js +2 -1
- package/package.json +2 -2
- package/src/api/CLAUDE.md +12 -0
- package/src/api/mutations/CLAUDE.md +12 -0
- package/src/api/mutations/creator-community.ts +230 -0
- package/src/api/mutations/index.ts +1 -0
- package/src/api/mutations/products.ts +42 -0
- package/src/api/queries/CLAUDE.md +13 -0
- package/src/api/queries/creator-community.ts +154 -0
- package/src/api/queries/creators.ts +5 -3
- package/src/api/queries/index.ts +1 -0
package/dist/CLAUDE.md
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
<claude-mem-context>
|
|
2
|
+
# Recent Activity
|
|
3
|
+
|
|
4
|
+
<!-- This section is auto-generated by claude-mem. Edit content outside the tags. -->
|
|
5
|
+
|
|
6
|
+
### Jan 25, 2026
|
|
7
|
+
|
|
8
|
+
| ID | Time | T | Title | Read |
|
|
9
|
+
|----|------|---|-------|------|
|
|
10
|
+
| #1649 | 10:55 AM | 🔵 | Missing useCreateProductPaymentIntent Export in SDK | ~386 |
|
|
11
|
+
</claude-mem-context>
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
<claude-mem-context>
|
|
2
|
+
# Recent Activity
|
|
3
|
+
|
|
4
|
+
<!-- This section is auto-generated by claude-mem. Edit content outside the tags. -->
|
|
5
|
+
|
|
6
|
+
### Jan 25, 2026
|
|
7
|
+
|
|
8
|
+
| ID | Time | T | Title | Read |
|
|
9
|
+
|----|------|---|-------|------|
|
|
10
|
+
| #1650 | 10:55 AM | 🔵 | Confirmed Payment Intent Hook Exists in SDK | ~243 |
|
|
11
|
+
| #1649 | " | 🔵 | Missing useCreateProductPaymentIntent Export in SDK | ~386 |
|
|
12
|
+
</claude-mem-context>
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { CommunityMemberResponse, CommunityMessageResponse, CreatorCommunityResponse } from '../queries/creator-community';
|
|
2
|
+
/**
|
|
3
|
+
* Update community settings (owner only)
|
|
4
|
+
*/
|
|
5
|
+
export declare function useUpdateCommunitySettings(creatorId: string): import("@tanstack/react-query").UseMutationResult<CreatorCommunityResponse, Error, {
|
|
6
|
+
name?: string;
|
|
7
|
+
description?: string;
|
|
8
|
+
isLocked?: boolean;
|
|
9
|
+
}, unknown>;
|
|
10
|
+
/**
|
|
11
|
+
* Join a creator's community
|
|
12
|
+
*/
|
|
13
|
+
export declare function useJoinCommunity(creatorId: string): import("@tanstack/react-query").UseMutationResult<CommunityMemberResponse, Error, void, unknown>;
|
|
14
|
+
/**
|
|
15
|
+
* Leave a creator's community
|
|
16
|
+
*/
|
|
17
|
+
export declare function useLeaveCommunity(creatorId: string): import("@tanstack/react-query").UseMutationResult<void, Error, void, unknown>;
|
|
18
|
+
/**
|
|
19
|
+
* Invite a user to the community (owner/moderator only)
|
|
20
|
+
*/
|
|
21
|
+
export declare function useInviteToCommunity(creatorId: string): import("@tanstack/react-query").UseMutationResult<CommunityMemberResponse, Error, string, unknown>;
|
|
22
|
+
/**
|
|
23
|
+
* Remove a member from the community (owner/moderator only)
|
|
24
|
+
*/
|
|
25
|
+
export declare function useRemoveCommunityMember(creatorId: string): import("@tanstack/react-query").UseMutationResult<void, Error, string, unknown>;
|
|
26
|
+
/**
|
|
27
|
+
* Update member settings (nickname, mute)
|
|
28
|
+
*/
|
|
29
|
+
export declare function useUpdateCommunityMemberSettings(creatorId: string): import("@tanstack/react-query").UseMutationResult<CommunityMemberResponse, Error, {
|
|
30
|
+
nickname?: string;
|
|
31
|
+
isMuted?: boolean;
|
|
32
|
+
}, unknown>;
|
|
33
|
+
/**
|
|
34
|
+
* Mark messages as read
|
|
35
|
+
*/
|
|
36
|
+
export declare function useMarkCommunityAsRead(creatorId: string): import("@tanstack/react-query").UseMutationResult<void, Error, void, unknown>;
|
|
37
|
+
/**
|
|
38
|
+
* Send a message to the community
|
|
39
|
+
*/
|
|
40
|
+
export declare function useSendCommunityMessage(creatorId: string): import("@tanstack/react-query").UseMutationResult<CommunityMessageResponse, Error, {
|
|
41
|
+
content: string;
|
|
42
|
+
messageType?: "TEXT" | "IMAGE" | "SYSTEM" | "ANNOUNCEMENT";
|
|
43
|
+
imageUrl?: string;
|
|
44
|
+
replyToId?: string;
|
|
45
|
+
}, unknown>;
|
|
46
|
+
/**
|
|
47
|
+
* Update a community message
|
|
48
|
+
*/
|
|
49
|
+
export declare function useUpdateCommunityMessage(creatorId: string): import("@tanstack/react-query").UseMutationResult<CommunityMessageResponse, Error, {
|
|
50
|
+
messageId: string;
|
|
51
|
+
content: string;
|
|
52
|
+
}, unknown>;
|
|
53
|
+
/**
|
|
54
|
+
* Delete a community message
|
|
55
|
+
*/
|
|
56
|
+
export declare function useDeleteCommunityMessage(creatorId: string): import("@tanstack/react-query").UseMutationResult<void, Error, string, unknown>;
|
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useUpdateCommunitySettings = useUpdateCommunitySettings;
|
|
4
|
+
exports.useJoinCommunity = useJoinCommunity;
|
|
5
|
+
exports.useLeaveCommunity = useLeaveCommunity;
|
|
6
|
+
exports.useInviteToCommunity = useInviteToCommunity;
|
|
7
|
+
exports.useRemoveCommunityMember = useRemoveCommunityMember;
|
|
8
|
+
exports.useUpdateCommunityMemberSettings = useUpdateCommunityMemberSettings;
|
|
9
|
+
exports.useMarkCommunityAsRead = useMarkCommunityAsRead;
|
|
10
|
+
exports.useSendCommunityMessage = useSendCommunityMessage;
|
|
11
|
+
exports.useUpdateCommunityMessage = useUpdateCommunityMessage;
|
|
12
|
+
exports.useDeleteCommunityMessage = useDeleteCommunityMessage;
|
|
13
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
14
|
+
const client_1 = require("../client");
|
|
15
|
+
const creator_community_1 = require("../queries/creator-community");
|
|
16
|
+
// ============================================================================
|
|
17
|
+
// COMMUNITY MANAGEMENT
|
|
18
|
+
// ============================================================================
|
|
19
|
+
/**
|
|
20
|
+
* Update community settings (owner only)
|
|
21
|
+
*/
|
|
22
|
+
function useUpdateCommunitySettings(creatorId) {
|
|
23
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
24
|
+
return (0, react_query_1.useMutation)({
|
|
25
|
+
mutationFn: async (data) => {
|
|
26
|
+
const client = (0, client_1.getApiClient)();
|
|
27
|
+
const response = await client.put(`/api/v1/creators/${creatorId}/community/settings`, data);
|
|
28
|
+
return response.data?.data || response.data;
|
|
29
|
+
},
|
|
30
|
+
onSuccess: () => {
|
|
31
|
+
queryClient.invalidateQueries({ queryKey: creator_community_1.communityKeys.detail(creatorId) });
|
|
32
|
+
},
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
// ============================================================================
|
|
36
|
+
// MEMBER MANAGEMENT
|
|
37
|
+
// ============================================================================
|
|
38
|
+
/**
|
|
39
|
+
* Join a creator's community
|
|
40
|
+
*/
|
|
41
|
+
function useJoinCommunity(creatorId) {
|
|
42
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
43
|
+
return (0, react_query_1.useMutation)({
|
|
44
|
+
mutationFn: async () => {
|
|
45
|
+
const client = (0, client_1.getApiClient)();
|
|
46
|
+
const response = await client.post(`/api/v1/creators/${creatorId}/community/join`);
|
|
47
|
+
return response.data?.data || response.data;
|
|
48
|
+
},
|
|
49
|
+
onSuccess: () => {
|
|
50
|
+
queryClient.invalidateQueries({ queryKey: creator_community_1.communityKeys.detail(creatorId) });
|
|
51
|
+
queryClient.invalidateQueries({ queryKey: creator_community_1.communityKeys.members(creatorId) });
|
|
52
|
+
},
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Leave a creator's community
|
|
57
|
+
*/
|
|
58
|
+
function useLeaveCommunity(creatorId) {
|
|
59
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
60
|
+
return (0, react_query_1.useMutation)({
|
|
61
|
+
mutationFn: async () => {
|
|
62
|
+
const client = (0, client_1.getApiClient)();
|
|
63
|
+
await client.post(`/api/v1/creators/${creatorId}/community/leave`);
|
|
64
|
+
},
|
|
65
|
+
onSuccess: () => {
|
|
66
|
+
queryClient.invalidateQueries({ queryKey: creator_community_1.communityKeys.detail(creatorId) });
|
|
67
|
+
queryClient.invalidateQueries({ queryKey: creator_community_1.communityKeys.members(creatorId) });
|
|
68
|
+
},
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Invite a user to the community (owner/moderator only)
|
|
73
|
+
*/
|
|
74
|
+
function useInviteToCommunity(creatorId) {
|
|
75
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
76
|
+
return (0, react_query_1.useMutation)({
|
|
77
|
+
mutationFn: async (userId) => {
|
|
78
|
+
const client = (0, client_1.getApiClient)();
|
|
79
|
+
const response = await client.post(`/api/v1/creators/${creatorId}/community/invite`, { userId });
|
|
80
|
+
return response.data?.data || response.data;
|
|
81
|
+
},
|
|
82
|
+
onSuccess: () => {
|
|
83
|
+
queryClient.invalidateQueries({ queryKey: creator_community_1.communityKeys.members(creatorId) });
|
|
84
|
+
},
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Remove a member from the community (owner/moderator only)
|
|
89
|
+
*/
|
|
90
|
+
function useRemoveCommunityMember(creatorId) {
|
|
91
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
92
|
+
return (0, react_query_1.useMutation)({
|
|
93
|
+
mutationFn: async (userId) => {
|
|
94
|
+
const client = (0, client_1.getApiClient)();
|
|
95
|
+
await client.delete(`/api/v1/creators/${creatorId}/community/members/${userId}`);
|
|
96
|
+
},
|
|
97
|
+
onSuccess: () => {
|
|
98
|
+
queryClient.invalidateQueries({ queryKey: creator_community_1.communityKeys.members(creatorId) });
|
|
99
|
+
queryClient.invalidateQueries({ queryKey: creator_community_1.communityKeys.detail(creatorId) });
|
|
100
|
+
},
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Update member settings (nickname, mute)
|
|
105
|
+
*/
|
|
106
|
+
function useUpdateCommunityMemberSettings(creatorId) {
|
|
107
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
108
|
+
return (0, react_query_1.useMutation)({
|
|
109
|
+
mutationFn: async (data) => {
|
|
110
|
+
const client = (0, client_1.getApiClient)();
|
|
111
|
+
const response = await client.put(`/api/v1/creators/${creatorId}/community/settings/me`, data);
|
|
112
|
+
return response.data?.data || response.data;
|
|
113
|
+
},
|
|
114
|
+
onSuccess: () => {
|
|
115
|
+
queryClient.invalidateQueries({ queryKey: creator_community_1.communityKeys.members(creatorId) });
|
|
116
|
+
},
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* Mark messages as read
|
|
121
|
+
*/
|
|
122
|
+
function useMarkCommunityAsRead(creatorId) {
|
|
123
|
+
return (0, react_query_1.useMutation)({
|
|
124
|
+
mutationFn: async () => {
|
|
125
|
+
const client = (0, client_1.getApiClient)();
|
|
126
|
+
await client.post(`/api/v1/creators/${creatorId}/community/read`);
|
|
127
|
+
},
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
// ============================================================================
|
|
131
|
+
// MESSAGES
|
|
132
|
+
// ============================================================================
|
|
133
|
+
/**
|
|
134
|
+
* Send a message to the community
|
|
135
|
+
*/
|
|
136
|
+
function useSendCommunityMessage(creatorId) {
|
|
137
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
138
|
+
return (0, react_query_1.useMutation)({
|
|
139
|
+
mutationFn: async (data) => {
|
|
140
|
+
const client = (0, client_1.getApiClient)();
|
|
141
|
+
const response = await client.post(`/api/v1/creators/${creatorId}/community/messages`, data);
|
|
142
|
+
return response.data?.data || response.data;
|
|
143
|
+
},
|
|
144
|
+
onSuccess: () => {
|
|
145
|
+
queryClient.invalidateQueries({ queryKey: creator_community_1.communityKeys.messages(creatorId) });
|
|
146
|
+
queryClient.invalidateQueries({ queryKey: creator_community_1.communityKeys.detail(creatorId) });
|
|
147
|
+
},
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
/**
|
|
151
|
+
* Update a community message
|
|
152
|
+
*/
|
|
153
|
+
function useUpdateCommunityMessage(creatorId) {
|
|
154
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
155
|
+
return (0, react_query_1.useMutation)({
|
|
156
|
+
mutationFn: async ({ messageId, content, }) => {
|
|
157
|
+
const client = (0, client_1.getApiClient)();
|
|
158
|
+
const response = await client.put(`/api/v1/creators/${creatorId}/community/messages/${messageId}`, { content });
|
|
159
|
+
return response.data?.data || response.data;
|
|
160
|
+
},
|
|
161
|
+
onSuccess: () => {
|
|
162
|
+
queryClient.invalidateQueries({ queryKey: creator_community_1.communityKeys.messages(creatorId) });
|
|
163
|
+
},
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
/**
|
|
167
|
+
* Delete a community message
|
|
168
|
+
*/
|
|
169
|
+
function useDeleteCommunityMessage(creatorId) {
|
|
170
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
171
|
+
return (0, react_query_1.useMutation)({
|
|
172
|
+
mutationFn: async (messageId) => {
|
|
173
|
+
const client = (0, client_1.getApiClient)();
|
|
174
|
+
await client.delete(`/api/v1/creators/${creatorId}/community/messages/${messageId}`);
|
|
175
|
+
},
|
|
176
|
+
onSuccess: () => {
|
|
177
|
+
queryClient.invalidateQueries({ queryKey: creator_community_1.communityKeys.messages(creatorId) });
|
|
178
|
+
},
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"creator-community.js","sourceRoot":"","sources":["../../../src/api/mutations/creator-community.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport {\n  communityKeys,\n  CommunityMemberResponse,\n  CommunityMessageResponse,\n  CreatorCommunityResponse,\n} from '../queries/creator-community';\n\n// ============================================================================\n// COMMUNITY MANAGEMENT\n// ============================================================================\n\n/**\n * Update community settings (owner only)\n */\nexport function useUpdateCommunitySettings(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: {\n      name?: string;\n      description?: string;\n      isLocked?: boolean;\n    }): Promise<CreatorCommunityResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/creators/${creatorId}/community/settings`,\n        data\n      );\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: communityKeys.detail(creatorId) });\n    },\n  });\n}\n\n// ============================================================================\n// MEMBER MANAGEMENT\n// ============================================================================\n\n/**\n * Join a creator's community\n */\nexport function useJoinCommunity(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (): Promise<CommunityMemberResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/community/join`);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: communityKeys.detail(creatorId) });\n      queryClient.invalidateQueries({ queryKey: communityKeys.members(creatorId) });\n    },\n  });\n}\n\n/**\n * Leave a creator's community\n */\nexport function useLeaveCommunity(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (): Promise<void> => {\n      const client = getApiClient();\n      await client.post(`/api/v1/creators/${creatorId}/community/leave`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: communityKeys.detail(creatorId) });\n      queryClient.invalidateQueries({ queryKey: communityKeys.members(creatorId) });\n    },\n  });\n}\n\n/**\n * Invite a user to the community (owner/moderator only)\n */\nexport function useInviteToCommunity(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (userId: string): Promise<CommunityMemberResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/creators/${creatorId}/community/invite`,\n        { userId }\n      );\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: communityKeys.members(creatorId) });\n    },\n  });\n}\n\n/**\n * Remove a member from the community (owner/moderator only)\n */\nexport function useRemoveCommunityMember(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (userId: string): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/creators/${creatorId}/community/members/${userId}`);\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: communityKeys.members(creatorId) });\n      queryClient.invalidateQueries({ queryKey: communityKeys.detail(creatorId) });\n    },\n  });\n}\n\n/**\n * Update member settings (nickname, mute)\n */\nexport function useUpdateCommunityMemberSettings(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: {\n      nickname?: string;\n      isMuted?: boolean;\n    }): Promise<CommunityMemberResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/creators/${creatorId}/community/settings/me`,\n        data\n      );\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: communityKeys.members(creatorId) });\n    },\n  });\n}\n\n/**\n * Mark messages as read\n */\nexport function useMarkCommunityAsRead(creatorId: string) {\n  return useMutation({\n    mutationFn: async (): Promise<void> => {\n      const client = getApiClient();\n      await client.post(`/api/v1/creators/${creatorId}/community/read`);\n    },\n  });\n}\n\n// ============================================================================\n// MESSAGES\n// ============================================================================\n\n/**\n * Send a message to the community\n */\nexport function useSendCommunityMessage(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: {\n      content: string;\n      messageType?: 'TEXT' | 'IMAGE' | 'SYSTEM' | 'ANNOUNCEMENT';\n      imageUrl?: string;\n      replyToId?: string;\n    }): Promise<CommunityMessageResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/creators/${creatorId}/community/messages`,\n        data\n      );\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: communityKeys.messages(creatorId) });\n      queryClient.invalidateQueries({ queryKey: communityKeys.detail(creatorId) });\n    },\n  });\n}\n\n/**\n * Update a community message\n */\nexport function useUpdateCommunityMessage(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      messageId,\n      content,\n    }: {\n      messageId: string;\n      content: string;\n    }): Promise<CommunityMessageResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/creators/${creatorId}/community/messages/${messageId}`,\n        { content }\n      );\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: communityKeys.messages(creatorId) });\n    },\n  });\n}\n\n/**\n * Delete a community message\n */\nexport function useDeleteCommunityMessage(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (messageId: string): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(\n        `/api/v1/creators/${creatorId}/community/messages/${messageId}`\n      );\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: communityKeys.messages(creatorId) });\n    },\n  });\n}\n"]}
|
|
@@ -20,8 +20,8 @@ export declare function useCreateCreator(options?: Omit<UseMutationOptions<Creat
|
|
|
20
20
|
userId: string;
|
|
21
21
|
slug: string;
|
|
22
22
|
displayName: string;
|
|
23
|
-
bio?:
|
|
24
|
-
avatarUrl?:
|
|
23
|
+
bio?: string | null;
|
|
24
|
+
avatarUrl?: string | null;
|
|
25
25
|
cityIds: string[];
|
|
26
26
|
canFacilitate: boolean;
|
|
27
27
|
canCreateContent: boolean;
|
|
@@ -56,8 +56,8 @@ export declare function useUpdateCreator(options?: Omit<UseMutationOptions<Creat
|
|
|
56
56
|
userId: string;
|
|
57
57
|
slug: string;
|
|
58
58
|
displayName: string;
|
|
59
|
-
bio?:
|
|
60
|
-
avatarUrl?:
|
|
59
|
+
bio?: string | null;
|
|
60
|
+
avatarUrl?: string | null;
|
|
61
61
|
cityIds: string[];
|
|
62
62
|
canFacilitate: boolean;
|
|
63
63
|
canCreateContent: boolean;
|
|
@@ -229,16 +229,18 @@ export declare function useCreateGatheringType(creatorId: string): import("@tans
|
|
|
229
229
|
id: string;
|
|
230
230
|
creatorId: string;
|
|
231
231
|
name: string;
|
|
232
|
-
description?:
|
|
232
|
+
description?: string | null;
|
|
233
233
|
duration: number;
|
|
234
234
|
vibes: string[];
|
|
235
235
|
category?: "WALK" | "COFFEE" | "MOVEMENT" | "CONVERSATION" | "CREATIVE" | "COWORKING" | null;
|
|
236
|
-
|
|
236
|
+
timeOfDay?: string | null;
|
|
237
|
+
venueType?: string | null;
|
|
238
|
+
suggestedPrice?: number | null;
|
|
237
239
|
currency: string;
|
|
238
240
|
isAiGenerated: boolean;
|
|
239
241
|
isApproved: boolean;
|
|
240
|
-
aiPromptContext?:
|
|
241
|
-
defaultVenueId?:
|
|
242
|
+
aiPromptContext?: string | null;
|
|
243
|
+
defaultVenueId?: string | null;
|
|
242
244
|
defaultVenue?: Record<string, never> | null;
|
|
243
245
|
createdAt: string;
|
|
244
246
|
updatedAt: string;
|
|
@@ -248,6 +250,8 @@ export declare function useCreateGatheringType(creatorId: string): import("@tans
|
|
|
248
250
|
duration: number;
|
|
249
251
|
vibes?: string[];
|
|
250
252
|
category?: "WALK" | "COFFEE" | "MOVEMENT" | "CONVERSATION" | "CREATIVE" | "COWORKING";
|
|
253
|
+
timeOfDay?: string;
|
|
254
|
+
venueType?: string;
|
|
251
255
|
suggestedPrice?: number;
|
|
252
256
|
currency: string;
|
|
253
257
|
defaultVenueId?: string;
|
|
@@ -271,16 +275,18 @@ export declare function useUpdateGatheringType(creatorId: string): import("@tans
|
|
|
271
275
|
id: string;
|
|
272
276
|
creatorId: string;
|
|
273
277
|
name: string;
|
|
274
|
-
description?:
|
|
278
|
+
description?: string | null;
|
|
275
279
|
duration: number;
|
|
276
280
|
vibes: string[];
|
|
277
281
|
category?: "WALK" | "COFFEE" | "MOVEMENT" | "CONVERSATION" | "CREATIVE" | "COWORKING" | null;
|
|
278
|
-
|
|
282
|
+
timeOfDay?: string | null;
|
|
283
|
+
venueType?: string | null;
|
|
284
|
+
suggestedPrice?: number | null;
|
|
279
285
|
currency: string;
|
|
280
286
|
isAiGenerated: boolean;
|
|
281
287
|
isApproved: boolean;
|
|
282
|
-
aiPromptContext?:
|
|
283
|
-
defaultVenueId?:
|
|
288
|
+
aiPromptContext?: string | null;
|
|
289
|
+
defaultVenueId?: string | null;
|
|
284
290
|
defaultVenue?: Record<string, never> | null;
|
|
285
291
|
createdAt: string;
|
|
286
292
|
updatedAt: string;
|
|
@@ -304,16 +310,18 @@ export declare function useApproveGatheringType(creatorId: string): import("@tan
|
|
|
304
310
|
id: string;
|
|
305
311
|
creatorId: string;
|
|
306
312
|
name: string;
|
|
307
|
-
description?:
|
|
313
|
+
description?: string | null;
|
|
308
314
|
duration: number;
|
|
309
315
|
vibes: string[];
|
|
310
316
|
category?: "WALK" | "COFFEE" | "MOVEMENT" | "CONVERSATION" | "CREATIVE" | "COWORKING" | null;
|
|
311
|
-
|
|
317
|
+
timeOfDay?: string | null;
|
|
318
|
+
venueType?: string | null;
|
|
319
|
+
suggestedPrice?: number | null;
|
|
312
320
|
currency: string;
|
|
313
321
|
isAiGenerated: boolean;
|
|
314
322
|
isApproved: boolean;
|
|
315
|
-
aiPromptContext?:
|
|
316
|
-
defaultVenueId?:
|
|
323
|
+
aiPromptContext?: string | null;
|
|
324
|
+
defaultVenueId?: string | null;
|
|
317
325
|
defaultVenue?: Record<string, never> | null;
|
|
318
326
|
createdAt: string;
|
|
319
327
|
updatedAt: string;
|
|
@@ -348,16 +356,18 @@ export declare function useGenerateGatheringTypeSuggestions(creatorId: string):
|
|
|
348
356
|
id: string;
|
|
349
357
|
creatorId: string;
|
|
350
358
|
name: string;
|
|
351
|
-
description?:
|
|
359
|
+
description?: string | null;
|
|
352
360
|
duration: number;
|
|
353
361
|
vibes: string[];
|
|
354
362
|
category?: "WALK" | "COFFEE" | "MOVEMENT" | "CONVERSATION" | "CREATIVE" | "COWORKING" | null;
|
|
355
|
-
|
|
363
|
+
timeOfDay?: string | null;
|
|
364
|
+
venueType?: string | null;
|
|
365
|
+
suggestedPrice?: number | null;
|
|
356
366
|
currency: string;
|
|
357
367
|
isAiGenerated: boolean;
|
|
358
368
|
isApproved: boolean;
|
|
359
|
-
aiPromptContext?:
|
|
360
|
-
defaultVenueId?:
|
|
369
|
+
aiPromptContext?: string | null;
|
|
370
|
+
defaultVenueId?: string | null;
|
|
361
371
|
defaultVenue?: Record<string, never> | null;
|
|
362
372
|
createdAt: string;
|
|
363
373
|
updatedAt: string;
|
|
@@ -43,4 +43,5 @@ __exportStar(require("./brands"), exports);
|
|
|
43
43
|
__exportStar(require("./products"), exports);
|
|
44
44
|
__exportStar(require("./venues"), exports);
|
|
45
45
|
__exportStar(require("./stripe-connect"), exports);
|
|
46
|
-
|
|
46
|
+
__exportStar(require("./creator-community"), exports);
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL211dGF0aW9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7R0FJRzs7Ozs7Ozs7Ozs7Ozs7OztBQUVILDBDQUF3QjtBQUN4Qix5Q0FBdUI7QUFDdkIsNkNBQTJCO0FBQzNCLDJDQUF5QjtBQUN6Qix5Q0FBdUI7QUFDdkIsNENBQTBCO0FBQzFCLHdDQUFzQjtBQUN0QixrREFBZ0M7QUFDaEMsMkNBQXlCO0FBQ3pCLGtEQUFnQztBQUNoQyw0Q0FBMEI7QUFDMUIsMENBQXdCO0FBQ3hCLHlDQUF1QjtBQUN2QixnREFBOEI7QUFDOUIsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQiwrQ0FBNkI7QUFDN0IsOENBQTRCO0FBQzVCLDJDQUF5QjtBQUN6Qiw2Q0FBMkI7QUFDM0IsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQiwyQ0FBeUI7QUFDekIsbURBQWlDO0FBQ2pDLHNEQUFvQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogTXV0YXRpb24gSG9va3NcbiAqXG4gKiBSZS1leHBvcnRzIGFsbCBtdXRhdGlvbiBob29rcyBmb3IgQVBJIGVuZHBvaW50cy5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2FkbWluJztcbmV4cG9ydCAqIGZyb20gJy4vYXV0aCc7XG5leHBvcnQgKiBmcm9tICcuL2Jvb2tpbmdzJztcbmV4cG9ydCAqIGZyb20gJy4vZXZlbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vaHVicyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYnJhcnknO1xuZXhwb3J0ICogZnJvbSAnLi9tYXAnO1xuZXhwb3J0ICogZnJvbSAnLi9ub3RpZmljYXRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vb2ZmZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vc3Vic2NyaXB0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL3N1cHBvcnQnO1xuZXhwb3J0ICogZnJvbSAnLi91c2Vycyc7XG5leHBvcnQgKiBmcm9tICcuL2phY2snO1xuZXhwb3J0ICogZnJvbSAnLi9hbWJhc3NhZG9ycyc7XG5leHBvcnQgKiBmcm9tICcuL2dyb3c5MCc7XG5leHBvcnQgKiBmcm9tICcuL21hdGNoaW5nJztcbmV4cG9ydCAqIGZyb20gJy4vZXZlbnQtY2hhdCc7XG5leHBvcnQgKiBmcm9tICcuL3VzZXItcGlucyc7XG5leHBvcnQgKiBmcm9tICcuL2JhZGdlcyc7XG5leHBvcnQgKiBmcm9tICcuL2NyZWF0b3JzJztcbmV4cG9ydCAqIGZyb20gJy4vYnJhbmRzJztcbmV4cG9ydCAqIGZyb20gJy4vcHJvZHVjdHMnO1xuZXhwb3J0ICogZnJvbSAnLi92ZW51ZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdHJpcGUtY29ubmVjdCc7XG5leHBvcnQgKiBmcm9tICcuL2NyZWF0b3ItY29tbXVuaXR5JztcbiJdfQ==
|
|
@@ -173,3 +173,27 @@ export declare function useCancelProductBooking(): import("@tanstack/react-query
|
|
|
173
173
|
export declare function useCompleteProductBooking(): import("@tanstack/react-query").UseMutationResult<ProductBookingResponse, Error, {
|
|
174
174
|
bookingId: string;
|
|
175
175
|
}, unknown>;
|
|
176
|
+
export interface PaymentIntentResponse {
|
|
177
|
+
clientSecret: string;
|
|
178
|
+
paymentIntentId: string;
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Create a payment intent for a product booking
|
|
182
|
+
* Use this with Stripe Elements to process payment
|
|
183
|
+
*
|
|
184
|
+
* @example
|
|
185
|
+
* ```tsx
|
|
186
|
+
* const { mutate: createPaymentIntent, data, isLoading } = useCreateProductPaymentIntent();
|
|
187
|
+
*
|
|
188
|
+
* // Create payment intent
|
|
189
|
+
* createPaymentIntent({ bookingId: 'booking-123' });
|
|
190
|
+
*
|
|
191
|
+
* // Use clientSecret with Stripe Elements
|
|
192
|
+
* if (data?.clientSecret) {
|
|
193
|
+
* // Pass to Stripe PaymentElement
|
|
194
|
+
* }
|
|
195
|
+
* ```
|
|
196
|
+
*/
|
|
197
|
+
export declare function useCreateProductPaymentIntent(): import("@tanstack/react-query").UseMutationResult<PaymentIntentResponse, Error, {
|
|
198
|
+
bookingId: string;
|
|
199
|
+
}, unknown>;
|
|
@@ -7,6 +7,7 @@ exports.useBookProduct = useBookProduct;
|
|
|
7
7
|
exports.useUpdateProductBooking = useUpdateProductBooking;
|
|
8
8
|
exports.useCancelProductBooking = useCancelProductBooking;
|
|
9
9
|
exports.useCompleteProductBooking = useCompleteProductBooking;
|
|
10
|
+
exports.useCreateProductPaymentIntent = useCreateProductPaymentIntent;
|
|
10
11
|
const react_query_1 = require("@tanstack/react-query");
|
|
11
12
|
const client_1 = require("../client");
|
|
12
13
|
const products_1 = require("../queries/products");
|
|
@@ -223,4 +224,30 @@ function useCompleteProductBooking() {
|
|
|
223
224
|
},
|
|
224
225
|
});
|
|
225
226
|
}
|
|
226
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.js","sourceRoot":"","sources":["../../../src/api/mutations/products.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { productKeys, CreatorProductResponse, ProductBookingResponse, ProductType, DeliveryMethod } from '../queries/products';\nimport { creatorKeys } from '../queries/creators';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface CreateProductRequest {\n  title: string;\n  description?: string;\n  imageUrl?: string;\n  type?: ProductType;\n  price: number;\n  currency?: string;\n  durationMinutes?: number;\n  maxParticipants?: number;\n  deliveryMethod?: DeliveryMethod;\n  locationDetails?: string;\n  slug?: string;\n}\n\nexport interface UpdateProductRequest {\n  title?: string;\n  description?: string;\n  imageUrl?: string;\n  type?: ProductType;\n  price?: number;\n  currency?: string;\n  durationMinutes?: number;\n  maxParticipants?: number;\n  deliveryMethod?: DeliveryMethod;\n  locationDetails?: string;\n  isActive?: boolean;\n  isFeatured?: boolean;\n}\n\nexport interface BookProductRequest {\n  scheduledAt: string;\n  timezone?: string;\n  clientNotes?: string;\n}\n\nexport interface UpdateBookingRequest {\n  scheduledAt?: string;\n  clientNotes?: string;\n  creatorNotes?: string;\n  meetingLink?: string;\n}\n\nexport interface CancelBookingRequest {\n  reason?: string;\n}\n\n// ============================================================================\n// MUTATION HOOKS - PRODUCTS\n// ============================================================================\n\n/**\n * Create a new product for a creator\n *\n * @example\n * ```tsx\n * const { mutate: createProduct, isLoading } = useCreateProduct();\n *\n * createProduct({\n *   creatorId: 'creator-123',\n *   data: {\n *     title: '1-on-1 Coaching Session',\n *     description: 'Personal coaching session',\n *     type: 'SESSION_1ON1',\n *     price: 5000,\n *     durationMinutes: 60,\n *   },\n * });\n * ```\n */\nexport function useCreateProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      data,\n    }: {\n      creatorId: string;\n      data: CreateProductRequest;\n    }): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/products`, data);\n      return response.data;\n    },\n    onSuccess: (_, { creatorId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\n/**\n * Update an existing product\n *\n * @example\n * ```tsx\n * const { mutate: updateProduct, isLoading } = useUpdateProduct();\n *\n * updateProduct({\n *   creatorId: 'creator-123',\n *   productId: 'product-456',\n *   data: {\n *     price: 6000,\n *     isActive: true,\n *   },\n * });\n * ```\n */\nexport function useUpdateProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      productId,\n      data,\n    }: {\n      creatorId: string;\n      productId: string;\n      data: UpdateProductRequest;\n    }): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/creators/${creatorId}/products/${productId}`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: (_, { creatorId, productId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.detail(productId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\n/**\n * Delete a product\n *\n * @example\n * ```tsx\n * const { mutate: deleteProduct, isLoading } = useDeleteProduct();\n *\n * deleteProduct({\n *   creatorId: 'creator-123',\n *   productId: 'product-456',\n * });\n * ```\n */\nexport function useDeleteProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      productId,\n    }: {\n      creatorId: string;\n      productId: string;\n    }): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/creators/${creatorId}/products/${productId}`);\n    },\n    onSuccess: (_, { creatorId, productId }) => {\n      queryClient.removeQueries({ queryKey: productKeys.detail(productId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\n// ============================================================================\n// MUTATION HOOKS - BOOKINGS\n// ============================================================================\n\n/**\n * Book a product/session\n *\n * @example\n * ```tsx\n * const { mutate: bookProduct, isLoading } = useBookProduct();\n *\n * bookProduct({\n *   productId: 'product-123',\n *   data: {\n *     scheduledAt: '2024-03-15T10:00:00Z',\n *     timezone: 'Europe/London',\n *     clientNotes: 'Looking forward to the session!',\n *   },\n * });\n * ```\n */\nexport function useBookProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      productId,\n      data,\n    }: {\n      productId: string;\n      data: BookProductRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/products/${productId}/book`, data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n    },\n  });\n}\n\n/**\n * Update a product booking\n *\n * @example\n * ```tsx\n * const { mutate: updateBooking, isLoading } = useUpdateProductBooking();\n *\n * updateBooking({\n *   bookingId: 'booking-123',\n *   data: {\n *     scheduledAt: '2024-03-16T14:00:00Z',\n *     clientNotes: 'Rescheduled due to conflict',\n *   },\n * });\n * ```\n */\nexport function useUpdateProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n      data,\n    }: {\n      bookingId: string;\n      data: UpdateBookingRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/users/me/product-bookings/${bookingId}`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      // Also invalidate creator bookings as they see this\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\n/**\n * Cancel a product booking\n *\n * @example\n * ```tsx\n * const { mutate: cancelBooking, isLoading } = useCancelProductBooking();\n *\n * cancelBooking({\n *   bookingId: 'booking-123',\n *   data: { reason: 'Schedule conflict' },\n * });\n * ```\n */\nexport function useCancelProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n      data,\n    }: {\n      bookingId: string;\n      data?: CancelBookingRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.delete(\n        `/api/v1/users/me/product-bookings/${bookingId}`,\n        { data }\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\n/**\n * Mark a booking as completed (creator only)\n *\n * @example\n * ```tsx\n * const { mutate: completeBooking, isLoading } = useCompleteProductBooking();\n *\n * completeBooking({ bookingId: 'booking-123' });\n * ```\n */\nexport function useCompleteProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n    }: {\n      bookingId: string;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/users/me/product-bookings/${bookingId}/complete`\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n"]}
|
|
227
|
+
/**
|
|
228
|
+
* Create a payment intent for a product booking
|
|
229
|
+
* Use this with Stripe Elements to process payment
|
|
230
|
+
*
|
|
231
|
+
* @example
|
|
232
|
+
* ```tsx
|
|
233
|
+
* const { mutate: createPaymentIntent, data, isLoading } = useCreateProductPaymentIntent();
|
|
234
|
+
*
|
|
235
|
+
* // Create payment intent
|
|
236
|
+
* createPaymentIntent({ bookingId: 'booking-123' });
|
|
237
|
+
*
|
|
238
|
+
* // Use clientSecret with Stripe Elements
|
|
239
|
+
* if (data?.clientSecret) {
|
|
240
|
+
* // Pass to Stripe PaymentElement
|
|
241
|
+
* }
|
|
242
|
+
* ```
|
|
243
|
+
*/
|
|
244
|
+
function useCreateProductPaymentIntent() {
|
|
245
|
+
return (0, react_query_1.useMutation)({
|
|
246
|
+
mutationFn: async ({ bookingId, }) => {
|
|
247
|
+
const client = (0, client_1.getApiClient)();
|
|
248
|
+
const response = await client.post(`/api/v1/users/me/product-bookings/${bookingId}/payment-intent`);
|
|
249
|
+
return response.data;
|
|
250
|
+
},
|
|
251
|
+
});
|
|
252
|
+
}
|
|
253
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.js","sourceRoot":"","sources":["../../../src/api/mutations/products.ts"],"names":[],"mappings":";;AA8EA,4CAoBC;AAmBD,4CA0BC;AAeD,4CAoBC;AAuBD,wCAmBC;AAkBD,0DAyBC;AAeD,0DAwBC;AAYD,8DAqBC;AA4BD,sEAcC;AAzXD,uDAAoE;AACpE,sCAAyC;AACzC,kDAA+H;AAqD/H,+EAA+E;AAC/E,4BAA4B;AAC5B,+EAA+E;AAE/E;;;;;;;;;;;;;;;;;;GAkBG;AACH,SAAgB,gBAAgB;IAC9B,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,EACT,IAAI,GAIL,EAAmC,EAAE;YACpC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,oBAAoB,SAAS,WAAW,EAAE,IAAI,CAAC,CAAC;YACnF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;YAC9B,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAC9E,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACnE,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,SAAgB,gBAAgB;IAC9B,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,EACT,SAAS,EACT,IAAI,GAKL,EAAmC,EAAE;YACpC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,oBAAoB,SAAS,aAAa,SAAS,EAAE,EACrD,IAAI,CACL,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,EAAE;YACzC,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAC3E,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAC9E,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACnE,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,SAAgB,gBAAgB;IAC9B,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,EACT,SAAS,GAIV,EAAiB,EAAE;YAClB,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,MAAM,CAAC,MAAM,CAAC,oBAAoB,SAAS,aAAa,SAAS,EAAE,CAAC,CAAC;QAC7E,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,EAAE;YACzC,WAAW,CAAC,aAAa,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YACvE,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAC9E,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACnE,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED,+EAA+E;AAC/E,4BAA4B;AAC5B,+EAA+E;AAE/E;;;;;;;;;;;;;;;;GAgBG;AACH,SAAgB,cAAc;IAC5B,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,EACT,IAAI,GAIL,EAAmC,EAAE;YACpC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,oBAAoB,SAAS,OAAO,EAAE,IAAI,CAAC,CAAC;YAC/E,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,GAAG,EAAE;YACd,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;QACxE,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;;;;GAeG;AACH,SAAgB,uBAAuB;IACrC,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,EACT,IAAI,GAIL,EAAmC,EAAE;YACpC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAC/B,qCAAqC,SAAS,EAAE,EAChD,IAAI,CACL,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;YAC9B,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAClF,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;YACtE,oDAAoD;YACpD,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QACtE,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,SAAgB,uBAAuB;IACrC,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,EACT,IAAI,GAIL,EAAmC,EAAE;YACpC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,MAAM,CAClC,qCAAqC,SAAS,EAAE,EAChD,EAAE,IAAI,EAAE,CACT,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;YAC9B,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAClF,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;YACtE,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QACtE,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,yBAAyB;IACvC,MAAM,WAAW,GAAG,IAAA,4BAAc,GAAE,CAAC;IAErC,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,GAGV,EAAmC,EAAE;YACpC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAChC,qCAAqC,SAAS,WAAW,CAC1D,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;QACD,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;YAC9B,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAClF,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;YACtE,WAAW,CAAC,iBAAiB,CAAC,EAAE,QAAQ,EAAE,sBAAW,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QACtE,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAWD;;;;;;;;;;;;;;;;GAgBG;AACH,SAAgB,6BAA6B;IAC3C,OAAO,IAAA,yBAAW,EAAC;QACjB,UAAU,EAAE,KAAK,EAAE,EACjB,SAAS,GAGV,EAAkC,EAAE;YACnC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAChC,qCAAqC,SAAS,iBAAiB,CAChE,CAAC;YACF,OAAO,QAAQ,CAAC,IAAI,CAAC;QACvB,CAAC;KACF,CAAC,CAAC;AACL,CAAC","sourcesContent":["import { useMutation, useQueryClient } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { productKeys, CreatorProductResponse, ProductBookingResponse, ProductType, DeliveryMethod } from '../queries/products';\nimport { creatorKeys } from '../queries/creators';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface CreateProductRequest {\n  title: string;\n  description?: string;\n  imageUrl?: string;\n  type?: ProductType;\n  price: number;\n  currency?: string;\n  durationMinutes?: number;\n  maxParticipants?: number;\n  deliveryMethod?: DeliveryMethod;\n  locationDetails?: string;\n  slug?: string;\n}\n\nexport interface UpdateProductRequest {\n  title?: string;\n  description?: string;\n  imageUrl?: string;\n  type?: ProductType;\n  price?: number;\n  currency?: string;\n  durationMinutes?: number;\n  maxParticipants?: number;\n  deliveryMethod?: DeliveryMethod;\n  locationDetails?: string;\n  isActive?: boolean;\n  isFeatured?: boolean;\n}\n\nexport interface BookProductRequest {\n  scheduledAt: string;\n  timezone?: string;\n  clientNotes?: string;\n}\n\nexport interface UpdateBookingRequest {\n  scheduledAt?: string;\n  clientNotes?: string;\n  creatorNotes?: string;\n  meetingLink?: string;\n}\n\nexport interface CancelBookingRequest {\n  reason?: string;\n}\n\n// ============================================================================\n// MUTATION HOOKS - PRODUCTS\n// ============================================================================\n\n/**\n * Create a new product for a creator\n *\n * @example\n * ```tsx\n * const { mutate: createProduct, isLoading } = useCreateProduct();\n *\n * createProduct({\n *   creatorId: 'creator-123',\n *   data: {\n *     title: '1-on-1 Coaching Session',\n *     description: 'Personal coaching session',\n *     type: 'SESSION_1ON1',\n *     price: 5000,\n *     durationMinutes: 60,\n *   },\n * });\n * ```\n */\nexport function useCreateProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      data,\n    }: {\n      creatorId: string;\n      data: CreateProductRequest;\n    }): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/products`, data);\n      return response.data;\n    },\n    onSuccess: (_, { creatorId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\n/**\n * Update an existing product\n *\n * @example\n * ```tsx\n * const { mutate: updateProduct, isLoading } = useUpdateProduct();\n *\n * updateProduct({\n *   creatorId: 'creator-123',\n *   productId: 'product-456',\n *   data: {\n *     price: 6000,\n *     isActive: true,\n *   },\n * });\n * ```\n */\nexport function useUpdateProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      productId,\n      data,\n    }: {\n      creatorId: string;\n      productId: string;\n      data: UpdateProductRequest;\n    }): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/creators/${creatorId}/products/${productId}`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: (_, { creatorId, productId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.detail(productId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\n/**\n * Delete a product\n *\n * @example\n * ```tsx\n * const { mutate: deleteProduct, isLoading } = useDeleteProduct();\n *\n * deleteProduct({\n *   creatorId: 'creator-123',\n *   productId: 'product-456',\n * });\n * ```\n */\nexport function useDeleteProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      productId,\n    }: {\n      creatorId: string;\n      productId: string;\n    }): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/creators/${creatorId}/products/${productId}`);\n    },\n    onSuccess: (_, { creatorId, productId }) => {\n      queryClient.removeQueries({ queryKey: productKeys.detail(productId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\n// ============================================================================\n// MUTATION HOOKS - BOOKINGS\n// ============================================================================\n\n/**\n * Book a product/session\n *\n * @example\n * ```tsx\n * const { mutate: bookProduct, isLoading } = useBookProduct();\n *\n * bookProduct({\n *   productId: 'product-123',\n *   data: {\n *     scheduledAt: '2024-03-15T10:00:00Z',\n *     timezone: 'Europe/London',\n *     clientNotes: 'Looking forward to the session!',\n *   },\n * });\n * ```\n */\nexport function useBookProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      productId,\n      data,\n    }: {\n      productId: string;\n      data: BookProductRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/products/${productId}/book`, data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n    },\n  });\n}\n\n/**\n * Update a product booking\n *\n * @example\n * ```tsx\n * const { mutate: updateBooking, isLoading } = useUpdateProductBooking();\n *\n * updateBooking({\n *   bookingId: 'booking-123',\n *   data: {\n *     scheduledAt: '2024-03-16T14:00:00Z',\n *     clientNotes: 'Rescheduled due to conflict',\n *   },\n * });\n * ```\n */\nexport function useUpdateProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n      data,\n    }: {\n      bookingId: string;\n      data: UpdateBookingRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/users/me/product-bookings/${bookingId}`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      // Also invalidate creator bookings as they see this\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\n/**\n * Cancel a product booking\n *\n * @example\n * ```tsx\n * const { mutate: cancelBooking, isLoading } = useCancelProductBooking();\n *\n * cancelBooking({\n *   bookingId: 'booking-123',\n *   data: { reason: 'Schedule conflict' },\n * });\n * ```\n */\nexport function useCancelProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n      data,\n    }: {\n      bookingId: string;\n      data?: CancelBookingRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.delete(\n        `/api/v1/users/me/product-bookings/${bookingId}`,\n        { data }\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\n/**\n * Mark a booking as completed (creator only)\n *\n * @example\n * ```tsx\n * const { mutate: completeBooking, isLoading } = useCompleteProductBooking();\n *\n * completeBooking({ bookingId: 'booking-123' });\n * ```\n */\nexport function useCompleteProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n    }: {\n      bookingId: string;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/users/me/product-bookings/${bookingId}/complete`\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\n// ============================================================================\n// MUTATION HOOKS - PAYMENTS\n// ============================================================================\n\nexport interface PaymentIntentResponse {\n  clientSecret: string;\n  paymentIntentId: string;\n}\n\n/**\n * Create a payment intent for a product booking\n * Use this with Stripe Elements to process payment\n *\n * @example\n * ```tsx\n * const { mutate: createPaymentIntent, data, isLoading } = useCreateProductPaymentIntent();\n *\n * // Create payment intent\n * createPaymentIntent({ bookingId: 'booking-123' });\n *\n * // Use clientSecret with Stripe Elements\n * if (data?.clientSecret) {\n *   // Pass to Stripe PaymentElement\n * }\n * ```\n */\nexport function useCreateProductPaymentIntent() {\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n    }: {\n      bookingId: string;\n    }): Promise<PaymentIntentResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/users/me/product-bookings/${bookingId}/payment-intent`\n      );\n      return response.data;\n    },\n  });\n}\n"]}
|