2024-01-05 05:20:55 +00:00
|
|
|
import 'package:auto_route/auto_route.dart';
|
2023-05-25 05:52:43 +02:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
2023-11-09 16:19:53 +00:00
|
|
|
import 'package:immich_mobile/extensions/build_context_extensions.dart';
|
2023-05-25 05:52:43 +02:00
|
|
|
import 'package:immich_mobile/routing/router.dart';
|
|
|
|
import 'package:immich_mobile/shared/models/user.dart';
|
|
|
|
import 'package:immich_mobile/shared/ui/user_avatar.dart';
|
|
|
|
|
|
|
|
class PartnerList extends HookConsumerWidget {
|
2024-01-27 16:14:32 +00:00
|
|
|
const PartnerList({super.key, required this.partner});
|
2023-05-25 05:52:43 +02:00
|
|
|
|
|
|
|
final List<User> partner;
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context, WidgetRef ref) {
|
|
|
|
return SliverList(
|
|
|
|
delegate:
|
|
|
|
SliverChildBuilderDelegate(listEntry, childCount: partner.length),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
Widget listEntry(BuildContext context, int index) {
|
|
|
|
final User p = partner[index];
|
|
|
|
return ListTile(
|
2023-11-11 23:02:26 -06:00
|
|
|
contentPadding: const EdgeInsets.only(
|
|
|
|
left: 12.0,
|
|
|
|
right: 18.0,
|
|
|
|
),
|
|
|
|
leading: userAvatar(context, p, radius: 24),
|
2023-06-28 22:33:57 -05:00
|
|
|
title: Text(
|
2023-11-11 20:03:32 -05:00
|
|
|
"${p.name}'s photos",
|
2023-11-20 08:58:03 -06:00
|
|
|
style: context.textTheme.labelLarge,
|
2023-11-11 23:02:26 -06:00
|
|
|
),
|
|
|
|
trailing: Text(
|
|
|
|
"View all",
|
2023-11-20 08:58:03 -06:00
|
|
|
style: context.textTheme.labelLarge?.copyWith(
|
2023-11-09 16:19:53 +00:00
|
|
|
color: context.primaryColor,
|
2023-06-28 22:33:57 -05:00
|
|
|
),
|
|
|
|
),
|
2024-01-05 05:20:55 +00:00
|
|
|
onTap: () => context.pushRoute((PartnerDetailRoute(partner: p))),
|
2023-05-25 05:52:43 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|