2023-12-02 11:42:52 +00:00
|
|
|
import "dart:async";
|
|
|
|
|
2022-12-06 17:47:37 +00:00
|
|
|
import 'package:flutter/material.dart';
|
2023-08-11 11:27:00 +00:00
|
|
|
import "package:photos/core/error-reporting/super_logging.dart";
|
2023-04-06 04:06:03 +00:00
|
|
|
import "package:photos/generated/l10n.dart";
|
2023-08-24 15:35:28 +00:00
|
|
|
import "package:photos/services/memories_service.dart";
|
2023-06-15 12:45:26 +00:00
|
|
|
import "package:photos/services/user_remote_flag_service.dart";
|
2022-12-06 17:47:37 +00:00
|
|
|
import 'package:photos/theme/ente_theme.dart';
|
2023-03-10 08:08:51 +00:00
|
|
|
import 'package:photos/ui/components/buttons/icon_button_widget.dart';
|
2022-12-06 17:47:37 +00:00
|
|
|
import 'package:photos/ui/components/captioned_text_widget.dart';
|
2023-01-31 12:21:57 +00:00
|
|
|
import 'package:photos/ui/components/menu_item_widget/menu_item_widget.dart';
|
2022-12-06 17:47:37 +00:00
|
|
|
import 'package:photos/ui/components/title_bar_title_widget.dart';
|
|
|
|
import 'package:photos/ui/components/title_bar_widget.dart';
|
2023-06-15 12:45:26 +00:00
|
|
|
import "package:photos/ui/components/toggle_switch_widget.dart";
|
2023-10-13 07:46:56 +00:00
|
|
|
import "package:photos/ui/settings/machine_learning_settings_page.dart";
|
2022-12-22 08:15:52 +00:00
|
|
|
import 'package:photos/ui/tools/debug/app_storage_viewer.dart';
|
2023-02-03 08:25:01 +00:00
|
|
|
import 'package:photos/ui/viewer/gallery/photo_grid_size_picker_page.dart';
|
2022-12-07 01:34:50 +00:00
|
|
|
import 'package:photos/utils/local_settings.dart';
|
2022-12-22 05:31:19 +00:00
|
|
|
import 'package:photos/utils/navigation_util.dart';
|
2022-12-06 17:47:37 +00:00
|
|
|
|
|
|
|
class AdvancedSettingsScreen extends StatefulWidget {
|
|
|
|
const AdvancedSettingsScreen({super.key});
|
|
|
|
|
|
|
|
@override
|
|
|
|
State<AdvancedSettingsScreen> createState() => _AdvancedSettingsScreenState();
|
|
|
|
}
|
|
|
|
|
|
|
|
class _AdvancedSettingsScreenState extends State<AdvancedSettingsScreen> {
|
2023-02-03 08:29:28 +00:00
|
|
|
late int _photoGridSize;
|
2022-12-06 17:47:37 +00:00
|
|
|
|
|
|
|
@override
|
|
|
|
void initState() {
|
2022-12-07 03:18:41 +00:00
|
|
|
_photoGridSize = LocalSettings.instance.getPhotoGridSize();
|
2022-12-06 17:47:37 +00:00
|
|
|
super.initState();
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
final colorScheme = getEnteColorScheme(context);
|
|
|
|
return Scaffold(
|
|
|
|
body: CustomScrollView(
|
|
|
|
primary: false,
|
|
|
|
slivers: <Widget>[
|
|
|
|
TitleBarWidget(
|
2023-04-06 04:06:03 +00:00
|
|
|
flexibleSpaceTitle: TitleBarTitleWidget(
|
|
|
|
title: S.of(context).advancedSettings,
|
2022-12-06 17:47:37 +00:00
|
|
|
),
|
|
|
|
actionIcons: [
|
|
|
|
IconButtonWidget(
|
|
|
|
icon: Icons.close_outlined,
|
|
|
|
iconButtonType: IconButtonType.secondary,
|
|
|
|
onTap: () {
|
|
|
|
Navigator.pop(context);
|
|
|
|
Navigator.pop(context);
|
|
|
|
},
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
SliverList(
|
|
|
|
delegate: SliverChildBuilderDelegate(
|
2023-01-07 10:55:43 +00:00
|
|
|
(delegateBuildContext, index) {
|
2022-12-06 17:47:37 +00:00
|
|
|
return Padding(
|
|
|
|
padding: const EdgeInsets.symmetric(horizontal: 16),
|
|
|
|
child: Padding(
|
|
|
|
padding: const EdgeInsets.symmetric(vertical: 20),
|
|
|
|
child: Column(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
children: [
|
|
|
|
Column(
|
|
|
|
children: [
|
2023-12-13 09:07:15 +00:00
|
|
|
Column(
|
|
|
|
children: [
|
|
|
|
MenuItemWidget(
|
|
|
|
captionedTextWidget: CaptionedTextWidget(
|
|
|
|
title: S.of(context).machineLearning,
|
|
|
|
),
|
|
|
|
menuItemColor: colorScheme.fillFaint,
|
|
|
|
trailingWidget: Icon(
|
|
|
|
Icons.chevron_right_outlined,
|
|
|
|
color: colorScheme.strokeBase,
|
|
|
|
),
|
|
|
|
singleBorderRadius: 8,
|
|
|
|
alignCaptionedTextToLeft: true,
|
|
|
|
onTap: () async {
|
2023-12-21 07:34:06 +00:00
|
|
|
// ignore: unawaited_futures
|
2023-12-13 09:07:15 +00:00
|
|
|
routeToPage(
|
|
|
|
context,
|
|
|
|
const MachineLearningSettingsPage(),
|
|
|
|
);
|
|
|
|
},
|
|
|
|
),
|
|
|
|
const SizedBox(
|
|
|
|
height: 24,
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
2022-12-06 17:47:37 +00:00
|
|
|
GestureDetector(
|
|
|
|
onTap: () {
|
2023-02-03 08:25:01 +00:00
|
|
|
routeToPage(
|
|
|
|
context,
|
|
|
|
const PhotoGridSizePickerPage(),
|
|
|
|
).then((value) {
|
|
|
|
setState(() {
|
|
|
|
_photoGridSize = LocalSettings.instance
|
|
|
|
.getPhotoGridSize();
|
|
|
|
});
|
|
|
|
});
|
2022-12-06 17:47:37 +00:00
|
|
|
},
|
|
|
|
child: MenuItemWidget(
|
2022-12-07 03:38:32 +00:00
|
|
|
captionedTextWidget: CaptionedTextWidget(
|
2023-04-06 04:06:03 +00:00
|
|
|
title: S.of(context).photoGridSize,
|
2022-12-07 03:38:32 +00:00
|
|
|
subTitle: _photoGridSize.toString(),
|
2022-12-06 17:47:37 +00:00
|
|
|
),
|
|
|
|
menuItemColor: colorScheme.fillFaint,
|
2022-12-07 03:36:41 +00:00
|
|
|
trailingWidget: Icon(
|
2022-12-22 09:17:33 +00:00
|
|
|
Icons.chevron_right_outlined,
|
|
|
|
color: colorScheme.strokeBase,
|
2022-12-06 17:47:37 +00:00
|
|
|
),
|
2023-02-02 02:26:41 +00:00
|
|
|
singleBorderRadius: 8,
|
2022-12-06 17:47:37 +00:00
|
|
|
alignCaptionedTextToLeft: true,
|
|
|
|
isGestureDetectorDisabled: true,
|
|
|
|
),
|
|
|
|
),
|
2022-12-22 05:31:19 +00:00
|
|
|
const SizedBox(
|
|
|
|
height: 24,
|
|
|
|
),
|
2023-08-24 15:35:28 +00:00
|
|
|
MenuItemWidget(
|
|
|
|
captionedTextWidget: CaptionedTextWidget(
|
2023-10-13 07:24:51 +00:00
|
|
|
title: S.of(context).manageDeviceStorage,
|
2023-08-24 15:35:28 +00:00
|
|
|
),
|
|
|
|
menuItemColor: colorScheme.fillFaint,
|
2023-10-13 07:24:51 +00:00
|
|
|
trailingWidget: Icon(
|
|
|
|
Icons.chevron_right_outlined,
|
|
|
|
color: colorScheme.strokeBase,
|
|
|
|
),
|
2023-08-24 15:35:28 +00:00
|
|
|
singleBorderRadius: 8,
|
|
|
|
alignCaptionedTextToLeft: true,
|
2023-10-13 07:24:51 +00:00
|
|
|
onTap: () async {
|
2023-12-21 07:34:06 +00:00
|
|
|
// ignore: unawaited_futures
|
2023-10-13 07:24:51 +00:00
|
|
|
routeToPage(context, const AppStorageViewer());
|
|
|
|
},
|
2023-08-24 15:35:28 +00:00
|
|
|
),
|
|
|
|
const SizedBox(
|
|
|
|
height: 24,
|
|
|
|
),
|
2022-12-22 05:31:19 +00:00
|
|
|
MenuItemWidget(
|
2023-04-06 04:06:03 +00:00
|
|
|
captionedTextWidget: CaptionedTextWidget(
|
2023-10-13 07:24:51 +00:00
|
|
|
title: S.of(context).showMemories,
|
2022-12-22 05:31:19 +00:00
|
|
|
),
|
|
|
|
menuItemColor: colorScheme.fillFaint,
|
2023-02-02 02:26:41 +00:00
|
|
|
singleBorderRadius: 8,
|
2022-12-22 05:31:19 +00:00
|
|
|
alignCaptionedTextToLeft: true,
|
2023-10-13 07:24:51 +00:00
|
|
|
trailingWidget: ToggleSwitchWidget(
|
|
|
|
value: () =>
|
|
|
|
MemoriesService.instance.showMemories,
|
|
|
|
onChanged: () async {
|
2023-12-02 11:42:52 +00:00
|
|
|
unawaited(
|
|
|
|
MemoriesService.instance.setShowMemories(
|
|
|
|
!MemoriesService.instance.showMemories,
|
|
|
|
),
|
2023-10-13 07:24:51 +00:00
|
|
|
);
|
|
|
|
},
|
|
|
|
),
|
2022-12-22 05:31:19 +00:00
|
|
|
),
|
2023-06-15 12:45:26 +00:00
|
|
|
const SizedBox(
|
|
|
|
height: 24,
|
|
|
|
),
|
|
|
|
MenuItemWidget(
|
2023-06-15 12:53:47 +00:00
|
|
|
captionedTextWidget: CaptionedTextWidget(
|
|
|
|
title: S.of(context).maps,
|
2023-06-15 12:45:26 +00:00
|
|
|
),
|
|
|
|
menuItemColor: colorScheme.fillFaint,
|
|
|
|
singleBorderRadius: 8,
|
|
|
|
alignCaptionedTextToLeft: true,
|
|
|
|
trailingWidget: ToggleSwitchWidget(
|
|
|
|
value: () => UserRemoteFlagService.instance
|
|
|
|
.getCachedBoolValue(
|
|
|
|
UserRemoteFlagService.mapEnabled,
|
|
|
|
),
|
|
|
|
onChanged: () async {
|
|
|
|
final isEnabled = UserRemoteFlagService
|
|
|
|
.instance
|
|
|
|
.getCachedBoolValue(
|
|
|
|
UserRemoteFlagService.mapEnabled,
|
|
|
|
);
|
|
|
|
|
|
|
|
await UserRemoteFlagService.instance
|
|
|
|
.setBoolValue(
|
|
|
|
UserRemoteFlagService.mapEnabled,
|
|
|
|
!isEnabled,
|
|
|
|
);
|
|
|
|
},
|
|
|
|
),
|
2023-08-11 11:27:00 +00:00
|
|
|
),
|
|
|
|
const SizedBox(
|
|
|
|
height: 24,
|
|
|
|
),
|
|
|
|
MenuItemWidget(
|
|
|
|
captionedTextWidget: CaptionedTextWidget(
|
|
|
|
title: S.of(context).crashReporting,
|
|
|
|
),
|
|
|
|
menuItemColor: colorScheme.fillFaint,
|
|
|
|
singleBorderRadius: 8,
|
|
|
|
alignCaptionedTextToLeft: true,
|
|
|
|
trailingWidget: ToggleSwitchWidget(
|
|
|
|
value: () => SuperLogging.shouldReportCrashes(),
|
|
|
|
onChanged: () async {
|
|
|
|
await SuperLogging.setShouldReportCrashes(
|
|
|
|
!SuperLogging.shouldReportCrashes(),
|
|
|
|
);
|
|
|
|
},
|
|
|
|
),
|
2023-08-19 11:39:56 +00:00
|
|
|
),
|
2022-12-06 17:47:37 +00:00
|
|
|
],
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
},
|
|
|
|
childCount: 1,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|