335 lines
14 KiB
Dart
335 lines
14 KiB
Dart
// import 'package:refilc/models/settings.dart';
|
|
import 'package:refilc/api/providers/user_provider.dart';
|
|
import 'package:refilc/models/settings.dart';
|
|
import 'package:refilc/theme/colors/colors.dart';
|
|
import 'package:refilc_mobile_ui/common/chips/new_chip.dart';
|
|
import 'package:refilc_mobile_ui/common/panel/panel_button.dart';
|
|
import 'package:refilc_mobile_ui/common/splitted_panel/splitted_panel.dart';
|
|
import 'package:refilc_mobile_ui/screens/settings/settings_helper.dart';
|
|
import 'package:flutter/cupertino.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter_feather_icons/flutter_feather_icons.dart';
|
|
import 'package:provider/provider.dart';
|
|
import 'package:refilc_plus/ui/mobile/settings/submenu/calendar_sync.dart';
|
|
import 'package:refilc_plus/ui/mobile/settings/submenu/grade_exporting.dart';
|
|
import 'package:refilc_plus/models/premium_scopes.dart';
|
|
import 'package:refilc_plus/providers/plus_provider.dart';
|
|
import 'package:refilc_plus/ui/mobile/plus/upsell.dart';
|
|
import 'package:refilc_plus/ui/mobile/settings/welcome_message.dart';
|
|
|
|
import 'package:refilc_kreta_api/providers/grade_provider.dart';
|
|
import 'package:refilc_mobile_ui/common/action_button.dart';
|
|
|
|
// import 'package:provider/provider.dart';
|
|
import 'submenu_screen.i18n.dart';
|
|
|
|
class MenuExtrasSettings extends StatelessWidget {
|
|
const MenuExtrasSettings({
|
|
super.key,
|
|
this.borderRadius = const BorderRadius.vertical(
|
|
top: Radius.circular(4.0), bottom: Radius.circular(12.0)),
|
|
});
|
|
|
|
final BorderRadius borderRadius;
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return PanelButton(
|
|
onPressed: () => Navigator.of(context, rootNavigator: true).push(
|
|
CupertinoPageRoute(builder: (context) => const ExtrasSettingsScreen()),
|
|
),
|
|
title: Text("extras".i18n),
|
|
leading: Icon(
|
|
FeatherIcons.edit,
|
|
size: 22.0,
|
|
color: AppColors.of(context).text.withValues(alpha: 0.95),
|
|
),
|
|
trailing: Row(
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: [
|
|
if (Provider.of<SettingsProvider>(context)
|
|
.unseenNewFeatures
|
|
.toSet()
|
|
.intersection({'grade_exporting'}).isNotEmpty)
|
|
const NewChip(),
|
|
Icon(
|
|
FeatherIcons.chevronRight,
|
|
size: 22.0,
|
|
color: AppColors.of(context).text.withValues(alpha: 0.95),
|
|
)
|
|
],
|
|
),
|
|
borderRadius: borderRadius,
|
|
);
|
|
}
|
|
}
|
|
|
|
class ExtrasSettingsScreen extends StatefulWidget {
|
|
const ExtrasSettingsScreen({super.key});
|
|
|
|
@override
|
|
ExtrasSettingsScreenState createState() => ExtrasSettingsScreenState();
|
|
}
|
|
|
|
class ExtrasSettingsScreenState extends State<ExtrasSettingsScreen> {
|
|
late SettingsProvider settingsProvider;
|
|
late UserProvider user;
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
SettingsProvider settingsProvider = Provider.of<SettingsProvider>(context);
|
|
UserProvider user = Provider.of<UserProvider>(context);
|
|
|
|
return Scaffold(
|
|
appBar: AppBar(
|
|
surfaceTintColor: Theme.of(context).scaffoldBackgroundColor,
|
|
leading: BackButton(color: AppColors.of(context).text),
|
|
title: Text(
|
|
"extras".i18n,
|
|
style: TextStyle(color: AppColors.of(context).text),
|
|
),
|
|
),
|
|
body: SingleChildScrollView(
|
|
child: Padding(
|
|
padding: const EdgeInsets.symmetric(vertical: 16.0, horizontal: 24.0),
|
|
child: Column(
|
|
children: [
|
|
SplittedPanel(
|
|
padding: const EdgeInsets.only(top: 8.0),
|
|
cardPadding: const EdgeInsets.all(4.0),
|
|
isSeparated: true,
|
|
children: [
|
|
PanelButton(
|
|
padding: const EdgeInsets.only(left: 14.0, right: 6.0),
|
|
onPressed: () async {
|
|
if (!Provider.of<PlusProvider>(context, listen: false)
|
|
.hasScope(PremiumScopes.customGradeRarities)) {
|
|
return PlusLockedFeaturePopup.show(
|
|
context: context,
|
|
feature: PremiumFeature.gradeRarities);
|
|
}
|
|
|
|
// settingsProvider.update(
|
|
// gradeOpeningFun: !settingsProvider.gradeOpeningFun);
|
|
SettingsHelper.surpriseGradeRarityText(
|
|
context,
|
|
title: 'rarity_title'.i18n,
|
|
cancel: 'cancel'.i18n,
|
|
done: 'done'.i18n,
|
|
rarities: [
|
|
"common".i18n,
|
|
"uncommon".i18n,
|
|
"rare".i18n,
|
|
"epic".i18n,
|
|
"legendary".i18n,
|
|
],
|
|
);
|
|
setState(() {});
|
|
},
|
|
trailingDivider: true,
|
|
title: Text(
|
|
"surprise_grades".i18n,
|
|
style: TextStyle(
|
|
color: AppColors.of(context).text.withValues(
|
|
alpha:
|
|
settingsProvider.gradeOpeningFun ? .95 : .25),
|
|
),
|
|
),
|
|
leading: Icon(
|
|
FeatherIcons.gift,
|
|
size: 22.0,
|
|
color: AppColors.of(context).text.withValues(
|
|
alpha: settingsProvider.gradeOpeningFun ? .95 : .25),
|
|
),
|
|
trailing: Switch(
|
|
onChanged: (v) async {
|
|
settingsProvider.update(gradeOpeningFun: v);
|
|
|
|
setState(() {});
|
|
},
|
|
value: settingsProvider.gradeOpeningFun,
|
|
activeColor: Theme.of(context).colorScheme.secondary,
|
|
),
|
|
borderRadius: const BorderRadius.vertical(
|
|
top: Radius.circular(12.0),
|
|
bottom: Radius.circular(12.0),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
SplittedPanel(
|
|
padding: const EdgeInsets.only(top: 9.0),
|
|
cardPadding: const EdgeInsets.all(4.0),
|
|
isSeparated: true,
|
|
children: [
|
|
WelcomeMessagePanelButton(settingsProvider, user),
|
|
],
|
|
),
|
|
SplittedPanel(
|
|
padding: const EdgeInsets.only(top: 9.0),
|
|
cardPadding: const EdgeInsets.all(4.0),
|
|
isSeparated: true,
|
|
children: [
|
|
MenuCalendarSync(
|
|
borderRadius: BorderRadius.circular(12.0),
|
|
),
|
|
],
|
|
),
|
|
SplittedPanel(
|
|
padding: const EdgeInsets.only(top: 9.0),
|
|
cardPadding: const EdgeInsets.all(4.0),
|
|
isSeparated: true,
|
|
children: [
|
|
MenuGradeExporting(
|
|
borderRadius: BorderRadius.circular(12.0),
|
|
),
|
|
],
|
|
),
|
|
SplittedPanel(
|
|
padding: const EdgeInsets.only(top: 9.0),
|
|
cardPadding: const EdgeInsets.all(4.0),
|
|
isSeparated: true,
|
|
children: [
|
|
PanelButton(
|
|
padding: const EdgeInsets.only(left: 14.0, right: 6.0),
|
|
onPressed: () async {
|
|
if (!settingsProvider.goodStudent) {
|
|
showDialog(
|
|
context: context,
|
|
builder: (context) => WillPopScope(
|
|
onWillPop: () async => false,
|
|
child: AlertDialog(
|
|
shape: RoundedRectangleBorder(
|
|
borderRadius: BorderRadius.circular(12.0)),
|
|
title: Text("attention".i18n),
|
|
content: Text("goodstudent_disclaimer".i18n),
|
|
actions: [
|
|
ActionButton(
|
|
label: "understand".i18n,
|
|
onTap: () {
|
|
Navigator.of(context).pop();
|
|
settingsProvider.update(
|
|
goodStudent: true);
|
|
Provider.of<GradeProvider>(context,
|
|
listen: false)
|
|
.convertBySettings();
|
|
setState(() {});
|
|
})
|
|
],
|
|
),
|
|
),
|
|
);
|
|
} else {
|
|
settingsProvider.update(goodStudent: false);
|
|
Provider.of<GradeProvider>(context, listen: false)
|
|
.convertBySettings();
|
|
setState(() {});
|
|
}
|
|
},
|
|
title: Text(
|
|
"goodstudent".i18n,
|
|
style: TextStyle(
|
|
color: AppColors.of(context).text.withValues(
|
|
alpha: settingsProvider.goodStudent ? .95 : .25),
|
|
),
|
|
),
|
|
leading: Icon(
|
|
FeatherIcons.userCheck,
|
|
size: 22.0,
|
|
color: AppColors.of(context).text.withValues(
|
|
alpha: settingsProvider.goodStudent ? .95 : .25),
|
|
),
|
|
trailing: Switch(
|
|
onChanged: (v) async {
|
|
if (v) {
|
|
showDialog(
|
|
context: context,
|
|
builder: (context) => WillPopScope(
|
|
onWillPop: () async => false,
|
|
child: AlertDialog(
|
|
shape: RoundedRectangleBorder(
|
|
borderRadius: BorderRadius.circular(12.0)),
|
|
title: Text("attention".i18n),
|
|
content: Text("goodstudent_disclaimer".i18n),
|
|
actions: [
|
|
ActionButton(
|
|
label: "understand".i18n,
|
|
onTap: () {
|
|
Navigator.of(context).pop();
|
|
settingsProvider.update(
|
|
goodStudent: true);
|
|
Provider.of<GradeProvider>(context,
|
|
listen: false)
|
|
.convertBySettings();
|
|
setState(() {});
|
|
})
|
|
],
|
|
),
|
|
),
|
|
);
|
|
} else {
|
|
settingsProvider.update(goodStudent: false);
|
|
Provider.of<GradeProvider>(context, listen: false)
|
|
.convertBySettings();
|
|
setState(() {});
|
|
}
|
|
},
|
|
value: settingsProvider.goodStudent,
|
|
activeColor: Theme.of(context).colorScheme.secondary,
|
|
),
|
|
borderRadius: const BorderRadius.vertical(
|
|
top: Radius.circular(12.0),
|
|
bottom: Radius.circular(12.0),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
SplittedPanel(
|
|
padding: const EdgeInsets.only(top: 9.0),
|
|
cardPadding: const EdgeInsets.all(4.0),
|
|
isSeparated: true,
|
|
children: [
|
|
PanelButton(
|
|
padding: const EdgeInsets.only(left: 14.0, right: 6.0),
|
|
onPressed: () async {
|
|
settingsProvider.update(
|
|
presentationMode: !settingsProvider.presentationMode);
|
|
setState(() {});
|
|
},
|
|
title: Text(
|
|
"presentation".i18n,
|
|
style: TextStyle(
|
|
color: AppColors.of(context).text.withValues(
|
|
alpha:
|
|
settingsProvider.presentationMode ? .95 : .25),
|
|
),
|
|
),
|
|
leading: Icon(
|
|
FeatherIcons.tv,
|
|
size: 22.0,
|
|
color: AppColors.of(context).text.withValues(
|
|
alpha: settingsProvider.presentationMode ? .95 : .25),
|
|
),
|
|
trailing: Switch(
|
|
onChanged: (v) async {
|
|
settingsProvider.update(presentationMode: v);
|
|
setState(() {});
|
|
},
|
|
value: settingsProvider.presentationMode,
|
|
activeColor: Theme.of(context).colorScheme.secondary,
|
|
),
|
|
borderRadius: const BorderRadius.vertical(
|
|
top: Radius.circular(12.0),
|
|
bottom: Radius.circular(12.0),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
],
|
|
),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|