-
Notifications
You must be signed in to change notification settings - Fork 25
/
list_paged_filter_app.dart
50 lines (46 loc) · 1.72 KB
/
list_paged_filter_app.dart
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
import 'package:example/src/album/model/album.dart';
import 'package:example/src/album/model/photo.dart';
import 'package:example/src/album/model/photo_repository.dart';
import 'package:example/src/album/ui/photos_list_empty.dart';
import 'package:example/src/album/ui/photos_list_paged.dart';
import 'package:example/src/common/error_message.dart';
import 'package:example/src/common/loading_indicator.dart';
import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import 'package:flutter_bloc_patterns/paged_filter_list.dart';
import 'package:flutter_bloc_patterns/view.dart';
void main() => runApp(PagedFilterListSampleApp());
typedef PhotosBloc = PagedListFilterBloc<Photo, Album>;
class PagedFilterListSampleApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Paged Filter List Sample App',
theme: ThemeData(primarySwatch: Colors.green),
home: BlocProvider(
create: (_) {
return PhotosBloc(PagedFilterPhotoRepository())
..loadFirstPage(pageSize: 12, filter: const Album(id: 1));
},
child: _PhotosPage(),
),
);
}
}
class _PhotosPage extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text('Photos')),
body: ViewStateBuilder<PagedList<Photo>, PhotosBloc>(
loading: (context) => const LoadingIndicator(),
data: (context, page) => PhotosListPaged(
page,
onLoadNextPage: context.read<PhotosBloc>().loadNextPage,
),
empty: (context) => const PhotosListEmpty(),
error: (context, error) => ErrorMessage(error: error),
),
);
}
}