From 91b0c8cfeef912bbda451e9b9ac104ed87677a3e Mon Sep 17 00:00:00 2001 From: Clemence Kyara Date: Mon, 15 Jul 2024 08:55:58 +0300 Subject: [PATCH] Improve customisability --- .../src/LocationTag/LocationTag.js | 77 +++++++++---------- 1 file changed, 38 insertions(+), 39 deletions(-) diff --git a/packages/hurumap-core/src/LocationTag/LocationTag.js b/packages/hurumap-core/src/LocationTag/LocationTag.js index e28f1275a..0406db1ce 100644 --- a/packages/hurumap-core/src/LocationTag/LocationTag.js +++ b/packages/hurumap-core/src/LocationTag/LocationTag.js @@ -1,15 +1,11 @@ -import { - Box, - LinearProgress as MuiLinearProgress, - Typography, - IconButton, - styled, -} from "@mui/material"; +import { Box, IconButton, LinearProgress, styled } from "@mui/material"; import { alpha } from "@mui/material/styles"; -import { typographyClasses } from "@mui/material/Typography"; import React from "react"; -const LocationTagRoot = styled(Box)(({ active, theme, variant }) => { +const LocationTagRoot = styled(Box, { + shouldForwardProp: (prop) => + !["active", "highlight", "variant"].includes(prop), +})(({ active, theme, variant }) => { const { palette, typography } = theme; let color = palette.text.primary; let backgroundColor = palette.background.default; @@ -29,7 +25,7 @@ const LocationTagRoot = styled(Box)(({ active, theme, variant }) => { }; }); -const LinearProgress = styled(MuiLinearProgress)(({ theme }) => { +const LoadingLinearProgress = styled(LinearProgress)(({ theme }) => { const { typography } = theme; return { @@ -41,36 +37,49 @@ const LinearProgress = styled(MuiLinearProgress)(({ theme }) => { }; }); -const LevelTypography = styled(Typography)(({ theme }) => { +const LevelTypography = styled("h6", { + // component color and not Typoegraphy color + shouldForwardProp: (prop) => !["color"].includes(prop), +})(({ color, theme }) => { const { palette, typography } = theme; + const backgroundColor = palette[color]?.main; + return { + backgroundColor, borderRadius: typography.pxToRem(4), color: palette.text.secondary, - fontWeight: "bold", fontSize: typography.pxToRem(7), + fontWeight: "bold", letterSpacing: "0.56px", lineHeight: 10 / 7, + margin: 0, padding: `${typography.pxToRem(4)} ${typography.pxToRem(12)}`, position: "absolute", textAlign: "center", textTransform: "uppercase", top: typography.pxToRem(-8), - [`&.${typographyClasses.colorPrimary}`]: { - backgroundColor: palette.primary.main, - }, - [`&.${typographyClasses.colorSecondary}`]: { - backgroundColor: palette.secondary.main, - }, + }; +}); + +const NameTypography = styled("span")(({ theme }) => { + return { + fontSize: theme.typography.pxToRem(9), + fontWeight: "bold", + lineHeight: 13 / 9, + margin: "auto", + textTransform: "capitalize", }; }); const LocationTag = React.forwardRef(function LocationTag( { - IconButtonProps, LevelTypographyProps, + LoadingLinearProgressProps, + MarkerProps, NameTypographyProps, active, code, + color, isLoading, level, name: nameProp, @@ -92,51 +101,41 @@ const LocationTag = React.forwardRef(function LocationTag( const name = isLoading ? "…" : nameProp; return ( {variant === "marker" ? ( ({ + color: "#ebebeb", position: "absolute", top: -68, - color: "#ebebeb", "&:hover": { color: "#666666", "& .Component108-4_svg__b": { stroke: theme.palette.text?.secondary, }, }, - ...IconButtonProps?.sx, + ...MarkerProps?.sx, })} /> ) : null} {isLoading ? ( - + ) : ( - + {level} )} - ({ - fontSize: theme.typography.pxToRem(9), - fontWeight: "bold", - lineHeight: 13 / 9, - margin: "auto", - textTransform: "capitalize", - ...NameTypographyProps?.sx, - })} - > - {name} - + {name} ); });