From c894456fe6398ba1a3cf4ed47f1d70774cebdf70 Mon Sep 17 00:00:00 2001 From: NaiJi Date: Mon, 6 Nov 2023 17:15:38 +0400 Subject: [PATCH 1/8] refactor: Fix linter warnings - Remove unused text_extensions.dart --- lib/logic/api_maps/rest_maps/backblaze.dart | 2 +- .../digital_ocean/digital_ocean_api.dart | 1 - .../server_providers/hetzner/hetzner_api.dart | 4 +- .../server_installation_state.dart | 4 +- .../cubit/server_jobs/server_jobs_cubit.dart | 2 +- .../providers/dns_providers/cloudflare.dart | 2 +- lib/logic/providers/dns_providers/desec.dart | 2 +- .../dns_providers/digital_ocean_dns.dart | 2 +- .../components/progress_bar/progress_bar.dart | 4 +- lib/ui/helpers/empty_page_placeholder.dart | 2 +- lib/ui/pages/backups/backup_details.dart | 6 +- lib/ui/pages/backups/backups_list.dart | 120 +++++++++--------- lib/ui/pages/backups/snapshot_modal.dart | 2 +- .../pages/more/app_settings/app_settings.dart | 2 +- lib/ui/pages/more/more.dart | 2 +- lib/ui/pages/server_details/charts/chart.dart | 2 +- .../server_details/charts/network_charts.dart | 6 +- lib/ui/pages/services/service_page.dart | 2 +- lib/ui/pages/services/services.dart | 4 +- .../setup/initializing/initializing.dart | 6 +- .../initializing/server_type_picker.dart | 9 +- .../recovering/recover_by_new_device_key.dart | 4 +- .../recovering/recover_by_old_token.dart | 4 +- .../recovering/recover_by_recovery_key.dart | 2 +- .../recovering/recovery_confirm_server.dart | 2 +- .../recovering/recovery_method_select.dart | 2 +- .../setup/recovering/recovery_routing.dart | 2 +- .../recovery_server_provider_connected.dart | 4 +- lib/ui/pages/users/user_details.dart | 2 +- lib/utils/breakpoints.dart | 2 +- lib/utils/extensions/text_extensions.dart | 51 -------- 31 files changed, 106 insertions(+), 155 deletions(-) delete mode 100644 lib/utils/extensions/text_extensions.dart diff --git a/lib/logic/api_maps/rest_maps/backblaze.dart b/lib/logic/api_maps/rest_maps/backblaze.dart index d908cd26..f622a2fd 100644 --- a/lib/logic/api_maps/rest_maps/backblaze.dart +++ b/lib/logic/api_maps/rest_maps/backblaze.dart @@ -137,7 +137,7 @@ class BackblazeApi extends RestApiMap { { 'daysFromHidingToDeleting': 30, 'daysFromUploadingToHiding': null, - 'fileNamePrefix': '' + 'fileNamePrefix': '', } ], }, diff --git a/lib/logic/api_maps/rest_maps/server_providers/digital_ocean/digital_ocean_api.dart b/lib/logic/api_maps/rest_maps/server_providers/digital_ocean/digital_ocean_api.dart index 9ffdb666..bd453dee 100644 --- a/lib/logic/api_maps/rest_maps/server_providers/digital_ocean/digital_ocean_api.dart +++ b/lib/logic/api_maps/rest_maps/server_providers/digital_ocean/digital_ocean_api.dart @@ -5,7 +5,6 @@ import 'package:selfprivacy/config/get_it_config.dart'; import 'package:selfprivacy/logic/api_maps/generic_result.dart'; import 'package:selfprivacy/logic/api_maps/rest_maps/rest_api_map.dart'; import 'package:selfprivacy/logic/api_maps/tls_options.dart'; -import 'package:selfprivacy/logic/models/disk_size.dart'; import 'package:selfprivacy/logic/models/hive/user.dart'; import 'package:selfprivacy/logic/models/json/digital_ocean_server_info.dart'; import 'package:selfprivacy/utils/password_generator.dart'; diff --git a/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart b/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart index 5029561d..cb66c57a 100644 --- a/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart +++ b/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart @@ -409,7 +409,7 @@ class HetznerApi extends RestApiMap { 'labels': {'labelkey': 'value'}, 'location': region, 'automount': false, - 'format': 'ext4' + 'format': 'ext4', }, ); volume = HetznerVolume.fromJson(createVolumeResponse.data['volume']); @@ -586,7 +586,7 @@ class HetznerApi extends RestApiMap { final Map queryParameters = { 'start': start.toUtc().toIso8601String(), 'end': end.toUtc().toIso8601String(), - 'type': type + 'type': type, }; final Response res = await client.get( '/servers/$serverId/metrics', diff --git a/lib/logic/cubit/server_installation/server_installation_state.dart b/lib/logic/cubit/server_installation/server_installation_state.dart index 9f701a0a..9abd5a21 100644 --- a/lib/logic/cubit/server_installation/server_installation_state.dart +++ b/lib/logic/cubit/server_installation/server_installation_state.dart @@ -26,7 +26,7 @@ abstract class ServerInstallationState extends Equatable { serverDetails, isServerStarted, isServerResetedFirstTime, - installationDialoguePopUp + installationDialoguePopUp, ]; final String? providerApiToken; @@ -317,7 +317,7 @@ class ServerInstallationRecovery extends ServerInstallationState { isServerStarted, isServerResetedFirstTime, currentStep, - installationDialoguePopUp + installationDialoguePopUp, ]; ServerInstallationRecovery copyWith({ diff --git a/lib/logic/cubit/server_jobs/server_jobs_cubit.dart b/lib/logic/cubit/server_jobs/server_jobs_cubit.dart index 4cc0cf97..09d77b14 100644 --- a/lib/logic/cubit/server_jobs/server_jobs_cubit.dart +++ b/lib/logic/cubit/server_jobs/server_jobs_cubit.dart @@ -90,7 +90,7 @@ class ServerJobsCubit ServerJobsState( serverJobList: [ for (final ServerJob job in state.serverJobList) - if (job.uid != uid) job + if (job.uid != uid) job, ], ), ); diff --git a/lib/logic/providers/dns_providers/cloudflare.dart b/lib/logic/providers/dns_providers/cloudflare.dart index 6cf4a494..de30ca3c 100644 --- a/lib/logic/providers/dns_providers/cloudflare.dart +++ b/lib/logic/providers/dns_providers/cloudflare.dart @@ -385,7 +385,7 @@ class CloudflareDnsProvider extends DnsProvider { mx, txt1, txt2, - vpn + vpn, ]; } diff --git a/lib/logic/providers/dns_providers/desec.dart b/lib/logic/providers/dns_providers/desec.dart index a5e3e8d7..37d39776 100644 --- a/lib/logic/providers/dns_providers/desec.dart +++ b/lib/logic/providers/dns_providers/desec.dart @@ -323,7 +323,7 @@ class DesecDnsProvider extends DnsProvider { mx, txt1, txt2, - vpn + vpn, ]; } diff --git a/lib/logic/providers/dns_providers/digital_ocean_dns.dart b/lib/logic/providers/dns_providers/digital_ocean_dns.dart index 4fac4b65..a721a8c6 100644 --- a/lib/logic/providers/dns_providers/digital_ocean_dns.dart +++ b/lib/logic/providers/dns_providers/digital_ocean_dns.dart @@ -276,7 +276,7 @@ class DigitalOceanDnsProvider extends DnsProvider { mx, txt1, txt2, - vpn + vpn, ]; } diff --git a/lib/ui/components/progress_bar/progress_bar.dart b/lib/ui/components/progress_bar/progress_bar.dart index 7f743f44..1861bd0b 100644 --- a/lib/ui/components/progress_bar/progress_bar.dart +++ b/lib/ui/components/progress_bar/progress_bar.dart @@ -78,7 +78,7 @@ class _ProgressBarState extends State { end: Alignment.bottomRight, colors: [ Theme.of(context).colorScheme.primary, - Theme.of(context).colorScheme.secondary + Theme.of(context).colorScheme.secondary, ], ), ), @@ -110,7 +110,7 @@ class _ProgressBarState extends State { style: progressTextStyleLight, children: [ TextSpan(text: '${index + 1}.', style: style), - TextSpan(text: step, style: style) + TextSpan(text: step, style: style), ], ), ), diff --git a/lib/ui/helpers/empty_page_placeholder.dart b/lib/ui/helpers/empty_page_placeholder.dart index e1bb0d7b..e96f91f9 100644 --- a/lib/ui/helpers/empty_page_placeholder.dart +++ b/lib/ui/helpers/empty_page_placeholder.dart @@ -32,7 +32,7 @@ class EmptyPagePlaceholder extends StatelessWidget { child: _expandedContent(context), ), ), - ) + ), ], ); diff --git a/lib/ui/pages/backups/backup_details.dart b/lib/ui/pages/backups/backup_details.dart index 344876b1..fa2f3b61 100644 --- a/lib/ui/pages/backups/backup_details.dart +++ b/lib/ui/pages/backups/backup_details.dart @@ -163,7 +163,7 @@ class BackupDetailsPage extends StatelessWidget { autobackupPeriod != null ? 'backup.autobackup_period_subtitle'.tr( namedArgs: { - 'period': autobackupPeriod.toPrettyString(context.locale) + 'period': autobackupPeriod.toPrettyString(context.locale), }, ) : 'backup.autobackup_period_never'.tr(), @@ -337,7 +337,7 @@ class BackupDetailsPage extends StatelessWidget { actionButtonOnPressed: () => { context.read().forgetSnapshot( backup.id, - ) + ), }, ); }, @@ -385,7 +385,7 @@ class BackupDetailsPage extends StatelessWidget { ), onTap: () => context.pushRoute(BackupsListRoute(service: null)), - ) + ), ], ), const SizedBox(height: 8), diff --git a/lib/ui/pages/backups/backups_list.dart b/lib/ui/pages/backups/backups_list.dart index 4af870ef..00de5435 100644 --- a/lib/ui/pages/backups/backups_list.dart +++ b/lib/ui/pages/backups/backups_list.dart @@ -39,68 +39,70 @@ class BackupsListPage extends StatelessWidget { ), ) else - ...backups.map((final Backup backup) { - final service = context - .read() - .state - .getServiceById(backup.serviceId); - return ListTile( - onTap: preventActions - ? null - : () { - showModalBottomSheet( - useRootNavigator: true, - context: context, - isScrollControlled: true, - builder: (final BuildContext context) => - DraggableScrollableSheet( - expand: false, - maxChildSize: 0.9, - minChildSize: 0.5, - initialChildSize: 0.7, - builder: (final context, final scrollController) => - SnapshotModal( - snapshot: backup, - scrollController: scrollController, + ...backups.map( + (final Backup backup) { + final service = context + .read() + .state + .getServiceById(backup.serviceId); + return ListTile( + onTap: preventActions + ? null + : () { + showModalBottomSheet( + useRootNavigator: true, + context: context, + isScrollControlled: true, + builder: (final BuildContext context) => + DraggableScrollableSheet( + expand: false, + maxChildSize: 0.9, + minChildSize: 0.5, + initialChildSize: 0.7, + builder: (final context, final scrollController) => + SnapshotModal( + snapshot: backup, + scrollController: scrollController, + ), ), + ); + }, + onLongPress: preventActions + ? null + : () { + showPopUpAlert( + alertTitle: 'backup.forget_snapshot'.tr(), + description: 'backup.forget_snapshot_alert'.tr(), + actionButtonTitle: 'backup.forget_snapshot'.tr(), + actionButtonOnPressed: () => { + context.read().forgetSnapshot( + backup.id, + ), + }, + ); + }, + title: Text( + '${MaterialLocalizations.of(context).formatShortDate(backup.time)} ${TimeOfDay.fromDateTime(backup.time).format(context)}', + ), + subtitle: Text( + service?.displayName ?? backup.fallbackServiceName, + ), + leading: service != null + ? SvgPicture.string( + service.svgIcon, + height: 24, + width: 24, + colorFilter: ColorFilter.mode( + Theme.of(context).colorScheme.onBackground, + BlendMode.srcIn, ), - ); - }, - onLongPress: preventActions - ? null - : () { - showPopUpAlert( - alertTitle: 'backup.forget_snapshot'.tr(), - description: 'backup.forget_snapshot_alert'.tr(), - actionButtonTitle: 'backup.forget_snapshot'.tr(), - actionButtonOnPressed: () => { - context.read().forgetSnapshot( - backup.id, - ) - }, - ); - }, - title: Text( - '${MaterialLocalizations.of(context).formatShortDate(backup.time)} ${TimeOfDay.fromDateTime(backup.time).format(context)}', - ), - subtitle: Text( - service?.displayName ?? backup.fallbackServiceName, - ), - leading: service != null - ? SvgPicture.string( - service.svgIcon, - height: 24, - width: 24, - colorFilter: ColorFilter.mode( - Theme.of(context).colorScheme.onBackground, - BlendMode.srcIn, + ) + : const Icon( + Icons.question_mark_outlined, ), - ) - : const Icon( - Icons.question_mark_outlined, - ), - ); - }) + ); + }, + ), ], ); } diff --git a/lib/ui/pages/backups/snapshot_modal.dart b/lib/ui/pages/backups/snapshot_modal.dart index 9d714c25..37b10a17 100644 --- a/lib/ui/pages/backups/snapshot_modal.dart +++ b/lib/ui/pages/backups/snapshot_modal.dart @@ -172,7 +172,7 @@ class _SnapshotModalState extends State { isWarning: true, text: 'backup.snapshot_modal_service_not_found'.tr(), ), - ) + ), ], ), ); diff --git a/lib/ui/pages/more/app_settings/app_settings.dart b/lib/ui/pages/more/app_settings/app_settings.dart index 6ab69f40..9d7edf6b 100644 --- a/lib/ui/pages/more/app_settings/app_settings.dart +++ b/lib/ui/pages/more/app_settings/app_settings.dart @@ -62,7 +62,7 @@ class _AppSettingsPageState extends State { ), const _ResetAppTile(), // const Divider(height: 0), - _deleteServer(context) + _deleteServer(context), ], ); } diff --git a/lib/ui/pages/more/more.dart b/lib/ui/pages/more/more.dart index 3d85b093..0e96d340 100644 --- a/lib/ui/pages/more/more.dart +++ b/lib/ui/pages/more/more.dart @@ -118,7 +118,7 @@ class MorePage extends StatelessWidget { ), ], ), - ) + ), ], ), ); diff --git a/lib/ui/pages/server_details/charts/chart.dart b/lib/ui/pages/server_details/charts/chart.dart index 774dcf75..76576261 100644 --- a/lib/ui/pages/server_details/charts/chart.dart +++ b/lib/ui/pages/server_details/charts/chart.dart @@ -113,7 +113,7 @@ class _Chart extends StatelessWidget { titles: [ 'resource_chart.month'.tr(), 'resource_chart.day'.tr(), - 'resource_chart.hour'.tr() + 'resource_chart.hour'.tr(), ], ), const SizedBox(height: 8), diff --git a/lib/ui/pages/server_details/charts/network_charts.dart b/lib/ui/pages/server_details/charts/network_charts.dart index 946d0247..e0df74b7 100644 --- a/lib/ui/pages/server_details/charts/network_charts.dart +++ b/lib/ui/pages/server_details/charts/network_charts.dart @@ -113,7 +113,7 @@ class NetworkChart extends StatelessWidget { minY: 0, maxY: [ ...listData[0].map((final e) => e.value), - ...listData[1].map((final e) => e.value) + ...listData[1].map((final e) => e.value), ].reduce(max) * 1.2, minX: 0, @@ -154,7 +154,7 @@ class NetworkChart extends StatelessWidget { ), interval: [ ...listData[0].map((final e) => e.value), - ...listData[1].map((final e) => e.value) + ...listData[1].map((final e) => e.value), ].reduce(max) * 2 / 6.5, @@ -168,7 +168,7 @@ class NetworkChart extends StatelessWidget { verticalInterval: 40, horizontalInterval: [ ...listData[0].map((final e) => e.value), - ...listData[1].map((final e) => e.value) + ...listData[1].map((final e) => e.value), ].reduce(max) * 2 / 6.5, diff --git a/lib/ui/pages/services/service_page.dart b/lib/ui/pages/services/service_page.dart index e1e00ec0..37f9515c 100644 --- a/lib/ui/pages/services/service_page.dart +++ b/lib/ui/pages/services/service_page.dart @@ -134,7 +134,7 @@ class _ServicePageState extends State { .read() .state .getVolume(service.storageUsage.volume ?? '') - .displayName + .displayName, }, ), style: Theme.of(context).textTheme.bodyMedium, diff --git a/lib/ui/pages/services/services.dart b/lib/ui/pages/services/services.dart index 36af585f..2aa31d8b 100644 --- a/lib/ui/pages/services/services.dart +++ b/lib/ui/pages/services/services.dart @@ -69,7 +69,7 @@ class _ServicesPageState extends State { ), child: _Card(service: service), ), - ) + ), ], ), ), @@ -179,7 +179,7 @@ class _Card extends StatelessWidget { ), const SizedBox(height: 8), ], - ) + ), ], ), ), diff --git a/lib/ui/pages/setup/initializing/initializing.dart b/lib/ui/pages/setup/initializing/initializing.dart index a681c07a..841c1955 100644 --- a/lib/ui/pages/setup/initializing/initializing.dart +++ b/lib/ui/pages/setup/initializing/initializing.dart @@ -49,7 +49,7 @@ class InitializingPage extends StatelessWidget { () => _stepCheck(cubit), () => _stepCheck(cubit), () => _stepCheck(cubit), - () => _stepCheck(cubit) + () => _stepCheck(cubit), ][cubit.state.progress.index](); } @@ -193,7 +193,7 @@ class InitializingPage extends StatelessWidget { .replace(const RecoveryRoute()); }, ), - ) + ), ], ), ], @@ -517,7 +517,7 @@ class InitializingPage extends StatelessWidget { BrandTimer( startDateTime: state.timerStart!, duration: state.duration!, - ) + ), ], ), if (state.isLoading) diff --git a/lib/ui/pages/setup/initializing/server_type_picker.dart b/lib/ui/pages/setup/initializing/server_type_picker.dart index 3ce0f94b..9862fc3c 100644 --- a/lib/ui/pages/setup/initializing/server_type_picker.dart +++ b/lib/ui/pages/setup/initializing/server_type_picker.dart @@ -329,7 +329,7 @@ class SelectTypePage extends StatelessWidget { 'initializing.choose_server_type_payment_per_month' .tr( args: [ - '${(type.price.value + storagePrice + publicIpPrice).toStringAsFixed(4)} ${type.price.currency.shortcode}' + '${(type.price.value + storagePrice + publicIpPrice).toStringAsFixed(4)} ${type.price.currency.shortcode}', ], ), style: Theme.of(context) @@ -371,7 +371,7 @@ class SelectTypePage extends StatelessWidget { .tr( args: [ type.price.value - .toString() + .toString(), ], ), style: Theme.of(context) @@ -401,7 +401,7 @@ class SelectTypePage extends StatelessWidget { 'initializing.choose_server_type_payment_storage' .tr( args: [ - storagePrice.toString() + storagePrice.toString(), ], ), style: Theme.of(context) @@ -432,7 +432,8 @@ class SelectTypePage extends StatelessWidget { 'initializing.choose_server_type_payment_ip' .tr( args: [ - publicIpPrice.toString() + publicIpPrice + .toString(), ], ), style: Theme.of(context) diff --git a/lib/ui/pages/setup/recovering/recover_by_new_device_key.dart b/lib/ui/pages/setup/recovering/recover_by_new_device_key.dart index d1dce974..12c412e6 100644 --- a/lib/ui/pages/setup/recovering/recover_by_new_device_key.dart +++ b/lib/ui/pages/setup/recovering/recover_by_new_device_key.dart @@ -25,7 +25,7 @@ class RecoverByNewDeviceKeyInstruction extends StatelessWidget { child: Text('recovering.method_device_button'.tr()), onPressed: () => Navigator.of(context) .push(materialRoute(const RecoverByNewDeviceKeyInput())), - ) + ), ], ); } @@ -81,7 +81,7 @@ class RecoverByNewDeviceKeyInput extends StatelessWidget { : () => context.read().trySubmit(), child: Text('basis.continue'.tr()), - ) + ), ], ); }, diff --git a/lib/ui/pages/setup/recovering/recover_by_old_token.dart b/lib/ui/pages/setup/recovering/recover_by_old_token.dart index 1a777f83..76bf6b4d 100644 --- a/lib/ui/pages/setup/recovering/recover_by_old_token.dart +++ b/lib/ui/pages/setup/recovering/recover_by_old_token.dart @@ -41,7 +41,7 @@ class RecoverByOldTokenInstruction extends StatelessWidget { onPressed: () => context .read() .selectRecoveryMethod(ServerRecoveryMethods.oldToken), - ) + ), ], ), ); @@ -90,7 +90,7 @@ class RecoverByOldToken extends StatelessWidget { ? null : () => context.read().trySubmit(), child: Text('basis.continue'.tr()), - ) + ), ], ); }, diff --git a/lib/ui/pages/setup/recovering/recover_by_recovery_key.dart b/lib/ui/pages/setup/recovering/recover_by_recovery_key.dart index ad18bc95..8633ad59 100644 --- a/lib/ui/pages/setup/recovering/recover_by_recovery_key.dart +++ b/lib/ui/pages/setup/recovering/recover_by_recovery_key.dart @@ -50,7 +50,7 @@ class RecoverByRecoveryKey extends StatelessWidget { ? null : () => context.read().trySubmit(), child: Text('basis.continue'.tr()), - ) + ), ], ); }, diff --git a/lib/ui/pages/setup/recovering/recovery_confirm_server.dart b/lib/ui/pages/setup/recovering/recovery_confirm_server.dart index 2efcff87..3c0ade69 100644 --- a/lib/ui/pages/setup/recovering/recovery_confirm_server.dart +++ b/lib/ui/pages/setup/recovering/recovery_confirm_server.dart @@ -81,7 +81,7 @@ class _RecoveryConfirmServerState extends State { ); } }, - ) + ), ], ); diff --git a/lib/ui/pages/setup/recovering/recovery_method_select.dart b/lib/ui/pages/setup/recovering/recovery_method_select.dart index f8cec44a..dd5d77bd 100644 --- a/lib/ui/pages/setup/recovering/recovery_method_select.dart +++ b/lib/ui/pages/setup/recovering/recovery_method_select.dart @@ -51,7 +51,7 @@ class RecoveryMethodSelect extends StatelessWidget { title: 'recovering.method_select_nothing'.tr(), onPressed: () => Navigator.of(context) .push(materialRoute(const RecoveryFallbackMethodSelect())), - ) + ), ], ); } diff --git a/lib/ui/pages/setup/recovering/recovery_routing.dart b/lib/ui/pages/setup/recovering/recovery_routing.dart index 3ab5109a..e26e202e 100644 --- a/lib/ui/pages/setup/recovering/recovery_routing.dart +++ b/lib/ui/pages/setup/recovering/recovery_routing.dart @@ -136,7 +136,7 @@ class SelectDomainToRecover extends StatelessWidget { : () => context.read().trySubmit(), child: Text('basis.continue'.tr()), - ) + ), ], ), ); diff --git a/lib/ui/pages/setup/recovering/recovery_server_provider_connected.dart b/lib/ui/pages/setup/recovering/recovery_server_provider_connected.dart index 40f13eaa..1c9411c6 100644 --- a/lib/ui/pages/setup/recovering/recovery_server_provider_connected.dart +++ b/lib/ui/pages/setup/recovering/recovery_server_provider_connected.dart @@ -23,7 +23,7 @@ class RecoveryServerProviderConnected extends StatelessWidget { heroTitle: 'recovering.provider_connected'.tr( args: [ appConfig.state.serverDetails?.provider.displayName ?? - 'Server Provider' + 'Server Provider', ], ), heroSubtitle: 'recovering.provider_connected_description'.tr( @@ -45,7 +45,7 @@ class RecoveryServerProviderConnected extends StatelessWidget { labelText: 'recovering.provider_connected_placeholder'.tr( args: [ appConfig.state.serverDetails?.provider.displayName ?? - 'Server Provider' + 'Server Provider', ], ), ), diff --git a/lib/ui/pages/users/user_details.dart b/lib/ui/pages/users/user_details.dart index 90ab1603..9523ccf4 100644 --- a/lib/ui/pages/users/user_details.dart +++ b/lib/ui/pages/users/user_details.dart @@ -124,7 +124,7 @@ class _DeleteUserTile extends StatelessWidget { ), ], ), - ) + ), }, leading: const Icon(Icons.person_remove_outlined), title: Text( diff --git a/lib/utils/breakpoints.dart b/lib/utils/breakpoints.dart index 0e9104e2..88eca747 100644 --- a/lib/utils/breakpoints.dart +++ b/lib/utils/breakpoints.dart @@ -7,7 +7,7 @@ import 'package:flutter/material.dart'; const Set _desktop = { TargetPlatform.linux, TargetPlatform.macOS, - TargetPlatform.windows + TargetPlatform.windows, }; const Set _mobile = { diff --git a/lib/utils/extensions/text_extensions.dart b/lib/utils/extensions/text_extensions.dart deleted file mode 100644 index a00f7096..00000000 --- a/lib/utils/extensions/text_extensions.dart +++ /dev/null @@ -1,51 +0,0 @@ -import 'package:flutter/material.dart'; - -extension TextExtension on Text { - Text withColor(final Color color) => Text( - data!, - key: key, - strutStyle: strutStyle, - textAlign: textAlign, - textDirection: textDirection, - locale: locale, - softWrap: softWrap, - overflow: overflow, - textScaleFactor: textScaleFactor, - maxLines: maxLines, - semanticsLabel: semanticsLabel, - textWidthBasis: textWidthBasis ?? textWidthBasis, - style: style != null - ? style!.copyWith(color: color) - : TextStyle(color: color), - ); - - Text copyWith({ - final Key? key, - final StrutStyle? strutStyle, - final TextAlign? textAlign, - final TextDirection? textDirection, - final Locale? locale, - final bool? softWrap, - final TextOverflow? overflow, - final double? textScaleFactor, - final int? maxLines, - final String? semanticsLabel, - final TextWidthBasis? textWidthBasis, - final TextStyle? style, - }) => - Text( - data!, - key: key ?? this.key, - strutStyle: strutStyle ?? this.strutStyle, - textAlign: textAlign ?? this.textAlign, - textDirection: textDirection ?? this.textDirection, - locale: locale ?? this.locale, - softWrap: softWrap ?? this.softWrap, - overflow: overflow ?? this.overflow, - textScaleFactor: textScaleFactor ?? this.textScaleFactor, - maxLines: maxLines ?? this.maxLines, - semanticsLabel: semanticsLabel ?? this.semanticsLabel, - textWidthBasis: textWidthBasis ?? this.textWidthBasis, - style: style != null ? this.style?.merge(style) ?? style : this.style, - ); -} From ec8d08ff076f513025ed486747d40ab98448823f Mon Sep 17 00:00:00 2001 From: NaiJi Date: Mon, 13 Nov 2023 14:03:52 +0400 Subject: [PATCH 2/8] fix(api): Force DateTime to UTC where timezone naive - Solve https://git.selfprivacy.org/SelfPrivacy/selfprivacy.org.app/issues/385 --- .../api_maps/graphql_maps/server_api/server_actions_api.dart | 2 +- lib/logic/api_maps/graphql_maps/server_api/server_api.dart | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/logic/api_maps/graphql_maps/server_api/server_actions_api.dart b/lib/logic/api_maps/graphql_maps/server_api/server_actions_api.dart index 05269d33..51a893c0 100644 --- a/lib/logic/api_maps/graphql_maps/server_api/server_actions_api.dart +++ b/lib/logic/api_maps/graphql_maps/server_api/server_actions_api.dart @@ -29,7 +29,7 @@ mixin ServerActionsApi on GraphQLApiMap { print(response.exception.toString()); } if (response.parsedData!.rebootSystem.success) { - time = DateTime.now(); + time = DateTime.now().toUtc(); } } catch (e) { print(e); diff --git a/lib/logic/api_maps/graphql_maps/server_api/server_api.dart b/lib/logic/api_maps/graphql_maps/server_api/server_api.dart index bc28a681..fcf3db05 100644 --- a/lib/logic/api_maps/graphql_maps/server_api/server_api.dart +++ b/lib/logic/api_maps/graphql_maps/server_api/server_api.dart @@ -248,7 +248,7 @@ class ServerApi extends GraphQLApiMap final GraphQLClient client = await getClient(); final input = Input$RecoveryKeyLimitsInput( - expirationDate: expirationDate, + expirationDate: expirationDate?.toUtc(), uses: numberOfUses, ); final variables = Variables$Mutation$GetNewRecoveryApiKey( From a2b28e199d97b78874473eb15c12da2a300a9bf8 Mon Sep 17 00:00:00 2001 From: NaiJi Date: Sun, 19 Nov 2023 23:51:36 +0400 Subject: [PATCH 3/8] feat: Implement flexible precision formatting for prices --- .../initializing/server_type_picker.dart | 19 ++++++++++++++----- lib/utils/ui_helpers.dart | 11 +++++++++++ 2 files changed, 25 insertions(+), 5 deletions(-) diff --git a/lib/ui/pages/setup/initializing/server_type_picker.dart b/lib/ui/pages/setup/initializing/server_type_picker.dart index 3ce0f94b..932cbd93 100644 --- a/lib/ui/pages/setup/initializing/server_type_picker.dart +++ b/lib/ui/pages/setup/initializing/server_type_picker.dart @@ -9,6 +9,7 @@ import 'package:selfprivacy/logic/models/server_type.dart'; import 'package:selfprivacy/ui/components/buttons/brand_button.dart'; import 'package:selfprivacy/ui/components/info_box/info_box.dart'; import 'package:selfprivacy/ui/layouts/responsive_layout_with_infobox.dart'; +import 'package:selfprivacy/utils/ui_helpers.dart'; class ServerTypePicker extends StatefulWidget { const ServerTypePicker({ @@ -329,7 +330,7 @@ class SelectTypePage extends StatelessWidget { 'initializing.choose_server_type_payment_per_month' .tr( args: [ - '${(type.price.value + storagePrice + publicIpPrice).toStringAsFixed(4)} ${type.price.currency.shortcode}' + '${UiHelpers.formatWithPrecision(type.price.value + storagePrice + publicIpPrice)} ${type.price.currency.shortcode}', ], ), style: Theme.of(context) @@ -370,8 +371,10 @@ class SelectTypePage extends StatelessWidget { 'initializing.choose_server_type_payment_server' .tr( args: [ - type.price.value - .toString() + UiHelpers + .formatWithPrecision( + type.price.value, + ), ], ), style: Theme.of(context) @@ -401,7 +404,10 @@ class SelectTypePage extends StatelessWidget { 'initializing.choose_server_type_payment_storage' .tr( args: [ - storagePrice.toString() + UiHelpers + .formatWithPrecision( + storagePrice, + ), ], ), style: Theme.of(context) @@ -432,7 +438,10 @@ class SelectTypePage extends StatelessWidget { 'initializing.choose_server_type_payment_ip' .tr( args: [ - publicIpPrice.toString() + UiHelpers + .formatWithPrecision( + publicIpPrice, + ), ], ), style: Theme.of(context) diff --git a/lib/utils/ui_helpers.dart b/lib/utils/ui_helpers.dart index f4d58a05..10f7419d 100644 --- a/lib/utils/ui_helpers.dart +++ b/lib/utils/ui_helpers.dart @@ -1,3 +1,4 @@ +import 'package:intl/intl.dart'; import 'package:selfprivacy/logic/cubit/server_installation/server_installation_cubit.dart'; /// it's ui helpers use only for ui components, don't use for logic components. @@ -5,4 +6,14 @@ import 'package:selfprivacy/logic/cubit/server_installation/server_installation_ class UiHelpers { static String getDomainName(final ServerInstallationState config) => config.isDomainSelected ? config.serverDomain!.domainName : 'example.com'; + + static String formatWithPrecision( + final double value, { + final int fraction = 2, + }) { + final NumberFormat formatter = NumberFormat(); + formatter.minimumFractionDigits = 0; + formatter.maximumFractionDigits = fraction; + return formatter.format(value); + } } From f7afd6fd158b05929ca67d0a3f7b9c370ff3f11f Mon Sep 17 00:00:00 2001 From: NaiJi Date: Mon, 20 Nov 2023 03:32:41 +0400 Subject: [PATCH 4/8] fix(hetzner): Remove optional status enum for getVolumes of Hetzner --- .../server_providers/hetzner/hetzner_api.dart | 11 ++--------- 1 file changed, 2 insertions(+), 9 deletions(-) diff --git a/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart b/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart index 5029561d..72df384b 100644 --- a/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart +++ b/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart @@ -360,20 +360,13 @@ class HetznerApi extends RestApiMap { return GenericResult(success: true, data: pricing); } - Future>> getVolumes({ - final String? status, - }) async { + Future>> getVolumes() async { final List volumes = []; Response? getVolumesResonse; final Dio client = await getClient(); try { - getVolumesResonse = await client.get( - '/volumes', - queryParameters: { - 'status': status, - }, - ); + getVolumesResonse = await client.get('/volumes'); for (final volume in getVolumesResonse.data['volumes']) { volumes.add(HetznerVolume.fromJson(volume)); } From cea2f6d8a488fdf0f554c6a64a13099225f8b4c3 Mon Sep 17 00:00:00 2001 From: NaiJi Date: Mon, 20 Nov 2023 18:10:07 +0400 Subject: [PATCH 5/8] refactor: Correct a typo in Hetzner API --- .../server_providers/hetzner/hetzner_api.dart | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart b/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart index 72df384b..37c825dc 100644 --- a/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart +++ b/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart @@ -363,11 +363,11 @@ class HetznerApi extends RestApiMap { Future>> getVolumes() async { final List volumes = []; - Response? getVolumesResonse; + Response? getVolumesResponse; final Dio client = await getClient(); try { - getVolumesResonse = await client.get('/volumes'); - for (final volume in getVolumesResonse.data['volumes']) { + getVolumesResponse = await client.get('/volumes'); + for (final volume in getVolumesResponse.data['volumes']) { volumes.add(HetznerVolume.fromJson(volume)); } } catch (e) { @@ -384,8 +384,8 @@ class HetznerApi extends RestApiMap { return GenericResult( data: volumes, success: true, - code: getVolumesResonse.statusCode, - message: getVolumesResonse.statusMessage, + code: getVolumesResponse.statusCode, + message: getVolumesResponse.statusMessage, ); } From f11a75dfb7d49076ccdac47749df2319337b2b29 Mon Sep 17 00:00:00 2001 From: NaiJi Date: Mon, 20 Nov 2023 18:29:26 +0400 Subject: [PATCH 6/8] refactor: Remove obsolete network objects --- lib/logic/api_maps/rest_maps/backblaze.dart | 2 +- .../dns_providers/cloudflare/cloudflare_api.dart | 2 +- .../digital_ocean_dns/digital_ocean_dns_api.dart | 2 +- lib/logic/api_maps/rest_maps/rest_api_map.dart | 8 ++++---- .../server_providers/hetzner/hetzner_api.dart | 4 ++-- lib/ui/pages/server_details/charts/cpu_chart.dart | 10 ++++++---- .../pages/server_details/charts/network_charts.dart | 12 ++++++++---- 7 files changed, 23 insertions(+), 17 deletions(-) diff --git a/lib/logic/api_maps/rest_maps/backblaze.dart b/lib/logic/api_maps/rest_maps/backblaze.dart index f622a2fd..97a9ac4f 100644 --- a/lib/logic/api_maps/rest_maps/backblaze.dart +++ b/lib/logic/api_maps/rest_maps/backblaze.dart @@ -103,7 +103,7 @@ class BackblazeApi extends RestApiMap { } else { throw Exception('code: ${response.statusCode}'); } - } on DioError catch (e) { + } on DioException catch (e) { print(e); return GenericResult( data: false, diff --git a/lib/logic/api_maps/rest_maps/dns_providers/cloudflare/cloudflare_api.dart b/lib/logic/api_maps/rest_maps/dns_providers/cloudflare/cloudflare_api.dart index 0ba88ee3..bfc1b029 100644 --- a/lib/logic/api_maps/rest_maps/dns_providers/cloudflare/cloudflare_api.dart +++ b/lib/logic/api_maps/rest_maps/dns_providers/cloudflare/cloudflare_api.dart @@ -144,7 +144,7 @@ class CloudflareApi extends RestApiMap { ); } await Future.wait(allCreateFutures); - } on DioError catch (e) { + } on DioException catch (e) { print(e.message); rethrow; } catch (e) { diff --git a/lib/logic/api_maps/rest_maps/dns_providers/digital_ocean_dns/digital_ocean_dns_api.dart b/lib/logic/api_maps/rest_maps/dns_providers/digital_ocean_dns/digital_ocean_dns_api.dart index e1b5c601..558915ce 100644 --- a/lib/logic/api_maps/rest_maps/dns_providers/digital_ocean_dns/digital_ocean_dns_api.dart +++ b/lib/logic/api_maps/rest_maps/dns_providers/digital_ocean_dns/digital_ocean_dns_api.dart @@ -133,7 +133,7 @@ class DigitalOceanDnsApi extends RestApiMap { ); } await Future.wait(allCreateFutures); - } on DioError catch (e) { + } on DioException catch (e) { print(e.message); rethrow; } catch (e) { diff --git a/lib/logic/api_maps/rest_maps/rest_api_map.dart b/lib/logic/api_maps/rest_maps/rest_api_map.dart index 547ce4aa..5f70e69a 100644 --- a/lib/logic/api_maps/rest_maps/rest_api_map.dart +++ b/lib/logic/api_maps/rest_maps/rest_api_map.dart @@ -15,8 +15,8 @@ abstract class RestApiMap { dio.interceptors.add(PrettyDioLogger()); } dio.interceptors.add(ConsoleInterceptor()); - (dio.httpClientAdapter as IOHttpClientAdapter).onHttpClientCreate = - (final HttpClient client) { + (dio.httpClientAdapter as IOHttpClientAdapter).createHttpClient = () { + final HttpClient client = HttpClient(); client.badCertificateCallback = (final X509Certificate cert, final String host, final int port) => true; @@ -25,7 +25,7 @@ abstract class RestApiMap { dio.interceptors.add( InterceptorsWrapper( - onError: (final DioError e, final ErrorInterceptorHandler handler) { + onError: (final DioException e, final ErrorInterceptorHandler handler) { print(e.requestOptions.path); print(e.requestOptions.data); @@ -96,7 +96,7 @@ class ConsoleInterceptor extends InterceptorsWrapper { @override Future onError( - final DioError err, + final DioException err, final ErrorInterceptorHandler handler, ) async { final Response? response = err.response; diff --git a/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart b/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart index cb66c57a..0b783a2c 100644 --- a/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart +++ b/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart @@ -87,7 +87,7 @@ class HetznerApi extends RestApiMap { final String stagingAcme = TlsOptions.stagingAcme ? 'true' : 'false'; Response? serverCreateResponse; HetznerServerInfo? serverInfo; - DioError? hetznerError; + DioException? hetznerError; bool success = false; final Dio client = await getClient(); @@ -117,7 +117,7 @@ class HetznerApi extends RestApiMap { serverCreateResponse.data['server'], ); success = true; - } on DioError catch (e) { + } on DioException catch (e) { print(e); hetznerError = e; } catch (e) { diff --git a/lib/ui/pages/server_details/charts/cpu_chart.dart b/lib/ui/pages/server_details/charts/cpu_chart.dart index a11361d4..252d5069 100644 --- a/lib/ui/pages/server_details/charts/cpu_chart.dart +++ b/lib/ui/pages/server_details/charts/cpu_chart.dart @@ -65,7 +65,7 @@ class CpuChart extends StatelessWidget { isCurved: false, barWidth: 2, color: Theme.of(context).colorScheme.primary, - dotData: FlDotData( + dotData: const FlDotData( show: false, ), belowBarData: BarAreaData( @@ -86,7 +86,9 @@ class CpuChart extends StatelessWidget { maxY: 100, minX: 0, titlesData: FlTitlesData( - topTitles: AxisTitles(sideTitles: SideTitles(showTitles: false)), + topTitles: const AxisTitles( + sideTitles: SideTitles(showTitles: false), + ), bottomTitles: AxisTitles( sideTitles: SideTitles( interval: 40, @@ -107,12 +109,12 @@ class CpuChart extends StatelessWidget { showTitles: true, ), ), - leftTitles: AxisTitles( + leftTitles: const AxisTitles( sideTitles: SideTitles( showTitles: false, ), ), - rightTitles: AxisTitles( + rightTitles: const AxisTitles( sideTitles: SideTitles( showTitles: false, ), diff --git a/lib/ui/pages/server_details/charts/network_charts.dart b/lib/ui/pages/server_details/charts/network_charts.dart index e0df74b7..ce79df6b 100644 --- a/lib/ui/pages/server_details/charts/network_charts.dart +++ b/lib/ui/pages/server_details/charts/network_charts.dart @@ -73,7 +73,7 @@ class NetworkChart extends StatelessWidget { isCurved: false, barWidth: 2, color: Theme.of(context).colorScheme.primary, - dotData: FlDotData( + dotData: const FlDotData( show: false, ), belowBarData: BarAreaData( @@ -94,7 +94,7 @@ class NetworkChart extends StatelessWidget { isCurved: false, barWidth: 2, color: Theme.of(context).colorScheme.tertiary, - dotData: FlDotData( + dotData: const FlDotData( show: false, ), belowBarData: BarAreaData( @@ -118,7 +118,9 @@ class NetworkChart extends StatelessWidget { 1.2, minX: 0, titlesData: FlTitlesData( - topTitles: AxisTitles(sideTitles: SideTitles(showTitles: false)), + topTitles: const AxisTitles( + sideTitles: SideTitles(showTitles: false), + ), bottomTitles: AxisTitles( sideTitles: SideTitles( interval: 40, @@ -139,7 +141,9 @@ class NetworkChart extends StatelessWidget { showTitles: true, ), ), - leftTitles: AxisTitles(sideTitles: SideTitles(showTitles: false)), + leftTitles: const AxisTitles( + sideTitles: SideTitles(showTitles: false), + ), rightTitles: AxisTitles( sideTitles: SideTitles( reservedSize: 50, From 1e68789a8c49128415ba288e42c0cbbd58da7766 Mon Sep 17 00:00:00 2001 From: NaiJi Date: Mon, 20 Nov 2023 18:31:24 +0400 Subject: [PATCH 7/8] fix: Bump material_color_utilities version to 0.5.0, required by flutter test --- pubspec.lock | 54 ++++++++++++++++++++++++++++++---------------------- pubspec.yaml | 2 +- 2 files changed, 32 insertions(+), 24 deletions(-) diff --git a/pubspec.lock b/pubspec.lock index 05045a0a..226a9ad4 100644 --- a/pubspec.lock +++ b/pubspec.lock @@ -197,10 +197,10 @@ packages: dependency: transitive description: name: collection - sha256: "4a07be6cb69c84d677a6c3096fcf960cc3285a8330b4603e0d463d15d9bd934c" + sha256: ee67cb0715911d28db6bf4af1026078bd6f0128b07a5f66fb2ed94ec6783c09a url: "https://pub.dev" source: hosted - version: "1.17.1" + version: "1.18.0" connectivity_plus: dependency: transitive description: @@ -697,10 +697,10 @@ packages: dependency: "direct main" description: name: intl - sha256: a3715e3bc90294e971cb7dc063fbf3cd9ee0ebf8604ffeafabd9e6f16abbdbe6 + sha256: "3bc132a9dbce73a7e4a21a17d06e1878839ffbf975568bc875c60537824b0c4d" url: "https://pub.dev" source: hosted - version: "0.18.0" + version: "0.18.1" io: dependency: transitive description: @@ -817,26 +817,26 @@ packages: dependency: transitive description: name: matcher - sha256: "6501fbd55da300384b768785b83e5ce66991266cec21af89ab9ae7f5ce1c4cbb" + sha256: "1803e76e6653768d64ed8ff2e1e67bea3ad4b923eb5c56a295c3e634bad5960e" url: "https://pub.dev" source: hosted - version: "0.12.15" + version: "0.12.16" material_color_utilities: dependency: "direct main" description: name: material_color_utilities - sha256: d92141dc6fe1dad30722f9aa826c7fbc896d021d792f80678280601aff8cf724 + sha256: "9528f2f296073ff54cb9fee677df673ace1218163c3bc7628093e7eed5203d41" url: "https://pub.dev" source: hosted - version: "0.2.0" + version: "0.5.0" meta: dependency: transitive description: name: meta - sha256: "3c74dbf8763d36539f114c799d8a2d87343b5067e9d796ca22b5eb8437090ee3" + sha256: a6e590c838b18133bb482a2745ad77c5bb7715fb0451209e1a7567d416678b8e url: "https://pub.dev" source: hosted - version: "1.9.1" + version: "1.10.0" mime: dependency: transitive description: @@ -1198,26 +1198,26 @@ packages: dependency: transitive description: name: source_span - sha256: dd904f795d4b4f3b870833847c461801f6750a9fa8e61ea5ac53f9422b31f250 + sha256: "53e943d4206a5e30df338fd4c6e7a077e02254531b138a15aec3bd143c1a8b3c" url: "https://pub.dev" source: hosted - version: "1.9.1" + version: "1.10.0" stack_trace: dependency: transitive description: name: stack_trace - sha256: c3c7d8edb15bee7f0f74debd4b9c5f3c2ea86766fe4178eb2a18eb30a0bdaed5 + sha256: "73713990125a6d93122541237550ee3352a2d84baad52d375a4cad2eb9b7ce0b" url: "https://pub.dev" source: hosted - version: "1.11.0" + version: "1.11.1" stream_channel: dependency: transitive description: name: stream_channel - sha256: "83615bee9045c1d322bbbd1ba209b7a749c2cbcdcb3fdd1df8eb488b3279c1c8" + sha256: ba2aa5d8cc609d96bbb2899c28934f9e1af5cddbd60a827822ea467161eb54e7 url: "https://pub.dev" source: hosted - version: "2.1.1" + version: "2.1.2" stream_transform: dependency: transitive description: @@ -1246,26 +1246,26 @@ packages: dependency: transitive description: name: test - sha256: "3dac9aecf2c3991d09b9cdde4f98ded7b30804a88a0d7e4e7e1678e78d6b97f4" + sha256: a1f7595805820fcc05e5c52e3a231aedd0b72972cb333e8c738a8b1239448b6f url: "https://pub.dev" source: hosted - version: "1.24.1" + version: "1.24.9" test_api: dependency: transitive description: name: test_api - sha256: eb6ac1540b26de412b3403a163d919ba86f6a973fe6cc50ae3541b80092fdcfb + sha256: "5c2f730018264d276c20e4f1503fd1308dfbbae39ec8ee63c5236311ac06954b" url: "https://pub.dev" source: hosted - version: "0.5.1" + version: "0.6.1" test_core: dependency: transitive description: name: test_core - sha256: "5138dbffb77b2289ecb12b81c11ba46036590b72a64a7a90d6ffb880f1a29e93" + sha256: a757b14fc47507060a162cc2530d9a4a2f92f5100a952c7443b5cad5ef5b106a url: "https://pub.dev" source: hosted - version: "0.5.1" + version: "0.5.9" timezone: dependency: "direct main" description: @@ -1410,6 +1410,14 @@ packages: url: "https://pub.dev" source: hosted version: "1.0.2" + web: + dependency: transitive + description: + name: web + sha256: afe077240a270dcfd2aafe77602b4113645af95d0ad31128cc02bce5ac5d5152 + url: "https://pub.dev" + source: hosted + version: "0.3.0" web_socket_channel: dependency: transitive description: @@ -1467,5 +1475,5 @@ packages: source: hosted version: "3.1.1" sdks: - dart: ">=3.0.2 <4.0.0" + dart: ">=3.2.0-194.0.dev <4.0.0" flutter: ">=3.10.2" diff --git a/pubspec.yaml b/pubspec.yaml index 1d58f581..5bc9c402 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -39,7 +39,7 @@ dependencies: ionicons: ^0.2.2 json_annotation: ^4.8.1 local_auth: ^2.1.6 - material_color_utilities: ^0.2.0 + material_color_utilities: ^0.5.0 modal_bottom_sheet: ^3.0.0-pre nanoid: ^1.0.0 package_info: ^2.0.2 From e50ef9b189b86699e9cc9126b30b23d427d73a41 Mon Sep 17 00:00:00 2001 From: NaiJi Date: Mon, 20 Nov 2023 19:38:24 +0400 Subject: [PATCH 8/8] fix: Revert lints of premaster flutter version back to 3.16 --- lib/logic/api_maps/rest_maps/backblaze.dart | 2 +- .../dns_providers/cloudflare/cloudflare_api.dart | 2 +- .../digital_ocean_dns/digital_ocean_dns_api.dart | 2 +- lib/logic/api_maps/rest_maps/rest_api_map.dart | 8 ++++---- .../rest_maps/server_providers/hetzner/hetzner_api.dart | 4 ++-- lib/ui/pages/server_details/charts/cpu_chart.dart | 8 ++++---- lib/ui/pages/server_details/charts/network_charts.dart | 8 ++++---- 7 files changed, 17 insertions(+), 17 deletions(-) diff --git a/lib/logic/api_maps/rest_maps/backblaze.dart b/lib/logic/api_maps/rest_maps/backblaze.dart index 97a9ac4f..f622a2fd 100644 --- a/lib/logic/api_maps/rest_maps/backblaze.dart +++ b/lib/logic/api_maps/rest_maps/backblaze.dart @@ -103,7 +103,7 @@ class BackblazeApi extends RestApiMap { } else { throw Exception('code: ${response.statusCode}'); } - } on DioException catch (e) { + } on DioError catch (e) { print(e); return GenericResult( data: false, diff --git a/lib/logic/api_maps/rest_maps/dns_providers/cloudflare/cloudflare_api.dart b/lib/logic/api_maps/rest_maps/dns_providers/cloudflare/cloudflare_api.dart index bfc1b029..0ba88ee3 100644 --- a/lib/logic/api_maps/rest_maps/dns_providers/cloudflare/cloudflare_api.dart +++ b/lib/logic/api_maps/rest_maps/dns_providers/cloudflare/cloudflare_api.dart @@ -144,7 +144,7 @@ class CloudflareApi extends RestApiMap { ); } await Future.wait(allCreateFutures); - } on DioException catch (e) { + } on DioError catch (e) { print(e.message); rethrow; } catch (e) { diff --git a/lib/logic/api_maps/rest_maps/dns_providers/digital_ocean_dns/digital_ocean_dns_api.dart b/lib/logic/api_maps/rest_maps/dns_providers/digital_ocean_dns/digital_ocean_dns_api.dart index 558915ce..e1b5c601 100644 --- a/lib/logic/api_maps/rest_maps/dns_providers/digital_ocean_dns/digital_ocean_dns_api.dart +++ b/lib/logic/api_maps/rest_maps/dns_providers/digital_ocean_dns/digital_ocean_dns_api.dart @@ -133,7 +133,7 @@ class DigitalOceanDnsApi extends RestApiMap { ); } await Future.wait(allCreateFutures); - } on DioException catch (e) { + } on DioError catch (e) { print(e.message); rethrow; } catch (e) { diff --git a/lib/logic/api_maps/rest_maps/rest_api_map.dart b/lib/logic/api_maps/rest_maps/rest_api_map.dart index 5f70e69a..547ce4aa 100644 --- a/lib/logic/api_maps/rest_maps/rest_api_map.dart +++ b/lib/logic/api_maps/rest_maps/rest_api_map.dart @@ -15,8 +15,8 @@ abstract class RestApiMap { dio.interceptors.add(PrettyDioLogger()); } dio.interceptors.add(ConsoleInterceptor()); - (dio.httpClientAdapter as IOHttpClientAdapter).createHttpClient = () { - final HttpClient client = HttpClient(); + (dio.httpClientAdapter as IOHttpClientAdapter).onHttpClientCreate = + (final HttpClient client) { client.badCertificateCallback = (final X509Certificate cert, final String host, final int port) => true; @@ -25,7 +25,7 @@ abstract class RestApiMap { dio.interceptors.add( InterceptorsWrapper( - onError: (final DioException e, final ErrorInterceptorHandler handler) { + onError: (final DioError e, final ErrorInterceptorHandler handler) { print(e.requestOptions.path); print(e.requestOptions.data); @@ -96,7 +96,7 @@ class ConsoleInterceptor extends InterceptorsWrapper { @override Future onError( - final DioException err, + final DioError err, final ErrorInterceptorHandler handler, ) async { final Response? response = err.response; diff --git a/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart b/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart index fe317327..3778498a 100644 --- a/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart +++ b/lib/logic/api_maps/rest_maps/server_providers/hetzner/hetzner_api.dart @@ -87,7 +87,7 @@ class HetznerApi extends RestApiMap { final String stagingAcme = TlsOptions.stagingAcme ? 'true' : 'false'; Response? serverCreateResponse; HetznerServerInfo? serverInfo; - DioException? hetznerError; + DioError? hetznerError; bool success = false; final Dio client = await getClient(); @@ -117,7 +117,7 @@ class HetznerApi extends RestApiMap { serverCreateResponse.data['server'], ); success = true; - } on DioException catch (e) { + } on DioError catch (e) { print(e); hetznerError = e; } catch (e) { diff --git a/lib/ui/pages/server_details/charts/cpu_chart.dart b/lib/ui/pages/server_details/charts/cpu_chart.dart index 252d5069..7350f003 100644 --- a/lib/ui/pages/server_details/charts/cpu_chart.dart +++ b/lib/ui/pages/server_details/charts/cpu_chart.dart @@ -65,7 +65,7 @@ class CpuChart extends StatelessWidget { isCurved: false, barWidth: 2, color: Theme.of(context).colorScheme.primary, - dotData: const FlDotData( + dotData: FlDotData( show: false, ), belowBarData: BarAreaData( @@ -86,7 +86,7 @@ class CpuChart extends StatelessWidget { maxY: 100, minX: 0, titlesData: FlTitlesData( - topTitles: const AxisTitles( + topTitles: AxisTitles( sideTitles: SideTitles(showTitles: false), ), bottomTitles: AxisTitles( @@ -109,12 +109,12 @@ class CpuChart extends StatelessWidget { showTitles: true, ), ), - leftTitles: const AxisTitles( + leftTitles: AxisTitles( sideTitles: SideTitles( showTitles: false, ), ), - rightTitles: const AxisTitles( + rightTitles: AxisTitles( sideTitles: SideTitles( showTitles: false, ), diff --git a/lib/ui/pages/server_details/charts/network_charts.dart b/lib/ui/pages/server_details/charts/network_charts.dart index ce79df6b..08747192 100644 --- a/lib/ui/pages/server_details/charts/network_charts.dart +++ b/lib/ui/pages/server_details/charts/network_charts.dart @@ -73,7 +73,7 @@ class NetworkChart extends StatelessWidget { isCurved: false, barWidth: 2, color: Theme.of(context).colorScheme.primary, - dotData: const FlDotData( + dotData: FlDotData( show: false, ), belowBarData: BarAreaData( @@ -94,7 +94,7 @@ class NetworkChart extends StatelessWidget { isCurved: false, barWidth: 2, color: Theme.of(context).colorScheme.tertiary, - dotData: const FlDotData( + dotData: FlDotData( show: false, ), belowBarData: BarAreaData( @@ -118,7 +118,7 @@ class NetworkChart extends StatelessWidget { 1.2, minX: 0, titlesData: FlTitlesData( - topTitles: const AxisTitles( + topTitles: AxisTitles( sideTitles: SideTitles(showTitles: false), ), bottomTitles: AxisTitles( @@ -141,7 +141,7 @@ class NetworkChart extends StatelessWidget { showTitles: true, ), ), - leftTitles: const AxisTitles( + leftTitles: AxisTitles( sideTitles: SideTitles(showTitles: false), ), rightTitles: AxisTitles(