@spotsdev/sdk 1.0.0 → 1.2.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 +318 -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 +424 -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
@@ -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 (flat array - reference data)
29
+ * Get all templates
32
30
  *
33
- * @endpoint GET /api/v1/templates
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(`/api/v1/templates?${queryParams}`);
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 /api/v1/templates/{templateId}
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(`/api/v1/templates/${templateId}`);
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 /api/v1/templates/slug/{slug}
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(`/api/v1/templates/slug/${slug}`);
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwaS9xdWVyaWVzL3RlbXBsYXRlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7OztHQU1HOzs7QUE2Qkgsb0NBaUJDO0FBT0Qsa0NBY0M7QUFPRCw4Q0FjQztBQXRGRCx1REFBa0Y7QUFDbEYsc0NBQXlDO0FBR3pDLCtFQUErRTtBQUMvRSxhQUFhO0FBQ2IsK0VBQStFO0FBRWxFLFFBQUEsWUFBWSxHQUFHO0lBQzFCLEdBQUcsRUFBRSxDQUFDLFdBQVcsQ0FBVTtJQUMzQixLQUFLLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxHQUFHLG9CQUFZLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBVTtJQUNuRCxJQUFJLEVBQUUsQ0FBQyxPQUErQixFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsb0JBQVksQ0FBQyxLQUFLLEVBQUUsRUFBRSxPQUFPLENBQVU7SUFDdEYsT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsR0FBRyxvQkFBWSxDQUFDLEdBQUcsRUFBRSxRQUFRLENBQVU7SUFDdkQsTUFBTSxFQUFFLENBQUMsRUFBVSxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsb0JBQVksQ0FBQyxPQUFPLEVBQUUsRUFBRSxFQUFFLENBQVU7SUFDaEUsTUFBTSxFQUFFLENBQUMsSUFBWSxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsb0JBQVksQ0FBQyxHQUFHLEVBQUUsTUFBTSxFQUFFLElBQUksQ0FBVTtDQUN2RSxDQUFDO0FBRUYsK0VBQStFO0FBQy9FLGNBQWM7QUFDZCwrRUFBK0U7QUFFL0U7Ozs7O0dBS0c7QUFDSCxTQUFnQixZQUFZLENBQzFCLE1BQThCLEVBQzlCLE9BQW1FO0lBRW5FLE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLG9CQUFZLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUNuQyxPQUFPLEVBQUUsS0FBSyxJQUF5QixFQUFFO1lBQ3ZDLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFDO1lBQzlCLE1BQU0sV0FBVyxHQUFHLElBQUksZUFBZSxFQUFFLENBQUM7WUFDMUMsSUFBSSxNQUFNLEVBQUUsUUFBUTtnQkFBRSxXQUFXLENBQUMsR0FBRyxDQUFDLFVBQVUsRUFBRSxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDbkUsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUEwQixxQkFBcUIsV0FBVyxFQUFFLENBQUMsQ0FBQztZQUMvRixzREFBc0Q7WUFDdEQsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztRQUM1QixDQUFDO1FBQ0QsU0FBUyxFQUFFLElBQUksR0FBRyxFQUFFLEdBQUcsRUFBRSxFQUFFLG9DQUFvQztRQUMvRCxHQUFHLE9BQU87S0FDWCxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLFdBQVcsQ0FDekIsVUFBa0IsRUFDbEIsT0FBaUU7SUFFakUsT0FBTyxJQUFBLHNCQUFRLEVBQUM7UUFDZCxRQUFRLEVBQUUsb0JBQVksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDO1FBQ3pDLE9BQU8sRUFBRSxLQUFLLElBQXVCLEVBQUU7WUFDckMsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUM7WUFDOUIsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUF3QixxQkFBcUIsVUFBVSxFQUFFLENBQUMsQ0FBQztZQUM1RixPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQzVCLENBQUM7UUFDRCxPQUFPLEVBQUUsQ0FBQyxDQUFDLFVBQVU7UUFDckIsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQixpQkFBaUIsQ0FDL0IsSUFBWSxFQUNaLE9BQWlFO0lBRWpFLE9BQU8sSUFBQSxzQkFBUSxFQUFDO1FBQ2QsUUFBUSxFQUFFLG9CQUFZLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQztRQUNuQyxPQUFPLEVBQUUsS0FBSyxJQUF1QixFQUFFO1lBQ3JDLE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFDO1lBQzlCLE1BQU0sUUFBUSxHQUFHLE1BQU0sTUFBTSxDQUFDLEdBQUcsQ0FBd0IsMEJBQTBCLElBQUksRUFBRSxDQUFDLENBQUM7WUFDM0YsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztRQUM1QixDQUFDO1FBQ0QsT0FBTyxFQUFFLENBQUMsQ0FBQyxJQUFJO1FBQ2YsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVGVtcGxhdGVzIFF1ZXJ5IEhvb2tzXG4gKlxuICogVGFuU3RhY2sgUXVlcnkgaG9va3MgZm9yIHBvc3QgdGVtcGxhdGUgb3BlcmF0aW9ucy5cbiAqXG4gKiBUZW1wbGF0ZXMgYXJlIHJlZmVyZW5jZSBkYXRhIChmbGF0IGFycmF5KSwgbm90IHBhZ2luYXRlZC5cbiAqL1xuXG5pbXBvcnQgeyB1c2VRdWVyeSwgVXNlUXVlcnlPcHRpb25zLCBVc2VRdWVyeVJlc3VsdCB9IGZyb20gJ0B0YW5zdGFjay9yZWFjdC1xdWVyeSc7XG5pbXBvcnQgeyBnZXRBcGlDbGllbnQgfSBmcm9tICcuLi9jbGllbnQnO1xuaW1wb3J0IHR5cGUgeyBUZW1wbGF0ZSwgQXBpUmVzcG9uc2UgfSBmcm9tICcuLi90eXBlcyc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFFVRVJZIEtFWVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuZXhwb3J0IGNvbnN0IHRlbXBsYXRlS2V5cyA9IHtcbiAgYWxsOiBbJ3RlbXBsYXRlcyddIGFzIGNvbnN0LFxuICBsaXN0czogKCkgPT4gWy4uLnRlbXBsYXRlS2V5cy5hbGwsICdsaXN0J10gYXMgY29uc3QsXG4gIGxpc3Q6IChmaWx0ZXJzPzogeyBzcG90VHlwZT86IHN0cmluZyB9KSA9PiBbLi4udGVtcGxhdGVLZXlzLmxpc3RzKCksIGZpbHRlcnNdIGFzIGNvbnN0LFxuICBkZXRhaWxzOiAoKSA9PiBbLi4udGVtcGxhdGVLZXlzLmFsbCwgJ2RldGFpbCddIGFzIGNvbnN0LFxuICBkZXRhaWw6IChpZDogc3RyaW5nKSA9PiBbLi4udGVtcGxhdGVLZXlzLmRldGFpbHMoKSwgaWRdIGFzIGNvbnN0LFxuICBieVNsdWc6IChzbHVnOiBzdHJpbmcpID0+IFsuLi50ZW1wbGF0ZUtleXMuYWxsLCAnc2x1ZycsIHNsdWddIGFzIGNvbnN0LFxufTtcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gUVVFUlkgSE9PS1Ncbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBHZXQgYWxsIHRlbXBsYXRlcyAoZmxhdCBhcnJheSAtIHJlZmVyZW5jZSBkYXRhKVxuICpcbiAqIEBlbmRwb2ludCBHRVQgL2FwaS92MS90ZW1wbGF0ZXNcbiAqIEByZXR1cm5zIEZsYXQgYXJyYXkgb2YgdGVtcGxhdGVzIChub3QgcGFnaW5hdGVkKVxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlVGVtcGxhdGVzKFxuICBwYXJhbXM/OiB7IHNwb3RUeXBlPzogc3RyaW5nIH0sXG4gIG9wdGlvbnM/OiBPbWl0PFVzZVF1ZXJ5T3B0aW9uczxUZW1wbGF0ZVtdPiwgJ3F1ZXJ5S2V5JyB8ICdxdWVyeUZuJz5cbik6IFVzZVF1ZXJ5UmVzdWx0PFRlbXBsYXRlW10+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogdGVtcGxhdGVLZXlzLmxpc3QocGFyYW1zKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxUZW1wbGF0ZVtdPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHF1ZXJ5UGFyYW1zID0gbmV3IFVSTFNlYXJjaFBhcmFtcygpO1xuICAgICAgaWYgKHBhcmFtcz8uc3BvdFR5cGUpIHF1ZXJ5UGFyYW1zLnNldCgnc3BvdFR5cGUnLCBwYXJhbXMuc3BvdFR5cGUpO1xuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0PEFwaVJlc3BvbnNlPFRlbXBsYXRlW10+PihgL2FwaS92MS90ZW1wbGF0ZXM/JHtxdWVyeVBhcmFtc31gKTtcbiAgICAgIC8vIFRlbXBsYXRlcyBlbmRwb2ludCByZXR1cm5zIGZsYXQgYXJyYXk6IHsgZGF0YTogW10gfVxuICAgICAgcmV0dXJuIHJlc3BvbnNlLmRhdGEuZGF0YTtcbiAgICB9LFxuICAgIHN0YWxlVGltZTogMTAwMCAqIDYwICogNjAsIC8vIENhY2hlIGZvciAxIGhvdXIgKHJlZmVyZW5jZSBkYXRhKVxuICAgIC4uLm9wdGlvbnMsXG4gIH0pO1xufVxuXG4vKipcbiAqIEdldCBhIHRlbXBsYXRlIGJ5IElEXG4gKlxuICogQGVuZHBvaW50IEdFVCAvYXBpL3YxL3RlbXBsYXRlcy97dGVtcGxhdGVJZH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVRlbXBsYXRlKFxuICB0ZW1wbGF0ZUlkOiBzdHJpbmcsXG4gIG9wdGlvbnM/OiBPbWl0PFVzZVF1ZXJ5T3B0aW9uczxUZW1wbGF0ZT4sICdxdWVyeUtleScgfCAncXVlcnlGbic+XG4pOiBVc2VRdWVyeVJlc3VsdDxUZW1wbGF0ZT4ge1xuICByZXR1cm4gdXNlUXVlcnkoe1xuICAgIHF1ZXJ5S2V5OiB0ZW1wbGF0ZUtleXMuZGV0YWlsKHRlbXBsYXRlSWQpLFxuICAgIHF1ZXJ5Rm46IGFzeW5jICgpOiBQcm9taXNlPFRlbXBsYXRlPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LmdldDxBcGlSZXNwb25zZTxUZW1wbGF0ZT4+KGAvYXBpL3YxL3RlbXBsYXRlcy8ke3RlbXBsYXRlSWR9YCk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhO1xuICAgIH0sXG4gICAgZW5hYmxlZDogISF0ZW1wbGF0ZUlkLFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pO1xufVxuXG4vKipcbiAqIEdldCBhIHRlbXBsYXRlIGJ5IHNsdWdcbiAqXG4gKiBAZW5kcG9pbnQgR0VUIC9hcGkvdjEvdGVtcGxhdGVzL3NsdWcve3NsdWd9XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VUZW1wbGF0ZUJ5U2x1ZyhcbiAgc2x1Zzogc3RyaW5nLFxuICBvcHRpb25zPzogT21pdDxVc2VRdWVyeU9wdGlvbnM8VGVtcGxhdGU+LCAncXVlcnlLZXknIHwgJ3F1ZXJ5Rm4nPlxuKTogVXNlUXVlcnlSZXN1bHQ8VGVtcGxhdGU+IHtcbiAgcmV0dXJuIHVzZVF1ZXJ5KHtcbiAgICBxdWVyeUtleTogdGVtcGxhdGVLZXlzLmJ5U2x1ZyhzbHVnKSxcbiAgICBxdWVyeUZuOiBhc3luYyAoKTogUHJvbWlzZTxUZW1wbGF0ZT4gPT4ge1xuICAgICAgY29uc3QgY2xpZW50ID0gZ2V0QXBpQ2xpZW50KCk7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5nZXQ8QXBpUmVzcG9uc2U8VGVtcGxhdGU+PihgL2FwaS92MS90ZW1wbGF0ZXMvc2x1Zy8ke3NsdWd9YCk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhO1xuICAgIH0sXG4gICAgZW5hYmxlZDogISFzbHVnLFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pO1xufVxuIl19
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 { User, Post, Club, Spot, SpotSubscription, FavoriteSpot } from '../types';
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 /api/v1/users/me
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 /api/v1/users/me/stats
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 /api/v1/users/me/activity
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 /api/v1/user/me/posts
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 /api/v1/user/me/clubs
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 /api/v1/user/me/subscriptions
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 /api/v1/user/me/blocked
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 /api/v1/users/me/owned-spots
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 /api/v1/users/me/favorites
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 /api/v1/users/me
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
- const response = await client.get('/api/v1/users/me');
49
- return response.data.data;
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 /api/v1/users/me/stats
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('/api/v1/users/me/stats');
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 /api/v1/users/me/activity
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(`/api/v1/users/me/activity?limit=${limit}`);
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 /api/v1/user/me/posts
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(`/api/v1/user/me/posts?${queryParams}`);
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 /api/v1/user/me/clubs
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('/api/v1/user/me/clubs');
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 /api/v1/user/me/subscriptions
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('/api/v1/user/me/subscriptions');
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 /api/v1/user/me/blocked
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('/api/v1/user/me/blocked');
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 /api/v1/users/me/owned-spots
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('/api/v1/users/me/owned-spots');
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 /api/v1/users/me/favorites
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('/api/v1/users/me/favorites');
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"]}
@@ -2,42 +2,15 @@
2
2
  * Spots SDK Types
3
3
  *
4
4
  * Type sources:
5
- * - Entity types (User, Spot, Post, etc.) → import from @prisma/client
6
- * - DTO types (CreatePostDto, etc.) → import from @spotsdev/types
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 while maintaining
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 type { User, Spot, SpotPost, PostReply, PostResponse, PostUpvote, PostReport, Club, ClubMember, Conversation, Message, Notification, PostTemplate, Vibe, Interest, Intention, LifeSituation, FavoriteSpot, SpotImage, SpotVibe, SpotIntention, SpotClaim, SpotSubscription, City, Product, Order, OrderItem, Payment, InventoryLog, StripeConnectAccount, SpotType, SpotPostType, AccountStatus, ClaimStatus, ResponseStatus, ReportReason, ReportStatus, NotificationType, ProductType, ProductStatus, OrderStatus, PaymentProvider, PaymentStatus, FulfillmentType, InventoryChangeReason, } from '@prisma/client';
39
- import type { SendOtpDto, VerifyOtpDto, CreatePostDto, CreateReplyDto, CreateResponseDto, UpdateResponseDto, UpdateUserDto, UpvoteResponseDto, VerifyOtpWrappedResponseDto, CreateConversationDto, CreateMessageDto, ClaimSpotDto } from '@spotsdev/types';
40
- import type { SpotPost, PostTemplate } from '@prisma/client';
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.) → import from @prisma/client
7
- * - DTO types (CreatePostDto, etc.) → import from @spotsdev/types
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 while maintaining
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXBpL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7Ozs7R0FXRzs7Ozs7Ozs7Ozs7Ozs7OztBQWdDSCwrRUFBK0U7QUFDL0UsMEJBQTBCO0FBQzFCLCtFQUErRTtBQUUvRSxtRUFBbUU7QUFDbkUsa0RBQWdDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBTcG90cyBTREsgVHlwZXNcbiAqXG4gKiBUeXBlIHNvdXJjZXM6XG4gKiAtIEVudGl0eSB0eXBlcyAoVXNlciwgU3BvdCwgUG9zdCwgZXRjLikg4oaSIGltcG9ydCBmcm9tIEBwcmlzbWEvY2xpZW50XG4gKiAtIERUTyB0eXBlcyAoQ3JlYXRlUG9zdER0bywgZXRjLikg4oaSIGltcG9ydCBmcm9tIEBzcG90c2Rldi90eXBlc1xuICpcbiAqIFRoaXMgZmlsZSBwcm92aWRlcyB0eXBlIGFsaWFzZXMgZm9yIFNESyBjb252ZW5pZW5jZSB3aGlsZSBtYWludGFpbmluZ1xuICogc2luZ2xlIHNvdXJjZXMgb2YgdHJ1dGg6XG4gKiAtIFByaXNtYSBzY2hlbWEgZm9yIGVudGl0aWVzXG4gKiAtIE9wZW5BUEkgc3BlYyBmb3IgRFRPc1xuICovXG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIEFQSSBSRVNQT05TRSBUWVBFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKipcbiAqIFN0YW5kYXJkIEFQSSByZXNwb25zZSB3cmFwcGVyIGZyb20gUmVzcG9uc2VJbnRlcmNlcHRvclxuICogQWxsIEFQSSByZXNwb25zZXMgYXJlIHdyYXBwZWQgaW4gdGhpcyBmb3JtYXRcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBcGlSZXNwb25zZTxUPiB7XG4gIHN1Y2Nlc3M6IGJvb2xlYW47XG4gIGRhdGE6IFQ7XG4gIHRpbWVzdGFtcDogc3RyaW5nO1xufVxuXG4vKipcbiAqIFBhZ2luYXRlZCByZXNwb25zZSBmb3IgbGlzdCBlbmRwb2ludHNcbiAqIFVzZWQgaW5zaWRlIEFwaVJlc3BvbnNlLmRhdGEgZm9yIHBhZ2luYXRlZCBxdWVyaWVzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUGFnaW5hdGVkUmVzcG9uc2U8VD4ge1xuICBkYXRhOiBUW107XG4gIG1ldGE6IHtcbiAgICB0b3RhbDogbnVtYmVyO1xuICAgIHBhZ2U6IG51bWJlcjtcbiAgICBsaW1pdDogbnVtYmVyO1xuICAgIHRvdGFsUGFnZXM6IG51bWJlcjtcbiAgICBoYXNOZXh0UGFnZTogYm9vbGVhbjtcbiAgICBoYXNQcmV2aW91c1BhZ2U6IGJvb2xlYW47XG4gIH07XG59XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFJFLUVYUE9SVFMgRlJPTSBTT1VSQ0VTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8vIFJlLWV4cG9ydCBhbGwgRFRPIHR5cGVzIGZyb20gQHNwb3RzZGV2L3R5cGVzIChPcGVuQVBJIGdlbmVyYXRlZClcbmV4cG9ydCAqIGZyb20gJ0BzcG90c2Rldi90eXBlcyc7XG5cbi8vIFJlLWV4cG9ydCBlbnRpdHkgdHlwZXMgZnJvbSBAcHJpc21hL2NsaWVudFxuZXhwb3J0IHR5cGUge1xuICAvLyBNb2RlbHNcbiAgVXNlcixcbiAgU3BvdCxcbiAgU3BvdFBvc3QsXG4gIFBvc3RSZXBseSxcbiAgUG9zdFJlc3BvbnNlLFxuICBQb3N0VXB2b3RlLFxuICBQb3N0UmVwb3J0LFxuICBDbHViLFxuICBDbHViTWVtYmVyLFxuICBDb252ZXJzYXRpb24sXG4gIE1lc3NhZ2UsXG4gIE5vdGlmaWNhdGlvbixcbiAgUG9zdFRlbXBsYXRlLFxuICBWaWJlLFxuICBJbnRlcmVzdCxcbiAgSW50ZW50aW9uLFxuICBMaWZlU2l0dWF0aW9uLFxuICBGYXZvcml0ZVNwb3QsXG4gIFNwb3RJbWFnZSxcbiAgU3BvdFZpYmUsXG4gIFNwb3RJbnRlbnRpb24sXG4gIFNwb3RDbGFpbSxcbiAgU3BvdFN1YnNjcmlwdGlvbixcbiAgQ2l0eSxcbiAgLy8gTWFya2V0cGxhY2UgTW9kZWxzXG4gIFByb2R1Y3QsXG4gIE9yZGVyLFxuICBPcmRlckl0ZW0sXG4gIFBheW1lbnQsXG4gIEludmVudG9yeUxvZyxcbiAgU3RyaXBlQ29ubmVjdEFjY291bnQsXG4gIC8vIEVudW1zXG4gIFNwb3RUeXBlLFxuICBTcG90UG9zdFR5cGUsXG4gIEFjY291bnRTdGF0dXMsXG4gIENsYWltU3RhdHVzLFxuICBSZXNwb25zZVN0YXR1cyxcbiAgUmVwb3J0UmVhc29uLFxuICBSZXBvcnRTdGF0dXMsXG4gIE5vdGlmaWNhdGlvblR5cGUsXG4gIC8vIE1hcmtldHBsYWNlIEVudW1zXG4gIFByb2R1Y3RUeXBlLFxuICBQcm9kdWN0U3RhdHVzLFxuICBPcmRlclN0YXR1cyxcbiAgUGF5bWVudFByb3ZpZGVyLFxuICBQYXltZW50U3RhdHVzLFxuICBGdWxmaWxsbWVudFR5cGUsXG4gIEludmVudG9yeUNoYW5nZVJlYXNvbixcbn0gZnJvbSAnQHByaXNtYS9jbGllbnQnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBTREsgVFlQRSBBTElBU0VTXG4vLyBUaGVzZSBwcm92aWRlIGNvbnZlbmllbnQgbmFtZXMgdGhhdCBtYXRjaCBTREsgdXNhZ2UgcGF0dGVybnNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuaW1wb3J0IHR5cGUge1xuICBTZW5kT3RwRHRvLFxuICBWZXJpZnlPdHBEdG8sXG4gIENyZWF0ZVBvc3REdG8sXG4gIENyZWF0ZVJlcGx5RHRvLFxuICBDcmVhdGVSZXNwb25zZUR0byxcbiAgVXBkYXRlUmVzcG9uc2VEdG8sXG4gIFVwZGF0ZVVzZXJEdG8sXG4gIFVwdm90ZVJlc3BvbnNlRHRvLFxuICBWZXJpZnlPdHBXcmFwcGVkUmVzcG9uc2VEdG8sXG4gIENyZWF0ZUNvbnZlcnNhdGlvbkR0byxcbiAgQ3JlYXRlTWVzc2FnZUR0byxcbiAgQ2xhaW1TcG90RHRvLFxufSBmcm9tICdAc3BvdHNkZXYvdHlwZXMnO1xuXG5pbXBvcnQgdHlwZSB7IFNwb3RQb3N0LCBQb3N0VGVtcGxhdGUgfSBmcm9tICdAcHJpc21hL2NsaWVudCc7XG5cbi8vIFJlcXVlc3QgdHlwZSBhbGlhc2VzIChtYXAgdG8gRFRPcylcbmV4cG9ydCB0eXBlIFNlbmRPdHBSZXF1ZXN0ID0gU2VuZE90cER0bztcbmV4cG9ydCB0eXBlIFZlcmlmeU90cFJlcXVlc3QgPSBWZXJpZnlPdHBEdG87XG5leHBvcnQgdHlwZSBDcmVhdGVQb3N0UmVxdWVzdCA9IENyZWF0ZVBvc3REdG87XG5leHBvcnQgdHlwZSBDcmVhdGVSZXBseVJlcXVlc3QgPSBDcmVhdGVSZXBseUR0bztcbmV4cG9ydCB0eXBlIFJlc3BvbmRUb1Bvc3RSZXF1ZXN0ID0gQ3JlYXRlUmVzcG9uc2VEdG87XG5leHBvcnQgdHlwZSBVcGRhdGVSZXNwb25zZVJlcXVlc3QgPSBVcGRhdGVSZXNwb25zZUR0bztcbmV4cG9ydCB0eXBlIFVwZGF0ZVByb2ZpbGVSZXF1ZXN0ID0gVXBkYXRlVXNlckR0bztcbmV4cG9ydCB0eXBlIENyZWF0ZUNvbnZlcnNhdGlvblJlcXVlc3QgPSBDcmVhdGVDb252ZXJzYXRpb25EdG87XG5leHBvcnQgdHlwZSBTZW5kTWVzc2FnZVJlcXVlc3QgPSBDcmVhdGVNZXNzYWdlRHRvO1xuZXhwb3J0IHR5cGUgQ2xhaW1TcG90UmVxdWVzdCA9IENsYWltU3BvdER0bztcblxuLy8gUmVzcG9uc2UgdHlwZSBhbGlhc2VzXG5leHBvcnQgdHlwZSBVcHZvdGVSZXNwb25zZSA9IFVwdm90ZVJlc3BvbnNlRHRvO1xuZXhwb3J0IHR5cGUgQXV0aFJlc3BvbnNlID0gVmVyaWZ5T3RwV3JhcHBlZFJlc3BvbnNlRHRvO1xuXG4vLyBFbnRpdHkgdHlwZSBhbGlhc2VzIChmb3IgYmFja3dhcmQgY29tcGF0aWJpbGl0eSlcbmV4cG9ydCB0eXBlIFBvc3QgPSBTcG90UG9zdDtcbmV4cG9ydCB0eXBlIFRlbXBsYXRlID0gUG9zdFRlbXBsYXRlO1xuIl19
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