@growsober/sdk 1.0.25 → 1.0.27

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.
@@ -43,6 +43,14 @@ export declare function useCancelProductBooking(): import("@tanstack/react-query
43
43
  export declare function useCompleteProductBooking(): import("@tanstack/react-query").UseMutationResult<ProductBookingResponse, Error, {
44
44
  bookingId: string;
45
45
  }, unknown>;
46
+ export declare function useConfirmProductBooking(): import("@tanstack/react-query").UseMutationResult<ProductBookingResponse, Error, {
47
+ creatorId: string;
48
+ bookingId: string;
49
+ }, unknown>;
50
+ export declare function useCompleteCreatorBooking(): import("@tanstack/react-query").UseMutationResult<ProductBookingResponse, Error, {
51
+ creatorId: string;
52
+ bookingId: string;
53
+ }, unknown>;
46
54
  export interface PaymentIntentResponse {
47
55
  clientSecret: string;
48
56
  paymentIntentId: string;
@@ -7,6 +7,8 @@ exports.useBookProduct = useBookProduct;
7
7
  exports.useUpdateProductBooking = useUpdateProductBooking;
8
8
  exports.useCancelProductBooking = useCancelProductBooking;
9
9
  exports.useCompleteProductBooking = useCompleteProductBooking;
10
+ exports.useConfirmProductBooking = useConfirmProductBooking;
11
+ exports.useCompleteCreatorBooking = useCompleteCreatorBooking;
10
12
  exports.useCreateProductPaymentIntent = useCreateProductPaymentIntent;
11
13
  const react_query_1 = require("@tanstack/react-query");
12
14
  const client_1 = require("../client");
@@ -118,6 +120,39 @@ function useCompleteProductBooking() {
118
120
  },
119
121
  });
120
122
  }
123
+ // ============================================================================
124
+ // MUTATION HOOKS - CREATOR BOOKING MANAGEMENT
125
+ // ============================================================================
126
+ function useConfirmProductBooking() {
127
+ const queryClient = (0, react_query_1.useQueryClient)();
128
+ return (0, react_query_1.useMutation)({
129
+ mutationFn: async ({ creatorId, bookingId, }) => {
130
+ const client = (0, client_1.getApiClient)();
131
+ const response = await client.post(`/api/v1/creators/${creatorId}/products/bookings/${bookingId}/confirm`);
132
+ return response.data;
133
+ },
134
+ onSuccess: (_, { creatorId, bookingId }) => {
135
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.bookingDetail(bookingId) });
136
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.creatorBookings(creatorId) });
137
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.myBookings() });
138
+ },
139
+ });
140
+ }
141
+ function useCompleteCreatorBooking() {
142
+ const queryClient = (0, react_query_1.useQueryClient)();
143
+ return (0, react_query_1.useMutation)({
144
+ mutationFn: async ({ creatorId, bookingId, }) => {
145
+ const client = (0, client_1.getApiClient)();
146
+ const response = await client.post(`/api/v1/creators/${creatorId}/products/bookings/${bookingId}/complete`);
147
+ return response.data;
148
+ },
149
+ onSuccess: (_, { creatorId, bookingId }) => {
150
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.bookingDetail(bookingId) });
151
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.creatorBookings(creatorId) });
152
+ queryClient.invalidateQueries({ queryKey: products_1.productKeys.myBookings() });
153
+ },
154
+ });
155
+ }
121
156
  function useCreateProductPaymentIntent() {
122
157
  return (0, react_query_1.useMutation)({
123
158
  mutationFn: async ({ bookingId, }) => {
@@ -127,4 +162,4 @@ function useCreateProductPaymentIntent() {
127
162
  },
128
163
  });
129
164
  }
130
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.js","sourceRoot":"","sources":["../../../src/api/mutations/products.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { productKeys, CreatorProductResponse, ProductBookingResponse, CreateProductDto, UpdateProductDto } from '../queries/products';\nimport { creatorKeys } from '../queries/creators';\n\n// ============================================================================\n// TYPES — request types derived from auto-generated OpenAPI DTOs\n// ============================================================================\n\nexport type CreateProductRequest = CreateProductDto;\nexport type UpdateProductRequest = UpdateProductDto;\n\nexport interface BookProductRequest {\n  scheduledAt: string;\n  timezone?: string;\n  clientNotes?: string;\n}\n\nexport interface UpdateBookingRequest {\n  scheduledAt?: string;\n  clientNotes?: string;\n  creatorNotes?: string;\n  meetingLink?: string;\n}\n\nexport interface CancelBookingRequest {\n  reason?: string;\n}\n\n// ============================================================================\n// MUTATION HOOKS - PRODUCTS\n// ============================================================================\n\nexport function useCreateProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      data,\n    }: {\n      creatorId: string;\n      data: CreateProductRequest;\n    }): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/products`, data);\n      return response.data;\n    },\n    onSuccess: (_, { creatorId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\nexport function useUpdateProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      productId,\n      data,\n    }: {\n      creatorId: string;\n      productId: string;\n      data: UpdateProductRequest;\n    }): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/creators/${creatorId}/products/${productId}`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: (_, { creatorId, productId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.detail(productId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\nexport function useDeleteProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      productId,\n    }: {\n      creatorId: string;\n      productId: string;\n    }): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/creators/${creatorId}/products/${productId}`);\n    },\n    onSuccess: (_, { creatorId, productId }) => {\n      queryClient.removeQueries({ queryKey: productKeys.detail(productId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\n// ============================================================================\n// MUTATION HOOKS - BOOKINGS\n// ============================================================================\n\nexport function useBookProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      productId,\n      data,\n    }: {\n      productId: string;\n      data: BookProductRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/products/${productId}/book`, data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n    },\n  });\n}\n\nexport function useUpdateProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n      data,\n    }: {\n      bookingId: string;\n      data: UpdateBookingRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/users/me/product-bookings/${bookingId}`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\nexport function useCancelProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n      data,\n    }: {\n      bookingId: string;\n      data?: CancelBookingRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.delete(\n        `/api/v1/users/me/product-bookings/${bookingId}`,\n        { data }\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\nexport function useCompleteProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n    }: {\n      bookingId: string;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/users/me/product-bookings/${bookingId}/complete`\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\n// ============================================================================\n// MUTATION HOOKS - PAYMENTS\n// ============================================================================\n\nexport interface PaymentIntentResponse {\n  clientSecret: string;\n  paymentIntentId: string;\n}\n\nexport function useCreateProductPaymentIntent() {\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n    }: {\n      bookingId: string;\n    }): Promise<PaymentIntentResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/users/me/product-bookings/${bookingId}/payment-intent`\n      );\n      return response.data;\n    },\n  });\n}\n"]}
165
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.js","sourceRoot":"","sources":["../../../src/api/mutations/products.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { productKeys, CreatorProductResponse, ProductBookingResponse, CreateProductDto, UpdateProductDto } from '../queries/products';\nimport { creatorKeys } from '../queries/creators';\n\n// ============================================================================\n// TYPES — request types derived from auto-generated OpenAPI DTOs\n// ============================================================================\n\nexport type CreateProductRequest = CreateProductDto;\nexport type UpdateProductRequest = UpdateProductDto;\n\nexport interface BookProductRequest {\n  scheduledAt: string;\n  timezone?: string;\n  clientNotes?: string;\n}\n\nexport interface UpdateBookingRequest {\n  scheduledAt?: string;\n  clientNotes?: string;\n  creatorNotes?: string;\n  meetingLink?: string;\n}\n\nexport interface CancelBookingRequest {\n  reason?: string;\n}\n\n// ============================================================================\n// MUTATION HOOKS - PRODUCTS\n// ============================================================================\n\nexport function useCreateProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      data,\n    }: {\n      creatorId: string;\n      data: CreateProductRequest;\n    }): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/creators/${creatorId}/products`, data);\n      return response.data;\n    },\n    onSuccess: (_, { creatorId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\nexport function useUpdateProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      productId,\n      data,\n    }: {\n      creatorId: string;\n      productId: string;\n      data: UpdateProductRequest;\n    }): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/creators/${creatorId}/products/${productId}`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: (_, { creatorId, productId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.detail(productId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\nexport function useDeleteProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      productId,\n    }: {\n      creatorId: string;\n      productId: string;\n    }): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/creators/${creatorId}/products/${productId}`);\n    },\n    onSuccess: (_, { creatorId, productId }) => {\n      queryClient.removeQueries({ queryKey: productKeys.detail(productId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.byCreator(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.lists() });\n    },\n  });\n}\n\n// ============================================================================\n// MUTATION HOOKS - BOOKINGS\n// ============================================================================\n\nexport function useBookProduct() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      productId,\n      data,\n    }: {\n      productId: string;\n      data: BookProductRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/products/${productId}/book`, data);\n      return response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n    },\n  });\n}\n\nexport function useUpdateProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n      data,\n    }: {\n      bookingId: string;\n      data: UpdateBookingRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.put(\n        `/api/v1/users/me/product-bookings/${bookingId}`,\n        data\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\nexport function useCancelProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n      data,\n    }: {\n      bookingId: string;\n      data?: CancelBookingRequest;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.delete(\n        `/api/v1/users/me/product-bookings/${bookingId}`,\n        { data }\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\nexport function useCompleteProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n    }: {\n      bookingId: string;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/users/me/product-bookings/${bookingId}/complete`\n      );\n      return response.data;\n    },\n    onSuccess: (_, { bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n      queryClient.invalidateQueries({ queryKey: productKeys.bookings() });\n    },\n  });\n}\n\n// ============================================================================\n// MUTATION HOOKS - CREATOR BOOKING MANAGEMENT\n// ============================================================================\n\nexport function useConfirmProductBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      bookingId,\n    }: {\n      creatorId: string;\n      bookingId: string;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/creators/${creatorId}/products/bookings/${bookingId}/confirm`\n      );\n      return response.data;\n    },\n    onSuccess: (_, { creatorId, bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.creatorBookings(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n    },\n  });\n}\n\nexport function useCompleteCreatorBooking() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      creatorId,\n      bookingId,\n    }: {\n      creatorId: string;\n      bookingId: string;\n    }): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/creators/${creatorId}/products/bookings/${bookingId}/complete`\n      );\n      return response.data;\n    },\n    onSuccess: (_, { creatorId, bookingId }) => {\n      queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.creatorBookings(creatorId) });\n      queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });\n    },\n  });\n}\n\n// ============================================================================\n// MUTATION HOOKS - PAYMENTS\n// ============================================================================\n\nexport interface PaymentIntentResponse {\n  clientSecret: string;\n  paymentIntentId: string;\n}\n\nexport function useCreateProductPaymentIntent() {\n  return useMutation({\n    mutationFn: async ({\n      bookingId,\n    }: {\n      bookingId: string;\n    }): Promise<PaymentIntentResponse> => {\n      const client = getApiClient();\n      const response = await client.post(\n        `/api/v1/users/me/product-bookings/${bookingId}/payment-intent`\n      );\n      return response.data;\n    },\n  });\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { UseMutationOptions } from '@tanstack/react-query';
2
- import type { VenueResponse, CreateVenueRequest, UpdateVenueRequest } from '../types';
2
+ import type { VenueResponse, CreateVenueRequest, UpdateVenueRequest, AddVenueOwnerRequest } from '../types';
3
3
  /**
4
4
  * Update a venue
5
5
  *
@@ -124,3 +124,19 @@ export declare function useCreateVenue(options?: Omit<UseMutationOptions<VenueRe
124
124
  * ```
125
125
  */
126
126
  export declare function useDeleteVenue(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): import("@tanstack/react-query").UseMutationResult<void, Error, string, unknown>;
127
+ export declare function useAddVenueOwner(): import("@tanstack/react-query").UseMutationResult<{
128
+ id: string;
129
+ venueId: string;
130
+ userId: string;
131
+ role: "OWNER" | "MANAGER";
132
+ user?: import("@growsober/types/dist/generated").components["schemas"]["VenueOwnerUserDto"];
133
+ createdAt: string;
134
+ updatedAt: string;
135
+ }, Error, {
136
+ venueId: string;
137
+ data: AddVenueOwnerRequest;
138
+ }, unknown>;
139
+ export declare function useRemoveVenueOwner(): import("@tanstack/react-query").UseMutationResult<void, Error, {
140
+ venueId: string;
141
+ userId: string;
142
+ }, unknown>;
@@ -3,6 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.useUpdateVenue = useUpdateVenue;
4
4
  exports.useCreateVenue = useCreateVenue;
5
5
  exports.useDeleteVenue = useDeleteVenue;
6
+ exports.useAddVenueOwner = useAddVenueOwner;
7
+ exports.useRemoveVenueOwner = useRemoveVenueOwner;
6
8
  const react_query_1 = require("@tanstack/react-query");
7
9
  const client_1 = require("../client");
8
10
  const venues_1 = require("../queries/venues");
@@ -31,7 +33,7 @@ function useUpdateVenue(options) {
31
33
  return (0, react_query_1.useMutation)({
32
34
  mutationFn: async ({ id, data, }) => {
33
35
  const client = (0, client_1.getApiClient)();
34
- const response = await client.patch(`/api/v1/venues/${id}`, data);
36
+ const response = await client.put(`/api/v1/venues/${id}`, data);
35
37
  return response.data?.data || response.data;
36
38
  },
37
39
  onSuccess: (_, variables) => {
@@ -107,4 +109,32 @@ function useDeleteVenue(options) {
107
109
  ...options,
108
110
  });
109
111
  }
110
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVudWVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwaS9tdXRhdGlvbnMvdmVudWVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBMEJBLHdDQTBCQztBQXVCRCx3Q0FnQkM7QUFtQkQsd0NBZ0JDO0FBOUhELHVEQUF3RjtBQUN4RixzQ0FBeUM7QUFDekMsOENBQThDO0FBRzlDLCtFQUErRTtBQUMvRSx1QkFBdUI7QUFDdkIsK0VBQStFO0FBRS9FOzs7Ozs7Ozs7Ozs7Ozs7O0dBZ0JHO0FBQ0gsU0FBZ0IsY0FBYyxDQUM1QixPQUdDO0lBRUQsTUFBTSxXQUFXLEdBQUcsSUFBQSw0QkFBYyxHQUFFLENBQUM7SUFFckMsT0FBTyxJQUFBLHlCQUFXLEVBQUM7UUFDakIsVUFBVSxFQUFFLEtBQUssRUFBRSxFQUNqQixFQUFFLEVBQ0YsSUFBSSxHQUlMLEVBQTBCLEVBQUU7WUFDM0IsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUM7WUFDOUIsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsS0FBSyxDQUFDLGtCQUFrQixFQUFFLEVBQUUsRUFBRSxJQUFJLENBQUMsQ0FBQztZQUNsRSxPQUFPLFFBQVEsQ0FBQyxJQUFJLEVBQUUsSUFBSSxJQUFJLFFBQVEsQ0FBQyxJQUFJLENBQUM7UUFDOUMsQ0FBQztRQUNELFNBQVMsRUFBRSxDQUFDLENBQUMsRUFBRSxTQUFTLEVBQUUsRUFBRTtZQUMxQixXQUFXLENBQUMsaUJBQWlCLENBQUMsRUFBRSxRQUFRLEVBQUUsa0JBQVMsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztZQUM1RSxXQUFXLENBQUMsaUJBQWlCLENBQUMsRUFBRSxRQUFRLEVBQUUsa0JBQVMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDakUsQ0FBQztRQUNELEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQkc7QUFDSCxTQUFnQixjQUFjLENBQzVCLE9BQTBGO0lBRTFGLE1BQU0sV0FBVyxHQUFHLElBQUEsNEJBQWMsR0FBRSxDQUFDO0lBRXJDLE9BQU8sSUFBQSx5QkFBVyxFQUFDO1FBQ2pCLFVBQVUsRUFBRSxLQUFLLEVBQUUsSUFBd0IsRUFBMEIsRUFBRTtZQUNyRSxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQztZQUM5QixNQUFNLFFBQVEsR0FBRyxNQUFNLE1BQU0sQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLENBQUM7WUFDM0QsT0FBTyxRQUFRLENBQUMsSUFBSSxFQUFFLElBQUksSUFBSSxRQUFRLENBQUMsSUFBSSxDQUFDO1FBQzlDLENBQUM7UUFDRCxTQUFTLEVBQUUsR0FBRyxFQUFFO1lBQ2QsV0FBVyxDQUFDLGlCQUFpQixDQUFDLEVBQUUsUUFBUSxFQUFFLGtCQUFTLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pFLENBQUM7UUFDRCxHQUFHLE9BQU87S0FDWCxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQ7Ozs7Ozs7Ozs7Ozs7Ozs7R0FnQkc7QUFDSCxTQUFnQixjQUFjLENBQzVCLE9BQXFFO0lBRXJFLE1BQU0sV0FBVyxHQUFHLElBQUEsNEJBQWMsR0FBRSxDQUFDO0lBRXJDLE9BQU8sSUFBQSx5QkFBVyxFQUFDO1FBQ2pCLFVBQVUsRUFBRSxLQUFLLEVBQUUsT0FBZSxFQUFpQixFQUFFO1lBQ25ELE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFDO1lBQzlCLE1BQU0sTUFBTSxDQUFDLE1BQU0sQ0FBQyxrQkFBa0IsT0FBTyxFQUFFLENBQUMsQ0FBQztRQUNuRCxDQUFDO1FBQ0QsU0FBUyxFQUFFLENBQUMsQ0FBQyxFQUFFLE9BQU8sRUFBRSxFQUFFO1lBQ3hCLFdBQVcsQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLFFBQVEsRUFBRSxrQkFBUyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDdkUsV0FBVyxDQUFDLGlCQUFpQixDQUFDLEVBQUUsUUFBUSxFQUFFLGtCQUFTLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQ2pFLENBQUM7UUFDRCxHQUFHLE9BQU87S0FDWCxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlTXV0YXRpb24sIHVzZVF1ZXJ5Q2xpZW50LCBVc2VNdXRhdGlvbk9wdGlvbnMgfSBmcm9tICdAdGFuc3RhY2svcmVhY3QtcXVlcnknO1xuaW1wb3J0IHsgZ2V0QXBpQ2xpZW50IH0gZnJvbSAnLi4vY2xpZW50JztcbmltcG9ydCB7IHZlbnVlS2V5cyB9IGZyb20gJy4uL3F1ZXJpZXMvdmVudWVzJztcbmltcG9ydCB0eXBlIHsgVmVudWVSZXNwb25zZSwgQ3JlYXRlVmVudWVSZXF1ZXN0LCBVcGRhdGVWZW51ZVJlcXVlc3QgfSBmcm9tICcuLi90eXBlcyc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFZFTlVFIE1VVEFUSU9OIEhPT0tTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogVXBkYXRlIGEgdmVudWVcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHN4XG4gKiBjb25zdCB1cGRhdGVWZW51ZSA9IHVzZVVwZGF0ZVZlbnVlKHtcbiAqICAgb25TdWNjZXNzOiAoKSA9PiB0b2FzdC5zdWNjZXNzKCdWZW51ZSB1cGRhdGVkJyksXG4gKiB9KTtcbiAqXG4gKiBjb25zdCBoYW5kbGVTYXZlID0gKCkgPT4ge1xuICogICB1cGRhdGVWZW51ZS5tdXRhdGUoe1xuICogICAgIGlkOiB2ZW51ZUlkLFxuICogICAgIGRhdGE6IHsgbmFtZTogJ1VwZGF0ZWQgTmFtZScsIGhhc0FmRHJpbmtzOiB0cnVlIH0sXG4gKiAgIH0pO1xuICogfTtcbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlVXBkYXRlVmVudWUoXG4gIG9wdGlvbnM/OiBPbWl0PFxuICAgIFVzZU11dGF0aW9uT3B0aW9uczxWZW51ZVJlc3BvbnNlLCBFcnJvciwgeyBpZDogc3RyaW5nOyBkYXRhOiBVcGRhdGVWZW51ZVJlcXVlc3QgfT4sXG4gICAgJ211dGF0aW9uRm4nXG4gID5cbikge1xuICBjb25zdCBxdWVyeUNsaWVudCA9IHVzZVF1ZXJ5Q2xpZW50KCk7XG5cbiAgcmV0dXJuIHVzZU11dGF0aW9uKHtcbiAgICBtdXRhdGlvbkZuOiBhc3luYyAoe1xuICAgICAgaWQsXG4gICAgICBkYXRhLFxuICAgIH06IHtcbiAgICAgIGlkOiBzdHJpbmc7XG4gICAgICBkYXRhOiBVcGRhdGVWZW51ZVJlcXVlc3Q7XG4gICAgfSk6IFByb21pc2U8VmVudWVSZXNwb25zZT4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KCk7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5wYXRjaChgL2FwaS92MS92ZW51ZXMvJHtpZH1gLCBkYXRhKTtcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhPy5kYXRhIHx8IHJlc3BvbnNlLmRhdGE7XG4gICAgfSxcbiAgICBvblN1Y2Nlc3M6IChfLCB2YXJpYWJsZXMpID0+IHtcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHsgcXVlcnlLZXk6IHZlbnVlS2V5cy5kZXRhaWwodmFyaWFibGVzLmlkKSB9KTtcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHsgcXVlcnlLZXk6IHZlbnVlS2V5cy5saXN0cygpIH0pO1xuICAgIH0sXG4gICAgLi4ub3B0aW9ucyxcbiAgfSk7XG59XG5cbi8qKlxuICogQ3JlYXRlIGEgdmVudWVcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHN4XG4gKiBjb25zdCBjcmVhdGVWZW51ZSA9IHVzZUNyZWF0ZVZlbnVlKHtcbiAqICAgb25TdWNjZXNzOiAodmVudWUpID0+IHtcbiAqICAgICB0b2FzdC5zdWNjZXNzKCdWZW51ZSBjcmVhdGVkJyk7XG4gKiAgICAgcm91dGVyLnB1c2goYC92ZW51ZXMvJHt2ZW51ZS5pZH1gKTtcbiAqICAgfSxcbiAqIH0pO1xuICpcbiAqIGNvbnN0IGhhbmRsZUNyZWF0ZSA9ICgpID0+IHtcbiAqICAgY3JlYXRlVmVudWUubXV0YXRlKHtcbiAqICAgICBuYW1lOiAnTXkgVmVudWUnLFxuICogICAgIGFkZHJlc3M6ICcxMjMgTWFpbiBTdCcsXG4gKiAgICAgaGFzQWZEcmlua3M6IHRydWUsXG4gKiAgIH0pO1xuICogfTtcbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlQ3JlYXRlVmVudWUoXG4gIG9wdGlvbnM/OiBPbWl0PFVzZU11dGF0aW9uT3B0aW9uczxWZW51ZVJlc3BvbnNlLCBFcnJvciwgQ3JlYXRlVmVudWVSZXF1ZXN0PiwgJ211dGF0aW9uRm4nPlxuKSB7XG4gIGNvbnN0IHF1ZXJ5Q2xpZW50ID0gdXNlUXVlcnlDbGllbnQoKTtcblxuICByZXR1cm4gdXNlTXV0YXRpb24oe1xuICAgIG11dGF0aW9uRm46IGFzeW5jIChkYXRhOiBDcmVhdGVWZW51ZVJlcXVlc3QpOiBQcm9taXNlPFZlbnVlUmVzcG9uc2U+ID0+IHtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGdldEFwaUNsaWVudCgpO1xuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQucG9zdCgnL2FwaS92MS92ZW51ZXMnLCBkYXRhKTtcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhPy5kYXRhIHx8IHJlc3BvbnNlLmRhdGE7XG4gICAgfSxcbiAgICBvblN1Y2Nlc3M6ICgpID0+IHtcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHsgcXVlcnlLZXk6IHZlbnVlS2V5cy5saXN0cygpIH0pO1xuICAgIH0sXG4gICAgLi4ub3B0aW9ucyxcbiAgfSk7XG59XG5cbi8qKlxuICogRGVsZXRlIGEgdmVudWVcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHN4XG4gKiBjb25zdCBkZWxldGVWZW51ZSA9IHVzZURlbGV0ZVZlbnVlKHtcbiAqICAgb25TdWNjZXNzOiAoKSA9PiB7XG4gKiAgICAgdG9hc3Quc3VjY2VzcygnVmVudWUgZGVsZXRlZCcpO1xuICogICAgIHJvdXRlci5wdXNoKCcvdmVudWVzJyk7XG4gKiAgIH0sXG4gKiB9KTtcbiAqXG4gKiBjb25zdCBoYW5kbGVEZWxldGUgPSAodmVudWVJZDogc3RyaW5nKSA9PiB7XG4gKiAgIGRlbGV0ZVZlbnVlLm11dGF0ZSh2ZW51ZUlkKTtcbiAqIH07XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZURlbGV0ZVZlbnVlKFxuICBvcHRpb25zPzogT21pdDxVc2VNdXRhdGlvbk9wdGlvbnM8dm9pZCwgRXJyb3IsIHN0cmluZz4sICdtdXRhdGlvbkZuJz5cbikge1xuICBjb25zdCBxdWVyeUNsaWVudCA9IHVzZVF1ZXJ5Q2xpZW50KCk7XG5cbiAgcmV0dXJuIHVzZU11dGF0aW9uKHtcbiAgICBtdXRhdGlvbkZuOiBhc3luYyAodmVudWVJZDogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGF3YWl0IGNsaWVudC5kZWxldGUoYC9hcGkvdjEvdmVudWVzLyR7dmVudWVJZH1gKTtcbiAgICB9LFxuICAgIG9uU3VjY2VzczogKF8sIHZlbnVlSWQpID0+IHtcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHsgcXVlcnlLZXk6IHZlbnVlS2V5cy5kZXRhaWwodmVudWVJZCkgfSk7XG4gICAgICBxdWVyeUNsaWVudC5pbnZhbGlkYXRlUXVlcmllcyh7IHF1ZXJ5S2V5OiB2ZW51ZUtleXMubGlzdHMoKSB9KTtcbiAgICB9LFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pO1xufVxuIl19
112
+ // ============================================================================
113
+ // VENUE OWNER MUTATION HOOKS
114
+ // ============================================================================
115
+ function useAddVenueOwner() {
116
+ const queryClient = (0, react_query_1.useQueryClient)();
117
+ return (0, react_query_1.useMutation)({
118
+ mutationFn: async ({ venueId, data, }) => {
119
+ const client = (0, client_1.getApiClient)();
120
+ const response = await client.post(`/api/v1/venues/${venueId}/owners`, data);
121
+ return response.data;
122
+ },
123
+ onSuccess: (_, { venueId }) => {
124
+ queryClient.invalidateQueries({ queryKey: venues_1.venueKeys.owners(venueId) });
125
+ },
126
+ });
127
+ }
128
+ function useRemoveVenueOwner() {
129
+ const queryClient = (0, react_query_1.useQueryClient)();
130
+ return (0, react_query_1.useMutation)({
131
+ mutationFn: async ({ venueId, userId, }) => {
132
+ const client = (0, client_1.getApiClient)();
133
+ await client.delete(`/api/v1/venues/${venueId}/owners/${userId}`);
134
+ },
135
+ onSuccess: (_, { venueId }) => {
136
+ queryClient.invalidateQueries({ queryKey: venues_1.venueKeys.owners(venueId) });
137
+ },
138
+ });
139
+ }
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"venues.js","sourceRoot":"","sources":["../../../src/api/mutations/venues.ts"],"names":[],"mappings":"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","sourcesContent":["import { useMutation, useQueryClient, UseMutationOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport { venueKeys } from '../queries/venues';\nimport type { VenueResponse, VenueOwnerResponse, CreateVenueRequest, UpdateVenueRequest, AddVenueOwnerRequest } from '../types';\n\n// ============================================================================\n// VENUE MUTATION HOOKS\n// ============================================================================\n\n/**\n * Update a venue\n *\n * @example\n * ```tsx\n * const updateVenue = useUpdateVenue({\n *   onSuccess: () => toast.success('Venue updated'),\n * });\n *\n * const handleSave = () => {\n *   updateVenue.mutate({\n *     id: venueId,\n *     data: { name: 'Updated Name', hasAfDrinks: true },\n *   });\n * };\n * ```\n */\nexport function useUpdateVenue(\n  options?: Omit<\n    UseMutationOptions<VenueResponse, Error, { id: string; data: UpdateVenueRequest }>,\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: UpdateVenueRequest;\n    }): Promise<VenueResponse> => {\n      const client = getApiClient();\n      const response = await client.put(`/api/v1/venues/${id}`, data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({ queryKey: venueKeys.detail(variables.id) });\n      queryClient.invalidateQueries({ queryKey: venueKeys.lists() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Create a venue\n *\n * @example\n * ```tsx\n * const createVenue = useCreateVenue({\n *   onSuccess: (venue) => {\n *     toast.success('Venue created');\n *     router.push(`/venues/${venue.id}`);\n *   },\n * });\n *\n * const handleCreate = () => {\n *   createVenue.mutate({\n *     name: 'My Venue',\n *     address: '123 Main St',\n *     hasAfDrinks: true,\n *   });\n * };\n * ```\n */\nexport function useCreateVenue(\n  options?: Omit<UseMutationOptions<VenueResponse, Error, CreateVenueRequest>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (data: CreateVenueRequest): Promise<VenueResponse> => {\n      const client = getApiClient();\n      const response = await client.post('/api/v1/venues', data);\n      return response.data?.data || response.data;\n    },\n    onSuccess: () => {\n      queryClient.invalidateQueries({ queryKey: venueKeys.lists() });\n    },\n    ...options,\n  });\n}\n\n/**\n * Delete a venue\n *\n * @example\n * ```tsx\n * const deleteVenue = useDeleteVenue({\n *   onSuccess: () => {\n *     toast.success('Venue deleted');\n *     router.push('/venues');\n *   },\n * });\n *\n * const handleDelete = (venueId: string) => {\n *   deleteVenue.mutate(venueId);\n * };\n * ```\n */\nexport function useDeleteVenue(\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>\n) {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async (venueId: string): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/venues/${venueId}`);\n    },\n    onSuccess: (_, venueId) => {\n      queryClient.invalidateQueries({ queryKey: venueKeys.detail(venueId) });\n      queryClient.invalidateQueries({ queryKey: venueKeys.lists() });\n    },\n    ...options,\n  });\n}\n\n// ============================================================================\n// VENUE OWNER MUTATION HOOKS\n// ============================================================================\n\nexport function useAddVenueOwner() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      venueId,\n      data,\n    }: {\n      venueId: string;\n      data: AddVenueOwnerRequest;\n    }): Promise<VenueOwnerResponse> => {\n      const client = getApiClient();\n      const response = await client.post(`/api/v1/venues/${venueId}/owners`, data);\n      return response.data;\n    },\n    onSuccess: (_, { venueId }) => {\n      queryClient.invalidateQueries({ queryKey: venueKeys.owners(venueId) });\n    },\n  });\n}\n\nexport function useRemoveVenueOwner() {\n  const queryClient = useQueryClient();\n\n  return useMutation({\n    mutationFn: async ({\n      venueId,\n      userId,\n    }: {\n      venueId: string;\n      userId: string;\n    }): Promise<void> => {\n      const client = getApiClient();\n      await client.delete(`/api/v1/venues/${venueId}/owners/${userId}`);\n    },\n    onSuccess: (_, { venueId }) => {\n      queryClient.invalidateQueries({ queryKey: venueKeys.owners(venueId) });\n    },\n  });\n}\n"]}
@@ -8,6 +8,7 @@ export declare const venueKeys: {
8
8
  detail: (id: string) => readonly ["venues", "detail", string];
9
9
  featured: () => readonly ["venues", "featured"];
10
10
  nearby: (params?: NearbyVenueParams) => readonly ["venues", "nearby", NearbyVenueParams | undefined];
11
+ mine: () => readonly ["venues", "mine"];
11
12
  owners: (venueId: string) => readonly ["venues", "detail", string, "owners"];
12
13
  events: (venueId: string) => readonly ["venues", "detail", string, "events"];
13
14
  offers: (venueId: string) => readonly ["venues", "detail", string, "offers"];
@@ -44,6 +45,37 @@ export interface PaginatedVenuesResponse {
44
45
  totalPages: number;
45
46
  };
46
47
  }
48
+ export declare function useMyVenues(options?: Omit<UseQueryOptions<VenueResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
49
+ id: string;
50
+ appId: string;
51
+ name: string;
52
+ slug: string;
53
+ description?: Record<string, never>;
54
+ type: "COFFEE_SHOP" | "RESTAURANT" | "BAR" | "WELLNESS" | "VENUE" | "ACTIVITY" | "RETAIL" | "OTHER";
55
+ hasAfDrinks: boolean;
56
+ isAfVenue: boolean;
57
+ afHighlights: string[];
58
+ address?: Record<string, never>;
59
+ cityId?: Record<string, never>;
60
+ locationLat?: Record<string, never>;
61
+ locationLong?: Record<string, never>;
62
+ phone?: Record<string, never>;
63
+ email?: Record<string, never>;
64
+ website?: Record<string, never>;
65
+ instagram?: Record<string, never>;
66
+ profileImage?: Record<string, never>;
67
+ bannerImage?: Record<string, never>;
68
+ photos: string[];
69
+ openingHours?: Record<string, never>;
70
+ rating?: Record<string, never>;
71
+ reviewCount: number;
72
+ isActive: boolean;
73
+ isVerified: boolean;
74
+ isFeatured: boolean;
75
+ isFoundingPartner: boolean;
76
+ createdAt: string;
77
+ updatedAt: string;
78
+ }[], Error>;
47
79
  /**
48
80
  * Get paginated list of venues with optional filters
49
81
  *
@@ -1,6 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.venueKeys = void 0;
4
+ exports.useMyVenues = useMyVenues;
4
5
  exports.useVenues = useVenues;
5
6
  exports.useFeaturedVenues = useFeaturedVenues;
6
7
  exports.useNearbyVenues = useNearbyVenues;
@@ -21,6 +22,7 @@ exports.venueKeys = {
21
22
  detail: (id) => [...exports.venueKeys.details(), id],
22
23
  featured: () => [...exports.venueKeys.all, 'featured'],
23
24
  nearby: (params) => [...exports.venueKeys.all, 'nearby', params],
25
+ mine: () => [...exports.venueKeys.all, 'mine'],
24
26
  owners: (venueId) => [...exports.venueKeys.detail(venueId), 'owners'],
25
27
  events: (venueId) => [...exports.venueKeys.detail(venueId), 'events'],
26
28
  offers: (venueId) => [...exports.venueKeys.detail(venueId), 'offers'],
@@ -29,6 +31,17 @@ exports.venueKeys = {
29
31
  // ============================================================================
30
32
  // QUERY HOOKS
31
33
  // ============================================================================
34
+ function useMyVenues(options) {
35
+ return (0, react_query_1.useQuery)({
36
+ queryKey: exports.venueKeys.mine(),
37
+ queryFn: async () => {
38
+ const client = (0, client_1.getApiClient)();
39
+ const response = await client.get('/api/v1/venues/me');
40
+ return response.data;
41
+ },
42
+ ...options,
43
+ });
44
+ }
32
45
  /**
33
46
  * Get paginated list of venues with optional filters
34
47
  *
@@ -208,4 +221,4 @@ function useVenueOffers(venueId, options) {
208
221
  ...options,
209
222
  });
210
223
  }
211
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"venues.js","sourceRoot":"","sources":["../../../src/api/queries/venues.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { VenueResponse, VenueOwnerResponse, EventResponse, OfferResponse } from '../types';\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const venueKeys = {\n  all: ['venues'] as const,\n  lists: () => [...venueKeys.all, 'list'] as const,\n  list: (filters?: VenueFilters) => [...venueKeys.lists(), filters] as const,\n  details: () => [...venueKeys.all, 'detail'] as const,\n  detail: (id: string) => [...venueKeys.details(), id] as const,\n  featured: () => [...venueKeys.all, 'featured'] as const,\n  nearby: (params?: NearbyVenueParams) => [...venueKeys.all, 'nearby', params] as const,\n  owners: (venueId: string) => [...venueKeys.detail(venueId), 'owners'] as const,\n  events: (venueId: string) => [...venueKeys.detail(venueId), 'events'] as const,\n  offers: (venueId: string) => [...venueKeys.detail(venueId), 'offers'] as const,\n  rewards: (venueId: string) => [...venueKeys.detail(venueId), 'rewards'] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface VenueFilters {\n  page?: number;\n  limit?: number;\n  search?: string;\n  cityId?: string;\n  type?: string;\n  hasAfDrinks?: boolean;\n  isAfVenue?: boolean;\n  isFeatured?: boolean;\n  isFoundingPartner?: boolean;\n  lat?: number;\n  long?: number;\n  radius?: number;\n  sortBy?: string;\n  sortOrder?: 'asc' | 'desc';\n}\n\nexport interface NearbyVenueParams {\n  lat: number;\n  long: number;\n  radius?: number;\n  limit?: number;\n}\n\nexport interface PaginatedVenuesResponse {\n  venues: VenueResponse[];\n  meta: {\n    total: number;\n    page: number;\n    limit: number;\n    totalPages: number;\n  };\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get paginated list of venues with optional filters\n *\n * @param filters - Query parameters for filtering and pagination\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenues({\n *   page: 1,\n *   limit: 20,\n *   cityId: 'city-123',\n *   hasAfDrinks: true,\n * });\n * ```\n */\nexport function useVenues(\n  filters?: VenueFilters,\n  options?: Omit<UseQueryOptions<PaginatedVenuesResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.list(filters),\n    queryFn: async (): Promise<PaginatedVenuesResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/venues', {\n        params: filters,\n      });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get featured venues\n *\n * @param limit - Maximum number of venues to return\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useFeaturedVenues(10);\n * ```\n */\nexport function useFeaturedVenues(\n  limit?: number,\n  options?: Omit<UseQueryOptions<VenueResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.featured(),\n    queryFn: async (): Promise<VenueResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/venues/featured', {\n        params: { limit },\n      });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get nearby venues based on location\n *\n * @param params - Location parameters (latitude, longitude, radius)\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useNearbyVenues({\n *   lat: 51.5074,\n *   long: -0.1278,\n *   radius: 5, // 5km radius\n *   limit: 20,\n * });\n * ```\n */\nexport function useNearbyVenues(\n  params: NearbyVenueParams,\n  options?: Omit<UseQueryOptions<VenueResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.nearby(params),\n    queryFn: async (): Promise<VenueResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/venues/nearby', {\n        params,\n      });\n      return response.data;\n    },\n    enabled: !!params.lat && !!params.long,\n    ...options,\n  });\n}\n\n/**\n * Get a single venue by ID\n *\n * @param id - Venue ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenue('venue-123');\n * ```\n */\nexport function useVenue(\n  id: string,\n  options?: Omit<UseQueryOptions<VenueResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.detail(id),\n    queryFn: async (): Promise<VenueResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/venues/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\n/**\n * Get venue owners\n *\n * @param venueId - Venue ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenueOwners('venue-123');\n * ```\n */\nexport function useVenueOwners(\n  venueId: string,\n  options?: Omit<UseQueryOptions<VenueOwnerResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.owners(venueId),\n    queryFn: async (): Promise<VenueOwnerResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/venues/${venueId}/owners`);\n      return response.data;\n    },\n    enabled: !!venueId,\n    ...options,\n  });\n}\n\n/**\n * Get upcoming events at a venue\n *\n * @param venueId - Venue ID\n * @param limit - Maximum number of events to return\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenueEvents('venue-123', 20);\n * ```\n */\nexport function useVenueEvents(\n  venueId: string,\n  limit?: number,\n  options?: Omit<UseQueryOptions<EventResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.events(venueId),\n    queryFn: async (): Promise<EventResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/venues/${venueId}/events`, {\n        params: { limit },\n      });\n      return response.data?.data || response.data || [];\n    },\n    enabled: !!venueId,\n    ...options,\n  });\n}\n\n/**\n * Get offers for a venue (from legacy Business model)\n *\n * @param venueId - Venue ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenueOffers('venue-123');\n * ```\n */\nexport function useVenueOffers(\n  venueId: string,\n  options?: Omit<UseQueryOptions<OfferResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.offers(venueId),\n    queryFn: async (): Promise<OfferResponse[]> => {\n      const client = getApiClient();\n      // Use businesses endpoint for offers (legacy)\n      const response = await client.get(`/api/v1/businesses/${venueId}/offers`);\n      return response.data;\n    },\n    enabled: !!venueId,\n    ...options,\n  });\n}\n"]}
224
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"venues.js","sourceRoot":"","sources":["../../../src/api/queries/venues.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { VenueResponse, VenueOwnerResponse, EventResponse, OfferResponse } from '../types';\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const venueKeys = {\n  all: ['venues'] as const,\n  lists: () => [...venueKeys.all, 'list'] as const,\n  list: (filters?: VenueFilters) => [...venueKeys.lists(), filters] as const,\n  details: () => [...venueKeys.all, 'detail'] as const,\n  detail: (id: string) => [...venueKeys.details(), id] as const,\n  featured: () => [...venueKeys.all, 'featured'] as const,\n  nearby: (params?: NearbyVenueParams) => [...venueKeys.all, 'nearby', params] as const,\n  mine: () => [...venueKeys.all, 'mine'] as const,\n  owners: (venueId: string) => [...venueKeys.detail(venueId), 'owners'] as const,\n  events: (venueId: string) => [...venueKeys.detail(venueId), 'events'] as const,\n  offers: (venueId: string) => [...venueKeys.detail(venueId), 'offers'] as const,\n  rewards: (venueId: string) => [...venueKeys.detail(venueId), 'rewards'] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface VenueFilters {\n  page?: number;\n  limit?: number;\n  search?: string;\n  cityId?: string;\n  type?: string;\n  hasAfDrinks?: boolean;\n  isAfVenue?: boolean;\n  isFeatured?: boolean;\n  isFoundingPartner?: boolean;\n  lat?: number;\n  long?: number;\n  radius?: number;\n  sortBy?: string;\n  sortOrder?: 'asc' | 'desc';\n}\n\nexport interface NearbyVenueParams {\n  lat: number;\n  long: number;\n  radius?: number;\n  limit?: number;\n}\n\nexport interface PaginatedVenuesResponse {\n  venues: VenueResponse[];\n  meta: {\n    total: number;\n    page: number;\n    limit: number;\n    totalPages: number;\n  };\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\nexport function useMyVenues(\n  options?: Omit<UseQueryOptions<VenueResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.mine(),\n    queryFn: async (): Promise<VenueResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/venues/me');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get paginated list of venues with optional filters\n *\n * @param filters - Query parameters for filtering and pagination\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenues({\n *   page: 1,\n *   limit: 20,\n *   cityId: 'city-123',\n *   hasAfDrinks: true,\n * });\n * ```\n */\nexport function useVenues(\n  filters?: VenueFilters,\n  options?: Omit<UseQueryOptions<PaginatedVenuesResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.list(filters),\n    queryFn: async (): Promise<PaginatedVenuesResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/venues', {\n        params: filters,\n      });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get featured venues\n *\n * @param limit - Maximum number of venues to return\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useFeaturedVenues(10);\n * ```\n */\nexport function useFeaturedVenues(\n  limit?: number,\n  options?: Omit<UseQueryOptions<VenueResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.featured(),\n    queryFn: async (): Promise<VenueResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/venues/featured', {\n        params: { limit },\n      });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get nearby venues based on location\n *\n * @param params - Location parameters (latitude, longitude, radius)\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useNearbyVenues({\n *   lat: 51.5074,\n *   long: -0.1278,\n *   radius: 5, // 5km radius\n *   limit: 20,\n * });\n * ```\n */\nexport function useNearbyVenues(\n  params: NearbyVenueParams,\n  options?: Omit<UseQueryOptions<VenueResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.nearby(params),\n    queryFn: async (): Promise<VenueResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/venues/nearby', {\n        params,\n      });\n      return response.data;\n    },\n    enabled: !!params.lat && !!params.long,\n    ...options,\n  });\n}\n\n/**\n * Get a single venue by ID\n *\n * @param id - Venue ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenue('venue-123');\n * ```\n */\nexport function useVenue(\n  id: string,\n  options?: Omit<UseQueryOptions<VenueResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.detail(id),\n    queryFn: async (): Promise<VenueResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/venues/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\n/**\n * Get venue owners\n *\n * @param venueId - Venue ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenueOwners('venue-123');\n * ```\n */\nexport function useVenueOwners(\n  venueId: string,\n  options?: Omit<UseQueryOptions<VenueOwnerResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.owners(venueId),\n    queryFn: async (): Promise<VenueOwnerResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/venues/${venueId}/owners`);\n      return response.data;\n    },\n    enabled: !!venueId,\n    ...options,\n  });\n}\n\n/**\n * Get upcoming events at a venue\n *\n * @param venueId - Venue ID\n * @param limit - Maximum number of events to return\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenueEvents('venue-123', 20);\n * ```\n */\nexport function useVenueEvents(\n  venueId: string,\n  limit?: number,\n  options?: Omit<UseQueryOptions<EventResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.events(venueId),\n    queryFn: async (): Promise<EventResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/venues/${venueId}/events`, {\n        params: { limit },\n      });\n      return response.data?.data || response.data || [];\n    },\n    enabled: !!venueId,\n    ...options,\n  });\n}\n\n/**\n * Get offers for a venue (from legacy Business model)\n *\n * @param venueId - Venue ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useVenueOffers('venue-123');\n * ```\n */\nexport function useVenueOffers(\n  venueId: string,\n  options?: Omit<UseQueryOptions<OfferResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: venueKeys.offers(venueId),\n    queryFn: async (): Promise<OfferResponse[]> => {\n      const client = getApiClient();\n      // Use businesses endpoint for offers (legacy)\n      const response = await client.get(`/api/v1/businesses/${venueId}/offers`);\n      return response.data;\n    },\n    enabled: !!venueId,\n    ...options,\n  });\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@growsober/sdk",
3
- "version": "1.0.25",
3
+ "version": "1.0.27",
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",
@@ -3,10 +3,15 @@
3
3
 
4
4
  <!-- This section is auto-generated by claude-mem. Edit content outside the tags. -->
5
5
 
6
+ ### Jan 23, 2026
7
+
8
+ | ID | Time | T | Title | Read |
9
+ |----|------|---|-------|------|
10
+ | #197 | 3:19 AM | 🔴 | Fixed Stripe Connect Mutations Import from apiClient to getApiClient | ~313 |
11
+
6
12
  ### Jan 25, 2026
7
13
 
8
14
  | ID | Time | T | Title | Read |
9
15
  |----|------|---|-------|------|
10
- | #1598 | 9:42 AM | 🔵 | Jack AI comprehensive file inventory reveals 40+ files across web, API, SDK, and mobile | ~720 |
11
- | #1049 | 2:00 AM | 🔵 | Complete authentication system with dual email/password and phone OTP flows | ~674 |
16
+ | #1791 | 12:21 PM | 🔴 | Fixed Stripe Connect API Endpoint Paths with /api/v1 Prefix | ~399 |
12
17
  </claude-mem-context>
@@ -203,6 +203,60 @@ export function useCompleteProductBooking() {
203
203
  });
204
204
  }
205
205
 
206
+ // ============================================================================
207
+ // MUTATION HOOKS - CREATOR BOOKING MANAGEMENT
208
+ // ============================================================================
209
+
210
+ export function useConfirmProductBooking() {
211
+ const queryClient = useQueryClient();
212
+
213
+ return useMutation({
214
+ mutationFn: async ({
215
+ creatorId,
216
+ bookingId,
217
+ }: {
218
+ creatorId: string;
219
+ bookingId: string;
220
+ }): Promise<ProductBookingResponse> => {
221
+ const client = getApiClient();
222
+ const response = await client.post(
223
+ `/api/v1/creators/${creatorId}/products/bookings/${bookingId}/confirm`
224
+ );
225
+ return response.data;
226
+ },
227
+ onSuccess: (_, { creatorId, bookingId }) => {
228
+ queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });
229
+ queryClient.invalidateQueries({ queryKey: productKeys.creatorBookings(creatorId) });
230
+ queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });
231
+ },
232
+ });
233
+ }
234
+
235
+ export function useCompleteCreatorBooking() {
236
+ const queryClient = useQueryClient();
237
+
238
+ return useMutation({
239
+ mutationFn: async ({
240
+ creatorId,
241
+ bookingId,
242
+ }: {
243
+ creatorId: string;
244
+ bookingId: string;
245
+ }): Promise<ProductBookingResponse> => {
246
+ const client = getApiClient();
247
+ const response = await client.post(
248
+ `/api/v1/creators/${creatorId}/products/bookings/${bookingId}/complete`
249
+ );
250
+ return response.data;
251
+ },
252
+ onSuccess: (_, { creatorId, bookingId }) => {
253
+ queryClient.invalidateQueries({ queryKey: productKeys.bookingDetail(bookingId) });
254
+ queryClient.invalidateQueries({ queryKey: productKeys.creatorBookings(creatorId) });
255
+ queryClient.invalidateQueries({ queryKey: productKeys.myBookings() });
256
+ },
257
+ });
258
+ }
259
+
206
260
  // ============================================================================
207
261
  // MUTATION HOOKS - PAYMENTS
208
262
  // ============================================================================
@@ -1,7 +1,7 @@
1
1
  import { useMutation, useQueryClient, UseMutationOptions } from '@tanstack/react-query';
2
2
  import { getApiClient } from '../client';
3
3
  import { venueKeys } from '../queries/venues';
4
- import type { VenueResponse, CreateVenueRequest, UpdateVenueRequest } from '../types';
4
+ import type { VenueResponse, VenueOwnerResponse, CreateVenueRequest, UpdateVenueRequest, AddVenueOwnerRequest } from '../types';
5
5
 
6
6
  // ============================================================================
7
7
  // VENUE MUTATION HOOKS
@@ -41,7 +41,7 @@ export function useUpdateVenue(
41
41
  data: UpdateVenueRequest;
42
42
  }): Promise<VenueResponse> => {
43
43
  const client = getApiClient();
44
- const response = await client.patch(`/api/v1/venues/${id}`, data);
44
+ const response = await client.put(`/api/v1/venues/${id}`, data);
45
45
  return response.data?.data || response.data;
46
46
  },
47
47
  onSuccess: (_, variables) => {
@@ -125,3 +125,48 @@ export function useDeleteVenue(
125
125
  ...options,
126
126
  });
127
127
  }
128
+
129
+ // ============================================================================
130
+ // VENUE OWNER MUTATION HOOKS
131
+ // ============================================================================
132
+
133
+ export function useAddVenueOwner() {
134
+ const queryClient = useQueryClient();
135
+
136
+ return useMutation({
137
+ mutationFn: async ({
138
+ venueId,
139
+ data,
140
+ }: {
141
+ venueId: string;
142
+ data: AddVenueOwnerRequest;
143
+ }): Promise<VenueOwnerResponse> => {
144
+ const client = getApiClient();
145
+ const response = await client.post(`/api/v1/venues/${venueId}/owners`, data);
146
+ return response.data;
147
+ },
148
+ onSuccess: (_, { venueId }) => {
149
+ queryClient.invalidateQueries({ queryKey: venueKeys.owners(venueId) });
150
+ },
151
+ });
152
+ }
153
+
154
+ export function useRemoveVenueOwner() {
155
+ const queryClient = useQueryClient();
156
+
157
+ return useMutation({
158
+ mutationFn: async ({
159
+ venueId,
160
+ userId,
161
+ }: {
162
+ venueId: string;
163
+ userId: string;
164
+ }): Promise<void> => {
165
+ const client = getApiClient();
166
+ await client.delete(`/api/v1/venues/${venueId}/owners/${userId}`);
167
+ },
168
+ onSuccess: (_, { venueId }) => {
169
+ queryClient.invalidateQueries({ queryKey: venueKeys.owners(venueId) });
170
+ },
171
+ });
172
+ }
@@ -14,6 +14,7 @@ export const venueKeys = {
14
14
  detail: (id: string) => [...venueKeys.details(), id] as const,
15
15
  featured: () => [...venueKeys.all, 'featured'] as const,
16
16
  nearby: (params?: NearbyVenueParams) => [...venueKeys.all, 'nearby', params] as const,
17
+ mine: () => [...venueKeys.all, 'mine'] as const,
17
18
  owners: (venueId: string) => [...venueKeys.detail(venueId), 'owners'] as const,
18
19
  events: (venueId: string) => [...venueKeys.detail(venueId), 'events'] as const,
19
20
  offers: (venueId: string) => [...venueKeys.detail(venueId), 'offers'] as const,
@@ -62,6 +63,20 @@ export interface PaginatedVenuesResponse {
62
63
  // QUERY HOOKS
63
64
  // ============================================================================
64
65
 
66
+ export function useMyVenues(
67
+ options?: Omit<UseQueryOptions<VenueResponse[]>, 'queryKey' | 'queryFn'>
68
+ ) {
69
+ return useQuery({
70
+ queryKey: venueKeys.mine(),
71
+ queryFn: async (): Promise<VenueResponse[]> => {
72
+ const client = getApiClient();
73
+ const response = await client.get('/api/v1/venues/me');
74
+ return response.data;
75
+ },
76
+ ...options,
77
+ });
78
+ }
79
+
65
80
  /**
66
81
  * Get paginated list of venues with optional filters
67
82
  *
@@ -0,0 +1,7 @@
1
+ <claude-mem-context>
2
+ # Recent Activity
3
+
4
+ <!-- This section is auto-generated by claude-mem. Edit content outside the tags. -->
5
+
6
+ *No recent activity*
7
+ </claude-mem-context>