145 lines
6.0 KiB
JavaScript
145 lines
6.0 KiB
JavaScript
'use client'
|
||
|
||
import { useEffect, useState } from 'react'
|
||
import { Tab, TabGroup, TabList, TabPanel, TabPanels } from '@headlessui/react'
|
||
import clsx from 'clsx'
|
||
|
||
import { Container } from '@/components/Container'
|
||
|
||
const features = [
|
||
{
|
||
title: 'Tailored to Your Preferences',
|
||
description:
|
||
"From your trip's duration to the daily itinerary and dining choices, everything is customized to your liking. We offer expert advice to align with your group's preferences, ensuring a journey that fits your vision perfectly.",
|
||
image: '/images/screenshots/payroll.png',
|
||
},
|
||
{
|
||
title: 'Unique & Memorable Adventures',
|
||
description:
|
||
"Experience exclusive activities like a barbeque on a secluded island or private moments in ancient temples. The VEDA crew can also lead you to the Nile’s most remarkable and energetic spots, tailored to your interests.",
|
||
image: '/images/screenshots/expenses.png',
|
||
},
|
||
{
|
||
title: 'Eco-Friendly & Organic',
|
||
description:
|
||
"Savor local dishes, fresh juices, and detox smoothies while using natural cleaning products and sailing on solar-powered boats. With VEDA, you're traveling on the Nile’s first genuinely green boat, combining sustainability with luxury.",
|
||
image: '/images/screenshots/reporting.png',
|
||
},
|
||
]
|
||
|
||
export function PrimaryFeatures() {
|
||
let [tabOrientation, setTabOrientation] = useState('horizontal')
|
||
|
||
useEffect(() => {
|
||
let lgMediaQuery = window.matchMedia('(min-width: 1024px)')
|
||
|
||
function onMediaQueryChange({ matches }) {
|
||
setTabOrientation(matches ? 'vertical' : 'horizontal')
|
||
}
|
||
|
||
onMediaQueryChange(lgMediaQuery)
|
||
lgMediaQuery.addEventListener('change', onMediaQueryChange)
|
||
|
||
return () => {
|
||
lgMediaQuery.removeEventListener('change', onMediaQueryChange)
|
||
}
|
||
}, [])
|
||
|
||
return (
|
||
<section
|
||
id="features"
|
||
aria-label="What makes us different"
|
||
className="relative overflow-hidden bg-blue-600 pb-28 pt-20 sm:py-32"
|
||
>
|
||
<img
|
||
className="absolute left-1/2 top-1/2 max-w-none translate-x-[-44%] translate-y-[-42%]"
|
||
src="/images/background-features.png"
|
||
alt=""
|
||
width={2245}
|
||
height={1636}
|
||
|
||
/>
|
||
<Container className="relative">
|
||
<div className="max-w-2xl md:mx-auto md:text-center xl:max-w-none">
|
||
<h2 className="font-display text-3xl tracking-tight text-white sm:text-4xl md:text-5xl">
|
||
What makes VEDA different?
|
||
</h2>
|
||
<p className="mt-6 text-lg tracking-tight text-blue-100">
|
||
Well everything you need if you aren’t that picky about minor
|
||
details like tax compliance.
|
||
</p>
|
||
</div>
|
||
<TabGroup
|
||
className="mt-16 grid grid-cols-1 items-center gap-y-2 pt-10 sm:gap-y-6 md:mt-20 lg:grid-cols-12 lg:pt-0"
|
||
vertical={tabOrientation === 'vertical'}
|
||
>
|
||
{({ selectedIndex }) => (
|
||
<>
|
||
<div className="-mx-4 flex overflow-x-auto pb-4 sm:mx-0 sm:overflow-visible sm:pb-0 lg:col-span-5">
|
||
<TabList className="relative z-10 flex gap-x-4 whitespace-nowrap px-6 sm:mx-auto sm:px-0 lg:mx-0 lg:block lg:gap-x-0 lg:gap-y-1 lg:whitespace-normal">
|
||
{features.map((feature, featureIndex) => (
|
||
<div
|
||
key={feature.title}
|
||
className={clsx(
|
||
'group relative rounded-full px-6 py-1 lg:rounded-l-xl lg:rounded-r-none lg:p-6',
|
||
selectedIndex === featureIndex
|
||
? 'bg-white lg:bg-white/10 lg:ring-1 lg:ring-inset lg:ring-white/10'
|
||
: 'hover:bg-white/10 lg:hover:bg-white/5',
|
||
)}
|
||
>
|
||
<h3>
|
||
<Tab
|
||
className={clsx(
|
||
'font-display text-lg ui-not-focus-visible:outline-none',
|
||
selectedIndex === featureIndex
|
||
? 'text-blue-600 lg:text-white'
|
||
: 'text-blue-100 hover:text-white lg:text-white',
|
||
)}
|
||
>
|
||
<span className="absolute inset-0 rounded-full lg:rounded-l-xl lg:rounded-r-none" />
|
||
{feature.title}
|
||
</Tab>
|
||
</h3>
|
||
<p
|
||
className={clsx(
|
||
'mt-2 hidden text-sm lg:block',
|
||
selectedIndex === featureIndex
|
||
? 'text-white'
|
||
: 'text-blue-100 group-hover:text-white',
|
||
)}
|
||
>
|
||
{feature.description}
|
||
</p>
|
||
</div>
|
||
))}
|
||
</TabList>
|
||
</div>
|
||
<TabPanels className="lg:col-span-7">
|
||
{features.map((feature) => (
|
||
<TabPanel key={feature.title} unmount={false}>
|
||
<div className="relative sm:px-6 lg:hidden">
|
||
<div className="absolute -inset-x-4 bottom-[-4.25rem] top-[-6.5rem] bg-white/10 ring-1 ring-inset ring-white/10 sm:inset-x-0 sm:rounded-t-xl" />
|
||
<p className="relative mx-auto max-w-2xl text-base text-white sm:text-center">
|
||
{feature.description}
|
||
</p>
|
||
</div>
|
||
<div className="mt-10 w-[45rem] overflow-hidden rounded-xl bg-slate-50 shadow-xl shadow-blue-900/20 sm:w-auto lg:mt-0 lg:w-[67.8125rem]">
|
||
<img
|
||
className="w-full"
|
||
src={feature.image}
|
||
alt=""
|
||
priority
|
||
sizes="(min-width: 1024px) 67.8125rem, (min-width: 640px) 100vw, 45rem"
|
||
/>
|
||
</div>
|
||
</TabPanel>
|
||
))}
|
||
</TabPanels>
|
||
</>
|
||
)}
|
||
</TabGroup>
|
||
</Container>
|
||
</section>
|
||
)
|
||
}
|