use the new redesigned search menu
This commit is contained in:
parent
f60b1c6575
commit
b85dd7d7d2
|
@ -191,7 +191,6 @@ class InsertOrEditContactActivity : SimpleActivity(), RefreshContactsListener {
|
||||||
|
|
||||||
MenuItemCompat.setOnActionExpandListener(searchMenuItem, object : MenuItemCompat.OnActionExpandListener {
|
MenuItemCompat.setOnActionExpandListener(searchMenuItem, object : MenuItemCompat.OnActionExpandListener {
|
||||||
override fun onMenuItemActionExpand(item: MenuItem?): Boolean {
|
override fun onMenuItemActionExpand(item: MenuItem?): Boolean {
|
||||||
getCurrentFragment()?.onSearchOpened()
|
|
||||||
isSearchOpen = true
|
isSearchOpen = true
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,9 +2,7 @@ package com.simplemobiletools.contacts.pro.activities
|
||||||
|
|
||||||
import android.annotation.SuppressLint
|
import android.annotation.SuppressLint
|
||||||
import android.app.Activity
|
import android.app.Activity
|
||||||
import android.app.SearchManager
|
|
||||||
import android.content.ActivityNotFoundException
|
import android.content.ActivityNotFoundException
|
||||||
import android.content.Context
|
|
||||||
import android.content.Intent
|
import android.content.Intent
|
||||||
import android.content.pm.ShortcutInfo
|
import android.content.pm.ShortcutInfo
|
||||||
import android.graphics.drawable.ColorDrawable
|
import android.graphics.drawable.ColorDrawable
|
||||||
|
@ -12,13 +10,9 @@ import android.graphics.drawable.Icon
|
||||||
import android.graphics.drawable.LayerDrawable
|
import android.graphics.drawable.LayerDrawable
|
||||||
import android.net.Uri
|
import android.net.Uri
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.view.Menu
|
|
||||||
import android.view.MenuItem
|
|
||||||
import android.widget.ImageView
|
import android.widget.ImageView
|
||||||
import android.widget.TextView
|
import android.widget.TextView
|
||||||
import android.widget.Toast
|
import android.widget.Toast
|
||||||
import androidx.appcompat.widget.SearchView
|
|
||||||
import androidx.core.view.MenuItemCompat
|
|
||||||
import androidx.viewpager.widget.ViewPager
|
import androidx.viewpager.widget.ViewPager
|
||||||
import com.simplemobiletools.commons.dialogs.FilePickerDialog
|
import com.simplemobiletools.commons.dialogs.FilePickerDialog
|
||||||
import com.simplemobiletools.commons.extensions.*
|
import com.simplemobiletools.commons.extensions.*
|
||||||
|
@ -57,9 +51,6 @@ class MainActivity : SimpleActivity(), RefreshContactsListener {
|
||||||
private val PICK_IMPORT_SOURCE_INTENT = 1
|
private val PICK_IMPORT_SOURCE_INTENT = 1
|
||||||
private val PICK_EXPORT_FILE_INTENT = 2
|
private val PICK_EXPORT_FILE_INTENT = 2
|
||||||
|
|
||||||
private var isSearchOpen = false
|
|
||||||
private var mSearchMenuItem: MenuItem? = null
|
|
||||||
private var searchQuery = ""
|
|
||||||
private var werePermissionsHandled = false
|
private var werePermissionsHandled = false
|
||||||
private var isFirstResume = true
|
private var isFirstResume = true
|
||||||
private var isGettingContacts = false
|
private var isGettingContacts = false
|
||||||
|
@ -77,6 +68,7 @@ class MainActivity : SimpleActivity(), RefreshContactsListener {
|
||||||
appLaunched(BuildConfig.APPLICATION_ID)
|
appLaunched(BuildConfig.APPLICATION_ID)
|
||||||
setupOptionsMenu()
|
setupOptionsMenu()
|
||||||
refreshMenuItems()
|
refreshMenuItems()
|
||||||
|
updateMaterialActivityViews(main_coordinator, main_holder, useTransparentNavigation = false, useTopSearchMenu = true)
|
||||||
storeStateVariables()
|
storeStateVariables()
|
||||||
setupTabs()
|
setupTabs()
|
||||||
checkContactPermissions()
|
checkContactPermissions()
|
||||||
|
@ -126,8 +118,8 @@ class MainActivity : SimpleActivity(), RefreshContactsListener {
|
||||||
it?.setupColors(getProperTextColor(), properPrimaryColor)
|
it?.setupColors(getProperTextColor(), properPrimaryColor)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
updateMenuColors()
|
||||||
setupTabColors()
|
setupTabColors()
|
||||||
setupToolbar(main_toolbar, searchMenuItem = mSearchMenuItem)
|
|
||||||
|
|
||||||
val configStartNameWithSurname = config.startNameWithSurname
|
val configStartNameWithSurname = config.startNameWithSurname
|
||||||
if (storedStartNameWithSurname != configStartNameWithSurname) {
|
if (storedStartNameWithSurname != configStartNameWithSurname) {
|
||||||
|
@ -174,34 +166,6 @@ class MainActivity : SimpleActivity(), RefreshContactsListener {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun refreshMenuItems() {
|
|
||||||
val currentFragment = getCurrentFragment()
|
|
||||||
main_toolbar.menu.apply {
|
|
||||||
findItem(R.id.sort).isVisible = currentFragment != groups_fragment
|
|
||||||
findItem(R.id.filter).isVisible = currentFragment != groups_fragment
|
|
||||||
findItem(R.id.dialpad).isVisible = !config.showDialpadButton
|
|
||||||
findItem(R.id.more_apps_from_us).isVisible = !resources.getBoolean(R.bool.hide_google_relations)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun setupOptionsMenu() {
|
|
||||||
setupSearch(main_toolbar.menu)
|
|
||||||
main_toolbar.setOnMenuItemClickListener { menuItem ->
|
|
||||||
when (menuItem.itemId) {
|
|
||||||
R.id.sort -> showSortingDialog(showCustomSorting = getCurrentFragment() is FavoritesFragment)
|
|
||||||
R.id.filter -> showFilterDialog()
|
|
||||||
R.id.dialpad -> launchDialpad()
|
|
||||||
R.id.import_contacts -> tryImportContacts()
|
|
||||||
R.id.export_contacts -> tryExportContacts()
|
|
||||||
R.id.more_apps_from_us -> launchMoreAppsFromUsIntent()
|
|
||||||
R.id.settings -> launchSettings()
|
|
||||||
R.id.about -> launchAbout()
|
|
||||||
else -> return@setOnMenuItemClickListener false
|
|
||||||
}
|
|
||||||
return@setOnMenuItemClickListener true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun onActivityResult(requestCode: Int, resultCode: Int, resultData: Intent?) {
|
override fun onActivityResult(requestCode: Int, resultCode: Int, resultData: Intent?) {
|
||||||
super.onActivityResult(requestCode, resultCode, resultData)
|
super.onActivityResult(requestCode, resultCode, resultData)
|
||||||
if (requestCode == PICK_IMPORT_SOURCE_INTENT && resultCode == Activity.RESULT_OK && resultData != null && resultData.data != null) {
|
if (requestCode == PICK_IMPORT_SOURCE_INTENT && resultCode == Activity.RESULT_OK && resultData != null && resultData.data != null) {
|
||||||
|
@ -217,13 +181,64 @@ class MainActivity : SimpleActivity(), RefreshContactsListener {
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onBackPressed() {
|
override fun onBackPressed() {
|
||||||
if (isSearchOpen && mSearchMenuItem != null) {
|
if (main_menu.isSearchOpen) {
|
||||||
mSearchMenuItem!!.collapseActionView()
|
main_menu.closeSearch()
|
||||||
} else {
|
} else {
|
||||||
super.onBackPressed()
|
super.onBackPressed()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun refreshMenuItems() {
|
||||||
|
val currentFragment = getCurrentFragment()
|
||||||
|
main_menu.getToolbar().menu.apply {
|
||||||
|
findItem(R.id.sort).isVisible = currentFragment != groups_fragment
|
||||||
|
findItem(R.id.filter).isVisible = currentFragment != groups_fragment
|
||||||
|
findItem(R.id.dialpad).isVisible = !config.showDialpadButton
|
||||||
|
findItem(R.id.more_apps_from_us).isVisible = !resources.getBoolean(R.bool.hide_google_relations)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun setupOptionsMenu() {
|
||||||
|
main_menu.getToolbar().inflateMenu(R.menu.menu)
|
||||||
|
main_menu.toggleHideOnScroll(false)
|
||||||
|
main_menu.setupMenu()
|
||||||
|
|
||||||
|
main_menu.onSearchOpenListener = {
|
||||||
|
main_dialpad_button.beGone()
|
||||||
|
}
|
||||||
|
|
||||||
|
main_menu.onSearchClosedListener = {
|
||||||
|
getAllFragments().forEach {
|
||||||
|
it?.onSearchClosed()
|
||||||
|
}
|
||||||
|
main_dialpad_button.beVisibleIf(config.showDialpadButton)
|
||||||
|
}
|
||||||
|
|
||||||
|
main_menu.onSearchTextChangedListener = { text ->
|
||||||
|
getCurrentFragment()?.onSearchQueryChanged(text)
|
||||||
|
}
|
||||||
|
|
||||||
|
main_menu.getToolbar().setOnMenuItemClickListener { menuItem ->
|
||||||
|
when (menuItem.itemId) {
|
||||||
|
R.id.sort -> showSortingDialog(showCustomSorting = getCurrentFragment() is FavoritesFragment)
|
||||||
|
R.id.filter -> showFilterDialog()
|
||||||
|
R.id.dialpad -> launchDialpad()
|
||||||
|
R.id.import_contacts -> tryImportContacts()
|
||||||
|
R.id.export_contacts -> tryExportContacts()
|
||||||
|
R.id.more_apps_from_us -> launchMoreAppsFromUsIntent()
|
||||||
|
R.id.settings -> launchSettings()
|
||||||
|
R.id.about -> launchAbout()
|
||||||
|
else -> return@setOnMenuItemClickListener false
|
||||||
|
}
|
||||||
|
return@setOnMenuItemClickListener true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun updateMenuColors() {
|
||||||
|
updateStatusbarColor(getProperBackgroundColor())
|
||||||
|
main_menu.updateColors()
|
||||||
|
}
|
||||||
|
|
||||||
private fun storeStateVariables() {
|
private fun storeStateVariables() {
|
||||||
config.apply {
|
config.apply {
|
||||||
storedShowContactThumbnails = showContactThumbnails
|
storedShowContactThumbnails = showContactThumbnails
|
||||||
|
@ -234,51 +249,6 @@ class MainActivity : SimpleActivity(), RefreshContactsListener {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun setupSearch(menu: Menu) {
|
|
||||||
val searchManager = getSystemService(Context.SEARCH_SERVICE) as SearchManager
|
|
||||||
mSearchMenuItem = menu.findItem(R.id.search)
|
|
||||||
(mSearchMenuItem!!.actionView as SearchView).apply {
|
|
||||||
setSearchableInfo(searchManager.getSearchableInfo(componentName))
|
|
||||||
isSubmitButtonEnabled = false
|
|
||||||
queryHint = getString(getSearchString())
|
|
||||||
setOnQueryTextListener(object : SearchView.OnQueryTextListener {
|
|
||||||
override fun onQueryTextSubmit(query: String) = false
|
|
||||||
|
|
||||||
override fun onQueryTextChange(newText: String): Boolean {
|
|
||||||
if (isSearchOpen) {
|
|
||||||
searchQuery = newText
|
|
||||||
getCurrentFragment()?.onSearchQueryChanged(newText)
|
|
||||||
}
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
MenuItemCompat.setOnActionExpandListener(mSearchMenuItem, object : MenuItemCompat.OnActionExpandListener {
|
|
||||||
override fun onMenuItemActionExpand(item: MenuItem?): Boolean {
|
|
||||||
getCurrentFragment()?.onSearchOpened()
|
|
||||||
isSearchOpen = true
|
|
||||||
main_dialpad_button.beGone()
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun onMenuItemActionCollapse(item: MenuItem?): Boolean {
|
|
||||||
getCurrentFragment()?.onSearchClosed()
|
|
||||||
isSearchOpen = false
|
|
||||||
main_dialpad_button.beVisibleIf(config.showDialpadButton)
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun getSearchString(): Int {
|
|
||||||
return when (getCurrentFragment()) {
|
|
||||||
favorites_fragment -> R.string.search_favorites
|
|
||||||
groups_fragment -> R.string.search_groups
|
|
||||||
else -> R.string.search_contacts
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@SuppressLint("NewApi")
|
@SuppressLint("NewApi")
|
||||||
private fun checkShortcuts() {
|
private fun checkShortcuts() {
|
||||||
val appIconColor = config.appIconColor
|
val appIconColor = config.appIconColor
|
||||||
|
@ -393,7 +363,7 @@ class MainActivity : SimpleActivity(), RefreshContactsListener {
|
||||||
updateBottomTabItemColors(it.customView, false)
|
updateBottomTabItemColors(it.customView, false)
|
||||||
},
|
},
|
||||||
tabSelectedAction = {
|
tabSelectedAction = {
|
||||||
closeSearch()
|
main_menu.closeSearch()
|
||||||
view_pager.currentItem = it.position
|
view_pager.currentItem = it.position
|
||||||
updateBottomTabItemColors(it.customView, true)
|
updateBottomTabItemColors(it.customView, true)
|
||||||
}
|
}
|
||||||
|
@ -541,13 +511,11 @@ class MainActivity : SimpleActivity(), RefreshContactsListener {
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun launchSettings() {
|
private fun launchSettings() {
|
||||||
closeSearch()
|
|
||||||
hideKeyboard()
|
hideKeyboard()
|
||||||
startActivity(Intent(applicationContext, SettingsActivity::class.java))
|
startActivity(Intent(applicationContext, SettingsActivity::class.java))
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun launchAbout() {
|
private fun launchAbout() {
|
||||||
closeSearch()
|
|
||||||
val licenses = LICENSE_JODA or LICENSE_GLIDE or LICENSE_GSON or LICENSE_INDICATOR_FAST_SCROLL or LICENSE_AUTOFITTEXTVIEW
|
val licenses = LICENSE_JODA or LICENSE_GLIDE or LICENSE_GSON or LICENSE_INDICATOR_FAST_SCROLL or LICENSE_AUTOFITTEXTVIEW
|
||||||
|
|
||||||
val faqItems = arrayListOf(
|
val faqItems = arrayListOf(
|
||||||
|
@ -599,8 +567,8 @@ class MainActivity : SimpleActivity(), RefreshContactsListener {
|
||||||
groups_fragment?.refreshContacts(contacts)
|
groups_fragment?.refreshContacts(contacts)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isSearchOpen) {
|
if (main_menu.isSearchOpen) {
|
||||||
getCurrentFragment()?.onSearchQueryChanged(searchQuery)
|
getCurrentFragment()?.onSearchQueryChanged(main_menu.getCurrentQuery())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -639,15 +607,6 @@ class MainActivity : SimpleActivity(), RefreshContactsListener {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun closeSearch() {
|
|
||||||
if (isSearchOpen) {
|
|
||||||
getAllFragments().forEach {
|
|
||||||
it?.onSearchQueryChanged("")
|
|
||||||
}
|
|
||||||
mSearchMenuItem?.collapseActionView()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun checkWhatsNewDialog() {
|
private fun checkWhatsNewDialog() {
|
||||||
arrayListOf<Release>().apply {
|
arrayListOf<Release>().apply {
|
||||||
add(Release(10, R.string.release_10))
|
add(Release(10, R.string.release_10))
|
||||||
|
|
|
@ -391,11 +391,6 @@ abstract class MyViewPagerFragment(context: Context, attributeSet: AttributeSet)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fun onSearchOpened() {
|
|
||||||
contactsIgnoringSearch = (fragment_list?.adapter as? ContactsAdapter)?.contactItems ?: ArrayList()
|
|
||||||
groupsIgnoringSearch = (fragment_list?.adapter as? GroupsAdapter)?.groups ?: ArrayList()
|
|
||||||
}
|
|
||||||
|
|
||||||
fun onSearchClosed() {
|
fun onSearchClosed() {
|
||||||
if (fragment_list.adapter is ContactsAdapter) {
|
if (fragment_list.adapter is ContactsAdapter) {
|
||||||
(fragment_list.adapter as? ContactsAdapter)?.updateItems(contactsIgnoringSearch)
|
(fragment_list.adapter as? ContactsAdapter)?.updateItems(contactsIgnoringSearch)
|
||||||
|
|
|
@ -5,21 +5,10 @@
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent">
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
<com.google.android.material.appbar.AppBarLayout
|
<com.simplemobiletools.commons.views.MySearchMenu
|
||||||
android:id="@+id/main_app_bar_layout"
|
android:id="@+id/main_menu"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content">
|
android:layout_height="wrap_content" />
|
||||||
|
|
||||||
<com.google.android.material.appbar.MaterialToolbar
|
|
||||||
android:id="@+id/main_toolbar"
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="?attr/actionBarSize"
|
|
||||||
android:background="@color/color_primary"
|
|
||||||
app:menu="@menu/menu"
|
|
||||||
app:title="@string/app_launcher_name"
|
|
||||||
app:titleTextAppearance="@style/AppTheme.ActionBar.TitleTextStyle" />
|
|
||||||
|
|
||||||
</com.google.android.material.appbar.AppBarLayout>
|
|
||||||
|
|
||||||
<androidx.constraintlayout.widget.ConstraintLayout
|
<androidx.constraintlayout.widget.ConstraintLayout
|
||||||
android:id="@+id/main_holder"
|
android:id="@+id/main_holder"
|
||||||
|
|
|
@ -3,12 +3,6 @@
|
||||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
xmlns:tools="http://schemas.android.com/tools"
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
tools:ignore="AppCompatResource,AlwaysShowAction">
|
tools:ignore="AppCompatResource,AlwaysShowAction">
|
||||||
<item
|
|
||||||
android:id="@+id/search"
|
|
||||||
android:icon="@drawable/ic_search_vector"
|
|
||||||
android:title="@string/search"
|
|
||||||
app:actionViewClass="androidx.appcompat.widget.SearchView"
|
|
||||||
app:showAsAction="collapseActionView|always" />
|
|
||||||
<item
|
<item
|
||||||
android:id="@+id/sort"
|
android:id="@+id/sort"
|
||||||
android:icon="@drawable/ic_sort_vector"
|
android:icon="@drawable/ic_sort_vector"
|
||||||
|
|
Loading…
Reference in New Issue