Files
hossein-por-shop/frontend/pages/cart/delivery.vue
2026-05-05 19:53:16 +03:30

182 lines
7.6 KiB
Vue

<script setup lang="ts">
// imports
import useGetAllAddress from "~/composables/api/account/useGetAllAddress";
import useGetCartOrders from "~/composables/api/orders/useGetCartOrders";
// meta
useSeoMeta({
title: "انتخاب آدرس",
});
definePageMeta({
layout: "cart",
middleware: "check-is-logged-in",
prevPage: { name: "cart", label: "سبد خرید" },
nextPage: { name: "cart-checkout", label: "تسویه حساب", query: "ZIBAL" },
});
// types
type DeliveryData = {
address: Address | null;
deliveryMethod: {
tipax: boolean;
pishtaz: boolean;
peyk: boolean;
deka: boolean;
};
};
// queries
const { data: cart } = useGetCartOrders();
const { data: addresses, isLoading: addressesIsLoading } = useGetAllAddress();
// computed
const selectedAddress = computed(() => {
return addresses.value?.find((i) => i.is_main) ?? null;
});
// state
const deliveryData = ref<DeliveryData>({
address: selectedAddress.value,
deliveryMethod: {
peyk: false,
pishtaz: false,
tipax: false,
deka: true,
},
});
</script>
<template>
<div class="flex flex-col w-full gap-5">
<AddressItem />
<div class="flex flex-col w-full gap-6">
<div class="flex items-center gap-3 py-3">
<NuxtImg
src="/img/location.gif"
loading="lazy"
fetch-priority="low"
class="size-12 pb-1 -mr-3"
/>
<span class="typo-sub-h-xl -mr-3"> آدرس های شما </span>
</div>
<div
v-if="addressesIsLoading"
class="flex flex-col gap-6 w-full"
>
<Skeleton
v-for="i in 3"
class="w-full !h-[8rem] !rounded-xl"
/>
</div>
<template v-else>
<div
v-if="!addresses?.length"
class="flex flex-grow w-full"
v-auto-animate
>
<Placeholder
title="آدرسی یافت نشد :("
icon="ci:bi-map"
class="!py-[2rem]"
/>
</div>
<div
v-else
class="flex flex-col gap-6 w-full"
>
<AddressItem
v-for="(address, index) in addresses"
:key="index"
:isSelected="address.id === cart?.address?.id"
:address="address"
/>
</div>
</template>
</div>
<div class="flex flex-col items-center w-full gap-4 my-3 p-4 border border-slate-200 rounded-xl bg-slate-50">
<span class="flex items-center justify-start w-full lg:text-[1.125rem] font-semibold text-slate-900">
شیوه ارسال
</span>
<label
@click="deliveryData.deliveryMethod.deka = true"
:class="deliveryData.deliveryMethod.deka ? 'ring-black ring-offset-2 ring-2' : ''"
class="flex flex-col select-none w-full gap-2 p-3 transition-all border cursor-pointer delivery-option focus-within:ring-2 ring-blue-500 ring-offset-2 focus-within:border-blue-500 rounded-100 border-slate-200 bg-slate-50"
>
<div class="flex items-center justify-between w-full">
<div class="flex items-center gap-2.5">
<SwitchRoot
v-model="deliveryData.deliveryMethod.deka"
:defaultValue="false"
class="w-[3rem] h-[1.8rem] shrink-0 flex data-[state=unchecked]:bg-slate-200 data-[state=checked]:bg-blue-500 border border-slate-200 data-[state=checked]:border-blue-500/20 rounded-full relative transition-all focus-within:outline-none"
>
<SwitchThumb
class="size-6 my-auto bg-white text-sm ms-1 flex items-center justify-center shadow-xl rounded-full transition-transform translate-x-0.5 will-change-transform data-[state=checked]:-translate-x-[68%]"
/>
</SwitchRoot>
<span class="w-full text-slate-800 text-sm lg:text-[1rem]">دکا پست</span>
</div>
<span class="text-slate-800 text-sm lg:text-[1rem]"> پرداخت در محل </span>
</div>
</label>
<!-- <label
@click="deliveryData.deliveryMethod.pishtaz = true"
:class="deliveryData.deliveryMethod.pishtaz ? 'ring-black ring-offset-2 ring-2' : ''"
class="flex flex-col select-none w-full gap-2 p-3 transition-all border cursor-pointer delivery-option focus-within:ring-2 ring-blue-500 ring-offset-2 focus-within:border-blue-500 rounded-100 border-slate-200 bg-slate-50"
>
<div class="flex items-center justify-between w-full">
<div class="flex items-center gap-2.5">
<SwitchRoot
v-model="deliveryData.deliveryMethod.pishtaz"
:defaultValue="false"
class="w-[3rem] h-[1.8rem] shrink-0 flex data-[state=unchecked]:bg-slate-200 data-[state=checked]:bg-blue-500 border border-slate-200 data-[state=checked]:border-blue-500/20 rounded-full relative transition-all focus-within:outline-none"
>
<SwitchThumb
class="size-6 my-auto bg-white text-sm ms-1 flex items-center justify-center shadow-xl rounded-full transition-transform translate-x-0.5 will-change-transform data-[state=checked]:-translate-x-[68%]"
/>
</SwitchRoot>
<span class="w-full text-slate-800 text-sm lg:text-[1rem]">پست پیشتاز</span>
</div>
<span class="text-slate-800 text-sm lg:text-[1rem]"> ۱۵۰٬۰۰۰ تومان </span>
</div>
</label>
<label
class="flex items-center opacity-50 select-none pointer-events-none justify-between w-full p-3 transition-all border cursor-pointer delivery-option focus-within:ring-2 ring-blue-500 ring-offset-2 focus-within:border-blue-500 rounded-100 border-slate-200 bg-slate-50"
>
<div class="flex items-center gap-2.5">
<SwitchRoot
v-model="deliveryData.deliveryMethod.tipax"
class="w-[3rem] h-[1.8rem] shrink-0 flex data-[state=unchecked]:bg-slate-200 data-[state=checked]:bg-blue-500 border border-slate-200 data-[state=checked]:border-blue-500/20 rounded-full relative transition-all focus-within:outline-none"
>
<SwitchThumb
class="size-6 my-auto bg-white text-sm ms-1 flex items-center justify-center shadow-xl rounded-full transition-transform translate-x-0.5 will-change-transform data-[state=checked]:-translate-x-[68%]"
/>
</SwitchRoot>
<span class="w-full text-slate-800 text-sm lg:text-[1rem]">تیپاکس</span>
</div>
<span class="text-slate-800 text-sm lg:text-[1rem]"> ۱۵۰٬۰۰۰ تومان </span>
</label> -->
</div>
<OrderSummary />
</div>
</template>
<style scoped></style>