A Metamask fork with Infura removed and default networks editable
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
ciphermask/ui/components/component-library/label
George Marshall cda3e3e4c0
Adding Label component (#16203)
2 years ago
..
README.mdx Adding Label component (#16203) 2 years ago
index.js Adding Label component (#16203) 2 years ago
label.js Adding Label component (#16203) 2 years ago
label.scss Adding Label component (#16203) 2 years ago
label.stories.js Adding Label component (#16203) 2 years ago
label.test.js Adding Label component (#16203) 2 years ago

README.mdx

import { Story, Canvas, ArgsTable } from '@storybook/addon-docs';

import { Label } from './label';

# Label

The `Label` is a component used to label form inputs.

<Canvas>
<Story id="ui-components-component-library-label-label-stories-js--default-story" />
</Canvas>

## Props

The `Label` accepts all props below as well as all [Text](/docs/ui-components-component-library-text-text-stories-js--default-story#props) and [Box](/docs/ui-components-ui-box-box-stories-js--default-story#props) component props.

<ArgsTable of={Label} />

### Children

The `children` of the label can be text or a react node.

<Canvas>
<Story id="ui-components-component-library-label-label-stories-js--children" />
</Canvas>

```jsx
import { DISPLAY, ALIGN_ITEMS, FLEX_DIRECTION, SIZES, COLORS } from '../../../helpers/constants/design-system';
import { Icon, ICON_NAMES } from '../../ui/component-library/icon';
import { Label } from '../../ui/component-library/label';
import { TextFieldBase } from '../../ui/component-library/text-field-base'

<Label>Plain text</Label>
<Label display={DISPLAY.FLEX} alignItems={ALIGN_ITEMS.FLEX_START}>
Text and icon
<Icon
color={COLORS.ICON_ALTERNATIVE}
name={ICON_NAMES.INFO_FILLED}
size={SIZES.AUTO}
/>
</Label>
<Label
display={DISPLAY.INLINE_FLEX}
flexDirection={FLEX_DIRECTION.COLUMN}
alignItems={ALIGN_ITEMS.FLEX_START}
>
Label that wraps an input
{/* TODO: replace with TextField component */}
<TextFieldBase placeholder="Click label to focus" />
</Label>
```

### Html For

Use the `htmlFor` prop to allow the `Label` to focus on an input with the same id when clicked. The cursor will also change to a `pointer` when the `htmlFor` has a value

<Canvas>
<Story id="ui-components-component-library-label-label-stories-js--html-for" />
</Canvas>

```jsx
import { TextFieldBase } from '../../ui/component-library/text-field-base';
import { Label } from '../../ui/component-library/label';

<Label htmlFor="add-network">Add network</Label>
<TextFieldBase id="add-network" placeholder="Enter network name" />
```

### Required

Use the `required` prop to add a required red asterisk next to the `children` of the `Label`. Note the required asterisk will always render after the `children`.

<Canvas>
<Story id="ui-components-component-library-label-label-stories-js--required" />
</Canvas>

```jsx
import { Label } from '../../ui/component-library/label';

<Label required>Label</Label>;
```

### Disabled

Use the `disabled` prop to set the `Label` in disabled state

<Canvas>
<Story id="ui-components-component-library-label-label-stories-js--disabled" />
</Canvas>

```jsx
import { Label } from '../../ui/component-library/label';

<Label disabled>Label</Label>;
```