Chloe 4684d54ac3
fix: create side dialog for content inside PDP
Signed-off-by: Chloe <pinkcloudvnn@gmail.com>
2024-05-21 15:19:00 +07:00

44 lines
1.3 KiB
TypeScript

import { getMenu, getMetaobjects } from 'lib/shopify';
import { ReactNode } from 'react';
import FiltersList from './filters-list';
const YMMFiltersContainer = ({ children }: { children: ReactNode }) => {
return (
<div className="rounded border bg-white px-6 pb-5 pt-4">
<p className="mb-3 text-xl font-semibold leading-tight tracking-tight text-neutral-700">
Find Your Car Part
</p>
{children}
</div>
);
};
const YMMFilters = async () => {
const yearsData = getMetaobjects('make_model_year_composite');
const modelsData = getMetaobjects('make_model_composite');
const makesData = getMetaobjects('make_composite');
const [years, models, makes] = await Promise.all([yearsData, modelsData, makesData]);
const menu = await getMenu('main-menu');
return (
<YMMFiltersContainer>
<FiltersList years={years} makes={makes} models={models} menu={menu} />
</YMMFiltersContainer>
);
};
export const YMMFiltersPlaceholder = () => {
return (
<YMMFiltersContainer>
<div className="flex grow animate-pulse flex-col items-center gap-3 md:flex-row">
<div className="h-9 w-full rounded bg-gray-100" />
<div className="h-9 w-full rounded bg-gray-100" />
<div className="h-9 w-full rounded bg-gray-100" />
</div>
</YMMFiltersContainer>
);
};
export default YMMFilters;