2020-06-29 16:03:41 +06:30
|
|
|
import 'package:fcs/model/shipment_model.dart';
|
|
|
|
|
|
|
|
|
|
import 'package:fcs/pages/search_page.dart';
|
|
|
|
|
import 'package:fcs/pages_fcs/shipping_address_row.dart';
|
|
|
|
|
import 'package:fcs/vo/shipping_address.dart';
|
|
|
|
|
import 'package:fcs/widget/bottom_up_page_route.dart';
|
|
|
|
|
import 'package:fcs/widget/localization/app_translations.dart';
|
|
|
|
|
import 'package:fcs/widget/progress.dart';
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
import 'package:provider/provider.dart';
|
|
|
|
|
|
|
|
|
|
import '../theme/theme.dart';
|
|
|
|
|
|
|
|
|
|
class ShippingAddressList extends StatefulWidget {
|
|
|
|
|
@override
|
|
|
|
|
_ShippingAddressListState createState() => _ShippingAddressListState();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class _ShippingAddressListState extends State<ShippingAddressList> {
|
|
|
|
|
bool _isLoading = false;
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
void initState() {
|
|
|
|
|
super.initState();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
void dispose() {
|
|
|
|
|
super.dispose();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
|
var shipmentModel = Provider.of<ShipmentModel>(context);
|
|
|
|
|
return LocalProgress(
|
|
|
|
|
inAsyncCall: _isLoading,
|
|
|
|
|
child: Scaffold(
|
|
|
|
|
appBar: AppBar(
|
|
|
|
|
centerTitle: true,
|
|
|
|
|
leading: new IconButton(
|
|
|
|
|
icon: new Icon(Icons.close),
|
|
|
|
|
onPressed: () => Navigator.of(context).pop(),
|
|
|
|
|
),
|
|
|
|
|
backgroundColor: primaryColor,
|
2020-06-30 16:11:58 +06:30
|
|
|
title: Text(AppTranslations.of(context).text("shipping_addresses")),
|
2020-06-29 16:03:41 +06:30
|
|
|
actions: <Widget>[
|
|
|
|
|
IconButton(
|
|
|
|
|
icon: Icon(
|
|
|
|
|
Icons.search,
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
),
|
|
|
|
|
iconSize: 30,
|
|
|
|
|
onPressed: () => showPlacesSearch(context),
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
body: Column(
|
|
|
|
|
children: <Widget>[
|
|
|
|
|
Expanded(
|
|
|
|
|
child: Column(
|
|
|
|
|
children:
|
|
|
|
|
getAddressList(context, shipmentModel.shippingAddresses),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
Container(
|
|
|
|
|
padding: EdgeInsets.only(top: 20, bottom: 15, right: 15),
|
|
|
|
|
child: Align(
|
|
|
|
|
alignment: Alignment.bottomRight,
|
|
|
|
|
child: Container(
|
|
|
|
|
width: 130,
|
|
|
|
|
height: 40,
|
|
|
|
|
child: FloatingActionButton.extended(
|
|
|
|
|
materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
|
|
|
|
|
onPressed: () {
|
|
|
|
|
Navigator.push(
|
|
|
|
|
context,
|
|
|
|
|
BottomUpPageRoute(ShippingAddressList()),
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
icon: Icon(Icons.add),
|
|
|
|
|
label: Text(
|
2020-06-30 16:11:58 +06:30
|
|
|
'Add New\nAddress',
|
2020-06-29 16:03:41 +06:30
|
|
|
style: TextStyle(fontSize: 12),
|
|
|
|
|
),
|
|
|
|
|
backgroundColor: primaryColor,
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
)),
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
List<Widget> getAddressList(
|
|
|
|
|
BuildContext context, List<ShippingAddress> addresses) {
|
|
|
|
|
return addresses.asMap().entries.map((s) {
|
|
|
|
|
return InkWell(
|
|
|
|
|
onTap: () {
|
|
|
|
|
Navigator.pop(context, s.value);
|
|
|
|
|
},
|
|
|
|
|
child: ShippingAddressRow(shippingAddress: s.value, index: s.key),
|
|
|
|
|
);
|
|
|
|
|
}).toList();
|
|
|
|
|
}
|
|
|
|
|
}
|