clean up code
This commit is contained in:
parent
84a3280964
commit
7107018ae2
3 changed files with 44 additions and 59 deletions
|
@ -4,15 +4,12 @@ import android.content.Context
|
||||||
import android.content.Intent
|
import android.content.Intent
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.view.MenuItem
|
import android.view.MenuItem
|
||||||
import androidx.lifecycle.Lifecycle
|
|
||||||
import androidx.lifecycle.Observer
|
import androidx.lifecycle.Observer
|
||||||
import androidx.lifecycle.ViewModelProvider
|
import androidx.lifecycle.ViewModelProvider
|
||||||
import androidx.recyclerview.widget.DividerItemDecoration
|
import androidx.recyclerview.widget.DividerItemDecoration
|
||||||
import androidx.recyclerview.widget.LinearLayoutManager
|
import androidx.recyclerview.widget.LinearLayoutManager
|
||||||
import com.keylesspalace.tusky.BaseActivity
|
import com.keylesspalace.tusky.BaseActivity
|
||||||
import com.keylesspalace.tusky.R
|
import com.keylesspalace.tusky.R
|
||||||
import com.keylesspalace.tusky.appstore.EventHub
|
|
||||||
import com.keylesspalace.tusky.appstore.StatusScheduledEvent
|
|
||||||
import com.keylesspalace.tusky.components.compose.ComposeActivity
|
import com.keylesspalace.tusky.components.compose.ComposeActivity
|
||||||
import com.keylesspalace.tusky.di.Injectable
|
import com.keylesspalace.tusky.di.Injectable
|
||||||
import com.keylesspalace.tusky.di.ViewModelFactory
|
import com.keylesspalace.tusky.di.ViewModelFactory
|
||||||
|
@ -20,31 +17,19 @@ import com.keylesspalace.tusky.entity.ScheduledStatus
|
||||||
import com.keylesspalace.tusky.util.Status
|
import com.keylesspalace.tusky.util.Status
|
||||||
import com.keylesspalace.tusky.util.hide
|
import com.keylesspalace.tusky.util.hide
|
||||||
import com.keylesspalace.tusky.util.show
|
import com.keylesspalace.tusky.util.show
|
||||||
import com.uber.autodispose.AutoDispose.autoDisposable
|
|
||||||
import com.uber.autodispose.android.lifecycle.AndroidLifecycleScopeProvider.from
|
|
||||||
import io.reactivex.android.schedulers.AndroidSchedulers
|
|
||||||
import kotlinx.android.synthetic.main.activity_scheduled_toot.*
|
import kotlinx.android.synthetic.main.activity_scheduled_toot.*
|
||||||
import kotlinx.android.synthetic.main.toolbar_basic.*
|
import kotlinx.android.synthetic.main.toolbar_basic.*
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class ScheduledTootActivity : BaseActivity(), ScheduledTootAction, Injectable {
|
class ScheduledTootActivity : BaseActivity(), ScheduledTootAction, Injectable {
|
||||||
|
|
||||||
companion object {
|
|
||||||
@JvmStatic
|
|
||||||
fun newIntent(context: Context): Intent {
|
|
||||||
return Intent(context, ScheduledTootActivity::class.java)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
lateinit var adapter: ScheduledTootAdapter
|
|
||||||
|
|
||||||
@Inject
|
|
||||||
lateinit var eventHub: EventHub
|
|
||||||
@Inject
|
@Inject
|
||||||
lateinit var viewModelFactory: ViewModelFactory
|
lateinit var viewModelFactory: ViewModelFactory
|
||||||
|
|
||||||
lateinit var viewModel: ScheduledTootViewModel
|
lateinit var viewModel: ScheduledTootViewModel
|
||||||
|
|
||||||
|
private val adapter = ScheduledTootAdapter(this)
|
||||||
|
|
||||||
override fun onCreate(savedInstanceState: Bundle?) {
|
override fun onCreate(savedInstanceState: Bundle?) {
|
||||||
super.onCreate(savedInstanceState)
|
super.onCreate(savedInstanceState)
|
||||||
setContentView(R.layout.activity_scheduled_toot)
|
setContentView(R.layout.activity_scheduled_toot)
|
||||||
|
@ -59,38 +44,13 @@ class ScheduledTootActivity : BaseActivity(), ScheduledTootAction, Injectable {
|
||||||
swipeRefreshLayout.setOnRefreshListener(this::refreshStatuses)
|
swipeRefreshLayout.setOnRefreshListener(this::refreshStatuses)
|
||||||
|
|
||||||
scheduledTootList.setHasFixedSize(true)
|
scheduledTootList.setHasFixedSize(true)
|
||||||
val layoutManager = LinearLayoutManager(this)
|
scheduledTootList.layoutManager = LinearLayoutManager(this)
|
||||||
scheduledTootList.layoutManager = layoutManager
|
val divider = DividerItemDecoration(this, DividerItemDecoration.VERTICAL)
|
||||||
val divider = DividerItemDecoration(this, layoutManager.orientation)
|
|
||||||
scheduledTootList.addItemDecoration(divider)
|
scheduledTootList.addItemDecoration(divider)
|
||||||
adapter = ScheduledTootAdapter(this)
|
|
||||||
scheduledTootList.adapter = adapter
|
scheduledTootList.adapter = adapter
|
||||||
|
|
||||||
viewModel = ViewModelProvider(this, viewModelFactory)[ScheduledTootViewModel::class.java]
|
viewModel = ViewModelProvider(this, viewModelFactory)[ScheduledTootViewModel::class.java]
|
||||||
|
|
||||||
loadStatuses()
|
|
||||||
|
|
||||||
eventHub.events
|
|
||||||
.observeOn(AndroidSchedulers.mainThread())
|
|
||||||
.`as`(autoDisposable(from(this, Lifecycle.Event.ON_DESTROY)))
|
|
||||||
.subscribe { event ->
|
|
||||||
if (event is StatusScheduledEvent) {
|
|
||||||
refreshStatuses()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun onOptionsItemSelected(item: MenuItem): Boolean {
|
|
||||||
when (item.itemId) {
|
|
||||||
android.R.id.home -> {
|
|
||||||
onBackPressed()
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return super.onOptionsItemSelected(item)
|
|
||||||
}
|
|
||||||
|
|
||||||
fun loadStatuses() {
|
|
||||||
viewModel.data.observe(this, Observer {
|
viewModel.data.observe(this, Observer {
|
||||||
adapter.submitList(it)
|
adapter.submitList(it)
|
||||||
})
|
})
|
||||||
|
@ -123,16 +83,24 @@ class ScheduledTootActivity : BaseActivity(), ScheduledTootAction, Injectable {
|
||||||
}
|
}
|
||||||
|
|
||||||
})
|
})
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onOptionsItemSelected(item: MenuItem): Boolean {
|
||||||
|
when (item.itemId) {
|
||||||
|
android.R.id.home -> {
|
||||||
|
onBackPressed()
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return super.onOptionsItemSelected(item)
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun refreshStatuses() {
|
private fun refreshStatuses() {
|
||||||
viewModel.reload()
|
viewModel.reload()
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun edit(position: Int, item: ScheduledStatus?) {
|
override fun edit(item: ScheduledStatus) {
|
||||||
if (item == null) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
val intent = ComposeActivity.startIntent(this, ComposeActivity.ComposeOptions(
|
val intent = ComposeActivity.startIntent(this, ComposeActivity.ComposeOptions(
|
||||||
tootText = item.params.text,
|
tootText = item.params.text,
|
||||||
contentWarning = item.params.spoilerText,
|
contentWarning = item.params.spoilerText,
|
||||||
|
@ -143,14 +111,16 @@ class ScheduledTootActivity : BaseActivity(), ScheduledTootAction, Injectable {
|
||||||
sensitive = item.params.sensitive
|
sensitive = item.params.sensitive
|
||||||
))
|
))
|
||||||
startActivity(intent)
|
startActivity(intent)
|
||||||
delete(position, item)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun delete(position: Int, item: ScheduledStatus?) {
|
|
||||||
if (item == null) {
|
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
override fun delete(item: ScheduledStatus) {
|
||||||
viewModel.deleteScheduledStatus(item)
|
viewModel.deleteScheduledStatus(item)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
@JvmStatic
|
||||||
|
fun newIntent(context: Context): Intent {
|
||||||
|
return Intent(context, ScheduledTootActivity::class.java)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,8 +27,8 @@ import com.keylesspalace.tusky.R
|
||||||
import com.keylesspalace.tusky.entity.ScheduledStatus
|
import com.keylesspalace.tusky.entity.ScheduledStatus
|
||||||
|
|
||||||
interface ScheduledTootAction {
|
interface ScheduledTootAction {
|
||||||
fun edit(position: Int, item: ScheduledStatus?)
|
fun edit(item: ScheduledStatus)
|
||||||
fun delete(position: Int, item: ScheduledStatus?)
|
fun delete(item: ScheduledStatus)
|
||||||
}
|
}
|
||||||
|
|
||||||
class ScheduledTootAdapter(
|
class ScheduledTootAdapter(
|
||||||
|
@ -71,11 +71,11 @@ class ScheduledTootAdapter(
|
||||||
text.text = item.params.text
|
text.text = item.params.text
|
||||||
edit.setOnClickListener { v: View ->
|
edit.setOnClickListener { v: View ->
|
||||||
v.isEnabled = false
|
v.isEnabled = false
|
||||||
listener.edit(adapterPosition, item)
|
listener.edit(item)
|
||||||
}
|
}
|
||||||
delete.setOnClickListener { v: View ->
|
delete.setOnClickListener { v: View ->
|
||||||
v.isEnabled = false
|
v.isEnabled = false
|
||||||
listener.delete(adapterPosition, item)
|
listener.delete(item)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,14 +4,18 @@ import android.util.Log
|
||||||
import androidx.lifecycle.ViewModel
|
import androidx.lifecycle.ViewModel
|
||||||
import androidx.paging.Config
|
import androidx.paging.Config
|
||||||
import androidx.paging.toLiveData
|
import androidx.paging.toLiveData
|
||||||
|
import com.keylesspalace.tusky.appstore.EventHub
|
||||||
|
import com.keylesspalace.tusky.appstore.StatusScheduledEvent
|
||||||
import com.keylesspalace.tusky.entity.ScheduledStatus
|
import com.keylesspalace.tusky.entity.ScheduledStatus
|
||||||
import com.keylesspalace.tusky.network.MastodonApi
|
import com.keylesspalace.tusky.network.MastodonApi
|
||||||
|
import io.reactivex.android.schedulers.AndroidSchedulers
|
||||||
import io.reactivex.disposables.CompositeDisposable
|
import io.reactivex.disposables.CompositeDisposable
|
||||||
import io.reactivex.rxkotlin.addTo
|
import io.reactivex.rxkotlin.addTo
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
class ScheduledTootViewModel @Inject constructor(
|
class ScheduledTootViewModel @Inject constructor(
|
||||||
val mastodonApi: MastodonApi
|
val mastodonApi: MastodonApi,
|
||||||
|
val eventHub: EventHub
|
||||||
): ViewModel() {
|
): ViewModel() {
|
||||||
|
|
||||||
private val disposables = CompositeDisposable()
|
private val disposables = CompositeDisposable()
|
||||||
|
@ -24,6 +28,17 @@ class ScheduledTootViewModel @Inject constructor(
|
||||||
|
|
||||||
val networkState = dataSourceFactory.networkState
|
val networkState = dataSourceFactory.networkState
|
||||||
|
|
||||||
|
init {
|
||||||
|
eventHub.events
|
||||||
|
.observeOn(AndroidSchedulers.mainThread())
|
||||||
|
.subscribe { event ->
|
||||||
|
if (event is StatusScheduledEvent) {
|
||||||
|
reload()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.addTo(disposables)
|
||||||
|
}
|
||||||
|
|
||||||
fun reload() {
|
fun reload() {
|
||||||
dataSourceFactory.reload()
|
dataSourceFactory.reload()
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue