Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
B
book-app
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
EzijingWeb
book-app
Commits
e9bf922f
提交
e9bf922f
authored
2月 21, 2024
作者:
maodou
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
1:过期优惠券相关显示
2:紫荆币待支付界面
上级
d25f0f4d
全部展开
显示空白字符变更
内嵌
并排
正在显示
16 个修改的文件
包含
203 行增加
和
5 行删除
+203
-5
coupon_bg_expired.png
assets/images/2.0x/coupon_bg_expired.png
+0
-0
coupon_expired.png
assets/images/2.0x/coupon_expired.png
+0
-0
coupon_bg_expired.png
assets/images/3.0x/coupon_bg_expired.png
+0
-0
coupon_expired.png
assets/images/3.0x/coupon_expired.png
+0
-0
coupon_bg_expired.png
assets/images/coupon_bg_expired.png
+0
-0
coupon_expired.png
assets/images/coupon_expired.png
+0
-0
order.dart
lib/models/order.dart
+12
-0
controller.dart
lib/pages/user_coupon/controller.dart
+5
-1
item.dart
lib/pages/user_coupon/widgets/item.dart
+0
-0
coin.dart
lib/pages/user_order/widgets/coin.dart
+9
-1
controller.dart
lib/pages/user_order_coin_awaiting/controller.dart
+139
-0
index.dart
lib/pages/user_order_coin_awaiting/index.dart
+20
-0
view.dart
lib/pages/user_order_coin_awaiting/view.dart
+0
-0
view.dart
lib/pages/user_order_evaluate/view.dart
+4
-1
index.dart
lib/routes/index.dart
+1
-0
routes.dart
lib/routes/routes.dart
+13
-2
没有找到文件。
assets/images/2.0x/coupon_bg_expired.png
0 → 100644
浏览文件 @
e9bf922f
7.4 KB
assets/images/2.0x/coupon_expired.png
0 → 100644
浏览文件 @
e9bf922f
4.0 KB
assets/images/3.0x/coupon_bg_expired.png
0 → 100644
浏览文件 @
e9bf922f
14.8 KB
assets/images/3.0x/coupon_expired.png
0 → 100644
浏览文件 @
e9bf922f
8.0 KB
assets/images/coupon_bg_expired.png
0 → 100644
浏览文件 @
e9bf922f
2.6 KB
assets/images/coupon_expired.png
0 → 100644
浏览文件 @
e9bf922f
1.9 KB
lib/models/order.dart
浏览文件 @
e9bf922f
...
...
@@ -264,6 +264,8 @@ class OrderInfoModel {
OrderInfoModel
({
this
.
id
,
this
.
ordersnum
,
this
.
goodsId
,
this
.
goodsName
,
this
.
totalPrice
,
this
.
finalTotalPrice
,
this
.
nums
,
...
...
@@ -282,6 +284,8 @@ class OrderInfoModel {
OrderInfoModel
.
fromJson
(
dynamic
json
)
{
id
=
json
[
'id'
];
ordersnum
=
json
[
'ordersnum'
];
goodsId
=
json
[
'goods_id'
];
goodsName
=
json
[
'goods_name'
];
totalPrice
=
json
[
'total_price'
];
finalTotalPrice
=
json
[
'final_total_price'
];
nums
=
json
[
'num'
];
...
...
@@ -304,6 +308,8 @@ class OrderInfoModel {
}
num
?
id
;
String
?
ordersnum
;
String
?
goodsId
;
//充值的凭证
String
?
goodsName
;
//充值名称
String
?
totalPrice
;
String
?
finalTotalPrice
;
num
?
nums
;
...
...
@@ -320,6 +326,8 @@ class OrderInfoModel {
List
<
BookListModel
>?
bookList
;
OrderInfoModel
copyWith
({
num
?
id
,
String
?
ordersnum
,
String
?
goodsId
,
String
?
goodsName
,
String
?
totalPrice
,
String
?
finalTotalPrice
,
num
?
nums
,
...
...
@@ -336,6 +344,8 @@ class OrderInfoModel {
List
<
BookListModel
>?
bookList
,
})
=>
OrderInfoModel
(
id:
id
??
this
.
id
,
ordersnum:
ordersnum
??
this
.
ordersnum
,
goodsId:
ordersnum
??
this
.
goodsId
,
goodsName:
ordersnum
??
this
.
goodsName
,
totalPrice:
totalPrice
??
this
.
totalPrice
,
finalTotalPrice:
finalTotalPrice
??
this
.
finalTotalPrice
,
nums:
nums
??
this
.
nums
,
...
...
@@ -355,6 +365,8 @@ class OrderInfoModel {
final
map
=
<
String
,
dynamic
>{};
map
[
'id'
]
=
id
;
map
[
'ordersnum'
]
=
ordersnum
;
map
[
'goods_id'
]
=
goodsId
;
map
[
'goods_name'
]
=
goodsName
;
map
[
'total_price'
]
=
totalPrice
;
map
[
'final_total_price'
]
=
finalTotalPrice
;
map
[
'num'
]
=
nums
;
...
...
lib/pages/user_coupon/controller.dart
浏览文件 @
e9bf922f
...
...
@@ -42,7 +42,11 @@ class UserCouponController extends GetxController {
);
// 如果是刷新 清理数据
if
(
isRefresh
)
coupons
.
clear
();
coupons
.
addAll
(
result
);
for
(
CouponModel
model
in
result
){
model
.
type
=
type
;
coupons
.
add
(
model
);
}
// coupons.addAll(result);
_page
++;
_noMore
=
result
.
length
<
_limit
;
update
();
...
...
lib/pages/user_coupon/widgets/item.dart
浏览文件 @
e9bf922f
差异被折叠。
点击展开。
lib/pages/user_order/widgets/coin.dart
浏览文件 @
e9bf922f
...
...
@@ -15,7 +15,14 @@ class BuiltCoin extends StatelessWidget {
}
else
if
(
model
.
status
==
3
){
status
=
'已完成'
;
}
return
Container
(
return
GestureDetector
(
onTap:
()
{
if
(
model
.
status
==
1
){
context
.
pushNamed
(
Routes
.
orderCoinAwaiting
,
queryParameters:
{
'orderNum'
:
model
.
ordersnum
});
}
},
child:
Container
(
margin:
EdgeInsets
.
only
(
left:
10
.
w
,
right:
10
.
w
,
top:
10
.
w
),
padding:
EdgeInsets
.
only
(
left:
11.5
.
w
),
decoration:
BoxDecoration
(
...
...
@@ -93,6 +100,7 @@ class BuiltCoin extends StatelessWidget {
)),
],
),
),
);
}
}
lib/pages/user_order_coin_awaiting/controller.dart
0 → 100644
浏览文件 @
e9bf922f
part of
user_order_coin_awaiting
;
/// 紫荆币等待付款订单
class
UserOrderCoinAwaitingController
extends
GetxController
{
final
String
orderNum
;
UserOrderCoinAwaitingController
(
this
.
orderNum
);
// 订单编号
late
OrderInfoModel
model
;
// 应付款、订单编号等
List
<
OrderCompletedModel
>
orderAwaitings
=
[];
// 支付宝
Tobias
tobias
=
Tobias
();
// 微信
Fluwx
fluwx
=
Fluwx
();
late
PayOrderModel
payOrderModel
;
@override
void
onReady
()
{
getOrderInfo
();
super
.
onReady
();
}
/// 取消订单
void
cancelPay
()
async
{
final
result
=
await
MineAPI
.
cancelPay
(
ordersnum:
orderNum
);
if
(
result
)
{
Toast
.
show
(
'取消成功'
);
update
();
}
}
/// 获取订单信息
Future
<
void
>
getOrderInfo
()
async
{
model
=
await
MineAPI
.
getOrderInfo
(
orderNum:
orderNum
);
String
payWay
=
''
;
if
(
model
.
payType
==
1
){
payWay
=
'微信'
;
}
else
if
(
model
.
payType
==
2
){
payWay
=
'支付宝'
;
}
else
if
(
model
.
payType
==
3
){
payWay
=
'紫荆币'
;
}
orderAwaitings
=
[
OrderCompletedModel
(
name:
'订单编号'
,
value:
model
.
ordersnum
.
toString
()),
OrderCompletedModel
(
name:
'支付方式'
,
value:
payWay
),
OrderCompletedModel
(
name:
'支付时间'
,
value:
model
.
payTime
.
toString
()),
];
update
();
}
Future
<
void
>
payOrder
()
async
{
if
(
model
.
payType
==
3
){
final
result
=
await
MineAPI
.
coinPay
(
ordersNum:
orderNum
);
if
(
result
){
Toast
.
show
(
'订单支付完成'
);
getOrderInfo
();
}
}
else
{
payOrderModel
=
await
MineAPI
.
getPayInfo
(
ordersNum:
orderNum
);
// 支付宝
if
(
model
.
payType
==
2
){
final
result
=
await
tobias
.
isAliPayInstalled
;
if
(!
result
){
Toast
.
show
(
'请先安装支付宝'
);
}
else
{
requestAliPay
();
}
}
// 微信
if
(
model
.
payType
==
1
){
final
result
=
await
fluwx
.
isWeChatInstalled
;
if
(!
result
){
Toast
.
show
(
'请先安装微信'
);
}
else
{
requestWechat
();
}
}
}
}
// 支付宝支付
void
requestAliPay
(){
print
(
'================================================================
${payOrderModel.encryptionOrder!}
'
);
tobias
.
pay
(
payOrderModel
.
encryptionOrder
!).
then
((
payResult
){
if
(
payResult
[
'resultStatus'
]
==
'9000'
)
{
requestOrderStatus
();
}
else
{
Toast
.
show
(
payResult
[
'memo'
].
toString
());
}
});
}
// 微信支付
void
requestWechat
(){
Payment
payment
=
Payment
(
appId:
payOrderModel
.
appid
??
''
,
partnerId:
payOrderModel
.
partnerid
??
''
,
prepayId:
payOrderModel
.
prepayid
??
''
,
packageValue:
payOrderModel
.
package
??
''
,
nonceStr:
payOrderModel
.
noncestr
??
''
,
timestamp:
payOrderModel
.
timestamp
!.
toInt
(),
sign:
payOrderModel
.
sign
??
''
);
fluwx
.
pay
(
which:
payment
);
fluwx
.
addSubscriber
((
response
)
{
if
(
response
.
errCode
==
0
)
{
requestOrderStatus
();
}
else
{
Toast
.
show
(
'
${response.errStr}
'
);
}
});
}
void
requestOrderStatus
()
async
{
final
result
=
await
ShopAPI
.
orderStatus
(
orderNumber:
payOrderModel
.
ordersnum
??
''
,
receipt:
''
);
if
(
result
.
paySuccess
==
1
){
Toast
.
show
(
'订单支付完成'
);
getOrderInfo
();
}
}
}
lib/pages/user_order_coin_awaiting/index.dart
0 → 100644
浏览文件 @
e9bf922f
library
user_order_coin_awaiting
;
import
'package:flutter/material.dart'
;
import
'package:flutter_book/theme.dart'
;
import
'package:flutter_book/utils/index.dart'
;
import
'package:flutter_book/widgets/index.dart'
;
import
'package:fluwx/fluwx.dart'
;
import
'package:get/get.dart'
;
import
'package:get/get_state_manager/src/simple/get_controllers.dart'
;
import
'package:flutter_screenutil/flutter_screenutil.dart'
;
import
'package:get/get_state_manager/src/simple/get_state.dart'
;
import
'package:go_router/go_router.dart'
;
import
'package:tobias/tobias.dart'
;
import
'../../apis/index.dart'
;
import
'../../models/index.dart'
;
part
'view.dart'
;
part
'controller.dart'
;
\ No newline at end of file
lib/pages/user_order_coin_awaiting/view.dart
0 → 100644
浏览文件 @
e9bf922f
差异被折叠。
点击展开。
lib/pages/user_order_evaluate/view.dart
浏览文件 @
e9bf922f
...
...
@@ -15,7 +15,7 @@ class UserOrderEvaluatePage extends StatefulWidget {
State
<
UserOrderEvaluatePage
>
createState
()
=>
_UserOrderEvaluatePageState
();
}
class
_UserOrderEvaluatePageState
extends
State
<
UserOrderEvaluatePage
>
{
class
_UserOrderEvaluatePageState
extends
State
<
UserOrderEvaluatePage
>
with
AutomaticKeepAliveClientMixin
{
late
UserOrderEvaluateController
myController
;
List
<
TextEditingController
>
controllers
=
[];
List
<
OrderEvaluate
>
orderEvaluates
=
[];
...
...
@@ -290,4 +290,7 @@ class _UserOrderEvaluatePageState extends State<UserOrderEvaluatePage> {
),
);
}
@override
bool
get
wantKeepAlive
=>
true
;
}
lib/routes/index.dart
浏览文件 @
e9bf922f
...
...
@@ -33,6 +33,7 @@ import 'package:flutter_book/pages/user_nick/index.dart';
import
'package:flutter_book/pages/user_notes/index.dart'
;
import
'package:flutter_book/pages/user_notes_des/index.dart'
;
import
'package:flutter_book/pages/user_order_awaiting/index.dart'
;
import
'package:flutter_book/pages/user_order_coin_awaiting/index.dart'
;
import
'package:flutter_book/pages/user_order_completed/index.dart'
;
import
'package:flutter_book/pages/user_order_refunded/index.dart'
;
import
'package:flutter_book/pages/user_point/index.dart'
;
...
...
lib/routes/routes.dart
浏览文件 @
e9bf922f
...
...
@@ -108,8 +108,10 @@ abstract class Routes {
static
const
order
=
'order'
;
// 已完成订单
static
const
orderCompleted
=
'order_completed'
;
// 待付款订单
//
图书
待付款订单
static
const
orderAwaiting
=
'order_awaiting'
;
// 紫荆币待付款订单
static
const
orderCoinAwaiting
=
'order_coin_awaiting'
;
// 已退款订单
static
const
orderRefunded
=
'order_refunded'
;
// 搜索订单
...
...
@@ -528,7 +530,7 @@ abstract class Routes {
child:
UserOrderCompletedPage
(
orderNum:
state
.
uri
.
queryParameters
[
'orderNum'
].
toString
())
)
),
GoRoute
(
// 待付款订单
GoRoute
(
//
图书
待付款订单
path:
'/
$orderAwaiting
'
,
name:
orderAwaiting
,
pageBuilder:
(
context
,
state
)
=>
CupertinoPage
(
...
...
@@ -537,6 +539,15 @@ abstract class Routes {
child:
UserOrderAwaitingPage
(
orderNum:
state
.
uri
.
queryParameters
[
'orderNum'
].
toString
())
)
),
GoRoute
(
// 紫荆币待付款订单
path:
'/
$orderCoinAwaiting
'
,
name:
orderCoinAwaiting
,
pageBuilder:
(
context
,
state
)
=>
CupertinoPage
(
name:
state
.
uri
.
toString
(),
key:
state
.
pageKey
,
child:
UserOrderCoinAwaitingPage
(
orderNum:
state
.
uri
.
queryParameters
[
'orderNum'
].
toString
())
)
),
GoRoute
(
// 已退款订单
path:
'/
$orderRefunded
'
,
name:
orderRefunded
,
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论