|
|
|
@ -1,8 +1,11 @@
|
|
|
|
|
import 'package:diplomaticquarterapp/core/enum/viewstate.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/core/model/pharmacies/Addresses.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/core/model/pharmacies/order_detail.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/core/model/pharmacies/payment-checkout-data.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/core/viewModels/pharmacyModule/OrderPreviewViewModel.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/core/viewModels/project_view_model.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/models/Appointments/AppoimentAllHistoryResultList.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/models/Authentication/authenticated_user.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/pages/base/base_view.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/pages/pharmacies/screens/address-select-page.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/pages/pharmacies/screens/payment-method-select-page.dart';
|
|
|
|
@ -12,6 +15,7 @@ import 'package:diplomaticquarterapp/pages/pharmacy/pharmacyAddresses/PharmacyAd
|
|
|
|
|
import 'package:diplomaticquarterapp/uitl/app_toast.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/uitl/translations_delegate_base.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/widgets/data_display/text.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/widgets/in_app_browser/InAppBrowser.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/widgets/others/app_scaffold_widget.dart';
|
|
|
|
|
import 'package:diplomaticquarterapp/widgets/transitions/fade_page.dart';
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
@ -30,10 +34,13 @@ class OrderPreviewPage extends StatelessWidget {
|
|
|
|
|
|
|
|
|
|
return BaseView<OrderPreviewViewModel>(
|
|
|
|
|
onModelReady: (model) => model.getShoppingCart(),
|
|
|
|
|
builder: (_, model, wi) => ChangeNotifierProvider.value(
|
|
|
|
|
builder: (_, model, wi) =>
|
|
|
|
|
ChangeNotifierProvider.value(
|
|
|
|
|
value: model.paymentCheckoutData,
|
|
|
|
|
child: AppScaffold(
|
|
|
|
|
appBarTitle: "${TranslationBase.of(context).checkOut}",
|
|
|
|
|
appBarTitle: "${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.checkOut}",
|
|
|
|
|
isShowAppBar: true,
|
|
|
|
|
isPharmacy: true,
|
|
|
|
|
isShowDecPage: false,
|
|
|
|
@ -76,7 +83,9 @@ class OrderPreviewPage extends StatelessWidget {
|
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
|
children: [
|
|
|
|
|
Texts(
|
|
|
|
|
TranslationBase.of(context).reviewOrder,
|
|
|
|
|
TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.reviewOrder,
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
|
color: Colors.black,
|
|
|
|
@ -85,8 +94,10 @@ class OrderPreviewPage extends StatelessWidget {
|
|
|
|
|
model.cartResponse.shoppingCarts != null
|
|
|
|
|
? model.cartResponse.shoppingCarts.length
|
|
|
|
|
: 0,
|
|
|
|
|
(index) => ProductOrderPreviewItem(
|
|
|
|
|
model.cartResponse.shoppingCarts[index]),
|
|
|
|
|
(index) =>
|
|
|
|
|
ProductOrderPreviewItem(
|
|
|
|
|
model.cartResponse
|
|
|
|
|
.shoppingCarts[index]),
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
@ -100,7 +111,8 @@ class OrderPreviewPage extends StatelessWidget {
|
|
|
|
|
CrossAxisAlignment.start,
|
|
|
|
|
children: [
|
|
|
|
|
Texts(
|
|
|
|
|
TranslationBase.of(context)
|
|
|
|
|
TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.orderSummary,
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
@ -114,13 +126,18 @@ class OrderPreviewPage extends StatelessWidget {
|
|
|
|
|
MainAxisAlignment.spaceBetween,
|
|
|
|
|
children: [
|
|
|
|
|
Texts(
|
|
|
|
|
"${TranslationBase.of(context).subtotal}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.subtotal}",
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
color: Colors.black,
|
|
|
|
|
fontWeight: FontWeight.w500,
|
|
|
|
|
),
|
|
|
|
|
Texts(
|
|
|
|
|
"${TranslationBase.of(context).sar} ${(model.cartResponse.subtotal).toStringAsFixed(2)}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.sar} ${(model.cartResponse.subtotal)
|
|
|
|
|
.toStringAsFixed(2)}",
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
color: Colors.black,
|
|
|
|
|
fontWeight: FontWeight.w500,
|
|
|
|
@ -139,13 +156,19 @@ class OrderPreviewPage extends StatelessWidget {
|
|
|
|
|
MainAxisAlignment.spaceBetween,
|
|
|
|
|
children: [
|
|
|
|
|
Texts(
|
|
|
|
|
"${TranslationBase.of(context).shipping}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.shipping}",
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
color: Colors.black,
|
|
|
|
|
fontWeight: FontWeight.w500,
|
|
|
|
|
),
|
|
|
|
|
Texts(
|
|
|
|
|
"${TranslationBase.of(context).sar} ${(model.totalAdditionalShippingCharge).toStringAsFixed(2)}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.sar} ${(model
|
|
|
|
|
.totalAdditionalShippingCharge)
|
|
|
|
|
.toStringAsFixed(2)}",
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
color: Colors.black,
|
|
|
|
|
fontWeight: FontWeight.w500,
|
|
|
|
@ -164,13 +187,19 @@ class OrderPreviewPage extends StatelessWidget {
|
|
|
|
|
MainAxisAlignment.spaceBetween,
|
|
|
|
|
children: [
|
|
|
|
|
Texts(
|
|
|
|
|
"${TranslationBase.of(context).vat}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.vat}",
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
color: Colors.black,
|
|
|
|
|
fontWeight: FontWeight.w500,
|
|
|
|
|
),
|
|
|
|
|
Texts(
|
|
|
|
|
"${TranslationBase.of(context).sar} ${(model.cartResponse.subtotalVatAmount).toStringAsFixed(2)}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.sar} ${(model.cartResponse
|
|
|
|
|
.subtotalVatAmount).toStringAsFixed(
|
|
|
|
|
2)}",
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
color: Colors.black,
|
|
|
|
|
fontWeight: FontWeight.w500,
|
|
|
|
@ -189,13 +218,18 @@ class OrderPreviewPage extends StatelessWidget {
|
|
|
|
|
MainAxisAlignment.spaceBetween,
|
|
|
|
|
children: [
|
|
|
|
|
Texts(
|
|
|
|
|
TranslationBase.of(context).total,
|
|
|
|
|
TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.total,
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
color: Colors.black,
|
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
|
),
|
|
|
|
|
Texts(
|
|
|
|
|
"${TranslationBase.of(context).sar} ${(model.cartResponse.subtotal).toStringAsFixed(2)}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.sar} ${(model.cartResponse.subtotal)
|
|
|
|
|
.toStringAsFixed(2)}",
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
color: Colors.black,
|
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
@ -269,7 +303,8 @@ class _SelectAddressWidgetState extends State<SelectAddressWidget> {
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
|
return Consumer<PaymentCheckoutData>(
|
|
|
|
|
builder: (ctx, paymentData, _) => Container(
|
|
|
|
|
builder: (ctx, paymentData, _) =>
|
|
|
|
|
Container(
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
child: address == null
|
|
|
|
|
? InkWell(
|
|
|
|
@ -289,7 +324,9 @@ class _SelectAddressWidgetState extends State<SelectAddressWidget> {
|
|
|
|
|
padding:
|
|
|
|
|
EdgeInsets.symmetric(vertical: 0, horizontal: 6),
|
|
|
|
|
child: Texts(
|
|
|
|
|
TranslationBase.of(context).selectAddress,
|
|
|
|
|
TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.selectAddress,
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
|
color: Color(0xff0000ff),
|
|
|
|
@ -324,7 +361,9 @@ class _SelectAddressWidgetState extends State<SelectAddressWidget> {
|
|
|
|
|
padding: EdgeInsets.symmetric(
|
|
|
|
|
vertical: 0, horizontal: 6),
|
|
|
|
|
child: Texts(
|
|
|
|
|
TranslationBase.of(context).shippingAddress,
|
|
|
|
|
TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.shippingAddress,
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
|
color: Colors.black,
|
|
|
|
@ -334,7 +373,9 @@ class _SelectAddressWidgetState extends State<SelectAddressWidget> {
|
|
|
|
|
InkWell(
|
|
|
|
|
onTap: () => {_navigateToAddressPage()},
|
|
|
|
|
child: Texts(
|
|
|
|
|
TranslationBase.of(context).changeAddress,
|
|
|
|
|
TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.changeAddress,
|
|
|
|
|
fontSize: 12,
|
|
|
|
|
fontWeight: FontWeight.normal,
|
|
|
|
|
color: Color(0xff0000ff),
|
|
|
|
@ -354,7 +395,9 @@ class _SelectAddressWidgetState extends State<SelectAddressWidget> {
|
|
|
|
|
Padding(
|
|
|
|
|
padding: const EdgeInsets.symmetric(vertical: 8),
|
|
|
|
|
child: Texts(
|
|
|
|
|
"${address.address1} ${address.address2} ${address.address2},, ${address.city}, ${address.country} ${address.zipPostalCode}",
|
|
|
|
|
"${address.address1} ${address.address2} ${address
|
|
|
|
|
.address2},, ${address.city}, ${address
|
|
|
|
|
.country} ${address.zipPostalCode}",
|
|
|
|
|
fontSize: 12,
|
|
|
|
|
fontWeight: FontWeight.normal,
|
|
|
|
|
color: Colors.grey.shade500,
|
|
|
|
@ -400,7 +443,9 @@ class _SelectAddressWidgetState extends State<SelectAddressWidget> {
|
|
|
|
|
padding: EdgeInsets.symmetric(
|
|
|
|
|
vertical: 0, horizontal: 6),
|
|
|
|
|
child: Texts(
|
|
|
|
|
"${TranslationBase.of(context).shipBy}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.shipBy}",
|
|
|
|
|
fontSize: 12,
|
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
|
color: Colors.black,
|
|
|
|
@ -443,7 +488,8 @@ class _SelectPaymentOptionWidgetState extends State<SelectPaymentOptionWidget> {
|
|
|
|
|
|
|
|
|
|
_navigateToPaymentOption() {
|
|
|
|
|
Navigator.push(context, FadePage(page: PaymentMethodSelectPage()))
|
|
|
|
|
.then((result) => {
|
|
|
|
|
.then((result) =>
|
|
|
|
|
{
|
|
|
|
|
setState(() {
|
|
|
|
|
if (result != null) {
|
|
|
|
|
paymentOption = result;
|
|
|
|
@ -485,7 +531,9 @@ class _SelectPaymentOptionWidgetState extends State<SelectPaymentOptionWidget> {
|
|
|
|
|
padding:
|
|
|
|
|
EdgeInsets.symmetric(vertical: 0, horizontal: 6),
|
|
|
|
|
child: Texts(
|
|
|
|
|
TranslationBase.of(context).selectPaymentOption,
|
|
|
|
|
TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.selectPaymentOption,
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
|
color: Color(0xff0000ff),
|
|
|
|
@ -539,7 +587,9 @@ class _SelectPaymentOptionWidgetState extends State<SelectPaymentOptionWidget> {
|
|
|
|
|
InkWell(
|
|
|
|
|
onTap: () => {_navigateToPaymentOption()},
|
|
|
|
|
child: Texts(
|
|
|
|
|
TranslationBase.of(context).changeMethod,
|
|
|
|
|
TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.changeMethod,
|
|
|
|
|
fontSize: 12,
|
|
|
|
|
fontWeight: FontWeight.normal,
|
|
|
|
|
color: Color(0xff0000ff),
|
|
|
|
@ -585,12 +635,15 @@ class _LakumWidgetState extends State<LakumWidget> {
|
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
|
children: [
|
|
|
|
|
Texts(
|
|
|
|
|
"${TranslationBase.of(context).lakumPoints}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.lakumPoints}",
|
|
|
|
|
fontSize: 12,
|
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
|
),
|
|
|
|
|
Texts(
|
|
|
|
|
"${widget.model.paymentCheckoutData.lacumInformation.lakumInquiryInformationObjVersion.pointsBalanceAmount}",
|
|
|
|
|
"${widget.model.paymentCheckoutData.lacumInformation
|
|
|
|
|
.lakumInquiryInformationObjVersion.pointsBalanceAmount}",
|
|
|
|
|
fontSize: 12,
|
|
|
|
|
fontWeight: FontWeight.normal,
|
|
|
|
|
),
|
|
|
|
@ -605,7 +658,9 @@ class _LakumWidgetState extends State<LakumWidget> {
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.end,
|
|
|
|
|
children: [
|
|
|
|
|
Texts(
|
|
|
|
|
"${TranslationBase.of(context).riyal}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.riyal}",
|
|
|
|
|
fontSize: 12,
|
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
|
),
|
|
|
|
@ -700,7 +755,9 @@ class _LakumWidgetState extends State<LakumWidget> {
|
|
|
|
|
)),
|
|
|
|
|
),
|
|
|
|
|
child: Texts(
|
|
|
|
|
"${TranslationBase.of(context).use}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.use}",
|
|
|
|
|
fontSize: 12,
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
@ -719,16 +776,21 @@ class _LakumWidgetState extends State<LakumWidget> {
|
|
|
|
|
class PaymentBottomWidget extends StatelessWidget {
|
|
|
|
|
final OrderPreviewViewModel model;
|
|
|
|
|
|
|
|
|
|
BuildContext context;
|
|
|
|
|
MyInAppBrowser browser;
|
|
|
|
|
|
|
|
|
|
PaymentBottomWidget(this.model);
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
|
final scaffold = Scaffold.of(context);
|
|
|
|
|
this.context = context;
|
|
|
|
|
|
|
|
|
|
return Container(
|
|
|
|
|
margin: EdgeInsets.symmetric(horizontal: 10, vertical: 0),
|
|
|
|
|
child: Consumer<PaymentCheckoutData>(
|
|
|
|
|
builder: (ctx, paymentData, _) => paymentData.cartDataVisible
|
|
|
|
|
builder: (ctx, paymentData, _) =>
|
|
|
|
|
paymentData.cartDataVisible
|
|
|
|
|
? Container(
|
|
|
|
|
child: Row(
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
|
|
@ -743,7 +805,10 @@ class PaymentBottomWidget extends StatelessWidget {
|
|
|
|
|
child: Row(
|
|
|
|
|
children: [
|
|
|
|
|
Texts(
|
|
|
|
|
"${TranslationBase.of(context).sar} ${(model.cartResponse.subtotal).toStringAsFixed(2)}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.sar} ${(model.cartResponse.subtotal)
|
|
|
|
|
.toStringAsFixed(2)}",
|
|
|
|
|
fontSize: 14,
|
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
|
color: Color(0xff929295),
|
|
|
|
@ -752,7 +817,9 @@ class PaymentBottomWidget extends StatelessWidget {
|
|
|
|
|
padding:
|
|
|
|
|
const EdgeInsets.symmetric(horizontal: 4),
|
|
|
|
|
child: Texts(
|
|
|
|
|
"${TranslationBase.of(context).inclusiveVat}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.inclusiveVat}",
|
|
|
|
|
fontSize: 8,
|
|
|
|
|
color: Color(0xff929295),
|
|
|
|
|
fontWeight: FontWeight.w600,
|
|
|
|
@ -762,7 +829,9 @@ class PaymentBottomWidget extends StatelessWidget {
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
Texts(
|
|
|
|
|
"${model.cartResponse.quantityCount} ${TranslationBase.of(context).items}",
|
|
|
|
|
"${model.cartResponse.quantityCount} ${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.items}",
|
|
|
|
|
fontSize: 10,
|
|
|
|
|
color: Colors.grey,
|
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
@ -782,8 +851,10 @@ class PaymentBottomWidget extends StatelessWidget {
|
|
|
|
|
paymentData.paymentOption != null)
|
|
|
|
|
? () async {
|
|
|
|
|
await model.makeOrder();
|
|
|
|
|
if (model.state != ViewState.Idle) {
|
|
|
|
|
AppToast.showSuccessToast(message: "Order has been placed successfully!!");
|
|
|
|
|
if (model.state == ViewState.Idle) {
|
|
|
|
|
AppToast.showSuccessToast(
|
|
|
|
|
message: "Order has been placed successfully!!");
|
|
|
|
|
openPayment(model.orderListModel[0], model.user);
|
|
|
|
|
} else {
|
|
|
|
|
AppToast.showErrorToast(message: model.error);
|
|
|
|
|
}
|
|
|
|
@ -794,7 +865,9 @@ class PaymentBottomWidget extends StatelessWidget {
|
|
|
|
|
child: Padding(
|
|
|
|
|
padding: const EdgeInsets.symmetric(vertical: 16),
|
|
|
|
|
child: new Text(
|
|
|
|
|
"${TranslationBase.of(context).proceedPay}",
|
|
|
|
|
"${TranslationBase
|
|
|
|
|
.of(context)
|
|
|
|
|
.proceedPay}",
|
|
|
|
|
style: new TextStyle(
|
|
|
|
|
color: (paymentData.address != null &&
|
|
|
|
|
paymentData.paymentOption != null)
|
|
|
|
@ -821,4 +894,58 @@ class PaymentBottomWidget extends StatelessWidget {
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
openPayment(OrderDetailModel order,
|
|
|
|
|
AuthenticatedUser authenticatedUser,) {
|
|
|
|
|
browser = new MyInAppBrowser(
|
|
|
|
|
onExitCallback: onBrowserExit, onLoadStartCallback: onBrowserLoadStart);
|
|
|
|
|
|
|
|
|
|
browser.openPharmacyPaymentBrowser(
|
|
|
|
|
order,
|
|
|
|
|
order.orderTotal,
|
|
|
|
|
'ePharmacy Order',
|
|
|
|
|
order.id,
|
|
|
|
|
order.billingAddress.email,
|
|
|
|
|
order.customValuesXml,
|
|
|
|
|
"${authenticatedUser.firstName} ${authenticatedUser
|
|
|
|
|
.middleName} ${authenticatedUser.lastName}",
|
|
|
|
|
authenticatedUser.patientID,
|
|
|
|
|
authenticatedUser,
|
|
|
|
|
browser);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
onBrowserLoadStart(String url) {
|
|
|
|
|
print("onBrowserLoadStart");
|
|
|
|
|
print(url);
|
|
|
|
|
|
|
|
|
|
MyInAppBrowser.successURLS.forEach((element) {
|
|
|
|
|
if (url.contains(element)) {
|
|
|
|
|
if (browser.isOpened()) browser.close();
|
|
|
|
|
MyInAppBrowser.isPaymentDone = true;
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
MyInAppBrowser.errorURLS.forEach((element) {
|
|
|
|
|
if (url.contains(element)) {
|
|
|
|
|
if (browser.isOpened()) browser.close();
|
|
|
|
|
MyInAppBrowser.isPaymentDone = false;
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
onBrowserExit(AppoitmentAllHistoryResultList appo, bool isPaymentMade) {
|
|
|
|
|
print("onBrowserExit Called!!!!");
|
|
|
|
|
if (isPaymentMade) {
|
|
|
|
|
AppToast.showSuccessToast(
|
|
|
|
|
message: "شكراً\nPayment status for your order is Paid");
|
|
|
|
|
Navigator.pop(context);
|
|
|
|
|
Navigator.pop(context);
|
|
|
|
|
} else {
|
|
|
|
|
AppToast.showErrorToast(
|
|
|
|
|
message:
|
|
|
|
|
"Transaction Failed!\Your transaction is field to some reason please try again or contact to the administration");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|