fix: space bottom bar with group/DM separation

- allow group/DM separation for space bottom bar/drawer
- fix unscrollable overflow of room list

Signed-off-by: TheOneWithTheBraid <the-one@with-the-braid.cf>
This commit is contained in:
TheOneWithTheBraid 2022-05-05 08:54:58 +02:00
parent bfbf425663
commit beb3ae9be3
5 changed files with 57 additions and 72 deletions

View File

@ -80,9 +80,11 @@ class _ChatListViewBodyState extends State<ChatListViewBody> {
.shouldShowStoriesHeader(context); .shouldShowStoriesHeader(context);
child = ListView.builder( child = ListView.builder(
key: ValueKey(Matrix.of(context).client.userID.toString() + key: ValueKey(Matrix.of(context).client.userID.toString() +
widget.controller.activeSpaceId.toString()), widget.controller.activeSpaceId.toString() +
widget.controller.activeSpacesEntry.runtimeType.toString()),
controller: widget.controller.scrollController, controller: widget.controller.scrollController,
itemCount: rooms.length + (displayStoriesHeader ? 1 : 0), // add +1 space below in order to properly scroll below the spaces bar
itemCount: rooms.length + (displayStoriesHeader ? 2 : 1),
itemBuilder: (BuildContext context, int i) { itemBuilder: (BuildContext context, int i) {
if (displayStoriesHeader) { if (displayStoriesHeader) {
if (i == 0) { if (i == 0) {
@ -90,6 +92,9 @@ class _ChatListViewBodyState extends State<ChatListViewBody> {
} }
i--; i--;
} }
if (i >= rooms.length) {
return const ListTile();
}
return ChatListItem( return ChatListItem(
rooms[i], rooms[i],
selected: widget.controller.selectedRoomIds.contains(rooms[i].id), selected: widget.controller.selectedRoomIds.contains(rooms[i].id),

View File

@ -94,11 +94,10 @@ class _SpacesBottomNavigation extends StatelessWidget {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
final currentIndex = controller.activeSpaceId == null final currentIndex = controller.spacesEntries.indexWhere((space) =>
? 1 controller.activeSpacesEntry.runtimeType == space.runtimeType &&
: controller.spaces (controller.activeSpaceId == space.getSpace(context)?.id)) +
.indexWhere((space) => controller.activeSpaceId == space.id) + 1;
2;
return Container( return Container(
height: 56, height: 56,
@ -110,14 +109,9 @@ class _SpacesBottomNavigation extends StatelessWidget {
currentIndex: currentIndex, currentIndex: currentIndex,
onTap: (i) => i == 0 onTap: (i) => i == 0
? controller.expandSpaces() ? controller.expandSpaces()
: i == 1
? controller.setActiveSpacesEntry(
context,
null,
)
: controller.setActiveSpacesEntry( : controller.setActiveSpacesEntry(
context, context,
controller.spacesEntries[i], controller.spacesEntries[i - 1],
), ),
selectedItemColor: Theme.of(context).colorScheme.primary, selectedItemColor: Theme.of(context).colorScheme.primary,
items: [ items: [

View File

@ -13,11 +13,9 @@ class SpacesDrawer extends StatelessWidget {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
final currentIndex = controller.activeSpaceId == null final currentIndex = controller.spacesEntries.indexWhere((space) =>
? 0 controller.activeSpacesEntry.runtimeType == space.runtimeType &&
: controller.spaces (controller.activeSpaceId == space.getSpace(context)?.id));
.indexWhere((space) => controller.activeSpaceId == space.id) +
1;
final Map<SpacesEntry, dynamic> spaceHierarchy = final Map<SpacesEntry, dynamic> spaceHierarchy =
Map.fromEntries(controller.spacesEntries.map((e) => MapEntry(e, null))); Map.fromEntries(controller.spacesEntries.map((e) => MapEntry(e, null)));
@ -30,35 +28,27 @@ class SpacesDrawer extends StatelessWidget {
return false; return false;
}, },
child: Column( child: Column(
children: List.generate( children: List.generate(spaceHierarchy.length, (index) {
spaceHierarchy.length,
(index) {
if (index == 0) {
return ListTile(
selected: currentIndex == index,
leading: const Icon(Icons.keyboard_arrow_down),
title: Text(L10n.of(context)!.allChats),
onTap: () => controller.setActiveSpacesEntry(
context,
null,
),
);
} else {
final space = spaceHierarchy.keys.toList()[index]; final space = spaceHierarchy.keys.toList()[index];
final room = space.getSpace(context)!; final room = space.getSpace(context);
final active = currentIndex == index;
return ListTile( return ListTile(
selected: currentIndex == index, selected: active,
leading: Avatar( leading: index == 0
? const Icon(Icons.keyboard_arrow_down)
: room == null
? space.getIcon(active)
: Avatar(
mxContent: room.avatar, mxContent: room.avatar,
name: space.getName(context), name: space.getName(context),
size: 24, size: 24,
fontSize: 12, fontSize: 12,
), ),
title: Text(space.getName(context)), title: Text(space.getName(context)),
subtitle: room.topic.isEmpty subtitle: room?.topic.isEmpty ?? true
? null ? null
: Tooltip( : Tooltip(
message: room.topic, message: room!.topic,
child: Text( child: Text(
room.topic.replaceAll('\n', ' '), room.topic.replaceAll('\n', ' '),
softWrap: false, softWrap: false,
@ -69,15 +59,15 @@ class SpacesDrawer extends StatelessWidget {
context, context,
space, space,
), ),
trailing: IconButton( trailing: room != null
? IconButton(
icon: const Icon(Icons.edit), icon: const Icon(Icons.edit),
tooltip: L10n.of(context)!.edit, tooltip: L10n.of(context)!.edit,
onPressed: () => controller.editSpace(context, room.id), onPressed: () => controller.editSpace(context, room.id),
), )
: null,
); );
} }),
},
),
), ),
); );
} }

View File

@ -9,7 +9,6 @@
#include <connectivity_plus_windows/connectivity_plus_windows_plugin.h> #include <connectivity_plus_windows/connectivity_plus_windows_plugin.h>
#include <desktop_drop/desktop_drop_plugin.h> #include <desktop_drop/desktop_drop_plugin.h>
#include <desktop_lifecycle/desktop_lifecycle_plugin.h> #include <desktop_lifecycle/desktop_lifecycle_plugin.h>
#include <file_selector_windows/file_selector_plugin.h>
#include <flutter_secure_storage_windows/flutter_secure_storage_windows_plugin.h> #include <flutter_secure_storage_windows/flutter_secure_storage_windows_plugin.h>
#include <flutter_webrtc/flutter_web_r_t_c_plugin.h> #include <flutter_webrtc/flutter_web_r_t_c_plugin.h>
#include <permission_handler_windows/permission_handler_windows_plugin.h> #include <permission_handler_windows/permission_handler_windows_plugin.h>
@ -22,8 +21,6 @@ void RegisterPlugins(flutter::PluginRegistry* registry) {
registry->GetRegistrarForPlugin("DesktopDropPlugin")); registry->GetRegistrarForPlugin("DesktopDropPlugin"));
DesktopLifecyclePluginRegisterWithRegistrar( DesktopLifecyclePluginRegisterWithRegistrar(
registry->GetRegistrarForPlugin("DesktopLifecyclePlugin")); registry->GetRegistrarForPlugin("DesktopLifecyclePlugin"));
FileSelectorPluginRegisterWithRegistrar(
registry->GetRegistrarForPlugin("FileSelectorPlugin"));
FlutterSecureStorageWindowsPluginRegisterWithRegistrar( FlutterSecureStorageWindowsPluginRegisterWithRegistrar(
registry->GetRegistrarForPlugin("FlutterSecureStorageWindowsPlugin")); registry->GetRegistrarForPlugin("FlutterSecureStorageWindowsPlugin"));
FlutterWebRTCPluginRegisterWithRegistrar( FlutterWebRTCPluginRegisterWithRegistrar(

View File

@ -6,7 +6,6 @@ list(APPEND FLUTTER_PLUGIN_LIST
connectivity_plus_windows connectivity_plus_windows
desktop_drop desktop_drop
desktop_lifecycle desktop_lifecycle
file_selector_windows
flutter_secure_storage_windows flutter_secure_storage_windows
flutter_webrtc flutter_webrtc
permission_handler_windows permission_handler_windows