ente/lib/ui/settings/danger_section_widget.dart

123 lines
3.4 KiB
Dart
Raw Normal View History

// @dart=2.9
import 'package:expandable/expandable.dart';
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';
import 'package:photos/ui/account/delete_account_page.dart';
import 'package:photos/ui/components/captioned_text_widget.dart';
import 'package:photos/ui/components/menu_item_widget.dart';
import 'package:photos/ui/settings/common_settings.dart';
import 'package:photos/utils/navigation_util.dart';
2021-07-27 14:51:45 +00:00
class DangerSectionWidget extends StatefulWidget {
const DangerSectionWidget({Key key}) : super(key: key);
2021-07-27 14:51:45 +00:00
@override
2022-07-03 09:45:00 +00:00
State<DangerSectionWidget> createState() => _DangerSectionWidgetState();
2021-07-27 14:51:45 +00:00
}
class _DangerSectionWidgetState extends State<DangerSectionWidget> {
final expandableController = ExpandableController(initialExpanded: false);
@override
void dispose() {
expandableController.dispose();
super.dispose();
}
2021-07-27 14:51:45 +00:00
@override
Widget build(BuildContext context) {
return ExpandablePanel(
header: MenuItemWidget(
captionedTextWidget: const CaptionedTextWidget(
text: "Exit",
makeTextBold: true,
),
isHeaderOfExpansion: true,
leadingIcon: Icons.logout_outlined,
trailingIcon: Icons.expand_more,
menuItemColor:
Theme.of(context).colorScheme.enteTheme.colorScheme.fillFaint,
expandableController: expandableController,
),
collapsed: const SizedBox.shrink(),
expanded: _getSectionOptions(context),
theme: getExpandableTheme(context),
controller: expandableController,
);
}
Widget _getSectionOptions(BuildContext context) {
2021-07-27 14:51:45 +00:00
return Column(
children: [
sectionOptionDivider,
MenuItemWidget(
captionedTextWidget: const CaptionedTextWidget(
text: "Logout",
),
trailingIcon: Icons.chevron_right_outlined,
trailingIconIsMuted: true,
2021-07-27 14:51:45 +00:00
onTap: () {
_onLogoutTapped();
},
),
MenuItemWidget(
captionedTextWidget: const CaptionedTextWidget(
2022-06-11 08:23:52 +00:00
text: "Delete account",
),
trailingIcon: Icons.chevron_right_outlined,
trailingIconIsMuted: true,
onTap: () {
routeToPage(context, const DeleteAccountPage());
},
2021-07-27 14:51:45 +00:00
),
],
);
}
Future<void> _onLogoutTapped() 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;
},
);
}
}