show last avatar if avatar loading
This commit is contained in:
parent
32dd08fd91
commit
d9f62a9de9
1 changed files with 8 additions and 11 deletions
|
|
@ -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),
|
};
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue