2022-05-18 10:39:11 +00:00
|
|
|
part of 'server_details_screen.dart';
|
2021-03-26 13:38:39 +00:00
|
|
|
|
2022-09-14 23:31:25 +00:00
|
|
|
class _ServerSettings extends StatefulWidget {
|
2022-09-15 16:57:26 +00:00
|
|
|
const _ServerSettings();
|
2021-03-26 13:38:39 +00:00
|
|
|
|
2022-09-14 23:31:25 +00:00
|
|
|
@override
|
|
|
|
State<_ServerSettings> createState() => _ServerSettingsState();
|
|
|
|
}
|
|
|
|
|
|
|
|
class _ServerSettingsState extends State<_ServerSettings> {
|
|
|
|
bool? allowAutoUpgrade;
|
|
|
|
bool? rebootAfterUpgrade;
|
|
|
|
|
2021-03-26 13:38:39 +00:00
|
|
|
@override
|
2022-06-05 22:40:34 +00:00
|
|
|
Widget build(final BuildContext context) {
|
|
|
|
final serverDetailsState = context.watch<ServerDetailsCubit>().state;
|
2022-02-08 21:01:08 +00:00
|
|
|
if (serverDetailsState is ServerDetailsNotReady) {
|
2022-09-12 17:38:22 +00:00
|
|
|
return Text('basis.loading'.tr());
|
2022-02-08 21:01:08 +00:00
|
|
|
} else if (serverDetailsState is! Loaded) {
|
|
|
|
return BrandLoader.horizontal();
|
|
|
|
}
|
2022-09-14 23:31:25 +00:00
|
|
|
if (allowAutoUpgrade == null || rebootAfterUpgrade == null) {
|
|
|
|
allowAutoUpgrade = serverDetailsState.autoUpgradeSettings.enable;
|
|
|
|
rebootAfterUpgrade = serverDetailsState.autoUpgradeSettings.allowReboot;
|
|
|
|
}
|
|
|
|
|
2022-09-15 16:57:26 +00:00
|
|
|
return Column(
|
2021-03-26 13:38:39 +00:00
|
|
|
children: [
|
|
|
|
SwitcherBlock(
|
2022-09-14 23:31:25 +00:00
|
|
|
onChange: (final switched) {
|
|
|
|
context
|
|
|
|
.read<ServerDetailsCubit>()
|
|
|
|
.repository
|
|
|
|
.setAutoUpgradeSettings(
|
|
|
|
AutoUpgradeSettings(
|
|
|
|
enable: switched,
|
|
|
|
allowReboot: rebootAfterUpgrade ?? false,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
setState(() {
|
|
|
|
allowAutoUpgrade = switched;
|
|
|
|
});
|
|
|
|
},
|
|
|
|
isActive: allowAutoUpgrade ?? false,
|
2022-09-12 17:38:22 +00:00
|
|
|
child: _TextColumn(
|
|
|
|
title: 'providers.server.settings.allow_autoupgrade'.tr(),
|
|
|
|
value: 'providers.server.settings.allow_autoupgrade_hint'.tr(),
|
2021-03-26 13:38:39 +00:00
|
|
|
),
|
|
|
|
),
|
2022-09-14 13:37:29 +00:00
|
|
|
const Divider(height: 0),
|
2021-03-26 13:38:39 +00:00
|
|
|
SwitcherBlock(
|
2022-09-14 23:31:25 +00:00
|
|
|
onChange: (final switched) {
|
|
|
|
context
|
|
|
|
.read<ServerDetailsCubit>()
|
|
|
|
.repository
|
|
|
|
.setAutoUpgradeSettings(
|
|
|
|
AutoUpgradeSettings(
|
|
|
|
enable: allowAutoUpgrade ?? false,
|
|
|
|
allowReboot: switched,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
setState(
|
|
|
|
() {
|
|
|
|
rebootAfterUpgrade = switched;
|
|
|
|
},
|
|
|
|
);
|
|
|
|
},
|
|
|
|
isActive: rebootAfterUpgrade ?? false,
|
2022-09-12 17:38:22 +00:00
|
|
|
child: _TextColumn(
|
|
|
|
title: 'providers.server.settings.reboot_after_upgrade'.tr(),
|
|
|
|
value: 'providers.server.settings.reboot_after_upgrade_hint'.tr(),
|
2021-03-26 13:38:39 +00:00
|
|
|
),
|
|
|
|
),
|
2022-09-14 13:37:29 +00:00
|
|
|
const Divider(height: 0),
|
2021-03-26 13:38:39 +00:00
|
|
|
_Button(
|
2022-01-25 17:00:47 +00:00
|
|
|
onTap: () {
|
2022-09-14 23:31:25 +00:00
|
|
|
Navigator.of(context).push(
|
|
|
|
materialRoute(
|
|
|
|
const SelectTimezone(),
|
|
|
|
),
|
|
|
|
);
|
2022-01-25 17:00:47 +00:00
|
|
|
},
|
2021-03-26 13:38:39 +00:00
|
|
|
child: _TextColumn(
|
2022-09-12 17:38:22 +00:00
|
|
|
title: 'providers.server.settings.server_timezone'.tr(),
|
|
|
|
value: serverDetailsState.serverTimezone.toString(),
|
2021-03-26 13:38:39 +00:00
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class _Button extends StatelessWidget {
|
|
|
|
const _Button({
|
|
|
|
required this.onTap,
|
|
|
|
required this.child,
|
2022-06-05 22:40:34 +00:00
|
|
|
});
|
2021-03-26 13:38:39 +00:00
|
|
|
|
|
|
|
final Widget child;
|
|
|
|
final VoidCallback onTap;
|
|
|
|
|
|
|
|
@override
|
2022-06-05 22:40:34 +00:00
|
|
|
Widget build(final BuildContext context) => InkWell(
|
|
|
|
onTap: onTap,
|
|
|
|
child: Container(
|
2022-09-14 13:37:29 +00:00
|
|
|
padding: const EdgeInsets.symmetric(vertical: 16),
|
2022-06-05 22:40:34 +00:00
|
|
|
child: child,
|
|
|
|
),
|
|
|
|
);
|
2021-03-26 13:38:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
class _TextColumn extends StatelessWidget {
|
|
|
|
const _TextColumn({
|
|
|
|
required this.title,
|
|
|
|
required this.value,
|
2022-06-05 22:40:34 +00:00
|
|
|
});
|
2021-03-26 13:38:39 +00:00
|
|
|
|
|
|
|
final String title;
|
|
|
|
final String value;
|
|
|
|
@override
|
2022-06-05 22:40:34 +00:00
|
|
|
Widget build(final BuildContext context) => Column(
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
children: [
|
|
|
|
BrandText.body1(
|
|
|
|
title,
|
2022-09-12 17:38:22 +00:00
|
|
|
style: Theme.of(context).textTheme.bodyLarge,
|
2021-03-26 13:38:39 +00:00
|
|
|
),
|
2022-06-05 22:40:34 +00:00
|
|
|
const SizedBox(height: 5),
|
|
|
|
BrandText.body1(
|
|
|
|
value,
|
2022-09-12 17:38:22 +00:00
|
|
|
style: Theme.of(context).textTheme.bodyMedium,
|
2022-06-05 22:40:34 +00:00
|
|
|
),
|
|
|
|
],
|
|
|
|
);
|
2021-03-26 13:38:39 +00:00
|
|
|
}
|