mirror of
https://github.com/gabehf/Fladder.git
synced 2026-03-07 13:38:13 -08:00
55 lines
1.8 KiB
Dart
55 lines
1.8 KiB
Dart
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
|
|
|
import 'package:fladder/models/item_base_model.dart';
|
|
import 'package:fladder/models/settings/home_settings_model.dart';
|
|
import 'package:fladder/providers/settings/home_settings_provider.dart';
|
|
import 'package:fladder/screens/shared/animated_fade_size.dart';
|
|
import 'package:fladder/screens/shared/media/carousel_banner.dart';
|
|
import 'package:fladder/screens/shared/media/detailed_banner.dart';
|
|
import 'package:fladder/screens/shared/media/media_banner.dart';
|
|
|
|
class HomeBannerWidget extends ConsumerWidget {
|
|
final List<ItemBaseModel> posters;
|
|
final Function(ItemBaseModel selected) onSelect;
|
|
|
|
const HomeBannerWidget({
|
|
required this.posters,
|
|
required this.onSelect,
|
|
super.key,
|
|
});
|
|
|
|
@override
|
|
Widget build(BuildContext context, WidgetRef ref) {
|
|
final bannerType = ref.watch(homeSettingsProvider.select((value) => value.homeBanner));
|
|
final maxHeight = (MediaQuery.sizeOf(context).shortestSide * 0.6).clamp(125.0, 375.0);
|
|
|
|
return switch (bannerType) {
|
|
HomeBanner.carousel => Column(
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: [
|
|
CarouselBanner(
|
|
items: posters,
|
|
maxHeight: maxHeight,
|
|
),
|
|
const SizedBox(height: 24)
|
|
],
|
|
),
|
|
HomeBanner.banner => Padding(
|
|
padding: const EdgeInsets.symmetric(horizontal: 6),
|
|
child: MediaBanner(
|
|
items: posters,
|
|
maxHeight: maxHeight,
|
|
),
|
|
),
|
|
HomeBanner.detailedBanner => AnimatedFadeSize(
|
|
child: DetailedBanner(
|
|
posters: posters,
|
|
onSelect: onSelect,
|
|
),
|
|
),
|
|
_ => const SizedBox.shrink(),
|
|
};
|
|
}
|
|
}
|