mirror of
				https://github.com/immich-app/immich.git
				synced 2025-11-03 19:17:11 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			62 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
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/widgets/map/map_settings/map_settings_list_tile.dart';
 | 
						|
import 'package:immich_mobile/widgets/map/map_settings/map_settings_time_dropdown.dart';
 | 
						|
import 'package:immich_mobile/widgets/map/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),
 | 
						|
            ],
 | 
						|
          ),
 | 
						|
        ),
 | 
						|
      ),
 | 
						|
    );
 | 
						|
  }
 | 
						|
}
 |