diff --git a/presentation/src/main/java/org/gdsc/presentation/view/allsearch/AllSearchFragment.kt b/presentation/src/main/java/org/gdsc/presentation/view/allsearch/AllSearchFragment.kt index 90835c1b..62358a27 100644 --- a/presentation/src/main/java/org/gdsc/presentation/view/allsearch/AllSearchFragment.kt +++ b/presentation/src/main/java/org/gdsc/presentation/view/allsearch/AllSearchFragment.kt @@ -55,6 +55,8 @@ class AllSearchFragment : Fragment() { binding.cgRecentSearch.removeAllViews() keywordList.forEach { if (it.isNotBlank()) { + binding.tvRecentSearch.visibility = View.VISIBLE + binding.tvDelete.visibility = View.VISIBLE binding.cgRecentSearch.addView( newChip(it, { keyword -> @@ -64,6 +66,9 @@ class AllSearchFragment : Fragment() { navigateToResultPage() } ) + } else { + binding.tvRecentSearch.visibility = View.GONE + binding.tvDelete.visibility = View.GONE } } } diff --git a/presentation/src/main/java/org/gdsc/presentation/view/allsearch/AllSearchViewModel.kt b/presentation/src/main/java/org/gdsc/presentation/view/allsearch/AllSearchViewModel.kt index 7ba86fa8..e18b1357 100644 --- a/presentation/src/main/java/org/gdsc/presentation/view/allsearch/AllSearchViewModel.kt +++ b/presentation/src/main/java/org/gdsc/presentation/view/allsearch/AllSearchViewModel.kt @@ -13,8 +13,10 @@ import kotlinx.coroutines.launch import org.gdsc.domain.DrinkPossibility import org.gdsc.domain.FoodCategory import org.gdsc.domain.SortType +import org.gdsc.domain.model.GroupPreview import org.gdsc.domain.model.Location import org.gdsc.domain.model.RegisteredRestaurant +import org.gdsc.domain.usecase.GetGroupBySearchWithLimitCountUseCase import org.gdsc.domain.usecase.GetRestaurantBySearchUseCase import org.gdsc.domain.usecase.GetRestaurantBySearchWithLimitCountUseCase import org.gdsc.domain.usecase.user.DeleteSearchedKeywordUseCase @@ -32,41 +34,12 @@ class AllSearchViewModel @Inject constructor( private val updateSearchedKeywordUseCase: UpdateSearchedKeywordUseCase, private val deleteSearchedKeywordUseCase: DeleteSearchedKeywordUseCase, private val initSearchedKeywordUseCase: InitSearchedKeywordUseCase, - private val getRestaurantBySearchWithLimitCountUseCase: GetRestaurantBySearchWithLimitCountUseCase + private val getRestaurantBySearchWithLimitCountUseCase: GetRestaurantBySearchWithLimitCountUseCase, + private val getGroupBySearchWithLimitCountUseCase: GetGroupBySearchWithLimitCountUseCase ) : ViewModel() { init { - viewModelScope.launch { - val location = locationManager.getCurrentLocation() - - if (location == null) { - _searchedRestaurantPreviewState.value = emptyList() - } else { - - val userLoc = Location(location.longitude.toString(), location.latitude.toString()) - - _searchedRestaurantPreviewState.value = - getRestaurantBySearchWithLimitCountUseCase(searchKeyword.value, userLoc, 3) - } - - } - - viewModelScope.launch { - val location = locationManager.getCurrentLocation() - - if (location == null) { - _searchedRestaurantState.value = PagingData.empty() - } else { - val userLoc = Location(location.longitude.toString(), location.latitude.toString()) - - getRestaurantBySearchUseCase(searchKeyword.value, userLoc).distinctUntilChanged() - .collect { - _searchedRestaurantState.value = it - } - } - } - viewModelScope.launch { val keywords = getSearchedKeywordsUseCase() if (keywords.isNotEmpty()) { @@ -101,6 +74,12 @@ class AllSearchViewModel @Inject constructor( val searchedRestaurantPreviewState: StateFlow> get() = _searchedRestaurantPreviewState + private var _searchedGroupPreviewState = + MutableStateFlow>(emptyList()) + + val searchedGroupPreviewState: StateFlow> + get() = _searchedGroupPreviewState + private var _searchedKeywordsState = MutableStateFlow>(emptyList()) val searchedKeywordsState: StateFlow> @@ -140,5 +119,46 @@ class AllSearchViewModel @Inject constructor( } } + fun searchRestaurantPreviewWithKeyword() { + viewModelScope.launch { + val location = locationManager.getCurrentLocation() + + if (location == null) { + _searchedRestaurantPreviewState.value = emptyList() + } else { + + val userLoc = Location(location.longitude.toString(), location.latitude.toString()) + + _searchedRestaurantPreviewState.value = + getRestaurantBySearchWithLimitCountUseCase(searchKeyword.value, userLoc, 3) + } + + } + } + + fun searchRestaurantWithKeyword() { + viewModelScope.launch { + val location = locationManager.getCurrentLocation() + + if (location == null) { + _searchedRestaurantState.value = PagingData.empty() + } else { + val userLoc = Location(location.longitude.toString(), location.latitude.toString()) + + getRestaurantBySearchUseCase(searchKeyword.value, userLoc).distinctUntilChanged() + .collect { + _searchedRestaurantState.value = it + } + } + } + } + + fun searchGroupPreviewWithKeyword() { + viewModelScope.launch { + val result = getGroupBySearchWithLimitCountUseCase(searchKeyword.value, 3) + _searchedGroupPreviewState.value = result + } + } + } \ No newline at end of file diff --git a/presentation/src/main/java/org/gdsc/presentation/view/allsearch/SearchCategoryAllFragment.kt b/presentation/src/main/java/org/gdsc/presentation/view/allsearch/SearchCategoryAllFragment.kt index 3c4ee35e..8c2247ec 100644 --- a/presentation/src/main/java/org/gdsc/presentation/view/allsearch/SearchCategoryAllFragment.kt +++ b/presentation/src/main/java/org/gdsc/presentation/view/allsearch/SearchCategoryAllFragment.kt @@ -43,6 +43,9 @@ class SearchCategoryAllFragment( override fun onViewCreated(view: View, savedInstanceState: Bundle?) { super.onViewCreated(view, savedInstanceState) + viewModel.searchRestaurantPreviewWithKeyword() + viewModel.searchGroupPreviewWithKeyword() + binding.restaurantRecyclerView.adapter = searchCategoryRestaurantPreviewAdapter binding.restaurantRecyclerView.layoutManager = LinearLayoutManager(requireContext()) @@ -68,44 +71,12 @@ class SearchCategoryAllFragment( } } - // Todo: Real APi - searchCategoryGroupPreviewAdapter.submitList( - listOf( - GroupInfo( - "https://avatars.githubusercontent.com/u/58663494?v=4", - 1, - "햄버거 먹으러 갈 사람 여기여기 모여라", - "버거 대마왕", - "https://avatars.githubusercontent.com/u/58663494?v=4", - false, - (0 .. 500).shuffled().first(), - false, - (0 .. 500).shuffled().first() - ), - GroupInfo( - "https://avatars.githubusercontent.com/u/58663494?v=4", - 2, - "햄버거 먹으러 갈 사람 여기여기 모여라", - "버거 대마왕", - "https://avatars.githubusercontent.com/u/58663494?v=4", - false, - (0 .. 500).shuffled().first(), - false, - (0 .. 500).shuffled().first() - ), - GroupInfo( - "https://avatars.githubusercontent.com/u/58663494?v=4", - 3, - "햄버거 먹으러 갈 사람 여기여기 모여라", - "버거 대마왕", - "https://avatars.githubusercontent.com/u/58663494?v=4", - false, - (0 .. 500).shuffled().first(), - false, - (0 .. 500).shuffled().first() - ), - ) - ) + repeatWhenUiStarted { + viewModel.searchedGroupPreviewState.collect { + searchCategoryGroupPreviewAdapter.submitList(it) + } + } + } override fun onDestroyView() { diff --git a/presentation/src/main/java/org/gdsc/presentation/view/allsearch/SearchCategoryRestaurantFragment.kt b/presentation/src/main/java/org/gdsc/presentation/view/allsearch/SearchCategoryRestaurantFragment.kt index cd13104f..af2d5526 100644 --- a/presentation/src/main/java/org/gdsc/presentation/view/allsearch/SearchCategoryRestaurantFragment.kt +++ b/presentation/src/main/java/org/gdsc/presentation/view/allsearch/SearchCategoryRestaurantFragment.kt @@ -42,6 +42,7 @@ class SearchCategoryRestaurantFragment( setSpinners() viewModel.setSearchKeyword(searchKeyword) + viewModel.searchRestaurantWithKeyword() binding.restaurantRecyclerView.adapter = searchCategoryRestaurantAdapter binding.restaurantRecyclerView.layoutManager = LinearLayoutManager(requireContext()) @@ -49,6 +50,7 @@ class SearchCategoryRestaurantFragment( } private fun observeState() { + repeatWhenUiStarted { viewModel.searchedRestaurantState.collect { searchCategoryRestaurantAdapter.submitData(it) diff --git a/presentation/src/main/java/org/gdsc/presentation/view/allsearch/adapter/SearchCategoryGroupPreviewAdapter.kt b/presentation/src/main/java/org/gdsc/presentation/view/allsearch/adapter/SearchCategoryGroupPreviewAdapter.kt index 00e6c93e..82423220 100644 --- a/presentation/src/main/java/org/gdsc/presentation/view/allsearch/adapter/SearchCategoryGroupPreviewAdapter.kt +++ b/presentation/src/main/java/org/gdsc/presentation/view/allsearch/adapter/SearchCategoryGroupPreviewAdapter.kt @@ -6,27 +6,27 @@ import androidx.recyclerview.widget.DiffUtil import androidx.recyclerview.widget.ListAdapter import androidx.recyclerview.widget.RecyclerView import com.bumptech.glide.Glide -import org.gdsc.domain.model.GroupInfo +import org.gdsc.domain.model.GroupPreview import org.gdsc.presentation.R import org.gdsc.presentation.databinding.ItemSearchGroupBinding class SearchCategoryGroupPreviewAdapter - : ListAdapter( + : ListAdapter( diffCallback ) { companion object { - val diffCallback = object : DiffUtil.ItemCallback() { + val diffCallback = object : DiffUtil.ItemCallback() { override fun areItemsTheSame( - oldItem: GroupInfo, - newItem: GroupInfo + oldItem: GroupPreview, + newItem: GroupPreview ): Boolean { return oldItem == newItem } override fun areContentsTheSame( - oldItem: GroupInfo, - newItem: GroupInfo + oldItem: GroupPreview, + newItem: GroupPreview ): Boolean { return oldItem == newItem } @@ -36,10 +36,10 @@ class SearchCategoryGroupPreviewAdapter class GroupWithSearchPreviewViewHolder( private val binding: ItemSearchGroupBinding, ): RecyclerView.ViewHolder(binding.root) { - fun bind(item: GroupInfo) { + fun bind(item: GroupPreview) { binding.run { Glide.with(itemView.context) - .load(item.groupProfileImageUrl) + .load("https://picsum.photos/200") .placeholder(R.drawable.base_profile_image) .into(ivGroupImage)