import 'package:fcs/helpers/theme.dart'; import 'package:fcs/pages/invoice/invoice_shipment_list.dart'; import 'package:fcs/pages/invoice/model/invoice_model.dart'; import 'package:fcs/pages/widgets/local_popup_menu_button.dart'; import 'package:fcs/pages/widgets/local_popupmenu.dart'; import 'package:fcs/pages/widgets/local_text.dart'; import 'package:fcs/pages/widgets/progress.dart'; import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; import 'package:provider/provider.dart'; import 'invoice_list_row.dart'; class InvoiceList extends StatefulWidget { final bool forCustomer; const InvoiceList({Key key, this.forCustomer}) : super(key: key); @override _InvoiceListState createState() => _InvoiceListState(); } class _InvoiceListState extends State { bool _isLoading = false; bool _showPaid = false; var _controller = ScrollController(); @override void initState() { super.initState(); _controller.addListener(() async { if (_controller.position.pixels == _controller.position.maxScrollExtent) { Provider.of(context, listen: false) .loadMore(isCustomer: widget.forCustomer); } }); Provider.of(context, listen: false).initData(false); } @override void dispose() { super.dispose(); } @override Widget build(BuildContext context) { var owner = true; var invoiceModel = Provider.of(context); final popupMenu = LocalPopupMenuButton( popmenus: [ LocalPopupMenu( id: 1, textKey: "invoice.popupmenu.pending", selected: invoiceModel.selectedIndex == 1), LocalPopupMenu( id: 2, textKey: "invoice.popupmenu.paid", selected: invoiceModel.selectedIndex == 2) ], popupMenuCallback: (p) => this.setState(() { _showPaid = p.id == 2; }), ); return LocalProgress( inAsyncCall: _isLoading, child: DefaultTabController( length: 2, child: Scaffold( appBar: AppBar( centerTitle: true, leading: new IconButton( icon: new Icon(CupertinoIcons.back), onPressed: () => Navigator.of(context).pop(), ), backgroundColor: primaryColor, title: LocalText(context, 'invoices.title', color: Colors.white, fontSize: 20), actions: [popupMenu], ), floatingActionButton: owner ? FloatingActionButton.extended( onPressed: () { _newInvoice(); }, icon: Icon(Icons.add), label: LocalText(context, 'invoices.add', color: Colors.white), backgroundColor: primaryColor, ) : null, body: Column( children: [ Expanded( child: RefreshIndicator( child: ListView.separated( physics: AlwaysScrollableScrollPhysics(), controller: _controller, separatorBuilder: (context, index) => Divider( color: Colors.black, ), scrollDirection: Axis.vertical, padding: EdgeInsets.only(top: 15), shrinkWrap: true, itemCount: invoiceModel.invoices.length, itemBuilder: (BuildContext context, int index) { return InvoiceListRow( key: ValueKey(invoiceModel.invoices[index].id), invoice: invoiceModel.invoices[index]); }), onRefresh: () => invoiceModel.refresh(), ), ), invoiceModel.isLoading ? Container( padding: EdgeInsets.all(8), color: primaryColor, child: Row( mainAxisAlignment: MainAxisAlignment.center, children: [ Text("Loading...", style: TextStyle(color: Colors.white)), ], ), ) : Container(), ], )), ), ); } _newInvoice() { Navigator.of(context) .push(CupertinoPageRoute(builder: (context) => InvoiceShipmentList())); } }