ente/lib/ui/settings/danger_section_widget.dart

97 lines
2.8 KiB
Dart
Raw Normal View History

2022-11-01 06:13:06 +00:00
2023-04-10 04:17:45 +00:00
import 'package:ente_auth/l10n/l10n.dart';
2022-11-01 06:13:06 +00:00
import 'package:ente_auth/services/user_service.dart';
import 'package:ente_auth/theme/ente_theme.dart';
import 'package:ente_auth/ui/account/delete_account_page.dart';
import 'package:ente_auth/ui/components/captioned_text_widget.dart';
import 'package:ente_auth/ui/components/expandable_menu_item_widget.dart';
import 'package:ente_auth/ui/components/menu_item_widget.dart';
import 'package:ente_auth/ui/settings/common_settings.dart';
import 'package:ente_auth/utils/navigation_util.dart';
import 'package:flutter/material.dart';
class DangerSectionWidget extends StatelessWidget {
2023-04-10 04:17:45 +00:00
const DangerSectionWidget({Key? key}) : super(key: key);
2022-11-01 06:13:06 +00:00
@override
Widget build(BuildContext context) {
return ExpandableMenuItemWidget(
2023-04-10 04:17:45 +00:00
title: context.l10n.exit,
2022-11-01 06:13:06 +00:00
selectionOptionsWidget: _getSectionOptions(context),
leadingIcon: Icons.logout_outlined,
);
}
Widget _getSectionOptions(BuildContext context) {
return Column(
children: [
sectionOptionSpacing,
MenuItemWidget(
2023-04-10 04:17:45 +00:00
captionedTextWidget: CaptionedTextWidget(
title: context.l10n.logout,
2022-11-01 06:13:06 +00:00
),
pressedColor: getEnteColorScheme(context).fillFaint,
trailingIcon: Icons.chevron_right_outlined,
trailingIconIsMuted: true,
2023-04-10 04:17:45 +00:00
onTap: () async {
2022-11-01 06:13:06 +00:00
_onLogoutTapped(context);
},
),
sectionOptionSpacing,
MenuItemWidget(
2023-04-10 04:17:45 +00:00
captionedTextWidget: CaptionedTextWidget(
title: context.l10n.deleteAccount,
2022-11-01 06:13:06 +00:00
),
pressedColor: getEnteColorScheme(context).fillFaint,
trailingIcon: Icons.chevron_right_outlined,
trailingIconIsMuted: true,
2023-04-10 04:17:45 +00:00
onTap: () async {
2022-11-01 06:13:06 +00:00
routeToPage(context, const DeleteAccountPage());
},
),
sectionOptionSpacing,
],
);
}
Future<void> _onLogoutTapped(BuildContext context) async {
final AlertDialog alert = AlertDialog(
title: const Text(
"Logout",
style: TextStyle(
color: Colors.red,
),
),
content: const Text("Are you sure you want to logout?"),
actions: [
TextButton(
child: const Text(
"Yes, logout",
style: TextStyle(
color: Colors.red,
),
),
onPressed: () async {
Navigator.of(context, rootNavigator: true).pop('dialog');
await UserService.instance.logout(context);
},
),
TextButton(
child: const Text("No"),
onPressed: () {
Navigator.of(context, rootNavigator: true).pop('dialog');
},
),
],
);
showDialog(
context: context,
builder: (BuildContext context) {
return alert;
},
);
}
}