@spotsdev/sdk 1.3.0 → 1.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/api/entities.d.ts +16 -29
- package/dist/api/entities.js +5 -1
- package/dist/api/mutations/posts.js +4 -3
- package/package.json +2 -2
- package/src/api/entities.ts +37 -84
- package/src/api/mutations/posts.ts +3 -2
package/dist/api/entities.d.ts
CHANGED
|
@@ -3,15 +3,21 @@
|
|
|
3
3
|
*
|
|
4
4
|
* These types mirror the Prisma schema entities but without @prisma/client dependency.
|
|
5
5
|
* This allows the SDK to work in React Native where Prisma is not available.
|
|
6
|
+
*
|
|
7
|
+
* IMPORTANT: Enum types are imported from @spotsdev/types (generated from OpenAPI spec).
|
|
8
|
+
* types.ts handles re-exporting from spots-types - this file only defines entity interfaces
|
|
9
|
+
* and SDK-specific types not in the OpenAPI spec.
|
|
6
10
|
*/
|
|
7
|
-
|
|
8
|
-
export type SpotPostType =
|
|
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';
|
|
11
|
+
import type { SpotType, AccountStatus, PostType, ResponseStatus, ReportReason, ProductResponseDto, ClaimStatus, OrderStatus, NotificationType } from '@spotsdev/types';
|
|
12
|
+
export type SpotPostType = PostType;
|
|
13
13
|
export type ReportStatus = 'PENDING' | 'REVIEWED' | 'RESOLVED' | 'DISMISSED';
|
|
14
|
-
export
|
|
14
|
+
export interface UserVibe {
|
|
15
|
+
id: string;
|
|
16
|
+
name: string;
|
|
17
|
+
emoji: string | null;
|
|
18
|
+
slug?: string;
|
|
19
|
+
category?: string;
|
|
20
|
+
}
|
|
15
21
|
export interface User {
|
|
16
22
|
id: string;
|
|
17
23
|
phone: string | null;
|
|
@@ -21,6 +27,7 @@ export interface User {
|
|
|
21
27
|
avatarUrl: string | null;
|
|
22
28
|
status: AccountStatus;
|
|
23
29
|
onboardingCompleted: boolean;
|
|
30
|
+
vibes?: UserVibe[];
|
|
24
31
|
lastActiveAt: Date | null;
|
|
25
32
|
createdAt: Date;
|
|
26
33
|
updatedAt: Date;
|
|
@@ -44,6 +51,7 @@ export interface Spot {
|
|
|
44
51
|
imageUrl: string | null;
|
|
45
52
|
ownerId: string | null;
|
|
46
53
|
isVerified: boolean;
|
|
54
|
+
marketplaceEnabled: boolean;
|
|
47
55
|
createdAt: Date | string;
|
|
48
56
|
updatedAt: Date | string;
|
|
49
57
|
}
|
|
@@ -271,28 +279,7 @@ export interface PaginationMeta {
|
|
|
271
279
|
hasNextPage: boolean;
|
|
272
280
|
hasPreviousPage: boolean;
|
|
273
281
|
}
|
|
274
|
-
export type
|
|
275
|
-
export type ProductStatus = 'DRAFT' | 'ACTIVE' | 'SOLD_OUT' | 'ARCHIVED';
|
|
276
|
-
export type OrderStatus = 'PENDING' | 'CONFIRMED' | 'PREPARING' | 'READY' | 'COMPLETED' | 'CANCELLED' | 'REFUNDED';
|
|
277
|
-
export interface Product {
|
|
278
|
-
id: string;
|
|
279
|
-
spotId: string;
|
|
280
|
-
name: string;
|
|
281
|
-
slug: string;
|
|
282
|
-
description: string | null;
|
|
283
|
-
type: ProductType;
|
|
284
|
-
status: ProductStatus;
|
|
285
|
-
price: number;
|
|
286
|
-
currency: string;
|
|
287
|
-
imageUrl: string | null;
|
|
288
|
-
images: string[];
|
|
289
|
-
stock: number | null;
|
|
290
|
-
maxQuantity: number;
|
|
291
|
-
sortOrder: number;
|
|
292
|
-
metadata: Record<string, unknown> | null;
|
|
293
|
-
createdAt: Date;
|
|
294
|
-
updatedAt: Date;
|
|
295
|
-
}
|
|
282
|
+
export type Product = ProductResponseDto;
|
|
296
283
|
export interface Order {
|
|
297
284
|
id: string;
|
|
298
285
|
spotId: string;
|
package/dist/api/entities.js
CHANGED
|
@@ -4,6 +4,10 @@
|
|
|
4
4
|
*
|
|
5
5
|
* These types mirror the Prisma schema entities but without @prisma/client dependency.
|
|
6
6
|
* This allows the SDK to work in React Native where Prisma is not available.
|
|
7
|
+
*
|
|
8
|
+
* IMPORTANT: Enum types are imported from @spotsdev/types (generated from OpenAPI spec).
|
|
9
|
+
* types.ts handles re-exporting from spots-types - this file only defines entity interfaces
|
|
10
|
+
* and SDK-specific types not in the OpenAPI spec.
|
|
7
11
|
*/
|
|
8
12
|
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  // Aliases for backwards compatibility\n  lat?: number | null\n  lng?: 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  // Dates as strings for JSON serialization compatibility\n  createdAt: Date | string\n  updatedAt: Date | string\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"]}
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entities.js","sourceRoot":"","sources":["../../src/api/entities.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG","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 * IMPORTANT: Enum types are imported from @spotsdev/types (generated from OpenAPI spec).\n * types.ts handles re-exporting from spots-types - this file only defines entity interfaces\n * and SDK-specific types not in the OpenAPI spec.\n */\n\n// ============================================================================\n// IMPORTS FROM @spotsdev/types (used in interfaces below)\n// These are NOT re-exported - types.ts handles the re-export from spots-types\n// ============================================================================\nimport type {\n  SpotType,\n  AccountStatus,\n  PostType,\n  PostStatus,\n  ResponseStatus,\n  ReportReason,\n  ProductType,\n  ProductStatus,\n  ProductResponseDto,\n  ClaimStatus,\n  OrderStatus,\n  NotificationType,\n} from '@spotsdev/types'\n\n// Type alias for backwards compatibility - SDK uses SpotPostType, API uses PostType\nexport type SpotPostType = PostType\n\n// Enums not yet in OpenAPI spec DTOs - these stay local until API exposes them\nexport type ReportStatus = 'PENDING' | 'REVIEWED' | 'RESOLVED' | 'DISMISSED'\n\n// ============================================================================\n// ENTITY INTERFACES\n// ============================================================================\n\nexport interface UserVibe {\n  id: string\n  name: string\n  emoji: string | null\n  slug?: string\n  category?: string\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  vibes?: UserVibe[]\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  // Aliases for backwards compatibility\n  lat?: number | null\n  lng?: 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  marketplaceEnabled: boolean\n  // Dates as strings for JSON serialization compatibility\n  createdAt: Date | string\n  updatedAt: Date | string\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\n// Use ProductResponseDto from spots-types directly\nexport type Product = ProductResponseDto\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"]}
|
|
@@ -51,9 +51,10 @@ function useCreatePost(options) {
|
|
|
51
51
|
function useUpdatePost(options) {
|
|
52
52
|
const queryClient = (0, react_query_1.useQueryClient)();
|
|
53
53
|
return (0, react_query_1.useMutation)({
|
|
54
|
-
mutationFn: async ({ postId,
|
|
54
|
+
mutationFn: async ({ postId, title, content }) => {
|
|
55
55
|
const client = (0, client_1.getApiClient)();
|
|
56
|
-
|
|
56
|
+
// API expects 'description' field, not 'content'
|
|
57
|
+
const response = await client.put(`/posts/${postId}`, { title, description: content });
|
|
57
58
|
return response.data.data;
|
|
58
59
|
},
|
|
59
60
|
onSuccess: (data, variables) => {
|
|
@@ -238,4 +239,4 @@ function useUpdatePostStatus(options) {
|
|
|
238
239
|
...options,
|
|
239
240
|
});
|
|
240
241
|
}
|
|
241
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"posts.js","sourceRoot":"","sources":["../../../src/api/mutations/posts.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Posts Mutation Hooks\n *\n * TanStack Query hooks for post/board mutation operations.\n */\n\nimport {\n  useMutation,\n  type UseMutationOptions,\n  type UseMutationResult,\n  useQueryClient,\n} from '@tanstack/react-query'\n\nimport {getApiClient} from '../client'\nimport {postKeys} from '../queries/posts'\nimport {\n  type ApiResponse,\n  type CreatePostRequest,\n  type CreateReplyRequest,\n  type Post,\n  type PostResponse,\n  type PostStatusDto,\n  type RespondToPostRequest,\n  type UpdateResponseRequest,\n  type UpvoteResponse,\n} from '../types'\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a new post\n *\n * @endpoint POST /spots/{spotId}/posts\n */\nexport function useCreatePost(\n  options?: Omit<\n    UseMutationOptions<Post, Error, {spotId: string} & CreatePostRequest>,\n    'mutationFn'\n  >,\n): UseMutationResult<Post, Error, {spotId: string} & CreatePostRequest> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({spotId, ...data}): Promise<Post> => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<Post>>(\n        `/spots/${spotId}/posts`,\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({\n        queryKey: postKeys.bySpot(variables.spotId),\n      })\n    },\n    ...options,\n  })\n}\n\n/**\n * Update a post\n *\n * @endpoint PUT /posts/{postId}\n */\nexport function useUpdatePost(\n  options?: Omit<\n    UseMutationOptions<\n      Post,\n      Error,\n      {postId: string; title?: string; content?: string}\n    >,\n    'mutationFn'\n  >,\n): UseMutationResult<\n  Post,\n  Error,\n  {postId: string; title?: string; content?: string}\n> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({postId, ...data}): Promise<Post> => {\n      const client = getApiClient()\n      const response = await client.put<ApiResponse<Post>>(\n        `/posts/${postId}`,\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: (data, variables) => {\n      queryClient.setQueryData(postKeys.detail(variables.postId), data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Delete a post\n *\n * @endpoint DELETE /posts/{postId}\n */\nexport function useDeletePost(\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>,\n): UseMutationResult<void, Error, string> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (postId: string): Promise<void> => {\n      const client = getApiClient()\n      await client.delete(`/posts/${postId}`)\n    },\n    onSuccess: (_, postId) => {\n      queryClient.invalidateQueries({queryKey: postKeys.detail(postId)})\n      queryClient.invalidateQueries({queryKey: postKeys.lists()})\n    },\n    ...options,\n  })\n}\n\n/**\n * Fulfill a post (mark as fulfilled)\n *\n * @endpoint PUT /posts/{postId}/fulfill\n */\nexport function useFulfillPost(\n  options?: Omit<UseMutationOptions<Post, Error, string>, 'mutationFn'>,\n): UseMutationResult<Post, Error, string> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (postId: string): Promise<Post> => {\n      const client = getApiClient()\n      const response = await client.put<ApiResponse<Post>>(\n        `/posts/${postId}/fulfill`,\n      )\n      return response.data.data\n    },\n    onSuccess: (data, postId) => {\n      queryClient.setQueryData(postKeys.detail(postId), data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Upvote/unupvote a post\n *\n * @endpoint POST /posts/{postId}/upvote\n */\nexport function useUpvotePost(\n  options?: Omit<\n    UseMutationOptions<UpvoteResponse, Error, string>,\n    'mutationFn'\n  >,\n): UseMutationResult<UpvoteResponse, Error, string> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (postId: string): Promise<UpvoteResponse> => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<UpvoteResponse>>(\n        `/posts/${postId}/upvote`,\n      )\n      return response.data.data\n    },\n    onSuccess: (_, postId) => {\n      queryClient.invalidateQueries({queryKey: postKeys.detail(postId)})\n    },\n    ...options,\n  })\n}\n\n/**\n * Create a reply to a post\n *\n * @endpoint POST /posts/{postId}/reply\n */\nexport function useCreateReply(\n  options?: Omit<\n    UseMutationOptions<unknown, Error, {postId: string} & CreateReplyRequest>,\n    'mutationFn'\n  >,\n): UseMutationResult<unknown, Error, {postId: string} & CreateReplyRequest> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({postId, ...data}) => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<unknown>>(\n        `/posts/${postId}/reply`,\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({\n        queryKey: postKeys.detail(variables.postId),\n      })\n    },\n    ...options,\n  })\n}\n\n/**\n * Delete a reply\n *\n * @endpoint DELETE /replies/{replyId}\n */\nexport function useDeleteReply(\n  options?: Omit<\n    UseMutationOptions<void, Error, {replyId: string; postId: string}>,\n    'mutationFn'\n  >,\n): UseMutationResult<void, Error, {replyId: string; postId: string}> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({replyId}): Promise<void> => {\n      const client = getApiClient()\n      await client.delete(`/replies/${replyId}`)\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({\n        queryKey: postKeys.detail(variables.postId),\n      })\n    },\n    ...options,\n  })\n}\n\n/**\n * Respond to a post (express interest)\n *\n * @endpoint POST /posts/{postId}/respond\n */\nexport function useRespondToPost(\n  options?: Omit<\n    UseMutationOptions<\n      PostResponse,\n      Error,\n      {postId: string} & RespondToPostRequest\n    >,\n    'mutationFn'\n  >,\n): UseMutationResult<\n  PostResponse,\n  Error,\n  {postId: string} & RespondToPostRequest\n> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({postId, ...data}): Promise<PostResponse> => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<PostResponse>>(\n        `/posts/${postId}/respond`,\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({\n        queryKey: postKeys.detail(variables.postId),\n      })\n      queryClient.invalidateQueries({\n        queryKey: postKeys.responses(variables.postId),\n      })\n    },\n    ...options,\n  })\n}\n\n/**\n * Accept or decline a response\n *\n * @endpoint PUT /responses/{responseId}\n */\nexport function useUpdateResponse(\n  options?: Omit<\n    UseMutationOptions<\n      PostResponse,\n      Error,\n      {responseId: string; postId: string} & UpdateResponseRequest\n    >,\n    'mutationFn'\n  >,\n): UseMutationResult<\n  PostResponse,\n  Error,\n  {responseId: string; postId: string} & UpdateResponseRequest\n> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({\n      responseId,\n      postId: _,\n      ...data\n    }): Promise<PostResponse> => {\n      const client = getApiClient()\n      const response = await client.put<ApiResponse<PostResponse>>(\n        `/responses/${responseId}`,\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({\n        queryKey: postKeys.responses(variables.postId),\n      })\n    },\n    ...options,\n  })\n}\n\n/**\n * Report a post\n *\n * @endpoint POST /posts/{postId}/report\n */\nexport function useReportPost(\n  options?: Omit<\n    UseMutationOptions<\n      void,\n      Error,\n      {postId: string; reason: string; details?: string}\n    >,\n    'mutationFn'\n  >,\n): UseMutationResult<\n  void,\n  Error,\n  {postId: string; reason: string; details?: string}\n> {\n  return useMutation({\n    mutationFn: async ({postId, ...data}): Promise<void> => {\n      const client = getApiClient()\n      await client.post(`/posts/${postId}/report`, data)\n    },\n    ...options,\n  })\n}\n\n// PostStatusUpdate matches partial PostStatusDto for updates\ninterface PostStatusUpdate {\n  isRead?: boolean\n  isHidden?: boolean\n  isPinned?: boolean\n}\n\n/**\n * Update user's status for a post (read/hidden/pinned)\n *\n * @endpoint PUT /posts/{postId}/status\n */\nexport function useUpdatePostStatus(\n  options?: Omit<\n    UseMutationOptions<\n      PostStatusDto,\n      Error,\n      {postId: string} & PostStatusUpdate\n    >,\n    'mutationFn'\n  >,\n): UseMutationResult<\n  PostStatusDto,\n  Error,\n  {postId: string} & PostStatusUpdate\n> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({postId, ...data}): Promise<PostStatusDto> => {\n      const client = getApiClient()\n      const response = await client.put<ApiResponse<PostStatusDto>>(\n        `/posts/${postId}/status`,\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: (data, variables) => {\n      queryClient.setQueryData(postKeys.status(variables.postId), data)\n    },\n    ...options,\n  })\n}\n"]}
|
|
242
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"posts.js","sourceRoot":"","sources":["../../../src/api/mutations/posts.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Posts Mutation Hooks\n *\n * TanStack Query hooks for post/board mutation operations.\n */\n\nimport {\n  useMutation,\n  type UseMutationOptions,\n  type UseMutationResult,\n  useQueryClient,\n} from '@tanstack/react-query'\n\nimport {getApiClient} from '../client'\nimport {postKeys} from '../queries/posts'\nimport {\n  type ApiResponse,\n  type CreatePostRequest,\n  type CreateReplyRequest,\n  type Post,\n  type PostResponse,\n  type PostStatusDto,\n  type RespondToPostRequest,\n  type UpdateResponseRequest,\n  type UpvoteResponse,\n} from '../types'\n\n// ============================================================================\n// MUTATION HOOKS\n// ============================================================================\n\n/**\n * Create a new post\n *\n * @endpoint POST /spots/{spotId}/posts\n */\nexport function useCreatePost(\n  options?: Omit<\n    UseMutationOptions<Post, Error, {spotId: string} & CreatePostRequest>,\n    'mutationFn'\n  >,\n): UseMutationResult<Post, Error, {spotId: string} & CreatePostRequest> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({spotId, ...data}): Promise<Post> => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<Post>>(\n        `/spots/${spotId}/posts`,\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({\n        queryKey: postKeys.bySpot(variables.spotId),\n      })\n    },\n    ...options,\n  })\n}\n\n/**\n * Update a post\n *\n * @endpoint PUT /posts/{postId}\n */\nexport function useUpdatePost(\n  options?: Omit<\n    UseMutationOptions<\n      Post,\n      Error,\n      {postId: string; title?: string; content?: string}\n    >,\n    'mutationFn'\n  >,\n): UseMutationResult<\n  Post,\n  Error,\n  {postId: string; title?: string; content?: string}\n> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({postId, title, content}): Promise<Post> => {\n      const client = getApiClient()\n      // API expects 'description' field, not 'content'\n      const response = await client.put<ApiResponse<Post>>(\n        `/posts/${postId}`,\n        {title, description: content},\n      )\n      return response.data.data\n    },\n    onSuccess: (data, variables) => {\n      queryClient.setQueryData(postKeys.detail(variables.postId), data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Delete a post\n *\n * @endpoint DELETE /posts/{postId}\n */\nexport function useDeletePost(\n  options?: Omit<UseMutationOptions<void, Error, string>, 'mutationFn'>,\n): UseMutationResult<void, Error, string> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (postId: string): Promise<void> => {\n      const client = getApiClient()\n      await client.delete(`/posts/${postId}`)\n    },\n    onSuccess: (_, postId) => {\n      queryClient.invalidateQueries({queryKey: postKeys.detail(postId)})\n      queryClient.invalidateQueries({queryKey: postKeys.lists()})\n    },\n    ...options,\n  })\n}\n\n/**\n * Fulfill a post (mark as fulfilled)\n *\n * @endpoint PUT /posts/{postId}/fulfill\n */\nexport function useFulfillPost(\n  options?: Omit<UseMutationOptions<Post, Error, string>, 'mutationFn'>,\n): UseMutationResult<Post, Error, string> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (postId: string): Promise<Post> => {\n      const client = getApiClient()\n      const response = await client.put<ApiResponse<Post>>(\n        `/posts/${postId}/fulfill`,\n      )\n      return response.data.data\n    },\n    onSuccess: (data, postId) => {\n      queryClient.setQueryData(postKeys.detail(postId), data)\n    },\n    ...options,\n  })\n}\n\n/**\n * Upvote/unupvote a post\n *\n * @endpoint POST /posts/{postId}/upvote\n */\nexport function useUpvotePost(\n  options?: Omit<\n    UseMutationOptions<UpvoteResponse, Error, string>,\n    'mutationFn'\n  >,\n): UseMutationResult<UpvoteResponse, Error, string> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async (postId: string): Promise<UpvoteResponse> => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<UpvoteResponse>>(\n        `/posts/${postId}/upvote`,\n      )\n      return response.data.data\n    },\n    onSuccess: (_, postId) => {\n      queryClient.invalidateQueries({queryKey: postKeys.detail(postId)})\n    },\n    ...options,\n  })\n}\n\n/**\n * Create a reply to a post\n *\n * @endpoint POST /posts/{postId}/reply\n */\nexport function useCreateReply(\n  options?: Omit<\n    UseMutationOptions<unknown, Error, {postId: string} & CreateReplyRequest>,\n    'mutationFn'\n  >,\n): UseMutationResult<unknown, Error, {postId: string} & CreateReplyRequest> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({postId, ...data}) => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<unknown>>(\n        `/posts/${postId}/reply`,\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({\n        queryKey: postKeys.detail(variables.postId),\n      })\n    },\n    ...options,\n  })\n}\n\n/**\n * Delete a reply\n *\n * @endpoint DELETE /replies/{replyId}\n */\nexport function useDeleteReply(\n  options?: Omit<\n    UseMutationOptions<void, Error, {replyId: string; postId: string}>,\n    'mutationFn'\n  >,\n): UseMutationResult<void, Error, {replyId: string; postId: string}> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({replyId}): Promise<void> => {\n      const client = getApiClient()\n      await client.delete(`/replies/${replyId}`)\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({\n        queryKey: postKeys.detail(variables.postId),\n      })\n    },\n    ...options,\n  })\n}\n\n/**\n * Respond to a post (express interest)\n *\n * @endpoint POST /posts/{postId}/respond\n */\nexport function useRespondToPost(\n  options?: Omit<\n    UseMutationOptions<\n      PostResponse,\n      Error,\n      {postId: string} & RespondToPostRequest\n    >,\n    'mutationFn'\n  >,\n): UseMutationResult<\n  PostResponse,\n  Error,\n  {postId: string} & RespondToPostRequest\n> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({postId, ...data}): Promise<PostResponse> => {\n      const client = getApiClient()\n      const response = await client.post<ApiResponse<PostResponse>>(\n        `/posts/${postId}/respond`,\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({\n        queryKey: postKeys.detail(variables.postId),\n      })\n      queryClient.invalidateQueries({\n        queryKey: postKeys.responses(variables.postId),\n      })\n    },\n    ...options,\n  })\n}\n\n/**\n * Accept or decline a response\n *\n * @endpoint PUT /responses/{responseId}\n */\nexport function useUpdateResponse(\n  options?: Omit<\n    UseMutationOptions<\n      PostResponse,\n      Error,\n      {responseId: string; postId: string} & UpdateResponseRequest\n    >,\n    'mutationFn'\n  >,\n): UseMutationResult<\n  PostResponse,\n  Error,\n  {responseId: string; postId: string} & UpdateResponseRequest\n> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({\n      responseId,\n      postId: _,\n      ...data\n    }): Promise<PostResponse> => {\n      const client = getApiClient()\n      const response = await client.put<ApiResponse<PostResponse>>(\n        `/responses/${responseId}`,\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: (_, variables) => {\n      queryClient.invalidateQueries({\n        queryKey: postKeys.responses(variables.postId),\n      })\n    },\n    ...options,\n  })\n}\n\n/**\n * Report a post\n *\n * @endpoint POST /posts/{postId}/report\n */\nexport function useReportPost(\n  options?: Omit<\n    UseMutationOptions<\n      void,\n      Error,\n      {postId: string; reason: string; details?: string}\n    >,\n    'mutationFn'\n  >,\n): UseMutationResult<\n  void,\n  Error,\n  {postId: string; reason: string; details?: string}\n> {\n  return useMutation({\n    mutationFn: async ({postId, ...data}): Promise<void> => {\n      const client = getApiClient()\n      await client.post(`/posts/${postId}/report`, data)\n    },\n    ...options,\n  })\n}\n\n// PostStatusUpdate matches partial PostStatusDto for updates\ninterface PostStatusUpdate {\n  isRead?: boolean\n  isHidden?: boolean\n  isPinned?: boolean\n}\n\n/**\n * Update user's status for a post (read/hidden/pinned)\n *\n * @endpoint PUT /posts/{postId}/status\n */\nexport function useUpdatePostStatus(\n  options?: Omit<\n    UseMutationOptions<\n      PostStatusDto,\n      Error,\n      {postId: string} & PostStatusUpdate\n    >,\n    'mutationFn'\n  >,\n): UseMutationResult<\n  PostStatusDto,\n  Error,\n  {postId: string} & PostStatusUpdate\n> {\n  const queryClient = useQueryClient()\n\n  return useMutation({\n    mutationFn: async ({postId, ...data}): Promise<PostStatusDto> => {\n      const client = getApiClient()\n      const response = await client.put<ApiResponse<PostStatusDto>>(\n        `/posts/${postId}/status`,\n        data,\n      )\n      return response.data.data\n    },\n    onSuccess: (data, variables) => {\n      queryClient.setQueryData(postKeys.status(variables.postId), data)\n    },\n    ...options,\n  })\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@spotsdev/sdk",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.4.0",
|
|
4
4
|
"description": "Shared TypeScript SDK for Spots API - TanStack Query hooks, API client, and utilities",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"source": "src/index.ts",
|
|
@@ -32,7 +32,7 @@
|
|
|
32
32
|
"react": ">=18.0.0"
|
|
33
33
|
},
|
|
34
34
|
"dependencies": {
|
|
35
|
-
"@spotsdev/types": "^1.1
|
|
35
|
+
"@spotsdev/types": "^1.3.1"
|
|
36
36
|
},
|
|
37
37
|
"devDependencies": {
|
|
38
38
|
"@types/node": "^20.0.0",
|
package/src/api/entities.ts
CHANGED
|
@@ -3,68 +3,49 @@
|
|
|
3
3
|
*
|
|
4
4
|
* These types mirror the Prisma schema entities but without @prisma/client dependency.
|
|
5
5
|
* This allows the SDK to work in React Native where Prisma is not available.
|
|
6
|
+
*
|
|
7
|
+
* IMPORTANT: Enum types are imported from @spotsdev/types (generated from OpenAPI spec).
|
|
8
|
+
* types.ts handles re-exporting from spots-types - this file only defines entity interfaces
|
|
9
|
+
* and SDK-specific types not in the OpenAPI spec.
|
|
6
10
|
*/
|
|
7
11
|
|
|
8
12
|
// ============================================================================
|
|
9
|
-
//
|
|
13
|
+
// IMPORTS FROM @spotsdev/types (used in interfaces below)
|
|
14
|
+
// These are NOT re-exported - types.ts handles the re-export from spots-types
|
|
10
15
|
// ============================================================================
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
export type SpotPostType =
|
|
32
|
-
| 'CHECK_IN'
|
|
33
|
-
| 'LOOKING_FOR'
|
|
34
|
-
| 'OFFERING'
|
|
35
|
-
| 'QUESTION'
|
|
36
|
-
| 'EVENT'
|
|
37
|
-
| 'RECOMMENDATION'
|
|
38
|
-
| 'GENERAL'
|
|
39
|
-
|
|
40
|
-
export type AccountStatus = 'ACTIVE' | 'SUSPENDED' | 'DELETED' | 'PENDING'
|
|
41
|
-
|
|
42
|
-
export type ClaimStatus = 'PENDING' | 'APPROVED' | 'REJECTED'
|
|
43
|
-
|
|
44
|
-
export type ResponseStatus = 'PENDING' | 'ACCEPTED' | 'DECLINED'
|
|
45
|
-
|
|
46
|
-
export type ReportReason =
|
|
47
|
-
| 'SPAM'
|
|
48
|
-
| 'HARASSMENT'
|
|
49
|
-
| 'INAPPROPRIATE'
|
|
50
|
-
| 'SCAM'
|
|
51
|
-
| 'OTHER'
|
|
52
|
-
|
|
16
|
+
import type {
|
|
17
|
+
SpotType,
|
|
18
|
+
AccountStatus,
|
|
19
|
+
PostType,
|
|
20
|
+
PostStatus,
|
|
21
|
+
ResponseStatus,
|
|
22
|
+
ReportReason,
|
|
23
|
+
ProductType,
|
|
24
|
+
ProductStatus,
|
|
25
|
+
ProductResponseDto,
|
|
26
|
+
ClaimStatus,
|
|
27
|
+
OrderStatus,
|
|
28
|
+
NotificationType,
|
|
29
|
+
} from '@spotsdev/types'
|
|
30
|
+
|
|
31
|
+
// Type alias for backwards compatibility - SDK uses SpotPostType, API uses PostType
|
|
32
|
+
export type SpotPostType = PostType
|
|
33
|
+
|
|
34
|
+
// Enums not yet in OpenAPI spec DTOs - these stay local until API exposes them
|
|
53
35
|
export type ReportStatus = 'PENDING' | 'REVIEWED' | 'RESOLVED' | 'DISMISSED'
|
|
54
36
|
|
|
55
|
-
export type NotificationType =
|
|
56
|
-
| 'POST_RESPONSE'
|
|
57
|
-
| 'POST_REPLY'
|
|
58
|
-
| 'POST_UPVOTE'
|
|
59
|
-
| 'RESPONSE_ACCEPTED'
|
|
60
|
-
| 'RESPONSE_DECLINED'
|
|
61
|
-
| 'NEW_MESSAGE'
|
|
62
|
-
| 'SYSTEM'
|
|
63
|
-
|
|
64
37
|
// ============================================================================
|
|
65
38
|
// ENTITY INTERFACES
|
|
66
39
|
// ============================================================================
|
|
67
40
|
|
|
41
|
+
export interface UserVibe {
|
|
42
|
+
id: string
|
|
43
|
+
name: string
|
|
44
|
+
emoji: string | null
|
|
45
|
+
slug?: string
|
|
46
|
+
category?: string
|
|
47
|
+
}
|
|
48
|
+
|
|
68
49
|
export interface User {
|
|
69
50
|
id: string
|
|
70
51
|
phone: string | null
|
|
@@ -74,6 +55,7 @@ export interface User {
|
|
|
74
55
|
avatarUrl: string | null
|
|
75
56
|
status: AccountStatus
|
|
76
57
|
onboardingCompleted: boolean
|
|
58
|
+
vibes?: UserVibe[]
|
|
77
59
|
lastActiveAt: Date | null
|
|
78
60
|
createdAt: Date
|
|
79
61
|
updatedAt: Date
|
|
@@ -99,6 +81,7 @@ export interface Spot {
|
|
|
99
81
|
imageUrl: string | null
|
|
100
82
|
ownerId: string | null
|
|
101
83
|
isVerified: boolean
|
|
84
|
+
marketplaceEnabled: boolean
|
|
102
85
|
// Dates as strings for JSON serialization compatibility
|
|
103
86
|
createdAt: Date | string
|
|
104
87
|
updatedAt: Date | string
|
|
@@ -365,38 +348,8 @@ export interface PaginationMeta {
|
|
|
365
348
|
// MARKETPLACE TYPES
|
|
366
349
|
// ============================================================================
|
|
367
350
|
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
export type ProductStatus = 'DRAFT' | 'ACTIVE' | 'SOLD_OUT' | 'ARCHIVED'
|
|
371
|
-
|
|
372
|
-
export type OrderStatus =
|
|
373
|
-
| 'PENDING'
|
|
374
|
-
| 'CONFIRMED'
|
|
375
|
-
| 'PREPARING'
|
|
376
|
-
| 'READY'
|
|
377
|
-
| 'COMPLETED'
|
|
378
|
-
| 'CANCELLED'
|
|
379
|
-
| 'REFUNDED'
|
|
380
|
-
|
|
381
|
-
export interface Product {
|
|
382
|
-
id: string
|
|
383
|
-
spotId: string
|
|
384
|
-
name: string
|
|
385
|
-
slug: string
|
|
386
|
-
description: string | null
|
|
387
|
-
type: ProductType
|
|
388
|
-
status: ProductStatus
|
|
389
|
-
price: number
|
|
390
|
-
currency: string
|
|
391
|
-
imageUrl: string | null
|
|
392
|
-
images: string[]
|
|
393
|
-
stock: number | null
|
|
394
|
-
maxQuantity: number
|
|
395
|
-
sortOrder: number
|
|
396
|
-
metadata: Record<string, unknown> | null
|
|
397
|
-
createdAt: Date
|
|
398
|
-
updatedAt: Date
|
|
399
|
-
}
|
|
351
|
+
// Use ProductResponseDto from spots-types directly
|
|
352
|
+
export type Product = ProductResponseDto
|
|
400
353
|
|
|
401
354
|
export interface Order {
|
|
402
355
|
id: string
|
|
@@ -82,11 +82,12 @@ export function useUpdatePost(
|
|
|
82
82
|
const queryClient = useQueryClient()
|
|
83
83
|
|
|
84
84
|
return useMutation({
|
|
85
|
-
mutationFn: async ({postId,
|
|
85
|
+
mutationFn: async ({postId, title, content}): Promise<Post> => {
|
|
86
86
|
const client = getApiClient()
|
|
87
|
+
// API expects 'description' field, not 'content'
|
|
87
88
|
const response = await client.put<ApiResponse<Post>>(
|
|
88
89
|
`/posts/${postId}`,
|
|
89
|
-
|
|
90
|
+
{title, description: content},
|
|
90
91
|
)
|
|
91
92
|
return response.data.data
|
|
92
93
|
},
|