@growsober/sdk 1.0.5 → 1.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/__tests__/e2e.test.d.ts +30 -0
- package/dist/__tests__/e2e.test.js +959 -63
- package/dist/api/mutations/badges.d.ts +116 -0
- package/dist/api/mutations/badges.js +177 -0
- package/dist/api/mutations/brands.d.ts +251 -0
- package/dist/api/mutations/brands.js +242 -0
- package/dist/api/mutations/creators.d.ts +131 -0
- package/dist/api/mutations/creators.js +129 -0
- package/dist/api/mutations/event-chat.d.ts +2 -2
- package/dist/api/mutations/event-chat.js +9 -9
- package/dist/api/mutations/index.d.ts +4 -0
- package/dist/api/mutations/index.js +5 -1
- package/dist/api/mutations/jack.d.ts +29 -0
- package/dist/api/mutations/jack.js +41 -1
- package/dist/api/mutations/products.d.ts +175 -0
- package/dist/api/mutations/products.js +226 -0
- package/dist/api/mutations/support.d.ts +20 -1
- package/dist/api/mutations/support.js +36 -1
- package/dist/api/queries/badges.d.ts +221 -0
- package/dist/api/queries/badges.js +290 -0
- package/dist/api/queries/bookings.d.ts +1 -1
- package/dist/api/queries/brands.d.ts +248 -0
- package/dist/api/queries/brands.js +226 -0
- package/dist/api/queries/businesses.d.ts +61 -1
- package/dist/api/queries/businesses.js +27 -1
- package/dist/api/queries/creators.d.ts +332 -0
- package/dist/api/queries/creators.js +249 -0
- package/dist/api/queries/event-chat.d.ts +1 -1
- package/dist/api/queries/event-chat.js +4 -4
- package/dist/api/queries/events.d.ts +45 -0
- package/dist/api/queries/index.d.ts +5 -0
- package/dist/api/queries/index.js +6 -1
- package/dist/api/queries/jack.d.ts +80 -0
- package/dist/api/queries/jack.js +98 -1
- package/dist/api/queries/library.d.ts +8 -0
- package/dist/api/queries/products.d.ts +185 -0
- package/dist/api/queries/products.js +203 -0
- package/dist/api/queries/support.d.ts +46 -1
- package/dist/api/queries/support.js +48 -1
- package/dist/api/queries/venues.d.ts +304 -0
- package/dist/api/queries/venues.js +211 -0
- package/dist/api/types.d.ts +245 -0
- package/dist/api/types.js +6 -1
- package/dist/api/utils/eventGrouping.d.ts +104 -0
- package/dist/api/utils/eventGrouping.js +155 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +5 -1
- package/package.json +5 -2
- package/src/__tests__/e2e.test.ts +996 -64
- package/src/api/mutations/badges.ts +228 -0
- package/src/api/mutations/brands.ts +376 -0
- package/src/api/mutations/creators.ts +171 -0
- package/src/api/mutations/event-chat.ts +8 -8
- package/src/api/mutations/index.ts +4 -0
- package/src/api/mutations/jack.ts +50 -1
- package/src/api/mutations/products.ts +336 -0
- package/src/api/mutations/support.ts +44 -0
- package/src/api/queries/badges.ts +385 -0
- package/src/api/queries/brands.ts +281 -0
- package/src/api/queries/businesses.ts +30 -1
- package/src/api/queries/creators.ts +308 -0
- package/src/api/queries/event-chat.ts +3 -3
- package/src/api/queries/index.ts +5 -0
- package/src/api/queries/jack.ts +139 -1
- package/src/api/queries/products.ts +312 -0
- package/src/api/queries/support.ts +54 -0
- package/src/api/queries/venues.ts +271 -0
- package/src/api/types.ts +317 -1
- package/src/api/utils/eventGrouping.ts +181 -0
- package/src/index.ts +6 -0
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
import { UseQueryOptions } from '@tanstack/react-query';
|
|
2
|
+
export type ProductType = 'SESSION_1ON1' | 'SESSION_GROUP' | 'PACKAGE' | 'WORKSHOP' | 'CONSULTATION';
|
|
3
|
+
export type DeliveryMethod = 'VIDEO_CALL' | 'PHONE_CALL' | 'IN_PERSON' | 'HYBRID';
|
|
4
|
+
export type BookingStatus = 'PENDING' | 'CONFIRMED' | 'CANCELLED' | 'COMPLETED';
|
|
5
|
+
export type PaymentStatus = 'PENDING' | 'PAID' | 'REFUNDED' | 'FAILED';
|
|
6
|
+
export interface CreatorProductResponse {
|
|
7
|
+
id: string;
|
|
8
|
+
creatorId: string;
|
|
9
|
+
title: string;
|
|
10
|
+
slug: string;
|
|
11
|
+
description: string | null;
|
|
12
|
+
imageUrl: string | null;
|
|
13
|
+
type: ProductType;
|
|
14
|
+
price: number;
|
|
15
|
+
currency: string;
|
|
16
|
+
durationMinutes: number;
|
|
17
|
+
maxParticipants: number;
|
|
18
|
+
deliveryMethod: DeliveryMethod;
|
|
19
|
+
locationDetails: string | null;
|
|
20
|
+
isActive: boolean;
|
|
21
|
+
isFeatured: boolean;
|
|
22
|
+
createdAt: string;
|
|
23
|
+
updatedAt: string;
|
|
24
|
+
creator?: {
|
|
25
|
+
id: string;
|
|
26
|
+
displayName: string;
|
|
27
|
+
slug: string;
|
|
28
|
+
avatarUrl: string | null;
|
|
29
|
+
specialties?: string[];
|
|
30
|
+
certifications?: string[];
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
export interface ProductBookingResponse {
|
|
34
|
+
id: string;
|
|
35
|
+
productId: string;
|
|
36
|
+
userId: string;
|
|
37
|
+
scheduledAt: string;
|
|
38
|
+
timezone: string;
|
|
39
|
+
status: BookingStatus;
|
|
40
|
+
paymentStatus: PaymentStatus | null;
|
|
41
|
+
stripePaymentIntentId: string | null;
|
|
42
|
+
amountPaid: number | null;
|
|
43
|
+
currency: string;
|
|
44
|
+
clientNotes: string | null;
|
|
45
|
+
creatorNotes: string | null;
|
|
46
|
+
meetingLink: string | null;
|
|
47
|
+
isCompleted: boolean;
|
|
48
|
+
completedAt: string | null;
|
|
49
|
+
isCancelled: boolean;
|
|
50
|
+
cancelledAt: string | null;
|
|
51
|
+
cancelledBy: string | null;
|
|
52
|
+
cancellationReason: string | null;
|
|
53
|
+
createdAt: string;
|
|
54
|
+
updatedAt: string;
|
|
55
|
+
product?: CreatorProductResponse;
|
|
56
|
+
user?: {
|
|
57
|
+
id: string;
|
|
58
|
+
name: string;
|
|
59
|
+
profileImage: string | null;
|
|
60
|
+
email: string;
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
export interface ProductFilters {
|
|
64
|
+
page?: number;
|
|
65
|
+
limit?: number;
|
|
66
|
+
type?: ProductType;
|
|
67
|
+
deliveryMethod?: DeliveryMethod;
|
|
68
|
+
minPrice?: number;
|
|
69
|
+
maxPrice?: number;
|
|
70
|
+
isActive?: boolean;
|
|
71
|
+
}
|
|
72
|
+
export interface PaginatedProductsResponse {
|
|
73
|
+
products: CreatorProductResponse[];
|
|
74
|
+
meta: {
|
|
75
|
+
total: number;
|
|
76
|
+
page: number;
|
|
77
|
+
limit: number;
|
|
78
|
+
totalPages: number;
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
export declare const productKeys: {
|
|
82
|
+
all: readonly ["products"];
|
|
83
|
+
lists: () => readonly ["products", "list"];
|
|
84
|
+
list: (filters?: ProductFilters) => readonly ["products", "list", ProductFilters | undefined];
|
|
85
|
+
details: () => readonly ["products", "detail"];
|
|
86
|
+
detail: (id: string) => readonly ["products", "detail", string];
|
|
87
|
+
slug: (slug: string) => readonly ["products", "slug", string];
|
|
88
|
+
byCreator: (creatorId: string, filters?: ProductFilters) => readonly ["products", "creator", string, ProductFilters | undefined];
|
|
89
|
+
bookings: () => readonly ["products", "bookings"];
|
|
90
|
+
myBookings: () => readonly ["products", "bookings", "me"];
|
|
91
|
+
creatorBookings: (creatorId: string) => readonly ["products", "bookings", "creator", string];
|
|
92
|
+
bookingDetail: (bookingId: string) => readonly ["products", "bookings", "detail", string];
|
|
93
|
+
};
|
|
94
|
+
/**
|
|
95
|
+
* Get paginated list of all active products
|
|
96
|
+
*
|
|
97
|
+
* @param filters - Query parameters for filtering and pagination
|
|
98
|
+
* @param options - TanStack Query options
|
|
99
|
+
*
|
|
100
|
+
* @example
|
|
101
|
+
* ```tsx
|
|
102
|
+
* const { data, isLoading } = useProducts({
|
|
103
|
+
* page: 1,
|
|
104
|
+
* limit: 20,
|
|
105
|
+
* type: 'SESSION_1ON1',
|
|
106
|
+
* });
|
|
107
|
+
* ```
|
|
108
|
+
*/
|
|
109
|
+
export declare function useProducts(filters?: ProductFilters, options?: Omit<UseQueryOptions<PaginatedProductsResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PaginatedProductsResponse, Error>;
|
|
110
|
+
/**
|
|
111
|
+
* Get a single product by ID
|
|
112
|
+
*
|
|
113
|
+
* @param id - Product ID
|
|
114
|
+
* @param options - TanStack Query options
|
|
115
|
+
*
|
|
116
|
+
* @example
|
|
117
|
+
* ```tsx
|
|
118
|
+
* const { data, isLoading } = useProduct('product-123');
|
|
119
|
+
* ```
|
|
120
|
+
*/
|
|
121
|
+
export declare function useProduct(id: string, options?: Omit<UseQueryOptions<CreatorProductResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<CreatorProductResponse, Error>;
|
|
122
|
+
/**
|
|
123
|
+
* Get a product by its slug
|
|
124
|
+
*
|
|
125
|
+
* @param slug - Product slug
|
|
126
|
+
* @param options - TanStack Query options
|
|
127
|
+
*
|
|
128
|
+
* @example
|
|
129
|
+
* ```tsx
|
|
130
|
+
* const { data, isLoading } = useProductBySlug('1-on-1-coaching-abc123');
|
|
131
|
+
* ```
|
|
132
|
+
*/
|
|
133
|
+
export declare function useProductBySlug(slug: string, options?: Omit<UseQueryOptions<CreatorProductResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<CreatorProductResponse, Error>;
|
|
134
|
+
/**
|
|
135
|
+
* Get products for a specific creator
|
|
136
|
+
*
|
|
137
|
+
* @param creatorId - Creator ID
|
|
138
|
+
* @param filters - Query parameters for filtering
|
|
139
|
+
* @param options - TanStack Query options
|
|
140
|
+
*
|
|
141
|
+
* @example
|
|
142
|
+
* ```tsx
|
|
143
|
+
* const { data, isLoading } = useCreatorProducts('creator-123', {
|
|
144
|
+
* type: 'SESSION_1ON1',
|
|
145
|
+
* isActive: true,
|
|
146
|
+
* });
|
|
147
|
+
* ```
|
|
148
|
+
*/
|
|
149
|
+
export declare function useCreatorProducts(creatorId: string, filters?: ProductFilters, options?: Omit<UseQueryOptions<PaginatedProductsResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<PaginatedProductsResponse, Error>;
|
|
150
|
+
/**
|
|
151
|
+
* Get current user's product bookings
|
|
152
|
+
*
|
|
153
|
+
* @param options - TanStack Query options
|
|
154
|
+
*
|
|
155
|
+
* @example
|
|
156
|
+
* ```tsx
|
|
157
|
+
* const { data, isLoading } = useMyProductBookings();
|
|
158
|
+
* ```
|
|
159
|
+
*/
|
|
160
|
+
export declare function useMyProductBookings(options?: Omit<UseQueryOptions<ProductBookingResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<ProductBookingResponse[], Error>;
|
|
161
|
+
/**
|
|
162
|
+
* Get a single product booking by ID
|
|
163
|
+
*
|
|
164
|
+
* @param bookingId - Booking ID
|
|
165
|
+
* @param options - TanStack Query options
|
|
166
|
+
*
|
|
167
|
+
* @example
|
|
168
|
+
* ```tsx
|
|
169
|
+
* const { data, isLoading } = useProductBooking('booking-123');
|
|
170
|
+
* ```
|
|
171
|
+
*/
|
|
172
|
+
export declare function useProductBooking(bookingId: string, options?: Omit<UseQueryOptions<ProductBookingResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<ProductBookingResponse, Error>;
|
|
173
|
+
/**
|
|
174
|
+
* Get bookings for a creator's products (creator dashboard)
|
|
175
|
+
*
|
|
176
|
+
* @param creatorId - Creator ID
|
|
177
|
+
* @param options - TanStack Query options
|
|
178
|
+
*
|
|
179
|
+
* @example
|
|
180
|
+
* ```tsx
|
|
181
|
+
* // For creator dashboard - see all bookings for their products
|
|
182
|
+
* const { data, isLoading } = useCreatorBookings('creator-123');
|
|
183
|
+
* ```
|
|
184
|
+
*/
|
|
185
|
+
export declare function useCreatorBookings(creatorId: string, options?: Omit<UseQueryOptions<ProductBookingResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<ProductBookingResponse[], Error>;
|
|
@@ -0,0 +1,203 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.productKeys = void 0;
|
|
4
|
+
exports.useProducts = useProducts;
|
|
5
|
+
exports.useProduct = useProduct;
|
|
6
|
+
exports.useProductBySlug = useProductBySlug;
|
|
7
|
+
exports.useCreatorProducts = useCreatorProducts;
|
|
8
|
+
exports.useMyProductBookings = useMyProductBookings;
|
|
9
|
+
exports.useProductBooking = useProductBooking;
|
|
10
|
+
exports.useCreatorBookings = useCreatorBookings;
|
|
11
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
12
|
+
const client_1 = require("../client");
|
|
13
|
+
// ============================================================================
|
|
14
|
+
// QUERY KEY FACTORY
|
|
15
|
+
// ============================================================================
|
|
16
|
+
exports.productKeys = {
|
|
17
|
+
all: ['products'],
|
|
18
|
+
lists: () => [...exports.productKeys.all, 'list'],
|
|
19
|
+
list: (filters) => [...exports.productKeys.lists(), filters],
|
|
20
|
+
details: () => [...exports.productKeys.all, 'detail'],
|
|
21
|
+
detail: (id) => [...exports.productKeys.details(), id],
|
|
22
|
+
slug: (slug) => [...exports.productKeys.all, 'slug', slug],
|
|
23
|
+
byCreator: (creatorId, filters) => [...exports.productKeys.all, 'creator', creatorId, filters],
|
|
24
|
+
bookings: () => [...exports.productKeys.all, 'bookings'],
|
|
25
|
+
myBookings: () => [...exports.productKeys.bookings(), 'me'],
|
|
26
|
+
creatorBookings: (creatorId) => [...exports.productKeys.bookings(), 'creator', creatorId],
|
|
27
|
+
bookingDetail: (bookingId) => [...exports.productKeys.bookings(), 'detail', bookingId],
|
|
28
|
+
};
|
|
29
|
+
// ============================================================================
|
|
30
|
+
// QUERY HOOKS
|
|
31
|
+
// ============================================================================
|
|
32
|
+
/**
|
|
33
|
+
* Get paginated list of all active products
|
|
34
|
+
*
|
|
35
|
+
* @param filters - Query parameters for filtering and pagination
|
|
36
|
+
* @param options - TanStack Query options
|
|
37
|
+
*
|
|
38
|
+
* @example
|
|
39
|
+
* ```tsx
|
|
40
|
+
* const { data, isLoading } = useProducts({
|
|
41
|
+
* page: 1,
|
|
42
|
+
* limit: 20,
|
|
43
|
+
* type: 'SESSION_1ON1',
|
|
44
|
+
* });
|
|
45
|
+
* ```
|
|
46
|
+
*/
|
|
47
|
+
function useProducts(filters, options) {
|
|
48
|
+
return (0, react_query_1.useQuery)({
|
|
49
|
+
queryKey: exports.productKeys.list(filters),
|
|
50
|
+
queryFn: async () => {
|
|
51
|
+
const client = (0, client_1.getApiClient)();
|
|
52
|
+
const response = await client.get('/api/v1/products', {
|
|
53
|
+
params: filters,
|
|
54
|
+
});
|
|
55
|
+
return response.data;
|
|
56
|
+
},
|
|
57
|
+
...options,
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Get a single product by ID
|
|
62
|
+
*
|
|
63
|
+
* @param id - Product ID
|
|
64
|
+
* @param options - TanStack Query options
|
|
65
|
+
*
|
|
66
|
+
* @example
|
|
67
|
+
* ```tsx
|
|
68
|
+
* const { data, isLoading } = useProduct('product-123');
|
|
69
|
+
* ```
|
|
70
|
+
*/
|
|
71
|
+
function useProduct(id, options) {
|
|
72
|
+
return (0, react_query_1.useQuery)({
|
|
73
|
+
queryKey: exports.productKeys.detail(id),
|
|
74
|
+
queryFn: async () => {
|
|
75
|
+
const client = (0, client_1.getApiClient)();
|
|
76
|
+
const response = await client.get(`/api/v1/products/${id}`);
|
|
77
|
+
return response.data;
|
|
78
|
+
},
|
|
79
|
+
enabled: !!id,
|
|
80
|
+
...options,
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Get a product by its slug
|
|
85
|
+
*
|
|
86
|
+
* @param slug - Product slug
|
|
87
|
+
* @param options - TanStack Query options
|
|
88
|
+
*
|
|
89
|
+
* @example
|
|
90
|
+
* ```tsx
|
|
91
|
+
* const { data, isLoading } = useProductBySlug('1-on-1-coaching-abc123');
|
|
92
|
+
* ```
|
|
93
|
+
*/
|
|
94
|
+
function useProductBySlug(slug, options) {
|
|
95
|
+
return (0, react_query_1.useQuery)({
|
|
96
|
+
queryKey: exports.productKeys.slug(slug),
|
|
97
|
+
queryFn: async () => {
|
|
98
|
+
const client = (0, client_1.getApiClient)();
|
|
99
|
+
const response = await client.get(`/api/v1/products/slug/${slug}`);
|
|
100
|
+
return response.data;
|
|
101
|
+
},
|
|
102
|
+
enabled: !!slug,
|
|
103
|
+
...options,
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Get products for a specific creator
|
|
108
|
+
*
|
|
109
|
+
* @param creatorId - Creator ID
|
|
110
|
+
* @param filters - Query parameters for filtering
|
|
111
|
+
* @param options - TanStack Query options
|
|
112
|
+
*
|
|
113
|
+
* @example
|
|
114
|
+
* ```tsx
|
|
115
|
+
* const { data, isLoading } = useCreatorProducts('creator-123', {
|
|
116
|
+
* type: 'SESSION_1ON1',
|
|
117
|
+
* isActive: true,
|
|
118
|
+
* });
|
|
119
|
+
* ```
|
|
120
|
+
*/
|
|
121
|
+
function useCreatorProducts(creatorId, filters, options) {
|
|
122
|
+
return (0, react_query_1.useQuery)({
|
|
123
|
+
queryKey: exports.productKeys.byCreator(creatorId, filters),
|
|
124
|
+
queryFn: async () => {
|
|
125
|
+
const client = (0, client_1.getApiClient)();
|
|
126
|
+
const response = await client.get(`/api/v1/creators/${creatorId}/products`, {
|
|
127
|
+
params: filters,
|
|
128
|
+
});
|
|
129
|
+
return response.data;
|
|
130
|
+
},
|
|
131
|
+
enabled: !!creatorId,
|
|
132
|
+
...options,
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Get current user's product bookings
|
|
137
|
+
*
|
|
138
|
+
* @param options - TanStack Query options
|
|
139
|
+
*
|
|
140
|
+
* @example
|
|
141
|
+
* ```tsx
|
|
142
|
+
* const { data, isLoading } = useMyProductBookings();
|
|
143
|
+
* ```
|
|
144
|
+
*/
|
|
145
|
+
function useMyProductBookings(options) {
|
|
146
|
+
return (0, react_query_1.useQuery)({
|
|
147
|
+
queryKey: exports.productKeys.myBookings(),
|
|
148
|
+
queryFn: async () => {
|
|
149
|
+
const client = (0, client_1.getApiClient)();
|
|
150
|
+
const response = await client.get('/api/v1/users/me/product-bookings');
|
|
151
|
+
return response.data;
|
|
152
|
+
},
|
|
153
|
+
...options,
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Get a single product booking by ID
|
|
158
|
+
*
|
|
159
|
+
* @param bookingId - Booking ID
|
|
160
|
+
* @param options - TanStack Query options
|
|
161
|
+
*
|
|
162
|
+
* @example
|
|
163
|
+
* ```tsx
|
|
164
|
+
* const { data, isLoading } = useProductBooking('booking-123');
|
|
165
|
+
* ```
|
|
166
|
+
*/
|
|
167
|
+
function useProductBooking(bookingId, options) {
|
|
168
|
+
return (0, react_query_1.useQuery)({
|
|
169
|
+
queryKey: exports.productKeys.bookingDetail(bookingId),
|
|
170
|
+
queryFn: async () => {
|
|
171
|
+
const client = (0, client_1.getApiClient)();
|
|
172
|
+
const response = await client.get(`/api/v1/users/me/product-bookings/${bookingId}`);
|
|
173
|
+
return response.data;
|
|
174
|
+
},
|
|
175
|
+
enabled: !!bookingId,
|
|
176
|
+
...options,
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* Get bookings for a creator's products (creator dashboard)
|
|
181
|
+
*
|
|
182
|
+
* @param creatorId - Creator ID
|
|
183
|
+
* @param options - TanStack Query options
|
|
184
|
+
*
|
|
185
|
+
* @example
|
|
186
|
+
* ```tsx
|
|
187
|
+
* // For creator dashboard - see all bookings for their products
|
|
188
|
+
* const { data, isLoading } = useCreatorBookings('creator-123');
|
|
189
|
+
* ```
|
|
190
|
+
*/
|
|
191
|
+
function useCreatorBookings(creatorId, options) {
|
|
192
|
+
return (0, react_query_1.useQuery)({
|
|
193
|
+
queryKey: exports.productKeys.creatorBookings(creatorId),
|
|
194
|
+
queryFn: async () => {
|
|
195
|
+
const client = (0, client_1.getApiClient)();
|
|
196
|
+
const response = await client.get(`/api/v1/creators/${creatorId}/products/bookings`);
|
|
197
|
+
return response.data;
|
|
198
|
+
},
|
|
199
|
+
enabled: !!creatorId,
|
|
200
|
+
...options,
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.js","sourceRoot":"","sources":["../../../src/api/queries/products.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport type ProductType = 'SESSION_1ON1' | 'SESSION_GROUP' | 'PACKAGE' | 'WORKSHOP' | 'CONSULTATION';\nexport type DeliveryMethod = 'VIDEO_CALL' | 'PHONE_CALL' | 'IN_PERSON' | 'HYBRID';\nexport type BookingStatus = 'PENDING' | 'CONFIRMED' | 'CANCELLED' | 'COMPLETED';\nexport type PaymentStatus = 'PENDING' | 'PAID' | 'REFUNDED' | 'FAILED';\n\nexport interface CreatorProductResponse {\n  id: string;\n  creatorId: string;\n  title: string;\n  slug: string;\n  description: string | null;\n  imageUrl: string | null;\n  type: ProductType;\n  price: number;\n  currency: string;\n  durationMinutes: number;\n  maxParticipants: number;\n  deliveryMethod: DeliveryMethod;\n  locationDetails: string | null;\n  isActive: boolean;\n  isFeatured: boolean;\n  createdAt: string;\n  updatedAt: string;\n  creator?: {\n    id: string;\n    displayName: string;\n    slug: string;\n    avatarUrl: string | null;\n    specialties?: string[];\n    certifications?: string[];\n  };\n}\n\nexport interface ProductBookingResponse {\n  id: string;\n  productId: string;\n  userId: string;\n  scheduledAt: string;\n  timezone: string;\n  status: BookingStatus;\n  paymentStatus: PaymentStatus | null;\n  stripePaymentIntentId: string | null;\n  amountPaid: number | null;\n  currency: string;\n  clientNotes: string | null;\n  creatorNotes: string | null;\n  meetingLink: string | null;\n  isCompleted: boolean;\n  completedAt: string | null;\n  isCancelled: boolean;\n  cancelledAt: string | null;\n  cancelledBy: string | null;\n  cancellationReason: string | null;\n  createdAt: string;\n  updatedAt: string;\n  product?: CreatorProductResponse;\n  user?: {\n    id: string;\n    name: string;\n    profileImage: string | null;\n    email: string;\n  };\n}\n\nexport interface ProductFilters {\n  page?: number;\n  limit?: number;\n  type?: ProductType;\n  deliveryMethod?: DeliveryMethod;\n  minPrice?: number;\n  maxPrice?: number;\n  isActive?: boolean;\n}\n\nexport interface PaginatedProductsResponse {\n  products: CreatorProductResponse[];\n  meta: {\n    total: number;\n    page: number;\n    limit: number;\n    totalPages: number;\n  };\n}\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const productKeys = {\n  all: ['products'] as const,\n  lists: () => [...productKeys.all, 'list'] as const,\n  list: (filters?: ProductFilters) => [...productKeys.lists(), filters] as const,\n  details: () => [...productKeys.all, 'detail'] as const,\n  detail: (id: string) => [...productKeys.details(), id] as const,\n  slug: (slug: string) => [...productKeys.all, 'slug', slug] as const,\n  byCreator: (creatorId: string, filters?: ProductFilters) =>\n    [...productKeys.all, 'creator', creatorId, filters] as const,\n  bookings: () => [...productKeys.all, 'bookings'] as const,\n  myBookings: () => [...productKeys.bookings(), 'me'] as const,\n  creatorBookings: (creatorId: string) => [...productKeys.bookings(), 'creator', creatorId] as const,\n  bookingDetail: (bookingId: string) => [...productKeys.bookings(), 'detail', bookingId] as const,\n};\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get paginated list of all active products\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 } = useProducts({\n *   page: 1,\n *   limit: 20,\n *   type: 'SESSION_1ON1',\n * });\n * ```\n */\nexport function useProducts(\n  filters?: ProductFilters,\n  options?: Omit<UseQueryOptions<PaginatedProductsResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.list(filters),\n    queryFn: async (): Promise<PaginatedProductsResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/products', {\n        params: filters,\n      });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get a single product by ID\n *\n * @param id - Product ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useProduct('product-123');\n * ```\n */\nexport function useProduct(\n  id: string,\n  options?: Omit<UseQueryOptions<CreatorProductResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.detail(id),\n    queryFn: async (): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/products/${id}`);\n      return response.data;\n    },\n    enabled: !!id,\n    ...options,\n  });\n}\n\n/**\n * Get a product by its slug\n *\n * @param slug - Product slug\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useProductBySlug('1-on-1-coaching-abc123');\n * ```\n */\nexport function useProductBySlug(\n  slug: string,\n  options?: Omit<UseQueryOptions<CreatorProductResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.slug(slug),\n    queryFn: async (): Promise<CreatorProductResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/products/slug/${slug}`);\n      return response.data;\n    },\n    enabled: !!slug,\n    ...options,\n  });\n}\n\n/**\n * Get products for a specific creator\n *\n * @param creatorId - Creator ID\n * @param filters - Query parameters for filtering\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCreatorProducts('creator-123', {\n *   type: 'SESSION_1ON1',\n *   isActive: true,\n * });\n * ```\n */\nexport function useCreatorProducts(\n  creatorId: string,\n  filters?: ProductFilters,\n  options?: Omit<UseQueryOptions<PaginatedProductsResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.byCreator(creatorId, filters),\n    queryFn: async (): Promise<PaginatedProductsResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/products`, {\n        params: filters,\n      });\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n\n/**\n * Get current user's product bookings\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useMyProductBookings();\n * ```\n */\nexport function useMyProductBookings(\n  options?: Omit<UseQueryOptions<ProductBookingResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.myBookings(),\n    queryFn: async (): Promise<ProductBookingResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/users/me/product-bookings');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get a single product booking by ID\n *\n * @param bookingId - Booking ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useProductBooking('booking-123');\n * ```\n */\nexport function useProductBooking(\n  bookingId: string,\n  options?: Omit<UseQueryOptions<ProductBookingResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.bookingDetail(bookingId),\n    queryFn: async (): Promise<ProductBookingResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/users/me/product-bookings/${bookingId}`);\n      return response.data;\n    },\n    enabled: !!bookingId,\n    ...options,\n  });\n}\n\n/**\n * Get bookings for a creator's products (creator dashboard)\n *\n * @param creatorId - Creator ID\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * // For creator dashboard - see all bookings for their products\n * const { data, isLoading } = useCreatorBookings('creator-123');\n * ```\n */\nexport function useCreatorBookings(\n  creatorId: string,\n  options?: Omit<UseQueryOptions<ProductBookingResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: productKeys.creatorBookings(creatorId),\n    queryFn: async (): Promise<ProductBookingResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/creators/${creatorId}/products/bookings`);\n      return response.data;\n    },\n    enabled: !!creatorId,\n    ...options,\n  });\n}\n"]}
|
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
import { UseQueryOptions } from '@tanstack/react-query';
|
|
2
|
-
import type { CheckInResponse, CheckInStreakResponse, MoodLogResponse, WinResponse, HabitResponse, ReflectionResponse } from '../types';
|
|
2
|
+
import type { CheckInResponse, CheckInStreakResponse, MoodLogResponse, WinResponse, HabitResponse, ReflectionResponse, CravingLogResponse, CravingStatsResponse } from '../types';
|
|
3
3
|
export declare const supportKeys: {
|
|
4
4
|
all: readonly ["support"];
|
|
5
5
|
checkIns: () => readonly ["support", "check-ins"];
|
|
6
6
|
checkInToday: () => readonly ["support", "check-ins", "today"];
|
|
7
7
|
checkInStreak: () => readonly ["support", "check-ins", "streak"];
|
|
8
8
|
moodLogs: () => readonly ["support", "mood"];
|
|
9
|
+
cravings: () => readonly ["support", "cravings"];
|
|
10
|
+
cravingStats: (days?: number) => readonly ["support", "cravings", "stats", number | undefined];
|
|
9
11
|
wins: () => readonly ["support", "wins"];
|
|
10
12
|
winsByCategory: () => readonly ["support", "wins", "by-category"];
|
|
11
13
|
habits: () => readonly ["support", "habits"];
|
|
@@ -184,3 +186,46 @@ export declare function useReflections(options?: Omit<UseQueryOptions<Reflection
|
|
|
184
186
|
createdAt: string;
|
|
185
187
|
updatedAt: string;
|
|
186
188
|
}[], Error>;
|
|
189
|
+
/**
|
|
190
|
+
* Get user's craving logs
|
|
191
|
+
*
|
|
192
|
+
* @param options - TanStack Query options
|
|
193
|
+
*
|
|
194
|
+
* @example
|
|
195
|
+
* ```tsx
|
|
196
|
+
* const { data, isLoading } = useCravings();
|
|
197
|
+
* ```
|
|
198
|
+
*/
|
|
199
|
+
export declare function useCravings(options?: Omit<UseQueryOptions<CravingLogResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
200
|
+
id: string;
|
|
201
|
+
userId: string;
|
|
202
|
+
intensity: number;
|
|
203
|
+
trigger?: Record<string, never>;
|
|
204
|
+
triggerType?: "STRESS" | "SOCIAL_PRESSURE" | "BOREDOM" | "EMOTIONAL" | "CELEBRATION" | "HABIT" | "PHYSICAL" | "ENVIRONMENT" | "OTHER";
|
|
205
|
+
notes?: Record<string, never>;
|
|
206
|
+
copingUsed: string[];
|
|
207
|
+
didResist?: Record<string, never>;
|
|
208
|
+
situation?: Record<string, never>;
|
|
209
|
+
mood?: Record<string, never>;
|
|
210
|
+
createdAt: string;
|
|
211
|
+
}[], Error>;
|
|
212
|
+
/**
|
|
213
|
+
* Get craving statistics for a given period
|
|
214
|
+
*
|
|
215
|
+
* @param days - Number of days to include (default: 30)
|
|
216
|
+
* @param options - TanStack Query options
|
|
217
|
+
*
|
|
218
|
+
* @example
|
|
219
|
+
* ```tsx
|
|
220
|
+
* const { data, isLoading } = useCravingStats(30);
|
|
221
|
+
* ```
|
|
222
|
+
*/
|
|
223
|
+
export declare function useCravingStats(days?: number, options?: Omit<UseQueryOptions<CravingStatsResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
224
|
+
averageIntensity: number;
|
|
225
|
+
totalLogs: number;
|
|
226
|
+
timesResisted: number;
|
|
227
|
+
resistanceRate: number;
|
|
228
|
+
topTriggers: string[];
|
|
229
|
+
topCopingStrategies: string[];
|
|
230
|
+
intensityDistribution: Record<string, never>;
|
|
231
|
+
}, Error>;
|
|
@@ -9,6 +9,8 @@ exports.useWins = useWins;
|
|
|
9
9
|
exports.useWinsByCategory = useWinsByCategory;
|
|
10
10
|
exports.useHabits = useHabits;
|
|
11
11
|
exports.useReflections = useReflections;
|
|
12
|
+
exports.useCravings = useCravings;
|
|
13
|
+
exports.useCravingStats = useCravingStats;
|
|
12
14
|
const react_query_1 = require("@tanstack/react-query");
|
|
13
15
|
const client_1 = require("../client");
|
|
14
16
|
// ============================================================================
|
|
@@ -20,6 +22,8 @@ exports.supportKeys = {
|
|
|
20
22
|
checkInToday: () => [...exports.supportKeys.checkIns(), 'today'],
|
|
21
23
|
checkInStreak: () => [...exports.supportKeys.checkIns(), 'streak'],
|
|
22
24
|
moodLogs: () => [...exports.supportKeys.all, 'mood'],
|
|
25
|
+
cravings: () => [...exports.supportKeys.all, 'cravings'],
|
|
26
|
+
cravingStats: (days) => [...exports.supportKeys.cravings(), 'stats', days],
|
|
23
27
|
wins: () => [...exports.supportKeys.all, 'wins'],
|
|
24
28
|
winsByCategory: () => [...exports.supportKeys.wins(), 'by-category'],
|
|
25
29
|
habits: () => [...exports.supportKeys.all, 'habits'],
|
|
@@ -199,4 +203,47 @@ function useReflections(options) {
|
|
|
199
203
|
...options,
|
|
200
204
|
});
|
|
201
205
|
}
|
|
202
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"support.js","sourceRoot":"","sources":["../../../src/api/queries/support.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type {\n  CheckInResponse,\n  CheckInStreakResponse,\n  MoodLogResponse,\n  WinResponse,\n  HabitResponse,\n  ReflectionResponse,\n} from '../types';\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const supportKeys = {\n  all: ['support'] as const,\n  checkIns: () => [...supportKeys.all, 'check-ins'] as const,\n  checkInToday: () => [...supportKeys.checkIns(), 'today'] as const,\n  checkInStreak: () => [...supportKeys.checkIns(), 'streak'] as const,\n  moodLogs: () => [...supportKeys.all, 'mood'] as const,\n  wins: () => [...supportKeys.all, 'wins'] as const,\n  winsByCategory: () => [...supportKeys.wins(), 'by-category'] as const,\n  habits: () => [...supportKeys.all, 'habits'] as const,\n  reflections: () => [...supportKeys.all, 'reflections'] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface WinsByCategory {\n  category: string;\n  wins: WinResponse[];\n  count: number;\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get user's daily check-ins\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCheckIns();\n * ```\n */\nexport function useCheckIns(\n  options?: Omit<UseQueryOptions<CheckInResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.checkIns(),\n    queryFn: async (): Promise<CheckInResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/check-ins');\n      // API wraps responses in { data: [...], meta: {...} }\n      return response.data?.data || response.data || [];\n    },\n    ...options,\n  });\n}\n\n/**\n * Get today's check-in\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useTodayCheckIn();\n * ```\n */\nexport function useTodayCheckIn(\n  options?: Omit<UseQueryOptions<CheckInResponse | null>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.checkInToday(),\n    queryFn: async (): Promise<CheckInResponse | null> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/check-ins/today');\n      // API wraps responses in { data: {...}, meta: {...} }\n      return response.data?.data ?? response.data ?? null;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user's check-in streak\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCheckInStreak();\n * ```\n */\nexport function useCheckInStreak(\n  options?: Omit<UseQueryOptions<CheckInStreakResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.checkInStreak(),\n    queryFn: async (): Promise<CheckInStreakResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/check-ins/streak');\n      // API wraps responses in { data: {...}, meta: {...} }\n      return response.data?.data || response.data || { currentStreak: 0, longestStreak: 0, totalCheckIns: 0 };\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user's mood logs\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useMoodLogs();\n * ```\n */\nexport function useMoodLogs(\n  options?: Omit<UseQueryOptions<MoodLogResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.moodLogs(),\n    queryFn: async (): Promise<MoodLogResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/mood');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user's wins\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useWins();\n * ```\n */\nexport function useWins(\n  options?: Omit<UseQueryOptions<WinResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.wins(),\n    queryFn: async (): Promise<WinResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/wins');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user's wins grouped by category\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useWinsByCategory();\n * ```\n */\nexport function useWinsByCategory(\n  options?: Omit<UseQueryOptions<WinsByCategory[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.winsByCategory(),\n    queryFn: async (): Promise<WinsByCategory[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/wins/by-category');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user's habits\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useHabits();\n * ```\n */\nexport function useHabits(\n  options?: Omit<UseQueryOptions<HabitResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.habits(),\n    queryFn: async (): Promise<HabitResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/habits');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user's reflections\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useReflections();\n * ```\n */\nexport function useReflections(\n  options?: Omit<UseQueryOptions<ReflectionResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.reflections(),\n    queryFn: async (): Promise<ReflectionResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/reflections');\n      return response.data;\n    },\n    ...options,\n  });\n}\n"]}
|
|
206
|
+
/**
|
|
207
|
+
* Get user's craving logs
|
|
208
|
+
*
|
|
209
|
+
* @param options - TanStack Query options
|
|
210
|
+
*
|
|
211
|
+
* @example
|
|
212
|
+
* ```tsx
|
|
213
|
+
* const { data, isLoading } = useCravings();
|
|
214
|
+
* ```
|
|
215
|
+
*/
|
|
216
|
+
function useCravings(options) {
|
|
217
|
+
return (0, react_query_1.useQuery)({
|
|
218
|
+
queryKey: exports.supportKeys.cravings(),
|
|
219
|
+
queryFn: async () => {
|
|
220
|
+
const client = (0, client_1.getApiClient)();
|
|
221
|
+
const response = await client.get('/api/v1/support/cravings');
|
|
222
|
+
return response.data;
|
|
223
|
+
},
|
|
224
|
+
...options,
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
/**
|
|
228
|
+
* Get craving statistics for a given period
|
|
229
|
+
*
|
|
230
|
+
* @param days - Number of days to include (default: 30)
|
|
231
|
+
* @param options - TanStack Query options
|
|
232
|
+
*
|
|
233
|
+
* @example
|
|
234
|
+
* ```tsx
|
|
235
|
+
* const { data, isLoading } = useCravingStats(30);
|
|
236
|
+
* ```
|
|
237
|
+
*/
|
|
238
|
+
function useCravingStats(days = 30, options) {
|
|
239
|
+
return (0, react_query_1.useQuery)({
|
|
240
|
+
queryKey: exports.supportKeys.cravingStats(days),
|
|
241
|
+
queryFn: async () => {
|
|
242
|
+
const client = (0, client_1.getApiClient)();
|
|
243
|
+
const response = await client.get(`/api/v1/support/cravings/stats?days=${days}`);
|
|
244
|
+
return response.data;
|
|
245
|
+
},
|
|
246
|
+
...options,
|
|
247
|
+
});
|
|
248
|
+
}
|
|
249
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"support.js","sourceRoot":"","sources":["../../../src/api/queries/support.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type {\n  CheckInResponse,\n  CheckInStreakResponse,\n  MoodLogResponse,\n  WinResponse,\n  HabitResponse,\n  ReflectionResponse,\n  CravingLogResponse,\n  CravingStatsResponse,\n} from '../types';\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const supportKeys = {\n  all: ['support'] as const,\n  checkIns: () => [...supportKeys.all, 'check-ins'] as const,\n  checkInToday: () => [...supportKeys.checkIns(), 'today'] as const,\n  checkInStreak: () => [...supportKeys.checkIns(), 'streak'] as const,\n  moodLogs: () => [...supportKeys.all, 'mood'] as const,\n  cravings: () => [...supportKeys.all, 'cravings'] as const,\n  cravingStats: (days?: number) => [...supportKeys.cravings(), 'stats', days] as const,\n  wins: () => [...supportKeys.all, 'wins'] as const,\n  winsByCategory: () => [...supportKeys.wins(), 'by-category'] as const,\n  habits: () => [...supportKeys.all, 'habits'] as const,\n  reflections: () => [...supportKeys.all, 'reflections'] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface WinsByCategory {\n  category: string;\n  wins: WinResponse[];\n  count: number;\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get user's daily check-ins\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCheckIns();\n * ```\n */\nexport function useCheckIns(\n  options?: Omit<UseQueryOptions<CheckInResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.checkIns(),\n    queryFn: async (): Promise<CheckInResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/check-ins');\n      // API wraps responses in { data: [...], meta: {...} }\n      return response.data?.data || response.data || [];\n    },\n    ...options,\n  });\n}\n\n/**\n * Get today's check-in\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useTodayCheckIn();\n * ```\n */\nexport function useTodayCheckIn(\n  options?: Omit<UseQueryOptions<CheckInResponse | null>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.checkInToday(),\n    queryFn: async (): Promise<CheckInResponse | null> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/check-ins/today');\n      // API wraps responses in { data: {...}, meta: {...} }\n      return response.data?.data ?? response.data ?? null;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user's check-in streak\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCheckInStreak();\n * ```\n */\nexport function useCheckInStreak(\n  options?: Omit<UseQueryOptions<CheckInStreakResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.checkInStreak(),\n    queryFn: async (): Promise<CheckInStreakResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/check-ins/streak');\n      // API wraps responses in { data: {...}, meta: {...} }\n      return response.data?.data || response.data || { currentStreak: 0, longestStreak: 0, totalCheckIns: 0 };\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user's mood logs\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useMoodLogs();\n * ```\n */\nexport function useMoodLogs(\n  options?: Omit<UseQueryOptions<MoodLogResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.moodLogs(),\n    queryFn: async (): Promise<MoodLogResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/mood');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user's wins\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useWins();\n * ```\n */\nexport function useWins(\n  options?: Omit<UseQueryOptions<WinResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.wins(),\n    queryFn: async (): Promise<WinResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/wins');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user's wins grouped by category\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useWinsByCategory();\n * ```\n */\nexport function useWinsByCategory(\n  options?: Omit<UseQueryOptions<WinsByCategory[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.winsByCategory(),\n    queryFn: async (): Promise<WinsByCategory[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/wins/by-category');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user's habits\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useHabits();\n * ```\n */\nexport function useHabits(\n  options?: Omit<UseQueryOptions<HabitResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.habits(),\n    queryFn: async (): Promise<HabitResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/habits');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user's reflections\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useReflections();\n * ```\n */\nexport function useReflections(\n  options?: Omit<UseQueryOptions<ReflectionResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.reflections(),\n    queryFn: async (): Promise<ReflectionResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/reflections');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get user's craving logs\n *\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCravings();\n * ```\n */\nexport function useCravings(\n  options?: Omit<UseQueryOptions<CravingLogResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.cravings(),\n    queryFn: async (): Promise<CravingLogResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/support/cravings');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get craving statistics for a given period\n *\n * @param days - Number of days to include (default: 30)\n * @param options - TanStack Query options\n *\n * @example\n * ```tsx\n * const { data, isLoading } = useCravingStats(30);\n * ```\n */\nexport function useCravingStats(\n  days: number = 30,\n  options?: Omit<UseQueryOptions<CravingStatsResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.cravingStats(days),\n    queryFn: async (): Promise<CravingStatsResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/support/cravings/stats?days=${days}`);\n      return response.data;\n    },\n    ...options,\n  });\n}\n"]}
|