MultiSelectField
is a custom implementation of a multi-select field for Flutter applications. This library provides a flexible and highly configurable solution for projects that require native multi-selection, real-time text filtering, and more advanced features.
- Flexibility: Complete control over the widget's design and behavior, allowing precise customizations according to project requirements.
- Native multi-selection: Implements multi-select functionality natively without the need for additional packages or complex modifications.
- Advanced features: Includes real-time text filtering and the display of selected items as chips, enhancing the user experience.
- Maintenance and evolution: As a custom implementation, it allows easy adaptation and evolution as project needs change.
- Independence: Avoids third-party dependencies, improving project stability and long-term control.
Check out the library on pub.dev.
Add the dependency to your pubspec.yaml
file:
dependencies:
multiselect_field: ^1.6.6
Then, install the dependencies using:
flutter pub get
flutter pub add multiselect_field
import 'package:multi_select_field/multiselect_field.dart';
class MyWidget extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MultiSelectField<Car>(
data: () => [
Choice<Car>('Ferrari'),
Choice<Car>('2', '488 GTB', metadata: Car(103, 27.500, 2015)),
Choice<Car>('3', '458 Italia', metadata: Car(99, 22.000, 2009)),
Choice<Car>('4', 'Portofino', metadata: Car(105, 31.000, 2017)),
Choice<Car>('5', 'California T', metadata: Car(102, 25.000, 2016)),
Choice<Car>('6', 'F8 Tributo', metadata: Car(104, 30.000, 2019)),
],
onSelect: (selectedItems) {
// Handle selected items here
print(selectedItems.map((item) => item.value).toList());
},
useTextFilter: true, // Enables real-time text filtering
);
}
}
data
:List<Choice<T>> Function()
. Function that returns a list ofChoice
elements for selection.onSelect
:Function(List<Choice<T>> ChoiceList)
. Callback invoked when items are selected.title
:Widget Function(bool isEmpty)?
. Optional widget that displays a title, depending on whether the selection is empty.footer
:Widget?
. Optional widget displayed at the bottom.singleSelectWidget
:Widget Function(Choice<T> ChoiceList)?
. Optional widget for displaying a single selected item.multiSelectWidget
:Widget Function(Choice<T> ChoiceList)?
. Optional widget for displaying multiple selected items.defaultData
:List<Choice<T>>?
. Optional function that returns the default list of selected items.singleSelection
:bool
. Defines if the widget should allow only a single selection. Defaults tofalse
.useTextFilter
:bool
. Enables or disables real-time text filtering.decoration
:Decoration?
. Custom decoration for the widget.padding
:EdgeInsetsGeometry?
. Defines the internal padding of the widget.textStyleSingleSelection
:TextStyle?
. Text style for single selection.
MultiSelectField<String>(
data: () => [
Choice(key: 'apple', value: 'Apple'),
Choice(key: 'banana', value: 'Banana'),
Choice(key: 'orange', value: 'Orange'),
],
defaultData: [Choice(key: 'banana', value: 'Banana')],
///[isFromDefault] Helps to know if current selected element is from default data or not.
onSelect: (selectedItems, isFromDefaultData) {
// Update selection state
},
title: (isEmpty) => Text(isEmpty ? 'Select a fruit' : 'Selected fruits'),
singleSelection: false,
useTextFilter: true,
decoration: BoxDecoration(
border: Border.all(color: Colors.blue),
borderRadius: BorderRadius.circular(5),
),
padding: EdgeInsets.all(10),
multiSelectWidget: (item) => Chip(
label: Text(item.value),
onDeleted: () {
// Remove selected item
},
),
);
data:image/s3,"s3://crabby-images/2ec65/2ec656c8a356d577010e5cfd60bbb37ffdb52be4" alt="Screenshot 2024-09-04 at 9 45 32 PM"
data:image/s3,"s3://crabby-images/3bb39/3bb3916bfb8a00a1f8a81e796a701781e8bf181e" alt="Screenshot 2024-09-04 at 9 54 57 PM"
data:image/s3,"s3://crabby-images/03c55/03c556557fbe433927608c031885953faa4a5bb5" alt="Screenshot 2024-09-04 at 9 55 49 PM"
data:image/s3,"s3://crabby-images/96983/969838b1387b7563c4df0abf6c86f5a1172745f0" alt="Screenshot 2024-09-04 at 9 56 50 PM"
data:image/s3,"s3://crabby-images/37477/3747788fd4256a56a641912adb5af5e33d306d80" alt="Screenshot 2024-09-04 at 9 54 03 PM"
Contributions are welcome! If you have ideas for new features or improvements, please open an issue or submit a pull request.
- Fork the repository.
- Create a new branch (
git checkout -b feature/new-feature
). - Commit your changes (
git commit -am 'Add new feature'
). - Push to the branch (
git push origin feature/new-feature
). - Open a pull request.
This project is licensed under the MIT License - see the LICENSE file for details.