mirror of
https://github.com/nostrlabs-io/zap-stream-flutter.git
synced 2025-06-15 11:48:21 +00:00
143 lines
3.2 KiB
Dart
143 lines
3.2 KiB
Dart
import 'package:flutter/widgets.dart';
|
|
import 'package:go_router/go_router.dart';
|
|
import 'package:ndk/ndk.dart';
|
|
import 'package:ndk/shared/nips/nip19/nip19.dart';
|
|
import 'package:zap_stream_flutter/const.dart';
|
|
import 'package:zap_stream_flutter/widgets/avatar.dart';
|
|
|
|
class ProfileLoaderWidget extends StatelessWidget {
|
|
final String pubkey;
|
|
final AsyncWidgetBuilder<Metadata?> builder;
|
|
|
|
const ProfileLoaderWidget(this.pubkey, this.builder, {super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return FutureBuilder(
|
|
key: super.key ?? Key("profile-loader:$pubkey"),
|
|
future: ndk.metadata.loadMetadata(pubkey),
|
|
builder: builder,
|
|
);
|
|
}
|
|
}
|
|
|
|
class ProfileNameWidget extends StatelessWidget {
|
|
final Metadata profile;
|
|
final TextStyle? style;
|
|
final bool? linkToProfile;
|
|
|
|
const ProfileNameWidget({
|
|
super.key,
|
|
required this.profile,
|
|
this.style,
|
|
this.linkToProfile,
|
|
});
|
|
|
|
static Widget pubkey(
|
|
String pubkey, {
|
|
Key? key,
|
|
TextStyle? style,
|
|
bool? linkToProfile,
|
|
}) {
|
|
return ProfileLoaderWidget(
|
|
pubkey,
|
|
(ctx, data) => ProfileNameWidget(
|
|
profile: data.data ?? Metadata(pubKey: pubkey),
|
|
style: style,
|
|
linkToProfile: linkToProfile,
|
|
),
|
|
key: key,
|
|
);
|
|
}
|
|
|
|
static String nameFromProfile(Metadata profile) {
|
|
if ((profile.displayName?.length ?? 0) > 0) {
|
|
return profile.displayName!;
|
|
}
|
|
if ((profile.name?.length ?? 0) > 0) {
|
|
return profile.name!;
|
|
}
|
|
return Nip19.encodeSimplePubKey(profile.pubKey);
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final inner = Text(
|
|
ProfileNameWidget.nameFromProfile(profile),
|
|
style: style,
|
|
);
|
|
if (linkToProfile ?? true) {
|
|
return GestureDetector(
|
|
onTap:
|
|
() => context.push(
|
|
"/p/${Nip19.encodePubKey(profile.pubKey)}",
|
|
extra: profile,
|
|
),
|
|
child: inner,
|
|
);
|
|
} else {
|
|
return inner;
|
|
}
|
|
}
|
|
}
|
|
|
|
class ProfileWidget extends StatelessWidget {
|
|
final Metadata profile;
|
|
final TextStyle? style;
|
|
final double? size;
|
|
final List<Widget>? children;
|
|
final bool? showName;
|
|
final double? spacing;
|
|
final bool? linkToProfile;
|
|
|
|
const ProfileWidget({
|
|
super.key,
|
|
required this.profile,
|
|
this.style,
|
|
this.size,
|
|
this.children,
|
|
this.showName,
|
|
this.spacing,
|
|
this.linkToProfile,
|
|
});
|
|
|
|
static Widget pubkey(
|
|
String pubkey, {
|
|
double? size,
|
|
List<Widget>? children,
|
|
bool? showName,
|
|
double? spacing,
|
|
Key? key,
|
|
bool? linkToProfile,
|
|
}) {
|
|
return ProfileLoaderWidget(pubkey, (ctx, state) {
|
|
return ProfileWidget(
|
|
profile: state.data ?? Metadata(pubKey: pubkey),
|
|
size: size,
|
|
showName: showName,
|
|
spacing: spacing,
|
|
key: key,
|
|
linkToProfile: linkToProfile,
|
|
children: children,
|
|
);
|
|
});
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Row(
|
|
spacing: spacing ?? 8,
|
|
children: [
|
|
AvatarWidget(profile: profile, size: size),
|
|
if (showName ?? true)
|
|
ProfileNameWidget(
|
|
profile: profile,
|
|
key: key,
|
|
linkToProfile: linkToProfile,
|
|
),
|
|
...(children ?? []),
|
|
],
|
|
);
|
|
}
|
|
}
|