mirror of
https://gitlab.com/veilid/veilidchat.git
synced 2025-01-23 22:11:19 -05:00
64 lines
2.3 KiB
Dart
64 lines
2.3 KiB
Dart
import 'package:animated_theme_switcher/animated_theme_switcher.dart';
|
|
import 'package:awesome_extensions/awesome_extensions.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter_form_builder/flutter_form_builder.dart';
|
|
import 'package:flutter_translate/flutter_translate.dart';
|
|
import 'package:go_router/go_router.dart';
|
|
|
|
import '../layout/default_app_bar.dart';
|
|
import '../theme/theme.dart';
|
|
import '../tools/tools.dart';
|
|
import '../veilid_processor/veilid_processor.dart';
|
|
import 'settings.dart';
|
|
|
|
class SettingsPage extends StatefulWidget {
|
|
const SettingsPage({super.key});
|
|
|
|
@override
|
|
SettingsPageState createState() => SettingsPageState();
|
|
}
|
|
|
|
class SettingsPageState extends State<SettingsPage> {
|
|
final _formKey = GlobalKey<FormBuilderState>();
|
|
static const String formFieldTheme = 'theme';
|
|
static const String formFieldBrightness = 'brightness';
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
|
|
WidgetsBinding.instance.addPostFrameCallback((_) async {
|
|
await changeWindowSetup(
|
|
TitleBarStyle.normal, OrientationCapability.normal);
|
|
});
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) =>
|
|
AsyncBlocBuilder<PreferencesCubit, Preferences>(
|
|
builder: (context, state) => ThemeSwitchingArea(
|
|
child: Scaffold(
|
|
appBar: DefaultAppBar(
|
|
title: Text(translate('settings_page.titlebar')),
|
|
leading: IconButton(
|
|
icon: const Icon(Icons.arrow_back),
|
|
onPressed: () => GoRouterHelper(context).pop(),
|
|
),
|
|
actions: <Widget>[
|
|
const SignalStrengthMeterWidget()
|
|
.paddingLTRB(16, 0, 16, 0),
|
|
]),
|
|
body: FormBuilder(
|
|
key: _formKey,
|
|
child: ListView(
|
|
children: [
|
|
buildSettingsPageColorPreferences(
|
|
context: context, onChanged: () => setState(() {})),
|
|
buildSettingsPageBrightnessPreferences(
|
|
context: context, onChanged: () => setState(() {})),
|
|
].map((x) => x.paddingLTRB(0, 0, 0, 8)).toList(),
|
|
),
|
|
).paddingSymmetric(horizontal: 24, vertical: 16),
|
|
)));
|
|
}
|