This commit is contained in:
Manasit.K
2025-01-07 16:21:43 +07:00
parent f16e5f491a
commit ec588a5c99
5 changed files with 193 additions and 167 deletions

View File

@@ -11,7 +11,6 @@ import 'package:flutter/services.dart';
import 'package:google_fonts/google_fonts.dart';
import 'package:mask_text_input_formatter/mask_text_input_formatter.dart';
import '../TransferMoney/TransferPromtptPayDialog.dart';
import '../api/api.dart';
import '../utils/color_custom.dart';
import 'PayQrDialogV2.dart';
@@ -487,15 +486,16 @@ class _TransferBankConfirmState extends State<TransferBankConfirm> {
context: context,
builder: (BuildContext context) {
return PayQrDialogV2(
price: widget.price,
price: value["slip"]["slipAmount"] ?? "",
bill: value["requestTransactionID"] ?? "",
phone: widget.phone,
name: value["slipTitleTH"]??"",
name_en: value["slipTitleEN"]??"",
bankName: value["bankName"]??"",
referenceNo:value["referenceNo"]??"",
slipDateTime: value["slipDateTime"]??"",
transactionId: "",
phone: value["slip"]["promptpayID"] ?? "",
name: value["slip"]["receiverNameTH"] ?? "",
name_en: value["slip"]["receiverNameEN"] ?? "",
bankName: value["slip"]["bankName"] ?? "",
referenceNo: value["slip"]["referenceNo"] ?? "",
slipDateTime: value["slip"]["slipDateTime"] ?? "",
transactionId: value["slip"]["lookref"] ?? "",
senderCom: value["slip"]["senderCompanyEN"] ?? "",
);
})
}

View File

@@ -1,5 +1,4 @@
import 'package:cathaypay_mobile/Home/HomePage.dart';
import 'package:cathaypay_mobile/utils/utils.dart';
import 'package:flutter/material.dart';
import 'package:google_fonts/google_fonts.dart';
@@ -7,7 +6,19 @@ import '../api/api.dart';
import '../model/profile_model.dart';
class PayQrDialogV2 extends StatefulWidget {
const PayQrDialogV2({Key? key, required this.name, required this.phone, required this.transactionId, required this.price, required this.name_en, required this.bankName, required this.referenceNo, required this.slipDateTime, required this.bill}) : super(key: key);
const PayQrDialogV2(
{Key? key,
required this.name,
required this.phone,
required this.transactionId,
required this.price,
required this.name_en,
required this.bankName,
required this.referenceNo,
required this.slipDateTime,
required this.bill,
required this.senderCom})
: super(key: key);
final String name;
final String name_en;
@@ -18,6 +29,8 @@ class PayQrDialogV2 extends StatefulWidget {
final String referenceNo;
final String slipDateTime;
final String bill;
final String senderCom;
// "slipTitleTH": "ตรวจสอบ การชำระเงิน",
// "slipTitleEN": "payment verification",
// "slipDateTime": "27 Dec 24 02:23",
@@ -54,25 +67,18 @@ class _PayQrDialogV2State extends State<PayQrDialogV2> {
@override
Widget build(BuildContext context) {
return Padding(
return Container(
padding: const EdgeInsets.only(left: 20, right: 20),
child: Column(mainAxisAlignment: MainAxisAlignment.center, crossAxisAlignment: CrossAxisAlignment.center, children: [
// Container(
// margin: EdgeInsets.only(bottom: 10),
// height: 80,
// width: 80,
// child: Image.asset(
// 'assets/images/LOGO.gif',
// height: 120,
// width: 120,
// )),
Card(
margin: const EdgeInsets.symmetric(vertical: 20),
child: Card(
color: Color(0xfffbfbfb),
child: Padding(
padding: const EdgeInsets.all(10.0),
child: Column(
children: [
Container(height: 180,width: 180,
Container(
height: 150,
width: 180,
child: Image(
image: AssetImage('images/neopay_logo.png'),
),
@@ -93,7 +99,6 @@ class _PayQrDialogV2State extends State<PayQrDialogV2> {
fontWeight: FontWeight.w300,
),
),
Text(
"จำนวนเงิน/Amount ฿" + widget.price,
style: TextStyle(
@@ -102,21 +107,25 @@ class _PayQrDialogV2State extends State<PayQrDialogV2> {
fontWeight: FontWeight.w300,
),
),
Container(height: 80,width: 180,
Container(
height: 80,
width: 180,
child: Image(
image: AssetImage('images/prompt.png'),
),
),
SizedBox(height: 15,),
SizedBox(
height: 15,
),
Container(
decoration: BoxDecoration(
image: DecorationImage(
image: AssetImage('images/neo_backgroup.png'),
fit: BoxFit.fill,
),
),
child:Column(children: [
child: Column(
children: [
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
@@ -184,7 +193,7 @@ class _PayQrDialogV2State extends State<PayQrDialogV2> {
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
"retrievalReferenceNumber",
"referenceNo",
style: TextStyle(
color: Color(0xff65676b),
fontSize: 14,
@@ -242,10 +251,7 @@ class _PayQrDialogV2State extends State<PayQrDialogV2> {
),
)
],
),SizedBox(
height: 35,
),
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
@@ -288,11 +294,37 @@ class _PayQrDialogV2State extends State<PayQrDialogV2> {
)
],
),
Row(
crossAxisAlignment: CrossAxisAlignment.end,
children: [
Text(
"senderCom.",
style: TextStyle(
color: Color(0xff65676b),
fontSize: 14,
fontWeight: FontWeight.w300,
),
),
Expanded(
child: Text(
widget.senderCom,
textAlign: TextAlign.end,
maxLines: 1,
overflow: TextOverflow.ellipsis,
style: TextStyle(
color: Color(0xff65676b),
fontSize: 14,
fontWeight: FontWeight.w600,
),
),
)
],
),
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
"เลขที่ทำรายการ",
"lookref",
style: TextStyle(
color: Color(0xff65676b),
fontSize: 14,
@@ -300,7 +332,7 @@ class _PayQrDialogV2State extends State<PayQrDialogV2> {
),
),
Text(
widget.bill,
widget.transactionId,
style: TextStyle(
color: Color(0xff65676b),
fontSize: 14,
@@ -309,19 +341,29 @@ class _PayQrDialogV2State extends State<PayQrDialogV2> {
)
],
),
],)
],
)),
SizedBox(
height: 10,
),
Text(
"Transfer / Payment from Bangkok Bank PromptPay",
style: TextStyle(
color: Color(0xff65676b),
fontSize: 12,
fontWeight: FontWeight.w300,
),
),
SizedBox(
height: 10,
),
SizedBox(height: 15,),
InkWell(
onTap: () async {
Navigator.popUntil(context, ModalRoute.withName('/HomePage'));
Navigator.pushReplacementNamed(context, "/HomePage");
},
child: Container(
margin: EdgeInsets.only(top: 20, bottom: 20),
margin: EdgeInsets.only(top: 20, bottom: 10),
width: MediaQuery.of(context).size.width,
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(40),
@@ -331,14 +373,6 @@ class _PayQrDialogV2State extends State<PayQrDialogV2> {
horizontal: 10,
vertical: 12,
),
child: Row(
mainAxisSize: MainAxisSize.min,
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
SizedBox(
width: 106,
height: 32,
child: Text(
"ปิด",
textAlign: TextAlign.center,
@@ -349,18 +383,11 @@ class _PayQrDialogV2State extends State<PayQrDialogV2> {
),
),
),
],
),
),
),
],
),
),
),
SizedBox(
height: 20,
),
]),
);
}
}

View File

@@ -1,8 +1,6 @@
import 'dart:convert';
import 'package:cathaypay_mobile/GetPaid/GetPaid.dart';
import 'package:cathaypay_mobile/Home/HomePage.dart';
import 'package:cathaypay_mobile/Pay/PayQrDialog.dart';
import 'package:cathaypay_mobile/PinCodeVadidate.dart';
import 'package:cathaypay_mobile/main.dart';
import 'package:cathaypay_mobile/utils/utils.dart';
@@ -11,8 +9,6 @@ import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:google_fonts/google_fonts.dart';
import 'package:intl/intl.dart';
import 'package:qr_code_scanner/qr_code_scanner.dart';
import '../api/api.dart';
import '../utils/color_custom.dart';
@@ -39,9 +35,11 @@ class _PayQrPageState extends State<PayThaiQr> {
initC2B() {
Utils.loadingProgress(context);
// var param = jsonEncode(<dynamic, dynamic>{"MobileDeviceNo": payPhone ?? "", "Note": "", "TransactionID": transactionID});
var param = jsonEncode(
<dynamic, dynamic>{"requestTransactionID": Utils.getDateInitPromptPay() + (profile?.phoneNumber?.lastChars(4)), "qrTextRequest": widget.code,
"amount": "${removeTextPrice()}00"});
var param = jsonEncode(<dynamic, dynamic>{
"requestTransactionID": Utils.getDateInitPromptPay() + (profile?.phoneNumber?.lastChars(4)),
"qrTextRequest": widget.code,
"amount": "${removeTextPrice()}00"
});
Api.post(context, Api.payThaiInitial, param).then((value) => {
if (value != null) {confirmPayQrC2BAmount(value["requestTransactionID"], value["responseTransactionID"])} else {}
@@ -60,15 +58,16 @@ class _PayQrPageState extends State<PayThaiQr> {
context: context,
builder: (BuildContext context) {
return PayQrDialogV2(
price: value["slipAmount"]??"",
price: value["slip"]["slipAmount"] ?? "",
bill: value["requestTransactionID"] ?? "",
phone: value["promptpayID"]??"",
name: value["slipTitleTH"]??"",
name_en: value["slipTitleEN"]??"",
bankName: value["bankName"]??"",
referenceNo:value["referenceNo"]??"",
slipDateTime: value["slipDateTime"]??"",
transactionId: "",
phone: value["slip"]["promptpayID"] ?? "",
name: value["slip"]["receiverNameTH"] ?? "",
name_en: value["slip"]["receiverNameEN"] ?? "",
bankName: value["slip"]["bankName"] ?? "",
referenceNo: value["slip"]["referenceNo"] ?? "",
slipDateTime: value["slip"]["slipDateTime"] ?? "",
transactionId: value["slip"]["lookref"] ?? "",
senderCom: value["slip"]["senderCompanyEN"] ?? "",
);
/* return PayQrDialog(
phone: "",

View File

@@ -62,10 +62,10 @@ class Api {
//static String getTransaction = BaseUrlBuilding + "api/v2/Payment/getTransaction";
static String getTransaction = BaseUrlBuilding + "api/v2/EPaymentReport/GetModelLogCriteria";
// static String BaseUrlBuildingCathay = "https://sathorn.cathay-pay.com/";
static String payPromptPayInitial = BaseUrlBuilding + "api/v2/EPaymentBBL/TransferedPromptPayIDInitial";
static String payPromptPayConfirm = BaseUrlBuilding + "api/v2/EPaymentBBL/TransferedPromptPayIDConfirm";
static String payThaiInitial = BaseUrlBuilding + "api/v2/EPaymentBBL/TransferedPromptPayQRInitial";
static String payThaiConfirm = BaseUrlBuilding + "api/v2/EPaymentBBL/TransferedPromptPayQRConfirm";
static String payPromptPayInitial = BaseUrlBuilding + "api/v4/EPaymentBBL/TransferedPromptPayIDInitial";
static String payPromptPayConfirm = BaseUrlBuilding + "api/v4/EPaymentBBL/TransferedPromptPayIDConfirm";
static String payThaiInitial = BaseUrlBuilding + "api/v4/EPaymentBBL/TransferedPromptPayQRInitial";
static String payThaiConfirm = BaseUrlBuilding + "api/v4/EPaymentBBL/TransferedPromptPayQRConfirm";
static String user = BaseUrlBuilding + "api/v1/User";

View File

@@ -16,7 +16,7 @@ publish_to: 'none' # Remove this line if you wish to publish to pub.dev
# https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html
# In Windows, build-name is used as the major, minor, and patch parts
# of the product and file versions while build-number is used as the build suffix.
version: 1.0.2+9
version: 1.0.3+10
environment:
sdk: '>=2.19.3 <3.0.0'