Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

icon storybook document #942

Merged
merged 15 commits into from
Feb 28, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
122 changes: 96 additions & 26 deletions benefit-finder/src/App/__tests__/__snapshots__/index.spec.jsx.snap

Large diffs are not rendered by default.

32 changes: 28 additions & 4 deletions benefit-finder/src/shared/components/Button/index.jsx
Original file line number Diff line number Diff line change
@@ -1,17 +1,20 @@
import { useEffect, useState } from 'react'
import { useHandleClassName } from '../../hooks'
import { Icon } from '../index'
import Colors from '../../styles/colors/_index.js'
import PropTypes from 'prop-types'
import './_index.scss'

/**
* a functional component that renders a reactive button
* @component
* @param {React.ReactNode} children - inherited children
* @param {string} className - inherited class(es)
* @param {function} onClick - an inherited function, triggered on a click event
* @param {boolean} secondary - alternative display styles
* @param {boolean} disabled - disabled state
* @param {boolean} unstyled - appear as a link
* @param {function} onClick - an inherited function, triggered on a click event
* @param {string} type - 'button', 'reset', 'download'
* @param {string} icon - indicates which icon to include
* @return {html} returns a semantic html button element
*/

Expand All @@ -23,10 +26,27 @@ function Button({
disabled,
unstyled,
type,
icon,
}) {
const [defaultClasses, setDefaultClasses] = useState(null)
const style =
secondary === true ? 'secondary' : unstyled === true ? 'unstyled' : null
/**
* a state hook that contains that handles the synthetic hover value
* @return {boolean} current state of mouseOver/mouseLeave
*/
const [isHovered, setIsHovered] = useState(false)
/**
* a state hook that contains that handles the fill of our svg icons
* @return {string} current hex value
*/
const [hoverColor, setHoverColor] = useState()

useEffect(() => {
;(isHovered && secondary) || (isHovered && unstyled)
? setHoverColor(Colors.marine)
: setHoverColor(Colors.popBlue)
}, [isHovered])

useEffect(() => {
switch (style) {
Expand Down Expand Up @@ -61,7 +81,10 @@ function Button({
className,
defaultClasses,
})}
onMouseOver={() => setIsHovered(true)}
onMouseLeave={() => setIsHovered(false)}
>
{icon && <Icon type={icon} color={hoverColor} />}
{children}
</button>
)
Expand All @@ -70,11 +93,12 @@ function Button({
Button.propTypes = {
children: PropTypes.node,
className: PropTypes.string,
disabled: PropTypes.bool,
onClick: PropTypes.func,
secondary: PropTypes.bool,
disabled: PropTypes.bool,
unstyled: PropTypes.bool,
onClick: PropTypes.func,
type: PropTypes.oneOf(['button', 'reset', 'download']),
icon: PropTypes.string,
}

export default Button
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,24 @@ exports[`Email > renders a match to the previous snapshot 1`] = `
class="bf-email-button bf-usa-button usa-button bf-usa-button--outline usa-button--outline"
type="button"
>
<i
aria-hidden="true"
>
<svg
fill="none"
height="16"
viewBox="0 0 20 16"
width="20"
xmlns="http://www.w3.org/2000/svg"
>
<path
clip-rule="evenodd"
d="M18 0.000244141H2C0.9 0.000244141 0.00999999 0.900244 0.00999999 2.00024L0 14.0002C0 15.1002 0.9 16.0002 2 16.0002H18C19.1 16.0002 20 15.1002 20 14.0002V2.00024C20 0.900244 19.1 0.000244141 18 0.000244141ZM18 14.0002H2V4.00024L10 9.00024L18 4.00024V14.0002ZM10 7.00024L2 2.00024H18L10 7.00024Z"
fill="#005ea2"
fill-rule="evenodd"
/>
</svg>
</i>
Email
</button>
</DocumentFragment>
Expand Down
7 changes: 6 additions & 1 deletion benefit-finder/src/shared/components/EmailButton/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,12 @@ const EmailButton = ({ ui, data }) => {
}

return (
<Button className="bf-email-button" secondary onClick={handleClick}>
<Button
className="bf-email-button"
secondary
onClick={handleClick}
icon="email"
>
{ui?.emailButton || 'Email'}
</Button>
)
Expand Down
22 changes: 14 additions & 8 deletions benefit-finder/src/shared/components/Icon/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,28 +18,34 @@ const Icon = ({ type, color, ...props }) => {
icon = <Icons.CarrotSmall color={color} />
break
case 'carrot-big':
icon = <Icons.CarrotBig />
icon = <Icons.CarrotBig color={color} />
break
case 'death':
icon = <Icons.Death />
icon = <Icons.Death color={color} />
break
case 'email':
icon = <Icons.Email color={color} />
break
case 'disability':
icon = <Icons.Disability />
icon = <Icons.Disability color={color} />
break
case 'close':
icon = <Icons.Close />
icon = <Icons.Close color={color} />
break
case 'green-check':
icon = <Icons.GreenCheck />
icon = <Icons.GreenCheck color={color} />
break
case 'open':
icon = <Icons.Open />
icon = <Icons.Open color={color} />
break
case 'modal-close':
icon = <Icons.ModalClose />
icon = <Icons.ModalClose color={color} />
break
case 'retirement':
icon = <Icons.Retirement />
icon = <Icons.Retirement color={color} />
break
case 'share':
icon = <Icons.Share color={color} />
break
default:
icon = null
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import Icon from './index.jsx'
export default {
component: Icon,
tags: ['autodocs'],
args: { type: 'retirement' },
}

export const Primary = {}
89 changes: 37 additions & 52 deletions benefit-finder/src/shared/components/Icon/index_icons.jsx
Original file line number Diff line number Diff line change
@@ -1,20 +1,6 @@
import Colors from '../../styles/colors/_index.js'

// export svg components in alpha order
// carrot-small
export const CarrotSmall = ({ color }) => (
<svg
className="bf-carrot-small"
xmlns="http://www.w3.org/2000/svg"
height="24"
viewBox="0 0 24 24"
width="24"
fill={color || Colors.white}
>
<path d="M0 0h24v24H0z" fill="none" />
<path d="M7 10l5 5 5-5z" />
</svg>
)

// carrot-big
export const CarrotBig = ({ color }) => (
Expand All @@ -35,6 +21,21 @@ export const CarrotBig = ({ color }) => (
</svg>
)

// carrot-small
export const CarrotSmall = ({ color }) => (
<svg
className="bf-carrot-small"
xmlns="http://www.w3.org/2000/svg"
height="24"
viewBox="0 0 24 24"
width="24"
fill={color || Colors.white}
>
<path d="M0 0h24v24H0z" fill="none" />
<path d="M7 10l5 5 5-5z" />
</svg>
)

// close
export const Close = ({ color }) => (
<svg
Expand All @@ -50,35 +51,20 @@ export const Close = ({ color }) => (
)

// death
export const Death = () => (
export const Death = ({ color }) => (
<svg
className="bf-death"
width="223"
height="268"
viewBox="0 0 223 268"
fill="none"
xmlns="http://www.w3.org/2000/svg"
width="49"
height="60"
viewBox="0 0 49 60"
fill="none"
>
<rect width="223" height="268" fill="url(#pattern0)" />
<defs>
<pattern
id="pattern0"
patternContentUnits="objectBoundingBox"
width="1"
height="1"
>
<use
xlinkHref="#image0_2519_15995"
transform="scale(0.0044843 0.00373134)"
/>
</pattern>
<image
id="image0_2519_15995"
width="223"
height="268"
xlinkHref=""
/>
</defs>
<path
fillRule="evenodd"
clipRule="evenodd"
d="M19.5995 7.05571C19.5995 10.6762 16.6742 13.6109 13.066 13.6109C9.45779 13.6109 6.53305 10.6762 6.53305 7.05571C6.53305 3.43523 9.45779 0.5 13.066 0.5C16.6742 0.5 19.5995 3.43523 19.5995 7.05571ZM3.26573 16.889H22.4163L23.3247 17.6484L32.2164 25.0832H45.7335L49 44.7498H44.1V59.4997H37.5665V39.8332H40.8335L39.8541 33.937L39.5101 31.6389H39.4724L39.2 29.9999H27.7665L20.0507 23.4442H9.48934L8.50934 33.2774H11.4335V59.5H4.9V39.8334H0L3.26573 16.889ZM21.2333 33.2769H14.6998V59.4994H21.2333V33.2769ZM27.7663 33.2769H34.2998V59.4994H27.7663V33.2769ZM42.4663 15.2496C42.4663 18.8701 39.5416 21.8054 35.9333 21.8054C32.3251 21.8054 29.3998 18.8701 29.3998 15.2496C29.3998 11.6292 32.3251 8.69393 35.9333 8.69393C39.5416 8.69393 42.4663 11.6292 42.4663 15.2496Z"
fill={color || Colors.marine}
/>
</svg>
)

Expand All @@ -103,29 +89,28 @@ export const Email = ({ color }) => (
// disability
export const Disability = ({ color }) => (
<svg
className="bf-disability"
width="45"
height="58"
viewBox="0 0 45 58"
fill="none"
xmlns="http://www.w3.org/2000/svg"
width="34"
height="44"
viewBox="0 0 34 44"
fill="none"
>
<mask
id="mask0_2881_3177"
id="mask0_3578_3079"
maskUnits="userSpaceOnUse"
x="0"
y="0"
width="45"
height="58"
width="34"
height="44"
>
<path
d="M15.2503 27.9979V33.8312C10.4378 33.8312 6.50033 37.7688 6.50033 42.5813C6.50033 47.3938 10.4378 51.3312 15.2503 51.3312C20.0628 51.3312 24.0003 47.3938 24.0003 42.5813H29.8337C29.8337 50.6313 23.3003 57.1646 15.2503 57.1646C7.20033 57.1646 0.666992 50.6313 0.666992 42.5813C0.666992 34.5312 7.20033 27.9979 15.2503 27.9979ZM32.6337 13.4146C36.9503 13.4146 39.8087 17.7896 38.0295 21.6688L33.1587 32.3729H38.5837C41.792 32.3729 44.417 34.9979 44.417 38.2062V54.2479H38.5837V39.6646H24.0587C19.8003 39.6646 16.9128 35.0854 18.6628 31.2063L24.0003 19.2479H17.5545L15.6587 23.7104L10.0587 22.1646L12.0128 16.9146C12.9753 14.7854 15.1045 13.4146 17.467 13.4146H32.6337ZM38.5837 0.40625C41.8053 0.40625 44.417 3.01792 44.417 6.23958C44.417 9.46124 41.8053 12.0729 38.5837 12.0729C35.362 12.0729 32.7503 9.46124 32.7503 6.23958C32.7503 3.01792 35.362 0.40625 38.5837 0.40625Z"
fill={color || Colors.white}
d="M11.25 21.5001V26.0001C7.5375 26.0001 4.5 29.0376 4.5 32.7501C4.5 36.4626 7.5375 39.5001 11.25 39.5001C14.9625 39.5001 18 36.4626 18 32.7501H22.5C22.5 38.9601 17.46 44.0001 11.25 44.0001C5.04 44.0001 0 38.9601 0 32.7501C0 26.5401 5.04 21.5001 11.25 21.5001ZM24.66 10.2501C27.99 10.2501 30.195 13.6251 28.8225 16.6176L25.065 24.8751H29.25C31.725 24.8751 33.75 26.9001 33.75 29.3751V41.7501H29.25V30.5001H18.045C14.76 30.5001 12.5325 26.9676 13.8825 23.9751L18 14.7501H13.0275L11.565 18.1926L7.245 17.0001L8.7525 12.9501C9.495 11.3076 11.1375 10.2501 12.96 10.2501H24.66ZM29.25 0.215088C31.7353 0.215088 33.75 2.22981 33.75 4.71509C33.75 7.20037 31.7353 9.21509 29.25 9.21509C26.7647 9.21509 24.75 7.20037 24.75 4.71509C24.75 2.22981 26.7647 0.215088 29.25 0.215088Z"
fill="white"
/>
</mask>
<g mask="url(#mask0_2881_3177)">
<g mask="url(#mask0_3578_3079)">
<path
d="M15.2501 27.9979V33.8312C10.4376 33.8312 6.50008 37.7688 6.50008 42.5813C6.50008 47.3938 10.4376 51.3312 15.2501 51.3312C20.0626 51.3312 24.0001 47.3938 24.0001 42.5813H29.8334C29.8334 50.6313 23.3001 57.1646 15.2501 57.1646C7.20008 57.1646 0.666748 50.6313 0.666748 42.5813C0.666748 34.5312 7.20008 27.9979 15.2501 27.9979ZM32.6334 13.4146C36.9501 13.4146 39.8084 17.7896 38.0293 21.6688L33.1584 32.3729H38.5834C41.7918 32.3729 44.4168 34.9979 44.4168 38.2062V54.2479H38.5834V39.6646H24.0584C19.8001 39.6646 16.9126 35.0854 18.6626 31.2063L24.0001 19.2479H17.5543L15.6584 23.7104L10.0584 22.1646L12.0126 16.9146C12.9751 14.7854 15.1042 13.4146 17.4668 13.4146H32.6334ZM38.5834 0.40625C41.8051 0.40625 44.4168 3.01792 44.4168 6.23958C44.4168 9.46124 41.8051 12.0729 38.5834 12.0729C35.3618 12.0729 32.7501 9.46124 32.7501 6.23958C32.7501 3.01792 35.3618 0.40625 38.5834 0.40625Z"
d="M11.25 21.5001V26.0001C7.5375 26.0001 4.5 29.0376 4.5 32.7501C4.5 36.4626 7.5375 39.5001 11.25 39.5001C14.9625 39.5001 18 36.4626 18 32.7501H22.5C22.5 38.9601 17.46 44.0001 11.25 44.0001C5.04 44.0001 0 38.9601 0 32.7501C0 26.5401 5.04 21.5001 11.25 21.5001ZM24.66 10.2501C27.99 10.2501 30.195 13.6251 28.8225 16.6176L25.065 24.8751H29.25C31.725 24.8751 33.75 26.9001 33.75 29.3751V41.7501H29.25V30.5001H18.045C14.76 30.5001 12.5325 26.9676 13.8825 23.9751L18 14.7501H13.0275L11.565 18.1926L7.245 17.0001L8.7525 12.9501C9.495 11.3076 11.1375 10.2501 12.96 10.2501H24.66ZM29.25 0.215088C31.7353 0.215088 33.75 2.22981 33.75 4.71509C33.75 7.20037 31.7353 9.21509 29.25 9.21509C26.7647 9.21509 24.75 7.20037 24.75 4.71509C24.75 2.22981 26.7647 0.215088 29.25 0.215088Z"
fill={color || Colors.officerNavy}
/>
</g>
Expand Down
Loading
Loading