# Checkbox Group
# Playground
        Select All Label:
       
 Field status: 
 Field size: 
 
        Add option:
       
Current value:
[ "Option 2" ]
Rendered class:
# Basic example
<t-checkbox-group
  v-model="model"
  name="checkbox-group"
  :options="[
    { value: 1, text: 'Option 1' },
    { value: 2, text: 'Option 2' }
  ]"
/>
# Props
| Property | Type | Default value | Accepted values | 
|---|---|---|---|
| id | String | null | Any valid type | 
| disabled | Boolean | false | Any valid type | 
| name | String | null | Any valid type | 
| required | Boolean | false | Any valid type | 
| options | Array / Object | [] | Any valid type | 
| valueAttribute | String | undefined | Any valid type | 
| textAttribute | String | undefined | Any valid type | 
| status | String / Boolean | null | true, false, 'success', 'error', 'warning' | 
| size | String | null | 'sm', 'lg' | 
| selectAll | Boolean | false | true, false | 
| selectAllLabel | String | 'Select All' | Any valid type | 
# Classes related props
| Property | Description | 
|---|---|
| baseClass | Base checkbox class (never changes) | 
| defaultStatusClass | Classes when checkbox doesnt has status and is not disabled | 
| errorStatusClass | Classes when checkbox has status of falseor"error" | 
| successStatusClass | Classes when checkbox has status of trueor"success" | 
| warningStatusClass | Classes when checkbox has status of "warning" | 
| disabledClass | Classes when the checkbox is disabled | 
| defaultSizeClass | Classes when the checkbox has no defined size | 
| largeSizeClass | Classes when the checkbox has the size defined as large ( lg) | 
| smallSizeClass | Classes when the checkbox has the size defined as small ( sm) | 
| selectAllClass | Classes when the checkbox has the size defined as small ( sm) | 
# Options format
The component accepts the options in different formats:
# Array of objects
<!-- Value, text attributes (preferred default) -->
<t-checkbox-group :options="[{ value: 1, text: 'Option 1' }, { value: 2, text: 'Option 2' }]" />
<!-- id instead of value as attribute -->
<t-checkbox-group :options="[{ id: 1, text: 'Option 1' }, { id: 2, text: 'Option 2' }]" />
<!-- label instead of text as attribute -->
<t-checkbox-group :options="[{ value: 1, label: 'Option 1' }, { value: 2, label: 'Option 2' }]" />
<!-- All the examples above will render: -->
<div>
  <div>
    <input id="checkbox-field-0" name="checkbox-field" type="checkbox" value="1">
    <label for="checkbox-field-0">Option 1</label>
  </div>
  <div>
    <input id="checkbox-field-1" name="checkbox-field" type="checkbox" value="2">
    <label for="checkbox-field-1">Option 2</label>
  </div>
</div>
# Object with value:text pairs
<t-checkbox-group :options="{ A: 'Option A', B: 'Option B', C: 'Option C' }" />
<!-- Will Render: -->
<div>
  <div>
    <input id="checkbox-field-0" name="checkbox-field" type="checkbox" value="A">
    <label for="checkbox-field-0">Option A</label>
  </div>
  <div>
    <input id="checkbox-field-1" name="checkbox-field" type="checkbox" value="B">
    <label for="checkbox-field-1">Option B</label>
  </div>
  <div>
    <input id="checkbox-field-2" name="checkbox-field" type="checkbox" value="C">
    <label for="checkbox-field-2">Option C</label>
  </div>
</div>
# Array of strings
<t-checkbox-group :options="['Red', 'Blue', 'Yellow']" />
<!-- Will Render: -->
<div>
  <div>
    <input id="checkbox-field-0" name="checkbox-field" type="checkbox" value="Red">
    <label for="checkbox-field-0">Red</label>
  </div>
  <div>
    <input id="checkbox-field-1" name="checkbox-field" type="checkbox" value="Blue">
    <label for="checkbox-field-1">Blue</label>
  </div>
  <div>
    <input id="checkbox-field-2" name="checkbox-field" type="checkbox" value="Yellow">
    <label for="checkbox-field-2">Yellow</label>
  </div>
</div>
# Array of numbers
<t-checkbox-group :options="[18, 19, 20]" />
<!-- Will Render: -->
<div>
  <div>
    <input id="checkbox-field-0" name="checkbox-field" type="checkbox" value="18">
    <label for="checkbox-field-0">18</label>
  </div>
  <div>
    <input id="checkbox-field-1" name="checkbox-field" type="checkbox" value="19">
    <label for="checkbox-field-1">19</label>
  </div>
  <div>
    <input id="checkbox-field-2" name="checkbox-field" type="checkbox" value="20">
    <label for="checkbox-field-2">20</label>
  </div>
</div>
# Define the value/text attributes
<t-checkbox-group
  :options="[
    { key: 'A', description: 'One option' },
    { key: 'B', description: 'Another option' },
    { key: 'C', description: 'One more' },
  ]"
  value-attribute="key"
  text-attribute="description"
/>
<!-- Will Render: -->
<div>
  <div>
    <input id="checkbox-field-0" name="checkbox-field" type="checkbox" value="A">
    <label for="checkbox-field-0">One option</label>
  </div>
  <div>
    <input id="checkbox-field-1" name="checkbox-field" type="checkbox" value="B">
    <label for="checkbox-field-1">Another option</label>
  </div>
  <div>
    <input id="checkbox-field-2" name="checkbox-field" type="checkbox" value="C">
    <label for="checkbox-field-2">One more</label>
  </div>
</div>
# Events
| Event | Arguments | Description | 
|---|---|---|
| input | String (The current value of the checkbox group) | Emitted every time the value of the v-modelchange | 
| change | String (The current value of the checkbox group) | Emitted every time the value of the v-modelchange | 
| focus | FocusEvent | Emitted when the any of the options are focused | 
| blur | FocusEvent | Emitted when the any of the options are blurred |