2022-09-07 08:30:09 +00:00
|
|
|
// @dart=2.9
|
|
|
|
|
2021-07-27 14:51:45 +00:00
|
|
|
import 'package:flutter/material.dart';
|
2022-07-12 06:30:02 +00:00
|
|
|
import 'package:photos/ente_theme_data.dart';
|
2021-07-27 14:51:45 +00:00
|
|
|
import 'package:photos/services/user_service.dart';
|
2022-07-08 08:51:01 +00:00
|
|
|
import 'package:photos/ui/account/delete_account_page.dart';
|
2022-10-04 04:42:07 +00:00
|
|
|
import 'package:photos/ui/components/captioned_text_widget.dart';
|
2022-10-05 11:48:56 +00:00
|
|
|
import 'package:photos/ui/components/expandable_menu_item_widget.dart';
|
2022-10-04 04:42:07 +00:00
|
|
|
import 'package:photos/ui/components/menu_item_widget.dart';
|
2022-03-08 19:43:51 +00:00
|
|
|
import 'package:photos/ui/settings/common_settings.dart';
|
2022-07-08 08:51:01 +00:00
|
|
|
import 'package:photos/utils/navigation_util.dart';
|
2021-07-27 14:51:45 +00:00
|
|
|
|
2022-10-06 03:52:05 +00:00
|
|
|
class DangerSectionWidget extends StatelessWidget {
|
2022-07-04 08:43:01 +00:00
|
|
|
const DangerSectionWidget({Key key}) : super(key: key);
|
2021-07-27 14:51:45 +00:00
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2022-10-05 11:48:56 +00:00
|
|
|
return ExpandableMenuItemWidget(
|
|
|
|
title: "Exit",
|
|
|
|
selectionOptionsWidget: _getSectionOptions(context),
|
|
|
|
leadingIcon: Icons.logout_outlined,
|
2022-03-08 19:43:51 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
Widget _getSectionOptions(BuildContext context) {
|
2021-07-27 14:51:45 +00:00
|
|
|
return Column(
|
|
|
|
children: [
|
2022-10-05 07:52:48 +00:00
|
|
|
sectionOptionSpacing,
|
2022-10-05 06:36:42 +00:00
|
|
|
MenuItemWidget(
|
|
|
|
captionedTextWidget: const CaptionedTextWidget(
|
2022-10-05 13:57:32 +00:00
|
|
|
title: "Logout",
|
2022-10-05 06:36:42 +00:00
|
|
|
),
|
|
|
|
trailingIcon: Icons.chevron_right_outlined,
|
|
|
|
trailingIconIsMuted: true,
|
2021-07-27 14:51:45 +00:00
|
|
|
onTap: () {
|
2022-10-06 03:52:05 +00:00
|
|
|
_onLogoutTapped(context);
|
2021-07-27 14:51:45 +00:00
|
|
|
},
|
|
|
|
),
|
2022-10-05 07:52:48 +00:00
|
|
|
sectionOptionSpacing,
|
2022-10-05 06:36:42 +00:00
|
|
|
MenuItemWidget(
|
|
|
|
captionedTextWidget: const CaptionedTextWidget(
|
2022-10-05 13:57:32 +00:00
|
|
|
title: "Delete account",
|
2022-06-11 08:23:52 +00:00
|
|
|
),
|
2022-10-05 06:36:42 +00:00
|
|
|
trailingIcon: Icons.chevron_right_outlined,
|
|
|
|
trailingIconIsMuted: true,
|
|
|
|
onTap: () {
|
|
|
|
routeToPage(context, const DeleteAccountPage());
|
|
|
|
},
|
2021-07-27 14:51:45 +00:00
|
|
|
),
|
2022-10-05 07:52:48 +00:00
|
|
|
sectionOptionSpacing,
|
2021-07-27 14:51:45 +00:00
|
|
|
],
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-10-06 03:52:05 +00:00
|
|
|
Future<void> _onLogoutTapped(BuildContext context) async {
|
2022-08-29 14:43:31 +00:00
|
|
|
final AlertDialog alert = AlertDialog(
|
2022-07-04 06:02:17 +00:00
|
|
|
title: const Text(
|
2022-05-30 10:52:46 +00:00
|
|
|
"Logout",
|
2021-07-27 14:51:45 +00:00
|
|
|
style: TextStyle(
|
|
|
|
color: Colors.red,
|
|
|
|
),
|
|
|
|
),
|
2022-07-04 06:02:17 +00:00
|
|
|
content: const Text("Are you sure you want to logout?"),
|
2021-07-27 14:51:45 +00:00
|
|
|
actions: [
|
|
|
|
TextButton(
|
2022-07-04 06:02:17 +00:00
|
|
|
child: const Text(
|
2022-05-30 10:52:46 +00:00
|
|
|
"Yes, logout",
|
2021-07-27 14:51:45 +00:00
|
|
|
style: TextStyle(
|
|
|
|
color: Colors.red,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
onPressed: () async {
|
|
|
|
Navigator.of(context, rootNavigator: true).pop('dialog');
|
|
|
|
await UserService.instance.logout(context);
|
|
|
|
},
|
|
|
|
),
|
|
|
|
TextButton(
|
|
|
|
child: Text(
|
2022-05-30 10:52:46 +00:00
|
|
|
"No",
|
2021-07-27 14:51:45 +00:00
|
|
|
style: TextStyle(
|
2022-07-12 06:30:02 +00:00
|
|
|
color: Theme.of(context).colorScheme.greenAlternative,
|
2021-07-27 14:51:45 +00:00
|
|
|
),
|
|
|
|
),
|
|
|
|
onPressed: () {
|
|
|
|
Navigator.of(context, rootNavigator: true).pop('dialog');
|
|
|
|
},
|
|
|
|
),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
|
|
|
|
showDialog(
|
|
|
|
context: context,
|
|
|
|
builder: (BuildContext context) {
|
|
|
|
return alert;
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|