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 {
|
|
|
|
const PartnerList({Key? key, required this.partner}) : super(key: key);
|
|
|
|
|
|
|
|
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(
|
|
|
|
contentPadding: const EdgeInsets.symmetric(horizontal: 12.0),
|
|
|
|
leading: userAvatar(context, p, radius: 30),
|
2023-06-29 05:33:57 +02:00
|
|
|
title: Text(
|
2023-11-12 02:03:32 +01:00
|
|
|
"${p.name}'s photos",
|
2023-06-29 05:33:57 +02:00
|
|
|
style: TextStyle(
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
fontSize: 14,
|
2023-11-09 17:19:53 +01:00
|
|
|
color: context.primaryColor,
|
2023-06-29 05:33:57 +02:00
|
|
|
),
|
|
|
|
),
|
2023-11-09 17:19:53 +01:00
|
|
|
onTap: () => context.autoPush((PartnerDetailRoute(partner: p))),
|
2023-05-25 05:52:43 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|