@growsober/sdk 1.0.5 → 1.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (70) hide show
  1. package/dist/__tests__/e2e.test.d.ts +30 -0
  2. package/dist/__tests__/e2e.test.js +959 -63
  3. package/dist/api/mutations/badges.d.ts +116 -0
  4. package/dist/api/mutations/badges.js +177 -0
  5. package/dist/api/mutations/brands.d.ts +251 -0
  6. package/dist/api/mutations/brands.js +242 -0
  7. package/dist/api/mutations/creators.d.ts +131 -0
  8. package/dist/api/mutations/creators.js +129 -0
  9. package/dist/api/mutations/event-chat.d.ts +2 -2
  10. package/dist/api/mutations/event-chat.js +9 -9
  11. package/dist/api/mutations/index.d.ts +4 -0
  12. package/dist/api/mutations/index.js +5 -1
  13. package/dist/api/mutations/jack.d.ts +29 -0
  14. package/dist/api/mutations/jack.js +41 -1
  15. package/dist/api/mutations/products.d.ts +175 -0
  16. package/dist/api/mutations/products.js +226 -0
  17. package/dist/api/mutations/support.d.ts +20 -1
  18. package/dist/api/mutations/support.js +36 -1
  19. package/dist/api/queries/badges.d.ts +221 -0
  20. package/dist/api/queries/badges.js +290 -0
  21. package/dist/api/queries/bookings.d.ts +1 -1
  22. package/dist/api/queries/brands.d.ts +248 -0
  23. package/dist/api/queries/brands.js +226 -0
  24. package/dist/api/queries/businesses.d.ts +61 -1
  25. package/dist/api/queries/businesses.js +27 -1
  26. package/dist/api/queries/creators.d.ts +332 -0
  27. package/dist/api/queries/creators.js +249 -0
  28. package/dist/api/queries/event-chat.d.ts +1 -1
  29. package/dist/api/queries/event-chat.js +4 -4
  30. package/dist/api/queries/events.d.ts +45 -0
  31. package/dist/api/queries/index.d.ts +5 -0
  32. package/dist/api/queries/index.js +6 -1
  33. package/dist/api/queries/jack.d.ts +80 -0
  34. package/dist/api/queries/jack.js +98 -1
  35. package/dist/api/queries/library.d.ts +8 -0
  36. package/dist/api/queries/products.d.ts +185 -0
  37. package/dist/api/queries/products.js +203 -0
  38. package/dist/api/queries/support.d.ts +46 -1
  39. package/dist/api/queries/support.js +48 -1
  40. package/dist/api/queries/venues.d.ts +304 -0
  41. package/dist/api/queries/venues.js +211 -0
  42. package/dist/api/types.d.ts +245 -0
  43. package/dist/api/types.js +6 -1
  44. package/dist/api/utils/eventGrouping.d.ts +104 -0
  45. package/dist/api/utils/eventGrouping.js +155 -0
  46. package/dist/index.d.ts +1 -0
  47. package/dist/index.js +5 -1
  48. package/package.json +5 -2
  49. package/src/__tests__/e2e.test.ts +996 -64
  50. package/src/api/mutations/badges.ts +228 -0
  51. package/src/api/mutations/brands.ts +376 -0
  52. package/src/api/mutations/creators.ts +171 -0
  53. package/src/api/mutations/event-chat.ts +8 -8
  54. package/src/api/mutations/index.ts +4 -0
  55. package/src/api/mutations/jack.ts +50 -1
  56. package/src/api/mutations/products.ts +336 -0
  57. package/src/api/mutations/support.ts +44 -0
  58. package/src/api/queries/badges.ts +385 -0
  59. package/src/api/queries/brands.ts +281 -0
  60. package/src/api/queries/businesses.ts +30 -1
  61. package/src/api/queries/creators.ts +308 -0
  62. package/src/api/queries/event-chat.ts +3 -3
  63. package/src/api/queries/index.ts +5 -0
  64. package/src/api/queries/jack.ts +139 -1
  65. package/src/api/queries/products.ts +312 -0
  66. package/src/api/queries/support.ts +54 -0
  67. package/src/api/queries/venues.ts +271 -0
  68. package/src/api/types.ts +317 -1
  69. package/src/api/utils/eventGrouping.ts +181 -0
  70. package/src/index.ts +6 -0
@@ -0,0 +1,116 @@
1
+ import { UseMutationOptions } from '@tanstack/react-query';
2
+ import type { PartnerRewardResponse, PartnerRewardRedemptionResponse, CreatePartnerRewardRequest } from '../types';
3
+ /**
4
+ * Redeem a partner reward
5
+ *
6
+ * @example
7
+ * ```tsx
8
+ * const redeemReward = useRedeemReward();
9
+ *
10
+ * const handleRedeem = async (rewardId: string) => {
11
+ * await redeemReward.mutateAsync(rewardId);
12
+ * // Show success message
13
+ * };
14
+ * ```
15
+ */
16
+ export declare function useRedeemReward(options?: Omit<UseMutationOptions<PartnerRewardRedemptionResponse, Error, string>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<PartnerRewardRedemptionResponse, Error, string, unknown>;
17
+ /**
18
+ * Create a partner reward (for business dashboard)
19
+ *
20
+ * @param businessId - Business ID creating the reward
21
+ *
22
+ * @example
23
+ * ```tsx
24
+ * const createReward = useCreatePartnerReward('business-123');
25
+ *
26
+ * const handleCreate = async () => {
27
+ * await createReward.mutateAsync({
28
+ * badgeId: 'badge-week-warrior',
29
+ * title: 'Free Coffee',
30
+ * description: 'Show your badge for a free coffee',
31
+ * });
32
+ * };
33
+ * ```
34
+ */
35
+ export declare function useCreatePartnerReward(businessId: string, options?: Omit<UseMutationOptions<PartnerRewardResponse, Error, CreatePartnerRewardRequest>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<PartnerRewardResponse, Error, CreatePartnerRewardRequest, unknown>;
36
+ interface CreateRewardRequest {
37
+ badgeId: string;
38
+ title: string;
39
+ description?: string;
40
+ code?: string;
41
+ redeemType?: 'IN_PERSON' | 'ONLINE' | 'BOTH';
42
+ maxRedemptions?: number;
43
+ perUserLimit?: number;
44
+ validFrom?: string;
45
+ validUntil?: string;
46
+ }
47
+ /**
48
+ * Create a reward for a venue
49
+ *
50
+ * @param venueId - Venue ID
51
+ *
52
+ * @example
53
+ * ```tsx
54
+ * const createReward = useCreateVenueReward('venue-123');
55
+ *
56
+ * const handleCreate = async () => {
57
+ * await createReward.mutateAsync({
58
+ * badgeId: 'badge-week-warrior',
59
+ * title: 'Free Coffee',
60
+ * description: 'Show your badge for a free coffee',
61
+ * redeemType: 'IN_PERSON',
62
+ * });
63
+ * };
64
+ * ```
65
+ */
66
+ export declare function useCreateVenueReward(venueId: string, options?: Omit<UseMutationOptions<unknown, Error, CreateRewardRequest>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<unknown, Error, CreateRewardRequest, unknown>;
67
+ /**
68
+ * Create a reward for a brand
69
+ *
70
+ * @param brandId - Brand ID
71
+ *
72
+ * @example
73
+ * ```tsx
74
+ * const createReward = useCreateBrandReward('brand-123');
75
+ *
76
+ * const handleCreate = async () => {
77
+ * await createReward.mutateAsync({
78
+ * badgeId: 'badge-week-warrior',
79
+ * title: '10% Off',
80
+ * description: 'Use code at checkout',
81
+ * code: 'SOBER10',
82
+ * redeemType: 'ONLINE',
83
+ * });
84
+ * };
85
+ * ```
86
+ */
87
+ export declare function useCreateBrandReward(brandId: string, options?: Omit<UseMutationOptions<unknown, Error, CreateRewardRequest>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<unknown, Error, CreateRewardRequest, unknown>;
88
+ /**
89
+ * Update a partner reward (for business dashboard)
90
+ *
91
+ * @param businessId - Business ID
92
+ *
93
+ * @example
94
+ * ```tsx
95
+ * const updateReward = useUpdatePartnerReward('business-123');
96
+ *
97
+ * const handleUpdate = async (rewardId: string) => {
98
+ * await updateReward.mutateAsync({
99
+ * id: rewardId,
100
+ * data: { title: 'Updated Title', isActive: false },
101
+ * });
102
+ * };
103
+ * ```
104
+ */
105
+ export declare function useUpdatePartnerReward(businessId: string, options?: Omit<UseMutationOptions<PartnerRewardResponse, Error, {
106
+ id: string;
107
+ data: Partial<CreatePartnerRewardRequest & {
108
+ isActive: boolean;
109
+ }>;
110
+ }>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<PartnerRewardResponse, Error, {
111
+ id: string;
112
+ data: Partial<CreatePartnerRewardRequest & {
113
+ isActive: boolean;
114
+ }>;
115
+ }, unknown>;
116
+ export {};
@@ -0,0 +1,177 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useRedeemReward = useRedeemReward;
4
+ exports.useCreatePartnerReward = useCreatePartnerReward;
5
+ exports.useCreateVenueReward = useCreateVenueReward;
6
+ exports.useCreateBrandReward = useCreateBrandReward;
7
+ exports.useUpdatePartnerReward = useUpdatePartnerReward;
8
+ const react_query_1 = require("@tanstack/react-query");
9
+ const client_1 = require("../client");
10
+ const badges_1 = require("../queries/badges");
11
+ // ============================================================================
12
+ // REWARD MUTATION HOOKS
13
+ // ============================================================================
14
+ /**
15
+ * Redeem a partner reward
16
+ *
17
+ * @example
18
+ * ```tsx
19
+ * const redeemReward = useRedeemReward();
20
+ *
21
+ * const handleRedeem = async (rewardId: string) => {
22
+ * await redeemReward.mutateAsync(rewardId);
23
+ * // Show success message
24
+ * };
25
+ * ```
26
+ */
27
+ function useRedeemReward(options) {
28
+ const queryClient = (0, react_query_1.useQueryClient)();
29
+ return (0, react_query_1.useMutation)({
30
+ mutationFn: async (rewardId) => {
31
+ const client = (0, client_1.getApiClient)();
32
+ const response = await client.post(`/api/v1/rewards/${rewardId}/redeem`);
33
+ return response.data?.data || response.data;
34
+ },
35
+ onSuccess: () => {
36
+ // Invalidate wallet, available and redeemed rewards
37
+ queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.wallet() });
38
+ queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.available() });
39
+ queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.redeemed() });
40
+ },
41
+ ...options,
42
+ });
43
+ }
44
+ /**
45
+ * Create a partner reward (for business dashboard)
46
+ *
47
+ * @param businessId - Business ID creating the reward
48
+ *
49
+ * @example
50
+ * ```tsx
51
+ * const createReward = useCreatePartnerReward('business-123');
52
+ *
53
+ * const handleCreate = async () => {
54
+ * await createReward.mutateAsync({
55
+ * badgeId: 'badge-week-warrior',
56
+ * title: 'Free Coffee',
57
+ * description: 'Show your badge for a free coffee',
58
+ * });
59
+ * };
60
+ * ```
61
+ */
62
+ function useCreatePartnerReward(businessId, options) {
63
+ const queryClient = (0, react_query_1.useQueryClient)();
64
+ return (0, react_query_1.useMutation)({
65
+ mutationFn: async (data) => {
66
+ const client = (0, client_1.getApiClient)();
67
+ const response = await client.post(`/api/v1/businesses/${businessId}/rewards`, data);
68
+ return response.data?.data || response.data;
69
+ },
70
+ onSuccess: () => {
71
+ queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.forBusiness(businessId) });
72
+ },
73
+ ...options,
74
+ });
75
+ }
76
+ /**
77
+ * Create a reward for a venue
78
+ *
79
+ * @param venueId - Venue ID
80
+ *
81
+ * @example
82
+ * ```tsx
83
+ * const createReward = useCreateVenueReward('venue-123');
84
+ *
85
+ * const handleCreate = async () => {
86
+ * await createReward.mutateAsync({
87
+ * badgeId: 'badge-week-warrior',
88
+ * title: 'Free Coffee',
89
+ * description: 'Show your badge for a free coffee',
90
+ * redeemType: 'IN_PERSON',
91
+ * });
92
+ * };
93
+ * ```
94
+ */
95
+ function useCreateVenueReward(venueId, options) {
96
+ const queryClient = (0, react_query_1.useQueryClient)();
97
+ return (0, react_query_1.useMutation)({
98
+ mutationFn: async (data) => {
99
+ const client = (0, client_1.getApiClient)();
100
+ const response = await client.post(`/api/v1/venues/${venueId}/rewards`, data);
101
+ return response.data?.data || response.data;
102
+ },
103
+ onSuccess: () => {
104
+ queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.forVenue(venueId) });
105
+ queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.available() });
106
+ },
107
+ ...options,
108
+ });
109
+ }
110
+ /**
111
+ * Create a reward for a brand
112
+ *
113
+ * @param brandId - Brand ID
114
+ *
115
+ * @example
116
+ * ```tsx
117
+ * const createReward = useCreateBrandReward('brand-123');
118
+ *
119
+ * const handleCreate = async () => {
120
+ * await createReward.mutateAsync({
121
+ * badgeId: 'badge-week-warrior',
122
+ * title: '10% Off',
123
+ * description: 'Use code at checkout',
124
+ * code: 'SOBER10',
125
+ * redeemType: 'ONLINE',
126
+ * });
127
+ * };
128
+ * ```
129
+ */
130
+ function useCreateBrandReward(brandId, options) {
131
+ const queryClient = (0, react_query_1.useQueryClient)();
132
+ return (0, react_query_1.useMutation)({
133
+ mutationFn: async (data) => {
134
+ const client = (0, client_1.getApiClient)();
135
+ const response = await client.post(`/api/v1/brands/${brandId}/rewards`, data);
136
+ return response.data?.data || response.data;
137
+ },
138
+ onSuccess: () => {
139
+ queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.forBrand(brandId) });
140
+ queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.available() });
141
+ },
142
+ ...options,
143
+ });
144
+ }
145
+ /**
146
+ * Update a partner reward (for business dashboard)
147
+ *
148
+ * @param businessId - Business ID
149
+ *
150
+ * @example
151
+ * ```tsx
152
+ * const updateReward = useUpdatePartnerReward('business-123');
153
+ *
154
+ * const handleUpdate = async (rewardId: string) => {
155
+ * await updateReward.mutateAsync({
156
+ * id: rewardId,
157
+ * data: { title: 'Updated Title', isActive: false },
158
+ * });
159
+ * };
160
+ * ```
161
+ */
162
+ function useUpdatePartnerReward(businessId, options) {
163
+ const queryClient = (0, react_query_1.useQueryClient)();
164
+ return (0, react_query_1.useMutation)({
165
+ mutationFn: async ({ id, data, }) => {
166
+ const client = (0, client_1.getApiClient)();
167
+ const response = await client.patch(`/api/v1/businesses/${businessId}/rewards/${id}`, data);
168
+ return response.data?.data || response.data;
169
+ },
170
+ onSuccess: () => {
171
+ queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.forBusiness(businessId) });
172
+ queryClient.invalidateQueries({ queryKey: badges_1.rewardKeys.available() });
173
+ },
174
+ ...options,
175
+ });
176
+ }
177
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badges.js","sourceRoot":"","sources":["../../../src/api/mutations/badges.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient, UseMutationOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { badgeKeys, rewardKeys } from '../queries/badges';\nimport type {\n  PartnerRewardResponse,\n  PartnerRewardRedemptionResponse,\n  CreatePartnerRewardRequest,\n} from '../types';\n\n// ============================================================================\n// REWARD MUTATION HOOKS\n// ============================================================================\n\n/**\n * Redeem a partner reward\n *\n * @example\n * ```tsx\n * const redeemReward = useRedeemReward();\n *\n * const handleRedeem = async (rewardId: string) => {\n *   await redeemReward.mutateAsync(rewardId);\n *   // Show success message\n * };\n * ```\n */\nexport function useRedeemReward(\n  options?: Omit<UseMutationOptions<PartnerRewardRedemptionResponse, Error, string>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (rewardId: string): Promise<PartnerRewardRedemptionResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/rewards/${rewardId}/redeem`);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      // Invalidate wallet, available and redeemed rewards\n      queryClient.invalidateQueries({ queryKey: rewardKeys.wallet() });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.redeemed() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a partner reward (for business dashboard)\n *\n * @param businessId - Business ID creating the reward\n *\n * @example\n * ```tsx\n * const createReward = useCreatePartnerReward('business-123');\n *\n * const handleCreate = async () => {\n *   await createReward.mutateAsync({\n *     badgeId: 'badge-week-warrior',\n *     title: 'Free Coffee',\n *     description: 'Show your badge for a free coffee',\n *   });\n * };\n * ```\n */\nexport function useCreatePartnerReward(\n  businessId: string,\n  options?: Omit<UseMutationOptions<PartnerRewardResponse, Error, CreatePartnerRewardRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreatePartnerRewardRequest): Promise<PartnerRewardResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/businesses/${businessId}/rewards`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forBusiness(businessId) });\n    },\n    ...options,\n  });\n}\n\n// ============================================================================\n// UNIFIED REWARD MUTATIONS (Venue & Brand)\n// ============================================================================\n\ninterface CreateRewardRequest {\n  badgeId: string;\n  title: string;\n  description?: string;\n  code?: string;\n  redeemType?: 'IN_PERSON' | 'ONLINE' | 'BOTH';\n  maxRedemptions?: number;\n  perUserLimit?: number;\n  validFrom?: string;\n  validUntil?: string;\n}\n\n/**\n * Create a reward for a venue\n *\n * @param venueId - Venue ID\n *\n * @example\n * ```tsx\n * const createReward = useCreateVenueReward('venue-123');\n *\n * const handleCreate = async () => {\n *   await createReward.mutateAsync({\n *     badgeId: 'badge-week-warrior',\n *     title: 'Free Coffee',\n *     description: 'Show your badge for a free coffee',\n *     redeemType: 'IN_PERSON',\n *   });\n * };\n * ```\n */\nexport function useCreateVenueReward(\n  venueId: string,\n  options?: Omit<UseMutationOptions<unknown, Error, CreateRewardRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateRewardRequest) => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/venues/${venueId}/rewards`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forVenue(venueId) });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a reward for a brand\n *\n * @param brandId - Brand ID\n *\n * @example\n * ```tsx\n * const createReward = useCreateBrandReward('brand-123');\n *\n * const handleCreate = async () => {\n *   await createReward.mutateAsync({\n *     badgeId: 'badge-week-warrior',\n *     title: '10% Off',\n *     description: 'Use code at checkout',\n *     code: 'SOBER10',\n *     redeemType: 'ONLINE',\n *   });\n * };\n * ```\n */\nexport function useCreateBrandReward(\n  brandId: string,\n  options?: Omit<UseMutationOptions<unknown, Error, CreateRewardRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateRewardRequest) => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/brands/${brandId}/rewards`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forBrand(brandId) });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Update a partner reward (for business dashboard)\n *\n * @param businessId - Business ID\n *\n * @example\n * ```tsx\n * const updateReward = useUpdatePartnerReward('business-123');\n *\n * const handleUpdate = async (rewardId: string) => {\n *   await updateReward.mutateAsync({\n *     id: rewardId,\n *     data: { title: 'Updated Title', isActive: false },\n *   });\n * };\n * ```\n */\nexport function useUpdatePartnerReward(\n  businessId: string,\n  options?: Omit<\n    UseMutationOptions<\n      PartnerRewardResponse,\n      Error,\n      { id: string; data: Partial<CreatePartnerRewardRequest & { isActive: boolean }> }\n    >,\n    'mutationFn'\n  >\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      id,\n      data,\n    }: {\n      id: string;\n      data: Partial<CreatePartnerRewardRequest & { isActive: boolean }>;\n    }): Promise<PartnerRewardResponse> => {\n      const client = getApiClient();\n      const response = await client.patch(`/api/v1/businesses/${businessId}/rewards/${id}`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: rewardKeys.forBusiness(businessId) });\n      queryClient.invalidateQueries({ queryKey: rewardKeys.available() });\n    },\n    ...options,\n  });\n}\n"]}
@@ -0,0 +1,251 @@
1
+ import { UseMutationOptions } from '@tanstack/react-query';
2
+ import type { BrandResponse, BrandOwnerResponse, BrandCreatorResponse, BrandOwnerRole, CreateBrandRequest, UpdateBrandRequest } from '../types';
3
+ /**
4
+ * Create a new brand
5
+ *
6
+ * @example
7
+ * ```tsx
8
+ * const { mutateAsync: createBrand } = useCreateBrand();
9
+ *
10
+ * await createBrand({
11
+ * slug: 'wellness-co',
12
+ * name: 'Wellness Co',
13
+ * description: 'A wellness brand',
14
+ * });
15
+ * ```
16
+ */
17
+ export declare function useCreateBrand(options?: Omit<UseMutationOptions<BrandResponse, Error, CreateBrandRequest>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
18
+ id: string;
19
+ slug: string;
20
+ name: string;
21
+ description?: Record<string, never>;
22
+ logoUrl?: Record<string, never>;
23
+ bannerUrl?: Record<string, never>;
24
+ primaryColor?: Record<string, never>;
25
+ website?: Record<string, never>;
26
+ email?: Record<string, never>;
27
+ instagram?: Record<string, never>;
28
+ isActive: boolean;
29
+ isVerified: boolean;
30
+ isFeatured: boolean;
31
+ createdAt: string;
32
+ updatedAt: string;
33
+ }, Error, CreateBrandRequest, unknown>;
34
+ /**
35
+ * Update a brand
36
+ *
37
+ * @example
38
+ * ```tsx
39
+ * const { mutateAsync: updateBrand } = useUpdateBrand();
40
+ *
41
+ * await updateBrand({
42
+ * id: 'brand-123',
43
+ * data: { description: 'Updated description' },
44
+ * });
45
+ * ```
46
+ */
47
+ export declare function useUpdateBrand(options?: Omit<UseMutationOptions<BrandResponse, Error, {
48
+ id: string;
49
+ data: UpdateBrandRequest;
50
+ }>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
51
+ id: string;
52
+ slug: string;
53
+ name: string;
54
+ description?: Record<string, never>;
55
+ logoUrl?: Record<string, never>;
56
+ bannerUrl?: Record<string, never>;
57
+ primaryColor?: Record<string, never>;
58
+ website?: Record<string, never>;
59
+ email?: Record<string, never>;
60
+ instagram?: Record<string, never>;
61
+ isActive: boolean;
62
+ isVerified: boolean;
63
+ isFeatured: boolean;
64
+ createdAt: string;
65
+ updatedAt: string;
66
+ }, Error, {
67
+ id: string;
68
+ data: UpdateBrandRequest;
69
+ }, unknown>;
70
+ /**
71
+ * Add a brand owner
72
+ *
73
+ * @example
74
+ * ```tsx
75
+ * const { mutateAsync: addOwner } = useAddBrandOwner();
76
+ *
77
+ * await addOwner({
78
+ * brandId: 'brand-123',
79
+ * userId: 'user-456',
80
+ * role: 'MANAGER',
81
+ * });
82
+ * ```
83
+ */
84
+ export declare function useAddBrandOwner(options?: Omit<UseMutationOptions<BrandOwnerResponse, Error, {
85
+ brandId: string;
86
+ userId: string;
87
+ role: BrandOwnerRole;
88
+ }>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
89
+ id: string;
90
+ brandId: string;
91
+ userId: string;
92
+ role: "OWNER" | "MANAGER" | "MARKETING";
93
+ user?: import("@growsober/types/dist/generated").components["schemas"]["BrandOwnerUserDto"];
94
+ createdAt: string;
95
+ updatedAt: string;
96
+ }, Error, {
97
+ brandId: string;
98
+ userId: string;
99
+ role: BrandOwnerRole;
100
+ }, unknown>;
101
+ /**
102
+ * Update a brand owner's role
103
+ *
104
+ * @example
105
+ * ```tsx
106
+ * const { mutateAsync: updateOwnerRole } = useUpdateBrandOwnerRole();
107
+ *
108
+ * await updateOwnerRole({
109
+ * brandId: 'brand-123',
110
+ * userId: 'user-456',
111
+ * role: 'OWNER',
112
+ * });
113
+ * ```
114
+ */
115
+ export declare function useUpdateBrandOwnerRole(options?: Omit<UseMutationOptions<BrandOwnerResponse, Error, {
116
+ brandId: string;
117
+ userId: string;
118
+ role: BrandOwnerRole;
119
+ }>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
120
+ id: string;
121
+ brandId: string;
122
+ userId: string;
123
+ role: "OWNER" | "MANAGER" | "MARKETING";
124
+ user?: import("@growsober/types/dist/generated").components["schemas"]["BrandOwnerUserDto"];
125
+ createdAt: string;
126
+ updatedAt: string;
127
+ }, Error, {
128
+ brandId: string;
129
+ userId: string;
130
+ role: BrandOwnerRole;
131
+ }, unknown>;
132
+ /**
133
+ * Remove a brand owner
134
+ *
135
+ * @example
136
+ * ```tsx
137
+ * const { mutateAsync: removeOwner } = useRemoveBrandOwner();
138
+ *
139
+ * await removeOwner({
140
+ * brandId: 'brand-123',
141
+ * userId: 'user-456',
142
+ * });
143
+ * ```
144
+ */
145
+ export declare function useRemoveBrandOwner(options?: Omit<UseMutationOptions<void, Error, {
146
+ brandId: string;
147
+ userId: string;
148
+ }>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<void, Error, {
149
+ brandId: string;
150
+ userId: string;
151
+ }, unknown>;
152
+ /**
153
+ * Add a creator partnership to a brand
154
+ *
155
+ * @example
156
+ * ```tsx
157
+ * const { mutateAsync: addCreator } = useAddBrandCreator();
158
+ *
159
+ * await addCreator({
160
+ * brandId: 'brand-123',
161
+ * creatorId: 'creator-456',
162
+ * commissionRate: 0.15,
163
+ * });
164
+ * ```
165
+ */
166
+ export declare function useAddBrandCreator(options?: Omit<UseMutationOptions<BrandCreatorResponse, Error, {
167
+ brandId: string;
168
+ creatorId: string;
169
+ startDate?: string;
170
+ endDate?: string;
171
+ commissionRate?: number;
172
+ isActive?: boolean;
173
+ }>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
174
+ id: string;
175
+ brandId: string;
176
+ creatorId: string;
177
+ startDate?: string;
178
+ endDate?: string;
179
+ isActive: boolean;
180
+ commissionRate?: number;
181
+ creator?: Record<string, never>;
182
+ createdAt: string;
183
+ updatedAt: string;
184
+ }, Error, {
185
+ brandId: string;
186
+ creatorId: string;
187
+ startDate?: string;
188
+ endDate?: string;
189
+ commissionRate?: number;
190
+ isActive?: boolean;
191
+ }, unknown>;
192
+ /**
193
+ * Update a creator partnership
194
+ *
195
+ * @example
196
+ * ```tsx
197
+ * const { mutateAsync: updateCreator } = useUpdateBrandCreator();
198
+ *
199
+ * await updateCreator({
200
+ * brandId: 'brand-123',
201
+ * creatorId: 'creator-456',
202
+ * isActive: false,
203
+ * });
204
+ * ```
205
+ */
206
+ export declare function useUpdateBrandCreator(options?: Omit<UseMutationOptions<BrandCreatorResponse, Error, {
207
+ brandId: string;
208
+ creatorId: string;
209
+ startDate?: string;
210
+ endDate?: string;
211
+ commissionRate?: number;
212
+ isActive?: boolean;
213
+ }>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<{
214
+ id: string;
215
+ brandId: string;
216
+ creatorId: string;
217
+ startDate?: string;
218
+ endDate?: string;
219
+ isActive: boolean;
220
+ commissionRate?: number;
221
+ creator?: Record<string, never>;
222
+ createdAt: string;
223
+ updatedAt: string;
224
+ }, Error, {
225
+ brandId: string;
226
+ creatorId: string;
227
+ startDate?: string;
228
+ endDate?: string;
229
+ commissionRate?: number;
230
+ isActive?: boolean;
231
+ }, unknown>;
232
+ /**
233
+ * Remove a creator partnership from a brand
234
+ *
235
+ * @example
236
+ * ```tsx
237
+ * const { mutateAsync: removeCreator } = useRemoveBrandCreator();
238
+ *
239
+ * await removeCreator({
240
+ * brandId: 'brand-123',
241
+ * creatorId: 'creator-456',
242
+ * });
243
+ * ```
244
+ */
245
+ export declare function useRemoveBrandCreator(options?: Omit<UseMutationOptions<void, Error, {
246
+ brandId: string;
247
+ creatorId: string;
248
+ }>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<void, Error, {
249
+ brandId: string;
250
+ creatorId: string;
251
+ }, unknown>;