add package return

This commit is contained in:
Sai Naw Wun
2020-10-20 08:02:29 +06:30
parent 4d0e5b6833
commit 4884311d47
14 changed files with 66 additions and 18 deletions

View File

@@ -104,8 +104,6 @@ class PackageModel extends BaseModel {
return Package(
id: m.id,
status: package_delivered_status,
currentStatus: package_delivered_status,
currentStatusDate: m.date,
trackingID: (count++).toString(),
market: m.message);
});
@@ -310,4 +308,8 @@ class PackageModel extends BaseModel {
return Services.instance.packageService
.changeDeliveryAddress(package.id, deliveryAddress.id);
}
Future<void> packageReturn(Package package) {
return Services.instance.packageService.packageReturn(package.id);
}
}

View File

@@ -56,7 +56,7 @@ class _PackageEditorPageState extends State<PackageEditorPage> {
iconData: MaterialCommunityIcons.barcode_scan,
);
final statusBox = DisplayText(
text: _package.currentStatus,
text: _package.status,
labelTextKey: "package.edit.status",
iconData: AntDesign.exclamationcircleo,
);

View File

@@ -1,3 +1,4 @@
import 'package:fcs/domain/constants.dart';
import 'package:fcs/domain/entities/package.dart';
import 'package:fcs/domain/vo/delivery_address.dart';
import 'package:fcs/helpers/theme.dart';
@@ -9,6 +10,7 @@ import 'package:fcs/pages/widgets/defalut_delivery_address.dart';
import 'package:fcs/pages/widgets/delivery_address_selection.dart';
import 'package:fcs/pages/widgets/display_text.dart';
import 'package:fcs/pages/widgets/fcs_id_icon.dart';
import 'package:fcs/pages/widgets/local_button.dart';
import 'package:fcs/pages/widgets/local_text.dart';
import 'package:fcs/pages/widgets/multi_img_controller.dart';
import 'package:fcs/pages/widgets/multi_img_file.dart';
@@ -25,6 +27,7 @@ final DateFormat dateFormat = DateFormat("d MMM yyyy");
class PackageInfo extends StatefulWidget {
final isSearchResult;
final Package package;
PackageInfo({this.package, this.isSearchResult = false});
@override
@@ -95,6 +98,11 @@ class _PackageInfoState extends State<PackageInfo> {
controller: multiImgController,
title: "Receipt File",
);
final returnButton = LocalButton(
textKey: "receiving.return.btn",
callBack: _return,
);
final deliveryAddressBox = DefaultDeliveryAddress(
deliveryAddress: _package.deliveryAddress,
labelKey: "package.delivery.address",
@@ -145,12 +153,15 @@ class _PackageInfoState extends State<PackageInfo> {
_package.photoUrls.length == 0 ? Container() : img,
widget.isSearchResult ? Container() : descBox,
remarkBox,
_package.status == package_processed_status
? returnButton
: Container(),
widget.isSearchResult ? Container() : deliveryAddressBox,
widget.isSearchResult
? Container()
: StatusTree(
shipmentHistory: _package.shipmentHistory,
currentStatus: _package.currentStatus),
currentStatus: _package.status),
SizedBox(
height: 20,
)
@@ -188,4 +199,26 @@ class _PackageInfoState extends State<PackageInfo> {
});
}
}
_return() {
showConfirmDialog(context, "receiving.return.confirm", _returnReceiving);
}
_returnReceiving() async {
setState(() {
_isLoading = true;
});
try {
PackageModel packageModel =
Provider.of<PackageModel>(context, listen: false);
await packageModel.packageReturn(_package);
Navigator.pop(context);
} catch (e) {
showMsgDialog(context, "Error", e.toString());
} finally {
setState(() {
_isLoading = false;
});
}
}
}

View File

@@ -76,7 +76,7 @@ class PackageListRow extends StatelessWidget {
children: <Widget>[
Padding(
padding: const EdgeInsets.all(3.0),
child: getStatus(package.currentStatus),
child: getStatus(package.status),
),
Padding(
padding: const EdgeInsets.all(0),

View File

@@ -140,7 +140,7 @@ class _ProcessingInfoState extends State<ProcessingInfo> {
_package.photoUrls.length == 0 ? Container() : img,
StatusTree(
shipmentHistory: _package.shipmentHistory,
currentStatus: _package.currentStatus),
currentStatus: _package.status),
SizedBox(
height: 20,
)

View File

@@ -81,7 +81,7 @@ class ProcessingListRow extends StatelessWidget {
children: <Widget>[
Padding(
padding: const EdgeInsets.all(3.0),
child: getStatus(package.currentStatus),
child: getStatus(package.status),
),
Padding(
padding: const EdgeInsets.all(0),

View File

@@ -3,10 +3,9 @@ import 'package:fcs/helpers/theme.dart';
import 'package:fcs/pages/main/model/main_model.dart';
import 'package:fcs/pages/main/util.dart';
import 'package:fcs/pages/package/model/package_model.dart';
import 'package:fcs/pages/package/package_editor.dart';
import 'package:fcs/pages/widgets/bottom_up_page_route.dart';
import 'package:fcs/pages/widgets/display_text.dart';
import 'package:fcs/pages/widgets/fcs_id_icon.dart';
import 'package:fcs/pages/widgets/local_button.dart';
import 'package:fcs/pages/widgets/local_text.dart';
import 'package:fcs/pages/widgets/multi_img_controller.dart';
import 'package:fcs/pages/widgets/multi_img_file.dart';
@@ -17,8 +16,6 @@ import 'package:flutter/material.dart';
import 'package:flutter_icons/flutter_icons.dart';
import 'package:intl/intl.dart';
import 'package:provider/provider.dart';
import 'package:timeline_list/timeline.dart';
import 'package:timeline_list/timeline_model.dart';
import 'receiving_editor.dart';
@@ -129,7 +126,7 @@ class _ReceivingInfoState extends State<ReceivingInfo> {
_package.photoUrls.length == 0 ? Container() : img,
StatusTree(
shipmentHistory: _package.shipmentHistory,
currentStatus: _package.currentStatus),
currentStatus: _package.status),
SizedBox(
height: 20,
)

View File

@@ -79,7 +79,7 @@ class ReceivingListRow extends StatelessWidget {
children: <Widget>[
Padding(
padding: const EdgeInsets.all(3.0),
child: getStatus(package.currentStatus),
child: getStatus(package.status),
),
Padding(
padding: const EdgeInsets.all(0),