mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-06 09:13:48 +08:00
207 lines
7.4 KiB
Dart
207 lines
7.4 KiB
Dart
import 'package:PiliPlus/common/widgets/refresh_indicator.dart';
|
||
import 'package:easy_debounce/easy_throttle.dart';
|
||
import 'package:flutter/material.dart';
|
||
import 'package:get/get.dart';
|
||
import 'package:PiliPlus/common/widgets/network_img_layer.dart';
|
||
|
||
import '../../../models/msg/msgfeed_like_me.dart';
|
||
import '../../../utils/app_scheme.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);
|
||
}
|
||
|
||
@override
|
||
void dispose() {
|
||
_scrollController.removeListener(_scrollListener);
|
||
_scrollController.dispose();
|
||
super.dispose();
|
||
}
|
||
|
||
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: (context, int i) {
|
||
return ListTile(
|
||
onTap: () {
|
||
String? nativeUri = msgFeedLikeMeList[i].item?.nativeUri;
|
||
if (nativeUri != null) {
|
||
PiliScheme.routePushFromUrl(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),
|
||
);
|
||
},
|
||
);
|
||
}
|
||
}
|