Files
PiliPlus/lib/pages/search_panel/live/view.dart
bggRGjQaUbCoE ca993df0c6 opt: get theme color
Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
2025-04-28 21:32:46 +08:00

63 lines
2.0 KiB
Dart

import 'package:PiliPlus/common/constants.dart';
import 'package:PiliPlus/models/search/result.dart';
import 'package:PiliPlus/pages/search_panel/controller.dart';
import 'package:PiliPlus/pages/search_panel/live/widgets/item.dart';
import 'package:PiliPlus/pages/search_panel/view.dart';
import 'package:PiliPlus/utils/grid.dart';
import 'package:flutter/material.dart';
import 'package:get/get.dart';
class SearchLivePanel extends CommonSearchPanel {
const SearchLivePanel({
super.key,
required super.keyword,
required super.tag,
required super.searchType,
});
@override
State<SearchLivePanel> createState() => _SearchLivePanelState();
}
class _SearchLivePanelState extends CommonSearchPanelState<SearchLivePanel,
SearchLiveModel, SearchLiveItemModel> {
@override
late final controller = Get.put(
SearchPanelController<SearchLiveModel, SearchLiveItemModel>(
keyword: widget.keyword,
searchType: widget.searchType,
tag: widget.tag,
),
tag: widget.searchType.name + widget.tag,
);
@override
Widget buildList(ThemeData theme, List<SearchLiveItemModel> list) {
return SliverPadding(
padding: EdgeInsets.only(
left: StyleString.safeSpace,
right: StyleString.safeSpace,
bottom: MediaQuery.paddingOf(context).bottom + 80,
),
sliver: SliverGrid(
gridDelegate: SliverGridDelegateWithExtentAndRatio(
maxCrossAxisExtent: Grid.smallCardWidth,
crossAxisSpacing: StyleString.safeSpace,
mainAxisSpacing: StyleString.safeSpace,
childAspectRatio: StyleString.aspectRatio,
mainAxisExtent: MediaQuery.textScalerOf(context).scale(80),
),
delegate: SliverChildBuilderDelegate(
(context, index) {
if (index == list.length - 1) {
controller.onLoadMore();
}
return LiveItem(liveItem: list[index]);
},
childCount: list.length,
),
),
);
}
}