import 'package:flutter/material.dart'; // ignore: depend_on_referenced_packages import 'package:flutter_web_plugins/flutter_web_plugins.dart'; import 'package:provider/provider.dart'; import 'package:logging/logging.dart'; import 'package:pshared/config/constants.dart'; import 'package:pshared/provider/locale.dart'; import 'package:pshared/provider/permissions.dart'; import 'package:pshared/provider/account.dart'; import 'package:pshared/provider/organizations.dart'; import 'package:pshared/provider/payment/amount.dart'; import 'package:pshared/provider/payment/flow.dart'; import 'package:pshared/provider/payment/provider.dart'; import 'package:pshared/provider/payment/quotation.dart'; import 'package:pshared/provider/recipient/provider.dart'; import 'package:pshared/provider/recipient/pmethods.dart'; import 'package:pshared/provider/payment/wallets.dart'; import 'package:pshared/models/payment/type.dart'; import 'package:pshared/service/payment/wallets.dart'; import 'package:pweb/app/app.dart'; import 'package:pweb/app/timeago.dart'; import 'package:pweb/providers/carousel.dart'; import 'package:pweb/providers/operatioins.dart'; import 'package:pweb/providers/two_factor.dart'; import 'package:pweb/providers/upload_history.dart'; import 'package:pweb/providers/wallet_transactions.dart'; import 'package:pweb/services/operations.dart'; import 'package:pweb/services/payments/history.dart'; import 'package:pweb/services/posthog.dart'; import 'package:pweb/services/wallet_transactions.dart'; import 'package:pweb/providers/account.dart'; void _setupLogging() { Logger.root.level = Level.ALL; Logger.root.onRecord.listen((record) { // ignore: avoid_print print('${record.level.name}: ${record.time}: ${record.loggerName}: ${record.message}'); }); } void main() async { WidgetsFlutterBinding.ensureInitialized(); await Constants.initialize(); await PosthogService.initialize(); _setupLogging(); setUrlStrategy(PathUrlStrategy()); initializeTimeagoLocales(); runApp( MultiProvider( providers: [ ChangeNotifierProvider(create: (_) => LocaleProvider(null)), ChangeNotifierProxyProvider( create: (_) => PwebAccountProvider(), update: (context, localeProvider, provider) => provider!..updateProvider(localeProvider), ), ChangeNotifierProxyProvider( create: (_) => TwoFactorProvider(), update: (context, accountProvider, provider) => provider!..update(accountProvider), ), ChangeNotifierProvider(create: (_) => OrganizationsProvider()), ChangeNotifierProxyProvider( create: (_) => PermissionsProvider(), update: (context, orgnization, provider) => provider!..update(orgnization), ), ChangeNotifierProvider(create: (_) => CarouselIndexProvider()), ChangeNotifierProvider( create: (_) => UploadHistoryProvider(service: MockUploadHistoryService())..load(), ), ChangeNotifierProxyProvider( create: (_) => RecipientsProvider(), update: (context, organizations, provider) => provider!..updateProviders(organizations), ), ChangeNotifierProxyProvider2( create: (_) => PaymentMethodsProvider(), update: (context, organizations, recipients, provider) => provider!..updateProviders(organizations, recipients), ), ChangeNotifierProxyProvider( create: (_) => WalletsProvider(ApiWalletsService()), update: (context, organizations, provider) => provider!..update(organizations), ), ChangeNotifierProvider( create: (_) => WalletTransactionsProvider(MockWalletTransactionsService())..load(), ), ChangeNotifierProxyProvider2( create: (_) => PaymentFlowProvider(initialType: PaymentType.bankAccount), update: (context, recipients, methods, provider) => provider!..update( recipients, methods, ), ), ChangeNotifierProvider( create: (_) => OperationProvider(OperationService())..loadOperations(), ), ChangeNotifierProvider( create: (_) => PaymentAmountProvider(), ), ChangeNotifierProxyProvider6( create: (_) => QuotationProvider(), update: (_, organization, payment, wallet, flow, recipients, methods, provider) => provider!..update(organization, payment, wallet, flow, recipients, methods), ), ChangeNotifierProxyProvider2( create: (_) => PaymentProvider(), update: (context, organization, quotation, provider) => provider!..update( organization, quotation, ), ), ], child: const PayApp(), ), ); }