refactor(ui): Update users list to allow showing avatars in the future

This commit is contained in:
Inex Code 2024-11-11 05:45:20 +03:00
parent 8b811caa75
commit 9fda021c67
3 changed files with 27 additions and 31 deletions

View file

@ -1,6 +1,5 @@
import 'package:auto_route/auto_route.dart'; import 'package:auto_route/auto_route.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:selfprivacy/config/brand_theme.dart';
import 'package:selfprivacy/logic/models/hive/user.dart'; import 'package:selfprivacy/logic/models/hive/user.dart';
import 'package:selfprivacy/ui/router/router.dart'; import 'package:selfprivacy/ui/router/router.dart';
@ -14,26 +13,17 @@ class UserListItem extends StatelessWidget {
final User user; final User user;
final bool isPrimaryUser; final bool isPrimaryUser;
@override @override
Widget build(final BuildContext context) => InkWell( Widget build(final BuildContext context) => ListTile(
onTap: () { onTap: () {
context.pushRoute(UserDetailsRoute(login: user.login)); context.pushRoute(UserDetailsRoute(login: user.login));
}, },
child: Container( leading: CircleAvatar(
padding: paddingH16V0, backgroundColor: user.color,
height: 48,
child: Row(
children: [
Container(
width: 17,
height: 17,
decoration: BoxDecoration(
color: user.color,
shape: BoxShape.circle,
),
),
const SizedBox(width: 20),
Flexible(
child: Text( child: Text(
user.login[0].toUpperCase(),
),
),
title: Text(
user.login, user.login,
style: Theme.of(context).textTheme.titleMedium?.copyWith( style: Theme.of(context).textTheme.titleMedium?.copyWith(
color: Theme.of(context).colorScheme.onSurface, color: Theme.of(context).colorScheme.onSurface,
@ -44,9 +34,5 @@ class UserListItem extends StatelessWidget {
: TextDecoration.lineThrough, : TextDecoration.lineThrough,
), ),
), ),
),
],
),
),
); );
} }

View file

@ -56,6 +56,12 @@ class UserDetailsPage extends StatelessWidget {
hasBackButton: true, hasBackButton: true,
hasFlashButton: true, hasFlashButton: true,
heroTitle: user.login, heroTitle: user.login,
heroIconWidget: CircleAvatar(
backgroundColor: user.color,
child: Text(
user.login[0].toUpperCase(),
),
),
children: [ children: [
_UserLogins(user: user, domainName: domainName), _UserLogins(user: user, domainName: domainName),
const SizedBox(height: 8), const SizedBox(height: 8),

View file

@ -92,7 +92,10 @@ class UsersPage extends StatelessWidget {
), ),
], ],
Padding( Padding(
padding: const EdgeInsets.all(8.0), padding: const EdgeInsets.symmetric(
horizontal: 16.0,
vertical: 8.0,
),
child: FilledButton.tonal( child: FilledButton.tonal(
child: Row( child: Row(
crossAxisAlignment: CrossAxisAlignment.center, crossAxisAlignment: CrossAxisAlignment.center,
@ -111,6 +114,7 @@ class UsersPage extends StatelessWidget {
Expanded( Expanded(
child: ListView.builder( child: ListView.builder(
itemCount: users.length, itemCount: users.length,
padding: const EdgeInsets.symmetric(horizontal: 16),
itemBuilder: itemBuilder:
(final BuildContext context, final int index) => (final BuildContext context, final int index) =>
UserListItem( UserListItem(