WFormCheckbox
A Wind-styled checkbox that integrates with Flutter's Form validation, providing built-in support for labels, hints, and error states.
- Basic Usage
- Constructor
- Props
- Layout Modes
- Event Handling
- State Variants
- Styling Examples
- All Supported Classes
- Customizing Theme
- Related Documentation
WFormCheckbox(
value: _agreeTerms,
onChanged: (v) => setState(() => _agreeTerms = v),
labelText: 'I agree to Terms of Service',
className: 'w-5 h-5 rounded border checked:bg-blue-500 error:border-red-500',
validator: (value) => value != true ? 'You must agree to terms' : null,
)
Basic Usage
The WFormCheckbox widget wraps a WCheckbox with a FormField. This allows you to use it directly inside a Form widget for easy validation and state management. When validation fails, it automatically triggers the error: state for its utility classes.
Form(
key: _formKey,
child: WFormCheckbox(
labelText: 'Newsletter',
hint: 'We will send you updates once a week.',
value: isSubscribed,
onChanged: (v) => setState(() => isSubscribed = v),
validator: (v) => v == false ? 'Required' : null,
),
)
Constructor
WFormCheckbox({
Key? key,
bool value = false,
FormFieldValidator? validator,
FormFieldSetter? onSaved,
AutovalidateMode? autovalidateMode,
bool enabled = true,
ValueChanged? onChanged,
String? className,
String? iconClassName,
bool disabled = false,
IconData? checkIcon,
Set? states,
Widget? label,
String? labelText,
String labelClassName = 'text-sm text-gray-700',
String? hint,
String hintClassName = 'text-gray-500 text-xs mt-1',
bool showError = true,
String errorClassName = 'text-red-500 text-xs mt-1',
})
Props
| Prop | Type | Default | Description |
|---|---|---|---|
value |
bool |
false |
The current value of the checkbox. |
className |
String? |
null |
Wind utility classes for the checkbox container. |
onChanged |
ValueChanged |
null |
Callback when the value changes. |
labelText |
String? |
null |
Simple text label displayed next to the checkbox. |
label |
Widget? |
null |
Custom label widget (takes precedence over labelText). |
labelClassName |
String |
'text-sm text-gray-700' |
Styling for the text label. |
hint |
String? |
null |
Optional hint text displayed below the checkbox. |
hintClassName |
String |
'text-gray-500 text-xs mt-1' |
Styling for the hint text. |
showError |
bool |
true |
Whether to display validation error messages. |
errorClassName |
String |
'text-red-500 text-xs mt-1' |
Styling for the error message. |
iconClassName |
String? |
null |
Utility classes for the check icon. |
checkIcon |
IconData? |
null |
Custom icon to use when checked. |
disabled |
bool |
false |
Disables the checkbox and its label interaction. |
states |
Set |
null |
Custom state identifiers merged with built-in checked and disabled triggers. |
Layout Modes
Label & Hint Layout
WFormCheckbox automatically handles the layout of the checkbox, label, and hint/error text. It uses a vertical flex container where the checkbox and label are aligned horizontally, and the hint or error is positioned below them.
WFormCheckbox(
labelText: 'Receive notifications',
hint: 'Enable to get push notifications on your device.',
className: 'w-6 h-6',
)
Event Handling
The onChanged callback is triggered whenever the user toggles the checkbox or clicks on the associated label. Since it's a FormField, it also integrates with standard form lifecycle events like onSaved and validator.
WFormCheckbox(
value: _val,
onChanged: (newValue) {
print('Checkbox is now: $newValue');
setState(() => _val = newValue);
},
onSaved: (v) => _model.termsAccepted = v ?? false,
)
State Variants
WFormCheckbox supports all standard Wind state prefixes. Specifically, it activates the error: prefix when the form field validation fails.
WFormCheckbox(
// Base style is gray, turns blue when checked, red on error
className: 'border-gray-300 checked:bg-blue-500 error:border-red-500',
validator: (v) => v != true ? 'Required' : null,
)
Styling Examples
Custom Colors and Sizes
You can easily customize the appearance of the checkbox and its icon using standard Tailwind-like classes.
WFormCheckbox(
className: 'w-8 h-8 rounded-full border-2 border-indigo-200 checked:bg-indigo-600 checked:border-transparent',
iconClassName: 'text-white text-xl',
labelText: 'Large Indigo Checkbox',
labelClassName: 'text-lg font-bold text-indigo-900',
)
Error State Customization
You can control how the error message appears when validation fails.
WFormCheckbox(
labelText: 'Agree to terms',
errorClassName: 'text-orange-600 italic font-medium mt-2',
validator: (v) => v != true ? 'This field is mandatory!' : null,
)
All Supported Classes
| Category | Classes |
|---|---|
| Layout | flex, flex-col, items-start, gap-{n} |
| Spacing | p-{n}, m-{n}, pt-{n}, pl-{n} |
| Sizing | w-{size}, h-{size}, aspect-square |
| Typography | text-{color}, text-{size}, font-{weight}, italic |
| Colors | bg-{color}, border-{color}, checked:bg-{color} |
| Borders | border, border-{width}, rounded, rounded-{size} |
| Form | error:{utility}, disabled:{utility} |
Customizing Theme
You can define default styles for form components in your WindThemeData.
WindThemeData(
// While WFormCheckbox doesn't have a specific theme object,
// it respects global color and spacing scales.
colors: {
'primary': Colors.blue,
'danger': Colors.red,
},
baseSpacingUnit: 4.0,
)
Related Documentation
- WCheckbox - The base checkbox component.
- WFormInput - Form-integrated text input.
- WAnchor - The wrapper used for label interactivity.
- WDiv - The container used for layout.