From 8e04c823077ee6a3c843f1e80d8a9f7f89211b35 Mon Sep 17 00:00:00 2001 From: Dave Falke Date: Fri, 15 Nov 2024 14:49:54 -0500 Subject: [PATCH 1/5] Add NoteBox component --- .../src/components/containers/NoteBox.tsx | 47 +++++++++++++++++++ packages/libs/coreui/src/index.ts | 1 + 2 files changed, 48 insertions(+) create mode 100644 packages/libs/coreui/src/components/containers/NoteBox.tsx diff --git a/packages/libs/coreui/src/components/containers/NoteBox.tsx b/packages/libs/coreui/src/components/containers/NoteBox.tsx new file mode 100644 index 0000000000..1d2aaedf18 --- /dev/null +++ b/packages/libs/coreui/src/components/containers/NoteBox.tsx @@ -0,0 +1,47 @@ +import { css } from '@emotion/react'; +import React, { ReactNode } from 'react'; +import { error, warning, mutedBlue } from '../../definitions/colors'; + +export interface Props { + type: 'info' | 'warning' | 'error'; + children: ReactNode; +} + +const baseCss = css` + border-left: 0.25em solid var(--note-box-border-color); + border-radius: 0.25em; + padding: 0.5em 1em; + background: var(--note-box-bg-color); + gap: 1em; + margin-bottom: 1em; +`; + +const infoCss = css` + --note-box-bg-color: ${mutedBlue[100]}; + --note-box-border-color: ${mutedBlue[600]}; + ${baseCss}; +`; + +const warningCss = css` + --note-box-bg-color: ${warning[100]}; + --note-box-border-color: ${warning[600]}; + font-weight: 500; + ${baseCss}; +`; + +const errorCss = css` + --note-box-bg-color: ${error[100]}; + --note-box-border-color: ${error[600]}; + font-weight: 500; + ${baseCss}; +`; + +export function NoteBox(props: Props) { + const finalCss = + props.type === 'warning' + ? warningCss + : props.type === 'error' + ? errorCss + : infoCss; + return
{props.children}
; +} diff --git a/packages/libs/coreui/src/index.ts b/packages/libs/coreui/src/index.ts index 3dca9af1b5..a4cb9293e9 100644 --- a/packages/libs/coreui/src/index.ts +++ b/packages/libs/coreui/src/index.ts @@ -30,6 +30,7 @@ export { default as SelectTree } from './components/inputs/SelectTree/SelectTree export { default as SearchBox } from './components/inputs/SearchBox/SearchBox'; export { default as CheckboxList } from './components/inputs/checkboxes/CheckboxList'; export { default as CheckboxTree } from './components/inputs/checkboxes/CheckboxTree/CheckboxTree'; +export { NoteBox } from './components/containers/NoteBox'; export { default as styles } from './styleDefinitions'; export { default as colors } from './definitions/colors'; From 8c7ffcccc761be7f3ce451c2a9a1d3e37be5b976 Mon Sep 17 00:00:00 2001 From: Dave Falke Date: Fri, 15 Nov 2024 14:50:12 -0500 Subject: [PATCH 2/5] Use NoteBox component, and fix overflow detection --- .../RecordTable/RecordTableDescription.jsx | 40 +++++++++---------- .../js/client/records/Sequences.tsx | 19 +-------- 2 files changed, 21 insertions(+), 38 deletions(-) diff --git a/packages/libs/wdk-client/src/Views/Records/RecordTable/RecordTableDescription.jsx b/packages/libs/wdk-client/src/Views/Records/RecordTable/RecordTableDescription.jsx index 2351870a9b..d48f81183a 100644 --- a/packages/libs/wdk-client/src/Views/Records/RecordTable/RecordTableDescription.jsx +++ b/packages/libs/wdk-client/src/Views/Records/RecordTable/RecordTableDescription.jsx @@ -1,17 +1,7 @@ import PropTypes from 'prop-types'; import React, { useState } from 'react'; import { safeHtml, wrappable } from '../../../Utils/ComponentUtils'; - -const containerStyle = { - display: 'flex', - flexWrap: 'wrap', - borderLeft: '.2em solid #79a3d7', - borderRight: '.2em solid #79a3d7', - padding: '.5em 1em', - background: '#ebf4ff', - gap: '1em', - marginBottom: '1em', -}; +import { NoteBox } from '@veupathdb/coreui'; function RecordTableDescription(props) { const { description } = props.table; @@ -21,7 +11,7 @@ function RecordTableDescription(props) { if (!description) return null; return ( -
+ {safeHtml( description, { @@ -30,7 +20,7 @@ function RecordTableDescription(props) { return; } if ( - el.clientWidth >= el.scrollWidth || + el.clientWidth >= el.scrollWidth && el.clientHeight >= el.scrollHeight ) { setIsOverflowing(false); @@ -51,15 +41,23 @@ function RecordTableDescription(props) { 'div' )} {isOverflowing && ( - + <> + + )} -
+ ); } diff --git a/packages/sites/ortho-site/webapp/wdkCustomization/js/client/records/Sequences.tsx b/packages/sites/ortho-site/webapp/wdkCustomization/js/client/records/Sequences.tsx index 1efea4f282..48ea0f26a5 100644 --- a/packages/sites/ortho-site/webapp/wdkCustomization/js/client/records/Sequences.tsx +++ b/packages/sites/ortho-site/webapp/wdkCustomization/js/client/records/Sequences.tsx @@ -31,6 +31,7 @@ import { PfamDomain } from 'ortho-client/components/pfam-domains/PfamDomain'; import { FilledButton, FloatingButton, + NoteBox, OutlinedButton, SelectList, Undo, @@ -662,23 +663,7 @@ export function RecordTable_Sequences( } as CSSProperties } > - {warningText && ( -
- {warningText} -
- )} + {warningText && {warningText}}
Date: Fri, 15 Nov 2024 15:29:55 -0500 Subject: [PATCH 3/5] Add story for NoteBox --- .../stories/containers/NoteBox.stories.tsx | 74 +++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 packages/libs/coreui/src/stories/containers/NoteBox.stories.tsx diff --git a/packages/libs/coreui/src/stories/containers/NoteBox.stories.tsx b/packages/libs/coreui/src/stories/containers/NoteBox.stories.tsx new file mode 100644 index 0000000000..412631fbd6 --- /dev/null +++ b/packages/libs/coreui/src/stories/containers/NoteBox.stories.tsx @@ -0,0 +1,74 @@ +import React from 'react'; +import { NoteBox, Props } from '../../components/containers/NoteBox'; +import { Story, Meta } from '@storybook/react/types-6-0'; +import { UIThemeProvider } from '../../components/theming'; +import { mutedGreen, mutedMagenta } from '../../definitions/colors'; + +export default { + title: 'Containers/NoteBox', + component: NoteBox, +} as Meta; + +const Template: Story = function Template(props) { + return ( + + + + ); +}; + +export const Info = Object.assign(Template.bind({}), { + args: { + type: 'info', + children: ( +
+ This is some general information about the content that follows on the + page. +
+ ), + }, +}); + +export const Warning = Object.assign(Template.bind({}), { + args: { + type: 'warning', + children: ( +
This is a warning about the content that follows on the page.
+ ), + }, +}); + +export const Error = Object.assign(Template.bind({}), { + args: { + type: 'error', + children: ( +
+ This is an error message about the content that follows on the page. +
+ ), + }, +}); + +export const LongContent = Object.assign(Template.bind({}), { + args: { + type: 'info', + 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. +
+ ), + }, +}); From 7b84bdc7fadf994b1fe9c16632c60f9214125ea2 Mon Sep 17 00:00:00 2001 From: Dave Falke Date: Fri, 22 Nov 2024 13:13:31 -0500 Subject: [PATCH 4/5] Update variable name for clarity --- .../webapp/wdkCustomization/js/client/records/Sequences.tsx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/sites/ortho-site/webapp/wdkCustomization/js/client/records/Sequences.tsx b/packages/sites/ortho-site/webapp/wdkCustomization/js/client/records/Sequences.tsx index 48ea0f26a5..db2ed1a9c4 100644 --- a/packages/sites/ortho-site/webapp/wdkCustomization/js/client/records/Sequences.tsx +++ b/packages/sites/ortho-site/webapp/wdkCustomization/js/client/records/Sequences.tsx @@ -638,7 +638,7 @@ export function RecordTable_Sequences( if (filteredRows == null) return null; - const warningText = + const errorText = numSequences >= MIN_SEQUENCES_FOR_TREE && (filteredRows.length > MAX_SEQUENCES_FOR_TREE || filteredRows.length < MIN_SEQUENCES_FOR_TREE) ? ( @@ -663,7 +663,7 @@ export function RecordTable_Sequences( } as CSSProperties } > - {warningText && {warningText}} + {errorText && {errorText}}
Date: Fri, 22 Nov 2024 15:20:01 -0500 Subject: [PATCH 5/5] 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. +

+
+ ), + }, +});