Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
B
book-app
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
EzijingWeb
book-app
Commits
b998c664
提交
b998c664
authored
2月 23, 2024
作者:
yueweilu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
二次支付
上级
ed1ad4ac
隐藏空白字符变更
内嵌
并排
正在显示
7 个修改的文件
包含
199 行增加
和
38 行删除
+199
-38
controller.dart
lib/pages/user_coin_recharge/controller.dart
+1
-1
controller.dart
lib/pages/user_order_awaiting/controller.dart
+3
-1
index.dart
lib/pages/user_order_awaiting/index.dart
+2
-0
controller.dart
lib/pages/user_order_coin_awaiting/controller.dart
+162
-12
index.dart
lib/pages/user_order_coin_awaiting/index.dart
+7
-0
view.dart
lib/pages/user_order_coin_awaiting/view.dart
+22
-22
validator.dart
lib/utils/validator.dart
+2
-2
没有找到文件。
lib/pages/user_coin_recharge/controller.dart
浏览文件 @
b998c664
...
@@ -162,7 +162,7 @@ class CoinRechargeController extends GetxController {
...
@@ -162,7 +162,7 @@ class CoinRechargeController extends GetxController {
}
}
final
result
=
await
MineAPI
.
createRechargeOrder
(
identifying:
rechargeModel
.
identifying
??
''
,
type:
type
);
final
result
=
await
MineAPI
.
createRechargeOrder
(
identifying:
rechargeModel
.
identifying
??
''
,
type:
type
);
print
(
'-----------------------------------
${result.ordersnum}
--------------------------------
${result.msg}
'
);
Console
.
log
(
'-----------------------------------
${result.ordersnum}
--------------------------------
${result.msg}
'
);
payOrderModel
=
result
;
payOrderModel
=
result
;
// 创建订单成功开启支付流程
// 创建订单成功开启支付流程
if
(
payOrderModel
.
ordersnum
!=
null
){
if
(
payOrderModel
.
ordersnum
!=
null
){
...
...
lib/pages/user_order_awaiting/controller.dart
浏览文件 @
b998c664
...
@@ -136,7 +136,9 @@ class UserOrderAwaitingController extends GetxController {
...
@@ -136,7 +136,9 @@ class UserOrderAwaitingController extends GetxController {
final
result
=
await
ShopAPI
.
orderStatus
(
orderNumber:
payOrderModel
.
ordersnum
??
''
,
receipt:
''
);
final
result
=
await
ShopAPI
.
orderStatus
(
orderNumber:
payOrderModel
.
ordersnum
??
''
,
receipt:
''
);
if
(
result
.
paySuccess
==
1
){
if
(
result
.
paySuccess
==
1
){
Toast
.
show
(
'订单支付完成'
);
Toast
.
show
(
'订单支付完成'
);
context
.
pop
();
if
(
context
.
mounted
){
context
.
pop
(
true
);
}
}
}
}
}
...
...
lib/pages/user_order_awaiting/index.dart
浏览文件 @
b998c664
...
@@ -18,6 +18,7 @@ import 'package:tobias/tobias.dart';
...
@@ -18,6 +18,7 @@ import 'package:tobias/tobias.dart';
import
'../../apis/index.dart'
;
import
'../../apis/index.dart'
;
import
'../../models/index.dart'
;
import
'../../models/index.dart'
;
import
'../../routes/index.dart'
;
import
'../../routes/index.dart'
;
import
'../user_order/index.dart'
;
part
'view.dart'
;
part
'view.dart'
;
part
'controller.dart'
;
part
'controller.dart'
;
\ No newline at end of file
lib/pages/user_order_coin_awaiting/controller.dart
浏览文件 @
b998c664
...
@@ -3,9 +3,9 @@ part of user_order_coin_awaiting;
...
@@ -3,9 +3,9 @@ part of user_order_coin_awaiting;
/// 紫荆币等待付款订单
/// 紫荆币等待付款订单
class
UserOrderCoinAwaitingController
extends
GetxController
{
class
UserOrderCoinAwaitingController
extends
GetxController
{
late
String
_orderNum
;
late
String
_orderNum
;
final
BuildContext
context
;
String
get
orderNum
=>
_orderNum
;
// 获取订单编号的方法
String
get
orderNum
=>
_orderNum
;
// 获取订单编号的方法
UserOrderCoinAwaitingController
();
UserOrderCoinAwaitingController
(
this
.
context
);
// 更新订单编号的方法
// 更新订单编号的方法
void
updateOrderNum
(
String
newOrderNum
)
{
void
updateOrderNum
(
String
newOrderNum
)
{
_orderNum
=
newOrderNum
;
_orderNum
=
newOrderNum
;
...
@@ -22,12 +22,77 @@ class UserOrderCoinAwaitingController extends GetxController {
...
@@ -22,12 +22,77 @@ class UserOrderCoinAwaitingController extends GetxController {
late
PayOrderModel
payOrderModel
;
late
PayOrderModel
payOrderModel
;
dynamic
_purchaseUpdatedSubscription
;
dynamic
_purchaseErrorSubscription
;
dynamic
_connectionSubscription
;
PurchasedItem
?
_resultItem
;
List
<
IAPItem
>
_items
=
[];
List
<
PurchasedItem
>
_purchases
=
[];
///未完成的订单
List
<
PurchasedItem
>
_pendingPurchases
=
[];
List
<
CoinModel
>
data
=
[];
@override
void
onInit
()
{
if
(
Platform
.
isIOS
){
_getProduct
();
initPlatformState
();
_getPendingPurchase
();
}
super
.
onInit
();
}
@override
@override
void
onReady
()
{
void
onReady
()
{
getOrderInfo
();
getOrderInfo
();
super
.
onReady
();
super
.
onReady
();
}
}
@override
void
onClose
()
{
if
(
_connectionSubscription
!=
null
)
{
_connectionSubscription
.
cancel
();
_connectionSubscription
=
null
;
}
if
(
_purchaseUpdatedSubscription
!=
null
)
{
_purchaseUpdatedSubscription
.
cancel
();
_purchaseUpdatedSubscription
=
null
;
}
if
(
_purchaseErrorSubscription
!=
null
)
{
_purchaseErrorSubscription
.
cancel
();
_purchaseErrorSubscription
=
null
;
}
super
.
onClose
();
}
Future
<
void
>
initPlatformState
()
async
{
var
result
=
await
FlutterInappPurchase
.
instance
.
initialize
();
print
(
'--------------initPlatformState-------------------------
$result
'
);
_connectionSubscription
=
FlutterInappPurchase
.
connectionUpdated
.
listen
((
connected
)
{
print
(
'connected:
$connected
'
);
});
_purchaseUpdatedSubscription
=
FlutterInappPurchase
.
purchaseUpdated
.
listen
((
productItem
)
{
CustomToast
.
dismiss
();
if
(
productItem
!=
null
){
_resultItem
=
productItem
;
requestOrderStatus
();
}
});
_purchaseErrorSubscription
=
FlutterInappPurchase
.
purchaseError
.
listen
((
purchaseError
)
{
CustomToast
.
dismiss
();
Toast
.
show
(
purchaseError
!.
message
.
toString
());
});
}
/// 取消订单
/// 取消订单
void
cancelPay
()
async
{
void
cancelPay
()
async
{
final
result
=
await
MineAPI
.
cancelPay
(
ordersnum:
orderNum
);
final
result
=
await
MineAPI
.
cancelPay
(
ordersnum:
orderNum
);
...
@@ -39,6 +104,8 @@ class UserOrderCoinAwaitingController extends GetxController {
...
@@ -39,6 +104,8 @@ class UserOrderCoinAwaitingController extends GetxController {
/// 获取订单信息
/// 获取订单信息
Future
<
void
>
getOrderInfo
()
async
{
Future
<
void
>
getOrderInfo
()
async
{
data
.
clear
();
model
=
await
MineAPI
.
getOrderInfo
(
orderNum:
orderNum
);
model
=
await
MineAPI
.
getOrderInfo
(
orderNum:
orderNum
);
String
payWay
=
''
;
String
payWay
=
''
;
if
(
model
.
payType
==
1
){
if
(
model
.
payType
==
1
){
...
@@ -54,16 +121,41 @@ class UserOrderCoinAwaitingController extends GetxController {
...
@@ -54,16 +121,41 @@ class UserOrderCoinAwaitingController extends GetxController {
OrderCompletedModel
(
name:
'支付时间'
,
value:
model
.
payTime
.
toString
()),
OrderCompletedModel
(
name:
'支付时间'
,
value:
model
.
payTime
.
toString
()),
];
];
data
.
add
(
CoinModel
(
identifying:
model
.
goodsId
));
update
();
update
();
}
}
/// 获取商品列表
Future
_getProduct
()
async
{
List
<
String
>
productList
=
data
.
where
((
coinModel
)
=>
coinModel
.
identifying
!=
null
)
.
map
((
coinModel
)
=>
coinModel
.
identifying
!)
.
toList
();
print
(
'-------------productList-------------------
$productList
'
);
List
<
IAPItem
>
items
=
await
FlutterInappPurchase
.
instance
.
getProducts
(
productList
);
for
(
var
item
in
items
)
{
_items
.
add
(
item
);
}
print
(
'-------------_items-------------------
$items
'
);
_items
=
items
;
_purchases
=
[];
// update();
}
Future
<
void
>
payOrder
()
async
{
Future
<
void
>
payOrder
()
async
{
if
(
model
.
payType
==
3
){
// 苹果支付
final
result
=
await
MineAPI
.
coinPay
(
ordersNum:
orderNum
);
if
(
model
.
payType
==
3
){
if
(
result
){
// 发起苹果支付
Toast
.
show
(
'订单支付完成'
);
IAPItem
targetItem
=
_items
.
firstWhere
(
getOrderInfo
();
(
item
)
=>
item
.
productId
==
model
.
goodsId
,
}
);
_requestPurchase
(
targetItem
);
}
}
else
{
else
{
payOrderModel
=
await
MineAPI
.
getPayInfo
(
ordersNum:
orderNum
);
payOrderModel
=
await
MineAPI
.
getPayInfo
(
ordersNum:
orderNum
);
...
@@ -78,7 +170,7 @@ class UserOrderCoinAwaitingController extends GetxController {
...
@@ -78,7 +170,7 @@ class UserOrderCoinAwaitingController extends GetxController {
}
}
}
}
// 微信
// 微信
if
(
model
.
payType
==
1
){
else
if
(
model
.
payType
==
1
){
final
result
=
await
fluwx
.
isWeChatInstalled
;
final
result
=
await
fluwx
.
isWeChatInstalled
;
if
(!
result
){
if
(!
result
){
Toast
.
show
(
'请先安装微信'
);
Toast
.
show
(
'请先安装微信'
);
...
@@ -88,11 +180,20 @@ class UserOrderCoinAwaitingController extends GetxController {
...
@@ -88,11 +180,20 @@ class UserOrderCoinAwaitingController extends GetxController {
}
}
}
}
}
}
}
// 苹果支付
void
_requestPurchase
(
IAPItem
item
)
{
CustomToast
.
loading
();
FlutterInappPurchase
.
instance
.
requestPurchase
(
item
.
productId
!);
}
}
// 支付宝支付
// 支付宝支付
void
requestAliPay
(){
void
requestAliPay
(){
print
(
'================================================================
${payOrderModel.encryptionOrder!}
'
);
Console
.
log
(
'================================================================
${payOrderModel.encryptionOrder!}
'
);
tobias
.
pay
(
payOrderModel
.
encryptionOrder
!).
then
((
payResult
){
tobias
.
pay
(
payOrderModel
.
encryptionOrder
!).
then
((
payResult
){
if
(
payResult
[
'resultStatus'
]
==
'9000'
)
{
if
(
payResult
[
'resultStatus'
]
==
'9000'
)
{
requestOrderStatus
();
requestOrderStatus
();
...
@@ -125,14 +226,63 @@ class UserOrderCoinAwaitingController extends GetxController {
...
@@ -125,14 +226,63 @@ class UserOrderCoinAwaitingController extends GetxController {
}
}
void
requestOrderStatus
()
async
{
void
requestOrderStatus
()
async
{
final
result
=
await
ShopAPI
.
orderStatus
(
orderNumber:
payOrderModel
.
ordersnum
??
''
,
receipt:
''
);
final
result
=
await
ShopAPI
.
orderStatus
(
orderNumber:
model
.
ordersnum
??
''
,
receipt:
_resultItem
!=
null
?
_resultItem
!.
transactionReceipt
.
toString
():
''
);
if
(
result
.
paySuccess
==
1
){
if
(
result
.
paySuccess
==
1
){
Toast
.
show
(
'订单支付完成'
);
Toast
.
show
(
'订单支付完成'
);
getOrderInfo
();
if
(
context
.
mounted
){
context
.
pop
(
true
);
}
if
(
model
.
payType
==
3
){
// 清除
if
(
StorageService
.
to
.
getObject
(
kFailOrder
)
!=
null
){
List
<
Map
<
String
,
String
>>
failOrderList
=
StorageService
.
to
.
getObject
(
kFailOrder
)
as
List
<
Map
<
String
,
String
>>;
List
<
Map
<
String
,
String
>>
temp
=
[];
temp
.
addAll
(
failOrderList
);
for
(
var
element
in
failOrderList
)
{
if
(
element
[
'orderNum'
]
==
result
.
ordersnum
){
temp
.
remove
(
element
);
}
}
StorageService
.
to
.
setObject
(
kFailOrder
,
temp
);
}
FlutterInappPurchase
.
instance
.
finishTransactionIOS
(
_resultItem
!.
transactionId
!);
}
}
else
{
Toast
.
show
(
'支付失败'
);
if
(
model
.
payType
==
3
){
// 保存未支付的订单
Map
<
String
,
String
>
failOrder
=
{
'orderNum'
:
payOrderModel
.
ordersnum
??
''
,
'transactionReceipt'
:
_resultItem
!.
transactionReceipt
.
toString
(),
'transactionId'
:
_resultItem
!.
transactionId
.
toString
()
};
List
<
Map
>
failOrderList
=
[];
failOrderList
.
add
(
failOrder
);
StorageService
.
to
.
setObject
(
kFailOrder
,
failOrderList
);
}
}
}
}
}
///获取未完成的购买
Future
_getPendingPurchase
()
async
{
List
<
PurchasedItem
>?
items
=
await
FlutterInappPurchase
.
instance
.
getPurchaseHistory
();
for
(
var
item
in
items
!)
{
_pendingPurchases
.
add
(
item
);
}
if
(
StorageService
.
to
.
getObject
(
kFailOrder
)
!=
null
){
List
<
Map
<
String
,
String
>>
failOrderList
=
StorageService
.
to
.
getObject
(
kFailOrder
)
as
List
<
Map
<
String
,
String
>>;
for
(
var
item
in
_pendingPurchases
)
{
for
(
var
element
in
failOrderList
)
{
if
(
element
[
'transactionId'
]
==
item
.
transactionId
){
requestOrderStatus
();
}
}
}
}
}
...
...
lib/pages/user_order_coin_awaiting/index.dart
浏览文件 @
b998c664
library
user_order_coin_awaiting
;
library
user_order_coin_awaiting
;
import
'dart:io'
;
import
'package:flutter/material.dart'
;
import
'package:flutter/material.dart'
;
import
'package:flutter_book/theme.dart'
;
import
'package:flutter_book/theme.dart'
;
import
'package:flutter_book/utils/index.dart'
;
import
'package:flutter_book/utils/index.dart'
;
import
'package:flutter_book/widgets/index.dart'
;
import
'package:flutter_book/widgets/index.dart'
;
import
'package:flutter_inapp_purchase/flutter_inapp_purchase.dart'
;
import
'package:flutter_inapp_purchase/modules.dart'
;
import
'package:fluwx/fluwx.dart'
;
import
'package:fluwx/fluwx.dart'
;
import
'package:get/get.dart'
;
import
'package:get/get.dart'
;
import
'package:get/get_state_manager/src/simple/get_controllers.dart'
;
import
'package:get/get_state_manager/src/simple/get_controllers.dart'
;
...
@@ -14,6 +18,8 @@ import 'package:tobias/tobias.dart';
...
@@ -14,6 +18,8 @@ import 'package:tobias/tobias.dart';
import
'../../apis/index.dart'
;
import
'../../apis/index.dart'
;
import
'../../models/index.dart'
;
import
'../../models/index.dart'
;
import
'../../services/index.dart'
;
import
'../user_order/index.dart'
;
part
'view.dart'
;
part
'view.dart'
;
part
'controller.dart'
;
part
'controller.dart'
;
\ No newline at end of file
lib/pages/user_order_coin_awaiting/view.dart
浏览文件 @
b998c664
...
@@ -16,7 +16,7 @@ class _UserOrderCoinAwaitingState extends State<UserOrderCoinAwaitingPage> {
...
@@ -16,7 +16,7 @@ class _UserOrderCoinAwaitingState extends State<UserOrderCoinAwaitingPage> {
@override
@override
void
initState
()
{
void
initState
()
{
myController
=
Get
.
put
(
UserOrderCoinAwaitingController
());
myController
=
Get
.
put
(
UserOrderCoinAwaitingController
(
context
));
myController
.
updateOrderNum
(
widget
.
orderNum
);
myController
.
updateOrderNum
(
widget
.
orderNum
);
super
.
initState
();
super
.
initState
();
}
}
...
@@ -176,27 +176,27 @@ class _UserOrderCoinAwaitingState extends State<UserOrderCoinAwaitingPage> {
...
@@ -176,27 +176,27 @@ class _UserOrderCoinAwaitingState extends State<UserOrderCoinAwaitingPage> {
SizedBox
(
SizedBox
(
height:
11.5
.
w
,
height:
11.5
.
w
,
),
),
Containe
r
(
GestureDetecto
r
(
margin:
EdgeInsets
.
symmetric
(
horizontal:
15
.
w
),
onTap:
(){
height:
40
.
w
,
myController
.
payOrder
();
decoration:
BoxDecoration
(
},
color:
AppTheme
.
primary
,
child:
Container
(
borderRadius:
BorderRadius
.
circular
(
180
.
w
),
margin:
EdgeInsets
.
symmetric
(
horizontal:
15
.
w
),
border:
Border
.
all
(
height:
40
.
w
,
color:
Colours
.
cC31F4C
,
width:
0.5
.
w
)),
decoration:
BoxDecoration
(
child:
Center
(
color:
AppTheme
.
primary
,
child:
GestureDetector
(
borderRadius:
BorderRadius
.
circular
(
180
.
w
),
onTap:
()
{
border:
Border
.
all
(
// print("保存昵称");
color:
Colours
.
cC31F4C
,
width:
0.5
.
w
)),
// context.pushNamed(Routes.orderEvaluate);
child:
Center
(
},
child:
Text
(
child:
Text
(
'立即支付 ¥
${myController.model.finalTotalPrice}
'
,
'立即支付 ¥
${myController.model.finalTotalPrice}
'
,
style:
TextStyle
(
style:
TextStyle
(
fontWeight:
Fonts
.
medium
,
fontWeight:
Fonts
.
medium
,
fontSize:
14
.
w
,
fontSize:
14
.
w
,
color:
Colours
.
cFF
)
,
color:
Colours
.
cFF
),
),
)
),
),
),
),
),
),
SizedBox
(
SizedBox
(
...
...
lib/utils/validator.dart
浏览文件 @
b998c664
...
@@ -91,9 +91,9 @@ class ValidatorTool {
...
@@ -91,9 +91,9 @@ class ValidatorTool {
// 密码
// 密码
static
bool
isValidPassword
(
String
value
)
{
static
bool
isValidPassword
(
String
value
)
{
//
RegExp passwordPattern = RegExp(r'^[A-Za-z0-9!@#\$%^&*()_+{}\[\]:;<>,.?~\\/-]{8,12}$');
RegExp
passwordPattern
=
RegExp
(
r'^[A-Za-z0-9!@#\$%^&*()_+{}\[\]:;<>,.?~\\/-]{8,12}$'
);
// RegExp passwordPattern = RegExp(r'^(?=.*[A-Za-z])(?=.*\d)(?=.*[~@#%$*()_+{}\[\]:;<>,.?\\/-])[A-Za-z0-9~@#%$*()_+{}\[\]:;<>,.?\\/-]{8,12}$');
// RegExp passwordPattern = RegExp(r'^(?=.*[A-Za-z])(?=.*\d)(?=.*[~@#%$*()_+{}\[\]:;<>,.?\\/-])[A-Za-z0-9~@#%$*()_+{}\[\]:;<>,.?\\/-]{8,12}$');
RegExp
passwordPattern
=
RegExp
(
r'^\d{6}$'
);
//
RegExp passwordPattern = RegExp(r'^\d{6}$');
return
passwordPattern
.
hasMatch
(
value
);
return
passwordPattern
.
hasMatch
(
value
);
}
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论