Checkbox
A checkbox component with configurable variants, sizes, label content, and validation states.
Live Preview
Basic Usage
blade
<x-basekit-ui::checkbox
name="terms"
value="accepted"
label="I accept the terms"
/>Props
| Prop | Type | Default | Description |
|---|---|---|---|
value | string | null | Submitted value |
is-checked | bool | false | Initial checked state |
variant | string | 'primary' | Visual style: primary, secondary, success, warning, danger, info, ghost |
size | string | 'md' | Control size: sm, md, lg |
label | string | null | Label text |
error | string | null | Error message shown below the control |
hint | string | null | Helper text shown below the control |
Standard checkbox attributes such as name, id, and disabled pass through to the underlying <input> element.
Slots
| Slot | Description |
|---|---|
label | Custom label markup |
error | Custom error markup |
hint | Custom helper text |
Variants
Supported variants: primary, secondary, success, warning, danger, info, ghost.
blade
<x-basekit-ui::checkbox name="primary" variant="primary" :is-checked="true" label="Primary" />
<x-basekit-ui::checkbox name="secondary" variant="secondary" :is-checked="true" label="Secondary" />
<x-basekit-ui::checkbox name="success" variant="success" :is-checked="true" label="Success" />
<x-basekit-ui::checkbox name="warning" variant="warning" :is-checked="true" label="Warning" />
<x-basekit-ui::checkbox name="danger" variant="danger" :is-checked="true" label="Danger" />
<x-basekit-ui::checkbox name="info" variant="info" :is-checked="true" label="Info" />
<x-basekit-ui::checkbox name="ghost" variant="ghost" :is-checked="true" label="Ghost" />Sizes
Supported sizes: sm, md, lg.
blade
<x-basekit-ui::checkbox name="small" size="sm" label="Small" />
<x-basekit-ui::checkbox name="medium" size="md" label="Medium" />
<x-basekit-ui::checkbox name="large" size="lg" label="Large" />Custom Label Markup
blade
<x-basekit-ui::checkbox name="terms">
<x-slot:label>
I agree to the <a href="/terms" class="text-blue-600">Terms of Service</a>
</x-slot:label>
</x-basekit-ui::checkbox>Checked and Error States
blade
<x-basekit-ui::checkbox
name="remember"
:is-checked="true"
label="Remember me"
/>
<x-basekit-ui::checkbox
name="newsletter"
error="Please confirm your choice"
label="Subscribe to updates"
/>Custom Classes
Override or extend styles with the class attribute:
blade
<x-basekit-ui::checkbox
name="custom-terms"
label="I agree"
class="mt-2"
/>CSS Variables
Customize checkbox appearance via CSS variables:
css
:root {
/* Checkbox - Base */
--checkbox-color: var(--color-slate-900);
--checkbox-border-color: var(--color-slate-300);
--checkbox-border-radius: var(--radius-sm);
--checkbox-transition:
background-color var(--transition-normal),
border-color var(--transition-normal), box-shadow var(--transition-normal);
/* Checkbox - Sizes */
--checkbox-size-sm: 1rem;
--checkbox-size-md: 1.125rem;
--checkbox-size-lg: 1.25rem;
/* Checkbox - States */
--checkbox-hover-border-color: var(--color-slate-400);
--checkbox-focus-border-color: var(--color-primary-500);
--checkbox-focus-ring-color: var(--color-primary-100);
--checkbox-focus-ring-width: 2px;
--checkbox-disabled-bg: var(--color-slate-100);
--checkbox-disabled-border-color: var(--color-slate-200);
--checkbox-disabled-color: var(--color-slate-500);
--checkbox-error-border-color: var(--color-danger-500);
--checkbox-error-ring-color: var(--color-danger-100);
--checkbox-error-color: var(--color-danger-700);
/* Checkbox - Variants */
--checkbox-primary-checked-bg: var(--color-primary-600);
--checkbox-primary-checked-border: var(--color-primary-600);
--checkbox-primary-focus-ring: var(--color-primary-100);
--checkbox-secondary-checked-bg: var(--color-slate-600);
--checkbox-secondary-checked-border: var(--color-slate-600);
--checkbox-secondary-focus-ring: var(--color-slate-200);
--checkbox-success-checked-bg: var(--color-success-600);
--checkbox-success-checked-border: var(--color-success-600);
--checkbox-success-focus-ring: var(--color-success-100);
--checkbox-warning-checked-bg: var(--color-warning-600);
--checkbox-warning-checked-border: var(--color-warning-600);
--checkbox-warning-focus-ring: var(--color-warning-100);
--checkbox-danger-checked-bg: var(--color-danger-600);
--checkbox-danger-checked-border: var(--color-danger-600);
--checkbox-danger-focus-ring: var(--color-danger-100);
--checkbox-info-checked-bg: var(--color-info-600);
--checkbox-info-checked-border: var(--color-info-600);
--checkbox-info-focus-ring: var(--color-info-100);
--checkbox-ghost-bg: transparent;
--checkbox-ghost-border: var(--color-slate-300);
--checkbox-ghost-checked-bg: var(--color-slate-700);
--checkbox-ghost-checked-border: var(--color-slate-700);
--checkbox-ghost-focus-ring: var(--color-slate-200);
}Configuration
Configure defaults in config/basekit-laravel-ui.php:
php
'checkbox' => [
'enabled' => true,
'variants' => ['primary', 'secondary', 'success', 'warning', 'danger', 'info', 'ghost'],
'sizes' => ['sm', 'md', 'lg'],
'default_variant' => 'primary',
'default_size' => 'md',
],