@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.
- package/dist/api/client.d.ts +1 -1
- package/dist/api/client.js +7 -3
- package/dist/api/entities.d.ts +316 -0
- package/dist/api/entities.js +9 -0
- package/dist/api/mutations/clubs.d.ts +6 -6
- package/dist/api/mutations/clubs.js +12 -10
- package/dist/api/mutations/conversations.d.ts +7 -7
- package/dist/api/mutations/conversations.js +17 -13
- package/dist/api/mutations/index.js +1 -1
- package/dist/api/mutations/notifications.d.ts +4 -4
- package/dist/api/mutations/notifications.js +7 -7
- package/dist/api/mutations/orders.d.ts +7 -7
- package/dist/api/mutations/orders.js +11 -13
- package/dist/api/mutations/posts.d.ts +13 -13
- package/dist/api/mutations/posts.js +41 -29
- package/dist/api/mutations/products.d.ts +5 -5
- package/dist/api/mutations/products.js +9 -13
- package/dist/api/mutations/spots.d.ts +42 -8
- package/dist/api/mutations/spots.js +51 -13
- package/dist/api/mutations/users.d.ts +12 -10
- package/dist/api/mutations/users.js +20 -18
- package/dist/api/queries/auth.d.ts +5 -5
- package/dist/api/queries/auth.js +7 -7
- package/dist/api/queries/clubs.d.ts +7 -7
- package/dist/api/queries/clubs.js +11 -11
- package/dist/api/queries/conversations.d.ts +5 -5
- package/dist/api/queries/conversations.js +7 -7
- package/dist/api/queries/index.js +1 -1
- package/dist/api/queries/misc.d.ts +8 -32
- package/dist/api/queries/misc.js +28 -66
- package/dist/api/queries/notifications.d.ts +4 -4
- package/dist/api/queries/notifications.js +5 -5
- package/dist/api/queries/orders.d.ts +4 -4
- package/dist/api/queries/orders.js +7 -7
- package/dist/api/queries/posts.d.ts +44 -7
- package/dist/api/queries/posts.js +118 -15
- package/dist/api/queries/products.d.ts +6 -10
- package/dist/api/queries/products.js +7 -9
- package/dist/api/queries/spots.d.ts +31 -16
- package/dist/api/queries/spots.js +113 -31
- package/dist/api/queries/templates.d.ts +6 -9
- package/dist/api/queries/templates.js +8 -13
- package/dist/api/queries/users.d.ts +25 -11
- package/dist/api/queries/users.js +75 -27
- package/dist/api/types.d.ts +36 -33
- package/dist/api/types.js +6 -7
- package/dist/index.d.ts +1 -2
- package/dist/index.js +1 -8
- package/package.json +6 -21
- package/src/api/client.ts +45 -30
- package/src/api/entities.ts +420 -0
- package/src/api/mutations/clubs.ts +73 -40
- package/src/api/mutations/conversations.ts +91 -47
- package/src/api/mutations/index.ts +8 -8
- package/src/api/mutations/notifications.ts +48 -25
- package/src/api/mutations/orders.ts +101 -70
- package/src/api/mutations/posts.ts +229 -118
- package/src/api/mutations/products.ts +120 -81
- package/src/api/mutations/spots.ts +167 -55
- package/src/api/mutations/users.ts +109 -76
- package/src/api/queries/auth.ts +49 -24
- package/src/api/queries/clubs.ts +53 -38
- package/src/api/queries/conversations.ts +48 -30
- package/src/api/queries/index.ts +21 -21
- package/src/api/queries/misc.ts +53 -82
- package/src/api/queries/notifications.ts +32 -21
- package/src/api/queries/orders.ts +59 -42
- package/src/api/queries/posts.ts +203 -48
- package/src/api/queries/products.ts +51 -44
- package/src/api/queries/spots.ts +216 -85
- package/src/api/queries/templates.ts +39 -32
- package/src/api/queries/users.ts +157 -64
- package/src/api/types.ts +72 -118
- package/src/index.ts +5 -11
|
@@ -3,8 +3,6 @@
|
|
|
3
3
|
* Templates Query Hooks
|
|
4
4
|
*
|
|
5
5
|
* TanStack Query hooks for post template operations.
|
|
6
|
-
*
|
|
7
|
-
* Templates are reference data (flat array), not paginated.
|
|
8
6
|
*/
|
|
9
7
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
8
|
exports.templateKeys = void 0;
|
|
@@ -28,10 +26,9 @@ exports.templateKeys = {
|
|
|
28
26
|
// QUERY HOOKS
|
|
29
27
|
// ============================================================================
|
|
30
28
|
/**
|
|
31
|
-
* Get all templates
|
|
29
|
+
* Get all templates
|
|
32
30
|
*
|
|
33
|
-
* @endpoint GET /
|
|
34
|
-
* @returns Flat array of templates (not paginated)
|
|
31
|
+
* @endpoint GET /templates
|
|
35
32
|
*/
|
|
36
33
|
function useTemplates(params, options) {
|
|
37
34
|
return (0, react_query_1.useQuery)({
|
|
@@ -41,25 +38,23 @@ function useTemplates(params, options) {
|
|
|
41
38
|
const queryParams = new URLSearchParams();
|
|
42
39
|
if (params?.spotType)
|
|
43
40
|
queryParams.set('spotType', params.spotType);
|
|
44
|
-
const response = await client.get(`/
|
|
45
|
-
// Templates endpoint returns flat array: { data: [] }
|
|
41
|
+
const response = await client.get(`/templates?${queryParams}`);
|
|
46
42
|
return response.data.data;
|
|
47
43
|
},
|
|
48
|
-
staleTime: 1000 * 60 * 60, // Cache for 1 hour (reference data)
|
|
49
44
|
...options,
|
|
50
45
|
});
|
|
51
46
|
}
|
|
52
47
|
/**
|
|
53
48
|
* Get a template by ID
|
|
54
49
|
*
|
|
55
|
-
* @endpoint GET /
|
|
50
|
+
* @endpoint GET /templates/{templateId}
|
|
56
51
|
*/
|
|
57
52
|
function useTemplate(templateId, options) {
|
|
58
53
|
return (0, react_query_1.useQuery)({
|
|
59
54
|
queryKey: exports.templateKeys.detail(templateId),
|
|
60
55
|
queryFn: async () => {
|
|
61
56
|
const client = (0, client_1.getApiClient)();
|
|
62
|
-
const response = await client.get(`/
|
|
57
|
+
const response = await client.get(`/templates/${templateId}`);
|
|
63
58
|
return response.data.data;
|
|
64
59
|
},
|
|
65
60
|
enabled: !!templateId,
|
|
@@ -69,18 +64,18 @@ function useTemplate(templateId, options) {
|
|
|
69
64
|
/**
|
|
70
65
|
* Get a template by slug
|
|
71
66
|
*
|
|
72
|
-
* @endpoint GET /
|
|
67
|
+
* @endpoint GET /templates/slug/{slug}
|
|
73
68
|
*/
|
|
74
69
|
function useTemplateBySlug(slug, options) {
|
|
75
70
|
return (0, react_query_1.useQuery)({
|
|
76
71
|
queryKey: exports.templateKeys.bySlug(slug),
|
|
77
72
|
queryFn: async () => {
|
|
78
73
|
const client = (0, client_1.getApiClient)();
|
|
79
|
-
const response = await client.get(`/
|
|
74
|
+
const response = await client.get(`/templates/slug/${slug}`);
|
|
80
75
|
return response.data.data;
|
|
81
76
|
},
|
|
82
77
|
enabled: !!slug,
|
|
83
78
|
...options,
|
|
84
79
|
});
|
|
85
80
|
}
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwaS9xdWVyaWVzL3RlbXBsYXRlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7R0FJRzs7O0FBa0NILG9DQWlCQztBQU9ELGtDQWdCQztBQU9ELDhDQWdCQztBQS9GRCx1REFJOEI7QUFFOUIsc0NBQXNDO0FBR3RDLCtFQUErRTtBQUMvRSxhQUFhO0FBQ2IsK0VBQStFO0FBRWxFLFFBQUEsWUFBWSxHQUFHO0lBQzFCLEdBQUcsRUFBRSxDQUFDLFdBQVcsQ0FBVTtJQUMzQixLQUFLLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxHQUFHLG9CQUFZLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBVTtJQUNuRCxJQUFJLEVBQUUsQ0FBQyxPQUE2QixFQUFFLEVBQUUsQ0FDdEMsQ0FBQyxHQUFHLG9CQUFZLENBQUMsS0FBSyxFQUFFLEVBQUUsT0FBTyxDQUFVO0lBQzdDLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLEdBQUcsb0JBQVksQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFVO0lBQ3ZELE1BQU0sRUFBRSxDQUFDLEVBQVUsRUFBRSxFQUFFLENBQUMsQ0FBQyxHQUFHLG9CQUFZLENBQUMsT0FBTyxFQUFFLEVBQUUsRUFBRSxDQUFVO0lBQ2hFLE1BQU0sRUFBRSxDQUFDLElBQVksRUFBRSxFQUFFLENBQUMsQ0FBQyxHQUFHLG9CQUFZLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQVU7Q0FDdkUsQ0FBQTtBQUVELCtFQUErRTtBQUMvRSxjQUFjO0FBQ2QsK0VBQStFO0FBRS9FOzs7O0dBSUc7QUFDSCxTQUFnQixZQUFZLENBQzFCLE1BQTRCLEVBQzVCLE9BQW1FO0lBRW5FLE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLG9CQUFZLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUNuQyxPQUFPLEVBQUUsS0FBSyxJQUF5QixFQUFFO1lBQ3ZDLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFBO1lBQzdCLE1BQU0sV0FBVyxHQUFHLElBQUksZUFBZSxFQUFFLENBQUE7WUFDekMsSUFBSSxNQUFNLEVBQUUsUUFBUTtnQkFBRSxXQUFXLENBQUMsR0FBRyxDQUFDLFVBQVUsRUFBRSxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUE7WUFDbEUsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUMvQixjQUFjLFdBQVcsRUFBRSxDQUM1QixDQUFBO1lBQ0QsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQTtRQUMzQixDQUFDO1FBQ0QsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFBO0FBQ0osQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQixXQUFXLENBQ3pCLFVBQWtCLEVBQ2xCLE9BQWlFO0lBRWpFLE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLG9CQUFZLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQztRQUN6QyxPQUFPLEVBQUUsS0FBSyxJQUF1QixFQUFFO1lBQ3JDLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFBO1lBQzdCLE1BQU0sUUFBUSxHQUFHLE1BQU0sTUFBTSxDQUFDLEdBQUcsQ0FDL0IsY0FBYyxVQUFVLEVBQUUsQ0FDM0IsQ0FBQTtZQUNELE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUE7UUFDM0IsQ0FBQztRQUNELE9BQU8sRUFBRSxDQUFDLENBQUMsVUFBVTtRQUNyQixHQUFHLE9BQU87S0FDWCxDQUFDLENBQUE7QUFDSixDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLGlCQUFpQixDQUMvQixJQUFZLEVBQ1osT0FBaUU7SUFFakUsT0FBTyxJQUFBLHNCQUFRLEVBQUM7UUFDZCxRQUFRLEVBQUUsb0JBQVksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDO1FBQ25DLE9BQU8sRUFBRSxLQUFLLElBQXVCLEVBQUU7WUFDckMsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUE7WUFDN0IsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUMvQixtQkFBbUIsSUFBSSxFQUFFLENBQzFCLENBQUE7WUFDRCxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFBO1FBQzNCLENBQUM7UUFDRCxPQUFPLEVBQUUsQ0FBQyxDQUFDLElBQUk7UUFDZixHQUFHLE9BQU87S0FDWCxDQUFDLENBQUE7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBUZW1wbGF0ZXMgUXVlcnkgSG9va3NcbiAqXG4gKiBUYW5TdGFjayBRdWVyeSBob29rcyBmb3IgcG9zdCB0ZW1wbGF0ZSBvcGVyYXRpb25zLlxuICovXG5cbmltcG9ydCB7XG4gIHVzZVF1ZXJ5LFxuICB0eXBlIFVzZVF1ZXJ5T3B0aW9ucyxcbiAgdHlwZSBVc2VRdWVyeVJlc3VsdCxcbn0gZnJvbSAnQHRhbnN0YWNrL3JlYWN0LXF1ZXJ5J1xuXG5pbXBvcnQge2dldEFwaUNsaWVudH0gZnJvbSAnLi4vY2xpZW50J1xuaW1wb3J0IHt0eXBlIEFwaVJlc3BvbnNlLCB0eXBlIFRlbXBsYXRlfSBmcm9tICcuLi90eXBlcydcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gUVVFUlkgS0VZU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5leHBvcnQgY29uc3QgdGVtcGxhdGVLZXlzID0ge1xuICBhbGw6IFsndGVtcGxhdGVzJ10gYXMgY29uc3QsXG4gIGxpc3RzOiAoKSA9PiBbLi4udGVtcGxhdGVLZXlzLmFsbCwgJ2xpc3QnXSBhcyBjb25zdCxcbiAgbGlzdDogKGZpbHRlcnM/OiB7c3BvdFR5cGU/OiBzdHJpbmd9KSA9PlxuICAgIFsuLi50ZW1wbGF0ZUtleXMubGlzdHMoKSwgZmlsdGVyc10gYXMgY29uc3QsXG4gIGRldGFpbHM6ICgpID0+IFsuLi50ZW1wbGF0ZUtleXMuYWxsLCAnZGV0YWlsJ10gYXMgY29uc3QsXG4gIGRldGFpbDogKGlkOiBzdHJpbmcpID0+IFsuLi50ZW1wbGF0ZUtleXMuZGV0YWlscygpLCBpZF0gYXMgY29uc3QsXG4gIGJ5U2x1ZzogKHNsdWc6IHN0cmluZykgPT4gWy4uLnRlbXBsYXRlS2V5cy5hbGwsICdzbHVnJywgc2x1Z10gYXMgY29uc3QsXG59XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFFVRVJZIEhPT0tTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogR2V0IGFsbCB0ZW1wbGF0ZXNcbiAqXG4gKiBAZW5kcG9pbnQgR0VUIC90ZW1wbGF0ZXNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVRlbXBsYXRlcyhcbiAgcGFyYW1zPzoge3Nwb3RUeXBlPzogc3RyaW5nfSxcbiAgb3B0aW9ucz86IE9taXQ8VXNlUXVlcnlPcHRpb25zPFRlbXBsYXRlW10+LCAncXVlcnlLZXknIHwgJ3F1ZXJ5Rm4nPixcbik6IFVzZVF1ZXJ5UmVzdWx0PFRlbXBsYXRlW10+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogdGVtcGxhdGVLZXlzLmxpc3QocGFyYW1zKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxUZW1wbGF0ZVtdPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKVxuICAgICAgY29uc3QgcXVlcnlQYXJhbXMgPSBuZXcgVVJMU2VhcmNoUGFyYW1zKClcbiAgICAgIGlmIChwYXJhbXM/LnNwb3RUeXBlKSBxdWVyeVBhcmFtcy5zZXQoJ3Nwb3RUeXBlJywgcGFyYW1zLnNwb3RUeXBlKVxuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0PEFwaVJlc3BvbnNlPFRlbXBsYXRlW10+PihcbiAgICAgICAgYC90ZW1wbGF0ZXM/JHtxdWVyeVBhcmFtc31gLFxuICAgICAgKVxuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGEuZGF0YVxuICAgIH0sXG4gICAgLi4ub3B0aW9ucyxcbiAgfSlcbn1cblxuLyoqXG4gKiBHZXQgYSB0ZW1wbGF0ZSBieSBJRFxuICpcbiAqIEBlbmRwb2ludCBHRVQgL3RlbXBsYXRlcy97dGVtcGxhdGVJZH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVRlbXBsYXRlKFxuICB0ZW1wbGF0ZUlkOiBzdHJpbmcsXG4gIG9wdGlvbnM/OiBPbWl0PFVzZVF1ZXJ5T3B0aW9uczxUZW1wbGF0ZT4sICdxdWVyeUtleScgfCAncXVlcnlGbic+LFxuKTogVXNlUXVlcnlSZXN1bHQ8VGVtcGxhdGU+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogdGVtcGxhdGVLZXlzLmRldGFpbCh0ZW1wbGF0ZUlkKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxUZW1wbGF0ZT4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KClcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldDxBcGlSZXNwb25zZTxUZW1wbGF0ZT4+KFxuICAgICAgICBgL3RlbXBsYXRlcy8ke3RlbXBsYXRlSWR9YCxcbiAgICAgIClcbiAgICAgIHJldHVybiByZXNwb25zZS5kYXRhLmRhdGFcbiAgICB9LFxuICAgIGVuYWJsZWQ6ICEhdGVtcGxhdGVJZCxcbiAgICAuLi5vcHRpb25zLFxuICB9KVxufVxuXG4vKipcbiAqIEdldCBhIHRlbXBsYXRlIGJ5IHNsdWdcbiAqXG4gKiBAZW5kcG9pbnQgR0VUIC90ZW1wbGF0ZXMvc2x1Zy97c2x1Z31cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVRlbXBsYXRlQnlTbHVnKFxuICBzbHVnOiBzdHJpbmcsXG4gIG9wdGlvbnM/OiBPbWl0PFVzZVF1ZXJ5T3B0aW9uczxUZW1wbGF0ZT4sICdxdWVyeUtleScgfCAncXVlcnlGbic+LFxuKTogVXNlUXVlcnlSZXN1bHQ8VGVtcGxhdGU+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogdGVtcGxhdGVLZXlzLmJ5U2x1ZyhzbHVnKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxUZW1wbGF0ZT4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KClcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldDxBcGlSZXNwb25zZTxUZW1wbGF0ZT4+KFxuICAgICAgICBgL3RlbXBsYXRlcy9zbHVnLyR7c2x1Z31gLFxuICAgICAgKVxuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGEuZGF0YVxuICAgIH0sXG4gICAgZW5hYmxlZDogISFzbHVnLFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pXG59XG4iXX0=
|
|
@@ -3,12 +3,13 @@
|
|
|
3
3
|
*
|
|
4
4
|
* TanStack Query hooks for user-related operations.
|
|
5
5
|
*/
|
|
6
|
-
import { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
|
|
7
|
-
import type
|
|
6
|
+
import { type UseQueryOptions, type UseQueryResult } from '@tanstack/react-query';
|
|
7
|
+
import { type Club, type FavoriteSpot, type Post, type Spot, type SpotsSummaryResponse, type SpotSubscription, type User } from '../types';
|
|
8
8
|
export declare const userKeys: {
|
|
9
9
|
all: readonly ["users"];
|
|
10
10
|
me: () => readonly ["users", "me"];
|
|
11
11
|
stats: () => readonly ["users", "me", "stats"];
|
|
12
|
+
spotsSummary: () => readonly ["users", "me", "spots-summary"];
|
|
12
13
|
activity: (limit?: number) => readonly ["users", "me", "activity", number | undefined];
|
|
13
14
|
posts: (params?: {
|
|
14
15
|
page?: number;
|
|
@@ -26,13 +27,14 @@ export declare const userKeys: {
|
|
|
26
27
|
/**
|
|
27
28
|
* Get current user's profile
|
|
28
29
|
*
|
|
29
|
-
* @endpoint GET /
|
|
30
|
+
* @endpoint GET /users/me
|
|
30
31
|
*/
|
|
31
32
|
export declare function useCurrentUser(options?: Omit<UseQueryOptions<User>, 'queryKey' | 'queryFn'>): UseQueryResult<User>;
|
|
32
33
|
/**
|
|
33
34
|
* Get current user's stats
|
|
34
35
|
*
|
|
35
|
-
* @endpoint GET /
|
|
36
|
+
* @endpoint GET /users/me/stats
|
|
37
|
+
* @deprecated This endpoint doesn't exist in the API. Use useUserSpotsSummary instead.
|
|
36
38
|
*/
|
|
37
39
|
export declare function useUserStats(options?: Omit<UseQueryOptions<{
|
|
38
40
|
posts: number;
|
|
@@ -43,16 +45,28 @@ export declare function useUserStats(options?: Omit<UseQueryOptions<{
|
|
|
43
45
|
responses: number;
|
|
44
46
|
upvotes: number;
|
|
45
47
|
}>;
|
|
48
|
+
/**
|
|
49
|
+
* Get current user's spots summary with activity indicators
|
|
50
|
+
*
|
|
51
|
+
* Returns list of spots where user has posted, with:
|
|
52
|
+
* - Post count per spot
|
|
53
|
+
* - Unread messages count
|
|
54
|
+
* - Pending responses count
|
|
55
|
+
* - Last activity timestamp
|
|
56
|
+
*
|
|
57
|
+
* @endpoint GET /users/me/spots-summary
|
|
58
|
+
*/
|
|
59
|
+
export declare function useUserSpotsSummary(options?: Omit<UseQueryOptions<SpotsSummaryResponse>, 'queryKey' | 'queryFn'>): UseQueryResult<SpotsSummaryResponse>;
|
|
46
60
|
/**
|
|
47
61
|
* Get current user's activity
|
|
48
62
|
*
|
|
49
|
-
* @endpoint GET /
|
|
63
|
+
* @endpoint GET /users/me/activity
|
|
50
64
|
*/
|
|
51
65
|
export declare function useUserActivity(limit?: number, options?: Omit<UseQueryOptions<unknown[]>, 'queryKey' | 'queryFn'>): UseQueryResult<unknown[]>;
|
|
52
66
|
/**
|
|
53
67
|
* Get current user's posts
|
|
54
68
|
*
|
|
55
|
-
* @endpoint GET /
|
|
69
|
+
* @endpoint GET /user/me/posts
|
|
56
70
|
*/
|
|
57
71
|
export declare function useUserPosts(params?: {
|
|
58
72
|
page?: number;
|
|
@@ -61,30 +75,30 @@ export declare function useUserPosts(params?: {
|
|
|
61
75
|
/**
|
|
62
76
|
* Get current user's clubs
|
|
63
77
|
*
|
|
64
|
-
* @endpoint GET /
|
|
78
|
+
* @endpoint GET /user/me/clubs
|
|
65
79
|
*/
|
|
66
80
|
export declare function useUserClubs(options?: Omit<UseQueryOptions<Club[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Club[]>;
|
|
67
81
|
/**
|
|
68
82
|
* Get current user's spot subscriptions
|
|
69
83
|
*
|
|
70
|
-
* @endpoint GET /
|
|
84
|
+
* @endpoint GET /user/me/subscriptions
|
|
71
85
|
*/
|
|
72
86
|
export declare function useUserSubscriptions(options?: Omit<UseQueryOptions<SpotSubscription[]>, 'queryKey' | 'queryFn'>): UseQueryResult<SpotSubscription[]>;
|
|
73
87
|
/**
|
|
74
88
|
* Get blocked users list
|
|
75
89
|
*
|
|
76
|
-
* @endpoint GET /
|
|
90
|
+
* @endpoint GET /user/me/blocked
|
|
77
91
|
*/
|
|
78
92
|
export declare function useBlockedUsers(options?: Omit<UseQueryOptions<User[]>, 'queryKey' | 'queryFn'>): UseQueryResult<User[]>;
|
|
79
93
|
/**
|
|
80
94
|
* Get current user's owned spots (for business owners)
|
|
81
95
|
*
|
|
82
|
-
* @endpoint GET /
|
|
96
|
+
* @endpoint GET /users/me/owned-spots
|
|
83
97
|
*/
|
|
84
98
|
export declare function useOwnedSpots(options?: Omit<UseQueryOptions<Spot[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Spot[]>;
|
|
85
99
|
/**
|
|
86
100
|
* Get current user's favorite spots
|
|
87
101
|
*
|
|
88
|
-
* @endpoint GET /
|
|
102
|
+
* @endpoint GET /users/me/favorites
|
|
89
103
|
*/
|
|
90
104
|
export declare function useUserFavorites(options?: Omit<UseQueryOptions<FavoriteSpot[]>, 'queryKey' | 'queryFn'>): UseQueryResult<FavoriteSpot[]>;
|
|
@@ -8,6 +8,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
8
8
|
exports.userKeys = void 0;
|
|
9
9
|
exports.useCurrentUser = useCurrentUser;
|
|
10
10
|
exports.useUserStats = useUserStats;
|
|
11
|
+
exports.useUserSpotsSummary = useUserSpotsSummary;
|
|
11
12
|
exports.useUserActivity = useUserActivity;
|
|
12
13
|
exports.useUserPosts = useUserPosts;
|
|
13
14
|
exports.useUserClubs = useUserClubs;
|
|
@@ -17,6 +18,20 @@ exports.useOwnedSpots = useOwnedSpots;
|
|
|
17
18
|
exports.useUserFavorites = useUserFavorites;
|
|
18
19
|
const react_query_1 = require("@tanstack/react-query");
|
|
19
20
|
const client_1 = require("../client");
|
|
21
|
+
// Helper to extract array data from API response
|
|
22
|
+
// API can return either { data: T[] } or { data: { data: T[], meta?: {...} } }
|
|
23
|
+
function extractArrayData(data) {
|
|
24
|
+
if (Array.isArray(data)) {
|
|
25
|
+
return data;
|
|
26
|
+
}
|
|
27
|
+
if (data && typeof data === 'object' && 'data' in data) {
|
|
28
|
+
const nested = data.data;
|
|
29
|
+
if (Array.isArray(nested)) {
|
|
30
|
+
return nested;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
return [];
|
|
34
|
+
}
|
|
20
35
|
// ============================================================================
|
|
21
36
|
// QUERY KEYS
|
|
22
37
|
// ============================================================================
|
|
@@ -24,6 +39,7 @@ exports.userKeys = {
|
|
|
24
39
|
all: ['users'],
|
|
25
40
|
me: () => [...exports.userKeys.all, 'me'],
|
|
26
41
|
stats: () => [...exports.userKeys.me(), 'stats'],
|
|
42
|
+
spotsSummary: () => [...exports.userKeys.me(), 'spots-summary'],
|
|
27
43
|
activity: (limit) => [...exports.userKeys.me(), 'activity', limit],
|
|
28
44
|
posts: (params) => [...exports.userKeys.me(), 'posts', params],
|
|
29
45
|
clubs: () => [...exports.userKeys.me(), 'clubs'],
|
|
@@ -38,15 +54,24 @@ exports.userKeys = {
|
|
|
38
54
|
/**
|
|
39
55
|
* Get current user's profile
|
|
40
56
|
*
|
|
41
|
-
* @endpoint GET /
|
|
57
|
+
* @endpoint GET /users/me
|
|
42
58
|
*/
|
|
43
59
|
function useCurrentUser(options) {
|
|
44
60
|
return (0, react_query_1.useQuery)({
|
|
45
61
|
queryKey: exports.userKeys.me(),
|
|
46
62
|
queryFn: async () => {
|
|
63
|
+
console.log('[SDK-USERS] Fetching /users/me...');
|
|
47
64
|
const client = (0, client_1.getApiClient)();
|
|
48
|
-
|
|
49
|
-
|
|
65
|
+
try {
|
|
66
|
+
const response = await client.get('/users/me');
|
|
67
|
+
console.log('[SDK-USERS] Success:', response.status);
|
|
68
|
+
return response.data.data;
|
|
69
|
+
}
|
|
70
|
+
catch (error) {
|
|
71
|
+
const axiosError = error;
|
|
72
|
+
console.log('[SDK-USERS] Error:', axiosError.response?.status, 'URL:', axiosError.config?.baseURL, axiosError.config?.url);
|
|
73
|
+
throw error;
|
|
74
|
+
}
|
|
50
75
|
},
|
|
51
76
|
...options,
|
|
52
77
|
});
|
|
@@ -54,14 +79,37 @@ function useCurrentUser(options) {
|
|
|
54
79
|
/**
|
|
55
80
|
* Get current user's stats
|
|
56
81
|
*
|
|
57
|
-
* @endpoint GET /
|
|
82
|
+
* @endpoint GET /users/me/stats
|
|
83
|
+
* @deprecated This endpoint doesn't exist in the API. Use useUserSpotsSummary instead.
|
|
58
84
|
*/
|
|
59
85
|
function useUserStats(options) {
|
|
60
86
|
return (0, react_query_1.useQuery)({
|
|
61
87
|
queryKey: exports.userKeys.stats(),
|
|
62
88
|
queryFn: async () => {
|
|
63
89
|
const client = (0, client_1.getApiClient)();
|
|
64
|
-
const response = await client.get('/
|
|
90
|
+
const response = await client.get('/users/me/stats');
|
|
91
|
+
return response.data.data;
|
|
92
|
+
},
|
|
93
|
+
...options,
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Get current user's spots summary with activity indicators
|
|
98
|
+
*
|
|
99
|
+
* Returns list of spots where user has posted, with:
|
|
100
|
+
* - Post count per spot
|
|
101
|
+
* - Unread messages count
|
|
102
|
+
* - Pending responses count
|
|
103
|
+
* - Last activity timestamp
|
|
104
|
+
*
|
|
105
|
+
* @endpoint GET /users/me/spots-summary
|
|
106
|
+
*/
|
|
107
|
+
function useUserSpotsSummary(options) {
|
|
108
|
+
return (0, react_query_1.useQuery)({
|
|
109
|
+
queryKey: exports.userKeys.spotsSummary(),
|
|
110
|
+
queryFn: async () => {
|
|
111
|
+
const client = (0, client_1.getApiClient)();
|
|
112
|
+
const response = await client.get('/users/me/spots-summary');
|
|
65
113
|
return response.data.data;
|
|
66
114
|
},
|
|
67
115
|
...options,
|
|
@@ -70,15 +118,15 @@ function useUserStats(options) {
|
|
|
70
118
|
/**
|
|
71
119
|
* Get current user's activity
|
|
72
120
|
*
|
|
73
|
-
* @endpoint GET /
|
|
121
|
+
* @endpoint GET /users/me/activity
|
|
74
122
|
*/
|
|
75
123
|
function useUserActivity(limit = 10, options) {
|
|
76
124
|
return (0, react_query_1.useQuery)({
|
|
77
125
|
queryKey: exports.userKeys.activity(limit),
|
|
78
126
|
queryFn: async () => {
|
|
79
127
|
const client = (0, client_1.getApiClient)();
|
|
80
|
-
const response = await client.get(`/
|
|
81
|
-
return response.data.data;
|
|
128
|
+
const response = await client.get(`/users/me/activity?limit=${limit}`);
|
|
129
|
+
return extractArrayData(response.data.data);
|
|
82
130
|
},
|
|
83
131
|
...options,
|
|
84
132
|
});
|
|
@@ -86,7 +134,7 @@ function useUserActivity(limit = 10, options) {
|
|
|
86
134
|
/**
|
|
87
135
|
* Get current user's posts
|
|
88
136
|
*
|
|
89
|
-
* @endpoint GET /
|
|
137
|
+
* @endpoint GET /user/me/posts
|
|
90
138
|
*/
|
|
91
139
|
function useUserPosts(params, options) {
|
|
92
140
|
return (0, react_query_1.useQuery)({
|
|
@@ -98,8 +146,8 @@ function useUserPosts(params, options) {
|
|
|
98
146
|
queryParams.set('page', String(params.page));
|
|
99
147
|
if (params?.limit)
|
|
100
148
|
queryParams.set('limit', String(params.limit));
|
|
101
|
-
const response = await client.get(`/
|
|
102
|
-
return response.data.data;
|
|
149
|
+
const response = await client.get(`/user/me/posts?${queryParams}`);
|
|
150
|
+
return extractArrayData(response.data.data);
|
|
103
151
|
},
|
|
104
152
|
...options,
|
|
105
153
|
});
|
|
@@ -107,15 +155,15 @@ function useUserPosts(params, options) {
|
|
|
107
155
|
/**
|
|
108
156
|
* Get current user's clubs
|
|
109
157
|
*
|
|
110
|
-
* @endpoint GET /
|
|
158
|
+
* @endpoint GET /user/me/clubs
|
|
111
159
|
*/
|
|
112
160
|
function useUserClubs(options) {
|
|
113
161
|
return (0, react_query_1.useQuery)({
|
|
114
162
|
queryKey: exports.userKeys.clubs(),
|
|
115
163
|
queryFn: async () => {
|
|
116
164
|
const client = (0, client_1.getApiClient)();
|
|
117
|
-
const response = await client.get('/
|
|
118
|
-
return response.data.data;
|
|
165
|
+
const response = await client.get('/user/me/clubs');
|
|
166
|
+
return extractArrayData(response.data.data);
|
|
119
167
|
},
|
|
120
168
|
...options,
|
|
121
169
|
});
|
|
@@ -123,15 +171,15 @@ function useUserClubs(options) {
|
|
|
123
171
|
/**
|
|
124
172
|
* Get current user's spot subscriptions
|
|
125
173
|
*
|
|
126
|
-
* @endpoint GET /
|
|
174
|
+
* @endpoint GET /user/me/subscriptions
|
|
127
175
|
*/
|
|
128
176
|
function useUserSubscriptions(options) {
|
|
129
177
|
return (0, react_query_1.useQuery)({
|
|
130
178
|
queryKey: exports.userKeys.subscriptions(),
|
|
131
179
|
queryFn: async () => {
|
|
132
180
|
const client = (0, client_1.getApiClient)();
|
|
133
|
-
const response = await client.get('/
|
|
134
|
-
return response.data.data;
|
|
181
|
+
const response = await client.get('/user/me/subscriptions');
|
|
182
|
+
return extractArrayData(response.data.data);
|
|
135
183
|
},
|
|
136
184
|
...options,
|
|
137
185
|
});
|
|
@@ -139,15 +187,15 @@ function useUserSubscriptions(options) {
|
|
|
139
187
|
/**
|
|
140
188
|
* Get blocked users list
|
|
141
189
|
*
|
|
142
|
-
* @endpoint GET /
|
|
190
|
+
* @endpoint GET /user/me/blocked
|
|
143
191
|
*/
|
|
144
192
|
function useBlockedUsers(options) {
|
|
145
193
|
return (0, react_query_1.useQuery)({
|
|
146
194
|
queryKey: exports.userKeys.blocked(),
|
|
147
195
|
queryFn: async () => {
|
|
148
196
|
const client = (0, client_1.getApiClient)();
|
|
149
|
-
const response = await client.get('/
|
|
150
|
-
return response.data.data;
|
|
197
|
+
const response = await client.get('/user/me/blocked');
|
|
198
|
+
return extractArrayData(response.data.data);
|
|
151
199
|
},
|
|
152
200
|
...options,
|
|
153
201
|
});
|
|
@@ -155,15 +203,15 @@ function useBlockedUsers(options) {
|
|
|
155
203
|
/**
|
|
156
204
|
* Get current user's owned spots (for business owners)
|
|
157
205
|
*
|
|
158
|
-
* @endpoint GET /
|
|
206
|
+
* @endpoint GET /users/me/owned-spots
|
|
159
207
|
*/
|
|
160
208
|
function useOwnedSpots(options) {
|
|
161
209
|
return (0, react_query_1.useQuery)({
|
|
162
210
|
queryKey: exports.userKeys.ownedSpots(),
|
|
163
211
|
queryFn: async () => {
|
|
164
212
|
const client = (0, client_1.getApiClient)();
|
|
165
|
-
const response = await client.get('/
|
|
166
|
-
return response.data.data;
|
|
213
|
+
const response = await client.get('/users/me/owned-spots');
|
|
214
|
+
return extractArrayData(response.data.data);
|
|
167
215
|
},
|
|
168
216
|
...options,
|
|
169
217
|
});
|
|
@@ -171,17 +219,17 @@ function useOwnedSpots(options) {
|
|
|
171
219
|
/**
|
|
172
220
|
* Get current user's favorite spots
|
|
173
221
|
*
|
|
174
|
-
* @endpoint GET /
|
|
222
|
+
* @endpoint GET /users/me/favorites
|
|
175
223
|
*/
|
|
176
224
|
function useUserFavorites(options) {
|
|
177
225
|
return (0, react_query_1.useQuery)({
|
|
178
226
|
queryKey: exports.userKeys.favorites(),
|
|
179
227
|
queryFn: async () => {
|
|
180
228
|
const client = (0, client_1.getApiClient)();
|
|
181
|
-
const response = await client.get('/
|
|
182
|
-
return response.data.data;
|
|
229
|
+
const response = await client.get('/users/me/favorites');
|
|
230
|
+
return extractArrayData(response.data.data);
|
|
183
231
|
},
|
|
184
232
|
...options,
|
|
185
233
|
});
|
|
186
234
|
}
|
|
187
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"users.js","sourceRoot":"","sources":["../../../src/api/queries/users.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Users Query Hooks\n *\n * TanStack Query hooks for user-related operations.\n */\n\nimport { useQuery, UseQueryOptions, UseQueryResult } from '@tanstack/react-query';\nimport { getApiClient } from '../client';\nimport type { User, Post, Club, Spot, SpotSubscription, FavoriteSpot, ApiResponse } from '../types';\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const userKeys = {\n  all: ['users'] as const,\n  me: () => [...userKeys.all, 'me'] as const,\n  stats: () => [...userKeys.me(), 'stats'] as const,\n  activity: (limit?: number) => [...userKeys.me(), 'activity', limit] as const,\n  posts: (params?: { page?: number; limit?: number }) => [...userKeys.me(), 'posts', params] as const,\n  clubs: () => [...userKeys.me(), 'clubs'] as const,\n  subscriptions: () => [...userKeys.me(), 'subscriptions'] as const,\n  blocked: () => [...userKeys.me(), 'blocked'] as const,\n  ownedSpots: () => [...userKeys.me(), 'owned-spots'] as const,\n  favorites: () => [...userKeys.me(), 'favorites'] as const,\n};\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get current user's profile\n *\n * @endpoint GET /api/v1/users/me\n */\nexport function useCurrentUser(\n  options?: Omit<UseQueryOptions<User>, 'queryKey' | 'queryFn'>\n): UseQueryResult<User> {\n  return useQuery({\n    queryKey: userKeys.me(),\n    queryFn: async (): Promise<User> => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<User>>('/api/v1/users/me');\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get current user's stats\n *\n * @endpoint GET /api/v1/users/me/stats\n */\nexport function useUserStats(\n  options?: Omit<UseQueryOptions<{ posts: number; responses: number; upvotes: number }>, 'queryKey' | 'queryFn'>\n): UseQueryResult<{ posts: number; responses: number; upvotes: number }> {\n  return useQuery({\n    queryKey: userKeys.stats(),\n    queryFn: async () => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<{ posts: number; responses: number; upvotes: number }>>('/api/v1/users/me/stats');\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get current user's activity\n *\n * @endpoint GET /api/v1/users/me/activity\n */\nexport function useUserActivity(\n  limit: number = 10,\n  options?: Omit<UseQueryOptions<unknown[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<unknown[]> {\n  return useQuery({\n    queryKey: userKeys.activity(limit),\n    queryFn: async () => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<unknown[]>>(`/api/v1/users/me/activity?limit=${limit}`);\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get current user's posts\n *\n * @endpoint GET /api/v1/user/me/posts\n */\nexport function useUserPosts(\n  params?: { page?: number; limit?: number },\n  options?: Omit<UseQueryOptions<Post[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Post[]> {\n  return useQuery({\n    queryKey: userKeys.posts(params),\n    queryFn: async () => {\n      const client = getApiClient();\n      const queryParams = new URLSearchParams();\n      if (params?.page) queryParams.set('page', String(params.page));\n      if (params?.limit) queryParams.set('limit', String(params.limit));\n      const response = await client.get<ApiResponse<Post[]>>(`/api/v1/user/me/posts?${queryParams}`);\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get current user's clubs\n *\n * @endpoint GET /api/v1/user/me/clubs\n */\nexport function useUserClubs(\n  options?: Omit<UseQueryOptions<Club[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Club[]> {\n  return useQuery({\n    queryKey: userKeys.clubs(),\n    queryFn: async () => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<Club[]>>('/api/v1/user/me/clubs');\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get current user's spot subscriptions\n *\n * @endpoint GET /api/v1/user/me/subscriptions\n */\nexport function useUserSubscriptions(\n  options?: Omit<UseQueryOptions<SpotSubscription[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<SpotSubscription[]> {\n  return useQuery({\n    queryKey: userKeys.subscriptions(),\n    queryFn: async () => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<SpotSubscription[]>>('/api/v1/user/me/subscriptions');\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get blocked users list\n *\n * @endpoint GET /api/v1/user/me/blocked\n */\nexport function useBlockedUsers(\n  options?: Omit<UseQueryOptions<User[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<User[]> {\n  return useQuery({\n    queryKey: userKeys.blocked(),\n    queryFn: async () => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<User[]>>('/api/v1/user/me/blocked');\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get current user's owned spots (for business owners)\n *\n * @endpoint GET /api/v1/users/me/owned-spots\n */\nexport function useOwnedSpots(\n  options?: Omit<UseQueryOptions<Spot[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<Spot[]> {\n  return useQuery({\n    queryKey: userKeys.ownedSpots(),\n    queryFn: async () => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<Spot[]>>('/api/v1/users/me/owned-spots');\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n\n/**\n * Get current user's favorite spots\n *\n * @endpoint GET /api/v1/users/me/favorites\n */\nexport function useUserFavorites(\n  options?: Omit<UseQueryOptions<FavoriteSpot[]>, 'queryKey' | 'queryFn'>\n): UseQueryResult<FavoriteSpot[]> {\n  return useQuery({\n    queryKey: userKeys.favorites(),\n    queryFn: async () => {\n      const client = getApiClient();\n      const response = await client.get<ApiResponse<FavoriteSpot[]>>('/api/v1/users/me/favorites');\n      return response.data.data;\n    },\n    ...options,\n  });\n}\n"]}
|
|
235
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"users.js","sourceRoot":"","sources":["../../../src/api/queries/users.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Users Query Hooks\n *\n * TanStack Query hooks for user-related operations.\n */\n\nimport {\n  useQuery,\n  type UseQueryOptions,\n  type UseQueryResult,\n} from '@tanstack/react-query'\n\nimport {getApiClient} from '../client'\nimport {\n  type ApiResponse,\n  type Club,\n  type FavoriteSpot,\n  type Post,\n  type Spot,\n  type SpotsSummaryResponse,\n  type SpotSubscription,\n  type User,\n} from '../types'\n\n// Helper to extract array data from API response\n// API can return either { data: T[] } or { data: { data: T[], meta?: {...} } }\nfunction extractArrayData<T>(data: unknown): T[] {\n  if (Array.isArray(data)) {\n    return data\n  }\n  if (data && typeof data === 'object' && 'data' in data) {\n    const nested = (data as {data: unknown}).data\n    if (Array.isArray(nested)) {\n      return nested\n    }\n  }\n  return []\n}\n\n// ============================================================================\n// QUERY KEYS\n// ============================================================================\n\nexport const userKeys = {\n  all: ['users'] as const,\n  me: () => [...userKeys.all, 'me'] as const,\n  stats: () => [...userKeys.me(), 'stats'] as const,\n  spotsSummary: () => [...userKeys.me(), 'spots-summary'] as const,\n  activity: (limit?: number) => [...userKeys.me(), 'activity', limit] as const,\n  posts: (params?: {page?: number; limit?: number}) =>\n    [...userKeys.me(), 'posts', params] as const,\n  clubs: () => [...userKeys.me(), 'clubs'] as const,\n  subscriptions: () => [...userKeys.me(), 'subscriptions'] as const,\n  blocked: () => [...userKeys.me(), 'blocked'] as const,\n  ownedSpots: () => [...userKeys.me(), 'owned-spots'] as const,\n  favorites: () => [...userKeys.me(), 'favorites'] as const,\n}\n\n// ============================================================================\n// QUERY HOOKS\n// ============================================================================\n\n/**\n * Get current user's profile\n *\n * @endpoint GET /users/me\n */\nexport function useCurrentUser(\n  options?: Omit<UseQueryOptions<User>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<User> {\n  return useQuery({\n    queryKey: userKeys.me(),\n    queryFn: async (): Promise<User> => {\n      console.log('[SDK-USERS] Fetching /users/me...')\n      const client = getApiClient()\n      try {\n        const response = await client.get<ApiResponse<User>>('/users/me')\n        console.log('[SDK-USERS] Success:', response.status)\n        return response.data.data\n      } catch (error: unknown) {\n        const axiosError = error as {\n          response?: {status: number}\n          config?: {url: string; baseURL?: string}\n        }\n        console.log(\n          '[SDK-USERS] Error:',\n          axiosError.response?.status,\n          'URL:',\n          axiosError.config?.baseURL,\n          axiosError.config?.url,\n        )\n        throw error\n      }\n    },\n    ...options,\n  })\n}\n\n/**\n * Get current user's stats\n *\n * @endpoint GET /users/me/stats\n * @deprecated This endpoint doesn't exist in the API. Use useUserSpotsSummary instead.\n */\nexport function useUserStats(\n  options?: Omit<\n    UseQueryOptions<{posts: number; responses: number; upvotes: number}>,\n    'queryKey' | 'queryFn'\n  >,\n): UseQueryResult<{posts: number; responses: number; upvotes: number}> {\n  return useQuery({\n    queryKey: userKeys.stats(),\n    queryFn: async () => {\n      const client = getApiClient()\n      const response =\n        await client.get<\n          ApiResponse<{posts: number; responses: number; upvotes: number}>\n        >('/users/me/stats')\n      return response.data.data\n    },\n    ...options,\n  })\n}\n\n/**\n * Get current user's spots summary with activity indicators\n *\n * Returns list of spots where user has posted, with:\n * - Post count per spot\n * - Unread messages count\n * - Pending responses count\n * - Last activity timestamp\n *\n * @endpoint GET /users/me/spots-summary\n */\nexport function useUserSpotsSummary(\n  options?: Omit<UseQueryOptions<SpotsSummaryResponse>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<SpotsSummaryResponse> {\n  return useQuery({\n    queryKey: userKeys.spotsSummary(),\n    queryFn: async () => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<SpotsSummaryResponse>>(\n        '/users/me/spots-summary',\n      )\n      return response.data.data\n    },\n    ...options,\n  })\n}\n\n/**\n * Get current user's activity\n *\n * @endpoint GET /users/me/activity\n */\nexport function useUserActivity(\n  limit: number = 10,\n  options?: Omit<UseQueryOptions<unknown[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<unknown[]> {\n  return useQuery({\n    queryKey: userKeys.activity(limit),\n    queryFn: async () => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<unknown>>(\n        `/users/me/activity?limit=${limit}`,\n      )\n      return extractArrayData<unknown>(response.data.data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Get current user's posts\n *\n * @endpoint GET /user/me/posts\n */\nexport function useUserPosts(\n  params?: {page?: number; limit?: number},\n  options?: Omit<UseQueryOptions<Post[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Post[]> {\n  return useQuery({\n    queryKey: userKeys.posts(params),\n    queryFn: async () => {\n      const client = getApiClient()\n      const queryParams = new URLSearchParams()\n      if (params?.page) queryParams.set('page', String(params.page))\n      if (params?.limit) queryParams.set('limit', String(params.limit))\n      const response = await client.get<ApiResponse<unknown>>(\n        `/user/me/posts?${queryParams}`,\n      )\n      return extractArrayData<Post>(response.data.data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Get current user's clubs\n *\n * @endpoint GET /user/me/clubs\n */\nexport function useUserClubs(\n  options?: Omit<UseQueryOptions<Club[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Club[]> {\n  return useQuery({\n    queryKey: userKeys.clubs(),\n    queryFn: async () => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<unknown>>('/user/me/clubs')\n      return extractArrayData<Club>(response.data.data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Get current user's spot subscriptions\n *\n * @endpoint GET /user/me/subscriptions\n */\nexport function useUserSubscriptions(\n  options?: Omit<UseQueryOptions<SpotSubscription[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<SpotSubscription[]> {\n  return useQuery({\n    queryKey: userKeys.subscriptions(),\n    queryFn: async () => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<unknown>>(\n        '/user/me/subscriptions',\n      )\n      return extractArrayData<SpotSubscription>(response.data.data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Get blocked users list\n *\n * @endpoint GET /user/me/blocked\n */\nexport function useBlockedUsers(\n  options?: Omit<UseQueryOptions<User[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<User[]> {\n  return useQuery({\n    queryKey: userKeys.blocked(),\n    queryFn: async () => {\n      const client = getApiClient()\n      const response =\n        await client.get<ApiResponse<unknown>>('/user/me/blocked')\n      return extractArrayData<User>(response.data.data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Get current user's owned spots (for business owners)\n *\n * @endpoint GET /users/me/owned-spots\n */\nexport function useOwnedSpots(\n  options?: Omit<UseQueryOptions<Spot[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<Spot[]> {\n  return useQuery({\n    queryKey: userKeys.ownedSpots(),\n    queryFn: async () => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<unknown>>(\n        '/users/me/owned-spots',\n      )\n      return extractArrayData<Spot>(response.data.data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Get current user's favorite spots\n *\n * @endpoint GET /users/me/favorites\n */\nexport function useUserFavorites(\n  options?: Omit<UseQueryOptions<FavoriteSpot[]>, 'queryKey' | 'queryFn'>,\n): UseQueryResult<FavoriteSpot[]> {\n  return useQuery({\n    queryKey: userKeys.favorites(),\n    queryFn: async () => {\n      const client = getApiClient()\n      const response = await client.get<ApiResponse<unknown>>(\n        '/users/me/favorites',\n      )\n      return extractArrayData<FavoriteSpot>(response.data.data)\n    },\n    ...options,\n  })\n}\n"]}
|
package/dist/api/types.d.ts
CHANGED
|
@@ -2,42 +2,15 @@
|
|
|
2
2
|
* Spots SDK Types
|
|
3
3
|
*
|
|
4
4
|
* Type sources:
|
|
5
|
-
* - Entity types (User, Spot, Post, etc.) →
|
|
6
|
-
* - DTO types (CreatePostDto, etc.) → import from @
|
|
5
|
+
* - Entity types (User, Spot, Post, etc.) → from ./entities (local definitions)
|
|
6
|
+
* - DTO types (CreatePostDto, etc.) → import from @spots/types (OpenAPI generated)
|
|
7
7
|
*
|
|
8
|
-
* This file provides type aliases for SDK convenience
|
|
9
|
-
* single sources of truth:
|
|
10
|
-
* - Prisma schema for entities
|
|
11
|
-
* - OpenAPI spec for DTOs
|
|
8
|
+
* This file provides type aliases for SDK convenience.
|
|
12
9
|
*/
|
|
13
|
-
/**
|
|
14
|
-
* Standard API response wrapper from ResponseInterceptor
|
|
15
|
-
* All API responses are wrapped in this format
|
|
16
|
-
*/
|
|
17
|
-
export interface ApiResponse<T> {
|
|
18
|
-
success: boolean;
|
|
19
|
-
data: T;
|
|
20
|
-
timestamp: string;
|
|
21
|
-
}
|
|
22
|
-
/**
|
|
23
|
-
* Paginated response for list endpoints
|
|
24
|
-
* Used inside ApiResponse.data for paginated queries
|
|
25
|
-
*/
|
|
26
|
-
export interface PaginatedResponse<T> {
|
|
27
|
-
data: T[];
|
|
28
|
-
meta: {
|
|
29
|
-
total: number;
|
|
30
|
-
page: number;
|
|
31
|
-
limit: number;
|
|
32
|
-
totalPages: number;
|
|
33
|
-
hasNextPage: boolean;
|
|
34
|
-
hasPreviousPage: boolean;
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
10
|
export * from '@spotsdev/types';
|
|
38
|
-
export
|
|
39
|
-
import type
|
|
40
|
-
import type
|
|
11
|
+
export * from './entities';
|
|
12
|
+
import { type ClaimSpotDto, type CreateConversationDto, type CreateMessageDto, type CreatePostDto, type CreateReplyDto, type CreateResponseDto, type SendOtpDto, type UpdateResponseDto, type UpdateUserDto, type UpvoteResponseDto, type VerifyOtpDto, type VerifyOtpWrappedResponseDto } from '@spotsdev/types';
|
|
13
|
+
import { type PostTemplate, type SpotPost } from './entities';
|
|
41
14
|
export type SendOtpRequest = SendOtpDto;
|
|
42
15
|
export type VerifyOtpRequest = VerifyOtpDto;
|
|
43
16
|
export type CreatePostRequest = CreatePostDto;
|
|
@@ -52,3 +25,33 @@ export type UpvoteResponse = UpvoteResponseDto;
|
|
|
52
25
|
export type AuthResponse = VerifyOtpWrappedResponseDto;
|
|
53
26
|
export type Post = SpotPost;
|
|
54
27
|
export type Template = PostTemplate;
|
|
28
|
+
/**
|
|
29
|
+
* Spot summary with activity indicators
|
|
30
|
+
* Returned by /users/me/spots-summary
|
|
31
|
+
*/
|
|
32
|
+
export interface SpotSummary {
|
|
33
|
+
spotId: string;
|
|
34
|
+
spotName: string;
|
|
35
|
+
spotSlug: string;
|
|
36
|
+
spotType: string;
|
|
37
|
+
postCount: number;
|
|
38
|
+
unreadMessages: number;
|
|
39
|
+
pendingResponses: number;
|
|
40
|
+
lastActivity: string | null;
|
|
41
|
+
hasNewActivity: boolean;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Response meta for spots summary
|
|
45
|
+
*/
|
|
46
|
+
export interface SpotsSummaryMeta {
|
|
47
|
+
totalSpots: number;
|
|
48
|
+
totalUnreadMessages: number;
|
|
49
|
+
totalPendingResponses: number;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Full response from /users/me/spots-summary
|
|
53
|
+
*/
|
|
54
|
+
export interface SpotsSummaryResponse {
|
|
55
|
+
data: SpotSummary[];
|
|
56
|
+
meta: SpotsSummaryMeta;
|
|
57
|
+
}
|
package/dist/api/types.js
CHANGED
|
@@ -3,13 +3,10 @@
|
|
|
3
3
|
* Spots SDK Types
|
|
4
4
|
*
|
|
5
5
|
* Type sources:
|
|
6
|
-
* - Entity types (User, Spot, Post, etc.) →
|
|
7
|
-
* - DTO types (CreatePostDto, etc.) → import from @
|
|
6
|
+
* - Entity types (User, Spot, Post, etc.) → from ./entities (local definitions)
|
|
7
|
+
* - DTO types (CreatePostDto, etc.) → import from @spots/types (OpenAPI generated)
|
|
8
8
|
*
|
|
9
|
-
* This file provides type aliases for SDK convenience
|
|
10
|
-
* single sources of truth:
|
|
11
|
-
* - Prisma schema for entities
|
|
12
|
-
* - OpenAPI spec for DTOs
|
|
9
|
+
* This file provides type aliases for SDK convenience.
|
|
13
10
|
*/
|
|
14
11
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
15
12
|
if (k2 === undefined) k2 = k;
|
|
@@ -31,4 +28,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
31
28
|
// ============================================================================
|
|
32
29
|
// Re-export all DTO types from @spotsdev/types (OpenAPI generated)
|
|
33
30
|
__exportStar(require("@spotsdev/types"), exports);
|
|
34
|
-
|
|
31
|
+
// Re-export entity types from local entities file (Prisma-compatible but no Prisma dep)
|
|
32
|
+
__exportStar(require("./entities"), exports);
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXBpL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7R0FRRzs7Ozs7Ozs7Ozs7Ozs7OztBQUVILCtFQUErRTtBQUMvRSwwQkFBMEI7QUFDMUIsK0VBQStFO0FBRS9FLG1FQUFtRTtBQUNuRSxrREFBK0I7QUFFL0Isd0ZBQXdGO0FBQ3hGLDZDQUEwQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogU3BvdHMgU0RLIFR5cGVzXG4gKlxuICogVHlwZSBzb3VyY2VzOlxuICogLSBFbnRpdHkgdHlwZXMgKFVzZXIsIFNwb3QsIFBvc3QsIGV0Yy4pIOKGkiBmcm9tIC4vZW50aXRpZXMgKGxvY2FsIGRlZmluaXRpb25zKVxuICogLSBEVE8gdHlwZXMgKENyZWF0ZVBvc3REdG8sIGV0Yy4pIOKGkiBpbXBvcnQgZnJvbSBAc3BvdHMvdHlwZXMgKE9wZW5BUEkgZ2VuZXJhdGVkKVxuICpcbiAqIFRoaXMgZmlsZSBwcm92aWRlcyB0eXBlIGFsaWFzZXMgZm9yIFNESyBjb252ZW5pZW5jZS5cbiAqL1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBSRS1FWFBPUlRTIEZST00gU09VUkNFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vLyBSZS1leHBvcnQgYWxsIERUTyB0eXBlcyBmcm9tIEBzcG90c2Rldi90eXBlcyAoT3BlbkFQSSBnZW5lcmF0ZWQpXG5leHBvcnQgKiBmcm9tICdAc3BvdHNkZXYvdHlwZXMnXG5cbi8vIFJlLWV4cG9ydCBlbnRpdHkgdHlwZXMgZnJvbSBsb2NhbCBlbnRpdGllcyBmaWxlIChQcmlzbWEtY29tcGF0aWJsZSBidXQgbm8gUHJpc21hIGRlcClcbmV4cG9ydCAqIGZyb20gJy4vZW50aXRpZXMnXG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFNESyBUWVBFIEFMSUFTRVNcbi8vIFRoZXNlIHByb3ZpZGUgY29udmVuaWVudCBuYW1lcyB0aGF0IG1hdGNoIFNESyB1c2FnZSBwYXR0ZXJuc1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG5pbXBvcnQge1xuICB0eXBlIENsYWltU3BvdER0byxcbiAgdHlwZSBDcmVhdGVDb252ZXJzYXRpb25EdG8sXG4gIHR5cGUgQ3JlYXRlTWVzc2FnZUR0byxcbiAgdHlwZSBDcmVhdGVQb3N0RHRvLFxuICB0eXBlIENyZWF0ZVJlcGx5RHRvLFxuICB0eXBlIENyZWF0ZVJlc3BvbnNlRHRvLFxuICB0eXBlIFNlbmRPdHBEdG8sXG4gIHR5cGUgVXBkYXRlUmVzcG9uc2VEdG8sXG4gIHR5cGUgVXBkYXRlVXNlckR0byxcbiAgdHlwZSBVcHZvdGVSZXNwb25zZUR0byxcbiAgdHlwZSBWZXJpZnlPdHBEdG8sXG4gIHR5cGUgVmVyaWZ5T3RwV3JhcHBlZFJlc3BvbnNlRHRvLFxufSBmcm9tICdAc3BvdHNkZXYvdHlwZXMnXG5cbmltcG9ydCB7dHlwZSBQb3N0VGVtcGxhdGUsIHR5cGUgU3BvdFBvc3R9IGZyb20gJy4vZW50aXRpZXMnXG5cbi8vIFJlcXVlc3QgdHlwZSBhbGlhc2VzIChtYXAgdG8gRFRPcylcbmV4cG9ydCB0eXBlIFNlbmRPdHBSZXF1ZXN0ID0gU2VuZE90cER0b1xuZXhwb3J0IHR5cGUgVmVyaWZ5T3RwUmVxdWVzdCA9IFZlcmlmeU90cER0b1xuZXhwb3J0IHR5cGUgQ3JlYXRlUG9zdFJlcXVlc3QgPSBDcmVhdGVQb3N0RHRvXG5leHBvcnQgdHlwZSBDcmVhdGVSZXBseVJlcXVlc3QgPSBDcmVhdGVSZXBseUR0b1xuZXhwb3J0IHR5cGUgUmVzcG9uZFRvUG9zdFJlcXVlc3QgPSBDcmVhdGVSZXNwb25zZUR0b1xuZXhwb3J0IHR5cGUgVXBkYXRlUmVzcG9uc2VSZXF1ZXN0ID0gVXBkYXRlUmVzcG9uc2VEdG9cbmV4cG9ydCB0eXBlIFVwZGF0ZVByb2ZpbGVSZXF1ZXN0ID0gVXBkYXRlVXNlckR0b1xuZXhwb3J0IHR5cGUgQ3JlYXRlQ29udmVyc2F0aW9uUmVxdWVzdCA9IENyZWF0ZUNvbnZlcnNhdGlvbkR0b1xuZXhwb3J0IHR5cGUgU2VuZE1lc3NhZ2VSZXF1ZXN0ID0gQ3JlYXRlTWVzc2FnZUR0b1xuZXhwb3J0IHR5cGUgQ2xhaW1TcG90UmVxdWVzdCA9IENsYWltU3BvdER0b1xuXG4vLyBSZXNwb25zZSB0eXBlIGFsaWFzZXNcbmV4cG9ydCB0eXBlIFVwdm90ZVJlc3BvbnNlID0gVXB2b3RlUmVzcG9uc2VEdG9cbmV4cG9ydCB0eXBlIEF1dGhSZXNwb25zZSA9IFZlcmlmeU90cFdyYXBwZWRSZXNwb25zZUR0b1xuXG4vLyBFbnRpdHkgdHlwZSBhbGlhc2VzIChmb3IgYmFja3dhcmQgY29tcGF0aWJpbGl0eSlcbmV4cG9ydCB0eXBlIFBvc3QgPSBTcG90UG9zdFxuZXhwb3J0IHR5cGUgVGVtcGxhdGUgPSBQb3N0VGVtcGxhdGVcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gU0RLLVNQRUNJRklDIFRZUEVTIChub3QgZnJvbSBlbnRpdGllcyBvciBEVE9zKVxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKipcbiAqIFNwb3Qgc3VtbWFyeSB3aXRoIGFjdGl2aXR5IGluZGljYXRvcnNcbiAqIFJldHVybmVkIGJ5IC91c2Vycy9tZS9zcG90cy1zdW1tYXJ5XG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3BvdFN1bW1hcnkge1xuICBzcG90SWQ6IHN0cmluZ1xuICBzcG90TmFtZTogc3RyaW5nXG4gIHNwb3RTbHVnOiBzdHJpbmdcbiAgc3BvdFR5cGU6IHN0cmluZ1xuICBwb3N0Q291bnQ6IG51bWJlclxuICB1bnJlYWRNZXNzYWdlczogbnVtYmVyXG4gIHBlbmRpbmdSZXNwb25zZXM6IG51bWJlclxuICBsYXN0QWN0aXZpdHk6IHN0cmluZyB8IG51bGxcbiAgaGFzTmV3QWN0aXZpdHk6IGJvb2xlYW5cbn1cblxuLyoqXG4gKiBSZXNwb25zZSBtZXRhIGZvciBzcG90cyBzdW1tYXJ5XG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3BvdHNTdW1tYXJ5TWV0YSB7XG4gIHRvdGFsU3BvdHM6IG51bWJlclxuICB0b3RhbFVucmVhZE1lc3NhZ2VzOiBudW1iZXJcbiAgdG90YWxQZW5kaW5nUmVzcG9uc2VzOiBudW1iZXJcbn1cblxuLyoqXG4gKiBGdWxsIHJlc3BvbnNlIGZyb20gL3VzZXJzL21lL3Nwb3RzLXN1bW1hcnlcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTcG90c1N1bW1hcnlSZXNwb25zZSB7XG4gIGRhdGE6IFNwb3RTdW1tYXJ5W11cbiAgbWV0YTogU3BvdHNTdW1tYXJ5TWV0YVxufVxuIl19
|