@spotsdev/sdk 1.0.0 → 1.1.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.
Files changed (74) hide show
  1. package/dist/api/client.d.ts +1 -1
  2. package/dist/api/client.js +7 -3
  3. package/dist/api/entities.d.ts +316 -0
  4. package/dist/api/entities.js +9 -0
  5. package/dist/api/mutations/clubs.d.ts +6 -6
  6. package/dist/api/mutations/clubs.js +12 -10
  7. package/dist/api/mutations/conversations.d.ts +7 -7
  8. package/dist/api/mutations/conversations.js +17 -13
  9. package/dist/api/mutations/index.js +1 -1
  10. package/dist/api/mutations/notifications.d.ts +4 -4
  11. package/dist/api/mutations/notifications.js +7 -7
  12. package/dist/api/mutations/orders.d.ts +7 -7
  13. package/dist/api/mutations/orders.js +11 -13
  14. package/dist/api/mutations/posts.d.ts +13 -13
  15. package/dist/api/mutations/posts.js +41 -29
  16. package/dist/api/mutations/products.d.ts +5 -5
  17. package/dist/api/mutations/products.js +9 -13
  18. package/dist/api/mutations/spots.d.ts +42 -8
  19. package/dist/api/mutations/spots.js +51 -13
  20. package/dist/api/mutations/users.d.ts +12 -10
  21. package/dist/api/mutations/users.js +20 -18
  22. package/dist/api/queries/auth.d.ts +5 -5
  23. package/dist/api/queries/auth.js +7 -7
  24. package/dist/api/queries/clubs.d.ts +7 -7
  25. package/dist/api/queries/clubs.js +11 -11
  26. package/dist/api/queries/conversations.d.ts +5 -5
  27. package/dist/api/queries/conversations.js +7 -7
  28. package/dist/api/queries/index.js +1 -1
  29. package/dist/api/queries/misc.d.ts +8 -32
  30. package/dist/api/queries/misc.js +28 -66
  31. package/dist/api/queries/notifications.d.ts +4 -4
  32. package/dist/api/queries/notifications.js +5 -5
  33. package/dist/api/queries/orders.d.ts +4 -4
  34. package/dist/api/queries/orders.js +7 -7
  35. package/dist/api/queries/posts.d.ts +44 -7
  36. package/dist/api/queries/posts.js +118 -15
  37. package/dist/api/queries/products.d.ts +6 -10
  38. package/dist/api/queries/products.js +7 -9
  39. package/dist/api/queries/spots.d.ts +31 -16
  40. package/dist/api/queries/spots.js +113 -31
  41. package/dist/api/queries/templates.d.ts +6 -9
  42. package/dist/api/queries/templates.js +8 -13
  43. package/dist/api/queries/users.d.ts +25 -11
  44. package/dist/api/queries/users.js +75 -27
  45. package/dist/api/types.d.ts +36 -33
  46. package/dist/api/types.js +6 -7
  47. package/dist/index.d.ts +1 -2
  48. package/dist/index.js +1 -8
  49. package/package.json +6 -21
  50. package/src/api/client.ts +45 -30
  51. package/src/api/entities.ts +420 -0
  52. package/src/api/mutations/clubs.ts +73 -40
  53. package/src/api/mutations/conversations.ts +91 -47
  54. package/src/api/mutations/index.ts +8 -8
  55. package/src/api/mutations/notifications.ts +48 -25
  56. package/src/api/mutations/orders.ts +101 -70
  57. package/src/api/mutations/posts.ts +229 -118
  58. package/src/api/mutations/products.ts +120 -81
  59. package/src/api/mutations/spots.ts +167 -55
  60. package/src/api/mutations/users.ts +109 -76
  61. package/src/api/queries/auth.ts +49 -24
  62. package/src/api/queries/clubs.ts +53 -38
  63. package/src/api/queries/conversations.ts +48 -30
  64. package/src/api/queries/index.ts +21 -21
  65. package/src/api/queries/misc.ts +53 -82
  66. package/src/api/queries/notifications.ts +32 -21
  67. package/src/api/queries/orders.ts +59 -42
  68. package/src/api/queries/posts.ts +203 -48
  69. package/src/api/queries/products.ts +51 -44
  70. package/src/api/queries/spots.ts +216 -85
  71. package/src/api/queries/templates.ts +39 -32
  72. package/src/api/queries/users.ts +157 -64
  73. package/src/api/types.ts +72 -118
  74. package/src/index.ts +5 -11
@@ -31,14 +31,14 @@ exports.clubKeys = {
31
31
  /**
32
32
  * Get clubs for a spot
33
33
  *
34
- * @endpoint GET /api/v1/clubs/spot/{spotId}
34
+ * @endpoint GET /clubs/spot/{spotId}
35
35
  */
36
36
  function useClubsBySpot(spotId, options) {
37
37
  return (0, react_query_1.useQuery)({
38
38
  queryKey: exports.clubKeys.bySpot(spotId),
39
39
  queryFn: async () => {
40
40
  const client = (0, client_1.getApiClient)();
41
- const response = await client.get(`/api/v1/clubs/spot/${spotId}`);
41
+ const response = await client.get(`/clubs/spot/${spotId}`);
42
42
  return response.data.data;
43
43
  },
44
44
  enabled: !!spotId,
@@ -48,14 +48,14 @@ function useClubsBySpot(spotId, options) {
48
48
  /**
49
49
  * Get a club by ID
50
50
  *
51
- * @endpoint GET /api/v1/clubs/{id}
51
+ * @endpoint GET /clubs/{id}
52
52
  */
53
53
  function useClub(clubId, options) {
54
54
  return (0, react_query_1.useQuery)({
55
55
  queryKey: exports.clubKeys.detail(clubId),
56
56
  queryFn: async () => {
57
57
  const client = (0, client_1.getApiClient)();
58
- const response = await client.get(`/api/v1/clubs/${clubId}`);
58
+ const response = await client.get(`/clubs/${clubId}`);
59
59
  return response.data.data;
60
60
  },
61
61
  enabled: !!clubId,
@@ -65,14 +65,14 @@ function useClub(clubId, options) {
65
65
  /**
66
66
  * Get a club by slug
67
67
  *
68
- * @endpoint GET /api/v1/clubs/slug/{slug}
68
+ * @endpoint GET /clubs/slug/{slug}
69
69
  */
70
70
  function useClubBySlug(slug, options) {
71
71
  return (0, react_query_1.useQuery)({
72
72
  queryKey: exports.clubKeys.bySlug(slug),
73
73
  queryFn: async () => {
74
74
  const client = (0, client_1.getApiClient)();
75
- const response = await client.get(`/api/v1/clubs/slug/${slug}`);
75
+ const response = await client.get(`/clubs/slug/${slug}`);
76
76
  return response.data.data;
77
77
  },
78
78
  enabled: !!slug,
@@ -82,14 +82,14 @@ function useClubBySlug(slug, options) {
82
82
  /**
83
83
  * Get clubs for a user
84
84
  *
85
- * @endpoint GET /api/v1/clubs/user/{userId}
85
+ * @endpoint GET /clubs/user/{userId}
86
86
  */
87
87
  function useClubsByUser(userId, options) {
88
88
  return (0, react_query_1.useQuery)({
89
89
  queryKey: exports.clubKeys.byUser(userId),
90
90
  queryFn: async () => {
91
91
  const client = (0, client_1.getApiClient)();
92
- const response = await client.get(`/api/v1/clubs/user/${userId}`);
92
+ const response = await client.get(`/clubs/user/${userId}`);
93
93
  return response.data.data;
94
94
  },
95
95
  enabled: !!userId,
@@ -99,18 +99,18 @@ function useClubsByUser(userId, options) {
99
99
  /**
100
100
  * Get membership status for a user in a club
101
101
  *
102
- * @endpoint GET /api/v1/clubs/{id}/membership/{userId}
102
+ * @endpoint GET /clubs/{id}/membership/{userId}
103
103
  */
104
104
  function useClubMembership(clubId, userId, options) {
105
105
  return (0, react_query_1.useQuery)({
106
106
  queryKey: exports.clubKeys.membership(clubId, userId),
107
107
  queryFn: async () => {
108
108
  const client = (0, client_1.getApiClient)();
109
- const response = await client.get(`/api/v1/clubs/${clubId}/membership/${userId}`);
109
+ const response = await client.get(`/clubs/${clubId}/membership/${userId}`);
110
110
  return response.data.data;
111
111
  },
112
112
  enabled: !!clubId && !!userId,
113
113
  ...options,
114
114
  });
115
115
  }
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clubs.js","sourceRoot":"","sources":["../../../src/api/queries/clubs.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Clubs Query Hooks\n *\n * TanStack Query hooks for club operations.\n */\n\nimport { useQuery, UseQueryOptions, UseQueryResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { Club, ApiResponse } from '../types';\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const clubKeys = {\n  all: ['clubs'] as const,\n  bySpot: (spotId: string) => [...clubKeys.all, 'spot', spotId] as const,\n  details: () => [...clubKeys.all, 'detail'] as const,\n  detail: (id: string) => [...clubKeys.details(), id] as const,\n  bySlug: (slug: string) => [...clubKeys.all, 'slug', slug] as const,\n  byUser: (userId: string) => [...clubKeys.all, 'user', userId] as const,\n  membership: (clubId: string, userId: string) => [...clubKeys.detail(clubId), 'membership', userId] as const,\n};\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get clubs for a spot\n *\n * @endpoint GET /api/v1/clubs/spot/{spotId}\n */\nexport function useClubsBySpot(\n  spotId: string,\n  options?: Omit<UseQueryOptions<Club[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Club[]> {\n  return useQuery({\n    queryKey: clubKeys.bySpot(spotId),\n    queryFn: async (): Promise<Club[]> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<Club[]>>(`/api/v1/clubs/spot/${spotId}`);\n      return response.data.data;\n    },\n    enabled: !!spotId,\n    ...options,\n  });\n}\n\n/**\n * Get a club by ID\n *\n * @endpoint GET /api/v1/clubs/{id}\n */\nexport function useClub(\n  clubId: string,\n  options?: Omit<UseQueryOptions<Club>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Club> {\n  return useQuery({\n    queryKey: clubKeys.detail(clubId),\n    queryFn: async (): Promise<Club> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<Club>>(`/api/v1/clubs/${clubId}`);\n      return response.data.data;\n    },\n    enabled: !!clubId,\n    ...options,\n  });\n}\n\n/**\n * Get a club by slug\n *\n * @endpoint GET /api/v1/clubs/slug/{slug}\n */\nexport function useClubBySlug(\n  slug: string,\n  options?: Omit<UseQueryOptions<Club>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Club> {\n  return useQuery({\n    queryKey: clubKeys.bySlug(slug),\n    queryFn: async (): Promise<Club> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<Club>>(`/api/v1/clubs/slug/${slug}`);\n      return response.data.data;\n    },\n    enabled: !!slug,\n    ...options,\n  });\n}\n\n/**\n * Get clubs for a user\n *\n * @endpoint GET /api/v1/clubs/user/{userId}\n */\nexport function useClubsByUser(\n  userId: string,\n  options?: Omit<UseQueryOptions<Club[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Club[]> {\n  return useQuery({\n    queryKey: clubKeys.byUser(userId),\n    queryFn: async (): Promise<Club[]> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<Club[]>>(`/api/v1/clubs/user/${userId}`);\n      return response.data.data;\n    },\n    enabled: !!userId,\n    ...options,\n  });\n}\n\n/**\n * Get membership status for a user in a club\n *\n * @endpoint GET /api/v1/clubs/{id}/membership/{userId}\n */\nexport function useClubMembership(\n  clubId: string,\n  userId: string,\n  options?: Omit<UseQueryOptions<{ isMember: boolean; role?: string }>, 'queryKey' | 'queryFn'>\n): UseQueryResult<{ isMember: boolean; role?: string }> {\n  return useQuery({\n    queryKey: clubKeys.membership(clubId, userId),\n    queryFn: async () => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<{ isMember: boolean; role?: string }>>(\n        `/api/v1/clubs/${clubId}/membership/${userId}`\n      );\n      return response.data.data;\n    },\n    enabled: !!clubId && !!userId,\n    ...options,\n  });\n}\n"]}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clubs.js","sourceRoot":"","sources":["../../../src/api/queries/clubs.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Clubs Query Hooks\n *\n * TanStack Query hooks for club operations.\n */\n\nimport {\n  useQuery,\n  type UseQueryOptions,\n  type UseQueryResult,\n} from '@tanstack/react-query'\n\nimport {getApiClient} from '../client'\nimport {type ApiResponse, type Club} from '../types'\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const clubKeys = {\n  all: ['clubs'] as const,\n  bySpot: (spotId: string) => [...clubKeys.all, 'spot', spotId] as const,\n  details: () => [...clubKeys.all, 'detail'] as const,\n  detail: (id: string) => [...clubKeys.details(), id] as const,\n  bySlug: (slug: string) => [...clubKeys.all, 'slug', slug] as const,\n  byUser: (userId: string) => [...clubKeys.all, 'user', userId] as const,\n  membership: (clubId: string, userId: string) =>\n    [...clubKeys.detail(clubId), 'membership', userId] as const,\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get clubs for a spot\n *\n * @endpoint GET /clubs/spot/{spotId}\n */\nexport function useClubsBySpot(\n  spotId: string,\n  options?: Omit<UseQueryOptions<Club[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Club[]> {\n  return useQuery({\n    queryKey: clubKeys.bySpot(spotId),\n    queryFn: async (): Promise<Club[]> => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<Club[]>>(\n        `/clubs/spot/${spotId}`,\n      )\n      return response.data.data\n    },\n    enabled: !!spotId,\n    ...options,\n  })\n}\n\n/**\n * Get a club by ID\n *\n * @endpoint GET /clubs/{id}\n */\nexport function useClub(\n  clubId: string,\n  options?: Omit<UseQueryOptions<Club>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Club> {\n  return useQuery({\n    queryKey: clubKeys.detail(clubId),\n    queryFn: async (): Promise<Club> => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<Club>>(`/clubs/${clubId}`)\n      return response.data.data\n    },\n    enabled: !!clubId,\n    ...options,\n  })\n}\n\n/**\n * Get a club by slug\n *\n * @endpoint GET /clubs/slug/{slug}\n */\nexport function useClubBySlug(\n  slug: string,\n  options?: Omit<UseQueryOptions<Club>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Club> {\n  return useQuery({\n    queryKey: clubKeys.bySlug(slug),\n    queryFn: async (): Promise<Club> => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<Club>>(\n        `/clubs/slug/${slug}`,\n      )\n      return response.data.data\n    },\n    enabled: !!slug,\n    ...options,\n  })\n}\n\n/**\n * Get clubs for a user\n *\n * @endpoint GET /clubs/user/{userId}\n */\nexport function useClubsByUser(\n  userId: string,\n  options?: Omit<UseQueryOptions<Club[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Club[]> {\n  return useQuery({\n    queryKey: clubKeys.byUser(userId),\n    queryFn: async (): Promise<Club[]> => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<Club[]>>(\n        `/clubs/user/${userId}`,\n      )\n      return response.data.data\n    },\n    enabled: !!userId,\n    ...options,\n  })\n}\n\n/**\n * Get membership status for a user in a club\n *\n * @endpoint GET /clubs/{id}/membership/{userId}\n */\nexport function useClubMembership(\n  clubId: string,\n  userId: string,\n  options?: Omit<\n    UseQueryOptions<{isMember: boolean; role?: string}>,\n    'queryKey' | 'queryFn'\n  >,\n): UseQueryResult<{isMember: boolean; role?: string}> {\n  return useQuery({\n    queryKey: clubKeys.membership(clubId, userId),\n    queryFn: async () => {\n      const client = getApiClient()\n      const response = await client.get<\n        ApiResponse<{isMember: boolean; role?: string}>\n      >(`/clubs/${clubId}/membership/${userId}`)\n      return response.data.data\n    },\n    enabled: !!clubId && !!userId,\n    ...options,\n  })\n}\n"]}
@@ -3,8 +3,8 @@
3
3
  *
4
4
  * TanStack Query hooks for conversation/messaging operations.
5
5
  */
6
- import { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
7
- import type { Conversation, Message } from '../types';
6
+ import { type UseQueryOptions, type UseQueryResult } from '@tanstack/react-query';
7
+ import { type Conversation, type Message } from '../types';
8
8
  export declare const conversationKeys: {
9
9
  all: readonly ["conversations"];
10
10
  lists: () => readonly ["conversations", "list"];
@@ -20,19 +20,19 @@ export declare const conversationKeys: {
20
20
  /**
21
21
  * Get all conversations for current user
22
22
  *
23
- * @endpoint GET /api/v1/conversations
23
+ * @endpoint GET /conversations
24
24
  */
25
25
  export declare function useConversations(options?: Omit<UseQueryOptions<Conversation[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Conversation[]>;
26
26
  /**
27
27
  * Get a single conversation with details
28
28
  *
29
- * @endpoint GET /api/v1/conversations/{id}
29
+ * @endpoint GET /conversations/{id}
30
30
  */
31
31
  export declare function useConversation(conversationId: string, options?: Omit<UseQueryOptions<Conversation>, 'queryKey' | 'queryFn'>): UseQueryResult<Conversation>;
32
32
  /**
33
33
  * Get messages for a conversation
34
34
  *
35
- * @endpoint GET /api/v1/conversations/{id}/messages
35
+ * @endpoint GET /conversations/{id}/messages
36
36
  */
37
37
  export declare function useConversationMessages(conversationId: string, params?: {
38
38
  limit?: number;
@@ -28,14 +28,14 @@ exports.conversationKeys = {
28
28
  /**
29
29
  * Get all conversations for current user
30
30
  *
31
- * @endpoint GET /api/v1/conversations
31
+ * @endpoint GET /conversations
32
32
  */
33
33
  function useConversations(options) {
34
34
  return (0, react_query_1.useQuery)({
35
35
  queryKey: exports.conversationKeys.list(),
36
36
  queryFn: async () => {
37
37
  const client = (0, client_1.getApiClient)();
38
- const response = await client.get('/api/v1/conversations');
38
+ const response = await client.get('/conversations');
39
39
  return response.data.data;
40
40
  },
41
41
  ...options,
@@ -44,14 +44,14 @@ function useConversations(options) {
44
44
  /**
45
45
  * Get a single conversation with details
46
46
  *
47
- * @endpoint GET /api/v1/conversations/{id}
47
+ * @endpoint GET /conversations/{id}
48
48
  */
49
49
  function useConversation(conversationId, options) {
50
50
  return (0, react_query_1.useQuery)({
51
51
  queryKey: exports.conversationKeys.detail(conversationId),
52
52
  queryFn: async () => {
53
53
  const client = (0, client_1.getApiClient)();
54
- const response = await client.get(`/api/v1/conversations/${conversationId}`);
54
+ const response = await client.get(`/conversations/${conversationId}`);
55
55
  return response.data.data;
56
56
  },
57
57
  enabled: !!conversationId,
@@ -61,7 +61,7 @@ function useConversation(conversationId, options) {
61
61
  /**
62
62
  * Get messages for a conversation
63
63
  *
64
- * @endpoint GET /api/v1/conversations/{id}/messages
64
+ * @endpoint GET /conversations/{id}/messages
65
65
  */
66
66
  function useConversationMessages(conversationId, params, options) {
67
67
  return (0, react_query_1.useQuery)({
@@ -73,11 +73,11 @@ function useConversationMessages(conversationId, params, options) {
73
73
  queryParams.set('limit', String(params.limit));
74
74
  if (params?.before)
75
75
  queryParams.set('before', params.before);
76
- const response = await client.get(`/api/v1/conversations/${conversationId}/messages?${queryParams}`);
76
+ const response = await client.get(`/conversations/${conversationId}/messages?${queryParams}`);
77
77
  return response.data;
78
78
  },
79
79
  enabled: !!conversationId,
80
80
  ...options,
81
81
  });
82
82
  }
83
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udmVyc2F0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvcXVlcmllcy9jb252ZXJzYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7OztHQUlHOzs7QUE2QkgsNENBWUM7QUFPRCwwQ0FjQztBQU9ELDBEQW9CQztBQXZGRCx1REFBa0Y7QUFDbEYsc0NBQXlDO0FBR3pDLCtFQUErRTtBQUMvRSxhQUFhO0FBQ2IsK0VBQStFO0FBRWxFLFFBQUEsZ0JBQWdCLEdBQUc7SUFDOUIsR0FBRyxFQUFFLENBQUMsZUFBZSxDQUFVO0lBQy9CLEtBQUssRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLEdBQUcsd0JBQWdCLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBVTtJQUN2RCxJQUFJLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxHQUFHLHdCQUFnQixDQUFDLEtBQUssRUFBRSxDQUFVO0lBQ2xELE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLEdBQUcsd0JBQWdCLENBQUMsR0FBRyxFQUFFLFFBQVEsQ0FBVTtJQUMzRCxNQUFNLEVBQUUsQ0FBQyxFQUFVLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyx3QkFBZ0IsQ0FBQyxPQUFPLEVBQUUsRUFBRSxFQUFFLENBQVU7SUFDcEUsUUFBUSxFQUFFLENBQUMsY0FBc0IsRUFBRSxNQUE0QixFQUFFLEVBQUUsQ0FDakUsQ0FBQyxHQUFHLHdCQUFnQixDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxDQUFVO0NBQzVFLENBQUM7QUFFRiwrRUFBK0U7QUFDL0UsY0FBYztBQUNkLCtFQUErRTtBQUUvRTs7OztHQUlHO0FBQ0gsU0FBZ0IsZ0JBQWdCLENBQzlCLE9BQXVFO0lBRXZFLE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLHdCQUFnQixDQUFDLElBQUksRUFBRTtRQUNqQyxPQUFPLEVBQUUsS0FBSyxJQUE2QixFQUFFO1lBQzNDLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFDO1lBQzlCLE1BQU0sUUFBUSxHQUFHLE1BQU0sTUFBTSxDQUFDLEdBQUcsQ0FBOEIsdUJBQXVCLENBQUMsQ0FBQztZQUN4RixPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQzVCLENBQUM7UUFDRCxHQUFHLE9BQU87S0FDWCxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLGVBQWUsQ0FDN0IsY0FBc0IsRUFDdEIsT0FBcUU7SUFFckUsT0FBTyxJQUFBLHNCQUFRLEVBQUM7UUFDZCxRQUFRLEVBQUUsd0JBQWdCLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQztRQUNqRCxPQUFPLEVBQUUsS0FBSyxJQUEyQixFQUFFO1lBQ3pDLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFDO1lBQzlCLE1BQU0sUUFBUSxHQUFHLE1BQU0sTUFBTSxDQUFDLEdBQUcsQ0FBNEIseUJBQXlCLGNBQWMsRUFBRSxDQUFDLENBQUM7WUFDeEcsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztRQUM1QixDQUFDO1FBQ0QsT0FBTyxFQUFFLENBQUMsQ0FBQyxjQUFjO1FBQ3pCLEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsdUJBQXVCLENBQ3JDLGNBQXNCLEVBQ3RCLE1BQTRDLEVBQzVDLE9BQXdJO0lBRXhJLE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLHdCQUFnQixDQUFDLFFBQVEsQ0FBQyxjQUFjLEVBQUUsTUFBTSxDQUFDO1FBQzNELE9BQU8sRUFBRSxLQUFLLElBQUksRUFBRTtZQUNsQixNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQztZQUM5QixNQUFNLFdBQVcsR0FBRyxJQUFJLGVBQWUsRUFBRSxDQUFDO1lBQzFDLElBQUksTUFBTSxFQUFFLEtBQUs7Z0JBQUUsV0FBVyxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1lBQ2xFLElBQUksTUFBTSxFQUFFLE1BQU07Z0JBQUUsV0FBVyxDQUFDLEdBQUcsQ0FBQyxRQUFRLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQzdELE1BQU0sUUFBUSxHQUFHLE1BQU0sTUFBTSxDQUFDLEdBQUcsQ0FDL0IseUJBQXlCLGNBQWMsYUFBYSxXQUFXLEVBQUUsQ0FDbEUsQ0FBQztZQUNGLE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQztRQUN2QixDQUFDO1FBQ0QsT0FBTyxFQUFFLENBQUMsQ0FBQyxjQUFjO1FBQ3pCLEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvbnZlcnNhdGlvbnMgUXVlcnkgSG9va3NcbiAqXG4gKiBUYW5TdGFjayBRdWVyeSBob29rcyBmb3IgY29udmVyc2F0aW9uL21lc3NhZ2luZyBvcGVyYXRpb25zLlxuICovXG5cbmltcG9ydCB7IHVzZVF1ZXJ5LCBVc2VRdWVyeU9wdGlvbnMsIFVzZVF1ZXJ5UmVzdWx0IH0gZnJvbSAnQHRhbnN0YWNrL3JlYWN0LXF1ZXJ5JztcbmltcG9ydCB7IGdldEFwaUNsaWVudCB9IGZyb20gJy4uL2NsaWVudCc7XG5pbXBvcnQgdHlwZSB7IENvbnZlcnNhdGlvbiwgTWVzc2FnZSwgQXBpUmVzcG9uc2UgfSBmcm9tICcuLi90eXBlcyc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFFVRVJZIEtFWVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGNvbnN0IGNvbnZlcnNhdGlvbktleXMgPSB7XG4gIGFsbDogWydjb252ZXJzYXRpb25zJ10gYXMgY29uc3QsXG4gIGxpc3RzOiAoKSA9PiBbLi4uY29udmVyc2F0aW9uS2V5cy5hbGwsICdsaXN0J10gYXMgY29uc3QsXG4gIGxpc3Q6ICgpID0+IFsuLi5jb252ZXJzYXRpb25LZXlzLmxpc3RzKCldIGFzIGNvbnN0LFxuICBkZXRhaWxzOiAoKSA9PiBbLi4uY29udmVyc2F0aW9uS2V5cy5hbGwsICdkZXRhaWwnXSBhcyBjb25zdCxcbiAgZGV0YWlsOiAoaWQ6IHN0cmluZykgPT4gWy4uLmNvbnZlcnNhdGlvbktleXMuZGV0YWlscygpLCBpZF0gYXMgY29uc3QsXG4gIG1lc3NhZ2VzOiAoY29udmVyc2F0aW9uSWQ6IHN0cmluZywgcGFyYW1zPzogeyBiZWZvcmU/OiBzdHJpbmcgfSkgPT5cbiAgICBbLi4uY29udmVyc2F0aW9uS2V5cy5kZXRhaWwoY29udmVyc2F0aW9uSWQpLCAnbWVzc2FnZXMnLCBwYXJhbXNdIGFzIGNvbnN0LFxufTtcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gUVVFUlkgSE9PS1Ncbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBHZXQgYWxsIGNvbnZlcnNhdGlvbnMgZm9yIGN1cnJlbnQgdXNlclxuICpcbiAqIEBlbmRwb2ludCBHRVQgL2FwaS92MS9jb252ZXJzYXRpb25zXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VDb252ZXJzYXRpb25zKFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8Q29udmVyc2F0aW9uW10+LCAncXVlcnlLZXknIHwgJ3F1ZXJ5Rm4nPlxuKTogVXNlUXVlcnlSZXN1bHQ8Q29udmVyc2F0aW9uW10+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogY29udmVyc2F0aW9uS2V5cy5saXN0KCksXG4gICAgcXVlcnlGbjogYXN5bmMgKCk6IFByb21pc2U8Q29udmVyc2F0aW9uW10+ID0+IHtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGdldEFwaUNsaWVudCgpO1xuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0PEFwaVJlc3BvbnNlPENvbnZlcnNhdGlvbltdPj4oJy9hcGkvdjEvY29udmVyc2F0aW9ucycpO1xuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGEuZGF0YTtcbiAgICB9LFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pO1xufVxuXG4vKipcbiAqIEdldCBhIHNpbmdsZSBjb252ZXJzYXRpb24gd2l0aCBkZXRhaWxzXG4gKlxuICogQGVuZHBvaW50IEdFVCAvYXBpL3YxL2NvbnZlcnNhdGlvbnMve2lkfVxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlQ29udmVyc2F0aW9uKFxuICBjb252ZXJzYXRpb25JZDogc3RyaW5nLFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8Q29udmVyc2F0aW9uPiwgJ3F1ZXJ5S2V5JyB8ICdxdWVyeUZuJz5cbik6IFVzZVF1ZXJ5UmVzdWx0PENvbnZlcnNhdGlvbj4ge1xuICByZXR1cm4gdXNlUXVlcnkoe1xuICAgIHF1ZXJ5S2V5OiBjb252ZXJzYXRpb25LZXlzLmRldGFpbChjb252ZXJzYXRpb25JZCksXG4gICAgcXVlcnlGbjogYXN5bmMgKCk6IFByb21pc2U8Q29udmVyc2F0aW9uPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldDxBcGlSZXNwb25zZTxDb252ZXJzYXRpb24+PihgL2FwaS92MS9jb252ZXJzYXRpb25zLyR7Y29udmVyc2F0aW9uSWR9YCk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhO1xuICAgIH0sXG4gICAgZW5hYmxlZDogISFjb252ZXJzYXRpb25JZCxcbiAgICAuLi5vcHRpb25zLFxuICB9KTtcbn1cblxuLyoqXG4gKiBHZXQgbWVzc2FnZXMgZm9yIGEgY29udmVyc2F0aW9uXG4gKlxuICogQGVuZHBvaW50IEdFVCAvYXBpL3YxL2NvbnZlcnNhdGlvbnMve2lkfS9tZXNzYWdlc1xuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlQ29udmVyc2F0aW9uTWVzc2FnZXMoXG4gIGNvbnZlcnNhdGlvbklkOiBzdHJpbmcsXG4gIHBhcmFtcz86IHsgbGltaXQ/OiBudW1iZXI7IGJlZm9yZT86IHN0cmluZyB9LFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8eyBkYXRhOiBNZXNzYWdlW107IG1ldGE6IHsgaGFzTW9yZTogYm9vbGVhbjsgb2xkZXN0TWVzc2FnZUF0OiBzdHJpbmcgfCBudWxsIH0gfT4sICdxdWVyeUtleScgfCAncXVlcnlGbic+XG4pOiBVc2VRdWVyeVJlc3VsdDx7IGRhdGE6IE1lc3NhZ2VbXTsgbWV0YTogeyBoYXNNb3JlOiBib29sZWFuOyBvbGRlc3RNZXNzYWdlQXQ6IHN0cmluZyB8IG51bGwgfSB9PiB7XG4gIHJldHVybiB1c2VRdWVyeSh7XG4gICAgcXVlcnlLZXk6IGNvbnZlcnNhdGlvbktleXMubWVzc2FnZXMoY29udmVyc2F0aW9uSWQsIHBhcmFtcyksXG4gICAgcXVlcnlGbjogYXN5bmMgKCkgPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KCk7XG4gICAgICBjb25zdCBxdWVyeVBhcmFtcyA9IG5ldyBVUkxTZWFyY2hQYXJhbXMoKTtcbiAgICAgIGlmIChwYXJhbXM/LmxpbWl0KSBxdWVyeVBhcmFtcy5zZXQoJ2xpbWl0JywgU3RyaW5nKHBhcmFtcy5saW1pdCkpO1xuICAgICAgaWYgKHBhcmFtcz8uYmVmb3JlKSBxdWVyeVBhcmFtcy5zZXQoJ2JlZm9yZScsIHBhcmFtcy5iZWZvcmUpO1xuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0PHsgZGF0YTogTWVzc2FnZVtdOyBtZXRhOiB7IGhhc01vcmU6IGJvb2xlYW47IG9sZGVzdE1lc3NhZ2VBdDogc3RyaW5nIHwgbnVsbCB9IH0+KFxuICAgICAgICBgL2FwaS92MS9jb252ZXJzYXRpb25zLyR7Y29udmVyc2F0aW9uSWR9L21lc3NhZ2VzPyR7cXVlcnlQYXJhbXN9YFxuICAgICAgKTtcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhO1xuICAgIH0sXG4gICAgZW5hYmxlZDogISFjb252ZXJzYXRpb25JZCxcbiAgICAuLi5vcHRpb25zLFxuICB9KTtcbn1cbiJdfQ==
83
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udmVyc2F0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvcXVlcmllcy9jb252ZXJzYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7OztHQUlHOzs7QUFrQ0gsNENBYUM7QUFPRCwwQ0FnQkM7QUFPRCwwREE4QkM7QUF6R0QsdURBSThCO0FBRTlCLHNDQUFzQztBQUd0QywrRUFBK0U7QUFDL0UsYUFBYTtBQUNiLCtFQUErRTtBQUVsRSxRQUFBLGdCQUFnQixHQUFHO0lBQzlCLEdBQUcsRUFBRSxDQUFDLGVBQWUsQ0FBVTtJQUMvQixLQUFLLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxHQUFHLHdCQUFnQixDQUFDLEdBQUcsRUFBRSxNQUFNLENBQVU7SUFDdkQsSUFBSSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsR0FBRyx3QkFBZ0IsQ0FBQyxLQUFLLEVBQUUsQ0FBVTtJQUNsRCxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxHQUFHLHdCQUFnQixDQUFDLEdBQUcsRUFBRSxRQUFRLENBQVU7SUFDM0QsTUFBTSxFQUFFLENBQUMsRUFBVSxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsd0JBQWdCLENBQUMsT0FBTyxFQUFFLEVBQUUsRUFBRSxDQUFVO0lBQ3BFLFFBQVEsRUFBRSxDQUFDLGNBQXNCLEVBQUUsTUFBMEIsRUFBRSxFQUFFLENBQy9ELENBQUMsR0FBRyx3QkFBZ0IsQ0FBQyxNQUFNLENBQUMsY0FBYyxDQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sQ0FBVTtDQUM1RSxDQUFBO0FBRUQsK0VBQStFO0FBQy9FLGNBQWM7QUFDZCwrRUFBK0U7QUFFL0U7Ozs7R0FJRztBQUNILFNBQWdCLGdCQUFnQixDQUM5QixPQUF1RTtJQUV2RSxPQUFPLElBQUEsc0JBQVEsRUFBQztRQUNkLFFBQVEsRUFBRSx3QkFBZ0IsQ0FBQyxJQUFJLEVBQUU7UUFDakMsT0FBTyxFQUFFLEtBQUssSUFBNkIsRUFBRTtZQUMzQyxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQTtZQUM3QixNQUFNLFFBQVEsR0FDWixNQUFNLE1BQU0sQ0FBQyxHQUFHLENBQThCLGdCQUFnQixDQUFDLENBQUE7WUFDakUsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQTtRQUMzQixDQUFDO1FBQ0QsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFBO0FBQ0osQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQixlQUFlLENBQzdCLGNBQXNCLEVBQ3RCLE9BQXFFO0lBRXJFLE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLHdCQUFnQixDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUM7UUFDakQsT0FBTyxFQUFFLEtBQUssSUFBMkIsRUFBRTtZQUN6QyxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQTtZQUM3QixNQUFNLFFBQVEsR0FBRyxNQUFNLE1BQU0sQ0FBQyxHQUFHLENBQy9CLGtCQUFrQixjQUFjLEVBQUUsQ0FDbkMsQ0FBQTtZQUNELE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUE7UUFDM0IsQ0FBQztRQUNELE9BQU8sRUFBRSxDQUFDLENBQUMsY0FBYztRQUN6QixHQUFHLE9BQU87S0FDWCxDQUFDLENBQUE7QUFDSixDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLHVCQUF1QixDQUNyQyxjQUFzQixFQUN0QixNQUEwQyxFQUMxQyxPQU1DO0lBS0QsT0FBTyxJQUFBLHNCQUFRLEVBQUM7UUFDZCxRQUFRLEVBQUUsd0JBQWdCLENBQUMsUUFBUSxDQUFDLGNBQWMsRUFBRSxNQUFNLENBQUM7UUFDM0QsT0FBTyxFQUFFLEtBQUssSUFBSSxFQUFFO1lBQ2xCLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFBO1lBQzdCLE1BQU0sV0FBVyxHQUFHLElBQUksZUFBZSxFQUFFLENBQUE7WUFDekMsSUFBSSxNQUFNLEVBQUUsS0FBSztnQkFBRSxXQUFXLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUE7WUFDakUsSUFBSSxNQUFNLEVBQUUsTUFBTTtnQkFBRSxXQUFXLENBQUMsR0FBRyxDQUFDLFFBQVEsRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUE7WUFDNUQsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUc5QixrQkFBa0IsY0FBYyxhQUFhLFdBQVcsRUFBRSxDQUFDLENBQUE7WUFDOUQsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFBO1FBQ3RCLENBQUM7UUFDRCxPQUFPLEVBQUUsQ0FBQyxDQUFDLGNBQWM7UUFDekIsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFBO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29udmVyc2F0aW9ucyBRdWVyeSBIb29rc1xuICpcbiAqIFRhblN0YWNrIFF1ZXJ5IGhvb2tzIGZvciBjb252ZXJzYXRpb24vbWVzc2FnaW5nIG9wZXJhdGlvbnMuXG4gKi9cblxuaW1wb3J0IHtcbiAgdXNlUXVlcnksXG4gIHR5cGUgVXNlUXVlcnlPcHRpb25zLFxuICB0eXBlIFVzZVF1ZXJ5UmVzdWx0LFxufSBmcm9tICdAdGFuc3RhY2svcmVhY3QtcXVlcnknXG5cbmltcG9ydCB7Z2V0QXBpQ2xpZW50fSBmcm9tICcuLi9jbGllbnQnXG5pbXBvcnQge3R5cGUgQXBpUmVzcG9uc2UsIHR5cGUgQ29udmVyc2F0aW9uLCB0eXBlIE1lc3NhZ2V9IGZyb20gJy4uL3R5cGVzJ1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBRVUVSWSBLRVlTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBjb25zdCBjb252ZXJzYXRpb25LZXlzID0ge1xuICBhbGw6IFsnY29udmVyc2F0aW9ucyddIGFzIGNvbnN0LFxuICBsaXN0czogKCkgPT4gWy4uLmNvbnZlcnNhdGlvbktleXMuYWxsLCAnbGlzdCddIGFzIGNvbnN0LFxuICBsaXN0OiAoKSA9PiBbLi4uY29udmVyc2F0aW9uS2V5cy5saXN0cygpXSBhcyBjb25zdCxcbiAgZGV0YWlsczogKCkgPT4gWy4uLmNvbnZlcnNhdGlvbktleXMuYWxsLCAnZGV0YWlsJ10gYXMgY29uc3QsXG4gIGRldGFpbDogKGlkOiBzdHJpbmcpID0+IFsuLi5jb252ZXJzYXRpb25LZXlzLmRldGFpbHMoKSwgaWRdIGFzIGNvbnN0LFxuICBtZXNzYWdlczogKGNvbnZlcnNhdGlvbklkOiBzdHJpbmcsIHBhcmFtcz86IHtiZWZvcmU/OiBzdHJpbmd9KSA9PlxuICAgIFsuLi5jb252ZXJzYXRpb25LZXlzLmRldGFpbChjb252ZXJzYXRpb25JZCksICdtZXNzYWdlcycsIHBhcmFtc10gYXMgY29uc3QsXG59XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFFVRVJZIEhPT0tTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogR2V0IGFsbCBjb252ZXJzYXRpb25zIGZvciBjdXJyZW50IHVzZXJcbiAqXG4gKiBAZW5kcG9pbnQgR0VUIC9jb252ZXJzYXRpb25zXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VDb252ZXJzYXRpb25zKFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8Q29udmVyc2F0aW9uW10+LCAncXVlcnlLZXknIHwgJ3F1ZXJ5Rm4nPixcbik6IFVzZVF1ZXJ5UmVzdWx0PENvbnZlcnNhdGlvbltdPiB7XG4gIHJldHVybiB1c2VRdWVyeSh7XG4gICAgcXVlcnlLZXk6IGNvbnZlcnNhdGlvbktleXMubGlzdCgpLFxuICAgIHF1ZXJ5Rm46IGFzeW5jICgpOiBQcm9taXNlPENvbnZlcnNhdGlvbltdPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKVxuICAgICAgY29uc3QgcmVzcG9uc2UgPVxuICAgICAgICBhd2FpdCBjbGllbnQuZ2V0PEFwaVJlc3BvbnNlPENvbnZlcnNhdGlvbltdPj4oJy9jb252ZXJzYXRpb25zJylcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhLmRhdGFcbiAgICB9LFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pXG59XG5cbi8qKlxuICogR2V0IGEgc2luZ2xlIGNvbnZlcnNhdGlvbiB3aXRoIGRldGFpbHNcbiAqXG4gKiBAZW5kcG9pbnQgR0VUIC9jb252ZXJzYXRpb25zL3tpZH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZUNvbnZlcnNhdGlvbihcbiAgY29udmVyc2F0aW9uSWQ6IHN0cmluZyxcbiAgb3B0aW9ucz86IE9taXQ8VXNlUXVlcnlPcHRpb25zPENvbnZlcnNhdGlvbj4sICdxdWVyeUtleScgfCAncXVlcnlGbic+LFxuKTogVXNlUXVlcnlSZXN1bHQ8Q29udmVyc2F0aW9uPiB7XG4gIHJldHVybiB1c2VRdWVyeSh7XG4gICAgcXVlcnlLZXk6IGNvbnZlcnNhdGlvbktleXMuZGV0YWlsKGNvbnZlcnNhdGlvbklkKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxDb252ZXJzYXRpb24+ID0+IHtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGdldEFwaUNsaWVudCgpXG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5nZXQ8QXBpUmVzcG9uc2U8Q29udmVyc2F0aW9uPj4oXG4gICAgICAgIGAvY29udmVyc2F0aW9ucy8ke2NvbnZlcnNhdGlvbklkfWAsXG4gICAgICApXG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhXG4gICAgfSxcbiAgICBlbmFibGVkOiAhIWNvbnZlcnNhdGlvbklkLFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pXG59XG5cbi8qKlxuICogR2V0IG1lc3NhZ2VzIGZvciBhIGNvbnZlcnNhdGlvblxuICpcbiAqIEBlbmRwb2ludCBHRVQgL2NvbnZlcnNhdGlvbnMve2lkfS9tZXNzYWdlc1xuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlQ29udmVyc2F0aW9uTWVzc2FnZXMoXG4gIGNvbnZlcnNhdGlvbklkOiBzdHJpbmcsXG4gIHBhcmFtcz86IHtsaW1pdD86IG51bWJlcjsgYmVmb3JlPzogc3RyaW5nfSxcbiAgb3B0aW9ucz86IE9taXQ8XG4gICAgVXNlUXVlcnlPcHRpb25zPHtcbiAgICAgIGRhdGE6IE1lc3NhZ2VbXVxuICAgICAgbWV0YToge2hhc01vcmU6IGJvb2xlYW47IG9sZGVzdE1lc3NhZ2VBdDogc3RyaW5nIHwgbnVsbH1cbiAgICB9PixcbiAgICAncXVlcnlLZXknIHwgJ3F1ZXJ5Rm4nXG4gID4sXG4pOiBVc2VRdWVyeVJlc3VsdDx7XG4gIGRhdGE6IE1lc3NhZ2VbXVxuICBtZXRhOiB7aGFzTW9yZTogYm9vbGVhbjsgb2xkZXN0TWVzc2FnZUF0OiBzdHJpbmcgfCBudWxsfVxufT4ge1xuICByZXR1cm4gdXNlUXVlcnkoe1xuICAgIHF1ZXJ5S2V5OiBjb252ZXJzYXRpb25LZXlzLm1lc3NhZ2VzKGNvbnZlcnNhdGlvbklkLCBwYXJhbXMpLFxuICAgIHF1ZXJ5Rm46IGFzeW5jICgpID0+IHtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGdldEFwaUNsaWVudCgpXG4gICAgICBjb25zdCBxdWVyeVBhcmFtcyA9IG5ldyBVUkxTZWFyY2hQYXJhbXMoKVxuICAgICAgaWYgKHBhcmFtcz8ubGltaXQpIHF1ZXJ5UGFyYW1zLnNldCgnbGltaXQnLCBTdHJpbmcocGFyYW1zLmxpbWl0KSlcbiAgICAgIGlmIChwYXJhbXM/LmJlZm9yZSkgcXVlcnlQYXJhbXMuc2V0KCdiZWZvcmUnLCBwYXJhbXMuYmVmb3JlKVxuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0PHtcbiAgICAgICAgZGF0YTogTWVzc2FnZVtdXG4gICAgICAgIG1ldGE6IHtoYXNNb3JlOiBib29sZWFuOyBvbGRlc3RNZXNzYWdlQXQ6IHN0cmluZyB8IG51bGx9XG4gICAgICB9PihgL2NvbnZlcnNhdGlvbnMvJHtjb252ZXJzYXRpb25JZH0vbWVzc2FnZXM/JHtxdWVyeVBhcmFtc31gKVxuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGFcbiAgICB9LFxuICAgIGVuYWJsZWQ6ICEhY29udmVyc2F0aW9uSWQsXG4gICAgLi4ub3B0aW9ucyxcbiAgfSlcbn1cbiJdfQ==
@@ -62,4 +62,4 @@ Object.defineProperty(exports, "productKeys", { enumerable: true, get: function
62
62
  __exportStar(require("./orders"), exports);
63
63
  var orders_1 = require("./orders");
64
64
  Object.defineProperty(exports, "orderKeys", { enumerable: true, get: function () { return orders_1.orderKeys; } });
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3F1ZXJpZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7O0dBSUc7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsNkRBQTZEO0FBQzdELHlDQUF1QjtBQUV2QixRQUFRO0FBQ1IsMENBQXdCO0FBQ3hCLGlDQUFtQztBQUExQixpR0FBQSxRQUFRLE9BQUE7QUFFakIsUUFBUTtBQUNSLDBDQUF3QjtBQUN4QixpQ0FBbUM7QUFBMUIsaUdBQUEsUUFBUSxPQUFBO0FBRWpCLFFBQVE7QUFDUiwwQ0FBd0I7QUFDeEIsaUNBQW1DO0FBQTFCLGlHQUFBLFFBQVEsT0FBQTtBQUVqQixnQkFBZ0I7QUFDaEIsa0RBQWdDO0FBQ2hDLGlEQUFtRDtBQUExQyxpSEFBQSxnQkFBZ0IsT0FBQTtBQUV6QixRQUFRO0FBQ1IsMENBQXdCO0FBQ3hCLGlDQUFtQztBQUExQixpR0FBQSxRQUFRLE9BQUE7QUFFakIsWUFBWTtBQUNaLDhDQUE0QjtBQUM1Qix5Q0FBMkM7QUFBbEMseUdBQUEsWUFBWSxPQUFBO0FBRXJCLGdCQUFnQjtBQUNoQixrREFBZ0M7QUFDaEMsaURBQW1EO0FBQTFDLGlIQUFBLGdCQUFnQixPQUFBO0FBRXpCLCtCQUErQjtBQUMvQix5Q0FBdUI7QUFDdkIsK0JBQWtDO0FBQXpCLGdHQUFBLFFBQVEsT0FBQTtBQUVqQix5QkFBeUI7QUFDekIsNkNBQTJCO0FBQzNCLHVDQUF5QztBQUFoQyx1R0FBQSxXQUFXLE9BQUE7QUFFcEIsdUJBQXVCO0FBQ3ZCLDJDQUF5QjtBQUN6QixtQ0FBcUM7QUFBNUIsbUdBQUEsU0FBUyxPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBTcG90cyBTREsgUXVlcnkgSG9va3MgSW5kZXhcbiAqXG4gKiBSZS1leHBvcnRzIGFsbCBxdWVyeSBob29rcyBhbmQga2V5cy5cbiAqL1xuXG4vLyBBdXRoIChtdXRhdGlvbnMsIGJ1dCBncm91cGVkIHdpdGggcXVlcmllcyBmb3IgY29udmVuaWVuY2UpXG5leHBvcnQgKiBmcm9tICcuL2F1dGgnO1xuXG4vLyBVc2Vyc1xuZXhwb3J0ICogZnJvbSAnLi91c2Vycyc7XG5leHBvcnQgeyB1c2VyS2V5cyB9IGZyb20gJy4vdXNlcnMnO1xuXG4vLyBTcG90c1xuZXhwb3J0ICogZnJvbSAnLi9zcG90cyc7XG5leHBvcnQgeyBzcG90S2V5cyB9IGZyb20gJy4vc3BvdHMnO1xuXG4vLyBQb3N0c1xuZXhwb3J0ICogZnJvbSAnLi9wb3N0cyc7XG5leHBvcnQgeyBwb3N0S2V5cyB9IGZyb20gJy4vcG9zdHMnO1xuXG4vLyBDb252ZXJzYXRpb25zXG5leHBvcnQgKiBmcm9tICcuL2NvbnZlcnNhdGlvbnMnO1xuZXhwb3J0IHsgY29udmVyc2F0aW9uS2V5cyB9IGZyb20gJy4vY29udmVyc2F0aW9ucyc7XG5cbi8vIENsdWJzXG5leHBvcnQgKiBmcm9tICcuL2NsdWJzJztcbmV4cG9ydCB7IGNsdWJLZXlzIH0gZnJvbSAnLi9jbHVicyc7XG5cbi8vIFRlbXBsYXRlc1xuZXhwb3J0ICogZnJvbSAnLi90ZW1wbGF0ZXMnO1xuZXhwb3J0IHsgdGVtcGxhdGVLZXlzIH0gZnJvbSAnLi90ZW1wbGF0ZXMnO1xuXG4vLyBOb3RpZmljYXRpb25zXG5leHBvcnQgKiBmcm9tICcuL25vdGlmaWNhdGlvbnMnO1xuZXhwb3J0IHsgbm90aWZpY2F0aW9uS2V5cyB9IGZyb20gJy4vbm90aWZpY2F0aW9ucyc7XG5cbi8vIE1pc2MgKGNpdGllcywgdmliZXMsIGV2ZW50cylcbmV4cG9ydCAqIGZyb20gJy4vbWlzYyc7XG5leHBvcnQgeyBtaXNjS2V5cyB9IGZyb20gJy4vbWlzYyc7XG5cbi8vIFByb2R1Y3RzIChtYXJrZXRwbGFjZSlcbmV4cG9ydCAqIGZyb20gJy4vcHJvZHVjdHMnO1xuZXhwb3J0IHsgcHJvZHVjdEtleXMgfSBmcm9tICcuL3Byb2R1Y3RzJztcblxuLy8gT3JkZXJzIChtYXJrZXRwbGFjZSlcbmV4cG9ydCAqIGZyb20gJy4vb3JkZXJzJztcbmV4cG9ydCB7IG9yZGVyS2V5cyB9IGZyb20gJy4vb3JkZXJzJztcbiJdfQ==
65
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3F1ZXJpZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7O0dBSUc7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUgsNkRBQTZEO0FBQzdELHlDQUFzQjtBQUV0QixRQUFRO0FBQ1IsMENBQXVCO0FBQ3ZCLGlDQUFnQztBQUF4QixpR0FBQSxRQUFRLE9BQUE7QUFFaEIsUUFBUTtBQUNSLDBDQUF1QjtBQUN2QixpQ0FBZ0M7QUFBeEIsaUdBQUEsUUFBUSxPQUFBO0FBRWhCLFFBQVE7QUFDUiwwQ0FBdUI7QUFDdkIsaUNBQWdDO0FBQXhCLGlHQUFBLFFBQVEsT0FBQTtBQUVoQixnQkFBZ0I7QUFDaEIsa0RBQStCO0FBQy9CLGlEQUFnRDtBQUF4QyxpSEFBQSxnQkFBZ0IsT0FBQTtBQUV4QixRQUFRO0FBQ1IsMENBQXVCO0FBQ3ZCLGlDQUFnQztBQUF4QixpR0FBQSxRQUFRLE9BQUE7QUFFaEIsWUFBWTtBQUNaLDhDQUEyQjtBQUMzQix5Q0FBd0M7QUFBaEMseUdBQUEsWUFBWSxPQUFBO0FBRXBCLGdCQUFnQjtBQUNoQixrREFBK0I7QUFDL0IsaURBQWdEO0FBQXhDLGlIQUFBLGdCQUFnQixPQUFBO0FBRXhCLCtCQUErQjtBQUMvQix5Q0FBc0I7QUFDdEIsK0JBQStCO0FBQXZCLGdHQUFBLFFBQVEsT0FBQTtBQUVoQix5QkFBeUI7QUFDekIsNkNBQTBCO0FBQzFCLHVDQUFzQztBQUE5Qix1R0FBQSxXQUFXLE9BQUE7QUFFbkIsdUJBQXVCO0FBQ3ZCLDJDQUF3QjtBQUN4QixtQ0FBa0M7QUFBMUIsbUdBQUEsU0FBUyxPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBTcG90cyBTREsgUXVlcnkgSG9va3MgSW5kZXhcbiAqXG4gKiBSZS1leHBvcnRzIGFsbCBxdWVyeSBob29rcyBhbmQga2V5cy5cbiAqL1xuXG4vLyBBdXRoIChtdXRhdGlvbnMsIGJ1dCBncm91cGVkIHdpdGggcXVlcmllcyBmb3IgY29udmVuaWVuY2UpXG5leHBvcnQgKiBmcm9tICcuL2F1dGgnXG5cbi8vIFVzZXJzXG5leHBvcnQgKiBmcm9tICcuL3VzZXJzJ1xuZXhwb3J0IHt1c2VyS2V5c30gZnJvbSAnLi91c2VycydcblxuLy8gU3BvdHNcbmV4cG9ydCAqIGZyb20gJy4vc3BvdHMnXG5leHBvcnQge3Nwb3RLZXlzfSBmcm9tICcuL3Nwb3RzJ1xuXG4vLyBQb3N0c1xuZXhwb3J0ICogZnJvbSAnLi9wb3N0cydcbmV4cG9ydCB7cG9zdEtleXN9IGZyb20gJy4vcG9zdHMnXG5cbi8vIENvbnZlcnNhdGlvbnNcbmV4cG9ydCAqIGZyb20gJy4vY29udmVyc2F0aW9ucydcbmV4cG9ydCB7Y29udmVyc2F0aW9uS2V5c30gZnJvbSAnLi9jb252ZXJzYXRpb25zJ1xuXG4vLyBDbHVic1xuZXhwb3J0ICogZnJvbSAnLi9jbHVicydcbmV4cG9ydCB7Y2x1YktleXN9IGZyb20gJy4vY2x1YnMnXG5cbi8vIFRlbXBsYXRlc1xuZXhwb3J0ICogZnJvbSAnLi90ZW1wbGF0ZXMnXG5leHBvcnQge3RlbXBsYXRlS2V5c30gZnJvbSAnLi90ZW1wbGF0ZXMnXG5cbi8vIE5vdGlmaWNhdGlvbnNcbmV4cG9ydCAqIGZyb20gJy4vbm90aWZpY2F0aW9ucydcbmV4cG9ydCB7bm90aWZpY2F0aW9uS2V5c30gZnJvbSAnLi9ub3RpZmljYXRpb25zJ1xuXG4vLyBNaXNjIChjaXRpZXMsIHZpYmVzLCBldmVudHMpXG5leHBvcnQgKiBmcm9tICcuL21pc2MnXG5leHBvcnQge21pc2NLZXlzfSBmcm9tICcuL21pc2MnXG5cbi8vIFByb2R1Y3RzIChtYXJrZXRwbGFjZSlcbmV4cG9ydCAqIGZyb20gJy4vcHJvZHVjdHMnXG5leHBvcnQge3Byb2R1Y3RLZXlzfSBmcm9tICcuL3Byb2R1Y3RzJ1xuXG4vLyBPcmRlcnMgKG1hcmtldHBsYWNlKVxuZXhwb3J0ICogZnJvbSAnLi9vcmRlcnMnXG5leHBvcnQge29yZGVyS2V5c30gZnJvbSAnLi9vcmRlcnMnXG4iXX0=
@@ -2,53 +2,29 @@
2
2
  * Misc Query Hooks
3
3
  *
4
4
  * TanStack Query hooks for cities, vibes, and other reference data.
5
- * All types come from @prisma/client (via ../types re-export).
6
- *
7
- * API Response Patterns:
8
- * - Reference data (vibes, templates, interests): { success, data: T[], timestamp }
9
- * - Large datasets (cities, spots, posts): { success, data: { data: T[], meta }, timestamp }
10
5
  */
11
- import { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
12
- import type { City, Vibe, LifeSituation, Interest, Intention } from '../types';
6
+ import { type UseQueryOptions, type UseQueryResult } from '@tanstack/react-query';
7
+ import { type City, type LifeSituation, type Vibe } from '../types';
13
8
  export declare const miscKeys: {
14
9
  cities: () => readonly ["cities"];
15
10
  vibes: () => readonly ["vibes"];
16
11
  lifeSituations: () => readonly ["life-situations"];
17
- interests: () => readonly ["interests"];
18
- intentions: () => readonly ["intentions"];
19
12
  };
20
13
  /**
21
- * Get all cities (paginated endpoint)
14
+ * Get all cities
22
15
  *
23
- * @endpoint GET /api/v1/cities
24
- * @returns PaginatedResponse with cities array
16
+ * @endpoint GET /cities
25
17
  */
26
18
  export declare function useCities(options?: Omit<UseQueryOptions<City[]>, 'queryKey' | 'queryFn'>): UseQueryResult<City[]>;
27
19
  /**
28
- * Get all vibes (flat array - reference data)
20
+ * Get all vibes
29
21
  *
30
- * @endpoint GET /api/v1/vibes
31
- * @returns Flat array of vibes (not paginated)
22
+ * @endpoint GET /vibes
32
23
  */
33
24
  export declare function useVibes(options?: Omit<UseQueryOptions<Vibe[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Vibe[]>;
34
25
  /**
35
- * Get all life situations (flat array - reference data for onboarding)
26
+ * Get all life situations (for onboarding)
36
27
  *
37
- * @endpoint GET /api/v1/life-situations
38
- * @returns Flat array of life situations (not paginated)
28
+ * @endpoint GET /life-situations
39
29
  */
40
30
  export declare function useLifeSituations(options?: Omit<UseQueryOptions<LifeSituation[]>, 'queryKey' | 'queryFn'>): UseQueryResult<LifeSituation[]>;
41
- /**
42
- * Get all interests (flat array - reference data)
43
- *
44
- * @endpoint GET /api/v1/interests
45
- * @returns Flat array of interests (not paginated)
46
- */
47
- export declare function useInterests(options?: Omit<UseQueryOptions<Interest[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Interest[]>;
48
- /**
49
- * Get all intentions (flat array - reference data)
50
- *
51
- * @endpoint GET /api/v1/intentions
52
- * @returns Flat array of intentions (not paginated)
53
- */
54
- export declare function useIntentions(options?: Omit<UseQueryOptions<Intention[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Intention[]>;
@@ -3,127 +3,89 @@
3
3
  * Misc Query Hooks
4
4
  *
5
5
  * TanStack Query hooks for cities, vibes, and other reference data.
6
- * All types come from @prisma/client (via ../types re-export).
7
- *
8
- * API Response Patterns:
9
- * - Reference data (vibes, templates, interests): { success, data: T[], timestamp }
10
- * - Large datasets (cities, spots, posts): { success, data: { data: T[], meta }, timestamp }
11
6
  */
12
7
  Object.defineProperty(exports, "__esModule", { value: true });
13
8
  exports.miscKeys = void 0;
14
9
  exports.useCities = useCities;
15
10
  exports.useVibes = useVibes;
16
11
  exports.useLifeSituations = useLifeSituations;
17
- exports.useInterests = useInterests;
18
- exports.useIntentions = useIntentions;
19
12
  const react_query_1 = require("@tanstack/react-query");
20
13
  const client_1 = require("../client");
21
14
  // ============================================================================
15
+ // HELPER FUNCTIONS
16
+ // ============================================================================
17
+ function extractArrayData(data) {
18
+ if (Array.isArray(data)) {
19
+ return data;
20
+ }
21
+ if (data && typeof data === 'object' && 'data' in data) {
22
+ const nested = data.data;
23
+ if (Array.isArray(nested)) {
24
+ return nested;
25
+ }
26
+ }
27
+ return [];
28
+ }
29
+ // ============================================================================
22
30
  // QUERY KEYS
23
31
  // ============================================================================
24
32
  exports.miscKeys = {
25
33
  cities: () => ['cities'],
26
34
  vibes: () => ['vibes'],
27
35
  lifeSituations: () => ['life-situations'],
28
- interests: () => ['interests'],
29
- intentions: () => ['intentions'],
30
36
  };
31
37
  // ============================================================================
32
38
  // QUERY HOOKS
33
39
  // ============================================================================
34
40
  /**
35
- * Get all cities (paginated endpoint)
41
+ * Get all cities
36
42
  *
37
- * @endpoint GET /api/v1/cities
38
- * @returns PaginatedResponse with cities array
43
+ * @endpoint GET /cities
39
44
  */
40
45
  function useCities(options) {
41
46
  return (0, react_query_1.useQuery)({
42
47
  queryKey: exports.miscKeys.cities(),
43
48
  queryFn: async () => {
44
49
  const client = (0, client_1.getApiClient)();
45
- const response = await client.get('/api/v1/cities');
46
- // Cities endpoint returns paginated format: { data: { data: [], meta: {} } }
47
- return response.data.data.data;
50
+ const response = await client.get('/cities');
51
+ return extractArrayData(response.data.data);
48
52
  },
49
53
  staleTime: 1000 * 60 * 60,
50
54
  ...options,
51
55
  });
52
56
  }
53
57
  /**
54
- * Get all vibes (flat array - reference data)
58
+ * Get all vibes
55
59
  *
56
- * @endpoint GET /api/v1/vibes
57
- * @returns Flat array of vibes (not paginated)
60
+ * @endpoint GET /vibes
58
61
  */
59
62
  function useVibes(options) {
60
63
  return (0, react_query_1.useQuery)({
61
64
  queryKey: exports.miscKeys.vibes(),
62
65
  queryFn: async () => {
63
66
  const client = (0, client_1.getApiClient)();
64
- const response = await client.get('/api/v1/vibes');
65
- // Vibes endpoint returns flat array: { data: [] }
66
- return response.data.data;
67
+ const response = await client.get('/vibes');
68
+ return extractArrayData(response.data.data);
67
69
  },
68
70
  staleTime: 1000 * 60 * 60,
69
71
  ...options,
70
72
  });
71
73
  }
72
74
  /**
73
- * Get all life situations (flat array - reference data for onboarding)
75
+ * Get all life situations (for onboarding)
74
76
  *
75
- * @endpoint GET /api/v1/life-situations
76
- * @returns Flat array of life situations (not paginated)
77
+ * @endpoint GET /life-situations
77
78
  */
78
79
  function useLifeSituations(options) {
79
80
  return (0, react_query_1.useQuery)({
80
81
  queryKey: exports.miscKeys.lifeSituations(),
81
82
  queryFn: async () => {
82
83
  const client = (0, client_1.getApiClient)();
83
- const response = await client.get('/api/v1/life-situations');
84
- // Life situations endpoint returns flat array: { data: [] }
85
- return response.data.data;
86
- },
87
- staleTime: 1000 * 60 * 60,
88
- ...options,
89
- });
90
- }
91
- /**
92
- * Get all interests (flat array - reference data)
93
- *
94
- * @endpoint GET /api/v1/interests
95
- * @returns Flat array of interests (not paginated)
96
- */
97
- function useInterests(options) {
98
- return (0, react_query_1.useQuery)({
99
- queryKey: exports.miscKeys.interests(),
100
- queryFn: async () => {
101
- const client = (0, client_1.getApiClient)();
102
- const response = await client.get('/api/v1/interests');
103
- // Interests endpoint returns flat array: { data: [] }
104
- return response.data.data;
105
- },
106
- staleTime: 1000 * 60 * 60,
107
- ...options,
108
- });
109
- }
110
- /**
111
- * Get all intentions (flat array - reference data)
112
- *
113
- * @endpoint GET /api/v1/intentions
114
- * @returns Flat array of intentions (not paginated)
115
- */
116
- function useIntentions(options) {
117
- return (0, react_query_1.useQuery)({
118
- queryKey: exports.miscKeys.intentions(),
119
- queryFn: async () => {
120
- const client = (0, client_1.getApiClient)();
121
- const response = await client.get('/api/v1/intentions');
122
- // Intentions endpoint returns flat array: { data: [] }
123
- return response.data.data;
84
+ const response = await client.get('/life-situations');
85
+ return extractArrayData(response.data.data);
124
86
  },
125
87
  staleTime: 1000 * 60 * 60,
126
88
  ...options,
127
89
  });
128
90
  }
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"misc.js","sourceRoot":"","sources":["../../../src/api/queries/misc.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG;;;AA4BH,8BAcC;AAQD,4BAcC;AAQD,8CAcC;AAQD,oCAcC;AAQD,sCAcC;AAhID,uDAAkF;AAClF,sCAAyC;AAGzC,+EAA+E;AAC/E,aAAa;AACb,+EAA+E;AAElE,QAAA,QAAQ,GAAG;IACtB,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC,QAAQ,CAAU;IACjC,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,OAAO,CAAU;IAC/B,cAAc,EAAE,GAAG,EAAE,CAAC,CAAC,iBAAiB,CAAU;IAClD,SAAS,EAAE,GAAG,EAAE,CAAC,CAAC,WAAW,CAAU;IACvC,UAAU,EAAE,GAAG,EAAE,CAAC,CAAC,YAAY,CAAU;CAC1C,CAAC;AAEF,+EAA+E;AAC/E,cAAc;AACd,+EAA+E;AAE/E;;;;;GAKG;AACH,SAAgB,SAAS,CACvB,OAA+D;IAE/D,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,gBAAQ,CAAC,MAAM,EAAE;QAC3B,OAAO,EAAE,KAAK,IAAqB,EAAE;YACnC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAuC,gBAAgB,CAAC,CAAC;YAC1F,6EAA6E;YAC7E,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;QACjC,CAAC;QACD,SAAS,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE;QACzB,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;;GAKG;AACH,SAAgB,QAAQ,CACtB,OAA+D;IAE/D,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,gBAAQ,CAAC,KAAK,EAAE;QAC1B,OAAO,EAAE,KAAK,IAAqB,EAAE;YACnC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAsB,eAAe,CAAC,CAAC;YACxE,kDAAkD;YAClD,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC;QAC5B,CAAC;QACD,SAAS,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE;QACzB,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;;GAKG;AACH,SAAgB,iBAAiB,CAC/B,OAAwE;IAExE,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,gBAAQ,CAAC,cAAc,EAAE;QACnC,OAAO,EAAE,KAAK,IAA8B,EAAE;YAC5C,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAA+B,yBAAyB,CAAC,CAAC;YAC3F,4DAA4D;YAC5D,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC;QAC5B,CAAC;QACD,SAAS,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE;QACzB,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;;GAKG;AACH,SAAgB,YAAY,CAC1B,OAAmE;IAEnE,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,gBAAQ,CAAC,SAAS,EAAE;QAC9B,OAAO,EAAE,KAAK,IAAyB,EAAE;YACvC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAA0B,mBAAmB,CAAC,CAAC;YAChF,sDAAsD;YACtD,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC;QAC5B,CAAC;QACD,SAAS,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE;QACzB,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;;GAKG;AACH,SAAgB,aAAa,CAC3B,OAAoE;IAEpE,OAAO,IAAA,sBAAQ,EAAC;QACd,QAAQ,EAAE,gBAAQ,CAAC,UAAU,EAAE;QAC/B,OAAO,EAAE,KAAK,IAA0B,EAAE;YACxC,MAAM,MAAM,GAAG,IAAA,qBAAY,GAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAA2B,oBAAoB,CAAC,CAAC;YAClF,uDAAuD;YACvD,OAAO,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC;QAC5B,CAAC;QACD,SAAS,EAAE,IAAI,GAAG,EAAE,GAAG,EAAE;QACzB,GAAG,OAAO;KACX,CAAC,CAAC;AACL,CAAC","sourcesContent":["/**\n * Misc Query Hooks\n *\n * TanStack Query hooks for cities, vibes, and other reference data.\n * All types come from @prisma/client (via ../types re-export).\n *\n * API Response Patterns:\n * - Reference data (vibes, templates, interests): { success, data: T[], timestamp }\n * - Large datasets (cities, spots, posts): { success, data: { data: T[], meta }, timestamp }\n */\n\nimport { useQuery, UseQueryOptions, UseQueryResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { City, Vibe, LifeSituation, Interest, Intention, ApiResponse, PaginatedResponse } from '../types';\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const miscKeys = {\n  cities: () => ['cities'] as const,\n  vibes: () => ['vibes'] as const,\n  lifeSituations: () => ['life-situations'] as const,\n  interests: () => ['interests'] as const,\n  intentions: () => ['intentions'] as const,\n};\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get all cities (paginated endpoint)\n *\n * @endpoint GET /api/v1/cities\n * @returns PaginatedResponse with cities array\n */\nexport function useCities(\n  options?: Omit<UseQueryOptions<City[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<City[]> {\n  return useQuery({\n    queryKey: miscKeys.cities(),\n    queryFn: async (): Promise<City[]> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<PaginatedResponse<City>>>('/api/v1/cities');\n      // Cities endpoint returns paginated format: { data: { data: [], meta: {} } }\n      return response.data.data.data;\n    },\n    staleTime: 1000 * 60 * 60,\n    ...options,\n  });\n}\n\n/**\n * Get all vibes (flat array - reference data)\n *\n * @endpoint GET /api/v1/vibes\n * @returns Flat array of vibes (not paginated)\n */\nexport function useVibes(\n  options?: Omit<UseQueryOptions<Vibe[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Vibe[]> {\n  return useQuery({\n    queryKey: miscKeys.vibes(),\n    queryFn: async (): Promise<Vibe[]> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<Vibe[]>>('/api/v1/vibes');\n      // Vibes endpoint returns flat array: { data: [] }\n      return response.data.data;\n    },\n    staleTime: 1000 * 60 * 60,\n    ...options,\n  });\n}\n\n/**\n * Get all life situations (flat array - reference data for onboarding)\n *\n * @endpoint GET /api/v1/life-situations\n * @returns Flat array of life situations (not paginated)\n */\nexport function useLifeSituations(\n  options?: Omit<UseQueryOptions<LifeSituation[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<LifeSituation[]> {\n  return useQuery({\n    queryKey: miscKeys.lifeSituations(),\n    queryFn: async (): Promise<LifeSituation[]> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<LifeSituation[]>>('/api/v1/life-situations');\n      // Life situations endpoint returns flat array: { data: [] }\n      return response.data.data;\n    },\n    staleTime: 1000 * 60 * 60,\n    ...options,\n  });\n}\n\n/**\n * Get all interests (flat array - reference data)\n *\n * @endpoint GET /api/v1/interests\n * @returns Flat array of interests (not paginated)\n */\nexport function useInterests(\n  options?: Omit<UseQueryOptions<Interest[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Interest[]> {\n  return useQuery({\n    queryKey: miscKeys.interests(),\n    queryFn: async (): Promise<Interest[]> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<Interest[]>>('/api/v1/interests');\n      // Interests endpoint returns flat array: { data: [] }\n      return response.data.data;\n    },\n    staleTime: 1000 * 60 * 60,\n    ...options,\n  });\n}\n\n/**\n * Get all intentions (flat array - reference data)\n *\n * @endpoint GET /api/v1/intentions\n * @returns Flat array of intentions (not paginated)\n */\nexport function useIntentions(\n  options?: Omit<UseQueryOptions<Intention[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Intention[]> {\n  return useQuery({\n    queryKey: miscKeys.intentions(),\n    queryFn: async (): Promise<Intention[]> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<Intention[]>>('/api/v1/intentions');\n      // Intentions endpoint returns flat array: { data: [] }\n      return response.data.data;\n    },\n    staleTime: 1000 * 60 * 60,\n    ...options,\n  });\n}\n"]}
91
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlzYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvcXVlcmllcy9taXNjLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7OztHQUlHOzs7QUFvREgsOEJBYUM7QUFPRCw0QkFhQztBQU9ELDhDQWNDO0FBeEdELHVEQUk4QjtBQUU5QixzQ0FBc0M7QUFRdEMsK0VBQStFO0FBQy9FLG1CQUFtQjtBQUNuQiwrRUFBK0U7QUFFL0UsU0FBUyxnQkFBZ0IsQ0FBSSxJQUFhO0lBQ3hDLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO1FBQ3hCLE9BQU8sSUFBSSxDQUFBO0lBQ2IsQ0FBQztJQUNELElBQUksSUFBSSxJQUFJLE9BQU8sSUFBSSxLQUFLLFFBQVEsSUFBSSxNQUFNLElBQUksSUFBSSxFQUFFLENBQUM7UUFDdkQsTUFBTSxNQUFNLEdBQUksSUFBd0IsQ0FBQyxJQUFJLENBQUE7UUFDN0MsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7WUFDMUIsT0FBTyxNQUFNLENBQUE7UUFDZixDQUFDO0lBQ0gsQ0FBQztJQUNELE9BQU8sRUFBRSxDQUFBO0FBQ1gsQ0FBQztBQUVELCtFQUErRTtBQUMvRSxhQUFhO0FBQ2IsK0VBQStFO0FBRWxFLFFBQUEsUUFBUSxHQUFHO0lBQ3RCLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLFFBQVEsQ0FBVTtJQUNqQyxLQUFLLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQVU7SUFDL0IsY0FBYyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsaUJBQWlCLENBQVU7Q0FDbkQsQ0FBQTtBQUVELCtFQUErRTtBQUMvRSxjQUFjO0FBQ2QsK0VBQStFO0FBRS9FOzs7O0dBSUc7QUFDSCxTQUFnQixTQUFTLENBQ3ZCLE9BQStEO0lBRS9ELE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLGdCQUFRLENBQUMsTUFBTSxFQUFFO1FBQzNCLE9BQU8sRUFBRSxLQUFLLElBQXFCLEVBQUU7WUFDbkMsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUE7WUFDN0IsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUF1QixTQUFTLENBQUMsQ0FBQTtZQUNsRSxPQUFPLGdCQUFnQixDQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDbkQsQ0FBQztRQUNELFNBQVMsRUFBRSxJQUFJLEdBQUcsRUFBRSxHQUFHLEVBQUU7UUFDekIsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFBO0FBQ0osQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQixRQUFRLENBQ3RCLE9BQStEO0lBRS9ELE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLGdCQUFRLENBQUMsS0FBSyxFQUFFO1FBQzFCLE9BQU8sRUFBRSxLQUFLLElBQXFCLEVBQUU7WUFDbkMsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUE7WUFDN0IsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUF1QixRQUFRLENBQUMsQ0FBQTtZQUNqRSxPQUFPLGdCQUFnQixDQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDbkQsQ0FBQztRQUNELFNBQVMsRUFBRSxJQUFJLEdBQUcsRUFBRSxHQUFHLEVBQUU7UUFDekIsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFBO0FBQ0osQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQixpQkFBaUIsQ0FDL0IsT0FBd0U7SUFFeEUsT0FBTyxJQUFBLHNCQUFRLEVBQUM7UUFDZCxRQUFRLEVBQUUsZ0JBQVEsQ0FBQyxjQUFjLEVBQUU7UUFDbkMsT0FBTyxFQUFFLEtBQUssSUFBOEIsRUFBRTtZQUM1QyxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQTtZQUM3QixNQUFNLFFBQVEsR0FDWixNQUFNLE1BQU0sQ0FBQyxHQUFHLENBQXVCLGtCQUFrQixDQUFDLENBQUE7WUFDNUQsT0FBTyxnQkFBZ0IsQ0FBZ0IsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQTtRQUM1RCxDQUFDO1FBQ0QsU0FBUyxFQUFFLElBQUksR0FBRyxFQUFFLEdBQUcsRUFBRTtRQUN6QixHQUFHLE9BQU87S0FDWCxDQUFDLENBQUE7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBNaXNjIFF1ZXJ5IEhvb2tzXG4gKlxuICogVGFuU3RhY2sgUXVlcnkgaG9va3MgZm9yIGNpdGllcywgdmliZXMsIGFuZCBvdGhlciByZWZlcmVuY2UgZGF0YS5cbiAqL1xuXG5pbXBvcnQge1xuICB1c2VRdWVyeSxcbiAgdHlwZSBVc2VRdWVyeU9wdGlvbnMsXG4gIHR5cGUgVXNlUXVlcnlSZXN1bHQsXG59IGZyb20gJ0B0YW5zdGFjay9yZWFjdC1xdWVyeSdcblxuaW1wb3J0IHtnZXRBcGlDbGllbnR9IGZyb20gJy4uL2NsaWVudCdcbmltcG9ydCB7XG4gIHR5cGUgQXBpUmVzcG9uc2UsXG4gIHR5cGUgQ2l0eSxcbiAgdHlwZSBMaWZlU2l0dWF0aW9uLFxuICB0eXBlIFZpYmUsXG59IGZyb20gJy4uL3R5cGVzJ1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBIRUxQRVIgRlVOQ1RJT05TXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmZ1bmN0aW9uIGV4dHJhY3RBcnJheURhdGE8VD4oZGF0YTogdW5rbm93bik6IFRbXSB7XG4gIGlmIChBcnJheS5pc0FycmF5KGRhdGEpKSB7XG4gICAgcmV0dXJuIGRhdGFcbiAgfVxuICBpZiAoZGF0YSAmJiB0eXBlb2YgZGF0YSA9PT0gJ29iamVjdCcgJiYgJ2RhdGEnIGluIGRhdGEpIHtcbiAgICBjb25zdCBuZXN0ZWQgPSAoZGF0YSBhcyB7ZGF0YTogdW5rbm93bn0pLmRhdGFcbiAgICBpZiAoQXJyYXkuaXNBcnJheShuZXN0ZWQpKSB7XG4gICAgICByZXR1cm4gbmVzdGVkXG4gICAgfVxuICB9XG4gIHJldHVybiBbXVxufVxuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBRVUVSWSBLRVlTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBjb25zdCBtaXNjS2V5cyA9IHtcbiAgY2l0aWVzOiAoKSA9PiBbJ2NpdGllcyddIGFzIGNvbnN0LFxuICB2aWJlczogKCkgPT4gWyd2aWJlcyddIGFzIGNvbnN0LFxuICBsaWZlU2l0dWF0aW9uczogKCkgPT4gWydsaWZlLXNpdHVhdGlvbnMnXSBhcyBjb25zdCxcbn1cblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gUVVFUlkgSE9PS1Ncbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBHZXQgYWxsIGNpdGllc1xuICpcbiAqIEBlbmRwb2ludCBHRVQgL2NpdGllc1xuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlQ2l0aWVzKFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8Q2l0eVtdPiwgJ3F1ZXJ5S2V5JyB8ICdxdWVyeUZuJz4sXG4pOiBVc2VRdWVyeVJlc3VsdDxDaXR5W10+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogbWlzY0tleXMuY2l0aWVzKCksXG4gICAgcXVlcnlGbjogYXN5bmMgKCk6IFByb21pc2U8Q2l0eVtdPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKVxuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0PEFwaVJlc3BvbnNlPHVua25vd24+PignL2NpdGllcycpXG4gICAgICByZXR1cm4gZXh0cmFjdEFycmF5RGF0YTxDaXR5PihyZXNwb25zZS5kYXRhLmRhdGEpXG4gICAgfSxcbiAgICBzdGFsZVRpbWU6IDEwMDAgKiA2MCAqIDYwLFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pXG59XG5cbi8qKlxuICogR2V0IGFsbCB2aWJlc1xuICpcbiAqIEBlbmRwb2ludCBHRVQgL3ZpYmVzXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VWaWJlcyhcbiAgb3B0aW9ucz86IE9taXQ8VXNlUXVlcnlPcHRpb25zPFZpYmVbXT4sICdxdWVyeUtleScgfCAncXVlcnlGbic+LFxuKTogVXNlUXVlcnlSZXN1bHQ8VmliZVtdPiB7XG4gIHJldHVybiB1c2VRdWVyeSh7XG4gICAgcXVlcnlLZXk6IG1pc2NLZXlzLnZpYmVzKCksXG4gICAgcXVlcnlGbjogYXN5bmMgKCk6IFByb21pc2U8VmliZVtdPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKVxuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0PEFwaVJlc3BvbnNlPHVua25vd24+PignL3ZpYmVzJylcbiAgICAgIHJldHVybiBleHRyYWN0QXJyYXlEYXRhPFZpYmU+KHJlc3BvbnNlLmRhdGEuZGF0YSlcbiAgICB9LFxuICAgIHN0YWxlVGltZTogMTAwMCAqIDYwICogNjAsXG4gICAgLi4ub3B0aW9ucyxcbiAgfSlcbn1cblxuLyoqXG4gKiBHZXQgYWxsIGxpZmUgc2l0dWF0aW9ucyAoZm9yIG9uYm9hcmRpbmcpXG4gKlxuICogQGVuZHBvaW50IEdFVCAvbGlmZS1zaXR1YXRpb25zXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VMaWZlU2l0dWF0aW9ucyhcbiAgb3B0aW9ucz86IE9taXQ8VXNlUXVlcnlPcHRpb25zPExpZmVTaXR1YXRpb25bXT4sICdxdWVyeUtleScgfCAncXVlcnlGbic+LFxuKTogVXNlUXVlcnlSZXN1bHQ8TGlmZVNpdHVhdGlvbltdPiB7XG4gIHJldHVybiB1c2VRdWVyeSh7XG4gICAgcXVlcnlLZXk6IG1pc2NLZXlzLmxpZmVTaXR1YXRpb25zKCksXG4gICAgcXVlcnlGbjogYXN5bmMgKCk6IFByb21pc2U8TGlmZVNpdHVhdGlvbltdPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKVxuICAgICAgY29uc3QgcmVzcG9uc2UgPVxuICAgICAgICBhd2FpdCBjbGllbnQuZ2V0PEFwaVJlc3BvbnNlPHVua25vd24+PignL2xpZmUtc2l0dWF0aW9ucycpXG4gICAgICByZXR1cm4gZXh0cmFjdEFycmF5RGF0YTxMaWZlU2l0dWF0aW9uPihyZXNwb25zZS5kYXRhLmRhdGEpXG4gICAgfSxcbiAgICBzdGFsZVRpbWU6IDEwMDAgKiA2MCAqIDYwLFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pXG59XG4iXX0=
@@ -3,8 +3,8 @@
3
3
  *
4
4
  * TanStack Query hooks for notification operations.
5
5
  */
6
- import { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
7
- import type { Notification } from '../types';
6
+ import { type UseQueryOptions, type UseQueryResult } from '@tanstack/react-query';
7
+ import { type Notification } from '../types';
8
8
  export declare const notificationKeys: {
9
9
  all: readonly ["notifications"];
10
10
  lists: () => readonly ["notifications", "list"];
@@ -20,7 +20,7 @@ export declare const notificationKeys: {
20
20
  /**
21
21
  * Get notifications for current user
22
22
  *
23
- * @endpoint GET /api/v1/notifications
23
+ * @endpoint GET /notifications
24
24
  */
25
25
  export declare function useNotifications(params?: {
26
26
  limit?: number;
@@ -29,6 +29,6 @@ export declare function useNotifications(params?: {
29
29
  /**
30
30
  * Get unread notification count
31
31
  *
32
- * @endpoint GET /api/v1/notifications/unread-count
32
+ * @endpoint GET /notifications/unread-count
33
33
  */
34
34
  export declare function useUnreadNotificationCount(options?: Omit<UseQueryOptions<number>, 'queryKey' | 'queryFn'>): UseQueryResult<number>;
@@ -25,7 +25,7 @@ exports.notificationKeys = {
25
25
  /**
26
26
  * Get notifications for current user
27
27
  *
28
- * @endpoint GET /api/v1/notifications
28
+ * @endpoint GET /notifications
29
29
  */
30
30
  function useNotifications(params, options) {
31
31
  return (0, react_query_1.useQuery)({
@@ -37,7 +37,7 @@ function useNotifications(params, options) {
37
37
  queryParams.set('limit', String(params.limit));
38
38
  if (params?.unreadOnly)
39
39
  queryParams.set('unreadOnly', String(params.unreadOnly));
40
- const response = await client.get(`/api/v1/notifications?${queryParams}`);
40
+ const response = await client.get(`/notifications?${queryParams}`);
41
41
  return response.data.data;
42
42
  },
43
43
  ...options,
@@ -46,17 +46,17 @@ function useNotifications(params, options) {
46
46
  /**
47
47
  * Get unread notification count
48
48
  *
49
- * @endpoint GET /api/v1/notifications/unread-count
49
+ * @endpoint GET /notifications/unread-count
50
50
  */
51
51
  function useUnreadNotificationCount(options) {
52
52
  return (0, react_query_1.useQuery)({
53
53
  queryKey: exports.notificationKeys.unreadCount(),
54
54
  queryFn: async () => {
55
55
  const client = (0, client_1.getApiClient)();
56
- const response = await client.get('/api/v1/notifications/unread-count');
56
+ const response = await client.get('/notifications/unread-count');
57
57
  return response.data.data.count;
58
58
  },
59
59
  ...options,
60
60
  });
61
61
  }
62
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvcXVlcmllcy9ub3RpZmljYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7OztHQUlHOzs7QUEwQkgsNENBZ0JDO0FBT0QsZ0VBWUM7QUEzREQsdURBQWtGO0FBQ2xGLHNDQUF5QztBQUd6QywrRUFBK0U7QUFDL0UsYUFBYTtBQUNiLCtFQUErRTtBQUVsRSxRQUFBLGdCQUFnQixHQUFHO0lBQzlCLEdBQUcsRUFBRSxDQUFDLGVBQWUsQ0FBVTtJQUMvQixLQUFLLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxHQUFHLHdCQUFnQixDQUFDLEdBQUcsRUFBRSxNQUFNLENBQVU7SUFDdkQsSUFBSSxFQUFFLENBQUMsTUFBaUQsRUFBRSxFQUFFLENBQUMsQ0FBQyxHQUFHLHdCQUFnQixDQUFDLEtBQUssRUFBRSxFQUFFLE1BQU0sQ0FBVTtJQUMzRyxXQUFXLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxHQUFHLHdCQUFnQixDQUFDLEdBQUcsRUFBRSxhQUFhLENBQVU7Q0FDckUsQ0FBQztBQUVGLCtFQUErRTtBQUMvRSxjQUFjO0FBQ2QsK0VBQStFO0FBRS9FOzs7O0dBSUc7QUFDSCxTQUFnQixnQkFBZ0IsQ0FDOUIsTUFBaUQsRUFDakQsT0FBdUU7SUFFdkUsT0FBTyxJQUFBLHNCQUFRLEVBQUM7UUFDZCxRQUFRLEVBQUUsd0JBQWdCLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUN2QyxPQUFPLEVBQUUsS0FBSyxJQUE2QixFQUFFO1lBQzNDLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFDO1lBQzlCLE1BQU0sV0FBVyxHQUFHLElBQUksZUFBZSxFQUFFLENBQUM7WUFDMUMsSUFBSSxNQUFNLEVBQUUsS0FBSztnQkFBRSxXQUFXLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFDbEUsSUFBSSxNQUFNLEVBQUUsVUFBVTtnQkFBRSxXQUFXLENBQUMsR0FBRyxDQUFDLFlBQVksRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7WUFDakYsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUE4Qix5QkFBeUIsV0FBVyxFQUFFLENBQUMsQ0FBQztZQUN2RyxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQzVCLENBQUM7UUFDRCxHQUFHLE9BQU87S0FDWCxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLDBCQUEwQixDQUN4QyxPQUErRDtJQUUvRCxPQUFPLElBQUEsc0JBQVEsRUFBQztRQUNkLFFBQVEsRUFBRSx3QkFBZ0IsQ0FBQyxXQUFXLEVBQUU7UUFDeEMsT0FBTyxFQUFFLEtBQUssSUFBcUIsRUFBRTtZQUNuQyxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQztZQUM5QixNQUFNLFFBQVEsR0FBRyxNQUFNLE1BQU0sQ0FBQyxHQUFHLENBQWlDLG9DQUFvQyxDQUFDLENBQUM7WUFDeEcsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7UUFDbEMsQ0FBQztRQUNELEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIE5vdGlmaWNhdGlvbnMgUXVlcnkgSG9va3NcbiAqXG4gKiBUYW5TdGFjayBRdWVyeSBob29rcyBmb3Igbm90aWZpY2F0aW9uIG9wZXJhdGlvbnMuXG4gKi9cblxuaW1wb3J0IHsgdXNlUXVlcnksIFVzZVF1ZXJ5T3B0aW9ucywgVXNlUXVlcnlSZXN1bHQgfSBmcm9tICdAdGFuc3RhY2svcmVhY3QtcXVlcnknO1xuaW1wb3J0IHsgZ2V0QXBpQ2xpZW50IH0gZnJvbSAnLi4vY2xpZW50JztcbmltcG9ydCB0eXBlIHsgTm90aWZpY2F0aW9uLCBBcGlSZXNwb25zZSB9IGZyb20gJy4uL3R5cGVzJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gUVVFUlkgS0VZU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5leHBvcnQgY29uc3Qgbm90aWZpY2F0aW9uS2V5cyA9IHtcbiAgYWxsOiBbJ25vdGlmaWNhdGlvbnMnXSBhcyBjb25zdCxcbiAgbGlzdHM6ICgpID0+IFsuLi5ub3RpZmljYXRpb25LZXlzLmFsbCwgJ2xpc3QnXSBhcyBjb25zdCxcbiAgbGlzdDogKHBhcmFtcz86IHsgbGltaXQ/OiBudW1iZXI7IHVucmVhZE9ubHk/OiBib29sZWFuIH0pID0+IFsuLi5ub3RpZmljYXRpb25LZXlzLmxpc3RzKCksIHBhcmFtc10gYXMgY29uc3QsXG4gIHVucmVhZENvdW50OiAoKSA9PiBbLi4ubm90aWZpY2F0aW9uS2V5cy5hbGwsICd1bnJlYWRDb3VudCddIGFzIGNvbnN0LFxufTtcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gUVVFUlkgSE9PS1Ncbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBHZXQgbm90aWZpY2F0aW9ucyBmb3IgY3VycmVudCB1c2VyXG4gKlxuICogQGVuZHBvaW50IEdFVCAvYXBpL3YxL25vdGlmaWNhdGlvbnNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZU5vdGlmaWNhdGlvbnMoXG4gIHBhcmFtcz86IHsgbGltaXQ/OiBudW1iZXI7IHVucmVhZE9ubHk/OiBib29sZWFuIH0sXG4gIG9wdGlvbnM/OiBPbWl0PFVzZVF1ZXJ5T3B0aW9uczxOb3RpZmljYXRpb25bXT4sICdxdWVyeUtleScgfCAncXVlcnlGbic+XG4pOiBVc2VRdWVyeVJlc3VsdDxOb3RpZmljYXRpb25bXT4ge1xuICByZXR1cm4gdXNlUXVlcnkoe1xuICAgIHF1ZXJ5S2V5OiBub3RpZmljYXRpb25LZXlzLmxpc3QocGFyYW1zKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxOb3RpZmljYXRpb25bXT4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KCk7XG4gICAgICBjb25zdCBxdWVyeVBhcmFtcyA9IG5ldyBVUkxTZWFyY2hQYXJhbXMoKTtcbiAgICAgIGlmIChwYXJhbXM/LmxpbWl0KSBxdWVyeVBhcmFtcy5zZXQoJ2xpbWl0JywgU3RyaW5nKHBhcmFtcy5saW1pdCkpO1xuICAgICAgaWYgKHBhcmFtcz8udW5yZWFkT25seSkgcXVlcnlQYXJhbXMuc2V0KCd1bnJlYWRPbmx5JywgU3RyaW5nKHBhcmFtcy51bnJlYWRPbmx5KSk7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5nZXQ8QXBpUmVzcG9uc2U8Tm90aWZpY2F0aW9uW10+PihgL2FwaS92MS9ub3RpZmljYXRpb25zPyR7cXVlcnlQYXJhbXN9YCk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhO1xuICAgIH0sXG4gICAgLi4ub3B0aW9ucyxcbiAgfSk7XG59XG5cbi8qKlxuICogR2V0IHVucmVhZCBub3RpZmljYXRpb24gY291bnRcbiAqXG4gKiBAZW5kcG9pbnQgR0VUIC9hcGkvdjEvbm90aWZpY2F0aW9ucy91bnJlYWQtY291bnRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVVucmVhZE5vdGlmaWNhdGlvbkNvdW50KFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8bnVtYmVyPiwgJ3F1ZXJ5S2V5JyB8ICdxdWVyeUZuJz5cbik6IFVzZVF1ZXJ5UmVzdWx0PG51bWJlcj4ge1xuICByZXR1cm4gdXNlUXVlcnkoe1xuICAgIHF1ZXJ5S2V5OiBub3RpZmljYXRpb25LZXlzLnVucmVhZENvdW50KCksXG4gICAgcXVlcnlGbjogYXN5bmMgKCk6IFByb21pc2U8bnVtYmVyPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldDxBcGlSZXNwb25zZTx7IGNvdW50OiBudW1iZXIgfT4+KCcvYXBpL3YxL25vdGlmaWNhdGlvbnMvdW5yZWFkLWNvdW50Jyk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhLmNvdW50O1xuICAgIH0sXG4gICAgLi4ub3B0aW9ucyxcbiAgfSk7XG59XG4iXX0=
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvcXVlcmllcy9ub3RpZmljYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7OztHQUlHOzs7QUFnQ0gsNENBbUJDO0FBT0QsZ0VBY0M7QUF0RUQsdURBSThCO0FBRTlCLHNDQUFzQztBQUd0QywrRUFBK0U7QUFDL0UsYUFBYTtBQUNiLCtFQUErRTtBQUVsRSxRQUFBLGdCQUFnQixHQUFHO0lBQzlCLEdBQUcsRUFBRSxDQUFDLGVBQWUsQ0FBVTtJQUMvQixLQUFLLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxHQUFHLHdCQUFnQixDQUFDLEdBQUcsRUFBRSxNQUFNLENBQVU7SUFDdkQsSUFBSSxFQUFFLENBQUMsTUFBK0MsRUFBRSxFQUFFLENBQ3hELENBQUMsR0FBRyx3QkFBZ0IsQ0FBQyxLQUFLLEVBQUUsRUFBRSxNQUFNLENBQVU7SUFDaEQsV0FBVyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsR0FBRyx3QkFBZ0IsQ0FBQyxHQUFHLEVBQUUsYUFBYSxDQUFVO0NBQ3JFLENBQUE7QUFFRCwrRUFBK0U7QUFDL0UsY0FBYztBQUNkLCtFQUErRTtBQUUvRTs7OztHQUlHO0FBQ0gsU0FBZ0IsZ0JBQWdCLENBQzlCLE1BQStDLEVBQy9DLE9BQXVFO0lBRXZFLE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLHdCQUFnQixDQUFDLElBQUksQ0FBQyxNQUFNLENBQUM7UUFDdkMsT0FBTyxFQUFFLEtBQUssSUFBNkIsRUFBRTtZQUMzQyxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQTtZQUM3QixNQUFNLFdBQVcsR0FBRyxJQUFJLGVBQWUsRUFBRSxDQUFBO1lBQ3pDLElBQUksTUFBTSxFQUFFLEtBQUs7Z0JBQUUsV0FBVyxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFBO1lBQ2pFLElBQUksTUFBTSxFQUFFLFVBQVU7Z0JBQ3BCLFdBQVcsQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLE1BQU0sQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQTtZQUMxRCxNQUFNLFFBQVEsR0FBRyxNQUFNLE1BQU0sQ0FBQyxHQUFHLENBQy9CLGtCQUFrQixXQUFXLEVBQUUsQ0FDaEMsQ0FBQTtZQUNELE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUE7UUFDM0IsQ0FBQztRQUNELEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQTtBQUNKLENBQUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsMEJBQTBCLENBQ3hDLE9BQStEO0lBRS9ELE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLHdCQUFnQixDQUFDLFdBQVcsRUFBRTtRQUN4QyxPQUFPLEVBQUUsS0FBSyxJQUFxQixFQUFFO1lBQ25DLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFBO1lBQzdCLE1BQU0sUUFBUSxHQUFHLE1BQU0sTUFBTSxDQUFDLEdBQUcsQ0FDL0IsNkJBQTZCLENBQzlCLENBQUE7WUFDRCxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQTtRQUNqQyxDQUFDO1FBQ0QsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFBO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogTm90aWZpY2F0aW9ucyBRdWVyeSBIb29rc1xuICpcbiAqIFRhblN0YWNrIFF1ZXJ5IGhvb2tzIGZvciBub3RpZmljYXRpb24gb3BlcmF0aW9ucy5cbiAqL1xuXG5pbXBvcnQge1xuICB1c2VRdWVyeSxcbiAgdHlwZSBVc2VRdWVyeU9wdGlvbnMsXG4gIHR5cGUgVXNlUXVlcnlSZXN1bHQsXG59IGZyb20gJ0B0YW5zdGFjay9yZWFjdC1xdWVyeSdcblxuaW1wb3J0IHtnZXRBcGlDbGllbnR9IGZyb20gJy4uL2NsaWVudCdcbmltcG9ydCB7dHlwZSBBcGlSZXNwb25zZSwgdHlwZSBOb3RpZmljYXRpb259IGZyb20gJy4uL3R5cGVzJ1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBRVUVSWSBLRVlTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbmV4cG9ydCBjb25zdCBub3RpZmljYXRpb25LZXlzID0ge1xuICBhbGw6IFsnbm90aWZpY2F0aW9ucyddIGFzIGNvbnN0LFxuICBsaXN0czogKCkgPT4gWy4uLm5vdGlmaWNhdGlvbktleXMuYWxsLCAnbGlzdCddIGFzIGNvbnN0LFxuICBsaXN0OiAocGFyYW1zPzoge2xpbWl0PzogbnVtYmVyOyB1bnJlYWRPbmx5PzogYm9vbGVhbn0pID0+XG4gICAgWy4uLm5vdGlmaWNhdGlvbktleXMubGlzdHMoKSwgcGFyYW1zXSBhcyBjb25zdCxcbiAgdW5yZWFkQ291bnQ6ICgpID0+IFsuLi5ub3RpZmljYXRpb25LZXlzLmFsbCwgJ3VucmVhZENvdW50J10gYXMgY29uc3QsXG59XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFFVRVJZIEhPT0tTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogR2V0IG5vdGlmaWNhdGlvbnMgZm9yIGN1cnJlbnQgdXNlclxuICpcbiAqIEBlbmRwb2ludCBHRVQgL25vdGlmaWNhdGlvbnNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZU5vdGlmaWNhdGlvbnMoXG4gIHBhcmFtcz86IHtsaW1pdD86IG51bWJlcjsgdW5yZWFkT25seT86IGJvb2xlYW59LFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8Tm90aWZpY2F0aW9uW10+LCAncXVlcnlLZXknIHwgJ3F1ZXJ5Rm4nPixcbik6IFVzZVF1ZXJ5UmVzdWx0PE5vdGlmaWNhdGlvbltdPiB7XG4gIHJldHVybiB1c2VRdWVyeSh7XG4gICAgcXVlcnlLZXk6IG5vdGlmaWNhdGlvbktleXMubGlzdChwYXJhbXMpLFxuICAgIHF1ZXJ5Rm46IGFzeW5jICgpOiBQcm9taXNlPE5vdGlmaWNhdGlvbltdPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKVxuICAgICAgY29uc3QgcXVlcnlQYXJhbXMgPSBuZXcgVVJMU2VhcmNoUGFyYW1zKClcbiAgICAgIGlmIChwYXJhbXM/LmxpbWl0KSBxdWVyeVBhcmFtcy5zZXQoJ2xpbWl0JywgU3RyaW5nKHBhcmFtcy5saW1pdCkpXG4gICAgICBpZiAocGFyYW1zPy51bnJlYWRPbmx5KVxuICAgICAgICBxdWVyeVBhcmFtcy5zZXQoJ3VucmVhZE9ubHknLCBTdHJpbmcocGFyYW1zLnVucmVhZE9ubHkpKVxuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0PEFwaVJlc3BvbnNlPE5vdGlmaWNhdGlvbltdPj4oXG4gICAgICAgIGAvbm90aWZpY2F0aW9ucz8ke3F1ZXJ5UGFyYW1zfWAsXG4gICAgICApXG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhXG4gICAgfSxcbiAgICAuLi5vcHRpb25zLFxuICB9KVxufVxuXG4vKipcbiAqIEdldCB1bnJlYWQgbm90aWZpY2F0aW9uIGNvdW50XG4gKlxuICogQGVuZHBvaW50IEdFVCAvbm90aWZpY2F0aW9ucy91bnJlYWQtY291bnRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVVucmVhZE5vdGlmaWNhdGlvbkNvdW50KFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8bnVtYmVyPiwgJ3F1ZXJ5S2V5JyB8ICdxdWVyeUZuJz4sXG4pOiBVc2VRdWVyeVJlc3VsdDxudW1iZXI+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogbm90aWZpY2F0aW9uS2V5cy51bnJlYWRDb3VudCgpLFxuICAgIHF1ZXJ5Rm46IGFzeW5jICgpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KClcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldDxBcGlSZXNwb25zZTx7Y291bnQ6IG51bWJlcn0+PihcbiAgICAgICAgJy9ub3RpZmljYXRpb25zL3VucmVhZC1jb3VudCcsXG4gICAgICApXG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhLmNvdW50XG4gICAgfSxcbiAgICAuLi5vcHRpb25zLFxuICB9KVxufVxuIl19