conditionally show room avatar in header

This commit is contained in:
Henry Hiles 2025-11-14 17:27:43 -05:00
commit f0a397f576
No known key found for this signature in database
7 changed files with 110 additions and 95 deletions

View file

@ -1,3 +1,4 @@
import "package:flutter/material.dart";
import "package:flutter/widgets.dart";
import "package:flutter_chat_core/flutter_chat_core.dart";
import "package:flutter_riverpod/flutter_riverpod.dart";
@ -118,3 +119,9 @@ extension ToMessage on Event {
};
}
}
extension ToTheme on ColorScheme {
ThemeData get theme => ThemeData.from(
colorScheme: this,
).copyWith(appBarTheme: AppBarTheme(titleSpacing: 0));
}

View file

@ -1,4 +1,5 @@
import "package:flutter_riverpod/flutter_riverpod.dart";
import "package:nexus/helpers/extension_helper.dart";
import "package:nexus/widgets/room_chat.dart";
import "package:nexus/widgets/sidebar.dart";
import "package:scaled_app/scaled_app.dart";
@ -31,18 +32,16 @@ class App extends StatelessWidget {
return MaterialApp(
debugShowCheckedModeBanner: false,
theme: ThemeData.from(
colorScheme:
lightDynamic ?? ColorScheme.fromSeed(seedColor: Colors.indigo),
),
darkTheme: ThemeData.from(
colorScheme:
darkDynamic ??
theme:
(lightDynamic ?? ColorScheme.fromSeed(seedColor: Colors.indigo))
.theme,
darkTheme:
(darkDynamic ??
ColorScheme.fromSeed(
seedColor: Colors.indigo,
brightness: Brightness.dark,
),
),
))
.theme,
home: Scaffold(
body: Builder(
builder: (context) => Row(

View file

@ -26,6 +26,7 @@ class AvatarOrHash extends StatelessWidget {
borderRadius: BorderRadius.all(Radius.circular(4)),
child: SizedBox(
height: height,
width: height,
child: avatar == null
? fallback ?? box
: Image.network(

View file

@ -11,15 +11,29 @@ class MemberList extends ConsumerWidget {
const MemberList(this.room, {super.key});
@override
Widget build(BuildContext context, WidgetRef ref) => ColoredBox(
color: Theme.of(context).colorScheme.surfaceContainerLow,
child: SizedBox(
width: 240,
Widget build(BuildContext context, WidgetRef ref) => Drawer(
shape: Border(),
child: ref
.watch(MembersController.provider(room))
.betterWhen(
data: (members) => ListView(
children: [
AppBar(
scrolledUnderElevation: 0,
backgroundColor: Theme.of(
context,
).colorScheme.surfaceContainerLow,
leading: Icon(Icons.people),
title: Text("Members"),
actionsPadding: EdgeInsets.only(right: 4),
actions: [
if (Scaffold.of(context).hasEndDrawer)
IconButton(
onPressed: Scaffold.of(context).closeEndDrawer,
icon: Icon(Icons.close),
),
],
),
...members
.where(
(membership) =>
@ -48,6 +62,5 @@ class MemberList extends ConsumerWidget {
],
),
),
),
);
}

View file

@ -8,8 +8,8 @@ import "package:nexus/widgets/avatar_or_hash.dart";
class RoomAppbar extends StatelessWidget implements PreferredSizeWidget {
final bool isDesktop;
final FullRoom room;
final VoidCallback onOpenMemberList;
final VoidCallback onOpenDrawer;
final void Function(BuildContext context) onOpenMemberList;
final void Function(BuildContext context) onOpenDrawer;
const RoomAppbar(
this.room, {
required this.isDesktop,
@ -23,24 +23,22 @@ class RoomAppbar extends StatelessWidget implements PreferredSizeWidget {
@override
AppBar build(BuildContext context) => AppBar(
leading: isDesktop ? null : DrawerButton(onPressed: onOpenDrawer),
actionsPadding: EdgeInsets.symmetric(horizontal: 8),
title: Row(
children: [
AvatarOrHash(
leading: isDesktop
? AvatarOrHash(
room.avatar,
room.title,
height: 32,
fallback: Icon(Icons.numbers),
headers: room.roomData.client.headers,
),
SizedBox(width: 12),
Expanded(
child: Column(
)
: DrawerButton(onPressed: () => onOpenDrawer(context)),
scrolledUnderElevation: 0,
backgroundColor: Theme.of(context).colorScheme.surfaceContainerLow,
actionsPadding: EdgeInsets.symmetric(horizontal: 8),
title: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(room.title, overflow: TextOverflow.ellipsis),
Text(
room.roomData.topic,
maxLines: 1,
@ -51,11 +49,11 @@ class RoomAppbar extends StatelessWidget implements PreferredSizeWidget {
),
],
),
),
],
),
actions: [
IconButton(onPressed: onOpenMemberList, icon: Icon(Icons.people)),
IconButton(
onPressed: () => onOpenMemberList(context),
icon: Icon(Icons.people),
),
if (!(Platform.isAndroid || Platform.isIOS))
IconButton(onPressed: () => exit(0), icon: Icon(Icons.close)),
],

View file

@ -58,9 +58,11 @@ class RoomChat extends HookConsumerWidget {
appBar: RoomAppbar(
room,
isDesktop: isDesktop,
onOpenDrawer: Scaffold.of(context).openDrawer,
onOpenMemberList: () =>
memberListOpened.value = !memberListOpened.value,
onOpenDrawer: (_) => Scaffold.of(context).openDrawer(),
onOpenMemberList: (thisContext) {
memberListOpened.value = !memberListOpened.value;
Scaffold.of(thisContext).openEndDrawer();
},
),
body: Row(
children: [
@ -245,9 +247,11 @@ class RoomChat extends HookConsumerWidget {
),
),
if (memberListOpened.value == true) MemberList(room.roomData),
if (memberListOpened.value == true && isDesktop)
MemberList(room.roomData),
],
),
endDrawer: isDesktop ? null : MemberList(room.roomData),
);
},
);

View file

@ -61,23 +61,16 @@ class Sidebar extends HookConsumerWidget {
return Scaffold(
backgroundColor: Colors.transparent,
appBar: AppBar(
title: Row(
children: [
AvatarOrHash(
leading: AvatarOrHash(
space.avatar,
fallback: space.icon,
space.title,
headers: space.client.headers,
),
SizedBox(width: 12),
Expanded(
child: Text(
title: Text(
space.title,
overflow: TextOverflow.ellipsis,
),
),
],
),
backgroundColor: Colors.transparent,
),
body: NavigationRail(