Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
B
book-app
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
EzijingWeb
book-app
Commits
40c03017
提交
40c03017
authored
2月 22, 2024
作者:
yueweilu
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'origin/test' into test
上级
15b53996
e9bf922f
全部展开
隐藏空白字符变更
内嵌
并排
正在显示
16 个修改的文件
包含
274 行增加
和
76 行删除
+274
-76
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
+80
-72
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
浏览文件 @
40c03017
7.4 KB
assets/images/2.0x/coupon_expired.png
0 → 100644
浏览文件 @
40c03017
4.0 KB
assets/images/3.0x/coupon_bg_expired.png
0 → 100644
浏览文件 @
40c03017
14.8 KB
assets/images/3.0x/coupon_expired.png
0 → 100644
浏览文件 @
40c03017
8.0 KB
assets/images/coupon_bg_expired.png
0 → 100644
浏览文件 @
40c03017
2.6 KB
assets/images/coupon_expired.png
0 → 100644
浏览文件 @
40c03017
1.9 KB
lib/models/order.dart
浏览文件 @
40c03017
...
@@ -264,6 +264,8 @@ class OrderInfoModel {
...
@@ -264,6 +264,8 @@ class OrderInfoModel {
OrderInfoModel
({
OrderInfoModel
({
this
.
id
,
this
.
id
,
this
.
ordersnum
,
this
.
ordersnum
,
this
.
goodsId
,
this
.
goodsName
,
this
.
totalPrice
,
this
.
totalPrice
,
this
.
finalTotalPrice
,
this
.
finalTotalPrice
,
this
.
nums
,
this
.
nums
,
...
@@ -282,6 +284,8 @@ class OrderInfoModel {
...
@@ -282,6 +284,8 @@ class OrderInfoModel {
OrderInfoModel
.
fromJson
(
dynamic
json
)
{
OrderInfoModel
.
fromJson
(
dynamic
json
)
{
id
=
json
[
'id'
];
id
=
json
[
'id'
];
ordersnum
=
json
[
'ordersnum'
];
ordersnum
=
json
[
'ordersnum'
];
goodsId
=
json
[
'goods_id'
];
goodsName
=
json
[
'goods_name'
];
totalPrice
=
json
[
'total_price'
];
totalPrice
=
json
[
'total_price'
];
finalTotalPrice
=
json
[
'final_total_price'
];
finalTotalPrice
=
json
[
'final_total_price'
];
nums
=
json
[
'num'
];
nums
=
json
[
'num'
];
...
@@ -304,6 +308,8 @@ class OrderInfoModel {
...
@@ -304,6 +308,8 @@ class OrderInfoModel {
}
}
num
?
id
;
num
?
id
;
String
?
ordersnum
;
String
?
ordersnum
;
String
?
goodsId
;
//充值的凭证
String
?
goodsName
;
//充值名称
String
?
totalPrice
;
String
?
totalPrice
;
String
?
finalTotalPrice
;
String
?
finalTotalPrice
;
num
?
nums
;
num
?
nums
;
...
@@ -320,6 +326,8 @@ class OrderInfoModel {
...
@@ -320,6 +326,8 @@ class OrderInfoModel {
List
<
BookListModel
>?
bookList
;
List
<
BookListModel
>?
bookList
;
OrderInfoModel
copyWith
({
num
?
id
,
OrderInfoModel
copyWith
({
num
?
id
,
String
?
ordersnum
,
String
?
ordersnum
,
String
?
goodsId
,
String
?
goodsName
,
String
?
totalPrice
,
String
?
totalPrice
,
String
?
finalTotalPrice
,
String
?
finalTotalPrice
,
num
?
nums
,
num
?
nums
,
...
@@ -336,6 +344,8 @@ class OrderInfoModel {
...
@@ -336,6 +344,8 @@ class OrderInfoModel {
List
<
BookListModel
>?
bookList
,
List
<
BookListModel
>?
bookList
,
})
=>
OrderInfoModel
(
id:
id
??
this
.
id
,
})
=>
OrderInfoModel
(
id:
id
??
this
.
id
,
ordersnum:
ordersnum
??
this
.
ordersnum
,
ordersnum:
ordersnum
??
this
.
ordersnum
,
goodsId:
ordersnum
??
this
.
goodsId
,
goodsName:
ordersnum
??
this
.
goodsName
,
totalPrice:
totalPrice
??
this
.
totalPrice
,
totalPrice:
totalPrice
??
this
.
totalPrice
,
finalTotalPrice:
finalTotalPrice
??
this
.
finalTotalPrice
,
finalTotalPrice:
finalTotalPrice
??
this
.
finalTotalPrice
,
nums:
nums
??
this
.
nums
,
nums:
nums
??
this
.
nums
,
...
@@ -355,6 +365,8 @@ class OrderInfoModel {
...
@@ -355,6 +365,8 @@ class OrderInfoModel {
final
map
=
<
String
,
dynamic
>{};
final
map
=
<
String
,
dynamic
>{};
map
[
'id'
]
=
id
;
map
[
'id'
]
=
id
;
map
[
'ordersnum'
]
=
ordersnum
;
map
[
'ordersnum'
]
=
ordersnum
;
map
[
'goods_id'
]
=
goodsId
;
map
[
'goods_name'
]
=
goodsName
;
map
[
'total_price'
]
=
totalPrice
;
map
[
'total_price'
]
=
totalPrice
;
map
[
'final_total_price'
]
=
finalTotalPrice
;
map
[
'final_total_price'
]
=
finalTotalPrice
;
map
[
'num'
]
=
nums
;
map
[
'num'
]
=
nums
;
...
...
lib/pages/user_coupon/controller.dart
浏览文件 @
40c03017
...
@@ -42,7 +42,11 @@ class UserCouponController extends GetxController {
...
@@ -42,7 +42,11 @@ class UserCouponController extends GetxController {
);
);
// 如果是刷新 清理数据
// 如果是刷新 清理数据
if
(
isRefresh
)
coupons
.
clear
();
if
(
isRefresh
)
coupons
.
clear
();
coupons
.
addAll
(
result
);
for
(
CouponModel
model
in
result
){
model
.
type
=
type
;
coupons
.
add
(
model
);
}
// coupons.addAll(result);
_page
++;
_page
++;
_noMore
=
result
.
length
<
_limit
;
_noMore
=
result
.
length
<
_limit
;
update
();
update
();
...
...
lib/pages/user_coupon/widgets/item.dart
浏览文件 @
40c03017
差异被折叠。
点击展开。
lib/pages/user_order/widgets/coin.dart
浏览文件 @
40c03017
...
@@ -15,83 +15,91 @@ class BuiltCoin extends StatelessWidget {
...
@@ -15,83 +15,91 @@ class BuiltCoin extends StatelessWidget {
}
else
if
(
model
.
status
==
3
){
}
else
if
(
model
.
status
==
3
){
status
=
'已完成'
;
status
=
'已完成'
;
}
}
return
Container
(
return
GestureDetector
(
margin:
EdgeInsets
.
only
(
left:
10
.
w
,
right:
10
.
w
,
top:
10
.
w
),
onTap:
()
{
padding:
EdgeInsets
.
only
(
left:
11.5
.
w
),
if
(
model
.
status
==
1
){
decoration:
BoxDecoration
(
context
.
pushNamed
(
Routes
.
orderCoinAwaiting
,
borderRadius:
BorderRadius
.
circular
(
8
.
w
),
queryParameters:
{
'orderNum'
:
model
.
ordersnum
});
color:
Colors
.
white
,
}
boxShadow:
[
},
BoxShadow
(
child:
Container
(
color:
const
Color
(
0xFFC7C7C7
).
withOpacity
(
0.5
),
margin:
EdgeInsets
.
only
(
left:
10
.
w
,
right:
10
.
w
,
top:
10
.
w
),
offset:
Offset
(
1.5
.
w
,
0
),
padding:
EdgeInsets
.
only
(
left:
11.5
.
w
),
blurRadius:
7
.
w
,
decoration:
BoxDecoration
(
spreadRadius:
0
.
w
,
borderRadius:
BorderRadius
.
circular
(
8
.
w
),
),
color:
Colors
.
white
,
],
boxShadow:
[
),
BoxShadow
(
child:
Row
(
color:
const
Color
(
0xFFC7C7C7
).
withOpacity
(
0.5
),
mainAxisAlignment:
MainAxisAlignment
.
start
,
offset:
Offset
(
1.5
.
w
,
0
),
crossAxisAlignment:
CrossAxisAlignment
.
start
,
blurRadius:
7
.
w
,
children:
[
spreadRadius:
0
.
w
,
Container
(
margin:
EdgeInsets
.
only
(
top:
19
.
w
,
bottom:
19
.
w
,
right:
16.5
.
w
),
child:
Image
.
asset
(
'assets/images/coin.png'
,
height:
27
.
w
,
width:
27
.
w
,
),
),
),
],
Expanded
(
),
child:
Row
(
child:
Row
(
mainAxisAlignment:
MainAxisAlignment
.
spaceBetween
,
mainAxisAlignment:
MainAxisAlignment
.
start
,
children:
[
crossAxisAlignment:
CrossAxisAlignment
.
start
,
Column
(
children:
[
crossAxisAlignment:
CrossAxisAlignment
.
start
,
Container
(
children:
[
margin:
EdgeInsets
.
only
(
top:
19
.
w
,
bottom:
19
.
w
,
right:
16.5
.
w
),
SizedBox
(
child:
Image
.
asset
(
height:
12
.
w
,
'assets/images/coin.png'
,
),
height:
27
.
w
,
Text
(
width:
27
.
w
,
model
.
createTime
.
toString
(),
style:
TextStyle
(
fontSize:
12
.
w
,
color:
Colours
.
c9
),
),
SizedBox
(
height:
4
.
w
,
),
Text
(
'充值紫荆币'
,
style:
TextStyle
(
fontSize:
13
.
w
,
color:
Colours
.
c3
,
fontWeight:
Fonts
.
medium
),
)
],
),
),
Container
(
),
margin:
EdgeInsets
.
only
(
right:
15
.
w
),
Expanded
(
child:
Column
(
child:
Row
(
crossAxisAlignment:
CrossAxisAlignment
.
end
,
mainAxisAlignment:
MainAxisAlignment
.
spaceBetween
,
children:
[
children:
[
SizedBox
(
Column
(
height:
6.5
.
w
,
crossAxisAlignment:
CrossAxisAlignment
.
start
,
children:
[
SizedBox
(
height:
12
.
w
,
),
Text
(
model
.
createTime
.
toString
(),
style:
TextStyle
(
fontSize:
12
.
w
,
color:
Colours
.
c9
),
),
SizedBox
(
height:
4
.
w
,
),
Text
(
'充值紫荆币'
,
style:
TextStyle
(
fontSize:
13
.
w
,
color:
Colours
.
c3
,
fontWeight:
Fonts
.
medium
),
)
],
),
Container
(
margin:
EdgeInsets
.
only
(
right:
15
.
w
),
child:
Column
(
crossAxisAlignment:
CrossAxisAlignment
.
end
,
children:
[
SizedBox
(
height:
6.5
.
w
,
),
Text
(
status
,
style:
TextStyle
(
fontSize:
13
.
w
,
color:
Colours
.
c9
),),
SizedBox
(
height:
6.5
.
w
,),
Text
(
'¥
${model.finalTotalPrice}
'
,
style:
TextStyle
(
fontSize:
14
.
w
,
color:
Colours
.
cAB1941
,
fontWeight:
Fonts
.
medium
),
)
],
),
),
),
Text
(
status
,
style:
TextStyle
(
fontSize:
13
.
w
,
color:
Colours
.
c9
),),
SizedBox
(
height:
6.5
.
w
,),
Text
(
'¥
${model.finalTotalPrice}
'
,
style:
TextStyle
(
fontSize:
14
.
w
,
color:
Colours
.
cAB1941
,
fontWeight:
Fonts
.
medium
),
)
],
),
),
],
],
)),
)),
],
],
),
),
),
);
);
}
}
...
...
lib/pages/user_order_coin_awaiting/controller.dart
0 → 100644
浏览文件 @
40c03017
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
浏览文件 @
40c03017
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
浏览文件 @
40c03017
差异被折叠。
点击展开。
lib/pages/user_order_evaluate/view.dart
浏览文件 @
40c03017
...
@@ -15,7 +15,7 @@ class UserOrderEvaluatePage extends StatefulWidget {
...
@@ -15,7 +15,7 @@ class UserOrderEvaluatePage extends StatefulWidget {
State
<
UserOrderEvaluatePage
>
createState
()
=>
_UserOrderEvaluatePageState
();
State
<
UserOrderEvaluatePage
>
createState
()
=>
_UserOrderEvaluatePageState
();
}
}
class
_UserOrderEvaluatePageState
extends
State
<
UserOrderEvaluatePage
>
{
class
_UserOrderEvaluatePageState
extends
State
<
UserOrderEvaluatePage
>
with
AutomaticKeepAliveClientMixin
{
late
UserOrderEvaluateController
myController
;
late
UserOrderEvaluateController
myController
;
List
<
TextEditingController
>
controllers
=
[];
List
<
TextEditingController
>
controllers
=
[];
List
<
OrderEvaluate
>
orderEvaluates
=
[];
List
<
OrderEvaluate
>
orderEvaluates
=
[];
...
@@ -290,4 +290,7 @@ class _UserOrderEvaluatePageState extends State<UserOrderEvaluatePage> {
...
@@ -290,4 +290,7 @@ class _UserOrderEvaluatePageState extends State<UserOrderEvaluatePage> {
),
),
);
);
}
}
@override
bool
get
wantKeepAlive
=>
true
;
}
}
lib/routes/index.dart
浏览文件 @
40c03017
...
@@ -33,6 +33,7 @@ import 'package:flutter_book/pages/user_nick/index.dart';
...
@@ -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/index.dart'
;
import
'package:flutter_book/pages/user_notes_des/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_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_completed/index.dart'
;
import
'package:flutter_book/pages/user_order_refunded/index.dart'
;
import
'package:flutter_book/pages/user_order_refunded/index.dart'
;
import
'package:flutter_book/pages/user_point/index.dart'
;
import
'package:flutter_book/pages/user_point/index.dart'
;
...
...
lib/routes/routes.dart
浏览文件 @
40c03017
...
@@ -108,8 +108,10 @@ abstract class Routes {
...
@@ -108,8 +108,10 @@ abstract class Routes {
static
const
order
=
'order'
;
static
const
order
=
'order'
;
// 已完成订单
// 已完成订单
static
const
orderCompleted
=
'order_completed'
;
static
const
orderCompleted
=
'order_completed'
;
// 待付款订单
//
图书
待付款订单
static
const
orderAwaiting
=
'order_awaiting'
;
static
const
orderAwaiting
=
'order_awaiting'
;
// 紫荆币待付款订单
static
const
orderCoinAwaiting
=
'order_coin_awaiting'
;
// 已退款订单
// 已退款订单
static
const
orderRefunded
=
'order_refunded'
;
static
const
orderRefunded
=
'order_refunded'
;
// 搜索订单
// 搜索订单
...
@@ -528,7 +530,7 @@ abstract class Routes {
...
@@ -528,7 +530,7 @@ abstract class Routes {
child:
UserOrderCompletedPage
(
orderNum:
state
.
uri
.
queryParameters
[
'orderNum'
].
toString
())
child:
UserOrderCompletedPage
(
orderNum:
state
.
uri
.
queryParameters
[
'orderNum'
].
toString
())
)
)
),
),
GoRoute
(
// 待付款订单
GoRoute
(
//
图书
待付款订单
path:
'/
$orderAwaiting
'
,
path:
'/
$orderAwaiting
'
,
name:
orderAwaiting
,
name:
orderAwaiting
,
pageBuilder:
(
context
,
state
)
=>
CupertinoPage
(
pageBuilder:
(
context
,
state
)
=>
CupertinoPage
(
...
@@ -537,6 +539,15 @@ abstract class Routes {
...
@@ -537,6 +539,15 @@ abstract class Routes {
child:
UserOrderAwaitingPage
(
orderNum:
state
.
uri
.
queryParameters
[
'orderNum'
].
toString
())
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
(
// 已退款订单
GoRoute
(
// 已退款订单
path:
'/
$orderRefunded
'
,
path:
'/
$orderRefunded
'
,
name:
orderRefunded
,
name:
orderRefunded
,
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论