This commit is contained in:
Sergey Penkovsky
2025-05-16 18:09:14 +03:00
parent 5cab9164ce
commit 9bce40735b
5 changed files with 48 additions and 20 deletions

View File

@@ -0,0 +1,21 @@
import 'package:dio/dio.dart';
import 'package:cherrypick/cherrypick.dart';
import '../data/network/json_placeholder_api.dart';
import '../data/post_repository_impl.dart';
import '../domain/repository/post_repository.dart';
class AppModule extends Module {
@override
void builder(Scope currentScope) {
bind<Dio>().toProvide(() => Dio()).singleton();
bind<JsonPlaceholderApi>()
.toProvide(() => JsonPlaceholderApi(currentScope.resolve<Dio>()))
.singleton();
bind<PostRepository>()
.toProvide(() =>
PostRepositoryImpl(currentScope.resolve<JsonPlaceholderApi>()))
.singleton();
}
}

View File

@@ -1,28 +1,29 @@
import 'package:cherrypick/cherrypick.dart';
import 'package:flutter/material.dart';
import 'package:dio/dio.dart';
import 'data/network/json_placeholder_api.dart';
import 'data/post_repository_impl.dart';
import 'di/app_module.dart';
import 'domain/repository/post_repository.dart';
import 'presentation/bloc/post_bloc.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import 'router/app_router.dart';
void main() {
final dio = Dio();
final api = JsonPlaceholderApi(dio);
final repository = PostRepositoryImpl(api);
final scope = CherryPick.openRootScope();
scope.installModules([AppModule()]);
runApp(MyApp(repository: repository));
runApp(MyApp(scope: scope));
}
class MyApp extends StatelessWidget {
final PostRepository repository;
final Scope scope;
final _appRouter = AppRouter();
MyApp({super.key, required this.repository});
MyApp({super.key, required this.scope});
@override
Widget build(BuildContext context) {
// Получаем репозиторий через injector
final repository = scope.resolve<PostRepository>();
return BlocProvider(
create: (_) => PostBloc(repository),
child: MaterialApp.router(

View File

@@ -150,6 +150,14 @@ packages:
url: "https://pub.dev"
source: hosted
version: "2.0.3"
cherrypick:
dependency: "direct main"
description:
name: cherrypick
sha256: e1e2b4f3a70cbe7760e479e6ddb7dce2fc85a1bbb2fba6c398efe235ed111dfe
url: "https://pub.dev"
source: hosted
version: "2.0.2"
clock:
dependency: transitive
description:

View File

@@ -11,6 +11,9 @@ environment:
dependencies:
flutter:
sdk: flutter
cherrypick: any
dio: ^5.4.0
retrofit: ^4.0.3
freezed_annotation: ^2.0.0

View File

@@ -5,29 +5,24 @@
// gestures. You can also use WidgetTester to find child widgets in the widget
// tree, read text, and verify that the values of widget properties are correct.
import 'package:dio/dio.dart';
import 'package:cherrypick/cherrypick.dart';
import 'package:flutter/material.dart';
import 'package:flutter_test/flutter_test.dart';
import 'package:postly/data/network/json_placeholder_api.dart';
import 'package:postly/data/post_repository_impl.dart';
import 'package:postly/domain/repository/post_repository.dart';
import 'package:postly/di/app_module.dart';
import 'package:postly/main.dart';
void main() {
late Dio dio;
late JsonPlaceholderApi api;
late PostRepository repository;
late Scope scope;
setUp(() {
dio = Dio();
api = JsonPlaceholderApi(dio);
repository = PostRepositoryImpl(api);
scope = CherryPick.openRootScope();
scope.installModules([AppModule()]);
});
testWidgets('Counter increments smoke test', (WidgetTester tester) async {
// Build our app and trigger a frame.
await tester.pumpWidget(MyApp(
repository: repository,
scope: scope,
));
// Verify that our counter starts at 0.