Object Dropdown Knob
The object knob allows you to dynamically enter an object value for a widget property in the Widgetbook UI. This is particularly useful for properties that require an object input, such as a user profile or an enum value.
Variants
The object knob has two variants:
context.knobs.object.dropdown()
: This variant allows you to enter an object value via a dropdown menu. It does not acceptnull
values.context.knobs.objectOrNull.dropdown()
: This variant allows you to enter an object value via a dropdown menu or set the value tonull
. It is useful when the property can be optional.
Widgetbook also offers support for segmented button object knobs which are documented on the Object Segmented Knob page.
Properties
In addition to the knob's base properties, the object dropdown knob includes the following:
options
T
required
The options shown in the dropdown menu. The type of the options must be the same as the type of the property.
labelBuilder
LabelBuilder<T>
optional
A function to format the options for display in the dropdown menu.
Usage
To use the object dropdown knob, call the context.knobs.object.dropdown()
method.
@UseCase(type: MyWidget, name: 'Default')
Widget buildUseCase(BuildContext context) {
return MyWidget(
status: context.knobs.object.dropdown(
label: 'status',
labelBuilder: (value) => value!.name,
options: [
OnlineStatusType.online,
OnlineStatusType.offline,
OnlineStatusType.busy,
],
),
);
}
enum OnlineStatusType { online, offline, busy }
Usage
To use the nullable object dropdown knob, call the context.knobs.objectOrNull.dropdown()
method.
@UseCase(type: MyWidget, name: 'Default')
Widget buildUseCase(BuildContext context) {
return MyWidget(
status: context.knobs.objectOrNull.dropdown(
label: 'status',
labelBuilder: (value) => value!.name,
options: [
OnlineStatusType.online,
OnlineStatusType.offline,
OnlineStatusType.busy,
],
),
);
}
enum OnlineStatusType { online, offline, busy }
Multi-snapshot Support
Multi-snapshot support for Widgetbook Cloud allows you to generate multiple screenshots of a single use case with varying values using KnobsConfigs and AddonsConfigs. Please refer to the ObjectKnobConfig page for more information.