From 2d96b4505e8c454a5ae3a844ffdc41387a5138d2 Mon Sep 17 00:00:00 2001 From: NaiJi Date: Wed, 18 May 2022 12:07:14 +0300 Subject: [PATCH] Disable unavailable functionality when server is not created - Remove create and upgrade server jobs when server is not there - Disable root SSH panel page when server is not there --- assets/translations/en.json | 2 +- lib/logic/cubit/backups/backups_cubit.dart | 1 + .../cubit/dns_records/dns_records_cubit.dart | 1 + lib/logic/cubit/services/services_cubit.dart | 1 + lib/logic/cubit/users/users_cubit.dart | 1 + .../components/jobs_content/jobs_content.dart | 62 +++++++++++-------- lib/ui/pages/more/more.dart | 11 +++- 7 files changed, 49 insertions(+), 30 deletions(-) diff --git a/assets/translations/en.json b/assets/translations/en.json index 78ba00c5..3b7bf3af 100644 --- a/assets/translations/en.json +++ b/assets/translations/en.json @@ -36,7 +36,7 @@ "about_project": "About us", "about_app": "About application", "onboarding": "Onboarding", - "create_ssh_key": "Create ssh key", + "create_ssh_key": "Create SSH key", "generate_key": "Generate key", "generate_key_text": "You can generate ssh key", "console": "Console", diff --git a/lib/logic/cubit/backups/backups_cubit.dart b/lib/logic/cubit/backups/backups_cubit.dart index 67570c4e..47ad4796 100644 --- a/lib/logic/cubit/backups/backups_cubit.dart +++ b/lib/logic/cubit/backups/backups_cubit.dart @@ -5,6 +5,7 @@ import 'package:selfprivacy/config/get_it_config.dart'; import 'package:selfprivacy/logic/api_maps/backblaze.dart'; import 'package:selfprivacy/logic/api_maps/server.dart'; import 'package:selfprivacy/logic/cubit/app_config_dependent/authentication_dependend_cubit.dart'; +import 'package:selfprivacy/logic/cubit/server_installation/server_installation_cubit.dart'; import 'package:selfprivacy/logic/models/hive/backblaze_bucket.dart'; import 'package:selfprivacy/logic/models/json/backup.dart'; diff --git a/lib/logic/cubit/dns_records/dns_records_cubit.dart b/lib/logic/cubit/dns_records/dns_records_cubit.dart index 6b8bf715..88ad9ba0 100644 --- a/lib/logic/cubit/dns_records/dns_records_cubit.dart +++ b/lib/logic/cubit/dns_records/dns_records_cubit.dart @@ -1,5 +1,6 @@ import 'package:cubit_form/cubit_form.dart'; import 'package:selfprivacy/logic/cubit/app_config_dependent/authentication_dependend_cubit.dart'; +import 'package:selfprivacy/logic/cubit/server_installation/server_installation_cubit.dart'; import 'package:selfprivacy/logic/models/hive/server_domain.dart'; import 'package:selfprivacy/logic/models/json/dns_records.dart'; diff --git a/lib/logic/cubit/services/services_cubit.dart b/lib/logic/cubit/services/services_cubit.dart index e503389d..5caa5a42 100644 --- a/lib/logic/cubit/services/services_cubit.dart +++ b/lib/logic/cubit/services/services_cubit.dart @@ -1,6 +1,7 @@ import 'package:selfprivacy/logic/api_maps/server.dart'; import 'package:selfprivacy/logic/common_enum/common_enum.dart'; import 'package:selfprivacy/logic/cubit/app_config_dependent/authentication_dependend_cubit.dart'; +import 'package:selfprivacy/logic/cubit/server_installation/server_installation_cubit.dart'; part 'services_state.dart'; diff --git a/lib/logic/cubit/users/users_cubit.dart b/lib/logic/cubit/users/users_cubit.dart index 543b5c46..41b8747a 100644 --- a/lib/logic/cubit/users/users_cubit.dart +++ b/lib/logic/cubit/users/users_cubit.dart @@ -1,6 +1,7 @@ import 'package:hive/hive.dart'; import 'package:selfprivacy/config/hive_config.dart'; import 'package:selfprivacy/logic/cubit/app_config_dependent/authentication_dependend_cubit.dart'; +import 'package:selfprivacy/logic/cubit/server_installation/server_installation_cubit.dart'; import 'package:selfprivacy/logic/models/hive/user.dart'; import '../../api_maps/server.dart'; diff --git a/lib/ui/components/jobs_content/jobs_content.dart b/lib/ui/components/jobs_content/jobs_content.dart index 92298a06..1859cd70 100644 --- a/lib/ui/components/jobs_content/jobs_content.dart +++ b/lib/ui/components/jobs_content/jobs_content.dart @@ -5,6 +5,7 @@ import 'package:selfprivacy/config/brand_colors.dart'; import 'package:selfprivacy/config/brand_theme.dart'; import 'package:selfprivacy/config/get_it_config.dart'; import 'package:selfprivacy/logic/cubit/jobs/jobs_cubit.dart'; +import 'package:selfprivacy/logic/cubit/server_installation/server_installation_cubit.dart'; import 'package:selfprivacy/ui/components/action_button/action_button.dart'; import 'package:selfprivacy/ui/components/brand_alert/brand_alert.dart'; import 'package:selfprivacy/ui/components/brand_button/brand_button.dart'; @@ -19,38 +20,45 @@ class JobsContent extends StatelessWidget { Widget build(BuildContext context) { return BlocBuilder( builder: (context, state) { - late final List widgets; + late List widgets; + var installationState = context.read().state; if (state is JobsStateEmpty) { widgets = [ SizedBox(height: 80), Center(child: BrandText.body1('jobs.empty'.tr())), - SizedBox(height: 80), - BrandButton.rised( - onPressed: () => context.read().upgradeServer(), - text: 'jobs.upgradeServer'.tr(), - ), - SizedBox(height: 10), - BrandButton.text( - onPressed: () { - var nav = getIt(); - nav.showPopUpDialog(BrandAlert( - title: 'jobs.rebootServer'.tr(), - contentText: 'modals.3'.tr(), - actions: [ - ActionButton( - text: 'basis.cancel'.tr(), - ), - ActionButton( - onPressed: () => - {context.read().rebootServer()}, - text: 'modals.9'.tr(), - ) - ], - )); - }, - title: 'jobs.rebootServer'.tr(), - ), ]; + + if (installationState is ServerInstallationFinished) { + widgets = [ + ...widgets, + SizedBox(height: 80), + BrandButton.rised( + onPressed: () => context.read().upgradeServer(), + text: 'jobs.upgradeServer'.tr(), + ), + SizedBox(height: 10), + BrandButton.text( + onPressed: () { + var nav = getIt(); + nav.showPopUpDialog(BrandAlert( + title: 'jobs.rebootServer'.tr(), + contentText: 'modals.3'.tr(), + actions: [ + ActionButton( + text: 'basis.cancel'.tr(), + ), + ActionButton( + onPressed: () => + {context.read().rebootServer()}, + text: 'modals.9'.tr(), + ) + ], + )); + }, + title: 'jobs.rebootServer'.tr(), + ), + ]; + } } else if (state is JobsStateLoading) { widgets = [ SizedBox(height: 80), diff --git a/lib/ui/pages/more/more.dart b/lib/ui/pages/more/more.dart index c588c007..d91ee769 100644 --- a/lib/ui/pages/more/more.dart +++ b/lib/ui/pages/more/more.dart @@ -3,6 +3,7 @@ import 'package:flutter/material.dart'; import 'package:ionicons/ionicons.dart'; import 'package:selfprivacy/config/brand_colors.dart'; import 'package:selfprivacy/config/brand_theme.dart'; +import 'package:selfprivacy/logic/cubit/server_installation/server_installation_cubit.dart'; import 'package:selfprivacy/ui/components/brand_divider/brand_divider.dart'; import 'package:selfprivacy/ui/components/brand_header/brand_header.dart'; import 'package:selfprivacy/ui/components/brand_icons/brand_icons.dart'; @@ -70,6 +71,8 @@ class MorePage extends StatelessWidget { goTo: Console(), ), _NavItem( + isEnabled: context.read().state + is ServerInstallationFinished, title: 'more.create_ssh_key'.tr(), iconData: Ionicons.key_outline, goTo: SshKeysPage( @@ -87,6 +90,7 @@ class MorePage extends StatelessWidget { class _NavItem extends StatelessWidget { const _NavItem({ Key? key, + this.isEnabled = true, required this.iconData, required this.goTo, required this.title, @@ -95,15 +99,18 @@ class _NavItem extends StatelessWidget { final IconData iconData; final Widget goTo; final String title; + final bool isEnabled; @override Widget build(BuildContext context) { return GestureDetector( - onTap: () => Navigator.of(context).push(materialRoute(goTo)), + onTap: isEnabled + ? () => Navigator.of(context).push(materialRoute(goTo)) + : null, child: _MoreMenuItem( iconData: iconData, title: title, - isActive: true, + isActive: isEnabled, ), ); }