2024-01-05 06:20:55 +01: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 17:19:53 +01: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 17:14:32 +01: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-12 06:02:26 +01:00
|
|
|
contentPadding: const EdgeInsets.only(
|
|
|
|
left: 12.0,
|
|
|
|
right: 18.0,
|
|
|
|
),
|
|
|
|
leading: userAvatar(context, p, radius: 24),
|
2023-06-29 05:33:57 +02:00
|
|
|
title: Text(
|
2023-11-12 02:03:32 +01:00
|
|
|
"${p.name}'s photos",
|
2023-11-20 15:58:03 +01:00
|
|
|
style: context.textTheme.labelLarge,
|
2023-11-12 06:02:26 +01:00
|
|
|
),
|
|
|
|
trailing: Text(
|
|
|
|
"View all",
|
2023-11-20 15:58:03 +01:00
|
|
|
style: context.textTheme.labelLarge?.copyWith(
|
2023-11-09 17:19:53 +01:00
|
|
|
color: context.primaryColor,
|
2023-06-29 05:33:57 +02:00
|
|
|
),
|
|
|
|
),
|
2024-01-05 06:20:55 +01:00
|
|
|
onTap: () => context.pushRoute((PartnerDetailRoute(partner: p))),
|
2023-05-25 05:52:43 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|