Current org now sets after list gets to the state of the provider
This commit is contained in:
@@ -20,7 +20,6 @@ class OrganizationsProvider extends ChangeNotifier {
|
||||
Organization get current => isOrganizationSet ? _current! : throw StateError('Organization is not set');
|
||||
|
||||
Organization? _org(String? orgRef) => organizations.firstWhereOrNull((org) => org.id == orgRef);
|
||||
Organization? _orgInList(String? orgRef, List<Organization> list) => list.firstWhereOrNull((org) => org.id == orgRef);
|
||||
Organization? get _current => _org(_currentOrg);
|
||||
|
||||
bool get isOrganizationSet => _current != null;
|
||||
@@ -36,13 +35,15 @@ class OrganizationsProvider extends ChangeNotifier {
|
||||
_setResource(_resource.copyWith(isLoading: true, error: null));
|
||||
try {
|
||||
final orgs = await OrganizationService.list();
|
||||
// keep fetched organizations so _org can resolve against them
|
||||
_setResource(Resource(data: orgs, isLoading: true));
|
||||
// fetch stored org
|
||||
String? org = await SecureStorageService.get(Constants.currentOrgKey);
|
||||
// check stored org availability
|
||||
org = orgs.firstWhereOrNull((o) => o.id == org)?.id;
|
||||
// fallback if org is not set or not available
|
||||
org ??= orgs.first.id;
|
||||
await setCurrentOrganization(org, availableOrganizations: orgs);
|
||||
await setCurrentOrganization(org);
|
||||
_setResource(Resource(data: orgs, isLoading: false));
|
||||
return orgs;
|
||||
} catch (e) {
|
||||
@@ -55,7 +56,8 @@ class OrganizationsProvider extends ChangeNotifier {
|
||||
_setResource(_resource.copyWith(isLoading: true, error: null));
|
||||
try {
|
||||
final org = await OrganizationService.loadByInvitation(invitationRef);
|
||||
await setCurrentOrganization(org.id, availableOrganizations: [org]);
|
||||
_setResource(Resource(data: [org], isLoading: true));
|
||||
await setCurrentOrganization(org.id);
|
||||
_setResource(Resource(data: [org], isLoading: false));
|
||||
return org;
|
||||
} catch (e) {
|
||||
@@ -64,23 +66,17 @@ class OrganizationsProvider extends ChangeNotifier {
|
||||
}
|
||||
}
|
||||
|
||||
bool _setCurrentOrganization(
|
||||
String? orgRef, {
|
||||
List<Organization>? availableOrganizations,
|
||||
}) {
|
||||
final organizationRef = _orgInList(orgRef, availableOrganizations ?? organizations)?.id;
|
||||
bool _setCurrentOrganization(String? orgRef) {
|
||||
final organizationRef = _org(orgRef)?.id;
|
||||
if (organizationRef == null) return false;
|
||||
|
||||
_currentOrg = organizationRef;
|
||||
return true;
|
||||
}
|
||||
|
||||
Future<bool> setCurrentOrganization(
|
||||
String? orgRef, {
|
||||
List<Organization>? availableOrganizations,
|
||||
}) async {
|
||||
if (!_setCurrentOrganization(orgRef, availableOrganizations: availableOrganizations)) return false;
|
||||
await SecureStorageService.set(Constants.currentOrgKey, _currentOrg);
|
||||
Future<bool> setCurrentOrganization(String? orgRef) async {
|
||||
if (!_setCurrentOrganization(orgRef)) return false;
|
||||
await SecureStorageService.set(Constants.currentOrgKey, orgRef);
|
||||
notifyListeners();
|
||||
return true;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user