mirror of
https://gitlab.com/famedly/fluffychat.git
synced 2025-01-11 10:12:49 +01:00
feat: Nicer verification dialog
This commit is contained in:
parent
127275782a
commit
1d16706ab3
BIN
assets/verification.png
Normal file
BIN
assets/verification.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 5.0 KiB |
@ -2,6 +2,7 @@ import 'dart:ui';
|
|||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
|
|
||||||
import 'package:adaptive_dialog/adaptive_dialog.dart';
|
import 'package:adaptive_dialog/adaptive_dialog.dart';
|
||||||
|
import 'package:fluffychat/widgets/avatar.dart';
|
||||||
import 'package:matrix/encryption.dart';
|
import 'package:matrix/encryption.dart';
|
||||||
import 'package:matrix/matrix.dart';
|
import 'package:matrix/matrix.dart';
|
||||||
import 'package:fluffychat/utils/platform_infos.dart';
|
import 'package:fluffychat/utils/platform_infos.dart';
|
||||||
@ -11,7 +12,6 @@ import 'package:flutter/services.dart';
|
|||||||
import 'package:flutter_gen/gen_l10n/l10n.dart';
|
import 'package:flutter_gen/gen_l10n/l10n.dart';
|
||||||
import '../widgets/adaptive_flat_button.dart';
|
import '../widgets/adaptive_flat_button.dart';
|
||||||
import 'package:future_loading_dialog/future_loading_dialog.dart';
|
import 'package:future_loading_dialog/future_loading_dialog.dart';
|
||||||
import '../utils/string_color.dart';
|
|
||||||
import '../utils/beautify_string_extension.dart';
|
import '../utils/beautify_string_extension.dart';
|
||||||
|
|
||||||
class KeyVerificationDialog extends StatefulWidget {
|
class KeyVerificationDialog extends StatefulWidget {
|
||||||
@ -78,6 +78,17 @@ class _KeyVerificationPageState extends State<KeyVerificationDialog> {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
|
User user;
|
||||||
|
final directChatId =
|
||||||
|
widget.request.client.getDirectChatFromUserId(widget.request.userId);
|
||||||
|
if (directChatId != null) {
|
||||||
|
user = widget.request.client
|
||||||
|
.getRoomById(directChatId)
|
||||||
|
?.getUserByMXIDSync(widget.request.userId);
|
||||||
|
}
|
||||||
|
final displayName =
|
||||||
|
user?.calcDisplayname() ?? widget.request.userId.localpart;
|
||||||
|
var title = Text(L10n.of(context).verifyTitle);
|
||||||
Widget body;
|
Widget body;
|
||||||
final buttons = <Widget>[];
|
final buttons = <Widget>[];
|
||||||
switch (widget.request.state) {
|
switch (widget.request.state) {
|
||||||
@ -153,33 +164,68 @@ class _KeyVerificationPageState extends State<KeyVerificationDialog> {
|
|||||||
));
|
));
|
||||||
break;
|
break;
|
||||||
case KeyVerificationState.askAccept:
|
case KeyVerificationState.askAccept:
|
||||||
body = Container(
|
title = Text(L10n.of(context).newVerificationRequest);
|
||||||
margin: EdgeInsets.only(left: 8.0, right: 8.0),
|
body = Column(
|
||||||
child: Text(
|
mainAxisSize: MainAxisSize.min,
|
||||||
L10n.of(context).askVerificationRequest(widget.request.userId),
|
children: [
|
||||||
style: TextStyle(fontSize: 20)),
|
Row(children: [
|
||||||
|
if (!PlatformInfos.isCupertinoStyle)
|
||||||
|
Avatar(user?.avatarUrl, displayName),
|
||||||
|
SizedBox(width: 12),
|
||||||
|
Expanded(
|
||||||
|
child: Column(
|
||||||
|
mainAxisSize: MainAxisSize.min,
|
||||||
|
crossAxisAlignment: PlatformInfos.isCupertinoStyle
|
||||||
|
? CrossAxisAlignment.center
|
||||||
|
: CrossAxisAlignment.start,
|
||||||
|
children: [
|
||||||
|
Text(
|
||||||
|
displayName,
|
||||||
|
style: TextStyle(fontSize: 16),
|
||||||
|
),
|
||||||
|
Text(
|
||||||
|
'${widget.request.userId} - ${widget.request.deviceId}',
|
||||||
|
style: TextStyle(
|
||||||
|
fontWeight: FontWeight.w300,
|
||||||
|
fontSize: 14,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
]),
|
||||||
|
const SizedBox(height: 16),
|
||||||
|
Image.asset('assets/verification.png', fit: BoxFit.contain),
|
||||||
|
const SizedBox(height: 16),
|
||||||
|
Text(
|
||||||
|
L10n.of(context).askVerificationRequest(displayName),
|
||||||
|
)
|
||||||
|
],
|
||||||
);
|
);
|
||||||
buttons.add(AdaptiveFlatButton(
|
|
||||||
label: L10n.of(context).accept,
|
|
||||||
onPressed: () => widget.request.acceptVerification(),
|
|
||||||
));
|
|
||||||
buttons.add(AdaptiveFlatButton(
|
buttons.add(AdaptiveFlatButton(
|
||||||
label: L10n.of(context).reject,
|
label: L10n.of(context).reject,
|
||||||
|
textColor: Colors.red,
|
||||||
onPressed: () {
|
onPressed: () {
|
||||||
widget.request.rejectVerification().then((_) {
|
widget.request.rejectVerification().then((_) {
|
||||||
Navigator.of(context, rootNavigator: false).pop();
|
Navigator.of(context, rootNavigator: false).pop();
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
));
|
));
|
||||||
|
buttons.add(AdaptiveFlatButton(
|
||||||
|
label: L10n.of(context).accept,
|
||||||
|
onPressed: () => widget.request.acceptVerification(),
|
||||||
|
));
|
||||||
break;
|
break;
|
||||||
case KeyVerificationState.waitingAccept:
|
case KeyVerificationState.waitingAccept:
|
||||||
body = Column(
|
body = Column(
|
||||||
mainAxisSize: MainAxisSize.min,
|
mainAxisSize: MainAxisSize.min,
|
||||||
children: <Widget>[
|
children: <Widget>[
|
||||||
|
Image.asset('assets/verification.png', fit: BoxFit.contain),
|
||||||
|
const SizedBox(height: 16),
|
||||||
PlatformInfos.isCupertinoStyle
|
PlatformInfos.isCupertinoStyle
|
||||||
? CupertinoActivityIndicator()
|
? CupertinoActivityIndicator()
|
||||||
: CircularProgressIndicator(),
|
: CircularProgressIndicator(),
|
||||||
SizedBox(height: 10),
|
const SizedBox(height: 16),
|
||||||
Text(
|
Text(
|
||||||
L10n.of(context).waitingPartnerAcceptRequest,
|
L10n.of(context).waitingPartnerAcceptRequest,
|
||||||
textAlign: TextAlign.center,
|
textAlign: TextAlign.center,
|
||||||
@ -308,58 +354,13 @@ class _KeyVerificationPageState extends State<KeyVerificationDialog> {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
body ??= Text('ERROR: Unknown state ' + widget.request.state.toString());
|
body ??= Text('ERROR: Unknown state ' + widget.request.state.toString());
|
||||||
final otherName = profile?.displayName ?? widget.request.userId;
|
|
||||||
var bottom;
|
|
||||||
if (widget.request.deviceId != null) {
|
|
||||||
final deviceName = widget
|
|
||||||
.request
|
|
||||||
.client
|
|
||||||
.userDeviceKeys[widget.request.userId]
|
|
||||||
?.deviceKeys[widget.request.deviceId]
|
|
||||||
?.deviceDisplayName ??
|
|
||||||
'';
|
|
||||||
bottom = Container(
|
|
||||||
alignment: Alignment.center,
|
|
||||||
padding: EdgeInsets.all(16.0),
|
|
||||||
child: Text('$deviceName (${widget.request.deviceId})',
|
|
||||||
style: TextStyle(color: Theme.of(context).textTheme.caption.color)),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
final userNameTitle = Row(
|
|
||||||
mainAxisSize: MainAxisSize.min,
|
|
||||||
crossAxisAlignment: CrossAxisAlignment.start,
|
|
||||||
children: <Widget>[
|
|
||||||
Text(
|
|
||||||
otherName,
|
|
||||||
maxLines: 1,
|
|
||||||
style: TextStyle(
|
|
||||||
color: otherName.color,
|
|
||||||
fontWeight: FontWeight.bold,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
if (otherName != widget.request.userId)
|
|
||||||
Text(
|
|
||||||
' - ' + widget.request.userId,
|
|
||||||
maxLines: 1,
|
|
||||||
style: TextStyle(
|
|
||||||
fontStyle: FontStyle.italic,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
);
|
|
||||||
final title = Text(L10n.of(context).verifyTitle);
|
|
||||||
final content = SingleChildScrollView(
|
final content = SingleChildScrollView(
|
||||||
scrollDirection: Axis.vertical,
|
scrollDirection: Axis.vertical,
|
||||||
child: Column(
|
child: Column(
|
||||||
mainAxisSize: MainAxisSize.min,
|
mainAxisSize: MainAxisSize.min,
|
||||||
children: [
|
children: [
|
||||||
if (PlatformInfos.isCupertinoStyle) ...[
|
SizedBox(height: 16),
|
||||||
SizedBox(height: 8),
|
|
||||||
Center(child: userNameTitle),
|
|
||||||
SizedBox(height: 12),
|
|
||||||
],
|
|
||||||
body,
|
body,
|
||||||
if (bottom != null) bottom,
|
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
@ -406,25 +406,9 @@ class MatrixState extends State<Matrix> with WidgetsBindingObserver {
|
|||||||
}
|
}
|
||||||
hidPopup = true;
|
hidPopup = true;
|
||||||
};
|
};
|
||||||
if (await showOkCancelAlertDialog(
|
request.onUpdate = null;
|
||||||
useRootNavigator: false,
|
hidPopup = true;
|
||||||
context: navigatorContext,
|
await KeyVerificationDialog(request: request).show(navigatorContext);
|
||||||
title: L10n.of(widget.context).newVerificationRequest,
|
|
||||||
message:
|
|
||||||
L10n.of(widget.context).askVerificationRequest(request.userId),
|
|
||||||
okLabel: L10n.of(widget.context).ok,
|
|
||||||
cancelLabel: L10n.of(widget.context).cancel,
|
|
||||||
) ==
|
|
||||||
OkCancelResult.ok) {
|
|
||||||
request.onUpdate = null;
|
|
||||||
hidPopup = true;
|
|
||||||
await request.acceptVerification();
|
|
||||||
await KeyVerificationDialog(request: request).show(navigatorContext);
|
|
||||||
} else {
|
|
||||||
request.onUpdate = null;
|
|
||||||
hidPopup = true;
|
|
||||||
await request.rejectVerification();
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
onLoginStateChanged[name] ??= c.onLoginStateChanged.stream.listen((state) {
|
onLoginStateChanged[name] ??= c.onLoginStateChanged.stream.listen((state) {
|
||||||
final loggedInWithMultipleClients = widget.clients.length > 1;
|
final loggedInWithMultipleClients = widget.clients.length > 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user