refa: settings model (#1773)

* opt: MediaQuery

* refa: settings model
This commit is contained in:
My-Responsitories
2025-12-10 16:41:31 +08:00
committed by GitHub
parent b12bdf2eb8
commit 890dc58dc3
13 changed files with 406 additions and 579 deletions

View File

@@ -8,10 +8,9 @@ class NormalItem extends StatefulWidget {
final StringGetter? getTitle;
final String? subtitle;
final StringGetter? getSubtitle;
final String? setKey;
final Widget? leading;
final Widget Function()? getTrailing;
final Function? onTap;
final void Function(BuildContext context, void Function() setState)? onTap;
final EdgeInsetsGeometry? contentPadding;
final TextStyle? titleStyle;
@@ -20,7 +19,6 @@ class NormalItem extends StatefulWidget {
this.getTitle,
this.subtitle,
this.getSubtitle,
this.setKey,
this.leading,
this.getTrailing,
this.onTap,
@@ -36,22 +34,21 @@ class NormalItem extends StatefulWidget {
class _NormalItemState extends State<NormalItem> {
@override
Widget build(BuildContext context) {
late final theme = Theme.of(context);
return ListTile(
contentPadding: widget.contentPadding,
onTap: () => widget.onTap?.call(() {
if (mounted) {
setState(() {});
}
}),
onTap: widget.onTap == null
? null
: () => widget.onTap!(context, refresh),
title: Text(
widget.title ?? widget.getTitle!(),
style: widget.titleStyle ?? Theme.of(context).textTheme.titleMedium!,
style: widget.titleStyle ?? theme.textTheme.titleMedium!,
),
subtitle: widget.subtitle != null || widget.getSubtitle != null
? Text(
widget.subtitle ?? widget.getSubtitle!(),
style: Theme.of(context).textTheme.labelMedium!.copyWith(
color: Theme.of(context).colorScheme.outline,
style: theme.textTheme.labelMedium!.copyWith(
color: theme.colorScheme.outline,
),
)
: null,
@@ -59,4 +56,10 @@ class _NormalItemState extends State<NormalItem> {
trailing: widget.getTrailing?.call(),
);
}
void refresh() {
if (mounted) {
setState(() {});
}
}
}

View File

@@ -1,25 +1,25 @@
import 'package:PiliPlus/common/widgets/dialog/dialog.dart';
import 'package:PiliPlus/common/widgets/flutter/list_tile.dart';
import 'package:PiliPlus/utils/storage.dart';
import 'package:PiliPlus/utils/storage_key.dart';
import 'package:PiliPlus/utils/storage_pref.dart';
import 'package:flutter/material.dart' hide ListTile;
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
import 'package:get/get.dart';
class SetSwitchItem extends StatefulWidget {
final String? title;
final String title;
final String? subtitle;
final String setKey;
final bool defaultVal;
final ValueChanged<bool>? onChanged;
final bool needReboot;
final Widget? leading;
final Function? onTap;
final void Function(BuildContext context)? onTap;
final EdgeInsetsGeometry? contentPadding;
final TextStyle? titleStyle;
const SetSwitchItem({
this.title,
required this.title,
this.subtitle,
required this.setKey,
this.defaultVal = false,
@@ -64,47 +64,17 @@ class _SetSwitchItemState extends State<SetSwitchItem> {
setVal();
}
Future<void> switchChange(ThemeData theme, value) async {
if (widget.setKey == SettingBoxKey.badCertificateCallback &&
(value ?? !val)) {
showDialog(
context: context,
builder: (context) => AlertDialog(
title: const Text('确定禁用 SSL 证书验证?'),
content: const Text('禁用容易受到中间人攻击'),
actions: [
TextButton(
onPressed: Get.back,
child: Text(
'取消',
style: TextStyle(
color: theme.colorScheme.outline,
),
),
),
TextButton(
onPressed: () async {
Get.back();
await GStorage.setting.put(
SettingBoxKey.badCertificateCallback,
true,
);
val = true;
SmartDialog.showToast('重启生效');
if (mounted) {
setState(() {});
}
},
child: const Text('确认'),
),
],
),
);
return;
}
Future<void> switchChange([bool? value]) async {
val = value ?? !val;
if (widget.setKey == SettingBoxKey.badCertificateCallback && val) {
val = await showConfirmDialog(
context: context,
title: '确定禁用 SSL 证书验证?',
content: '禁用容易受到中间人攻击',
);
}
if (widget.setKey == SettingBoxKey.appFontWeight) {
await GStorage.setting.put(SettingBoxKey.appFontWeight, val ? 4 : -1);
} else {
@@ -135,10 +105,9 @@ class _SetSwitchItemState extends State<SetSwitchItem> {
);
return ListTile(
contentPadding: widget.contentPadding,
enabled: widget.onTap != null ? val : true,
onTap: () =>
widget.onTap != null ? widget.onTap!() : switchChange(theme, null),
title: Text(widget.title!, style: titleStyle),
enabled: widget.onTap == null ? true : val,
onTap: widget.onTap == null ? switchChange : () => widget.onTap!(context),
title: Text(widget.title, style: titleStyle),
subtitle: widget.subtitle != null
? Text(widget.subtitle!, style: subTitleStyle)
: null,
@@ -148,7 +117,7 @@ class _SetSwitchItemState extends State<SetSwitchItem> {
scale: 0.8,
child: Switch(
value: val,
onChanged: (value) => switchChange(theme, value),
onChanged: switchChange,
),
),
);