328 lines
14 KiB
Dart
328 lines
14 KiB
Dart
import 'package:feature_discovery/feature_discovery.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter/services.dart';
|
|
import 'package:fluttertoast/fluttertoast.dart';
|
|
import 'package:line_icons/line_icons.dart';
|
|
|
|
import '../home/home.dart';
|
|
import '../intro_slider/app_intro.dart';
|
|
import '../podcasts/podcast_manage.dart';
|
|
import '../util/extension_helper.dart';
|
|
import '../util/general_dialog.dart';
|
|
import 'data_backup.dart';
|
|
import 'history.dart';
|
|
import 'languages.dart';
|
|
import 'layouts.dart';
|
|
import 'libries.dart';
|
|
import 'play_setting.dart';
|
|
import 'storage.dart';
|
|
import 'syncing.dart';
|
|
import 'theme.dart';
|
|
|
|
class Settings extends StatefulWidget {
|
|
@override
|
|
_SettingsState createState() => _SettingsState();
|
|
}
|
|
|
|
class _SettingsState extends State<Settings> {
|
|
Widget _feedbackItem(IconData icon, String name, String url) => ListTile(
|
|
onTap: () {
|
|
url.launchUrl;
|
|
Navigator.pop(context);
|
|
},
|
|
leading: Icon(
|
|
icon,
|
|
size: 20,
|
|
),
|
|
title: Text(
|
|
name,
|
|
maxLines: 2,
|
|
),
|
|
);
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final s = context.s;
|
|
return AnnotatedRegion<SystemUiOverlayStyle>(
|
|
value: SystemUiOverlayStyle(
|
|
statusBarIconBrightness: Theme.of(context).accentColorBrightness,
|
|
systemNavigationBarColor: Theme.of(context).primaryColor,
|
|
systemNavigationBarIconBrightness:
|
|
Theme.of(context).accentColorBrightness,
|
|
),
|
|
child: Scaffold(
|
|
appBar: AppBar(
|
|
title: Text(s.settings),
|
|
elevation: 0,
|
|
backgroundColor: context.primaryColor,
|
|
),
|
|
body: SafeArea(
|
|
child: SingleChildScrollView(
|
|
//physics: const AlwaysScrollableScrollPhysics(),
|
|
scrollDirection: Axis.vertical,
|
|
child: Column(
|
|
mainAxisAlignment: MainAxisAlignment.start,
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: <Widget>[
|
|
Column(
|
|
mainAxisAlignment: MainAxisAlignment.start,
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: <Widget>[
|
|
Padding(
|
|
padding: EdgeInsets.all(10.0),
|
|
),
|
|
Container(
|
|
height: 30.0,
|
|
padding: EdgeInsets.symmetric(horizontal: 70),
|
|
alignment: Alignment.centerLeft,
|
|
child: Text(s.settingsPrefrence,
|
|
style: Theme.of(context)
|
|
.textTheme
|
|
.bodyText1
|
|
.copyWith(color: context.accentColor)),
|
|
),
|
|
ListView(
|
|
physics: ClampingScrollPhysics(),
|
|
shrinkWrap: true,
|
|
scrollDirection: Axis.vertical,
|
|
children: <Widget>[
|
|
ListTile(
|
|
onTap: () => Navigator.push(
|
|
context,
|
|
MaterialPageRoute(
|
|
builder: (context) => ThemeSetting())),
|
|
contentPadding:
|
|
EdgeInsets.symmetric(horizontal: 25.0),
|
|
leading: Icon(LineIcons.adjust_solid,
|
|
color: context.accentColor),
|
|
title: Text(s.settingsAppearance),
|
|
subtitle: Text(s.settingsAppearanceDes),
|
|
),
|
|
Divider(height: 1),
|
|
ListTile(
|
|
onTap: () => Navigator.push(
|
|
context,
|
|
MaterialPageRoute(
|
|
builder: (context) => LayoutSetting())),
|
|
contentPadding:
|
|
EdgeInsets.symmetric(horizontal: 25.0),
|
|
leading: Icon(LineIcons.stop_circle_solid,
|
|
color: Colors.blueAccent),
|
|
title: Text(s.settingsLayout),
|
|
subtitle: Text(s.settingsLayoutDes),
|
|
),
|
|
Divider(height: 1),
|
|
ListTile(
|
|
onTap: () => Navigator.push(
|
|
context,
|
|
MaterialPageRoute(
|
|
builder: (context) => PlaySetting())),
|
|
contentPadding:
|
|
EdgeInsets.symmetric(horizontal: 25.0),
|
|
leading: Icon(LineIcons.play_circle,
|
|
color: Colors.redAccent),
|
|
title: Text(s.play),
|
|
subtitle: Text(s.settingsPlayDes),
|
|
),
|
|
Divider(height: 1),
|
|
ListTile(
|
|
onTap: () => Navigator.push(
|
|
context,
|
|
MaterialPageRoute(
|
|
builder: (context) => SyncingSetting())),
|
|
contentPadding:
|
|
EdgeInsets.symmetric(horizontal: 25.0),
|
|
leading: Icon(LineIcons.cloud_download_alt_solid,
|
|
color: Colors.yellow[700]),
|
|
title: Text(s.settingsSyncing),
|
|
subtitle: Text(s.settingsSyncingDes)),
|
|
Divider(height: 1),
|
|
ListTile(
|
|
onTap: () => Navigator.push(
|
|
context,
|
|
MaterialPageRoute(
|
|
builder: (context) => StorageSetting())),
|
|
contentPadding:
|
|
EdgeInsets.symmetric(horizontal: 25.0),
|
|
leading:
|
|
Icon(LineIcons.save, color: Colors.green[700]),
|
|
title: Text(s.settingStorage),
|
|
subtitle: Text(s.settingsStorageDes),
|
|
),
|
|
Divider(height: 1),
|
|
ListTile(
|
|
onTap: () => Navigator.push(
|
|
context,
|
|
MaterialPageRoute(
|
|
builder: (context) => PlayedHistory())),
|
|
contentPadding:
|
|
EdgeInsets.symmetric(horizontal: 25.0),
|
|
leading:
|
|
Icon(Icons.update, color: Colors.indigo[700]),
|
|
title: Text(s.settingsHistory),
|
|
subtitle: Text(s.settingsHistoryDes),
|
|
),
|
|
Divider(height: 1),
|
|
ListTile(
|
|
onTap: () => generalSheet(context,
|
|
title: s.settingsLanguages,
|
|
child: LanguagesSetting())
|
|
.then((value) => setState(() {})),
|
|
contentPadding:
|
|
EdgeInsets.symmetric(horizontal: 25.0),
|
|
leading: Icon(LineIcons.language_solid,
|
|
color: Colors.purpleAccent),
|
|
title: Text(s.settingsLanguages),
|
|
subtitle: Text(s.settingsLanguagesDes),
|
|
),
|
|
Divider(height: 1),
|
|
ListTile(
|
|
onTap: () {
|
|
//_exportOmpl(context);
|
|
Navigator.push(
|
|
context,
|
|
MaterialPageRoute(
|
|
builder: (context) => DataBackup()));
|
|
},
|
|
contentPadding:
|
|
EdgeInsets.symmetric(horizontal: 25.0),
|
|
leading: Icon(LineIcons.file_code_solid,
|
|
color: Colors.lightGreen[700]),
|
|
title: Text(s.settingsBackup),
|
|
subtitle: Text(s.settingsBackupDes),
|
|
),
|
|
Divider(height: 1),
|
|
],
|
|
),
|
|
],
|
|
),
|
|
Padding(
|
|
padding: EdgeInsets.all(10.0),
|
|
),
|
|
Column(
|
|
mainAxisAlignment: MainAxisAlignment.start,
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: <Widget>[
|
|
Container(
|
|
height: 30.0,
|
|
padding: EdgeInsets.symmetric(horizontal: 70),
|
|
alignment: Alignment.centerLeft,
|
|
child: Text(s.settingsInfo,
|
|
style: Theme.of(context)
|
|
.textTheme
|
|
.bodyText1
|
|
.copyWith(color: Theme.of(context).accentColor)),
|
|
),
|
|
ListView(
|
|
physics: ClampingScrollPhysics(),
|
|
shrinkWrap: true,
|
|
scrollDirection: Axis.vertical,
|
|
children: <Widget>[
|
|
ListTile(
|
|
onTap: () => Navigator.push(
|
|
context,
|
|
MaterialPageRoute(
|
|
builder: (context) => Libries())),
|
|
contentPadding:
|
|
EdgeInsets.symmetric(horizontal: 25.0),
|
|
leading: Icon(LineIcons.book_open_solid,
|
|
color: Colors.purple[700]),
|
|
title: Text(s.settingsLibraries),
|
|
subtitle: Text(s.settingsLibrariesDes),
|
|
),
|
|
Divider(height: 1),
|
|
ListTile(
|
|
onTap: () => generalSheet(
|
|
context,
|
|
title: s.settingsFeedback,
|
|
child: Column(
|
|
mainAxisSize: MainAxisSize.min,
|
|
mainAxisAlignment: MainAxisAlignment.start,
|
|
children: [
|
|
_feedbackItem(
|
|
LineIcons.github,
|
|
s.feedbackGithub,
|
|
'https://github.com/stonega/tsacdop/issues'),
|
|
Divider(height: 1),
|
|
_feedbackItem(
|
|
LineIcons.telegram,
|
|
s.feedbackTelegram,
|
|
'https://t.me/joinchat/Bk3LkRpTHy40QYC78PK7Qg'),
|
|
Divider(height: 1),
|
|
_feedbackItem(
|
|
LineIcons.envelope_open_text_solid,
|
|
s.feedbackEmail,
|
|
'mailto:<tsacdop.app@gmail.com>?subject=Tsacdop Feedback'),
|
|
Divider(height: 1),
|
|
_feedbackItem(
|
|
LineIcons.google_play,
|
|
s.feedbackPlay,
|
|
'https://play.google.com/store/apps/details?id=com.stonegate.tsacdop'),
|
|
Divider(height: 1),
|
|
],
|
|
),
|
|
),
|
|
contentPadding:
|
|
EdgeInsets.symmetric(horizontal: 25.0),
|
|
leading: Icon(LineIcons.bug_solid,
|
|
color: Colors.pink[700]),
|
|
title: Text(s.settingsFeedback),
|
|
subtitle: Text(s.settingsFeedbackDes),
|
|
),
|
|
Divider(
|
|
height: 2,
|
|
),
|
|
ListTile(
|
|
onTap: () {
|
|
FeatureDiscovery.clearPreferences(
|
|
context, const <String>{
|
|
addFeature,
|
|
menuFeature,
|
|
playlistFeature,
|
|
groupsFeature,
|
|
addGroupFeature,
|
|
configureGroup,
|
|
configurePodcast,
|
|
podcastFeature
|
|
});
|
|
Fluttertoast.showToast(
|
|
msg: s.toastDiscovery,
|
|
gravity: ToastGravity.BOTTOM,
|
|
);
|
|
},
|
|
contentPadding:
|
|
EdgeInsets.symmetric(horizontal: 25.0),
|
|
leading: Icon(LineIcons.capsules_solid,
|
|
color: Colors.pinkAccent),
|
|
title: Text(s.settingsDiscovery),
|
|
),
|
|
Divider(height: 1),
|
|
ListTile(
|
|
onTap: () => Navigator.push(
|
|
context,
|
|
MaterialPageRoute(
|
|
builder: (context) =>
|
|
SlideIntro(goto: Goto.settings))),
|
|
contentPadding:
|
|
EdgeInsets.symmetric(horizontal: 25.0),
|
|
leading: Icon(LineIcons.columns_solid,
|
|
color: Colors.blueGrey),
|
|
title: Text(s.settingsAppIntro),
|
|
),
|
|
Divider(height: 1),
|
|
],
|
|
),
|
|
Padding(
|
|
padding: EdgeInsets.all(10.0),
|
|
),
|
|
],
|
|
),
|
|
],
|
|
),
|
|
),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|