Usage
DropDownListView(
defaultItemIndex: 0,
items: ['item1', 'item2', 'item3'],
curve: Curves.ease, // opening or exit animation
safeArea: true, // popup will display with safearea, Default: true
physics: const NeverScrollableScrollPhysics() // scrollphysic for popup dropdown menu
elevation: 5, // elevation for popup dropdown
transitionPerPixel: 0.5, // popup menu duration for each pixel, in other word, control speed of popup menu depend on length
iconData: Icons.arrow_drop_down, // icon for dropdown menu
dropdownItemBuilder: (BuildContext context, dynamic value, int index, bool isSelected){
// value => value of specific item
// index => index of item
// isSelected => true when current index was selected
return Container(
width: double.infinity,
padding: const EdgeInsets.symmetric(vertical: 10, horizontal: 15),
child: Text(value, overflow: TextOverflow.ellipsis)
);
},
dropdownButtonBuilder: (context, int index){ // Build dropdown button
// index => index give the current selected index;
return Padding(
padding: const EdgeInsets.symmetric(horizontal: 20, vertical: 10),
child: Text('value ${val[index]}', overflow: TextOverflow.ellipsis)
);
},
onValueChanged: (value, index){ // this function is optional and will called with selection changed.
print("value changed $value");
},
)