@growsober/sdk 1.0.0 → 1.0.2
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/api/mutations/admin.d.ts +1 -20
- package/dist/api/mutations/admin.js +1 -1
- package/dist/api/mutations/auth.d.ts +83 -1
- package/dist/api/mutations/auth.js +102 -1
- package/dist/api/mutations/event-chat.d.ts +84 -7
- package/dist/api/mutations/event-chat.js +1 -1
- package/dist/api/mutations/matching.d.ts +2 -19
- package/dist/api/mutations/matching.js +6 -6
- package/dist/api/mutations/support.d.ts +5 -5
- package/dist/api/mutations/support.js +1 -1
- package/dist/api/queries/ambassadors.d.ts +71 -5
- package/dist/api/queries/ambassadors.js +1 -1
- package/dist/api/queries/cities.d.ts +52 -0
- package/dist/api/queries/cities.js +82 -0
- package/dist/api/queries/event-chat.d.ts +30 -4
- package/dist/api/queries/grow90.d.ts +46 -4
- package/dist/api/queries/hubs.d.ts +2 -2
- package/dist/api/queries/hubs.js +1 -1
- package/dist/api/queries/index.d.ts +1 -0
- package/dist/api/queries/index.js +2 -1
- package/dist/api/queries/map.d.ts +3 -3
- package/dist/api/queries/map.js +1 -1
- package/dist/api/queries/support.d.ts +88 -8
- package/dist/api/queries/support.js +1 -1
- package/dist/api/types.d.ts +63 -393
- package/dist/api/types.js +4 -4
- package/package.json +1 -1
- package/src/api/mutations/admin.ts +1 -20
- package/src/api/mutations/auth.ts +114 -0
- package/src/api/mutations/event-chat.ts +7 -7
- package/src/api/mutations/matching.ts +12 -32
- package/src/api/mutations/support.ts +11 -11
- package/src/api/queries/ambassadors.ts +6 -3
- package/src/api/queries/cities.ts +194 -0
- package/src/api/queries/hubs.ts +3 -3
- package/src/api/queries/index.ts +1 -0
- package/src/api/queries/map.ts +10 -10
- package/src/api/queries/support.ts +8 -8
- package/src/api/types.ts +96 -448
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Cities Query Hooks
|
|
4
|
+
*
|
|
5
|
+
* TanStack Query hooks for fetching city data.
|
|
6
|
+
* Cities are used for location-based features and user onboarding.
|
|
7
|
+
*
|
|
8
|
+
* @module api/queries/cities
|
|
9
|
+
*/
|
|
10
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
11
|
+
exports.cityKeys = void 0;
|
|
12
|
+
exports.useCities = useCities;
|
|
13
|
+
exports.useFeaturedCities = useFeaturedCities;
|
|
14
|
+
exports.useCity = useCity;
|
|
15
|
+
const react_query_1 = require("@tanstack/react-query");
|
|
16
|
+
const client_1 = require("../client");
|
|
17
|
+
// ============================================================================
|
|
18
|
+
// QUERY KEY FACTORY
|
|
19
|
+
// ============================================================================
|
|
20
|
+
exports.cityKeys = {
|
|
21
|
+
all: ['cities'],
|
|
22
|
+
lists: () => [...exports.cityKeys.all, 'list'],
|
|
23
|
+
list: (filters) => [...exports.cityKeys.lists(), filters],
|
|
24
|
+
details: () => [...exports.cityKeys.all, 'detail'],
|
|
25
|
+
detail: (id) => [...exports.cityKeys.details(), id],
|
|
26
|
+
featured: () => [...exports.cityKeys.all, 'featured'],
|
|
27
|
+
};
|
|
28
|
+
function useCities(filters, options) {
|
|
29
|
+
return (0, react_query_1.useQuery)({
|
|
30
|
+
queryKey: exports.cityKeys.list(filters),
|
|
31
|
+
queryFn: async () => {
|
|
32
|
+
const client = (0, client_1.getApiClient)();
|
|
33
|
+
const params = new URLSearchParams();
|
|
34
|
+
if (filters?.search)
|
|
35
|
+
params.append('search', filters.search);
|
|
36
|
+
if (filters?.countryCode)
|
|
37
|
+
params.append('countryCode', filters.countryCode);
|
|
38
|
+
if (filters?.isFeatured !== undefined)
|
|
39
|
+
params.append('isFeatured', String(filters.isFeatured));
|
|
40
|
+
const queryString = params.toString();
|
|
41
|
+
const url = `/api/v1/cities${queryString ? `?${queryString}` : ''}`;
|
|
42
|
+
const response = await client.get(url);
|
|
43
|
+
// Handle both wrapped and unwrapped response formats
|
|
44
|
+
return Array.isArray(response.data) ? response.data : response.data.data;
|
|
45
|
+
},
|
|
46
|
+
staleTime: 5 * 60 * 1000, // Cities don't change often, cache for 5 minutes
|
|
47
|
+
...options,
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Get featured cities
|
|
52
|
+
*
|
|
53
|
+
* @description
|
|
54
|
+
* Fetches only cities marked as featured.
|
|
55
|
+
* Useful for showing popular/recommended cities.
|
|
56
|
+
*
|
|
57
|
+
* @example
|
|
58
|
+
* ```tsx
|
|
59
|
+
* const { data: featuredCities } = useFeaturedCities();
|
|
60
|
+
* ```
|
|
61
|
+
*
|
|
62
|
+
* @param options - TanStack Query options
|
|
63
|
+
* @returns TanStack Query result with array of featured cities
|
|
64
|
+
*/
|
|
65
|
+
function useFeaturedCities(options) {
|
|
66
|
+
return useCities({ isFeatured: true }, options);
|
|
67
|
+
}
|
|
68
|
+
function useCity(id, options) {
|
|
69
|
+
return (0, react_query_1.useQuery)({
|
|
70
|
+
queryKey: exports.cityKeys.detail(id),
|
|
71
|
+
queryFn: async () => {
|
|
72
|
+
const client = (0, client_1.getApiClient)();
|
|
73
|
+
const response = await client.get(`/api/v1/cities/${id}`);
|
|
74
|
+
// Handle both wrapped and unwrapped response formats
|
|
75
|
+
return response.data.data || response.data;
|
|
76
|
+
},
|
|
77
|
+
enabled: !!id,
|
|
78
|
+
staleTime: 5 * 60 * 1000,
|
|
79
|
+
...options,
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cities.js","sourceRoot":"","sources":["../../../src/api/queries/cities.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Cities Query Hooks\n *\n * TanStack Query hooks for fetching city data.\n * Cities are used for location-based features and user onboarding.\n *\n * @module api/queries/cities\n */\n\nimport { useQuery, UseQueryOptions, UseQueryResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\n\n// ============================================================================\n// QUERY KEY FACTORY\n// ============================================================================\n\nexport const cityKeys = {\n  all: ['cities'] as const,\n  lists: () => [...cityKeys.all, 'list'] as const,\n  list: (filters?: CityFilters) => [...cityKeys.lists(), filters] as const,\n  details: () => [...cityKeys.all, 'detail'] as const,\n  detail: (id: string) => [...cityKeys.details(), id] as const,\n  featured: () => [...cityKeys.all, 'featured'] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface CityResponse {\n  id: string;\n  name: string;\n  country: string;\n  countryCode: string | null;\n  timezone: string | null;\n  latitude: number | null;\n  longitude: number | null;\n  memberCount: number;\n  isFeatured: boolean;\n  region: string | null;\n}\n\nexport interface CityFilters {\n  search?: string;\n  countryCode?: string;\n  isFeatured?: boolean;\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get list of cities with optional filters\n *\n * @description\n * Fetches available cities for location selection.\n * Can be filtered by name search, country code, or featured status.\n * Results are ordered by featured status, member count, and name.\n *\n * @endpoint GET /api/v1/cities\n *\n * @example\n * ```tsx\n * import { useCities } from '@growsober/sdk';\n *\n * function CityPicker() {\n *   const { data: cities, isLoading } = useCities();\n *\n *   if (isLoading) return <Spinner />;\n *\n *   return (\n *     <select>\n *       {cities?.map(city => (\n *         <option key={city.id} value={city.id}>\n *           {city.name}, {city.country}\n *         </option>\n *       ))}\n *     </select>\n *   );\n * }\n * ```\n *\n * @example\n * With search filter:\n * ```tsx\n * const { data: cities } = useCities({ search: 'London' });\n * ```\n *\n * @example\n * Filter by country:\n * ```tsx\n * const { data: ukCities } = useCities({ countryCode: 'GB' });\n * ```\n *\n * @param filters - Optional filters for city search\n * @param options - TanStack Query options\n * @returns TanStack Query result with array of cities\n */\ninterface CitiesApiResponse {\n  data: CityResponse[];\n  meta: {\n    timestamp: string;\n  };\n}\n\nexport function useCities(\n  filters?: CityFilters,\n  options?: Omit<UseQueryOptions<CityResponse[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<CityResponse[]> {\n  return useQuery({\n    queryKey: cityKeys.list(filters),\n    queryFn: async (): Promise<CityResponse[]> => {\n      const client = getApiClient();\n      const params = new URLSearchParams();\n\n      if (filters?.search) params.append('search', filters.search);\n      if (filters?.countryCode) params.append('countryCode', filters.countryCode);\n      if (filters?.isFeatured !== undefined) params.append('isFeatured', String(filters.isFeatured));\n\n      const queryString = params.toString();\n      const url = `/api/v1/cities${queryString ? `?${queryString}` : ''}`;\n\n      const response = await client.get<CitiesApiResponse>(url);\n      // Handle both wrapped and unwrapped response formats\n      return Array.isArray(response.data) ? response.data : response.data.data;\n    },\n    staleTime: 5 * 60 * 1000, // Cities don't change often, cache for 5 minutes\n    ...options,\n  });\n}\n\n/**\n * Get featured cities\n *\n * @description\n * Fetches only cities marked as featured.\n * Useful for showing popular/recommended cities.\n *\n * @example\n * ```tsx\n * const { data: featuredCities } = useFeaturedCities();\n * ```\n *\n * @param options - TanStack Query options\n * @returns TanStack Query result with array of featured cities\n */\nexport function useFeaturedCities(\n  options?: Omit<UseQueryOptions<CityResponse[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<CityResponse[]> {\n  return useCities({ isFeatured: true }, options);\n}\n\n/**\n * Get a single city by ID\n *\n * @description\n * Fetches details for a specific city.\n *\n * @endpoint GET /api/v1/cities/{id}\n *\n * @example\n * ```tsx\n * const { data: city } = useCity('city-uuid');\n * ```\n *\n * @param id - City ID\n * @param options - TanStack Query options\n * @returns TanStack Query result with city data\n */\ninterface CityApiResponse {\n  data: CityResponse;\n  meta: {\n    timestamp: string;\n  };\n}\n\nexport function useCity(\n  id: string,\n  options?: Omit<UseQueryOptions<CityResponse>, 'queryKey' | 'queryFn'>\n): UseQueryResult<CityResponse> {\n  return useQuery({\n    queryKey: cityKeys.detail(id),\n    queryFn: async (): Promise<CityResponse> => {\n      const client = getApiClient();\n      const response = await client.get<CityApiResponse>(`/api/v1/cities/${id}`);\n      // Handle both wrapped and unwrapped response formats\n      return (response.data as any).data || response.data;\n    },\n    enabled: !!id,\n    staleTime: 5 * 60 * 1000,\n    ...options,\n  });\n}\n"]}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import type { EventChatResponse, ChatMemberResponse, PaginatedMessagesResponse } from '../types';
|
|
2
1
|
export declare const eventChatKeys: {
|
|
3
2
|
all: readonly ["event-chat"];
|
|
4
3
|
chat: (eventId: string) => readonly ["event-chat", "chat", string];
|
|
@@ -8,12 +7,39 @@ export declare const eventChatKeys: {
|
|
|
8
7
|
/**
|
|
9
8
|
* Get or create chat for an event
|
|
10
9
|
*/
|
|
11
|
-
export declare function useEventChat(eventId: string | undefined): import("@tanstack/react-query").UseQueryResult<
|
|
10
|
+
export declare function useEventChat(eventId: string | undefined): import("@tanstack/react-query").UseQueryResult<{
|
|
11
|
+
id: string;
|
|
12
|
+
eventId: string;
|
|
13
|
+
messageCount: number;
|
|
14
|
+
memberCount: number;
|
|
15
|
+
isActive: boolean;
|
|
16
|
+
isLocked: boolean;
|
|
17
|
+
lastMessageAt?: string;
|
|
18
|
+
createdAt: string;
|
|
19
|
+
eventTitle?: string;
|
|
20
|
+
eventStartDate?: string;
|
|
21
|
+
}, Error>;
|
|
12
22
|
/**
|
|
13
23
|
* Get chat members
|
|
14
24
|
*/
|
|
15
|
-
export declare function useEventChatMembers(eventId: string | undefined): import("@tanstack/react-query").UseQueryResult<
|
|
25
|
+
export declare function useEventChatMembers(eventId: string | undefined): import("@tanstack/react-query").UseQueryResult<{
|
|
26
|
+
id: string;
|
|
27
|
+
chatId: string;
|
|
28
|
+
userId: string;
|
|
29
|
+
role: "MEMBER" | "MODERATOR" | "HOST";
|
|
30
|
+
nickname?: string;
|
|
31
|
+
isMuted: boolean;
|
|
32
|
+
lastReadAt?: string;
|
|
33
|
+
joinedAt: string;
|
|
34
|
+
userName?: string;
|
|
35
|
+
userImage?: string;
|
|
36
|
+
}[], Error>;
|
|
16
37
|
/**
|
|
17
38
|
* Get chat messages with infinite scroll pagination
|
|
18
39
|
*/
|
|
19
|
-
export declare function useEventChatMessages(eventId: string | undefined, limit?: number): import("@tanstack/react-query").UseInfiniteQueryResult<import("@tanstack/react-query").InfiniteData<
|
|
40
|
+
export declare function useEventChatMessages(eventId: string | undefined, limit?: number): import("@tanstack/react-query").UseInfiniteQueryResult<import("@tanstack/react-query").InfiniteData<{
|
|
41
|
+
messages: import("@growsober/types/dist/generated").components["schemas"]["MessageResponseDto"][];
|
|
42
|
+
total: number;
|
|
43
|
+
hasMore: boolean;
|
|
44
|
+
nextCursor?: string;
|
|
45
|
+
}, unknown>, Error>;
|
|
@@ -11,16 +11,58 @@ export declare const grow90Keys: {
|
|
|
11
11
|
/**
|
|
12
12
|
* Get current user's GROW90 enrollment
|
|
13
13
|
*/
|
|
14
|
-
export declare function useGrow90Enrollment(options?: Omit<UseQueryOptions<Grow90EnrollmentResponse | null>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<
|
|
14
|
+
export declare function useGrow90Enrollment(options?: Omit<UseQueryOptions<Grow90EnrollmentResponse | null>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
15
|
+
id: string;
|
|
16
|
+
userId: string;
|
|
17
|
+
startDate: string;
|
|
18
|
+
targetEndDate: string;
|
|
19
|
+
actualEndDate?: Record<string, never>;
|
|
20
|
+
currentDay: number;
|
|
21
|
+
completedDays: number;
|
|
22
|
+
missedDays: number;
|
|
23
|
+
status: "ACTIVE" | "COMPLETED" | "PAUSED" | "ABANDONED";
|
|
24
|
+
completedAt?: Record<string, never>;
|
|
25
|
+
dailyReminderTime: string;
|
|
26
|
+
weeklyCallDay?: Record<string, never>;
|
|
27
|
+
createdAt: string;
|
|
28
|
+
progressPercentage: number;
|
|
29
|
+
daysRemaining: number;
|
|
30
|
+
} | null, Error>;
|
|
15
31
|
/**
|
|
16
32
|
* Get today's GROW90 content and progress
|
|
17
33
|
*/
|
|
18
|
-
export declare function useGrow90Today(options?: Omit<UseQueryOptions<Grow90TodayResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<
|
|
34
|
+
export declare function useGrow90Today(options?: Omit<UseQueryOptions<Grow90TodayResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
35
|
+
progress: Record<string, never>;
|
|
36
|
+
dayNumber: number;
|
|
37
|
+
dailyContent: Record<string, never>;
|
|
38
|
+
tasks: Record<string, never>;
|
|
39
|
+
}, Error>;
|
|
19
40
|
/**
|
|
20
41
|
* Get all GROW90 progress entries
|
|
21
42
|
*/
|
|
22
|
-
export declare function useGrow90Progress(options?: Omit<UseQueryOptions<Grow90ProgressResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<
|
|
43
|
+
export declare function useGrow90Progress(options?: Omit<UseQueryOptions<Grow90ProgressResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
44
|
+
id: string;
|
|
45
|
+
dayNumber: number;
|
|
46
|
+
date: string;
|
|
47
|
+
isCompleted: boolean;
|
|
48
|
+
completedAt?: Record<string, never>;
|
|
49
|
+
morningCheckIn: boolean;
|
|
50
|
+
eveningCheckIn: boolean;
|
|
51
|
+
contentViewed: boolean;
|
|
52
|
+
journalEntry?: Record<string, never>;
|
|
53
|
+
gratitudeList: string[];
|
|
54
|
+
morningMood?: Record<string, never>;
|
|
55
|
+
eveningMood?: Record<string, never>;
|
|
56
|
+
createdAt: string;
|
|
57
|
+
}[], Error>;
|
|
23
58
|
/**
|
|
24
59
|
* Get GROW90 statistics
|
|
25
60
|
*/
|
|
26
|
-
export declare function useGrow90Stats(options?: Omit<UseQueryOptions<Grow90StatsResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<
|
|
61
|
+
export declare function useGrow90Stats(options?: Omit<UseQueryOptions<Grow90StatsResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
62
|
+
completedDays: number;
|
|
63
|
+
currentStreak: number;
|
|
64
|
+
longestStreak: number;
|
|
65
|
+
averageMood: Record<string, never>;
|
|
66
|
+
completionRate: number;
|
|
67
|
+
journalEntriesCount: number;
|
|
68
|
+
}, Error>;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { UseQueryOptions } from '@tanstack/react-query';
|
|
2
|
-
import type { HubResponse,
|
|
2
|
+
import type { HubResponse, ChatMemberResponse } from '../types';
|
|
3
3
|
export declare const hubKeys: {
|
|
4
4
|
all: readonly ["hubs"];
|
|
5
5
|
lists: () => readonly ["hubs", "list"];
|
|
@@ -35,7 +35,7 @@ export interface PaginatedHubsResponse {
|
|
|
35
35
|
};
|
|
36
36
|
}
|
|
37
37
|
export interface PaginatedMembersResponse {
|
|
38
|
-
data:
|
|
38
|
+
data: ChatMemberResponse[];
|
|
39
39
|
meta: {
|
|
40
40
|
total: number;
|
|
41
41
|
page: number;
|
package/dist/api/queries/hubs.js
CHANGED
|
@@ -140,4 +140,4 @@ function useHubMembership(id, options) {
|
|
|
140
140
|
...options,
|
|
141
141
|
});
|
|
142
142
|
}
|
|
143
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hubs.js","sourceRoot":"","sources":["../../../src/api/queries/hubs.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { HubResponse, HubMemberResponse } from '../types';\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const hubKeys = {\n  all: ['hubs'] as const,\n  lists: () => [...hubKeys.all, 'list'] as const,\n  list: (filters?: HubListFilters) => [...hubKeys.lists(), filters] as const,\n  details: () => [...hubKeys.all, 'detail'] as const,\n  detail: (id: string) => [...hubKeys.details(), id] as const,\n  bySlug: (slug: string) => [...hubKeys.all, 'slug', slug] as const,\n  myHubs: () => [...hubKeys.all, 'my-hubs'] as const,\n  members: (id: string, filters?: MemberFilters) =>\n    [...hubKeys.detail(id), 'members', filters] as const,\n  membership: (id: string) => [...hubKeys.detail(id), 'membership'] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface HubListFilters {\n  page?: number;\n  limit?: number;\n  cityId?: string;\n  search?: string;\n  isFeatured?: boolean;\n  visibility?: 'PUBLIC' | 'PRIVATE' | 'INVITE_ONLY';\n}\n\nexport interface MemberFilters {\n  page?: number;\n  limit?: number;\n  role?: string;\n  status?: string;\n}\n\nexport interface PaginatedHubsResponse {\n  data: HubResponse[];\n  meta: {\n    total: number;\n    page: number;\n    limit: number;\n    totalPages: number;\n  };\n}\n\n// HubMemberResponse is imported from '../types'\n\nexport interface PaginatedMembersResponse {\n  data: HubMemberResponse[];\n  meta: {\n    total: number;\n    page: number;\n    limit: number;\n    totalPages: number;\n  };\n}\n\nexport interface MembershipResponse {\n  isMember: boolean;\n  role?: 'OWNER' | 'ADMIN' | 'MEMBER';\n  status?: 'ACTIVE' | 'PENDING' | 'BANNED';\n  joinedAt?: string;\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get all hubs with pagination and filters\n *\n * @param filters - Optional filters for hubs list\n * @param options - React Query options\n * @returns Query result with paginated hubs\n */\nexport function useHubs(\n  filters?: HubListFilters,\n  options?: Omit<UseQueryOptions<PaginatedHubsResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: hubKeys.list(filters),\n    queryFn: async (): Promise<PaginatedHubsResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/hubs', { params: filters });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get hub by ID\n *\n * @param id - Hub ID\n * @param options - React Query options\n * @returns Query result with hub details\n */\nexport function useHub(\n  id: string,\n  options?: Omit<UseQueryOptions<HubResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: hubKeys.detail(id),\n    queryFn: async (): Promise<HubResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/hubs/${id}`);\n      return response.data;\n    },\n    enabled: !!id && (options?.enabled !== false),\n    ...options,\n  });\n}\n\n/**\n * Get hub by slug\n *\n * @param slug - Hub slug\n * @param options - React Query options\n * @returns Query result with hub details\n */\nexport function useHubBySlug(\n  slug: string,\n  options?: Omit<UseQueryOptions<HubResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: hubKeys.bySlug(slug),\n    queryFn: async (): Promise<HubResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/hubs/slug/${slug}`);\n      return response.data;\n    },\n    enabled: !!slug && (options?.enabled !== false),\n    ...options,\n  });\n}\n\n/**\n * Get hubs the current user is a member of\n *\n * @param options - React Query options\n * @returns Query result with user's hubs\n */\nexport function useMyHubs(\n  options?: Omit<UseQueryOptions<HubResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: hubKeys.myHubs(),\n    queryFn: async (): Promise<HubResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/hubs/my-hubs');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get hub members with pagination and filters\n *\n * @param id - Hub ID\n * @param filters - Optional filters for members list\n * @param options - React Query options\n * @returns Query result with paginated members\n */\nexport function useHubMembers(\n  id: string,\n  filters?: MemberFilters,\n  options?: Omit<UseQueryOptions<PaginatedMembersResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: hubKeys.members(id, filters),\n    queryFn: async (): Promise<PaginatedMembersResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/hubs/${id}/members`, {\n        params: filters\n      });\n      return response.data;\n    },\n    enabled: !!id && (options?.enabled !== false),\n    ...options,\n  });\n}\n\n/**\n * Get current user's membership status for a hub\n *\n * @param id - Hub ID\n * @param options - React Query options\n * @returns Query result with membership status\n */\nexport function useHubMembership(\n  id: string,\n  options?: Omit<UseQueryOptions<MembershipResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: hubKeys.membership(id),\n    queryFn: async (): Promise<MembershipResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/hubs/${id}/membership`);\n      return response.data;\n    },\n    enabled: !!id && (options?.enabled !== false),\n    ...options,\n  });\n}\n"]}
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hubs.js","sourceRoot":"","sources":["../../../src/api/queries/hubs.ts"],"names":[],"mappings":"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","sourcesContent":["import { useQuery, UseQueryOptions } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { HubResponse, ChatMemberResponse } from '../types';\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const hubKeys = {\n  all: ['hubs'] as const,\n  lists: () => [...hubKeys.all, 'list'] as const,\n  list: (filters?: HubListFilters) => [...hubKeys.lists(), filters] as const,\n  details: () => [...hubKeys.all, 'detail'] as const,\n  detail: (id: string) => [...hubKeys.details(), id] as const,\n  bySlug: (slug: string) => [...hubKeys.all, 'slug', slug] as const,\n  myHubs: () => [...hubKeys.all, 'my-hubs'] as const,\n  members: (id: string, filters?: MemberFilters) =>\n    [...hubKeys.detail(id), 'members', filters] as const,\n  membership: (id: string) => [...hubKeys.detail(id), 'membership'] as const,\n};\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\nexport interface HubListFilters {\n  page?: number;\n  limit?: number;\n  cityId?: string;\n  search?: string;\n  isFeatured?: boolean;\n  visibility?: 'PUBLIC' | 'PRIVATE' | 'INVITE_ONLY';\n}\n\nexport interface MemberFilters {\n  page?: number;\n  limit?: number;\n  role?: string;\n  status?: string;\n}\n\nexport interface PaginatedHubsResponse {\n  data: HubResponse[];\n  meta: {\n    total: number;\n    page: number;\n    limit: number;\n    totalPages: number;\n  };\n}\n\n// ChatMemberResponse is imported from '../types'\n\nexport interface PaginatedMembersResponse {\n  data: ChatMemberResponse[];\n  meta: {\n    total: number;\n    page: number;\n    limit: number;\n    totalPages: number;\n  };\n}\n\nexport interface MembershipResponse {\n  isMember: boolean;\n  role?: 'OWNER' | 'ADMIN' | 'MEMBER';\n  status?: 'ACTIVE' | 'PENDING' | 'BANNED';\n  joinedAt?: string;\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get all hubs with pagination and filters\n *\n * @param filters - Optional filters for hubs list\n * @param options - React Query options\n * @returns Query result with paginated hubs\n */\nexport function useHubs(\n  filters?: HubListFilters,\n  options?: Omit<UseQueryOptions<PaginatedHubsResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: hubKeys.list(filters),\n    queryFn: async (): Promise<PaginatedHubsResponse> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/hubs', { params: filters });\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get hub by ID\n *\n * @param id - Hub ID\n * @param options - React Query options\n * @returns Query result with hub details\n */\nexport function useHub(\n  id: string,\n  options?: Omit<UseQueryOptions<HubResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: hubKeys.detail(id),\n    queryFn: async (): Promise<HubResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/hubs/${id}`);\n      return response.data;\n    },\n    enabled: !!id && (options?.enabled !== false),\n    ...options,\n  });\n}\n\n/**\n * Get hub by slug\n *\n * @param slug - Hub slug\n * @param options - React Query options\n * @returns Query result with hub details\n */\nexport function useHubBySlug(\n  slug: string,\n  options?: Omit<UseQueryOptions<HubResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: hubKeys.bySlug(slug),\n    queryFn: async (): Promise<HubResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/hubs/slug/${slug}`);\n      return response.data;\n    },\n    enabled: !!slug && (options?.enabled !== false),\n    ...options,\n  });\n}\n\n/**\n * Get hubs the current user is a member of\n *\n * @param options - React Query options\n * @returns Query result with user's hubs\n */\nexport function useMyHubs(\n  options?: Omit<UseQueryOptions<HubResponse[]>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: hubKeys.myHubs(),\n    queryFn: async (): Promise<HubResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get('/api/v1/hubs/my-hubs');\n      return response.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get hub members with pagination and filters\n *\n * @param id - Hub ID\n * @param filters - Optional filters for members list\n * @param options - React Query options\n * @returns Query result with paginated members\n */\nexport function useHubMembers(\n  id: string,\n  filters?: MemberFilters,\n  options?: Omit<UseQueryOptions<PaginatedMembersResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: hubKeys.members(id, filters),\n    queryFn: async (): Promise<PaginatedMembersResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/hubs/${id}/members`, {\n        params: filters\n      });\n      return response.data;\n    },\n    enabled: !!id && (options?.enabled !== false),\n    ...options,\n  });\n}\n\n/**\n * Get current user's membership status for a hub\n *\n * @param id - Hub ID\n * @param options - React Query options\n * @returns Query result with membership status\n */\nexport function useHubMembership(\n  id: string,\n  options?: Omit<UseQueryOptions<MembershipResponse>, 'queryKey' | 'queryFn'>\n) {\n  return useQuery({\n    queryKey: hubKeys.membership(id),\n    queryFn: async (): Promise<MembershipResponse> => {\n      const client = getApiClient();\n      const response = await client.get(`/api/v1/hubs/${id}/membership`);\n      return response.data;\n    },\n    enabled: !!id && (options?.enabled !== false),\n    ...options,\n  });\n}\n"]}
|
|
@@ -23,6 +23,7 @@ __exportStar(require("./admin"), exports);
|
|
|
23
23
|
__exportStar(require("./auth"), exports);
|
|
24
24
|
__exportStar(require("./bookings"), exports);
|
|
25
25
|
__exportStar(require("./businesses"), exports);
|
|
26
|
+
__exportStar(require("./cities"), exports);
|
|
26
27
|
__exportStar(require("./events"), exports);
|
|
27
28
|
__exportStar(require("./hubs"), exports);
|
|
28
29
|
__exportStar(require("./library"), exports);
|
|
@@ -37,4 +38,4 @@ __exportStar(require("./ambassadors"), exports);
|
|
|
37
38
|
__exportStar(require("./grow90"), exports);
|
|
38
39
|
__exportStar(require("./matching"), exports);
|
|
39
40
|
__exportStar(require("./event-chat"), exports);
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3F1ZXJpZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7O0dBSUc7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFSCwwQ0FBd0I7QUFDeEIseUNBQXVCO0FBQ3ZCLDZDQUEyQjtBQUMzQiwrQ0FBNkI7QUFDN0IsMkNBQXlCO0FBQ3pCLDJDQUF5QjtBQUN6Qix5Q0FBdUI7QUFDdkIsNENBQTBCO0FBQzFCLHdDQUFzQjtBQUN0QixrREFBZ0M7QUFDaEMsMkNBQXlCO0FBQ3pCLGtEQUFnQztBQUNoQyw0Q0FBMEI7QUFDMUIsMENBQXdCO0FBQ3hCLHlDQUF1QjtBQUN2QixnREFBOEI7QUFDOUIsMkNBQXlCO0FBQ3pCLDZDQUEyQjtBQUMzQiwrQ0FBNkIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFF1ZXJ5IEhvb2tzXG4gKlxuICogUmUtZXhwb3J0cyBhbGwgcXVlcnkgaG9va3MgZm9yIEFQSSBlbmRwb2ludHMuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9hZG1pbic7XG5leHBvcnQgKiBmcm9tICcuL2F1dGgnO1xuZXhwb3J0ICogZnJvbSAnLi9ib29raW5ncyc7XG5leHBvcnQgKiBmcm9tICcuL2J1c2luZXNzZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9jaXRpZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9ldmVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9odWJzJztcbmV4cG9ydCAqIGZyb20gJy4vbGlicmFyeSc7XG5leHBvcnQgKiBmcm9tICcuL21hcCc7XG5leHBvcnQgKiBmcm9tICcuL25vdGlmaWNhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9vZmZlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdWJzY3JpcHRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vc3VwcG9ydCc7XG5leHBvcnQgKiBmcm9tICcuL3VzZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vamFjayc7XG5leHBvcnQgKiBmcm9tICcuL2FtYmFzc2Fkb3JzJztcbmV4cG9ydCAqIGZyb20gJy4vZ3JvdzkwJztcbmV4cG9ydCAqIGZyb20gJy4vbWF0Y2hpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi9ldmVudC1jaGF0JztcbiJdfQ==
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
* @module api/queries/map
|
|
9
9
|
*/
|
|
10
10
|
import { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
|
|
11
|
-
import type {
|
|
11
|
+
import type { MapMemberResponse, MapEventResponse, MapHubResponse, BusinessResponse } from '../types';
|
|
12
12
|
/**
|
|
13
13
|
* Query key factory for map-related queries
|
|
14
14
|
*/
|
|
@@ -88,7 +88,7 @@ export interface MapBusinessesParams {
|
|
|
88
88
|
* @param options - TanStack Query options
|
|
89
89
|
* @returns TanStack Query result with array of map users
|
|
90
90
|
*/
|
|
91
|
-
export declare function useMapMembers(params: MapMembersParams, options?: Omit<UseQueryOptions<
|
|
91
|
+
export declare function useMapMembers(params: MapMembersParams, options?: Omit<UseQueryOptions<MapMemberResponse[]>, 'queryKey' | 'queryFn'>): UseQueryResult<MapMemberResponse[]>;
|
|
92
92
|
/**
|
|
93
93
|
* Get events for map display
|
|
94
94
|
*
|
|
@@ -213,4 +213,4 @@ export declare function useMapHubs(params: MapHubsParams, options?: Omit<UseQuer
|
|
|
213
213
|
* @param options - TanStack Query options
|
|
214
214
|
* @returns TanStack Query result with array of map businesses
|
|
215
215
|
*/
|
|
216
|
-
export declare function useMapBusinesses(params: MapBusinessesParams, options?: Omit<UseQueryOptions<
|
|
216
|
+
export declare function useMapBusinesses(params: MapBusinessesParams, options?: Omit<UseQueryOptions<BusinessResponse[]>, 'queryKey' | 'queryFn'>): UseQueryResult<BusinessResponse[]>;
|
package/dist/api/queries/map.js
CHANGED
|
@@ -275,4 +275,4 @@ function useMapBusinesses(params, options) {
|
|
|
275
275
|
...options,
|
|
276
276
|
});
|
|
277
277
|
}
|
|
278
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map.js","sourceRoot":"","sources":["../../../src/api/queries/map.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Map Query Hooks\n *\n * TanStack Query hooks for map-related read operations.\n * These hooks handle fetching map data including users, events, and businesses\n * for display on the member map feature.\n *\n * @module api/queries/map\n */\n\nimport { useQuery, UseQueryOptions, UseQueryResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type {\n  MapUserResponse,\n  MapEventResponse,\n  MapHubResponse,\n  MapBusinessResponse,\n} from '../types';\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\n/**\n * Query key factory for map-related queries\n */\nexport const mapKeys = {\n  all: ['map'] as const,\n  members: (params?: MapMembersParams) => [...mapKeys.all, 'members', params] as const,\n  events: (params?: MapEventsParams) => [...mapKeys.all, 'events', params] as const,\n  hubs: (params?: MapHubsParams) => [...mapKeys.all, 'hubs', params] as const,\n  businesses: (params?: MapBusinessesParams) => [...mapKeys.all, 'businesses', params] as const,\n};\n\n// ============================================================================\n// PARAM TYPES\n// ============================================================================\n\nexport interface MapMembersParams {\n  lat: number;\n  lng: number;\n  radius?: number; // km\n  hubId?: string;\n  openToMeetOnly?: boolean;\n}\n\nexport interface MapEventsParams {\n  lat: number;\n  lng: number;\n  radius?: number; // km\n  hubId?: string;\n  upcoming?: boolean;\n}\n\nexport interface MapHubsParams {\n  lat: number;\n  lng: number;\n  radius?: number; // km\n  city?: string;\n}\n\nexport interface MapBusinessesParams {\n  lat: number;\n  lng: number;\n  radius?: number; // km\n  type?: string;\n  afDrinksOnly?: boolean;\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get members for map display\n *\n * @description\n * Retrieves users who have opted to be visible on the member map.\n * Only shows users who have enabled \"open to meet\" and shared their location.\n * Premium feature.\n *\n * @endpoint GET /api/v1/map/members\n *\n * @example\n * ```tsx\n * import { useMapMembers } from '@growsober/sdk';\n *\n * function MemberMap() {\n *   const { data: members, isLoading } = useMapMembers({\n *     lat: 51.5074,\n *     lng: -0.1278,\n *     radius: 50, // 50km radius\n *   });\n *\n *   if (isLoading) return <MapLoader />;\n *\n *   return (\n *     <Map>\n *       {members?.map(member => (\n *         <Marker\n *           key={member.id}\n *           position={[member.locationLat, member.locationLong]}\n *         >\n *           <Avatar src={member.avatar} />\n *         </Marker>\n *       ))}\n *     </Map>\n *   );\n * }\n * ```\n *\n * @param params - Location and filter parameters\n * @param options - TanStack Query options\n * @returns TanStack Query result with array of map users\n */\nexport function useMapMembers(\n  params: MapMembersParams,\n  options?: Omit<UseQueryOptions<MapUserResponse[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<MapUserResponse[]> {\n  return useQuery({\n    queryKey: mapKeys.members(params),\n    queryFn: async (): Promise<MapUserResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get<MapUserResponse[]>('/api/v1/map/members', {\n        params: {\n          lat: params.lat,\n          lng: params.lng,\n          radius: params.radius,\n          hubId: params.hubId,\n          openToMeetOnly: params.openToMeetOnly,\n        },\n      });\n      return response.data;\n    },\n    enabled: params.lat !== undefined && params.lng !== undefined,\n    ...options,\n  });\n}\n\n/**\n * Get events for map display\n *\n * @description\n * Retrieves events with location data for display on the map.\n * Shows upcoming events within the specified radius.\n *\n * @endpoint GET /api/v1/map/events\n *\n * @example\n * ```tsx\n * import { useMapEvents } from '@growsober/sdk';\n *\n * function EventMap() {\n *   const { data: events, isLoading } = useMapEvents({\n *     lat: 51.5074,\n *     lng: -0.1278,\n *     radius: 25,\n *     upcoming: true,\n *   });\n *\n *   return (\n *     <Map>\n *       {events?.map(event => (\n *         <Marker\n *           key={event.id}\n *           position={[event.locationLat, event.locationLong]}\n *           icon=\"event\"\n *         >\n *           <EventPopup event={event} />\n *         </Marker>\n *       ))}\n *     </Map>\n *   );\n * }\n * ```\n *\n * @param params - Location and filter parameters\n * @param options - TanStack Query options\n * @returns TanStack Query result with array of map events\n */\nexport function useMapEvents(\n  params: MapEventsParams,\n  options?: Omit<UseQueryOptions<MapEventResponse[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<MapEventResponse[]> {\n  return useQuery({\n    queryKey: mapKeys.events(params),\n    queryFn: async (): Promise<MapEventResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get<MapEventResponse[]>('/api/v1/map/events', {\n        params: {\n          lat: params.lat,\n          lng: params.lng,\n          radius: params.radius,\n          hubId: params.hubId,\n          upcoming: params.upcoming,\n        },\n      });\n      return response.data;\n    },\n    enabled: params.lat !== undefined && params.lng !== undefined,\n    ...options,\n  });\n}\n\n/**\n * Get hubs for map display\n *\n * @description\n * Retrieves hubs with location data for display on the map.\n * Shows active hubs within the specified radius.\n *\n * @endpoint GET /api/v1/map/hubs\n *\n * @example\n * ```tsx\n * import { useMapHubs } from '@growsober/sdk';\n *\n * function HubMap() {\n *   const { data: hubs, isLoading } = useMapHubs({\n *     lat: 51.5074,\n *     lng: -0.1278,\n *     radius: 50,\n *   });\n *\n *   return (\n *     <Map>\n *       {hubs?.map(hub => (\n *         <Marker\n *           key={hub.id}\n *           position={[hub.locationLat, hub.locationLong]}\n *           icon=\"hub\"\n *         >\n *           <HubPopup hub={hub} />\n *         </Marker>\n *       ))}\n *     </Map>\n *   );\n * }\n * ```\n *\n * @param params - Location and filter parameters\n * @param options - TanStack Query options\n * @returns TanStack Query result with array of map hubs\n */\nexport function useMapHubs(\n  params: MapHubsParams,\n  options?: Omit<UseQueryOptions<MapHubResponse[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<MapHubResponse[]> {\n  return useQuery({\n    queryKey: mapKeys.hubs(params),\n    queryFn: async (): Promise<MapHubResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get<MapHubResponse[]>('/api/v1/map/hubs', {\n        params: {\n          lat: params.lat,\n          lng: params.lng,\n          radius: params.radius,\n          city: params.city,\n        },\n      });\n      return response.data;\n    },\n    enabled: params.lat !== undefined && params.lng !== undefined,\n    ...options,\n  });\n}\n\n/**\n * Get businesses for map display\n *\n * @description\n * Retrieves partner businesses with location data for display on the map.\n * Can filter by type and whether they serve alcohol-free drinks.\n *\n * @endpoint GET /api/v1/map/businesses\n *\n * @example\n * ```tsx\n * import { useMapBusinesses } from '@growsober/sdk';\n *\n * function BusinessMap() {\n *   const { data: businesses, isLoading } = useMapBusinesses({\n *     lat: 51.5074,\n *     lng: -0.1278,\n *     radius: 10,\n *     afDrinksOnly: true, // Only show AF-friendly venues\n *   });\n *\n *   return (\n *     <Map>\n *       {businesses?.map(business => (\n *         <Marker\n *           key={business.id}\n *           position={[business.locationLat, business.locationLong]}\n *           icon={business.hasAfDrinks ? 'af-venue' : 'venue'}\n *         >\n *           <BusinessPopup business={business} />\n *         </Marker>\n *       ))}\n *     </Map>\n *   );\n * }\n * ```\n *\n * @param params - Location and filter parameters\n * @param options - TanStack Query options\n * @returns TanStack Query result with array of map businesses\n */\nexport function useMapBusinesses(\n  params: MapBusinessesParams,\n  options?: Omit<UseQueryOptions<MapBusinessResponse[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<MapBusinessResponse[]> {\n  return useQuery({\n    queryKey: mapKeys.businesses(params),\n    queryFn: async (): Promise<MapBusinessResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get<MapBusinessResponse[]>('/api/v1/map/businesses', {\n        params: {\n          lat: params.lat,\n          lng: params.lng,\n          radius: params.radius,\n          type: params.type,\n          afDrinksOnly: params.afDrinksOnly,\n        },\n      });\n      return response.data;\n    },\n    enabled: params.lat !== undefined && params.lng !== undefined,\n    ...options,\n  });\n}\n"]}
|
|
278
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map.js","sourceRoot":"","sources":["../../../src/api/queries/map.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Map Query Hooks\n *\n * TanStack Query hooks for map-related read operations.\n * These hooks handle fetching map data including users, events, and businesses\n * for display on the member map feature.\n *\n * @module api/queries/map\n */\n\nimport { useQuery, UseQueryOptions, UseQueryResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type {\n  MapMemberResponse,\n  MapEventResponse,\n  MapHubResponse,\n  BusinessResponse,\n} from '../types';\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\n/**\n * Query key factory for map-related queries\n */\nexport const mapKeys = {\n  all: ['map'] as const,\n  members: (params?: MapMembersParams) => [...mapKeys.all, 'members', params] as const,\n  events: (params?: MapEventsParams) => [...mapKeys.all, 'events', params] as const,\n  hubs: (params?: MapHubsParams) => [...mapKeys.all, 'hubs', params] as const,\n  businesses: (params?: MapBusinessesParams) => [...mapKeys.all, 'businesses', params] as const,\n};\n\n// ============================================================================\n// PARAM TYPES\n// ============================================================================\n\nexport interface MapMembersParams {\n  lat: number;\n  lng: number;\n  radius?: number; // km\n  hubId?: string;\n  openToMeetOnly?: boolean;\n}\n\nexport interface MapEventsParams {\n  lat: number;\n  lng: number;\n  radius?: number; // km\n  hubId?: string;\n  upcoming?: boolean;\n}\n\nexport interface MapHubsParams {\n  lat: number;\n  lng: number;\n  radius?: number; // km\n  city?: string;\n}\n\nexport interface MapBusinessesParams {\n  lat: number;\n  lng: number;\n  radius?: number; // km\n  type?: string;\n  afDrinksOnly?: boolean;\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get members for map display\n *\n * @description\n * Retrieves users who have opted to be visible on the member map.\n * Only shows users who have enabled \"open to meet\" and shared their location.\n * Premium feature.\n *\n * @endpoint GET /api/v1/map/members\n *\n * @example\n * ```tsx\n * import { useMapMembers } from '@growsober/sdk';\n *\n * function MemberMap() {\n *   const { data: members, isLoading } = useMapMembers({\n *     lat: 51.5074,\n *     lng: -0.1278,\n *     radius: 50, // 50km radius\n *   });\n *\n *   if (isLoading) return <MapLoader />;\n *\n *   return (\n *     <Map>\n *       {members?.map(member => (\n *         <Marker\n *           key={member.id}\n *           position={[member.locationLat, member.locationLong]}\n *         >\n *           <Avatar src={member.avatar} />\n *         </Marker>\n *       ))}\n *     </Map>\n *   );\n * }\n * ```\n *\n * @param params - Location and filter parameters\n * @param options - TanStack Query options\n * @returns TanStack Query result with array of map users\n */\nexport function useMapMembers(\n  params: MapMembersParams,\n  options?: Omit<UseQueryOptions<MapMemberResponse[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<MapMemberResponse[]> {\n  return useQuery({\n    queryKey: mapKeys.members(params),\n    queryFn: async (): Promise<MapMemberResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get<MapMemberResponse[]>('/api/v1/map/members', {\n        params: {\n          lat: params.lat,\n          lng: params.lng,\n          radius: params.radius,\n          hubId: params.hubId,\n          openToMeetOnly: params.openToMeetOnly,\n        },\n      });\n      return response.data;\n    },\n    enabled: params.lat !== undefined && params.lng !== undefined,\n    ...options,\n  });\n}\n\n/**\n * Get events for map display\n *\n * @description\n * Retrieves events with location data for display on the map.\n * Shows upcoming events within the specified radius.\n *\n * @endpoint GET /api/v1/map/events\n *\n * @example\n * ```tsx\n * import { useMapEvents } from '@growsober/sdk';\n *\n * function EventMap() {\n *   const { data: events, isLoading } = useMapEvents({\n *     lat: 51.5074,\n *     lng: -0.1278,\n *     radius: 25,\n *     upcoming: true,\n *   });\n *\n *   return (\n *     <Map>\n *       {events?.map(event => (\n *         <Marker\n *           key={event.id}\n *           position={[event.locationLat, event.locationLong]}\n *           icon=\"event\"\n *         >\n *           <EventPopup event={event} />\n *         </Marker>\n *       ))}\n *     </Map>\n *   );\n * }\n * ```\n *\n * @param params - Location and filter parameters\n * @param options - TanStack Query options\n * @returns TanStack Query result with array of map events\n */\nexport function useMapEvents(\n  params: MapEventsParams,\n  options?: Omit<UseQueryOptions<MapEventResponse[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<MapEventResponse[]> {\n  return useQuery({\n    queryKey: mapKeys.events(params),\n    queryFn: async (): Promise<MapEventResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get<MapEventResponse[]>('/api/v1/map/events', {\n        params: {\n          lat: params.lat,\n          lng: params.lng,\n          radius: params.radius,\n          hubId: params.hubId,\n          upcoming: params.upcoming,\n        },\n      });\n      return response.data;\n    },\n    enabled: params.lat !== undefined && params.lng !== undefined,\n    ...options,\n  });\n}\n\n/**\n * Get hubs for map display\n *\n * @description\n * Retrieves hubs with location data for display on the map.\n * Shows active hubs within the specified radius.\n *\n * @endpoint GET /api/v1/map/hubs\n *\n * @example\n * ```tsx\n * import { useMapHubs } from '@growsober/sdk';\n *\n * function HubMap() {\n *   const { data: hubs, isLoading } = useMapHubs({\n *     lat: 51.5074,\n *     lng: -0.1278,\n *     radius: 50,\n *   });\n *\n *   return (\n *     <Map>\n *       {hubs?.map(hub => (\n *         <Marker\n *           key={hub.id}\n *           position={[hub.locationLat, hub.locationLong]}\n *           icon=\"hub\"\n *         >\n *           <HubPopup hub={hub} />\n *         </Marker>\n *       ))}\n *     </Map>\n *   );\n * }\n * ```\n *\n * @param params - Location and filter parameters\n * @param options - TanStack Query options\n * @returns TanStack Query result with array of map hubs\n */\nexport function useMapHubs(\n  params: MapHubsParams,\n  options?: Omit<UseQueryOptions<MapHubResponse[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<MapHubResponse[]> {\n  return useQuery({\n    queryKey: mapKeys.hubs(params),\n    queryFn: async (): Promise<MapHubResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get<MapHubResponse[]>('/api/v1/map/hubs', {\n        params: {\n          lat: params.lat,\n          lng: params.lng,\n          radius: params.radius,\n          city: params.city,\n        },\n      });\n      return response.data;\n    },\n    enabled: params.lat !== undefined && params.lng !== undefined,\n    ...options,\n  });\n}\n\n/**\n * Get businesses for map display\n *\n * @description\n * Retrieves partner businesses with location data for display on the map.\n * Can filter by type and whether they serve alcohol-free drinks.\n *\n * @endpoint GET /api/v1/map/businesses\n *\n * @example\n * ```tsx\n * import { useMapBusinesses } from '@growsober/sdk';\n *\n * function BusinessMap() {\n *   const { data: businesses, isLoading } = useMapBusinesses({\n *     lat: 51.5074,\n *     lng: -0.1278,\n *     radius: 10,\n *     afDrinksOnly: true, // Only show AF-friendly venues\n *   });\n *\n *   return (\n *     <Map>\n *       {businesses?.map(business => (\n *         <Marker\n *           key={business.id}\n *           position={[business.locationLat, business.locationLong]}\n *           icon={business.hasAfDrinks ? 'af-venue' : 'venue'}\n *         >\n *           <BusinessPopup business={business} />\n *         </Marker>\n *       ))}\n *     </Map>\n *   );\n * }\n * ```\n *\n * @param params - Location and filter parameters\n * @param options - TanStack Query options\n * @returns TanStack Query result with array of map businesses\n */\nexport function useMapBusinesses(\n  params: MapBusinessesParams,\n  options?: Omit<UseQueryOptions<BusinessResponse[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<BusinessResponse[]> {\n  return useQuery({\n    queryKey: mapKeys.businesses(params),\n    queryFn: async (): Promise<BusinessResponse[]> => {\n      const client = getApiClient();\n      const response = await client.get<BusinessResponse[]>('/api/v1/map/businesses', {\n        params: {\n          lat: params.lat,\n          lng: params.lng,\n          radius: params.radius,\n          type: params.type,\n          afDrinksOnly: params.afDrinksOnly,\n        },\n      });\n      return response.data;\n    },\n    enabled: params.lat !== undefined && params.lng !== undefined,\n    ...options,\n  });\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { UseQueryOptions } from '@tanstack/react-query';
|
|
2
|
-
import type {
|
|
2
|
+
import type { CheckInResponse, CheckInStreakResponse, MoodLogResponse, WinResponse, HabitResponse, ReflectionResponse } from '../types';
|
|
3
3
|
export declare const supportKeys: {
|
|
4
4
|
all: readonly ["support"];
|
|
5
5
|
checkIns: () => readonly ["support", "check-ins"];
|
|
@@ -26,7 +26,20 @@ export interface WinsByCategory {
|
|
|
26
26
|
* const { data, isLoading } = useCheckIns();
|
|
27
27
|
* ```
|
|
28
28
|
*/
|
|
29
|
-
export declare function useCheckIns(options?: Omit<UseQueryOptions<
|
|
29
|
+
export declare function useCheckIns(options?: Omit<UseQueryOptions<CheckInResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
30
|
+
id: string;
|
|
31
|
+
userId: string;
|
|
32
|
+
date: string;
|
|
33
|
+
mood?: Record<string, never>;
|
|
34
|
+
energy?: Record<string, never>;
|
|
35
|
+
stayedSober?: Record<string, never>;
|
|
36
|
+
triggers: string[];
|
|
37
|
+
copingUsed: string[];
|
|
38
|
+
notes?: Record<string, never>;
|
|
39
|
+
gratitude: string[];
|
|
40
|
+
createdAt: string;
|
|
41
|
+
updatedAt: string;
|
|
42
|
+
}[], Error>;
|
|
30
43
|
/**
|
|
31
44
|
* Get today's check-in
|
|
32
45
|
*
|
|
@@ -37,7 +50,20 @@ export declare function useCheckIns(options?: Omit<UseQueryOptions<DailyCheckInR
|
|
|
37
50
|
* const { data, isLoading } = useTodayCheckIn();
|
|
38
51
|
* ```
|
|
39
52
|
*/
|
|
40
|
-
export declare function useTodayCheckIn(options?: Omit<UseQueryOptions<
|
|
53
|
+
export declare function useTodayCheckIn(options?: Omit<UseQueryOptions<CheckInResponse | null>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
54
|
+
id: string;
|
|
55
|
+
userId: string;
|
|
56
|
+
date: string;
|
|
57
|
+
mood?: Record<string, never>;
|
|
58
|
+
energy?: Record<string, never>;
|
|
59
|
+
stayedSober?: Record<string, never>;
|
|
60
|
+
triggers: string[];
|
|
61
|
+
copingUsed: string[];
|
|
62
|
+
notes?: Record<string, never>;
|
|
63
|
+
gratitude: string[];
|
|
64
|
+
createdAt: string;
|
|
65
|
+
updatedAt: string;
|
|
66
|
+
} | null, Error>;
|
|
41
67
|
/**
|
|
42
68
|
* Get user's check-in streak
|
|
43
69
|
*
|
|
@@ -48,7 +74,11 @@ export declare function useTodayCheckIn(options?: Omit<UseQueryOptions<DailyChec
|
|
|
48
74
|
* const { data, isLoading } = useCheckInStreak();
|
|
49
75
|
* ```
|
|
50
76
|
*/
|
|
51
|
-
export declare function useCheckInStreak(options?: Omit<UseQueryOptions<
|
|
77
|
+
export declare function useCheckInStreak(options?: Omit<UseQueryOptions<CheckInStreakResponse>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
78
|
+
currentStreak: number;
|
|
79
|
+
longestStreak: number;
|
|
80
|
+
totalCheckIns: number;
|
|
81
|
+
}, Error>;
|
|
52
82
|
/**
|
|
53
83
|
* Get user's mood logs
|
|
54
84
|
*
|
|
@@ -59,7 +89,17 @@ export declare function useCheckInStreak(options?: Omit<UseQueryOptions<UserStre
|
|
|
59
89
|
* const { data, isLoading } = useMoodLogs();
|
|
60
90
|
* ```
|
|
61
91
|
*/
|
|
62
|
-
export declare function useMoodLogs(options?: Omit<UseQueryOptions<MoodLogResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<
|
|
92
|
+
export declare function useMoodLogs(options?: Omit<UseQueryOptions<MoodLogResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
93
|
+
id: string;
|
|
94
|
+
userId: string;
|
|
95
|
+
mood: number;
|
|
96
|
+
energy?: Record<string, never>;
|
|
97
|
+
tags: string[];
|
|
98
|
+
note?: Record<string, never>;
|
|
99
|
+
activity?: Record<string, never>;
|
|
100
|
+
location?: Record<string, never>;
|
|
101
|
+
createdAt: string;
|
|
102
|
+
}[], Error>;
|
|
63
103
|
/**
|
|
64
104
|
* Get user's wins
|
|
65
105
|
*
|
|
@@ -70,7 +110,15 @@ export declare function useMoodLogs(options?: Omit<UseQueryOptions<MoodLogRespon
|
|
|
70
110
|
* const { data, isLoading } = useWins();
|
|
71
111
|
* ```
|
|
72
112
|
*/
|
|
73
|
-
export declare function useWins(options?: Omit<UseQueryOptions<WinResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<
|
|
113
|
+
export declare function useWins(options?: Omit<UseQueryOptions<WinResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
114
|
+
id: string;
|
|
115
|
+
userId: string;
|
|
116
|
+
title: string;
|
|
117
|
+
description?: Record<string, never>;
|
|
118
|
+
category: "SOBRIETY" | "HEALTH" | "RELATIONSHIP" | "CAREER" | "PERSONAL" | "FINANCIAL" | "OTHER";
|
|
119
|
+
imageUrl?: Record<string, never>;
|
|
120
|
+
createdAt: string;
|
|
121
|
+
}[], Error>;
|
|
74
122
|
/**
|
|
75
123
|
* Get user's wins grouped by category
|
|
76
124
|
*
|
|
@@ -92,7 +140,25 @@ export declare function useWinsByCategory(options?: Omit<UseQueryOptions<WinsByC
|
|
|
92
140
|
* const { data, isLoading } = useHabits();
|
|
93
141
|
* ```
|
|
94
142
|
*/
|
|
95
|
-
export declare function useHabits(options?: Omit<UseQueryOptions<HabitResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<
|
|
143
|
+
export declare function useHabits(options?: Omit<UseQueryOptions<HabitResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
144
|
+
id: string;
|
|
145
|
+
userId: string;
|
|
146
|
+
name: string;
|
|
147
|
+
description?: Record<string, never>;
|
|
148
|
+
icon?: Record<string, never>;
|
|
149
|
+
color?: Record<string, never>;
|
|
150
|
+
frequency: "DAILY" | "WEEKLY" | "CUSTOM";
|
|
151
|
+
targetDays: string[];
|
|
152
|
+
targetCount: number;
|
|
153
|
+
currentStreak: number;
|
|
154
|
+
longestStreak: number;
|
|
155
|
+
totalCompletions: number;
|
|
156
|
+
isActive: boolean;
|
|
157
|
+
isPaused: boolean;
|
|
158
|
+
reminderTime?: Record<string, never>;
|
|
159
|
+
createdAt: string;
|
|
160
|
+
updatedAt: string;
|
|
161
|
+
}[], Error>;
|
|
96
162
|
/**
|
|
97
163
|
* Get user's reflections
|
|
98
164
|
*
|
|
@@ -103,4 +169,18 @@ export declare function useHabits(options?: Omit<UseQueryOptions<HabitResponse[]
|
|
|
103
169
|
* const { data, isLoading } = useReflections();
|
|
104
170
|
* ```
|
|
105
171
|
*/
|
|
106
|
-
export declare function useReflections(options?: Omit<UseQueryOptions<ReflectionResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<
|
|
172
|
+
export declare function useReflections(options?: Omit<UseQueryOptions<ReflectionResponse[]>, 'queryKey' | 'queryFn'>): import("@tanstack/react-query").UseQueryResult<{
|
|
173
|
+
id: string;
|
|
174
|
+
userId: string;
|
|
175
|
+
weekStart: string;
|
|
176
|
+
weekNumber: number;
|
|
177
|
+
year: number;
|
|
178
|
+
overallRating?: Record<string, never>;
|
|
179
|
+
biggestWin?: Record<string, never>;
|
|
180
|
+
challenges?: Record<string, never>;
|
|
181
|
+
focusArea?: Record<string, never>;
|
|
182
|
+
goals: string[];
|
|
183
|
+
notes?: Record<string, never>;
|
|
184
|
+
createdAt: string;
|
|
185
|
+
updatedAt: string;
|
|
186
|
+
}[], Error>;
|