nested_choice_list 0.0.9
nested_choice_list: ^0.0.9 copied to clipboard
A flutter package for handling nested list item selection without limitation for the depth of the nested list.
A flutter package for handling nested list item selection without limitation for the depth of the nested list.
NestedChoiceList with single item selection example #
import 'package:flutter/material.dart';
import 'package:nested_choice_list/nested_choice_list.dart';
class SingleSelectionExample extends StatelessWidget {
const SingleSelectionExample({super.key});
final items = const [
NestedChoiceEntity(
value: 'value1',
label: 'label1 level1',
children: [
NestedChoiceEntity(value: 'value2', label: 'label2 level 2'),
NestedChoiceEntity(value: 'value3', label: 'label3 level 2'),
NestedChoiceEntity(
value: 'value4',
label: 'label4 level 2',
children: [
NestedChoiceEntity(value: 'value2', label: 'label2 level 3'),
NestedChoiceEntity(value: 'value3', label: 'label3 level 3'),
NestedChoiceEntity(
value: 'value4',
label: 'label4',
children: [
NestedChoiceEntity(value: 'value2', label: 'label2 level 4'),
NestedChoiceEntity(value: 'value3', label: 'label3 level 4'),
NestedChoiceEntity(value: 'value4', label: 'label4 level 4'),
],
),
],
),
],
),
NestedChoiceEntity(
value: 'value2',
label: 'label2 level1',
children: [
NestedChoiceEntity(value: 'value2', label: 'label2 level 2'),
NestedChoiceEntity(value: 'value3', label: 'label3 level 2'),
NestedChoiceEntity(
value: 'value4',
label: 'label4 level 2',
children: [
NestedChoiceEntity(value: 'value2', label: 'label2 level 3'),
NestedChoiceEntity(value: 'value3', label: 'label3 level 3'),
NestedChoiceEntity(value: 'value4', label: 'label4 level 3'),
],
),
],
),
NestedChoiceEntity(
value: 'value3',
label: 'label3 level1',
children: [
NestedChoiceEntity(value: 'value2', label: 'label2 level 2'),
NestedChoiceEntity(value: 'value3', label: 'label3 level 2'),
NestedChoiceEntity(value: 'value4', label: 'label4 level 2'),
],
),
NestedChoiceEntity(value: 'value4', label: 'label4 level1'),
];
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
backgroundColor: Theme.of(context).colorScheme.inversePrimary,
title: const Text('Nested Choice List with single selection'),
),
body: NestedChoiceList(
items: items,
onTapItem: (item) {
print(item);
Navigator.pop(context);
},
),
);
}
}
NestedChoiceList with multiple item selection example #
import 'package:flutter/material.dart';
import 'package:nested_choice_list/nested_choice_list.dart';
class MultiSelectionExample extends StatelessWidget {
const MultiSelectionExample({super.key});
final items = const [
NestedChoiceEntity(
value: 'value1',
label: 'label1 level1',
children: [
NestedChoiceEntity(value: 'value2', label: 'label2 level 2'),
NestedChoiceEntity(value: 'value3', label: 'label3 level 2'),
NestedChoiceEntity(
value: 'value4',
label: 'label4 level 2',
children: [
NestedChoiceEntity(value: 'value2', label: 'label2 level 3'),
NestedChoiceEntity(value: 'value3', label: 'label3 level 3'),
NestedChoiceEntity(
value: 'value4',
label: 'label4',
children: [
NestedChoiceEntity(value: 'value2', label: 'label2 level 4'),
NestedChoiceEntity(value: 'value3', label: 'label3 level 4'),
NestedChoiceEntity(value: 'value4', label: 'label4 level 4'),
],
),
],
),
],
),
NestedChoiceEntity(
value: 'value2',
label: 'label2 level1',
children: [
NestedChoiceEntity(value: 'value2', label: 'label2 level 2'),
NestedChoiceEntity(value: 'value3', label: 'label3 level 2'),
NestedChoiceEntity(
value: 'value4',
label: 'label4 level 2',
children: [
NestedChoiceEntity(value: 'value2', label: 'label2 level 3'),
NestedChoiceEntity(value: 'value3', label: 'label3 level 3'),
NestedChoiceEntity(value: 'value4', label: 'label4 level 3'),
],
),
],
),
NestedChoiceEntity(
value: 'value3',
label: 'label3 level1',
children: [
NestedChoiceEntity(value: 'value2', label: 'label2 level 2'),
NestedChoiceEntity(value: 'value3', label: 'label3 level 2'),
NestedChoiceEntity(value: 'value4', label: 'label4 level 2'),
],
),
NestedChoiceEntity(value: 'value4', label: 'label4 level1'),
];
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
backgroundColor: Theme.of(context).colorScheme.inversePrimary,
title: const Text('Nested Choice List with mulitple selection'),
),
body: NestedChoiceList(
items: items,
isMultiSelect: true,
onTapItem: (item) {
print(item);
},
),
);
}
}