From cea7ed28435d79a64f893417895ad291e86cbf4f Mon Sep 17 00:00:00 2001 From: Pavindu Lakshan Date: Tue, 31 Oct 2023 13:40:47 +0530 Subject: [PATCH 1/3] feat(react): add Switch component --- packages/react/.storybook/story-config.ts | 4 ++ .../src/components/Switch/Switch.stories.mdx | 56 +++++++++++++++++++ .../react/src/components/Switch/Switch.tsx | 47 ++++++++++++++++ .../Switch/__tests__/Switch.test.tsx | 32 +++++++++++ packages/react/src/components/Switch/index.ts | 20 +++++++ .../react/src/components/Switch/switch.scss | 26 +++++++++ packages/react/src/components/index.ts | 3 + 7 files changed, 188 insertions(+) create mode 100644 packages/react/src/components/Switch/Switch.stories.mdx create mode 100644 packages/react/src/components/Switch/Switch.tsx create mode 100644 packages/react/src/components/Switch/__tests__/Switch.test.tsx create mode 100644 packages/react/src/components/Switch/index.ts create mode 100644 packages/react/src/components/Switch/switch.scss diff --git a/packages/react/.storybook/story-config.ts b/packages/react/.storybook/story-config.ts index 8a70ad20..615c3dd0 100644 --- a/packages/react/.storybook/story-config.ts +++ b/packages/react/.storybook/story-config.ts @@ -107,6 +107,7 @@ export type Stories = | 'Skeleton' | 'Snackbar' | 'Stepper' + | 'Switch' | 'Tab' | 'TabPanel' | 'Tabs' @@ -361,6 +362,9 @@ const StoryConfig: StorybookConfig = { Stepper: { hierarchy: `${StorybookCategories.Surfaces}/Stepper`, }, + Switch: { + hierarchy: `${StorybookCategories.Inputs}/Switch`, + }, Tab: { hierarchy: `${StorybookCategories.Navigation}/Tab`, }, diff --git a/packages/react/src/components/Switch/Switch.stories.mdx b/packages/react/src/components/Switch/Switch.stories.mdx new file mode 100644 index 00000000..c0e3a7f8 --- /dev/null +++ b/packages/react/src/components/Switch/Switch.stories.mdx @@ -0,0 +1,56 @@ +import {ArgsTable, Source, Story, Canvas, Meta} from '@storybook/addon-docs'; +import dedent from 'ts-dedent'; +import StoryConfig from '../../../.storybook/story-config.ts'; +import Switch from './Switch.tsx'; +import FormControlLabel from '../FormControlLabel' + +export const meta = { + component: Switch, + title: StoryConfig.Switch.hierarchy, +}; + + + +export const Template = (args) => { + return ( + + ) +}; + +# Switch + +- [Overview](#overview) +- [Props](#props) +- [Usage](#usage) + +## Overview + +Switches toggle the state of a single setting on or off. + + + + {Template.bind({})} + + + +## Props + + + +## Usage + +Import and use the `Switch` component in your components as follows. + +} label="Off" />; +}`} +/> diff --git a/packages/react/src/components/Switch/Switch.tsx b/packages/react/src/components/Switch/Switch.tsx new file mode 100644 index 00000000..6b4aae39 --- /dev/null +++ b/packages/react/src/components/Switch/Switch.tsx @@ -0,0 +1,47 @@ +/** + * Copyright (c) 2023, WSO2 LLC. (https://www.wso2.com). All Rights Reserved. + * + * WSO2 LLC. licenses this file to you under the Apache License, + * Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import MuiSwitch, {SwitchProps as MuiSwitchProps} from '@mui/material/Switch'; +import clsx from 'clsx'; +import {forwardRef, ForwardRefExoticComponent, ReactElement, MutableRefObject} from 'react'; +import {WithWrapperProps} from '../../models'; +import {composeComponentDisplayName} from '../../utils'; +import './switch.scss'; + +export type SwitchProps = MuiSwitchProps; + +const COMPONENT_NAME: string = 'Switch'; + +/** + * @remarks `any` is used as the generic type for the props because the generic type is not used in the component. + */ +const Switch: ForwardRefExoticComponent & WithWrapperProps = forwardRef( + (props: SwitchProps, ref: MutableRefObject): ReactElement => { + const {className, ...rest} = props; + + const classes: string = clsx('oxygen-switch', className); + + return ; + }, +) as ForwardRefExoticComponent & WithWrapperProps; + +Switch.displayName = composeComponentDisplayName(COMPONENT_NAME); +Switch.muiName = COMPONENT_NAME; +Switch.defaultProps = {}; + +export default Switch; diff --git a/packages/react/src/components/Switch/__tests__/Switch.test.tsx b/packages/react/src/components/Switch/__tests__/Switch.test.tsx new file mode 100644 index 00000000..c560a6f0 --- /dev/null +++ b/packages/react/src/components/Switch/__tests__/Switch.test.tsx @@ -0,0 +1,32 @@ +/** + * Copyright (c) 2023, WSO2 LLC. (https://www.wso2.com). All Rights Reserved. + * + * WSO2 LLC. licenses this file to you under the Apache License, + * Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +import {render} from '@unit-testing'; +import Switch from '../Switch'; + +describe('Alert', () => { + it('should render successfully', () => { + const {baseElement} = render(); + expect(baseElement).toBeTruthy(); + }); + + it('should match the snapshot', () => { + const {baseElement} = render(); + expect(baseElement).toMatchSnapshot(); + }); +}); diff --git a/packages/react/src/components/Switch/index.ts b/packages/react/src/components/Switch/index.ts new file mode 100644 index 00000000..305d4d4c --- /dev/null +++ b/packages/react/src/components/Switch/index.ts @@ -0,0 +1,20 @@ +/** + * Copyright (c) 2023, WSO2 LLC. (https://www.wso2.com). All Rights Reserved. + * + * WSO2 LLC. licenses this file to you under the Apache License, + * Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +export {default} from './Switch'; +export type {SwitchProps} from './Switch'; diff --git a/packages/react/src/components/Switch/switch.scss b/packages/react/src/components/Switch/switch.scss new file mode 100644 index 00000000..049a6fb2 --- /dev/null +++ b/packages/react/src/components/Switch/switch.scss @@ -0,0 +1,26 @@ +/** + * Copyright (c) 2023, WSO2 LLC. (https://www.wso2.com). All Rights Reserved. + * + * WSO2 LLC. licenses this file to you under the Apache License, + * Version 2.0 (the "License"); you may not use this file except + * in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +.oxygen-switch { + padding-top: 14px !important; + padding-bottom: 14px !important; + + .MuiButtonBase-root { + height: 32px !important; + } +} diff --git a/packages/react/src/components/index.ts b/packages/react/src/components/index.ts index 119dd818..b2dbb46b 100644 --- a/packages/react/src/components/index.ts +++ b/packages/react/src/components/index.ts @@ -202,6 +202,9 @@ export * from './Skeleton'; export {default as Stepper} from './Stepper'; export * from './Stepper'; +export {default as Switch} from './Switch'; +export * from './Switch'; + export {default as Tab} from './Tab'; export * from './Tab'; From 665be5e87e5a48ad9dd9392cde616dad4f9e8747 Mon Sep 17 00:00:00 2001 From: Pavindu Lakshan Date: Tue, 31 Oct 2023 14:19:51 +0530 Subject: [PATCH 2/3] test(react): add snapshot for Switch component --- .../__snapshots__/Switch.test.tsx.snap | 29 +++++++++++++++++++ 1 file changed, 29 insertions(+) create mode 100644 packages/react/src/components/Switch/__tests__/__snapshots__/Switch.test.tsx.snap diff --git a/packages/react/src/components/Switch/__tests__/__snapshots__/Switch.test.tsx.snap b/packages/react/src/components/Switch/__tests__/__snapshots__/Switch.test.tsx.snap new file mode 100644 index 00000000..54c9bebd --- /dev/null +++ b/packages/react/src/components/Switch/__tests__/__snapshots__/Switch.test.tsx.snap @@ -0,0 +1,29 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`Alert should match the snapshot 1`] = ` + +
+ + + + + + + + +
+ +`; From d39ff32ec63df69f78029f1c37e03d909b68f331 Mon Sep 17 00:00:00 2001 From: Pavindu Lakshan Date: Wed, 1 Nov 2023 11:21:22 +0530 Subject: [PATCH 3/3] fix(react): fix style issues in switch component --- packages/react/src/components/Switch/switch.scss | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/packages/react/src/components/Switch/switch.scss b/packages/react/src/components/Switch/switch.scss index 049a6fb2..80099f53 100644 --- a/packages/react/src/components/Switch/switch.scss +++ b/packages/react/src/components/Switch/switch.scss @@ -17,10 +17,5 @@ */ .oxygen-switch { - padding-top: 14px !important; - padding-bottom: 14px !important; - - .MuiButtonBase-root { - height: 32px !important; - } + /* Add styles */ }