Made GradeAverage persistent
This commit is contained in:
parent
3f05f68ac1
commit
fb839eb458
@ -14,7 +14,7 @@ import 'model/chatList/chatProps.dart';
|
|||||||
import 'model/files/filesProps.dart';
|
import 'model/files/filesProps.dart';
|
||||||
import 'model/message/messageProps.dart';
|
import 'model/message/messageProps.dart';
|
||||||
import 'model/timetable/timetableProps.dart';
|
import 'model/timetable/timetableProps.dart';
|
||||||
import 'storage/settings/settingsProvider.dart';
|
import 'storage/base/settingsProvider.dart';
|
||||||
import 'theming/darkAppTheme.dart';
|
import 'theming/darkAppTheme.dart';
|
||||||
import 'theming/lightAppTheme.dart';
|
import 'theming/lightAppTheme.dart';
|
||||||
import 'view/login/login.dart';
|
import 'view/login/login.dart';
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:json_annotation/json_annotation.dart';
|
import 'package:json_annotation/json_annotation.dart';
|
||||||
|
|
||||||
|
import '../gradeAverages/gradeAveragesSettings.dart';
|
||||||
|
|
||||||
part 'settings.g.dart';
|
part 'settings.g.dart';
|
||||||
|
|
||||||
@JsonSerializable(explicitToJson: true)
|
@JsonSerializable(explicitToJson: true)
|
||||||
@ -12,7 +14,13 @@ class Settings {
|
|||||||
ThemeMode appTheme;
|
ThemeMode appTheme;
|
||||||
bool devToolsEnabled;
|
bool devToolsEnabled;
|
||||||
|
|
||||||
Settings(this.appTheme, this.devToolsEnabled);
|
GradeAveragesSettings gradeAveragesSettings;
|
||||||
|
|
||||||
|
Settings({
|
||||||
|
required this.appTheme,
|
||||||
|
required this.devToolsEnabled,
|
||||||
|
required this.gradeAveragesSettings
|
||||||
|
});
|
||||||
|
|
||||||
static String _themeToJson(ThemeMode m) => m.name;
|
static String _themeToJson(ThemeMode m) => m.name;
|
||||||
static ThemeMode _themeFromJson(String m) => ThemeMode.values.firstWhere((element) => element.name == m);
|
static ThemeMode _themeFromJson(String m) => ThemeMode.values.firstWhere((element) => element.name == m);
|
@ -7,11 +7,14 @@ part of 'settings.dart';
|
|||||||
// **************************************************************************
|
// **************************************************************************
|
||||||
|
|
||||||
Settings _$SettingsFromJson(Map<String, dynamic> json) => Settings(
|
Settings _$SettingsFromJson(Map<String, dynamic> json) => Settings(
|
||||||
Settings._themeFromJson(json['appTheme'] as String),
|
appTheme: Settings._themeFromJson(json['appTheme'] as String),
|
||||||
json['devToolsEnabled'] as bool,
|
devToolsEnabled: json['devToolsEnabled'] as bool,
|
||||||
|
gradeAveragesSettings: GradeAveragesSettings.fromJson(
|
||||||
|
json['gradeAveragesSettings'] as Map<String, dynamic>),
|
||||||
);
|
);
|
||||||
|
|
||||||
Map<String, dynamic> _$SettingsToJson(Settings instance) => <String, dynamic>{
|
Map<String, dynamic> _$SettingsToJson(Settings instance) => <String, dynamic>{
|
||||||
'appTheme': Settings._themeToJson(instance.appTheme),
|
'appTheme': Settings._themeToJson(instance.appTheme),
|
||||||
'devToolsEnabled': instance.devToolsEnabled,
|
'devToolsEnabled': instance.devToolsEnabled,
|
||||||
|
'gradeAveragesSettings': instance.gradeAveragesSettings.toJson(),
|
||||||
};
|
};
|
@ -1,6 +1,7 @@
|
|||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
import 'dart:developer';
|
import 'dart:developer';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:marianum_mobile/storage/gradeAverages/gradeAveragesSettings.dart';
|
||||||
import 'package:shared_preferences/shared_preferences.dart';
|
import 'package:shared_preferences/shared_preferences.dart';
|
||||||
|
|
||||||
import 'settings.dart';
|
import 'settings.dart';
|
||||||
@ -42,8 +43,12 @@ class SettingsProvider extends ChangeNotifier {
|
|||||||
|
|
||||||
Settings _defaults() {
|
Settings _defaults() {
|
||||||
return Settings(
|
return Settings(
|
||||||
ThemeMode.system,
|
appTheme: ThemeMode.system,
|
||||||
false,
|
devToolsEnabled: false,
|
||||||
|
gradeAveragesSettings: GradeAveragesSettings(
|
||||||
|
useGradeSystem: true,
|
||||||
|
inputs: []
|
||||||
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
15
lib/storage/gradeAverages/gradeAveragesSettings.dart
Normal file
15
lib/storage/gradeAverages/gradeAveragesSettings.dart
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
|
||||||
|
import 'package:json_annotation/json_annotation.dart';
|
||||||
|
|
||||||
|
part 'gradeAveragesSettings.g.dart';
|
||||||
|
|
||||||
|
@JsonSerializable()
|
||||||
|
class GradeAveragesSettings {
|
||||||
|
bool useGradeSystem;
|
||||||
|
List<int> inputs;
|
||||||
|
|
||||||
|
GradeAveragesSettings({required this.useGradeSystem, required this.inputs});
|
||||||
|
|
||||||
|
factory GradeAveragesSettings.fromJson(Map<String, dynamic> json) => _$GradeAveragesSettingsFromJson(json);
|
||||||
|
Map<String, dynamic> toJson() => _$GradeAveragesSettingsToJson(this);
|
||||||
|
}
|
21
lib/storage/gradeAverages/gradeAveragesSettings.g.dart
Normal file
21
lib/storage/gradeAverages/gradeAveragesSettings.g.dart
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
// GENERATED CODE - DO NOT MODIFY BY HAND
|
||||||
|
|
||||||
|
part of 'gradeAveragesSettings.dart';
|
||||||
|
|
||||||
|
// **************************************************************************
|
||||||
|
// JsonSerializableGenerator
|
||||||
|
// **************************************************************************
|
||||||
|
|
||||||
|
GradeAveragesSettings _$GradeAveragesSettingsFromJson(
|
||||||
|
Map<String, dynamic> json) =>
|
||||||
|
GradeAveragesSettings(
|
||||||
|
useGradeSystem: json['useGradeSystem'] as bool,
|
||||||
|
inputs: (json['inputs'] as List<dynamic>).map((e) => e as int).toList(),
|
||||||
|
);
|
||||||
|
|
||||||
|
Map<String, dynamic> _$GradeAveragesSettingsToJson(
|
||||||
|
GradeAveragesSettings instance) =>
|
||||||
|
<String, dynamic>{
|
||||||
|
'useGradeSystem': instance.useGradeSystem,
|
||||||
|
'inputs': instance.inputs,
|
||||||
|
};
|
@ -1,4 +1,6 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:marianum_mobile/storage/base/settingsProvider.dart';
|
||||||
|
import 'package:provider/provider.dart';
|
||||||
|
|
||||||
import '../../../../widget/confirmDialog.dart';
|
import '../../../../widget/confirmDialog.dart';
|
||||||
|
|
||||||
@ -14,6 +16,12 @@ class _GradeAverageState extends State<GradeAverage> {
|
|||||||
bool gradeSystem = true;
|
bool gradeSystem = true;
|
||||||
List<int> grades = List.empty(growable: true);
|
List<int> grades = List.empty(growable: true);
|
||||||
|
|
||||||
|
late SettingsProvider settings = Provider.of<SettingsProvider>(context, listen: false);
|
||||||
|
|
||||||
|
void _persistGrades() {
|
||||||
|
settings.val(write: true).gradeAveragesSettings.inputs = grades;
|
||||||
|
}
|
||||||
|
|
||||||
String getGradeDisplay(int grade) {
|
String getGradeDisplay(int grade) {
|
||||||
if(gradeSystem) {
|
if(gradeSystem) {
|
||||||
return "Note $grade";
|
return "Note $grade";
|
||||||
@ -22,6 +30,14 @@ class _GradeAverageState extends State<GradeAverage> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
super.initState();
|
||||||
|
|
||||||
|
grades = settings.val().gradeAveragesSettings.inputs;
|
||||||
|
gradeSystem = settings.val().gradeAveragesSettings.useGradeSystem;
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
if(grades.isNotEmpty) {
|
if(grades.isNotEmpty) {
|
||||||
@ -66,6 +82,8 @@ class _GradeAverageState extends State<GradeAverage> {
|
|||||||
void switchSystem() => setState(() {
|
void switchSystem() => setState(() {
|
||||||
grades.clear();
|
grades.clear();
|
||||||
gradeSystem = e;
|
gradeSystem = e;
|
||||||
|
settings.val(write: true).gradeAveragesSettings.useGradeSystem = e;
|
||||||
|
_persistGrades();
|
||||||
});
|
});
|
||||||
|
|
||||||
if(grades.isNotEmpty) {
|
if(grades.isNotEmpty) {
|
||||||
@ -117,6 +135,7 @@ class _GradeAverageState extends State<GradeAverage> {
|
|||||||
setState(() {
|
setState(() {
|
||||||
if(!grades.any(isThis)) return;
|
if(!grades.any(isThis)) return;
|
||||||
grades.removeAt(grades.indexWhere(isThis));
|
grades.removeAt(grades.indexWhere(isThis));
|
||||||
|
_persistGrades();
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
icon: const Icon(Icons.remove),
|
icon: const Icon(Icons.remove),
|
||||||
@ -127,6 +146,7 @@ class _GradeAverageState extends State<GradeAverage> {
|
|||||||
onPressed: () {
|
onPressed: () {
|
||||||
setState(() {
|
setState(() {
|
||||||
grades.add(grade);
|
grades.add(grade);
|
||||||
|
_persistGrades();
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
icon: const Icon(Icons.add),
|
icon: const Icon(Icons.add),
|
||||||
@ -145,6 +165,7 @@ class _GradeAverageState extends State<GradeAverage> {
|
|||||||
onPressed: () {
|
onPressed: () {
|
||||||
setState(() {
|
setState(() {
|
||||||
grades.removeWhere(isThis);
|
grades.removeWhere(isThis);
|
||||||
|
_persistGrades();
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
|
@ -3,11 +3,10 @@ import 'package:flutter/material.dart';
|
|||||||
import 'package:package_info/package_info.dart';
|
import 'package:package_info/package_info.dart';
|
||||||
import 'package:provider/provider.dart';
|
import 'package:provider/provider.dart';
|
||||||
import 'package:shared_preferences/shared_preferences.dart';
|
import 'package:shared_preferences/shared_preferences.dart';
|
||||||
import 'package:url_launcher/url_launcher.dart';
|
|
||||||
|
|
||||||
import '../../model/accountModel.dart';
|
import '../../model/accountModel.dart';
|
||||||
|
import '../../storage/base/settingsProvider.dart';
|
||||||
import '../../theming/appTheme.dart';
|
import '../../theming/appTheme.dart';
|
||||||
import '../../storage/settings/settingsProvider.dart';
|
|
||||||
import '../../widget/confirmDialog.dart';
|
import '../../widget/confirmDialog.dart';
|
||||||
import 'debug/debugOverview.dart';
|
import 'debug/debugOverview.dart';
|
||||||
import 'debug/jsonViewer.dart';
|
import 'debug/jsonViewer.dart';
|
||||||
@ -115,7 +114,7 @@ class _SettingsState extends State<Settings> {
|
|||||||
leading: const Icon(Icons.policy_outlined),
|
leading: const Icon(Icons.policy_outlined),
|
||||||
title: const Text("Datenschutz"),
|
title: const Text("Datenschutz"),
|
||||||
onTap: () {
|
onTap: () {
|
||||||
launchUrl(Uri.parse("https://mhsl.eu/datenschutz.html"));
|
ConfirmDialog.openBrowser(context, "https://mhsl.eu/datenschutz.html");
|
||||||
},
|
},
|
||||||
trailing: const Icon(Icons.open_in_new),
|
trailing: const Icon(Icons.open_in_new),
|
||||||
),
|
),
|
||||||
@ -124,7 +123,7 @@ class _SettingsState extends State<Settings> {
|
|||||||
leading: const Icon(Icons.badge_outlined),
|
leading: const Icon(Icons.badge_outlined),
|
||||||
title: const Text("Impressum"),
|
title: const Text("Impressum"),
|
||||||
onTap: () {
|
onTap: () {
|
||||||
launchUrl(Uri.parse("https://mhsl.eu/id.html"));
|
ConfirmDialog.openBrowser(context, "https://mhsl.eu/id.html");
|
||||||
},
|
},
|
||||||
trailing: const Icon(Icons.open_in_new),
|
trailing: const Icon(Icons.open_in_new),
|
||||||
),
|
),
|
||||||
@ -133,7 +132,7 @@ class _SettingsState extends State<Settings> {
|
|||||||
|
|
||||||
ListTile(
|
ListTile(
|
||||||
leading: const Icon(Icons.developer_mode_outlined),
|
leading: const Icon(Icons.developer_mode_outlined),
|
||||||
title: const Text("Entwicklermodus"),
|
title: const Text("Entwickleransicht"),
|
||||||
trailing: Checkbox(
|
trailing: Checkbox(
|
||||||
visualDensity: const VisualDensity(horizontal: VisualDensity.minimumDensity),
|
visualDensity: const VisualDensity(horizontal: VisualDensity.minimumDensity),
|
||||||
value: settings.val().devToolsEnabled,
|
value: settings.val().devToolsEnabled,
|
||||||
@ -149,16 +148,6 @@ class _SettingsState extends State<Settings> {
|
|||||||
visible: settings.val().devToolsEnabled,
|
visible: settings.val().devToolsEnabled,
|
||||||
child: Column(
|
child: Column(
|
||||||
children: [
|
children: [
|
||||||
ListTile(
|
|
||||||
leading: const Icon(Icons.data_object),
|
|
||||||
title: const Text("Storage view"),
|
|
||||||
onTap: () {
|
|
||||||
Navigator.push(context, MaterialPageRoute(builder: (context) {
|
|
||||||
return const DebugOverview();
|
|
||||||
}));
|
|
||||||
},
|
|
||||||
trailing: const Icon(Icons.arrow_right),
|
|
||||||
),
|
|
||||||
ListTile(
|
ListTile(
|
||||||
leading: const Icon(Icons.logo_dev_outlined),
|
leading: const Icon(Icons.logo_dev_outlined),
|
||||||
title: const Text("Logging verbosity"),
|
title: const Text("Logging verbosity"),
|
||||||
@ -170,9 +159,19 @@ class _SettingsState extends State<Settings> {
|
|||||||
},
|
},
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
ListTile(
|
||||||
|
leading: const Icon(Icons.data_object),
|
||||||
|
title: const Text("Cache JSON dump"),
|
||||||
|
onTap: () {
|
||||||
|
Navigator.push(context, MaterialPageRoute(builder: (context) {
|
||||||
|
return const DebugOverview();
|
||||||
|
}));
|
||||||
|
},
|
||||||
|
trailing: const Icon(Icons.arrow_right),
|
||||||
|
),
|
||||||
ListTile(
|
ListTile(
|
||||||
leading: const Icon(Icons.settings_applications_outlined),
|
leading: const Icon(Icons.settings_applications_outlined),
|
||||||
title: const Text("Settings JSON dump"),
|
title: const Text("Storage JSON dump"),
|
||||||
onTap: () {
|
onTap: () {
|
||||||
JsonViewer.asDialog(context, settings.val().toJson());
|
JsonViewer.asDialog(context, settings.val().toJson());
|
||||||
},
|
},
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:url_launcher/url_launcher.dart';
|
||||||
|
|
||||||
class ConfirmDialog extends StatelessWidget {
|
class ConfirmDialog extends StatelessWidget {
|
||||||
final String title;
|
final String title;
|
||||||
@ -26,4 +27,16 @@ class ConfirmDialog extends StatelessWidget {
|
|||||||
],
|
],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void openBrowser(BuildContext context, String url) {
|
||||||
|
showDialog(
|
||||||
|
context: context,
|
||||||
|
builder: (context) => ConfirmDialog(
|
||||||
|
title: "Link öffnen",
|
||||||
|
content: "Möchtest du den folgenden Link öffnen?\n${url}",
|
||||||
|
confirmButton: "Öffnen",
|
||||||
|
onConfirm: () => launchUrl(Uri.parse(url), mode: LaunchMode.externalApplication),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user