init nostr and add userinfo provider

This commit is contained in:
DASHU
2025-07-22 19:07:51 +08:00
parent 08bb4c63b4
commit 1d918dac20
11 changed files with 930 additions and 88 deletions

View File

@@ -1,9 +1,20 @@
import 'package:flutter/material.dart';
import 'package:nostr_sdk/utils/string_util.dart';
import 'package:provider/provider.dart';
import '../../data/metadata.dart';
import '../../provider/userinfo_provider.dart';
import '../image_component.dart';
class UserPicComponent extends StatefulWidget {
String pubkey;
double width;
UserPicComponent({required this.width});
UserPicComponent({
required this.pubkey,
required this.width,
});
@override
State<StatefulWidget> createState() {
@@ -14,20 +25,37 @@ class UserPicComponent extends StatefulWidget {
class _UserPicComponent extends State<UserPicComponent> {
@override
Widget build(BuildContext context) {
Widget innerWidget = Icon(
Icons.account_circle,
size: widget.width,
);
return Selector<UserinfoProvider, Metadata?>(
builder: (context, metadata, child) {
Widget innerWidget = Icon(
Icons.account_circle,
size: widget.width,
);
return Container(
width: widget.width,
height: widget.width,
clipBehavior: Clip.hardEdge,
alignment: Alignment.center,
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(widget.width / 2),
),
child: innerWidget,
);
if (metadata != null && StringUtil.isNotBlank(metadata.picture)) {
innerWidget = ImageComponent(
imageUrl: metadata.picture!,
width: widget.width,
height: widget.width,
fit: BoxFit.cover,
placeholder: (context, url) => CircularProgressIndicator(),
);
}
return Container(
width: widget.width,
height: widget.width,
clipBehavior: Clip.hardEdge,
alignment: Alignment.center,
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(widget.width / 2),
),
child: innerWidget,
);
}, selector: (context, _provider) {
if (StringUtil.isNotBlank(widget.pubkey)) {
return _provider.getMetadata(widget.pubkey);
}
});
}
}