@growsober/sdk 1.0.5 → 1.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/__tests__/e2e.test.d.ts +30 -0
- package/dist/__tests__/e2e.test.js +959 -63
- package/dist/api/mutations/badges.d.ts +116 -0
- package/dist/api/mutations/badges.js +177 -0
- package/dist/api/mutations/brands.d.ts +251 -0
- package/dist/api/mutations/brands.js +242 -0
- package/dist/api/mutations/creators.d.ts +131 -0
- package/dist/api/mutations/creators.js +129 -0
- package/dist/api/mutations/event-chat.d.ts +2 -2
- package/dist/api/mutations/event-chat.js +9 -9
- package/dist/api/mutations/index.d.ts +4 -0
- package/dist/api/mutations/index.js +5 -1
- package/dist/api/mutations/jack.d.ts +29 -0
- package/dist/api/mutations/jack.js +41 -1
- package/dist/api/mutations/products.d.ts +175 -0
- package/dist/api/mutations/products.js +226 -0
- package/dist/api/mutations/support.d.ts +20 -1
- package/dist/api/mutations/support.js +36 -1
- package/dist/api/queries/badges.d.ts +221 -0
- package/dist/api/queries/badges.js +290 -0
- package/dist/api/queries/bookings.d.ts +1 -1
- package/dist/api/queries/brands.d.ts +248 -0
- package/dist/api/queries/brands.js +226 -0
- package/dist/api/queries/businesses.d.ts +61 -1
- package/dist/api/queries/businesses.js +27 -1
- package/dist/api/queries/creators.d.ts +332 -0
- package/dist/api/queries/creators.js +249 -0
- package/dist/api/queries/event-chat.d.ts +1 -1
- package/dist/api/queries/event-chat.js +4 -4
- package/dist/api/queries/events.d.ts +45 -0
- package/dist/api/queries/index.d.ts +5 -0
- package/dist/api/queries/index.js +6 -1
- package/dist/api/queries/jack.d.ts +80 -0
- package/dist/api/queries/jack.js +98 -1
- package/dist/api/queries/library.d.ts +8 -0
- package/dist/api/queries/products.d.ts +185 -0
- package/dist/api/queries/products.js +203 -0
- package/dist/api/queries/support.d.ts +46 -1
- package/dist/api/queries/support.js +48 -1
- package/dist/api/queries/venues.d.ts +304 -0
- package/dist/api/queries/venues.js +211 -0
- package/dist/api/types.d.ts +245 -0
- package/dist/api/types.js +6 -1
- package/dist/api/utils/eventGrouping.d.ts +104 -0
- package/dist/api/utils/eventGrouping.js +155 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +5 -1
- package/package.json +5 -2
- package/src/__tests__/e2e.test.ts +996 -64
- package/src/api/mutations/badges.ts +228 -0
- package/src/api/mutations/brands.ts +376 -0
- package/src/api/mutations/creators.ts +171 -0
- package/src/api/mutations/event-chat.ts +8 -8
- package/src/api/mutations/index.ts +4 -0
- package/src/api/mutations/jack.ts +50 -1
- package/src/api/mutations/products.ts +336 -0
- package/src/api/mutations/support.ts +44 -0
- package/src/api/queries/badges.ts +385 -0
- package/src/api/queries/brands.ts +281 -0
- package/src/api/queries/businesses.ts +30 -1
- package/src/api/queries/creators.ts +308 -0
- package/src/api/queries/event-chat.ts +3 -3
- package/src/api/queries/index.ts +5 -0
- package/src/api/queries/jack.ts +139 -1
- package/src/api/queries/products.ts +312 -0
- package/src/api/queries/support.ts +54 -0
- package/src/api/queries/venues.ts +271 -0
- package/src/api/types.ts +317 -1
- package/src/api/utils/eventGrouping.ts +181 -0
- package/src/index.ts +6 -0
|
@@ -0,0 +1,242 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useCreateBrand = useCreateBrand;
|
|
4
|
+
exports.useUpdateBrand = useUpdateBrand;
|
|
5
|
+
exports.useAddBrandOwner = useAddBrandOwner;
|
|
6
|
+
exports.useUpdateBrandOwnerRole = useUpdateBrandOwnerRole;
|
|
7
|
+
exports.useRemoveBrandOwner = useRemoveBrandOwner;
|
|
8
|
+
exports.useAddBrandCreator = useAddBrandCreator;
|
|
9
|
+
exports.useUpdateBrandCreator = useUpdateBrandCreator;
|
|
10
|
+
exports.useRemoveBrandCreator = useRemoveBrandCreator;
|
|
11
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
12
|
+
const client_1 = require("../client");
|
|
13
|
+
const brands_1 = require("../queries/brands");
|
|
14
|
+
// ============================================================================
|
|
15
|
+
// MUTATION HOOKS
|
|
16
|
+
// ============================================================================
|
|
17
|
+
/**
|
|
18
|
+
* Create a new brand
|
|
19
|
+
*
|
|
20
|
+
* @example
|
|
21
|
+
* ```tsx
|
|
22
|
+
* const { mutateAsync: createBrand } = useCreateBrand();
|
|
23
|
+
*
|
|
24
|
+
* await createBrand({
|
|
25
|
+
* slug: 'wellness-co',
|
|
26
|
+
* name: 'Wellness Co',
|
|
27
|
+
* description: 'A wellness brand',
|
|
28
|
+
* });
|
|
29
|
+
* ```
|
|
30
|
+
*/
|
|
31
|
+
function useCreateBrand(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/brands', data);
|
|
37
|
+
return response.data;
|
|
38
|
+
},
|
|
39
|
+
onSuccess: () => {
|
|
40
|
+
queryClient.invalidateQueries({ queryKey: brands_1.brandKeys.all });
|
|
41
|
+
},
|
|
42
|
+
...options,
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Update a brand
|
|
47
|
+
*
|
|
48
|
+
* @example
|
|
49
|
+
* ```tsx
|
|
50
|
+
* const { mutateAsync: updateBrand } = useUpdateBrand();
|
|
51
|
+
*
|
|
52
|
+
* await updateBrand({
|
|
53
|
+
* id: 'brand-123',
|
|
54
|
+
* data: { description: 'Updated description' },
|
|
55
|
+
* });
|
|
56
|
+
* ```
|
|
57
|
+
*/
|
|
58
|
+
function useUpdateBrand(options) {
|
|
59
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
60
|
+
return (0, react_query_1.useMutation)({
|
|
61
|
+
mutationFn: async ({ id, data }) => {
|
|
62
|
+
const client = (0, client_1.getApiClient)();
|
|
63
|
+
const response = await client.patch(`/api/v1/brands/${id}`, data);
|
|
64
|
+
return response.data;
|
|
65
|
+
},
|
|
66
|
+
onSuccess: (_, variables) => {
|
|
67
|
+
queryClient.invalidateQueries({ queryKey: brands_1.brandKeys.detail(variables.id) });
|
|
68
|
+
},
|
|
69
|
+
...options,
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Add a brand owner
|
|
74
|
+
*
|
|
75
|
+
* @example
|
|
76
|
+
* ```tsx
|
|
77
|
+
* const { mutateAsync: addOwner } = useAddBrandOwner();
|
|
78
|
+
*
|
|
79
|
+
* await addOwner({
|
|
80
|
+
* brandId: 'brand-123',
|
|
81
|
+
* userId: 'user-456',
|
|
82
|
+
* role: 'MANAGER',
|
|
83
|
+
* });
|
|
84
|
+
* ```
|
|
85
|
+
*/
|
|
86
|
+
function useAddBrandOwner(options) {
|
|
87
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
88
|
+
return (0, react_query_1.useMutation)({
|
|
89
|
+
mutationFn: async ({ brandId, userId, role, }) => {
|
|
90
|
+
const client = (0, client_1.getApiClient)();
|
|
91
|
+
const response = await client.post(`/api/v1/brands/${brandId}/owners`, { userId, role });
|
|
92
|
+
return response.data;
|
|
93
|
+
},
|
|
94
|
+
onSuccess: (_, variables) => {
|
|
95
|
+
queryClient.invalidateQueries({ queryKey: brands_1.brandKeys.owners(variables.brandId) });
|
|
96
|
+
},
|
|
97
|
+
...options,
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Update a brand owner's role
|
|
102
|
+
*
|
|
103
|
+
* @example
|
|
104
|
+
* ```tsx
|
|
105
|
+
* const { mutateAsync: updateOwnerRole } = useUpdateBrandOwnerRole();
|
|
106
|
+
*
|
|
107
|
+
* await updateOwnerRole({
|
|
108
|
+
* brandId: 'brand-123',
|
|
109
|
+
* userId: 'user-456',
|
|
110
|
+
* role: 'OWNER',
|
|
111
|
+
* });
|
|
112
|
+
* ```
|
|
113
|
+
*/
|
|
114
|
+
function useUpdateBrandOwnerRole(options) {
|
|
115
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
116
|
+
return (0, react_query_1.useMutation)({
|
|
117
|
+
mutationFn: async ({ brandId, userId, role, }) => {
|
|
118
|
+
const client = (0, client_1.getApiClient)();
|
|
119
|
+
const response = await client.patch(`/api/v1/brands/${brandId}/owners/${userId}`, { role });
|
|
120
|
+
return response.data;
|
|
121
|
+
},
|
|
122
|
+
onSuccess: (_, variables) => {
|
|
123
|
+
queryClient.invalidateQueries({ queryKey: brands_1.brandKeys.owners(variables.brandId) });
|
|
124
|
+
},
|
|
125
|
+
...options,
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Remove a brand owner
|
|
130
|
+
*
|
|
131
|
+
* @example
|
|
132
|
+
* ```tsx
|
|
133
|
+
* const { mutateAsync: removeOwner } = useRemoveBrandOwner();
|
|
134
|
+
*
|
|
135
|
+
* await removeOwner({
|
|
136
|
+
* brandId: 'brand-123',
|
|
137
|
+
* userId: 'user-456',
|
|
138
|
+
* });
|
|
139
|
+
* ```
|
|
140
|
+
*/
|
|
141
|
+
function useRemoveBrandOwner(options) {
|
|
142
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
143
|
+
return (0, react_query_1.useMutation)({
|
|
144
|
+
mutationFn: async ({ brandId, userId, }) => {
|
|
145
|
+
const client = (0, client_1.getApiClient)();
|
|
146
|
+
await client.delete(`/api/v1/brands/${brandId}/owners/${userId}`);
|
|
147
|
+
},
|
|
148
|
+
onSuccess: (_, variables) => {
|
|
149
|
+
queryClient.invalidateQueries({ queryKey: brands_1.brandKeys.owners(variables.brandId) });
|
|
150
|
+
},
|
|
151
|
+
...options,
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* Add a creator partnership to a brand
|
|
156
|
+
*
|
|
157
|
+
* @example
|
|
158
|
+
* ```tsx
|
|
159
|
+
* const { mutateAsync: addCreator } = useAddBrandCreator();
|
|
160
|
+
*
|
|
161
|
+
* await addCreator({
|
|
162
|
+
* brandId: 'brand-123',
|
|
163
|
+
* creatorId: 'creator-456',
|
|
164
|
+
* commissionRate: 0.15,
|
|
165
|
+
* });
|
|
166
|
+
* ```
|
|
167
|
+
*/
|
|
168
|
+
function useAddBrandCreator(options) {
|
|
169
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
170
|
+
return (0, react_query_1.useMutation)({
|
|
171
|
+
mutationFn: async ({ brandId, creatorId, startDate, endDate, commissionRate, isActive, }) => {
|
|
172
|
+
const client = (0, client_1.getApiClient)();
|
|
173
|
+
const response = await client.post(`/api/v1/brands/${brandId}/creators`, {
|
|
174
|
+
creatorId,
|
|
175
|
+
startDate,
|
|
176
|
+
endDate,
|
|
177
|
+
commissionRate,
|
|
178
|
+
isActive,
|
|
179
|
+
});
|
|
180
|
+
return response.data;
|
|
181
|
+
},
|
|
182
|
+
onSuccess: (_, variables) => {
|
|
183
|
+
queryClient.invalidateQueries({ queryKey: brands_1.brandKeys.creators(variables.brandId) });
|
|
184
|
+
},
|
|
185
|
+
...options,
|
|
186
|
+
});
|
|
187
|
+
}
|
|
188
|
+
/**
|
|
189
|
+
* Update a creator partnership
|
|
190
|
+
*
|
|
191
|
+
* @example
|
|
192
|
+
* ```tsx
|
|
193
|
+
* const { mutateAsync: updateCreator } = useUpdateBrandCreator();
|
|
194
|
+
*
|
|
195
|
+
* await updateCreator({
|
|
196
|
+
* brandId: 'brand-123',
|
|
197
|
+
* creatorId: 'creator-456',
|
|
198
|
+
* isActive: false,
|
|
199
|
+
* });
|
|
200
|
+
* ```
|
|
201
|
+
*/
|
|
202
|
+
function useUpdateBrandCreator(options) {
|
|
203
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
204
|
+
return (0, react_query_1.useMutation)({
|
|
205
|
+
mutationFn: async ({ brandId, creatorId, ...data }) => {
|
|
206
|
+
const client = (0, client_1.getApiClient)();
|
|
207
|
+
const response = await client.patch(`/api/v1/brands/${brandId}/creators/${creatorId}`, data);
|
|
208
|
+
return response.data;
|
|
209
|
+
},
|
|
210
|
+
onSuccess: (_, variables) => {
|
|
211
|
+
queryClient.invalidateQueries({ queryKey: brands_1.brandKeys.creators(variables.brandId) });
|
|
212
|
+
},
|
|
213
|
+
...options,
|
|
214
|
+
});
|
|
215
|
+
}
|
|
216
|
+
/**
|
|
217
|
+
* Remove a creator partnership from a brand
|
|
218
|
+
*
|
|
219
|
+
* @example
|
|
220
|
+
* ```tsx
|
|
221
|
+
* const { mutateAsync: removeCreator } = useRemoveBrandCreator();
|
|
222
|
+
*
|
|
223
|
+
* await removeCreator({
|
|
224
|
+
* brandId: 'brand-123',
|
|
225
|
+
* creatorId: 'creator-456',
|
|
226
|
+
* });
|
|
227
|
+
* ```
|
|
228
|
+
*/
|
|
229
|
+
function useRemoveBrandCreator(options) {
|
|
230
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
231
|
+
return (0, react_query_1.useMutation)({
|
|
232
|
+
mutationFn: async ({ brandId, creatorId, }) => {
|
|
233
|
+
const client = (0, client_1.getApiClient)();
|
|
234
|
+
await client.delete(`/api/v1/brands/${brandId}/creators/${creatorId}`);
|
|
235
|
+
},
|
|
236
|
+
onSuccess: (_, variables) => {
|
|
237
|
+
queryClient.invalidateQueries({ queryKey: brands_1.brandKeys.creators(variables.brandId) });
|
|
238
|
+
},
|
|
239
|
+
...options,
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"brands.js","sourceRoot":"","sources":["../../../src/api/mutations/brands.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient, UseMutationOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { brandKeys } from '../queries/brands';\nimport type {\n  BrandResponse,\n  BrandOwnerResponse,\n  BrandCreatorResponse,\n  BrandOwnerRole,\n  CreateBrandRequest,\n  UpdateBrandRequest,\n} from '../types';\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a new brand\n *\n * @example\n * ```tsx\n * const { mutateAsync: createBrand } = useCreateBrand();\n *\n * await createBrand({\n *   slug: 'wellness-co',\n *   name: 'Wellness Co',\n *   description: 'A wellness brand',\n * });\n * ```\n */\nexport function useCreateBrand(\n  options?: Omit<UseMutationOptions<BrandResponse, Error, CreateBrandRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateBrandRequest): Promise<BrandResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/brands', data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: brandKeys.all });\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a brand\n *\n * @example\n * ```tsx\n * const { mutateAsync: updateBrand } = useUpdateBrand();\n *\n * await updateBrand({\n *   id: 'brand-123',\n *   data: { description: 'Updated description' },\n * });\n * ```\n */\nexport function useUpdateBrand(\n  options?: Omit<\n    UseMutationOptions<BrandResponse, Error, { id: string; data: UpdateBrandRequest }>,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ id, data }: { id: string; data: UpdateBrandRequest }): Promise<BrandResponse> => {\n      const client = getApiClient();\n      const response = await client.patch(`/api/v1/brands/${id}`, data);\n      return response.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: brandKeys.detail(variables.id) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Add a brand owner\n *\n * @example\n * ```tsx\n * const { mutateAsync: addOwner } = useAddBrandOwner();\n *\n * await addOwner({\n *   brandId: 'brand-123',\n *   userId: 'user-456',\n *   role: 'MANAGER',\n * });\n * ```\n */\nexport function useAddBrandOwner(\n  options?: Omit<\n    UseMutationOptions<\n      BrandOwnerResponse,\n      Error,\n      { brandId: string; userId: string; role: BrandOwnerRole }\n    >,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      brandId,\n      userId,\n      role,\n    }: {\n      brandId: string;\n      userId: string;\n      role: BrandOwnerRole;\n    }): Promise<BrandOwnerResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/brands/${brandId}/owners`, { userId, role });\n      return response.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: brandKeys.owners(variables.brandId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a brand owner's role\n *\n * @example\n * ```tsx\n * const { mutateAsync: updateOwnerRole } = useUpdateBrandOwnerRole();\n *\n * await updateOwnerRole({\n *   brandId: 'brand-123',\n *   userId: 'user-456',\n *   role: 'OWNER',\n * });\n * ```\n */\nexport function useUpdateBrandOwnerRole(\n  options?: Omit<\n    UseMutationOptions<\n      BrandOwnerResponse,\n      Error,\n      { brandId: string; userId: string; role: BrandOwnerRole }\n    >,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      brandId,\n      userId,\n      role,\n    }: {\n      brandId: string;\n      userId: string;\n      role: BrandOwnerRole;\n    }): Promise<BrandOwnerResponse> => {\n      const client = getApiClient();\n      const response = await client.patch(`/api/v1/brands/${brandId}/owners/${userId}`, { role });\n      return response.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: brandKeys.owners(variables.brandId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Remove a brand owner\n *\n * @example\n * ```tsx\n * const { mutateAsync: removeOwner } = useRemoveBrandOwner();\n *\n * await removeOwner({\n *   brandId: 'brand-123',\n *   userId: 'user-456',\n * });\n * ```\n */\nexport function useRemoveBrandOwner(\n  options?: Omit<\n    UseMutationOptions<void, Error, { brandId: string; userId: string }>,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      brandId,\n      userId,\n    }: {\n      brandId: string;\n      userId: string;\n    }): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/brands/${brandId}/owners/${userId}`);\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: brandKeys.owners(variables.brandId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Add a creator partnership to a brand\n *\n * @example\n * ```tsx\n * const { mutateAsync: addCreator } = useAddBrandCreator();\n *\n * await addCreator({\n *   brandId: 'brand-123',\n *   creatorId: 'creator-456',\n *   commissionRate: 0.15,\n * });\n * ```\n */\nexport function useAddBrandCreator(\n  options?: Omit<\n    UseMutationOptions<\n      BrandCreatorResponse,\n      Error,\n      {\n        brandId: string;\n        creatorId: string;\n        startDate?: string;\n        endDate?: string;\n        commissionRate?: number;\n        isActive?: boolean;\n      }\n    >,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      brandId,\n      creatorId,\n      startDate,\n      endDate,\n      commissionRate,\n      isActive,\n    }: {\n      brandId: string;\n      creatorId: string;\n      startDate?: string;\n      endDate?: string;\n      commissionRate?: number;\n      isActive?: boolean;\n    }): Promise<BrandCreatorResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/brands/${brandId}/creators`, {\n        creatorId,\n        startDate,\n        endDate,\n        commissionRate,\n        isActive,\n      });\n      return response.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: brandKeys.creators(variables.brandId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a creator partnership\n *\n * @example\n * ```tsx\n * const { mutateAsync: updateCreator } = useUpdateBrandCreator();\n *\n * await updateCreator({\n *   brandId: 'brand-123',\n *   creatorId: 'creator-456',\n *   isActive: false,\n * });\n * ```\n */\nexport function useUpdateBrandCreator(\n  options?: Omit<\n    UseMutationOptions<\n      BrandCreatorResponse,\n      Error,\n      {\n        brandId: string;\n        creatorId: string;\n        startDate?: string;\n        endDate?: string;\n        commissionRate?: number;\n        isActive?: boolean;\n      }\n    >,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      brandId,\n      creatorId,\n      ...data\n    }: {\n      brandId: string;\n      creatorId: string;\n      startDate?: string;\n      endDate?: string;\n      commissionRate?: number;\n      isActive?: boolean;\n    }): Promise<BrandCreatorResponse> => {\n      const client = getApiClient();\n      const response = await client.patch(`/api/v1/brands/${brandId}/creators/${creatorId}`, data);\n      return response.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: brandKeys.creators(variables.brandId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Remove a creator partnership from a brand\n *\n * @example\n * ```tsx\n * const { mutateAsync: removeCreator } = useRemoveBrandCreator();\n *\n * await removeCreator({\n *   brandId: 'brand-123',\n *   creatorId: 'creator-456',\n * });\n * ```\n */\nexport function useRemoveBrandCreator(\n  options?: Omit<\n    UseMutationOptions<void, Error, { brandId: string; creatorId: string }>,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      brandId,\n      creatorId,\n    }: {\n      brandId: string;\n      creatorId: string;\n    }): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/brands/${brandId}/creators/${creatorId}`);\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: brandKeys.creators(variables.brandId) });\n    },\n    ...options,\n  });\n}\n"]}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
import { UseMutationOptions } from '@tanstack/react-query';
|
|
2
|
+
import type { CreatorResponse, CreatorAvailabilityResponse, CreateCreatorRequest, UpdateCreatorRequest, CreateAvailabilityRequest } from '../types';
|
|
3
|
+
/**
|
|
4
|
+
* Create a new creator profile for the current user
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* ```tsx
|
|
8
|
+
* const { mutateAsync: createCreator } = useCreateCreator();
|
|
9
|
+
*
|
|
10
|
+
* await createCreator({
|
|
11
|
+
* slug: 'john-doe',
|
|
12
|
+
* displayName: 'John Doe',
|
|
13
|
+
* bio: 'Wellness facilitator',
|
|
14
|
+
* canFacilitate: true,
|
|
15
|
+
* });
|
|
16
|
+
* ```
|
|
17
|
+
*/
|
|
18
|
+
export declare function useCreateCreator(options?: Omit<UseMutationOptions<CreatorResponse, Error, CreateCreatorRequest>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
|
|
19
|
+
id: string;
|
|
20
|
+
userId: string;
|
|
21
|
+
slug: string;
|
|
22
|
+
displayName: string;
|
|
23
|
+
bio?: Record<string, never>;
|
|
24
|
+
avatarUrl?: Record<string, never>;
|
|
25
|
+
cityIds: string[];
|
|
26
|
+
canFacilitate: boolean;
|
|
27
|
+
canCreateContent: boolean;
|
|
28
|
+
isInfluencer: boolean;
|
|
29
|
+
specialties: string[];
|
|
30
|
+
certifications: string[];
|
|
31
|
+
sessionRate?: number;
|
|
32
|
+
isVerified: boolean;
|
|
33
|
+
isActive: boolean;
|
|
34
|
+
createdAt: string;
|
|
35
|
+
updatedAt: string;
|
|
36
|
+
user?: import("@growsober/types/dist/generated").components["schemas"]["CreatorUserDto"];
|
|
37
|
+
}, Error, CreateCreatorRequest, unknown>;
|
|
38
|
+
/**
|
|
39
|
+
* Update a creator profile
|
|
40
|
+
*
|
|
41
|
+
* @example
|
|
42
|
+
* ```tsx
|
|
43
|
+
* const { mutateAsync: updateCreator } = useUpdateCreator();
|
|
44
|
+
*
|
|
45
|
+
* await updateCreator({
|
|
46
|
+
* id: 'creator-123',
|
|
47
|
+
* data: { bio: 'Updated bio' },
|
|
48
|
+
* });
|
|
49
|
+
* ```
|
|
50
|
+
*/
|
|
51
|
+
export declare function useUpdateCreator(options?: Omit<UseMutationOptions<CreatorResponse, Error, {
|
|
52
|
+
id: string;
|
|
53
|
+
data: UpdateCreatorRequest;
|
|
54
|
+
}>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
|
|
55
|
+
id: string;
|
|
56
|
+
userId: string;
|
|
57
|
+
slug: string;
|
|
58
|
+
displayName: string;
|
|
59
|
+
bio?: Record<string, never>;
|
|
60
|
+
avatarUrl?: Record<string, never>;
|
|
61
|
+
cityIds: string[];
|
|
62
|
+
canFacilitate: boolean;
|
|
63
|
+
canCreateContent: boolean;
|
|
64
|
+
isInfluencer: boolean;
|
|
65
|
+
specialties: string[];
|
|
66
|
+
certifications: string[];
|
|
67
|
+
sessionRate?: number;
|
|
68
|
+
isVerified: boolean;
|
|
69
|
+
isActive: boolean;
|
|
70
|
+
createdAt: string;
|
|
71
|
+
updatedAt: string;
|
|
72
|
+
user?: import("@growsober/types/dist/generated").components["schemas"]["CreatorUserDto"];
|
|
73
|
+
}, Error, {
|
|
74
|
+
id: string;
|
|
75
|
+
data: UpdateCreatorRequest;
|
|
76
|
+
}, unknown>;
|
|
77
|
+
/**
|
|
78
|
+
* Add an availability slot for a creator
|
|
79
|
+
*
|
|
80
|
+
* @example
|
|
81
|
+
* ```tsx
|
|
82
|
+
* const { mutateAsync: addAvailability } = useAddCreatorAvailability();
|
|
83
|
+
*
|
|
84
|
+
* await addAvailability({
|
|
85
|
+
* creatorId: 'creator-123',
|
|
86
|
+
* data: {
|
|
87
|
+
* dayOfWeek: 1, // Monday
|
|
88
|
+
* startTime: '09:00',
|
|
89
|
+
* endTime: '17:00',
|
|
90
|
+
* timezone: 'Europe/London',
|
|
91
|
+
* isRecurring: true,
|
|
92
|
+
* },
|
|
93
|
+
* });
|
|
94
|
+
* ```
|
|
95
|
+
*/
|
|
96
|
+
export declare function useAddCreatorAvailability(options?: Omit<UseMutationOptions<CreatorAvailabilityResponse, Error, {
|
|
97
|
+
creatorId: string;
|
|
98
|
+
data: CreateAvailabilityRequest;
|
|
99
|
+
}>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
|
|
100
|
+
id: string;
|
|
101
|
+
creatorId: string;
|
|
102
|
+
dayOfWeek: Record<string, never>;
|
|
103
|
+
startTime: string;
|
|
104
|
+
endTime: string;
|
|
105
|
+
timezone: string;
|
|
106
|
+
isRecurring: boolean;
|
|
107
|
+
specificDate?: string;
|
|
108
|
+
}, Error, {
|
|
109
|
+
creatorId: string;
|
|
110
|
+
data: CreateAvailabilityRequest;
|
|
111
|
+
}, unknown>;
|
|
112
|
+
/**
|
|
113
|
+
* Remove an availability slot for a creator
|
|
114
|
+
*
|
|
115
|
+
* @example
|
|
116
|
+
* ```tsx
|
|
117
|
+
* const { mutateAsync: removeAvailability } = useRemoveCreatorAvailability();
|
|
118
|
+
*
|
|
119
|
+
* await removeAvailability({
|
|
120
|
+
* creatorId: 'creator-123',
|
|
121
|
+
* availabilityId: 'availability-456',
|
|
122
|
+
* });
|
|
123
|
+
* ```
|
|
124
|
+
*/
|
|
125
|
+
export declare function useRemoveCreatorAvailability(options?: Omit<UseMutationOptions<void, Error, {
|
|
126
|
+
creatorId: string;
|
|
127
|
+
availabilityId: string;
|
|
128
|
+
}>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<void, Error, {
|
|
129
|
+
creatorId: string;
|
|
130
|
+
availabilityId: string;
|
|
131
|
+
}, unknown>;
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.useCreateCreator = useCreateCreator;
|
|
4
|
+
exports.useUpdateCreator = useUpdateCreator;
|
|
5
|
+
exports.useAddCreatorAvailability = useAddCreatorAvailability;
|
|
6
|
+
exports.useRemoveCreatorAvailability = useRemoveCreatorAvailability;
|
|
7
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
8
|
+
const client_1 = require("../client");
|
|
9
|
+
const creators_1 = require("../queries/creators");
|
|
10
|
+
// ============================================================================
|
|
11
|
+
// MUTATION HOOKS
|
|
12
|
+
// ============================================================================
|
|
13
|
+
/**
|
|
14
|
+
* Create a new creator profile for the current user
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
* ```tsx
|
|
18
|
+
* const { mutateAsync: createCreator } = useCreateCreator();
|
|
19
|
+
*
|
|
20
|
+
* await createCreator({
|
|
21
|
+
* slug: 'john-doe',
|
|
22
|
+
* displayName: 'John Doe',
|
|
23
|
+
* bio: 'Wellness facilitator',
|
|
24
|
+
* canFacilitate: true,
|
|
25
|
+
* });
|
|
26
|
+
* ```
|
|
27
|
+
*/
|
|
28
|
+
function useCreateCreator(options) {
|
|
29
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
30
|
+
return (0, react_query_1.useMutation)({
|
|
31
|
+
mutationFn: async (data) => {
|
|
32
|
+
const client = (0, client_1.getApiClient)();
|
|
33
|
+
const response = await client.post('/api/v1/creators', data);
|
|
34
|
+
return response.data;
|
|
35
|
+
},
|
|
36
|
+
onSuccess: () => {
|
|
37
|
+
queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.all });
|
|
38
|
+
},
|
|
39
|
+
...options,
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Update a creator profile
|
|
44
|
+
*
|
|
45
|
+
* @example
|
|
46
|
+
* ```tsx
|
|
47
|
+
* const { mutateAsync: updateCreator } = useUpdateCreator();
|
|
48
|
+
*
|
|
49
|
+
* await updateCreator({
|
|
50
|
+
* id: 'creator-123',
|
|
51
|
+
* data: { bio: 'Updated bio' },
|
|
52
|
+
* });
|
|
53
|
+
* ```
|
|
54
|
+
*/
|
|
55
|
+
function useUpdateCreator(options) {
|
|
56
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
57
|
+
return (0, react_query_1.useMutation)({
|
|
58
|
+
mutationFn: async ({ id, data }) => {
|
|
59
|
+
const client = (0, client_1.getApiClient)();
|
|
60
|
+
const response = await client.patch(`/api/v1/creators/${id}`, data);
|
|
61
|
+
return response.data;
|
|
62
|
+
},
|
|
63
|
+
onSuccess: (_, variables) => {
|
|
64
|
+
queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.detail(variables.id) });
|
|
65
|
+
queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.me() });
|
|
66
|
+
},
|
|
67
|
+
...options,
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Add an availability slot for a creator
|
|
72
|
+
*
|
|
73
|
+
* @example
|
|
74
|
+
* ```tsx
|
|
75
|
+
* const { mutateAsync: addAvailability } = useAddCreatorAvailability();
|
|
76
|
+
*
|
|
77
|
+
* await addAvailability({
|
|
78
|
+
* creatorId: 'creator-123',
|
|
79
|
+
* data: {
|
|
80
|
+
* dayOfWeek: 1, // Monday
|
|
81
|
+
* startTime: '09:00',
|
|
82
|
+
* endTime: '17:00',
|
|
83
|
+
* timezone: 'Europe/London',
|
|
84
|
+
* isRecurring: true,
|
|
85
|
+
* },
|
|
86
|
+
* });
|
|
87
|
+
* ```
|
|
88
|
+
*/
|
|
89
|
+
function useAddCreatorAvailability(options) {
|
|
90
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
91
|
+
return (0, react_query_1.useMutation)({
|
|
92
|
+
mutationFn: async ({ creatorId, data, }) => {
|
|
93
|
+
const client = (0, client_1.getApiClient)();
|
|
94
|
+
const response = await client.post(`/api/v1/creators/${creatorId}/availability`, data);
|
|
95
|
+
return response.data;
|
|
96
|
+
},
|
|
97
|
+
onSuccess: (_, variables) => {
|
|
98
|
+
queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.availability(variables.creatorId) });
|
|
99
|
+
},
|
|
100
|
+
...options,
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Remove an availability slot for a creator
|
|
105
|
+
*
|
|
106
|
+
* @example
|
|
107
|
+
* ```tsx
|
|
108
|
+
* const { mutateAsync: removeAvailability } = useRemoveCreatorAvailability();
|
|
109
|
+
*
|
|
110
|
+
* await removeAvailability({
|
|
111
|
+
* creatorId: 'creator-123',
|
|
112
|
+
* availabilityId: 'availability-456',
|
|
113
|
+
* });
|
|
114
|
+
* ```
|
|
115
|
+
*/
|
|
116
|
+
function useRemoveCreatorAvailability(options) {
|
|
117
|
+
const queryClient = (0, react_query_1.useQueryClient)();
|
|
118
|
+
return (0, react_query_1.useMutation)({
|
|
119
|
+
mutationFn: async ({ creatorId, availabilityId, }) => {
|
|
120
|
+
const client = (0, client_1.getApiClient)();
|
|
121
|
+
await client.delete(`/api/v1/creators/${creatorId}/availability/${availabilityId}`);
|
|
122
|
+
},
|
|
123
|
+
onSuccess: (_, variables) => {
|
|
124
|
+
queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.availability(variables.creatorId) });
|
|
125
|
+
},
|
|
126
|
+
...options,
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"creators.js","sourceRoot":"","sources":["../../../src/api/mutations/creators.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient, UseMutationOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { creatorKeys } from '../queries/creators';\nimport type {\n  CreatorResponse,\n  CreatorAvailabilityResponse,\n  CreateCreatorRequest,\n  UpdateCreatorRequest,\n  CreateAvailabilityRequest,\n} from '../types';\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a new creator profile for the current user\n *\n * @example\n * ```tsx\n * const { mutateAsync: createCreator } = useCreateCreator();\n *\n * await createCreator({\n *   slug: 'john-doe',\n *   displayName: 'John Doe',\n *   bio: 'Wellness facilitator',\n *   canFacilitate: true,\n * });\n * ```\n */\nexport function useCreateCreator(\n  options?: Omit<UseMutationOptions<CreatorResponse, Error, CreateCreatorRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateCreatorRequest): Promise<CreatorResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/creators', data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.all });\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a creator profile\n *\n * @example\n * ```tsx\n * const { mutateAsync: updateCreator } = useUpdateCreator();\n *\n * await updateCreator({\n *   id: 'creator-123',\n *   data: { bio: 'Updated bio' },\n * });\n * ```\n */\nexport function useUpdateCreator(\n  options?: Omit<\n    UseMutationOptions<CreatorResponse, Error, { id: string; data: UpdateCreatorRequest }>,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({ id, data }: { id: string; data: UpdateCreatorRequest }): Promise<CreatorResponse> => {\n      const client = getApiClient();\n      const response = await client.patch(`/api/v1/creators/${id}`, data);\n      return response.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.detail(variables.id) });\n      queryClient.invalidateQueries({ queryKey: creatorKeys.me() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Add an availability slot for a creator\n *\n * @example\n * ```tsx\n * const { mutateAsync: addAvailability } = useAddCreatorAvailability();\n *\n * await addAvailability({\n *   creatorId: 'creator-123',\n *   data: {\n *     dayOfWeek: 1, // Monday\n *     startTime: '09:00',\n *     endTime: '17:00',\n *     timezone: 'Europe/London',\n *     isRecurring: true,\n *   },\n * });\n * ```\n */\nexport function useAddCreatorAvailability(\n  options?: Omit<\n    UseMutationOptions<\n      CreatorAvailabilityResponse,\n      Error,\n      { creatorId: string; data: CreateAvailabilityRequest }\n    >,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      data,\n    }: {\n      creatorId: string;\n      data: CreateAvailabilityRequest;\n    }): Promise<CreatorAvailabilityResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/availability`, data);\n      return response.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.availability(variables.creatorId) });\n    },\n    ...options,\n  });\n}\n\n/**\n * Remove an availability slot for a creator\n *\n * @example\n * ```tsx\n * const { mutateAsync: removeAvailability } = useRemoveCreatorAvailability();\n *\n * await removeAvailability({\n *   creatorId: 'creator-123',\n *   availabilityId: 'availability-456',\n * });\n * ```\n */\nexport function useRemoveCreatorAvailability(\n  options?: Omit<\n    UseMutationOptions<void, Error, { creatorId: string; availabilityId: string }>,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      availabilityId,\n    }: {\n      creatorId: string;\n      availabilityId: string;\n    }): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/creators/${creatorId}/availability/${availabilityId}`);\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.availability(variables.creatorId) });\n    },\n    ...options,\n  });\n}\n"]}
|
|
@@ -23,7 +23,7 @@ export declare function useJoinEventChat(eventId: string): import("@tanstack/rea
|
|
|
23
23
|
id: string;
|
|
24
24
|
chatId: string;
|
|
25
25
|
userId: string;
|
|
26
|
-
role: "
|
|
26
|
+
role: "ATTENDEE" | "CREATOR" | "VENUE_REP" | "BRAND_REP" | "ADMIN" | "MODERATOR";
|
|
27
27
|
nickname?: string;
|
|
28
28
|
isMuted: boolean;
|
|
29
29
|
lastReadAt?: string;
|
|
@@ -42,7 +42,7 @@ export declare function useUpdateMemberSettings(eventId: string): import("@tanst
|
|
|
42
42
|
id: string;
|
|
43
43
|
chatId: string;
|
|
44
44
|
userId: string;
|
|
45
|
-
role: "
|
|
45
|
+
role: "ATTENDEE" | "CREATOR" | "VENUE_REP" | "BRAND_REP" | "ADMIN" | "MODERATOR";
|
|
46
46
|
nickname?: string;
|
|
47
47
|
isMuted: boolean;
|
|
48
48
|
lastReadAt?: string;
|