@paprika/button
v1.1.18
Published
Button component, for performing an action on the page you’re viewing.
Downloads
27,349
Keywords
Readme
@paprika/button
Description
Button component, for performing an action on the page you’re viewing.
Installation
yarn add @paprika/button
or with npm:
npm install @paprika/button
Props
Button
| Prop | Type | required | default | Description | | ------------ | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -------- | ------------------------- | ---------------------------------------------------------------------------------------------------------------- | | a11yText | string | false | null | Descriptive a11y text for assistive technologies. By default, text from children node will be used. | | canPropagate | bool | false | true | If click events are allowed to propagate up the DOM tree. | | children | node | false | null | Body content of the button. | | icon | node | false | null | An icon to be included to the left of children content. | | isActive | bool | false | null | If the button is in an "active" or "selected" state. | | isDisabled | bool | false | false | If the button is disabled. | | isDropdown | bool | false | false | If the button includes a down arrow to the right of children content. | | isFullWidth | bool | false | false | If the width of the button should span it's parent container (100%). | | isPending | bool | false | false | If the button should render in a pending state (with a spinner icon). | | isSemantic | bool | false | true | If it will be rendered as a element. If false, a will be rendered via an accessible . | | isSubmit | bool | false | false | If the type attribute should "submit", instead of the default "button". | | kind | [ Button.types.kind.DEFAULT, Button.types.kind.PRIMARY, Button.types.kind.SECONDARY, Button.types.kind.DESTRUCTIVE, Button.types.kind.FLAT, Button.types.kind.MINOR, Button.types.kind.LINK] | false | Button.types.kind.DEFAULT | The visual style of the button. | | onClick | func | false | () => {} | Callback to be executed when the button is clicked or activated by keyboard. Typically required. | | role | string | false | "button" | Value for role attribute to override the default of "button". | | size | [ Button.types.size.SMALL, Button.types.size.MEDIUM, Button.types.size.LARGE] | false | Button.types.size.MEDIUM | Size of the button (font size, min-height, padding, etc). | | tabIndex | number | false | null | Value for tabindex attribute to override the default of 0. |
Button.Close
| Prop | Type | required | default | Description | | -------- | ------ | -------- | ------- | --------------------------------------------------------------------------------------------------- | | a11yText | string | false | null | Descriptive a11y text for assistive technologies. By default, text from children node will be used. | | isDark | bool | false | false | If the close button will be rendered on a dark background and will use inverted colours. |
Button.Icon
| Prop | Type | required | default | Description | | -------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | -------- | ----------------------- | --------------------------------------------------------- | | children | node | true | - | Body content of the button (an icon). | | kind | [ Icon.types.kind.DEFAULT, Icon.types.kind.PRIMARY, Icon.types.kind.SECONDARY, Icon.types.kind.DESTRUCTIVE, Icon.types.kind.FLAT, Icon.types.kind.MINOR, Icon.types.kind.LINK] | false | Icon.types.kind.DEFAULT | The visual style of the button. | | size | [ Icon.types.size.SMALL, Icon.types.size.MEDIUM, Icon.types.size.LARGE] | false | Icon.types.size.MEDIUM | Size of the button (font size, min-height, padding, etc). |
Button.Link
| Prop | Type | required | default | Description | | ---------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | -------- | ---------------------- | --------------------------------------------------------------------------------------------------- | | a11yText | string | false | null | Descriptive a11y text for assistive technologies. By default, text from children node will be used. | | children | node | true | - | Body content of the button. | | href | string | true | - | Url for the link. | | icon | node | false | null | An icon to be included to the left of children content. | | isDisabled | bool | false | false | If the button is disabled. | | kind | [ Link.types.kind.DEFAULT, Link.types.kind.PRIMARY, Link.types.kind.SECONDARY, Link.types.kind.DESTRUCTIVE, Link.types.kind.FLAT, Link.types.kind.MINOR, Link.types.kind.LINK] | false | Link.types.kind.LINK | The visual style of the button. | | size | [ Link.types.size.SMALL, Link.types.size.MEDIUM, Link.types.size.LARGE] | false | Link.types.size.MEDIUM | Size of the button (font size, min-height, padding, etc). | | shouldOpenNewTab | bool | false | false | Whether the link should open a new tab. | | suffixIcon | node | false | | Size of the button (font size, min-height, padding, etc). |
Button
The <Button>
component is a fully accessible button intended for use typically as a skeuomorphic button, but many visual styles (kinds) are available.
For buttons with a label that is only an icon, the <Button.Icon>
component is provided. For typical close buttons, <Button.Close>
is provided.
It is rendered as a <button>
element by default, but can also be rendered as a generic <span>
, via the <RawButton>
if global CSS conflicts are an issue (when isSemantic
prop is set to false
).
Usage
For a basic button
import Button from "@paprika/button";
<Button onClick={clickHandler}>Button label</Button>;
Or an Icon button
import Button from "@paprika/button";
import InfoIcon from "@paprika/icon/lib/InfoCircle";
<Button.Icon onClick={clickHandler}>
<InfoIcon />
</Button.Icon>;
Or a Close button
import Button from "@paprika/button";
<Button.Close onClick={clickHandler} />;