ente/lib/ui/settings/account_section_widget.dart

131 lines
4.2 KiB
Dart
Raw Normal View History

// @dart=2.9
import 'package:expandable/expandable.dart';
import 'package:flutter/material.dart';
2021-07-28 15:41:45 +00:00
import 'package:flutter_sodium/flutter_sodium.dart';
import 'package:photos/services/local_authentication_service.dart';
2021-07-28 15:41:45 +00:00
import 'package:photos/services/user_service.dart';
import 'package:photos/ui/account/change_email_dialog.dart';
import 'package:photos/ui/account/password_entry_page.dart';
import 'package:photos/ui/account/recovery_key_page.dart';
import 'package:photos/ui/settings/common_settings.dart';
import 'package:photos/ui/settings/settings_section_title.dart';
import 'package:photos/ui/settings/settings_text_item.dart';
2021-07-28 15:41:45 +00:00
import 'package:photos/utils/dialog_util.dart';
2022-04-06 17:41:24 +00:00
import 'package:photos/utils/navigation_util.dart';
class AccountSectionWidget extends StatefulWidget {
const AccountSectionWidget({Key key}) : super(key: key);
@override
AccountSectionWidgetState createState() => AccountSectionWidgetState();
}
class AccountSectionWidgetState extends State<AccountSectionWidget> {
@override
Widget build(BuildContext context) {
return ExpandablePanel(
2022-07-04 06:02:17 +00:00
header: const SettingsSectionTitle("Account"),
2022-09-05 13:54:53 +00:00
collapsed: const SizedBox.shrink(),
expanded: _getSectionOptions(context),
theme: getExpandableTheme(context),
);
}
Column _getSectionOptions(BuildContext context) {
2021-07-27 14:51:45 +00:00
return Column(
children: [
GestureDetector(
behavior: HitTestBehavior.translucent,
onTap: () async {
2022-09-06 08:35:34 +00:00
final hasAuthenticated = await LocalAuthenticationService.instance
.requestLocalAuthentication(
context,
"Please authenticate to view your recovery key",
);
2022-09-06 08:35:34 +00:00
if (hasAuthenticated) {
2022-09-03 03:02:42 +00:00
String recoveryKey;
try {
recoveryKey = await _getOrCreateRecoveryKey();
} catch (e) {
showGenericErrorDialog(context);
return;
}
routeToPage(
context,
RecoveryKeyPage(
recoveryKey,
"OK",
showAppBar: true,
onDone: () {},
),
);
2021-07-28 15:41:45 +00:00
}
},
2022-07-04 06:02:17 +00:00
child: const SettingsTextItem(
text: "Recovery key",
icon: Icons.navigate_next,
),
2021-07-28 15:41:45 +00:00
),
sectionOptionDivider,
2021-07-28 18:06:30 +00:00
GestureDetector(
behavior: HitTestBehavior.translucent,
onTap: () async {
2022-09-06 08:35:34 +00:00
final hasAuthenticated = await LocalAuthenticationService.instance
.requestLocalAuthentication(
context,
"Please authenticate to change your email",
);
2022-09-06 08:35:34 +00:00
if (hasAuthenticated) {
2022-09-03 03:02:42 +00:00
showDialog(
context: context,
builder: (BuildContext context) {
return const ChangeEmailDialog();
},
barrierColor: Colors.black.withOpacity(0.85),
barrierDismissible: false,
);
}
2021-07-28 18:06:30 +00:00
},
2022-07-04 06:02:17 +00:00
child: const SettingsTextItem(
text: "Change email",
icon: Icons.navigate_next,
),
2021-07-28 18:06:30 +00:00
),
sectionOptionDivider,
2021-07-28 15:41:45 +00:00
GestureDetector(
behavior: HitTestBehavior.translucent,
onTap: () async {
2022-09-06 08:35:34 +00:00
final hasAuthenticated = await LocalAuthenticationService.instance
.requestLocalAuthentication(
context,
"Please authenticate to change your password",
);
2022-09-06 08:35:34 +00:00
if (hasAuthenticated) {
2022-09-03 03:02:42 +00:00
Navigator.of(context).push(
MaterialPageRoute(
builder: (BuildContext context) {
return const PasswordEntryPage(
mode: PasswordEntryMode.update,
);
},
),
);
}
2021-07-28 15:41:45 +00:00
},
2022-07-04 06:02:17 +00:00
child: const SettingsTextItem(
2022-06-11 08:23:52 +00:00
text: "Change password",
icon: Icons.navigate_next,
),
2021-07-27 14:51:45 +00:00
),
],
);
}
2021-07-28 15:41:45 +00:00
Future<String> _getOrCreateRecoveryKey() async {
return Sodium.bin2hex(
2022-06-11 08:23:52 +00:00
await UserService.instance.getOrCreateRecoveryKey(context),
);
}
}