import type { Prop } from "./types" import { apiClient } from "./client" import type { PaginatedResponse, PaginationParams } from "./client" function mapBackendProp(item: any): Prop { const attrs = item.attributes || {} return { id: String(item.id), name: item.name, description: item.description || "", imageUrl: item.image_url || "/placeholder.svg?height=300&width=400", rarity: item.rarity_display || item.rarity || "", category: attrs.prop_type || "", status: item.status_display || item.status || "", publishedAt: item.published_at || "", batchesCount: item.batches_count || 0, activeCardsCount: item.active_cards_count || 0, tags: attrs.material ? [attrs.material] : [], createdAt: item.created_at || "", updatedAt: item.updated_at || "", } } export const getProps = async (params?: PaginationParams): Promise> => { const page = params?.page || 1 const pageSize = params?.pageSize || 10 const searchParam = params?.search ? `&search=${encodeURIComponent(params.search)}` : "" const response = await apiClient.get( `/card/category/prop/?page=${page}&page_size=${pageSize}${searchParam}` ) const data = response.data?.data || response.data const results: any[] = data.results || data const total = data.count || results.length return { items: results.map(mapBackendProp), total, page, pageSize, totalPages: Math.ceil(total / pageSize), } } export const getProp = async (id: string): Promise => { const response = await apiClient.get(`/card/templates/${id}/`) const data = response.data?.data || response.data return mapBackendProp(data) } export const createProp = async (propData: Partial & { rarityValue?: string }): Promise => { const payload: any = { name: propData.name, category: "prop", description: propData.description || "", } if (propData.rarityValue) { payload.rarity = propData.rarityValue } if (propData.imageUrl) { payload.image_url = propData.imageUrl } // 只在有实际属性值时才传 prop_attributes if (propData.category) { payload.prop_attributes = { prop_type: propData.category, } } const response = await apiClient.post(`/card/templates/`, payload) const data = response.data?.data || response.data return mapBackendProp(data) } export const updateProp = async (id: string, propData: Partial & { rarityValue?: string }): Promise => { const payload: any = {} if (propData.name !== undefined) payload.name = propData.name if (propData.description !== undefined) payload.description = propData.description if (propData.category !== undefined) payload.prop_attributes = { prop_type: propData.category } if (propData.rarityValue) payload.rarity = propData.rarityValue if (propData.imageUrl !== undefined) payload.image_url = propData.imageUrl const response = await apiClient.patch(`/card/templates/${id}/`, payload) const data = response.data?.data || response.data return mapBackendProp(data) } export const deleteProp = async (id: string): Promise => { await apiClient.delete(`/card/templates/${id}/`) return true } export const publishProp = async (id: string): Promise => { const response = await apiClient.post(`/card/templates/${id}/publish/`) const data = response.data?.template || response.data return mapBackendProp(data) } export const archiveProp = async (id: string): Promise => { const response = await apiClient.post(`/card/templates/${id}/archive/`) const data = response.data?.template || response.data return mapBackendProp(data) }