diff --git a/components/src/__tests__/utils.test.ts b/components/src/__tests__/utils.test.ts deleted file mode 100644 index bc1321a502e..00000000000 --- a/components/src/__tests__/utils.test.ts +++ /dev/null @@ -1,27 +0,0 @@ -import { describe, it, expect } from 'vitest' -import { truncateString } from '../utils' - -describe('truncateString', () => { - it('when an input string less than max length, return the original input', () => { - // Note (kj:05/03/2023) the max length and breakPoints are the same as what we use for the Desktop app - const str = 'opentrons-dev' - const result = truncateString(str, 80, 65) - expect(result).toEqual(str) - }) - - it('when an input string is more than 80 characters, return the truncated string', () => { - const str = `Lorem Ipsum Is Simply Dummy Text Of The Printing And Typesetting Industry. Lorem Ipsum Has Been The Industry's Standard Dummy Text Ever Since The 1500s, When An Unknown Printer Took A Galley Of Type And Scrambled It To Make A Type Specimen Book.Py` - const result = truncateString(str, 80, 65) - const truncatedStr = - 'Lorem Ipsum Is Simply Dummy Text Of The Printing And Typesetting ...imen Book.Py' - expect(result).toEqual(truncatedStr) - }) - - it('when an input string is more than 80 characters without specifying the break point, return the truncated string', () => { - const str = `Lorem Ipsum Is Simply Dummy Text Of The Printing And Typesetting Industry. Lorem Ipsum Has Been The Industry's Standard Dummy Text Ever Since The 1500s, When An Unknown Printer Took A Galley Of Type And Scrambled It To Make A Type Specimen Book.Py` - const result = truncateString(str, 80) - const truncatedStr = - 'Lorem Ipsum Is Simply Dummy Text Of The Printing And Typesetting Industry. Lo...' - expect(result).toEqual(truncatedStr) - }) -}) diff --git a/components/src/alerts/alerts.module.css b/components/src/alerts/alerts.module.css deleted file mode 100644 index 4927ad5eb7a..00000000000 --- a/components/src/alerts/alerts.module.css +++ /dev/null @@ -1,103 +0,0 @@ -@import '../index.module.css'; - -.alert { - font-size: var(--fs-body-2); - font-weight: var(--fw-regular); -} - -.alert:not(:first-of-type) { - border-top: none; -} - -.title_bar { - display: flex; - flex-direction: row; - justify-content: space-between; - align-items: center; - padding: 0.5rem 1rem; - font-weight: var(--fw-semibold); -} - -.title { - width: 100%; -} - -.success { - border: 1px solid var(--c-success); - - & > .title_bar { - background-color: var(--c-bg-success); - color: var(--c-success); - - & svg { - color: var(--c-success); - } - } -} - -.info { - border: 1px solid var(--c-highlight); - - & > .title_bar { - background-color: var(--c-bg-selected); - color: var(--c-selected-dark); - - & svg { - color: var(--c-highlight); - } - } -} - -.warning { - border: 1px solid var(--c-warning); - - & > .title_bar { - background-color: var(--c-warning-light); - color: var(--c-warning-dark); - - & svg { - fill: var(--c-warning); - } - } -} - -.error { - border: 1px solid var(--c-error); - - & > .title_bar { - background-color: var(--c-error-light); - color: var(--c-error-dark); - - & svg { - fill: var(--c-error); - } - } -} - -.message { - padding: 1rem 3rem; - background-color: white; - - & a { - text-decoration: underline; - color: inherit; - } - - &:empty { - padding: 0; - } -} - -.icon { - width: 1.5rem; - margin-right: 0.5rem; -} - -.close { - width: 2rem; - padding: 0.125rem; - - &:hover { - background-color: rgba(100, 100, 100, 0.1); - } -} diff --git a/components/src/atoms/Checkbox/__tests__/Checkbox.test.tsx b/components/src/atoms/Checkbox/__tests__/Checkbox.test.tsx deleted file mode 100644 index cfee4c22835..00000000000 --- a/components/src/atoms/Checkbox/__tests__/Checkbox.test.tsx +++ /dev/null @@ -1,55 +0,0 @@ -import type * as React from 'react' -import { describe, beforeEach, afterEach, vi, expect, it } from 'vitest' -import { fireEvent, screen } from '@testing-library/react' -import '@testing-library/jest-dom/vitest' -import { renderWithProviders } from '../../../testing/utils' -import { Checkbox } from '..' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('Checkbox', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - onClick: vi.fn(), - isChecked: false, - labelText: 'fake checkbox label', - tabIndex: 1, - disabled: false, - } - }) - - afterEach(() => { - vi.resetAllMocks() - }) - - it('renders label with disabled true', () => { - props.disabled = true - render(props) - const checkBoxInput = screen.getByRole('checkbox', { - name: 'fake checkbox label', - }) - expect(checkBoxInput).toBeDisabled() - }) - - it('renders label with correct style - tabIndex 1', () => { - props.tabIndex = 1 - render(props) - const checkBoxInput = screen.getByRole('checkbox', { - name: 'fake checkbox label', - }) - expect(checkBoxInput).toHaveAttribute('tabindex', '1') - }) - - it('calls mock function when clicking checkbox', () => { - render(props) - const checkBoxInput = screen.getByRole('checkbox', { - name: 'fake checkbox label', - }) - fireEvent.click(checkBoxInput) - expect(props.onClick).toHaveBeenCalled() - }) -}) diff --git a/components/src/atoms/CheckboxField/__tests__/CheckboxField.test.tsx b/components/src/atoms/CheckboxField/__tests__/CheckboxField.test.tsx deleted file mode 100644 index 06fc3153d9e..00000000000 --- a/components/src/atoms/CheckboxField/__tests__/CheckboxField.test.tsx +++ /dev/null @@ -1,141 +0,0 @@ -import type * as React from 'react' -import { describe, beforeEach, afterEach, vi, expect, it } from 'vitest' -import { fireEvent, screen } from '@testing-library/react' -import '@testing-library/jest-dom/vitest' -import { ALIGN_CENTER, JUSTIFY_CENTER } from '../../../styles' -import { renderWithProviders } from '../../../testing/utils' -import { BORDERS, COLORS } from '../../../helix-design-system' -import { TYPOGRAPHY, SPACING } from '../../../ui-style-constants' -import { CheckboxField } from '..' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('CheckboxField', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - onChange: vi.fn(), - value: false, - name: 'mockCheckboxField', - label: 'checkMockCheckboxField', - disabled: false, - isIndeterminate: false, - } - }) - - afterEach(() => { - vi.resetAllMocks() - }) - - it('renders label with correct style', () => { - render(props) - const checkBoxInput = screen.getByRole('checkbox', { - name: 'checkMockCheckboxField', - }) - const checkBoxFieldBox = screen.getByText('checkMockCheckboxField') - const checkBoxIcon = screen.getByTestId('CheckboxField_icon') - - // INNER_STYLE_NO_VALUE - expect(checkBoxIcon).toHaveStyle(`width: 1.25rem`) - expect(checkBoxIcon).toHaveStyle(`min-width: 1.25rem`) - expect(checkBoxIcon).toHaveStyle(`color: ${String(COLORS.grey50)}`) - expect(checkBoxIcon).toHaveStyle(`display: flex`) - expect(checkBoxIcon).toHaveStyle( - `border-radius: ${String(BORDERS.borderRadius2)}` - ) - expect(checkBoxIcon).toHaveStyle( - `justify-content: ${String(JUSTIFY_CENTER)}` - ) - expect(checkBoxIcon).toHaveStyle(`align-items: ${String(ALIGN_CENTER)}`) - - // INPUT_STYLE - expect(checkBoxInput).toHaveStyle(`position: absolute`) - expect(checkBoxInput).toHaveStyle(`overflow: hidden`) - expect(checkBoxInput).toHaveStyle(`clip: rect(0 0 0 0)`) - expect(checkBoxInput).toHaveStyle(`height: 1px`) - expect(checkBoxInput).toHaveStyle(`width: 1px`) - expect(checkBoxInput).toHaveStyle(`margin: -1px`) - expect(checkBoxInput).toHaveStyle(`padding: 0`) - expect(checkBoxInput).toHaveStyle(`border: 0`) - expect(checkBoxInput).toHaveAttribute('tabindex', '0') - - // LABEL_TEXT_STYLE - expect(checkBoxFieldBox).toHaveStyle( - `font-size: ${String(TYPOGRAPHY.fontSizeP)}` - ) - expect(checkBoxFieldBox).toHaveStyle( - `font-weight: ${String(TYPOGRAPHY.fontWeightRegular)}` - ) - expect(checkBoxFieldBox).toHaveStyle(`color: ${String(COLORS.black90)}`) - expect(checkBoxFieldBox).toHaveStyle(`flex: 0 0 auto`) - expect(checkBoxFieldBox).toHaveStyle( - `padding: ${SPACING.spacing8} ${SPACING.spacing8}` - ) - }) - - it('render icon with correct style - value true', () => { - props.value = true - render(props) - const checkBoxIcon = screen.getByTestId('CheckboxField_icon') - expect(checkBoxIcon).toHaveStyle(`width: 1.25rem`) - expect(checkBoxIcon).toHaveStyle(`min-width: 1.25rem`) - expect(checkBoxIcon).toHaveStyle(`color: ${String(COLORS.blue50)}`) - expect(checkBoxIcon).toHaveStyle(`display: flex`) - expect(checkBoxIcon).toHaveStyle( - `border-radius: ${String(BORDERS.borderRadius2)}` - ) - expect(checkBoxIcon).toHaveStyle( - `justify-content: ${String(JUSTIFY_CENTER)}` - ) - expect(checkBoxIcon).toHaveStyle(`align-items: ${String(ALIGN_CENTER)}`) - }) - - it('renders label with correct style - value undefined', () => { - props.value = undefined - render(props) - const checkBoxIcon = screen.getByTestId('CheckboxField_icon') - expect(checkBoxIcon).toHaveStyle(`width: 1.25rem`) - expect(checkBoxIcon).toHaveStyle(`min-width: 1.25rem`) - expect(checkBoxIcon).toHaveStyle(`color: ${String(COLORS.grey50)}`) - expect(checkBoxIcon).toHaveStyle(`display: flex`) - expect(checkBoxIcon).toHaveStyle( - `border-radius: ${String(BORDERS.borderRadius2)}` - ) - expect(checkBoxIcon).toHaveStyle( - `justify-content: ${String(JUSTIFY_CENTER)}` - ) - expect(checkBoxIcon).toHaveStyle(`align-items: ${String(ALIGN_CENTER)}`) - }) - - it('renders label with correct style - disabled true', () => { - props.disabled = true - render(props) - const checkBoxInput = screen.getByRole('checkbox', { - name: 'checkMockCheckboxField', - }) - expect(checkBoxInput).toBeDisabled() - }) - - it('renders label with correct style - tabIndex 1', () => { - props.tabIndex = 1 - render(props) - const checkBoxInput = screen.getByRole('checkbox', { - name: 'checkMockCheckboxField', - }) - const checkBoxFieldBox = screen.getByText('checkMockCheckboxField') - expect(checkBoxInput).toHaveAttribute('tabindex', '1') - expect(checkBoxFieldBox).toHaveAttribute('tabindex', '1') - }) - - it('calls mock function when clicking checkboxfield', () => { - render(props) - const checkBoxInput = screen.getByRole('checkbox', { - name: 'checkMockCheckboxField', - }) - fireEvent.click(checkBoxInput) - expect(props.onChange).toHaveBeenCalled() - }) -}) diff --git a/components/src/atoms/Chip/__tests__/Chip.test.tsx b/components/src/atoms/Chip/__tests__/Chip.test.tsx deleted file mode 100644 index 65de215160f..00000000000 --- a/components/src/atoms/Chip/__tests__/Chip.test.tsx +++ /dev/null @@ -1,429 +0,0 @@ -import type * as React from 'react' -import { describe, it, expect, beforeEach } from 'vitest' -import { screen } from '@testing-library/react' -import { BORDERS, COLORS } from '../../../helix-design-system' -import { SPACING } from '../../../ui-style-constants' -import { renderWithProviders } from '../../../testing/utils' -import { Chip } from '..' - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('Chip Touchscreen', () => { - let props: React.ComponentProps - - it('should render text, icon, bgcolor with success colors', () => { - props = { - text: 'mockSuccess', - type: 'success', - } - render(props) - const chip = screen.getByTestId('Chip_success') - const chipText = screen.getByText('mockSuccess') - expect(chip).toHaveStyle(`background-color: ${COLORS.green35}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.green60}`) - const icon = screen.getByLabelText('icon_mockSuccess') - expect(icon).toHaveStyle(`color: ${COLORS.green60}`) - // ToDo (kk:03/28/2024) seems that jsdom doesn't support switching via media query - // I will keep investigating this - // expect(icon).toHaveStyle(`width: 1.5rem`) - }) - - it('should render text, icon, no bgcolor with success colors and bg false', () => { - props = { - background: false, - text: 'mockSuccess', - type: 'success', - } - render(props) - const chip = screen.getByTestId('Chip_success') - const chipText = screen.getByText('mockSuccess') - expect(chip).toHaveStyle(`background-color: ${COLORS.transparent}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.green60}`) - const icon = screen.getByLabelText('icon_mockSuccess') - expect(icon).toHaveStyle(`color: ${COLORS.green60}`) - }) - - it('should render text, icon, bgcolor with warning colors', () => { - props = { - text: 'mockWarning', - type: 'warning', - } - render(props) - const chip = screen.getByTestId('Chip_warning') - const chipText = screen.getByText('mockWarning') - expect(chip).toHaveStyle(`background-color: ${COLORS.yellow35}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.yellow60}`) - const icon = screen.getByLabelText('icon_mockWarning') - expect(icon).toHaveStyle(`color: ${COLORS.yellow60}`) - }) - - it('should render text, icon, no bgcolor with warning colors and bg false', () => { - props = { - background: false, - text: 'mockWarning', - type: 'warning', - } - render(props) - const chip = screen.getByTestId('Chip_warning') - const chipText = screen.getByText('mockWarning') - expect(chip).toHaveStyle(`background-color: ${COLORS.transparent}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.yellow60}`) - const icon = screen.getByLabelText('icon_mockWarning') - expect(icon).toHaveStyle(`color: ${COLORS.yellow60}`) - }) - - it('should render text, icon, bgcolor with neutral colors', () => { - props = { - text: 'mockNeutral', - type: 'neutral', - } - render(props) - const chip = screen.getByTestId('Chip_neutral') - const chipText = screen.getByText('mockNeutral') - expect(chip).toHaveStyle( - `background-color: ${COLORS.black90}${COLORS.opacity20HexCode}` - ) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.grey60}`) - const icon = screen.getByLabelText('icon_mockNeutral') - expect(icon).toHaveStyle(`color: ${COLORS.grey60}`) - }) - - it('should render text, icon, no bgcolor with neutral colors and bg false', () => { - props = { - background: false, - text: 'mockNeutral', - type: 'neutral', - } - render(props) - const chip = screen.getByTestId('Chip_neutral') - const chipText = screen.getByText('mockNeutral') - expect(chip).toHaveStyle(`background-color: ${COLORS.transparent}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.grey60}`) - const icon = screen.getByLabelText('icon_mockNeutral') - expect(icon).toHaveStyle(`color: ${COLORS.grey60}`) - }) - - it('should render text, icon, bgcolor with error colors', () => { - props = { - text: 'mockError', - type: 'error', - } - render(props) - const chip = screen.getByTestId('Chip_error') - const chipText = screen.getByText('mockError') - expect(chip).toHaveStyle(`background-color: ${COLORS.red35}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.red60}`) - const icon = screen.getByLabelText('icon_mockError') - expect(icon).toHaveStyle(`color: ${COLORS.red60}`) - }) - - it('should render text, icon, no bgcolor with error colors and bg false', () => { - props = { - background: false, - text: 'mockError', - type: 'error', - } - render(props) - const chip = screen.getByTestId('Chip_error') - const chipText = screen.getByText('mockError') - expect(chip).toHaveStyle(`background-color: ${COLORS.transparent}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.red60}`) - const icon = screen.getByLabelText('icon_mockError') - expect(icon).toHaveStyle(`color: ${COLORS.red60}`) - }) - - it('should render text, icon, bgcolor with info colors', () => { - props = { - text: 'mockInfo', - type: 'info', - } - render(props) - const chip = screen.getByTestId('Chip_info') - const chipText = screen.getByText('mockInfo') - expect(chip).toHaveStyle(`background-color: ${COLORS.blue35}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.blue60}`) - const icon = screen.getByLabelText('icon_mockInfo') - expect(icon).toHaveStyle(`color: ${COLORS.blue60}`) - }) - - it('should render text, icon, no bgcolor with info colors and bg false', () => { - props = { - background: false, - text: 'mockInfo', - type: 'info', - } - render(props) - const chip = screen.getByTestId('Chip_info') - const chipText = screen.getByText('mockInfo') - expect(chip).toHaveStyle(`background-color: ${COLORS.transparent}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.blue60}`) - const icon = screen.getByLabelText('icon_mockInfo') - expect(icon).toHaveStyle(`color: ${COLORS.blue60}`) - }) - it('renders no icon when hasIcon is false', () => { - props = { - text: 'mockInfo', - hasIcon: false, - type: 'info', - } - render(props) - expect(screen.queryByText('icon_mockInfo')).not.toBeInTheDocument() - }) - - it('render text with smaller padding and smaller icon when chip size is small and background is false', () => { - props = { - background: false, - text: 'mockInfo', - type: 'info', - chipSize: 'small', - } - render(props) - const chip = screen.getByTestId('Chip_info') - expect(chip).toHaveStyle(`padding: ${SPACING.spacing4} 0`) - const icon = screen.getByLabelText('icon_mockInfo') - expect(icon).toHaveStyle(`width: 0.75rem`) - }) - - // ToDo (kk:03/28/2024) seems that jsdom doesn't support switching via media query - // I will keep investigating this - // it('render text with smaller padding and smaller icon when chip size is small and background is true', () => { - // props = { - // background: true, - // text: 'mockInfo', - // type: 'info', - // chipSize: 'small', - // } - // render(props) - // const chip = screen.getByTestId('Chip_info') - // expect(chip).toHaveStyle(`padding: ${SPACING.spacing4} ${SPACING.spacing8}`) - // const icon = screen.getByLabelText('icon_mockInfo') - // expect(icon).toHaveStyle(`width: 1.25rem`) - // }) -}) - -describe('Chip Web', () => { - let props: React.ComponentProps - - beforeEach(() => { - Object.defineProperty(window, 'innerWidth', { - writable: true, - configurable: true, - value: 1024, - }) - - Object.defineProperty(window, 'innerHeight', { - writable: true, - configurable: true, - value: 768, - }) - }) - it('should render text, icon, bgcolor with success colors', () => { - props = { - text: 'mockSuccess', - type: 'success', - } - render(props) - const chip = screen.getByTestId('Chip_success') - const chipText = screen.getByText('mockSuccess') - expect(chip).toHaveStyle(`background-color: ${COLORS.green35}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.green60}`) - // expect(chipText).toHaveStyle( - // `padding: ${SPACING.spacing2} ${SPACING.spacing8}` - // ) - const icon = screen.getByLabelText('icon_mockSuccess') - expect(icon).toHaveStyle(`color: ${COLORS.green60}`) - expect(icon).toHaveStyle(`width: 1rem`) - }) - - it('should render text, icon, no bgcolor with success colors and bg false', () => { - props = { - background: false, - text: 'mockSuccess', - type: 'success', - } - render(props) - const chip = screen.getByTestId('Chip_success') - const chipText = screen.getByText('mockSuccess') - expect(chip).toHaveStyle(`background-color: ${COLORS.transparent}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.green60}`) - const icon = screen.getByLabelText('icon_mockSuccess') - expect(icon).toHaveStyle(`color: ${COLORS.green60}`) - }) - - it('should render text, icon, bgcolor with warning colors', () => { - props = { - text: 'mockWarning', - type: 'warning', - } - render(props) - const chip = screen.getByTestId('Chip_warning') - const chipText = screen.getByText('mockWarning') - expect(chip).toHaveStyle(`background-color: ${COLORS.yellow35}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.yellow60}`) - const icon = screen.getByLabelText('icon_mockWarning') - expect(icon).toHaveStyle(`color: ${COLORS.yellow60}`) - }) - - it('should render text, icon, no bgcolor with warning colors and bg false', () => { - props = { - background: false, - text: 'mockWarning', - type: 'warning', - } - render(props) - const chip = screen.getByTestId('Chip_warning') - const chipText = screen.getByText('mockWarning') - expect(chip).toHaveStyle(`background-color: ${COLORS.transparent}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.yellow60}`) - const icon = screen.getByLabelText('icon_mockWarning') - expect(icon).toHaveStyle(`color: ${COLORS.yellow60}`) - }) - - it('should render text, icon, bgcolor with neutral colors', () => { - props = { - text: 'mockNeutral', - type: 'neutral', - } - render(props) - const chip = screen.getByTestId('Chip_neutral') - const chipText = screen.getByText('mockNeutral') - expect(chip).toHaveStyle( - `background-color: ${COLORS.black90}${COLORS.opacity20HexCode}` - ) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.grey60}`) - const icon = screen.getByLabelText('icon_mockNeutral') - expect(icon).toHaveStyle(`color: ${COLORS.grey60}`) - }) - - it('should render text, icon, no bgcolor with neutral colors and bg false', () => { - props = { - background: false, - text: 'mockNeutral', - type: 'neutral', - } - render(props) - const chip = screen.getByTestId('Chip_neutral') - const chipText = screen.getByText('mockNeutral') - expect(chip).toHaveStyle(`background-color: ${COLORS.transparent}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.grey60}`) - const icon = screen.getByLabelText('icon_mockNeutral') - expect(icon).toHaveStyle(`color: ${COLORS.grey60}`) - }) - - it('should render text, icon, bgcolor with error colors', () => { - props = { - text: 'mockError', - type: 'error', - } - render(props) - const chip = screen.getByTestId('Chip_error') - const chipText = screen.getByText('mockError') - expect(chip).toHaveStyle(`background-color: ${COLORS.red35}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.red60}`) - const icon = screen.getByLabelText('icon_mockError') - expect(icon).toHaveStyle(`color: ${COLORS.red60}`) - }) - - it('should render text, icon, no bgcolor with error colors and bg false', () => { - props = { - background: false, - text: 'mockError', - type: 'error', - } - render(props) - const chip = screen.getByTestId('Chip_error') - const chipText = screen.getByText('mockError') - expect(chip).toHaveStyle(`background-color: ${COLORS.transparent}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.red60}`) - const icon = screen.getByLabelText('icon_mockError') - expect(icon).toHaveStyle(`color: ${COLORS.red60}`) - }) - - it('should render text, icon, bgcolor with info colors', () => { - props = { - text: 'mockInfo', - type: 'info', - } - render(props) - const chip = screen.getByTestId('Chip_info') - const chipText = screen.getByText('mockInfo') - expect(chip).toHaveStyle(`background-color: ${COLORS.blue35}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.blue60}`) - const icon = screen.getByLabelText('icon_mockInfo') - expect(icon).toHaveStyle(`color: ${COLORS.blue60}`) - }) - - it('should render text, icon, no bgcolor with info colors and bg false', () => { - props = { - background: false, - text: 'mockInfo', - type: 'info', - } - render(props) - const chip = screen.getByTestId('Chip_info') - const chipText = screen.getByText('mockInfo') - expect(chip).toHaveStyle(`background-color: ${COLORS.transparent}`) - expect(chip).toHaveStyle(`border-radius: ${BORDERS.borderRadiusFull}`) - expect(chipText).toHaveStyle(`color: ${COLORS.blue60}`) - const icon = screen.getByLabelText('icon_mockInfo') - expect(icon).toHaveStyle(`color: ${COLORS.blue60}`) - }) - it('renders no icon when hasIcon is false', () => { - props = { - text: 'mockInfo', - hasIcon: false, - type: 'info', - } - render(props) - expect(screen.queryByText('icon_mockInfo')).not.toBeInTheDocument() - }) - - it('render text with smaller padding and smaller icon when chip size is small and background is false', () => { - props = { - background: false, - text: 'mockInfo', - type: 'info', - chipSize: 'small', - } - render(props) - const chip = screen.getByTestId('Chip_info') - expect(chip).toHaveStyle(`padding: ${SPACING.spacing4} 0`) - const icon = screen.getByLabelText('icon_mockInfo') - expect(icon).toHaveStyle(`width: 0.75rem`) - }) - - it('render text with smaller padding and smaller icon when chip size is small and background is true', () => { - props = { - background: true, - text: 'mockInfo', - type: 'info', - chipSize: 'small', - } - render(props) - const chip = screen.getByTestId('Chip_info') - expect(chip).toHaveStyle(`padding: ${SPACING.spacing4} ${SPACING.spacing6}`) - const icon = screen.getByLabelText('icon_mockInfo') - expect(icon).toHaveStyle(`width: 0.75rem`) - }) -}) diff --git a/components/src/atoms/InputField/__tests__/InputField.test.tsx b/components/src/atoms/InputField/__tests__/InputField.test.tsx deleted file mode 100644 index f53d4f4163a..00000000000 --- a/components/src/atoms/InputField/__tests__/InputField.test.tsx +++ /dev/null @@ -1,63 +0,0 @@ -import type * as React from 'react' -import { describe, it, vi, beforeEach, expect } from 'vitest' -import { screen, fireEvent } from '@testing-library/react' -import { renderWithProviders } from '../../../testing/utils' -import { InputField } from '..' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('HeaterShakerSlideout', () => { - let props: React.ComponentProps - beforeEach(() => { - props = { - type: 'number', - caption: 'caption', - max: 10, - min: 1, - units: 'rpm', - value: '5', - disabled: false, - onFocus: vi.fn(), - onBlur: vi.fn(), - onChange: vi.fn(), - readOnly: false, - autoFocus: false, - } - }) - it('renders correct information when type is number', () => { - render(props) - screen.getByText('caption') - screen.getByText('rpm') - }) - it('renders correct information when type is text', () => { - props = { - type: 'text', - value: 'string', - units: 'C', - onChange: vi.fn(), - } - render(props) - screen.getByText('C') - }) - it('renders error message when value is outside of number type range', () => { - props = { - type: 'number', - caption: 'caption', - max: 10, - min: 1, - units: 'rpm', - value: '9', - error: 'error', - onChange: vi.fn(), - id: 'input_id', - } - render(props) - const input = screen.getByTestId('input_id') - fireEvent.change(input, { target: { value: ['12'] } }) - expect(props.onChange).toHaveBeenCalled() - screen.getByText('caption') - screen.getByText('error') - }) -}) diff --git a/components/src/atoms/ListButton/__tests__/ListButton.test.tsx b/components/src/atoms/ListButton/__tests__/ListButton.test.tsx deleted file mode 100644 index e7ba460b5e2..00000000000 --- a/components/src/atoms/ListButton/__tests__/ListButton.test.tsx +++ /dev/null @@ -1,46 +0,0 @@ -import type * as React from 'react' -import { vi, describe, it, expect, beforeEach } from 'vitest' -import '@testing-library/jest-dom/vitest' -import { fireEvent, screen } from '@testing-library/react' -import { renderWithProviders } from '../../../testing/utils' -import { COLORS } from '../../../helix-design-system' - -import { ListButton } from '..' - -const render = (props: React.ComponentProps) => - renderWithProviders() - -describe('ListButton', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - type: 'noActive', - children:
mock ListButton content
, - onClick: vi.fn(), - } - }) - - it('should render correct style - noActive', () => { - render(props) - const listButton = screen.getByTestId('ListButton_noActive') - expect(listButton).toHaveStyle(`backgroundColor: ${COLORS.grey30}`) - }) - it('should render correct style - connected', () => { - props.type = 'connected' - render(props) - const listButton = screen.getByTestId('ListButton_connected') - expect(listButton).toHaveStyle(`backgroundColor: ${COLORS.green30}`) - }) - it('should render correct style - notConnected', () => { - props.type = 'notConnected' - render(props) - const listButton = screen.getByTestId('ListButton_notConnected') - expect(listButton).toHaveStyle(`backgroundColor: ${COLORS.yellow30}`) - }) - it('should call on click when pressed', () => { - render(props) - fireEvent.click(screen.getByText('mock ListButton content')) - expect(props.onClick).toHaveBeenCalled() - }) -}) diff --git a/components/src/atoms/ListButton/__tests__/ListButtonAccordion.test.tsx b/components/src/atoms/ListButton/__tests__/ListButtonAccordion.test.tsx deleted file mode 100644 index 29a2673c773..00000000000 --- a/components/src/atoms/ListButton/__tests__/ListButtonAccordion.test.tsx +++ /dev/null @@ -1,35 +0,0 @@ -import type * as React from 'react' -import { describe, it, beforeEach } from 'vitest' -import { screen } from '@testing-library/react' -import { renderWithProviders } from '../../../testing/utils' - -import { ListButtonAccordion } from '..' - -const render = (props: React.ComponentProps) => - renderWithProviders() - -describe('ListButtonAccordion', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - children:
mock ListButtonAccordion content
, - headline: 'mock headline', - isExpanded: true, - } - }) - - it('should render non nested accordion', () => { - render(props) - screen.getByText('mock headline') - screen.getByText('mock ListButtonAccordion content') - }) - it('should render non nested accordion with main headline', () => { - props.isNested = true - props.mainHeadline = 'mock main headline' - render(props) - screen.getByText('mock main headline') - screen.getByText('mock headline') - screen.getByText('mock ListButtonAccordion content') - }) -}) diff --git a/components/src/atoms/ListButton/__tests__/ListButtonRadioButton.test.tsx b/components/src/atoms/ListButton/__tests__/ListButtonRadioButton.test.tsx deleted file mode 100644 index e9448ffabdf..00000000000 --- a/components/src/atoms/ListButton/__tests__/ListButtonRadioButton.test.tsx +++ /dev/null @@ -1,27 +0,0 @@ -import type * as React from 'react' -import { describe, it, beforeEach, vi, expect } from 'vitest' -import { fireEvent, screen } from '@testing-library/react' -import { renderWithProviders } from '../../../testing/utils' - -import { ListButtonRadioButton } from '..' - -const render = (props: React.ComponentProps) => - renderWithProviders() - -describe('ListButtonRadioButton', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - buttonText: 'mock text', - buttonValue: 'mockValue', - onChange: vi.fn(), - } - }) - - it('should render non nested accordion', () => { - render(props) - fireEvent.click(screen.getByText('mock text')) - expect(props.onChange).toHaveBeenCalled() - }) -}) diff --git a/components/src/atoms/ListItem/__tests__/ListItem.test.tsx b/components/src/atoms/ListItem/__tests__/ListItem.test.tsx deleted file mode 100644 index ce15aec5d8e..00000000000 --- a/components/src/atoms/ListItem/__tests__/ListItem.test.tsx +++ /dev/null @@ -1,61 +0,0 @@ -import type * as React from 'react' -import { vi, describe, it, expect, beforeEach } from 'vitest' -import '@testing-library/jest-dom/vitest' -import { fireEvent, screen } from '@testing-library/react' -import { renderWithProviders } from '../../../testing/utils' -import { BORDERS, COLORS } from '../../../helix-design-system' - -import { ListItem } from '..' - -const render = (props: React.ComponentProps) => - renderWithProviders() - -describe('ListItem', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - type: 'error', - children:
mock listitem content
, - onClick: vi.fn(), - } - }) - - it('should render correct style - error', () => { - render(props) - screen.getByText('mock listitem content') - const listItem = screen.getByTestId('ListItem_error') - expect(listItem).toHaveStyle(`backgroundColor: ${COLORS.red35}`) - expect(listItem).toHaveStyle(`borderRadius: ${BORDERS.borderRadius4}`) - }) - it('should render correct style - noActive', () => { - props.type = 'noActive' - render(props) - screen.getByText('mock listitem content') - const listItem = screen.getByTestId('ListItem_noActive') - expect(listItem).toHaveStyle(`backgroundColor: ${COLORS.grey20}`) - expect(listItem).toHaveStyle(`borderRadius: ${BORDERS.borderRadius4}`) - }) - it('should render correct style - success', () => { - props.type = 'success' - render(props) - screen.getByText('mock listitem content') - const listItem = screen.getByTestId('ListItem_success') - expect(listItem).toHaveStyle(`backgroundColor: ${COLORS.green35}`) - expect(listItem).toHaveStyle(`borderRadius: ${BORDERS.borderRadius4}`) - }) - it('should render correct style - warning', () => { - props.type = 'warning' - render(props) - screen.getByText('mock listitem content') - const listItem = screen.getByTestId('ListItem_warning') - expect(listItem).toHaveStyle(`backgroundColor: ${COLORS.yellow35}`) - expect(listItem).toHaveStyle(`borderRadius: ${BORDERS.borderRadius4}`) - }) - it('should call on click when pressed', () => { - render(props) - const listItem = screen.getByText('mock listitem content') - fireEvent.click(listItem) - expect(props.onClick).toHaveBeenCalled() - }) -}) diff --git a/components/src/atoms/MenuList/__tests__/MenuItem.test.tsx b/components/src/atoms/MenuList/__tests__/MenuItem.test.tsx deleted file mode 100644 index f6d0485be45..00000000000 --- a/components/src/atoms/MenuList/__tests__/MenuItem.test.tsx +++ /dev/null @@ -1,50 +0,0 @@ -import type * as React from 'react' -import { describe, it, expect, beforeEach } from 'vitest' -import { screen } from '@testing-library/react' - -import { renderWithProviders } from '../../../testing/utils' -import { COLORS } from '../../../helix-design-system' -import { SPACING, TYPOGRAPHY } from '../../../ui-style-constants' - -import { MenuItem } from '../MenuItem' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('MenuItem', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - children: 'mockMenuItem', - isAlert: false, - } - }) - - it('render button with styles', () => { - render(props) - const menuItem = screen.getByText('mockMenuItem') - expect(menuItem).toHaveStyle(`background-color: ${COLORS.transparent}`) - expect(menuItem).toHaveStyle(`color: ${COLORS.black90}`) - expect(menuItem) - .toHaveStyle(`padding: ${SPACING.spacing8} ${SPACING.spacing12} ${SPACING.spacing8} - ${SPACING.spacing12}`) - expect(menuItem).toHaveStyle(`font-size: ${TYPOGRAPHY.fontSizeP}`) - }) - - it('render button with styles disabled', () => { - props = { - ...props, - disabled: true, - } - render(props) - const menuItem = screen.getByText('mockMenuItem') - expect(menuItem).toHaveStyle(`background-color: ${COLORS.transparent}`) - expect(menuItem).toHaveStyle(`color: ${COLORS.grey40}`) - expect(menuItem) - .toHaveStyle(`padding: ${SPACING.spacing8} ${SPACING.spacing12} ${SPACING.spacing8} - ${SPACING.spacing12}`) - expect(menuItem).toHaveStyle(`font-size: ${TYPOGRAPHY.fontSizeP}`) - }) -}) diff --git a/components/src/atoms/MenuList/__tests__/MenuList.test.tsx b/components/src/atoms/MenuList/__tests__/MenuList.test.tsx deleted file mode 100644 index e38e145eceb..00000000000 --- a/components/src/atoms/MenuList/__tests__/MenuList.test.tsx +++ /dev/null @@ -1,36 +0,0 @@ -import type * as React from 'react' -import { describe, it, expect, vi, beforeEach } from 'vitest' -import { fireEvent, screen } from '@testing-library/react' - -import { renderWithProviders } from '../../../testing/utils' -import { MenuList } from '..' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -const mockBtn =
mockBtn
- -describe('MenuList', () => { - let props: React.ComponentProps - beforeEach(() => { - props = { - children: mockBtn, - } - }) - - it('renders a child not on device', () => { - render(props) - screen.getByText('mockBtn') - }) - it('renders isOnDevice child, clicking background overlay calls onClick', () => { - props = { - ...props, - isOnDevice: true, - onClick: vi.fn(), - } - render(props) - fireEvent.click(screen.getByLabelText('BackgroundOverlay_ModalShell')) - expect(props.onClick).toHaveBeenCalled() - }) -}) diff --git a/components/src/atoms/MenuList/__tests__/OverflowBtn.test.tsx b/components/src/atoms/MenuList/__tests__/OverflowBtn.test.tsx deleted file mode 100644 index 00f080fae2c..00000000000 --- a/components/src/atoms/MenuList/__tests__/OverflowBtn.test.tsx +++ /dev/null @@ -1,33 +0,0 @@ -import type * as React from 'react' -import { vi, it, expect, describe } from 'vitest' -import { fireEvent, screen } from '@testing-library/react' - -import { COLORS } from '../../../helix-design-system' -import { renderWithProviders } from '../../../testing/utils' -import { OverflowBtn } from '../OverflowBtn' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('OverflowBtn', () => { - it('renders a clickable button', () => { - const handleClick = vi.fn() - render({ - onClick: handleClick, - }) - - const button = screen.getByRole('button') - fireEvent.click(button) - expect(handleClick).toHaveBeenCalledTimes(1) - }) - - it('renders a hover state', () => { - render({ - onClick: vi.fn(), - }) - expect(screen.getByRole('button')).toHaveStyle( - `background-color: ${COLORS.transparent}` - ) - }) -}) diff --git a/components/src/atoms/Snackbar/__tests__/Snackbar.test.tsx b/components/src/atoms/Snackbar/__tests__/Snackbar.test.tsx deleted file mode 100644 index a4ae1f8f6b0..00000000000 --- a/components/src/atoms/Snackbar/__tests__/Snackbar.test.tsx +++ /dev/null @@ -1,73 +0,0 @@ -import type * as React from 'react' -import { describe, it, expect, vi, beforeEach } from 'vitest' -import '@testing-library/jest-dom/vitest' -import { screen, act } from '@testing-library/react' -import { renderWithProviders } from '../../../testing/utils' -import { Snackbar } from '..' -import { COLORS } from '../../../helix-design-system' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('Snackbar', () => { - let props: React.ComponentProps - beforeEach(() => { - props = { - message: 'test message', - onClose: vi.fn(), - } - }) - - it('renders correct message', () => { - render(props) - screen.getByText('test message') - }) - - it('should have proper styling', () => { - props = { - message: 'test message', - } - render(props) - const testSnackbar = screen.getByTestId('Snackbar') - expect(testSnackbar).toHaveStyle(`background-color: ${COLORS.black90}`) - }) - - it('after 4 seconds the snackbar should be closed automatically', async () => { - vi.useFakeTimers() - props = { - message: 'test message', - duration: 4000, - onClose: vi.fn(), - } - render(props) - screen.getByText('test message') - act(() => { - vi.advanceTimersByTime(100) - }) - expect(props.onClose).not.toHaveBeenCalled() - act(() => { - vi.advanceTimersByTime(5000) - }) - expect(props.onClose).toHaveBeenCalled() - }) - - it('should stay more than 4 seconds when given a longer duration', async () => { - vi.useFakeTimers() - props = { - message: 'test message', - duration: 8000, - onClose: vi.fn(), - } - render(props) - screen.getByText('test message') - act(() => { - vi.advanceTimersByTime(4100) - }) - expect(props.onClose).not.toHaveBeenCalled() - act(() => { - vi.advanceTimersByTime(5000) - }) - expect(props.onClose).toHaveBeenCalled() - }) -}) diff --git a/components/src/atoms/Tag/__tests__/Tag.test.tsx b/components/src/atoms/Tag/__tests__/Tag.test.tsx deleted file mode 100644 index dcb25c77d27..00000000000 --- a/components/src/atoms/Tag/__tests__/Tag.test.tsx +++ /dev/null @@ -1,55 +0,0 @@ -import type * as React from 'react' -import { describe, it, expect } from 'vitest' -import { screen } from '@testing-library/react' -import { COLORS } from '../../../helix-design-system' -import { renderWithProviders } from '../../../testing/utils' -import { Tag } from '../index' - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('Tag', () => { - let props: React.ComponentProps - - it('should render text, icon with default', () => { - props = { - text: 'mockDefault', - type: 'default', - iconName: 'ot-alert', - iconPosition: 'left', - } - render(props) - const tag = screen.getByTestId('Tag_default') - screen.getByText('mockDefault') - expect(tag).toHaveStyle( - `background-color: ${COLORS.black90}${COLORS.opacity20HexCode}` - ) - screen.getByLabelText('icon_left_mockDefault') - }) - it('should render text, right icon with branded', () => { - props = { - text: 'mockBranded', - type: 'branded', - iconName: 'ot-alert', - iconPosition: 'right', - } - render(props) - const tag = screen.getByTestId('Tag_branded') - screen.getByText('mockBranded') - expect(tag).toHaveStyle(`background-color: ${COLORS.blue50}`) - screen.getByLabelText('icon_right_mockBranded') - }) - it('should render text with interactive', () => { - props = { - text: 'mockInteractive', - type: 'interactive', - } - render(props) - const tag = screen.getByTestId('Tag_interactive') - screen.getByText('mockInteractive') - expect(tag).toHaveStyle( - `background-color: ${COLORS.black90}${COLORS.opacity20HexCode}` - ) - }) -}) diff --git a/components/src/atoms/Toast/__tests__/ODDToast.test.tsx b/components/src/atoms/Toast/__tests__/ODDToast.test.tsx deleted file mode 100644 index d198df7f03e..00000000000 --- a/components/src/atoms/Toast/__tests__/ODDToast.test.tsx +++ /dev/null @@ -1,178 +0,0 @@ -import type * as React from 'react' -import { describe, it, expect, vi, beforeEach } from 'vitest' -import '@testing-library/jest-dom/vitest' -import { act, fireEvent, screen } from '@testing-library/react' -import { renderWithProviders } from '../../../testing/utils' -import { Toast, TOAST_ANIMATION_DURATION } from '..' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('Toast', () => { - let props: React.ComponentProps - beforeEach(() => { - props = { - id: '1', - message: 'test message', - heading: 'heading message', - type: 'success', - closeButton: true, - buttonText: 'Close', - onClose: vi.fn(), - displayType: 'odd', - exitNow: false, - } - }) - - it('renders correct message', () => { - render(props) - screen.getByText('test message') - screen.getByText('heading message') - }) - it('truncates heading message whern too long', () => { - props = { - ...props, - heading: 'Super-long-protocol-file-name-that-the-user-made.py', - } - render(props) - screen.getByText('Super-long-protocol-file-name-that-the-u...py') - }) - it('calls onClose when close button is pressed', () => { - vi.useFakeTimers() - render(props) - const closeButton = screen.getByRole('button') - fireEvent.click(closeButton) - act(() => { - vi.advanceTimersByTime(TOAST_ANIMATION_DURATION) - }) - expect(props.onClose).toHaveBeenCalled() - }) - it('does not render close button if buttonText and closeButton are undefined', () => { - props = { - ...props, - buttonText: undefined, - closeButton: undefined, - } - render(props) - expect(screen.queryByRole('button')).toBeNull() - }) - it('should have success styling when passing success as type', () => { - render(props) - const successToast = screen.getByTestId('Toast_success') - expect(successToast).toHaveStyle(`color: #04aa65 - background-color: ##baffcd`) - screen.getByLabelText('icon_success') - }) - it('should have warning styling when passing warning as type', () => { - props = { - ...props, - type: 'warning', - } - render(props) - const warningToast = screen.getByTestId('Toast_warning') - expect(warningToast).toHaveStyle(`color: #f09d20 - background-color: #ffe9be`) - screen.getByLabelText('icon_warning') - }) - - it('after 7 seconds the toast should be closed automatically', async () => { - vi.useFakeTimers() - props = { - ...props, - duration: 7000, - } - render(props) - screen.getByText('test message') - act(() => { - vi.advanceTimersByTime(100) - }) - expect(props.onClose).not.toHaveBeenCalled() - act(() => { - vi.advanceTimersByTime(8000) - }) - expect(props.onClose).toHaveBeenCalled() - }) - - it('should stay more than 7 seconds when disableTimeout is true', async () => { - vi.useFakeTimers() - props = { - ...props, - disableTimeout: true, - } - render(props) - screen.getByText('test message') - act(() => { - vi.advanceTimersByTime(100) - }) - expect(props.onClose).not.toHaveBeenCalled() - act(() => { - vi.advanceTimersByTime(7000) - }) - expect(props.onClose).not.toHaveBeenCalled() - }) - - it('should not stay more than 7 seconds when disableTimeout is false', async () => { - vi.useFakeTimers() - props = { - ...props, - disableTimeout: false, - } - render(props) - screen.getByText('test message') - act(() => { - vi.advanceTimersByTime(100) - }) - expect(props.onClose).not.toHaveBeenCalled() - act(() => { - vi.advanceTimersByTime(9000) - }) - expect(props.onClose).toHaveBeenCalled() - }) - - it('should dismiss when a second toast appears', async () => { - vi.useFakeTimers() - props = { - ...props, - disableTimeout: true, - exitNow: true, - } - render(props) - screen.getByText('test message') - act(() => { - vi.advanceTimersByTime(100) - }) - expect(props.onClose).not.toHaveBeenCalled() - act(() => { - vi.advanceTimersByTime(TOAST_ANIMATION_DURATION) - }) - expect(props.onClose).toHaveBeenCalled() - }) - it('renders link text with an optional callback', async () => { - vi.useFakeTimers() - props = { - ...props, - linkText: 'test link', - onLinkClick: vi.fn(), - } - render(props) - const clickableLink = screen.getByText('test link') - fireEvent.click(clickableLink) - expect(props.onLinkClick).toHaveBeenCalled() - }) - it('toast will not disappear on a general click if both close button and clickable link present', async () => { - vi.useFakeTimers() - props = { - ...props, - linkText: 'test link', - closeButton: true, - } - render(props) - const clickableLink = screen.getByText('test message') - fireEvent.click(clickableLink) - act(() => { - vi.advanceTimersByTime(TOAST_ANIMATION_DURATION) - }) - expect(props.onClose).not.toHaveBeenCalled() - }) -}) diff --git a/components/src/atoms/Toast/__tests__/Toast.test.tsx b/components/src/atoms/Toast/__tests__/Toast.test.tsx deleted file mode 100644 index 5133651ecd6..00000000000 --- a/components/src/atoms/Toast/__tests__/Toast.test.tsx +++ /dev/null @@ -1,174 +0,0 @@ -import type * as React from 'react' -import { describe, it, expect, vi, beforeEach } from 'vitest' -import '@testing-library/jest-dom/vitest' -import { act, fireEvent, screen } from '@testing-library/react' -import { renderWithProviders } from '../../../testing/utils' -import { Toast, TOAST_ANIMATION_DURATION } from '..' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('Toast', () => { - let props: React.ComponentProps - beforeEach(() => { - props = { - id: '1', - message: 'test message', - type: 'success', - closeButton: true, - onClose: vi.fn(), - } - }) - - it('renders correct message', () => { - render(props) - screen.getByText('test message') - }) - - it('calls onClose when close button is pressed', () => { - vi.useFakeTimers() - render(props) - const closeButton = screen.getByRole('button') - fireEvent.click(closeButton) - act(() => { - vi.advanceTimersByTime(TOAST_ANIMATION_DURATION) - }) - expect(props.onClose).toHaveBeenCalled() - }) - - it('does not render x button if prop is false', () => { - props = { - ...props, - closeButton: false, - } - render(props) - expect(screen.queryByRole('button')).toBeNull() - }) - - it('should have success styling when passing success as type', () => { - render(props) - const successToast = screen.getByTestId('Toast_success') - expect(successToast).toHaveStyle(`color: #04aa65 - background-color: #f3fffa`) - screen.getByLabelText('icon_success') - }) - - it('should have warning styling when passing warning as type', () => { - props = { - ...props, - type: 'warning', - } - render(props) - const warningToast = screen.getByTestId('Toast_warning') - expect(warningToast).toHaveStyle(`color: #f09d20 - background-color: #fffcf5`) - screen.getByLabelText('icon_warning') - }) - - it('should have error styling when passing error as type', () => { - props = { - ...props, - type: 'error', - } - render(props) - const errorToast = screen.getByTestId('Toast_error') - expect(errorToast).toHaveStyle(`color: #bf0000 - background-color: #fff3f3`) - screen.getByLabelText('icon_error') - }) - - it('should have info styling when passing info as type', () => { - props = { - ...props, - type: 'info', - } - render(props) - const infoToast = screen.getByTestId('Toast_info') - expect(infoToast).toHaveStyle(`color: #16212D - background-color: #eaeaeb`) - screen.getByLabelText('icon_info') - }) - - it('should stay more than 7 seconds when disableTimeout is true', async () => { - vi.useFakeTimers() - props = { - ...props, - disableTimeout: true, - } - render(props) - screen.getByText('test message') - act(() => { - vi.advanceTimersByTime(100) - }) - expect(props.onClose).not.toHaveBeenCalled() - act(() => { - vi.advanceTimersByTime(7000) - }) - expect(props.onClose).not.toHaveBeenCalled() - }) - - it('should not stay more than 7 seconds when disableTimeout is false', async () => { - vi.useFakeTimers() - props = { - ...props, - disableTimeout: false, - } - render(props) - screen.getByText('test message') - act(() => { - vi.advanceTimersByTime(100) - }) - expect(props.onClose).not.toHaveBeenCalled() - act(() => { - vi.advanceTimersByTime(9000) - }) - expect(props.onClose).toHaveBeenCalled() - }) - - it('should dismiss when a second toast appears', async () => { - vi.useFakeTimers() - props = { - ...props, - disableTimeout: true, - exitNow: true, - } - render(props) - screen.getByText('test message') - act(() => { - vi.advanceTimersByTime(100) - }) - expect(props.onClose).not.toHaveBeenCalled() - act(() => { - vi.advanceTimersByTime(TOAST_ANIMATION_DURATION) - }) - expect(props.onClose).toHaveBeenCalled() - }) - it('renders link text with an optional callback', async () => { - vi.useFakeTimers() - props = { - ...props, - linkText: 'test link', - onLinkClick: vi.fn(), - } - render(props) - const clickableLink = screen.getByText('test link') - fireEvent.click(clickableLink) - expect(props.onLinkClick).toHaveBeenCalled() - }) - it('toast will not disappear on a general click if both close button and clickable link present', async () => { - vi.useFakeTimers() - props = { - ...props, - linkText: 'test link', - closeButton: true, - } - render(props) - const clickableLink = screen.getByText('test message') - fireEvent.click(clickableLink) - act(() => { - vi.advanceTimersByTime(TOAST_ANIMATION_DURATION) - }) - expect(props.onClose).not.toHaveBeenCalled() - }) -}) diff --git a/components/src/atoms/ToggleGroup/__tests__/ToggleGroup.test.tsx b/components/src/atoms/ToggleGroup/__tests__/ToggleGroup.test.tsx deleted file mode 100644 index f7beb737696..00000000000 --- a/components/src/atoms/ToggleGroup/__tests__/ToggleGroup.test.tsx +++ /dev/null @@ -1,28 +0,0 @@ -import type * as React from 'react' -import { describe, it, expect, vi } from 'vitest' -import { fireEvent, screen } from '@testing-library/react' -import { renderWithProviders } from '../../../testing/utils' -import { ToggleGroup } from '../index' - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('ToggleGroup', () => { - let props: React.ComponentProps - - it('should render text and buttons', () => { - props = { - leftText: 'mock leftText', - rightText: 'mock rightText', - leftClick: vi.fn(), - rightClick: vi.fn(), - selectedValue: 'mock leftText', - } - render(props) - fireEvent.click(screen.getByText('mock leftText')) - expect(props.leftClick).toHaveBeenCalled() - fireEvent.click(screen.getByText('mock rightText')) - expect(props.rightClick).toHaveBeenCalled() - }) -}) diff --git a/components/src/atoms/Tooltip/__tests__/Tooltip.test.tsx b/components/src/atoms/Tooltip/__tests__/Tooltip.test.tsx deleted file mode 100644 index ddc1e4f6a1a..00000000000 --- a/components/src/atoms/Tooltip/__tests__/Tooltip.test.tsx +++ /dev/null @@ -1,78 +0,0 @@ -import type * as React from 'react' -import { describe, it, expect, vi, beforeEach } from 'vitest' -import '@testing-library/jest-dom/vitest' -import { screen } from '@testing-library/react' - -import { COLORS } from '../../../helix-design-system' -import { TOOLTIP_TOP } from '../../../tooltips' -import { SPACING } from '../../../ui-style-constants' -import { POSITION_ABSOLUTE } from '../../../styles' - -import { renderWithProviders } from '../../../testing/utils' -import { Tooltip } from '..' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -const placement = TOOLTIP_TOP -const id = 'Tooltip_123' -const tooltipRef = vi.fn() -const tooltipStyle = { - position: POSITION_ABSOLUTE, - left: SPACING.spacing4, -} as const -const arrowRef = vi.fn() -const arrowStyle = { - position: POSITION_ABSOLUTE, - left: SPACING.spacing8, -} as const - -const MockTooltipProps = { - id: id, - placement: placement, - arrowStyle: arrowStyle, - arrowRef: arrowRef, - visible: true, - ref: tooltipRef, - style: tooltipStyle, -} - -describe('Tooltip', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - children: 'mock children' as React.ReactNode, - tooltipProps: MockTooltipProps, - key: 'mock key', - } - }) - - it('renders correct children when the tooltip is visible', () => { - render(props) - const tooltip = screen.getByText('mock children') - expect(tooltip).toBeInTheDocument() - expect(tooltip).toHaveStyle('position: absolute') - expect(tooltip).toHaveStyle('left: 0.25rem') - expect(tooltip).toHaveStyle(`background: ${COLORS.black90}`) - expect(tooltip).toHaveStyle(`color: ${COLORS.white}`) - expect(tooltip).toHaveStyle('max-width: 8.75rem') - expect(tooltip).toHaveStyle('font-size: 0.625rem') - expect(tooltip).toHaveAttribute('role', 'tooltip') - }) - - it('renders correct children when the tooltip is visible with a specific with', () => { - props = { ...props, width: '3rem' } - render(props) - const tooltip = screen.getByText('mock children') - expect(tooltip).toHaveStyle('width: 3rem') - }) - - it('does not render children when the tooltip is invisible', () => { - MockTooltipProps.visible = false - render(props) - const tooltip = screen.queryByText('mock children') - expect(tooltip).not.toBeInTheDocument() - }) -}) diff --git a/components/src/atoms/buttons/__tests__/AlertPrimaryButton.test.tsx b/components/src/atoms/buttons/__tests__/AlertPrimaryButton.test.tsx deleted file mode 100644 index cad0175d981..00000000000 --- a/components/src/atoms/buttons/__tests__/AlertPrimaryButton.test.tsx +++ /dev/null @@ -1,47 +0,0 @@ -import type * as React from 'react' -import { describe, it, beforeEach, expect } from 'vitest' -import { screen } from '@testing-library/react' -import '@testing-library/jest-dom/vitest' -import { renderWithProviders } from '../../../testing/utils' -import { BORDERS, COLORS } from '../../../helix-design-system' -import { TYPOGRAPHY, SPACING } from '../../../ui-style-constants' - -import { AlertPrimaryButton } from '../AlertPrimaryButton' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('AlertPrimaryButton', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - children: 'alert primary button', - } - }) - - it('renders alert primary button with text', () => { - render(props) - const button = screen.getByText('alert primary button') - expect(button).toHaveStyle(`background-color: ${COLORS.red50}`) - expect(button).toHaveStyle( - `padding: ${SPACING.spacing8} ${SPACING.spacing16} ${SPACING.spacing8} ${SPACING.spacing16}` - ) - expect(button).toHaveStyle(`font-size: ${TYPOGRAPHY.fontSizeP}`) - expect(button).toHaveStyle(`font-weight: ${TYPOGRAPHY.fontWeightSemiBold}`) - expect(button).toHaveStyle(`line-height: ${TYPOGRAPHY.lineHeight20}`) - expect(button).toHaveStyle(`border-radius: ${BORDERS.borderRadius8}`) - expect(button).toHaveStyle( - `text-transform: ${TYPOGRAPHY.textTransformNone}` - ) - expect(button).toHaveStyle('box-shadow: 0 0 0') - }) - - it('renders alert primary button with text and disabled', () => { - props.disabled = true - render(props) - const button = screen.getByText('alert primary button') - expect(button).toBeDisabled() - }) -}) diff --git a/components/src/atoms/buttons/__tests__/AltPrimaryButton.test.tsx b/components/src/atoms/buttons/__tests__/AltPrimaryButton.test.tsx deleted file mode 100644 index f65613d0561..00000000000 --- a/components/src/atoms/buttons/__tests__/AltPrimaryButton.test.tsx +++ /dev/null @@ -1,57 +0,0 @@ -import type * as React from 'react' -import { describe, it, beforeEach, expect } from 'vitest' -import { screen } from '@testing-library/react' -import '@testing-library/jest-dom/vitest' -import { renderWithProviders } from '../../../testing/utils' -import { BORDERS, COLORS } from '../../../helix-design-system' -import { TYPOGRAPHY, SPACING } from '../../../ui-style-constants' -import { AltPrimaryButton } from '../AltPrimaryButton' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('AltPrimaryButton', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - children: 'alt primary button', - } - }) - - it('renders alt primary button with text', () => { - render(props) - const button = screen.getByText('alt primary button') - expect(button).toHaveStyle(`background-color: ${COLORS.grey30}`) - expect(button).toHaveStyle( - `padding: ${SPACING.spacing8} ${SPACING.spacing16} ${SPACING.spacing8} ${SPACING.spacing16}` - ) - expect(button).toHaveStyle(`font-size: ${TYPOGRAPHY.fontSizeP}`) - expect(button).toHaveStyle(`font-weight: ${TYPOGRAPHY.fontWeightSemiBold}`) - expect(button).toHaveStyle(`line-height: ${TYPOGRAPHY.lineHeight20}`) - expect(button).toHaveStyle(`border-radius: ${BORDERS.borderRadius8}`) - expect(button).toHaveStyle( - `text-transform: ${TYPOGRAPHY.textTransformNone}` - ) - expect(button).toHaveStyle(`box-shadow: none`) - expect(button).toHaveStyle(`color: ${COLORS.black90}`) - }) - - it('renders alt primary button with text and disabled', () => { - props.disabled = true - render(props) - const button = screen.getByText('alt primary button') - expect(button).toBeDisabled() - expect(button).toHaveStyle(`background-color: ${COLORS.grey30}`) - expect(button).toHaveStyle(`color: ${COLORS.grey40}`) - }) - - // (kk: 09/23/2024) hover test needs jsdom update so this will be activated later - // it('applies the correct states to the button - hover', () => { - // render(props) - // const button = screen.getByText('alt primary button') - // fireEvent.mouseOver(button) - // expect(button).toHaveStyle(`background-color: ${COLORS.grey35}`) - // }) -}) diff --git a/components/src/atoms/buttons/__tests__/EmptySelectorButton.test.tsx b/components/src/atoms/buttons/__tests__/EmptySelectorButton.test.tsx deleted file mode 100644 index 6fea2d8d297..00000000000 --- a/components/src/atoms/buttons/__tests__/EmptySelectorButton.test.tsx +++ /dev/null @@ -1,42 +0,0 @@ -import type * as React from 'react' -import '@testing-library/jest-dom/vitest' -import { fireEvent, screen } from '@testing-library/react' -import { describe, it, expect, vi, beforeEach } from 'vitest' -import { renderWithProviders } from '../../../testing/utils' -import { JUSTIFY_CENTER, JUSTIFY_START } from '../../../styles' -import { EmptySelectorButton } from '../EmptySelectorButton' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('EmptySelectorButton', () => { - let props: React.ComponentProps - beforeEach(() => { - props = { - onClick: vi.fn(), - text: 'mock text', - iconName: 'add', - textAlignment: 'left', - } - }) - it('renders the props and button cta', () => { - render(props) - const button = screen.getByText('mock text') - fireEvent.click(button) - expect(props.onClick).toHaveBeenCalled() - screen.getByTestId('EmptySelectorButton_add') - expect(screen.getByTestId('EmptySelectorButton_container')).toHaveStyle( - `justify-content: ${JUSTIFY_START}` - ) - }) - it('renders middled aligned button', () => { - props.textAlignment = 'middle' - props.iconName = undefined - render(props) - expect(screen.getByTestId('EmptySelectorButton_container')).toHaveStyle( - `justify-content: ${JUSTIFY_CENTER}` - ) - screen.queryByTestId('EmptySelectorButton_add') - }) -}) diff --git a/components/src/atoms/buttons/__tests__/LargeButton.test.tsx b/components/src/atoms/buttons/__tests__/LargeButton.test.tsx deleted file mode 100644 index 52f6c9e71f6..00000000000 --- a/components/src/atoms/buttons/__tests__/LargeButton.test.tsx +++ /dev/null @@ -1,91 +0,0 @@ -import type * as React from 'react' -import { describe, it, expect, vi, beforeEach } from 'vitest' -import '@testing-library/jest-dom/vitest' -import { fireEvent, screen } from '@testing-library/react' - -import { renderWithProviders } from '../../../testing/utils' -import { COLORS } from '../../../helix-design-system' -import { LargeButton } from '../LargeButton' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('LargeButton', () => { - let props: React.ComponentProps - beforeEach(() => { - props = { - onClick: vi.fn(), - buttonText: 'large button', - iconName: 'play-round-corners', - } - }) - it('renders the default button and it works as expected', () => { - render(props) - fireEvent.click(screen.getByText('large button')) - expect(props.onClick).toHaveBeenCalled() - }) - it('renders the alert button', () => { - props = { - ...props, - buttonType: 'alert', - } - render(props) - expect(screen.getByRole('button')).toHaveStyle( - `background-color: ${COLORS.red35}` - ) - }) - it('renders the secondary button', () => { - props = { - ...props, - buttonType: 'secondary', - } - render(props) - expect(screen.getByRole('button')).toHaveStyle( - `background-color: ${COLORS.blue35}` - ) - }) - - it('renders the alertStroke button', () => { - props = { - ...props, - buttonType: 'alertStroke', - } - render(props) - expect(screen.getByRole('button')).toHaveStyle( - `background-color: ${COLORS.transparent}` - ) - }) - - it('renders the alertAlt button', () => { - props = { - ...props, - buttonType: 'alertAlt', - } - render(props) - expect(screen.getByRole('button')).toHaveStyle( - `background-color: ${COLORS.white}` - ) - }) - - it('renders the stroke button', () => { - props = { - ...props, - buttonType: 'stroke', - } - render(props) - expect(screen.getByRole('button')).toHaveStyle( - `background-color: ${COLORS.white}` - ) - expect(screen.getByRole('button')).toHaveStyle(`color: ${COLORS.blue50}`) - }) - - it('renders the button as disabled', () => { - props = { - ...props, - disabled: true, - } - render(props) - expect(screen.getByRole('button')).toBeDisabled() - }) -}) diff --git a/components/src/atoms/buttons/__tests__/PrimaryButton.test.tsx b/components/src/atoms/buttons/__tests__/PrimaryButton.test.tsx deleted file mode 100644 index 558f4a595eb..00000000000 --- a/components/src/atoms/buttons/__tests__/PrimaryButton.test.tsx +++ /dev/null @@ -1,64 +0,0 @@ -import type * as React from 'react' -import { describe, it, beforeEach, expect } from 'vitest' -import { fireEvent, screen } from '@testing-library/react' -import '@testing-library/jest-dom/vitest' -import { renderWithProviders } from '../../../testing/utils' -import { BORDERS, COLORS } from '../../../helix-design-system' -import { TYPOGRAPHY, SPACING } from '../../../ui-style-constants' -import { PrimaryButton } from '../PrimaryButton' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('PrimaryButton', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - children: 'primary button', - } - }) - - it('renders primary button with text', () => { - render(props) - const button = screen.getByText('primary button') - expect(button).toHaveStyle(`background-color: ${COLORS.blue50}`) - expect(button).toHaveStyle( - `padding: ${SPACING.spacing8} ${SPACING.spacing16} ${SPACING.spacing8} ${SPACING.spacing16}` - ) - expect(button).toHaveStyle(`font-size: ${TYPOGRAPHY.fontSizeP}`) - expect(button).toHaveStyle(`font-weight: ${TYPOGRAPHY.fontWeightSemiBold}`) - expect(button).toHaveStyle(`line-height: ${TYPOGRAPHY.lineHeight20}`) - expect(button).toHaveStyle(`border-radius: ${BORDERS.borderRadius8}`) - expect(button).toHaveStyle( - `text-transform: ${TYPOGRAPHY.textTransformNone}` - ) - expect(button).toHaveStyle(`box-shadow: none`) - expect(button).toHaveStyle(`color: ${COLORS.white}`) - }) - - it('renders primary button with text and disabled', () => { - props.disabled = true - render(props) - const button = screen.getByText('primary button') - expect(button).toBeDisabled() - expect(button).toHaveStyle(`background-color: ${COLORS.grey30}`) - expect(button).toHaveStyle(`color: ${COLORS.grey40}`) - }) - - it('applies the correct states to the button - hover', () => { - render(props) - const button = screen.getByText('primary button') - fireEvent.mouseOver(button) - expect(button).toHaveStyle(`background-color: ${COLORS.blue50}`) - }) - - it('renders primary button with text and different background color', () => { - props.backgroundColor = COLORS.red50 - render(props) - const button = screen.getByText('primary button') - expect(button).toHaveStyle(`background-color: ${COLORS.red50}`) - expect(button).toHaveStyle(`color: ${COLORS.white}`) - }) -}) diff --git a/components/src/atoms/buttons/__tests__/RadioButton.test.tsx b/components/src/atoms/buttons/__tests__/RadioButton.test.tsx deleted file mode 100644 index 95aaf6532fc..00000000000 --- a/components/src/atoms/buttons/__tests__/RadioButton.test.tsx +++ /dev/null @@ -1,98 +0,0 @@ -import type * as React from 'react' -import '@testing-library/jest-dom/vitest' -import { screen, queryByAttribute } from '@testing-library/react' -import { describe, it, expect, vi, beforeEach } from 'vitest' -import { renderWithProviders } from '../../../testing/utils' -import { COLORS } from '../../../helix-design-system' -import { SPACING } from '../../../ui-style-constants' -import { RadioButton } from '../RadioButton' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('RadioButton', () => { - let props: React.ComponentProps - beforeEach(() => { - props = { - onChange: vi.fn(), - buttonLabel: 'radio button', - buttonValue: 1, - } - }) - - it('renders the large button', () => { - props = { - ...props, - radioButtonType: 'large', - } - render(props) - const label = screen.getByRole('label') - expect(label).toHaveStyle(`background-color: ${COLORS.blue35}`) - expect(label).toHaveStyle( - `padding: ${SPACING.spacing12} ${SPACING.spacing16}` - ) - }) - - it('renders the large selected button', () => { - props = { - ...props, - isSelected: true, - radioButtonType: 'large', - } - render(props) - const label = screen.getByRole('label') - expect(label).toHaveStyle(`background-color: ${COLORS.blue50}`) - expect(label).toHaveStyle( - `padding: ${SPACING.spacing12} ${SPACING.spacing16}` - ) - }) - - it('renders the small button with an icon', () => { - props = { - ...props, - radioButtonType: 'small', - iconName: 'alert-circle', - } - render(props) - const label = screen.getByRole('label') - expect(label).toHaveStyle(`background-color: ${COLORS.blue35}`) - expect(label).toHaveStyle( - `padding: ${SPACING.spacing12} ${SPACING.spacing16}` - ) - }) - - it('renders the small selected button', () => { - props = { - ...props, - isSelected: true, - radioButtonType: 'small', - } - render(props) - const label = screen.getByRole('label') - expect(label).toHaveStyle(`background-color: ${COLORS.blue50}`) - expect(label).toHaveStyle( - `padding: ${SPACING.spacing12} ${SPACING.spacing16}` - ) - }) - - it('renders id instead of buttonLabel when id is set', () => { - props = { - ...props, - id: 'mock-radio-button-id', - } - render(props) - const getById = queryByAttribute.bind(null, 'id') - const idRadioButton = getById( - render(props).container, - 'mock-radio-button-id' - ) - expect(idRadioButton).toBeInTheDocument() - const buttonLabelIdRadioButton = getById( - render(props).container, - // @ts-expect-error(ja, 8/23/24): buttonLabel is a string type - props.buttonLabel - ) - expect(buttonLabelIdRadioButton).not.toBeInTheDocument() - }) -}) diff --git a/components/src/atoms/buttons/__tests__/SecondaryButton.test.tsx b/components/src/atoms/buttons/__tests__/SecondaryButton.test.tsx deleted file mode 100644 index 8887e679268..00000000000 --- a/components/src/atoms/buttons/__tests__/SecondaryButton.test.tsx +++ /dev/null @@ -1,54 +0,0 @@ -import type * as React from 'react' -import { describe, it, beforeEach, expect } from 'vitest' -import { screen } from '@testing-library/react' -import '@testing-library/jest-dom/vitest' -import { renderWithProviders } from '../../../testing/utils' -import { TYPOGRAPHY, SPACING } from '../../../ui-style-constants' -import { BORDERS, COLORS } from '../../../helix-design-system' - -import { SecondaryButton } from '../SecondaryButton' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('SecondaryButton', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - children: 'secondary button', - } - }) - - it('renders primary button with text', () => { - render(props) - const button = screen.getByText('secondary button') - expect(button).toHaveStyle(`background-color: ${COLORS.transparent}`) - expect(button).toHaveStyle( - `padding: ${SPACING.spacing8} ${SPACING.spacing16}` - ) - expect(button).toHaveStyle(`font-size: ${TYPOGRAPHY.fontSizeP}`) - expect(button).toHaveStyle(`font-weight: ${TYPOGRAPHY.fontWeightSemiBold}`) - expect(button).toHaveStyle(`line-height: ${TYPOGRAPHY.lineHeight20}`) - expect(button).toHaveStyle(`border-radius: ${BORDERS.borderRadius8}`) - expect(button).toHaveStyle( - `text-transform: ${TYPOGRAPHY.textTransformNone}` - ) - expect(button).toHaveStyle(`color: ${COLORS.blue50}`) - }) - - it('renders secondary button with text and disabled', () => { - props.disabled = true - render(props) - const button = screen.getByText('secondary button') - expect(button).toBeDisabled() - }) - - it('renders secondary button with text and different background color', () => { - props.color = COLORS.red50 - render(props) - const button = screen.getByText('secondary button') - expect(button).toHaveStyle(`color: ${COLORS.red50}`) - }) -}) diff --git a/components/src/buttons/buttons.module.css b/components/src/buttons/buttons.module.css deleted file mode 100644 index 16fd871d974..00000000000 --- a/components/src/buttons/buttons.module.css +++ /dev/null @@ -1,428 +0,0 @@ -/* button styling */ -@import '../index.module.css'; - -:root { - --button-pad: 0.5rem; - - --button-inverted: { - /* VVV from legacy --button-inverted VVV */ - color: var(--c-font-light); - border-color: var(--c-font-light); - - &:active { - font-weight: var(--fw-regular); - background-color: color-mod(var(--c-bg-dark) tint(10%)); - } - - &:focus { - background-color: color-mod(var(--c-bg-dark) tint(5%)); - } - - &:hover { - background-color: color-mod(var(--c-bg-dark) tint(5%)); - } - - &:disabled, - &.disabled { - background-color: transparent; - - /* from legacy --button-disabled */ - font-weight: normal; - - /* from legacy --button-disabled */ - border-color: var(--c-font-disabled); - - /* from legacy --button-disabled */ - color: var(--c-font-disabled); - - /* from legacy --button-disabled */ - fill: var(--c-font-disabled); - - /* from legacy --button-disabled */ - cursor: default; - - /* from legacy --button-disabled */ - pointer-events: none; - - /* from legacy --button-disabled */ - } - - &.hover { - background-color: color-mod(var(--c-bg-dark) tint(5%)); - } - - /* ^^^ from legacy --button-default ^^^ */ - } -} - -/* TODO(ka, 2017-2-14): standardize primary button vars */ - -.button_primary { - /* VVV from legacy --button-default VVV */ - display: inline-block; - text-decoration: none; - position: relative; - line-height: 1.4; - border: none; - padding: var(--button-pad); - font-size: var(--fs-body-2); - font-weight: var(--fw-semibold); - text-align: center; - text-transform: uppercase; - cursor: pointer; - background: transparent; - border-radius: var(--bd-radius-default); - - /* ^^^ from legacy --button-default ^^^ */ - - width: 100%; - color: var(--c-font-light); - background-color: var(--c-bg-dark); - - /* TODO(mc, 2017-12-07): pull shadows out to central file */ - box-shadow: - 0 0 2px rgba(0, 0, 0, 0.12), - 0 2px 2px rgba(0, 0, 0, 0.24); - - &:focus { - background-color: color-mod(var(--c-bg-dark) shade(30%)); - } - - &:hover { - background-color: color-mod(var(--c-bg-dark) shade(30%)); - } - - &.hover { - background-color: color-mod(var(--c-bg-dark) shade(30%)); - } - - &:active { - font-weight: var(--fw-regular); - background-color: color-mod(var(--c-bg-dark) tint(30%)); - - /* TODO(mc, 2017-12-07): pull shadows out to central file */ - box-shadow: - 0 0 8px rgba(0, 0, 0, 0.12), - 0 8px 8px rgba(0, 0, 0, 0.24); - } - - &.inverted { - background-color: var(--c-bg-light); - color: var(--c-font-dark); - - &:focus, - &:hover, - &.hover { - background-color: color-mod(var(--c-bg-light) shade(5%)); - } - - &:active { - background-color: color-mod(var(--c-bg-light) shade(10%)); - } - } - - &:disabled, - &.disabled { - /* from legacy --button-disabled */ - font-weight: normal; - - /* from legacy --button-disabled */ - border-color: var(--c-font-disabled); - - /* from legacy --button-disabled */ - fill: var(--c-font-disabled); - - /* from legacy --button-disabled */ - cursor: default; - - /* from legacy --button-disabled */ - pointer-events: none; - - /* from legacy --button-disabled */ - - background-color: color-mod(var(--c-bg-dark) tint(70%)); - box-shadow: none; - color: var(--c-font-disabled); - } -} - -.button_flat { - /* VVV from legacy --button-default VVV */ - display: inline-block; - text-decoration: none; - position: relative; - line-height: 1.4; - border: none; - padding: var(--button-pad); - font-size: var(--fs-body-2); - font-weight: var(--fw-semibold); - text-align: center; - text-transform: uppercase; - cursor: pointer; - color: var(--c-font-dark); - background: transparent; - border-radius: var(--bd-radius-default); - - &:active { - font-weight: var(--fw-regular); - background-color: color-mod(var(--c-bg-light) shade(10%)); - } - - &:disabled, - &.disabled { - background-color: transparent; - - /* from legacy --button-disabled */ - font-weight: normal; - - /* from legacy --button-disabled */ - border-color: var(--c-font-disabled); - - /* from legacy --button-disabled */ - color: var(--c-font-disabled); - - /* from legacy --button-disabled */ - fill: var(--c-font-disabled); - - /* from legacy --button-disabled */ - cursor: default; - - /* from legacy --button-disabled */ - pointer-events: none; - - /* from legacy --button-disabled */ - } - - &:focus { - background-color: color-mod(var(--c-med-gray) alpha(25%)); - } - - &:hover { - background-color: color-mod(var(--c-med-gray) alpha(25%)); - } - - &.hover { - background-color: color-mod(var(--c-med-gray) alpha(25%)); - } - - /* ^^^ from legacy --button-default ^^^ */ - - width: 9rem; - - &.inverted { - /* VVV from legacy --button-inverted VVV */ - color: var(--c-font-light); - border-color: var(--c-font-light); - - &:active { - font-weight: var(--fw-regular); - background-color: color-mod(var(--c-bg-dark) tint(10%)); - } - - &:disabled, - &.disabled { - background-color: transparent; - - /* from legacy --button-disabled */ - font-weight: normal; - - /* from legacy --button-disabled */ - border-color: var(--c-font-disabled); - - /* from legacy --button-disabled */ - color: var(--c-font-disabled); - - /* from legacy --button-disabled */ - fill: var(--c-font-disabled); - - /* from legacy --button-disabled */ - cursor: default; - - /* from legacy --button-disabled */ - pointer-events: none; - - /* from legacy --button-disabled */ - } - - &:focus { - background-color: color-mod(var(--c-bg-dark) tint(5%)); - } - - &:hover { - background-color: color-mod(var(--c-bg-dark) tint(5%)); - } - - &.hover { - background-color: color-mod(var(--c-bg-dark) tint(5%)); - } - - /* ^^^ from legacy --button-default ^^^ */ - } -} - -.button_outline { - /* VVV from legacy --button-default VVV */ - display: inline-block; - text-decoration: none; - position: relative; - line-height: 1.4; - padding: var(--button-pad); - font-size: var(--fs-body-2); - font-weight: var(--fw-semibold); - text-align: center; - text-transform: uppercase; - cursor: pointer; - color: var(--c-font-dark); - background: transparent; - border-radius: var(--bd-radius-default); - - &:active { - font-weight: var(--fw-regular); - background-color: color-mod(var(--c-bg-light) shade(10%)); - } - - &:disabled, - &.disabled { - background-color: transparent; - - /* from legacy --button-disabled */ - font-weight: normal; - - /* from legacy --button-disabled */ - border-color: var(--c-font-disabled); - - /* from legacy --button-disabled */ - color: var(--c-font-disabled); - - /* from legacy --button-disabled */ - fill: var(--c-font-disabled); - - /* from legacy --button-disabled */ - cursor: default; - - /* from legacy --button-disabled */ - pointer-events: none; - - /* from legacy --button-disabled */ - } - - &:focus { - background-color: color-mod(var(--c-med-gray) alpha(25%)); - } - - &:hover { - background-color: color-mod(var(--c-med-gray) alpha(25%)); - } - - &.hover { - background-color: color-mod(var(--c-med-gray) alpha(25%)); - } - - /* ^^^ from legacy --button-default ^^^ */ - - width: 9rem; - border: 1px solid var(--c-font-dark); - - &.inverted { - /* VVV from legacy --button-inverted VVV */ - color: var(--c-font-light); - border-color: var(--c-font-light); - - &:active { - font-weight: var(--fw-regular); - background-color: color-mod(var(--c-bg-dark) tint(10%)); - } - - &:disabled, - &.disabled { - background-color: transparent; - - /* from legacy --button-disabled */ - font-weight: normal; - - /* from legacy --button-disabled */ - border-color: var(--c-font-disabled); - - /* from legacy --button-disabled */ - color: var(--c-font-disabled); - - /* from legacy --button-disabled */ - fill: var(--c-font-disabled); - - /* from legacy --button-disabled */ - cursor: default; - - /* from legacy --button-disabled */ - pointer-events: none; - - /* from legacy --button-disabled */ - } - - &:focus { - background-color: color-mod(var(--c-bg-dark) tint(5%)); - } - - &:hover { - background-color: color-mod(var(--c-bg-dark) tint(5%)); - } - - &.hover { - background-color: color-mod(var(--c-bg-dark) tint(5%)); - } - - /* ^^^ from legacy --button-default ^^^ */ - } -} - -/* style for IconButton */ - -.button_icon { - width: auto; - - & > * { - display: block; - height: 100%; - width: 100%; - } - - &.inverted { - color: white; - fill: white; - - /* TODO(mc, 2019-03-29): Is this correct? Our icons use only fill */ - stroke: white; - - &:disabled, - &.disabled { - background-color: transparent; - - /* from legacy --button-disabled */ - font-weight: normal; - - /* from legacy --button-disabled */ - border-color: var(--c-font-disabled); - - /* from legacy --button-disabled */ - color: var(--c-font-disabled); - - /* from legacy --button-disabled */ - fill: var(--c-font-disabled); - - /* from legacy --button-disabled */ - cursor: default; - - /* from legacy --button-disabled */ - pointer-events: none; - - /* from legacy --button-disabled */ - } - } -} - -/* style for the supplementary icon displayed by Button */ -.icon { - position: absolute; - top: var(--button-pad); - left: var(--button-pad); - height: calc(100% - 2 * var(--button-pad)); -} \ No newline at end of file diff --git a/components/src/controls/styles.module.css b/components/src/controls/styles.module.css deleted file mode 100644 index b04331b4459..00000000000 --- a/components/src/controls/styles.module.css +++ /dev/null @@ -1,103 +0,0 @@ -@import '../index.module.css'; - -:root { - --mw-labeled-toggle: 25rem; -} - -/* Toggle Button */ -.toggled_on { - fill: #0ec9eb; - color: #0ec9eb; -} - -.toggled_off { - fill: var(--c-dark-gray); -} - -.labeled_control_wrapper { - width: 100%; - padding: 1rem; - display: block; - - &:not(:last-child) { - border-bottom: 1px solid var(--c-light-gray); - } -} - -.labeled_control { - display: block; -} - -.stacked_labeled_control { - display: block; - margin-left: 1rem; - margin-top: 0.5rem; -} - -.stacked_labeled_control_label { - font-size: var(--fs-body-1); /* from legacy --font-body-1-dark */ - color: var(--c-font-dark); /* from legacy --font-body-1-dark */ - display: inline-block; - font-weight: var(--fw-semibold); -} - -.labeled_control_label { - font-size: var(--fs-body-1); /* from legacy --font-body-1-dark */ - color: var(--c-font-dark); /* from legacy --font-body-1-dark */ - max-width: var(--mw-labeled-toggle); - display: inline-block; - font-weight: var(--fw-semibold); -} - -.labeled_toggle_button { - float: right; - width: 2rem; - margin-right: 1rem; - padding: 0; - - &:hover { - background-color: transparent; - } -} - -.labeled_button, -.labeled_select { - float: right; - width: 9rem; - margin-top: 0.5rem; -} - -.labeled_select { - font-size: var(--fs-body-2); /* from legacy --font-body-2-dark */ - font-weight: var(--fw-regular); /* from legacy --font-body-2-dark */ - color: var(--c-font-dark); /* from legacy --font-body-2-dark */ -} - -.labeled_checkbox { - float: right; -} - -.stacked_control_info { - font-size: var(--fs-body-1); /* from legacy --font-body-1-dark */ - font-weight: var(--fw-regular); /* from legacy --font-body-1-dark */ - color: var(--c-font-dark); /* from legacy --font-body-1-dark */ - - & > p { - margin-top: 0.5rem; - margin-bottom: 0; - line-height: 1.5; - } -} - -.control_info { - font-size: var(--fs-body-1); /* from legacy --font-body-1-dark */ - font-weight: var(--fw-regular); /* from legacy --font-body-1-dark */ - color: var(--c-font-dark); /* from legacy --font-body-1-dark */ - max-width: var(--mw-labeled-toggle); - - & > p { - margin-top: 0.5rem; - margin-bottom: 0; - line-height: 1.5; - } -} diff --git a/components/src/forms/Select.module.css b/components/src/forms/Select.module.css deleted file mode 100644 index 0905084b931..00000000000 --- a/components/src/forms/Select.module.css +++ /dev/null @@ -1,118 +0,0 @@ -/* stylelint-disable selector-class-pattern */ -@import '../index.module.css'; - -/* NOTE(mc, 2021-04-27): this class only used by storybook */ -.example_select_override { - & :global(.ot_select__control) { - background-color: blue; - } -} - -.select { - position: relative; - - & :global(.ot_select__control) { - font-size: var(--fs-body-1); /* from legacy --font-body-1-dark */ - font-weight: var(--fw-regular); /* from legacy --font-body-1-dark */ - color: var(--c-font-dark); /* from legacy --font-body-1-dark */ - display: flex; - position: relative; - background-color: var(--c-light-gray); - border: none; - padding: 0.25rem 0; - outline: none; - border-radius: var(--bd-radius-form-field); - height: 1.75rem; - box-shadow: none; - } - - & :global(.ot_select__control--menu-is-open) { - border-bottom-left-radius: 0; - border-bottom-right-radius: 0; - } - - & :global(.ot_select__control--menu-is-open), - & :global(.ot_select__control--is-focused) { - background-color: var(--c-white); - box-shadow: 0 0.125rem 0.25rem 0 color-mod(var(--c-black) alpha(0.5)); - } - - & :global(.ot_select__option) { - display: flex; - padding: 0.25rem 0.75rem; - cursor: default; - } - - & :global(.ot_select__option--is-focused) { - background-color: var(--c-light-gray); - } - - & :global(.ot_select__option--is-disabled) { - color: var(--c-font-disabled); - } - - & :global(.ot_select__group-heading) { - font-size: var(--fs-caption); /* from legacy --font-form-caption */ - font-weight: var(--fw-semibold); /* from legacy --font-form-caption */ - color: var(--c-med-gray); /* from legacy --font-form-caption */ - text-transform: uppercase; - margin-left: 0.5rem; - } - - & :global(.ot_select__single-value) { - display: flex; - } - - & :global(.ot_select__group):not(:first-child) { - margin-top: 0.25rem; - border-top: 1px solid color-mod(var(--c-med-gray) alpha(0.4)); - padding-top: 0.25rem; - } -} - -.dropdown_indicator { - position: absolute; - top: 0.25rem; - right: 0.25rem; - width: 1.25rem; - pointer-events: none; - - & > svg { - color: var(--c-dark-gray); - } - - &.flipped > svg { - transform: rotate(180deg); - } -} - -.dropdown_indicator_icon { - width: 100%; -} - -.menu { - font-size: var(--fs-body-1); /* from legacy --font-body-1-dark */ - font-weight: var(--fw-regular); /* from legacy --font-body-1-dark */ - color: var(--c-font-dark); /* from legacy --font-body-1-dark */ - position: absolute; - top: 100%; - left: 0; - right: 0; - z-index: 99; - background-color: var(--c-white); - box-shadow: 0 0.125rem 0.25rem 0 color-mod(var(--c-black) alpha(0.5)); - border-bottom-left-radius: var(--bd-radius-form-field); - border-bottom-right-radius: var(--bd-radius-form-field); - padding-top: 0.25rem; - padding-bottom: 0.25rem; -} - -.menu_control_bridge { - position: absolute; - background-color: var(--c-white); - top: calc(100% - 2px); - left: 0; - right: 0; - z-index: 99; - height: 4px; -} diff --git a/components/src/forms/SelectField.module.css b/components/src/forms/SelectField.module.css deleted file mode 100644 index fa5b709f6c8..00000000000 --- a/components/src/forms/SelectField.module.css +++ /dev/null @@ -1,16 +0,0 @@ -@import '@opentrons/components/styles'; - -.select_field.error { - & :global(.ot_select__control) { - background-color: var(--c-warning-light); - } -} - -.select_caption { - font-size: var(--fs-caption); - - &.error { - color: var(--c-warning-dark); - font-weight: var(--fw-semibold); - } -} diff --git a/components/src/forms/__tests__/DeprecatedCheckboxField.test.tsx b/components/src/forms/__tests__/DeprecatedCheckboxField.test.tsx deleted file mode 100644 index aee3a745784..00000000000 --- a/components/src/forms/__tests__/DeprecatedCheckboxField.test.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { describe, it } from 'vitest' - -describe('DeprecatedCheckboxField', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/forms/__tests__/DropdownField.test.tsx b/components/src/forms/__tests__/DropdownField.test.tsx deleted file mode 100644 index 7e39375e08e..00000000000 --- a/components/src/forms/__tests__/DropdownField.test.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { describe, it } from 'vitest' - -describe('DropdownField', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/forms/__tests__/InputField.test.tsx b/components/src/forms/__tests__/InputField.test.tsx deleted file mode 100644 index 7c385f0d3d3..00000000000 --- a/components/src/forms/__tests__/InputField.test.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { describe, it } from 'vitest' - -describe('InputField', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/forms/__tests__/Select.test.tsx b/components/src/forms/__tests__/Select.test.tsx deleted file mode 100644 index 15d79208764..00000000000 --- a/components/src/forms/__tests__/Select.test.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { describe, it } from 'vitest' - -describe('Select', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/forms/__tests__/SelectField.test.tsx b/components/src/forms/__tests__/SelectField.test.tsx deleted file mode 100644 index 1f0d14e7744..00000000000 --- a/components/src/forms/__tests__/SelectField.test.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { describe, it } from 'vitest' - -describe('SelectField', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/forms/__tests__/ToggleField.test.tsx b/components/src/forms/__tests__/ToggleField.test.tsx deleted file mode 100644 index 93e459a6824..00000000000 --- a/components/src/forms/__tests__/ToggleField.test.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { describe, it } from 'vitest' - -describe('ToggleField', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/forms/forms.module.css b/components/src/forms/forms.module.css deleted file mode 100644 index 6e52c8e68c3..00000000000 --- a/components/src/forms/forms.module.css +++ /dev/null @@ -1,239 +0,0 @@ -@import '../index.module.css'; - -.accessibly_hidden { - position: absolute; - overflow: hidden; - clip: rect(0 0 0 0); - height: 1px; - width: 1px; - margin: -1px; - padding: 0; - border: 0; -} - -.form_field { - font-size: var(--fs-body-1); /* from legacy --font-form-default */ - font-weight: var(--fw-regular); /* from legacy --font-form-default */ - color: var(--c-font-dark); /* from legacy --font-form-default */ - display: flex; - align-items: center; - line-height: 1; -} - -.label_text { - flex: 0 0 auto; - padding: 0 0.5rem; - - &:empty { - padding: 0; - } -} - -.form_group_label { - font-size: var(--fs-body-1); /* from legacy --font-form-default */ - color: var(--c-font-dark); /* from legacy --font-form-default */ - font-weight: var(--fw-semibold); - margin-bottom: 0.15rem; - text-transform: capitalize; - - &::after { - content: ':'; - } -} - -.form_group_label_pipette_settings_slideout { - font-weight: var(--fw-semibold); - margin-bottom: 0.5rem; - text-transform: capitalize; - font-size: 13px; - color: #16212d; -} - -.checkbox_icon { - /* Icon for radiobutton and for checkbox */ - width: 1.25rem; - min-width: 1.25rem; - color: var(--c-font-dark); - display: flex; - justify-content: center; - align-items: center; - - &:not(.checkbox_disabled):hover { - cursor: pointer; - } - - &.error { - color: var(--c-warning-dark); - } -} - -.checkbox_icon.checked { - color: var(--c-blue); -} - -.toggle_icon { - /* Icon for radiobutton and for checkbox */ - display: block; - width: 2rem; - min-width: 2rem; - color: var(--c-font-dark); - - &:not(.toggle_disabled):hover { - cursor: pointer; - } -} - -.dropdown_disabled, -.checkbox_disabled, -.toggle_disabled { - opacity: 0.5; -} - -.input_field_container { - width: 100%; -} - -.input_field { - display: flex; - flex: 1 1; - background-color: var(--c-light-gray); - border-radius: var(--bd-radius-form-field); - padding: 0.25rem 0.25rem 0.25rem 0.5rem; - - & input { - font-size: var(--fs-body-1); /* from legacy --font-form-default */ - font-weight: var(--fw-regular); /* from legacy --font-form-default */ - color: var(--c-font-dark); /* from legacy --font-form-default */ - background-color: inherit; - border-radius: inherit; - border: none; - flex: 1 1 auto; - width: 100%; - height: 1rem; - - /* TODO: Ian 2018-09-14 Firefox has 1px padding on input element, - * but I can't figure out how to fix it in Firefox without breaking it in Chrome. - * Better CSS reset for inputs needed? - */ - - /* padding: 1px; */ - } - - & input:focus { - outline: none; - } - - & input::placeholder { - color: var(--c-med-gray); - } - - &:focus-within { - background-color: var(--c-white); - box-shadow: 0 0.125rem 0.25rem 0 color-mod(var(--c-black) alpha(0.5)); - } - - & .suffix { - font-size: var(--fs-body-1); /* from legacy --font-form-default */ - color: var(--c-font-dark); /* from legacy --font-form-default */ - font-weight: var(--fw-semibold); - display: inline-block; - flex: 1 0; - text-align: right; - align-self: center; - } -} - -.input_caption { - font-size: var(--fs-caption); /* from legacy --font-form-caption */ - font-weight: var(--fw-semibold); /* from legacy --font-form-caption */ - color: var(--c-med-gray); /* from legacy --font-form-caption */ - line-height: 1.2; - - & .right { - float: right; - } -} - -.inline { - display: flex; - - & .label_text { - padding-right: 1.5rem; - } -} - -.inline_item { - flex: 1; -} - -.error div, -.error span { - color: var(--c-warning-dark); -} - -.error select, -.error .input_field { - background-color: var(--c-warning-light); -} - -.dropdown { - background-color: var(--c-light-gray); -} - -.dropdown_field { - position: relative; - - & select { - font-size: var(--fs-body-1); /* from legacy --font-form-default */ - font-weight: var(--fw-regular); /* from legacy --font-form-default */ - color: var(--c-font-dark); /* from legacy --font-form-default */ - border: 0; - padding: 0.25rem 0.5rem; - outline: none; - height: 1.5rem; - border-radius: var(--bd-radius-form-field); - font-family: inherit; - width: 100%; - appearance: none; - overflow: hidden; - - &:focus { - background-color: var(--c-white); - box-shadow: 0 0.125rem 0.25rem 0 color-mod(var(--c-black) alpha(0.5)); - } - } - - & .dropdown_icon { - position: absolute; - top: 0.2rem; - right: 0.25rem; - width: 1.25rem; - pointer-events: none; - - & svg { - color: var(--c-dark-gray); - } - } -} - -.error_icon { - display: inline-block; - width: 1.5rem; - min-width: 1.5rem; - padding-right: 0.5rem; -} - -.disabled { - /* Disable mouse interaction. NOTE: User can still tab to focus a field */ - pointer-events: none; - - & .form_group_label { - color: var(--c-light-gray); - } - - /* stylelint-disable no-descending-specificity */ - & input, - & .suffix { - color: var(--c-med-gray); - } -} diff --git a/components/src/hardware-sim/BaseDeck/something.test.tsx b/components/src/hardware-sim/BaseDeck/something.test.tsx new file mode 100644 index 00000000000..c13f1494c93 --- /dev/null +++ b/components/src/hardware-sim/BaseDeck/something.test.tsx @@ -0,0 +1,7 @@ +import { describe, it, expect } from 'vitest' + +describe('test', () => { + it('should pass', () => { + expect(true).toBe(true) + }) +}) diff --git a/components/src/hardware-sim/Deck/SlotLabels.tsx b/components/src/hardware-sim/Deck/SlotLabels.tsx index 7a14d6215ec..5d47ae9c22a 100644 --- a/components/src/hardware-sim/Deck/SlotLabels.tsx +++ b/components/src/hardware-sim/Deck/SlotLabels.tsx @@ -1,5 +1,5 @@ import { FLEX_ROBOT_TYPE } from '@opentrons/shared-data' -import { DeckInfoLabel } from '../../molecules' +import { DeckInfoLabel } from '../../molecules/DeckInfoLabel' import { Flex } from '../../primitives' import { ALIGN_CENTER, DIRECTION_COLUMN, JUSTIFY_CENTER } from '../../styles' import { RobotCoordsForeignObject } from './RobotCoordsForeignObject' diff --git a/components/src/hardware-sim/Labware/__tests__/Labware.test.tsx b/components/src/hardware-sim/Labware/__tests__/Labware.test.tsx deleted file mode 100644 index cf2060bbe68..00000000000 --- a/components/src/hardware-sim/Labware/__tests__/Labware.test.tsx +++ /dev/null @@ -1,43 +0,0 @@ -import { describe, it, vi, beforeEach } from 'vitest' -import { render, screen } from '@testing-library/react' -import '@testing-library/jest-dom/vitest' -import { fixture12Trough } from '@opentrons/shared-data' -import { - LabwareOutline, - LabwareWellLabelsComponent as LabwareWellLabels, -} from '../labwareInternals' -import { Labware } from '../Labware' -import type { LabwareDefinition2 } from '@opentrons/shared-data' - -vi.mock('../labwareInternals') - -const troughFixture12 = fixture12Trough as LabwareDefinition2 - -describe('Labware', () => { - beforeEach(() => { - vi.mocked(LabwareOutline).mockReturnValue(
mock labware outline
) - }) - - it('should render a labware outline', () => { - const props = { definition: troughFixture12 } - render( - - - - ) - screen.getByText('mock labware outline') - }) - it('should render well labels', () => { - const props = { - definition: troughFixture12, - showLabels: true, - } - vi.mocked(LabwareWellLabels).mockReturnValue(
mock well labels
) - render( - - - - ) - screen.getByText('mock well labels') - }) -}) diff --git a/components/src/hardware-sim/Labware/__tests__/LabwareRender.test.tsx b/components/src/hardware-sim/Labware/__tests__/LabwareRender.test.tsx deleted file mode 100644 index 65a0edebdfd..00000000000 --- a/components/src/hardware-sim/Labware/__tests__/LabwareRender.test.tsx +++ /dev/null @@ -1,54 +0,0 @@ -import { describe, it, vi, beforeEach } from 'vitest' -import { render, screen } from '@testing-library/react' -import '@testing-library/jest-dom/vitest' -import { fixture12Trough } from '@opentrons/shared-data' -import { - StaticLabwareComponent as StaticLabware, - WellLabelsComponent as WellLabels, - StrokedWellsComponent as StrokedWells, -} from '../labwareInternals' -import { LabwareRender, WELL_LABEL_OPTIONS } from '../LabwareRender' -import type { LabwareDefinition2 } from '@opentrons/shared-data' - -vi.mock('../labwareInternals') - -const troughFixture12 = fixture12Trough as LabwareDefinition2 - -describe('LabwareRender', () => { - beforeEach(() => { - vi.mocked(StaticLabware).mockReturnValue(
mock static labware
) - }) - - it('should render a static labware component', () => { - const props = { definition: troughFixture12 } - render( - - - - ) - screen.getByText('mock static labware') - }) - it('should render stroked wells', () => { - const props = { definition: troughFixture12, wellStroke: { A1: 'blue' } } - vi.mocked(StrokedWells).mockReturnValue(
mock stroked wells
) - render( - - - - ) - screen.getByText('mock stroked wells') - }) - it('should render well labels', () => { - const props = { - definition: troughFixture12, - wellLabelOption: WELL_LABEL_OPTIONS.SHOW_LABEL_INSIDE, - } - vi.mocked(WellLabels).mockReturnValue(
mock well labels
) - render( - - - - ) - screen.getByText('mock well labels') - }) -}) diff --git a/components/src/hardware-sim/Labware/labwareInternals/__tests__/LabwareWellLabels.test.tsx b/components/src/hardware-sim/Labware/labwareInternals/__tests__/LabwareWellLabels.test.tsx deleted file mode 100644 index 88bd32a295a..00000000000 --- a/components/src/hardware-sim/Labware/labwareInternals/__tests__/LabwareWellLabels.test.tsx +++ /dev/null @@ -1,66 +0,0 @@ -import { describe, it, expect } from 'vitest' -import { render, screen } from '@testing-library/react' -import '@testing-library/jest-dom/vitest' -import { fixture12Trough as _fixture12Trough } from '@opentrons/shared-data' -import { LabwareWellLabels } from '../LabwareWellLabels' - -import type { LabwareDefinition2 } from '@opentrons/shared-data' - -const troughFixture12 = _fixture12Trough as LabwareDefinition2 - -describe('LabwareWellLabels', () => { - it('should render well labels', () => { - const props = { - definition: troughFixture12, - } - render( - - - - ) - - screen.getByText('A') - new Array(12) - .fill(null) - .forEach((_, index) => screen.getByText(`${index + 1}`)) - }) - it('should highlight the well labels with the given color', () => { - expect.assertions(13) // there should be 13 highlighted well labels - const props = { - definition: troughFixture12, - highlightedWellLabels: { - wells: Object.keys(troughFixture12.wells as Record), - color: 'blue', - }, - } - render( - - - - ) - const letterWellLabel = screen.getByText('A') - expect(letterWellLabel.getAttribute('fill')).toBe('blue') - new Array(12).fill(null).forEach((_, index) => { - const numberWellLabel = screen.getByText(`${index + 1}`) - expect(numberWellLabel.getAttribute('fill')).toBe('blue') - }) - }) - it('should color the well labels', () => { - expect.assertions(13) // there should be 13 well labels - const props = { - definition: troughFixture12, - wellLabelColor: 'red', - } - render( - - - - ) - const letterWellLabel = screen.getByText('A') - expect(letterWellLabel.getAttribute('fill')).toBe('red') - new Array(12).fill(null).forEach((_, index) => { - const numberWellLabel = screen.getByText(`${index + 1}`) - expect(numberWellLabel.getAttribute('fill')).toBe('red') - }) - }) -}) diff --git a/components/src/hardware-sim/Labware/labwareInternals/__tests__/StrokedWells.test.tsx b/components/src/hardware-sim/Labware/labwareInternals/__tests__/StrokedWells.test.tsx deleted file mode 100644 index ed76a64f206..00000000000 --- a/components/src/hardware-sim/Labware/labwareInternals/__tests__/StrokedWells.test.tsx +++ /dev/null @@ -1,31 +0,0 @@ -import { describe, it, vi } from 'vitest' -import { render, screen } from '@testing-library/react' -import '@testing-library/jest-dom/vitest' -import { fixture12Trough } from '@opentrons/shared-data' -import { StrokedWells } from '../StrokedWells' -import { WellComponent as Well } from '../Well' -import type { LabwareDefinition2 } from '@opentrons/shared-data' - -vi.mock('../Well') - -const troughFixture12 = fixture12Trough as LabwareDefinition2 - -describe('StrokedWells', () => { - it('should render a series of wells with the given stroke', () => { - vi.mocked(Well).mockImplementation(({ stroke, wellName }) => - // eslint-disable-next-line @typescript-eslint/restrict-template-expressions - { - return
{`well ${wellName} with stroke ${stroke}`}
- } - ) - - render( - - ) - screen.getByText('well A1 with stroke blue') - screen.getByText('well A2 with stroke blue') - }) -}) diff --git a/components/src/hardware-sim/Labware/labwareInternals/__tests__/WellLabels.test.tsx b/components/src/hardware-sim/Labware/labwareInternals/__tests__/WellLabels.test.tsx deleted file mode 100644 index dc8af68a6c5..00000000000 --- a/components/src/hardware-sim/Labware/labwareInternals/__tests__/WellLabels.test.tsx +++ /dev/null @@ -1,91 +0,0 @@ -import { describe, it, expect } from 'vitest' -import { render, screen } from '@testing-library/react' -import '@testing-library/jest-dom/vitest' -import { fixture12Trough as _fixture12Trough } from '@opentrons/shared-data' -import { WellLabels } from '../WellLabels' -import { WELL_LABEL_OPTIONS } from '../../LabwareRender' -import type { LabwareDefinition2 } from '@opentrons/shared-data' - -const troughFixture12 = _fixture12Trough as LabwareDefinition2 - -describe('WellLabels', () => { - it('should render well labels outside of the labware', () => { - expect.assertions(14) - const props = { - definition: troughFixture12, - wellLabelOption: WELL_LABEL_OPTIONS.SHOW_LABEL_INSIDE, - } - render( - - - - ) - const wellLabels = screen.getAllByTestId('WellsLabels_show_inside') - expect(wellLabels.length).toBe(13) // 1 label for the single "A" row + 12 labels for the trough columns - expect(wellLabels[0]).toHaveTextContent('A') - // assertions for each of the numbered columns, skipping the first well label which has the letter row - new Array(12) - .fill(null) - .forEach((_, index) => - expect(wellLabels[index + 1]).toHaveTextContent(`${index + 1}`) - ) - }) - it('should render well labels inside of the labware', () => { - expect.assertions(14) - const props = { - definition: troughFixture12, - wellLabelOption: WELL_LABEL_OPTIONS.SHOW_LABEL_OUTSIDE, - } - render( - - - - ) - const wellLabels = screen.getAllByTestId('WellsLabels_show_outside') - expect(wellLabels.length).toBe(13) // 1 label for the single "A" row + 12 labels for the trough columns - expect(wellLabels[0]).toHaveTextContent('A') - // assertions for each of the numbered columns, skipping the first well label which has the letter row - new Array(12) - .fill(null) - .forEach((_, index) => - expect(wellLabels[index + 1]).toHaveTextContent(`${index + 1}`) - ) - }) - it('should highlight the well labels with the given color', () => { - expect.assertions(13) // there should be 13 highlighted well labels - const props = { - definition: troughFixture12, - wellLabelOption: WELL_LABEL_OPTIONS.SHOW_LABEL_OUTSIDE, - highlightedWellLabels: { - wells: Object.keys(troughFixture12.wells), - color: 'blue', - }, - } - render( - - - - ) - const wellLabels = screen.getAllByTestId('WellsLabels_show_outside') - wellLabels.forEach(wellLabel => - expect(wellLabel.getAttribute('fill')).toBe('blue') - ) - }) - it('should color the well labels', () => { - expect.assertions(13) // there should be 13 highlighted well labels - const props = { - definition: troughFixture12, - wellLabelOption: WELL_LABEL_OPTIONS.SHOW_LABEL_OUTSIDE, - wellLabelColor: 'red', - } - render( - - - - ) - const wellLabels = screen.getAllByTestId('WellsLabels_show_outside') - wellLabels.forEach(wellLabel => - expect(wellLabel.getAttribute('fill')).toBe('red') - ) - }) -}) diff --git a/components/src/hardware-sim/Pipette/__tests__/EightEmanatingNozzles.test.tsx b/components/src/hardware-sim/Pipette/__tests__/EightEmanatingNozzles.test.tsx deleted file mode 100644 index c1b18c65b8b..00000000000 --- a/components/src/hardware-sim/Pipette/__tests__/EightEmanatingNozzles.test.tsx +++ /dev/null @@ -1,16 +0,0 @@ -import { describe, it, expect, vi, beforeEach } from 'vitest' -import { render } from '@testing-library/react' -import { EightEmanatingNozzles } from '../EightEmanatingNozzles' -import { EmanatingNozzle } from '../EmanatingNozzle' - -vi.mock('../EmanatingNozzle') - -describe('EightEmanatingNozzles', () => { - beforeEach(() => { - vi.mocked(EmanatingNozzle).mockReturnValue(
mock emanating nozzle
) - }) - it('should render eight emanating nozzles', () => { - render() - expect(EmanatingNozzle).toHaveBeenCalledTimes(8) - }) -}) diff --git a/components/src/hardware-sim/Pipette/__tests__/EmanatingNozzle.test.tsx b/components/src/hardware-sim/Pipette/__tests__/EmanatingNozzle.test.tsx deleted file mode 100644 index fcc1f2ae10f..00000000000 --- a/components/src/hardware-sim/Pipette/__tests__/EmanatingNozzle.test.tsx +++ /dev/null @@ -1,67 +0,0 @@ -import { describe, it, expect } from 'vitest' -import { render, screen } from '@testing-library/react' -import { C_SELECTED_DARK, C_TRANSPARENT } from '../../../styles' -import { EmanatingNozzle } from '../EmanatingNozzle' -import { SINGLE_CHANNEL_PIPETTE_HEIGHT } from '../constants' - -describe('EmanatingNozzle', () => { - it('should render an small origin circle', () => { - render( - - - - ) - const originCircle = screen.getByTestId('origin_circle') - expect(originCircle).toHaveAttribute('cx', '5') - expect(originCircle).toHaveAttribute('cy', '10') - expect(originCircle).toHaveAttribute('r', '0.5') - expect(originCircle).toHaveAttribute('stroke', C_SELECTED_DARK) - expect(originCircle).toHaveAttribute('fill', C_SELECTED_DARK) - }) - it('should render a medium sized animating circle', () => { - render( - - - - ) - const emanatingCircle = screen.getByTestId('emanating_circle') - expect(emanatingCircle).toHaveAttribute('cx', '5') - expect(emanatingCircle).toHaveAttribute('cy', '10') - expect(emanatingCircle).toHaveAttribute('r', '0.5') - expect(emanatingCircle).toHaveAttribute('stroke', C_SELECTED_DARK) - expect(emanatingCircle).toHaveAttribute('fill', C_TRANSPARENT) - }) - it('should render a medium sized animating circle that grows', () => { - render( - - - - ) - const radiusAnimation = screen.getByTestId('radius_animation') - expect(radiusAnimation).toHaveAttribute('attributeName', 'r') - expect(radiusAnimation).toHaveAttribute('from', '5') - expect(radiusAnimation).toHaveAttribute( - 'to', - (SINGLE_CHANNEL_PIPETTE_HEIGHT / 2).toString() - ) - expect(radiusAnimation).toHaveAttribute('begin', '0') - expect(radiusAnimation).toHaveAttribute('dur', '1.1') - expect(radiusAnimation).toHaveAttribute('calcMode', 'ease-out') - expect(radiusAnimation).toHaveAttribute('repeatCount', 'indefinite') - }) - it('should render a medium sized animating circle that fades out', () => { - render( - - - - ) - const opacityAnimation = screen.getByTestId('opacity_animation') - expect(opacityAnimation).toHaveAttribute('attributeName', 'opacity') - expect(opacityAnimation).toHaveAttribute('from', '0.7') - expect(opacityAnimation).toHaveAttribute('to', '0') - expect(opacityAnimation).toHaveAttribute('begin', '0') - expect(opacityAnimation).toHaveAttribute('dur', '1.1') - expect(opacityAnimation).toHaveAttribute('calcMode', 'linear') - expect(opacityAnimation).toHaveAttribute('repeatCount', 'indefinite') - }) -}) diff --git a/components/src/hardware-sim/Pipette/__tests__/PipetteRender.test.tsx b/components/src/hardware-sim/Pipette/__tests__/PipetteRender.test.tsx deleted file mode 100644 index bf94221fe37..00000000000 --- a/components/src/hardware-sim/Pipette/__tests__/PipetteRender.test.tsx +++ /dev/null @@ -1,99 +0,0 @@ -import type * as React from 'react' -import { describe, it, expect, vi, beforeEach } from 'vitest' -import { screen } from '@testing-library/react' -import { fixtureTiprack300ul as _fixtureTiprack300ul } from '@opentrons/shared-data' -import { renderWithProviders } from '../../../testing/utils' -import { RobotCoordsForeignDiv } from '../../Deck/RobotCoordsForeignDiv' -import { PipetteRender } from '../PipetteRender' -import { EmanatingNozzle } from '../EmanatingNozzle' -import { EightEmanatingNozzles } from '../EightEmanatingNozzles' -import { - SINGLE_CHANNEL_PIPETTE_WIDTH, - SINGLE_CHANNEL_PIPETTE_HEIGHT, - MULTI_CHANNEL_PIPETTE_WIDTH, - MULTI_CHANNEL_PIPETTE_HEIGHT, -} from '../constants' - -import type { LabwareDefinition2 } from '@opentrons/shared-data' - -vi.mock('../../Deck/RobotCoordsForeignDiv') -vi.mock('../EmanatingNozzle') -vi.mock('../EightEmanatingNozzles') - -const fixtureTiprack300Ul = _fixtureTiprack300ul as LabwareDefinition2 - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('PipetteRender', () => { - let props: React.ComponentProps - beforeEach(() => { - props = { - labwareDef: fixtureTiprack300Ul, - pipetteName: 'p1000_single', - } - vi.mocked(RobotCoordsForeignDiv).mockReturnValue(
) - }) - - describe('when the pipette is single channel', () => { - beforeEach(() => { - vi.mocked(RobotCoordsForeignDiv).mockImplementation(({ children }) => ( -
- {`rectangle with width ${SINGLE_CHANNEL_PIPETTE_WIDTH} and height ${SINGLE_CHANNEL_PIPETTE_HEIGHT}`}{' '} - {children} -
- )) - - vi.mocked(EmanatingNozzle).mockReturnValue( -
mock emanating nozzle
- ) - }) - - it('should render a rectangle with the correct dimensions', () => { - render(props) - screen.getByText( - `rectangle with width ${SINGLE_CHANNEL_PIPETTE_WIDTH} and height ${SINGLE_CHANNEL_PIPETTE_HEIGHT}` - ) - vi.mocked(EmanatingNozzle).mockRestore() - }) - it('should render a single emanating nozzle', () => { - render(props) - screen.getByText('mock emanating nozzle') - expect(EightEmanatingNozzles).not.toHaveBeenCalled() - }) - }) - describe('when the pipette is 8 channel', () => { - beforeEach(() => { - vi.mocked(RobotCoordsForeignDiv).mockImplementation(({ children }) => ( -
- {`rectangle with width ${MULTI_CHANNEL_PIPETTE_WIDTH} and height ${MULTI_CHANNEL_PIPETTE_HEIGHT}`}{' '} - {children} -
- )) - - vi.mocked(EightEmanatingNozzles).mockReturnValue( -
mock eight emanating nozzles
- ) - }) - it('should render a rectangle with the correct dimensions', () => { - props = { - ...props, - pipetteName: 'p10_multi', - } - render(props) - screen.getByText( - `rectangle with width ${MULTI_CHANNEL_PIPETTE_WIDTH} and height ${MULTI_CHANNEL_PIPETTE_HEIGHT}` - ) - vi.mocked(EightEmanatingNozzles).mockRestore() - }) - it('should render eight emanating nozzles', () => { - props = { - ...props, - pipetteName: 'p10_multi', - } - render(props) - screen.getByText('mock eight emanating nozzles') - }) - }) -}) diff --git a/components/src/hardware-sim/ProtocolDeck/LabwareInfo.tsx b/components/src/hardware-sim/ProtocolDeck/LabwareInfo.tsx index d8c9b44a9f1..87d145b320c 100644 --- a/components/src/hardware-sim/ProtocolDeck/LabwareInfo.tsx +++ b/components/src/hardware-sim/ProtocolDeck/LabwareInfo.tsx @@ -1,7 +1,7 @@ import type * as React from 'react' import { css } from 'styled-components' -import { RobotCoordsForeignDiv } from '../Deck' +import { RobotCoordsForeignDiv } from '../Deck/RobotCoordsForeignDiv' import { DISPLAY_FLEX, DIRECTION_COLUMN, diff --git a/components/src/hardware-sim/ProtocolDeck/index.tsx b/components/src/hardware-sim/ProtocolDeck/index.tsx index 20c3a0c990b..a25cdb35d24 100644 --- a/components/src/hardware-sim/ProtocolDeck/index.tsx +++ b/components/src/hardware-sim/ProtocolDeck/index.tsx @@ -7,9 +7,9 @@ import { getTopLabwareInfo, } from '@opentrons/shared-data' -import { BaseDeck } from '../BaseDeck' +import { BaseDeck } from '../BaseDeck/BaseDeck' import { LabwareInfo } from './LabwareInfo' -import { getStandardDeckViewLayerBlockList } from './utils' +import { getStandardDeckViewLayerBlockList } from './utils/getStandardDeckViewLayerBlockList' import { getLabwareInfoByLiquidId } from './utils/getLabwareInfoByLiquidId' import { getTopMostLabwareInSlots } from './utils/getLabwareInSlots' import { getModulesInSlots } from './utils/getModulesInSlots' diff --git a/components/src/hardware-sim/ProtocolDeck/utils/__tests__/getLabwareInforByLiquidId.test.ts b/components/src/hardware-sim/ProtocolDeck/utils/__tests__/getLabwareInforByLiquidId.test.ts deleted file mode 100644 index 23ae614167c..00000000000 --- a/components/src/hardware-sim/ProtocolDeck/utils/__tests__/getLabwareInforByLiquidId.test.ts +++ /dev/null @@ -1,158 +0,0 @@ -import { describe, it, expect } from 'vitest' -import { getLabwareInfoByLiquidId } from '../getLabwareInfoByLiquidId' -import type { RunTimeCommand } from '@opentrons/shared-data' - -const mockLoadLiquidRunTimeCommands = [ - { - id: '97ba49a5-04f6-4f91-986a-04a0eb632882', - createdAt: '2022-09-07T19:47:42.781065+00:00', - commandType: 'loadPipette', - key: '0feeecaf-3895-46d7-ab71-564601265e35', - status: 'succeeded', - params: { - pipetteName: 'p20_single_gen2', - mount: 'left', - pipetteId: '90183a18-a1df-4fd6-9636-be3bcec63fe4', - }, - result: { - pipetteId: '90183a18-a1df-4fd6-9636-be3bcec63fe4', - }, - startedAt: '2022-09-07T19:47:42.782665+00:00', - completedAt: '2022-09-07T19:47:42.785061+00:00', - }, - { - id: '846e0b7b-1e54-4f42-9ab1-964ebda45da5', - createdAt: '2022-09-07T19:47:42.781281+00:00', - commandType: 'loadLiquid', - key: '1870d1a2-8dcd-46f2-9e27-16578365913b', - status: 'succeeded', - params: { - liquidId: '1', - labwareId: 'mockLabwareId1', - volumeByWell: { - A2: 20, - B2: 20, - C2: 20, - D2: 20, - E2: 20, - F2: 20, - G2: 20, - H2: 20, - }, - }, - result: {}, - startedAt: '2022-09-07T19:47:42.785987+00:00', - completedAt: '2022-09-07T19:47:42.786087+00:00', - }, - { - id: '1e03ae10-7e9b-465c-bc72-21ab5706bfb0', - createdAt: '2022-09-07T19:47:42.781323+00:00', - commandType: 'loadLiquid', - key: '48df9766-04ff-4927-9f2d-4efdcf0b3df8', - status: 'succeeded', - params: { - liquidId: '1', - labwareId: 'mockLabwareId2', - volumeByWell: { - D3: 40, - }, - }, - result: {}, - startedAt: '2022-09-07T19:47:42.786212+00:00', - completedAt: '2022-09-07T19:47:42.786285+00:00', - }, - { - id: '1e03ae10-7e9b-465c-bc72-21ab5706bfb0', - createdAt: '2022-09-07T19:47:42.781323+00:00', - commandType: 'loadLiquid', - key: '48df9766-04ff-4927-9f2d-4efdcf0b3df8', - status: 'succeeded', - params: { - liquidId: '1', - labwareId: 'mockLabwareId2', - volumeByWell: { - A3: 33, - B3: 33, - C3: 33, - }, - }, - result: {}, - startedAt: '2022-09-07T19:47:42.786212+00:00', - completedAt: '2022-09-07T19:47:42.786285+00:00', - }, - { - id: 'e8596bb3-b650-4d62-9bb5-dfc6e9e63249', - createdAt: '2022-09-07T19:47:42.781363+00:00', - commandType: 'loadLiquid', - key: '69d19b03-fdcc-4964-a2f8-3cbb30f4ddf3', - status: 'succeeded', - params: { - liquidId: '0', - labwareId: 'mockLabwareId1', - volumeByWell: { - A1: 33, - B1: 33, - C1: 33, - D1: 33, - E1: 33, - F1: 33, - G1: 33, - H1: 33, - }, - }, - result: {}, - startedAt: '2022-09-07T19:47:42.786347+00:00', - completedAt: '2022-09-07T19:47:42.786412+00:00', - }, -] - -describe('getLabwareInfoByLiquidId', () => { - it('returns labware info by liquid id', () => { - const expected = { - '0': [ - { - labwareId: 'mockLabwareId1', - volumeByWell: { - A1: 33, - B1: 33, - C1: 33, - D1: 33, - E1: 33, - F1: 33, - G1: 33, - H1: 33, - }, - }, - ], - '1': [ - { - labwareId: 'mockLabwareId1', - volumeByWell: { - A2: 20, - B2: 20, - C2: 20, - D2: 20, - E2: 20, - F2: 20, - G2: 20, - H2: 20, - }, - }, - { - labwareId: 'mockLabwareId2', - volumeByWell: { - A3: 33, - B3: 33, - C3: 33, - D3: 40, - }, - }, - ], - } - expect( - getLabwareInfoByLiquidId( - mockLoadLiquidRunTimeCommands as RunTimeCommand[] - ) - ).toEqual(expected) - }) -}) diff --git a/components/src/hooks/__tests__/useConditionalConfirm.test.tsx b/components/src/hooks/__tests__/useConditionalConfirm.test.tsx deleted file mode 100644 index 8405757f4a2..00000000000 --- a/components/src/hooks/__tests__/useConditionalConfirm.test.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { describe, it } from 'vitest' - -describe('useConditionalConfirm', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/hooks/__tests__/useDrag.test.ts b/components/src/hooks/__tests__/useDrag.test.ts deleted file mode 100644 index 38b0d9dc708..00000000000 --- a/components/src/hooks/__tests__/useDrag.test.ts +++ /dev/null @@ -1,46 +0,0 @@ -import { describe, it, expect } from 'vitest' -import { act, renderHook } from '@testing-library/react' -import { useDrag } from '../useDrag' -import type { ElementPosition } from '../useDrag' - -const mockPosition: ElementPosition = { - width: 100, - height: 200, - x: 10, - y: 20, -} - -describe('useDrag', () => { - it('useDrag returns UseDragResult', () => { - const { result } = renderHook(() => useDrag(mockPosition)) - - expect(result.current.position.width).toBe(mockPosition.width) - expect(result.current.position.height).toBe(mockPosition.height) - expect(result.current.position.x).toBe(mockPosition.x) - expect(result.current.position.y).toBe(mockPosition.y) - expect(result.current.style.width).toBe(`${mockPosition.width}px`) - expect(result.current.style.height).toBe(`${mockPosition.height}px`) - expect(result.current.style.touchAction).toBe('none') - expect(result.current.style.transform).toBe( - `translate3D(${mockPosition.x}px, ${mockPosition.y}px, 0)` - ) - expect(result.current.style.position).toBe('absolute') - expect(typeof result.current.isEnabled).toBe('boolean') - }) - - it('When calling enable, isEnabled true', () => { - const { result } = renderHook(() => useDrag(mockPosition)) - act(() => { - result.current.enable() - }) - expect(result.current.isEnabled).toBe(true) - }) - - it('When calling disable, isEnabled false', () => { - const { result } = renderHook(() => useDrag(mockPosition)) - act(() => { - result.current.disable() - }) - expect(result.current.isEnabled).toBe(false) - }) -}) diff --git a/components/src/hooks/__tests__/useIdle.test.ts b/components/src/hooks/__tests__/useIdle.test.ts deleted file mode 100644 index 8063c317325..00000000000 --- a/components/src/hooks/__tests__/useIdle.test.ts +++ /dev/null @@ -1,68 +0,0 @@ -import { describe, it, expect, vi, beforeEach } from 'vitest' -import { renderHook } from '@testing-library/react' -import { useIdle } from '../useIdle' - -const MOCK_EVENTS: Array = [ - 'mousedown', - 'click', - 'scroll', -] - -const MOCK_OPTIONS = { - events: MOCK_EVENTS, - initialState: false, -} - -describe('useIdle', () => { - beforeEach(() => { - vi.useFakeTimers({ shouldAdvanceTime: true }) - }) - - it('should return the default initialState', () => { - const mockTime = 1000 - const { result } = renderHook(() => useIdle(mockTime)) - expect(result.current).toBe(true) - }) - - it('should return the given initialState', () => { - const mockTime = 1000 - const { result } = renderHook(() => useIdle(mockTime, MOCK_OPTIONS)) - expect(result.current).toBe(false) - }) - - it('should return true after 1000ms', () => { - const mockTime = 1000 - const { result } = renderHook(() => useIdle(mockTime, MOCK_OPTIONS)) - expect(result.current).toBe(false) - setTimeout(() => { - expect(result.current).toBe(true) - }, 1001) - }) - - it('should return true after 180,000ms - 3min', () => { - const mockTime = 60 * 1000 * 3 - const { result } = renderHook(() => useIdle(mockTime, MOCK_OPTIONS)) - expect(result.current).toBe(false) - setTimeout(() => { - expect(result.current).toBe(true) - }, 180001) - }) - - it('should return true after 180,0000ms - 30min', () => { - const mockTime = 60 * 1000 * 30 - const { result } = renderHook(() => useIdle(mockTime, MOCK_OPTIONS)) - expect(result.current).toBe(false) - setTimeout(() => { - expect(result.current).toBe(true) - }, 1800001) - }) - - it('should return true after 3,600,000ms - 1 hour', () => { - const mockTime = 60 * 1000 * 60 - const { result } = renderHook(() => useIdle(mockTime, MOCK_OPTIONS)) - expect(result.current).toBe(false) - setTimeout(() => { - expect(result.current).toBe(true) - }, 3600001) - }) -}) diff --git a/components/src/hooks/__tests__/useInterval.test.tsx b/components/src/hooks/__tests__/useInterval.test.tsx deleted file mode 100644 index 49675e8db2a..00000000000 --- a/components/src/hooks/__tests__/useInterval.test.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { describe, it } from 'vitest' - -describe('useInterval hook', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/hooks/__tests__/useLongPress.test.ts b/components/src/hooks/__tests__/useLongPress.test.ts deleted file mode 100644 index f324f5634ff..00000000000 --- a/components/src/hooks/__tests__/useLongPress.test.ts +++ /dev/null @@ -1,25 +0,0 @@ -import { describe, it, expect } from 'vitest' -import { act, renderHook, waitFor } from '@testing-library/react' -import { useLongPress } from '../useLongPress' - -describe('useLongPress', () => { - it('useLongPress returns typeof UseLongPressResult', () => { - const { result } = renderHook(() => useLongPress()) - expect(result.current.style.touchAction).toBe('none') - expect(result.current.isEnabled).toBe(true) - expect(result.current.isLongPressed).toBe(false) - expect(result.current.isTapped).toBe(false) - }) - - it('when callling disable, isEnabled true', () => { - const { result } = renderHook(() => useLongPress()) - act(() => result.current.enable()) - waitFor(() => expect(result.current.isEnabled).toBe(true)) - }) - - it('when callling disable, isEnabled false', () => { - const { result } = renderHook(() => useLongPress()) - act(() => result.current.disable()) - waitFor(() => expect(result.current.isEnabled).toBe(false)) - }) -}) diff --git a/components/src/hooks/__tests__/useMountEffect.test.tsx b/components/src/hooks/__tests__/useMountEffect.test.tsx deleted file mode 100644 index 2614f91101b..00000000000 --- a/components/src/hooks/__tests__/useMountEffect.test.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { describe, it } from 'vitest' - -describe('useMountEffect hook', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/hooks/__tests__/usePrevious.test.tsx b/components/src/hooks/__tests__/usePrevious.test.tsx deleted file mode 100644 index 7f130f2688d..00000000000 --- a/components/src/hooks/__tests__/usePrevious.test.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { describe, it } from 'vitest' - -describe('usePrevious hook', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/hooks/__tests__/useScrolling.test.tsx b/components/src/hooks/__tests__/useScrolling.test.tsx deleted file mode 100644 index 64feb136ca0..00000000000 --- a/components/src/hooks/__tests__/useScrolling.test.tsx +++ /dev/null @@ -1,46 +0,0 @@ -import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest' -import { renderHook, act } from '@testing-library/react' -import { useScrolling } from '../useScrolling' - -describe('useScrolling', () => { - beforeEach(() => { - vi.useFakeTimers() - }) - - afterEach(() => { - vi.resetAllMocks() - vi.clearAllTimers() - vi.useRealTimers() - }) - - it('returns false when there is no scrolling', () => { - const ref = document.createElement('div') - const { result } = renderHook(() => useScrolling(ref)) - expect(result.current).toBe(false) - }) - - it('returns true when scrolling', () => { - const ref = document.createElement('div') - const { result } = renderHook(() => useScrolling(ref)) - ref.scrollTop = 10 - act(() => { - ref.dispatchEvent(new Event('scroll')) - }) - expect(result.current).toBe(true) - }) - - it('returns false after scrolling stops', () => { - vi.useFakeTimers({ shouldAdvanceTime: true }) - const ref = document.createElement('div') - const { result } = renderHook(() => useScrolling(ref)) - ref.scrollTop = 10 - act(() => { - ref.dispatchEvent(new Event('scroll')) - }) - expect(result.current).toBe(true) - act(() => { - vi.advanceTimersByTime(300) - }) - expect(result.current).toBe(false) - }) -}) diff --git a/components/src/hooks/__tests__/useSwipe.test.tsx b/components/src/hooks/__tests__/useSwipe.test.tsx deleted file mode 100644 index cba756f82a2..00000000000 --- a/components/src/hooks/__tests__/useSwipe.test.tsx +++ /dev/null @@ -1,26 +0,0 @@ -import { describe, it, expect } from 'vitest' -import { act, renderHook } from '@testing-library/react' -import { useSwipe } from '../useSwipe' - -describe('useSwipe hook', () => { - it('useSwipe returns UseSwipeResult object', () => { - const { result } = renderHook(() => useSwipe()) - expect(result.current.style.touchAction).toBe('none') - expect(result.current.isEnabled).toBe(true) - expect(result.current.swipeType).toBe('') - }) - - it('When calling enable, isEnabled true', () => { - const { result } = renderHook(() => useSwipe()) - result.current.enable() - expect(result.current.isEnabled).toBe(true) - }) - - it('When calling disable, isEnabled false', () => { - const { result } = renderHook(() => useSwipe()) - act(() => { - result.current.disable() - }) - expect(result.current.isEnabled).toBe(false) - }) -}) diff --git a/components/src/hooks/__tests__/useTimeout.test.tsx b/components/src/hooks/__tests__/useTimeout.test.tsx deleted file mode 100644 index 4b9e2bd34dc..00000000000 --- a/components/src/hooks/__tests__/useTimeout.test.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { describe, it } from 'vitest' - -describe('useTimeouthook', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/hooks/__tests__/useToggle.test.tsx b/components/src/hooks/__tests__/useToggle.test.tsx deleted file mode 100644 index 481d94d1085..00000000000 --- a/components/src/hooks/__tests__/useToggle.test.tsx +++ /dev/null @@ -1,5 +0,0 @@ -import { describe, it } from 'vitest' - -describe('useToggle hook', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/index.module.css b/components/src/index.module.css deleted file mode 100644 index d8eb24e7076..00000000000 --- a/components/src/index.module.css +++ /dev/null @@ -1,9 +0,0 @@ -/* opentrons style library */ - -@import './styles/colors.module.css'; -@import './styles/typography.module.css'; -@import './styles/borders.module.css'; - -:global(*) { - box-sizing: border-box; -} diff --git a/components/src/index.ts b/components/src/index.ts index e52904f06fd..5a80fe60f6e 100644 --- a/components/src/index.ts +++ b/components/src/index.ts @@ -1,41 +1,2 @@ -// opentrons components library - -export * from './hooks' -export * from './utils' - -// Components -export * from './alerts' -export * from './buttons' -export * from './controls' -export * from './hardware-sim' -export * from './legacy-hardware-sim' -export * from './forms' -export * from './icons' -export * from './images' -export * from './instrument' -export * from './interaction-enhancers' -export * from './lists' -export * from './modals' -export * from './nav' -export * from './primitives' -export * from './slotmap' -export * from './structure' -export * from './tooltips' -export * from './organisms' - -// styles -export * from './styles' -// new ui-overhaul style vars -export * from './ui-style-constants' - -// helix design system -export * from './helix-design-system' - -// Pure Types -export * from './robot-types' - -// Molecules -export * from './molecules' - -// Atoms -export * from './atoms' +export { ProtocolDeck } from './hardware-sim/ProtocolDeck' +export { LabwareRender } from './hardware-sim/Labware' \ No newline at end of file diff --git a/components/src/instrument/PipetteSelect.module.css b/components/src/instrument/PipetteSelect.module.css deleted file mode 100644 index f5d7f2ea505..00000000000 --- a/components/src/instrument/PipetteSelect.module.css +++ /dev/null @@ -1,14 +0,0 @@ -.pipette_volume_class { - cursor: default; - min-width: 3.5rem; -} - -.pipette_channels { - cursor: default; - min-width: 7rem; -} - -.pipette_category { - cursor: default; - min-width: 2.5rem; -} diff --git a/components/src/instrument/__tests__/InstrumentInfo.test.tsx b/components/src/instrument/__tests__/InstrumentInfo.test.tsx deleted file mode 100644 index 0101f7d6674..00000000000 --- a/components/src/instrument/__tests__/InstrumentInfo.test.tsx +++ /dev/null @@ -1,55 +0,0 @@ -import type * as React from 'react' -import { screen } from '@testing-library/react' -import { describe, beforeEach, it, vi } from 'vitest' -import { LEFT, RIGHT, fixtureP1000SingleV2Specs } from '@opentrons/shared-data' -import { renderWithProviders } from '../../testing/utils' -import { InstrumentInfo } from '../InstrumentInfo' -import { InstrumentDiagram } from '../InstrumentDiagram' - -vi.mock('../InstrumentDiagram') - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('InstrumentInfo', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - mount: LEFT, - description: 'mock description', - pipetteSpecs: fixtureP1000SingleV2Specs, - tiprackModels: ['mock1', 'mock2'], - showMountLabel: true, - } - vi.mocked(InstrumentDiagram).mockReturnValue( -
mock instrumentDiagram
- ) - }) - it('renders a p1000 pipette with 2 tiprack models for left mount', () => { - render(props) - screen.getByText('mock instrumentDiagram') - screen.getByText('left pipette') - screen.getByText('mock description') - screen.getByText('Tip rack') - screen.getByText('mock1') - screen.getByText('mock2') - }) - it('renders a p1000 pipette with 1 tiprack model for right mount', () => { - props.mount = RIGHT - props.tiprackModels = ['mock1'] - render(props) - screen.getByText('mock instrumentDiagram') - screen.getByText('right pipette') - screen.getByText('mock description') - screen.getByText('Tip rack') - screen.getByText('mock1') - }) - it('renders none for pip and tiprack if none are selected', () => { - props.pipetteSpecs = undefined - props.tiprackModels = undefined - render(props) - screen.getByText('None') - }) -}) diff --git a/components/src/instrument/__tests__/PipetteSelect.test.tsx b/components/src/instrument/__tests__/PipetteSelect.test.tsx deleted file mode 100644 index 5ca7d2bd2d8..00000000000 --- a/components/src/instrument/__tests__/PipetteSelect.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('PipetteSelect', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/instrument/instrument.module.css b/components/src/instrument/instrument.module.css deleted file mode 100644 index f6bb8d1ecf0..00000000000 --- a/components/src/instrument/instrument.module.css +++ /dev/null @@ -1,45 +0,0 @@ -@import '@opentrons/components/styles'; - -.pipette_group { - margin: 0 auto; - max-width: 46rem; - padding-bottom: 2rem; - display: grid; - grid-template-columns: 50% 50%; - grid-template-areas: 'left right'; -} - -.right { - grid-area: right; - grid-template-columns: 40% 80%; - grid-template-areas: 'img info'; -} - -.pipette_info { - grid-area: info; - min-height: 8rem; -} - -.flipped_image { - transform: scaleX(-1); - filter: FlipH; -} - -.pipette_icon { - grid-area: img; - text-align: center; -} - -.title { - font-size: var(--fs-body-2); - font-weight: var(--fw-semibold); - color: var(--c-font-dark); - text-transform: capitalize; - margin: 2rem 0 0.25rem; -} - -.value { - font-size: var(--fs-body-2); /* from legacy --font-body-2-dark */ - font-weight: var(--fw-regular); /* from legacy --font-body-2-dark */ - color: var(--c-font-dark); /* from legacy --font-body-2-dark */ -} diff --git a/components/src/interaction-enhancers/__tests__/useHover.test.tsx b/components/src/interaction-enhancers/__tests__/useHover.test.tsx deleted file mode 100644 index a847c2a683b..00000000000 --- a/components/src/interaction-enhancers/__tests__/useHover.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('useHover hook', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/legacy-hardware-sim/LabwareNameOverlay.module.css b/components/src/legacy-hardware-sim/LabwareNameOverlay.module.css deleted file mode 100644 index dbb492c6efe..00000000000 --- a/components/src/legacy-hardware-sim/LabwareNameOverlay.module.css +++ /dev/null @@ -1,20 +0,0 @@ -@import '../index.module.css'; - -.name_overlay { - width: 100%; - font-size: 0.5rem; - color: var(--c-font-light); - background-color: color-mod(var(--c-black) alpha(0.75)); - padding: 0.25rem; - border-radius: 0 0 0.5rem 0.5rem; -} - -.display_name { - font-weight: var(--fw-semibold); - color: var(--c-font-light); - overflow-wrap: break-word; -} - -.deck_slot:active { - cursor: grabbing; -} \ No newline at end of file diff --git a/components/src/legacy-hardware-sim/ModuleItem.module.css b/components/src/legacy-hardware-sim/ModuleItem.module.css deleted file mode 100644 index 814de48d7d1..00000000000 --- a/components/src/legacy-hardware-sim/ModuleItem.module.css +++ /dev/null @@ -1,98 +0,0 @@ -@import '@opentrons/components/styles'; - -.module { - color: var(--c-black); - background-color: var(--c-black); - opacity: 0.9; - border-radius: 6px; - width: 100%; - height: 100%; - display: flex; -} - -.module_review_icon { - color: var(--c-white); - margin: 0 0.25rem 0 0; - height: 12px; - width: 12px; -} - -.module_review_icon_missing { - color: var(--c-red); -} - -.module_review_icon_present { - color: var(--c-green); -} - -.module_review_text { - fill: currentColor; - font-size: 0.55rem; - font-weight: var(--fw-semibold); - color: var(--c-white); - text-transform: capitalize; - white-space: pre; - margin-bottom: 0.75rem; -} - -.module_name_overlay { - color: var(--c-black); - opacity: 0.7; -} - -.module_connect_info_wrapper { - display: flex; - flex-direction: row; - font-size: 0.5rem; - color: var(--c-white); -} - -.module_port_text { - fill: currentColor; - color: var(--c-white); - font-size: 0.65rem; - font-weight: var(--fw-semibold); - text-transform: uppercase; -} - -.module_port_text_na { - fill: currentColor; - color: var(--c-med-gray); - font-size: 0.65rem; - font-weight: var(--fw-semibold); - text-transform: uppercase; -} - -.module_wrapper { - display: flex; - width: 100%; - padding: 1.15rem; - justify-content: center; - flex-direction: column; - align-items: flex-end; -} - -.flipped_module_wrapper { - display: flex; - width: 100%; - padding: 1.15rem; - justify-content: center; - flex-direction: column; - align-items: flex-start; -} - -.module_name_text { - fill: currentColor; - color: var(--c-white); - font-size: 0.5rem; - font-weight: var(--fw-semibold); - text-transform: uppercase; -} - -.flipped { - transform: rotate(180deg); -} - -.right_icon { - margin: 0 0 0 1rem; -} \ No newline at end of file diff --git a/components/src/lists/lists.module.css b/components/src/lists/lists.module.css deleted file mode 100644 index b0439030438..00000000000 --- a/components/src/lists/lists.module.css +++ /dev/null @@ -1,171 +0,0 @@ -@import '../index.module.css'; - -:root { - --list-padding-large: 1rem; - --list-padding-small: 0.75rem; -} - -.clickable { - cursor: pointer; -} - -.disabled { - background-color: transparent; - - & * { - color: var(--c-font-disabled); - outline-color: #eee; - fill: var(--c-font-disabled); - background-color: transparent; - } -} - -.panel_group, -.titled_list, -.list_item { - background-color: white; -} - -.panel_group { - box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.33); -} - -.hover_border { - outline: var(--bd-width-default) solid var(--c-highlight); -} - -.header_text { - text-transform: uppercase; - font-size: var(--fs-caption); - font-weight: var(--fw-semibold); - color: var(--c-font-disabled); -} - -/* - TODO(IL, 2021-07-30): when consumers of this class are migrated to CSS-in-JS, keep in mind - the meaning of .title_bar is vague, it is widely used by several unrelated components. - Also, it's almost the same as .titled_list_title_bar -- they are the same - except for flex-related rules. -*/ -.title_bar { - position: relative; - display: flex; - text-decoration: none; - padding: var(--list-padding-large) var(--list-padding-small); - flex-direction: column; -} - -/* Specifically for TitledList */ -.titled_list_title_bar { - position: relative; - display: flex; - text-decoration: none; - padding: var(--list-padding-large) var(--list-padding-small); - flex-direction: row; - align-items: center; -} - -.titled_list_selected { - & .title_bar { - background-color: var(--c-bg-selected); - - & * { - color: var(--c-selected-dark); - font-weight: var(--fw-semibold); - } - } -} - -.title { - font-size: var(--fs-body-2); - font-weight: var(--fw-regular); - margin: 0; - text-transform: uppercase; -} - -.title_enabled { - color: var(--c-font-dark); -} - -.title_disabled { - color: var(--c-font-disabled); -} - -.title_bar_icon { - color: var(--c-font-dark); - height: 1.5rem; -} - -.title_bar_error { - background-color: var(--c-error-light); -} - -.icon_left_of_title { - margin-right: 0.5rem; - height: 1.2rem; -} - -.icon_left_of_title_container { - display: flex; - justify-content: flex-start; -} - -.title_bar_carat { - position: absolute; - top: 0; - bottom: 0; - right: 0; - padding: calc(var(--list-padding-small) - var(--bd-width-default)); - padding-top: 1rem; - - &:hover { - background-color: color-mod(var(--c-black) alpha(5%)); - } -} - -.list { - list-style-type: none; - padding-left: 0; - margin: 0; -} - -.list_item { - font-size: var(--fs-body-1); /* from legacy --font-body-1-dark */ - font-weight: var(--fw-regular); /* from legacy --font-body-1-dark */ - color: var(--c-font-dark); /* from legacy --font-body-1-dark */ - display: flex; - flex-direction: row; - align-items: center; - width: 100%; - line-height: 1.25; - margin: 0; - padding: var(--list-padding-small); - - &:hover { - background-color: var(--c-bg-hover); - } - - &.active { - background-color: var(--c-bg-selected); - } -} - -a.list_item { - text-decoration: none; -} - -.list_alert { - font-size: var(--fs-body-1); /* from legacy --font-body-1-dark */ - font-weight: var(--fw-regular); /* from legacy --font-body-1-dark */ - color: var(--c-font-dark); /* from legacy --font-body-1-dark */ - width: 100%; - padding: var(--list-padding-small); - background-color: var(--c-bg-light); - font-style: italic; -} - -.item_icon { - flex: none; - height: calc(1.25 * var(--fs-body-1)); - margin-right: 0.5rem; -} diff --git a/components/src/modals/__tests__/Modal.test.tsx b/components/src/modals/__tests__/Modal.test.tsx deleted file mode 100644 index 1dfa84cdaca..00000000000 --- a/components/src/modals/__tests__/Modal.test.tsx +++ /dev/null @@ -1,65 +0,0 @@ -// -import type * as React from 'react' -import '@testing-library/jest-dom/vitest' -import { screen } from '@testing-library/react' -import { describe, it, expect, beforeEach } from 'vitest' -import { renderWithProviders } from '../../testing/utils' -import { COLORS } from '../../helix-design-system' -import { Modal } from '../Modal' - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('Modal', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - type: 'info', - title: 'mock info modal', - children:
mock modal content
, - } - }) - - it('should render modal without header icon when type is info', () => { - render(props) - expect(screen.queryByTestId('Modal_header_icon')).not.toBeInTheDocument() - screen.getByText('mock info modal') - expect(screen.getByTestId('Modal_header')).toHaveStyle( - `background-color: ${COLORS.white}` - ) - }) - - it('should render modal with orange header icon when type is warning', () => { - props.type = 'warning' - render(props) - const headerIcon = screen.getByTestId('Modal_header_icon') - expect(headerIcon).toBeInTheDocument() - expect(headerIcon).toHaveStyle(`color: ${COLORS.yellow50}`) - expect(screen.getByTestId('Modal_header')).toHaveStyle( - `background-color: ${COLORS.white}` - ) - }) - - it('should render modal with red header icon when type is error', () => { - props.type = 'error' - render(props) - const headerIcon = screen.getByTestId('Modal_header_icon') - expect(headerIcon).toBeInTheDocument() - expect(headerIcon).toHaveStyle(`color: ${COLORS.red50}`) - expect(screen.getByTestId('Modal_header')).toHaveStyle( - `background-color: ${COLORS.white}` - ) - }) - - it('should supply a default margin to account for the sidebar, aligning the modal in the center of the app', () => { - render(props) - expect(screen.getByLabelText('ModalShell_ModalArea')).toHaveStyle( - 'width: 31.25rem' - ) - expect(screen.getByLabelText('ModalShell_ModalArea')).toHaveStyle( - 'margin-left: 5.656rem' - ) - }) -}) diff --git a/components/src/modals/__tests__/ModalHeader.test.tsx b/components/src/modals/__tests__/ModalHeader.test.tsx deleted file mode 100644 index d0e790b2fce..00000000000 --- a/components/src/modals/__tests__/ModalHeader.test.tsx +++ /dev/null @@ -1,73 +0,0 @@ -import type * as React from 'react' -import { screen, fireEvent } from '@testing-library/react' -import '@testing-library/jest-dom/vitest' -import { describe, it, expect, vi, beforeEach } from 'vitest' - -import { renderWithProviders } from '../../testing/utils' -import { ModalHeader } from '../ModalHeader' -import { COLORS } from '../../helix-design-system' -import { SPACING } from '../../ui-style-constants' -import { ALIGN_CENTER, JUSTIFY_CENTER } from '../../styles' - -const mockClose = vi.fn() - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('ModalHeader', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - onClose: mockClose, - title: 'mock modal header title', - backgroundColor: COLORS.white, - color: COLORS.black90, - } - }) - - it('should render text and close icon', () => { - render(props) - const title = screen.getByText('mock modal header title') - expect(title).toHaveStyle(`color: ${COLORS.black90}`) - screen.getByTestId('ModalHeader_icon_close_mock modal header title') - }) - - it('should render text, icon, and close icon', () => { - props.icon = { - name: 'ot-alert', - color: COLORS.black90, - size: '1.25rem', - marginRight: SPACING.spacing8, - } - render(props) - expect(screen.getByTestId('Modal_header_icon')).toHaveStyle( - `color: ${COLORS.black90}` - ) - expect(screen.getByTestId('Modal_header_icon')).toHaveStyle( - `width: 1.25rem` - ) - expect(screen.getByTestId('Modal_header_icon')).toHaveStyle( - `height: 1.25rem` - ) - expect(screen.getByTestId('Modal_header_icon')).toHaveStyle( - `margin-right: ${SPACING.spacing8}` - ) - }) - - it('should call a mock function when clicking close icon', () => { - render(props) - const closeIcon = screen.getByTestId( - 'ModalHeader_icon_close_mock modal header title' - ) - expect(closeIcon).toHaveStyle('width: 1.625rem') - expect(closeIcon).toHaveStyle('height: 1.625rem') - expect(closeIcon).toHaveStyle('display: flex') - expect(closeIcon).toHaveStyle(`justify-content: ${JUSTIFY_CENTER}`) - expect(closeIcon).toHaveStyle(`align-items: ${ALIGN_CENTER}`) - expect(closeIcon).toHaveStyle('border-radius: 0.875rem') - fireEvent.click(closeIcon) - expect(mockClose).toHaveBeenCalled() - }) -}) diff --git a/components/src/modals/__tests__/ModalShell.test.tsx b/components/src/modals/__tests__/ModalShell.test.tsx deleted file mode 100644 index 1e1be0304f5..00000000000 --- a/components/src/modals/__tests__/ModalShell.test.tsx +++ /dev/null @@ -1,45 +0,0 @@ -import type * as React from 'react' -import '@testing-library/jest-dom/vitest' -import { screen } from '@testing-library/react' -import { describe, it, expect, beforeEach } from 'vitest' -import { renderWithProviders } from '../../testing/utils' -import { ModalShell } from '../ModalShell' - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('ModalShell', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - children:
mock modal shell
, - fullPage: false, - } - }) - - it('should render content', () => { - render(props) - screen.getByText('mock modal shell') - expect(screen.getByLabelText('ModalShell_ModalArea')).toHaveStyle( - 'height: auto' - ) - }) - - it('should render full size modal when fullSize is true', () => { - props.fullPage = true - render(props) - expect(screen.getByLabelText('ModalShell_ModalArea')).toHaveStyle( - 'height: 100%' - ) - }) - - it('should render header and footer', () => { - props.header =
mock header
- props.footer =
mock footer
- render(props) - screen.getByText('mock header') - screen.getByText('mock footer') - }) -}) diff --git a/components/src/modals/modals.module.css b/components/src/modals/modals.module.css deleted file mode 100644 index 00aef452c61..00000000000 --- a/components/src/modals/modals.module.css +++ /dev/null @@ -1,275 +0,0 @@ -/* common styling for modals */ -@import '../index.module.css'; - -.modal { - /* from legacy --absolute-fill */ - top: 0; - - /* from legacy --absolute-fill */ - right: 0; - - /* from legacy --absolute-fill */ - bottom: 0; - - /* from legacy --absolute-fill */ - left: 0; - - /* from legacy --absolute-fill */ - display: flex; - - /* from legacy --center-children */ - justify-content: center; - - /* from legacy --center-children */ - align-items: center; - - /* from legacy --center-children */ - - align-items: flex-start; - position: fixed; - z-index: 1; - padding: 4rem; -} - -.modal_page { - position: absolute; - - /* from legacy --absolute-fill */ - top: 0; - - /* from legacy --absolute-fill */ - right: 0; - - /* from legacy --absolute-fill */ - bottom: 0; - - /* from legacy --absolute-fill */ - left: 0; - - /* from legacy --absolute-fill */ - - display: flex; - - /* from legacy --flex-start */ - justify-content: flex-start; - - /* from legacy --flex-start */ - align-items: center; - - /* from legacy --flex-start */ - - flex-direction: column; - padding: 4.5rem 3rem 1rem 3rem; -} - -.overlay { - position: absolute; - - /* from legacy --absolute-fill */ - top: 0; - - /* from legacy --absolute-fill */ - right: 0; - - /* from legacy --absolute-fill */ - bottom: 0; - - /* from legacy --absolute-fill */ - left: 0; - - /* from legacy --absolute-fill */ - - background-color: rgba(0, 0, 0, 0.9); -} - -.title_bar { - position: absolute; - top: 0; - left: 0; - right: 0; - width: 100%; - z-index: 3; -} - -.modal_contents { - z-index: 1; - - /* from legacy --modal-contents */ - width: 100%; - - /* from legacy --modal-contents */ - max-width: 38rem; - - /* from legacy --modal-contents */ - margin: 0 auto; - - /* from legacy --modal-contents */ - padding: 1rem; - - /* from legacy --modal-contents */ - border-radius: 0.5rem; - - /* from legacy --modal-contents */ - - background-color: white; -} - -.modal_page_contents { - z-index: 1; - - /* from legacy --modal-contents */ - width: 100%; - - /* from legacy --modal-contents */ - max-width: 38rem; - - /* from legacy --modal-contents */ - margin: 0 auto; - - /* from legacy --modal-contents */ - padding: 1rem; - - /* from legacy --modal-contents */ - border-radius: 0.5rem; - - /* from legacy --modal-contents */ - - background-color: white; - max-height: 100%; - overflow-y: auto; - padding-top: 1rem; -} - -.modal_heading { - font-size: var(--fs-header); - - /* from legacy --font-header-dark */ - font-weight: var(--fw-semibold); - - /* from legacy --font-header-dark */ - color: var(--c-font-dark); - - /* from legacy --font-header-dark */ - - margin-top: 0; - margin-bottom: 1rem; - text-transform: capitalize; -} - -.alert_modal_wrapper { - position: relative; - max-height: 100%; - padding-top: 4rem; - border-radius: 0; -} - -.alert_modal_heading.no_icon_heading { - padding-left: 2rem; -} - -.no_alert_header { - padding-top: 1.5rem; -} - -.spinner_modal_contents { - /* from legacy --modal-contents */ - width: 100%; - - /* from legacy --modal-contents */ - margin: 0 auto; - - /* from legacy --modal-contents */ - padding: 1rem; - - /* from legacy --modal-contents */ - border-radius: 0.5rem; - - /* from legacy --modal-contents */ - font-size: var(--fs-body-2); - - /* from legacy --font-body-2-light */ - font-weight: var(--fw-regular); - - /* from legacy --font-body-2-light */ - color: var(--c-font-light); - - /* from legacy --font-body-2-light */ - - max-width: 30rem; - padding-top: 3rem; - background-color: transparent; - flex-direction: column; - font-style: italic; - text-align: center; - z-index: 4; -} - -.spinner_modal_icon { - width: 7.5rem; - margin-bottom: 3rem; -} - -.clickable { - cursor: pointer; -} - -.alert_modal { - z-index: 10; -} - -.alert_modal_overlay { - background-color: rgba(115, 115, 115, 0.9); -} - -.alert_modal_contents { - font-size: var(--fs-body-2); - - /* from legacy --font-body-2-dark */ - font-weight: var(--fw-regular); - - /* from legacy --font-body-2-dark */ - color: var(--c-font-dark); - - /* from legacy --font-body-2-dark */ - - width: 100%; - max-height: 100%; - padding: 1rem; - - & > p { - padding-bottom: 1rem; - } -} - -.alert_modal_heading { - font-size: var(--fs-header); - - /* from legacy --font-header-dark */ - color: var(--c-font-dark); - - /* from legacy --font-header-dark */ - - font-weight: normal; - position: absolute; - top: 0; - left: 0; - right: 0; - display: flex; - align-items: center; - padding: 1rem; - background-color: #e0e0e0; -} - -.alert_modal_icon { - height: 1.125rem; - margin-right: 0.75rem; -} - -.alert_modal_buttons { - float: right; - margin-top: 1rem; -} - -.alert_button { - margin-left: 1rem; -} \ No newline at end of file diff --git a/components/src/molecules/Banner/__tests__/Banner.test.tsx b/components/src/molecules/Banner/__tests__/Banner.test.tsx deleted file mode 100644 index f9ae53a7bf5..00000000000 --- a/components/src/molecules/Banner/__tests__/Banner.test.tsx +++ /dev/null @@ -1,94 +0,0 @@ -import type * as React from 'react' -import { describe, it, vi, expect, beforeEach } from 'vitest' -import { fireEvent, screen } from '@testing-library/react' -import { renderWithProviders } from '../../../testing/utils' - -import { Banner } from '..' - -const render = (props: React.ComponentProps) => { - return renderWithProviders()[0] -} - -describe('Banner', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - type: 'success', - children: 'TITLE', - } - }) - - it('renders success banner', () => { - render(props) - screen.getByLabelText('icon_success') - screen.getByText('TITLE') - }) - - it('renders success banner with exit button and when click dismisses banner', () => { - props = { - type: 'success', - children: 'TITLE', - onCloseClick: vi.fn(), - } - render(props) - screen.getByText('TITLE') - const btn = screen.getByLabelText('close_icon') - fireEvent.click(btn) - expect(props.onCloseClick).toHaveBeenCalled() - }) - - it('renders warning banner', () => { - props = { - type: 'warning', - children: 'TITLE', - } - render(props) - screen.getByLabelText('icon_warning') - screen.getByText('TITLE') - }) - - it('renders error banner', () => { - props = { - type: 'error', - children: 'TITLE', - } - render(props) - screen.getByLabelText('icon_error') - screen.getByText('TITLE') - }) - - it('renders updating banner', () => { - props = { - type: 'updating', - children: 'TITLE', - } - render(props) - screen.getByLabelText('icon_updating') - screen.getByText('TITLE') - }) - - it('renders custom icon banner', () => { - props = { - type: 'warning', - children: 'TITLE', - icon: { name: 'ot-hot-to-touch' }, - } - render(props) - screen.getByLabelText('icon_warning') - screen.getByText('TITLE') - }) - - it('renders custom close', () => { - props = { - type: 'warning', - children: 'TITLE', - closeButton: 'close button', - onCloseClick: vi.fn(), - } - render(props) - const btn = screen.getByText('close button') - fireEvent.click(btn) - expect(props.onCloseClick).toHaveBeenCalled() - }) -}) diff --git a/components/src/molecules/DeckInfoLabel/__tests__/DeckInfoLabel.test.tsx b/components/src/molecules/DeckInfoLabel/__tests__/DeckInfoLabel.test.tsx deleted file mode 100644 index 7a7c7f6a782..00000000000 --- a/components/src/molecules/DeckInfoLabel/__tests__/DeckInfoLabel.test.tsx +++ /dev/null @@ -1,49 +0,0 @@ -import type * as React from 'react' -import { describe, it, beforeEach, expect } from 'vitest' -import { renderWithProviders } from '../../../testing/utils' -import { screen } from '@testing-library/react' -import { SPACING } from '../../../ui-style-constants' -import { BORDERS, COLORS } from '../../../helix-design-system' - -import { DeckInfoLabel } from '..' - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('DeckInfoLabel', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - deckLabel: 'A1', - } - }) - - it('should render the proper styles - web style', () => { - render(props) - const deckInfoLabel = screen.getByTestId('DeckInfoLabel_A1') - expect(deckInfoLabel).toHaveStyle( - `padding: ${SPACING.spacing2} ${SPACING.spacing4}` - ) - expect(deckInfoLabel).toHaveStyle(`height: ${SPACING.spacing20}`) - expect(deckInfoLabel).toHaveStyle('width: max-content') - expect(deckInfoLabel).toHaveStyle(`border: 1px solid ${COLORS.black90}`) - expect(deckInfoLabel).toHaveStyle(`border-radius: ${BORDERS.borderRadius8}`) - }) - - it.todo('should render the proper styles - odd style') - - it('should render deck label', () => { - render(props) - screen.getByText('A1') - }) - - it('should render an icon', () => { - props = { - iconName: 'ot-temperature-v2', - } - render(props) - screen.getByLabelText(props.iconName) - }) -}) diff --git a/components/src/molecules/DeckInfoLabel/index.tsx b/components/src/molecules/DeckInfoLabel/index.tsx index 12fba78b93b..c0c06fd85d5 100644 --- a/components/src/molecules/DeckInfoLabel/index.tsx +++ b/components/src/molecules/DeckInfoLabel/index.tsx @@ -1,6 +1,6 @@ import styled from 'styled-components' -import { StyledText } from '../../atoms' +import { StyledText } from '../../atoms/StyledText' import { BORDERS, COLORS } from '../../helix-design-system' import { Icon } from '../../icons' import { Flex } from '../../primitives' diff --git a/components/src/molecules/DeckLabel/__tests__/DeckLabel.test.tsx b/components/src/molecules/DeckLabel/__tests__/DeckLabel.test.tsx deleted file mode 100644 index 088536e706a..00000000000 --- a/components/src/molecules/DeckLabel/__tests__/DeckLabel.test.tsx +++ /dev/null @@ -1,69 +0,0 @@ -import type * as React from 'react' -import { screen } from '@testing-library/react' -import { describe, it, beforeEach, expect } from 'vitest' - -import { COLORS } from '../../../helix-design-system' -import { SPACING } from '../../../ui-style-constants' -import { FLEX_MAX_CONTENT } from '../../../styles' -import { renderWithProviders } from '../../../testing/utils' -import { DeckLabel } from '..' - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('DeckLabel', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - text: 'mock DeckLabel text', - isSelected: false, - isLast: true, - } - }) - - it('should render text and styles isSelected - false', () => { - render(props) - screen.getByText('mock DeckLabel text') - const deckLabel = screen.getByTestId('DeckLabel_UnSelected') - expect(deckLabel).toHaveStyle(`padding: ${SPACING.spacing2}`) - expect(deckLabel).toHaveStyle(`width: ${FLEX_MAX_CONTENT}`) - expect(deckLabel).toHaveStyle(`color: ${COLORS.blue50}`) - expect(deckLabel).toHaveStyle(`border-right: 1.5px solid ${COLORS.blue50}`) - expect(deckLabel).toHaveStyle(`border-bottom: 1.5px solid ${COLORS.blue50}`) - expect(deckLabel).toHaveStyle(`border-left: 1.5px solid ${COLORS.blue50}`) - expect(deckLabel).toHaveStyle(`background-color: ${COLORS.white}`) - }) - - it('should render text and styles isSelected - false not last', () => { - props = { - ...props, - isLast: false, - } - render(props) - screen.getByText('mock DeckLabel text') - const deckLabel = screen.getByTestId('DeckLabel_UnSelected') - expect(deckLabel).toHaveStyle(`padding: ${SPACING.spacing2}`) - expect(deckLabel).toHaveStyle(`width: ${FLEX_MAX_CONTENT}`) - expect(deckLabel).toHaveStyle(`color: ${COLORS.blue50}`) - expect(deckLabel).toHaveStyle(`border-right: 1.5px solid ${COLORS.blue50}`) - expect(deckLabel).toHaveStyle(`border-left: 1.5px solid ${COLORS.blue50}`) - expect(deckLabel).toHaveStyle(`background-color: ${COLORS.white}`) - }) - - it('should render text and styles isSelected - true', () => { - props = { - ...props, - isSelected: true, - } - render(props) - screen.getByText('mock DeckLabel text') - const deckLabel = screen.getByTestId('DeckLabel_Selected') - expect(deckLabel).toHaveStyle(`padding: ${SPACING.spacing2}`) - expect(deckLabel).toHaveStyle(`width: ${FLEX_MAX_CONTENT}`) - expect(deckLabel).toHaveStyle(`color: ${COLORS.white}`) - expect(deckLabel).toHaveStyle(`border: 1.5px solid ${COLORS.blue50}`) - expect(deckLabel).toHaveStyle(`background-color: ${COLORS.blue50}`) - }) -}) diff --git a/components/src/molecules/DeckLabel/index.tsx b/components/src/molecules/DeckLabel/index.tsx index d3a8c02b975..b2fe9ff3f35 100644 --- a/components/src/molecules/DeckLabel/index.tsx +++ b/components/src/molecules/DeckLabel/index.tsx @@ -1,11 +1,11 @@ import { css } from 'styled-components' import { getModuleType } from '@opentrons/shared-data' -import { Flex } from '../../primitives' +import { Flex } from '../../primitives/Flex' import { ALIGN_CENTER, FLEX_MAX_CONTENT } from '../../styles' import { COLORS } from '../../helix-design-system' import { SPACING } from '../../ui-style-constants' -import { StyledText } from '../../atoms' -import { ModuleIcon } from '../../icons' +import { StyledText } from '../../atoms/StyledText' +import { ModuleIcon } from '../../icons/ModuleIcon' import type { FlattenSimpleInterpolation } from 'styled-components' import type { ModuleModel } from '@opentrons/shared-data' diff --git a/components/src/molecules/DropdownMenu/__tests__/DropdownMenu.test.tsx b/components/src/molecules/DropdownMenu/__tests__/DropdownMenu.test.tsx deleted file mode 100644 index ee1de9643e5..00000000000 --- a/components/src/molecules/DropdownMenu/__tests__/DropdownMenu.test.tsx +++ /dev/null @@ -1,85 +0,0 @@ -import type * as React from 'react' -import { screen, fireEvent } from '@testing-library/react' -import { describe, it, expect, vi, beforeEach } from 'vitest' - -import { renderWithProviders } from '../../../testing/utils' -import { DropdownMenu } from '..' -import type { DropdownOption } from '..' - -const mockOptions: DropdownOption[] = [ - { name: 'Option 1', value: 'option1' }, - { name: 'Option 2', value: 'option2' }, - { name: 'Option 3', value: 'option3' }, -] - -const mockOnClick = vi.fn() - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('DropdownMenu', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - filterOptions: mockOptions, - onClick: mockOnClick, - currentOption: mockOptions[0], - } - }) - - it('renders with default props', () => { - render(props) - expect(screen.getByText('Option 1')).toBeInTheDocument() - }) - - it('renders with custom props', () => { - props = { - filterOptions: mockOptions, - onClick: mockOnClick, - currentOption: mockOptions[0], - dropdownType: 'neutral', - title: 'Custom Dropdown', - caption: 'Select an option', - tooltipText: 'This is a tooltip', - } - render(props) - - expect(screen.getByText('Custom Dropdown')).toBeInTheDocument() - expect(screen.getByText('Select an option')).toBeInTheDocument() - expect(screen.getByText('Option 1')).toBeInTheDocument() - }) - - it('opens dropdown menu on click', () => { - render(props) - fireEvent.click(screen.getByText('Option 1')) - expect(screen.getByText('Option 2')).toBeInTheDocument() - expect(screen.getByText('Option 3')).toBeInTheDocument() - }) - - it('calls onClick when an option is selected', () => { - render(props) - fireEvent.click(screen.getByText('Option 1')) - fireEvent.click(screen.getByText('Option 2')) - - expect(mockOnClick).toHaveBeenCalledWith('option2') - }) - - // ToDo (kk:08/13/2024) activate when jsdom is updated - // it('renders tooltip when tooltipText is provided', () => { - // props = { - // filterOptions: mockOptions, - // onClick: mockOnClick, - // currentOption: mockOptions[0], - // title: 'With Tooltip', - // tooltipText: 'Tooltip content', - // } - // render(props) - - // expect(screen.getByText('With Tooltip')).toBeInTheDocument() - // const infoIcon = screen.getByTestId('information_icon') - // fireEvent.mouseOver(infoIcon) - // expect(screen.getByText('Tooltip content')).toBeInTheDocument() - // }) -}) diff --git a/components/src/molecules/InfoScreen/__tests__/InfoScreen.test.tsx b/components/src/molecules/InfoScreen/__tests__/InfoScreen.test.tsx deleted file mode 100644 index 8e3e53faed0..00000000000 --- a/components/src/molecules/InfoScreen/__tests__/InfoScreen.test.tsx +++ /dev/null @@ -1,40 +0,0 @@ -import type * as React from 'react' -import { screen } from '@testing-library/react' -import { describe, it, expect, beforeEach } from 'vitest' - -import { renderWithProviders } from '../../../testing/utils' -import { BORDERS, COLORS } from '../../../helix-design-system' -import { InfoScreen } from '..' - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('InfoScreen', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - content: 'mock info text', - } - }) - - it('should render text and icon with proper color - labware', () => { - render(props) - screen.getByLabelText('alert') - screen.getByText('mock info text') - }) - - it('should have proper styles', () => { - render(props) - expect(screen.getByTestId('InfoScreen')).toHaveStyle( - `background-color: ${COLORS.grey30}` - ) - expect(screen.getByTestId('InfoScreen')).toHaveStyle( - `border-radius: ${BORDERS.borderRadius8}` - ) - expect(screen.getByLabelText('alert')).toHaveStyle( - `color: ${COLORS.grey60}` - ) - }) -}) diff --git a/components/src/molecules/LiquidIcon/__tests__/LiquidIcon.test.tsx b/components/src/molecules/LiquidIcon/__tests__/LiquidIcon.test.tsx deleted file mode 100644 index c50396f47fc..00000000000 --- a/components/src/molecules/LiquidIcon/__tests__/LiquidIcon.test.tsx +++ /dev/null @@ -1,50 +0,0 @@ -import type * as React from 'react' -import { describe, it, expect } from 'vitest' -import { renderWithProviders } from '../../../testing/utils' -import { screen } from '@testing-library/react' -import { SPACING } from '../../../ui-style-constants' -import { BORDERS, COLORS } from '../../../helix-design-system' - -import { LiquidIcon } from '..' - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('LiquidIcon', () => { - let props: React.ComponentProps - - it('should render the proper style for large icon', () => { - props = { - size: 'medium', - color: COLORS.red50, - } - render(props) - const LiquidIcon = screen.getByTestId(`LiquidIcon_${COLORS.red50}`) - expect(LiquidIcon).toHaveStyle(`padding: ${SPACING.spacing12}`) - expect(LiquidIcon).toHaveStyle('height: max-content') - expect(LiquidIcon).toHaveStyle('width: max-content') - expect(LiquidIcon).toHaveStyle(`background-color: ${COLORS.white}`) - expect(LiquidIcon).toHaveStyle(`border-style: ${BORDERS.styleSolid}`) - expect(LiquidIcon).toHaveStyle(`border-width: 1px`) - expect(LiquidIcon).toHaveStyle(`border-color: ${COLORS.grey30}`) - expect(LiquidIcon).toHaveStyle(`border-radius: ${BORDERS.borderRadius4}`) - }) - - it('should render the proper style for large icon', () => { - props = { - size: 'small', - color: COLORS.blue50, - } - render(props) - const LiquidIcon = screen.getByTestId(`LiquidIcon_${COLORS.blue50}`) - expect(LiquidIcon).toHaveStyle(`padding: ${SPACING.spacing8}`) - expect(LiquidIcon).toHaveStyle('height: max-content') - expect(LiquidIcon).toHaveStyle('width: max-content') - expect(LiquidIcon).toHaveStyle(`background-color: ${COLORS.white}`) - expect(LiquidIcon).toHaveStyle(`border-style: ${BORDERS.styleSolid}`) - expect(LiquidIcon).toHaveStyle(`border-width: 1px`) - expect(LiquidIcon).toHaveStyle(`border-color: ${COLORS.grey30}`) - expect(LiquidIcon).toHaveStyle(`border-radius: ${BORDERS.borderRadius4}`) - }) -}) diff --git a/components/src/molecules/ParametersTable/__tests__/ParametersTable.test.tsx b/components/src/molecules/ParametersTable/__tests__/ParametersTable.test.tsx deleted file mode 100644 index dbe674a60f8..00000000000 --- a/components/src/molecules/ParametersTable/__tests__/ParametersTable.test.tsx +++ /dev/null @@ -1,126 +0,0 @@ -import type * as React from 'react' -import { renderWithProviders } from '../../../testing/utils' -import { describe, it, beforeEach } from 'vitest' -import { screen } from '@testing-library/react' -import { ParametersTable } from '../index' - -import type { RunTimeParameter } from '@opentrons/shared-data' - -const tMock = (key: string) => key -const mockRunTimeParameter: RunTimeParameter[] = [ - { - displayName: 'Trash Tips', - variableName: 'TIP_TRASH', - description: - 'to throw tip into the trash or to not throw tip into the trash', - type: 'bool', - default: true, - value: true, - }, - { - displayName: 'EtoH Volume', - variableName: 'ETOH_VOLUME', - description: '70% ethanol volume', - type: 'float', - suffix: 'mL', - min: 1.5, - max: 10.0, - default: 6.5, - value: 6.5, - }, - { - displayName: 'Default Module Offsets', - variableName: 'DEFAULT_OFFSETS', - description: 'default module offsets for temp, H-S, and none', - type: 'str', - value: 'none', - choices: [ - { - displayName: 'No offsets', - value: 'none', - }, - { - displayName: 'temp offset', - value: '1', - }, - { - displayName: 'heater-shaker offset', - value: '2', - }, - ], - default: 'none', - }, - { - displayName: 'pipette mount', - variableName: 'mont', - description: 'pipette mount', - type: 'str', - value: 'left', - choices: [ - { - displayName: 'Left', - value: 'left', - }, - { - displayName: 'Right', - value: 'right', - }, - ], - default: 'left', - }, -] - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('ParametersTable', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - runTimeParameters: mockRunTimeParameter, - } - }) - - it('should render table header', () => { - render(props) - screen.getByText('Name') - screen.getByText('Default Value') - screen.getByText('Range') - }) - - it('should render parameters default information', () => { - render(props) - screen.getByText('Trash Tips') - screen.getByText('On') - screen.getByText('On, off') - - screen.getByText('EtoH Volume') - screen.getByText('6.5 mL') - screen.getByText('1.5-10.0') - - // more than 2 options - screen.getByText('Default Module Offsets') - screen.getByText('No offsets') - screen.getByText('3 options') - - // 2 options - screen.getByText('pipette mount') - screen.getByText('Left') - screen.getByText('Left, Right') - }) - - it('should render the raw i18n values if a t prop is provided', () => { - props.t = tMock - render(props) - screen.getByText('name') - screen.getByText('default_value') - screen.getByText('range') - }) - - it('should render a description icon if description is provided', () => { - render(props) - screen.getByTestId('Icon_0') - }) -}) diff --git a/components/src/molecules/Tabs/__tests__/Tabs.test.tsx b/components/src/molecules/Tabs/__tests__/Tabs.test.tsx deleted file mode 100644 index f78f2e525e2..00000000000 --- a/components/src/molecules/Tabs/__tests__/Tabs.test.tsx +++ /dev/null @@ -1,90 +0,0 @@ -import type * as React from 'react' -import { vi, describe, it, expect, beforeEach } from 'vitest' -import { fireEvent, screen } from '@testing-library/react' -import { BORDERS, COLORS } from '../../../helix-design-system' -import { SPACING } from '../../../ui-style-constants' -import { POSITION_RELATIVE } from '../../../styles' -import { renderWithProviders } from '../../../testing/utils' -import { Tabs } from '../index' - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('Tabs', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - tabs: [ - { text: 'set up', onClick: vi.fn() }, - { text: 'parameters', onClick: vi.fn() }, - { text: 'module controls', onClick: vi.fn() }, - ], - } - }) - - it('renders unclicked tabs with text', () => { - render(props) - - const tabTexts = ['set up', 'parameters', 'module controls'] - const tabStyles = { - backgroundColor: COLORS.purple30, - borderRadius: BORDERS.borderRadius8, - padding: `${SPACING.spacing8} ${SPACING.spacing16}`, - position: POSITION_RELATIVE, - } - - tabTexts.forEach(text => { - const tab = screen.getByText(text) - expect(tab).not.toBeNull() - - Object.entries(tabStyles).forEach(([key, value]) => { - expect(tab).toHaveStyle(`${key}: ${value}`) - }) - }) - }) - - it('renders an active tab', () => { - props.tabs[0].isActive = true - - render(props) - - const tab1 = screen.getByText('set up') - - expect(tab1).toHaveStyle(`background-color: ${COLORS.purple50}`) - expect(tab1).toHaveStyle(`color: ${COLORS.white}`) - }) - - it('should call the right click handler when clicked', () => { - render(props) - - const tabList = props.tabs - - fireEvent.click(screen.getByText('set up')) - expect(tabList[0].onClick).toHaveBeenCalled() - - fireEvent.click(screen.getByText('parameters')) - expect(tabList[1].onClick).toHaveBeenCalled() - - fireEvent.click(screen.getByText('module controls')) - expect(tabList[2].onClick).toHaveBeenCalled() - }) - - it('should show right style when disabled', () => { - props = { - tabs: [ - { text: 'set up', onClick: vi.fn(), disabled: true }, - { text: 'parameters', onClick: vi.fn() }, - { text: 'module controls', onClick: vi.fn() }, - ], - } - render(props) - const tab = screen.getByText('set up') - expect(tab).toHaveStyle(`background-color: ${COLORS.grey30}`) - expect(tab).toHaveStyle(`color: ${COLORS.grey40}`) - - fireEvent.click(tab) - expect(props.tabs[0].onClick).not.toHaveBeenCalled() - }) -}) diff --git a/components/src/nav/SidePanel.module.css b/components/src/nav/SidePanel.module.css deleted file mode 100644 index 84eb4bd4e73..00000000000 --- a/components/src/nav/SidePanel.module.css +++ /dev/null @@ -1,34 +0,0 @@ -@import '../index.module.css'; - -:root { - --sidebar-width: 18.25rem; -} - -.panel { - flex-shrink: 0; - overflow: visible; - border-right: var(--bd-light); - background-color: var(--c-bg-light); - position: relative; - padding: 0 4px; -} - -.title_bar { - display: flex; - align-items: center; - width: var(--sidebar-width); -} - -.title { - font-size: var(--fs-header); /* from legacy --font-header-dark */ - font-weight: var(--fw-semibold); /* from legacy --font-header-dark */ - color: var(--c-font-dark); /* from legacy --font-header-dark */ - margin: 1rem auto; -} - -.panel_contents { - width: var(--sidebar-width); - height: calc(100vh - 3.5rem); - overflow-x: hidden; - overflow-y: auto; -} diff --git a/components/src/organisms/DeckLabelSet/__tests__/DeckLabelSet.test.tsx b/components/src/organisms/DeckLabelSet/__tests__/DeckLabelSet.test.tsx deleted file mode 100644 index fbb6c1b274d..00000000000 --- a/components/src/organisms/DeckLabelSet/__tests__/DeckLabelSet.test.tsx +++ /dev/null @@ -1,49 +0,0 @@ -import type * as React from 'react' -import { describe, it, vi, beforeEach, expect } from 'vitest' -import { screen } from '@testing-library/react' - -import { renderWithProviders } from '../../../testing/utils' -import { BORDERS, COLORS } from '../../../helix-design-system' -import { DeckLabel } from '../../../molecules/DeckLabel' -import { DeckLabelSet } from '..' - -vi.mock('../../../molecules/DeckLabel') - -const mockDeckLabels = [ - { - text: 'Label', - isSelected: false, - labelBorderRadius: BORDERS.borderRadius4, - }, - { - text: 'Label', - isSelected: false, - labelBorderRadius: BORDERS.borderRadius4, - }, -] - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} -describe('DeckLabelSet', () => { - let props: React.ComponentProps - - beforeEach(() => { - props = { - x: 1, - y: 1, - width: 50, - height: 50, - deckLabels: mockDeckLabels, - } - vi.mocked(DeckLabel).mockReturnValue(
mock DeckLabels
) - }) - - it('should render blue border and DeckLabel', () => { - render(props) - expect(screen.getAllByText('mock DeckLabels').length).toBe(2) - const deckLabelSet = screen.getByTestId('DeckLabeSet') - expect(deckLabelSet).toHaveStyle(`border: 1.5px solid ${COLORS.blue50}`) - expect(deckLabelSet).toHaveStyle(`border-radius: ${BORDERS.borderRadius4}`) - }) -}) diff --git a/components/src/organisms/EndUserAgreementFooter/__tests__/EndUserAgreementFooter.test.tsx b/components/src/organisms/EndUserAgreementFooter/__tests__/EndUserAgreementFooter.test.tsx deleted file mode 100644 index a13aacfe27f..00000000000 --- a/components/src/organisms/EndUserAgreementFooter/__tests__/EndUserAgreementFooter.test.tsx +++ /dev/null @@ -1,21 +0,0 @@ -import { describe, it, expect } from 'vitest' -import { screen } from '@testing-library/react' -import { renderWithProviders } from '../../../testing/utils' -import { EndUserAgreementFooter } from '../index' - -const render = () => { - return renderWithProviders() -} - -describe('EndUserAgreementFooter', () => { - it('should render text and links', () => { - render() - screen.getByText('Copyright © 2024 Opentrons') - expect( - screen.getByRole('link', { name: 'privacy policy' }) - ).toHaveAttribute('href', 'https://opentrons.com/privacy-policy') - expect( - screen.getByRole('link', { name: 'end user license agreement' }) - ).toHaveAttribute('href', 'https://opentrons.com/eula') - }) -}) diff --git a/components/src/organisms/Toolbox/__tests__/Toolbox.test.tsx b/components/src/organisms/Toolbox/__tests__/Toolbox.test.tsx deleted file mode 100644 index cb102be031b..00000000000 --- a/components/src/organisms/Toolbox/__tests__/Toolbox.test.tsx +++ /dev/null @@ -1,35 +0,0 @@ -import type * as React from 'react' -import { describe, it, expect, vi } from 'vitest' -import { fireEvent, screen } from '@testing-library/react' -import { renderWithProviders } from '../../../testing/utils' -import { Toolbox } from '../index' - -const render = (props: React.ComponentProps) => { - return renderWithProviders() -} - -describe('Toolbox', () => { - let props: React.ComponentProps - - it('should render text and buttons', () => { - props = { - title:
mock header
, - children:
mock children
, - confirmButtonText: 'done', - onCloseClick: vi.fn(), - closeButton:
exit
, - onConfirmClick: vi.fn(), - secondaryHeaderButton:
mock secondary header button
, - } - render(props) - screen.getByText('mock header') - screen.getByText('done') - fireEvent.click(screen.getByTestId('Toolbox_confirmButton')) - expect(props.onConfirmClick).toHaveBeenCalled() - screen.getByText('mock children') - screen.getByText('exit') - fireEvent.click(screen.getByTestId('Toolbox_closeButton')) - expect(props.onCloseClick).toHaveBeenCalled() - screen.getByText('mock secondary header button') - }) -}) diff --git a/components/src/primitives/__tests__/Box.test.tsx b/components/src/primitives/__tests__/Box.test.tsx deleted file mode 100644 index 330b24a0005..00000000000 --- a/components/src/primitives/__tests__/Box.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('Box primitive component', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/primitives/__tests__/Btn.test.tsx b/components/src/primitives/__tests__/Btn.test.tsx deleted file mode 100644 index 4c1f7b88e43..00000000000 --- a/components/src/primitives/__tests__/Btn.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('Btn primitive component', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/primitives/__tests__/Flex.test.tsx b/components/src/primitives/__tests__/Flex.test.tsx deleted file mode 100644 index 50920489028..00000000000 --- a/components/src/primitives/__tests__/Flex.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('Flex primitive component', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/primitives/__tests__/Link.test.tsx b/components/src/primitives/__tests__/Link.test.tsx deleted file mode 100644 index d23a7b85461..00000000000 --- a/components/src/primitives/__tests__/Link.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('Link primitive component', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/primitives/__tests__/Svg.test.tsx b/components/src/primitives/__tests__/Svg.test.tsx deleted file mode 100644 index aa3e23aaa5d..00000000000 --- a/components/src/primitives/__tests__/Svg.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('Svg primitive component', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/primitives/__tests__/Text.test.tsx b/components/src/primitives/__tests__/Text.test.tsx deleted file mode 100644 index df7acaa4ca5..00000000000 --- a/components/src/primitives/__tests__/Text.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('Text primitive component', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/primitives/__tests__/primitives.test.tsx b/components/src/primitives/__tests__/primitives.test.tsx deleted file mode 100644 index 427fcf9e6ce..00000000000 --- a/components/src/primitives/__tests__/primitives.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('primitive components with style props', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/primitives/__tests__/style-props.test.tsx b/components/src/primitives/__tests__/style-props.test.tsx deleted file mode 100644 index 501739ec6f3..00000000000 --- a/components/src/primitives/__tests__/style-props.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('style props', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/slotmap/__tests__/OT2SlotMap.test.tsx b/components/src/slotmap/__tests__/OT2SlotMap.test.tsx deleted file mode 100644 index 48877e7df5a..00000000000 --- a/components/src/slotmap/__tests__/OT2SlotMap.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('SlotMap', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/slotmap/styles.module.css b/components/src/slotmap/styles.module.css deleted file mode 100644 index 20bc4ad7234..00000000000 --- a/components/src/slotmap/styles.module.css +++ /dev/null @@ -1,18 +0,0 @@ -@import '../index.module.css'; - -.slot_rect { - stroke: var(--c-med-gray); - fill: none; -} - -.slot_occupied { - fill: var(--c-light-gray); -} - -.slot_occupied.slot_error { - fill: var(--c-warning-light); -} - -.collision_icon { - color: var(--c-med-gray); -} diff --git a/components/src/structure/Pill.module.css b/components/src/structure/Pill.module.css deleted file mode 100644 index 1fd5de05470..00000000000 --- a/components/src/structure/Pill.module.css +++ /dev/null @@ -1,16 +0,0 @@ -@import '../index.module.css'; - -.pill { - border-radius: var(--bd-radius-pill); - color: var(--c-white); - padding: 0.5em; -} - -.pill:empty::before { - /* zero width space to give empty pill the same line height */ - content: "\200b"; -} - -.invert_text { - color: var(--c-black); -} diff --git a/components/src/structure/Splash.module.css b/components/src/structure/Splash.module.css deleted file mode 100644 index e512219d5d3..00000000000 --- a/components/src/structure/Splash.module.css +++ /dev/null @@ -1,16 +0,0 @@ -@import '@opentrons/components/styles'; - -.splash { - position: relative; - width: 100%; - height: 100%; - color: var(--c-light-gray); - - & > * { - position: absolute; - top: 50%; - left: 50%; - transform: translate(-50%, -50%); - max-height: 100%; - } -} diff --git a/components/src/structure/structure.module.css b/components/src/structure/structure.module.css deleted file mode 100644 index e394643774e..00000000000 --- a/components/src/structure/structure.module.css +++ /dev/null @@ -1,114 +0,0 @@ -/* TitleBar styles */ -@import '../index.module.css'; - -.title_bar { - display: flex; - align-items: center; - height: 3rem; - text-transform: uppercase; - background-color: var(--c-dark-gray); -} - -.title_bar, -.title_bar a { - color: white; -} - -.title, -.subtitle, -.separator { - font-size: var(--fs-header); - margin: 0; -} - -.title, -.separator { - font-weight: var(--fw-semibold); -} - -.title { - white-space: nowrap; /* from legacy --truncate */ - overflow: hidden; /* from legacy --truncate */ - text-overflow: ellipsis; /* from legacy --truncate */ - min-width: 0; /* from legacy --truncate */ - padding: 0 1.5rem; -} - -.subtitle { - padding: 0 1.5rem; - font-weight: normal; -} - -.title.right { - margin-left: auto; -} - -.title_button { - flex: none; -} - -.page_tabs { - width: 100%; - text-align: center; -} - -.tab_link { - display: inline-block; - width: 50%; - padding: 0.25rem 0; - font-size: var(--fs-huge); - opacity: 0.2; - background-color: var(--c-med-gray); - color: white; - text-transform: uppercase; -} - -.active_tab_link { - opacity: 1; -} - -.tab_title { - font-weight: normal; -} - -.active_tab_link .tab_title { - font-weight: var(--fw-bold); -} - -.disabled { - pointer-events: none; - background-color: transparent; - - & * { - color: var(--c-font-disabled); - fill: var(--c-font-disabled); - background-color: transparent; - } -} - -.labeled_value { - font-size: var(--fs-body-1); /* from legacy --font-body-1-dark */ - font-weight: var(--fw-regular); /* from legacy --font-body-1-dark */ - color: var(--c-font-dark); /* from legacy --font-body-1-dark */ - line-height: 1.5; - - & svg { - height: var(--fs-body-2); - } -} - -.labeled_value_label { - font-weight: var(--fw-semibold); - margin-top: 0; - margin-bottom: 0.25rem; -} - -.labeled_value_value { - margin: 0; -} - -.right_node { - display: flex; - justify-content: flex-end; - margin-left: auto; -} diff --git a/components/src/styles/borders.module.css b/components/src/styles/borders.module.css deleted file mode 100644 index 285048280e4..00000000000 --- a/components/src/styles/borders.module.css +++ /dev/null @@ -1,20 +0,0 @@ -@import './colors.module.css'; - -:root { - /* borders */ - --bd-radius-default: 2px; - --bd-radius-form-field: 3px; - --bd-radius-pill: 12px; - --bd-width-default: 1px; - --bd-light: var(--bd-width-default) solid var(--c-light-gray); - - /* dropshadows */ - - /* TODO: Ian 2018-07-26 consolidate all shadows here (eg from buttons) */ - --shadow-lvl-1: - 0 1px 3px 0 rgba(0, 0, 0, 0.1), - 0 1px 2px 0 rgba(0, 0, 0, 0.2); - --shadow-lvl-2: - 0 3px 6px 0 rgba(0, 0, 0, 0.13), - 0 3px 6px 0 rgba(0, 0, 0, 0.23); -} diff --git a/components/src/styles/colors.module.css b/components/src/styles/colors.module.css deleted file mode 100644 index 631a708b687..00000000000 --- a/components/src/styles/colors.module.css +++ /dev/null @@ -1,57 +0,0 @@ -:root { - /* ot brand */ - --c-mustard: #ffd252; - --c-blue: #006cfa; - --c-light-blue: color-mod(var(--c-blue) lightness(85%)); - - /* - * grays - * TODO(mc, 2019-03-22): align with style guide - */ - --c-near-black: #a4a4a4; /* style guide: n/a */ - --c-dark-gray: #4a4a4a; /* style guide: near-black */ - --c-charcoal: #979797; - --c-med-gray: #9b9b9b; /* style guide: n/a */ - --c-light-gray: #e5e2e2; /* style guide: smoke, should be e6e6e6 */ - --c-lightest-gray: #ededed; /* style guide: n/a */ - - /* - * background colors - * TODO(mc, 2019-03-22): combine with colors - */ - --c-bg-dark: #4a4a4a; - --c-bg-light: #fafafa; - --c-bg-selected: #f0f3ff; - --c-bg-hover: #f1f1f1; - --c-bg-success: #b6febc; - - /* general UI */ - --c-highlight: #5fd8ee; - --c-selected-dark: #00c3e6; - --c-warning-dark: #9e5e00; - --c-warning: #e28200; - --c-warning-light: #ffd58f; - --c-error-dark: #ac0505; - --c-error: #d12929; - --c-error-light: #ffc0c0; - --c-success: #60b120; - --c-blue-enabled: #006cfa; - --c-light-grey-hover: #c6c6c6; - - /* Misc */ - --c-selection-overlay: color-mod(var(--c-highlight) alpha(0.3)); - --c-plate-bg: #ccc; - --c-white: #fff; - --c-black: #000; - --c-green: #7ed321; - --c-red: #f00000; - --c-orange: #f5a623; - - --transition-color: { - transition: color 0.15s ease-in-out; - } - - --transition-background-color: { - transition: background-color 0.15s ease-in-out; - } -} diff --git a/components/src/styles/index.module.css b/components/src/styles/index.module.css deleted file mode 100644 index 03c51cb45e7..00000000000 --- a/components/src/styles/index.module.css +++ /dev/null @@ -1,8 +0,0 @@ -.clickable { - cursor: pointer; -} - -.rotated { - transform-origin: center; - transform: rotate(180deg); -} diff --git a/components/src/styles/typography.module.css b/components/src/styles/typography.module.css deleted file mode 100644 index b3f0fa3092e..00000000000 --- a/components/src/styles/typography.module.css +++ /dev/null @@ -1,22 +0,0 @@ -:root { - --c-font-dark: #4a4a4a; - --c-font-icon: #6f6f6f; - --c-font-light: white; - --c-font-disabled: #9c9c9c; - --fs-huge: 3rem; - --fs-header: 1.125rem; - --fs-default: 1rem; - --fs-body-2: 0.875rem; - --fs-body-1: 0.75rem; - --fs-caption: 0.625rem; - --fs-tiny: 0.325rem; - --fs-micro: 0.2rem; - --fw-bold: 800; - --fw-semibold: 600; - --fw-regular: 400; - --fw-light: 300; - --ff-code: Consolas, monaco, monospace; - --lh-solid: 1; - --lh-title: 1.25; - --lh-copy: 1.5; -} diff --git a/components/src/tooltips/__tests__/Tooltip.test.tsx b/components/src/tooltips/__tests__/Tooltip.test.tsx deleted file mode 100644 index 257af16d8d2..00000000000 --- a/components/src/tooltips/__tests__/Tooltip.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('hook-based Tooltip', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/tooltips/__tests__/useHoverTooltip.test.tsx b/components/src/tooltips/__tests__/useHoverTooltip.test.tsx deleted file mode 100644 index be1a50c7c62..00000000000 --- a/components/src/tooltips/__tests__/useHoverTooltip.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('useHoverTooltip', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/tooltips/__tests__/usePopper.test.tsx b/components/src/tooltips/__tests__/usePopper.test.tsx deleted file mode 100644 index 898f97af4a8..00000000000 --- a/components/src/tooltips/__tests__/usePopper.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('usePopper hook', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/tooltips/__tests__/useTooltip.test.tsx b/components/src/tooltips/__tests__/useTooltip.test.tsx deleted file mode 100644 index 05e8df97fc0..00000000000 --- a/components/src/tooltips/__tests__/useTooltip.test.tsx +++ /dev/null @@ -1,4 +0,0 @@ -import { describe, it } from 'vitest' -describe('useTooltip hook', () => { - it.todo('replace deprecated enzyme test') -}) diff --git a/components/src/tooltips/tooltips.module.css b/components/src/tooltips/tooltips.module.css deleted file mode 100644 index 64ca0f85f98..00000000000 --- a/components/src/tooltips/tooltips.module.css +++ /dev/null @@ -1,72 +0,0 @@ -/* common styling for tooltips */ -@import '../index.module.css'; - -.tooltip_box { - font-size: var(--fs-body-1); /* from legacy --font-body-1-light */ - font-weight: var(--fw-regular); /* from legacy --font-body-1-light */ - color: var(--c-font-light); /* from legacy --font-body-1-light */ - background-color: var(--c-bg-dark); - box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.13), 0 3px 6px 0 rgba(0, 0, 0, 0.23); - padding: 8px; - cursor: pointer; - z-index: 9001; -} - -.arrow { - position: absolute; - bottom: 0; - left: 0; - margin-bottom: -0.5em; - width: 1em; - height: 0.5em; - - &::before { - border-width: 0.5em 0.5em 0 0.5em; - content: ''; - margin: auto; - display: block; - width: 0; - height: 0; - border-style: solid; - border-color: var(--c-bg-dark) transparent transparent transparent; - } -} - -.arrow.bottom { - top: 0; - left: 0; - margin-top: -0.5em; - width: 1em; - height: 0.5em; - - &::before { - border-width: 0 0.5em 0.5em 0.5em; - border-color: transparent transparent var(--c-bg-dark) transparent; - } -} - -.arrow.right { - top: 0; - left: 0; - margin-left: -0.5em; - height: 1em; - width: 0.5em; - - &::before { - border-width: 0.5em 0.5em 0.5em 0; - border-color: transparent var(--c-bg-dark) transparent transparent; - } -} - -.arrow.left { - top: 0; - right: 0; - margin-right: -0.5em; - height: 1em; - width: 0.5em; - - &::before { - border-width: 0.5em 0 0.5em 0.5em; - border-color: transparent transparent transparent var(--c-bg-dark); - } -}