part of 'users.dart'; @RoutePage() class NewUserPage extends StatelessWidget { const NewUserPage({super.key}); @override Widget build(final BuildContext context) { final ServerInstallationState config = context.watch().state; final String domainName = UiHelpers.getDomainName(config); return BlocProvider( create: (final BuildContext context) { final jobCubit = context.read(); // final jobsState = jobCubit.state; // final users = [ // ...context.read().state.users, // if (jobsState is JobsStateWithJobs) // ...jobsState.clientJobList // .whereType() // .map((final job) => job.user), // ]; return UserFormCubit( jobsCubit: jobCubit, fieldFactory: FieldCubitFactory(context), ); }, child: Builder( builder: (final BuildContext context) { final FormCubitState formCubitState = context.watch().state; return BlocListener( listener: (final BuildContext context, final FormCubitState state) { if (state.isSubmitted) { context.router.maybePop(); } }, child: BrandHeroScreen( heroTitle: 'users.new_user'.tr(), heroIcon: Icons.person_add_outlined, children: [ if (formCubitState.isErrorShown) Text( 'users.username_rule'.tr(), style: TextStyle( color: Theme.of(context).colorScheme.error, ), ), const SizedBox(width: 14), IntrinsicHeight( child: CubitFormTextField( autofocus: true, formFieldCubit: context.read().login, decoration: InputDecoration( labelText: 'users.login'.tr(), suffixText: '@$domainName', ), ), ), const SizedBox(height: 20), CubitFormTextField( formFieldCubit: context.read().password, decoration: InputDecoration( alignLabelWithHint: false, labelText: 'basis.password'.tr(), suffixIcon: Padding( padding: const EdgeInsets.only(right: 8), child: Row( mainAxisSize: MainAxisSize.min, children: [ IconButton( icon: Icon( Icons.copy, size: 24.0, color: Theme.of(context).colorScheme.secondary, ), onPressed: () { final String currentPassword = context .read() .password .state .value; PlatformAdapter.setClipboard(currentPassword); getIt().showSnackBar( 'basis.copied_to_clipboard'.tr(), ); }, ), IconButton( icon: Icon( Icons.refresh, size: 24.0, color: Theme.of(context).colorScheme.secondary, ), onPressed: context.read().genNewPassword, ), ], ), ), ), ), const SizedBox(height: 30), BrandButton.filled( onPressed: formCubitState.isSubmitting ? null : () => context.read().trySubmit(), title: 'basis.create'.tr(), ), const SizedBox(height: 40), Text('users.new_user_info_note'.tr()), const SizedBox(height: 30), ], ), ); }, ), ); } }