show last avatar if avatar loading

This commit is contained in:
Henry Hiles 2026-05-26 12:07:35 -04:00
commit d9f62a9de9
Signed by: Henry-Hiles
SSH key fingerprint: SHA256:VKQUdS31Q90KvX7EkKMHMBpUspcmItAh86a+v7PGiIs

View file

@ -1,7 +1,6 @@
import "package:flutter/material.dart";
import "package:flutter_riverpod/flutter_riverpod.dart";
import "package:nexus/controllers/author_controller.dart";
import "package:nexus/helpers/extensions/better_when.dart";
import "package:nexus/helpers/extensions/get_localpart.dart";
import "package:nexus/helpers/extensions/show_user_popover.dart";
import "package:nexus/models/event.dart";
@ -13,24 +12,22 @@ class MessageAvatar extends ConsumerWidget {
const MessageAvatar(this.event, {this.height = 24, super.key});
@override
Widget build(BuildContext context, WidgetRef ref) => ref
.watch(AuthorController.provider(event))
.betterWhen(
data: (membership) => InkWell(
Widget build(BuildContext context, WidgetRef ref) =>
switch (ref.watch(AuthorController.provider(event))) {
AsyncData(:final value) || AsyncLoading(:final value?) => InkWell(
onTapUp: (details) {
context.showUserPopover(
membership,
value,
event.sender,
globalPosition: details.globalPosition,
);
},
child: AvatarOrHash(
membership.avatarUrl,
membership.displayName ?? event.sender.localpart,
value.avatarUrl,
value.displayName ?? event.sender.localpart,
height: height,
),
),
loading: () =>
AvatarOrHash(null, event.sender.localpart, height: height),
);
_ => AvatarOrHash(null, event.sender.localpart, height: height),
};
}