ZHR007 3 months ago
parent
commit
db2a38d9cf
7 changed files with 147 additions and 17 deletions
  1. BIN
      android/app/src/main/res/drawable-v21/splash.png
  2. BIN
      android/app/src/main/res/drawable/splash.png
  3. 31
      lib/controller/mine/my_friend_controller.dart
  4. 2
      lib/network/api_urls.dart
  5. 5
      lib/network/user_api.dart
  6. 34
      lib/network/user_api.g.dart
  7. 92
      lib/pages/mine/my_friend_page.dart

BIN
android/app/src/main/res/drawable-v21/splash.png

Before After
Width: 562  |  Height: 1250  |  Size: 68 KiB Width: 1500  |  Height: 2942  |  Size: 216 KiB

BIN
android/app/src/main/res/drawable/splash.png

Before After
Width: 562  |  Height: 1250  |  Size: 68 KiB Width: 1500  |  Height: 2942  |  Size: 216 KiB

31
lib/controller/mine/my_friend_controller.dart

@ -16,6 +16,11 @@ class MyFriendController extends GetxController with GetSingleTickerProviderStat
final page = 1.obs; final page = 1.obs;
final size = 10.obs; final size = 10.obs;
final applyPage = 1.obs;
final applySize = 10.obs;
final tab = 0.obs;
late UserApi _userApi; late UserApi _userApi;
late final EasyRefreshController listRefreshController; late final EasyRefreshController listRefreshController;
@ -69,8 +74,8 @@ class MyFriendController extends GetxController with GetSingleTickerProviderStat
getFriendApplyList() async { getFriendApplyList() async {
try{ try{
final response = await _userApi.userPageFriendApply( final response = await _userApi.userPageFriendApply(
pageNum: page.value,
pageSize: size.value,
pageNum: applyPage.value,
pageSize: applySize.value,
); );
if (response.data.isSuccess && response.data.data != null) { if (response.data.isSuccess && response.data.data != null) {
final data = response.data.data?.records ?? []; final data = response.data.data?.records ?? [];
@ -94,4 +99,26 @@ class MyFriendController extends GetxController with GetSingleTickerProviderStat
} }
} }
applyFriend(String id, int status, fa.Records item) async {
try {
final response = await _userApi.userConfirmFriendApply({
"id": id,
"status": status
});
if (response.data.isSuccess) {
SmartDialog.showToast(response.data.message);
item.status = status;
} else {
//
throw Exception(response.data.message ?? '获取数据失败');
}
} catch(e){
print('好友处理失败: $e');
SmartDialog.showToast('好友处理失败');
rethrow;
}
}
} }

2
lib/network/api_urls.dart

@ -94,6 +94,8 @@ class ApiUrls {
'dating-agency-service/user/get/dongwo/own-user-count'; 'dating-agency-service/user/get/dongwo/own-user-count';
static const String userPageFriendApply = static const String userPageFriendApply =
'dating-agency-chat-audio/user/page/friend-apply'; 'dating-agency-chat-audio/user/page/friend-apply';
static const String userConfirmFriendApply =
'dating-agency-chat-audio/user/confirm/friend-apply';
// //
static const String getMarriageList = static const String getMarriageList =

5
lib/network/user_api.dart

@ -244,4 +244,9 @@ abstract class UserApi {
@Query('pageNum') required int pageNum, @Query('pageNum') required int pageNum,
@Query('pageSize') required int pageSize, @Query('pageSize') required int pageSize,
}); });
@POST(ApiUrls.userConfirmFriendApply)
Future<HttpResponse<BaseResponse<dynamic>>> userConfirmFriendApply(
@Body() Map<String, dynamic> data,
);
} }

34
lib/network/user_api.g.dart

@ -1489,6 +1489,40 @@ class _UserApi implements UserApi {
return httpResponse; return httpResponse;
} }
@override
Future<HttpResponse<BaseResponse<dynamic>>> userConfirmFriendApply(
Map<String, dynamic> data,
) async {
final _extra = <String, dynamic>{};
final queryParameters = <String, dynamic>{};
final _headers = <String, dynamic>{};
final _data = <String, dynamic>{};
_data.addAll(data);
final _options = _setStreamType<HttpResponse<BaseResponse<dynamic>>>(
Options(method: 'POST', headers: _headers, extra: _extra)
.compose(
_dio.options,
'dating-agency-chat-audio/user/confirm/friend-apply',
queryParameters: queryParameters,
data: _data,
)
.copyWith(baseUrl: _combineBaseUrls(_dio.options.baseUrl, baseUrl)),
);
final _result = await _dio.fetch<Map<String, dynamic>>(_options);
late BaseResponse<dynamic> _value;
try {
_value = BaseResponse<dynamic>.fromJson(
_result.data!,
(json) => json as dynamic,
);
} on Object catch (e, s) {
errorLogger?.logError(e, s, _options);
rethrow;
}
final httpResponse = HttpResponse(_value, _result);
return httpResponse;
}
RequestOptions _setStreamType<T>(RequestOptions requestOptions) { RequestOptions _setStreamType<T>(RequestOptions requestOptions) {
if (T != dynamic && if (T != dynamic &&
!(requestOptions.responseType == ResponseType.bytes || !(requestOptions.responseType == ResponseType.bytes ||

92
lib/pages/mine/my_friend_page.dart

@ -1,6 +1,7 @@
import 'package:cached_network_image/cached_network_image.dart'; import 'package:cached_network_image/cached_network_image.dart';
import 'package:dating_touchme_app/components/page_appbar.dart'; import 'package:dating_touchme_app/components/page_appbar.dart';
import 'package:dating_touchme_app/controller/mine/my_friend_controller.dart'; import 'package:dating_touchme_app/controller/mine/my_friend_controller.dart';
import 'package:dating_touchme_app/extension/ex_widget.dart';
import 'package:dating_touchme_app/generated/assets.dart'; import 'package:dating_touchme_app/generated/assets.dart';
import 'package:dating_touchme_app/model/mine/friend_data.dart'; import 'package:dating_touchme_app/model/mine/friend_data.dart';
import 'package:easy_refresh/easy_refresh.dart'; import 'package:easy_refresh/easy_refresh.dart';
@ -45,21 +46,37 @@ class MyFriendPage extends StatelessWidget {
// //
onRefresh: () async { onRefresh: () async {
print('推荐列表下拉刷新被触发'); print('推荐列表下拉刷新被触发');
controller.page.value = 1;
controller.friendList.clear();
await controller.getFriendList();
controller.listRefreshController.finishRefresh(IndicatorResult.success);
controller.listRefreshController.finishLoad(IndicatorResult.none);
if(controller.tab.value == 0){
controller.page.value = 1;
controller.friendList.clear();
await controller.getFriendList();
controller.listRefreshController.finishRefresh(IndicatorResult.success);
controller.listRefreshController.finishLoad(IndicatorResult.none);
} else {
controller.applyPage.value = 1;
controller.friendApplyList.clear();
await controller.getFriendApplyList();
controller.listRefreshController.finishRefresh(IndicatorResult.success);
controller.listRefreshController.finishLoad(IndicatorResult.none);
}
}, },
// //
onLoad: () async { onLoad: () async {
print('推荐列表上拉加载被触发, hasMore: '); print('推荐列表上拉加载被触发, hasMore: ');
controller.page.value += 1;
controller.getFriendList();
if(controller.tab.value == 0){
controller.page.value += 1;
controller.getFriendList();
} else {
controller.applyPage.value += 1;
controller.getFriendApplyList();
}
}, },
child: SingleChildScrollView( child: SingleChildScrollView(
child: Container( child: Container(
padding: EdgeInsets.symmetric(horizontal: 12.w), padding: EdgeInsets.symmetric(horizontal: 12.w),
constraints: BoxConstraints(
minHeight: MediaQuery.of(context).size.height - MediaQuery.of(context).padding.top,
),
child: Column( child: Column(
children: [ children: [
TDTabBar( TDTabBar(
@ -88,11 +105,25 @@ class MyFriendPage extends StatelessWidget {
controller: controller.tabController, controller: controller.tabController,
showIndicator: false, showIndicator: false,
isScrollable: true, isScrollable: true,
onTap: (index) {
onTap: (index) async {
print('相亲页面 Tab: $index'); print('相亲页面 Tab: $index');
controller.tab.value = index;
if(index == 0){
controller.friendList.clear();
controller.page.value = 1;
await controller.getFriendList();
controller.listRefreshController.finishRefresh(IndicatorResult.success);
controller.listRefreshController.finishLoad(IndicatorResult.none);
} else {
controller.friendApplyList.clear();
controller.applyPage.value = 1;
await controller.getFriendApplyList();
controller.listRefreshController.finishRefresh(IndicatorResult.success);
controller.listRefreshController.finishLoad(IndicatorResult.none);
}
}, },
), ),
if(controller.friendList.isEmpty) ...[
if((controller.tab.value == 0 && controller.friendList.isEmpty) || (controller.tab.value == 1 && controller.friendApplyList.isEmpty)) ...[
Container( Container(
padding: EdgeInsets.only(top: 60.w,bottom: 13.w), padding: EdgeInsets.only(top: 60.w,bottom: 13.w),
child: Center( child: Center(
@ -140,14 +171,16 @@ class MyFriendPage extends StatelessWidget {
), ),
), ),
], ],
if(controller.friendList.isNotEmpty) ...[
if(controller.tab.value == 0 && controller.friendList.isNotEmpty) ...[
...controller.friendList.map((e){ ...controller.friendList.map((e){
return UserItem(item: e,); return UserItem(item: e,);
}), }),
], ],
AddUserItem(item: fa.Records(),),
AddUserItem(item: fa.Records(),),
AddUserItem(item: fa.Records(),),
if(controller.tab.value == 1 && controller.friendApplyList.isNotEmpty) ...[
...controller.friendApplyList.map((e){
return AddUserItem(item: e, controller: controller,);
}),
]
], ],
), ),
), ),
@ -256,7 +289,8 @@ class _UserItemState extends State<UserItem> {
class AddUserItem extends StatefulWidget { class AddUserItem extends StatefulWidget {
final fa.Records item; final fa.Records item;
const AddUserItem({super.key, required this.item});
final MyFriendController controller;
const AddUserItem({super.key, required this.item, required this.controller});
@override @override
State<AddUserItem> createState() => _AddUserItemState(); State<AddUserItem> createState() => _AddUserItemState();
@ -378,7 +412,35 @@ class _AddUserItemState extends State<AddUserItem> {
), ),
), ),
), ),
)
).onTap((){
showDialog(
context: context,
builder: (BuildContext context) {
// AlertDialog
return AlertDialog(
title: Text("提示"),
content: Text("请确认是否同意添加对方为好友"),
actions: <Widget>[
//
TextButton(
child: Text("同意"),
onPressed: () async {
await widget.controller.applyFriend(widget.item.id ?? "", 2, widget.item);
Navigator.of(context).pop();
},
),
//
TextButton(
child: Text("拒绝"),
onPressed: () async {
await widget.controller.applyFriend(widget.item.id ?? "", 3, widget.item);
Navigator.of(context).pop();
},
),
],
);
});
})
], ],
), ),
); );

Loading…
Cancel
Save