From 364d457ed4e5d77032da0b142a5c61ecb8ceb568 Mon Sep 17 00:00:00 2001 From: koji Date: Mon, 30 Sep 2024 14:24:39 -0400 Subject: [PATCH 1/9] fix(protocol-designer, components): fix text-wrap issue in PD fix text-wrap issue in PD close RQA- --- .../ListItemChildren/ListItemDescriptor.tsx | 4 +++- components/src/molecules/DropdownMenu/index.tsx | 14 ++++++++++---- .../src/pages/ProtocolOverview/index.tsx | 6 +++++- 3 files changed, 18 insertions(+), 6 deletions(-) diff --git a/components/src/atoms/ListItem/ListItemChildren/ListItemDescriptor.tsx b/components/src/atoms/ListItem/ListItemChildren/ListItemDescriptor.tsx index 7560bf25e5e..75edad88385 100644 --- a/components/src/atoms/ListItem/ListItemChildren/ListItemDescriptor.tsx +++ b/components/src/atoms/ListItem/ListItemChildren/ListItemDescriptor.tsx @@ -36,7 +36,9 @@ export const ListItemDescriptor = ( > {description} - {content} + + {content} + ) } diff --git a/components/src/molecules/DropdownMenu/index.tsx b/components/src/molecules/DropdownMenu/index.tsx index d82aa20b4f8..aecc3591156 100644 --- a/components/src/molecules/DropdownMenu/index.tsx +++ b/components/src/molecules/DropdownMenu/index.tsx @@ -235,12 +235,9 @@ export function DropdownMenu(props: DropdownMenuProps): JSX.Element { font-weight: ${dropdownType === 'rounded' ? TYPOGRAPHY.pSemiBold : TYPOGRAPHY.pRegular}; - white-space: ${NO_WRAP}; - overflow: ${OVERFLOW_HIDDEN}; - text-overflow: ellipsis; `} > - + {currentOption.name} @@ -311,3 +308,12 @@ export function DropdownMenu(props: DropdownMenuProps): JSX.Element { ) } + +const MENU_TEXT_STYLE = css` + display: -webkit-box; + -webkit-box-orient: vertical; + overflow: hidden; + text-overflow: ellipsis; + word-wrap: break-word; + -webkit-line-clamp: 1; +` diff --git a/protocol-designer/src/pages/ProtocolOverview/index.tsx b/protocol-designer/src/pages/ProtocolOverview/index.tsx index 92c2ec27724..a5243bd5f1f 100644 --- a/protocol-designer/src/pages/ProtocolOverview/index.tsx +++ b/protocol-designer/src/pages/ProtocolOverview/index.tsx @@ -469,7 +469,11 @@ export function ProtocolOverview(): JSX.Element { gridGap={SPACING.spacing8} > - + {liquid.name} From def2d39e59d6f9ef87320584b73a08443f261df6 Mon Sep 17 00:00:00 2001 From: koji Date: Mon, 30 Sep 2024 14:51:56 -0400 Subject: [PATCH 2/9] fix lint errors --- .../src/molecules/DropdownMenu/index.tsx | 3 +- .../ProtocolOverview/LiquidDefinitions.tsx | 71 +++++++++++++++++++ .../__tests__/ProtocolOverview.test.tsx | 8 ++- .../src/pages/ProtocolOverview/index.tsx | 43 ++--------- 4 files changed, 83 insertions(+), 42 deletions(-) create mode 100644 protocol-designer/src/pages/ProtocolOverview/LiquidDefinitions.tsx diff --git a/components/src/molecules/DropdownMenu/index.tsx b/components/src/molecules/DropdownMenu/index.tsx index aecc3591156..30a02209121 100644 --- a/components/src/molecules/DropdownMenu/index.tsx +++ b/components/src/molecules/DropdownMenu/index.tsx @@ -9,7 +9,6 @@ import { DIRECTION_COLUMN, DIRECTION_ROW, JUSTIFY_SPACE_BETWEEN, - NO_WRAP, OVERFLOW_AUTO, OVERFLOW_HIDDEN, POSITION_ABSOLUTE, @@ -312,7 +311,7 @@ export function DropdownMenu(props: DropdownMenuProps): JSX.Element { const MENU_TEXT_STYLE = css` display: -webkit-box; -webkit-box-orient: vertical; - overflow: hidden; + overflow: ${OVERFLOW_HIDDEN}; text-overflow: ellipsis; word-wrap: break-word; -webkit-line-clamp: 1; diff --git a/protocol-designer/src/pages/ProtocolOverview/LiquidDefinitions.tsx b/protocol-designer/src/pages/ProtocolOverview/LiquidDefinitions.tsx new file mode 100644 index 00000000000..03c274ce104 --- /dev/null +++ b/protocol-designer/src/pages/ProtocolOverview/LiquidDefinitions.tsx @@ -0,0 +1,71 @@ +import { useTranslation } from 'react-i18next' +import { css } from 'styled-components' +import { + ALIGN_CENTER, + DIRECTION_COLUMN, + Flex, + InfoScreen, + LiquidIcon, + ListItem, + ListItemDescriptor, + OVERFLOW_HIDDEN, + SPACING, + StyledText, +} from '@opentrons/components' + +import type { AllIngredGroupFields } from '../../labware-ingred/types' + +interface LiquidDefinitionsProps { + allIngredientGroupFields: AllIngredGroupFields +} + +export function LiquidDefinitions({ + allIngredientGroupFields, +}: LiquidDefinitionsProps): JSX.Element { + const { t } = useTranslation('protocol_overview') + return ( + + + {t('liquid_defs')} + + + {Object.keys(allIngredientGroupFields).length > 0 ? ( + Object.values(allIngredientGroupFields).map((liquid, index) => ( + + + + + {liquid.name} + + + } + content={liquid.description ?? t('na')} + /> + + )) + ) : ( + + )} + + + ) +} + +const LIQUID_DEFINITION_TEXT = css` + display: -webkit-box; + -webkit-box-orient: vertical; + -webkit-line-clamp: 3; + overflow: ${OVERFLOW_HIDDEN}; + text-overflow: ellipsis; +` diff --git a/protocol-designer/src/pages/ProtocolOverview/__tests__/ProtocolOverview.test.tsx b/protocol-designer/src/pages/ProtocolOverview/__tests__/ProtocolOverview.test.tsx index e77515eaba0..471898802f6 100644 --- a/protocol-designer/src/pages/ProtocolOverview/__tests__/ProtocolOverview.test.tsx +++ b/protocol-designer/src/pages/ProtocolOverview/__tests__/ProtocolOverview.test.tsx @@ -16,6 +16,7 @@ import { selectors as labwareIngredSelectors } from '../../../labware-ingred/sel import { ProtocolOverview } from '../index' import { DeckThumbnail } from '../DeckThumbnail' import { OffDeckThumbnail } from '../OffdeckThumbnail' +import { LiquidDefinitions } from '../LiquidDefinitions' import type { NavigateFunction } from 'react-router-dom' @@ -27,6 +28,8 @@ vi.mock('../../../organisms/MaterialsListModal') vi.mock('../../../labware-ingred/selectors') vi.mock('../../../organisms') vi.mock('../../../labware-ingred/selectors') +vi.mock('../LiquidDefinitions') + const mockNavigate = vi.fn() vi.mock('react-router-dom', async importOriginal => { @@ -72,6 +75,9 @@ describe('ProtocolOverview', () => { vi.mocked(OffDeckThumbnail).mockReturnValue(
mock OffdeckThumbnail
) + vi.mocked(LiquidDefinitions).mockReturnValue( +
mock LiquidDefinitions
+ ) }) it('renders each section with text', () => { @@ -101,7 +107,7 @@ describe('ProtocolOverview', () => { screen.getByText('Right pipette') screen.getByText('Extension mount') // liquids - screen.getByText('Liquid Definitions') + screen.getByText('mock LiquidDefinitions') // steps screen.getByText('Protocol steps') }) diff --git a/protocol-designer/src/pages/ProtocolOverview/index.tsx b/protocol-designer/src/pages/ProtocolOverview/index.tsx index a5243bd5f1f..eba7ecbbb8e 100644 --- a/protocol-designer/src/pages/ProtocolOverview/index.tsx +++ b/protocol-designer/src/pages/ProtocolOverview/index.tsx @@ -58,6 +58,7 @@ import { import { DeckThumbnail } from './DeckThumbnail' import { OffDeckThumbnail } from './OffdeckThumbnail' import { getWarningContent } from './UnusedModalContent' +import { LiquidDefinitions } from './LiquidDefinitions' import type { CreateCommand, PipetteName } from '@opentrons/shared-data' import type { DeckSlot } from '@opentrons/step-generation' @@ -449,45 +450,9 @@ export function ProtocolOverview(): JSX.Element { ) : null} - - - {t('liquid_defs')} - - - {Object.keys(allIngredientGroupFields).length > 0 ? ( - Object.values(allIngredientGroupFields).map( - (liquid, index) => ( - - - - - {liquid.name} - - - } - content={liquid.description ?? t('na')} - /> - - ) - ) - ) : ( - - )} - - + From d5d6d03982b58b1ba61b79a6ffff766f70bed584 Mon Sep 17 00:00:00 2001 From: koji Date: Mon, 30 Sep 2024 15:13:10 -0400 Subject: [PATCH 3/9] export liquid definitions and add its tests --- .../__tests__/LiquidDefinitions.test.tsx | 78 +++++++++++++++++++ .../src/pages/ProtocolOverview/index.tsx | 8 +- 2 files changed, 84 insertions(+), 2 deletions(-) create mode 100644 protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx diff --git a/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx b/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx new file mode 100644 index 00000000000..53b86445c38 --- /dev/null +++ b/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx @@ -0,0 +1,78 @@ +import { describe, it, vi, beforeEach, expect } from 'vitest' +import { screen } from '@testing-library/react' + +import { InfoScreen } from '@opentrons/components' +import { renderWithProviders } from '../../../__testing-utils__' +import { i18n } from '../../../assets/localization' +import { LiquidDefinitions } from '../LiquidDefinitions' + +import type { ComponentProps } from 'react' + +vi.mock('@opentrons/components', async importOriginal => { + const actual = await importOriginal() + return { + ...actual, + InfoScreen: () =>
mock InfoScreen
, + } +}) + +const mockAllIngredientGroupFields = { + '0': { + name: 'EtOH', + displayColor: '#b925ff', + description: 'Immer fisch Hergestllter EtOH', + serialize: false, + liquidGroupId: '0', + }, + '1': { + name: '10mM Tris pH8,5', + displayColor: '#ffd600', + description: null, + serialize: false, + liquidGroupId: '1', + }, + '2': { + name: 'Amplicon PCR sample + AMPure XP beads', + displayColor: '#9dffd8', + description: '25µl Amplicon PCR + 20 µl AMPure XP beads', + serialize: false, + liquidGroupId: '2', + }, +} + +const render = (props: ComponentProps) => { + return renderWithProviders(, { + i18nInstance: i18n, + }) +} + +describe('LiquidDefinitions', () => { + let props: ComponentProps + + beforeEach(() => { + props = { + allIngredientGroupFields: {}, + } + }) + + it('should render text and InfoScreen if no liquid', () => { + render(props) + screen.getByText('Liquid Definitions') + screen.getByText('mock InfoScreen') + }) + + it('should render liquid information if there are liquids', () => { + props = { + allIngredientGroupFields: mockAllIngredientGroupFields, + } + render(props) + screen.getByText('EtOH') + screen.getByText('Immer fisch Hergestllter EtOH') + + screen.getByText('10mM Tris pH8,5') + screen.getByText('N/A') + + screen.getByText('Amplicon PCR sample + AMPure XP beads') + screen.getByText('25µl Amplicon PCR + 20 µl AMPure XP beads') + }) +}) diff --git a/protocol-designer/src/pages/ProtocolOverview/index.tsx b/protocol-designer/src/pages/ProtocolOverview/index.tsx index eba7ecbbb8e..ed03b886b60 100644 --- a/protocol-designer/src/pages/ProtocolOverview/index.tsx +++ b/protocol-designer/src/pages/ProtocolOverview/index.tsx @@ -1,3 +1,4 @@ +import { Fragment } from 'react' import { useState, useEffect } from 'react' import { useTranslation } from 'react-i18next' import { useNavigate } from 'react-router-dom' @@ -224,8 +225,11 @@ export function ProtocolOverview(): JSX.Element { const cancelModal = (): void => { setShowExportWarningModal(false) } + + console.log('obj', JSON.stringify(allIngredientGroupFields, null, 4)) + return ( - <> + {showEditMetadataModal ? ( { @@ -531,7 +535,7 @@ export function ProtocolOverview(): JSX.Element {
- + ) } From 8eb56d460dd7ee9527811baa3c587556093efbbb Mon Sep 17 00:00:00 2001 From: koji Date: Mon, 30 Sep 2024 15:46:10 -0400 Subject: [PATCH 4/9] align descriptor's alignment --- .../atoms/ListItem/ListItemChildren/ListItemDescriptor.tsx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/components/src/atoms/ListItem/ListItemChildren/ListItemDescriptor.tsx b/components/src/atoms/ListItem/ListItemChildren/ListItemDescriptor.tsx index 75edad88385..51d9ca9e181 100644 --- a/components/src/atoms/ListItem/ListItemChildren/ListItemDescriptor.tsx +++ b/components/src/atoms/ListItem/ListItemChildren/ListItemDescriptor.tsx @@ -1,6 +1,6 @@ import { Flex } from '../../../primitives' import { - ALIGN_CENTER, + ALIGN_FLEX_START, DIRECTION_ROW, FLEX_AUTO, JUSTIFY_SPACE_BETWEEN, @@ -22,7 +22,7 @@ export const ListItemDescriptor = ( flexDirection={DIRECTION_ROW} gridGap={SPACING.spacing8} width="100%" - alignItems={ALIGN_CENTER} + alignItems={ALIGN_FLEX_START} justifyContent={type === 'mini' ? JUSTIFY_SPACE_BETWEEN : 'none'} padding={ type === 'mini' From 6b454beaa4627484ef348a435ecc6737a53ca1fb Mon Sep 17 00:00:00 2001 From: koji Date: Mon, 30 Sep 2024 16:02:05 -0400 Subject: [PATCH 5/9] fix linting errors --- .../ProtocolOverview/__tests__/LiquidDefinitions.test.tsx | 2 +- protocol-designer/src/pages/ProtocolOverview/index.tsx | 4 +--- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx b/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx index 53b86445c38..903cccbef67 100644 --- a/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx +++ b/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx @@ -1,4 +1,4 @@ -import { describe, it, vi, beforeEach, expect } from 'vitest' +import { describe, it, vi, beforeEach } from 'vitest' import { screen } from '@testing-library/react' import { InfoScreen } from '@opentrons/components' diff --git a/protocol-designer/src/pages/ProtocolOverview/index.tsx b/protocol-designer/src/pages/ProtocolOverview/index.tsx index ed03b886b60..bb5cfa822ba 100644 --- a/protocol-designer/src/pages/ProtocolOverview/index.tsx +++ b/protocol-designer/src/pages/ProtocolOverview/index.tsx @@ -1,5 +1,4 @@ -import { Fragment } from 'react' -import { useState, useEffect } from 'react' +import { Fragment, useState, useEffect } from 'react' import { useTranslation } from 'react-i18next' import { useNavigate } from 'react-router-dom' import { useDispatch, useSelector } from 'react-redux' @@ -17,7 +16,6 @@ import { JUSTIFY_FLEX_END, JUSTIFY_SPACE_BETWEEN, LargeButton, - LiquidIcon, ListItem, ListItemDescriptor, Modal, From 073d9eb5d7f7e0d35dbecbd6d025277414598f97 Mon Sep 17 00:00:00 2001 From: koji Date: Mon, 30 Sep 2024 16:10:56 -0400 Subject: [PATCH 6/9] fix lint error --- .../ProtocolOverview/__tests__/LiquidDefinitions.test.tsx | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx b/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx index 903cccbef67..5f59721269b 100644 --- a/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx +++ b/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx @@ -1,3 +1,4 @@ +import type * as React from 'react' import { describe, it, vi, beforeEach } from 'vitest' import { screen } from '@testing-library/react' @@ -6,8 +7,6 @@ import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../assets/localization' import { LiquidDefinitions } from '../LiquidDefinitions' -import type { ComponentProps } from 'react' - vi.mock('@opentrons/components', async importOriginal => { const actual = await importOriginal() return { @@ -40,14 +39,14 @@ const mockAllIngredientGroupFields = { }, } -const render = (props: ComponentProps) => { +const render = (props: React.ComponentProps) => { return renderWithProviders(, { i18nInstance: i18n, }) } describe('LiquidDefinitions', () => { - let props: ComponentProps + let props: React.ComponentProps beforeEach(() => { props = { From 6b2331110eb454f4e31df22a42a543d4395d7428 Mon Sep 17 00:00:00 2001 From: koji Date: Mon, 30 Sep 2024 16:15:15 -0400 Subject: [PATCH 7/9] fix the last lint error --- .../__tests__/LiquidDefinitions.test.tsx | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx b/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx index 5f59721269b..33fa6214760 100644 --- a/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx +++ b/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx @@ -1,12 +1,13 @@ -import type * as React from 'react' import { describe, it, vi, beforeEach } from 'vitest' import { screen } from '@testing-library/react' -import { InfoScreen } from '@opentrons/components' import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../assets/localization' import { LiquidDefinitions } from '../LiquidDefinitions' +import { ComponentProps } from 'react' +import type { InfoScreen } from '@opentrons/components' + vi.mock('@opentrons/components', async importOriginal => { const actual = await importOriginal() return { @@ -39,14 +40,14 @@ const mockAllIngredientGroupFields = { }, } -const render = (props: React.ComponentProps) => { +const render = (props: ComponentProps) => { return renderWithProviders(, { i18nInstance: i18n, }) } describe('LiquidDefinitions', () => { - let props: React.ComponentProps + let props: ComponentProps beforeEach(() => { props = { From bfd9074d3d5f22447af11ab6e0a0033ac566e004 Mon Sep 17 00:00:00 2001 From: koji Date: Mon, 30 Sep 2024 16:17:16 -0400 Subject: [PATCH 8/9] Update LiquidDefinitions.test.tsx --- .../pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx b/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx index 33fa6214760..832cea4d800 100644 --- a/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx +++ b/protocol-designer/src/pages/ProtocolOverview/__tests__/LiquidDefinitions.test.tsx @@ -5,7 +5,7 @@ import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../assets/localization' import { LiquidDefinitions } from '../LiquidDefinitions' -import { ComponentProps } from 'react' +import type { ComponentProps } from 'react' import type { InfoScreen } from '@opentrons/components' vi.mock('@opentrons/components', async importOriginal => { From 69d38bf868dc42d28807f524db5c3be755abdc89 Mon Sep 17 00:00:00 2001 From: koji Date: Tue, 1 Oct 2024 09:42:23 -0400 Subject: [PATCH 9/9] remove console.log --- protocol-designer/src/pages/ProtocolOverview/index.tsx | 2 -- 1 file changed, 2 deletions(-) diff --git a/protocol-designer/src/pages/ProtocolOverview/index.tsx b/protocol-designer/src/pages/ProtocolOverview/index.tsx index bb5cfa822ba..0009f4cf624 100644 --- a/protocol-designer/src/pages/ProtocolOverview/index.tsx +++ b/protocol-designer/src/pages/ProtocolOverview/index.tsx @@ -224,8 +224,6 @@ export function ProtocolOverview(): JSX.Element { setShowExportWarningModal(false) } - console.log('obj', JSON.stringify(allIngredientGroupFields, null, 4)) - return ( {showEditMetadataModal ? (