mirror of
https://github.com/bggRGjQaUbCoE/PiliPlus.git
synced 2026-06-01 00:28:18 +08:00
refa persistent header & dynamic sliver appbar
Signed-off-by: dom <githubaccount56556@proton.me>
This commit is contained in:
@@ -1,7 +1,7 @@
|
||||
import 'package:PiliPlus/common/skeleton/video_card_h.dart';
|
||||
import 'package:PiliPlus/common/widgets/custom_sliver_persistent_header_delegate.dart';
|
||||
import 'package:PiliPlus/common/widgets/flutter/refresh_indicator.dart';
|
||||
import 'package:PiliPlus/common/widgets/loading_widget/http_error.dart';
|
||||
import 'package:PiliPlus/common/widgets/sliver/sliver_pinned_header.dart';
|
||||
import 'package:PiliPlus/http/loading_state.dart';
|
||||
import 'package:PiliPlus/models_new/space/space_fav/data.dart';
|
||||
import 'package:PiliPlus/pages/member_favorite/controller.dart';
|
||||
@@ -109,56 +109,51 @@ class _MemberFavoriteState extends State<MemberFavorite>
|
||||
}) {
|
||||
return SliverMainAxisGroup(
|
||||
slivers: [
|
||||
SliverPersistentHeader(
|
||||
pinned: true,
|
||||
delegate: CustomSliverPersistentHeaderDelegate(
|
||||
child: Material(
|
||||
color: theme.colorScheme.surface,
|
||||
child: Builder(
|
||||
builder: (context) {
|
||||
return InkWell(
|
||||
onTap: () {
|
||||
_controller.setExpand(isFav);
|
||||
(context as Element).markNeedsBuild();
|
||||
data.refresh();
|
||||
if (!isEnd.value) {
|
||||
isEnd.refresh();
|
||||
}
|
||||
},
|
||||
child: Container(
|
||||
height: 45,
|
||||
alignment: .centerLeft,
|
||||
padding: const .only(left: 12),
|
||||
child: Text.rich(
|
||||
TextSpan(
|
||||
children: [
|
||||
WidgetSpan(
|
||||
alignment: .middle,
|
||||
child: Icon(
|
||||
_controller.isExpand(isFav)
|
||||
? Icons.expand_less
|
||||
: Icons.expand_more,
|
||||
color: theme.colorScheme.outline,
|
||||
),
|
||||
SliverPinnedHeader(
|
||||
child: Material(
|
||||
color: theme.colorScheme.surface,
|
||||
child: Builder(
|
||||
builder: (context) {
|
||||
return InkWell(
|
||||
onTap: () {
|
||||
_controller.setExpand(isFav);
|
||||
(context as Element).markNeedsBuild();
|
||||
data.refresh();
|
||||
if (!isEnd.value) {
|
||||
isEnd.refresh();
|
||||
}
|
||||
},
|
||||
child: Padding(
|
||||
padding: const .symmetric(horizontal: 12, vertical: 10),
|
||||
child: Text.rich(
|
||||
TextSpan(
|
||||
children: [
|
||||
WidgetSpan(
|
||||
alignment: .middle,
|
||||
child: Icon(
|
||||
_controller.isExpand(isFav)
|
||||
? Icons.expand_less
|
||||
: Icons.expand_more,
|
||||
color: theme.colorScheme.outline,
|
||||
),
|
||||
TextSpan(
|
||||
text: ' ${data.value.name}',
|
||||
style: const TextStyle(fontSize: 14),
|
||||
),
|
||||
TextSpan(
|
||||
text: ' ${data.value.name}',
|
||||
style: const TextStyle(fontSize: 14),
|
||||
),
|
||||
TextSpan(
|
||||
text: ' ${data.value.mediaListResponse?.count}',
|
||||
style: TextStyle(
|
||||
fontSize: 13,
|
||||
color: theme.colorScheme.outline,
|
||||
),
|
||||
TextSpan(
|
||||
text: ' ${data.value.mediaListResponse?.count}',
|
||||
style: TextStyle(
|
||||
fontSize: 13,
|
||||
color: theme.colorScheme.outline,
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
},
|
||||
),
|
||||
),
|
||||
);
|
||||
},
|
||||
),
|
||||
),
|
||||
),
|
||||
|
||||
Reference in New Issue
Block a user