@spotsdev/sdk 1.0.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 (79) hide show
  1. package/dist/api/client.d.ts +12 -0
  2. package/dist/api/client.js +68 -0
  3. package/dist/api/mutations/clubs.d.ts +47 -0
  4. package/dist/api/mutations/clubs.js +95 -0
  5. package/dist/api/mutations/conversations.d.ts +45 -0
  6. package/dist/api/mutations/conversations.js +110 -0
  7. package/dist/api/mutations/index.d.ts +13 -0
  8. package/dist/api/mutations/index.js +38 -0
  9. package/dist/api/mutations/notifications.d.ts +38 -0
  10. package/dist/api/mutations/notifications.js +64 -0
  11. package/dist/api/mutations/orders.d.ts +73 -0
  12. package/dist/api/mutations/orders.js +116 -0
  13. package/dist/api/mutations/posts.d.ts +123 -0
  14. package/dist/api/mutations/posts.js +229 -0
  15. package/dist/api/mutations/products.d.ts +81 -0
  16. package/dist/api/mutations/products.js +102 -0
  17. package/dist/api/mutations/spots.d.ts +59 -0
  18. package/dist/api/mutations/spots.js +129 -0
  19. package/dist/api/mutations/users.d.ts +71 -0
  20. package/dist/api/mutations/users.js +173 -0
  21. package/dist/api/queries/auth.d.ts +37 -0
  22. package/dist/api/queries/auth.js +61 -0
  23. package/dist/api/queries/clubs.d.ts +52 -0
  24. package/dist/api/queries/clubs.js +116 -0
  25. package/dist/api/queries/conversations.d.ts +52 -0
  26. package/dist/api/queries/conversations.js +83 -0
  27. package/dist/api/queries/index.d.ts +26 -0
  28. package/dist/api/queries/index.js +65 -0
  29. package/dist/api/queries/misc.d.ts +54 -0
  30. package/dist/api/queries/misc.js +129 -0
  31. package/dist/api/queries/notifications.d.ts +34 -0
  32. package/dist/api/queries/notifications.js +62 -0
  33. package/dist/api/queries/orders.d.ts +45 -0
  34. package/dist/api/queries/orders.js +93 -0
  35. package/dist/api/queries/posts.d.ts +55 -0
  36. package/dist/api/queries/posts.js +130 -0
  37. package/dist/api/queries/products.d.ts +52 -0
  38. package/dist/api/queries/products.js +89 -0
  39. package/dist/api/queries/spots.d.ts +78 -0
  40. package/dist/api/queries/spots.js +168 -0
  41. package/dist/api/queries/templates.d.ts +42 -0
  42. package/dist/api/queries/templates.js +86 -0
  43. package/dist/api/queries/users.d.ts +90 -0
  44. package/dist/api/queries/users.js +187 -0
  45. package/dist/api/services/index.d.ts +2 -0
  46. package/dist/api/services/index.js +8 -0
  47. package/dist/api/services/marketplace.d.ts +129 -0
  48. package/dist/api/services/marketplace.js +168 -0
  49. package/dist/api/types.d.ts +54 -0
  50. package/dist/api/types.js +34 -0
  51. package/dist/index.d.ts +38 -0
  52. package/dist/index.js +73 -0
  53. package/package.json +57 -0
  54. package/src/api/client.ts +78 -0
  55. package/src/api/mutations/clubs.ts +107 -0
  56. package/src/api/mutations/conversations.ts +124 -0
  57. package/src/api/mutations/index.ts +29 -0
  58. package/src/api/mutations/notifications.ts +70 -0
  59. package/src/api/mutations/orders.ts +174 -0
  60. package/src/api/mutations/posts.ts +278 -0
  61. package/src/api/mutations/products.ts +160 -0
  62. package/src/api/mutations/spots.ts +146 -0
  63. package/src/api/mutations/users.ts +197 -0
  64. package/src/api/queries/auth.ts +67 -0
  65. package/src/api/queries/clubs.ts +135 -0
  66. package/src/api/queries/conversations.ts +94 -0
  67. package/src/api/queries/index.ts +48 -0
  68. package/src/api/queries/misc.ts +140 -0
  69. package/src/api/queries/notifications.ts +66 -0
  70. package/src/api/queries/orders.ts +119 -0
  71. package/src/api/queries/posts.ts +142 -0
  72. package/src/api/queries/products.ts +123 -0
  73. package/src/api/queries/spots.ts +201 -0
  74. package/src/api/queries/templates.ts +95 -0
  75. package/src/api/queries/users.ts +206 -0
  76. package/src/api/services/index.ts +6 -0
  77. package/src/api/services/marketplace.ts +265 -0
  78. package/src/api/types.ts +144 -0
  79. package/src/index.ts +63 -0
@@ -0,0 +1,90 @@
1
+ /**
2
+ * Users Query Hooks
3
+ *
4
+ * TanStack Query hooks for user-related operations.
5
+ */
6
+ import { UseQueryOptions, UseQueryResult } from '@tanstack/react-query';
7
+ import type { User, Post, Club, Spot, SpotSubscription, FavoriteSpot } from '../types';
8
+ export declare const userKeys: {
9
+ all: readonly ["users"];
10
+ me: () => readonly ["users", "me"];
11
+ stats: () => readonly ["users", "me", "stats"];
12
+ activity: (limit?: number) => readonly ["users", "me", "activity", number | undefined];
13
+ posts: (params?: {
14
+ page?: number;
15
+ limit?: number;
16
+ }) => readonly ["users", "me", "posts", {
17
+ page?: number;
18
+ limit?: number;
19
+ } | undefined];
20
+ clubs: () => readonly ["users", "me", "clubs"];
21
+ subscriptions: () => readonly ["users", "me", "subscriptions"];
22
+ blocked: () => readonly ["users", "me", "blocked"];
23
+ ownedSpots: () => readonly ["users", "me", "owned-spots"];
24
+ favorites: () => readonly ["users", "me", "favorites"];
25
+ };
26
+ /**
27
+ * Get current user's profile
28
+ *
29
+ * @endpoint GET /api/v1/users/me
30
+ */
31
+ export declare function useCurrentUser(options?: Omit<UseQueryOptions<User>, 'queryKey' | 'queryFn'>): UseQueryResult<User>;
32
+ /**
33
+ * Get current user's stats
34
+ *
35
+ * @endpoint GET /api/v1/users/me/stats
36
+ */
37
+ export declare function useUserStats(options?: Omit<UseQueryOptions<{
38
+ posts: number;
39
+ responses: number;
40
+ upvotes: number;
41
+ }>, 'queryKey' | 'queryFn'>): UseQueryResult<{
42
+ posts: number;
43
+ responses: number;
44
+ upvotes: number;
45
+ }>;
46
+ /**
47
+ * Get current user's activity
48
+ *
49
+ * @endpoint GET /api/v1/users/me/activity
50
+ */
51
+ export declare function useUserActivity(limit?: number, options?: Omit<UseQueryOptions<unknown[]>, 'queryKey' | 'queryFn'>): UseQueryResult<unknown[]>;
52
+ /**
53
+ * Get current user's posts
54
+ *
55
+ * @endpoint GET /api/v1/user/me/posts
56
+ */
57
+ export declare function useUserPosts(params?: {
58
+ page?: number;
59
+ limit?: number;
60
+ }, options?: Omit<UseQueryOptions<Post[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Post[]>;
61
+ /**
62
+ * Get current user's clubs
63
+ *
64
+ * @endpoint GET /api/v1/user/me/clubs
65
+ */
66
+ export declare function useUserClubs(options?: Omit<UseQueryOptions<Club[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Club[]>;
67
+ /**
68
+ * Get current user's spot subscriptions
69
+ *
70
+ * @endpoint GET /api/v1/user/me/subscriptions
71
+ */
72
+ export declare function useUserSubscriptions(options?: Omit<UseQueryOptions<SpotSubscription[]>, 'queryKey' | 'queryFn'>): UseQueryResult<SpotSubscription[]>;
73
+ /**
74
+ * Get blocked users list
75
+ *
76
+ * @endpoint GET /api/v1/user/me/blocked
77
+ */
78
+ export declare function useBlockedUsers(options?: Omit<UseQueryOptions<User[]>, 'queryKey' | 'queryFn'>): UseQueryResult<User[]>;
79
+ /**
80
+ * Get current user's owned spots (for business owners)
81
+ *
82
+ * @endpoint GET /api/v1/users/me/owned-spots
83
+ */
84
+ export declare function useOwnedSpots(options?: Omit<UseQueryOptions<Spot[]>, 'queryKey' | 'queryFn'>): UseQueryResult<Spot[]>;
85
+ /**
86
+ * Get current user's favorite spots
87
+ *
88
+ * @endpoint GET /api/v1/users/me/favorites
89
+ */
90
+ export declare function useUserFavorites(options?: Omit<UseQueryOptions<FavoriteSpot[]>, 'queryKey' | 'queryFn'>): UseQueryResult<FavoriteSpot[]>;
@@ -0,0 +1,187 @@
1
+ "use strict";
2
+ /**
3
+ * Users Query Hooks
4
+ *
5
+ * TanStack Query hooks for user-related operations.
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.userKeys = void 0;
9
+ exports.useCurrentUser = useCurrentUser;
10
+ exports.useUserStats = useUserStats;
11
+ exports.useUserActivity = useUserActivity;
12
+ exports.useUserPosts = useUserPosts;
13
+ exports.useUserClubs = useUserClubs;
14
+ exports.useUserSubscriptions = useUserSubscriptions;
15
+ exports.useBlockedUsers = useBlockedUsers;
16
+ exports.useOwnedSpots = useOwnedSpots;
17
+ exports.useUserFavorites = useUserFavorites;
18
+ const react_query_1 = require("@tanstack/react-query");
19
+ const client_1 = require("../client");
20
+ // ============================================================================
21
+ // QUERY KEYS
22
+ // ============================================================================
23
+ exports.userKeys = {
24
+ all: ['users'],
25
+ me: () => [...exports.userKeys.all, 'me'],
26
+ stats: () => [...exports.userKeys.me(), 'stats'],
27
+ activity: (limit) => [...exports.userKeys.me(), 'activity', limit],
28
+ posts: (params) => [...exports.userKeys.me(), 'posts', params],
29
+ clubs: () => [...exports.userKeys.me(), 'clubs'],
30
+ subscriptions: () => [...exports.userKeys.me(), 'subscriptions'],
31
+ blocked: () => [...exports.userKeys.me(), 'blocked'],
32
+ ownedSpots: () => [...exports.userKeys.me(), 'owned-spots'],
33
+ favorites: () => [...exports.userKeys.me(), 'favorites'],
34
+ };
35
+ // ============================================================================
36
+ // QUERY HOOKS
37
+ // ============================================================================
38
+ /**
39
+ * Get current user's profile
40
+ *
41
+ * @endpoint GET /api/v1/users/me
42
+ */
43
+ function useCurrentUser(options) {
44
+ return (0, react_query_1.useQuery)({
45
+ queryKey: exports.userKeys.me(),
46
+ queryFn: async () => {
47
+ const client = (0, client_1.getApiClient)();
48
+ const response = await client.get('/api/v1/users/me');
49
+ return response.data.data;
50
+ },
51
+ ...options,
52
+ });
53
+ }
54
+ /**
55
+ * Get current user's stats
56
+ *
57
+ * @endpoint GET /api/v1/users/me/stats
58
+ */
59
+ function useUserStats(options) {
60
+ return (0, react_query_1.useQuery)({
61
+ queryKey: exports.userKeys.stats(),
62
+ queryFn: async () => {
63
+ const client = (0, client_1.getApiClient)();
64
+ const response = await client.get('/api/v1/users/me/stats');
65
+ return response.data.data;
66
+ },
67
+ ...options,
68
+ });
69
+ }
70
+ /**
71
+ * Get current user's activity
72
+ *
73
+ * @endpoint GET /api/v1/users/me/activity
74
+ */
75
+ function useUserActivity(limit = 10, options) {
76
+ return (0, react_query_1.useQuery)({
77
+ queryKey: exports.userKeys.activity(limit),
78
+ queryFn: async () => {
79
+ const client = (0, client_1.getApiClient)();
80
+ const response = await client.get(`/api/v1/users/me/activity?limit=${limit}`);
81
+ return response.data.data;
82
+ },
83
+ ...options,
84
+ });
85
+ }
86
+ /**
87
+ * Get current user's posts
88
+ *
89
+ * @endpoint GET /api/v1/user/me/posts
90
+ */
91
+ function useUserPosts(params, options) {
92
+ return (0, react_query_1.useQuery)({
93
+ queryKey: exports.userKeys.posts(params),
94
+ queryFn: async () => {
95
+ const client = (0, client_1.getApiClient)();
96
+ const queryParams = new URLSearchParams();
97
+ if (params?.page)
98
+ queryParams.set('page', String(params.page));
99
+ if (params?.limit)
100
+ queryParams.set('limit', String(params.limit));
101
+ const response = await client.get(`/api/v1/user/me/posts?${queryParams}`);
102
+ return response.data.data;
103
+ },
104
+ ...options,
105
+ });
106
+ }
107
+ /**
108
+ * Get current user's clubs
109
+ *
110
+ * @endpoint GET /api/v1/user/me/clubs
111
+ */
112
+ function useUserClubs(options) {
113
+ return (0, react_query_1.useQuery)({
114
+ queryKey: exports.userKeys.clubs(),
115
+ queryFn: async () => {
116
+ const client = (0, client_1.getApiClient)();
117
+ const response = await client.get('/api/v1/user/me/clubs');
118
+ return response.data.data;
119
+ },
120
+ ...options,
121
+ });
122
+ }
123
+ /**
124
+ * Get current user's spot subscriptions
125
+ *
126
+ * @endpoint GET /api/v1/user/me/subscriptions
127
+ */
128
+ function useUserSubscriptions(options) {
129
+ return (0, react_query_1.useQuery)({
130
+ queryKey: exports.userKeys.subscriptions(),
131
+ queryFn: async () => {
132
+ const client = (0, client_1.getApiClient)();
133
+ const response = await client.get('/api/v1/user/me/subscriptions');
134
+ return response.data.data;
135
+ },
136
+ ...options,
137
+ });
138
+ }
139
+ /**
140
+ * Get blocked users list
141
+ *
142
+ * @endpoint GET /api/v1/user/me/blocked
143
+ */
144
+ function useBlockedUsers(options) {
145
+ return (0, react_query_1.useQuery)({
146
+ queryKey: exports.userKeys.blocked(),
147
+ queryFn: async () => {
148
+ const client = (0, client_1.getApiClient)();
149
+ const response = await client.get('/api/v1/user/me/blocked');
150
+ return response.data.data;
151
+ },
152
+ ...options,
153
+ });
154
+ }
155
+ /**
156
+ * Get current user's owned spots (for business owners)
157
+ *
158
+ * @endpoint GET /api/v1/users/me/owned-spots
159
+ */
160
+ function useOwnedSpots(options) {
161
+ return (0, react_query_1.useQuery)({
162
+ queryKey: exports.userKeys.ownedSpots(),
163
+ queryFn: async () => {
164
+ const client = (0, client_1.getApiClient)();
165
+ const response = await client.get('/api/v1/users/me/owned-spots');
166
+ return response.data.data;
167
+ },
168
+ ...options,
169
+ });
170
+ }
171
+ /**
172
+ * Get current user's favorite spots
173
+ *
174
+ * @endpoint GET /api/v1/users/me/favorites
175
+ */
176
+ function useUserFavorites(options) {
177
+ return (0, react_query_1.useQuery)({
178
+ queryKey: exports.userKeys.favorites(),
179
+ queryFn: async () => {
180
+ const client = (0, client_1.getApiClient)();
181
+ const response = await client.get('/api/v1/users/me/favorites');
182
+ return response.data.data;
183
+ },
184
+ ...options,
185
+ });
186
+ }
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"]}
@@ -0,0 +1,2 @@
1
+ export { productsService, ordersService, paymentsService } from './marketplace';
2
+ export type { CreateProductInput, UpdateProductInput, CreateOrderInput, } from './marketplace';
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.paymentsService = exports.ordersService = exports.productsService = void 0;
4
+ var marketplace_1 = require("./marketplace");
5
+ Object.defineProperty(exports, "productsService", { enumerable: true, get: function () { return marketplace_1.productsService; } });
6
+ Object.defineProperty(exports, "ordersService", { enumerable: true, get: function () { return marketplace_1.ordersService; } });
7
+ Object.defineProperty(exports, "paymentsService", { enumerable: true, get: function () { return marketplace_1.paymentsService; } });
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL3NlcnZpY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZDQUFnRjtBQUF2RSw4R0FBQSxlQUFlLE9BQUE7QUFBRSw0R0FBQSxhQUFhLE9BQUE7QUFBRSw4R0FBQSxlQUFlLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBwcm9kdWN0c1NlcnZpY2UsIG9yZGVyc1NlcnZpY2UsIHBheW1lbnRzU2VydmljZSB9IGZyb20gJy4vbWFya2V0cGxhY2UnO1xuZXhwb3J0IHR5cGUge1xuICBDcmVhdGVQcm9kdWN0SW5wdXQsXG4gIFVwZGF0ZVByb2R1Y3RJbnB1dCxcbiAgQ3JlYXRlT3JkZXJJbnB1dCxcbn0gZnJvbSAnLi9tYXJrZXRwbGFjZSc7XG4iXX0=
@@ -0,0 +1,129 @@
1
+ /**
2
+ * Marketplace API Service
3
+ *
4
+ * Plain async functions for products and orders.
5
+ * Can be used in tests or non-React environments.
6
+ */
7
+ import type { Product, ProductType, ProductStatus, OrderStatus, PaginatedResponse } from '../types';
8
+ import type { ProductWithSpot } from '../queries/products';
9
+ import type { OrderWithDetails } from '../queries/orders';
10
+ export type { ProductWithSpot, OrderWithDetails };
11
+ export interface CreateProductInput {
12
+ name: string;
13
+ description?: string;
14
+ type: ProductType;
15
+ price: number;
16
+ currency?: string;
17
+ stockQuantity?: number;
18
+ lowStockAlert?: number;
19
+ deliveryRadius?: number;
20
+ prepTimeMinutes?: number;
21
+ eventDate?: string;
22
+ imageUrl?: string;
23
+ }
24
+ export interface UpdateProductInput {
25
+ name?: string;
26
+ description?: string;
27
+ price?: number;
28
+ stockQuantity?: number;
29
+ lowStockAlert?: number;
30
+ status?: ProductStatus;
31
+ deliveryRadius?: number;
32
+ prepTimeMinutes?: number;
33
+ eventDate?: string;
34
+ imageUrl?: string;
35
+ }
36
+ export interface CreateOrderInput {
37
+ spotId: string;
38
+ items: Array<{
39
+ productId: string;
40
+ quantity: number;
41
+ }>;
42
+ notes?: string;
43
+ }
44
+ export declare const productsService: {
45
+ /**
46
+ * List products for a spot
47
+ */
48
+ listBySpot(spotId: string, params?: {
49
+ type?: ProductType;
50
+ status?: ProductStatus;
51
+ limit?: number;
52
+ page?: number;
53
+ }): Promise<PaginatedResponse<Product>>;
54
+ /**
55
+ * Get product by ID
56
+ */
57
+ getById(productId: string): Promise<ProductWithSpot>;
58
+ /**
59
+ * Get product by slug
60
+ */
61
+ getBySlug(spotId: string, slug: string): Promise<ProductWithSpot>;
62
+ /**
63
+ * Create a product (requires owner auth)
64
+ */
65
+ create(spotId: string, data: CreateProductInput): Promise<Product>;
66
+ /**
67
+ * Update a product (requires owner auth)
68
+ */
69
+ update(productId: string, data: UpdateProductInput): Promise<Product>;
70
+ /**
71
+ * Delete a product (requires owner auth)
72
+ */
73
+ delete(productId: string): Promise<void>;
74
+ /**
75
+ * Adjust stock (requires owner auth)
76
+ */
77
+ adjustStock(productId: string, quantity: number, reason: "RESTOCK" | "ADJUSTMENT", notes?: string): Promise<Product>;
78
+ };
79
+ export declare const ordersService: {
80
+ /**
81
+ * Create an order
82
+ */
83
+ create(data: CreateOrderInput): Promise<OrderWithDetails>;
84
+ /**
85
+ * Get order by ID
86
+ */
87
+ getById(orderId: string): Promise<OrderWithDetails>;
88
+ /**
89
+ * List my orders (as buyer)
90
+ */
91
+ listMyOrders(params?: {
92
+ status?: OrderStatus;
93
+ limit?: number;
94
+ page?: number;
95
+ }): Promise<PaginatedResponse<OrderWithDetails>>;
96
+ /**
97
+ * List spot orders (as seller)
98
+ */
99
+ listSpotOrders(spotId: string, params?: {
100
+ status?: OrderStatus;
101
+ limit?: number;
102
+ page?: number;
103
+ }): Promise<PaginatedResponse<OrderWithDetails>>;
104
+ /**
105
+ * Update order status (as seller)
106
+ */
107
+ updateStatus(orderId: string, status: OrderStatus): Promise<OrderWithDetails>;
108
+ /**
109
+ * Cancel order (as buyer)
110
+ */
111
+ cancel(orderId: string): Promise<OrderWithDetails>;
112
+ };
113
+ export declare const paymentsService: {
114
+ /**
115
+ * Create Stripe PaymentIntent
116
+ */
117
+ createStripeIntent(orderId: string): Promise<{
118
+ clientSecret: string;
119
+ paymentIntentId: string;
120
+ }>;
121
+ /**
122
+ * Create Coinbase charge
123
+ */
124
+ createCoinbaseCharge(orderId: string): Promise<{
125
+ chargeId: string;
126
+ chargeCode: string;
127
+ hostedUrl: string;
128
+ }>;
129
+ };
@@ -0,0 +1,168 @@
1
+ "use strict";
2
+ /**
3
+ * Marketplace API Service
4
+ *
5
+ * Plain async functions for products and orders.
6
+ * Can be used in tests or non-React environments.
7
+ */
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.paymentsService = exports.ordersService = exports.productsService = void 0;
10
+ const client_1 = require("../client");
11
+ // ============================================================================
12
+ // PRODUCTS SERVICE
13
+ // ============================================================================
14
+ exports.productsService = {
15
+ /**
16
+ * List products for a spot
17
+ */
18
+ async listBySpot(spotId, params) {
19
+ const client = (0, client_1.getApiClient)();
20
+ const queryParams = new URLSearchParams();
21
+ if (params?.type)
22
+ queryParams.set('type', params.type);
23
+ if (params?.status)
24
+ queryParams.set('status', params.status);
25
+ if (params?.limit)
26
+ queryParams.set('limit', String(params.limit));
27
+ if (params?.page)
28
+ queryParams.set('page', String(params.page));
29
+ const response = await client.get(`/api/v1/spots/${spotId}/products?${queryParams}`);
30
+ return response.data.data;
31
+ },
32
+ /**
33
+ * Get product by ID
34
+ */
35
+ async getById(productId) {
36
+ const client = (0, client_1.getApiClient)();
37
+ const response = await client.get(`/api/v1/products/${productId}`);
38
+ return response.data.data;
39
+ },
40
+ /**
41
+ * Get product by slug
42
+ */
43
+ async getBySlug(spotId, slug) {
44
+ const client = (0, client_1.getApiClient)();
45
+ const response = await client.get(`/api/v1/spots/${spotId}/products/slug/${slug}`);
46
+ return response.data.data;
47
+ },
48
+ /**
49
+ * Create a product (requires owner auth)
50
+ */
51
+ async create(spotId, data) {
52
+ const client = (0, client_1.getApiClient)();
53
+ const response = await client.post(`/api/v1/spots/${spotId}/products`, data);
54
+ return response.data.data;
55
+ },
56
+ /**
57
+ * Update a product (requires owner auth)
58
+ */
59
+ async update(productId, data) {
60
+ const client = (0, client_1.getApiClient)();
61
+ const response = await client.put(`/api/v1/products/${productId}`, data);
62
+ return response.data.data;
63
+ },
64
+ /**
65
+ * Delete a product (requires owner auth)
66
+ */
67
+ async delete(productId) {
68
+ const client = (0, client_1.getApiClient)();
69
+ await client.delete(`/api/v1/products/${productId}`);
70
+ },
71
+ /**
72
+ * Adjust stock (requires owner auth)
73
+ */
74
+ async adjustStock(productId, quantity, reason, notes) {
75
+ const client = (0, client_1.getApiClient)();
76
+ const response = await client.post(`/api/v1/products/${productId}/stock`, { quantity, reason, notes });
77
+ return response.data.data;
78
+ },
79
+ };
80
+ // ============================================================================
81
+ // ORDERS SERVICE
82
+ // ============================================================================
83
+ exports.ordersService = {
84
+ /**
85
+ * Create an order
86
+ */
87
+ async create(data) {
88
+ const client = (0, client_1.getApiClient)();
89
+ const response = await client.post('/api/v1/orders', data);
90
+ return response.data.data;
91
+ },
92
+ /**
93
+ * Get order by ID
94
+ */
95
+ async getById(orderId) {
96
+ const client = (0, client_1.getApiClient)();
97
+ const response = await client.get(`/api/v1/orders/${orderId}`);
98
+ return response.data.data;
99
+ },
100
+ /**
101
+ * List my orders (as buyer)
102
+ */
103
+ async listMyOrders(params) {
104
+ const client = (0, client_1.getApiClient)();
105
+ const queryParams = new URLSearchParams();
106
+ if (params?.status)
107
+ queryParams.set('status', params.status);
108
+ if (params?.limit)
109
+ queryParams.set('limit', String(params.limit));
110
+ if (params?.page)
111
+ queryParams.set('page', String(params.page));
112
+ const response = await client.get(`/api/v1/users/me/orders?${queryParams}`);
113
+ return response.data.data;
114
+ },
115
+ /**
116
+ * List spot orders (as seller)
117
+ */
118
+ async listSpotOrders(spotId, params) {
119
+ const client = (0, client_1.getApiClient)();
120
+ const queryParams = new URLSearchParams();
121
+ if (params?.status)
122
+ queryParams.set('status', params.status);
123
+ if (params?.limit)
124
+ queryParams.set('limit', String(params.limit));
125
+ if (params?.page)
126
+ queryParams.set('page', String(params.page));
127
+ const response = await client.get(`/api/v1/seller/spots/${spotId}/orders?${queryParams}`);
128
+ return response.data.data;
129
+ },
130
+ /**
131
+ * Update order status (as seller)
132
+ */
133
+ async updateStatus(orderId, status) {
134
+ const client = (0, client_1.getApiClient)();
135
+ const response = await client.put(`/api/v1/orders/${orderId}/status`, { status });
136
+ return response.data.data;
137
+ },
138
+ /**
139
+ * Cancel order (as buyer)
140
+ */
141
+ async cancel(orderId) {
142
+ const client = (0, client_1.getApiClient)();
143
+ const response = await client.post(`/api/v1/orders/${orderId}/cancel`);
144
+ return response.data.data;
145
+ },
146
+ };
147
+ // ============================================================================
148
+ // PAYMENTS SERVICE
149
+ // ============================================================================
150
+ exports.paymentsService = {
151
+ /**
152
+ * Create Stripe PaymentIntent
153
+ */
154
+ async createStripeIntent(orderId) {
155
+ const client = (0, client_1.getApiClient)();
156
+ const response = await client.post(`/api/v1/payments/stripe/intent/${orderId}`);
157
+ return response.data.data;
158
+ },
159
+ /**
160
+ * Create Coinbase charge
161
+ */
162
+ async createCoinbaseCharge(orderId) {
163
+ const client = (0, client_1.getApiClient)();
164
+ const response = await client.post(`/api/v1/payments/coinbase/charge/${orderId}`);
165
+ return response.data.data;
166
+ },
167
+ };
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"marketplace.js","sourceRoot":"","sources":["../../../src/api/services/marketplace.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Marketplace API Service\n *\n * Plain async functions for products and orders.\n * Can be used in tests or non-React environments.\n */\n\nimport { getApiClient } from '../client';\nimport type {\n  Product,\n  ProductType,\n  ProductStatus,\n  OrderStatus,\n  ApiResponse,\n  PaginatedResponse,\n} from '../types';\nimport type { ProductWithSpot } from '../queries/products';\nimport type { OrderWithDetails } from '../queries/orders';\n\n// Re-export for convenience\nexport type { ProductWithSpot, OrderWithDetails };\n\nexport interface CreateProductInput {\n  name: string;\n  description?: string;\n  type: ProductType;\n  price: number;\n  currency?: string;\n  stockQuantity?: number;\n  lowStockAlert?: number;\n  deliveryRadius?: number;\n  prepTimeMinutes?: number;\n  eventDate?: string;\n  imageUrl?: string;\n}\n\nexport interface UpdateProductInput {\n  name?: string;\n  description?: string;\n  price?: number;\n  stockQuantity?: number;\n  lowStockAlert?: number;\n  status?: ProductStatus;\n  deliveryRadius?: number;\n  prepTimeMinutes?: number;\n  eventDate?: string;\n  imageUrl?: string;\n}\n\nexport interface CreateOrderInput {\n  spotId: string;\n  items: Array<{ productId: string; quantity: number }>;\n  notes?: string;\n}\n\n// ============================================================================\n// PRODUCTS SERVICE\n// ============================================================================\n\nexport const productsService = {\n  /**\n   * List products for a spot\n   */\n  async listBySpot(\n    spotId: string,\n    params?: { type?: ProductType; status?: ProductStatus; limit?: number; page?: number }\n  ): Promise<PaginatedResponse<Product>> {\n    const client = getApiClient();\n    const queryParams = new URLSearchParams();\n    if (params?.type) queryParams.set('type', params.type);\n    if (params?.status) queryParams.set('status', params.status);\n    if (params?.limit) queryParams.set('limit', String(params.limit));\n    if (params?.page) queryParams.set('page', String(params.page));\n    const response = await client.get<ApiResponse<PaginatedResponse<Product>>>(\n      `/api/v1/spots/${spotId}/products?${queryParams}`\n    );\n    return response.data.data;\n  },\n\n  /**\n   * Get product by ID\n   */\n  async getById(productId: string): Promise<ProductWithSpot> {\n    const client = getApiClient();\n    const response = await client.get<ApiResponse<ProductWithSpot>>(\n      `/api/v1/products/${productId}`\n    );\n    return response.data.data;\n  },\n\n  /**\n   * Get product by slug\n   */\n  async getBySlug(spotId: string, slug: string): Promise<ProductWithSpot> {\n    const client = getApiClient();\n    const response = await client.get<ApiResponse<ProductWithSpot>>(\n      `/api/v1/spots/${spotId}/products/slug/${slug}`\n    );\n    return response.data.data;\n  },\n\n  /**\n   * Create a product (requires owner auth)\n   */\n  async create(spotId: string, data: CreateProductInput): Promise<Product> {\n    const client = getApiClient();\n    const response = await client.post<ApiResponse<Product>>(\n      `/api/v1/spots/${spotId}/products`,\n      data\n    );\n    return response.data.data;\n  },\n\n  /**\n   * Update a product (requires owner auth)\n   */\n  async update(productId: string, data: UpdateProductInput): Promise<Product> {\n    const client = getApiClient();\n    const response = await client.put<ApiResponse<Product>>(\n      `/api/v1/products/${productId}`,\n      data\n    );\n    return response.data.data;\n  },\n\n  /**\n   * Delete a product (requires owner auth)\n   */\n  async delete(productId: string): Promise<void> {\n    const client = getApiClient();\n    await client.delete(`/api/v1/products/${productId}`);\n  },\n\n  /**\n   * Adjust stock (requires owner auth)\n   */\n  async adjustStock(\n    productId: string,\n    quantity: number,\n    reason: 'RESTOCK' | 'ADJUSTMENT',\n    notes?: string\n  ): Promise<Product> {\n    const client = getApiClient();\n    const response = await client.post<ApiResponse<Product>>(\n      `/api/v1/products/${productId}/stock`,\n      { quantity, reason, notes }\n    );\n    return response.data.data;\n  },\n};\n\n// ============================================================================\n// ORDERS SERVICE\n// ============================================================================\n\nexport const ordersService = {\n  /**\n   * Create an order\n   */\n  async create(data: CreateOrderInput): Promise<OrderWithDetails> {\n    const client = getApiClient();\n    const response = await client.post<ApiResponse<OrderWithDetails>>(\n      '/api/v1/orders',\n      data\n    );\n    return response.data.data;\n  },\n\n  /**\n   * Get order by ID\n   */\n  async getById(orderId: string): Promise<OrderWithDetails> {\n    const client = getApiClient();\n    const response = await client.get<ApiResponse<OrderWithDetails>>(\n      `/api/v1/orders/${orderId}`\n    );\n    return response.data.data;\n  },\n\n  /**\n   * List my orders (as buyer)\n   */\n  async listMyOrders(\n    params?: { status?: OrderStatus; limit?: number; page?: number }\n  ): Promise<PaginatedResponse<OrderWithDetails>> {\n    const client = getApiClient();\n    const queryParams = new URLSearchParams();\n    if (params?.status) queryParams.set('status', params.status);\n    if (params?.limit) queryParams.set('limit', String(params.limit));\n    if (params?.page) queryParams.set('page', String(params.page));\n    const response = await client.get<ApiResponse<PaginatedResponse<OrderWithDetails>>>(\n      `/api/v1/users/me/orders?${queryParams}`\n    );\n    return response.data.data;\n  },\n\n  /**\n   * List spot orders (as seller)\n   */\n  async listSpotOrders(\n    spotId: string,\n    params?: { status?: OrderStatus; limit?: number; page?: number }\n  ): Promise<PaginatedResponse<OrderWithDetails>> {\n    const client = getApiClient();\n    const queryParams = new URLSearchParams();\n    if (params?.status) queryParams.set('status', params.status);\n    if (params?.limit) queryParams.set('limit', String(params.limit));\n    if (params?.page) queryParams.set('page', String(params.page));\n    const response = await client.get<ApiResponse<PaginatedResponse<OrderWithDetails>>>(\n      `/api/v1/seller/spots/${spotId}/orders?${queryParams}`\n    );\n    return response.data.data;\n  },\n\n  /**\n   * Update order status (as seller)\n   */\n  async updateStatus(orderId: string, status: OrderStatus): Promise<OrderWithDetails> {\n    const client = getApiClient();\n    const response = await client.put<ApiResponse<OrderWithDetails>>(\n      `/api/v1/orders/${orderId}/status`,\n      { status }\n    );\n    return response.data.data;\n  },\n\n  /**\n   * Cancel order (as buyer)\n   */\n  async cancel(orderId: string): Promise<OrderWithDetails> {\n    const client = getApiClient();\n    const response = await client.post<ApiResponse<OrderWithDetails>>(\n      `/api/v1/orders/${orderId}/cancel`\n    );\n    return response.data.data;\n  },\n};\n\n// ============================================================================\n// PAYMENTS SERVICE\n// ============================================================================\n\nexport const paymentsService = {\n  /**\n   * Create Stripe PaymentIntent\n   */\n  async createStripeIntent(orderId: string): Promise<{ clientSecret: string; paymentIntentId: string }> {\n    const client = getApiClient();\n    const response = await client.post<ApiResponse<{ clientSecret: string; paymentIntentId: string }>>(\n      `/api/v1/payments/stripe/intent/${orderId}`\n    );\n    return response.data.data;\n  },\n\n  /**\n   * Create Coinbase charge\n   */\n  async createCoinbaseCharge(orderId: string): Promise<{ chargeId: string; chargeCode: string; hostedUrl: string }> {\n    const client = getApiClient();\n    const response = await client.post<ApiResponse<{ chargeId: string; chargeCode: string; hostedUrl: string }>>(\n      `/api/v1/payments/coinbase/charge/${orderId}`\n    );\n    return response.data.data;\n  },\n};\n"]}