Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lanarsinc/direct-select-flutter
DirectSelect is a selection widget with an ethereal, full-screen modal popup displaying the available choices when the widget is interact with. https://dribbble.com/shots/3876250-DirectSelect-Dropdown-ux
https://github.com/lanarsinc/direct-select-flutter
flutter flutter-ui flutter-ui-collection selection-widget widget
Last synced: 4 days ago
JSON representation
DirectSelect is a selection widget with an ethereal, full-screen modal popup displaying the available choices when the widget is interact with. https://dribbble.com/shots/3876250-DirectSelect-Dropdown-ux
- Host: GitHub
- URL: https://github.com/lanarsinc/direct-select-flutter
- Owner: LanarsInc
- License: bsd-2-clause
- Created: 2019-03-15T09:51:29.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2024-01-10T16:18:11.000Z (about 1 year ago)
- Last Synced: 2025-01-12T22:04:18.709Z (11 days ago)
- Topics: flutter, flutter-ui, flutter-ui-collection, selection-widget, widget
- Language: Dart
- Size: 3.79 MB
- Stars: 787
- Watchers: 12
- Forks: 63
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# direct-select-flutter
DirectSelect is a selection widget with an ethereal, full-screen modal popup displaying the available choices when the widget is interact with.
Inspired by [dribble shot](https://dribbble.com/shots/3876250-DirectSelect-Dropdown-ux).Made in [lanars.com](https://lanars.com).
[![pub package](https://img.shields.io/pub/v/direct_select_flutter.svg)](https://pub.dev/packages/direct_select_flutter)
# iOS
# Android
# Usage
Create DirectSelectList and fill it with items using itemBuilder
```dart
final dsl = DirectSelectList(
values: _cities,
defaultItemIndex: 3,
itemBuilder: (String value) => getDropDownMenuItem(value),
focusedItemDecoration: _getDslDecoration(),
onItemSelectedListener: (item, index, context) {
Scaffold.of(context).showSnackBar(SnackBar(content: Text(item)));
});
```
Create items like this
```dart
DirectSelectItem getDropDownMenuItem(String value) {
return DirectSelectItem(
itemHeight: 56,
value: value,
itemBuilder: (context, value) {
return Text(value);
});
}
```
Create decorations for focused items
```dart
_getDslDecoration() {
return BoxDecoration(
border: BorderDirectional(
bottom: BorderSide(width: 1, color: Colors.black12),
top: BorderSide(width: 1, color: Colors.black12),
),
);
}
```
Create DirectSelectContainer and fill it with your data
```dart
Scaffold(
appBar: appBar,
body: DirectSelectContainer(
child: Padding(
padding: const EdgeInsets.all(16.0),
child: Column(
mainAxisSize: MainAxisSize.min,
verticalDirection: VerticalDirection.down,
children: [
SizedBox(height: 150.0),
Padding(
padding: const EdgeInsets.all(8.0),
child: Column(
children: [
Container(
alignment: AlignmentDirectional.centerStart,
margin: EdgeInsets.only(left: 4),
child: Text("City"),
),
Padding(
padding: const EdgeInsets.fromLTRB(0, 8, 0, 0),
child: Card(
child: Row(
mainAxisSize: MainAxisSize.max,
children: [
Expanded(
child: Padding(
child: DirectSelectList(
values: _cities,
defaultItemIndex: 3,
itemBuilder: (String value) => getDropDownMenuItem(value),
focusedItemDecoration: _getDslDecoration(),
onItemSelectedListener: (item, index, context) {
Scaffold.of(context).showSnackBar(SnackBar(content: Text(item)));
}),
padding: EdgeInsets.only(left: 12))),
Padding(
padding: EdgeInsets.only(right: 8),
child: Icon(
Icons.unfold_more,
color: Colors.black38,
),
)
],
),
),
),
],
),
),
],
),
),
),
);
```