Skip to content

Commit

Permalink
Merge pull request #108 from ElchinGasymov/careerhub_add_interactor
Browse files Browse the repository at this point in the history
Интерактор для фильтров и di
  • Loading branch information
G-dev-ui authored Aug 18, 2024
2 parents e459847 + 9084c72 commit f85552c
Show file tree
Hide file tree
Showing 3 changed files with 49 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,12 @@ package ru.practicum.android.diploma.di

import org.koin.dsl.module
import ru.practicum.android.diploma.domain.DetailsInteractor
import ru.practicum.android.diploma.domain.SearchInteractor
import ru.practicum.android.diploma.domain.FavouriteVacanciesInteractor
import ru.practicum.android.diploma.domain.impl.FavouriteVacanciesInteractorImpl
import ru.practicum.android.diploma.domain.FilterInteractor
import ru.practicum.android.diploma.domain.SearchInteractor
import ru.practicum.android.diploma.domain.impl.DetailsInteractorImpl
import ru.practicum.android.diploma.domain.impl.FavouriteVacanciesInteractorImpl
import ru.practicum.android.diploma.domain.impl.FilterInteractorImpl
import ru.practicum.android.diploma.domain.impl.SearchInteractorImpl

val interactorModule = module {
Expand All @@ -20,4 +22,8 @@ val interactorModule = module {
factory<DetailsInteractor> {
DetailsInteractorImpl(repository = get())
}

factory<FilterInteractor> {
FilterInteractorImpl(repository = get())
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
package ru.practicum.android.diploma.domain

import kotlinx.coroutines.flow.Flow
import ru.practicum.android.diploma.domain.models.Country
import ru.practicum.android.diploma.domain.models.Industries
import ru.practicum.android.diploma.domain.models.Region
import ru.practicum.android.diploma.util.ResponseData

interface FilterInteractor {
suspend fun getCountries(): Flow<ResponseData<List<Country>>>
suspend fun getRegions(id: String): Flow<ResponseData<List<Region>>>
suspend fun getAllRegions(): Flow<ResponseData<List<Region>>>
suspend fun getIndustries(): Flow<ResponseData<List<Industries>>>
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
package ru.practicum.android.diploma.domain.impl

import kotlinx.coroutines.flow.Flow
import ru.practicum.android.diploma.domain.FilterInteractor
import ru.practicum.android.diploma.domain.api.FilterRepository
import ru.practicum.android.diploma.domain.models.Country
import ru.practicum.android.diploma.domain.models.Industries
import ru.practicum.android.diploma.domain.models.Region
import ru.practicum.android.diploma.util.ResponseData

class FilterInteractorImpl(private val repository: FilterRepository) : FilterInteractor {
override suspend fun getCountries(): Flow<ResponseData<List<Country>>> {
return repository.getCountries()
}

override suspend fun getRegions(id: String): Flow<ResponseData<List<Region>>> {
return repository.getRegions(id)
}

override suspend fun getAllRegions(): Flow<ResponseData<List<Region>>> {
return repository.getAllRegions()
}

override suspend fun getIndustries(): Flow<ResponseData<List<Industries>>> {
return repository.getIndustries()
}
}

0 comments on commit f85552c

Please sign in to comment.