Skip to content

Commit

Permalink
feat: implement :focus-visible for the Switch component with target…
Browse files Browse the repository at this point in the history
…ed focus style for non-pointer devices
  • Loading branch information
cheton committed Sep 8, 2023
1 parent 947354e commit 24f5aa5
Show file tree
Hide file tree
Showing 10 changed files with 364 additions and 274 deletions.
12 changes: 12 additions & 0 deletions packages/react-docs/pages/components/switch/basic.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
import { Switch } from '@tonic-ui/react';
import React from 'react';

const App = () => {
return (
<Switch>
Label
</Switch>
);
};

export default App;
17 changes: 17 additions & 0 deletions packages/react-docs/pages/components/switch/colors.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import { Flex, Switch } from '@tonic-ui/react';
import React from 'react';

const App = () => {
return (
<Flex columnGap="6x">
<Switch variantColor="red" defaultChecked>
Label
</Switch>
<Switch variantColor="green" defaultChecked>
Label
</Switch>
</Flex>
);
};

export default App;
27 changes: 27 additions & 0 deletions packages/react-docs/pages/components/switch/faq-input-element.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import { Button, Flex, Switch } from '@tonic-ui/react';
import React, { useRef } from 'react';

const App = () => {
const inputRef = useRef();

const handleClick = () => {
const inputEl = inputRef?.current;
if (inputEl) {
inputEl.focus();
window.alert('The switch toggle is ' + (inputEl.checked ? 'on' : 'off'));
}
};

return (
<Flex alignItems="center" columnGap="6x">
<Switch defaultChecked inputRef={inputRef}>
Label
</Switch>
<Button onClick={handleClick}>
Click Me
</Button>
</Flex>
);
};

export default App;
24 changes: 24 additions & 0 deletions packages/react-docs/pages/components/switch/flex-layout.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
import { Box, Flex, Switch, Text } from '@tonic-ui/react';
import React from 'react';

const App = () => {
return (
<Flex alignItems="flex-start" columnGap="2x">
<Switch id="form-control" />
<Box
as="label"
htmlFor="form-control"
sx={{
cursor: 'pointer',
pt: '1x',
userSelect: 'none',
}}
>
<Text>Label</Text>
<Text fontSize="xs" lineHeight="xs">Helper text</Text>
</Box>
</Flex>
);
};

export default App;
Original file line number Diff line number Diff line change
Expand Up @@ -10,87 +10,29 @@ import { Switch } from '@tonic-ui/react';

## Usage

```jsx
<Switch>
Label
</Switch>
```
### Basic

{render('./basic')}

You can use a flex container to align a switch with other components. This allows you to easily control the positioning and spacing of all elements within the container.

```jsx
<Flex alignItems="flex-start" columnGap="2x">
<Switch id="form-control" />
<Box
as="label"
htmlFor="form-control"
sx={{
cursor: 'pointer',
pt: '1x',
userSelect: 'none',
}}
>
<Text>Label</Text>
<Text fontSize="xs" lineHeight="xs">Helper text</Text>
</Box>
</Flex>
```
{render('./flex-layout')}

### Colors

Use the `variantColor` prop to change the color scheme of a radio button. `variantColor` can be any color key with key `50` (hover) or `60` (checked) that exist in `theme.colors`.

```jsx
<Flex columnGap="6x">
<Switch variantColor="red" defaultChecked>
Label
</Switch>
<Switch variantColor="green" defaultChecked>
Label
</Switch>
</Flex>
```
{render('./colors')}

### Sizes

Use the `size` prop to change the size of the switch. You can set the value to `sm`, `md`, or `lg`.

```jsx
<Flex columnGap="6x">
<Switch size="sm">
Label
</Switch>
<Switch size="md">
Label
</Switch>
<Switch size="lg">
Label
</Switch>
</Flex>
```
{render('./sizes')}

### States

```jsx
<Stack spacing="6x">
<Flex columnGap="6x">
<Switch>
Label
</Switch>
<Switch checked>
Label
</Switch>
</Flex>
<Flex columnGap="6x">
<Switch disabled>
Label
</Switch>
<Switch checked disabled>
Label
</Switch>
</Flex>
</Stack>
```
{render('./states')}

## Accessibility

Expand All @@ -117,27 +59,7 @@ Once you have obtained the reference to the input element, you can access its pr

Here's an example of how you can utilize the `inputRef` prop to access the input element and perform actions:

```jsx
function Example() {
const inputRef = React.useRef();

const handleClick = () => {
inputRef.current.focus();
console.log(inputRef.current.checked); // => true
};

return (
<Flex alignItems="center" columnGap="6x">
<Switch defaultChecked inputRef={inputRef}>
Label
</Switch>
<Button onClick={handleClick}>
Click Me
</Button>
</Flex>
);
}
```
{render('./faq-input-element')}

## Props

Expand Down
20 changes: 20 additions & 0 deletions packages/react-docs/pages/components/switch/sizes.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
import { Flex, Switch } from '@tonic-ui/react';
import React from 'react';

const App = () => {
return (
<Flex columnGap="6x">
<Switch size="sm">
Label
</Switch>
<Switch size="md">
Label
</Switch>
<Switch size="lg">
Label
</Switch>
</Flex>
);
};

export default App;
27 changes: 27 additions & 0 deletions packages/react-docs/pages/components/switch/states.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import { Flex, Stack, Switch } from '@tonic-ui/react';
import React from 'react';

const App = () => {
return (
<Stack spacing="6x">
<Flex columnGap="6x">
<Switch checked={false}>
Label
</Switch>
<Switch checked={true}>
Label
</Switch>
</Flex>
<Flex columnGap="6x">
<Switch checked={false} disabled>
Label
</Switch>
<Switch checked={true} disabled>
Label
</Switch>
</Flex>
</Stack>
);
};

export default App;
Loading

0 comments on commit 24f5aa5

Please sign in to comment.