From 9a404a713b98c0b0f70ae9d6d953b3dd3259a26f Mon Sep 17 00:00:00 2001 From: Arkadiusz Bachorski <60391032+arkadiuszbachorski@users.noreply.github.com> Date: Wed, 9 Oct 2024 14:05:02 +0200 Subject: [PATCH 1/2] Add Switch stories --- .../src/components/Switch/Switch.stories.tsx | 39 +++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 packages/design-system/src/components/Switch/Switch.stories.tsx diff --git a/packages/design-system/src/components/Switch/Switch.stories.tsx b/packages/design-system/src/components/Switch/Switch.stories.tsx new file mode 100644 index 00000000..b8aea584 --- /dev/null +++ b/packages/design-system/src/components/Switch/Switch.stories.tsx @@ -0,0 +1,39 @@ +// +// This source file is part of the Stanford Biodesign Digital Health ENGAGE-HF open-source project +// +// SPDX-FileCopyrightText: 2023 Stanford University and the project authors (see CONTRIBUTORS.md) +// +// SPDX-License-Identifier: MIT +// +import { type Meta, type StoryObj } from '@storybook/react' +import { fn } from '@storybook/test' +import { useState } from 'react' +import { SideLabel } from '@/packages/design-system/src/components/SideLabel' +import { Switch } from './Switch' + +const meta: Meta = { + title: 'Components/Switch', + component: Switch, + args: { + onCheckedChange: fn(), + }, +} + +export default meta + +type Story = StoryObj + +export const Unchecked: Story = { args: { checked: false } } + +export const Checked: Story = { args: { checked: true } } + +export const Functional = () => { + const [checked, setChecked] = useState(false) + return +} + +export const Labeled = () => ( + + + +) From 6f04792900e088258bcf898b98573aa8b7db1e26 Mon Sep 17 00:00:00 2001 From: Arkadiusz Bachorski <60391032+arkadiuszbachorski@users.noreply.github.com> Date: Wed, 9 Oct 2024 14:09:53 +0200 Subject: [PATCH 2/2] Add Switch tests --- .../src/components/Switch/Switch.test.tsx | 30 +++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 packages/design-system/src/components/Switch/Switch.test.tsx diff --git a/packages/design-system/src/components/Switch/Switch.test.tsx b/packages/design-system/src/components/Switch/Switch.test.tsx new file mode 100644 index 00000000..f092f8ec --- /dev/null +++ b/packages/design-system/src/components/Switch/Switch.test.tsx @@ -0,0 +1,30 @@ +// +// This source file is part of the Stanford Biodesign Digital Health ENGAGE-HF open-source project +// +// SPDX-FileCopyrightText: 2023 Stanford University and the project authors (see CONTRIBUTORS.md) +// +// SPDX-License-Identifier: MIT +// +import { fireEvent, render, screen } from '@testing-library/react' +import { vitest } from 'vitest' +import { Switch } from '.' + +describe('Switch', () => { + it('renders functional switch element', () => { + const onCheckedChange = vitest.fn() + + render( + , + ) + + const element = screen.getByLabelText('Toggle') + fireEvent.click(element) + + const newCheckedValue = false + expect(onCheckedChange).toHaveBeenCalledWith(newCheckedValue) + }) +})