fix(pages): adapt all pages to backend-aligned types
Replace removed fields with available data sources throughout UI: - order pages: use service.title instead of consumer/player names - chat: look up sender from session.participants, remove readonly - community: simplify post cards, keep pinned icon - post detail: keep pinned/linkedOrderId display - shop rules: use string commissionValue - dashboard: parse string amounts for income display - dispute/review: remove initiator/avatar references
This commit is contained in:
@@ -140,7 +140,7 @@ export default function OrderDetailPage({ params }: { params: Promise<{ id: stri
|
||||
const base =
|
||||
order.status === "pending_accept"
|
||||
? new Date(order.createdAt).getTime()
|
||||
: new Date(order.closedAt ?? order.createdAt).getTime()
|
||||
: new Date(order.createdAt).getTime()
|
||||
const timeoutMs =
|
||||
order.status === "pending_accept" ? ORDER_ACCEPT_TIMEOUT_MS : ORDER_CLOSE_TIMEOUT_MS
|
||||
const remainSeconds = Math.max(0, Math.ceil((timeoutMs - (nowTs - base)) / 1000))
|
||||
@@ -223,17 +223,9 @@ export default function OrderDetailPage({ params }: { params: Promise<{ id: stri
|
||||
<div className="flex justify-between text-sm">
|
||||
<span className="text-muted-foreground">打手</span>
|
||||
<Link href={`/player/${order.playerId}`} className="text-primary hover:underline">
|
||||
{order.playerName}
|
||||
{order.service.title}
|
||||
</Link>
|
||||
</div>
|
||||
{order.shopName && (
|
||||
<div className="flex justify-between text-sm">
|
||||
<span className="text-muted-foreground">店铺</span>
|
||||
<Link href={`/shop/${order.shopId}`} className="text-primary hover:underline">
|
||||
{order.shopName}
|
||||
</Link>
|
||||
</div>
|
||||
)}
|
||||
<Separator />
|
||||
<div className="flex justify-between text-sm font-medium">
|
||||
<span>总价</span>
|
||||
@@ -265,13 +257,6 @@ export default function OrderDetailPage({ params }: { params: Promise<{ id: stri
|
||||
{new Date(order.acceptedAt).toLocaleString("zh-CN")}
|
||||
</div>
|
||||
)}
|
||||
{order.closedAt && (
|
||||
<div className="flex items-center gap-2">
|
||||
<CheckCircle className="h-3.5 w-3.5 text-green-500" />
|
||||
<span className="text-muted-foreground">结单时间:</span>
|
||||
{new Date(order.closedAt).toLocaleString("zh-CN")}
|
||||
</div>
|
||||
)}
|
||||
{order.completedAt && (
|
||||
<div className="flex items-center gap-2">
|
||||
<CheckCircle className="h-3.5 w-3.5 text-green-500" />
|
||||
|
||||
Reference in New Issue
Block a user