From 9ec79daba1fb9c5406e00811fa0fdbb966cd7302 Mon Sep 17 00:00:00 2001 From: Varand Pezeshkian Date: Mon, 22 Jun 2020 16:04:09 -0700 Subject: [PATCH] =?UTF-8?q?feat(Banner):=20Add=20=E2=80=98custom=E2=80=99?= =?UTF-8?q?=20variant=20to=20Banner?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- catalog/pages/banner/index.md | 17 +++++++ src/components/Banner/Banner.styles.js | 10 ++++ .../__snapshots__/index.spec.js.snap | 42 ++++++++--------- src/components/Banner/constants.js | 5 +- src/components/Banner/index.js | 47 +++++++++++++++---- 5 files changed, 89 insertions(+), 32 deletions(-) diff --git a/catalog/pages/banner/index.md b/catalog/pages/banner/index.md index 52ade76c5..ceaba2f45 100644 --- a/catalog/pages/banner/index.md +++ b/catalog/pages/banner/index.md @@ -131,6 +131,23 @@ rows: }} /> + ``` diff --git a/src/components/Banner/Banner.styles.js b/src/components/Banner/Banner.styles.js index 4228095d0..860cb0961 100644 --- a/src/components/Banner/Banner.styles.js +++ b/src/components/Banner/Banner.styles.js @@ -50,6 +50,11 @@ export const Container = styled.div` background-color: ${getThemeValue("primary", "lightest")}; border-color: ${getThemeValue("primary", "base")}; } + + &.banner-variant-custom { + background-color: ${props => props.customColors.backgroundColor}; + border-color: ${props => props.customColors.primaryColor}; + } `; export const ContentSection = styled.div` @@ -57,11 +62,16 @@ export const ContentSection = styled.div` padding-right: ${spacing.comfy}; `; +export const HeaderText = styled(Text)` + color: ${props => props.customColors.textColor}; +`; + export const Content = styled(Text)` padding-top: 12px; opacity: 1; transition: opacity 0.3s ${constants.easing.easeInOutQuad} 0.1s; line-height: 1.29; + color: ${props => props.customColors.textColor}; .collapsed & { transition: opacity 0.3s ${constants.easing.easeInOutQuad}; diff --git a/src/components/Banner/__tests__/__snapshots__/index.spec.js.snap b/src/components/Banner/__tests__/__snapshots__/index.spec.js.snap index 87f3314d2..fa8f5f544 100644 --- a/src/components/Banner/__tests__/__snapshots__/index.spec.js.snap +++ b/src/components/Banner/__tests__/__snapshots__/index.spec.js.snap @@ -102,7 +102,7 @@ exports[` renders correctly when open 1`] = ` class="c2" > This is your primary message text. @@ -248,7 +248,7 @@ exports[` renders correctly when variant is set 1`] = ` class="c2" > This is your primary message text. @@ -344,7 +344,7 @@ exports[` renders correctly with close button 1`] = ` opacity: 0; } -.sc-fzqBZW.c6 { +.sc-fzqNJr.c6 { background-color: transparent; border: none; padding: 0; @@ -368,8 +368,8 @@ exports[` renders correctly with close button 1`] = ` justify-content: center; } -.sc-fzqBZW.c6:active, -.sc-fzqBZW.c6:hover { +.sc-fzqNJr.c6:active, +.sc-fzqNJr.c6:hover { background-color: transparent; } @@ -429,7 +429,7 @@ exports[` renders correctly with close button 1`] = ` class="c2" > This is your primary message text. @@ -606,7 +606,7 @@ exports[` renders correctly with close button hidden 1`] = ` class="c2" > This is your primary message text. @@ -724,7 +724,7 @@ exports[` renders correctly with content 1`] = ` class="c2" > This is your primary message text. @@ -864,7 +864,7 @@ exports[` renders correctly with custom icon 1`] = ` class="c2" > This is your primary message text. @@ -964,7 +964,7 @@ exports[` renders correctly with custom title for the close button 1`] opacity: 0; } -.sc-fzoyAV.c7 { +.sc-fzoLag.c7 { background-color: transparent; border: none; padding: 0; @@ -988,8 +988,8 @@ exports[` renders correctly with custom title for the close button 1`] justify-content: center; } -.sc-fzoyAV.c7:active, -.sc-fzoyAV.c7:hover { +.sc-fzoLag.c7:active, +.sc-fzoLag.c7:hover { background-color: transparent; } @@ -1049,7 +1049,7 @@ exports[` renders correctly with custom title for the close button 1`] class="c2" > This is your primary message text. @@ -1183,7 +1183,7 @@ exports[` renders correctly with expand/collapse button 1`] = ` opacity: 0; } -.sc-fzoLag.c7 { +.sc-fzoXzr.c7 { background-color: transparent; border: none; padding: 0; @@ -1207,8 +1207,8 @@ exports[` renders correctly with expand/collapse button 1`] = ` justify-content: center; } -.sc-fzoLag.c7:active, -.sc-fzoLag.c7:hover { +.sc-fzoXzr.c7:active, +.sc-fzoXzr.c7:hover { background-color: transparent; } @@ -1268,7 +1268,7 @@ exports[` renders correctly with expand/collapse button 1`] = ` class="c2" > This is your primary message text. @@ -1403,7 +1403,7 @@ exports[` renders correctly with link 1`] = ` opacity: 0; } -.sc-fzqNJr.c7 { +.sc-fzoyAV.c7 { background-color: transparent; border: none; padding: 0; @@ -1427,8 +1427,8 @@ exports[` renders correctly with link 1`] = ` justify-content: center; } -.sc-fzqNJr.c7:active, -.sc-fzqNJr.c7:hover { +.sc-fzoyAV.c7:active, +.sc-fzoyAV.c7:hover { background-color: transparent; } @@ -1488,7 +1488,7 @@ exports[` renders correctly with link 1`] = ` class="c2" > This is your primary message text. diff --git a/src/components/Banner/constants.js b/src/components/Banner/constants.js index 4ba2d4d37..305f6706b 100644 --- a/src/components/Banner/constants.js +++ b/src/components/Banner/constants.js @@ -1,9 +1,10 @@ import { ErrorIcon, SuccessIcon, AlertIcon, InfoIcon } from "../Icons"; -export const variants = ["error", "success", "alert", "info"]; +export const variants = ["error", "success", "alert", "info", "custom"]; export const variantsIcons = { [variants[0]]: ErrorIcon, [variants[1]]: SuccessIcon, [variants[2]]: AlertIcon, - [variants[3]]: InfoIcon + [variants[3]]: InfoIcon, + [variants[4]]: InfoIcon }; diff --git a/src/components/Banner/index.js b/src/components/Banner/index.js index 14dfd99da..318d36e90 100644 --- a/src/components/Banner/index.js +++ b/src/components/Banner/index.js @@ -2,7 +2,6 @@ import React, { Component } from "react"; import PropTypes from "prop-types"; import classnames from "classnames"; import { Transition } from "react-transition-group"; -import { Text } from "../Text"; import { variants, variantsIcons } from "./constants"; import { constants } from "../../theme"; import { @@ -13,6 +12,7 @@ import { ContentSection, CloseIcon, Link, + HeaderText, BASE_BANNER_HEIGHT, MAX_BANNER_HEIGHT } from "./Banner.styles"; @@ -35,7 +35,12 @@ class Banner extends Component { variant: PropTypes.oneOf(variants), icon: PropTypes.node, closeButtonTitleText: PropTypes.string, - closeButtonHidden: PropTypes.bool + closeButtonHidden: PropTypes.bool, + customColors: PropTypes.shape({ + primaryColor: PropTypes.string, + backgroundColor: PropTypes.string, + textColor: PropTypes.string + }) }; static defaultProps = { @@ -55,7 +60,8 @@ class Banner extends Component { variant: null, icon: null, closeButtonTitleText: "Close banner", - closeButtonHidden: false + closeButtonHidden: false, + customColors: {} }; // Container max height should be handled programmatically as content height is unknown @@ -78,6 +84,8 @@ class Banner extends Component { content = React.createRef(); + isCustomVariant = () => this.props.variant === variants[4]; + toggleContent = () => { const { onButtonClick } = this.props; const collapsedMaxHeight = `${BASE_BANNER_HEIGHT}px`; @@ -142,17 +150,31 @@ class Banner extends Component { }; renderIcon = () => { - const { variant, icon } = this.props; + const { + variant, + icon, + customColors: { primaryColor: color } + } = this.props; if (!variant && !icon) { return null; } const Icon = variantsIcons[variant]; - return icon || ; + let customColor = null; + if (this.isCustomVariant()) customColor = { color }; + + return icon || ; }; render() { - const { isOpen, heading, content, variant, style } = this.props; + const { + isOpen, + heading, + content, + variant, + style, + customColors + } = this.props; const { isExpanded, maxHeight } = this.state; return ( @@ -169,15 +191,22 @@ class Banner extends Component { [`banner-variant-${variant}`]: variant, "visible-banner": state === "entered" })} + customColors={this.isCustomVariant() && customColors} > {this.renderIcon()} - + {heading} - + {this.renderControl()}
- {content} + + {content} +
{this.renderCloseButton()}