@spotsdev/sdk 1.0.0 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (74) hide show
  1. package/dist/api/client.d.ts +1 -1
  2. package/dist/api/client.js +7 -3
  3. package/dist/api/entities.d.ts +316 -0
  4. package/dist/api/entities.js +9 -0
  5. package/dist/api/mutations/clubs.d.ts +6 -6
  6. package/dist/api/mutations/clubs.js +12 -10
  7. package/dist/api/mutations/conversations.d.ts +7 -7
  8. package/dist/api/mutations/conversations.js +17 -13
  9. package/dist/api/mutations/index.js +1 -1
  10. package/dist/api/mutations/notifications.d.ts +4 -4
  11. package/dist/api/mutations/notifications.js +7 -7
  12. package/dist/api/mutations/orders.d.ts +7 -7
  13. package/dist/api/mutations/orders.js +11 -13
  14. package/dist/api/mutations/posts.d.ts +13 -13
  15. package/dist/api/mutations/posts.js +41 -29
  16. package/dist/api/mutations/products.d.ts +5 -5
  17. package/dist/api/mutations/products.js +9 -13
  18. package/dist/api/mutations/spots.d.ts +42 -8
  19. package/dist/api/mutations/spots.js +51 -13
  20. package/dist/api/mutations/users.d.ts +12 -10
  21. package/dist/api/mutations/users.js +20 -18
  22. package/dist/api/queries/auth.d.ts +5 -5
  23. package/dist/api/queries/auth.js +7 -7
  24. package/dist/api/queries/clubs.d.ts +7 -7
  25. package/dist/api/queries/clubs.js +11 -11
  26. package/dist/api/queries/conversations.d.ts +5 -5
  27. package/dist/api/queries/conversations.js +7 -7
  28. package/dist/api/queries/index.js +1 -1
  29. package/dist/api/queries/misc.d.ts +8 -32
  30. package/dist/api/queries/misc.js +28 -66
  31. package/dist/api/queries/notifications.d.ts +4 -4
  32. package/dist/api/queries/notifications.js +5 -5
  33. package/dist/api/queries/orders.d.ts +4 -4
  34. package/dist/api/queries/orders.js +7 -7
  35. package/dist/api/queries/posts.d.ts +44 -7
  36. package/dist/api/queries/posts.js +118 -15
  37. package/dist/api/queries/products.d.ts +6 -10
  38. package/dist/api/queries/products.js +7 -9
  39. package/dist/api/queries/spots.d.ts +31 -16
  40. package/dist/api/queries/spots.js +113 -31
  41. package/dist/api/queries/templates.d.ts +6 -9
  42. package/dist/api/queries/templates.js +8 -13
  43. package/dist/api/queries/users.d.ts +25 -11
  44. package/dist/api/queries/users.js +75 -27
  45. package/dist/api/types.d.ts +36 -33
  46. package/dist/api/types.js +6 -7
  47. package/dist/index.d.ts +1 -2
  48. package/dist/index.js +1 -8
  49. package/package.json +6 -21
  50. package/src/api/client.ts +45 -30
  51. package/src/api/entities.ts +420 -0
  52. package/src/api/mutations/clubs.ts +73 -40
  53. package/src/api/mutations/conversations.ts +91 -47
  54. package/src/api/mutations/index.ts +8 -8
  55. package/src/api/mutations/notifications.ts +48 -25
  56. package/src/api/mutations/orders.ts +101 -70
  57. package/src/api/mutations/posts.ts +229 -118
  58. package/src/api/mutations/products.ts +120 -81
  59. package/src/api/mutations/spots.ts +167 -55
  60. package/src/api/mutations/users.ts +109 -76
  61. package/src/api/queries/auth.ts +49 -24
  62. package/src/api/queries/clubs.ts +53 -38
  63. package/src/api/queries/conversations.ts +48 -30
  64. package/src/api/queries/index.ts +21 -21
  65. package/src/api/queries/misc.ts +53 -82
  66. package/src/api/queries/notifications.ts +32 -21
  67. package/src/api/queries/orders.ts +59 -42
  68. package/src/api/queries/posts.ts +203 -48
  69. package/src/api/queries/products.ts +51 -44
  70. package/src/api/queries/spots.ts +216 -85
  71. package/src/api/queries/templates.ts +39 -32
  72. package/src/api/queries/users.ts +157 -64
  73. package/src/api/types.ts +72 -118
  74. package/src/index.ts +5 -11
@@ -1,4 +1,4 @@
1
- import { AxiosInstance } from 'axios';
1
+ import { type AxiosInstance } from 'axios';
2
2
  export interface SDKConfig {
3
3
  baseURL: string;
4
4
  getAccessToken: () => string | null | Promise<string | null>;
@@ -40,10 +40,14 @@ function createApiClient(sdkConfig) {
40
40
  if (token) {
41
41
  requestConfig.headers.Authorization = `Bearer ${token}`;
42
42
  }
43
+ // Debug logging
44
+ console.log(`[SDK] ${requestConfig.method?.toUpperCase()} ${sdkConfig.baseURL}${requestConfig.url}`);
43
45
  return requestConfig;
44
- }, (error) => Promise.reject(error));
46
+ }, error => Promise.reject(error));
45
47
  // Response interceptor - handle 401
46
- client.interceptors.response.use((response) => response, async (error) => {
48
+ client.interceptors.response.use(response => response, async (error) => {
49
+ console.log(`[SDK] Error: ${error.response?.status} ${error.config?.url}`, error.message);
50
+ // Handle auth token expiration (401)
47
51
  if (error.response?.status === 401) {
48
52
  if (sdkConfig.refreshAccessToken) {
49
53
  try {
@@ -65,4 +69,4 @@ function createApiClient(sdkConfig) {
65
69
  });
66
70
  return client;
67
71
  }
68
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FwaS9jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBWUEsb0NBR0M7QUFFRCxvQ0FLQztBQUVELDhCQUtDO0FBN0JELGtEQUFxRjtBQVNyRixJQUFJLE1BQU0sR0FBcUIsSUFBSSxDQUFDO0FBQ3BDLElBQUksU0FBUyxHQUF5QixJQUFJLENBQUM7QUFtRWxDLDhCQUFTO0FBakVsQixTQUFnQixZQUFZLENBQUMsU0FBb0I7SUFDL0MsTUFBTSxHQUFHLFNBQVMsQ0FBQztJQUNuQixvQkFBQSxTQUFTLEdBQUcsZUFBZSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQ3pDLENBQUM7QUFFRCxTQUFnQixZQUFZO0lBQzFCLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUNmLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0RBQWdELENBQUMsQ0FBQztJQUNwRSxDQUFDO0lBQ0QsT0FBTyxTQUFTLENBQUM7QUFDbkIsQ0FBQztBQUVELFNBQWdCLFNBQVM7SUFDdkIsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ1osTUFBTSxJQUFJLEtBQUssQ0FBQyxnREFBZ0QsQ0FBQyxDQUFDO0lBQ3BFLENBQUM7SUFDRCxPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBRUQsU0FBUyxlQUFlLENBQUMsU0FBb0I7SUFDM0MsTUFBTSxNQUFNLEdBQUcsZUFBSyxDQUFDLE1BQU0sQ0FBQztRQUMxQixPQUFPLEVBQUUsU0FBUyxDQUFDLE9BQU87UUFDMUIsT0FBTyxFQUFFO1lBQ1AsY0FBYyxFQUFFLGtCQUFrQjtTQUNuQztLQUNGLENBQUMsQ0FBQztJQUVILHVDQUF1QztJQUN2QyxNQUFNLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQzdCLEtBQUssRUFBRSxhQUF5QyxFQUFFLEVBQUU7UUFDbEQsTUFBTSxLQUFLLEdBQUcsTUFBTSxTQUFTLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDL0MsSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUNWLGFBQWEsQ0FBQyxPQUFPLENBQUMsYUFBYSxHQUFHLFVBQVUsS0FBSyxFQUFFLENBQUM7UUFDMUQsQ0FBQztRQUNELE9BQU8sYUFBYSxDQUFDO0lBQ3ZCLENBQUMsRUFDRCxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FDakMsQ0FBQztJQUVGLG9DQUFvQztJQUNwQyxNQUFNLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQzlCLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxRQUFRLEVBQ3RCLEtBQUssRUFBRSxLQUFpQixFQUFFLEVBQUU7UUFDMUIsSUFBSSxLQUFLLENBQUMsUUFBUSxFQUFFLE1BQU0sS0FBSyxHQUFHLEVBQUUsQ0FBQztZQUNuQyxJQUFJLFNBQVMsQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO2dCQUNqQyxJQUFJLENBQUM7b0JBQ0gsTUFBTSxRQUFRLEdBQUcsTUFBTSxTQUFTLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztvQkFDdEQsSUFBSSxRQUFRLElBQUksS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDO3dCQUM3QixLQUFLLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxhQUFhLEdBQUcsVUFBVSxRQUFRLEVBQUUsQ0FBQzt3QkFDMUQsT0FBTyxNQUFNLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztvQkFDdEMsQ0FBQztnQkFDSCxDQUFDO2dCQUFDLE1BQU0sQ0FBQztvQkFDUCxTQUFTLENBQUMsY0FBYyxFQUFFLEVBQUUsQ0FBQztnQkFDL0IsQ0FBQztZQUNILENBQUM7aUJBQU0sQ0FBQztnQkFDTixTQUFTLENBQUMsY0FBYyxFQUFFLEVBQUUsQ0FBQztZQUMvQixDQUFDO1FBQ0gsQ0FBQztRQUNELE9BQU8sT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMvQixDQUFDLENBQ0YsQ0FBQztJQUVGLE9BQU8sTUFBTSxDQUFDO0FBQ2hCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXhpb3MsIHsgQXhpb3NJbnN0YW5jZSwgQXhpb3NFcnJvciwgSW50ZXJuYWxBeGlvc1JlcXVlc3RDb25maWcgfSBmcm9tICdheGlvcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU0RLQ29uZmlnIHtcbiAgYmFzZVVSTDogc3RyaW5nO1xuICBnZXRBY2Nlc3NUb2tlbjogKCkgPT4gc3RyaW5nIHwgbnVsbCB8IFByb21pc2U8c3RyaW5nIHwgbnVsbD47XG4gIHJlZnJlc2hBY2Nlc3NUb2tlbj86ICgpID0+IFByb21pc2U8c3RyaW5nPjtcbiAgb25VbmF1dGhvcml6ZWQ/OiAoKSA9PiB2b2lkO1xufVxuXG5sZXQgY29uZmlnOiBTREtDb25maWcgfCBudWxsID0gbnVsbDtcbmxldCBhcGlDbGllbnQ6IEF4aW9zSW5zdGFuY2UgfCBudWxsID0gbnVsbDtcblxuZXhwb3J0IGZ1bmN0aW9uIGNvbmZpZ3VyZVNESyhzZGtDb25maWc6IFNES0NvbmZpZyk6IHZvaWQge1xuICBjb25maWcgPSBzZGtDb25maWc7XG4gIGFwaUNsaWVudCA9IGNyZWF0ZUFwaUNsaWVudChzZGtDb25maWcpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0QXBpQ2xpZW50KCk6IEF4aW9zSW5zdGFuY2Uge1xuICBpZiAoIWFwaUNsaWVudCkge1xuICAgIHRocm93IG5ldyBFcnJvcignU0RLIG5vdCBjb25maWd1cmVkLiBDYWxsIGNvbmZpZ3VyZVNESygpIGZpcnN0LicpO1xuICB9XG4gIHJldHVybiBhcGlDbGllbnQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRDb25maWcoKTogU0RLQ29uZmlnIHtcbiAgaWYgKCFjb25maWcpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1NESyBub3QgY29uZmlndXJlZC4gQ2FsbCBjb25maWd1cmVTREsoKSBmaXJzdC4nKTtcbiAgfVxuICByZXR1cm4gY29uZmlnO1xufVxuXG5mdW5jdGlvbiBjcmVhdGVBcGlDbGllbnQoc2RrQ29uZmlnOiBTREtDb25maWcpOiBBeGlvc0luc3RhbmNlIHtcbiAgY29uc3QgY2xpZW50ID0gYXhpb3MuY3JlYXRlKHtcbiAgICBiYXNlVVJMOiBzZGtDb25maWcuYmFzZVVSTCxcbiAgICBoZWFkZXJzOiB7XG4gICAgICAnQ29udGVudC1UeXBlJzogJ2FwcGxpY2F0aW9uL2pzb24nLFxuICAgIH0sXG4gIH0pO1xuXG4gIC8vIFJlcXVlc3QgaW50ZXJjZXB0b3IgLSBhZGQgYXV0aCB0b2tlblxuICBjbGllbnQuaW50ZXJjZXB0b3JzLnJlcXVlc3QudXNlKFxuICAgIGFzeW5jIChyZXF1ZXN0Q29uZmlnOiBJbnRlcm5hbEF4aW9zUmVxdWVzdENvbmZpZykgPT4ge1xuICAgICAgY29uc3QgdG9rZW4gPSBhd2FpdCBzZGtDb25maWcuZ2V0QWNjZXNzVG9rZW4oKTtcbiAgICAgIGlmICh0b2tlbikge1xuICAgICAgICByZXF1ZXN0Q29uZmlnLmhlYWRlcnMuQXV0aG9yaXphdGlvbiA9IGBCZWFyZXIgJHt0b2tlbn1gO1xuICAgICAgfVxuICAgICAgcmV0dXJuIHJlcXVlc3RDb25maWc7XG4gICAgfSxcbiAgICAoZXJyb3IpID0+IFByb21pc2UucmVqZWN0KGVycm9yKVxuICApO1xuXG4gIC8vIFJlc3BvbnNlIGludGVyY2VwdG9yIC0gaGFuZGxlIDQwMVxuICBjbGllbnQuaW50ZXJjZXB0b3JzLnJlc3BvbnNlLnVzZShcbiAgICAocmVzcG9uc2UpID0+IHJlc3BvbnNlLFxuICAgIGFzeW5jIChlcnJvcjogQXhpb3NFcnJvcikgPT4ge1xuICAgICAgaWYgKGVycm9yLnJlc3BvbnNlPy5zdGF0dXMgPT09IDQwMSkge1xuICAgICAgICBpZiAoc2RrQ29uZmlnLnJlZnJlc2hBY2Nlc3NUb2tlbikge1xuICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICBjb25zdCBuZXdUb2tlbiA9IGF3YWl0IHNka0NvbmZpZy5yZWZyZXNoQWNjZXNzVG9rZW4oKTtcbiAgICAgICAgICAgIGlmIChuZXdUb2tlbiAmJiBlcnJvci5jb25maWcpIHtcbiAgICAgICAgICAgICAgZXJyb3IuY29uZmlnLmhlYWRlcnMuQXV0aG9yaXphdGlvbiA9IGBCZWFyZXIgJHtuZXdUb2tlbn1gO1xuICAgICAgICAgICAgICByZXR1cm4gY2xpZW50LnJlcXVlc3QoZXJyb3IuY29uZmlnKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICAgIHNka0NvbmZpZy5vblVuYXV0aG9yaXplZD8uKCk7XG4gICAgICAgICAgfVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHNka0NvbmZpZy5vblVuYXV0aG9yaXplZD8uKCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIHJldHVybiBQcm9taXNlLnJlamVjdChlcnJvcik7XG4gICAgfVxuICApO1xuXG4gIHJldHVybiBjbGllbnQ7XG59XG5cbmV4cG9ydCB7IGFwaUNsaWVudCB9O1xuIl19
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FwaS9jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBZ0JBLG9DQUdDO0FBRUQsb0NBS0M7QUFFRCw4QkFLQztBQWpDRCxrREFJYztBQVNkLElBQUksTUFBTSxHQUFxQixJQUFJLENBQUE7QUFDbkMsSUFBSSxTQUFTLEdBQXlCLElBQUksQ0FBQTtBQThFbEMsOEJBQVM7QUE1RWpCLFNBQWdCLFlBQVksQ0FBQyxTQUFvQjtJQUMvQyxNQUFNLEdBQUcsU0FBUyxDQUFBO0lBQ2xCLG9CQUFBLFNBQVMsR0FBRyxlQUFlLENBQUMsU0FBUyxDQUFDLENBQUE7QUFDeEMsQ0FBQztBQUVELFNBQWdCLFlBQVk7SUFDMUIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQ2YsTUFBTSxJQUFJLEtBQUssQ0FBQyxnREFBZ0QsQ0FBQyxDQUFBO0lBQ25FLENBQUM7SUFDRCxPQUFPLFNBQVMsQ0FBQTtBQUNsQixDQUFDO0FBRUQsU0FBZ0IsU0FBUztJQUN2QixJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDWixNQUFNLElBQUksS0FBSyxDQUFDLGdEQUFnRCxDQUFDLENBQUE7SUFDbkUsQ0FBQztJQUNELE9BQU8sTUFBTSxDQUFBO0FBQ2YsQ0FBQztBQUVELFNBQVMsZUFBZSxDQUFDLFNBQW9CO0lBQzNDLE1BQU0sTUFBTSxHQUFHLGVBQUssQ0FBQyxNQUFNLENBQUM7UUFDMUIsT0FBTyxFQUFFLFNBQVMsQ0FBQyxPQUFPO1FBQzFCLE9BQU8sRUFBRTtZQUNQLGNBQWMsRUFBRSxrQkFBa0I7U0FDbkM7S0FDRixDQUFDLENBQUE7SUFFRix1Q0FBdUM7SUFDdkMsTUFBTSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUM3QixLQUFLLEVBQUUsYUFBeUMsRUFBRSxFQUFFO1FBQ2xELE1BQU0sS0FBSyxHQUFHLE1BQU0sU0FBUyxDQUFDLGNBQWMsRUFBRSxDQUFBO1FBQzlDLElBQUksS0FBSyxFQUFFLENBQUM7WUFDVixhQUFhLENBQUMsT0FBTyxDQUFDLGFBQWEsR0FBRyxVQUFVLEtBQUssRUFBRSxDQUFBO1FBQ3pELENBQUM7UUFFRCxnQkFBZ0I7UUFDaEIsT0FBTyxDQUFDLEdBQUcsQ0FDVCxTQUFTLGFBQWEsQ0FBQyxNQUFNLEVBQUUsV0FBVyxFQUFFLElBQUksU0FBUyxDQUFDLE9BQU8sR0FBRyxhQUFhLENBQUMsR0FBRyxFQUFFLENBQ3hGLENBQUE7UUFDRCxPQUFPLGFBQWEsQ0FBQTtJQUN0QixDQUFDLEVBQ0QsS0FBSyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUMvQixDQUFBO0lBRUQsb0NBQW9DO0lBQ3BDLE1BQU0sQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FDOUIsUUFBUSxDQUFDLEVBQUUsQ0FBQyxRQUFRLEVBQ3BCLEtBQUssRUFBRSxLQUFpQixFQUFFLEVBQUU7UUFDMUIsT0FBTyxDQUFDLEdBQUcsQ0FDVCxnQkFBZ0IsS0FBSyxDQUFDLFFBQVEsRUFBRSxNQUFNLElBQUksS0FBSyxDQUFDLE1BQU0sRUFBRSxHQUFHLEVBQUUsRUFDN0QsS0FBSyxDQUFDLE9BQU8sQ0FDZCxDQUFBO1FBRUQscUNBQXFDO1FBQ3JDLElBQUksS0FBSyxDQUFDLFFBQVEsRUFBRSxNQUFNLEtBQUssR0FBRyxFQUFFLENBQUM7WUFDbkMsSUFBSSxTQUFTLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztnQkFDakMsSUFBSSxDQUFDO29CQUNILE1BQU0sUUFBUSxHQUFHLE1BQU0sU0FBUyxDQUFDLGtCQUFrQixFQUFFLENBQUE7b0JBQ3JELElBQUksUUFBUSxJQUFJLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQzt3QkFDN0IsS0FBSyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsYUFBYSxHQUFHLFVBQVUsUUFBUSxFQUFFLENBQUE7d0JBQ3pELE9BQU8sTUFBTSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUE7b0JBQ3JDLENBQUM7Z0JBQ0gsQ0FBQztnQkFBQyxNQUFNLENBQUM7b0JBQ1AsU0FBUyxDQUFDLGNBQWMsRUFBRSxFQUFFLENBQUE7Z0JBQzlCLENBQUM7WUFDSCxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sU0FBUyxDQUFDLGNBQWMsRUFBRSxFQUFFLENBQUE7WUFDOUIsQ0FBQztRQUNILENBQUM7UUFDRCxPQUFPLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUE7SUFDOUIsQ0FBQyxDQUNGLENBQUE7SUFFRCxPQUFPLE1BQU0sQ0FBQTtBQUNmLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXhpb3MsIHtcbiAgdHlwZSBBeGlvc0Vycm9yLFxuICB0eXBlIEF4aW9zSW5zdGFuY2UsXG4gIHR5cGUgSW50ZXJuYWxBeGlvc1JlcXVlc3RDb25maWcsXG59IGZyb20gJ2F4aW9zJ1xuXG5leHBvcnQgaW50ZXJmYWNlIFNES0NvbmZpZyB7XG4gIGJhc2VVUkw6IHN0cmluZ1xuICBnZXRBY2Nlc3NUb2tlbjogKCkgPT4gc3RyaW5nIHwgbnVsbCB8IFByb21pc2U8c3RyaW5nIHwgbnVsbD5cbiAgcmVmcmVzaEFjY2Vzc1Rva2VuPzogKCkgPT4gUHJvbWlzZTxzdHJpbmc+XG4gIG9uVW5hdXRob3JpemVkPzogKCkgPT4gdm9pZFxufVxuXG5sZXQgY29uZmlnOiBTREtDb25maWcgfCBudWxsID0gbnVsbFxubGV0IGFwaUNsaWVudDogQXhpb3NJbnN0YW5jZSB8IG51bGwgPSBudWxsXG5cbmV4cG9ydCBmdW5jdGlvbiBjb25maWd1cmVTREsoc2RrQ29uZmlnOiBTREtDb25maWcpOiB2b2lkIHtcbiAgY29uZmlnID0gc2RrQ29uZmlnXG4gIGFwaUNsaWVudCA9IGNyZWF0ZUFwaUNsaWVudChzZGtDb25maWcpXG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRBcGlDbGllbnQoKTogQXhpb3NJbnN0YW5jZSB7XG4gIGlmICghYXBpQ2xpZW50KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdTREsgbm90IGNvbmZpZ3VyZWQuIENhbGwgY29uZmlndXJlU0RLKCkgZmlyc3QuJylcbiAgfVxuICByZXR1cm4gYXBpQ2xpZW50XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRDb25maWcoKTogU0RLQ29uZmlnIHtcbiAgaWYgKCFjb25maWcpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1NESyBub3QgY29uZmlndXJlZC4gQ2FsbCBjb25maWd1cmVTREsoKSBmaXJzdC4nKVxuICB9XG4gIHJldHVybiBjb25maWdcbn1cblxuZnVuY3Rpb24gY3JlYXRlQXBpQ2xpZW50KHNka0NvbmZpZzogU0RLQ29uZmlnKTogQXhpb3NJbnN0YW5jZSB7XG4gIGNvbnN0IGNsaWVudCA9IGF4aW9zLmNyZWF0ZSh7XG4gICAgYmFzZVVSTDogc2RrQ29uZmlnLmJhc2VVUkwsXG4gICAgaGVhZGVyczoge1xuICAgICAgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJyxcbiAgICB9LFxuICB9KVxuXG4gIC8vIFJlcXVlc3QgaW50ZXJjZXB0b3IgLSBhZGQgYXV0aCB0b2tlblxuICBjbGllbnQuaW50ZXJjZXB0b3JzLnJlcXVlc3QudXNlKFxuICAgIGFzeW5jIChyZXF1ZXN0Q29uZmlnOiBJbnRlcm5hbEF4aW9zUmVxdWVzdENvbmZpZykgPT4ge1xuICAgICAgY29uc3QgdG9rZW4gPSBhd2FpdCBzZGtDb25maWcuZ2V0QWNjZXNzVG9rZW4oKVxuICAgICAgaWYgKHRva2VuKSB7XG4gICAgICAgIHJlcXVlc3RDb25maWcuaGVhZGVycy5BdXRob3JpemF0aW9uID0gYEJlYXJlciAke3Rva2VufWBcbiAgICAgIH1cblxuICAgICAgLy8gRGVidWcgbG9nZ2luZ1xuICAgICAgY29uc29sZS5sb2coXG4gICAgICAgIGBbU0RLXSAke3JlcXVlc3RDb25maWcubWV0aG9kPy50b1VwcGVyQ2FzZSgpfSAke3Nka0NvbmZpZy5iYXNlVVJMfSR7cmVxdWVzdENvbmZpZy51cmx9YCxcbiAgICAgIClcbiAgICAgIHJldHVybiByZXF1ZXN0Q29uZmlnXG4gICAgfSxcbiAgICBlcnJvciA9PiBQcm9taXNlLnJlamVjdChlcnJvciksXG4gIClcblxuICAvLyBSZXNwb25zZSBpbnRlcmNlcHRvciAtIGhhbmRsZSA0MDFcbiAgY2xpZW50LmludGVyY2VwdG9ycy5yZXNwb25zZS51c2UoXG4gICAgcmVzcG9uc2UgPT4gcmVzcG9uc2UsXG4gICAgYXN5bmMgKGVycm9yOiBBeGlvc0Vycm9yKSA9PiB7XG4gICAgICBjb25zb2xlLmxvZyhcbiAgICAgICAgYFtTREtdIEVycm9yOiAke2Vycm9yLnJlc3BvbnNlPy5zdGF0dXN9ICR7ZXJyb3IuY29uZmlnPy51cmx9YCxcbiAgICAgICAgZXJyb3IubWVzc2FnZSxcbiAgICAgIClcblxuICAgICAgLy8gSGFuZGxlIGF1dGggdG9rZW4gZXhwaXJhdGlvbiAoNDAxKVxuICAgICAgaWYgKGVycm9yLnJlc3BvbnNlPy5zdGF0dXMgPT09IDQwMSkge1xuICAgICAgICBpZiAoc2RrQ29uZmlnLnJlZnJlc2hBY2Nlc3NUb2tlbikge1xuICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICBjb25zdCBuZXdUb2tlbiA9IGF3YWl0IHNka0NvbmZpZy5yZWZyZXNoQWNjZXNzVG9rZW4oKVxuICAgICAgICAgICAgaWYgKG5ld1Rva2VuICYmIGVycm9yLmNvbmZpZykge1xuICAgICAgICAgICAgICBlcnJvci5jb25maWcuaGVhZGVycy5BdXRob3JpemF0aW9uID0gYEJlYXJlciAke25ld1Rva2VufWBcbiAgICAgICAgICAgICAgcmV0dXJuIGNsaWVudC5yZXF1ZXN0KGVycm9yLmNvbmZpZylcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICAgIHNka0NvbmZpZy5vblVuYXV0aG9yaXplZD8uKClcbiAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgc2RrQ29uZmlnLm9uVW5hdXRob3JpemVkPy4oKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgICByZXR1cm4gUHJvbWlzZS5yZWplY3QoZXJyb3IpXG4gICAgfSxcbiAgKVxuXG4gIHJldHVybiBjbGllbnRcbn1cblxuZXhwb3J0IHthcGlDbGllbnR9XG4iXX0=
@@ -0,0 +1,316 @@
1
+ /**
2
+ * Spots SDK Entity Types
3
+ *
4
+ * These types mirror the Prisma schema entities but without @prisma/client dependency.
5
+ * This allows the SDK to work in React Native where Prisma is not available.
6
+ */
7
+ export type SpotType = 'CAFE' | 'RESTAURANT' | 'BAR' | 'PARK' | 'BEACH' | 'COWORKING' | 'LIBRARY' | 'GYM' | 'MUSEUM' | 'GALLERY' | 'THEATER' | 'CINEMA' | 'MALL' | 'MARKET' | 'HOTEL' | 'HOSTEL' | 'OTHER';
8
+ export type SpotPostType = 'CHECK_IN' | 'LOOKING_FOR' | 'OFFERING' | 'QUESTION' | 'EVENT' | 'RECOMMENDATION' | 'GENERAL';
9
+ export type AccountStatus = 'ACTIVE' | 'SUSPENDED' | 'DELETED' | 'PENDING';
10
+ export type ClaimStatus = 'PENDING' | 'APPROVED' | 'REJECTED';
11
+ export type ResponseStatus = 'PENDING' | 'ACCEPTED' | 'DECLINED';
12
+ export type ReportReason = 'SPAM' | 'HARASSMENT' | 'INAPPROPRIATE' | 'SCAM' | 'OTHER';
13
+ export type ReportStatus = 'PENDING' | 'REVIEWED' | 'RESOLVED' | 'DISMISSED';
14
+ export type NotificationType = 'POST_RESPONSE' | 'POST_REPLY' | 'POST_UPVOTE' | 'RESPONSE_ACCEPTED' | 'RESPONSE_DECLINED' | 'NEW_MESSAGE' | 'SYSTEM';
15
+ export interface User {
16
+ id: string;
17
+ phone: string | null;
18
+ email: string | null;
19
+ name: string | null;
20
+ bio: string | null;
21
+ avatarUrl: string | null;
22
+ status: AccountStatus;
23
+ onboardingCompleted: boolean;
24
+ lastActiveAt: Date | null;
25
+ createdAt: Date;
26
+ updatedAt: Date;
27
+ }
28
+ export interface Spot {
29
+ id: string;
30
+ name: string;
31
+ slug: string;
32
+ description: string | null;
33
+ address: string | null;
34
+ city: string | null;
35
+ country: string | null;
36
+ latitude: number | null;
37
+ longitude: number | null;
38
+ type: SpotType;
39
+ googlePlaceId: string | null;
40
+ website: string | null;
41
+ phone: string | null;
42
+ imageUrl: string | null;
43
+ ownerId: string | null;
44
+ isVerified: boolean;
45
+ createdAt: Date;
46
+ updatedAt: Date;
47
+ }
48
+ export interface SpotPost {
49
+ id: string;
50
+ spotId: string;
51
+ userId: string;
52
+ postType: SpotPostType;
53
+ title: string;
54
+ content: string | null;
55
+ emoji: string | null;
56
+ expiresAt: Date | null;
57
+ status: 'ACTIVE' | 'FULFILLED' | 'EXPIRED' | 'DELETED';
58
+ upvoteCount: number;
59
+ responseCount: number;
60
+ replyCount: number;
61
+ createdAt: Date;
62
+ updatedAt: Date;
63
+ user?: User;
64
+ spot?: Spot;
65
+ }
66
+ export interface PostReply {
67
+ id: string;
68
+ postId: string;
69
+ userId: string;
70
+ content: string;
71
+ createdAt: Date;
72
+ updatedAt: Date;
73
+ user?: User;
74
+ }
75
+ export interface PostResponse {
76
+ id: string;
77
+ postId: string;
78
+ userId: string;
79
+ note: string | null;
80
+ status: ResponseStatus;
81
+ createdAt: Date;
82
+ updatedAt: Date;
83
+ user?: User;
84
+ post?: SpotPost;
85
+ }
86
+ export interface PostUpvote {
87
+ id: string;
88
+ postId: string;
89
+ userId: string;
90
+ createdAt: Date;
91
+ }
92
+ /**
93
+ * PostUpvoter - user who upvoted a post (from /posts/:id/upvotes endpoint)
94
+ */
95
+ export interface PostUpvoter {
96
+ id: string;
97
+ userId: string;
98
+ name: string | null;
99
+ avatarUrl: string | null;
100
+ createdAt: Date;
101
+ }
102
+ /**
103
+ * PostUpvotesResponse - response from /posts/:id/upvotes endpoint
104
+ */
105
+ export interface PostUpvotesResponse {
106
+ data: PostUpvoter[];
107
+ meta: {
108
+ total: number;
109
+ limit: number;
110
+ offset: number;
111
+ hasMore: boolean;
112
+ currentUserUpvoted: boolean;
113
+ isPostAuthor: boolean;
114
+ };
115
+ }
116
+ export interface PostReport {
117
+ id: string;
118
+ postId: string;
119
+ userId: string;
120
+ reason: ReportReason;
121
+ details: string | null;
122
+ status: ReportStatus;
123
+ createdAt: Date;
124
+ updatedAt: Date;
125
+ }
126
+ export interface Club {
127
+ id: string;
128
+ name: string;
129
+ slug: string;
130
+ description: string | null;
131
+ imageUrl: string | null;
132
+ isPrivate: boolean;
133
+ createdById: string;
134
+ createdAt: Date;
135
+ updatedAt: Date;
136
+ }
137
+ export interface ClubMember {
138
+ id: string;
139
+ clubId: string;
140
+ userId: string;
141
+ role: 'MEMBER' | 'ADMIN' | 'OWNER';
142
+ joinedAt: Date;
143
+ }
144
+ export interface Conversation {
145
+ id: string;
146
+ createdAt: Date;
147
+ updatedAt: Date;
148
+ participants?: User[];
149
+ messages?: Message[];
150
+ }
151
+ export interface Message {
152
+ id: string;
153
+ conversationId: string;
154
+ senderId: string;
155
+ content: string;
156
+ createdAt: Date;
157
+ sender?: User;
158
+ }
159
+ export interface Notification {
160
+ id: string;
161
+ userId: string;
162
+ type: NotificationType;
163
+ title: string;
164
+ body: string | null;
165
+ data: Record<string, unknown> | null;
166
+ isRead: boolean;
167
+ createdAt: Date;
168
+ }
169
+ export interface PostTemplate {
170
+ id: string;
171
+ postType: SpotPostType;
172
+ emoji: string;
173
+ title: string;
174
+ placeholder: string | null;
175
+ isActive: boolean;
176
+ sortOrder: number;
177
+ createdAt: Date;
178
+ updatedAt: Date;
179
+ }
180
+ export interface Vibe {
181
+ id: string;
182
+ name: string;
183
+ emoji: string | null;
184
+ createdAt: Date;
185
+ }
186
+ export interface Interest {
187
+ id: string;
188
+ name: string;
189
+ emoji: string | null;
190
+ category: string | null;
191
+ createdAt: Date;
192
+ }
193
+ export interface Intention {
194
+ id: string;
195
+ name: string;
196
+ emoji: string | null;
197
+ createdAt: Date;
198
+ }
199
+ export interface LifeSituation {
200
+ id: string;
201
+ name: string;
202
+ emoji: string | null;
203
+ createdAt: Date;
204
+ }
205
+ export interface FavoriteSpot {
206
+ id: string;
207
+ userId: string;
208
+ spotId: string;
209
+ createdAt: Date;
210
+ spot?: Spot;
211
+ }
212
+ export interface SpotImage {
213
+ id: string;
214
+ spotId: string;
215
+ url: string;
216
+ caption: string | null;
217
+ sortOrder: number;
218
+ createdAt: Date;
219
+ }
220
+ export interface SpotVibe {
221
+ id: string;
222
+ spotId: string;
223
+ vibeId: string;
224
+ vibe?: Vibe;
225
+ }
226
+ export interface SpotIntention {
227
+ id: string;
228
+ spotId: string;
229
+ intentionId: string;
230
+ intention?: Intention;
231
+ }
232
+ export interface SpotClaim {
233
+ id: string;
234
+ spotId: string;
235
+ userId: string;
236
+ status: ClaimStatus;
237
+ verificationMethod: string | null;
238
+ createdAt: Date;
239
+ updatedAt: Date;
240
+ }
241
+ export interface SpotSubscription {
242
+ id: string;
243
+ spotId: string;
244
+ userId: string;
245
+ createdAt: Date;
246
+ spot?: Spot;
247
+ }
248
+ export interface City {
249
+ id: string;
250
+ name: string;
251
+ country: string;
252
+ latitude: number;
253
+ longitude: number;
254
+ timezone: string | null;
255
+ createdAt: Date;
256
+ }
257
+ /**
258
+ * Paginated response with meta information
259
+ */
260
+ export interface PaginatedResponse<T> {
261
+ data: T[];
262
+ meta: PaginationMeta;
263
+ }
264
+ export interface PaginationMeta {
265
+ total: number;
266
+ page: number;
267
+ limit: number;
268
+ totalPages: number;
269
+ hasNextPage: boolean;
270
+ hasPreviousPage: boolean;
271
+ }
272
+ export type ProductType = 'PHYSICAL' | 'DIGITAL' | 'SERVICE' | 'BUNDLE';
273
+ export type ProductStatus = 'DRAFT' | 'ACTIVE' | 'SOLD_OUT' | 'ARCHIVED';
274
+ export type OrderStatus = 'PENDING' | 'CONFIRMED' | 'PREPARING' | 'READY' | 'COMPLETED' | 'CANCELLED' | 'REFUNDED';
275
+ export interface Product {
276
+ id: string;
277
+ spotId: string;
278
+ name: string;
279
+ slug: string;
280
+ description: string | null;
281
+ type: ProductType;
282
+ status: ProductStatus;
283
+ price: number;
284
+ currency: string;
285
+ imageUrl: string | null;
286
+ images: string[];
287
+ stock: number | null;
288
+ maxQuantity: number;
289
+ sortOrder: number;
290
+ metadata: Record<string, unknown> | null;
291
+ createdAt: Date;
292
+ updatedAt: Date;
293
+ }
294
+ export interface Order {
295
+ id: string;
296
+ spotId: string;
297
+ userId: string;
298
+ status: OrderStatus;
299
+ subtotal: number;
300
+ tax: number;
301
+ total: number;
302
+ currency: string;
303
+ notes: string | null;
304
+ metadata: Record<string, unknown> | null;
305
+ createdAt: Date;
306
+ updatedAt: Date;
307
+ }
308
+ export interface OrderItem {
309
+ id: string;
310
+ orderId: string;
311
+ productId: string;
312
+ quantity: number;
313
+ unitPrice: number;
314
+ total: number;
315
+ createdAt: Date;
316
+ }
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ /**
3
+ * Spots SDK Entity Types
4
+ *
5
+ * These types mirror the Prisma schema entities but without @prisma/client dependency.
6
+ * This allows the SDK to work in React Native where Prisma is not available.
7
+ */
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entities.js","sourceRoot":"","sources":["../../src/api/entities.ts"],"names":[],"mappings":";AAAA;;;;;GAKG","sourcesContent":["/**\n * Spots SDK Entity Types\n *\n * These types mirror the Prisma schema entities but without @prisma/client dependency.\n * This allows the SDK to work in React Native where Prisma is not available.\n */\n\n// ============================================================================\n// ENUMS\n// ============================================================================\n\nexport type SpotType =\n  | 'CAFE'\n  | 'RESTAURANT'\n  | 'BAR'\n  | 'PARK'\n  | 'BEACH'\n  | 'COWORKING'\n  | 'LIBRARY'\n  | 'GYM'\n  | 'MUSEUM'\n  | 'GALLERY'\n  | 'THEATER'\n  | 'CINEMA'\n  | 'MALL'\n  | 'MARKET'\n  | 'HOTEL'\n  | 'HOSTEL'\n  | 'OTHER'\n\nexport type SpotPostType =\n  | 'CHECK_IN'\n  | 'LOOKING_FOR'\n  | 'OFFERING'\n  | 'QUESTION'\n  | 'EVENT'\n  | 'RECOMMENDATION'\n  | 'GENERAL'\n\nexport type AccountStatus = 'ACTIVE' | 'SUSPENDED' | 'DELETED' | 'PENDING'\n\nexport type ClaimStatus = 'PENDING' | 'APPROVED' | 'REJECTED'\n\nexport type ResponseStatus = 'PENDING' | 'ACCEPTED' | 'DECLINED'\n\nexport type ReportReason =\n  | 'SPAM'\n  | 'HARASSMENT'\n  | 'INAPPROPRIATE'\n  | 'SCAM'\n  | 'OTHER'\n\nexport type ReportStatus = 'PENDING' | 'REVIEWED' | 'RESOLVED' | 'DISMISSED'\n\nexport type NotificationType =\n  | 'POST_RESPONSE'\n  | 'POST_REPLY'\n  | 'POST_UPVOTE'\n  | 'RESPONSE_ACCEPTED'\n  | 'RESPONSE_DECLINED'\n  | 'NEW_MESSAGE'\n  | 'SYSTEM'\n\n// ============================================================================\n// ENTITY INTERFACES\n// ============================================================================\n\nexport interface User {\n  id: string\n  phone: string | null\n  email: string | null\n  name: string | null\n  bio: string | null\n  avatarUrl: string | null\n  status: AccountStatus\n  onboardingCompleted: boolean\n  lastActiveAt: Date | null\n  createdAt: Date\n  updatedAt: Date\n}\n\nexport interface Spot {\n  id: string\n  name: string\n  slug: string\n  description: string | null\n  address: string | null\n  city: string | null\n  country: string | null\n  latitude: number | null\n  longitude: number | null\n  type: SpotType\n  googlePlaceId: string | null\n  website: string | null\n  phone: string | null\n  imageUrl: string | null\n  ownerId: string | null\n  isVerified: boolean\n  createdAt: Date\n  updatedAt: Date\n}\n\nexport interface SpotPost {\n  id: string\n  spotId: string\n  userId: string\n  postType: SpotPostType\n  title: string\n  content: string | null\n  emoji: string | null\n  expiresAt: Date | null\n  status: 'ACTIVE' | 'FULFILLED' | 'EXPIRED' | 'DELETED'\n  upvoteCount: number\n  responseCount: number\n  replyCount: number\n  createdAt: Date\n  updatedAt: Date\n  // Relations (optional, populated by API)\n  user?: User\n  spot?: Spot\n}\n\nexport interface PostReply {\n  id: string\n  postId: string\n  userId: string\n  content: string\n  createdAt: Date\n  updatedAt: Date\n  user?: User\n}\n\nexport interface PostResponse {\n  id: string\n  postId: string\n  userId: string\n  note: string | null\n  status: ResponseStatus\n  createdAt: Date\n  updatedAt: Date\n  user?: User\n  post?: SpotPost\n}\n\nexport interface PostUpvote {\n  id: string\n  postId: string\n  userId: string\n  createdAt: Date\n}\n\n/**\n * PostUpvoter - user who upvoted a post (from /posts/:id/upvotes endpoint)\n */\nexport interface PostUpvoter {\n  id: string\n  userId: string\n  name: string | null\n  avatarUrl: string | null\n  createdAt: Date\n}\n\n/**\n * PostUpvotesResponse - response from /posts/:id/upvotes endpoint\n */\nexport interface PostUpvotesResponse {\n  data: PostUpvoter[]\n  meta: {\n    total: number\n    limit: number\n    offset: number\n    hasMore: boolean\n    currentUserUpvoted: boolean\n    isPostAuthor: boolean\n  }\n}\n\nexport interface PostReport {\n  id: string\n  postId: string\n  userId: string\n  reason: ReportReason\n  details: string | null\n  status: ReportStatus\n  createdAt: Date\n  updatedAt: Date\n}\n\nexport interface Club {\n  id: string\n  name: string\n  slug: string\n  description: string | null\n  imageUrl: string | null\n  isPrivate: boolean\n  createdById: string\n  createdAt: Date\n  updatedAt: Date\n}\n\nexport interface ClubMember {\n  id: string\n  clubId: string\n  userId: string\n  role: 'MEMBER' | 'ADMIN' | 'OWNER'\n  joinedAt: Date\n}\n\nexport interface Conversation {\n  id: string\n  createdAt: Date\n  updatedAt: Date\n  participants?: User[]\n  messages?: Message[]\n}\n\nexport interface Message {\n  id: string\n  conversationId: string\n  senderId: string\n  content: string\n  createdAt: Date\n  sender?: User\n}\n\nexport interface Notification {\n  id: string\n  userId: string\n  type: NotificationType\n  title: string\n  body: string | null\n  data: Record<string, unknown> | null\n  isRead: boolean\n  createdAt: Date\n}\n\nexport interface PostTemplate {\n  id: string\n  postType: SpotPostType\n  emoji: string\n  title: string\n  placeholder: string | null\n  isActive: boolean\n  sortOrder: number\n  createdAt: Date\n  updatedAt: Date\n}\n\nexport interface Vibe {\n  id: string\n  name: string\n  emoji: string | null\n  createdAt: Date\n}\n\nexport interface Interest {\n  id: string\n  name: string\n  emoji: string | null\n  category: string | null\n  createdAt: Date\n}\n\nexport interface Intention {\n  id: string\n  name: string\n  emoji: string | null\n  createdAt: Date\n}\n\nexport interface LifeSituation {\n  id: string\n  name: string\n  emoji: string | null\n  createdAt: Date\n}\n\nexport interface FavoriteSpot {\n  id: string\n  userId: string\n  spotId: string\n  createdAt: Date\n  spot?: Spot\n}\n\nexport interface SpotImage {\n  id: string\n  spotId: string\n  url: string\n  caption: string | null\n  sortOrder: number\n  createdAt: Date\n}\n\nexport interface SpotVibe {\n  id: string\n  spotId: string\n  vibeId: string\n  vibe?: Vibe\n}\n\nexport interface SpotIntention {\n  id: string\n  spotId: string\n  intentionId: string\n  intention?: Intention\n}\n\nexport interface SpotClaim {\n  id: string\n  spotId: string\n  userId: string\n  status: ClaimStatus\n  verificationMethod: string | null\n  createdAt: Date\n  updatedAt: Date\n}\n\nexport interface SpotSubscription {\n  id: string\n  spotId: string\n  userId: string\n  createdAt: Date\n  spot?: Spot\n}\n\nexport interface City {\n  id: string\n  name: string\n  country: string\n  latitude: number\n  longitude: number\n  timezone: string | null\n  createdAt: Date\n}\n\n// ============================================================================\n// API RESPONSE TYPES\n// ============================================================================\n\n// NOTE: ApiResponse is re-exported from @spots/types in types.ts\n\n/**\n * Paginated response with meta information\n */\nexport interface PaginatedResponse<T> {\n  data: T[]\n  meta: PaginationMeta\n}\n\nexport interface PaginationMeta {\n  total: number\n  page: number\n  limit: number\n  totalPages: number\n  hasNextPage: boolean\n  hasPreviousPage: boolean\n}\n\n// ============================================================================\n// MARKETPLACE TYPES\n// ============================================================================\n\nexport type ProductType = 'PHYSICAL' | 'DIGITAL' | 'SERVICE' | 'BUNDLE'\n\nexport type ProductStatus = 'DRAFT' | 'ACTIVE' | 'SOLD_OUT' | 'ARCHIVED'\n\nexport type OrderStatus =\n  | 'PENDING'\n  | 'CONFIRMED'\n  | 'PREPARING'\n  | 'READY'\n  | 'COMPLETED'\n  | 'CANCELLED'\n  | 'REFUNDED'\n\nexport interface Product {\n  id: string\n  spotId: string\n  name: string\n  slug: string\n  description: string | null\n  type: ProductType\n  status: ProductStatus\n  price: number\n  currency: string\n  imageUrl: string | null\n  images: string[]\n  stock: number | null\n  maxQuantity: number\n  sortOrder: number\n  metadata: Record<string, unknown> | null\n  createdAt: Date\n  updatedAt: Date\n}\n\nexport interface Order {\n  id: string\n  spotId: string\n  userId: string\n  status: OrderStatus\n  subtotal: number\n  tax: number\n  total: number\n  currency: string\n  notes: string | null\n  metadata: Record<string, unknown> | null\n  createdAt: Date\n  updatedAt: Date\n}\n\nexport interface OrderItem {\n  id: string\n  orderId: string\n  productId: string\n  quantity: number\n  unitPrice: number\n  total: number\n  createdAt: Date\n}\n"]}
@@ -3,12 +3,12 @@
3
3
  *
4
4
  * TanStack Query hooks for club mutation operations.
5
5
  */
6
- import { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
7
- import type { Club } from '../types';
6
+ import { type UseMutationOptions, type UseMutationResult } from '@tanstack/react-query';
7
+ import { type Club } from '../types';
8
8
  /**
9
9
  * Create a new club
10
10
  *
11
- * @endpoint POST /api/v1/clubs
11
+ * @endpoint POST /clubs
12
12
  */
13
13
  export declare function useCreateClub(options?: Omit<UseMutationOptions<Club, Error, {
14
14
  spotId: string;
@@ -22,7 +22,7 @@ export declare function useCreateClub(options?: Omit<UseMutationOptions<Club, Er
22
22
  /**
23
23
  * Update a club
24
24
  *
25
- * @endpoint PUT /api/v1/clubs/{id}
25
+ * @endpoint PUT /clubs/{id}
26
26
  */
27
27
  export declare function useUpdateClub(options?: Omit<UseMutationOptions<Club, Error, {
28
28
  clubId: string;
@@ -36,12 +36,12 @@ export declare function useUpdateClub(options?: Omit<UseMutationOptions<Club, Er
36
36
  /**
37
37
  * Join a club
38
38
  *
39
- * @endpoint POST /api/v1/clubs/{id}/join
39
+ * @endpoint POST /clubs/{id}/join
40
40
  */
41
41
  export declare function useJoinClub(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
42
42
  /**
43
43
  * Leave a club
44
44
  *
45
- * @endpoint POST /api/v1/clubs/{id}/leave
45
+ * @endpoint POST /clubs/{id}/leave
46
46
  */
47
47
  export declare function useLeaveClub(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
@@ -19,18 +19,20 @@ const users_1 = require("../queries/users");
19
19
  /**
20
20
  * Create a new club
21
21
  *
22
- * @endpoint POST /api/v1/clubs
22
+ * @endpoint POST /clubs
23
23
  */
24
24
  function useCreateClub(options) {
25
25
  const queryClient = (0, react_query_1.useQueryClient)();
26
26
  return (0, react_query_1.useMutation)({
27
27
  mutationFn: async (data) => {
28
28
  const client = (0, client_1.getApiClient)();
29
- const response = await client.post('/api/v1/clubs', data);
29
+ const response = await client.post('/clubs', data);
30
30
  return response.data.data;
31
31
  },
32
32
  onSuccess: (_, variables) => {
33
- queryClient.invalidateQueries({ queryKey: clubs_1.clubKeys.bySpot(variables.spotId) });
33
+ queryClient.invalidateQueries({
34
+ queryKey: clubs_1.clubKeys.bySpot(variables.spotId),
35
+ });
34
36
  },
35
37
  ...options,
36
38
  });
@@ -38,14 +40,14 @@ function useCreateClub(options) {
38
40
  /**
39
41
  * Update a club
40
42
  *
41
- * @endpoint PUT /api/v1/clubs/{id}
43
+ * @endpoint PUT /clubs/{id}
42
44
  */
43
45
  function useUpdateClub(options) {
44
46
  const queryClient = (0, react_query_1.useQueryClient)();
45
47
  return (0, react_query_1.useMutation)({
46
48
  mutationFn: async ({ clubId, ...data }) => {
47
49
  const client = (0, client_1.getApiClient)();
48
- const response = await client.put(`/api/v1/clubs/${clubId}`, data);
50
+ const response = await client.put(`/clubs/${clubId}`, data);
49
51
  return response.data.data;
50
52
  },
51
53
  onSuccess: (data, variables) => {
@@ -57,14 +59,14 @@ function useUpdateClub(options) {
57
59
  /**
58
60
  * Join a club
59
61
  *
60
- * @endpoint POST /api/v1/clubs/{id}/join
62
+ * @endpoint POST /clubs/{id}/join
61
63
  */
62
64
  function useJoinClub(options) {
63
65
  const queryClient = (0, react_query_1.useQueryClient)();
64
66
  return (0, react_query_1.useMutation)({
65
67
  mutationFn: async (clubId) => {
66
68
  const client = (0, client_1.getApiClient)();
67
- await client.post(`/api/v1/clubs/${clubId}/join`);
69
+ await client.post(`/clubs/${clubId}/join`);
68
70
  },
69
71
  onSuccess: (_, clubId) => {
70
72
  queryClient.invalidateQueries({ queryKey: clubs_1.clubKeys.detail(clubId) });
@@ -76,14 +78,14 @@ function useJoinClub(options) {
76
78
  /**
77
79
  * Leave a club
78
80
  *
79
- * @endpoint POST /api/v1/clubs/{id}/leave
81
+ * @endpoint POST /clubs/{id}/leave
80
82
  */
81
83
  function useLeaveClub(options) {
82
84
  const queryClient = (0, react_query_1.useQueryClient)();
83
85
  return (0, react_query_1.useMutation)({
84
86
  mutationFn: async (clubId) => {
85
87
  const client = (0, client_1.getApiClient)();
86
- await client.post(`/api/v1/clubs/${clubId}/leave`);
88
+ await client.post(`/clubs/${clubId}/leave`);
87
89
  },
88
90
  onSuccess: (_, clubId) => {
89
91
  queryClient.invalidateQueries({ queryKey: clubs_1.clubKeys.detail(clubId) });
@@ -92,4 +94,4 @@ function useLeaveClub(options) {
92
94
  ...options,
93
95
  });
94
96
  }
95
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2x1YnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL211dGF0aW9ucy9jbHVicy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7R0FJRzs7QUFpQkgsc0NBZ0JDO0FBT0Qsc0NBZ0JDO0FBT0Qsa0NBZ0JDO0FBT0Qsb0NBZ0JDO0FBcEdELHVEQUEyRztBQUMzRyxzQ0FBeUM7QUFDekMsNENBQTRDO0FBQzVDLDRDQUE0QztBQUc1QywrRUFBK0U7QUFDL0UsaUJBQWlCO0FBQ2pCLCtFQUErRTtBQUUvRTs7OztHQUlHO0FBQ0gsU0FBZ0IsYUFBYSxDQUMzQixPQUFxSDtJQUVySCxNQUFNLFdBQVcsR0FBRyxJQUFBLDRCQUFjLEdBQUUsQ0FBQztJQUVyQyxPQUFPLElBQUEseUJBQVcsRUFBQztRQUNqQixVQUFVLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBaUIsRUFBRTtZQUN4QyxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQztZQUM5QixNQUFNLFFBQVEsR0FBRyxNQUFNLE1BQU0sQ0FBQyxJQUFJLENBQW9CLGVBQWUsRUFBRSxJQUFJLENBQUMsQ0FBQztZQUM3RSxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQzVCLENBQUM7UUFDRCxTQUFTLEVBQUUsQ0FBQyxDQUFDLEVBQUUsU0FBUyxFQUFFLEVBQUU7WUFDMUIsV0FBVyxDQUFDLGlCQUFpQixDQUFDLEVBQUUsUUFBUSxFQUFFLGdCQUFRLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDakYsQ0FBQztRQUNELEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsYUFBYSxDQUMzQixPQUFzSDtJQUV0SCxNQUFNLFdBQVcsR0FBRyxJQUFBLDRCQUFjLEdBQUUsQ0FBQztJQUVyQyxPQUFPLElBQUEseUJBQVcsRUFBQztRQUNqQixVQUFVLEVBQUUsS0FBSyxFQUFFLEVBQUUsTUFBTSxFQUFFLEdBQUcsSUFBSSxFQUFFLEVBQWlCLEVBQUU7WUFDdkQsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUM7WUFDOUIsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsR0FBRyxDQUFvQixpQkFBaUIsTUFBTSxFQUFFLEVBQUUsSUFBSSxDQUFDLENBQUM7WUFDdEYsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztRQUM1QixDQUFDO1FBQ0QsU0FBUyxFQUFFLENBQUMsSUFBSSxFQUFFLFNBQVMsRUFBRSxFQUFFO1lBQzdCLFdBQVcsQ0FBQyxZQUFZLENBQUMsZ0JBQVEsQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQ3BFLENBQUM7UUFDRCxHQUFHLE9BQU87S0FDWCxDQUFDLENBQUM7QUFDTCxDQUFDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLFdBQVcsQ0FDekIsT0FBcUU7SUFFckUsTUFBTSxXQUFXLEdBQUcsSUFBQSw0QkFBYyxHQUFFLENBQUM7SUFFckMsT0FBTyxJQUFBLHlCQUFXLEVBQUM7UUFDakIsVUFBVSxFQUFFLEtBQUssRUFBRSxNQUFjLEVBQWlCLEVBQUU7WUFDbEQsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUM7WUFDOUIsTUFBTSxNQUFNLENBQUMsSUFBSSxDQUFDLGlCQUFpQixNQUFNLE9BQU8sQ0FBQyxDQUFDO1FBQ3BELENBQUM7UUFDRCxTQUFTLEVBQUUsQ0FBQyxDQUFDLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDdkIsV0FBVyxDQUFDLGlCQUFpQixDQUFDLEVBQUUsUUFBUSxFQUFFLGdCQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQztZQUNyRSxXQUFXLENBQUMsaUJBQWlCLENBQUMsRUFBRSxRQUFRLEVBQUUsZ0JBQVEsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDaEUsQ0FBQztRQUNELEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsWUFBWSxDQUMxQixPQUFxRTtJQUVyRSxNQUFNLFdBQVcsR0FBRyxJQUFBLDRCQUFjLEdBQUUsQ0FBQztJQUVyQyxPQUFPLElBQUEseUJBQVcsRUFBQztRQUNqQixVQUFVLEVBQUUsS0FBSyxFQUFFLE1BQWMsRUFBaUIsRUFBRTtZQUNsRCxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQztZQUM5QixNQUFNLE1BQU0sQ0FBQyxJQUFJLENBQUMsaUJBQWlCLE1BQU0sUUFBUSxDQUFDLENBQUM7UUFDckQsQ0FBQztRQUNELFNBQVMsRUFBRSxDQUFDLENBQUMsRUFBRSxNQUFNLEVBQUUsRUFBRTtZQUN2QixXQUFXLENBQUMsaUJBQWlCLENBQUMsRUFBRSxRQUFRLEVBQUUsZ0JBQVEsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1lBQ3JFLFdBQVcsQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLFFBQVEsRUFBRSxnQkFBUSxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNoRSxDQUFDO1FBQ0QsR0FBRyxPQUFPO0tBQ1gsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ2x1YnMgTXV0YXRpb24gSG9va3NcbiAqXG4gKiBUYW5TdGFjayBRdWVyeSBob29rcyBmb3IgY2x1YiBtdXRhdGlvbiBvcGVyYXRpb25zLlxuICovXG5cbmltcG9ydCB7IHVzZU11dGF0aW9uLCB1c2VRdWVyeUNsaWVudCwgVXNlTXV0YXRpb25PcHRpb25zLCBVc2VNdXRhdGlvblJlc3VsdCB9IGZyb20gJ0B0YW5zdGFjay9yZWFjdC1xdWVyeSc7XG5pbXBvcnQgeyBnZXRBcGlDbGllbnQgfSBmcm9tICcuLi9jbGllbnQnO1xuaW1wb3J0IHsgY2x1YktleXMgfSBmcm9tICcuLi9xdWVyaWVzL2NsdWJzJztcbmltcG9ydCB7IHVzZXJLZXlzIH0gZnJvbSAnLi4vcXVlcmllcy91c2Vycyc7XG5pbXBvcnQgdHlwZSB7IENsdWIsIEFwaVJlc3BvbnNlIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBNVVRBVElPTiBIT09LU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKipcbiAqIENyZWF0ZSBhIG5ldyBjbHViXG4gKlxuICogQGVuZHBvaW50IFBPU1QgL2FwaS92MS9jbHVic1xuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlQ3JlYXRlQ2x1YihcbiAgb3B0aW9ucz86IE9taXQ8VXNlTXV0YXRpb25PcHRpb25zPENsdWIsIEVycm9yLCB7IHNwb3RJZDogc3RyaW5nOyBuYW1lOiBzdHJpbmc7IGRlc2NyaXB0aW9uPzogc3RyaW5nIH0+LCAnbXV0YXRpb25Gbic+XG4pOiBVc2VNdXRhdGlvblJlc3VsdDxDbHViLCBFcnJvciwgeyBzcG90SWQ6IHN0cmluZzsgbmFtZTogc3RyaW5nOyBkZXNjcmlwdGlvbj86IHN0cmluZyB9PiB7XG4gIGNvbnN0IHF1ZXJ5Q2xpZW50ID0gdXNlUXVlcnlDbGllbnQoKTtcblxuICByZXR1cm4gdXNlTXV0YXRpb24oe1xuICAgIG11dGF0aW9uRm46IGFzeW5jIChkYXRhKTogUHJvbWlzZTxDbHViPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LnBvc3Q8QXBpUmVzcG9uc2U8Q2x1Yj4+KCcvYXBpL3YxL2NsdWJzJywgZGF0YSk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhO1xuICAgIH0sXG4gICAgb25TdWNjZXNzOiAoXywgdmFyaWFibGVzKSA9PiB7XG4gICAgICBxdWVyeUNsaWVudC5pbnZhbGlkYXRlUXVlcmllcyh7IHF1ZXJ5S2V5OiBjbHViS2V5cy5ieVNwb3QodmFyaWFibGVzLnNwb3RJZCkgfSk7XG4gICAgfSxcbiAgICAuLi5vcHRpb25zLFxuICB9KTtcbn1cblxuLyoqXG4gKiBVcGRhdGUgYSBjbHViXG4gKlxuICogQGVuZHBvaW50IFBVVCAvYXBpL3YxL2NsdWJzL3tpZH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVVwZGF0ZUNsdWIoXG4gIG9wdGlvbnM/OiBPbWl0PFVzZU11dGF0aW9uT3B0aW9uczxDbHViLCBFcnJvciwgeyBjbHViSWQ6IHN0cmluZzsgbmFtZT86IHN0cmluZzsgZGVzY3JpcHRpb24/OiBzdHJpbmcgfT4sICdtdXRhdGlvbkZuJz5cbik6IFVzZU11dGF0aW9uUmVzdWx0PENsdWIsIEVycm9yLCB7IGNsdWJJZDogc3RyaW5nOyBuYW1lPzogc3RyaW5nOyBkZXNjcmlwdGlvbj86IHN0cmluZyB9PiB7XG4gIGNvbnN0IHF1ZXJ5Q2xpZW50ID0gdXNlUXVlcnlDbGllbnQoKTtcblxuICByZXR1cm4gdXNlTXV0YXRpb24oe1xuICAgIG11dGF0aW9uRm46IGFzeW5jICh7IGNsdWJJZCwgLi4uZGF0YSB9KTogUHJvbWlzZTxDbHViPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LnB1dDxBcGlSZXNwb25zZTxDbHViPj4oYC9hcGkvdjEvY2x1YnMvJHtjbHViSWR9YCwgZGF0YSk7XG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhO1xuICAgIH0sXG4gICAgb25TdWNjZXNzOiAoZGF0YSwgdmFyaWFibGVzKSA9PiB7XG4gICAgICBxdWVyeUNsaWVudC5zZXRRdWVyeURhdGEoY2x1YktleXMuZGV0YWlsKHZhcmlhYmxlcy5jbHViSWQpLCBkYXRhKTtcbiAgICB9LFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pO1xufVxuXG4vKipcbiAqIEpvaW4gYSBjbHViXG4gKlxuICogQGVuZHBvaW50IFBPU1QgL2FwaS92MS9jbHVicy97aWR9L2pvaW5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZUpvaW5DbHViKFxuICBvcHRpb25zPzogT21pdDxVc2VNdXRhdGlvbk9wdGlvbnM8dm9pZCwgRXJyb3IsIHN0cmluZz4sICdtdXRhdGlvbkZuJz5cbik6IFVzZU11dGF0aW9uUmVzdWx0PHZvaWQsIEVycm9yLCBzdHJpbmc+IHtcbiAgY29uc3QgcXVlcnlDbGllbnQgPSB1c2VRdWVyeUNsaWVudCgpO1xuXG4gIHJldHVybiB1c2VNdXRhdGlvbih7XG4gICAgbXV0YXRpb25GbjogYXN5bmMgKGNsdWJJZDogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGF3YWl0IGNsaWVudC5wb3N0KGAvYXBpL3YxL2NsdWJzLyR7Y2x1YklkfS9qb2luYCk7XG4gICAgfSxcbiAgICBvblN1Y2Nlc3M6IChfLCBjbHViSWQpID0+IHtcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHsgcXVlcnlLZXk6IGNsdWJLZXlzLmRldGFpbChjbHViSWQpIH0pO1xuICAgICAgcXVlcnlDbGllbnQuaW52YWxpZGF0ZVF1ZXJpZXMoeyBxdWVyeUtleTogdXNlcktleXMuY2x1YnMoKSB9KTtcbiAgICB9LFxuICAgIC4uLm9wdGlvbnMsXG4gIH0pO1xufVxuXG4vKipcbiAqIExlYXZlIGEgY2x1YlxuICpcbiAqIEBlbmRwb2ludCBQT1NUIC9hcGkvdjEvY2x1YnMve2lkfS9sZWF2ZVxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlTGVhdmVDbHViKFxuICBvcHRpb25zPzogT21pdDxVc2VNdXRhdGlvbk9wdGlvbnM8dm9pZCwgRXJyb3IsIHN0cmluZz4sICdtdXRhdGlvbkZuJz5cbik6IFVzZU11dGF0aW9uUmVzdWx0PHZvaWQsIEVycm9yLCBzdHJpbmc+IHtcbiAgY29uc3QgcXVlcnlDbGllbnQgPSB1c2VRdWVyeUNsaWVudCgpO1xuXG4gIHJldHVybiB1c2VNdXRhdGlvbih7XG4gICAgbXV0YXRpb25GbjogYXN5bmMgKGNsdWJJZDogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKTtcbiAgICAgIGF3YWl0IGNsaWVudC5wb3N0KGAvYXBpL3YxL2NsdWJzLyR7Y2x1YklkfS9sZWF2ZWApO1xuICAgIH0sXG4gICAgb25TdWNjZXNzOiAoXywgY2x1YklkKSA9PiB7XG4gICAgICBxdWVyeUNsaWVudC5pbnZhbGlkYXRlUXVlcmllcyh7IHF1ZXJ5S2V5OiBjbHViS2V5cy5kZXRhaWwoY2x1YklkKSB9KTtcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHsgcXVlcnlLZXk6IHVzZXJLZXlzLmNsdWJzKCkgfSk7XG4gICAgfSxcbiAgICAuLi5vcHRpb25zLFxuICB9KTtcbn1cbiJdfQ==
97
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2x1YnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL211dGF0aW9ucy9jbHVicy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7R0FJRzs7QUF1Qkgsc0NBNkJDO0FBT0Qsc0NBOEJDO0FBT0Qsa0NBZ0JDO0FBT0Qsb0NBZ0JDO0FBcklELHVEQUs4QjtBQUU5QixzQ0FBc0M7QUFDdEMsNENBQXlDO0FBQ3pDLDRDQUF5QztBQUd6QywrRUFBK0U7QUFDL0UsaUJBQWlCO0FBQ2pCLCtFQUErRTtBQUUvRTs7OztHQUlHO0FBQ0gsU0FBZ0IsYUFBYSxDQUMzQixPQU9DO0lBTUQsTUFBTSxXQUFXLEdBQUcsSUFBQSw0QkFBYyxHQUFFLENBQUE7SUFFcEMsT0FBTyxJQUFBLHlCQUFXLEVBQUM7UUFDakIsVUFBVSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQWlCLEVBQUU7WUFDeEMsTUFBTSxNQUFNLEdBQUcsSUFBQSxxQkFBWSxHQUFFLENBQUE7WUFDN0IsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsSUFBSSxDQUFvQixRQUFRLEVBQUUsSUFBSSxDQUFDLENBQUE7WUFDckUsT0FBTyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQTtRQUMzQixDQUFDO1FBQ0QsU0FBUyxFQUFFLENBQUMsQ0FBQyxFQUFFLFNBQVMsRUFBRSxFQUFFO1lBQzFCLFdBQVcsQ0FBQyxpQkFBaUIsQ0FBQztnQkFDNUIsUUFBUSxFQUFFLGdCQUFRLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUM7YUFDNUMsQ0FBQyxDQUFBO1FBQ0osQ0FBQztRQUNELEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQTtBQUNKLENBQUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsYUFBYSxDQUMzQixPQU9DO0lBTUQsTUFBTSxXQUFXLEdBQUcsSUFBQSw0QkFBYyxHQUFFLENBQUE7SUFFcEMsT0FBTyxJQUFBLHlCQUFXLEVBQUM7UUFDakIsVUFBVSxFQUFFLEtBQUssRUFBRSxFQUFDLE1BQU0sRUFBRSxHQUFHLElBQUksRUFBQyxFQUFpQixFQUFFO1lBQ3JELE1BQU0sTUFBTSxHQUFHLElBQUEscUJBQVksR0FBRSxDQUFBO1lBQzdCLE1BQU0sUUFBUSxHQUFHLE1BQU0sTUFBTSxDQUFDLEdBQUcsQ0FDL0IsVUFBVSxNQUFNLEVBQUUsRUFDbEIsSUFBSSxDQUNMLENBQUE7WUFDRCxPQUFPLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFBO1FBQzNCLENBQUM7UUFDRCxTQUFTLEVBQUUsQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFLEVBQUU7WUFDN0IsV0FBVyxDQUFDLFlBQVksQ0FBQyxnQkFBUSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUE7UUFDbkUsQ0FBQztRQUNELEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQTtBQUNKLENBQUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsV0FBVyxDQUN6QixPQUFxRTtJQUVyRSxNQUFNLFdBQVcsR0FBRyxJQUFBLDRCQUFjLEdBQUUsQ0FBQTtJQUVwQyxPQUFPLElBQUEseUJBQVcsRUFBQztRQUNqQixVQUFVLEVBQUUsS0FBSyxFQUFFLE1BQWMsRUFBaUIsRUFBRTtZQUNsRCxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQTtZQUM3QixNQUFNLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxNQUFNLE9BQU8sQ0FBQyxDQUFBO1FBQzVDLENBQUM7UUFDRCxTQUFTLEVBQUUsQ0FBQyxDQUFDLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDdkIsV0FBVyxDQUFDLGlCQUFpQixDQUFDLEVBQUMsUUFBUSxFQUFFLGdCQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFDLENBQUMsQ0FBQTtZQUNsRSxXQUFXLENBQUMsaUJBQWlCLENBQUMsRUFBQyxRQUFRLEVBQUUsZ0JBQVEsQ0FBQyxLQUFLLEVBQUUsRUFBQyxDQUFDLENBQUE7UUFDN0QsQ0FBQztRQUNELEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQTtBQUNKLENBQUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsWUFBWSxDQUMxQixPQUFxRTtJQUVyRSxNQUFNLFdBQVcsR0FBRyxJQUFBLDRCQUFjLEdBQUUsQ0FBQTtJQUVwQyxPQUFPLElBQUEseUJBQVcsRUFBQztRQUNqQixVQUFVLEVBQUUsS0FBSyxFQUFFLE1BQWMsRUFBaUIsRUFBRTtZQUNsRCxNQUFNLE1BQU0sR0FBRyxJQUFBLHFCQUFZLEdBQUUsQ0FBQTtZQUM3QixNQUFNLE1BQU0sQ0FBQyxJQUFJLENBQUMsVUFBVSxNQUFNLFFBQVEsQ0FBQyxDQUFBO1FBQzdDLENBQUM7UUFDRCxTQUFTLEVBQUUsQ0FBQyxDQUFDLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDdkIsV0FBVyxDQUFDLGlCQUFpQixDQUFDLEVBQUMsUUFBUSxFQUFFLGdCQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFDLENBQUMsQ0FBQTtZQUNsRSxXQUFXLENBQUMsaUJBQWlCLENBQUMsRUFBQyxRQUFRLEVBQUUsZ0JBQVEsQ0FBQyxLQUFLLEVBQUUsRUFBQyxDQUFDLENBQUE7UUFDN0QsQ0FBQztRQUNELEdBQUcsT0FBTztLQUNYLENBQUMsQ0FBQTtBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENsdWJzIE11dGF0aW9uIEhvb2tzXG4gKlxuICogVGFuU3RhY2sgUXVlcnkgaG9va3MgZm9yIGNsdWIgbXV0YXRpb24gb3BlcmF0aW9ucy5cbiAqL1xuXG5pbXBvcnQge1xuICB1c2VNdXRhdGlvbixcbiAgdHlwZSBVc2VNdXRhdGlvbk9wdGlvbnMsXG4gIHR5cGUgVXNlTXV0YXRpb25SZXN1bHQsXG4gIHVzZVF1ZXJ5Q2xpZW50LFxufSBmcm9tICdAdGFuc3RhY2svcmVhY3QtcXVlcnknXG5cbmltcG9ydCB7Z2V0QXBpQ2xpZW50fSBmcm9tICcuLi9jbGllbnQnXG5pbXBvcnQge2NsdWJLZXlzfSBmcm9tICcuLi9xdWVyaWVzL2NsdWJzJ1xuaW1wb3J0IHt1c2VyS2V5c30gZnJvbSAnLi4vcXVlcmllcy91c2VycydcbmltcG9ydCB7dHlwZSBBcGlSZXNwb25zZSwgdHlwZSBDbHVifSBmcm9tICcuLi90eXBlcydcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gTVVUQVRJT04gSE9PS1Ncbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBDcmVhdGUgYSBuZXcgY2x1YlxuICpcbiAqIEBlbmRwb2ludCBQT1NUIC9jbHVic1xuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlQ3JlYXRlQ2x1YihcbiAgb3B0aW9ucz86IE9taXQ8XG4gICAgVXNlTXV0YXRpb25PcHRpb25zPFxuICAgICAgQ2x1YixcbiAgICAgIEVycm9yLFxuICAgICAge3Nwb3RJZDogc3RyaW5nOyBuYW1lOiBzdHJpbmc7IGRlc2NyaXB0aW9uPzogc3RyaW5nfVxuICAgID4sXG4gICAgJ211dGF0aW9uRm4nXG4gID4sXG4pOiBVc2VNdXRhdGlvblJlc3VsdDxcbiAgQ2x1YixcbiAgRXJyb3IsXG4gIHtzcG90SWQ6IHN0cmluZzsgbmFtZTogc3RyaW5nOyBkZXNjcmlwdGlvbj86IHN0cmluZ31cbj4ge1xuICBjb25zdCBxdWVyeUNsaWVudCA9IHVzZVF1ZXJ5Q2xpZW50KClcblxuICByZXR1cm4gdXNlTXV0YXRpb24oe1xuICAgIG11dGF0aW9uRm46IGFzeW5jIChkYXRhKTogUHJvbWlzZTxDbHViPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKVxuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQucG9zdDxBcGlSZXNwb25zZTxDbHViPj4oJy9jbHVicycsIGRhdGEpXG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhXG4gICAgfSxcbiAgICBvblN1Y2Nlc3M6IChfLCB2YXJpYWJsZXMpID0+IHtcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHtcbiAgICAgICAgcXVlcnlLZXk6IGNsdWJLZXlzLmJ5U3BvdCh2YXJpYWJsZXMuc3BvdElkKSxcbiAgICAgIH0pXG4gICAgfSxcbiAgICAuLi5vcHRpb25zLFxuICB9KVxufVxuXG4vKipcbiAqIFVwZGF0ZSBhIGNsdWJcbiAqXG4gKiBAZW5kcG9pbnQgUFVUIC9jbHVicy97aWR9XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VVcGRhdGVDbHViKFxuICBvcHRpb25zPzogT21pdDxcbiAgICBVc2VNdXRhdGlvbk9wdGlvbnM8XG4gICAgICBDbHViLFxuICAgICAgRXJyb3IsXG4gICAgICB7Y2x1YklkOiBzdHJpbmc7IG5hbWU/OiBzdHJpbmc7IGRlc2NyaXB0aW9uPzogc3RyaW5nfVxuICAgID4sXG4gICAgJ211dGF0aW9uRm4nXG4gID4sXG4pOiBVc2VNdXRhdGlvblJlc3VsdDxcbiAgQ2x1YixcbiAgRXJyb3IsXG4gIHtjbHViSWQ6IHN0cmluZzsgbmFtZT86IHN0cmluZzsgZGVzY3JpcHRpb24/OiBzdHJpbmd9XG4+IHtcbiAgY29uc3QgcXVlcnlDbGllbnQgPSB1c2VRdWVyeUNsaWVudCgpXG5cbiAgcmV0dXJuIHVzZU11dGF0aW9uKHtcbiAgICBtdXRhdGlvbkZuOiBhc3luYyAoe2NsdWJJZCwgLi4uZGF0YX0pOiBQcm9taXNlPENsdWI+ID0+IHtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGdldEFwaUNsaWVudCgpXG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5wdXQ8QXBpUmVzcG9uc2U8Q2x1Yj4+KFxuICAgICAgICBgL2NsdWJzLyR7Y2x1YklkfWAsXG4gICAgICAgIGRhdGEsXG4gICAgICApXG4gICAgICByZXR1cm4gcmVzcG9uc2UuZGF0YS5kYXRhXG4gICAgfSxcbiAgICBvblN1Y2Nlc3M6IChkYXRhLCB2YXJpYWJsZXMpID0+IHtcbiAgICAgIHF1ZXJ5Q2xpZW50LnNldFF1ZXJ5RGF0YShjbHViS2V5cy5kZXRhaWwodmFyaWFibGVzLmNsdWJJZCksIGRhdGEpXG4gICAgfSxcbiAgICAuLi5vcHRpb25zLFxuICB9KVxufVxuXG4vKipcbiAqIEpvaW4gYSBjbHViXG4gKlxuICogQGVuZHBvaW50IFBPU1QgL2NsdWJzL3tpZH0vam9pblxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlSm9pbkNsdWIoXG4gIG9wdGlvbnM/OiBPbWl0PFVzZU11dGF0aW9uT3B0aW9uczx2b2lkLCBFcnJvciwgc3RyaW5nPiwgJ211dGF0aW9uRm4nPixcbik6IFVzZU11dGF0aW9uUmVzdWx0PHZvaWQsIEVycm9yLCBzdHJpbmc+IHtcbiAgY29uc3QgcXVlcnlDbGllbnQgPSB1c2VRdWVyeUNsaWVudCgpXG5cbiAgcmV0dXJuIHVzZU11dGF0aW9uKHtcbiAgICBtdXRhdGlvbkZuOiBhc3luYyAoY2x1YklkOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+ID0+IHtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGdldEFwaUNsaWVudCgpXG4gICAgICBhd2FpdCBjbGllbnQucG9zdChgL2NsdWJzLyR7Y2x1YklkfS9qb2luYClcbiAgICB9LFxuICAgIG9uU3VjY2VzczogKF8sIGNsdWJJZCkgPT4ge1xuICAgICAgcXVlcnlDbGllbnQuaW52YWxpZGF0ZVF1ZXJpZXMoe3F1ZXJ5S2V5OiBjbHViS2V5cy5kZXRhaWwoY2x1YklkKX0pXG4gICAgICBxdWVyeUNsaWVudC5pbnZhbGlkYXRlUXVlcmllcyh7cXVlcnlLZXk6IHVzZXJLZXlzLmNsdWJzKCl9KVxuICAgIH0sXG4gICAgLi4ub3B0aW9ucyxcbiAgfSlcbn1cblxuLyoqXG4gKiBMZWF2ZSBhIGNsdWJcbiAqXG4gKiBAZW5kcG9pbnQgUE9TVCAvY2x1YnMve2lkfS9sZWF2ZVxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlTGVhdmVDbHViKFxuICBvcHRpb25zPzogT21pdDxVc2VNdXRhdGlvbk9wdGlvbnM8dm9pZCwgRXJyb3IsIHN0cmluZz4sICdtdXRhdGlvbkZuJz4sXG4pOiBVc2VNdXRhdGlvblJlc3VsdDx2b2lkLCBFcnJvciwgc3RyaW5nPiB7XG4gIGNvbnN0IHF1ZXJ5Q2xpZW50ID0gdXNlUXVlcnlDbGllbnQoKVxuXG4gIHJldHVybiB1c2VNdXRhdGlvbih7XG4gICAgbXV0YXRpb25GbjogYXN5bmMgKGNsdWJJZDogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gICAgICBjb25zdCBjbGllbnQgPSBnZXRBcGlDbGllbnQoKVxuICAgICAgYXdhaXQgY2xpZW50LnBvc3QoYC9jbHVicy8ke2NsdWJJZH0vbGVhdmVgKVxuICAgIH0sXG4gICAgb25TdWNjZXNzOiAoXywgY2x1YklkKSA9PiB7XG4gICAgICBxdWVyeUNsaWVudC5pbnZhbGlkYXRlUXVlcmllcyh7cXVlcnlLZXk6IGNsdWJLZXlzLmRldGFpbChjbHViSWQpfSlcbiAgICAgIHF1ZXJ5Q2xpZW50LmludmFsaWRhdGVRdWVyaWVzKHtxdWVyeUtleTogdXNlcktleXMuY2x1YnMoKX0pXG4gICAgfSxcbiAgICAuLi5vcHRpb25zLFxuICB9KVxufVxuIl19
@@ -3,18 +3,18 @@
3
3
  *
4
4
  * TanStack Query hooks for conversation/messaging mutation operations.
5
5
  */
6
- import { UseMutationOptions, UseMutationResult } from '@tanstack/react-query';
7
- import type { Conversation, Message, CreateConversationRequest, SendMessageRequest } from '../types';
6
+ import { type UseMutationOptions, type UseMutationResult } from '@tanstack/react-query';
7
+ import { type Conversation, type CreateConversationRequest, type Message, type SendMessageRequest } from '../types';
8
8
  /**
9
9
  * Create a new conversation
10
10
  *
11
- * @endpoint POST /api/v1/conversations
11
+ * @endpoint POST /conversations
12
12
  */
13
13
  export declare function useCreateConversation(options?: Omit<UseMutationOptions<Conversation, Error, CreateConversationRequest>, 'mutationFn'>): UseMutationResult<Conversation, Error, CreateConversationRequest>;
14
14
  /**
15
15
  * Create or get direct conversation with a user
16
16
  *
17
- * @endpoint POST /api/v1/conversations/direct
17
+ * @endpoint POST /conversations/direct
18
18
  */
19
19
  export declare function useCreateDirectConversation(options?: Omit<UseMutationOptions<Conversation, Error, {
20
20
  userId: string;
@@ -24,7 +24,7 @@ export declare function useCreateDirectConversation(options?: Omit<UseMutationOp
24
24
  /**
25
25
  * Send a message in a conversation
26
26
  *
27
- * @endpoint POST /api/v1/conversations/{id}/messages
27
+ * @endpoint POST /conversations/{id}/messages
28
28
  */
29
29
  export declare function useSendMessage(options?: Omit<UseMutationOptions<Message, Error, {
30
30
  conversationId: string;
@@ -34,12 +34,12 @@ export declare function useSendMessage(options?: Omit<UseMutationOptions<Message
34
34
  /**
35
35
  * Mark conversation as read
36
36
  *
37
- * @endpoint PUT /api/v1/conversations/{id}/read
37
+ * @endpoint PUT /conversations/{id}/read
38
38
  */
39
39
  export declare function useMarkConversationAsRead(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;
40
40
  /**
41
41
  * Send typing indicator
42
42
  *
43
- * @endpoint POST /api/v1/conversations/{id}/typing
43
+ * @endpoint POST /conversations/{id}/typing
44
44
  */
45
45
  export declare function useSendTypingIndicator(options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>): UseMutationResult<void, Error, string>;