Files
fcs/lib/pages/discount/discount_list.dart

139 lines
4.5 KiB
Dart
Raw Normal View History

2020-10-07 02:33:06 +06:30
import 'package:fcs/helpers/theme.dart';
import 'package:fcs/localization/app_translations.dart';
2020-10-19 05:13:49 +06:30
import 'package:fcs/pages/discount/discount_list_row.dart';
2020-10-07 02:33:06 +06:30
import 'package:fcs/pages/discount/model/discount_model.dart';
import 'package:fcs/pages/main/util.dart';
2020-10-22 04:14:53 +06:30
import 'package:fcs/pages/widgets/local_popup_menu_button.dart';
import 'package:fcs/pages/widgets/local_popupmenu.dart';
2020-10-15 18:48:32 +06:30
import 'package:fcs/pages/widgets/local_text.dart';
2020-10-07 02:33:06 +06:30
import 'package:fcs/pages/widgets/progress.dart';
2020-10-12 03:34:05 +06:30
import 'package:flutter/cupertino.dart';
2020-06-26 16:04:40 +06:30
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
2020-10-07 02:33:06 +06:30
import 'discount_editor.dart';
2020-06-26 16:04:40 +06:30
class DiscountList extends StatefulWidget {
2020-10-22 04:14:53 +06:30
final bool selectionMode;
2020-10-14 20:56:46 +06:30
2021-09-10 12:02:08 +06:30
const DiscountList({Key? key, this.selectionMode = false}) : super(key: key);
2020-06-26 16:04:40 +06:30
@override
_DiscountListState createState() => _DiscountListState();
}
class _DiscountListState extends State<DiscountList> {
bool _isLoading = false;
2020-10-22 04:14:53 +06:30
var _controller = ScrollController();
2020-10-15 15:49:02 +06:30
@override
void initState() {
super.initState();
2020-10-22 04:14:53 +06:30
_controller.addListener(() async {
if (_controller.position.pixels == _controller.position.maxScrollExtent) {
Provider.of<DiscountModel>(context, listen: false).loadMore();
}
});
Provider.of<DiscountModel>(context, listen: false).initData();
2020-10-15 15:49:02 +06:30
}
2020-06-26 16:04:40 +06:30
@override
Widget build(BuildContext context) {
var discountModel = Provider.of<DiscountModel>(context);
2020-10-22 04:14:53 +06:30
final popupMenu = LocalPopupMenuButton(
popmenus: [
LocalPopupMenu(
id: 1,
textKey: "discount.popupmenu.available",
selected: discountModel.selectedIndex == 1),
LocalPopupMenu(
id: 2,
textKey: "discount.popupmenu.used",
selected: discountModel.selectedIndex == 2)
],
popupMenuCallback: (p) => this.setState(() {
discountModel.selectedIndex = p.id;
}),
);
2020-06-26 16:04:40 +06:30
return LocalProgress(
inAsyncCall: _isLoading,
child: Scaffold(
appBar: AppBar(
2020-06-30 16:11:58 +06:30
centerTitle: true,
2020-06-26 16:04:40 +06:30
title: Text(
2021-09-10 12:02:08 +06:30
AppTranslations.of(context)!.text("discount.title"),
2020-06-26 16:04:40 +06:30
),
2020-06-30 16:11:58 +06:30
leading: new IconButton(
2020-10-12 03:34:05 +06:30
icon: new Icon(CupertinoIcons.back),
2020-06-30 16:11:58 +06:30
onPressed: () => Navigator.of(context).pop(),
),
2020-06-26 16:04:40 +06:30
backgroundColor: primaryColor,
2020-10-22 04:14:53 +06:30
actions: <Widget>[popupMenu],
2020-06-26 16:04:40 +06:30
),
2020-10-22 04:14:53 +06:30
body: Column(
children: [
Expanded(
child: ListView.separated(
separatorBuilder: (context, index) => Divider(
color: Colors.black,
height: 1,
),
controller: _controller,
itemCount: discountModel.discounts.length,
itemBuilder: (BuildContext context, int index) {
var discount = discountModel.discounts[index];
return DiscountListRow(
key: ValueKey(discount.id),
discount: discount,
onSelect: (d) {
if (widget.selectionMode) {
Navigator.pop(context, discount);
return;
}
Navigator.push(
context,
CupertinoPageRoute(
builder: (context) =>
DiscountEditor(discount: discount)),
);
},
);
},
),
),
discountModel.isLoading
? Container(
padding: EdgeInsets.all(8),
color: primaryColor,
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text("Loading...",
style: TextStyle(color: Colors.white)),
],
),
)
: Container(),
],
2020-06-26 16:04:40 +06:30
),
floatingActionButton: FloatingActionButton.extended(
onPressed: () {
Navigator.push(
context,
2020-10-14 13:54:42 +06:30
CupertinoPageRoute(builder: (context) => DiscountEditor()),
2020-06-26 16:04:40 +06:30
);
},
icon: Icon(Icons.add),
2020-10-15 18:48:32 +06:30
label: LocalText(
context,
'discount.new',
color: Colors.white,
),
2020-06-26 16:04:40 +06:30
backgroundColor: primaryColor,
),
),
);
}
}