Refactor code to configure the message list action mode menu
This commit is contained in:
parent
d22bb731f6
commit
a44aedb4a8
1 changed files with 36 additions and 35 deletions
|
@ -1364,16 +1364,22 @@ class MessageListFragment :
|
||||||
}
|
}
|
||||||
|
|
||||||
val isOutbox: Boolean
|
val isOutbox: Boolean
|
||||||
get() {
|
get() = isSpecialFolder(account?.outboxFolderId)
|
||||||
val currentFolder = currentFolder ?: return false
|
|
||||||
return currentFolder.databaseId == account!!.outboxFolderId
|
|
||||||
}
|
|
||||||
|
|
||||||
private val isInbox: Boolean
|
private val isInbox: Boolean
|
||||||
get() {
|
get() = isSpecialFolder(account?.inboxFolderId)
|
||||||
val currentFolder = currentFolder ?: return false
|
|
||||||
return currentFolder.databaseId == account!!.inboxFolderId
|
private val isArchiveFolder: Boolean
|
||||||
}
|
get() = isSpecialFolder(account?.archiveFolderId)
|
||||||
|
|
||||||
|
private val isSpamFolder: Boolean
|
||||||
|
get() = isSpecialFolder(account?.spamFolderId)
|
||||||
|
|
||||||
|
private fun isSpecialFolder(specialFolderId: Long?): Boolean {
|
||||||
|
val folderId = specialFolderId ?: return false
|
||||||
|
val currentFolder = currentFolder ?: return false
|
||||||
|
return currentFolder.databaseId == folderId
|
||||||
|
}
|
||||||
|
|
||||||
val isRemoteFolder: Boolean
|
val isRemoteFolder: Boolean
|
||||||
get() {
|
get() {
|
||||||
|
@ -1775,8 +1781,23 @@ class MessageListFragment :
|
||||||
if (account?.hasSpamFolder() == true) {
|
if (account?.hasSpamFolder() == true) {
|
||||||
menu.findItem(R.id.spam).isVisible = true
|
menu.findItem(R.id.spam).isVisible = true
|
||||||
}
|
}
|
||||||
|
} else if (isOutbox) {
|
||||||
|
menu.findItem(R.id.mark_as_read).isVisible = false
|
||||||
|
menu.findItem(R.id.mark_as_unread).isVisible = false
|
||||||
|
menu.findItem(R.id.archive).isVisible = false
|
||||||
|
menu.findItem(R.id.copy).isVisible = false
|
||||||
|
menu.findItem(R.id.flag).isVisible = false
|
||||||
|
menu.findItem(R.id.unflag).isVisible = false
|
||||||
|
menu.findItem(R.id.spam).isVisible = false
|
||||||
|
menu.findItem(R.id.move).isVisible = false
|
||||||
|
|
||||||
|
disableMarkAsRead = true
|
||||||
|
disableFlag = true
|
||||||
|
|
||||||
|
if (account.hasDraftsFolder()) {
|
||||||
|
menu.findItem(R.id.move_to_drafts).isVisible = true
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
// hide unsupported
|
|
||||||
if (!messagingController.isCopyCapable(account)) {
|
if (!messagingController.isCopyCapable(account)) {
|
||||||
menu.findItem(R.id.copy).isVisible = false
|
menu.findItem(R.id.copy).isVisible = false
|
||||||
}
|
}
|
||||||
|
@ -1785,33 +1806,13 @@ class MessageListFragment :
|
||||||
menu.findItem(R.id.move).isVisible = false
|
menu.findItem(R.id.move).isVisible = false
|
||||||
menu.findItem(R.id.archive).isVisible = false
|
menu.findItem(R.id.archive).isVisible = false
|
||||||
menu.findItem(R.id.spam).isVisible = false
|
menu.findItem(R.id.spam).isVisible = false
|
||||||
}
|
} else {
|
||||||
|
if (isArchiveFolder) {
|
||||||
|
menu.findItem(R.id.archive).isVisible = false
|
||||||
|
}
|
||||||
|
|
||||||
val hideArchiveAction = isSingleFolderMode && currentFolder!!.databaseId == account.archiveFolderId
|
if (isSpamFolder) {
|
||||||
if (hideArchiveAction) {
|
menu.findItem(R.id.spam).isVisible = false
|
||||||
menu.findItem(R.id.archive).isVisible = false
|
|
||||||
}
|
|
||||||
|
|
||||||
val hideSpamAction = isSingleFolderMode && currentFolder!!.databaseId == account.spamFolderId
|
|
||||||
if (hideSpamAction) {
|
|
||||||
menu.findItem(R.id.spam).isVisible = false
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isOutbox) {
|
|
||||||
menu.findItem(R.id.mark_as_read).isVisible = false
|
|
||||||
menu.findItem(R.id.mark_as_unread).isVisible = false
|
|
||||||
menu.findItem(R.id.archive).isVisible = false
|
|
||||||
menu.findItem(R.id.copy).isVisible = false
|
|
||||||
menu.findItem(R.id.flag).isVisible = false
|
|
||||||
menu.findItem(R.id.unflag).isVisible = false
|
|
||||||
menu.findItem(R.id.spam).isVisible = false
|
|
||||||
menu.findItem(R.id.move).isVisible = false
|
|
||||||
|
|
||||||
disableMarkAsRead = true
|
|
||||||
disableFlag = true
|
|
||||||
|
|
||||||
if (account.hasDraftsFolder()) {
|
|
||||||
menu.findItem(R.id.move_to_drafts).isVisible = true
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue