fluffychat/lib/widgets/profile_bottom_sheet.dart

117 lines
4.4 KiB
Dart
Raw Permalink Normal View History

import 'dart:math';
import 'package:flutter/material.dart';
2021-10-26 18:50:34 +02:00
import 'package:flutter_gen/gen_l10n/l10n.dart';
import 'package:future_loading_dialog/future_loading_dialog.dart';
import 'package:matrix/matrix.dart';
import 'package:vrouter/vrouter.dart';
2021-10-26 18:50:34 +02:00
import 'package:fluffychat/config/themes.dart';
import 'package:fluffychat/widgets/content_banner.dart';
import 'package:fluffychat/widgets/matrix.dart';
import '../utils/localized_exception_extension.dart';
class ProfileBottomSheet extends StatelessWidget {
final String userId;
final BuildContext outerContext;
const ProfileBottomSheet({
2022-01-28 18:21:20 +01:00
required this.userId,
required this.outerContext,
Key? key,
}) : super(key: key);
void _startDirectChat(BuildContext context) async {
final client = Matrix.of(context).client;
final result = await showFutureLoadingDialog<String>(
context: context,
2021-11-13 11:54:23 +01:00
future: () => client.startDirectChat(userId),
);
if (result.error == null) {
2022-01-28 18:21:20 +01:00
VRouter.of(context).toSegments(['rooms', result.result!]);
Navigator.of(context, rootNavigator: false).pop();
return;
}
}
@override
Widget build(BuildContext context) {
return Center(
2021-10-14 18:09:30 +02:00
child: SizedBox(
width: min(
MediaQuery.of(context).size.width, FluffyThemes.columnWidth * 1.5),
child: Material(
elevation: 4,
child: SafeArea(
child: Scaffold(
extendBodyBehindAppBar: true,
appBar: AppBar(
elevation: 0,
backgroundColor:
Theme.of(context).scaffoldBackgroundColor.withOpacity(0.5),
leading: IconButton(
2021-10-14 18:09:30 +02:00
icon: const Icon(Icons.arrow_downward_outlined),
onPressed: Navigator.of(context, rootNavigator: false).pop,
2022-01-28 18:21:20 +01:00
tooltip: L10n.of(context)!.close,
),
),
body: FutureBuilder<Profile>(
future:
Matrix.of(context).client.getProfileFromUserId(userId),
builder: (context, snapshot) {
final profile = snapshot.data;
return Column(
children: [
Expanded(
child: profile == null
? Container(
alignment: Alignment.center,
color: Theme.of(context).secondaryHeaderColor,
child: snapshot.hasError
2022-01-28 18:21:20 +01:00
? Text(snapshot.error!
.toLocalizedString(context))
2021-10-17 14:15:29 +02:00
: const CircularProgressIndicator
.adaptive(strokeWidth: 2),
)
: ContentBanner(
2022-01-29 12:35:03 +01:00
mxContent: profile.avatarUrl,
2022-07-08 10:13:44 +02:00
defaultIcon: Icons.account_circle_outlined,
client: Matrix.of(context).client,
placeholder: (context) => Center(
child: Text(
userId.localpart ?? userId,
style:
Theme.of(context).textTheme.headline3,
),
),
),
),
ListTile(
2022-01-28 18:21:20 +01:00
title: Text(
profile?.displayName ?? userId.localpart ?? ''),
subtitle: Text(userId),
2021-10-14 18:09:30 +02:00
trailing: const Icon(Icons.account_box_outlined),
),
Container(
width: double.infinity,
2021-10-14 18:09:30 +02:00
padding: const EdgeInsets.all(12),
child: ElevatedButton.icon(
onPressed: () => _startDirectChat(context),
2022-01-28 18:21:20 +01:00
label: Text(L10n.of(context)!.newChat),
2021-10-14 18:09:30 +02:00
icon: const Icon(Icons.send_outlined),
),
),
2021-10-14 18:09:30 +02:00
const SizedBox(height: 8),
],
);
}),
),
),
),
),
);
}
}