Refine bonus account detail card
This commit is contained in:
@@ -17,17 +17,11 @@ withDefaults(defineProps<{
|
|||||||
email?: string;
|
email?: string;
|
||||||
companyName?: string | null;
|
companyName?: string | null;
|
||||||
balance: number;
|
balance: number;
|
||||||
avatarSrc?: string;
|
|
||||||
initials?: string;
|
|
||||||
compact?: boolean;
|
|
||||||
stats?: BonusCardStat[];
|
stats?: BonusCardStat[];
|
||||||
sourceLinks?: BonusCardLink[];
|
sourceLinks?: BonusCardLink[];
|
||||||
}>(), {
|
}>(), {
|
||||||
email: '',
|
email: '',
|
||||||
companyName: null,
|
companyName: null,
|
||||||
avatarSrc: '',
|
|
||||||
initials: 'FR',
|
|
||||||
compact: false,
|
|
||||||
stats: () => [],
|
stats: () => [],
|
||||||
sourceLinks: () => [],
|
sourceLinks: () => [],
|
||||||
});
|
});
|
||||||
@@ -41,73 +35,40 @@ function formatAmount(value: number) {
|
|||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<article
|
<article class="surface-card rounded-[32px] p-6">
|
||||||
class="surface-card rounded-[32px]"
|
<div class="space-y-1">
|
||||||
:class="compact ? 'flex min-h-[280px] flex-col p-6' : 'p-6'"
|
<h1 class="text-2xl font-bold leading-tight text-[#123824]">{{ fullName }}</h1>
|
||||||
>
|
<p v-if="companyName || email" class="text-sm text-[#5c7b69]">
|
||||||
<template v-if="compact">
|
{{ companyName || email }}
|
||||||
<div class="flex justify-center">
|
</p>
|
||||||
<img
|
</div>
|
||||||
v-if="avatarSrc"
|
|
||||||
:src="avatarSrc"
|
|
||||||
:alt="fullName"
|
|
||||||
class="h-24 w-24 rounded-[32px] object-cover shadow-[0_12px_30px_rgba(18,56,36,0.14)]"
|
|
||||||
>
|
|
||||||
<div
|
|
||||||
v-else
|
|
||||||
class="flex h-24 w-24 items-center justify-center rounded-[32px] bg-[linear-gradient(135deg,#dff7e9_0%,#c2ead3_100%)] text-3xl font-black text-[#123824] shadow-[inset_0_1px_0_rgba(255,255,255,0.65)]"
|
|
||||||
>
|
|
||||||
{{ initials }}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="flex-1" />
|
<div class="mt-6 grid gap-3 md:grid-cols-2 xl:grid-cols-4">
|
||||||
|
<div
|
||||||
<div class="pt-8 text-center">
|
v-for="stat in stats"
|
||||||
<h2 class="text-lg font-bold leading-tight text-[#123824]">{{ fullName }}</h2>
|
:key="stat.label"
|
||||||
|
class="rounded-[24px] bg-[#f6fbf8] px-4 py-4"
|
||||||
|
>
|
||||||
|
<p class="text-[11px] font-semibold uppercase tracking-[0.18em] text-[#6a8a76]">{{ stat.label }}</p>
|
||||||
|
<p class="mt-2 text-xl font-bold leading-none text-[#123824]">{{ stat.value }}</p>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="pt-6 text-left">
|
<div class="mt-6 rounded-[24px] bg-[#f6fbf8] px-4 py-4">
|
||||||
<p class="text-[11px] font-semibold uppercase tracking-[0.18em] text-[#6a8a76]">Доступный бонус</p>
|
<p class="text-[11px] font-semibold uppercase tracking-[0.18em] text-[#6a8a76]">Доступный бонус</p>
|
||||||
<p class="mt-2 text-2xl font-black leading-none text-[#123824]">{{ formatAmount(balance) }}</p>
|
<p class="mt-2 text-3xl font-black leading-none text-[#123824]">{{ formatAmount(balance) }}</p>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
|
||||||
|
|
||||||
<template v-else>
|
<div v-if="sourceLinks.length" class="mt-6 space-y-2">
|
||||||
<div class="space-y-1">
|
<div
|
||||||
<h1 class="text-2xl font-bold leading-tight text-[#123824]">{{ fullName }}</h1>
|
v-for="link in sourceLinks"
|
||||||
<p v-if="companyName || email" class="text-sm text-[#5c7b69]">
|
:key="link.id"
|
||||||
{{ companyName || email }}
|
class="rounded-[24px] bg-[#f6fbf8] px-4 py-4 text-sm text-[#355947]"
|
||||||
</p>
|
>
|
||||||
|
<p class="font-semibold text-[#123824]">{{ link.refereeName }}</p>
|
||||||
|
<p class="mt-1">{{ link.refereeCompanyName || link.refereeEmail }}</p>
|
||||||
|
<p class="mt-2 text-xs text-[#5c7b69]">Бонус {{ link.bonusPercent }}%</p>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
<div class="mt-6 grid gap-3 md:grid-cols-2 xl:grid-cols-4">
|
|
||||||
<div
|
|
||||||
v-for="stat in stats"
|
|
||||||
:key="stat.label"
|
|
||||||
class="rounded-[24px] bg-[#f6fbf8] px-4 py-4"
|
|
||||||
>
|
|
||||||
<p class="text-[11px] font-semibold uppercase tracking-[0.18em] text-[#6a8a76]">{{ stat.label }}</p>
|
|
||||||
<p class="mt-2 text-xl font-bold leading-none text-[#123824]">{{ stat.value }}</p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="mt-6 rounded-[24px] bg-[#f6fbf8] px-4 py-4">
|
|
||||||
<p class="text-[11px] font-semibold uppercase tracking-[0.18em] text-[#6a8a76]">Доступный бонус</p>
|
|
||||||
<p class="mt-2 text-3xl font-black leading-none text-[#123824]">{{ formatAmount(balance) }}</p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div v-if="sourceLinks.length" class="mt-6 space-y-2">
|
|
||||||
<div
|
|
||||||
v-for="link in sourceLinks"
|
|
||||||
:key="link.id"
|
|
||||||
class="rounded-[24px] bg-[#f6fbf8] px-4 py-4 text-sm text-[#355947]"
|
|
||||||
>
|
|
||||||
<p class="font-semibold text-[#123824]">{{ link.refereeName }}</p>
|
|
||||||
<p class="mt-1">{{ link.refereeCompanyName || link.refereeEmail }}</p>
|
|
||||||
<p class="mt-2 text-xs text-[#5c7b69]">Бонус {{ link.bonusPercent }}%</p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
</article>
|
</article>
|
||||||
</template>
|
</template>
|
||||||
|
|||||||
Reference in New Issue
Block a user