@growsober/sdk 1.0.0
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/README.md +276 -0
- package/dist/__tests__/e2e.test.d.ts +7 -0
- package/dist/__tests__/e2e.test.js +472 -0
- package/dist/api/client.d.ts +11 -0
- package/dist/api/client.js +61 -0
- package/dist/api/mutations/admin.d.ts +167 -0
- package/dist/api/mutations/admin.js +326 -0
- package/dist/api/mutations/ambassadors.d.ts +52 -0
- package/dist/api/mutations/ambassadors.js +148 -0
- package/dist/api/mutations/auth.d.ts +267 -0
- package/dist/api/mutations/auth.js +332 -0
- package/dist/api/mutations/bookings.d.ts +59 -0
- package/dist/api/mutations/bookings.js +143 -0
- package/dist/api/mutations/event-chat.d.ts +35 -0
- package/dist/api/mutations/event-chat.js +147 -0
- package/dist/api/mutations/events.d.ts +87 -0
- package/dist/api/mutations/events.js +205 -0
- package/dist/api/mutations/grow90.d.ts +36 -0
- package/dist/api/mutations/grow90.js +132 -0
- package/dist/api/mutations/hubs.d.ts +111 -0
- package/dist/api/mutations/hubs.js +240 -0
- package/dist/api/mutations/index.d.ts +22 -0
- package/dist/api/mutations/index.js +39 -0
- package/dist/api/mutations/jack.d.ts +61 -0
- package/dist/api/mutations/jack.js +104 -0
- package/dist/api/mutations/library.d.ts +67 -0
- package/dist/api/mutations/library.js +168 -0
- package/dist/api/mutations/map.d.ts +153 -0
- package/dist/api/mutations/map.js +181 -0
- package/dist/api/mutations/matching.d.ts +130 -0
- package/dist/api/mutations/matching.js +204 -0
- package/dist/api/mutations/notifications.d.ts +63 -0
- package/dist/api/mutations/notifications.js +106 -0
- package/dist/api/mutations/offers.d.ts +26 -0
- package/dist/api/mutations/offers.js +47 -0
- package/dist/api/mutations/subscriptions.d.ts +127 -0
- package/dist/api/mutations/subscriptions.js +140 -0
- package/dist/api/mutations/support.d.ts +165 -0
- package/dist/api/mutations/support.js +307 -0
- package/dist/api/mutations/users.d.ts +211 -0
- package/dist/api/mutations/users.js +261 -0
- package/dist/api/queries/admin.d.ts +257 -0
- package/dist/api/queries/admin.js +320 -0
- package/dist/api/queries/ambassadors.d.ts +53 -0
- package/dist/api/queries/ambassadors.js +98 -0
- package/dist/api/queries/auth.d.ts +16 -0
- package/dist/api/queries/auth.js +25 -0
- package/dist/api/queries/bookings.d.ts +91 -0
- package/dist/api/queries/bookings.js +102 -0
- package/dist/api/queries/businesses.d.ts +212 -0
- package/dist/api/queries/businesses.js +154 -0
- package/dist/api/queries/event-chat.d.ts +19 -0
- package/dist/api/queries/event-chat.js +75 -0
- package/dist/api/queries/events.d.ts +322 -0
- package/dist/api/queries/events.js +221 -0
- package/dist/api/queries/grow90.d.ts +26 -0
- package/dist/api/queries/grow90.js +85 -0
- package/dist/api/queries/hubs.d.ts +165 -0
- package/dist/api/queries/hubs.js +143 -0
- package/dist/api/queries/index.d.ts +23 -0
- package/dist/api/queries/index.js +40 -0
- package/dist/api/queries/jack.d.ts +63 -0
- package/dist/api/queries/jack.js +92 -0
- package/dist/api/queries/library.d.ts +132 -0
- package/dist/api/queries/library.js +120 -0
- package/dist/api/queries/map.d.ts +216 -0
- package/dist/api/queries/map.js +278 -0
- package/dist/api/queries/matching.d.ts +136 -0
- package/dist/api/queries/matching.js +161 -0
- package/dist/api/queries/notifications.d.ts +78 -0
- package/dist/api/queries/notifications.js +88 -0
- package/dist/api/queries/offers.d.ts +91 -0
- package/dist/api/queries/offers.js +103 -0
- package/dist/api/queries/subscriptions.d.ts +56 -0
- package/dist/api/queries/subscriptions.js +73 -0
- package/dist/api/queries/support.d.ts +106 -0
- package/dist/api/queries/support.js +202 -0
- package/dist/api/queries/users.d.ts +293 -0
- package/dist/api/queries/users.js +370 -0
- package/dist/api/types.d.ts +464 -0
- package/dist/api/types.js +9 -0
- package/dist/hooks/useAuth.d.ts +5 -0
- package/dist/hooks/useAuth.js +39 -0
- package/dist/hooks/useUser.d.ts +43 -0
- package/dist/hooks/useUser.js +44 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.js +67 -0
- package/package.json +62 -0
- package/src/__tests__/e2e.test.ts +502 -0
- package/src/api/client.ts +71 -0
- package/src/api/mutations/admin.ts +531 -0
- package/src/api/mutations/ambassadors.ts +185 -0
- package/src/api/mutations/auth.ts +350 -0
- package/src/api/mutations/bookings.ts +190 -0
- package/src/api/mutations/event-chat.ts +177 -0
- package/src/api/mutations/events.ts +273 -0
- package/src/api/mutations/grow90.ts +169 -0
- package/src/api/mutations/hubs.ts +385 -0
- package/src/api/mutations/index.ts +23 -0
- package/src/api/mutations/jack.ts +130 -0
- package/src/api/mutations/library.ts +212 -0
- package/src/api/mutations/map.ts +230 -0
- package/src/api/mutations/matching.ts +271 -0
- package/src/api/mutations/notifications.ts +114 -0
- package/src/api/mutations/offers.ts +73 -0
- package/src/api/mutations/subscriptions.ts +162 -0
- package/src/api/mutations/support.ts +390 -0
- package/src/api/mutations/users.ts +271 -0
- package/src/api/queries/admin.ts +480 -0
- package/src/api/queries/ambassadors.ts +139 -0
- package/src/api/queries/auth.ts +24 -0
- package/src/api/queries/bookings.ts +135 -0
- package/src/api/queries/businesses.ts +203 -0
- package/src/api/queries/event-chat.ts +78 -0
- package/src/api/queries/events.ts +272 -0
- package/src/api/queries/grow90.ts +98 -0
- package/src/api/queries/hubs.ts +211 -0
- package/src/api/queries/index.ts +24 -0
- package/src/api/queries/jack.ts +127 -0
- package/src/api/queries/library.ts +166 -0
- package/src/api/queries/map.ts +331 -0
- package/src/api/queries/matching.ts +238 -0
- package/src/api/queries/notifications.ts +103 -0
- package/src/api/queries/offers.ts +136 -0
- package/src/api/queries/subscriptions.ts +91 -0
- package/src/api/queries/support.ts +235 -0
- package/src/api/queries/users.ts +393 -0
- package/src/api/types.ts +596 -0
- package/src/index.ts +57 -0
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.supportKeys = void 0;
|
|
4
|
+
exports.useCheckIns = useCheckIns;
|
|
5
|
+
exports.useTodayCheckIn = useTodayCheckIn;
|
|
6
|
+
exports.useCheckInStreak = useCheckInStreak;
|
|
7
|
+
exports.useMoodLogs = useMoodLogs;
|
|
8
|
+
exports.useWins = useWins;
|
|
9
|
+
exports.useWinsByCategory = useWinsByCategory;
|
|
10
|
+
exports.useHabits = useHabits;
|
|
11
|
+
exports.useReflections = useReflections;
|
|
12
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
13
|
+
const client_1 = require("../client");
|
|
14
|
+
// ============================================================================
|
|
15
|
+
// QUERY KEY FACTORY
|
|
16
|
+
// ============================================================================
|
|
17
|
+
exports.supportKeys = {
|
|
18
|
+
all: ['support'],
|
|
19
|
+
checkIns: () => [...exports.supportKeys.all, 'check-ins'],
|
|
20
|
+
checkInToday: () => [...exports.supportKeys.checkIns(), 'today'],
|
|
21
|
+
checkInStreak: () => [...exports.supportKeys.checkIns(), 'streak'],
|
|
22
|
+
moodLogs: () => [...exports.supportKeys.all, 'mood'],
|
|
23
|
+
wins: () => [...exports.supportKeys.all, 'wins'],
|
|
24
|
+
winsByCategory: () => [...exports.supportKeys.wins(), 'by-category'],
|
|
25
|
+
habits: () => [...exports.supportKeys.all, 'habits'],
|
|
26
|
+
reflections: () => [...exports.supportKeys.all, 'reflections'],
|
|
27
|
+
};
|
|
28
|
+
// ============================================================================
|
|
29
|
+
// QUERY HOOKS
|
|
30
|
+
// ============================================================================
|
|
31
|
+
/**
|
|
32
|
+
* Get user's daily check-ins
|
|
33
|
+
*
|
|
34
|
+
* @param options - TanStack Query options
|
|
35
|
+
*
|
|
36
|
+
* @example
|
|
37
|
+
* ```tsx
|
|
38
|
+
* const { data, isLoading } = useCheckIns();
|
|
39
|
+
* ```
|
|
40
|
+
*/
|
|
41
|
+
function useCheckIns(options) {
|
|
42
|
+
return (0, react_query_1.useQuery)({
|
|
43
|
+
queryKey: exports.supportKeys.checkIns(),
|
|
44
|
+
queryFn: async () => {
|
|
45
|
+
const client = (0, client_1.getApiClient)();
|
|
46
|
+
const response = await client.get('/api/v1/support/check-ins');
|
|
47
|
+
// API wraps responses in { data: [...], meta: {...} }
|
|
48
|
+
return response.data?.data || response.data || [];
|
|
49
|
+
},
|
|
50
|
+
...options,
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Get today's check-in
|
|
55
|
+
*
|
|
56
|
+
* @param options - TanStack Query options
|
|
57
|
+
*
|
|
58
|
+
* @example
|
|
59
|
+
* ```tsx
|
|
60
|
+
* const { data, isLoading } = useTodayCheckIn();
|
|
61
|
+
* ```
|
|
62
|
+
*/
|
|
63
|
+
function useTodayCheckIn(options) {
|
|
64
|
+
return (0, react_query_1.useQuery)({
|
|
65
|
+
queryKey: exports.supportKeys.checkInToday(),
|
|
66
|
+
queryFn: async () => {
|
|
67
|
+
const client = (0, client_1.getApiClient)();
|
|
68
|
+
const response = await client.get('/api/v1/support/check-ins/today');
|
|
69
|
+
// API wraps responses in { data: {...}, meta: {...} }
|
|
70
|
+
return response.data?.data ?? response.data ?? null;
|
|
71
|
+
},
|
|
72
|
+
...options,
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Get user's check-in streak
|
|
77
|
+
*
|
|
78
|
+
* @param options - TanStack Query options
|
|
79
|
+
*
|
|
80
|
+
* @example
|
|
81
|
+
* ```tsx
|
|
82
|
+
* const { data, isLoading } = useCheckInStreak();
|
|
83
|
+
* ```
|
|
84
|
+
*/
|
|
85
|
+
function useCheckInStreak(options) {
|
|
86
|
+
return (0, react_query_1.useQuery)({
|
|
87
|
+
queryKey: exports.supportKeys.checkInStreak(),
|
|
88
|
+
queryFn: async () => {
|
|
89
|
+
const client = (0, client_1.getApiClient)();
|
|
90
|
+
const response = await client.get('/api/v1/support/check-ins/streak');
|
|
91
|
+
// API wraps responses in { data: {...}, meta: {...} }
|
|
92
|
+
return response.data?.data || response.data || { currentStreak: 0, longestStreak: 0, totalCheckIns: 0 };
|
|
93
|
+
},
|
|
94
|
+
...options,
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Get user's mood logs
|
|
99
|
+
*
|
|
100
|
+
* @param options - TanStack Query options
|
|
101
|
+
*
|
|
102
|
+
* @example
|
|
103
|
+
* ```tsx
|
|
104
|
+
* const { data, isLoading } = useMoodLogs();
|
|
105
|
+
* ```
|
|
106
|
+
*/
|
|
107
|
+
function useMoodLogs(options) {
|
|
108
|
+
return (0, react_query_1.useQuery)({
|
|
109
|
+
queryKey: exports.supportKeys.moodLogs(),
|
|
110
|
+
queryFn: async () => {
|
|
111
|
+
const client = (0, client_1.getApiClient)();
|
|
112
|
+
const response = await client.get('/api/v1/support/mood');
|
|
113
|
+
return response.data;
|
|
114
|
+
},
|
|
115
|
+
...options,
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* Get user's wins
|
|
120
|
+
*
|
|
121
|
+
* @param options - TanStack Query options
|
|
122
|
+
*
|
|
123
|
+
* @example
|
|
124
|
+
* ```tsx
|
|
125
|
+
* const { data, isLoading } = useWins();
|
|
126
|
+
* ```
|
|
127
|
+
*/
|
|
128
|
+
function useWins(options) {
|
|
129
|
+
return (0, react_query_1.useQuery)({
|
|
130
|
+
queryKey: exports.supportKeys.wins(),
|
|
131
|
+
queryFn: async () => {
|
|
132
|
+
const client = (0, client_1.getApiClient)();
|
|
133
|
+
const response = await client.get('/api/v1/support/wins');
|
|
134
|
+
return response.data;
|
|
135
|
+
},
|
|
136
|
+
...options,
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Get user's wins grouped by category
|
|
141
|
+
*
|
|
142
|
+
* @param options - TanStack Query options
|
|
143
|
+
*
|
|
144
|
+
* @example
|
|
145
|
+
* ```tsx
|
|
146
|
+
* const { data, isLoading } = useWinsByCategory();
|
|
147
|
+
* ```
|
|
148
|
+
*/
|
|
149
|
+
function useWinsByCategory(options) {
|
|
150
|
+
return (0, react_query_1.useQuery)({
|
|
151
|
+
queryKey: exports.supportKeys.winsByCategory(),
|
|
152
|
+
queryFn: async () => {
|
|
153
|
+
const client = (0, client_1.getApiClient)();
|
|
154
|
+
const response = await client.get('/api/v1/support/wins/by-category');
|
|
155
|
+
return response.data;
|
|
156
|
+
},
|
|
157
|
+
...options,
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Get user's habits
|
|
162
|
+
*
|
|
163
|
+
* @param options - TanStack Query options
|
|
164
|
+
*
|
|
165
|
+
* @example
|
|
166
|
+
* ```tsx
|
|
167
|
+
* const { data, isLoading } = useHabits();
|
|
168
|
+
* ```
|
|
169
|
+
*/
|
|
170
|
+
function useHabits(options) {
|
|
171
|
+
return (0, react_query_1.useQuery)({
|
|
172
|
+
queryKey: exports.supportKeys.habits(),
|
|
173
|
+
queryFn: async () => {
|
|
174
|
+
const client = (0, client_1.getApiClient)();
|
|
175
|
+
const response = await client.get('/api/v1/support/habits');
|
|
176
|
+
return response.data;
|
|
177
|
+
},
|
|
178
|
+
...options,
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
/**
|
|
182
|
+
* Get user's reflections
|
|
183
|
+
*
|
|
184
|
+
* @param options - TanStack Query options
|
|
185
|
+
*
|
|
186
|
+
* @example
|
|
187
|
+
* ```tsx
|
|
188
|
+
* const { data, isLoading } = useReflections();
|
|
189
|
+
* ```
|
|
190
|
+
*/
|
|
191
|
+
function useReflections(options) {
|
|
192
|
+
return (0, react_query_1.useQuery)({
|
|
193
|
+
queryKey: exports.supportKeys.reflections(),
|
|
194
|
+
queryFn: async () => {
|
|
195
|
+
const client = (0, client_1.getApiClient)();
|
|
196
|
+
const response = await client.get('/api/v1/support/reflections');
|
|
197
|
+
return response.data;
|
|
198
|
+
},
|
|
199
|
+
...options,
|
|
200
|
+
});
|
|
201
|
+
}
|
|
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  DailyCheckInResponse,\n  MoodLogResponse,\n  WinResponse,\n  HabitResponse,\n  ReflectionResponse,\n  UserStreakResponse,\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<DailyCheckInResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.checkIns(),\n    queryFn: async (): Promise<DailyCheckInResponse[]> => {\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<DailyCheckInResponse | null>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.checkInToday(),\n    queryFn: async (): Promise<DailyCheckInResponse | 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<UserStreakResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: supportKeys.checkInStreak(),\n    queryFn: async (): Promise<UserStreakResponse> => {\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"]}
|
|
@@ -0,0 +1,293 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Users Query Hooks
|
|
3
|
+
*
|
|
4
|
+
* TanStack Query hooks for user-related read operations.
|
|
5
|
+
* These hooks handle fetching user data, profiles, library items, and subscriptions.
|
|
6
|
+
*
|
|
7
|
+
* @module api/queries/users
|
|
8
|
+
*/
|
|
9
|
+
import { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
|
|
10
|
+
import type { UserResponse, UserPublicResponse, LibraryContentResponse, LibraryProgressResponse, OfferResponse } from '../types';
|
|
11
|
+
/**
|
|
12
|
+
* Query key factory for user-related queries
|
|
13
|
+
* @see https://tkdodo.eu/blog/effective-react-query-keys
|
|
14
|
+
*/
|
|
15
|
+
export declare const userKeys: {
|
|
16
|
+
all: readonly ["users"];
|
|
17
|
+
me: () => readonly ["users", "me"];
|
|
18
|
+
detail: (id: string) => readonly ["users", "detail", string];
|
|
19
|
+
public: (id: string) => readonly ["users", "public", string];
|
|
20
|
+
library: {
|
|
21
|
+
all: () => readonly ["users", "me", "library"];
|
|
22
|
+
bookmarks: () => readonly ["users", "me", "library", "bookmarks"];
|
|
23
|
+
progress: () => readonly ["users", "me", "library", "progress"];
|
|
24
|
+
};
|
|
25
|
+
offers: {
|
|
26
|
+
all: () => readonly ["users", "me", "offers"];
|
|
27
|
+
redeemed: () => readonly ["users", "me", "offers", "redeemed"];
|
|
28
|
+
};
|
|
29
|
+
subscription: () => readonly ["users", "me", "subscription"];
|
|
30
|
+
};
|
|
31
|
+
/**
|
|
32
|
+
* Get current user's profile
|
|
33
|
+
*
|
|
34
|
+
* @description
|
|
35
|
+
* Retrieves the currently authenticated user's complete profile information.
|
|
36
|
+
* Requires a valid access token to be set via the SDK configuration.
|
|
37
|
+
*
|
|
38
|
+
* @endpoint GET /api/v1/users/me
|
|
39
|
+
*
|
|
40
|
+
* @example
|
|
41
|
+
* ```tsx
|
|
42
|
+
* import { useCurrentUser } from '@growsober/sdk';
|
|
43
|
+
*
|
|
44
|
+
* function ProfileScreen() {
|
|
45
|
+
* const { data: user, isLoading, error } = useCurrentUser();
|
|
46
|
+
*
|
|
47
|
+
* if (isLoading) return <Spinner />;
|
|
48
|
+
* if (error) return <Error message={error.message} />;
|
|
49
|
+
* if (!user) return <NotFound />;
|
|
50
|
+
*
|
|
51
|
+
* return (
|
|
52
|
+
* <div>
|
|
53
|
+
* <h1>{user.name}</h1>
|
|
54
|
+
* <p>{user.email}</p>
|
|
55
|
+
* <p>Sober Since: {user.soberDate}</p>
|
|
56
|
+
* </div>
|
|
57
|
+
* );
|
|
58
|
+
* }
|
|
59
|
+
* ```
|
|
60
|
+
*
|
|
61
|
+
* @example
|
|
62
|
+
* With custom options:
|
|
63
|
+
* ```tsx
|
|
64
|
+
* const { data: user } = useCurrentUser({
|
|
65
|
+
* refetchOnMount: false,
|
|
66
|
+
* staleTime: 5 * 60 * 1000, // 5 minutes
|
|
67
|
+
* });
|
|
68
|
+
* ```
|
|
69
|
+
*
|
|
70
|
+
* @param options - TanStack Query options for customizing the query behavior
|
|
71
|
+
* @returns TanStack Query result with user data
|
|
72
|
+
*/
|
|
73
|
+
export declare function useCurrentUser(options?: Omit<UseQueryOptions<UserResponse>, 'queryKey' | 'queryFn'>): UseQueryResult<UserResponse>;
|
|
74
|
+
/**
|
|
75
|
+
* Get a specific user's full profile by ID
|
|
76
|
+
*
|
|
77
|
+
* @description
|
|
78
|
+
* Retrieves a user's complete profile information by their ID.
|
|
79
|
+
* This may include private information depending on the requesting user's permissions.
|
|
80
|
+
*
|
|
81
|
+
* @endpoint GET /api/v1/users/{id}
|
|
82
|
+
*
|
|
83
|
+
* @example
|
|
84
|
+
* ```tsx
|
|
85
|
+
* import { useUser } from '@growsober/sdk';
|
|
86
|
+
*
|
|
87
|
+
* function UserProfileScreen({ userId }: { userId: string }) {
|
|
88
|
+
* const { data: user, isLoading } = useUser(userId);
|
|
89
|
+
*
|
|
90
|
+
* if (isLoading) return <Spinner />;
|
|
91
|
+
*
|
|
92
|
+
* return (
|
|
93
|
+
* <div>
|
|
94
|
+
* <Avatar src={user.avatar} />
|
|
95
|
+
* <h1>{user.name}</h1>
|
|
96
|
+
* <p>{user.bio}</p>
|
|
97
|
+
* </div>
|
|
98
|
+
* );
|
|
99
|
+
* }
|
|
100
|
+
* ```
|
|
101
|
+
*
|
|
102
|
+
* @example
|
|
103
|
+
* With conditional fetching:
|
|
104
|
+
* ```tsx
|
|
105
|
+
* const { data: user } = useUser(userId, {
|
|
106
|
+
* enabled: !!userId, // Only fetch when userId is defined
|
|
107
|
+
* });
|
|
108
|
+
* ```
|
|
109
|
+
*
|
|
110
|
+
* @param id - The user ID to fetch
|
|
111
|
+
* @param options - TanStack Query options for customizing the query behavior
|
|
112
|
+
* @returns TanStack Query result with user data
|
|
113
|
+
*/
|
|
114
|
+
export declare function useUser(id: string, options?: Omit<UseQueryOptions<UserResponse>, 'queryKey' | 'queryFn'>): UseQueryResult<UserResponse>;
|
|
115
|
+
/**
|
|
116
|
+
* Get a user's public profile by ID
|
|
117
|
+
*
|
|
118
|
+
* @description
|
|
119
|
+
* Retrieves a user's public profile information.
|
|
120
|
+
* This endpoint returns only publicly visible information and doesn't require authentication.
|
|
121
|
+
*
|
|
122
|
+
* @endpoint GET /api/v1/users/{id}/public
|
|
123
|
+
*
|
|
124
|
+
* @example
|
|
125
|
+
* ```tsx
|
|
126
|
+
* import { usePublicProfile } from '@growsober/sdk';
|
|
127
|
+
*
|
|
128
|
+
* function PublicProfileCard({ userId }: { userId: string }) {
|
|
129
|
+
* const { data: profile, isLoading } = usePublicProfile(userId);
|
|
130
|
+
*
|
|
131
|
+
* if (isLoading) return <Skeleton />;
|
|
132
|
+
*
|
|
133
|
+
* return (
|
|
134
|
+
* <div>
|
|
135
|
+
* <Avatar src={profile.avatar} />
|
|
136
|
+
* <h2>{profile.displayName}</h2>
|
|
137
|
+
* <p>{profile.city}</p>
|
|
138
|
+
* {profile.soberSince && (
|
|
139
|
+
* <p>Sober since: {new Date(profile.soberSince).toLocaleDateString()}</p>
|
|
140
|
+
* )}
|
|
141
|
+
* </div>
|
|
142
|
+
* );
|
|
143
|
+
* }
|
|
144
|
+
* ```
|
|
145
|
+
*
|
|
146
|
+
* @param id - The user ID to fetch
|
|
147
|
+
* @param options - TanStack Query options for customizing the query behavior
|
|
148
|
+
* @returns TanStack Query result with public profile data
|
|
149
|
+
*/
|
|
150
|
+
export declare function usePublicProfile(id: string, options?: Omit<UseQueryOptions<UserPublicResponse>, 'queryKey' | 'queryFn'>): UseQueryResult<UserPublicResponse>;
|
|
151
|
+
/**
|
|
152
|
+
* Get current user's bookmarked library content
|
|
153
|
+
*
|
|
154
|
+
* @description
|
|
155
|
+
* Retrieves all library content (articles, videos, podcasts, etc.) that the user has bookmarked.
|
|
156
|
+
* This allows users to save content for later reading/viewing.
|
|
157
|
+
*
|
|
158
|
+
* @endpoint GET /api/v1/users/me/library/bookmarks
|
|
159
|
+
*
|
|
160
|
+
* @example
|
|
161
|
+
* ```tsx
|
|
162
|
+
* import { useMyBookmarks } from '@growsober/sdk';
|
|
163
|
+
*
|
|
164
|
+
* function BookmarksScreen() {
|
|
165
|
+
* const { data: bookmarks, isLoading } = useMyBookmarks();
|
|
166
|
+
*
|
|
167
|
+
* if (isLoading) return <Loading />;
|
|
168
|
+
*
|
|
169
|
+
* return (
|
|
170
|
+
* <div>
|
|
171
|
+
* <h1>My Saved Content</h1>
|
|
172
|
+
* {bookmarks?.map(content => (
|
|
173
|
+
* <ContentCard key={content.id} content={content} />
|
|
174
|
+
* ))}
|
|
175
|
+
* </div>
|
|
176
|
+
* );
|
|
177
|
+
* }
|
|
178
|
+
* ```
|
|
179
|
+
*
|
|
180
|
+
* @example
|
|
181
|
+
* With auto-refresh:
|
|
182
|
+
* ```tsx
|
|
183
|
+
* const { data: bookmarks } = useMyBookmarks({
|
|
184
|
+
* refetchInterval: 60000, // Refresh every minute
|
|
185
|
+
* });
|
|
186
|
+
* ```
|
|
187
|
+
*
|
|
188
|
+
* @param options - TanStack Query options for customizing the query behavior
|
|
189
|
+
* @returns TanStack Query result with array of bookmarked content
|
|
190
|
+
*/
|
|
191
|
+
export declare function useMyBookmarks(options?: Omit<UseQueryOptions<LibraryContentResponse[]>, 'queryKey' | 'queryFn'>): UseQueryResult<LibraryContentResponse[]>;
|
|
192
|
+
/**
|
|
193
|
+
* Get current user's library content progress
|
|
194
|
+
*
|
|
195
|
+
* @description
|
|
196
|
+
* Retrieves the user's progress on library content items.
|
|
197
|
+
* Tracks which content has been started, completed, or partially viewed/read.
|
|
198
|
+
*
|
|
199
|
+
* @endpoint GET /api/v1/users/me/library/progress
|
|
200
|
+
*
|
|
201
|
+
* @example
|
|
202
|
+
* ```tsx
|
|
203
|
+
* import { useMyProgress } from '@growsober/sdk';
|
|
204
|
+
*
|
|
205
|
+
* function LibraryProgressScreen() {
|
|
206
|
+
* const { data: progress, isLoading } = useMyProgress();
|
|
207
|
+
*
|
|
208
|
+
* if (isLoading) return <Loading />;
|
|
209
|
+
*
|
|
210
|
+
* const completed = progress?.filter(p => p.completed) || [];
|
|
211
|
+
* const inProgress = progress?.filter(p => !p.completed && p.progress > 0) || [];
|
|
212
|
+
*
|
|
213
|
+
* return (
|
|
214
|
+
* <div>
|
|
215
|
+
* <h2>Completed: {completed.length}</h2>
|
|
216
|
+
* <h2>In Progress: {inProgress.length}</h2>
|
|
217
|
+
* </div>
|
|
218
|
+
* );
|
|
219
|
+
* }
|
|
220
|
+
* ```
|
|
221
|
+
*
|
|
222
|
+
* @example
|
|
223
|
+
* Check progress for specific content:
|
|
224
|
+
* ```tsx
|
|
225
|
+
* function ContentProgress({ contentId }: { contentId: string }) {
|
|
226
|
+
* const { data: progress } = useMyProgress();
|
|
227
|
+
* const contentProgress = progress?.find(p => p.contentId === contentId);
|
|
228
|
+
*
|
|
229
|
+
* return (
|
|
230
|
+
* <ProgressBar
|
|
231
|
+
* value={contentProgress?.progress || 0}
|
|
232
|
+
* max={100}
|
|
233
|
+
* />
|
|
234
|
+
* );
|
|
235
|
+
* }
|
|
236
|
+
* ```
|
|
237
|
+
*
|
|
238
|
+
* @param options - TanStack Query options for customizing the query behavior
|
|
239
|
+
* @returns TanStack Query result with array of progress records
|
|
240
|
+
*/
|
|
241
|
+
export declare function useMyProgress(options?: Omit<UseQueryOptions<LibraryProgressResponse[]>, 'queryKey' | 'queryFn'>): UseQueryResult<LibraryProgressResponse[]>;
|
|
242
|
+
/**
|
|
243
|
+
* Get current user's redeemed offers
|
|
244
|
+
*
|
|
245
|
+
* @description
|
|
246
|
+
* Retrieves all offers/deals that the user has redeemed.
|
|
247
|
+
* Shows history of partner offers used by the user.
|
|
248
|
+
*
|
|
249
|
+
* @endpoint GET /api/v1/users/me/offers/redeemed
|
|
250
|
+
*
|
|
251
|
+
* @example
|
|
252
|
+
* ```tsx
|
|
253
|
+
* import { useMyRedeemedOffers } from '@growsober/sdk';
|
|
254
|
+
*
|
|
255
|
+
* function RedeemedOffersScreen() {
|
|
256
|
+
* const { data: offers, isLoading } = useMyRedeemedOffers();
|
|
257
|
+
*
|
|
258
|
+
* if (isLoading) return <Loading />;
|
|
259
|
+
*
|
|
260
|
+
* return (
|
|
261
|
+
* <div>
|
|
262
|
+
* <h1>My Redeemed Offers</h1>
|
|
263
|
+
* {offers?.map(offer => (
|
|
264
|
+
* <div key={offer.id}>
|
|
265
|
+
* <h3>{offer.title}</h3>
|
|
266
|
+
* <p>Redeemed: {new Date(offer.redeemedAt).toLocaleDateString()}</p>
|
|
267
|
+
* <p>Code: {offer.code}</p>
|
|
268
|
+
* </div>
|
|
269
|
+
* ))}
|
|
270
|
+
* </div>
|
|
271
|
+
* );
|
|
272
|
+
* }
|
|
273
|
+
* ```
|
|
274
|
+
*
|
|
275
|
+
* @example
|
|
276
|
+
* Check if specific offer was redeemed:
|
|
277
|
+
* ```tsx
|
|
278
|
+
* function OfferCard({ offerId }: { offerId: string }) {
|
|
279
|
+
* const { data: redeemedOffers } = useMyRedeemedOffers();
|
|
280
|
+
* const isRedeemed = redeemedOffers?.some(o => o.id === offerId);
|
|
281
|
+
*
|
|
282
|
+
* return (
|
|
283
|
+
* <button disabled={isRedeemed}>
|
|
284
|
+
* {isRedeemed ? 'Already Redeemed' : 'Redeem Offer'}
|
|
285
|
+
* </button>
|
|
286
|
+
* );
|
|
287
|
+
* }
|
|
288
|
+
* ```
|
|
289
|
+
*
|
|
290
|
+
* @param options - TanStack Query options for customizing the query behavior
|
|
291
|
+
* @returns TanStack Query result with array of redeemed offers
|
|
292
|
+
*/
|
|
293
|
+
export declare function useMyRedeemedOffers(options?: Omit<UseQueryOptions<OfferResponse[]>, 'queryKey' | 'queryFn'>): UseQueryResult<OfferResponse[]>;
|