Skip to content

Commit

Permalink
[CCUBE-1608][MAHI]Migrate Icon, Image Button, Card, Notification and …
Browse files Browse the repository at this point in the history
…SmartApp Banner to V3
  • Loading branch information
mahidhar-reddy09 committed Nov 5, 2024
1 parent 0aabee4 commit 07209b5
Show file tree
Hide file tree
Showing 7 changed files with 76 additions and 73 deletions.
4 changes: 2 additions & 2 deletions src/card/card.style.tsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
import styled from "styled-components";
import { V2_Color } from "../v2_color/color";
import { Colour } from "../theme";

// =============================================================================
// STYLING
// =============================================================================
export const StyledCard = styled.div`
border-radius: 0.5rem;
background: ${V2_Color.Neutral[8]};
background: ${Colour.bg};
padding: 1rem 2rem;
box-shadow: 0 0.125rem 0.5rem rgba(104, 104, 104, 0.25);
`;
4 changes: 2 additions & 2 deletions src/card/card.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { V2_Text } from "../v2_text/text";
import { Typography } from "../typography/typography";
import { StyledCard } from "./card.style";
import { CardProps } from "./types";

Expand All @@ -13,7 +13,7 @@ export const Card = ({ children, ...otherProps }: CardProps): JSX.Element => {
// =============================================================================
const renderContent = () =>
typeof children === "string" ? (
<V2_Text.Body>{children}</V2_Text.Body>
<Typography.BodyBL>{children}</Typography.BodyBL>
) : (
children
);
Expand Down
39 changes: 24 additions & 15 deletions src/icon-button/icon-button.style.tsx
Original file line number Diff line number Diff line change
@@ -1,17 +1,14 @@
import styled, { css } from "styled-components";
import { V2_Color } from "../v2_color/color";
import { SizeType, StyleType } from "./types";

import { Colour } from "../theme";
interface StyleProps {
$styleType: StyleType;
$sizeType: SizeType;
}

export const Main = styled.button<StyleProps>`
align-items: center;
background-color: ${V2_Color.Primary};
border-radius: 0.25rem;
color: ${V2_Color.Neutral[8]};
cursor: pointer;
display: flex;
justify-content: center;
Expand Down Expand Up @@ -62,33 +59,45 @@ export const Main = styled.button<StyleProps>`
switch (props.$styleType) {
case "secondary":
return css`
background-color: ${V2_Color.Neutral[8]};
border: 1px solid ${V2_Color.Primary};
color: ${V2_Color.Primary};
background-color: ${Colour.bg};
border: 1px solid ${Colour["border-primary"]};
color: ${Colour["text-primary"]};
:hover {
background-color: ${Colour["bg-hover-neutral"]};
}
`;
case "light":
return css`
background-color: ${V2_Color.Neutral[8]};
border: 1px solid ${V2_Color.Neutral[5]};
color: ${V2_Color.Primary};
background-color: ${Colour.bg};
border: 1px solid ${Colour.border};
color: ${Colour["text-primary"]};
:hover {
background-color: ${Colour["bg-hover-neutral"]};
}
`;
case "primary":
default:
return css`
background-color: ${V2_Color.Primary};
background-color: ${Colour["bg-primary"]};
border: none;
color: ${V2_Color.Neutral[8]};
color: ${Colour["text-inverse"]};
:hover {
background-color: ${Colour["bg-primary-hover"]};
}
`;
}
}}
&:hover {
box-shadow: 1px 1px 4px 2px rgba(0, 0, 0, 0.2);
}
&:disabled {
background-color: ${V2_Color.Neutral[6]};
border: 1px solid ${V2_Color.Neutral[6]};
color: ${V2_Color.Neutral[3]};
background-color: ${Colour["bg-disabled"]};
border: 1px solid ${Colour["border-disabled"]};
color: ${Colour["text-disabled"]};
cursor: not-allowed;
&:hover {
Expand Down
37 changes: 16 additions & 21 deletions src/image-button/image-button.style.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import { V2_MediaQuery } from "../v2_media";
import styled, { css } from "styled-components";
import { V2_Color } from "../v2_color/color";
import { V2_TextStyleHelper } from "../v2_text/helper";
import { Colour, Font } from "../theme";
import { MediaQuery } from "../theme";

export const Main = styled.button<{
$selected?: boolean;
Expand All @@ -14,14 +13,14 @@ export const Main = styled.button<{
justify-content: center;
align-items: center;
padding: 1.5rem 1rem;
background-color: ${V2_Color.Neutral[8]};
background-color: ${Colour.bg};
border: 1px solid transparent;
border-radius: 0.5rem;
cursor: pointer;
max-width: 13rem;
transition: all 200ms ease;
${V2_TextStyleHelper.getTextStyle("Body", "semibold")}
color: ${({ $selected }) => $selected && V2_Color.Primary};
${Font["body-baseline-semibold"]}
color: ${({ $selected }) => $selected && Colour["text-primary"]};
overflow-wrap: anywhere;
img {
Expand All @@ -31,36 +30,32 @@ export const Main = styled.button<{
object-fit: contain;
}
${V2_MediaQuery.MaxWidth.mobileL} {
${MediaQuery.MaxWidth.sm} {
padding: 0.5rem 0.25rem;
gap: 0.25rem;
${V2_TextStyleHelper.getTextStyle("BodySmall", "semibold")}
${Font["body-lg-semibold"]}
}
${(props) => {
if (props.$error) {
return css`
background: ${V2_Color.Neutral[8]};
border: 1px solid ${V2_Color.Validation.Red.Border};
:hover {
box-shadow: 0 0 4px 1px ${V2_Color.Shadow.Red};
}
background: ${Colour.bg};
border: 1px solid ${Colour["border-error"]};
`;
} else if (props.$selected) {
return css`
background: ${V2_Color.Accent.Light[5]};
border: 1px solid ${V2_Color.Primary};
background: ${Colour["bg-selected"]};
border: 1px solid ${Colour["border-selected"]};
:hover {
box-shadow: 0 0 4px 1px ${V2_Color.Shadow.Accent};
&:hover {
background: ${Colour["bg-selected-hover"]};
border: 1px solid ${Colour["border-selected-hover"]};
}
`;
} else {
return css`
&:hover {
border: 1px solid ${V2_Color.Accent.Light[1]};
box-shadow: 0 0 4px 1px ${V2_Color.Shadow.Accent};
border: 1px solid ${Colour["border-hover-strong"]};
}
`;
}
Expand All @@ -74,7 +69,7 @@ export const Main = styled.button<{
img {
filter: grayscale(100%);
}
color: ${V2_Color.Neutral[3]};
color: ${Colour["text-disabled"]};
outline: none;
cursor: not-allowed;
Expand Down
36 changes: 18 additions & 18 deletions src/notification-banner/notification-banner.styles.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import { CrossIcon } from "@lifesg/react-icons/cross";
import styled, { css } from "styled-components";
import { V2_Color } from "../v2_color";
import { V2_Layout } from "../v2_layout";
import { ClickableIcon } from "../shared/clickable-icon";
import { V2_Text, V2_TextStyleHelper } from "../v2_text";
import { Transition } from "../transition";
import { Colour, Font } from "../theme";
import { Layout } from "../layout";
import { Typography } from "../typography";

// =============================================================================
// STYLE INTERFACES, transient props are denoted with $
Expand All @@ -23,19 +23,19 @@ interface ContentStyleProps {
// STYLING
// =============================================================================
const commonLinkStyle = css`
color: ${V2_Color.Validation.Orange.Icon};
color: ${Colour["hyperlink-inverse"]};
svg {
color: ${V2_Color.Validation.Orange.Icon};
color: ${Colour["icon-primary-inverse"]};
}
:hover,
:active,
:visited,
:focus {
color: ${V2_Color.Validation.Orange.Icon};
color: ${Colour["hyperlink-inverse"]};
svg {
color: ${V2_Color.Validation.Orange.Icon};
color: ${Colour["icon-primary-inverse"]};
}
}
`;
Expand All @@ -46,12 +46,12 @@ export const Wrapper = styled.div<WrapperStyleProps>`
top: 0;
width: 100%;
transition: ${Transition.Base};
background: ${V2_Color.Neutral[2]};
background: ${Colour["bg-inverse-subtle"]};
z-index: 25;
cursor: ${(props) => (props.$clickable ? "pointer" : "default")};
`;

export const Container = styled(V2_Layout.Content)`
export const Container = styled(Layout.Content)`
display: flex;
`;

Expand All @@ -68,20 +68,20 @@ export const Content = styled.div<ContentStyleProps>`
display: inline-block;
width: 100%;
${V2_TextStyleHelper.getTextStyle("Body", "regular")}
color: ${V2_Color.Neutral[8]};
${Font["body-baseline-regular"]}
color: ${Colour["text-inverse"]};
p {
display: inline-block;
}
strong {
${V2_TextStyleHelper.getFontFamily("Body", "semibold")}
color: ${V2_Color.Neutral[8]};
${Font["body-baseline-semibold"]}
color: ${Colour["text-inverse"]};
}
a {
${V2_TextStyleHelper.getTextStyle("Body", "regular")}
${Font["body-baseline-regular"]}
${commonLinkStyle}
}
Expand All @@ -98,7 +98,7 @@ export const Content = styled.div<ContentStyleProps>`
}}
`;

export const ContentLink = styled(V2_Text.Hyperlink.Default)`
export const ContentLink = styled(Typography.LinkBL)`
position: relative;
${commonLinkStyle}
Expand All @@ -113,7 +113,7 @@ export const StyledIconButton = styled(ClickableIcon)`
export const StyledIcon = styled(CrossIcon)`
height: 1.875rem;
width: 1.875rem;
color: ${V2_Color.Neutral[8]};
color: ${Colour["icon-inverse"]};
`;

export const ActionButton = styled.button`
Expand All @@ -125,8 +125,8 @@ export const ActionButton = styled.button`
border: none;
background: transparent;
color: ${V2_Color.Validation.Orange.Icon};
${V2_TextStyleHelper.getTextStyle("BodySmall", "semibold")};
color: ${Colour["hyperlink-inverse"]};
${Font["body-md-semibold"]};
cursor: pointer;
`;
Expand Down
8 changes: 4 additions & 4 deletions src/notification-banner/types.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { V2_TextLinkProps, V2_TextProps } from "../v2_text/types";
import { TypographyLinkProps, TypographyProps } from "../typography";

export interface NotificationBannerProps
extends React.HTMLAttributes<HTMLDivElement> {
Expand All @@ -21,11 +21,11 @@ export interface NotificationBannerWithForwardedRefProps

export type ContentType = "text" | "link";

export interface ContentLinkAttributes extends V2_TextLinkProps {}
export interface ContentTextAttributes extends V2_TextProps {}
export interface ContentLinkAttributes extends TypographyLinkProps {}
export interface ContentTextAttributes extends TypographyProps {}

export interface NotificationContentAttributes {
type: ContentType;
content: string;
otherAttributes?: V2_TextLinkProps | V2_TextProps | undefined;
otherAttributes?: TypographyLinkProps | TypographyProps | undefined;
}
21 changes: 10 additions & 11 deletions src/smart-app-banner/smart-app-banner.styles.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,9 @@ import { StarFillIcon } from "@lifesg/react-icons/star-fill";
import { StarHalfIcon } from "@lifesg/react-icons/star-half";
import styled, { css, keyframes } from "styled-components";
import { Button } from "../button";
import { V2_Color } from "../v2_color";
import { V2_MediaQuery } from "../v2_media";
import { ClickableIcon } from "../shared/clickable-icon";
import { V2_Text, V2_TextStyleHelper } from "../v2_text";
import { Colour, Font, MediaQuery } from "../theme";
import { Typography } from "../typography/typography";

const slideDown = keyframes`
from {
Expand Down Expand Up @@ -36,7 +35,7 @@ export const SmartAppBannerContainer = styled.div<{
width: calc(100% - 2.5rem);
min-height: 5.5rem;
z-index: 9001;
background: ${V2_Color.Neutral[8]};
background: ${Colour.bg};
box-shadow: 0 0.125rem 0.5rem rgba(104, 104, 104, 0.25);
border-radius: 0.5rem;
${(props) => {
Expand All @@ -58,7 +57,7 @@ export const DismissButton = styled(ClickableIcon)`
`;

export const Cross = styled(CrossIcon)`
color: ${V2_Color.Neutral[1]};
color: ${Colour.icon};
height: 1.25rem;
width: 1.25rem;
`;
Expand All @@ -77,7 +76,7 @@ export const TextContainer = styled.div`
flex-direction: column;
align-items: left;
margin: 0.5rem;
${V2_MediaQuery.MaxWidth.mobileM} {
${MediaQuery.MaxWidth.xs} {
margin: 0 0.5rem;
}
`;
Expand All @@ -97,18 +96,18 @@ export const StyledButton = styled(Button.Small)`
height: auto;
& > span {
overflow-wrap: anywhere;
${V2_TextStyleHelper.getTextStyle("XSmall", "semibold")};
${Font["body-xs-semibold"]}
}
`;

export const Title = styled(V2_Text.H6)`
export const Title = styled(Typography.BodySM)`
overflow-wrap: anywhere;
${V2_MediaQuery.MaxWidth.mobileM} {
${V2_TextStyleHelper.getTextStyle("XSmall", "semibold")}
${MediaQuery.MaxWidth.xs} {
${Font["body-xs-semibold"]}
}
`;

export const Description = styled(V2_Text.XSmall)`
export const Description = styled(Typography.BodyXS)`
overflow-wrap: anywhere;
`;

Expand Down

0 comments on commit 07209b5

Please sign in to comment.