import 'dart:io'; import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; import 'package:flutter_colorpicker/flutter_colorpicker.dart'; import 'package:tetra_stats/views/settings_view.dart' show subtitleStyle; import 'package:tetra_stats/main.dart' show MyAppState, prefs; import 'package:tetra_stats/gen/strings.g.dart'; import 'package:window_manager/window_manager.dart'; late String oldWindowTitle; Color pickerColor = Colors.cyanAccent; Color currentColor = Colors.cyanAccent; class CustomizationView extends StatefulWidget { const CustomizationView({super.key}); @override State createState() => CustomizationState(); } class CustomizationState extends State { late bool oskKagariGimmick; late bool sheetbotRadarGraphs; late int ratingMode; late int timestampMode; void changeColor(Color color) { setState(() => pickerColor = color); } @override void initState() { if (!kIsWeb && !Platform.isAndroid && !Platform.isIOS) { windowManager.getTitle().then((value) => oldWindowTitle = value); windowManager.setTitle("Tetra Stats: ${t.settings}"); } _getPreferences(); super.initState(); } @override void dispose() { if (!kIsWeb && !Platform.isAndroid && !Platform.isIOS) windowManager.setTitle(oldWindowTitle); super.dispose(); } void _getPreferences() { if (prefs.getBool("oskKagariGimmick") != null) { oskKagariGimmick = prefs.getBool("oskKagariGimmick")!; } else { oskKagariGimmick = true; } if (prefs.getBool("sheetbotRadarGraphs") != null) { sheetbotRadarGraphs = prefs.getBool("sheetbotRadarGraphs")!; } else { sheetbotRadarGraphs = false; } if (prefs.getInt("ratingMode") != null) { ratingMode = prefs.getInt("ratingMode")!; } else { ratingMode = 0; } if (prefs.getInt("timestampMode") != null) { timestampMode = prefs.getInt("timestampMode")!; } else { timestampMode = 0; } } ThemeData getTheme(BuildContext context, Color color){ return Theme.of(context).copyWith(colorScheme: ColorScheme.dark(primary: color, secondary: Colors.white)); } @override Widget build(BuildContext context) { final t = Translations.of(context); List>? locales = >[]; for (var v in AppLocale.values) { locales.add(DropdownMenuItem( value: v, child: Text(t.locales[v.languageTag]!))); } return Scaffold( appBar: AppBar( title: Text(t.customization), ), backgroundColor: Colors.black, body: SafeArea( child: ListView( children: [ ListTile( title: Text(t.AccentColor), subtitle: Text(t.AccentColorDescription, style: subtitleStyle), trailing: ColorIndicator(HSVColor.fromColor(Theme.of(context).colorScheme.primary), width: 25, height: 25), onTap: () { showDialog( context: context, builder: (BuildContext context) => AlertDialog( title: const Text('Pick an accent color'), content: SingleChildScrollView( child: ColorPicker( pickerColor: pickerColor, onColorChanged: changeColor, ), ), actions: [ ElevatedButton( child: const Text('Set'), onPressed: () { setState(() { context.findAncestorStateOfType()?.setAccentColor(pickerColor); prefs.setInt("accentColor", pickerColor.value); }); Navigator.of(context).pop(); }, ), ])); } ), // const ListTile( // title: Text("Stats Table in TL mathes list"), // subtitle: Text("Not implemented"), // ), ListTile(title: Text(t.timestamps), subtitle: Text(t.timestampsDescription, style: subtitleStyle), trailing: DropdownButton( value: timestampMode, items: [ DropdownMenuItem(value: 0, child: Text(t.timestampsAbsoluteGMT)), DropdownMenuItem(value: 1, child: Text(t.timestampsAbsoluteLocalTime)), DropdownMenuItem(value: 2, child: Text(t.timestampsRelative)) ], onChanged: (dynamic value){ prefs.setInt("timestampMode", value); setState(() { timestampMode = value; }); }, ), ), ListTile(title: Text(t.rating), subtitle: Text(t.ratingDescription, style: subtitleStyle), trailing: DropdownButton( value: ratingMode, items: [ const DropdownMenuItem(value: 0, child: Text("TR")), const DropdownMenuItem(value: 1, child: Text("Glicko")), DropdownMenuItem(value: 2, child: Text(t.ratingLBposition)) ], onChanged: (dynamic value){ prefs.setInt("ratingMode", value); setState(() { ratingMode = value; }); }, ), ), ListTile(title: Text(t.sheetbotGraphs), subtitle: Text(t.sheetbotGraphsDescription, style: subtitleStyle), trailing: Switch(value: sheetbotRadarGraphs, onChanged: (bool value){ prefs.setBool("sheetbotRadarGraphs", value); setState(() { sheetbotRadarGraphs = value; }); }),), ListTile(title: Text(t.oskKagari), subtitle: Text(t.oskKagariDescription, style: subtitleStyle), trailing: Switch(value: oskKagariGimmick, onChanged: (bool value){ prefs.setBool("oskKagariGimmick", value); setState(() { oskKagariGimmick = value; }); }),) ], )), ); } }