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

342 lines
10 KiB
Dart
Raw Normal View History

2020-12-01 19:02:21 +06:30
import 'package:fcs/domain/entities/market.dart';
import 'package:fcs/domain/entities/package.dart';
import 'package:fcs/domain/entities/user.dart';
import 'package:fcs/helpers/theme.dart';
import 'package:fcs/pages/market/market_editor.dart';
import 'package:fcs/pages/market/model/market_model.dart';
import 'package:fcs/pages/package/model/package_model.dart';
import 'package:fcs/pages/package/tracking_id_page.dart';
import 'package:fcs/pages/main/util.dart';
2024-02-07 17:26:29 +06:30
import 'package:fcs/pages/user_search/user_search.dart';
2020-12-01 19:02:21 +06:30
import 'package:fcs/pages/widgets/display_text.dart';
import 'package:fcs/pages/widgets/fcs_id_icon.dart';
import 'package:fcs/pages/widgets/input_text.dart';
2024-01-25 17:40:35 +06:30
import 'package:fcs/pages/widgets/local_app_bar.dart';
2020-12-01 19:02:21 +06:30
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';
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
2021-09-10 12:00:08 +06:30
import 'package:flutter_vector_icons/flutter_vector_icons.dart';
2020-12-01 19:02:21 +06:30
import 'package:intl/intl.dart';
import 'package:provider/provider.dart';
2020-12-02 20:55:00 +06:30
class ProcessingEditEditor extends StatefulWidget {
2021-09-10 12:00:08 +06:30
final Package? package;
2020-12-02 20:55:00 +06:30
ProcessingEditEditor({this.package});
2020-12-01 19:02:21 +06:30
@override
2020-12-02 20:55:00 +06:30
_ProcessingEditEditorState createState() => _ProcessingEditEditorState();
2020-12-01 19:02:21 +06:30
}
2020-12-02 20:55:00 +06:30
class _ProcessingEditEditorState extends State<ProcessingEditEditor> {
2020-12-01 19:02:21 +06:30
TextEditingController _remarkCtl = new TextEditingController();
TextEditingController _descCtl = new TextEditingController();
2021-09-10 12:00:08 +06:30
Package? _package;
2021-10-11 17:09:47 +06:30
User? _consignee;
User? _sender;
2020-12-01 19:02:21 +06:30
bool _isLoading = false;
@override
void initState() {
super.initState();
_package = widget.package;
2021-09-10 12:00:08 +06:30
selectedMarket = _package!.market ?? "";
2021-09-13 14:25:07 +06:30
_descCtl.text = _package!.desc ?? "";
_remarkCtl.text = _package!.remark ?? "";
2021-09-10 12:00:08 +06:30
multiImgController.setImageUrls = _package!.photoUrls;
2021-10-11 17:09:47 +06:30
_consignee = User(
2021-09-10 12:00:08 +06:30
fcsID: _package!.fcsID ?? "",
name: _package!.userName ?? "",
phoneNumber: _package!.phoneNumber ?? "");
2021-10-11 17:09:47 +06:30
_sender = User(
fcsID: _package!.senderFCSID ?? "",
name: _package!.senderName ?? "",
phoneNumber: _package!.senderPhoneNumber ?? "");
2020-12-01 19:02:21 +06:30
}
final DateFormat dateFormat = DateFormat("d MMM yyyy");
bool isNew = false;
MultiImgController multiImgController = MultiImgController();
@override
Widget build(BuildContext context) {
var fcsIDBox = Row(
children: <Widget>[
Expanded(
child: DisplayText(
2021-10-11 17:09:47 +06:30
text: _consignee!.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-10-11 17:09:47 +06:30
this._consignee = u;
2020-12-01 19:02:21 +06:30
});
})),
],
);
final namebox = DisplayText(
2021-10-11 17:09:47 +06:30
text: _consignee!.name,
labelTextKey: "processing.consignee.name",
2020-12-01 19:02:21 +06:30
iconData: Icons.person,
);
final phoneNumberBox = DisplayText(
2021-10-11 17:09:47 +06:30
text: _consignee!.phoneNumber,
2020-12-01 19:02:21 +06:30
labelTextKey: "processing.phone",
iconData: Icons.phone,
);
final trackingIdBox = DisplayText(
2021-09-10 12:00:08 +06:30
text: _package!.trackingID,
2020-12-01 19:02:21 +06:30
labelTextKey: "processing.tracking.id",
iconData: MaterialCommunityIcons.barcode_scan,
);
final completeProcessingBtn = fcsButton(
context,
getLocalString(context, 'processing.edit.complete.btn'),
callack: _completeProcessing,
);
final descBox = InputText(
labelTextKey: 'processing.desc',
iconData: MaterialCommunityIcons.message_text_outline,
controller: _descCtl);
final remarkBox = InputText(
labelTextKey: 'processing.remark',
iconData: Entypo.new_message,
controller: _remarkCtl);
final img = MultiImageFile(
enabled: true,
controller: multiImgController,
title: "Receipt File",
);
2021-10-11 17:09:47 +06:30
final consigneeBox = Container(
child: Column(
children: [
fcsIDBox,
phoneNumberBox,
namebox,
],
),
);
var shipperIDBox = Row(
children: <Widget>[
Expanded(
child: DisplayText(
text: _sender != null ? _sender!.fcsID : "",
labelTextKey: "processing.fcs.id",
icon: FcsIDIcon(),
)),
IconButton(
icon: Icon(Icons.search, color: primaryColor),
onPressed: () => searchUser(context, onUserSelect: (u) {
setState(() {
this._sender = u;
});
}, popPage: true)),
],
);
final shipperPhoneNumberBox = DisplayText(
text: _sender != null ? _sender!.phoneNumber : "",
labelTextKey: "processing.phone",
maxLines: 2,
iconData: Icons.phone,
);
final shipperNamebox = DisplayText(
text: _sender != null ? _sender!.name : "",
labelTextKey: "processing.shipper.name",
maxLines: 2,
iconData: Icons.person,
);
final shipperBox = Container(
child: Column(
children: [
shipperIDBox,
shipperPhoneNumberBox,
shipperNamebox,
],
),
);
2020-12-01 19:02:21 +06:30
return LocalProgress(
inAsyncCall: _isLoading,
child: Scaffold(
2024-01-25 17:40:35 +06:30
appBar: LocalAppBar(
labelKey: "processing.edit.title",
2020-12-01 19:02:21 +06:30
backgroundColor: Colors.white,
2024-01-25 17:40:35 +06:30
labelColor: primaryColor,
arrowColor: primaryColor,
onBack: () {
if (isDataChanged()) {
showConfirmDialog(context, "back.button_confirm", () {
Navigator.of(context).pop();
});
} else {
Navigator.of(context).pop();
}
},
2020-12-01 19:02:21 +06:30
),
body: Padding(
padding: const EdgeInsets.all(8.0),
child: ListView(
children: [
trackingIdBox,
2021-10-11 17:09:47 +06:30
Row(
children: [
Flexible(child: consigneeBox),
Flexible(child: shipperBox)
],
),
2020-12-01 19:02:21 +06:30
marketDropdown(),
descBox,
remarkBox,
img,
completeProcessingBtn,
SizedBox(
height: 20,
)
],
),
),
),
);
}
2021-09-10 12:00:08 +06:30
String? selectedMarket;
2020-12-01 19:02:21 +06:30
Widget marketDropdown() {
List<Market> _markets = Provider.of<MarketModel>(context).markets;
2021-09-10 16:48:21 +06:30
List<String?> markets = _markets.map((e) => e.name).toList();
2020-12-01 19:02:21 +06:30
markets.insert(0, MANAGE_MARKET);
if (!markets.contains(selectedMarket)) {
2021-10-11 17:09:47 +06:30
markets.insert(0, selectedMarket);
2020-12-01 19:02:21 +06:30
}
return Padding(
2021-10-11 17:09:47 +06:30
padding: const EdgeInsets.only(left: 5.0, right: 0, top: 10),
2020-12-01 19:02:21 +06:30
child: Row(
children: [
Padding(
padding: const EdgeInsets.only(left: 0, right: 10),
child: Icon(Icons.store, color: primaryColor),
),
Expanded(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Padding(
padding: const EdgeInsets.only(right: 18.0),
child: LocalText(
context,
"processing.market",
color: Colors.black54,
fontSize: 16,
),
),
DropdownButton<String>(
isDense: true,
value: selectedMarket,
style: TextStyle(color: Colors.black, fontSize: 14),
underline: Container(
height: 1,
color: Colors.grey,
),
2021-09-10 12:00:08 +06:30
onChanged: (String? newValue) {
2020-12-01 19:02:21 +06:30
setState(() {
if (newValue == MANAGE_MARKET) {
selectedMarket = null;
_manageMarket();
return;
}
selectedMarket = newValue;
});
},
isExpanded: true,
2021-09-10 16:48:21 +06:30
items: markets.map<DropdownMenuItem<String>>((String? value) {
2020-12-01 19:02:21 +06:30
return DropdownMenuItem<String>(
value: value,
child: Text(value ?? "",
overflow: TextOverflow.ellipsis,
style: TextStyle(
color: value == MANAGE_MARKET
? secondaryColor
: primaryColor)),
);
}).toList(),
),
],
),
),
],
),
);
}
_manageMarket() {
Navigator.push<Package>(
context,
CupertinoPageRoute(builder: (context) => MarketEditor()),
);
}
_completeProcessing() async {
2021-10-11 17:09:47 +06:30
if (_consignee!.fcsID == null || _consignee!.fcsID == "") {
2020-12-01 19:02:21 +06:30
showMsgDialog(context, "Error", "Expected FCS-ID");
return;
}
setState(() {
_isLoading = true;
});
PackageModel packageModel =
Provider.of<PackageModel>(context, listen: false);
try {
2021-10-11 17:09:47 +06:30
_package!.fcsID = _consignee!.fcsID;
_package!.senderFCSID = _sender!.fcsID;
2021-09-10 12:00:08 +06:30
_package!.desc = _descCtl.text;
_package!.remark = _remarkCtl.text;
2021-10-11 17:09:47 +06:30
_package!.market = selectedMarket ?? "";
2021-09-10 12:00:08 +06:30
await packageModel.updateProcessing(_package!,
2020-12-01 19:02:21 +06:30
multiImgController.getAddedFile, multiImgController.getDeletedUrl);
Navigator.pop(context);
} catch (e) {
showMsgDialog(context, "Error", e.toString());
} finally {
setState(() {
_isLoading = false;
});
}
}
isDataChanged() {
2021-01-07 18:15:39 +06:30
if (isNew) {
2021-10-11 17:09:47 +06:30
return _consignee!.fcsID != "" ||
2021-01-07 18:15:39 +06:30
selectedMarket != null ||
_descCtl.text != "" ||
_remarkCtl.text != "" ||
multiImgController.getAddedFile.isNotEmpty;
} else {
var _package = Package(
2021-10-11 17:09:47 +06:30
fcsID: _consignee!.fcsID,
senderFCSID: _sender!.fcsID,
market: selectedMarket,
2024-01-25 17:40:35 +06:30
desc: _descCtl.text,
2021-01-07 18:15:39 +06:30
remark: _remarkCtl.text,
2021-09-10 12:00:08 +06:30
photoUrls: widget.package!.photoUrls);
return widget.package!.isChangedForEditProcessing(_package) ||
2021-01-07 18:15:39 +06:30
multiImgController.getAddedFile.isNotEmpty ||
multiImgController.getDeletedUrl.isNotEmpty;
}
}
2020-12-01 19:02:21 +06:30
}