Initial commit

This commit is contained in:
jahongireshonqulov
2025-10-18 09:40:06 +05:00
commit 1bf3e41abe
352 changed files with 16315 additions and 0 deletions

View File

@@ -0,0 +1,95 @@
import 'package:cargocalculaterapp/core/local_source/local_source.dart';
import 'package:cargocalculaterapp/generated/l10n.dart';
import 'package:cargocalculaterapp/router/app_routes.dart';
import 'package:equatable/equatable.dart';
import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import '../../../../../constants/constants.dart';
import '../../../../../core/error/failure.dart';
import '../../../../../core/functions/base_finctions.dart';
import '../../../../../injector_container.dart';
import '../../../../../router/name_routes.dart';
import '../../../data/model/sign_up_request.dart';
import '../../../domain/usecases/sign_up_usecase.dart';
import '../../pages/auth_confirm/argument/auth_confirm_argument.dart';
part 'sign_up_event.dart';
part 'sign_up_state.dart';
class SignUpBloc extends Bloc<SignUpEvent, SignUpState> {
SignUpBloc(this.signUpUseCase)
: super(
const SignUpState(
isLoading: false,
isButtonEnabled: false,
passwordHidden: true,
),
) {
on<PasswordVisibilityEvent>(_passwordVisibility);
on<OnInputEnterEvent>(_onDataEnter);
on<SubmitEvent>(_signUp);
}
final SignUpUseCase signUpUseCase;
void _passwordVisibility(
PasswordVisibilityEvent event,
Emitter<SignUpState> emit,
) {
emit(state.copyWith(isButtonEnabled: !state.isButtonEnabled));
}
void _onDataEnter(OnInputEnterEvent event, Emitter<SignUpState> emit) {
emit(
state.copyWith(
isButtonEnabled:
(isEmail(event.login) || isPhoneNumber(event.login)) &&
event.fullName.isNotEmpty,
),
);
}
bool isEmail(String input) {
return RegExConst.emailRegex.hasMatch(input);
}
bool isPhoneNumber(String input) {
return RegExConst.phoneRegex.hasMatch(input);
}
Future<void> _signUp(SubmitEvent event, Emitter<SignUpState> emit) async {
emit(state.copyWith(isLoading: true));
final response = await signUpUseCase(
SignUpRequest(
fullname: event.fullName,
email: isEmail(event.login) ? event.login : "",
phoneNumber: isPhoneNumber(event.login)
? event.login.replaceAll("+", "")
: "",
),
);
response.fold(
(l) {
emit(state.copyWith(isLoading: false));
if (l is ServerFailure) {
Functions.showErrorSnackBar(AppLocalization.current.phone_registered);
}
},
(r) {
sl<LocalSource>().setAccessToken(r.token ?? "");
emit(state.copyWith(isLoading: false));
Navigator.pushNamed(
rootNavigatorKey.currentContext!,
Routes.authConfirm,
arguments: AuthConfirmArgument(
fullName: event.fullName,
mail: isEmail(event.login) ? event.login : "",
phoneNumber: isPhoneNumber(event.login) ? event.login : "",
fromLoginPage: false,
),
);
},
);
}
}

View File

@@ -0,0 +1,32 @@
part of 'sign_up_bloc.dart';
sealed class SignUpEvent extends Equatable {
const SignUpEvent();
}
final class PasswordVisibilityEvent extends SignUpEvent {
const PasswordVisibilityEvent();
@override
List<Object?> get props => [];
}
final class OnInputEnterEvent extends SignUpEvent {
final String login;
final String fullName;
const OnInputEnterEvent({required this.login, required this.fullName});
@override
List<Object?> get props => [login, fullName];
}
final class SubmitEvent extends SignUpEvent {
final String login;
final String fullName;
const SubmitEvent({required this.login, required this.fullName});
@override
List<Object?> get props => [login, fullName];
}

View File

@@ -0,0 +1,28 @@
part of 'sign_up_bloc.dart';
class SignUpState extends Equatable {
const SignUpState({
required this.passwordHidden,
required this.isLoading,
required this.isButtonEnabled,
});
final bool passwordHidden;
final bool isLoading;
final bool isButtonEnabled;
SignUpState copyWith({
bool? passwordHidden,
bool? isLoading,
bool? isButtonEnabled,
}) {
return SignUpState(
isLoading: isLoading ?? this.isLoading,
passwordHidden: passwordHidden ?? this.passwordHidden,
isButtonEnabled: isButtonEnabled ?? this.isButtonEnabled,
);
}
@override
List<Object?> get props => [passwordHidden, isLoading, isButtonEnabled];
}