immich/mobile/lib/presentation/widgets/bottom_sheet/map_bottom_sheet.widget.dart
2025-07-30 11:37:38 -04:00

43 lines
1.4 KiB
Dart

import 'package:flutter/material.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:immich_mobile/presentation/widgets/bottom_sheet/base_bottom_sheet.widget.dart';
import 'package:immich_mobile/presentation/widgets/map/map.state.dart';
import 'package:immich_mobile/presentation/widgets/timeline/timeline.widget.dart';
import 'package:immich_mobile/providers/infrastructure/timeline.provider.dart';
import 'package:maplibre_gl/maplibre_gl.dart';
class MapBottomSheet extends ConsumerWidget {
const MapBottomSheet({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
LatLngBounds bounds = ref.watch(mapStateProvider.select((s) => s.bounds));
ref.listen(mapStateProvider, (previous, next) async {
bounds = next.bounds;
});
return ProviderScope(
overrides: [
// TODO: when ProviderScope changed, we should refresh timeline
timelineServiceProvider.overrideWith((ref) {
final timelineService =
ref.watch(timelineFactoryProvider).map(bounds);
ref.onDispose(timelineService.dispose);
return timelineService;
}),
],
child: const BaseBottomSheet(
initialChildSize: 0.25,
shouldCloseOnMinExtent: false,
actions: [],
slivers: [
SliverFillRemaining(
child: Timeline(),
),
],
),
);
}
}