import 'package:flutter/material.dart'; import 'package:hooks_riverpod/hooks_riverpod.dart'; import 'package:immich_mobile/providers/map/map_state.provider.dart'; import 'package:immich_mobile/modules/map/widgets/map_settings/map_settings_list_tile.dart'; import 'package:immich_mobile/modules/map/widgets/map_settings/map_settings_time_dropdown.dart'; import 'package:immich_mobile/modules/map/widgets/map_settings/map_theme_picker.dart'; class MapSettingsSheet extends HookConsumerWidget { const MapSettingsSheet({super.key}); @override Widget build(BuildContext context, WidgetRef ref) { final mapState = ref.watch(mapStateNotifierProvider); return DraggableScrollableSheet( expand: false, initialChildSize: 0.6, builder: (ctx, scrollController) => SingleChildScrollView( controller: scrollController, child: Card( elevation: 0.0, shadowColor: Colors.transparent, margin: EdgeInsets.zero, child: Column( mainAxisSize: MainAxisSize.max, children: [ MapThemePicker( themeMode: mapState.themeMode, onThemeChange: (mode) => ref .read(mapStateNotifierProvider.notifier) .switchTheme(mode), ), const Divider(height: 30, thickness: 2), MapSettingsListTile( title: "map_settings_only_show_favorites", selected: mapState.showFavoriteOnly, onChanged: (favoriteOnly) => ref .read(mapStateNotifierProvider.notifier) .switchFavoriteOnly(favoriteOnly), ), MapSettingsListTile( title: "map_settings_include_show_archived", selected: mapState.includeArchived, onChanged: (includeArchive) => ref .read(mapStateNotifierProvider.notifier) .switchIncludeArchived(includeArchive), ), MapSettingsListTile( title: "map_settings_include_show_partners", selected: mapState.withPartners, onChanged: (withPartners) => ref .read(mapStateNotifierProvider.notifier) .switchWithPartners(withPartners), ), MapTimeDropDown( relativeTime: mapState.relativeTime, onTimeChange: (time) => ref .read(mapStateNotifierProvider.notifier) .setRelativeTime(time), ), const SizedBox(height: 20), ], ), ), ), ); } }