From a078561462fb33f24d838c974894b3fc7d6c9eb7 Mon Sep 17 00:00:00 2001 From: Miqdad Date: Tue, 26 Aug 2025 12:54:05 +0700 Subject: sementara --- src/lib/category/components/Breadcrumb.jsx | 177 ++++++++++++++++++++++++----- 1 file changed, 150 insertions(+), 27 deletions(-) (limited to 'src/lib/category/components') diff --git a/src/lib/category/components/Breadcrumb.jsx b/src/lib/category/components/Breadcrumb.jsx index 127904ee..b369d781 100644 --- a/src/lib/category/components/Breadcrumb.jsx +++ b/src/lib/category/components/Breadcrumb.jsx @@ -1,45 +1,168 @@ -import odooApi from '@/core/api/odooApi' -import { createSlug } from '@/core/utils/slug' +import odooApi from '@/core/api/odooApi'; +import { createSlug } from '@/core/utils/slug'; import { Breadcrumb as ChakraBreadcrumb, BreadcrumbItem, BreadcrumbLink, - Skeleton -} from '@chakra-ui/react' -import Link from 'next/link' -import React from 'react' -import { useQuery } from 'react-query' - -/** - * Render a breadcrumb component. - * - * @param {object} categoryId - The ID of the category. - * @return {JSX.Element} The breadcrumb component. - */ + Skeleton, +} from '@chakra-ui/react'; +import Link from 'next/link'; +import React from 'react'; +import { useQuery } from 'react-query'; +import useDevice from '@/core/hooks/useDevice'; + const Breadcrumb = ({ categoryId }) => { + const { isDesktop, isMobile } = useDevice(); + const breadcrumbs = useQuery( - `category-breadcrumbs/${categoryId}`, - async () => await odooApi('GET', `/api/v1/category/${categoryId}/category-breadcrumb`) - ) + ['category-breadcrumbs', categoryId], + async () => + await odooApi('GET', `/api/v1/category/${categoryId}/category-breadcrumb`) + ); + + const cats = breadcrumbs.data ?? []; + const total = cats.length; + + const showEllipsis = total > 2; + const parent = total >= 2 ? cats[total - 2] : null; + const last = total ? cats[total - 1] : null; + const hiddenText = showEllipsis + ? cats + .slice(0, total - 2) + .map((c) => c.name) + .join(' / ') + : ''; + + // ===== MOBILE: 2 BARIS -> (1) Home/..//Parent (2) Last (wrap) ===== + if (isMobile) { + return ( +
+ + {/* Baris 1 */} + + + + Home + + + {showEllipsis && ( + + + .. + + + )} + + {parent && ( + + + {parent.name} + + + )} + + + {/* Baris 2 */} + {last && ( + + + + {last.name} + + + + )} + +
+ ); + } + + // ===== DESKTOP: biarkan seperti semula ===== + if (isDesktop) { + return ( +
+ + + + + Home + + + + {cats.map((category, index) => ( + + {index === cats.length - 1 ? ( + + {category.name} + + ) : ( + + {category.name} + + )} + + ))} + + +
+ ); + } + + // Fallback → layout desktop return (
- + Home - - {breadcrumbs.data?.map((category, index) => ( - - {index === breadcrumbs.data.length - 1 ? ( - {category.name} + {cats.map((category, index) => ( + + {index === cats.length - 1 ? ( + + {category.name} + ) : ( {category.name} @@ -50,7 +173,7 @@ const Breadcrumb = ({ categoryId }) => {
- ) -} + ); +}; -export default Breadcrumb +export default Breadcrumb; -- cgit v1.2.3