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/main/model/main_model.dart';
|
|
|
|
|
import 'package:fcs/pages/widgets/display_text.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';
|
|
|
|
|
import 'package:fcs/pages/widgets/progress.dart';
|
2020-10-12 03:34:05 +06:30
|
|
|
import 'package:fcs/pages/widgets/status_tree.dart';
|
2020-09-15 07:13:41 +06:30
|
|
|
import 'package:flutter/material.dart';
|
2020-09-17 06:02:48 +06:30
|
|
|
import 'package:flutter_icons/flutter_icons.dart';
|
2020-09-15 07:13:41 +06:30
|
|
|
import 'package:intl/intl.dart';
|
2020-09-18 21:33:41 +06:30
|
|
|
import 'package:provider/provider.dart';
|
2020-09-17 06:02:48 +06:30
|
|
|
import 'package:timeline_list/timeline_model.dart';
|
|
|
|
|
|
|
|
|
|
final DateFormat dateFormat = DateFormat("d MMM yyyy");
|
2020-09-15 07:13:41 +06:30
|
|
|
|
|
|
|
|
class PackageInfo extends StatefulWidget {
|
2020-10-12 03:34:05 +06:30
|
|
|
final isSearchResult;
|
2020-09-15 07:13:41 +06:30
|
|
|
final Package package;
|
2020-10-12 03:34:05 +06:30
|
|
|
PackageInfo({this.package, this.isSearchResult = false});
|
2020-09-15 07:13:41 +06:30
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
_PackageInfoState createState() => _PackageInfoState();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class _PackageInfoState extends State<PackageInfo> {
|
|
|
|
|
var dateFormatter = new DateFormat('dd MMM yyyy');
|
|
|
|
|
Package _package;
|
|
|
|
|
bool _isLoading = false;
|
2020-09-17 06:02:48 +06:30
|
|
|
MultiImgController multiImgController = MultiImgController();
|
2020-09-15 07:13:41 +06:30
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
void initState() {
|
|
|
|
|
super.initState();
|
2020-09-18 21:33:41 +06:30
|
|
|
initPackage(widget.package);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
initPackage(Package package) {
|
|
|
|
|
setState(() {
|
|
|
|
|
_package = package;
|
|
|
|
|
multiImgController.setImageUrls = package.photoUrls;
|
|
|
|
|
});
|
2020-09-15 07:13:41 +06:30
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
void dispose() {
|
|
|
|
|
super.dispose();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
2020-09-17 06:02:48 +06:30
|
|
|
final trackingIdBox = DisplayText(
|
|
|
|
|
text: _package.trackingID,
|
2020-10-08 03:32:52 +06:30
|
|
|
labelTextKey: "package.tracking.id",
|
2020-09-17 06:02:48 +06:30
|
|
|
iconData: MaterialCommunityIcons.barcode_scan,
|
|
|
|
|
);
|
|
|
|
|
final customerNameBox = DisplayText(
|
|
|
|
|
text: _package.userName,
|
2020-10-08 03:32:52 +06:30
|
|
|
labelTextKey: "package.create.name",
|
2020-09-17 06:02:48 +06:30
|
|
|
iconData: Icons.perm_identity,
|
|
|
|
|
);
|
|
|
|
|
final statusBox = DisplayText(
|
|
|
|
|
text: _package.currentStatus,
|
2020-10-08 03:32:52 +06:30
|
|
|
labelTextKey: "package.edit.status",
|
2020-09-17 06:02:48 +06:30
|
|
|
iconData: AntDesign.exclamationcircleo,
|
|
|
|
|
);
|
|
|
|
|
final marketBox = DisplayText(
|
|
|
|
|
text: _package.market ?? "-",
|
2020-10-08 03:32:52 +06:30
|
|
|
labelTextKey: "package.create.market",
|
2020-09-17 06:02:48 +06:30
|
|
|
iconData: Icons.store,
|
|
|
|
|
);
|
|
|
|
|
final descBox = DisplayText(
|
|
|
|
|
text: _package.desc ?? "-",
|
2020-10-08 03:32:52 +06:30
|
|
|
labelTextKey: "package.edit.desc",
|
2020-09-17 06:02:48 +06:30
|
|
|
iconData: MaterialCommunityIcons.message_text_outline,
|
|
|
|
|
);
|
|
|
|
|
final remarkBox = DisplayText(
|
|
|
|
|
text: _package.remark ?? "-",
|
2020-10-08 03:32:52 +06:30
|
|
|
labelTextKey: "package.edit.remark",
|
2020-09-17 06:02:48 +06:30
|
|
|
iconData: Entypo.new_message,
|
|
|
|
|
);
|
|
|
|
|
final img = MultiImageFile(
|
|
|
|
|
enabled: false,
|
|
|
|
|
controller: multiImgController,
|
|
|
|
|
title: "Receipt File",
|
|
|
|
|
);
|
|
|
|
|
|
2020-09-15 07:13:41 +06:30
|
|
|
return LocalProgress(
|
|
|
|
|
inAsyncCall: _isLoading,
|
|
|
|
|
child: Scaffold(
|
|
|
|
|
appBar: AppBar(
|
|
|
|
|
centerTitle: true,
|
|
|
|
|
leading: new IconButton(
|
2020-09-17 06:02:48 +06:30
|
|
|
icon: new Icon(Icons.close, color: primaryColor, size: 30),
|
2020-09-15 07:13:41 +06:30
|
|
|
onPressed: () => Navigator.of(context).pop(),
|
|
|
|
|
),
|
2020-09-17 06:02:48 +06:30
|
|
|
shadowColor: Colors.transparent,
|
|
|
|
|
backgroundColor: Colors.white,
|
|
|
|
|
title: LocalText(
|
|
|
|
|
context,
|
|
|
|
|
"package.info.title",
|
|
|
|
|
fontSize: 20,
|
|
|
|
|
color: primaryColor,
|
|
|
|
|
),
|
2020-09-15 07:13:41 +06:30
|
|
|
),
|
|
|
|
|
body: Card(
|
|
|
|
|
child: Column(
|
|
|
|
|
children: <Widget>[
|
|
|
|
|
Expanded(
|
|
|
|
|
child: Padding(
|
|
|
|
|
padding: const EdgeInsets.all(10.0),
|
|
|
|
|
child: ListView(children: <Widget>[
|
2020-09-17 06:02:48 +06:30
|
|
|
trackingIdBox,
|
2020-10-12 03:34:05 +06:30
|
|
|
widget.isSearchResult ? Container() : customerNameBox,
|
|
|
|
|
widget.isSearchResult ? Container() : marketBox,
|
2020-09-17 06:02:48 +06:30
|
|
|
statusBox,
|
|
|
|
|
_package.photoUrls.length == 0 ? Container() : img,
|
2020-10-12 03:34:05 +06:30
|
|
|
widget.isSearchResult ? Container() : descBox,
|
2020-09-17 06:02:48 +06:30
|
|
|
remarkBox,
|
2020-10-12 03:34:05 +06:30
|
|
|
StatusTree(
|
|
|
|
|
shipmentHistory: _package.shipmentHistory,
|
|
|
|
|
currentStatus: _package.currentStatus),
|
2020-09-17 06:02:48 +06:30
|
|
|
SizedBox(
|
|
|
|
|
height: 20,
|
2020-09-15 07:13:41 +06:30
|
|
|
)
|
|
|
|
|
]),
|
|
|
|
|
)),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
}
|
2020-09-17 06:02:48 +06:30
|
|
|
|
|
|
|
|
List<TimelineModel> _models() {
|
|
|
|
|
if (_package.shipmentHistory == null) return [];
|
|
|
|
|
return _package.shipmentHistory
|
|
|
|
|
.map((e) => TimelineModel(
|
|
|
|
|
Padding(
|
|
|
|
|
padding: const EdgeInsets.all(18.0),
|
|
|
|
|
child: Column(
|
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
|
children: <Widget>[
|
|
|
|
|
Text(e.status,
|
|
|
|
|
style: TextStyle(
|
|
|
|
|
color: e.done ? primaryColor : Colors.grey,
|
|
|
|
|
fontSize: 16,
|
|
|
|
|
fontWeight: FontWeight.bold)),
|
|
|
|
|
Text(dateFormat.format(e.date)),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
iconBackground: e.done ? primaryColor : Colors.grey,
|
|
|
|
|
icon: Icon(
|
|
|
|
|
e.status == "shipped"
|
|
|
|
|
? Ionicons.ios_airplane
|
|
|
|
|
: e.status == "delivered"
|
|
|
|
|
? MaterialCommunityIcons.truck_fast
|
2020-10-11 02:17:23 +06:30
|
|
|
: e.status == "packed"
|
|
|
|
|
? MaterialCommunityIcons.package
|
|
|
|
|
: e.status == "processed"
|
|
|
|
|
? FontAwesome.dropbox
|
|
|
|
|
: MaterialCommunityIcons.inbox_arrow_down,
|
2020-09-17 06:02:48 +06:30
|
|
|
color: Colors.white,
|
|
|
|
|
)))
|
|
|
|
|
.toList();
|
|
|
|
|
}
|
2020-09-15 07:13:41 +06:30
|
|
|
}
|