import 'package:fcs/helpers/theme.dart'; import 'package:fcs/localization/app_translations.dart'; import 'package:fcs/pages/box/model/box_model.dart'; import 'package:fcs/pages/widgets/bottom_up_page_route.dart'; import 'package:fcs/pages/widgets/local_text.dart'; import 'package:fcs/pages/widgets/progress.dart'; import 'package:flutter/material.dart'; import 'package:provider/provider.dart'; import 'box_editor.dart'; import 'box_list_row.dart'; class BoxList extends StatefulWidget { @override _BoxListState createState() => _BoxListState(); } class _BoxListState extends State { 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: 2, child: Scaffold( appBar: AppBar( centerTitle: true, leading: new IconButton( icon: new Icon(Icons.close), onPressed: () => Navigator.of(context).pop(), ), backgroundColor: primaryColor, title: LocalText(context, "boxes.name", color: Colors.white, fontSize: 20), 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: "Delivered"), ], ), ), floatingActionButton: FloatingActionButton.extended( onPressed: () { _newPickup(); }, icon: Icon(Icons.add), label: Text(AppTranslations.of(context).text("boxes.new")), backgroundColor: primaryColor, ), body: TabBarView( children: [ _upComing(), _completed(), ], )), ), ); } _newPickup() { Navigator.push( context, BottomUpPageRoute(BoxEditor()), ); } Widget _upComing() { var boxModel = 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: boxModel.upcoming.length, itemBuilder: (BuildContext context, int index) { return BoxListRow( box: boxModel.upcoming[index], isReadOnly: false, ); }), ), ], ); } Widget _completed() { var boxModel = 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: boxModel.completed.length, itemBuilder: (BuildContext context, int index) { return BoxListRow( box: boxModel.completed[index], isReadOnly: false, ); }), ), ], ); } }