2024-12-16 10:11:48 -06:00
|
|
|
import 'package:auto_route/auto_route.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_hooks/flutter_hooks.dart';
|
|
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
2025-03-12 19:26:56 +05:30
|
|
|
import 'package:immich_mobile/domain/models/user.model.dart';
|
2024-12-16 10:11:48 -06:00
|
|
|
import 'package:immich_mobile/providers/album/current_album.provider.dart';
|
|
|
|
import 'package:immich_mobile/routing/router.dart';
|
|
|
|
import 'package:immich_mobile/widgets/common/user_circle_avatar.dart';
|
|
|
|
|
|
|
|
class AlbumSharedUserIcons extends HookConsumerWidget {
|
|
|
|
const AlbumSharedUserIcons({super.key});
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context, WidgetRef ref) {
|
2025-03-12 19:26:56 +05:30
|
|
|
final sharedUsers = useRef<List<UserDto>>(const []);
|
2024-12-16 10:11:48 -06:00
|
|
|
sharedUsers.value = ref.watch(
|
|
|
|
currentAlbumProvider.select((album) {
|
|
|
|
if (album == null) {
|
|
|
|
return const [];
|
|
|
|
}
|
|
|
|
|
|
|
|
if (album.sharedUsers.length == sharedUsers.value.length) {
|
|
|
|
return sharedUsers.value;
|
|
|
|
}
|
|
|
|
|
2025-03-12 19:26:56 +05:30
|
|
|
return album.sharedUsers.map((u) => u.toDto()).toList(growable: false);
|
2024-12-16 10:11:48 -06:00
|
|
|
}),
|
|
|
|
);
|
|
|
|
|
|
|
|
if (sharedUsers.value.isEmpty) {
|
|
|
|
return const SizedBox();
|
|
|
|
}
|
|
|
|
|
|
|
|
return GestureDetector(
|
2025-01-16 21:20:44 -06:00
|
|
|
onTap: () => context.pushRoute(const AlbumOptionsRoute()),
|
2024-12-16 10:11:48 -06:00
|
|
|
child: SizedBox(
|
|
|
|
height: 50,
|
|
|
|
child: ListView.builder(
|
2025-06-05 00:41:28 +07:00
|
|
|
padding: const EdgeInsets.only(left: 16, bottom: 8),
|
2024-12-16 10:11:48 -06:00
|
|
|
scrollDirection: Axis.horizontal,
|
|
|
|
itemBuilder: ((context, index) {
|
|
|
|
return Padding(
|
|
|
|
padding: const EdgeInsets.only(right: 8.0),
|
|
|
|
child: UserCircleAvatar(
|
|
|
|
user: sharedUsers.value[index],
|
|
|
|
radius: 18,
|
|
|
|
size: 36,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}),
|
|
|
|
itemCount: sharedUsers.value.length,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|