mirror of
https://github.com/etesync/android
synced 2025-01-11 00:01:12 +00:00
Overhaul Etebase collection activity.
This commit is contained in:
parent
be22beb7f9
commit
74b4ef3ee9
@ -18,25 +18,35 @@ import org.jetbrains.anko.uiThread
|
|||||||
|
|
||||||
class CollectionActivity() : BaseActivity() {
|
class CollectionActivity() : BaseActivity() {
|
||||||
private lateinit var account: Account
|
private lateinit var account: Account
|
||||||
private lateinit var colUid: String
|
private val model: AccountViewModel by viewModels()
|
||||||
private val model: AccountCollectionViewModel by viewModels()
|
private val collectionModel: CollectionViewModel by viewModels()
|
||||||
private val itemsModel: ItemsViewModel by viewModels()
|
private val itemsModel: ItemsViewModel by viewModels()
|
||||||
|
|
||||||
override fun onCreate(savedInstanceState: Bundle?) {
|
override fun onCreate(savedInstanceState: Bundle?) {
|
||||||
super.onCreate(savedInstanceState)
|
super.onCreate(savedInstanceState)
|
||||||
|
|
||||||
account = intent.extras!!.getParcelable(EXTRA_ACCOUNT)!!
|
account = intent.extras!!.getParcelable(EXTRA_ACCOUNT)!!
|
||||||
colUid = intent.extras!!.getString(EXTRA_COLLECTION_UID)!!
|
val colUid = intent.extras!!.getString(EXTRA_COLLECTION_UID)
|
||||||
|
val colType = intent.extras!!.getString(EXTRA_COLLECTION_TYPE)
|
||||||
|
|
||||||
setContentView(R.layout.etebase_collection_activity)
|
setContentView(R.layout.etebase_collection_activity)
|
||||||
|
|
||||||
if (savedInstanceState == null) {
|
if (savedInstanceState == null) {
|
||||||
model.loadCollection(this, account, colUid)
|
model.loadAccount(this, account)
|
||||||
model.observe(this) {
|
if (colUid != null) {
|
||||||
itemsModel.loadItems(it)
|
model.observe(this) {
|
||||||
}
|
collectionModel.loadCollection(it, colUid)
|
||||||
supportFragmentManager.commit {
|
collectionModel.observe(this) { cachedCollection ->
|
||||||
replace(R.id.fragment_container, ViewCollectionFragment())
|
itemsModel.loadItems(it, cachedCollection)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
supportFragmentManager.commit {
|
||||||
|
replace(R.id.fragment_container, ViewCollectionFragment())
|
||||||
|
}
|
||||||
|
} else if (colType != null) {
|
||||||
|
supportFragmentManager.commit {
|
||||||
|
// replace(R.id.fragment_container, CreateCollectionFragment(colType))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -46,6 +56,7 @@ class CollectionActivity() : BaseActivity() {
|
|||||||
companion object {
|
companion object {
|
||||||
private val EXTRA_ACCOUNT = "account"
|
private val EXTRA_ACCOUNT = "account"
|
||||||
private val EXTRA_COLLECTION_UID = "collectionUid"
|
private val EXTRA_COLLECTION_UID = "collectionUid"
|
||||||
|
private val EXTRA_COLLECTION_TYPE = "collectionType"
|
||||||
|
|
||||||
fun newIntent(context: Context, account: Account, colUid: String): Intent {
|
fun newIntent(context: Context, account: Account, colUid: String): Intent {
|
||||||
val intent = Intent(context, CollectionActivity::class.java)
|
val intent = Intent(context, CollectionActivity::class.java)
|
||||||
@ -53,48 +64,74 @@ class CollectionActivity() : BaseActivity() {
|
|||||||
intent.putExtra(EXTRA_COLLECTION_UID, colUid)
|
intent.putExtra(EXTRA_COLLECTION_UID, colUid)
|
||||||
return intent
|
return intent
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fun newCreateCollectionIntent(context: Context, account: Account, colType: String): Intent {
|
||||||
|
val intent = Intent(context, CollectionActivity::class.java)
|
||||||
|
intent.putExtra(EXTRA_ACCOUNT, account)
|
||||||
|
intent.putExtra(EXTRA_COLLECTION_TYPE, colType)
|
||||||
|
return intent
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class AccountCollectionViewModel : ViewModel() {
|
class AccountViewModel : ViewModel() {
|
||||||
private val collection = MutableLiveData<AccountCollectionHolder>()
|
private val holder = MutableLiveData<AccountHolder>()
|
||||||
|
|
||||||
fun loadCollection(context: Context, account: Account, colUid: String) {
|
fun loadAccount(context: Context, account: Account) {
|
||||||
doAsync {
|
doAsync {
|
||||||
val settings = AccountSettings(context, account)
|
val settings = AccountSettings(context, account)
|
||||||
val etebaseLocalCache = EtebaseLocalCache.getInstance(context, account.name)
|
val etebaseLocalCache = EtebaseLocalCache.getInstance(context, account.name)
|
||||||
val etebase = EtebaseLocalCache.getEtebase(context, HttpClient.sharedClient, settings)
|
val etebase = EtebaseLocalCache.getEtebase(context, HttpClient.sharedClient, settings)
|
||||||
val colMgr = etebase.collectionManager
|
val colMgr = etebase.collectionManager
|
||||||
val cachedCollection = synchronized(etebaseLocalCache) {
|
|
||||||
etebaseLocalCache.collectionGet(colMgr, colUid)!!
|
|
||||||
}
|
|
||||||
uiThread {
|
uiThread {
|
||||||
collection.value = AccountCollectionHolder(
|
holder.value = AccountHolder(
|
||||||
account,
|
account,
|
||||||
etebaseLocalCache,
|
etebaseLocalCache,
|
||||||
etebase,
|
etebase,
|
||||||
colMgr,
|
colMgr
|
||||||
cachedCollection
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fun observe(owner: LifecycleOwner, observer: (AccountCollectionHolder) -> Unit) =
|
fun observe(owner: LifecycleOwner, observer: (AccountHolder) -> Unit) =
|
||||||
collection.observe(owner, observer)
|
holder.observe(owner, observer)
|
||||||
|
|
||||||
val value: AccountCollectionHolder?
|
val value: AccountHolder?
|
||||||
get() = collection.value
|
get() = holder.value
|
||||||
}
|
}
|
||||||
|
|
||||||
data class AccountCollectionHolder(val account: Account, val etebaseLocalCache: EtebaseLocalCache, val etebase: com.etebase.client.Account, val colMgr: CollectionManager, val cachedCollection: CachedCollection)
|
data class AccountHolder(val account: Account, val etebaseLocalCache: EtebaseLocalCache, val etebase: com.etebase.client.Account, val colMgr: CollectionManager)
|
||||||
|
|
||||||
|
class CollectionViewModel : ViewModel() {
|
||||||
|
private val collection = MutableLiveData<CachedCollection>()
|
||||||
|
|
||||||
|
fun loadCollection(accountHolder: AccountHolder, colUid: String) {
|
||||||
|
doAsync {
|
||||||
|
val etebaseLocalCache = accountHolder.etebaseLocalCache
|
||||||
|
val colMgr = accountHolder.colMgr
|
||||||
|
val cachedCollection = synchronized(etebaseLocalCache) {
|
||||||
|
etebaseLocalCache.collectionGet(colMgr, colUid)!!
|
||||||
|
}
|
||||||
|
uiThread {
|
||||||
|
collection.value = cachedCollection
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fun observe(owner: LifecycleOwner, observer: (CachedCollection) -> Unit) =
|
||||||
|
collection.observe(owner, observer)
|
||||||
|
|
||||||
|
val value: CachedCollection?
|
||||||
|
get() = collection.value
|
||||||
|
}
|
||||||
|
|
||||||
class ItemsViewModel : ViewModel() {
|
class ItemsViewModel : ViewModel() {
|
||||||
private val cachedItems = MutableLiveData<List<CachedItem>>()
|
private val cachedItems = MutableLiveData<List<CachedItem>>()
|
||||||
|
|
||||||
fun loadItems(accountCollectionHolder: AccountCollectionHolder) {
|
fun loadItems(accountCollectionHolder: AccountHolder, cachedCollection: CachedCollection) {
|
||||||
doAsync {
|
doAsync {
|
||||||
val col = accountCollectionHolder.cachedCollection.col
|
val col = cachedCollection.col
|
||||||
val itemMgr = accountCollectionHolder.colMgr.getItemManager(col)
|
val itemMgr = accountCollectionHolder.colMgr.getItemManager(col)
|
||||||
val items = accountCollectionHolder.etebaseLocalCache.itemList(itemMgr, col.uid, withDeleted = true)
|
val items = accountCollectionHolder.etebaseLocalCache.itemList(itemMgr, col.uid, withDeleted = true)
|
||||||
uiThread {
|
uiThread {
|
||||||
|
@ -12,6 +12,7 @@ import androidx.fragment.app.activityViewModels
|
|||||||
import androidx.fragment.app.viewModels
|
import androidx.fragment.app.viewModels
|
||||||
import com.etebase.client.Collection
|
import com.etebase.client.Collection
|
||||||
import com.etebase.client.exceptions.EtebaseException
|
import com.etebase.client.exceptions.EtebaseException
|
||||||
|
import com.etesync.syncadapter.CachedCollection
|
||||||
import com.etesync.syncadapter.Constants
|
import com.etesync.syncadapter.Constants
|
||||||
import com.etesync.syncadapter.R
|
import com.etesync.syncadapter.R
|
||||||
import com.etesync.syncadapter.resource.LocalCalendar
|
import com.etesync.syncadapter.resource.LocalCalendar
|
||||||
@ -20,10 +21,10 @@ import org.apache.commons.lang3.StringUtils
|
|||||||
import org.jetbrains.anko.doAsync
|
import org.jetbrains.anko.doAsync
|
||||||
import org.jetbrains.anko.uiThread
|
import org.jetbrains.anko.uiThread
|
||||||
import yuku.ambilwarna.AmbilWarnaDialog
|
import yuku.ambilwarna.AmbilWarnaDialog
|
||||||
import java.lang.String
|
|
||||||
|
|
||||||
class EditCollectionFragment() : Fragment() {
|
class EditCollectionFragment(private val cachedCollection: CachedCollection) : Fragment() {
|
||||||
private val model: AccountCollectionViewModel by activityViewModels()
|
private val model: AccountViewModel by activityViewModels()
|
||||||
|
private val collectionModel: CollectionViewModel by activityViewModels()
|
||||||
private val loadingModel: LoadingViewModel by viewModels()
|
private val loadingModel: LoadingViewModel by viewModels()
|
||||||
|
|
||||||
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
|
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
|
||||||
@ -31,51 +32,30 @@ class EditCollectionFragment() : Fragment() {
|
|||||||
setHasOptionsMenu(true)
|
setHasOptionsMenu(true)
|
||||||
|
|
||||||
if (savedInstanceState == null) {
|
if (savedInstanceState == null) {
|
||||||
model.observe(this) {
|
updateTitle()
|
||||||
updateTitle(it)
|
if (container != null) {
|
||||||
if (container != null) {
|
initUi(inflater, ret)
|
||||||
initUi(inflater, ret, it)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret
|
return ret
|
||||||
}
|
}
|
||||||
|
|
||||||
fun updateTitle(accountCollectionHolder: AccountCollectionHolder) {
|
fun updateTitle() {
|
||||||
accountCollectionHolder.let {
|
(activity as? BaseActivity?)?.supportActionBar?.setTitle(R.string.edit_collection)
|
||||||
val new = false
|
|
||||||
var titleId: Int = R.string.create_calendar
|
|
||||||
if (new) {
|
|
||||||
when (it.cachedCollection.meta.collectionType) {
|
|
||||||
Constants.ETEBASE_TYPE_CALENDAR -> {
|
|
||||||
titleId = R.string.create_calendar
|
|
||||||
}
|
|
||||||
Constants.ETEBASE_TYPE_TASKS -> {
|
|
||||||
titleId = R.string.create_tasklist
|
|
||||||
}
|
|
||||||
Constants.ETEBASE_TYPE_ADDRESS_BOOK -> {
|
|
||||||
titleId = R.string.create_addressbook
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
titleId = R.string.edit_collection
|
|
||||||
}
|
|
||||||
(activity as? BaseActivity?)?.supportActionBar?.setTitle(titleId)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun initUi(inflater: LayoutInflater, v: View, collectionHolder: AccountCollectionHolder) {
|
private fun initUi(inflater: LayoutInflater, v: View) {
|
||||||
val title = v.findViewById<EditText>(R.id.display_name)
|
val title = v.findViewById<EditText>(R.id.display_name)
|
||||||
val desc = v.findViewById<EditText>(R.id.description)
|
val desc = v.findViewById<EditText>(R.id.description)
|
||||||
|
|
||||||
val meta = collectionHolder.cachedCollection.meta
|
val meta = cachedCollection.meta
|
||||||
|
|
||||||
title.setText(meta.name)
|
title.setText(meta.name)
|
||||||
desc.setText(meta.description)
|
desc.setText(meta.description)
|
||||||
|
|
||||||
val colorSquare = v.findViewById<View>(R.id.color)
|
val colorSquare = v.findViewById<View>(R.id.color)
|
||||||
when (collectionHolder.cachedCollection.meta.collectionType) {
|
when (cachedCollection.meta.collectionType) {
|
||||||
Constants.ETEBASE_TYPE_CALENDAR -> {
|
Constants.ETEBASE_TYPE_CALENDAR -> {
|
||||||
title.setHint(R.string.create_calendar_display_name_hint)
|
title.setHint(R.string.create_calendar_display_name_hint)
|
||||||
|
|
||||||
@ -133,7 +113,7 @@ class EditCollectionFragment() : Fragment() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private fun deleteColection() {
|
private fun deleteColection() {
|
||||||
val meta = model.value!!.cachedCollection.meta
|
val meta = cachedCollection.meta
|
||||||
val name = meta.name
|
val name = meta.name
|
||||||
|
|
||||||
AlertDialog.Builder(requireContext())
|
AlertDialog.Builder(requireContext())
|
||||||
@ -151,7 +131,7 @@ class EditCollectionFragment() : Fragment() {
|
|||||||
loadingModel.setLoading(true)
|
loadingModel.setLoading(true)
|
||||||
doAsync {
|
doAsync {
|
||||||
try {
|
try {
|
||||||
val col = model.value!!.cachedCollection.col
|
val col = cachedCollection.col
|
||||||
col.delete()
|
col.delete()
|
||||||
uploadCollection(col)
|
uploadCollection(col)
|
||||||
activity?.finish()
|
activity?.finish()
|
||||||
@ -174,7 +154,7 @@ class EditCollectionFragment() : Fragment() {
|
|||||||
private fun saveCollection() {
|
private fun saveCollection() {
|
||||||
var ok = true
|
var ok = true
|
||||||
|
|
||||||
val meta = model.value!!.cachedCollection.meta
|
val meta = cachedCollection.meta
|
||||||
val v = requireView()
|
val v = requireView()
|
||||||
|
|
||||||
var edit = v.findViewById<EditText>(R.id.display_name)
|
var edit = v.findViewById<EditText>(R.id.display_name)
|
||||||
@ -201,7 +181,7 @@ class EditCollectionFragment() : Fragment() {
|
|||||||
loadingModel.setLoading(true)
|
loadingModel.setLoading(true)
|
||||||
doAsync {
|
doAsync {
|
||||||
try {
|
try {
|
||||||
val col = model.value!!.cachedCollection.col
|
val col = cachedCollection.col
|
||||||
col.meta = meta
|
col.meta = meta
|
||||||
uploadCollection(col)
|
uploadCollection(col)
|
||||||
parentFragmentManager.popBackStack()
|
parentFragmentManager.popBackStack()
|
||||||
@ -230,6 +210,6 @@ class EditCollectionFragment() : Fragment() {
|
|||||||
synchronized(etebaseLocalCache) {
|
synchronized(etebaseLocalCache) {
|
||||||
etebaseLocalCache.collectionSet(colMgr, col)
|
etebaseLocalCache.collectionSet(colMgr, col)
|
||||||
}
|
}
|
||||||
model.loadCollection(requireContext(), accountHolder.account, col.uid)
|
collectionModel.loadCollection(model.value!!, col.uid)
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -16,7 +16,7 @@ import java.text.SimpleDateFormat
|
|||||||
import java.util.concurrent.Future
|
import java.util.concurrent.Future
|
||||||
|
|
||||||
class ListEntriesFragment : ListFragment(), AdapterView.OnItemClickListener {
|
class ListEntriesFragment : ListFragment(), AdapterView.OnItemClickListener {
|
||||||
private val model: AccountCollectionViewModel by activityViewModels()
|
private val collectionModel: CollectionViewModel by activityViewModels()
|
||||||
private val itemsModel: ItemsViewModel by activityViewModels()
|
private val itemsModel: ItemsViewModel by activityViewModels()
|
||||||
private var asyncTask: Future<Unit>? = null
|
private var asyncTask: Future<Unit>? = null
|
||||||
|
|
||||||
@ -35,12 +35,12 @@ class ListEntriesFragment : ListFragment(), AdapterView.OnItemClickListener {
|
|||||||
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
||||||
super.onViewCreated(view, savedInstanceState)
|
super.onViewCreated(view, savedInstanceState)
|
||||||
|
|
||||||
model.observe(this) { col ->
|
collectionModel.observe(this) { col ->
|
||||||
itemsModel.observe(this) {
|
itemsModel.observe(this) {
|
||||||
val entries = it.sortedByDescending { item ->
|
val entries = it.sortedByDescending { item ->
|
||||||
item.meta.mtime ?: 0
|
item.meta.mtime ?: 0
|
||||||
}
|
}
|
||||||
val listAdapter = EntriesListAdapter(requireContext(), col.cachedCollection)
|
val listAdapter = EntriesListAdapter(requireContext(), col)
|
||||||
setListAdapter(listAdapter)
|
setListAdapter(listAdapter)
|
||||||
|
|
||||||
listAdapter.addAll(entries)
|
listAdapter.addAll(entries)
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
package com.etesync.syncadapter.ui.etebase
|
package com.etesync.syncadapter.ui.etebase
|
||||||
|
|
||||||
import android.content.Context
|
|
||||||
import android.content.DialogInterface
|
import android.content.DialogInterface
|
||||||
import android.graphics.Color.parseColor
|
import android.graphics.Color.parseColor
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
@ -11,6 +10,7 @@ import androidx.appcompat.app.AlertDialog
|
|||||||
import androidx.fragment.app.Fragment
|
import androidx.fragment.app.Fragment
|
||||||
import androidx.fragment.app.activityViewModels
|
import androidx.fragment.app.activityViewModels
|
||||||
import androidx.fragment.app.commit
|
import androidx.fragment.app.commit
|
||||||
|
import com.etesync.syncadapter.CachedCollection
|
||||||
import com.etesync.syncadapter.Constants
|
import com.etesync.syncadapter.Constants
|
||||||
import com.etesync.syncadapter.R
|
import com.etesync.syncadapter.R
|
||||||
import com.etesync.syncadapter.resource.LocalCalendar
|
import com.etesync.syncadapter.resource.LocalCalendar
|
||||||
@ -23,7 +23,7 @@ import tourguide.tourguide.ToolTip
|
|||||||
import java.util.*
|
import java.util.*
|
||||||
|
|
||||||
class ViewCollectionFragment : Fragment() {
|
class ViewCollectionFragment : Fragment() {
|
||||||
private val model: AccountCollectionViewModel by activityViewModels()
|
private val collectionModel: CollectionViewModel by activityViewModels()
|
||||||
private val itemsModel: ItemsViewModel by activityViewModels()
|
private val itemsModel: ItemsViewModel by activityViewModels()
|
||||||
|
|
||||||
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
|
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
|
||||||
@ -31,8 +31,8 @@ class ViewCollectionFragment : Fragment() {
|
|||||||
setHasOptionsMenu(true)
|
setHasOptionsMenu(true)
|
||||||
|
|
||||||
if (savedInstanceState == null) {
|
if (savedInstanceState == null) {
|
||||||
model.observe(this) {
|
collectionModel.observe(this) {
|
||||||
(activity as? BaseActivity?)?.supportActionBar?.title = it.cachedCollection.meta.name
|
(activity as? BaseActivity?)?.supportActionBar?.title = it.meta.name
|
||||||
if (container != null) {
|
if (container != null) {
|
||||||
initUi(inflater, ret, it)
|
initUi(inflater, ret, it)
|
||||||
}
|
}
|
||||||
@ -42,7 +42,7 @@ class ViewCollectionFragment : Fragment() {
|
|||||||
return ret
|
return ret
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun initUi(inflater: LayoutInflater, container: View, collectionHolder: AccountCollectionHolder) {
|
private fun initUi(inflater: LayoutInflater, container: View, cachedCollection: CachedCollection) {
|
||||||
val title = container.findViewById<TextView>(R.id.display_name)
|
val title = container.findViewById<TextView>(R.id.display_name)
|
||||||
if (!HintManager.getHintSeen(requireContext(), HINT_IMPORT)) {
|
if (!HintManager.getHintSeen(requireContext(), HINT_IMPORT)) {
|
||||||
val tourGuide = ShowcaseBuilder.getBuilder(requireActivity())
|
val tourGuide = ShowcaseBuilder.getBuilder(requireActivity())
|
||||||
@ -63,8 +63,8 @@ class ViewCollectionFragment : Fragment() {
|
|||||||
.setPositiveButton(android.R.string.yes) { _, _ -> }.show()
|
.setPositiveButton(android.R.string.yes) { _, _ -> }.show()
|
||||||
}
|
}
|
||||||
|
|
||||||
val col = collectionHolder.cachedCollection.col
|
val col = cachedCollection.col
|
||||||
val meta = collectionHolder.cachedCollection.meta
|
val meta = cachedCollection.meta
|
||||||
val isAdmin = col.accessLevel == "adm"
|
val isAdmin = col.accessLevel == "adm"
|
||||||
|
|
||||||
val colorSquare = container.findViewById<View>(R.id.color)
|
val colorSquare = container.findViewById<View>(R.id.color)
|
||||||
@ -112,7 +112,7 @@ class ViewCollectionFragment : Fragment() {
|
|||||||
when (item.itemId) {
|
when (item.itemId) {
|
||||||
R.id.on_edit -> {
|
R.id.on_edit -> {
|
||||||
parentFragmentManager.commit {
|
parentFragmentManager.commit {
|
||||||
replace(R.id.fragment_container, EditCollectionFragment())
|
replace(R.id.fragment_container, EditCollectionFragment(collectionModel.value!!))
|
||||||
addToBackStack(EditCollectionFragment::class.java.name)
|
addToBackStack(EditCollectionFragment::class.java.name)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user