mirror of
https://github.com/immich-app/immich.git
synced 2025-12-22 01:11:20 +03:00
* feat: show "appears in" albums on asset viewer bottom sheet fix: multiple RemoteAlbumPages in navigation stack this also allows us to not have to set the current album before navigating to RemoteAlbumPage chore: clarification comments handle nested album pages fix: hide "appears in" when an asset is not in any albums fix: way more bottom padding for some reason we can't query the safe area here :/ * fix: bottom sheet now is usable when navigating to another asset viewer * fix: rebase conflict * fix: restore ancestors album to currentRemoteAlbumProvider when popping * fix: view flashing when dismissing a album viewer * chore: code review changes * fix: styling and padding * chore: rework currentRemoteAlbumProvider to be scoped by the Remote album page * fix: override remote album provider on required pages * chore: convert query to all SQL calls instead of matching in Dart * fix: album query * fix: unawaited future * Update deep_link.service.dart --------- Co-authored-by: Alex <alex.tran1502@gmail.com>
48 lines
1.6 KiB
Dart
48 lines
1.6 KiB
Dart
import 'package:auto_route/auto_route.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
import 'package:immich_mobile/providers/infrastructure/current_album.provider.dart';
|
|
import 'package:immich_mobile/providers/infrastructure/remote_album.provider.dart';
|
|
import 'package:immich_mobile/routing/router.dart';
|
|
import 'package:immich_mobile/widgets/common/user_circle_avatar.dart';
|
|
|
|
class RemoteAlbumSharedUserIcons extends ConsumerWidget {
|
|
const RemoteAlbumSharedUserIcons({super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context, WidgetRef ref) {
|
|
final currentAlbum = ref.watch(currentRemoteAlbumProvider);
|
|
if (currentAlbum == null) {
|
|
return const SizedBox();
|
|
}
|
|
|
|
final sharedUsersAsync = ref.watch(remoteAlbumSharedUsersProvider(currentAlbum.id));
|
|
|
|
return sharedUsersAsync.maybeWhen(
|
|
data: (sharedUsers) {
|
|
if (sharedUsers.isEmpty) {
|
|
return const SizedBox();
|
|
}
|
|
|
|
return GestureDetector(
|
|
onTap: () => context.pushRoute(DriftAlbumOptionsRoute(album: currentAlbum)),
|
|
child: SizedBox(
|
|
height: 50,
|
|
child: ListView.builder(
|
|
scrollDirection: Axis.horizontal,
|
|
itemBuilder: ((context, index) {
|
|
return Padding(
|
|
padding: const EdgeInsets.only(right: 4.0),
|
|
child: UserCircleAvatar(user: sharedUsers[index], radius: 18, size: 36, hasBorder: true),
|
|
);
|
|
}),
|
|
itemCount: sharedUsers.length,
|
|
),
|
|
),
|
|
);
|
|
},
|
|
orElse: () => const SizedBox(),
|
|
);
|
|
}
|
|
}
|