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