refactor
This commit is contained in:
@@ -1,57 +0,0 @@
|
||||
import 'package:flutter_bloc/flutter_bloc.dart';
|
||||
import 'package:equatable/equatable.dart';
|
||||
import 'package:get_it/get_it.dart';
|
||||
import 'package:supabase_flutter/supabase_flutter.dart';
|
||||
|
||||
part 'auth_events.dart';
|
||||
part 'auth_state.dart';
|
||||
|
||||
class AuthBloc extends Bloc<AuthEvent, AuthState> {
|
||||
final _supabase = GetIt.instance<SupabaseClient>();
|
||||
|
||||
AuthBloc()
|
||||
: super(const AuthState(status: AuthStatus.initial, isLoginMode: true)) {
|
||||
on<ToggleAuthMode>(
|
||||
(event, emit) => emit(state.copyWith(isLoginMode: !state.isLoginMode)),
|
||||
);
|
||||
on<LoginRequested>((event, emit) async {
|
||||
emit(state.copyWith(status: AuthStatus.loading));
|
||||
try {
|
||||
if (state.isLoginMode) {
|
||||
// --- LOGICA LOGIN ---
|
||||
await _supabase.auth.signInWithPassword(
|
||||
email: event.email,
|
||||
password: event.password,
|
||||
);
|
||||
// Non serve emettere success qui, ci pensa il SessionBloc!
|
||||
} else {
|
||||
// --- LOGICA SIGNUP ---
|
||||
await _supabase.auth.signUp(
|
||||
email: event.email,
|
||||
password: event.password,
|
||||
// Qui potresti passare il "Codice Negozio" nei data dell'utente
|
||||
data: {'store_code': event.storeCode},
|
||||
);
|
||||
|
||||
// Nota: Se Supabase richiede conferma email, l'utente non sarà
|
||||
// loggato subito. Gestiamolo con un messaggio.
|
||||
emit(
|
||||
state.copyWith(
|
||||
status: AuthStatus.success,
|
||||
error: "Controlla la tua email per confermare l'account!",
|
||||
),
|
||||
);
|
||||
}
|
||||
} on AuthException catch (e) {
|
||||
emit(state.copyWith(status: AuthStatus.failure, error: e.message));
|
||||
} catch (e) {
|
||||
emit(
|
||||
state.copyWith(
|
||||
status: AuthStatus.failure,
|
||||
error: "Errore imprevisto: $e",
|
||||
),
|
||||
);
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
@@ -1,24 +0,0 @@
|
||||
part of 'auth_bloc.dart';
|
||||
|
||||
abstract class AuthEvent extends Equatable {
|
||||
const AuthEvent();
|
||||
|
||||
@override
|
||||
List<Object?> get props => [];
|
||||
}
|
||||
|
||||
class ToggleAuthMode extends AuthEvent {} // Passa da Login a Registrazione
|
||||
|
||||
class LoginRequested extends AuthEvent {
|
||||
final String email;
|
||||
final String password;
|
||||
final String? storeCode;
|
||||
const LoginRequested({
|
||||
required this.email,
|
||||
required this.password,
|
||||
this.storeCode,
|
||||
});
|
||||
|
||||
@override
|
||||
List<Object?> get props => [email, password, storeCode];
|
||||
}
|
||||
@@ -1,26 +0,0 @@
|
||||
part of 'auth_bloc.dart';
|
||||
|
||||
enum AuthStatus { initial, loading, success, failure }
|
||||
|
||||
class AuthState extends Equatable {
|
||||
const AuthState({
|
||||
required this.status,
|
||||
this.error,
|
||||
required this.isLoginMode,
|
||||
});
|
||||
|
||||
final AuthStatus status;
|
||||
final String? error;
|
||||
final bool isLoginMode;
|
||||
|
||||
@override
|
||||
List<Object?> get props => [status, error, isLoginMode];
|
||||
|
||||
AuthState copyWith({AuthStatus? status, String? error, bool? isLoginMode}) {
|
||||
return AuthState(
|
||||
status: status ?? this.status,
|
||||
error: error,
|
||||
isLoginMode: isLoginMode ?? this.isLoginMode,
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -12,14 +12,26 @@ class CompanyBloc extends Bloc<CompanyEvent, CompanyState> {
|
||||
CompanyBloc() : super(const CompanyState(status: CompanyStatus.initial)) {
|
||||
on<SaveCompanyRequested>((event, emit) async {
|
||||
emit(const CompanyState(status: CompanyStatus.loading));
|
||||
|
||||
try {
|
||||
// Recuperiamo l'ID utente corrente da Supabase Auth
|
||||
final userId = _supabase.auth.currentUser!.id;
|
||||
|
||||
await _supabase.from('companies').insert({
|
||||
'owner_id': userId,
|
||||
await _supabase.from('company').insert({
|
||||
'user_id': userId,
|
||||
'ragione_sociale': event.ragioneSociale,
|
||||
'partita_iva': event.partitaIva,
|
||||
// Se il CF è vuoto, usa la P.IVA (logica salva-tempo per ditte individuali)
|
||||
'codice_fiscale': event.codiceFiscale.isEmpty
|
||||
? event.partitaIva
|
||||
: event.codiceFiscale,
|
||||
'codice_univoco': event.codiceUnivoco,
|
||||
'indirizzo': event.indirizzo,
|
||||
'cap': event.cap,
|
||||
'citta': event.citta,
|
||||
'provincia': event.provincia,
|
||||
'company_logo': event.companyLogo,
|
||||
'is_paid': false, // Di default partono con trial/non pagato
|
||||
});
|
||||
|
||||
emit(const CompanyState(status: CompanyStatus.success));
|
||||
|
||||
@@ -1,16 +1,47 @@
|
||||
part of 'company_bloc.dart';
|
||||
|
||||
abstract class CompanyEvent {
|
||||
// lib/blocs/company/company_event.dart
|
||||
|
||||
abstract class CompanyEvent extends Equatable {
|
||||
const CompanyEvent();
|
||||
|
||||
@override
|
||||
List<Object?> get props => [];
|
||||
}
|
||||
|
||||
final class SaveCompanyRequested extends CompanyEvent {
|
||||
class SaveCompanyRequested extends CompanyEvent {
|
||||
final String ragioneSociale;
|
||||
final String partitaIva;
|
||||
final String codiceFiscale;
|
||||
final String codiceUnivoco;
|
||||
const SaveCompanyRequested(
|
||||
this.ragioneSociale,
|
||||
this.partitaIva,
|
||||
this.codiceUnivoco,
|
||||
);
|
||||
final String indirizzo;
|
||||
final String cap;
|
||||
final String citta;
|
||||
final String provincia;
|
||||
final String companyLogo;
|
||||
|
||||
const SaveCompanyRequested({
|
||||
required this.ragioneSociale,
|
||||
required this.partitaIva,
|
||||
required this.codiceFiscale,
|
||||
required this.codiceUnivoco,
|
||||
required this.indirizzo,
|
||||
required this.cap,
|
||||
required this.citta,
|
||||
required this.provincia,
|
||||
this.companyLogo = '', // Default vuoto come da schema SQL
|
||||
});
|
||||
|
||||
@override
|
||||
List<Object?> get props => [
|
||||
ragioneSociale,
|
||||
partitaIva,
|
||||
codiceFiscale,
|
||||
codiceUnivoco,
|
||||
indirizzo,
|
||||
cap,
|
||||
citta,
|
||||
provincia,
|
||||
companyLogo,
|
||||
];
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user