@nice-digital/nds-checkbox
v4.0.14
Published
Checkbox component for the NICE Design System
Downloads
648
Maintainers
Keywords
Readme
@nice-digital/nds-checkbox
Checkbox component for the NICE Design System
@nice-digital/nds-checkbox
- Installation - Usage - React - Props - SCSS - HTML
Installation
Install Node, and then:
npm i @nice-digital/nds-checkbox --save
Usage
React
Import the Checkbox
component from the package and use within JSX:
import React from "react";
import { Checkbox } from "@nice-digital/nds-checkbox";
// The mimimum to be supplied for the input to render is a value and a name
<Checkbox value="yes" name="contact-permission" />;
Note: The React component automatically imports the SCSS, so there's no need to import the SCSS directly yourself.
Props
value
- Type:
string
(required)
The value for the single input.
<Checkbox value="yes" name="contact-permission" />
name
- Type:
string
(required)
The name attribute on the single input
<Checkbox label="yes" name="contact-permission" />
label
- Type:
string
The label for the single input.
<Checkbox label="yes" name="contact-permission" label="Yes, please." />
hint
- Type:
string
Any hint or help text that should be rendered underneath the checkbox and label
<Checkbox
label="yes"
name="contact-permission"
label="Yes, please."
hint="You can unsubscribe at any time"
/>
disabled
- Type:
boolean
Prop to control whether the disabled attribute is present on the input.
<Checkbox label="yes" name="contact-permission" disabled={true} />
error
- Type:
string
|boolean
Prop to control whether an error class (and styling) is applied to the input, label and container. If true
is supplied then the error styling is applied, if a string
is supplied, the error styling is applied and an error message is rendered.
<Checkbox label="yes" name="contact-permission" error={true} />
<Checkbox label="yes" name="contact-permission" error="Please check the terms and conditions" />
hint
- Type:
string
Add hint text underneath the label
<Checkbox
label="yes"
name="contact-permission"
hint="You can unsubscribe at any time."
/>
inline
- Type:
boolean
Prop to control whether the container recieves a class to set it visually inline. All checkboxes in the group would need this prop.
<div>
<Checkbox label="yes" name="contact-permission" inline={true} />
<Checkbox label="no" name="contact-permission" inline={true} />
</div>
anything else
You can pass any other props to the component that will be added to the input
tag
const otherProps = {
"data-testing": true,
"qa-selection": "checkbox control"
}
<Checkbox label="yes" group="my-group" {...otherProps} />
SCSS
If you're not using React, then import the SCSS directly into your application by:
@forward '@nice-digital/nds-checkbox/scss/checkbox';
HTML
If you're not using React, then include the SCSS as above and use the HTML:
<div class="checkbox">
<input
type="checkbox"
class="checkbox__input"
id="contact-preference_email"
name="contact-preference"
value="email"
/>
<label class="checkbox__label" for="contact-preference_email">
Email
</label>
</div>
Error state:
<div class="checkbox checkbox--error">
<input
type="checkbox"
class="checkbox__input"
id="contact-preference_email"
name="contact-preference"
value="email"
/>
<label class="checkbox__label" for="contact-preference_email">
Email
</label>
</div>