youhua
This commit is contained in:
@@ -1,11 +1,11 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:shadcn_ui/shadcn_ui.dart';
|
||||
import 'package:flutter_localizations/flutter_localizations.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:shared_preferences/shared_preferences.dart';
|
||||
|
||||
import 'core/constants/app_colors.dart';
|
||||
import 'core/network/dio_client.dart';
|
||||
import 'core/storage/local_storage.dart';
|
||||
import 'core/theme/app_theme.dart';
|
||||
import 'data/services/user_service.dart';
|
||||
import 'data/services/market_service.dart';
|
||||
import 'data/services/trade_service.dart';
|
||||
@@ -20,6 +20,9 @@ import 'ui/pages/main/main_page.dart';
|
||||
void main() async {
|
||||
WidgetsFlutterBinding.ensureInitialized();
|
||||
|
||||
// 禁用 Provider 类型检查
|
||||
Provider.debugCheckInvalidValueType = null;
|
||||
|
||||
// 初始化本地存储
|
||||
final prefs = await SharedPreferences.getInstance();
|
||||
await LocalStorage.init();
|
||||
@@ -37,59 +40,79 @@ class MyApp extends StatelessWidget {
|
||||
// 服务
|
||||
Provider<DioClient>(create: (_) => DioClient()),
|
||||
ProxyProvider<DioClient, UserService>(
|
||||
create: (_) => throw UnimplementedError(),
|
||||
update: (_, client) => UserService(client),
|
||||
create: (_) => UserService(DioClient()),
|
||||
update: (_, client, previous) => previous ?? UserService(client),
|
||||
),
|
||||
ProxyProvider<DioClient, MarketService>(
|
||||
create: (_) => throw UnimplementedError(),
|
||||
update: (_, client) => MarketService(client),
|
||||
create: (_) => MarketService(DioClient()),
|
||||
update: (_, client, previous) => previous ?? MarketService(client),
|
||||
),
|
||||
ProxyProvider<DioClient, TradeService>(
|
||||
create: (_) => throw UnimplementedError(),
|
||||
update: (_, client) => TradeService(client),
|
||||
create: (_) => TradeService(DioClient()),
|
||||
update: (_, client, previous) => previous ?? TradeService(client),
|
||||
),
|
||||
ProxyProvider<DioClient, AssetService>(
|
||||
create: (_) => throw UnimplementedError(),
|
||||
update: (_, client) => AssetService(client),
|
||||
create: (_) => AssetService(DioClient()),
|
||||
update: (_, client, previous) => previous ?? AssetService(client),
|
||||
),
|
||||
ProxyProvider<DioClient, FundService>(
|
||||
create: (_) => throw UnimplementedError(),
|
||||
update: (_, client) => FundService(client),
|
||||
create: (_) => FundService(DioClient()),
|
||||
update: (_, client, previous) => previous ?? FundService(client),
|
||||
),
|
||||
// 状态管理
|
||||
ProxyProvider2<UserService, DioClient, AuthProvider>(
|
||||
create: (_) => throw UnimplementedError(),
|
||||
update: (_, userService, __) => AuthProvider(userService),
|
||||
create: (_) => AuthProvider(UserService(DioClient())),
|
||||
update: (_, userService, __, previous) =>
|
||||
previous ?? AuthProvider(userService),
|
||||
),
|
||||
ProxyProvider<MarketService, MarketProvider>(
|
||||
create: (_) => throw UnimplementedError(),
|
||||
update: (_, service) => MarketProvider(service),
|
||||
create: (_) => MarketProvider(MarketService(DioClient())),
|
||||
update: (_, service, previous) =>
|
||||
previous ?? MarketProvider(service),
|
||||
),
|
||||
ProxyProvider2<AssetService, FundService, AssetProvider>(
|
||||
create: (_) => throw UnimplementedError(),
|
||||
update: (_, assetService, fundService) => AssetProvider(assetService, fundService),
|
||||
create: (_) =>
|
||||
AssetProvider(AssetService(DioClient()), FundService(DioClient())),
|
||||
update: (_, assetService, fundService, previous) =>
|
||||
previous ?? AssetProvider(assetService, fundService),
|
||||
),
|
||||
],
|
||||
child: MaterialApp(
|
||||
title: '模拟所',
|
||||
debugShowCheckedModeBanner: false,
|
||||
theme: AppTheme.darkTheme,
|
||||
home: Consumer<AuthProvider>(
|
||||
builder: (context, auth, _) {
|
||||
if (auth.isLoading) {
|
||||
return const Scaffold(
|
||||
backgroundColor: AppColors.background,
|
||||
body: Center(
|
||||
child: CircularProgressIndicator(color: AppColors.primary),
|
||||
),
|
||||
);
|
||||
}
|
||||
if (auth.isLoggedIn) {
|
||||
return const MainPage();
|
||||
}
|
||||
return const LoginPage();
|
||||
},
|
||||
child: ShadApp.custom(
|
||||
themeMode: ThemeMode.dark,
|
||||
darkTheme: ShadThemeData(
|
||||
brightness: Brightness.dark,
|
||||
colorScheme: const ShadSlateColorScheme.dark(),
|
||||
),
|
||||
appBuilder: (context) {
|
||||
return MaterialApp(
|
||||
debugShowCheckedModeBanner: false,
|
||||
theme: Theme.of(context),
|
||||
localizationsDelegates: const [
|
||||
GlobalShadLocalizations.delegate,
|
||||
GlobalMaterialLocalizations.delegate,
|
||||
GlobalCupertinoLocalizations.delegate,
|
||||
GlobalWidgetsLocalizations.delegate,
|
||||
],
|
||||
builder: (context, child) {
|
||||
return ShadAppBuilder(child: child!);
|
||||
},
|
||||
home: Consumer<AuthProvider>(
|
||||
builder: (context, auth, _) {
|
||||
if (auth.isLoading) {
|
||||
return const Scaffold(
|
||||
body: Center(
|
||||
child: CircularProgressIndicator(),
|
||||
),
|
||||
);
|
||||
}
|
||||
if (auth.isLoggedIn) {
|
||||
return const MainPage();
|
||||
}
|
||||
return const LoginPage();
|
||||
},
|
||||
),
|
||||
);
|
||||
},
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user