|
|
@ -8,13 +8,13 @@ import android.view.View |
|
|
|
import android.view.ViewGroup |
|
|
|
import android.view.ViewGroup |
|
|
|
import androidx.appcompat.widget.SearchView |
|
|
|
import androidx.appcompat.widget.SearchView |
|
|
|
import androidx.appcompat.widget.Toolbar |
|
|
|
import androidx.appcompat.widget.Toolbar |
|
|
|
import androidx.fragment.app.DialogFragment |
|
|
|
|
|
|
|
import androidx.fragment.app.FragmentManager |
|
|
|
import androidx.fragment.app.FragmentManager |
|
|
|
import androidx.lifecycle.Observer |
|
|
|
import androidx.lifecycle.Observer |
|
|
|
import androidx.recyclerview.widget.DiffUtil |
|
|
|
import androidx.recyclerview.widget.DiffUtil |
|
|
|
import androidx.recyclerview.widget.LinearLayoutManager |
|
|
|
import androidx.recyclerview.widget.LinearLayoutManager |
|
|
|
import androidx.recyclerview.widget.RecyclerView |
|
|
|
import androidx.recyclerview.widget.RecyclerView |
|
|
|
import io.legado.app.R |
|
|
|
import io.legado.app.R |
|
|
|
|
|
|
|
import io.legado.app.base.BaseDialogFragment |
|
|
|
import io.legado.app.constant.PreferKey |
|
|
|
import io.legado.app.constant.PreferKey |
|
|
|
import io.legado.app.constant.Theme |
|
|
|
import io.legado.app.constant.Theme |
|
|
|
import io.legado.app.data.entities.Book |
|
|
|
import io.legado.app.data.entities.Book |
|
|
@ -27,7 +27,7 @@ import io.legado.app.utils.putPrefBoolean |
|
|
|
import kotlinx.android.synthetic.main.dialog_change_source.* |
|
|
|
import kotlinx.android.synthetic.main.dialog_change_source.* |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ChangeSourceDialog : DialogFragment(), |
|
|
|
class ChangeSourceDialog : BaseDialogFragment(), |
|
|
|
Toolbar.OnMenuItemClickListener, |
|
|
|
Toolbar.OnMenuItemClickListener, |
|
|
|
ChangeSourceAdapter.CallBack { |
|
|
|
ChangeSourceAdapter.CallBack { |
|
|
|
|
|
|
|
|
|
|
@ -67,8 +67,7 @@ class ChangeSourceDialog : DialogFragment(), |
|
|
|
return inflater.inflate(R.layout.dialog_change_source, container) |
|
|
|
return inflater.inflate(R.layout.dialog_change_source, container) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
override fun onViewCreated(view: View, savedInstanceState: Bundle?) { |
|
|
|
override fun onFragmentCreated(view: View, savedInstanceState: Bundle?) { |
|
|
|
super.onViewCreated(view, savedInstanceState) |
|
|
|
|
|
|
|
viewModel.initData(arguments) |
|
|
|
viewModel.initData(arguments) |
|
|
|
showTitle() |
|
|
|
showTitle() |
|
|
|
initMenu() |
|
|
|
initMenu() |
|
|
@ -76,7 +75,6 @@ class ChangeSourceDialog : DialogFragment(), |
|
|
|
initSearchView() |
|
|
|
initSearchView() |
|
|
|
initLiveData() |
|
|
|
initLiveData() |
|
|
|
viewModel.loadDbSearchBook() |
|
|
|
viewModel.loadDbSearchBook() |
|
|
|
viewModel.search() |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private fun showTitle() { |
|
|
|
private fun showTitle() { |
|
|
@ -138,6 +136,12 @@ class ChangeSourceDialog : DialogFragment(), |
|
|
|
private fun initLiveData() { |
|
|
|
private fun initLiveData() { |
|
|
|
viewModel.searchStateData.observe(viewLifecycleOwner, Observer { |
|
|
|
viewModel.searchStateData.observe(viewLifecycleOwner, Observer { |
|
|
|
refresh_progress_bar.isAutoLoading = it |
|
|
|
refresh_progress_bar.isAutoLoading = it |
|
|
|
|
|
|
|
if (it) { |
|
|
|
|
|
|
|
stopMenuItem?.setIcon(R.drawable.ic_stop_black_24dp) |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
stopMenuItem?.setIcon(R.drawable.ic_refresh_black_24dp) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
tool_bar.menu.applyTint(requireContext(), Theme.getTheme()) |
|
|
|
}) |
|
|
|
}) |
|
|
|
viewModel.searchBooksLiveData.observe(viewLifecycleOwner, Observer { |
|
|
|
viewModel.searchBooksLiveData.observe(viewLifecycleOwner, Observer { |
|
|
|
val diffResult = DiffUtil.calculateDiff(DiffCallBack(adapter.getItems(), it)) |
|
|
|
val diffResult = DiffUtil.calculateDiff(DiffCallBack(adapter.getItems(), it)) |
|
|
@ -146,6 +150,9 @@ class ChangeSourceDialog : DialogFragment(), |
|
|
|
}) |
|
|
|
}) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private val stopMenuItem: MenuItem? |
|
|
|
|
|
|
|
get() = tool_bar.menu.findItem(R.id.menu_stop) |
|
|
|
|
|
|
|
|
|
|
|
override fun onMenuItemClick(item: MenuItem?): Boolean { |
|
|
|
override fun onMenuItemClick(item: MenuItem?): Boolean { |
|
|
|
when (item?.itemId) { |
|
|
|
when (item?.itemId) { |
|
|
|
R.id.menu_load_toc -> { |
|
|
|
R.id.menu_load_toc -> { |
|
|
|