From dd52279fdc70ea3ff6003f598b0f237d83e36661 Mon Sep 17 00:00:00 2001 From: TJ Egan Date: Mon, 17 Aug 2020 10:10:27 -0700 Subject: [PATCH] docs(ContentSwitcher): update docs (#6650) * docs(ContentSwitcher): update docs * docs(ContentSwitcher): finish up doc updates --- .../react/src/components/Button/Button.mdx | 29 ++- .../ContentSwitcher/ContentSwitcher-story.js | 43 ++-- .../ContentSwitcher/ContentSwitcher.mdx | 203 ++++++++++++++++++ 3 files changed, 238 insertions(+), 37 deletions(-) create mode 100644 packages/react/src/components/ContentSwitcher/ContentSwitcher.mdx diff --git a/packages/react/src/components/Button/Button.mdx b/packages/react/src/components/Button/Button.mdx index f8f0e668b247..987ca19ac875 100644 --- a/packages/react/src/components/Button/Button.mdx +++ b/packages/react/src/components/Button/Button.mdx @@ -10,11 +10,24 @@ import { Add16, Delete16 } from '@carbon/icons-react'; -## Table of Contents - [Overview](#overview) +- [Icon-only Buttons](#icon-only-buttons) +- [Set of Buttons](#set-of-buttons) - [Skeleton state](#skeleton-state) - [Component API](#component-api) + - [Button `as`](#button-as) + - [Button `className`](#button-classname) + - [Button `hasIconOnly`](#button-hasicononly) + - [Button `href`](#button-href) + - [Button `iconDescription`](#button-icondescription) + - [Button `kind`](#button-kind) + - [Button `renderIcon`](#button-rendericon) + - [Button `role`](#button-role) + - [Button `size`](#button-size) + - [Button `tooltipAlignment`](#button-tooltipalignment) + - [Button `tooltipPosition`](#button-tooltipposition) + - [ButtonSet `stacked`](#buttonset-stacked) - [References](#references) - [Feedback](#feedback) @@ -71,7 +84,7 @@ content is being loaded. ## Component API - + Additional props passed into `Button` will be forwarded along to the underlying button element. @@ -294,15 +307,13 @@ By passing in `stacked` to the `ButtonSet` component, you can arrange your two ## References -- [MDN: ARIA button role](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/button_role) -- [W3: Role attribute](https://www.w3.org/WAI/PF/HTML/wiki/RoleAttribute) -- [W3: ARIA button role example](https://www.w3.org/TR/2016/WD-wai-aria-practices-1.1-20160317/examples/button/button.html) +[MDN: ARIA button role](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/button_role) + +[W3: Role attribute](https://www.w3.org/WAI/PF/HTML/wiki/RoleAttribute) + +[W3: ARIA button role example](https://www.w3.org/TR/2016/WD-wai-aria-practices-1.1-20160317/examples/button/button.html) ## Feedback Help us improve these docs by [editing this file on GitHub](https://github.com/carbon-design-system/carbon/edit/master/packages/react/src/components/Accordion/Accordion.stories.mdx) - -``` - -``` diff --git a/packages/react/src/components/ContentSwitcher/ContentSwitcher-story.js b/packages/react/src/components/ContentSwitcher/ContentSwitcher-story.js index a85365d2a2a0..a7fc1f01b49c 100644 --- a/packages/react/src/components/ContentSwitcher/ContentSwitcher-story.js +++ b/packages/react/src/components/ContentSwitcher/ContentSwitcher-story.js @@ -10,6 +10,7 @@ import { action } from '@storybook/addon-actions'; import { withKnobs, boolean, select } from '@storybook/addon-knobs'; import ContentSwitcher from '../ContentSwitcher'; import Switch from '../Switch'; +import mdx from './ContentSwitcher.mdx'; const selectionModes = { 'Change selection automatically upon focus (automatic)': 'automatic', @@ -19,6 +20,7 @@ const selectionModes = { const props = { contentSwitcher: () => ({ light: boolean('Light variant (light)', false), + selectedIndex: select('Selected index (selectedIndex)', [0, 1, 2], 0), selectionMode: select( 'Selection mode (selectionMode)', selectionModes, @@ -42,44 +44,29 @@ export default { subcomponents: { Switch, }, + docs: { + page: mdx, + }, }, }; -export const Default = () => { - const switchProps = props.switch(); - return ( - - - - - - ); -}; +export const Default = () => ( + {}}> + + + + +); -Default.parameters = { - info: { - text: ` - The Content Switcher component manipulates the content shown following an exclusive or “either/or” pattern. - Create Switch components for each section in the content switcher. - `, - }, -}; +Default.story = { name: 'Content Switcher' }; -export const Selected = () => { +export const ContentSwitcherPlayground = () => { const switchProps = props.switch(); return ( - + ); }; - -Selected.parameters = { - info: { - text: ` - Render the Content Switcher with a different section automatically selected - `, - }, -}; diff --git a/packages/react/src/components/ContentSwitcher/ContentSwitcher.mdx b/packages/react/src/components/ContentSwitcher/ContentSwitcher.mdx new file mode 100644 index 000000000000..476eb0e907c4 --- /dev/null +++ b/packages/react/src/components/ContentSwitcher/ContentSwitcher.mdx @@ -0,0 +1,203 @@ +import { Story, Props, Source, Preview } from '@storybook/addon-docs/blocks'; +import ContentSwitcher from '../ContentSwitcher'; +import Switch from '../Switch'; + +# Content Switcher + + + + + +- [Overview](#overview) +- [Component API](#component-api) + - [ContentSwitcher `className`](#contentswitcher-classname) + - [ContentSwitcher `light`](#contentswitcher-light) + - [ContentSwitcher `onChange`](#contentswitcher-onchange) + - [ContentSwitcher `selectedIndex`](#contentswitcher-selectedindex) + - [ContentSwitcher `selectionMode`](#contentswitcher-selectionmode) + - [Switch `className`](#switch-classname) + - [Switch `disabled`](#switch-disabled) + - [Switch `index`, `name` and `text`](#switch-index-name-and-text) +- [References](#references) + - [Accessibility concerns](#accessibility-concerns) +- [Feedback](#feedback) + + + +## Overview + +Content switchers allow users to toggle between two or more content sections +within the same space on screen. Only one content section is shown at a time. +Create Switch components for each section in the content switcher. + + + + + +## Component API + + + +### ContentSwitcher `className` + +The className prop passed into `ContentSwitcher` will be forwarded along to the +underlying wrapper `div.bx--content-switcher` element. This is useful for +specifying a custom class name for layout. + +```jsx +... +``` + +### ContentSwitcher `light` + +In certain circumstances, a `ContentSwitcher` will exist on a container element +with the same background color. To improve contrast, you can use the `light` +property to toggle the light variant of the `ContentSwitcher`. + +```jsx +... +``` + +### ContentSwitcher `onChange` + +This is a required prop. You will need to specify a function to run when the +selection of the `ContentSwitcher` is changed. + +```jsx + { + /* Code to run on change */ + }}> + ... + +``` + +### ContentSwitcher `selectedIndex` + +This prop allows you to specify which `ContentSwitcher` index you would like to +be selected on initial render. This number defaults to `0`. + + {}}> + + + + + +```jsx + {}}> + + + + +``` + +### ContentSwitcher `selectionMode` + +By default, when a `ContentSwitcher` is focused and an arrow key is pressed, the +selection is updated immediately and the `onChange` is fired. However, sometimes +you may want to only change the `selectedIndex` once a selection has been made. +To do this, you can set the `selectionMode` to `manual`, and the `onChange` will +only fire when a selection is made. + + { + console.log('change'); + }}> + + + + + +```jsx + { + console.log('change'); + }}> + + + + +``` + +### Switch `className` + +The className prop passed into `Switch` will be forwarded along to the +underlying wrapper `button` element. + +```jsx + + + + +``` + +### Switch `disabled` + +You can disable the `ContentSwitcher` by passing in `disabled` to the `Switch` +elements directly. + + + + + + + +```jsx + + + + + +``` + +### Switch `index`, `name` and `text` + +These are the values that will be returned in the `onChange` call. + + { + const { index, name, text } = obj; + alert(`index: ${index} || name: ${name} || text: ${text}`); + }}> + + + + + +```jsx + { + let { index, name, text } = obj; + alert(`index: ${index} || name: ${name} || text: ${text}`); + }}> + + + + +``` + +## References + +### Accessibility concerns + +Each content switcher tab must have a unique title that clearly describes the +content panel. This is particularly helpful for users of assistive technologies +so they have the necessary information to efficiently navigate the content. + +Content authors need to ensure the content that is added to the tab panel is +accessible. For example, if you add an image to the panel you need to include +alternative text to pass accessibility testing. + +[W3C WAI-ARIA Tab Design Pattern](https://www.w3.org/TR/wai-aria-practices-1.1/#tabpanel) +covers the usage of ARIA names, state and roles, as well as the expected +keyboard interactions. + +[Carbon Usage Guidelines](https://www.carbondesignsystem.com/components/content-switcher/usage/) + +## Feedback + +Help us improve this component by providing feedback, asking questions, and +leaving any other comments on +[GitHub](https://github.com/carbon-design-system/carbon/edit/master/packages/react/src/components/ContentSwitcher/ContentSwitcher.mdx).