mirror of
https://github.com/immich-app/immich.git
synced 2026-06-04 13:15:22 -04:00
111 lines
4.5 KiB
Dart
111 lines
4.5 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
import 'package:immich_mobile/domain/models/time_range.model.dart';
|
|
import 'package:immich_mobile/extensions/translate_extensions.dart';
|
|
import 'package:immich_mobile/generated/translations.g.dart';
|
|
import 'package:immich_mobile/presentation/widgets/map/map.state.dart';
|
|
import 'package:immich_mobile/widgets/map/map_settings/map_custom_time_range.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 DriftMapSettingsSheet extends ConsumerStatefulWidget {
|
|
const DriftMapSettingsSheet({super.key});
|
|
|
|
@override
|
|
ConsumerState<DriftMapSettingsSheet> createState() => _DriftMapSettingsSheetState();
|
|
}
|
|
|
|
class _DriftMapSettingsSheetState extends ConsumerState<DriftMapSettingsSheet> {
|
|
late bool useCustomRange;
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
final mapState = ref.read(mapStateProvider);
|
|
final timeRange = mapState.timeRange;
|
|
useCustomRange = timeRange.from.isSome || timeRange.to.isSome;
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final mapState = ref.watch(mapStateProvider);
|
|
|
|
return DraggableScrollableSheet(
|
|
expand: false,
|
|
initialChildSize: useCustomRange ? 0.7 : 0.6,
|
|
builder: (ctx, scrollController) => SingleChildScrollView(
|
|
controller: scrollController,
|
|
child: Card(
|
|
elevation: 0.0,
|
|
shadowColor: Colors.transparent,
|
|
color: Colors.transparent,
|
|
margin: EdgeInsets.zero,
|
|
child: Column(
|
|
mainAxisSize: MainAxisSize.max,
|
|
children: [
|
|
MapThemePicker(
|
|
themeMode: mapState.themeMode,
|
|
onThemeChange: (mode) => ref.read(mapStateProvider.notifier).switchTheme(mode),
|
|
),
|
|
const Divider(height: 30, thickness: 1),
|
|
MapSettingsListTile(
|
|
title: "map_settings_only_show_favorites".t(context: context),
|
|
selected: mapState.onlyFavorites,
|
|
onChanged: (favoriteOnly) => ref.read(mapStateProvider.notifier).switchFavoriteOnly(favoriteOnly),
|
|
),
|
|
MapSettingsListTile(
|
|
title: "map_settings_include_show_archived".t(context: context),
|
|
selected: mapState.includeArchived,
|
|
onChanged: (includeArchive) =>
|
|
ref.read(mapStateProvider.notifier).switchIncludeArchived(includeArchive),
|
|
),
|
|
MapSettingsListTile(
|
|
title: "map_settings_include_show_partners".t(context: context),
|
|
selected: mapState.withPartners,
|
|
onChanged: (withPartners) => ref.read(mapStateProvider.notifier).switchWithPartners(withPartners),
|
|
),
|
|
if (useCustomRange) ...[
|
|
MapTimeRange(
|
|
timeRange: mapState.timeRange,
|
|
onChanged: (range) {
|
|
ref.read(mapStateProvider.notifier).setTimeRange(range);
|
|
},
|
|
),
|
|
Align(
|
|
alignment: Alignment.centerLeft,
|
|
child: TextButton(
|
|
onPressed: () => setState(() {
|
|
useCustomRange = false;
|
|
ref.read(mapStateProvider.notifier).setRelativeTime(0);
|
|
ref.read(mapStateProvider.notifier).setTimeRange(const TimeRange());
|
|
}),
|
|
child: Text(context.t.remove_custom_date_range),
|
|
),
|
|
),
|
|
] else ...[
|
|
MapTimeDropDown(
|
|
relativeTime: mapState.relativeDays,
|
|
onTimeChange: (time) => ref.read(mapStateProvider.notifier).setRelativeTime(time),
|
|
),
|
|
Align(
|
|
alignment: Alignment.centerLeft,
|
|
child: TextButton(
|
|
onPressed: () => setState(() {
|
|
useCustomRange = true;
|
|
ref.read(mapStateProvider.notifier).setRelativeTime(0);
|
|
ref.read(mapStateProvider.notifier).setTimeRange(const TimeRange());
|
|
}),
|
|
child: Text(context.t.use_custom_date_range),
|
|
),
|
|
),
|
|
],
|
|
const SizedBox(height: 20),
|
|
],
|
|
),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|