@growsober/sdk 1.0.11 → 1.0.14

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.
@@ -129,3 +129,41 @@ export declare function useRemoveCreatorAvailability(options?: Omit<UseMutationO
129
129
  creatorId: string;
130
130
  availabilityId: string;
131
131
  }, unknown>;
132
+ export interface CreateCreatorRewardRequest {
133
+ badgeId: string;
134
+ title: string;
135
+ description: string;
136
+ redeemType: 'IN_PERSON' | 'ONLINE' | 'BOTH';
137
+ code?: string;
138
+ maxRedemptions?: number;
139
+ validUntil?: string;
140
+ }
141
+ export interface CreatorRewardResponse {
142
+ id: string;
143
+ creatorId: string;
144
+ badgeId: string;
145
+ title: string;
146
+ description: string;
147
+ redeemType: 'IN_PERSON' | 'ONLINE' | 'BOTH';
148
+ code?: string;
149
+ maxRedemptions?: number;
150
+ validUntil?: string;
151
+ createdAt: string;
152
+ updatedAt: string;
153
+ }
154
+ /**
155
+ * Create a new reward for a creator
156
+ *
157
+ * @example
158
+ * ```tsx
159
+ * const createReward = useCreateCreatorReward(creatorId);
160
+ *
161
+ * await createReward.mutateAsync({
162
+ * badgeId: 'badge-123',
163
+ * title: 'Free Session',
164
+ * description: 'Get a free 30-minute session',
165
+ * redeemType: 'IN_PERSON',
166
+ * });
167
+ * ```
168
+ */
169
+ export declare function useCreateCreatorReward(creatorId: string): import("@tanstack/react-query").UseMutationResult<CreatorRewardResponse, Error, CreateCreatorRewardRequest, unknown>;
@@ -4,6 +4,7 @@ exports.useCreateCreator = useCreateCreator;
4
4
  exports.useUpdateCreator = useUpdateCreator;
5
5
  exports.useAddCreatorAvailability = useAddCreatorAvailability;
6
6
  exports.useRemoveCreatorAvailability = useRemoveCreatorAvailability;
7
+ exports.useCreateCreatorReward = useCreateCreatorReward;
7
8
  const react_query_1 = require("@tanstack/react-query");
8
9
  const client_1 = require("../client");
9
10
  const creators_1 = require("../queries/creators");
@@ -126,4 +127,33 @@ function useRemoveCreatorAvailability(options) {
126
127
  ...options,
127
128
  });
128
129
  }
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"]}
130
+ /**
131
+ * Create a new reward for a creator
132
+ *
133
+ * @example
134
+ * ```tsx
135
+ * const createReward = useCreateCreatorReward(creatorId);
136
+ *
137
+ * await createReward.mutateAsync({
138
+ * badgeId: 'badge-123',
139
+ * title: 'Free Session',
140
+ * description: 'Get a free 30-minute session',
141
+ * redeemType: 'IN_PERSON',
142
+ * });
143
+ * ```
144
+ */
145
+ function useCreateCreatorReward(creatorId) {
146
+ const queryClient = (0, react_query_1.useQueryClient)();
147
+ return (0, react_query_1.useMutation)({
148
+ mutationFn: async (data) => {
149
+ const client = (0, client_1.getApiClient)();
150
+ const response = await client.post(`/api/v1/creators/${creatorId}/rewards`, data);
151
+ return response.data;
152
+ },
153
+ onSuccess: () => {
154
+ queryClient.invalidateQueries({ queryKey: creators_1.creatorKeys.detail(creatorId) });
155
+ queryClient.invalidateQueries({ queryKey: ['creator-rewards', creatorId] });
156
+ },
157
+ });
158
+ }
159
+ //# 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\n// ============================================================================\n// CREATOR REWARDS\n// ============================================================================\n\nexport interface CreateCreatorRewardRequest {\n  badgeId: string;\n  title: string;\n  description: string;\n  redeemType: 'IN_PERSON' | 'ONLINE' | 'BOTH';\n  code?: string;\n  maxRedemptions?: number;\n  validUntil?: string;\n}\n\nexport interface CreatorRewardResponse {\n  id: string;\n  creatorId: string;\n  badgeId: string;\n  title: string;\n  description: string;\n  redeemType: 'IN_PERSON' | 'ONLINE' | 'BOTH';\n  code?: string;\n  maxRedemptions?: number;\n  validUntil?: string;\n  createdAt: string;\n  updatedAt: string;\n}\n\n/**\n * Create a new reward for a creator\n *\n * @example\n * ```tsx\n * const createReward = useCreateCreatorReward(creatorId);\n *\n * await createReward.mutateAsync({\n *   badgeId: 'badge-123',\n *   title: 'Free Session',\n *   description: 'Get a free 30-minute session',\n *   redeemType: 'IN_PERSON',\n * });\n * ```\n */\nexport function useCreateCreatorReward(creatorId: string) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateCreatorRewardRequest): Promise<CreatorRewardResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/rewards`, data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: creatorKeys.detail(creatorId) });\n      queryClient.invalidateQueries({ queryKey: ['creator-rewards', creatorId] });\n    },\n  });\n}\n"]}
@@ -26,3 +26,4 @@ export * from './creators';
26
26
  export * from './brands';
27
27
  export * from './products';
28
28
  export * from './venues';
29
+ export * from './stripe-connect';
@@ -42,4 +42,5 @@ __exportStar(require("./creators"), exports);
42
42
  __exportStar(require("./brands"), exports);
43
43
  __exportStar(require("./products"), exports);
44
44
  __exportStar(require("./venues"), exports);
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL211dGF0aW9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7R0FJRzs7Ozs7Ozs7Ozs7Ozs7OztBQUVILDBDQUF3QjtBQUN4Qix5Q0FBdUI7QUFDdkIsNkNBQTJCO0FBQzNCLDJDQUF5QjtBQUN6Qix5Q0FBdUI7QUFDdkIsNENBQTBCO0FBQzFCLHdDQUFzQjtBQUN0QixrREFBZ0M7QUFDaEMsMkNBQXlCO0FBQ3pCLGtEQUFnQztBQUNoQyw0Q0FBMEI7QUFDMUIsMENBQXdCO0FBQ3hCLHlDQUF1QjtBQUN2QixnREFBOEI7QUFDOUIsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQiwrQ0FBNkI7QUFDN0IsOENBQTRCO0FBQzVCLDJDQUF5QjtBQUN6Qiw2Q0FBMkI7QUFDM0IsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQiwyQ0FBeUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIE11dGF0aW9uIEhvb2tzXG4gKlxuICogUmUtZXhwb3J0cyBhbGwgbXV0YXRpb24gaG9va3MgZm9yIEFQSSBlbmRwb2ludHMuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9hZG1pbic7XG5leHBvcnQgKiBmcm9tICcuL2F1dGgnO1xuZXhwb3J0ICogZnJvbSAnLi9ib29raW5ncyc7XG5leHBvcnQgKiBmcm9tICcuL2V2ZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2h1YnMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWJyYXJ5JztcbmV4cG9ydCAqIGZyb20gJy4vbWFwJztcbmV4cG9ydCAqIGZyb20gJy4vbm90aWZpY2F0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL29mZmVycyc7XG5leHBvcnQgKiBmcm9tICcuL3N1YnNjcmlwdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdXBwb3J0JztcbmV4cG9ydCAqIGZyb20gJy4vdXNlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9qYWNrJztcbmV4cG9ydCAqIGZyb20gJy4vYW1iYXNzYWRvcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9ncm93OTAnO1xuZXhwb3J0ICogZnJvbSAnLi9tYXRjaGluZyc7XG5leHBvcnQgKiBmcm9tICcuL2V2ZW50LWNoYXQnO1xuZXhwb3J0ICogZnJvbSAnLi91c2VyLXBpbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9iYWRnZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9jcmVhdG9ycyc7XG5leHBvcnQgKiBmcm9tICcuL2JyYW5kcyc7XG5leHBvcnQgKiBmcm9tICcuL3Byb2R1Y3RzJztcbmV4cG9ydCAqIGZyb20gJy4vdmVudWVzJztcbiJdfQ==
45
+ __exportStar(require("./stripe-connect"), exports);
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL211dGF0aW9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7R0FJRzs7Ozs7Ozs7Ozs7Ozs7OztBQUVILDBDQUF3QjtBQUN4Qix5Q0FBdUI7QUFDdkIsNkNBQTJCO0FBQzNCLDJDQUF5QjtBQUN6Qix5Q0FBdUI7QUFDdkIsNENBQTBCO0FBQzFCLHdDQUFzQjtBQUN0QixrREFBZ0M7QUFDaEMsMkNBQXlCO0FBQ3pCLGtEQUFnQztBQUNoQyw0Q0FBMEI7QUFDMUIsMENBQXdCO0FBQ3hCLHlDQUF1QjtBQUN2QixnREFBOEI7QUFDOUIsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQiwrQ0FBNkI7QUFDN0IsOENBQTRCO0FBQzVCLDJDQUF5QjtBQUN6Qiw2Q0FBMkI7QUFDM0IsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQiwyQ0FBeUI7QUFDekIsbURBQWlDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBNdXRhdGlvbiBIb29rc1xuICpcbiAqIFJlLWV4cG9ydHMgYWxsIG11dGF0aW9uIGhvb2tzIGZvciBBUEkgZW5kcG9pbnRzLlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vYWRtaW4nO1xuZXhwb3J0ICogZnJvbSAnLi9hdXRoJztcbmV4cG9ydCAqIGZyb20gJy4vYm9va2luZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi9ldmVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9odWJzJztcbmV4cG9ydCAqIGZyb20gJy4vbGlicmFyeSc7XG5leHBvcnQgKiBmcm9tICcuL21hcCc7XG5leHBvcnQgKiBmcm9tICcuL25vdGlmaWNhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9vZmZlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdWJzY3JpcHRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vc3VwcG9ydCc7XG5leHBvcnQgKiBmcm9tICcuL3VzZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vamFjayc7XG5leHBvcnQgKiBmcm9tICcuL2FtYmFzc2Fkb3JzJztcbmV4cG9ydCAqIGZyb20gJy4vZ3JvdzkwJztcbmV4cG9ydCAqIGZyb20gJy4vbWF0Y2hpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi9ldmVudC1jaGF0JztcbmV4cG9ydCAqIGZyb20gJy4vdXNlci1waW5zJztcbmV4cG9ydCAqIGZyb20gJy4vYmFkZ2VzJztcbmV4cG9ydCAqIGZyb20gJy4vY3JlYXRvcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9icmFuZHMnO1xuZXhwb3J0ICogZnJvbSAnLi9wcm9kdWN0cyc7XG5leHBvcnQgKiBmcm9tICcuL3ZlbnVlcyc7XG5leHBvcnQgKiBmcm9tICcuL3N0cmlwZS1jb25uZWN0JztcbiJdfQ==
@@ -0,0 +1,9 @@
1
+ export interface OnboardingLinkResponse {
2
+ url: string;
3
+ }
4
+ export interface DashboardLinkResponse {
5
+ url: string;
6
+ }
7
+ export declare function useStartStripeOnboarding(): import("@tanstack/react-query").UseMutationResult<OnboardingLinkResponse, Error, void, unknown>;
8
+ export declare function useRefreshStripeOnboarding(): import("@tanstack/react-query").UseMutationResult<OnboardingLinkResponse, Error, void, unknown>;
9
+ export declare function useGetStripeDashboard(): import("@tanstack/react-query").UseMutationResult<DashboardLinkResponse, Error, void, unknown>;
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useStartStripeOnboarding = useStartStripeOnboarding;
4
+ exports.useRefreshStripeOnboarding = useRefreshStripeOnboarding;
5
+ exports.useGetStripeDashboard = useGetStripeDashboard;
6
+ const react_query_1 = require("@tanstack/react-query");
7
+ const client_1 = require("../client");
8
+ // ============================================================================
9
+ // HOOKS
10
+ // ============================================================================
11
+ function useStartStripeOnboarding() {
12
+ return (0, react_query_1.useMutation)({
13
+ mutationFn: async () => {
14
+ const response = await (0, client_1.getApiClient)().post('/creators/me/stripe-connect/onboard');
15
+ return response.data;
16
+ },
17
+ });
18
+ }
19
+ function useRefreshStripeOnboarding() {
20
+ return (0, react_query_1.useMutation)({
21
+ mutationFn: async () => {
22
+ const response = await (0, client_1.getApiClient)().post('/creators/me/stripe-connect/refresh');
23
+ return response.data;
24
+ },
25
+ });
26
+ }
27
+ function useGetStripeDashboard() {
28
+ return (0, react_query_1.useMutation)({
29
+ mutationFn: async () => {
30
+ const response = await (0, client_1.getApiClient)().get('/creators/me/stripe-connect/dashboard');
31
+ return response.data;
32
+ },
33
+ });
34
+ }
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyaXBlLWNvbm5lY3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL211dGF0aW9ucy9zdHJpcGUtY29ubmVjdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQW1CQSw0REFPQztBQUVELGdFQU9DO0FBRUQsc0RBT0M7QUE1Q0QsdURBQW9EO0FBQ3BELHNDQUF5QztBQWN6QywrRUFBK0U7QUFDL0UsUUFBUTtBQUNSLCtFQUErRTtBQUUvRSxTQUFnQix3QkFBd0I7SUFDdEMsT0FBTyxJQUFBLHlCQUFXLEVBQUM7UUFDakIsVUFBVSxFQUFFLEtBQUssSUFBSSxFQUFFO1lBQ3JCLE1BQU0sUUFBUSxHQUFHLE1BQU0sSUFBQSxxQkFBWSxHQUFFLENBQUMsSUFBSSxDQUF5QixxQ0FBcUMsQ0FBQyxDQUFDO1lBQzFHLE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQztRQUN2QixDQUFDO0tBQ0YsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQUVELFNBQWdCLDBCQUEwQjtJQUN4QyxPQUFPLElBQUEseUJBQVcsRUFBQztRQUNqQixVQUFVLEVBQUUsS0FBSyxJQUFJLEVBQUU7WUFDckIsTUFBTSxRQUFRLEdBQUcsTUFBTSxJQUFBLHFCQUFZLEdBQUUsQ0FBQyxJQUFJLENBQXlCLHFDQUFxQyxDQUFDLENBQUM7WUFDMUcsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDO1FBQ3ZCLENBQUM7S0FDRixDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQsU0FBZ0IscUJBQXFCO0lBQ25DLE9BQU8sSUFBQSx5QkFBVyxFQUFDO1FBQ2pCLFVBQVUsRUFBRSxLQUFLLElBQUksRUFBRTtZQUNyQixNQUFNLFFBQVEsR0FBRyxNQUFNLElBQUEscUJBQVksR0FBRSxDQUFDLEdBQUcsQ0FBd0IsdUNBQXVDLENBQUMsQ0FBQztZQUMxRyxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUM7UUFDdkIsQ0FBQztLQUNGLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VNdXRhdGlvbiB9IGZyb20gJ0B0YW5zdGFjay9yZWFjdC1xdWVyeSc7XG5pbXBvcnQgeyBnZXRBcGlDbGllbnQgfSBmcm9tICcuLi9jbGllbnQnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBUWVBFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5leHBvcnQgaW50ZXJmYWNlIE9uYm9hcmRpbmdMaW5rUmVzcG9uc2Uge1xuICB1cmw6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEYXNoYm9hcmRMaW5rUmVzcG9uc2Uge1xuICB1cmw6IHN0cmluZztcbn1cblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gSE9PS1Ncbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGZ1bmN0aW9uIHVzZVN0YXJ0U3RyaXBlT25ib2FyZGluZygpIHtcbiAgcmV0dXJuIHVzZU11dGF0aW9uKHtcbiAgICBtdXRhdGlvbkZuOiBhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGdldEFwaUNsaWVudCgpLnBvc3Q8T25ib2FyZGluZ0xpbmtSZXNwb25zZT4oJy9jcmVhdG9ycy9tZS9zdHJpcGUtY29ubmVjdC9vbmJvYXJkJyk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YTtcbiAgICB9LFxuICB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVzZVJlZnJlc2hTdHJpcGVPbmJvYXJkaW5nKCkge1xuICByZXR1cm4gdXNlTXV0YXRpb24oe1xuICAgIG11dGF0aW9uRm46IGFzeW5jICgpID0+IHtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZ2V0QXBpQ2xpZW50KCkucG9zdDxPbmJvYXJkaW5nTGlua1Jlc3BvbnNlPignL2NyZWF0b3JzL21lL3N0cmlwZS1jb25uZWN0L3JlZnJlc2gnKTtcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhO1xuICAgIH0sXG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdXNlR2V0U3RyaXBlRGFzaGJvYXJkKCkge1xuICByZXR1cm4gdXNlTXV0YXRpb24oe1xuICAgIG11dGF0aW9uRm46IGFzeW5jICgpID0+IHtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZ2V0QXBpQ2xpZW50KCkuZ2V0PERhc2hib2FyZExpbmtSZXNwb25zZT4oJy9jcmVhdG9ycy9tZS9zdHJpcGUtY29ubmVjdC9kYXNoYm9hcmQnKTtcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhO1xuICAgIH0sXG4gIH0pO1xufVxuIl19
@@ -28,3 +28,4 @@ export * from './venues';
28
28
  export * from './creators';
29
29
  export * from './brands';
30
30
  export * from './products';
31
+ export * from './stripe-connect';
@@ -44,4 +44,5 @@ __exportStar(require("./venues"), exports);
44
44
  __exportStar(require("./creators"), exports);
45
45
  __exportStar(require("./brands"), exports);
46
46
  __exportStar(require("./products"), exports);
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3F1ZXJpZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7O0dBSUc7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFSCwwQ0FBd0I7QUFDeEIseUNBQXVCO0FBQ3ZCLDZDQUEyQjtBQUMzQiwrQ0FBNkI7QUFDN0IsMkNBQXlCO0FBQ3pCLDJDQUF5QjtBQUN6Qix5Q0FBdUI7QUFDdkIsNENBQTBCO0FBQzFCLHdDQUFzQjtBQUN0QixrREFBZ0M7QUFDaEMsMkNBQXlCO0FBQ3pCLGtEQUFnQztBQUNoQyw0Q0FBMEI7QUFDMUIsMENBQXdCO0FBQ3hCLHlDQUF1QjtBQUN2QixnREFBOEI7QUFDOUIsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQiwrQ0FBNkI7QUFDN0IsOENBQTRCO0FBQzVCLDJDQUF5QjtBQUN6QiwyQ0FBeUI7QUFDekIsNkNBQTJCO0FBQzNCLDJDQUF5QjtBQUN6Qiw2Q0FBMkIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFF1ZXJ5IEhvb2tzXG4gKlxuICogUmUtZXhwb3J0cyBhbGwgcXVlcnkgaG9va3MgZm9yIEFQSSBlbmRwb2ludHMuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9hZG1pbic7XG5leHBvcnQgKiBmcm9tICcuL2F1dGgnO1xuZXhwb3J0ICogZnJvbSAnLi9ib29raW5ncyc7XG5leHBvcnQgKiBmcm9tICcuL2J1c2luZXNzZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9jaXRpZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9ldmVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9odWJzJztcbmV4cG9ydCAqIGZyb20gJy4vbGlicmFyeSc7XG5leHBvcnQgKiBmcm9tICcuL21hcCc7XG5leHBvcnQgKiBmcm9tICcuL25vdGlmaWNhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9vZmZlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdWJzY3JpcHRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vc3VwcG9ydCc7XG5leHBvcnQgKiBmcm9tICcuL3VzZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vamFjayc7XG5leHBvcnQgKiBmcm9tICcuL2FtYmFzc2Fkb3JzJztcbmV4cG9ydCAqIGZyb20gJy4vZ3JvdzkwJztcbmV4cG9ydCAqIGZyb20gJy4vbWF0Y2hpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi9ldmVudC1jaGF0JztcbmV4cG9ydCAqIGZyb20gJy4vdXNlci1waW5zJztcbmV4cG9ydCAqIGZyb20gJy4vYmFkZ2VzJztcbmV4cG9ydCAqIGZyb20gJy4vdmVudWVzJztcbmV4cG9ydCAqIGZyb20gJy4vY3JlYXRvcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9icmFuZHMnO1xuZXhwb3J0ICogZnJvbSAnLi9wcm9kdWN0cyc7XG4iXX0=
47
+ __exportStar(require("./stripe-connect"), exports);
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3F1ZXJpZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7O0dBSUc7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFSCwwQ0FBd0I7QUFDeEIseUNBQXVCO0FBQ3ZCLDZDQUEyQjtBQUMzQiwrQ0FBNkI7QUFDN0IsMkNBQXlCO0FBQ3pCLDJDQUF5QjtBQUN6Qix5Q0FBdUI7QUFDdkIsNENBQTBCO0FBQzFCLHdDQUFzQjtBQUN0QixrREFBZ0M7QUFDaEMsMkNBQXlCO0FBQ3pCLGtEQUFnQztBQUNoQyw0Q0FBMEI7QUFDMUIsMENBQXdCO0FBQ3hCLHlDQUF1QjtBQUN2QixnREFBOEI7QUFDOUIsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQiwrQ0FBNkI7QUFDN0IsOENBQTRCO0FBQzVCLDJDQUF5QjtBQUN6QiwyQ0FBeUI7QUFDekIsNkNBQTJCO0FBQzNCLDJDQUF5QjtBQUN6Qiw2Q0FBMkI7QUFDM0IsbURBQWlDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBRdWVyeSBIb29rc1xuICpcbiAqIFJlLWV4cG9ydHMgYWxsIHF1ZXJ5IGhvb2tzIGZvciBBUEkgZW5kcG9pbnRzLlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vYWRtaW4nO1xuZXhwb3J0ICogZnJvbSAnLi9hdXRoJztcbmV4cG9ydCAqIGZyb20gJy4vYm9va2luZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi9idXNpbmVzc2VzJztcbmV4cG9ydCAqIGZyb20gJy4vY2l0aWVzJztcbmV4cG9ydCAqIGZyb20gJy4vZXZlbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vaHVicyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYnJhcnknO1xuZXhwb3J0ICogZnJvbSAnLi9tYXAnO1xuZXhwb3J0ICogZnJvbSAnLi9ub3RpZmljYXRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vb2ZmZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vc3Vic2NyaXB0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL3N1cHBvcnQnO1xuZXhwb3J0ICogZnJvbSAnLi91c2Vycyc7XG5leHBvcnQgKiBmcm9tICcuL2phY2snO1xuZXhwb3J0ICogZnJvbSAnLi9hbWJhc3NhZG9ycyc7XG5leHBvcnQgKiBmcm9tICcuL2dyb3c5MCc7XG5leHBvcnQgKiBmcm9tICcuL21hdGNoaW5nJztcbmV4cG9ydCAqIGZyb20gJy4vZXZlbnQtY2hhdCc7XG5leHBvcnQgKiBmcm9tICcuL3VzZXItcGlucyc7XG5leHBvcnQgKiBmcm9tICcuL2JhZGdlcyc7XG5leHBvcnQgKiBmcm9tICcuL3ZlbnVlcyc7XG5leHBvcnQgKiBmcm9tICcuL2NyZWF0b3JzJztcbmV4cG9ydCAqIGZyb20gJy4vYnJhbmRzJztcbmV4cG9ydCAqIGZyb20gJy4vcHJvZHVjdHMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdHJpcGUtY29ubmVjdCc7XG4iXX0=
@@ -0,0 +1,37 @@
1
+ export type StripeConnectStatus = 'ACTIVE' | 'ONBOARDING' | 'RESTRICTED' | 'DISABLED' | 'PENDING';
2
+ export interface StripeAccountStatus {
3
+ status: StripeConnectStatus;
4
+ chargesEnabled: boolean;
5
+ payoutsEnabled: boolean;
6
+ detailsSubmitted: boolean;
7
+ createdAt?: string;
8
+ }
9
+ export interface EarningsSummary {
10
+ totalEarnings: number;
11
+ pendingEarnings: number;
12
+ availableBalance: number;
13
+ currency: string;
14
+ }
15
+ export interface EarningsHistoryItem {
16
+ id: string;
17
+ amount: number;
18
+ currency: string;
19
+ status: string;
20
+ paidAt: string;
21
+ eventTitle?: string;
22
+ }
23
+ export interface EarningsResponse {
24
+ summary: EarningsSummary;
25
+ history: EarningsHistoryItem[];
26
+ }
27
+ export declare const stripeConnectKeys: {
28
+ all: readonly ["stripe-connect"];
29
+ status: () => readonly ["stripe-connect", "status"];
30
+ earnings: () => readonly ["stripe-connect", "earnings"];
31
+ };
32
+ export declare function useStripeConnectStatus(options?: {
33
+ enabled?: boolean;
34
+ }): import("@tanstack/react-query").UseQueryResult<StripeAccountStatus, Error>;
35
+ export declare function useCreatorEarnings(options?: {
36
+ enabled?: boolean;
37
+ }): import("@tanstack/react-query").UseQueryResult<EarningsResponse, Error>;
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.stripeConnectKeys = void 0;
4
+ exports.useStripeConnectStatus = useStripeConnectStatus;
5
+ exports.useCreatorEarnings = useCreatorEarnings;
6
+ const react_query_1 = require("@tanstack/react-query");
7
+ const client_1 = require("../client");
8
+ // ============================================================================
9
+ // QUERY KEYS
10
+ // ============================================================================
11
+ exports.stripeConnectKeys = {
12
+ all: ['stripe-connect'],
13
+ status: () => [...exports.stripeConnectKeys.all, 'status'],
14
+ earnings: () => [...exports.stripeConnectKeys.all, 'earnings'],
15
+ };
16
+ // ============================================================================
17
+ // HOOKS
18
+ // ============================================================================
19
+ function useStripeConnectStatus(options) {
20
+ return (0, react_query_1.useQuery)({
21
+ queryKey: exports.stripeConnectKeys.status(),
22
+ queryFn: async () => {
23
+ const response = await (0, client_1.getApiClient)().get('/creators/me/stripe-connect/status');
24
+ return response.data;
25
+ },
26
+ enabled: options?.enabled ?? true,
27
+ });
28
+ }
29
+ function useCreatorEarnings(options) {
30
+ return (0, react_query_1.useQuery)({
31
+ queryKey: exports.stripeConnectKeys.earnings(),
32
+ queryFn: async () => {
33
+ const response = await (0, client_1.getApiClient)().get('/creators/me/stripe-connect/earnings');
34
+ return response.data;
35
+ },
36
+ enabled: options?.enabled ?? true,
37
+ });
38
+ }
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyaXBlLWNvbm5lY3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3F1ZXJpZXMvc3RyaXBlLWNvbm5lY3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBb0RBLHdEQVNDO0FBRUQsZ0RBU0M7QUF4RUQsdURBQWlEO0FBQ2pELHNDQUF5QztBQXFDekMsK0VBQStFO0FBQy9FLGFBQWE7QUFDYiwrRUFBK0U7QUFFbEUsUUFBQSxpQkFBaUIsR0FBRztJQUMvQixHQUFHLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBVTtJQUNoQyxNQUFNLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxHQUFHLHlCQUFpQixDQUFDLEdBQUcsRUFBRSxRQUFRLENBQVU7SUFDM0QsUUFBUSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsR0FBRyx5QkFBaUIsQ0FBQyxHQUFHLEVBQUUsVUFBVSxDQUFVO0NBQ2hFLENBQUM7QUFFRiwrRUFBK0U7QUFDL0UsUUFBUTtBQUNSLCtFQUErRTtBQUUvRSxTQUFnQixzQkFBc0IsQ0FBQyxPQUErQjtJQUNwRSxPQUFPLElBQUEsc0JBQVEsRUFBQztRQUNkLFFBQVEsRUFBRSx5QkFBaUIsQ0FBQyxNQUFNLEVBQUU7UUFDcEMsT0FBTyxFQUFFLEtBQUssSUFBSSxFQUFFO1lBQ2xCLE1BQU0sUUFBUSxHQUFHLE1BQU0sSUFBQSxxQkFBWSxHQUFFLENBQUMsR0FBRyxDQUFzQixvQ0FBb0MsQ0FBQyxDQUFDO1lBQ3JHLE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQztRQUN2QixDQUFDO1FBQ0QsT0FBTyxFQUFFLE9BQU8sRUFBRSxPQUFPLElBQUksSUFBSTtLQUNsQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQsU0FBZ0Isa0JBQWtCLENBQUMsT0FBK0I7SUFDaEUsT0FBTyxJQUFBLHNCQUFRLEVBQUM7UUFDZCxRQUFRLEVBQUUseUJBQWlCLENBQUMsUUFBUSxFQUFFO1FBQ3RDLE9BQU8sRUFBRSxLQUFLLElBQUksRUFBRTtZQUNsQixNQUFNLFFBQVEsR0FBRyxNQUFNLElBQUEscUJBQVksR0FBRSxDQUFDLEdBQUcsQ0FBbUIsc0NBQXNDLENBQUMsQ0FBQztZQUNwRyxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUM7UUFDdkIsQ0FBQztRQUNELE9BQU8sRUFBRSxPQUFPLEVBQUUsT0FBTyxJQUFJLElBQUk7S0FDbEMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZVF1ZXJ5IH0gZnJvbSAnQHRhbnN0YWNrL3JlYWN0LXF1ZXJ5JztcbmltcG9ydCB7IGdldEFwaUNsaWVudCB9IGZyb20gJy4uL2NsaWVudCc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFRZUEVTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCB0eXBlIFN0cmlwZUNvbm5lY3RTdGF0dXMgPSAnQUNUSVZFJyB8ICdPTkJPQVJESU5HJyB8ICdSRVNUUklDVEVEJyB8ICdESVNBQkxFRCcgfCAnUEVORElORyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3RyaXBlQWNjb3VudFN0YXR1cyB7XG4gIHN0YXR1czogU3RyaXBlQ29ubmVjdFN0YXR1cztcbiAgY2hhcmdlc0VuYWJsZWQ6IGJvb2xlYW47XG4gIHBheW91dHNFbmFibGVkOiBib29sZWFuO1xuICBkZXRhaWxzU3VibWl0dGVkOiBib29sZWFuO1xuICBjcmVhdGVkQXQ/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRWFybmluZ3NTdW1tYXJ5IHtcbiAgdG90YWxFYXJuaW5nczogbnVtYmVyO1xuICBwZW5kaW5nRWFybmluZ3M6IG51bWJlcjtcbiAgYXZhaWxhYmxlQmFsYW5jZTogbnVtYmVyO1xuICBjdXJyZW5jeTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVhcm5pbmdzSGlzdG9yeUl0ZW0ge1xuICBpZDogc3RyaW5nO1xuICBhbW91bnQ6IG51bWJlcjtcbiAgY3VycmVuY3k6IHN0cmluZztcbiAgc3RhdHVzOiBzdHJpbmc7XG4gIHBhaWRBdDogc3RyaW5nO1xuICBldmVudFRpdGxlPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVhcm5pbmdzUmVzcG9uc2Uge1xuICBzdW1tYXJ5OiBFYXJuaW5nc1N1bW1hcnk7XG4gIGhpc3Rvcnk6IEVhcm5pbmdzSGlzdG9yeUl0ZW1bXTtcbn1cblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gUVVFUlkgS0VZU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5leHBvcnQgY29uc3Qgc3RyaXBlQ29ubmVjdEtleXMgPSB7XG4gIGFsbDogWydzdHJpcGUtY29ubmVjdCddIGFzIGNvbnN0LFxuICBzdGF0dXM6ICgpID0+IFsuLi5zdHJpcGVDb25uZWN0S2V5cy5hbGwsICdzdGF0dXMnXSBhcyBjb25zdCxcbiAgZWFybmluZ3M6ICgpID0+IFsuLi5zdHJpcGVDb25uZWN0S2V5cy5hbGwsICdlYXJuaW5ncyddIGFzIGNvbnN0LFxufTtcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gSE9PS1Ncbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGZ1bmN0aW9uIHVzZVN0cmlwZUNvbm5lY3RTdGF0dXMob3B0aW9ucz86IHsgZW5hYmxlZD86IGJvb2xlYW4gfSkge1xuICByZXR1cm4gdXNlUXVlcnkoe1xuICAgIHF1ZXJ5S2V5OiBzdHJpcGVDb25uZWN0S2V5cy5zdGF0dXMoKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGdldEFwaUNsaWVudCgpLmdldDxTdHJpcGVBY2NvdW50U3RhdHVzPignL2NyZWF0b3JzL21lL3N0cmlwZS1jb25uZWN0L3N0YXR1cycpO1xuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGE7XG4gICAgfSxcbiAgICBlbmFibGVkOiBvcHRpb25zPy5lbmFibGVkID8/IHRydWUsXG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdXNlQ3JlYXRvckVhcm5pbmdzKG9wdGlvbnM/OiB7IGVuYWJsZWQ/OiBib29sZWFuIH0pIHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogc3RyaXBlQ29ubmVjdEtleXMuZWFybmluZ3MoKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGdldEFwaUNsaWVudCgpLmdldDxFYXJuaW5nc1Jlc3BvbnNlPignL2NyZWF0b3JzL21lL3N0cmlwZS1jb25uZWN0L2Vhcm5pbmdzJyk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YTtcbiAgICB9LFxuICAgIGVuYWJsZWQ6IG9wdGlvbnM/LmVuYWJsZWQgPz8gdHJ1ZSxcbiAgfSk7XG59XG4iXX0=
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@growsober/sdk",
3
- "version": "1.0.11",
3
+ "version": "1.0.14",
4
4
  "description": "Shared TypeScript SDK for GrowSober API - TanStack Query hooks, API client, and utilities",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.js",
@@ -169,3 +169,62 @@ export function useRemoveCreatorAvailability(
169
169
  ...options,
170
170
  });
171
171
  }
172
+
173
+ // ============================================================================
174
+ // CREATOR REWARDS
175
+ // ============================================================================
176
+
177
+ export interface CreateCreatorRewardRequest {
178
+ badgeId: string;
179
+ title: string;
180
+ description: string;
181
+ redeemType: 'IN_PERSON' | 'ONLINE' | 'BOTH';
182
+ code?: string;
183
+ maxRedemptions?: number;
184
+ validUntil?: string;
185
+ }
186
+
187
+ export interface CreatorRewardResponse {
188
+ id: string;
189
+ creatorId: string;
190
+ badgeId: string;
191
+ title: string;
192
+ description: string;
193
+ redeemType: 'IN_PERSON' | 'ONLINE' | 'BOTH';
194
+ code?: string;
195
+ maxRedemptions?: number;
196
+ validUntil?: string;
197
+ createdAt: string;
198
+ updatedAt: string;
199
+ }
200
+
201
+ /**
202
+ * Create a new reward for a creator
203
+ *
204
+ * @example
205
+ * ```tsx
206
+ * const createReward = useCreateCreatorReward(creatorId);
207
+ *
208
+ * await createReward.mutateAsync({
209
+ * badgeId: 'badge-123',
210
+ * title: 'Free Session',
211
+ * description: 'Get a free 30-minute session',
212
+ * redeemType: 'IN_PERSON',
213
+ * });
214
+ * ```
215
+ */
216
+ export function useCreateCreatorReward(creatorId: string) {
217
+ const queryClient = useQueryClient();
218
+
219
+ return useMutation({
220
+ mutationFn: async (data: CreateCreatorRewardRequest): Promise<CreatorRewardResponse> => {
221
+ const client = getApiClient();
222
+ const response = await client.post(`/api/v1/creators/${creatorId}/rewards`, data);
223
+ return response.data;
224
+ },
225
+ onSuccess: () => {
226
+ queryClient.invalidateQueries({ queryKey: creatorKeys.detail(creatorId) });
227
+ queryClient.invalidateQueries({ queryKey: ['creator-rewards', creatorId] });
228
+ },
229
+ });
230
+ }
@@ -27,3 +27,4 @@ export * from './creators';
27
27
  export * from './brands';
28
28
  export * from './products';
29
29
  export * from './venues';
30
+ export * from './stripe-connect';
@@ -0,0 +1,45 @@
1
+ import { useMutation } from '@tanstack/react-query';
2
+ import { getApiClient } from '../client';
3
+
4
+ // ============================================================================
5
+ // TYPES
6
+ // ============================================================================
7
+
8
+ export interface OnboardingLinkResponse {
9
+ url: string;
10
+ }
11
+
12
+ export interface DashboardLinkResponse {
13
+ url: string;
14
+ }
15
+
16
+ // ============================================================================
17
+ // HOOKS
18
+ // ============================================================================
19
+
20
+ export function useStartStripeOnboarding() {
21
+ return useMutation({
22
+ mutationFn: async () => {
23
+ const response = await getApiClient().post<OnboardingLinkResponse>('/creators/me/stripe-connect/onboard');
24
+ return response.data;
25
+ },
26
+ });
27
+ }
28
+
29
+ export function useRefreshStripeOnboarding() {
30
+ return useMutation({
31
+ mutationFn: async () => {
32
+ const response = await getApiClient().post<OnboardingLinkResponse>('/creators/me/stripe-connect/refresh');
33
+ return response.data;
34
+ },
35
+ });
36
+ }
37
+
38
+ export function useGetStripeDashboard() {
39
+ return useMutation({
40
+ mutationFn: async () => {
41
+ const response = await getApiClient().get<DashboardLinkResponse>('/creators/me/stripe-connect/dashboard');
42
+ return response.data;
43
+ },
44
+ });
45
+ }
@@ -29,3 +29,4 @@ export * from './venues';
29
29
  export * from './creators';
30
30
  export * from './brands';
31
31
  export * from './products';
32
+ export * from './stripe-connect';
@@ -0,0 +1,73 @@
1
+ import { useQuery } from '@tanstack/react-query';
2
+ import { getApiClient } from '../client';
3
+
4
+ // ============================================================================
5
+ // TYPES
6
+ // ============================================================================
7
+
8
+ export type StripeConnectStatus = 'ACTIVE' | 'ONBOARDING' | 'RESTRICTED' | 'DISABLED' | 'PENDING';
9
+
10
+ export interface StripeAccountStatus {
11
+ status: StripeConnectStatus;
12
+ chargesEnabled: boolean;
13
+ payoutsEnabled: boolean;
14
+ detailsSubmitted: boolean;
15
+ createdAt?: string;
16
+ }
17
+
18
+ export interface EarningsSummary {
19
+ totalEarnings: number;
20
+ pendingEarnings: number;
21
+ availableBalance: number;
22
+ currency: string;
23
+ }
24
+
25
+ export interface EarningsHistoryItem {
26
+ id: string;
27
+ amount: number;
28
+ currency: string;
29
+ status: string;
30
+ paidAt: string;
31
+ eventTitle?: string;
32
+ }
33
+
34
+ export interface EarningsResponse {
35
+ summary: EarningsSummary;
36
+ history: EarningsHistoryItem[];
37
+ }
38
+
39
+ // ============================================================================
40
+ // QUERY KEYS
41
+ // ============================================================================
42
+
43
+ export const stripeConnectKeys = {
44
+ all: ['stripe-connect'] as const,
45
+ status: () => [...stripeConnectKeys.all, 'status'] as const,
46
+ earnings: () => [...stripeConnectKeys.all, 'earnings'] as const,
47
+ };
48
+
49
+ // ============================================================================
50
+ // HOOKS
51
+ // ============================================================================
52
+
53
+ export function useStripeConnectStatus(options?: { enabled?: boolean }) {
54
+ return useQuery({
55
+ queryKey: stripeConnectKeys.status(),
56
+ queryFn: async () => {
57
+ const response = await getApiClient().get<StripeAccountStatus>('/creators/me/stripe-connect/status');
58
+ return response.data;
59
+ },
60
+ enabled: options?.enabled ?? true,
61
+ });
62
+ }
63
+
64
+ export function useCreatorEarnings(options?: { enabled?: boolean }) {
65
+ return useQuery({
66
+ queryKey: stripeConnectKeys.earnings(),
67
+ queryFn: async () => {
68
+ const response = await getApiClient().get<EarningsResponse>('/creators/me/stripe-connect/earnings');
69
+ return response.data;
70
+ },
71
+ enabled: options?.enabled ?? true,
72
+ });
73
+ }