selfprivacy.org.app/lib/ui/pages/setup/recovering/recovery_hentzner_connected...

75 lines
3.0 KiB
Dart
Raw Normal View History

import 'package:easy_localization/easy_localization.dart';
import 'package:flutter/material.dart';
import 'package:selfprivacy/config/brand_theme.dart';
import 'package:selfprivacy/logic/cubit/forms/setup/initializing/hetzner_form_cubit.dart';
import 'package:selfprivacy/ui/components/brand_bottom_sheet/brand_bottom_sheet.dart';
2022-05-24 21:55:39 +03:00
import 'package:selfprivacy/ui/components/brand_button/filled_button.dart';
import 'package:selfprivacy/ui/components/brand_button/brand_button.dart';
import 'package:selfprivacy/ui/components/brand_hero_screen/brand_hero_screen.dart';
import 'package:cubit_form/cubit_form.dart';
import 'package:selfprivacy/logic/cubit/server_installation/server_installation_cubit.dart';
import 'package:selfprivacy/ui/components/brand_md/brand_md.dart';
class RecoveryHetznerConnected extends StatelessWidget {
2022-06-05 22:36:32 +03:00
const RecoveryHetznerConnected({final Key? key}) : super(key: key);
2022-05-24 21:55:39 +03:00
@override
2022-06-05 22:36:32 +03:00
Widget build(final BuildContext context) {
ServerInstallationCubit appConfig = context.watch<ServerInstallationCubit>();
return BlocProvider(
2022-06-05 22:36:32 +03:00
create: (final BuildContext context) => HetznerFormCubit(appConfig),
child: Builder(
2022-06-05 22:36:32 +03:00
builder: (final BuildContext context) {
FormCubitState formCubitState = context.watch<HetznerFormCubit>().state;
return BrandHeroScreen(
2022-05-24 21:55:39 +03:00
heroTitle: 'recovering.hetzner_connected'.tr(),
heroSubtitle: 'recovering.hetzner_connected_description'.tr(args: [
appConfig.state.serverDomain?.domainName ?? 'your domain'
]),
hasBackButton: true,
hasFlashButton: false,
children: [
CubitFormTextField(
formFieldCubit: context.read<HetznerFormCubit>().apiKey,
decoration: InputDecoration(
2022-05-24 21:55:39 +03:00
border: const OutlineInputBorder(),
labelText: 'recovering.hetzner_connected_placeholder'.tr(),
),
),
2022-05-24 21:55:39 +03:00
const SizedBox(height: 16),
FilledButton(
2022-05-24 21:55:39 +03:00
title: 'more.continue'.tr(),
onPressed: formCubitState.isSubmitting
? null
: () => context.read<HetznerFormCubit>().trySubmit(),
),
2022-05-24 21:55:39 +03:00
const SizedBox(height: 16),
BrandButton.text(
title: 'initializing.how'.tr(),
onPressed: () => showModalBottomSheet<void>(
context: context,
isScrollControlled: true,
backgroundColor: Colors.transparent,
2022-06-05 22:36:32 +03:00
builder: (final BuildContext context) {
2022-05-24 21:55:39 +03:00
return const BrandBottomSheet(
isExpended: true,
child: Padding(
padding: paddingH15V0,
child: BrandMarkdown(
fileName: 'how_hetzner',
),
),
);
},
),
),
],
);
},
),
);
}
}