2024-07-31 02:44:49 +08:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:get/get.dart';
|
2024-07-31 22:48:22 +08:00
|
|
|
import 'package:provider/provider.dart';
|
2024-07-31 02:44:49 +08:00
|
|
|
import 'package:shared_preferences/shared_preferences.dart';
|
|
|
|
import 'package:solian/exts.dart';
|
2024-09-15 15:55:14 +08:00
|
|
|
import 'package:solian/platform.dart';
|
2024-09-15 12:25:50 +08:00
|
|
|
import 'package:solian/providers/database/database.dart';
|
2024-07-31 22:48:22 +08:00
|
|
|
import 'package:solian/providers/theme_switcher.dart';
|
2024-08-02 00:29:51 +08:00
|
|
|
import 'package:solian/router.dart';
|
2024-07-31 02:44:49 +08:00
|
|
|
import 'package:solian/theme.dart';
|
|
|
|
|
|
|
|
class SettingScreen extends StatefulWidget {
|
|
|
|
const SettingScreen({super.key});
|
|
|
|
|
|
|
|
@override
|
|
|
|
State<SettingScreen> createState() => _SettingScreenState();
|
|
|
|
}
|
|
|
|
|
|
|
|
class _SettingScreenState extends State<SettingScreen> {
|
2024-09-15 15:55:14 +08:00
|
|
|
SharedPreferences? _prefs;
|
2024-07-31 02:44:49 +08:00
|
|
|
|
|
|
|
Widget _buildCaptionHeader(String title) {
|
|
|
|
return Container(
|
|
|
|
width: MediaQuery.of(context).size.width,
|
|
|
|
color: Theme.of(context).colorScheme.surfaceContainer,
|
|
|
|
padding: const EdgeInsets.symmetric(horizontal: 24, vertical: 12),
|
|
|
|
child: Text(title),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
Widget _buildThemeColorButton(String label, Color color) {
|
|
|
|
return IconButton(
|
|
|
|
icon: Icon(Icons.circle, color: color),
|
|
|
|
tooltip: label,
|
|
|
|
onPressed: () {
|
2024-07-31 22:48:22 +08:00
|
|
|
context.read<ThemeSwitcher>().setTheme(
|
2024-09-13 20:22:10 +08:00
|
|
|
AppTheme.build(
|
2024-07-31 22:48:22 +08:00
|
|
|
Brightness.light,
|
|
|
|
seedColor: color,
|
|
|
|
),
|
2024-09-13 20:22:10 +08:00
|
|
|
AppTheme.build(
|
2024-07-31 22:48:22 +08:00
|
|
|
Brightness.dark,
|
|
|
|
seedColor: color,
|
|
|
|
),
|
|
|
|
);
|
2024-09-15 15:55:14 +08:00
|
|
|
_prefs?.setInt('global_theme_color', color.value);
|
2024-07-31 13:29:26 +08:00
|
|
|
context.clearSnackbar();
|
2024-07-31 02:44:49 +08:00
|
|
|
context.showSnackbar('themeColorApplied'.tr);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2024-07-31 13:29:26 +08:00
|
|
|
static final List<(String, Color)> _presentTheme = [
|
|
|
|
('themeColorRed', const Color.fromRGBO(154, 98, 91, 1)),
|
|
|
|
('themeColorBlue', const Color.fromRGBO(103, 96, 193, 1)),
|
|
|
|
('themeColorMiku', const Color.fromRGBO(56, 120, 126, 1)),
|
|
|
|
('themeColorKagamine', const Color.fromRGBO(244, 183, 63, 1)),
|
|
|
|
('themeColorLuka', const Color.fromRGBO(243, 174, 218, 1)),
|
|
|
|
];
|
|
|
|
|
2024-07-31 02:44:49 +08:00
|
|
|
@override
|
|
|
|
void initState() {
|
|
|
|
super.initState();
|
|
|
|
SharedPreferences.getInstance().then((inst) {
|
|
|
|
_prefs = inst;
|
2024-09-15 15:55:14 +08:00
|
|
|
if (mounted) {
|
|
|
|
setState(() {});
|
|
|
|
}
|
2024-07-31 02:44:49 +08:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return Material(
|
|
|
|
color: Theme.of(context).colorScheme.surface,
|
|
|
|
child: ListView(
|
|
|
|
children: [
|
|
|
|
_buildCaptionHeader('themeColor'.tr),
|
|
|
|
SizedBox(
|
|
|
|
height: 56,
|
|
|
|
child: ListView(
|
|
|
|
scrollDirection: Axis.horizontal,
|
2024-07-31 13:29:26 +08:00
|
|
|
children: _presentTheme
|
|
|
|
.map((x) => _buildThemeColorButton(x.$1, x.$2))
|
|
|
|
.toList(),
|
2024-07-31 02:44:49 +08:00
|
|
|
).paddingSymmetric(horizontal: 12, vertical: 8),
|
|
|
|
),
|
2024-09-15 15:55:14 +08:00
|
|
|
_buildCaptionHeader('notification'.tr),
|
|
|
|
Tooltip(
|
|
|
|
message: 'settingsNotificationBgServiceDesc'.tr,
|
|
|
|
child: CheckboxListTile(
|
|
|
|
contentPadding: const EdgeInsets.symmetric(horizontal: 22),
|
|
|
|
secondary: const Icon(Icons.system_security_update_warning),
|
|
|
|
enabled: PlatformInfo.isAndroid,
|
|
|
|
title: Text('settingsNotificationBgService'.tr),
|
|
|
|
subtitle: Column(
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
children: [
|
|
|
|
Text('holdToSeeDetail'.tr),
|
|
|
|
Text(
|
|
|
|
'needRestartToApply'.tr,
|
|
|
|
style: const TextStyle(fontWeight: FontWeight.bold),
|
|
|
|
)
|
|
|
|
],
|
|
|
|
),
|
|
|
|
value:
|
|
|
|
_prefs?.getBool('service_background_notification') ?? false,
|
|
|
|
onChanged: (value) {
|
|
|
|
_prefs
|
|
|
|
?.setBool('service_background_notification', value ?? false)
|
|
|
|
.then((_) {
|
|
|
|
setState(() {});
|
|
|
|
});
|
|
|
|
},
|
|
|
|
),
|
|
|
|
),
|
2024-08-02 00:29:51 +08:00
|
|
|
_buildCaptionHeader('more'.tr),
|
2024-09-13 23:19:33 +08:00
|
|
|
ListTile(
|
2024-09-15 12:25:50 +08:00
|
|
|
leading: const Icon(Icons.delete_sweep),
|
2024-09-13 23:19:33 +08:00
|
|
|
trailing: const Icon(Icons.chevron_right),
|
2024-09-15 12:25:50 +08:00
|
|
|
subtitle: FutureBuilder(
|
|
|
|
future: AppDatabase.getDatabaseSize(),
|
|
|
|
builder: (context, snapshot) {
|
|
|
|
if (!snapshot.hasData) {
|
|
|
|
return Text('localDatabaseSize'.trParams(
|
|
|
|
{'size': 'unknown'.tr},
|
|
|
|
));
|
|
|
|
}
|
|
|
|
return Text('localDatabaseSize'.trParams(
|
|
|
|
{'size': snapshot.data!.formatBytes()},
|
|
|
|
));
|
|
|
|
},
|
|
|
|
),
|
2024-09-13 23:19:33 +08:00
|
|
|
contentPadding: const EdgeInsets.symmetric(horizontal: 22),
|
2024-09-15 12:25:50 +08:00
|
|
|
title: Text('localDatabaseWipe'.tr),
|
2024-09-13 23:19:33 +08:00
|
|
|
onTap: () {
|
2024-09-15 12:25:50 +08:00
|
|
|
AppDatabase.removeDatabase().then((_) {
|
|
|
|
setState(() {});
|
|
|
|
});
|
2024-09-13 23:19:33 +08:00
|
|
|
},
|
|
|
|
),
|
|
|
|
ListTile(
|
2024-09-15 12:25:50 +08:00
|
|
|
leading: const Icon(Icons.info_outline),
|
2024-09-13 23:19:33 +08:00
|
|
|
trailing: const Icon(Icons.chevron_right),
|
|
|
|
contentPadding: const EdgeInsets.symmetric(horizontal: 22),
|
2024-09-15 12:25:50 +08:00
|
|
|
title: Text('about'.tr),
|
2024-09-13 23:19:33 +08:00
|
|
|
onTap: () {
|
2024-09-15 12:25:50 +08:00
|
|
|
AppRouter.instance.pushNamed('about');
|
2024-09-13 23:19:33 +08:00
|
|
|
},
|
|
|
|
),
|
2024-07-31 02:44:49 +08:00
|
|
|
],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|