search_page 0.1.0 search_page: ^0.1.0 copied to clipboard
Fast and easy way to build a custom search view experience
example/lib/main.dart
import 'package:flutter/material.dart';
import 'package:search_page/search_page.dart';
import 'person.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(),
);
}
}
class MyHomePage extends StatelessWidget {
static List<Person> people = [
Person('Mike', 'Barron', 64),
Person('Todd', 'Black', 30),
Person('Ahmad', 'Edwards', 55),
Person('Anthony', 'Johnson', 67),
Person('Annette', 'Brooks', 39),
];
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Search Page'),
),
body: ListView.builder(
itemCount: people.length,
itemBuilder: (context, index) {
final Person person = people[index];
return ListTile(
title: Text(person.name),
subtitle: Text(person.surname),
trailing: Text('${person.age} yo'),
);
},
),
floatingActionButton: FloatingActionButton(
tooltip: 'Search people',
onPressed: () => showSearch(
context: context,
delegate: SearchPage<Person>(
items: people,
searchLabel: 'Search people',
suggestion: Center(
child: Text('Filter people by name, surname or age'),
),
failure: Center(
child: Text('No person found :('),
),
filter: (person) => [
person.name,
person.surname,
person.age.toString(),
],
builder: (person) => ListTile(
title: Text(person.name),
subtitle: Text(person.surname),
trailing: Text('${person.age} yo'),
),
),
),
child: Icon(Icons.search),
),
);
}
}