Files
PiliPlus/lib/pages/search_panel/all/view.dart
bggRGjQaUbCoE 55733d30c5 opt ui
Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
2025-08-16 18:34:55 +08:00

106 lines
3.8 KiB
Dart

import 'package:PiliPlus/common/constants.dart';
import 'package:PiliPlus/common/skeleton/video_card_h.dart';
import 'package:PiliPlus/common/widgets/video_card/video_card_h.dart';
import 'package:PiliPlus/models/search/result.dart';
import 'package:PiliPlus/pages/search_panel/all/controller.dart';
import 'package:PiliPlus/pages/search_panel/all/widgets/pgc_card_v_search.dart';
import 'package:PiliPlus/pages/search_panel/pgc/widgets/item.dart';
import 'package:PiliPlus/pages/search_panel/user/widgets/item.dart';
import 'package:PiliPlus/pages/search_panel/view.dart';
import 'package:PiliPlus/utils/grid.dart';
import 'package:PiliPlus/utils/waterfall.dart';
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:waterfall_flow/waterfall_flow.dart'
hide SliverWaterfallFlowDelegateWithMaxCrossAxisExtent;
class SearchAllPanel extends CommonSearchPanel {
const SearchAllPanel({
super.key,
required super.keyword,
required super.tag,
required super.searchType,
});
@override
State<SearchAllPanel> createState() => _SearchAllPanelState();
}
class _SearchAllPanelState
extends CommonSearchPanelState<SearchAllPanel, SearchAllData, dynamic> {
@override
late final SearchAllController controller = Get.put(
SearchAllController(
keyword: widget.keyword,
searchType: widget.searchType,
tag: widget.tag,
),
tag: widget.searchType.name + widget.tag,
);
@override
Widget buildList(ThemeData theme, List<dynamic> list) {
return SliverWaterfallFlow(
gridDelegate: SliverWaterfallFlowDelegateWithMaxCrossAxisExtent(
maxCrossAxisExtent: Grid.smallCardWidth * 2,
crossAxisSpacing: StyleString.safeSpace,
),
delegate: SliverChildBuilderDelegate(
(_, index) {
if (index == list.length - 1) {
controller.onLoadMore();
}
return switch (list[index]) {
SearchVideoItemModel e => SizedBox(
height: 120,
child: VideoCardH(videoItem: e),
),
List<SearchPgcItemModel> e =>
e.length == 1
? SizedBox(
height: 160,
child: SearchPgcItem(item: e.first),
)
: SizedBox(
height:
Grid.smallCardWidth / 2 / 0.75 +
MediaQuery.textScalerOf(context).scale(60),
child: ListView.builder(
padding: const EdgeInsets.only(bottom: 7),
physics: const AlwaysScrollableScrollPhysics(),
scrollDirection: Axis.horizontal,
itemCount: e.length,
itemBuilder: (context, index) {
return Container(
width: Grid.smallCardWidth / 2,
margin: EdgeInsets.only(
left: StyleString.safeSpace,
right: index == e.length - 1
? StyleString.safeSpace
: 0,
),
child: PgcCardVSearch(item: e[index]),
);
},
),
),
SearchUserItemModel e => Padding(
padding: const EdgeInsets.only(bottom: 5),
child: SearchUserItem(item: e),
),
_ => const SizedBox.shrink(),
};
},
childCount: list.length,
),
);
}
@override
Widget get builLoading => SliverGrid.builder(
gridDelegate: Grid.videoCardHDelegate(context),
itemBuilder: (context, index) => const VideoCardHSkeleton(),
itemCount: 10,
);
}