mirror of
https://gitlab.com/famedly/fluffychat.git
synced 2025-01-04 14:02:35 +01:00
af51c9c0ea
Signed-off-by: TheOneWithTheBraid <the-one@with-the-braid.cf>
186 lines
5.5 KiB
Dart
186 lines
5.5 KiB
Dart
import 'dart:convert';
|
|
import 'dart:typed_data';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:adaptive_dialog/adaptive_dialog.dart';
|
|
import 'package:file_picker_cross/file_picker_cross.dart';
|
|
import 'package:flutter_gen/gen_l10n/l10n.dart';
|
|
import 'package:future_loading_dialog/future_loading_dialog.dart';
|
|
import 'package:intl/intl.dart';
|
|
import 'package:matrix/matrix.dart';
|
|
import 'package:vrouter/vrouter.dart';
|
|
|
|
import 'package:fluffychat/pages/settings_account/settings_account_view.dart';
|
|
import 'package:fluffychat/widgets/matrix.dart';
|
|
|
|
class SettingsAccount extends StatefulWidget {
|
|
const SettingsAccount({Key? key}) : super(key: key);
|
|
|
|
@override
|
|
SettingsAccountController createState() => SettingsAccountController();
|
|
}
|
|
|
|
class SettingsAccountController extends State<SettingsAccount> {
|
|
Future<dynamic>? profileFuture;
|
|
Profile? profile;
|
|
bool profileUpdated = false;
|
|
|
|
void updateProfile() => setState(() {
|
|
profileUpdated = true;
|
|
profile = profileFuture = null;
|
|
});
|
|
|
|
void setDisplaynameAction() async {
|
|
final input = await showTextInputDialog(
|
|
useRootNavigator: false,
|
|
context: context,
|
|
title: L10n.of(context)!.editDisplayname,
|
|
okLabel: L10n.of(context)!.ok,
|
|
cancelLabel: L10n.of(context)!.cancel,
|
|
textFields: [
|
|
DialogTextField(
|
|
initialText: profile?.displayName ??
|
|
Matrix.of(context).client.userID!.localpart,
|
|
)
|
|
],
|
|
);
|
|
if (input == null) return;
|
|
final matrix = Matrix.of(context);
|
|
final success = await showFutureLoadingDialog(
|
|
context: context,
|
|
future: () =>
|
|
matrix.client.setDisplayName(matrix.client.userID!, input.single),
|
|
);
|
|
if (success.error == null) {
|
|
updateProfile();
|
|
}
|
|
}
|
|
|
|
void logoutAction() async {
|
|
if (await showOkCancelAlertDialog(
|
|
useRootNavigator: false,
|
|
context: context,
|
|
title: L10n.of(context)!.areYouSureYouWantToLogout,
|
|
okLabel: L10n.of(context)!.yes,
|
|
cancelLabel: L10n.of(context)!.cancel,
|
|
) ==
|
|
OkCancelResult.cancel) {
|
|
return;
|
|
}
|
|
final matrix = Matrix.of(context);
|
|
await showFutureLoadingDialog(
|
|
context: context,
|
|
future: () => matrix.client.logout(),
|
|
);
|
|
}
|
|
|
|
void deleteAccountAction() async {
|
|
if (await showOkCancelAlertDialog(
|
|
useRootNavigator: false,
|
|
context: context,
|
|
title: L10n.of(context)!.warning,
|
|
message: L10n.of(context)!.deactivateAccountWarning,
|
|
okLabel: L10n.of(context)!.ok,
|
|
cancelLabel: L10n.of(context)!.cancel,
|
|
) ==
|
|
OkCancelResult.cancel) {
|
|
return;
|
|
}
|
|
final supposedMxid = Matrix.of(context).client.userID!;
|
|
final mxids = await showTextInputDialog(
|
|
useRootNavigator: false,
|
|
context: context,
|
|
title: L10n.of(context)!.confirmMatrixId,
|
|
textFields: [
|
|
DialogTextField(
|
|
validator: (text) => text == supposedMxid
|
|
? null
|
|
: L10n.of(context)!.supposedMxid(supposedMxid),
|
|
),
|
|
],
|
|
okLabel: L10n.of(context)!.delete,
|
|
cancelLabel: L10n.of(context)!.cancel,
|
|
);
|
|
if (mxids == null || mxids.length != 1 || mxids.single != supposedMxid) {
|
|
return;
|
|
}
|
|
final input = await showTextInputDialog(
|
|
useRootNavigator: false,
|
|
context: context,
|
|
title: L10n.of(context)!.pleaseEnterYourPassword,
|
|
okLabel: L10n.of(context)!.ok,
|
|
cancelLabel: L10n.of(context)!.cancel,
|
|
textFields: [
|
|
const DialogTextField(
|
|
obscureText: true,
|
|
hintText: '******',
|
|
minLines: 1,
|
|
maxLines: 1,
|
|
)
|
|
],
|
|
);
|
|
if (input == null) return;
|
|
await showFutureLoadingDialog(
|
|
context: context,
|
|
future: () => Matrix.of(context).client.deactivateAccount(
|
|
auth: AuthenticationPassword(
|
|
password: input.single,
|
|
identifier: AuthenticationUserIdentifier(
|
|
user: Matrix.of(context).client.userID!),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
|
|
void addAccountAction() => VRouter.of(context).to('add');
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final client = Matrix.of(context).client;
|
|
profileFuture ??= client
|
|
.getProfileFromUserId(
|
|
client.userID!,
|
|
cache: !profileUpdated,
|
|
getFromRooms: !profileUpdated,
|
|
)
|
|
.then((p) {
|
|
if (mounted) setState(() => profile = p);
|
|
return p;
|
|
});
|
|
return SettingsAccountView(this);
|
|
}
|
|
|
|
Future<void> dehydrateAction() => dehydrateDevice(context);
|
|
|
|
static Future<void> dehydrateDevice(BuildContext context) async {
|
|
final response = await showOkCancelAlertDialog(
|
|
context: context,
|
|
isDestructiveAction: true,
|
|
title: L10n.of(context)!.dehydrate,
|
|
message: L10n.of(context)!.dehydrateWarning,
|
|
);
|
|
if (response != OkCancelResult.ok) {
|
|
return;
|
|
}
|
|
await showFutureLoadingDialog(
|
|
context: context,
|
|
future: () async {
|
|
try {
|
|
final export = await Matrix.of(context).client.exportDump();
|
|
final filePickerCross = FilePickerCross(
|
|
Uint8List.fromList(const Utf8Codec().encode(export!)),
|
|
path:
|
|
'/fluffychat-export-${DateFormat(DateFormat.YEAR_MONTH_DAY).format(DateTime.now())}.fluffybackup',
|
|
fileExtension: 'fluffybackup');
|
|
await filePickerCross.exportToStorage(
|
|
subject: L10n.of(context)!.dehydrateShare,
|
|
);
|
|
} catch (e, s) {
|
|
Logs().e('Export error', e, s);
|
|
}
|
|
},
|
|
);
|
|
}
|
|
}
|