From 8f1e79c04a042d57ddaf769e7c2d1ca23eb884f3 Mon Sep 17 00:00:00 2001 From: Dave Falke Date: Fri, 22 Nov 2024 15:20:01 -0500 Subject: [PATCH] Add support for icons to NoteBox. A part of this involved increasing padding and border-width to compensate for the additional space needed for the icon. --- .../src/components/containers/NoteBox.tsx | 30 ++++- .../stories/containers/NoteBox.stories.tsx | 110 +++++++++++++++--- 2 files changed, 123 insertions(+), 17 deletions(-) diff --git a/packages/libs/coreui/src/components/containers/NoteBox.tsx b/packages/libs/coreui/src/components/containers/NoteBox.tsx index 1d2aaedf18..86ccd763c2 100644 --- a/packages/libs/coreui/src/components/containers/NoteBox.tsx +++ b/packages/libs/coreui/src/components/containers/NoteBox.tsx @@ -1,19 +1,22 @@ import { css } from '@emotion/react'; import React, { ReactNode } from 'react'; import { error, warning, mutedBlue } from '../../definitions/colors'; +import { Error, Info, Warning } from '@material-ui/icons'; export interface Props { type: 'info' | 'warning' | 'error'; + showIcon?: boolean; children: ReactNode; } const baseCss = css` - border-left: 0.25em solid var(--note-box-border-color); + border-left: 0.35em solid var(--note-box-border-color); border-radius: 0.25em; - padding: 0.5em 1em; + padding: 1em 3em; background: var(--note-box-bg-color); gap: 1em; margin-bottom: 1em; + position: relative; `; const infoCss = css` @@ -36,6 +39,12 @@ const errorCss = css` ${baseCss}; `; +const iconCss = css` + position: absolute; + left: 0.5em; + font-size: 1.5em; +`; + export function NoteBox(props: Props) { const finalCss = props.type === 'warning' @@ -43,5 +52,20 @@ export function NoteBox(props: Props) { : props.type === 'error' ? errorCss : infoCss; - return
{props.children}
; + + const Icon = + props.showIcon === true + ? props.type === 'info' + ? Info + : props.type === 'warning' + ? Warning + : props.type === 'error' + ? Error + : null + : null; + return ( +
+ {Icon ? : null} {props.children} +
+ ); } diff --git a/packages/libs/coreui/src/stories/containers/NoteBox.stories.tsx b/packages/libs/coreui/src/stories/containers/NoteBox.stories.tsx index 412631fbd6..4f6ff41314 100644 --- a/packages/libs/coreui/src/stories/containers/NoteBox.stories.tsx +++ b/packages/libs/coreui/src/stories/containers/NoteBox.stories.tsx @@ -11,22 +11,25 @@ export default { const Template: Story = function Template(props) { return ( - - - +
+ + + +
); }; -export const Info = Object.assign(Template.bind({}), { +export const InfoWithoutIcon = Object.assign(Template.bind({}), { args: { type: 'info', + showIcon: false, children: (
This is some general information about the content that follows on the @@ -36,18 +39,20 @@ export const Info = Object.assign(Template.bind({}), { }, }); -export const Warning = Object.assign(Template.bind({}), { +export const WarningWithoutIcon = Object.assign(Template.bind({}), { args: { type: 'warning', + showIcon: false, children: (
This is a warning about the content that follows on the page.
), }, }); -export const Error = Object.assign(Template.bind({}), { +export const ErrorWithoutIcon = Object.assign(Template.bind({}), { args: { type: 'error', + showIcon: false, children: (
This is an error message about the content that follows on the page. @@ -56,9 +61,10 @@ export const Error = Object.assign(Template.bind({}), { }, }); -export const LongContent = Object.assign(Template.bind({}), { +export const LongContentWithoutIcon = Object.assign(Template.bind({}), { args: { type: 'info', + showIcon: false, children: (
Lorem ipsum odor amet, consectetuer adipiscing elit. Faucibus morbi ac @@ -72,3 +78,79 @@ export const LongContent = Object.assign(Template.bind({}), { ), }, }); + +export const InfoWithIcon = Object.assign(Template.bind({}), { + args: { + type: 'info', + showIcon: true, + children: ( +
+ This is some general information about the content that follows on the + page. +
+ ), + }, +}); + +export const WarningWithIcon = Object.assign(Template.bind({}), { + args: { + type: 'warning', + showIcon: true, + children: ( +
This is a warning about the content that follows on the page.
+ ), + }, +}); + +export const ErrorWithIcon = Object.assign(Template.bind({}), { + args: { + type: 'error', + showIcon: true, + children: ( +
+ This is an error message about the content that follows on the page. +
+ ), + }, +}); + +export const LongContentWithIcon = Object.assign(Template.bind({}), { + args: { + type: 'info', + showIcon: true, + children: ( +
+ Lorem ipsum odor amet, consectetuer adipiscing elit. Faucibus morbi ac + ultrices purus urna tristique mattis consequat. Posuere volutpat + facilisi natoque dictumst dignissim magna dapibus. Taciti vel a etiam + curabitur velit torquent. Fusce interdum dictum vulputate sollicitudin + nulla. Orci placerat congue odio aptent enim mauris. Turpis nec rhoncus + eleifend eleifend eget. Auctor sed nullam vestibulum quisque egestas; + nullam aenean ante. +
+ ), + }, +}); + +export const ExpandableContentWithIcon = Object.assign(Template.bind({}), { + args: { + type: 'info', + showIcon: true, + children: ( +
+ + There are some interesting things about this... + +

+ Lorem ipsum odor amet, consectetuer adipiscing elit. Faucibus morbi ac + ultrices purus urna tristique mattis consequat. Posuere volutpat + facilisi natoque dictumst dignissim magna dapibus. Taciti vel a etiam + curabitur velit torquent. Fusce interdum dictum vulputate sollicitudin + nulla. Orci placerat congue odio aptent enim mauris. Turpis nec + rhoncus eleifend eleifend eget. Auctor sed nullam vestibulum quisque + egestas; nullam aenean ante. +

+
+ ), + }, +});