Files
fcs/lib/pages/package/package_list.dart

183 lines
5.8 KiB
Dart
Raw Normal View History

2025-03-12 17:49:27 +06:30
// ignore_for_file: use_build_context_synchronously
2020-10-07 02:33:06 +06:30
import 'package:fcs/domain/entities/package.dart';
import 'package:fcs/helpers/theme.dart';
import 'package:fcs/pages/package/model/package_model.dart';
import 'package:fcs/pages/package/package_info.dart';
import 'package:fcs/pages/package/package_list_row.dart';
2024-02-07 17:26:29 +06:30
import 'package:fcs/pages/package_search/package_search.dart';
2024-01-25 17:40:35 +06:30
import 'package:fcs/pages/widgets/local_app_bar.dart';
2020-10-12 03:34:05 +06:30
import 'package:fcs/pages/widgets/local_popup_menu_button.dart';
2024-02-07 17:26:29 +06:30
import 'package:fcs/domain/vo/local_popupmenu.dart';
2020-10-07 02:33:06 +06:30
import 'package:fcs/pages/widgets/progress.dart';
2020-11-13 02:38:16 +06:30
import 'package:fcs/pagination/paginator_listview.dart';
2020-09-18 04:04:21 +06:30
import 'package:flutter/cupertino.dart';
2020-09-15 07:13:41 +06:30
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
class PackageList extends StatefulWidget {
2020-10-16 10:58:31 +06:30
final bool forCustomer;
2020-10-12 03:34:05 +06:30
2025-03-12 17:49:27 +06:30
const PackageList({super.key, this.forCustomer = true});
2020-09-15 07:13:41 +06:30
@override
_PackageListState createState() => _PackageListState();
}
class _PackageListState extends State<PackageList> {
2025-03-12 17:49:27 +06:30
bool isLoading = false;
int _selectedIndexForCustomer = 1;
int _selectedIndex = 0;
2020-09-15 07:13:41 +06:30
@override
void initState() {
_init();
2020-09-15 07:13:41 +06:30
super.initState();
}
_init() {
var model = context.read<PackageModel>();
2025-03-12 17:49:27 +06:30
if (widget.forCustomer) {
_selectedIndexForCustomer = model.selectedIndexForCustomer;
model.initDataForCustomer(_selectedIndexForCustomer);
} else {
_selectedIndex = model.selectedIndex;
model.initData(_selectedIndex);
}
if (mounted) {
setState(() {});
}
}
2020-09-15 07:13:41 +06:30
@override
Widget build(BuildContext context) {
var packageModel = Provider.of<PackageModel>(context);
2020-11-13 02:38:16 +06:30
var packages = widget.forCustomer
? packageModel.customerPackages
: packageModel.packages;
2020-10-15 19:40:03 +06:30
2020-10-12 03:34:05 +06:30
final popupMenu = LocalPopupMenuButton(
popmenus: [
LocalPopupMenu(
id: 1,
textKey: "package.popupmenu.active",
2025-03-12 17:49:27 +06:30
selected: packageModel.selectedIndexForCustomer == 1),
LocalPopupMenu(
id: 2,
textKey: "package.popupmenu.delivered",
2025-03-12 17:49:27 +06:30
selected: packageModel.selectedIndexForCustomer == 2)
],
popupMenuCallback: (p) {
2025-03-12 17:49:27 +06:30
setState(() {
_selectedIndexForCustomer = p.id;
});
context
.read<PackageModel>()
2025-03-12 17:49:27 +06:30
.onChangedForCustomer(_selectedIndexForCustomer);
});
2020-09-15 07:13:41 +06:30
return LocalProgress(
2025-03-12 17:49:27 +06:30
inAsyncCall: isLoading,
2020-09-15 07:13:41 +06:30
child: Scaffold(
2024-01-25 17:40:35 +06:30
appBar: LocalAppBar(
labelKey: 'package.title',
actions: [
2020-10-16 10:58:31 +06:30
widget.forCustomer
? Container()
: IconButton(
2020-09-18 21:33:41 +06:30
icon: Icon(
Icons.search,
color: Colors.white,
),
iconSize: 30,
onPressed: () => searchPackage(context,
2024-01-25 17:40:35 +06:30
callbackPackageSelect: _searchCallback)),
2025-03-12 17:49:27 +06:30
widget.forCustomer ? popupMenu : _menuFilteringWidget(context)
2020-09-15 07:13:41 +06:30
],
),
2020-11-13 02:38:16 +06:30
body: PaginatorListView<Package>(
2021-09-11 16:56:20 +06:30
paginatorListener: packages!,
2024-01-23 17:48:34 +06:30
rowBuilder: (p) =>
PackageListRow(package: p, isCustomer: widget.forCustomer),
2020-11-13 02:38:16 +06:30
color: primaryColor,
2020-10-12 03:34:05 +06:30
)),
2020-09-15 07:13:41 +06:30
);
}
2020-09-18 21:33:41 +06:30
_searchCallback(Package package) async {
var packageModel = Provider.of<PackageModel>(context, listen: false);
2025-03-12 17:49:27 +06:30
Package? package0 = await packageModel.getPackage(package.id!);
if (package0 == null) return;
2020-09-18 21:33:41 +06:30
Navigator.push(
context,
2025-03-12 17:49:27 +06:30
CupertinoPageRoute(builder: (context) => PackageInfo(package: package0)),
);
}
Widget _menuFilteringWidget(BuildContext context) {
return Padding(
padding: const EdgeInsets.only(right: 5),
child: PopupMenuButton<LocalPopupMenu>(
elevation: 3.2,
tooltip: '',
onSelected: (choice) async {
setState(() {
_selectedIndex = choice.id;
});
await context.read<PackageModel>().onChanged(choice.id);
},
icon: SizedBox(
width: 30,
height: 30,
child: Stack(
alignment: Alignment.center,
children: <Widget>[
const Icon(
Icons.filter_list,
color: Colors.white,
),
_selectedIndex != 0
? Positioned(
bottom: 15,
right: 0,
child: Container(
width: 10,
height: 10,
decoration: const BoxDecoration(
shape: BoxShape.circle,
color: Colors.red,
),
),
)
: Container()
],
),
),
itemBuilder: (BuildContext context) {
return packageFiteringMenu.map((LocalPopupMenu choice) {
return PopupMenuItem<LocalPopupMenu>(
value: choice,
child: Row(
children: <Widget>[
Flexible(
child: Text("${choice.text}",
style: TextStyle(color: Colors.black))),
const SizedBox(
width: 10,
),
_selectedIndex == choice.id
? const Icon(
Icons.check,
color: Colors.grey,
)
: const SizedBox(),
],
),
);
}).toList();
}),
2020-09-18 21:33:41 +06:30
);
}
2020-09-15 07:13:41 +06:30
}