enable custom view widgets;

This commit is contained in:
Saif Allah Khaled
2019-09-05 15:47:49 +02:00
parent ce9d724747
commit 894ffd7c9e

View File

@@ -17,6 +17,7 @@ class CountryCodePicker extends StatefulWidget {
final InputDecoration searchDecoration; final InputDecoration searchDecoration;
final TextStyle searchStyle; final TextStyle searchStyle;
final WidgetBuilder emptySearchBuilder; final WidgetBuilder emptySearchBuilder;
final Widget customWidget;
/// shows the name of the country instead of the dialcode /// shows the name of the country instead of the dialcode
final bool showOnlyCountryWhenClosed; final bool showOnlyCountryWhenClosed;
@@ -43,7 +44,8 @@ class CountryCodePicker extends StatefulWidget {
this.emptySearchBuilder, this.emptySearchBuilder,
this.showOnlyCountryWhenClosed = false, this.showOnlyCountryWhenClosed = false,
this.alignLeft = false, this.alignLeft = false,
this.showFlag = true this.showFlag = true,
this.customWidget,
}); });
@override @override
@@ -71,12 +73,17 @@ class _CountryCodePickerState extends State<CountryCodePicker> {
_CountryCodePickerState(this.elements); _CountryCodePickerState(this.elements);
@override @override
Widget build(BuildContext context) => FlatButton( Widget build(BuildContext context) {
child: Flex( Widget _widget;
if (widget.customWidget != null)
_widget = widget.customWidget;
else {
_widget = Flex(
direction: Axis.horizontal, direction: Axis.horizontal,
mainAxisSize: MainAxisSize.min, mainAxisSize: MainAxisSize.min,
children: <Widget>[ children: <Widget>[
widget.showFlag ? Flexible( widget.showFlag
? Flexible(
flex: widget.alignLeft ? 0 : 1, flex: widget.alignLeft ? 0 : 1,
fit: widget.alignLeft ? FlexFit.tight : FlexFit.loose, fit: widget.alignLeft ? FlexFit.tight : FlexFit.loose,
child: Padding( child: Padding(
@@ -89,7 +96,8 @@ class _CountryCodePickerState extends State<CountryCodePicker> {
width: 32.0, width: 32.0,
), ),
), ),
) : Container(), )
: Container(),
Flexible( Flexible(
fit: widget.alignLeft ? FlexFit.tight : FlexFit.loose, fit: widget.alignLeft ? FlexFit.tight : FlexFit.loose,
child: Text( child: Text(
@@ -100,10 +108,14 @@ class _CountryCodePickerState extends State<CountryCodePicker> {
), ),
), ),
], ],
), );
}
return FlatButton(
child: _widget,
padding: widget.padding, padding: widget.padding,
onPressed: _showSelectionDialog, onPressed: _showSelectionDialog,
); );
}
@override @override
initState() { initState() {
@@ -130,16 +142,12 @@ class _CountryCodePickerState extends State<CountryCodePicker> {
void _showSelectionDialog() { void _showSelectionDialog() {
showDialog( showDialog(
context: context, context: context,
builder: (_) => builder: (_) => SelectionDialog(elements, favoriteElements,
SelectionDialog(
elements,
favoriteElements,
showCountryOnly: widget.showCountryOnly, showCountryOnly: widget.showCountryOnly,
emptySearchBuilder: widget.emptySearchBuilder, emptySearchBuilder: widget.emptySearchBuilder,
searchDecoration: widget.searchDecoration, searchDecoration: widget.searchDecoration,
searchStyle: widget.searchStyle, searchStyle: widget.searchStyle,
showFlag: widget.showFlag showFlag: widget.showFlag),
),
).then((e) { ).then((e) {
if (e != null) { if (e != null) {
setState(() { setState(() {