Files
fcs/lib/pages/processing/processing_editor.dart

284 lines
7.9 KiB
Dart
Raw Normal View History

2020-10-08 16:53:43 +06:30
import 'package:fcs/domain/entities/package.dart';
2020-12-01 19:02:21 +06:30
import 'package:fcs/domain/entities/processing.dart';
2020-10-12 03:34:05 +06:30
import 'package:fcs/domain/entities/user.dart';
2020-10-08 16:53:43 +06:30
import 'package:fcs/helpers/theme.dart';
import 'package:fcs/pages/main/util.dart';
2021-01-05 18:03:51 +06:30
import 'package:fcs/pages/package/package_info.dart';
2020-10-12 03:34:05 +06:30
import 'package:fcs/pages/user_search/user_serach.dart';
2020-10-08 16:53:43 +06:30
import 'package:fcs/pages/widgets/display_text.dart';
2020-10-12 03:34:05 +06:30
import 'package:fcs/pages/widgets/fcs_id_icon.dart';
2020-10-08 16:53:43 +06:30
import 'package:fcs/pages/widgets/local_text.dart';
import 'package:fcs/pages/widgets/progress.dart';
2020-10-14 13:54:42 +06:30
import 'package:flutter/cupertino.dart';
2020-10-08 16:53:43 +06:30
import 'package:flutter/material.dart';
2021-09-10 12:00:08 +06:30
import 'package:flutter_vector_icons/flutter_vector_icons.dart';
2020-10-08 16:53:43 +06:30
import 'package:provider/provider.dart';
2020-12-01 19:02:21 +06:30
import 'model/processing_model.dart';
import 'package_editor.dart';
2020-10-08 16:53:43 +06:30
2020-12-01 19:02:21 +06:30
class ProcesingEditor extends StatefulWidget {
2021-09-10 12:00:08 +06:30
final Processing? processing;
2020-12-01 19:02:21 +06:30
const ProcesingEditor({this.processing});
2020-10-08 16:53:43 +06:30
@override
2020-12-01 19:02:21 +06:30
_ProcesingEditorState createState() => _ProcesingEditorState();
2020-10-08 16:53:43 +06:30
}
2020-12-01 19:02:21 +06:30
class _ProcesingEditorState extends State<ProcesingEditor> {
Processing processing = Processing();
2020-10-08 16:53:43 +06:30
bool _isLoading = false;
2021-09-10 12:00:08 +06:30
late bool _isNew;
User? consignee;
User? sender;
2020-12-01 19:02:21 +06:30
List<Package> packages = [];
2020-10-08 16:53:43 +06:30
@override
void initState() {
super.initState();
2020-12-01 19:02:21 +06:30
_isNew = widget.processing == null;
if (!_isNew) {
2021-09-10 12:00:08 +06:30
processing = widget.processing!;
2021-01-05 18:03:51 +06:30
consignee = User(
2020-12-01 19:02:21 +06:30
fcsID: processing.userID,
name: processing.userName,
phoneNumber: processing.userPhoneNumber);
2021-01-05 18:03:51 +06:30
sender = User(
2020-12-01 19:02:21 +06:30
fcsID: processing.fcsID,
name: processing.shipperName,
phoneNumber: processing.shipperPhoneNumber);
packages = processing.packages;
}
2020-10-08 16:53:43 +06:30
}
@override
Widget build(BuildContext context) {
2020-10-12 03:34:05 +06:30
var fcsIDBox = Row(
children: <Widget>[
Expanded(
child: DisplayText(
2021-09-10 12:00:08 +06:30
text: consignee != null ? consignee!.fcsID : "",
2020-10-12 03:34:05 +06:30
labelTextKey: "processing.fcs.id",
icon: FcsIDIcon(),
)),
IconButton(
icon: Icon(Icons.search, color: primaryColor),
2021-01-10 15:56:27 +06:30
onPressed: () => searchUser(context, onUserSelect: (u) {
2020-10-12 03:34:05 +06:30
setState(() {
2021-01-05 18:03:51 +06:30
this.consignee = u;
2020-10-12 03:34:05 +06:30
});
2021-01-10 15:56:27 +06:30
}, popPage: true)),
2020-10-12 03:34:05 +06:30
],
);
2020-12-01 19:02:21 +06:30
2020-10-12 03:34:05 +06:30
final phoneNumberBox = DisplayText(
2021-09-10 12:00:08 +06:30
text: consignee != null ? consignee!.phoneNumber : "",
2020-10-12 03:34:05 +06:30
labelTextKey: "processing.phone",
2020-12-01 19:02:21 +06:30
maxLines: 2,
2020-10-12 03:34:05 +06:30
iconData: Icons.phone,
);
2020-12-01 19:02:21 +06:30
final namebox = DisplayText(
2021-09-10 12:00:08 +06:30
text: consignee != null ? consignee!.name : "",
2020-12-01 19:02:21 +06:30
labelTextKey: "processing.consignee.name",
maxLines: 2,
iconData: Icons.person,
2020-10-08 16:53:43 +06:30
);
2020-12-01 19:02:21 +06:30
final consigneeBox = Container(
child: Column(
children: [
fcsIDBox,
phoneNumberBox,
namebox,
],
),
);
var shipperIDBox = Row(
children: <Widget>[
Expanded(
child: DisplayText(
2021-09-10 12:00:08 +06:30
text: sender != null ? sender!.fcsID : "",
2020-12-01 19:02:21 +06:30
labelTextKey: "processing.fcs.id",
icon: FcsIDIcon(),
)),
IconButton(
icon: Icon(Icons.search, color: primaryColor),
2021-01-10 15:56:27 +06:30
onPressed: () => searchUser(context, onUserSelect: (u) {
2020-12-01 19:02:21 +06:30
setState(() {
2021-01-05 18:03:51 +06:30
this.sender = u;
2020-12-01 19:02:21 +06:30
});
2021-01-10 15:56:27 +06:30
}, popPage: true)),
2020-12-01 19:02:21 +06:30
],
2020-10-08 16:53:43 +06:30
);
2020-12-01 19:02:21 +06:30
final shipperPhoneNumberBox = DisplayText(
2021-09-10 12:00:08 +06:30
text: sender != null ? sender!.phoneNumber : "",
2020-12-01 19:02:21 +06:30
labelTextKey: "processing.phone",
maxLines: 2,
iconData: Icons.phone,
2020-10-08 16:53:43 +06:30
);
2020-12-01 19:02:21 +06:30
final shipperNamebox = DisplayText(
2021-09-10 12:00:08 +06:30
text: sender != null ? sender!.name : "",
2020-12-01 19:02:21 +06:30
labelTextKey: "processing.shipper.name",
maxLines: 2,
iconData: Icons.person,
2020-10-08 16:53:43 +06:30
);
2020-12-01 19:02:21 +06:30
final shipperBox = Container(
child: Column(
children: [
shipperIDBox,
shipperPhoneNumberBox,
shipperNamebox,
],
),
);
2020-10-08 16:53:43 +06:30
2020-12-01 19:02:21 +06:30
final packageTitleBox = Container(
2020-10-12 03:34:05 +06:30
child: Row(
2020-12-01 19:02:21 +06:30
mainAxisAlignment: MainAxisAlignment.end,
2020-10-12 03:34:05 +06:30
children: [
2020-12-01 19:02:21 +06:30
Text("Packages (${packages.length})"),
IconButton(
icon: Icon(
Icons.add_circle,
color: primaryColor,
),
onPressed: () async {
2021-01-05 18:03:51 +06:30
if (this.consignee == null) {
2021-01-10 15:56:27 +06:30
showMsgDialog(
context, "Warning", "Please select 'Consignee'");
2021-01-05 18:03:51 +06:30
return;
}
2021-09-10 12:00:08 +06:30
Package? _package = await Navigator.push<Package>(
2020-12-01 19:02:21 +06:30
context,
2021-01-05 18:03:51 +06:30
CupertinoPageRoute(
builder: (context) => PackageEditor(
sender: this.sender,
consignee: this.consignee,
)),
2020-12-01 19:02:21 +06:30
);
2021-10-11 17:09:47 +06:30
_addPackage(_package);
2020-12-02 20:55:00 +06:30
// _savePackage(_package);
2020-12-01 19:02:21 +06:30
}),
],
),
);
final createButton = fcsButton(
context,
getLocalString(context, 'processing.edit.complete.btn'),
callack: _save,
);
return LocalProgress(
inAsyncCall: _isLoading,
child: Scaffold(
appBar: AppBar(
centerTitle: true,
leading: new IconButton(
icon:
new Icon(CupertinoIcons.back, color: primaryColor, size: 30),
onPressed: () {
2021-01-10 15:56:27 +06:30
Navigator.of(context).pop();
},
2020-12-01 19:02:21 +06:30
),
shadowColor: Colors.transparent,
backgroundColor: Colors.white,
title: LocalText(
context,
_isNew ? "processing.create" : "processing.update",
fontSize: 20,
color: primaryColor,
),
2020-10-08 16:53:43 +06:30
),
2020-12-01 19:02:21 +06:30
body: Padding(
padding: const EdgeInsets.only(left: 12.0, right: 12),
child: ListView(
children: <Widget>[
SizedBox(
height: 10,
2020-10-12 08:26:27 +06:30
),
2020-12-01 19:02:21 +06:30
Row(
children: [
Flexible(child: consigneeBox),
Flexible(child: shipperBox)
],
),
Divider(),
packageTitleBox,
Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: _getPackages(context, packages),
),
SizedBox(
height: 20,
),
2020-12-02 20:55:00 +06:30
createButton,
2020-12-01 19:02:21 +06:30
SizedBox(
height: 10,
2020-10-12 08:26:27 +06:30
),
],
2020-10-08 16:53:43 +06:30
),
),
2020-12-01 19:02:21 +06:30
));
2020-10-08 16:53:43 +06:30
}
2020-12-01 19:02:21 +06:30
List<Widget> _getPackages(BuildContext context, List<Package> packages) {
return packages.map((p) {
2021-01-05 18:03:51 +06:30
return InkWell(
onTap: () async {
2021-09-10 12:00:08 +06:30
Package? _package = await Navigator.of(context).push<Package>(
2021-01-05 18:03:51 +06:30
CupertinoPageRoute(
builder: (context) => PackageInfo(package: p)));
2021-09-10 12:00:08 +06:30
_savePackage(_package!);
2021-01-05 18:03:51 +06:30
},
child: DisplayText(
labelTextKey: "processing.tracking.id",
iconData: MaterialCommunityIcons.barcode_scan,
text: p.trackingID,
2020-12-01 19:02:21 +06:30
),
);
}).toList();
2020-10-08 16:53:43 +06:30
}
2021-10-11 17:09:47 +06:30
_addPackage(Package? package) {
2020-12-02 20:55:00 +06:30
if (package == null) return;
this.packages.add(package);
setState(() {});
2020-12-01 19:02:21 +06:30
}
2021-10-11 17:09:47 +06:30
_savePackage(Package? package) {
2020-12-02 20:55:00 +06:30
if (package == null) return;
setState(() {});
}
2020-12-01 19:02:21 +06:30
_save() async {
2020-10-08 16:53:43 +06:30
setState(() {
_isLoading = true;
});
2020-12-01 19:02:21 +06:30
ProcessingModel processingModel =
Provider.of<ProcessingModel>(context, listen: false);
2020-10-08 16:53:43 +06:30
try {
2020-12-01 19:02:21 +06:30
if (_isNew) {
await processingModel.createProcessing(processing);
} else {
2021-09-10 12:00:08 +06:30
processing.id = widget.processing!.id;
2020-12-01 19:02:21 +06:30
await processingModel.updateProcessing(processing);
}
2020-10-08 16:53:43 +06:30
Navigator.pop(context);
} catch (e) {
showMsgDialog(context, "Error", e.toString());
} finally {
setState(() {
_isLoading = false;
});
}
}
}