This commit is contained in:
2026-04-07 11:30:22 +02:00
parent 4bbd1edf48
commit 130780cbb8
20 changed files with 426 additions and 131 deletions

View File

@@ -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",
),
);
}
});
}
}

View File

@@ -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];
}

View File

@@ -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,
);
}
}

View File

@@ -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));

View File

@@ -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,
];
}