chatapp3-flutter/lib/modules/home/popular/follow/sc_room_follow_page.dart
2026-04-14 17:21:05 +08:00

286 lines
10 KiB
Dart

import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:yumi/app_localizations.dart';
import 'package:provider/provider.dart';
import 'package:yumi/ui_kit/components/sc_compontent.dart';
import 'package:yumi/ui_kit/components/sc_page_list.dart';
import 'package:yumi/ui_kit/components/text/sc_text.dart';
import 'package:yumi/app/constants/sc_screen.dart';
import 'package:yumi/shared/data_sources/sources/repositories/sc_user_repository_impl.dart';
import 'package:yumi/shared/business_logic/models/res/follow_room_res.dart';
import 'package:yumi/services/general/sc_app_general_manager.dart';
import 'package:yumi/services/audio/rtc_manager.dart';
///关注房间
class SCRoomFollowPage extends SCPageList {
@override
_RoomFollowPageState createState() => _RoomFollowPageState();
}
class _RoomFollowPageState
extends SCPageListState<FollowRoomRes, SCRoomFollowPage> {
String? lastId;
bool _isLoading = true; // 添加加载状态
@override
void initState() {
super.initState();
enablePullUp = true;
backgroundColor = Colors.transparent;
isGridView = true;
gridViewCount = 2;
loadData(1);
}
@override
Widget build(BuildContext context) {
return Scaffold(
resizeToAvoidBottomInset: false,
backgroundColor: Colors.transparent,
body: buildList(context),
);
}
@override
Widget buildItem(FollowRoomRes roomRes) {
return GestureDetector(
child: Container(
margin: EdgeInsets.symmetric(horizontal: 5.w, vertical: 5.w),
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(12.w),
color: Colors.transparent,
),
child: Stack(
alignment: Alignment.bottomCenter,
children: [
Container(
padding: EdgeInsets.all(3.w),
decoration: BoxDecoration(
image: DecorationImage(
image: AssetImage("sc_images/index/sc_icon_room_bord.png"),
fit: BoxFit.fill,
),
),
child: netImage(
url: resolveRoomCoverUrl(
roomRes.roomProfile?.id,
roomRes.roomProfile?.roomCover,
),
defaultImg: kRoomCoverDefaultImg,
borderRadius: BorderRadius.circular(12.w),
width: 200.w,
height: 200.w,
),
),
Container(
padding: EdgeInsets.symmetric(vertical: 6.w),
margin: EdgeInsets.symmetric(horizontal: 1.w),
decoration: BoxDecoration(
image: DecorationImage(
image: AssetImage(
"sc_images/index/sc_icon_index_room_brd.png",
),
fit: BoxFit.fill,
),
),
child: Row(
children: [
SizedBox(width: 10.w),
Consumer<SCAppGeneralManager>(
builder: (_, provider, __) {
return netImage(
url:
"${provider.findCountryByName(roomRes.roomProfile?.countryName ?? "")?.nationalFlag}",
width: 20.w,
height: 13.w,
borderRadius: BorderRadius.circular(2.w),
);
},
),
SizedBox(width: 5.w),
Expanded(
child: SizedBox(
height: 21.w,
child: text(
roomRes.roomProfile?.roomName ?? "",
fontSize: 15.sp,
textColor: Color(0xffffffff),
fontWeight: FontWeight.w400,
),
// (roomRes.roomProfile?.roomName?.length ?? 0) > 10
// ? Marquee(
// text: roomRes.roomProfile?.roomName ?? "",
// style: TextStyle(
// fontSize: 15.sp,
// color: Color(0xffffffff),
// fontWeight: FontWeight.w400,
// decoration: TextDecoration.none,
// ),
// scrollAxis: Axis.horizontal,
// crossAxisAlignment: CrossAxisAlignment.start,
// blankSpace: 20.0,
// velocity: 40.0,
// pauseAfterRound: Duration(seconds: 1),
// accelerationDuration: Duration(seconds: 1),
// accelerationCurve: Curves.easeOut,
// decelerationDuration: Duration(
// milliseconds: 500,
// ),
// decelerationCurve: Curves.easeOut,
// )
// : Text(
// roomRes.roomProfile?.roomName ?? "",
// maxLines: 1,
// overflow: TextOverflow.ellipsis,
// style: TextStyle(
// fontSize: 15.sp,
// color: Color(0xffffffff),
// fontWeight: FontWeight.w400,
// decoration: TextDecoration.none,
// ),
// ),
),
),
SizedBox(width: 5.w),
(roomRes
.roomProfile
?.extValues
?.roomSetting
?.password
?.isEmpty ??
false)
? Image.asset(
"sc_images/general/sc_icon_online_user.png",
width: 14.w,
height: 14.w,
)
: Image.asset(
"sc_images/index/sc_icon_room_suo.png",
width: 20.w,
height: 20.w,
),
(roomRes
.roomProfile
?.extValues
?.roomSetting
?.password
?.isEmpty ??
false)
? SizedBox(width: 3.w)
: Container(height: 10.w),
(roomRes
.roomProfile
?.extValues
?.roomSetting
?.password
?.isEmpty ??
false)
? text(
roomRes.roomProfile?.extValues?.memberQuantity ?? "0",
fontSize: 12.sp,
)
: Container(height: 10.w),
SizedBox(width: 10.w),
],
),
),
getRoomCoverHeaddress(roomRes).isNotEmpty
? Transform.translate(
offset: Offset(0, -5.w),
child: Transform.scale(
scaleX: 1.1,
scaleY: 1.12,
child: Image.asset(getRoomCoverHeaddress(roomRes)),
),
)
: Container(),
(roomRes.roomProfile?.roomGameIcon?.isNotEmpty ?? false)
? PositionedDirectional(
top: 8.w,
end: 8.w,
child: netImage(
url: roomRes.roomProfile?.roomGameIcon ?? "",
width: 25.w,
height: 25.w,
borderRadius: BorderRadius.circular(4.w),
),
)
: Container(),
],
),
),
onTap: () {
Provider.of<RtcProvider>(
context,
listen: false,
).joinVoiceRoomSession(context, roomRes.roomProfile?.id ?? "");
},
);
}
String getRoomCoverHeaddress(FollowRoomRes roomRes) {
return "";
}
@override
empty() {
List<Widget> list = [];
list.add(SizedBox(height: height(30)));
list.add(
Image.asset(
'sc_images/general/sc_icon_loading.png',
width: 120.w,
height: 120.w,
),
);
list.add(SizedBox(height: height(15)));
list.add(
Text(
SCAppLocalizations.of(context)!.youHaventFollowed,
style: TextStyle(
fontSize: sp(14),
color: Color(0xff999999),
fontWeight: FontWeight.w400,
decoration: TextDecoration.none,
height: 1,
),
),
);
return Column(
mainAxisSize: MainAxisSize.max,
crossAxisAlignment: CrossAxisAlignment.center,
children: list,
);
}
///加载数据
@override
loadPage({
required int page,
required Function(List<FollowRoomRes>) onSuccess,
Function? onErr,
}) async {
if (page == 1) {
lastId = null;
}
try {
var roomList = await SCAccountRepository().followRoomList(lastId: lastId);
if (roomList.isNotEmpty) {
lastId = roomList.last.id;
}
onSuccess(roomList);
} catch (e) {
if (onErr != null) {
onErr();
}
} finally {
// 无论成功失败,都隐藏骨架屏
setState(() {
_isLoading = false;
});
}
}
}