refactor nomi tabelle

This commit is contained in:
2026-05-20 11:03:33 +02:00
parent f190ad9353
commit c85f4b086e
24 changed files with 217 additions and 159 deletions

View File

@@ -1,3 +1,4 @@
import 'package:flux/core/enums_and_consts/consts.dart';
import 'package:flux/features/master_data/staff/models/staff_member_model.dart';
import 'package:flux/features/master_data/store/models/store_model.dart';
import 'package:get_it/get_it.dart';
@@ -11,7 +12,7 @@ class StaffRepository {
// Prende tutto lo staff della Company (per l'Hub Anagrafiche)
Future<List<StaffMemberModel>> getStaffMembers(String companyId) async {
final response = await _supabase
.from('staff_member')
.from(Tables.staffMembers)
.select()
.eq('company_id', companyId)
.order('name', ascending: true);
@@ -21,7 +22,7 @@ class StaffRepository {
Future<StaffMemberModel> saveStaffMember(StaffMemberModel member) async {
final response = await _supabase
.from('staff_member')
.from(Tables.staffMembers)
.upsert(member.toMap())
.select()
.single();
@@ -64,7 +65,7 @@ class StaffRepository {
try {
await _supabase.auth.resetPasswordForEmail(
email,
redirectTo: 'https://flux-web-invite.marco-6ba.workers.dev/',
redirectTo: resetPasswordUrl,
);
} catch (e) {
throw Exception("Errore nell'invio del link: $e");
@@ -77,14 +78,14 @@ class StaffRepository {
// Qui facciamo una JOIN per avere i dati del membro partendo dalla tabella di giunzione
Future<List<StaffMemberModel>> getStaffMembersInStore(String storeId) async {
final response = await _supabase
.from('staff_in_stores')
.from(Tables.staffInStores)
.select(
'staff_member (*)',
'${Tables.staffMembers} (*)',
) // Prende tutti i campi della tabella staff_member collegata
.eq('store_id', storeId);
return (response as List)
.map((item) => StaffMemberModel.fromMap(item['staff_member']))
.map((item) => StaffMemberModel.fromMap(item[Tables.staffMembers]))
.toList();
}
@@ -92,20 +93,20 @@ class StaffRepository {
// Qui facciamo una JOIN per avere i dati del membro partendo dalla tabella di giunzione
Future<List<StoreModel>> getStaffMemberStore(String staffId) async {
final response = await _supabase
.from('staff_in_stores')
.from(Tables.staffInStores)
.select(
'store (*)',
'${Tables.stores} (*)',
) // Prende tutti i campi della tabella store collegata
.eq('staff_member_id', staffId);
return (response as List)
.map((item) => StoreModel.fromMap(item['store']))
.map((item) => StoreModel.fromMap(item[Tables.stores]))
.toList();
}
// Assegna un membro a un negozio
Future<void> assignStaffToStore(String staffId, String storeId) async {
await _supabase.from('staff_in_stores').insert({
await _supabase.from(Tables.staffInStores).insert({
'staff_member_id': staffId,
'store_id': storeId,
});
@@ -114,7 +115,7 @@ class StaffRepository {
// Rimuove l'assegnazione
Future<void> removeStaffFromStore(String staffId, String storeId) async {
await _supabase
.from('staff_in_stores')
.from(Tables.staffInStores)
.delete()
.eq('staff_member_id', staffId)
.eq('store_id', storeId);
@@ -125,7 +126,7 @@ class StaffRepository {
// Utility per pulire le assegnazioni esistenti prima di riscriverle
Future<void> clearStoreAssignments(String staffId) async {
await _supabase
.from('staff_in_stores')
.from(Tables.staffInStores)
.delete()
.eq('staff_member_id', staffId);
}