| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 | 
							- import 'package:app_flowy/user/domain/i_auth.dart';
 
- import 'package:dartz/dartz.dart';
 
- import 'package:flowy_sdk/protobuf/flowy-user/protobuf.dart';
 
- import 'package:freezed_annotation/freezed_annotation.dart';
 
- import 'package:flutter_bloc/flutter_bloc.dart';
 
- part 'sign_up_bloc.freezed.dart';
 
- class SignUpBloc extends Bloc<SignUpEvent, SignUpState> {
 
-   final IAuth authImpl;
 
-   SignUpBloc(this.authImpl) : super(SignUpState.initial());
 
-   @override
 
-   Stream<SignUpState> mapEventToState(
 
-     SignUpEvent event,
 
-   ) async* {
 
-     yield* event.map(signUpWithUserEmailAndPassword: (e) async* {
 
-       yield* _performActionOnSignUp();
 
-     }, emailChanged: (EmailChanged value) async* {
 
-       yield state.copyWith(
 
-           email: value.email, emailError: none(), successOrFail: none());
 
-     }, passwordChanged: (PasswordChanged value) async* {
 
-       yield state.copyWith(
 
-           password: value.password,
 
-           passwordError: none(),
 
-           successOrFail: none());
 
-     }, repeatPasswordChanged: (RepeatPasswordChanged value) async* {
 
-       yield state.copyWith(
 
-           repeatedPassword: value.password,
 
-           repeatPasswordError: none(),
 
-           successOrFail: none());
 
-     });
 
-   }
 
-   Stream<SignUpState> _performActionOnSignUp() async* {
 
-     yield state.copyWith(
 
-       isSubmitting: true,
 
-       successOrFail: none(),
 
-     );
 
-     final password = state.password;
 
-     final repeatedPassword = state.repeatedPassword;
 
-     if (password == null) {
 
-       yield state.copyWith(
 
-         isSubmitting: false,
 
-         passwordError: some("Password can't be empty"),
 
-       );
 
-       return;
 
-     }
 
-     if (repeatedPassword == null) {
 
-       yield state.copyWith(
 
-         isSubmitting: false,
 
-         repeatPasswordError: some("Repeat password can't be empty"),
 
-       );
 
-       return;
 
-     }
 
-     if (password != repeatedPassword) {
 
-       yield state.copyWith(
 
-         isSubmitting: false,
 
-         repeatPasswordError:
 
-             some("Repeat password is not the same as password"),
 
-       );
 
-       return;
 
-     }
 
-     yield state.copyWith(
 
-       passwordError: none(),
 
-       repeatPasswordError: none(),
 
-     );
 
-     final result =
 
-         await authImpl.signUp(state.email, state.password, state.email);
 
-     yield result.fold(
 
-       (userProfile) => state.copyWith(
 
-         isSubmitting: false,
 
-         successOrFail: some(left(userProfile)),
 
-         emailError: none(),
 
-         passwordError: none(),
 
-         repeatPasswordError: none(),
 
-       ),
 
-       (error) => stateFromCode(error),
 
-     );
 
-   }
 
-   SignUpState stateFromCode(UserError error) {
 
-     switch (error.code) {
 
-       case ErrorCode.EmailFormatInvalid:
 
-         return state.copyWith(
 
-           isSubmitting: false,
 
-           emailError: some(error.msg),
 
-           passwordError: none(),
 
-           successOrFail: none(),
 
-         );
 
-       case ErrorCode.PasswordFormatInvalid:
 
-         return state.copyWith(
 
-           isSubmitting: false,
 
-           passwordError: some(error.msg),
 
-           emailError: none(),
 
-           successOrFail: none(),
 
-         );
 
-       default:
 
-         return state.copyWith(
 
-             isSubmitting: false, successOrFail: some(right(error)));
 
-     }
 
-   }
 
- }
 
- @freezed
 
- class SignUpEvent with _$SignUpEvent {
 
-   const factory SignUpEvent.signUpWithUserEmailAndPassword() =
 
-       SignUpWithUserEmailAndPassword;
 
-   const factory SignUpEvent.emailChanged(String email) = EmailChanged;
 
-   const factory SignUpEvent.passwordChanged(String password) = PasswordChanged;
 
-   const factory SignUpEvent.repeatPasswordChanged(String password) =
 
-       RepeatPasswordChanged;
 
- }
 
- @freezed
 
- class SignUpState with _$SignUpState {
 
-   const factory SignUpState({
 
-     String? email,
 
-     String? password,
 
-     String? repeatedPassword,
 
-     required bool isSubmitting,
 
-     required Option<String> passwordError,
 
-     required Option<String> repeatPasswordError,
 
-     required Option<String> emailError,
 
-     required Option<Either<UserProfile, UserError>> successOrFail,
 
-   }) = _SignUpState;
 
-   factory SignUpState.initial() => SignUpState(
 
-         isSubmitting: false,
 
-         passwordError: none(),
 
-         repeatPasswordError: none(),
 
-         emailError: none(),
 
-         successOrFail: none(),
 
-       );
 
- }
 
 
  |