mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-06 09:13:48 +08:00
196 lines
7.1 KiB
Dart
196 lines
7.1 KiB
Dart
import 'package:easy_debounce/easy_throttle.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
|
|
import 'package:get/get.dart';
|
|
import 'package:PiliPalaX/common/widgets/network_img_layer.dart';
|
|
|
|
import '../../../models/msg/msgfeed_like_me.dart';
|
|
import 'controller.dart';
|
|
|
|
class LikeMePage extends StatefulWidget {
|
|
const LikeMePage({super.key});
|
|
|
|
@override
|
|
State<LikeMePage> createState() => _LikeMePageState();
|
|
}
|
|
|
|
class _LikeMePageState extends State<LikeMePage> {
|
|
late final LikeMeController _likeMeController = Get.put(LikeMeController());
|
|
final ScrollController _scrollController = ScrollController();
|
|
|
|
@override
|
|
void initState() {
|
|
_likeMeController.queryMsgFeedLikeMe();
|
|
super.initState();
|
|
_scrollController.addListener(_scrollListener);
|
|
}
|
|
|
|
Future _scrollListener() async {
|
|
if (_scrollController.position.pixels >=
|
|
_scrollController.position.maxScrollExtent - 200) {
|
|
EasyThrottle.throttle('my-throttler', const Duration(milliseconds: 800),
|
|
() async {
|
|
await _likeMeController.onLoad();
|
|
});
|
|
}
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Scaffold(
|
|
appBar: AppBar(
|
|
title: const Text('收到的赞'),
|
|
),
|
|
body: RefreshIndicator(
|
|
onRefresh: () async {
|
|
await _likeMeController.onRefresh();
|
|
},
|
|
child: SingleChildScrollView(
|
|
controller: _scrollController,
|
|
child: LayoutBuilder(
|
|
builder: (BuildContext context, BoxConstraints constraints) {
|
|
return Obx(
|
|
() {
|
|
if (_likeMeController.msgFeedLikeMeLatestList.isEmpty &&
|
|
_likeMeController.msgFeedLikeMeTotalList.isEmpty) {
|
|
return const Center(
|
|
child: CircularProgressIndicator(),
|
|
);
|
|
}
|
|
return Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
if (_likeMeController
|
|
.msgFeedLikeMeLatestList.isNotEmpty) ...<Widget>[
|
|
Text(" 最新",
|
|
style: Theme.of(context)
|
|
.textTheme
|
|
.labelMedium!
|
|
.copyWith(
|
|
color:
|
|
Theme.of(context).colorScheme.outline)),
|
|
LikeMeList(
|
|
msgFeedLikeMeList:
|
|
_likeMeController.msgFeedLikeMeLatestList),
|
|
],
|
|
if (_likeMeController
|
|
.msgFeedLikeMeTotalList.isNotEmpty) ...<Widget>[
|
|
Text(" 累计",
|
|
style: Theme.of(context)
|
|
.textTheme
|
|
.labelMedium!
|
|
.copyWith(
|
|
color:
|
|
Theme.of(context).colorScheme.outline)),
|
|
LikeMeList(
|
|
msgFeedLikeMeList:
|
|
_likeMeController.msgFeedLikeMeTotalList),
|
|
]
|
|
]);
|
|
},
|
|
);
|
|
}),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|
|
|
|
class LikeMeList extends StatelessWidget {
|
|
const LikeMeList({
|
|
super.key,
|
|
required this.msgFeedLikeMeList,
|
|
});
|
|
final RxList<LikeMeItems> msgFeedLikeMeList;
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return ListView.separated(
|
|
itemCount: msgFeedLikeMeList.length,
|
|
shrinkWrap: true,
|
|
physics: const NeverScrollableScrollPhysics(),
|
|
itemBuilder: (_, int i) {
|
|
return ListTile(
|
|
onTap: () {
|
|
String nativeUri = msgFeedLikeMeList[i].item?.nativeUri ?? "";
|
|
SmartDialog.showToast("跳转至:$nativeUri(暂未实现)");
|
|
},
|
|
leading: Column(
|
|
children: [
|
|
const Spacer(),
|
|
SizedBox(
|
|
width: 50,
|
|
height: 50,
|
|
child: Stack(
|
|
children: [
|
|
for (var j = 0;
|
|
j < msgFeedLikeMeList[i].users!.length && j < 4;
|
|
j++) ...<Widget>[
|
|
Positioned(
|
|
left: 15 * (j % 2).toDouble(),
|
|
top: 15 * (j ~/ 2).toDouble(),
|
|
child: NetworkImgLayer(
|
|
width: msgFeedLikeMeList[i].users!.length > 1
|
|
? 30
|
|
: 45,
|
|
height: msgFeedLikeMeList[i].users!.length > 1
|
|
? 30
|
|
: 45,
|
|
type: 'avatar',
|
|
src: msgFeedLikeMeList[i].users![j].avatar,
|
|
)),
|
|
]
|
|
],
|
|
)),
|
|
const Spacer(),
|
|
],
|
|
),
|
|
title: Text(
|
|
// "${msgFeedLikeMeList[i].users!.map((e) => e.nickname).join("/")}"
|
|
"${msgFeedLikeMeList[i].users?[0].nickname}"
|
|
"${msgFeedLikeMeList[i].users!.length > 1 ? '、' + msgFeedLikeMeList[i].users![1].nickname.toString() + ' 等' : ''} "
|
|
"${msgFeedLikeMeList[i].counts! > 1 ? '共 ' + msgFeedLikeMeList[i].counts.toString() + ' 人' : ''}"
|
|
"赞了我的${msgFeedLikeMeList[i].item?.business}",
|
|
style: Theme.of(context).textTheme.titleSmall!.copyWith(
|
|
height: 1.5, color: Theme.of(context).colorScheme.primary),
|
|
maxLines: 2,
|
|
overflow: TextOverflow.ellipsis,
|
|
),
|
|
subtitle: msgFeedLikeMeList[i].item?.title != null &&
|
|
msgFeedLikeMeList[i].item?.title != ""
|
|
? Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
const SizedBox(height: 4),
|
|
Text(msgFeedLikeMeList[i].item?.title ?? "",
|
|
maxLines: 3,
|
|
overflow: TextOverflow.ellipsis,
|
|
style: Theme.of(context).textTheme.bodyMedium!.copyWith(
|
|
color: Theme.of(context).colorScheme.outline,
|
|
height: 1.5))
|
|
],
|
|
)
|
|
: null,
|
|
trailing: msgFeedLikeMeList[i].item?.image != null &&
|
|
msgFeedLikeMeList[i].item?.image != ""
|
|
? NetworkImgLayer(
|
|
width: 45,
|
|
height: 45,
|
|
type: 'cover',
|
|
src: msgFeedLikeMeList[i].item?.image,
|
|
)
|
|
: null,
|
|
);
|
|
},
|
|
separatorBuilder: (BuildContext context, int index) {
|
|
return Divider(
|
|
indent: 72,
|
|
endIndent: 20,
|
|
height: 6,
|
|
color: Colors.grey.withOpacity(0.1),
|
|
);
|
|
},
|
|
);
|
|
}
|
|
}
|