Files
moxxy/lib/ui/pages/profile/selfheader.dart

110 lines
2.8 KiB
Dart

import 'package:flutter/material.dart';
import 'package:moxxyv2/ui/helpers.dart';
import 'package:moxxyv2/ui/widgets/avatar.dart';
import 'package:qr_flutter/qr_flutter.dart';
class SelfProfileHeader extends StatelessWidget {
const SelfProfileHeader(
this.jid,
this.avatarUrl,
this.displayName,
this.setAvatar,
{
Key? key,
}
) : super(key: key);
final String jid;
final String avatarUrl;
final String displayName;
final void Function(String, String) setAvatar;
Future<void> _showJidQRCode(BuildContext context) async {
await showDialog<dynamic>(
context: context,
builder: (BuildContext context) => SimpleDialog(
children: [
Center(
child: SizedBox(
width: 220,
height: 220,
child: QrImage(
data: 'xmpp:$jid',
size: 220,
backgroundColor: Colors.white,
embeddedImage: const AssetImage('assets/images/logo.png'),
embeddedImageStyle: QrEmbeddedImageStyle(
size: const Size(50, 50),
),
),
),
)
],
),
);
}
Future<void> pickAndSetAvatar(BuildContext context) async {
final avatar = await pickAvatar(context, jid, avatarUrl);
if (avatar != null) {
setAvatar(avatar.path, avatar.hash);
}
}
@override
Widget build(BuildContext context) {
return Column(
children: [
Hero(
tag: 'self_profile_picture',
child: Material(
child: AvatarWrapper(
radius: 110,
avatarUrl: avatarUrl,
altIcon: Icons.person,
onTapFunction: () => pickAndSetAvatar(context),
),
),
),
Padding(
padding: const EdgeInsets.only(top: 8),
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text(
displayName,
style: const TextStyle(
fontSize: 20,
),
)
],
),
),
Padding(
padding: const EdgeInsets.only(top: 3),
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text(
jid,
style: const TextStyle(
fontSize: 15,
),
),
Padding(
padding: const EdgeInsetsDirectional.only(start: 3),
child: IconButton(
icon: const Icon(Icons.qr_code),
onPressed: () => _showJidQRCode(context),
),
)
],
),
),
],
);
}
}