import 'package:farm_tpf/custom_model/Device.dart'; import 'package:farm_tpf/custom_model/SuppliesUsing.dart'; import 'package:farm_tpf/custom_model/Supply.dart'; import 'package:farm_tpf/presentation/custom_widgets/widget_text_form_field.dart'; import 'package:farm_tpf/presentation/screens/actions/controller/ChangeDevice.dart'; import 'package:farm_tpf/presentation/screens/actions/controller/ChangeFieldInForm.dart'; import 'package:farm_tpf/presentation/screens/actions/controller/ChangeFormButton.dart'; import 'package:farm_tpf/presentation/screens/actions/controller/ChangeSupplyUsing.dart'; import 'package:farm_tpf/presentation/screens/actions/controller/ChangeUnit.dart'; import 'package:farm_tpf/presentation/screens/actions/resource_device_activity/sc_device_activity.dart'; import 'package:farm_tpf/presentation/screens/actions/state_management_helper/change_supply.dart'; import 'package:farm_tpf/presentation/screens/resources/sc_resource_helper.dart'; import 'package:farm_tpf/utils/const_color.dart'; import 'package:farm_tpf/utils/const_common.dart'; import 'package:farm_tpf/utils/const_style.dart'; import 'package:farm_tpf/utils/validators.dart'; import 'package:flutter/material.dart'; import 'package:get/get.dart'; import 'package:farm_tpf/utils/formatter.dart'; import '../util_action.dart'; class WidgetSprayingSupply extends StatefulWidget { final List currentItems; final Function(List supplyChanges) onChangeSupplies; WidgetSprayingSupply({this.currentItems, @required this.onChangeSupplies}); @override _WidgetSprayingSupplyState createState() => _WidgetSprayingSupplyState(); } class _WidgetSprayingSupplyState extends State { final _dosageController = TextEditingController(); final _quantityController = TextEditingController(); final _howToUseController = TextEditingController(); final changeSelectedSupply = Get.put(ChangeSupply()); final changeSupplyUsing = Get.put(ChangeSupplyUsing()); final changeUnit = Get.put(ChangeUnit()); final changeButton = Get.put(ChangeButtonInForm()); final changeSelectedDevice = Get.put(ChangeDevice()); final changeFormField = Get.put(ChangeFieldFormSupply()); @override void initState() { super.initState(); changeSelectedSupply.initValue(); changeSelectedDevice.initValue(); changeSupplyUsing.init(widget.currentItems); changeUnit.initValue(); changeButton.resetValue(); changeFormField.init(); } Widget _buildListSupply() { return GetBuilder(builder: (value) { widget.onChangeSupplies(value.currentItems); if (value.currentItems.isEmpty) { return Container(); } else { return Container( height: 120, child: ListView.builder( physics: ClampingScrollPhysics(), scrollDirection: Axis.horizontal, shrinkWrap: true, itemCount: value.currentItems.length, itemBuilder: (context, index) { return GestureDetector( onTap: () { print("edit"); changeSupplyUsing.changeIndexEdit(index); changeButton.updateToEdit(true); var editedSupplyUsing = value.currentItems[index]; var editedSupply = Supply() ..id = editedSupplyUsing.tbSuppliesInWarehouseId ..tbSuppliesName = editedSupplyUsing.supplyName ..unit = editedSupplyUsing.supplyUnit; changeSelectedSupply.change(editedSupply); var editedDevice = Device() ..id = editedSupplyUsing.tbEquipmentOfCustomerId ..name = editedSupplyUsing.equipmentName; changeSelectedDevice.change(editedDevice); changeUnit .updateListByUnitName(editedSupplyUsing.supplyUnit); changeUnit.updateSelected(editedSupplyUsing.supplyUnit); _dosageController.text = editedSupplyUsing.dosage; _howToUseController.text = editedSupplyUsing.howToUse; _quantityController.text = editedSupplyUsing.quantity .formatNumtoStringDecimal(); }, child: Card( child: Stack( alignment: Alignment.bottomCenter, overflow: Overflow.visible, children: [ Positioned( child: ClipRRect( borderRadius: BorderRadius.circular(8), child: Container( padding: EdgeInsets.all(4), width: 150, child: Column( mainAxisAlignment: MainAxisAlignment.center, children: [ SizedBox( height: 12.0, ), Flexible( child: Text( value.currentItems[index].supplyName ?? "", overflow: TextOverflow.ellipsis, maxLines: 1), ), Validators.stringNotNullOrEmpty( value.currentItems[index].dosage) ? Flexible( child: Text( "${value.currentItems[index].dosage ?? ""}")) : SizedBox(), Validators.stringNotNullOrEmpty(value .currentItems[index].quantity .formatNumtoStringDecimal()) ? Flexible( child: Text( "${value.currentItems[index].quantity.formatNumtoStringDecimal() ?? ""} ${value.currentItems[index].supplyUnit ?? ""}")) : SizedBox(), Validators.stringNotNullOrEmpty(value .currentItems[index].equipmentName) ? Flexible( child: Text( "${value.currentItems[index].equipmentName ?? ""}")) : SizedBox(), Validators.stringNotNullOrEmpty( value.currentItems[index].howToUse) ? Flexible( child: Text( "${value.currentItems[index].howToUse ?? ""}")) : SizedBox(), ], ), ), )), Positioned( top: -10, right: -10, child: IconButton( icon: Icon( Icons.cancel, color: Colors.redAccent, ), onPressed: () { changeSupplyUsing.deleteSupply(index); }), ) ], ))); })); } }); } Widget _btnSelectSubstrates() { return GetBuilder(builder: (data) { return FlatButton( padding: EdgeInsets.only(top: 0.0, right: 0.0, bottom: 0.0, left: 0.0), onPressed: () { Navigator.of(context) .push(MaterialPageRoute( builder: (_) => ResourceHelperScreen( titleName: "Thuốc BVTV", type: ConstCommon.supplyTypeProtectPlant, selectedId: changeSelectedSupply.selectedSupplyId), fullscreenDialog: false)) .then((value) { if (value != null) { var result = value as Supply; changeSelectedSupply.change(result); changeUnit.updateListByUnitName(result.unit); changeFormField.change(true); } }); }, child: Container( padding: EdgeInsets.only( top: 0.0, right: 0.0, bottom: 10.5, left: 0.0), decoration: BoxDecoration( border: kBorderTextField, ), child: Row( children: [ GetBuilder( builder: (_) => Expanded( child: Text( changeSelectedSupply.selectedSupplyName ?? "Tên thương mại", style: TextStyle( fontSize: 14.0, color: Colors.black87)))), Icon( Icons.arrow_drop_down, color: Colors.grey, ), ], ))); }); } Widget _btnSelectDevice() { return GetBuilder(builder: (data) { return FlatButton( padding: EdgeInsets.only(top: 0.0, right: 0.0, bottom: 0.0, left: 0.0), onPressed: () { Navigator.of(context) .push(MaterialPageRoute( builder: (_) => ListDeviceActivity( selectedId: changeSelectedDevice.selectedDeviceId), fullscreenDialog: false)) .then((value) { if (value != null) { var result = value as Device; changeSelectedDevice.change(result); changeFormField.change(true); } }); }, child: Container( padding: EdgeInsets.only( top: 0.0, right: 0.0, bottom: 10.5, left: 0.0), decoration: BoxDecoration( border: kBorderTextField, ), child: Row( children: [ GetBuilder( builder: (_) => Expanded( child: Text( changeSelectedDevice.selectedDeviceName ?? "Thiết bị", style: TextStyle( fontSize: 14.0, color: Colors.black87)))), Icon( Icons.arrow_drop_down, color: Colors.grey, ), ], ))); }); } Widget _dropdownUnitTypes() { return GetBuilder(builder: (data) { return DropdownButtonFormField( itemHeight: 100, value: data.selectedUnit.isEmpty ? null : data.selectedUnit, items: data.currentUnits .map((label) => DropdownMenuItem( child: Text(label), value: label, )) .toList(), onChanged: (value) { var currentQuantity = _quantityController.text; num assignValue = currentQuantity.parseDoubleThousand(); if (assignValue != null) { var oldSelected = data.selectedUnit; if (oldSelected == value) { } else { assignValue = UtilAction.convertUnit( inputValue: assignValue, oldUnit: oldSelected, newUnit: value); } _quantityController.text = assignValue.formatNumtoStringDecimal(); } changeUnit.updateSelected(value); }, ); }); } _quantityField() { return WidgetTextFormFieldNumber( hintValue: "Tổng lượng sử dụng *", textController: _quantityController, onChanged: (value) { if (!Validators.stringNotNullOrEmpty(value) && !Validators.stringNotNullOrEmpty(_howToUseController.text) && !Validators.stringNotNullOrEmpty(_dosageController.text) && Get.find().selectedSupplyId <= 0 && changeSelectedDevice.selectedDeviceId <= 0) { changeFormField.change(false); } else { changeFormField.change(true); } }, ); } _buttonInForm() { return GetBuilder(builder: (_) { return Align( alignment: Alignment.centerRight, child: Row( mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ _.isEdit ? OutlineButton( shape: RoundedRectangleBorder( borderRadius: new BorderRadius.circular(8.0)), child: Text("Huỷ"), onPressed: () { changeButton.resetValue(); _resetForm(); _hidenKeyboard(context); }) : SizedBox(), _.isEdit ? FlatButton( color: COLOR_CONST.DEFAULT, shape: RoundedRectangleBorder( borderRadius: new BorderRadius.circular(8.0)), onPressed: () { var currentSupply = changeSelectedSupply.currentSupply; var currentDevice = changeSelectedDevice.currentDevice; var currentQuantity = _quantityController.text.parseDoubleThousand(); if (currentSupply.id != null && currentQuantity > 0) { var quantityWithCurrentSupplyUnit = UtilAction.convertUnit( inputValue: currentQuantity, oldUnit: changeUnit.selectedUnit, newUnit: changeSelectedSupply.currentSupply.unit); SuppliesUsing newSup = SuppliesUsing() ..dosage = _dosageController.text ..howToUse = _howToUseController.text ..quantity = quantityWithCurrentSupplyUnit ..tbSuppliesInWarehouseId = currentSupply.id ..suppliesInWarehouseId = currentSupply.id ..supplyName = currentSupply.tbSuppliesName ..tbEquipmentOfCustomerId = currentDevice.id ..equipmentOfCustomerId = currentDevice.id ..equipmentName = currentDevice.name ..supplyUnit = currentSupply.unit ..unit = currentSupply.unit; changeSupplyUsing.editSupply( changeSupplyUsing.currentIndex, newSup); _resetForm(); _hidenKeyboard(context); } }, child: Text( "Sửa", style: TextStyle(color: Colors.white), )) : FlatButton( color: COLOR_CONST.DEFAULT, shape: RoundedRectangleBorder( borderRadius: new BorderRadius.circular(8.0)), onPressed: () { var currentSupply = changeSelectedSupply.currentSupply; var currentDevice = changeSelectedDevice.currentDevice; var currentQuantity = _quantityController.text.parseDoubleThousand(); if (currentSupply.id != null && currentQuantity > 0) { var quantityWithCurrentSupplyUnit = UtilAction.convertUnit( inputValue: currentQuantity, oldUnit: changeUnit.selectedUnit, newUnit: changeSelectedSupply.currentSupply.unit); SuppliesUsing newSup = SuppliesUsing() ..dosage = _dosageController.text ..howToUse = _howToUseController.text ..quantity = quantityWithCurrentSupplyUnit ..tbSuppliesInWarehouseId = currentSupply.id ..suppliesInWarehouseId = currentSupply.id ..supplyName = currentSupply.tbSuppliesName ..supplyUnit = currentSupply.unit ..tbEquipmentOfCustomerId = currentDevice.id ..equipmentOfCustomerId = currentDevice.id ..equipmentName = currentDevice.name ..unit = currentSupply.unit; changeSupplyUsing.addSupply(newSup); _resetForm(); _hidenKeyboard(context); } }, child: Text( "Thêm", style: TextStyle(color: Colors.white), )) ], ), ); }); } Widget _formEdit() { return Container( padding: EdgeInsets.all(8.0), decoration: BoxDecoration( shape: BoxShape.rectangle, borderRadius: BorderRadius.circular(10), color: Colors.white, border: Border.all(color: COLOR_CONST.DEFAULT)), child: Column( children: [ Container( width: double.infinity, child: Text( "Tên thương mại *", style: TextStyle(color: Colors.black54, fontSize: 13.0), ), ), _btnSelectSubstrates(), TextFormField( keyboardType: TextInputType.text, controller: _dosageController, decoration: InputDecoration(labelText: "Liều lượng sử dụng"), onSaved: (newValue) {}, onChanged: (value) { if (!Validators.stringNotNullOrEmpty( _quantityController.text) && !Validators.stringNotNullOrEmpty( _howToUseController.text) && !Validators.stringNotNullOrEmpty(value) && Get.find().selectedSupplyId <= 0 && changeSelectedDevice.selectedDeviceId <= 0) { changeFormField.change(false); } else { changeFormField.change(true); } }, ), Row( mainAxisSize: MainAxisSize.min, mainAxisAlignment: MainAxisAlignment.spaceEvenly, crossAxisAlignment: CrossAxisAlignment.center, children: [ Expanded( flex: 2, child: Container( height: 70, child: _quantityField(), ), ), SizedBox( width: 16.0, ), Expanded( flex: 1, child: Align( alignment: Alignment.bottomCenter, child: _dropdownUnitTypes(), )), ]), Container( width: double.infinity, child: Text( "Thiết bị", style: TextStyle(color: Colors.black54, fontSize: 13.0), ), ), _btnSelectDevice(), TextFormField( keyboardType: TextInputType.text, controller: _howToUseController, decoration: InputDecoration(labelText: "Phương pháp sử dụng"), onSaved: (newValue) {}, onChanged: (value) { if (!Validators.stringNotNullOrEmpty( _quantityController.text) && !Validators.stringNotNullOrEmpty(value) && !Validators.stringNotNullOrEmpty(_dosageController.text) && Get.find().selectedSupplyId <= 0 && changeSelectedDevice.selectedDeviceId <= 0) { changeFormField.change(false); } else { changeFormField.change(true); } }, ), _buttonInForm() ], )); } _resetForm() { changeSupplyUsing.changeIndexEdit(-1); changeButton.resetValue(); _dosageController.text = ""; _howToUseController.text = ""; _quantityController.text = ""; changeUnit.initValue(); changeSelectedSupply.initValue(); changeSelectedDevice.initValue(); } _hidenKeyboard(BuildContext context) { FocusScopeNode currentFocus = FocusScope.of(context); if (!currentFocus.hasPrimaryFocus) { currentFocus.unfocus(); } } @override Widget build(BuildContext context) { return Column( children: [ _buildListSupply(), SizedBox( height: 8.0, ), _formEdit() ], ); } }