lemmur-app-android/lib/pages/users_list.dart

64 lines
1.7 KiB
Dart

import 'package:flutter/material.dart';
import 'package:lemmy_api_client/v3.dart';
import '../util/extensions/api.dart';
import '../util/goto.dart';
import '../widgets/avatar.dart';
import '../widgets/infinite_scroll.dart';
import '../widgets/markdown_text.dart';
/// Infinite list of Users fetched by the given fetcher
class UsersListPage extends StatelessWidget {
final String title;
final Fetcher<PersonViewSafe> fetcher;
const UsersListPage({Key? key, required this.fetcher, this.title = ''})
: super(key: key);
@override
Widget build(BuildContext context) {
final theme = Theme.of(context);
return Scaffold(
appBar: AppBar(
backgroundColor: theme.cardColor,
title: Text(title),
),
body: InfiniteScroll<PersonViewSafe>(
fetcher: fetcher,
itemBuilder: (user) => Column(
children: [
const Divider(),
UsersListItem(user: user),
],
),
uniqueProp: (user) => user.person.actorId,
),
);
}
}
class UsersListItem extends StatelessWidget {
final PersonViewSafe user;
const UsersListItem({Key? key, required this.user}) : super(key: key);
@override
Widget build(BuildContext context) {
return ListTile(
title: Text(user.person.originPreferredName),
subtitle: user.person.bio != null
? Opacity(
opacity: 0.7,
child: MarkdownText(
user.person.bio!,
instanceHost: user.instanceHost,
),
)
: null,
onTap: () => goToUser.fromPersonSafe(context, user.person),
leading: Avatar(url: user.person.avatar),
);
}
}