refactor: Stories header with futurebuilder

This commit is contained in:
Krille 2023-01-02 17:12:24 +01:00
parent 09a74bf3ee
commit fd152baa28

View File

@ -115,14 +115,11 @@ class StoriesHeader extends StatelessWidget {
itemCount: stories.length, itemCount: stories.length,
itemBuilder: (context, i) { itemBuilder: (context, i) {
final room = stories[i]; final room = stories[i];
return FutureBuilder<Profile>( final creator = room
future: room.getCreatorProfile(), .unsafeGetUserFromMemoryOrFallback(room.creatorId ?? 'Unknown');
builder: (context, snapshot) {
final userId = room.creatorId; final userId = room.creatorId;
final displayname = snapshot.data?.displayName ?? final displayname = creator.calcDisplayname();
userId?.localpart ?? final avatarUrl = creator.avatarUrl;
'Unknown';
final avatarUrl = snapshot.data?.avatarUrl;
if (!displayname.toLowerCase().contains(filter.toLowerCase())) { if (!displayname.toLowerCase().contains(filter.toLowerCase())) {
return Container(); return Container();
} }
@ -140,7 +137,6 @@ class StoriesHeader extends StatelessWidget {
onPressed: () => _goToStoryAction(context, room.id), onPressed: () => _goToStoryAction(context, room.id),
onLongPressed: () => _contextualActions(context, room), onLongPressed: () => _contextualActions(context, room),
); );
});
}, },
), ),
); );
@ -148,9 +144,6 @@ class StoriesHeader extends StatelessWidget {
} }
extension on Room { extension on Room {
Future<Profile> getCreatorProfile() =>
client.getProfileFromUserId(getState(EventTypes.RoomCreate)!.senderId);
bool get hasPosts { bool get hasPosts {
if (membership == Membership.invite) return true; if (membership == Membership.invite) return true;
final lastEvent = this.lastEvent; final lastEvent = this.lastEvent;