43 lines
1.2 KiB
Dart
43 lines
1.2 KiB
Dart
import 'package:flutter/material.dart';
|
|
|
|
import 'package:provider/provider.dart';
|
|
|
|
import 'package:pshared/provider/organizations.dart';
|
|
|
|
import 'package:pweb/generated/i18n/app_localizations.dart';
|
|
|
|
|
|
class OrganizationLoader extends StatelessWidget {
|
|
final Widget child;
|
|
|
|
const OrganizationLoader({super.key, required this.child});
|
|
|
|
@override
|
|
Widget build(BuildContext context) => Consumer<OrganizationsProvider>(builder: (context, provider, _) {
|
|
if (provider.isLoading) return const Center(child: CircularProgressIndicator());
|
|
if (provider.error != null) {
|
|
final loc = AppLocalizations.of(context)!;
|
|
return Center(
|
|
child: Column(
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: [
|
|
Text(loc.errorLogin),
|
|
const SizedBox(height: 12),
|
|
ElevatedButton(
|
|
onPressed: provider.load,
|
|
child: Text(loc.retry),
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
if ((provider.error == null) && (!provider.isOrganizationSet)) {
|
|
WidgetsBinding.instance.addPostFrameCallback((_) {
|
|
provider.load();
|
|
});
|
|
return const Center(child: CircularProgressIndicator());
|
|
}
|
|
return child;
|
|
});
|
|
}
|