set showing as dialog with search

This commit is contained in:
Salvatore Giordano
2018-03-31 20:08:42 +02:00
parent d4e11edc4e
commit 2101639d78
7 changed files with 132 additions and 101 deletions

13
.vscode/launch.json vendored Normal file
View File

@@ -0,0 +1,13 @@
{
// Use IntelliSense to learn about possible attributes.
// Hover to view descriptions of existing attributes.
// For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [
{
"name": "Flutter",
"request": "launch",
"type": "dart"
}
]
}

View File

@@ -1,9 +1,7 @@
# country_code_picker
A new flutter package project.
A flutter package for showing a country code selector.
## Getting Started
## Usage
For help getting started with Flutter, view our online [documentation](https://flutter.io/).
For help on editing package code, view the [documentation](https://flutter.io/developing-packages/).

17
lib/celement.dart Normal file
View File

@@ -0,0 +1,17 @@
class CElement {
String name;
String flag;
String code;
String dial_code;
CElement({this.name, this.flag, this.code, this.dial_code});
@override
String toString() {
return "$flag $dial_code";
}
String toLongString() {
return "$flag $dial_code $name";
}
}

View File

@@ -1,62 +1,64 @@
library country_code_picker;
import 'dart:convert';
import 'dart:io';
import 'package:country_code_picker/country_codes.dart';
import 'package:flutter/material.dart';
class _CElement {
String name;
String flag;
String code;
String dial_code;
_CElement({this.name, this.flag, this.code, this.dial_code});
}
import 'package:country_code_picker/selectionDialog.dart';
import 'package:country_code_picker/celement.dart';
class CountryCodePicker extends StatefulWidget {
final Function(CElement) onChanged;
final String initialSelection;
@override
State<StatefulWidget> createState() {
List<Map> jsonList = codes;
CountryCodePicker({this.onChanged, this.initialSelection});
List<_CElement> elements = jsonList.map((s) =>
new _CElement(name: s['name'],
code: s['code'],
dial_code: s['dial_code'],
flag: s['flag'],
)).toList();
@override
State<StatefulWidget> createState() {
List<Map> jsonList = codes;
return new _CountryCodePickerState(elements);
}
List<CElement> elements = jsonList
.map((s) => new CElement(
name: s['name'],
code: s['code'],
dial_code: s['dial_code'],
flag: s['flag'],
))
.toList();
return new _CountryCodePickerState(elements);
}
}
class _CountryCodePickerState extends State<CountryCodePicker> {
List<_CElement> elements = [];
CElement selectedItem;
List<CElement> elements = [];
_CElement _selectedItem;
_CountryCodePickerState(this.elements);
_CountryCodePickerState(this.elements);
@override
Widget build(BuildContext context) => new GestureDetector(
child: new Text("${selectedItem.toString()}"),
onTap: _showSelectionDialog,
);
@override
initState() {
selectedItem = elements.firstWhere((e) => e.code == widget.initialSelection,
orElse: () => elements[0]);
super.initState();
}
@override
Widget build(BuildContext context) =>
new Container(
height: 40.0,
width: 100.0,
child: new DropdownButton<_CElement>(
value: _selectedItem ?? elements[0],
items: elements.map((e) =>
new DropdownMenuItem<_CElement>(
key: new Key(e.code),
value: e,
child: new Text("${e.flag} ${e.name} ${e.dial_code}"),
)).toList(),
onChanged: (v) {
setState(() {
_selectedItem = v;
});
}),
);
void _showSelectionDialog() {
showDialog(
context: context,
child: new SelectionDialog(elements),
).then((e) {
if (e != null) {
setState(() {
selectedItem = e;
});
if (widget.onChanged != null) {
widget.onChanged(e);
}
}
});
}
}

51
lib/selectionDialog.dart Normal file
View File

@@ -0,0 +1,51 @@
import 'package:flutter/material.dart';
import 'package:country_code_picker/celement.dart';
class SelectionDialog extends StatefulWidget {
final List<CElement> elements;
SelectionDialog(this.elements);
@override
State<StatefulWidget> createState() => new _SelectionDialogState();
}
class _SelectionDialogState extends State<SelectionDialog> {
List<CElement> showedElements = [];
@override
Widget build(BuildContext context) => new SimpleDialog(
title: new TextField(
decoration: new InputDecoration(prefixIcon: new Icon(Icons.search)),
onChanged: _filterElements,
),
children: showedElements
.map((e) => new SimpleDialogOption(
child: new Text(e.toLongString()),
onPressed: () {
_selectItem(e);
}))
.toList());
@override
void initState() {
showedElements = widget.elements;
super.initState();
}
void _filterElements(String s) {
s = s.toUpperCase();
setState(() {
showedElements = widget.elements
.where((e) =>
e.code.contains(s) ||
e.dial_code.contains(s) ||
e.name.toUpperCase().contains(s))
.toList();
});
}
void _selectItem(CElement e) {
Navigator.pop(context, e);
}
}

View File

@@ -9,41 +9,4 @@ dependencies:
sdk: flutter
dev_dependencies:
test: ^0.12.0
# For information on the generic Dart part of this file, see the
# following page: https://www.dartlang.org/tools/pub/pubspec
# The following section is specific to Flutter.
flutter:
# To add assets to your package, add an assets section, like this:
# assets:
# - images/a_dot_burr.jpeg
# - images/a_dot_ham.jpeg
#
# For details regarding assets in packages, see
# https://flutter.io/assets-and-images/#from-packages
#
# An image asset can refer to one or more resolution-specific "variants", see
# https://flutter.io/assets-and-images/#resolution-aware.
# To add custom fonts to your package, add a fonts section here,
# in this "flutter" section. Each entry in this list should have a
# "family" key with the font family name, and a "fonts" key with a
# list giving the asset and other descriptors for the font. For
# example:
# fonts:
# - family: Schyler
# fonts:
# - asset: fonts/Schyler-Regular.ttf
# - asset: fonts/Schyler-Italic.ttf
# style: italic
# - family: Trajan Pro
# fonts:
# - asset: fonts/TrajanPro.ttf
# - asset: fonts/TrajanPro_Bold.ttf
# weight: 700
#
# For details regarding fonts in packages, see
# https://flutter.io/custom-fonts/#from-packages
test: ^0.12.0

View File

@@ -1,13 +0,0 @@
import 'package:test/test.dart';
import 'package:country_code_picker/country_code_picker.dart';
void main() {
test('adds one to input values', () {
final calculator = new Calculator();
expect(calculator.addOne(2), 3);
expect(calculator.addOne(-7), -6);
expect(calculator.addOne(0), 1);
expect(() => calculator.addOne(null), throwsNoSuchMethodError);
});
}