import 'package:easy_localization/easy_localization.dart'; import 'package:flutter/material.dart'; import 'package:selfprivacy/logic/cubit/forms/setup/recovering/recovery_device_form_cubit.dart'; import 'package:selfprivacy/ui/components/brand_button/filled_button.dart'; import 'package:selfprivacy/ui/components/brand_hero_screen/brand_hero_screen.dart'; import 'package:selfprivacy/utils/route_transitions/basic.dart'; import 'package:cubit_form/cubit_form.dart'; import 'package:selfprivacy/logic/cubit/server_installation/server_installation_cubit.dart'; import 'package:selfprivacy/logic/cubit/forms/factories/field_cubit_factory.dart'; class RecoverByNewDeviceKeyInstruction extends StatelessWidget { const RecoverByNewDeviceKeyInstruction({final super.key}); @override Widget build(final BuildContext context) => BrandHeroScreen( heroTitle: 'recovering.recovery_main_header'.tr(), heroSubtitle: 'recovering.method_device_description'.tr(), hasBackButton: true, hasFlashButton: false, onBackButtonPressed: context.read().revertRecoveryStep, children: [ FilledButton( title: 'recovering.method_device_button'.tr(), onPressed: () => Navigator.of(context) .push(materialRoute(const RecoverByNewDeviceKeyInput())), ) ], ); } class RecoverByNewDeviceKeyInput extends StatelessWidget { const RecoverByNewDeviceKeyInput({final super.key}); @override Widget build(final BuildContext context) { final ServerInstallationCubit appConfig = context.watch(); return BlocProvider( create: (final BuildContext context) => RecoveryDeviceFormCubit( appConfig, FieldCubitFactory(context), ServerRecoveryMethods.newDeviceKey, ), child: BlocListener( listener: (final BuildContext context, final ServerInstallationState state) { if (state is ServerInstallationRecovery && state.currentStep != RecoveryStep.newDeviceKey) { Navigator.of(context).pop(); } }, child: Builder( builder: (final BuildContext context) { final FormCubitState formCubitState = context.watch().state; return BrandHeroScreen( heroTitle: 'recovering.recovery_main_header'.tr(), heroSubtitle: 'recovering.method_device_input_description'.tr(), hasBackButton: true, hasFlashButton: false, children: [ CubitFormTextField( formFieldCubit: context.read().tokenField, decoration: InputDecoration( border: const OutlineInputBorder(), labelText: 'recovering.method_device_input_placeholder'.tr(), ), ), const SizedBox(height: 16), FilledButton( title: 'basis.continue'.tr(), onPressed: formCubitState.isSubmitting ? null : () => context.read().trySubmit(), ) ], ); }, ), ), ); } }