refactored pr

This commit is contained in:
Sergey Penkovsky
2023-01-04 11:03:29 +03:00
parent 8c3a0df452
commit e0f5874621
3 changed files with 22 additions and 22 deletions

View File

@@ -22,15 +22,15 @@ class FeatureModule extends Module {
.withName('networkRepo')
.toProvide(
() => NetworkDataRepository(
currentScope.resolve<ApiClient>(
named: isMock ? 'apiClientMock' : 'apiClientImpl',
),
),
)
currentScope.resolve<ApiClient>(
named: isMock ? 'apiClientMock' : 'apiClientImpl',
),
),
)
.singleton();
bind<DataBloc>().toProvideWithParam(
(param) => DataBloc(
bind<DataBloc>().toProvideWithParams(
(param) => DataBloc(
currentScope.resolve<DataRepository>(named: 'networkRepo'),
param,
),
@@ -47,7 +47,7 @@ void main() async {
.openSubScope('featureScope')
.installModules([FeatureModule(isMock: true)]);
final dataBloc = subScope.resolve<DataBloc>(param: 'PARAMETER');
final dataBloc = subScope.resolve<DataBloc>(params: 'PARAMETER');
dataBloc.data.listen((d) => print('Received data: $d'),
onError: (e) => print('Error: $e'), onDone: () => print('DONE'));

View File

@@ -13,7 +13,7 @@
enum Mode { SIMPLE, INSTANCE, PROVIDER_INSTANCE, PROVIDER_WITH_PARAMS_INSTANCE }
typedef ProviderWithParam<T> = T Function(dynamic param);
typedef ProviderWithParams<T> = T Function(dynamic params);
/// RU: Класс Binding<T> настраивает параметры экземпляра.
/// ENG: The Binding<T> class configures the settings for the instance.
@@ -24,7 +24,7 @@ class Binding<T> {
late String _name;
T? _instance;
T? Function()? _provider;
ProviderWithParam<T>? _providerWithParam;
ProviderWithParams<T>? _providerWithParams;
late bool _isSingleton = false;
late bool _isNamed = false;
@@ -98,9 +98,9 @@ class Binding<T> {
/// ENG: Initialization instance via provider [value] with a dynamic param.
///
/// return [Binding]
Binding<T> toProvideWithParam(ProviderWithParam<T> value) {
Binding<T> toProvideWithParams(ProviderWithParams<T> value) {
_mode = Mode.PROVIDER_WITH_PARAMS_INSTANCE;
_providerWithParam = value;
_providerWithParams = value;
return this;
}
@@ -132,10 +132,11 @@ class Binding<T> {
}
/// RU: Поиск экземпляра с параметром.
/// ENG: Resolve instance with param.
///
/// ENG: Resolve instance with [params].
///
/// return [T]
T? providerWithParam(dynamic param) {
return _providerWithParam?.call(param);
T? providerWithParams(dynamic params) {
return _providerWithParams?.call(params);
}
}

View File

@@ -86,8 +86,8 @@ class Scope {
/// If you want to get [null] if the dependency cannot be found then use [tryResolve] instead
/// return - returns an object of type [T] or [StateError]
///
T resolve<T>({String? named, dynamic param}) {
var resolved = tryResolve<T>(named: named, param: param);
T resolve<T>({String? named, dynamic params}) {
var resolved = tryResolve<T>(named: named, params: params);
if (resolved != null) {
return resolved;
} else {
@@ -99,7 +99,7 @@ class Scope {
/// RU: Возвращает найденную зависимость типа [T] или null, если она не может быть найдена.
/// ENG: Returns found dependency of type [T] or null if it cannot be found.
///
T? tryResolve<T>({String? named, dynamic param}) {
T? tryResolve<T>({String? named, dynamic params}) {
// 1 Поиск зависимости по всем модулям текущего скоупа
if (_modulesList.isNotEmpty) {
for (var module in _modulesList) {
@@ -113,11 +113,10 @@ class Scope {
case Mode.PROVIDER_INSTANCE:
return binding.provider;
case Mode.PROVIDER_WITH_PARAMS_INSTANCE:
if (param == null) {
throw StateError(
'Param is null. Maybe you forget pass it');
if (params == null) {
throw StateError('Param is null. Maybe you forget pass it');
}
return binding.providerWithParam(param);
return binding.providerWithParams(params);
default:
return null;
}