ente/lib/ui/settings_page.dart

132 lines
3.9 KiB
Dart
Raw Normal View History

// @dart=2.9
import 'dart:io';
2020-09-09 14:04:11 +00:00
import 'package:flutter/foundation.dart';
2020-08-28 23:50:34 +00:00
import 'package:flutter/material.dart';
2021-07-27 14:51:45 +00:00
import 'package:photos/core/configuration.dart';
import 'package:photos/ui/settings/account_section_widget.dart';
import 'package:photos/ui/settings/app_version_widget.dart';
import 'package:photos/ui/settings/backup_section_widget.dart';
2021-07-27 14:51:45 +00:00
import 'package:photos/ui/settings/danger_section_widget.dart';
import 'package:photos/ui/settings/debug_section_widget.dart';
2021-07-28 14:08:27 +00:00
import 'package:photos/ui/settings/details_section_widget.dart';
import 'package:photos/ui/settings/info_section_widget.dart';
import 'package:photos/ui/settings/security_section_widget.dart';
import 'package:photos/ui/settings/settings_section_title.dart';
2022-03-08 07:04:53 +00:00
import 'package:photos/ui/settings/social_section_widget.dart';
import 'package:photos/ui/settings/support_section_widget.dart';
import 'package:photos/ui/settings/theme_switch_widget.dart';
2020-08-28 23:50:34 +00:00
class SettingsPage extends StatelessWidget {
2022-06-23 13:06:35 +00:00
final ValueNotifier<String> emailNotifier;
const SettingsPage({Key key, @required this.emailNotifier}) : super(key: key);
2020-08-28 23:50:34 +00:00
@override
Widget build(BuildContext context) {
return Scaffold(
body: _getBody(context),
2020-08-28 23:50:34 +00:00
);
}
Widget _getBody(BuildContext context) {
final hasLoggedIn = Configuration.instance.getToken() != null;
final List<Widget> contents = [];
2022-06-09 09:50:57 +00:00
contents.add(
Container(
padding: const EdgeInsets.symmetric(horizontal: 2, vertical: 4),
child: Align(
alignment: Alignment.centerLeft,
child: AnimatedBuilder(
// [AnimatedBuilder] accepts any [Listenable] subtype.
animation: emailNotifier,
builder: (BuildContext context, Widget child) {
return Text(
emailNotifier.value,
style: Theme.of(context)
.textTheme
.subtitle1
.copyWith(overflow: TextOverflow.ellipsis),
);
},
),
2022-06-09 09:50:57 +00:00
),
),
);
final sectionDivider = Divider(
2022-05-02 18:43:33 +00:00
height: 20,
color: Theme.of(context).colorScheme.onSurface.withOpacity(0.12),
);
2022-07-04 06:02:17 +00:00
contents.add(const Padding(padding: EdgeInsets.all(4)));
2021-04-05 13:39:54 +00:00
if (hasLoggedIn) {
contents.addAll([
const DetailsSectionWidget(),
2022-07-04 06:02:17 +00:00
const Padding(padding: EdgeInsets.only(bottom: 24)),
const BackupSectionWidget(),
sectionDivider,
const AccountSectionWidget(),
sectionDivider,
]);
}
contents.addAll([
const SecuritySectionWidget(),
sectionDivider,
]);
if (Platform.isAndroid || kDebugMode) {
contents.addAll([
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
crossAxisAlignment: CrossAxisAlignment.center,
children: const [
SettingsSectionTitle("Theme"),
2022-07-14 10:30:01 +00:00
Padding(
padding: EdgeInsets.only(right: 4),
child: ThemeSwitchWidget(),
),
],
),
sectionDivider,
]);
}
contents.addAll([
2022-07-04 06:02:17 +00:00
const SupportSectionWidget(),
sectionDivider,
2022-07-04 06:02:17 +00:00
const SocialSectionWidget(),
sectionDivider,
2022-07-04 06:02:17 +00:00
const InfoSectionWidget(),
]);
2021-07-27 14:51:45 +00:00
if (hasLoggedIn) {
contents.addAll([
sectionDivider,
const DangerSectionWidget(),
2021-07-27 14:51:45 +00:00
]);
}
2022-05-17 17:23:00 +00:00
2021-03-21 11:21:45 +00:00
if (kDebugMode && hasLoggedIn) {
2022-07-04 06:02:17 +00:00
contents.addAll([sectionDivider, const DebugSectionWidget()]);
}
2022-07-04 06:02:17 +00:00
contents.add(const AppVersionWidget());
2022-06-11 08:23:52 +00:00
contents.add(
2022-07-04 06:02:17 +00:00
const Padding(
2022-06-11 08:23:52 +00:00
padding: EdgeInsets.only(bottom: 60),
),
);
2022-05-17 17:23:00 +00:00
2020-08-28 23:50:34 +00:00
return SingleChildScrollView(
2020-08-29 00:39:52 +00:00
child: Padding(
2022-07-03 06:56:43 +00:00
padding: const EdgeInsets.symmetric(vertical: 12.0, horizontal: 20),
child: Center(
child: ConstrainedBox(
2022-07-04 06:02:17 +00:00
constraints: const BoxConstraints(maxWidth: 350),
2022-07-03 06:56:43 +00:00
child: Column(
children: contents,
2022-06-13 15:14:49 +00:00
),
2022-07-03 06:56:43 +00:00
),
),
),
2020-08-28 23:50:34 +00:00
);
}
}