Refine order detail layout

This commit is contained in:
Ruslan Bakiev
2026-04-06 15:21:05 +07:00
parent 2e3c64bc98
commit bb39642b67
5 changed files with 301 additions and 121 deletions

View File

@@ -5,10 +5,6 @@ import {
type OrderDetailQuery,
} from '~/composables/graphql/generated';
import { formatOrderCode } from '~/composables/useOrderCodePresentation';
import {
orderDeliveryStateText,
orderLogisticsStateText,
} from '~/composables/useOrderDetailPresentation';
type OrderItem = NonNullable<OrderDetailQuery['order']>;
@@ -27,8 +23,6 @@ const currentOrderCode = computed(() => formatOrderCode(currentOrder.value?.code
<template>
<section class="space-y-6">
<NuxtLink to="/orders" class="text-sm font-semibold text-[#0d854a]"> Назад к моим заказам</NuxtLink>
<div v-if="orderQuery.loading.value" class="manager-empty-state">
Загружаем заказ...
</div>
@@ -38,9 +32,19 @@ const currentOrderCode = computed(() => formatOrderCode(currentOrder.value?.code
</div>
<template v-else>
<div class="manager-hero">
<p class="manager-eyebrow">Заказ</p>
<h1 class="manager-title">{{ currentOrderCode }}</h1>
<div class="surface-card rounded-3xl px-5 py-4">
<div class="flex flex-wrap items-center gap-3">
<NuxtLink to="/orders" class="text-sm font-semibold text-[#0d854a]">
Назад к моим заказам
</NuxtLink>
<span class="hidden h-4 w-px bg-[#d8e4dd] md:block" />
<span class="text-[11px] font-semibold uppercase tracking-[0.18em] text-[#6a8a76]">
Заказ
</span>
<span class="text-lg font-black tracking-[-0.03em] text-[#123824]">
{{ currentOrderCode }}
</span>
</div>
</div>
<div class="space-y-4">
@@ -58,26 +62,12 @@ const currentOrderCode = computed(() => formatOrderCode(currentOrder.value?.code
:calculation-payload="currentOrder.calculationPayload"
:framed="false"
/>
</div>
<div class="surface-card rounded-3xl p-5">
<h2 class="text-xl font-bold text-[#123824]">Доставка</h2>
<div class="mt-4 space-y-4 text-sm text-[#123824]">
<div class="space-y-1">
<p class="text-[11px] font-semibold uppercase tracking-[0.18em] text-[#6a8a76]">Адрес</p>
<p class="text-base font-semibold">{{ currentOrder.deliveryAddress || 'Адрес пока не указан' }}</p>
</div>
<div class="grid gap-4 md:grid-cols-2">
<div class="space-y-1">
<p class="text-[11px] font-semibold uppercase tracking-[0.18em] text-[#6a8a76]">Комментарий по доставке</p>
<p>{{ orderDeliveryStateText(currentOrder.deliveryTerms) }}</p>
</div>
<div class="space-y-1">
<p class="text-[11px] font-semibold uppercase tracking-[0.18em] text-[#6a8a76]">Логистика</p>
<p>{{ orderLogisticsStateText(currentOrder.deliveryFee) }}</p>
</div>
</div>
</div>
<OrdersOrderDeliveryLine
class="mt-3"
:delivery-address="currentOrder.deliveryAddress"
:delivery-terms="currentOrder.deliveryTerms"
:delivery-fee="currentOrder.deliveryFee"
/>
</div>
</div>
</template>