2021-10-09 17:08:28 +06:30
|
|
|
import 'package:fcs/domain/entities/pickup.dart';
|
2021-09-13 17:36:52 +06:30
|
|
|
import 'package:fcs/helpers/theme.dart';
|
|
|
|
|
import 'package:fcs/pages/pickup/pickup_info.dart';
|
|
|
|
|
import 'package:fcs/pages/pickup/pickup_list_row.dart';
|
2021-10-09 17:08:28 +06:30
|
|
|
import 'package:fcs/pages/pickup_search/pickup_serach.dart';
|
2021-09-13 17:36:52 +06:30
|
|
|
import 'package:fcs/pages/widgets/local_text.dart';
|
|
|
|
|
import 'package:fcs/pages/widgets/progress.dart';
|
|
|
|
|
import 'package:fcs/pagination/paginator_listview.dart';
|
|
|
|
|
import 'package:flutter/cupertino.dart';
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
import 'package:provider/provider.dart';
|
|
|
|
|
|
2021-10-09 17:08:28 +06:30
|
|
|
import 'model/pickup_model.dart';
|
|
|
|
|
|
2021-09-13 17:36:52 +06:30
|
|
|
class PickupList extends StatefulWidget {
|
|
|
|
|
@override
|
|
|
|
|
_PickupListState createState() => _PickupListState();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class _PickupListState extends State<PickupList> {
|
|
|
|
|
bool _isLoading = false;
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
void initState() {
|
|
|
|
|
super.initState();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
void dispose() {
|
|
|
|
|
super.dispose();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
2021-10-09 17:08:28 +06:30
|
|
|
var pickupModel = Provider.of<PickupModel>(context);
|
|
|
|
|
var pickups = pickupModel.pickups;
|
2021-09-13 17:36:52 +06:30
|
|
|
|
|
|
|
|
return LocalProgress(
|
|
|
|
|
inAsyncCall: _isLoading,
|
|
|
|
|
child: Scaffold(
|
|
|
|
|
appBar: AppBar(
|
|
|
|
|
centerTitle: true,
|
|
|
|
|
leading: new IconButton(
|
|
|
|
|
icon: new Icon(CupertinoIcons.back),
|
|
|
|
|
onPressed: () => Navigator.of(context).pop(),
|
|
|
|
|
),
|
|
|
|
|
backgroundColor: primaryColor,
|
|
|
|
|
title: LocalText(
|
|
|
|
|
context,
|
|
|
|
|
"pickup.title",
|
|
|
|
|
fontSize: 20,
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
),
|
|
|
|
|
actions: <Widget>[
|
|
|
|
|
IconButton(
|
|
|
|
|
icon: Icon(
|
|
|
|
|
Icons.search,
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
),
|
|
|
|
|
iconSize: 30,
|
2021-10-09 17:08:28 +06:30
|
|
|
onPressed: () => searchPickup(context,
|
|
|
|
|
callbackPickupSelect: _searchCallback),
|
2021-09-13 17:36:52 +06:30
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
2021-10-09 17:08:28 +06:30
|
|
|
body: PaginatorListView<Pickup>(
|
|
|
|
|
paginatorListener: pickups!,
|
|
|
|
|
rowBuilder: (p) => PickupListRow(key: ValueKey(p.id), pickup: p),
|
2021-09-13 17:36:52 +06:30
|
|
|
color: primaryColor,
|
|
|
|
|
)),
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
2021-10-09 17:08:28 +06:30
|
|
|
_searchCallback(Pickup pickup) async {
|
|
|
|
|
Pickup? _pickup = await context.read<PickupModel>().getPickup(pickup.id!);
|
|
|
|
|
if (_pickup == null) return;
|
2021-09-13 17:36:52 +06:30
|
|
|
Navigator.push(
|
|
|
|
|
context,
|
2021-10-09 17:08:28 +06:30
|
|
|
CupertinoPageRoute(builder: (context) => PickupInfo(pickup: _pickup)),
|
2021-09-13 17:36:52 +06:30
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|