Browse Source

替换图片

ios
王子贤 3 months ago
parent
commit
35db68c83b
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 size = 10.obs;
final applyPage = 1.obs;
final applySize = 10.obs;
final tab = 0.obs;
late UserApi _userApi;
late final EasyRefreshController listRefreshController;
@ -69,8 +74,8 @@ class MyFriendController extends GetxController with GetSingleTickerProviderStat
getFriendApplyList() async {
try{
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) {
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';
static const String userPageFriendApply =
'dating-agency-chat-audio/user/page/friend-apply';
static const String userConfirmFriendApply =
'dating-agency-chat-audio/user/confirm/friend-apply';
//
static const String getMarriageList =

5
lib/network/user_api.dart

@ -244,4 +244,9 @@ abstract class UserApi {
@Query('pageNum') required int pageNum,
@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;
}
@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) {
if (T != dynamic &&
!(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:dating_touchme_app/components/page_appbar.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/model/mine/friend_data.dart';
import 'package:easy_refresh/easy_refresh.dart';
@ -45,21 +46,37 @@ class MyFriendPage extends StatelessWidget {
//
onRefresh: () async {
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 {
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: Container(
padding: EdgeInsets.symmetric(horizontal: 12.w),
constraints: BoxConstraints(
minHeight: MediaQuery.of(context).size.height - MediaQuery.of(context).padding.top,
),
child: Column(
children: [
TDTabBar(
@ -88,11 +105,25 @@ class MyFriendPage extends StatelessWidget {
controller: controller.tabController,
showIndicator: false,
isScrollable: true,
onTap: (index) {
onTap: (index) async {
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(
padding: EdgeInsets.only(top: 60.w,bottom: 13.w),
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){
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 {
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
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