Files
fcs/lib/pages/widgets/delivery_address_selection.dart

108 lines
3.5 KiB
Dart
Raw Normal View History

2021-01-10 15:56:27 +06:30
import 'package:fcs/domain/entities/user.dart';
2020-10-13 07:50:25 +06:30
import 'package:fcs/domain/vo/delivery_address.dart';
import 'package:fcs/helpers/theme.dart';
import 'package:fcs/pages/delivery_address/delivery_address_editor.dart';
import 'package:fcs/pages/delivery_address/delivery_address_row.dart';
2021-01-10 23:05:36 +06:30
import 'package:fcs/pages/delivery_address/model/delivery_address_model.dart';
2020-10-13 07:50:25 +06:30
import 'package:fcs/pages/widgets/local_text.dart';
2020-10-14 13:54:42 +06:30
import 'package:flutter/cupertino.dart';
2020-10-13 07:50:25 +06:30
import 'package:flutter/material.dart';
2021-01-10 23:05:36 +06:30
import 'package:provider/provider.dart';
typedef OnAdded();
2020-10-13 07:50:25 +06:30
class DeliveryAddressSelection extends StatelessWidget {
final DeliveryAddress deliveryAddress;
2021-01-07 18:15:39 +06:30
final List<DeliveryAddress> deliveryAddresses;
2021-01-10 15:56:27 +06:30
final User user;
2021-01-10 23:05:36 +06:30
final OnAdded onAdded;
2020-10-13 07:50:25 +06:30
2021-01-07 18:15:39 +06:30
const DeliveryAddressSelection(
2021-01-10 23:05:36 +06:30
{Key key,
this.deliveryAddress,
this.deliveryAddresses,
this.user,
this.onAdded})
2020-10-13 07:50:25 +06:30
: super(key: key);
2021-01-10 23:05:36 +06:30
Future<List<DeliveryAddress>> _getDeliverAddresses(
BuildContext context) async {
var addressModel =
Provider.of<DeliveryAddressModel>(context, listen: false);
var _deliveryAddresses = await addressModel.getDeliveryAddresses(user.id);
return _deliveryAddresses;
}
2020-10-13 07:50:25 +06:30
@override
Widget build(BuildContext context) {
2021-01-10 23:05:36 +06:30
if (user != null) {}
2020-10-13 07:50:25 +06:30
return Scaffold(
appBar: AppBar(
centerTitle: true,
leading: new IconButton(
2020-10-15 03:06:13 +06:30
icon: new Icon(CupertinoIcons.back, color: primaryColor),
onPressed: () => Navigator.of(context).pop(),
2020-10-13 07:50:25 +06:30
),
2020-10-15 03:06:13 +06:30
backgroundColor: Colors.white,
shadowColor: Colors.transparent,
title: LocalText(context, 'delivery_addresses',
color: primaryColor, fontSize: 20),
2020-10-13 07:50:25 +06:30
),
floatingActionButton: FloatingActionButton.extended(
2021-01-10 15:56:27 +06:30
onPressed: () async {
2021-01-10 23:05:36 +06:30
bool updated = await Navigator.of(context).push(CupertinoPageRoute(
2021-01-10 15:56:27 +06:30
builder: (context) => DeliveryAddressEditor(
user: user,
)));
2021-01-10 23:05:36 +06:30
if (updated && onAdded != null) {
onAdded();
Navigator.pop(context);
}
2020-10-13 07:50:25 +06:30
},
icon: Icon(Icons.add),
label: LocalText(context, "delivery_address.new_address",
color: Colors.white),
backgroundColor: primaryColor,
),
body: Padding(
padding: const EdgeInsets.all(8.0),
child: ListView.separated(
separatorBuilder: (c, i) => Divider(
color: primaryColor,
),
2021-01-07 18:15:39 +06:30
itemCount: deliveryAddresses.length,
2020-10-13 07:50:25 +06:30
itemBuilder: (context, index) {
2021-01-07 18:15:39 +06:30
return _row(context, deliveryAddresses[index]);
2020-10-13 07:50:25 +06:30
}),
));
}
_row(BuildContext context, DeliveryAddress _deliveryAddress) {
return InkWell(
onTap: () => _select(context, _deliveryAddress),
child: Row(
children: [
Padding(
padding: const EdgeInsets.all(10.0),
child: Icon(Icons.check,
color: deliveryAddress != null &&
_deliveryAddress.id == deliveryAddress.id
? primaryColor
: Colors.black26),
),
Expanded(
child: DeliveryAddressRow(
key: ValueKey(_deliveryAddress.id),
deliveryAddress: _deliveryAddress,
)),
],
),
);
}
_select(BuildContext context, DeliveryAddress _deliveryAddress) {
Navigator.pop(context, _deliveryAddress);
}
}