import 'package:fcs/model/pickup_model.dart'; import 'package:fcs/pages/pickup_list_row.dart'; import 'package:provider/provider.dart'; import 'package:fcs/model/buyer_model.dart'; import 'package:fcs/pages/search_page.dart'; import 'package:fcs/vo/buyer.dart'; import 'package:fcs/vo/popup_menu.dart'; import 'package:fcs/widget/localization/app_translations.dart'; import 'package:fcs/widget/popupmenu.dart'; import 'package:flutter/material.dart'; import 'package:fcs/widget/progress.dart'; import '../theme/theme.dart'; import '../theme/theme.dart'; import '../theme/theme.dart'; import 'buyer_list_row.dart'; import 'pickup_editor.dart'; class PickUpList extends StatefulWidget { @override _PickUpListState createState() => _PickUpListState(); } class _PickUpListState extends State { Buyer buyer; bool _isLoading = false; @override void initState() { super.initState(); } @override void dispose() { super.dispose(); } @override Widget build(BuildContext context) { return LocalProgress( inAsyncCall: _isLoading, child: DefaultTabController( length: 3, child: Scaffold( appBar: AppBar( centerTitle: true, leading: new IconButton( icon: new Icon(Icons.close), onPressed: () => Navigator.of(context).pop(), ), backgroundColor: primaryColor, title: Text(AppTranslations.of(context).text("pickup.title")), actions: [ IconButton( icon: Icon( Icons.search, color: Colors.white, ), iconSize: 30, onPressed: () => showPlacesSearch(context), ), ], bottom: TabBar( unselectedLabelColor: Colors.grey, tabs: [ Tab( text: "Upcoming", ), Tab(text: "Completed"), Tab(text: "Canceled"), ], ), ), floatingActionButton: FloatingActionButton.extended( onPressed: () { _newPickup(); }, icon: Icon(Icons.add), label: Text(AppTranslations.of(context).text("pickup.new")), backgroundColor: primaryColor, ), body: TabBarView( children: [ //Icon(Icons.directions_car), _upComing(), _completed(), _canceled() ], )), ), ); } _newPickup() { Navigator.push( context, MaterialPageRoute(builder: (context) => new PickUpEditor()), ); } Widget _upComing() { var pickupModel = Provider.of(context); return Column( children: [ Expanded( child: new ListView.separated( separatorBuilder: (context, index) => Divider( color: Colors.black, ), scrollDirection: Axis.vertical, padding: EdgeInsets.only(top: 15), shrinkWrap: true, itemCount: pickupModel.upcoming.length, itemBuilder: (BuildContext context, int index) { return PickupListRow(pickUp: pickupModel.upcoming[index]); }), ), ], ); } Widget _completed() { var pickupModel = Provider.of(context); return Column( children: [ Expanded( child: new ListView.separated( separatorBuilder: (context, index) => Divider( color: Colors.black, ), scrollDirection: Axis.vertical, padding: EdgeInsets.only(top: 15), shrinkWrap: true, itemCount: pickupModel.completed.length, itemBuilder: (BuildContext context, int index) { return PickupListRow(pickUp: pickupModel.completed[index]); }), ), ], ); } Widget _canceled() { var pickupModel = Provider.of(context); return Column( children: [ Expanded( child: new ListView.separated( separatorBuilder: (context, index) => Divider( color: Colors.black, ), scrollDirection: Axis.vertical, padding: EdgeInsets.only(top: 15), shrinkWrap: true, itemCount: pickupModel.canceled.length, itemBuilder: (BuildContext context, int index) { return PickupListRow(pickUp: pickupModel.canceled[index]); }), ), ], ); } }