mirror of
https://github.com/SimpleMobileTools/Simple-Dialer.git
synced 2025-04-03 13:01:49 +02:00
adding Search at Recents too
This commit is contained in:
parent
56034b98cb
commit
567fb8212a
@ -4,6 +4,7 @@ import android.content.Intent
|
|||||||
import android.graphics.drawable.Drawable
|
import android.graphics.drawable.Drawable
|
||||||
import android.net.Uri
|
import android.net.Uri
|
||||||
import android.provider.CallLog.Calls
|
import android.provider.CallLog.Calls
|
||||||
|
import android.text.SpannableString
|
||||||
import android.text.TextUtils
|
import android.text.TextUtils
|
||||||
import android.util.TypedValue
|
import android.util.TypedValue
|
||||||
import android.view.Menu
|
import android.view.Menu
|
||||||
@ -33,6 +34,7 @@ class RecentCallsAdapter(activity: SimpleActivity, var recentCalls: ArrayList<Re
|
|||||||
private var fontSize = activity.getTextSize()
|
private var fontSize = activity.getTextSize()
|
||||||
private val areMultipleSIMsAvailable = activity.areMultipleSIMsAvailable()
|
private val areMultipleSIMsAvailable = activity.areMultipleSIMsAvailable()
|
||||||
private val redColor = resources.getColor(R.color.md_red_700)
|
private val redColor = resources.getColor(R.color.md_red_700)
|
||||||
|
private var textToHighlight = ""
|
||||||
|
|
||||||
init {
|
init {
|
||||||
initDrawables()
|
initDrawables()
|
||||||
@ -203,11 +205,15 @@ class RecentCallsAdapter(activity: SimpleActivity, var recentCalls: ArrayList<Re
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fun updateItems(newItems: ArrayList<RecentCall>) {
|
fun updateItems(newItems: ArrayList<RecentCall>, highlightText: String = "") {
|
||||||
if (newItems.hashCode() != recentCalls.hashCode()) {
|
if (newItems.hashCode() != recentCalls.hashCode()) {
|
||||||
recentCalls = newItems.clone() as ArrayList<RecentCall>
|
recentCalls = newItems.clone() as ArrayList<RecentCall>
|
||||||
|
textToHighlight = highlightText
|
||||||
notifyDataSetChanged()
|
notifyDataSetChanged()
|
||||||
finishActMode()
|
finishActMode()
|
||||||
|
} else if (textToHighlight != highlightText) {
|
||||||
|
textToHighlight = highlightText
|
||||||
|
notifyDataSetChanged()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -216,9 +222,13 @@ class RecentCallsAdapter(activity: SimpleActivity, var recentCalls: ArrayList<Re
|
|||||||
private fun setupView(view: View, call: RecentCall) {
|
private fun setupView(view: View, call: RecentCall) {
|
||||||
view.apply {
|
view.apply {
|
||||||
item_recents_frame.isSelected = selectedKeys.contains(call.id)
|
item_recents_frame.isSelected = selectedKeys.contains(call.id)
|
||||||
var nameToShow = call.name
|
var nameToShow = SpannableString(call.name)
|
||||||
if (call.neighbourIDs.isNotEmpty()) {
|
if (call.neighbourIDs.isNotEmpty()) {
|
||||||
nameToShow += " (${call.neighbourIDs.size + 1})"
|
nameToShow = SpannableString("$nameToShow (${call.neighbourIDs.size + 1})")
|
||||||
|
}
|
||||||
|
|
||||||
|
if (textToHighlight.isNotEmpty() && nameToShow.contains(textToHighlight, true)) {
|
||||||
|
nameToShow = SpannableString(nameToShow.toString().highlightTextPart(textToHighlight, adjustedPrimaryColor))
|
||||||
}
|
}
|
||||||
|
|
||||||
item_recents_name.apply {
|
item_recents_name.apply {
|
||||||
|
@ -6,6 +6,7 @@ import com.simplemobiletools.commons.extensions.*
|
|||||||
import com.simplemobiletools.commons.helpers.MyContactsContentProvider
|
import com.simplemobiletools.commons.helpers.MyContactsContentProvider
|
||||||
import com.simplemobiletools.commons.helpers.PERMISSION_READ_CALL_LOG
|
import com.simplemobiletools.commons.helpers.PERMISSION_READ_CALL_LOG
|
||||||
import com.simplemobiletools.commons.helpers.SimpleContactsHelper
|
import com.simplemobiletools.commons.helpers.SimpleContactsHelper
|
||||||
|
import com.simplemobiletools.commons.helpers.mydebug
|
||||||
import com.simplemobiletools.dialer.R
|
import com.simplemobiletools.dialer.R
|
||||||
import com.simplemobiletools.dialer.activities.SimpleActivity
|
import com.simplemobiletools.dialer.activities.SimpleActivity
|
||||||
import com.simplemobiletools.dialer.adapters.RecentCallsAdapter
|
import com.simplemobiletools.dialer.adapters.RecentCallsAdapter
|
||||||
@ -16,6 +17,8 @@ import com.simplemobiletools.dialer.models.RecentCall
|
|||||||
import kotlinx.android.synthetic.main.fragment_recents.view.*
|
import kotlinx.android.synthetic.main.fragment_recents.view.*
|
||||||
|
|
||||||
class RecentsFragment(context: Context, attributeSet: AttributeSet) : MyViewPagerFragment(context, attributeSet), RefreshItemsListener {
|
class RecentsFragment(context: Context, attributeSet: AttributeSet) : MyViewPagerFragment(context, attributeSet), RefreshItemsListener {
|
||||||
|
private var allRecentCalls = ArrayList<RecentCall>()
|
||||||
|
|
||||||
override fun setupFragment() {
|
override fun setupFragment() {
|
||||||
val placeholderResId = if (context.hasPermission(PERMISSION_READ_CALL_LOG)) {
|
val placeholderResId = if (context.hasPermission(PERMISSION_READ_CALL_LOG)) {
|
||||||
R.string.no_previous_calls
|
R.string.no_previous_calls
|
||||||
@ -47,6 +50,7 @@ class RecentsFragment(context: Context, attributeSet: AttributeSet) : MyViewPage
|
|||||||
RecentsHelper(context).getRecentCalls { recents ->
|
RecentsHelper(context).getRecentCalls { recents ->
|
||||||
SimpleContactsHelper(context).getAvailableContacts(false) { contacts ->
|
SimpleContactsHelper(context).getAvailableContacts(false) { contacts ->
|
||||||
val privateContacts = MyContactsContentProvider.getSimpleContacts(context, privateCursor)
|
val privateContacts = MyContactsContentProvider.getSimpleContacts(context, privateCursor)
|
||||||
|
|
||||||
recents.filter { it.phoneNumber == it.name }.forEach { recent ->
|
recents.filter { it.phoneNumber == it.name }.forEach { recent ->
|
||||||
var wasNameFilled = false
|
var wasNameFilled = false
|
||||||
if (privateContacts.isNotEmpty()) {
|
if (privateContacts.isNotEmpty()) {
|
||||||
@ -65,6 +69,7 @@ class RecentsFragment(context: Context, attributeSet: AttributeSet) : MyViewPage
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
allRecentCalls = recents
|
||||||
activity?.runOnUiThread {
|
activity?.runOnUiThread {
|
||||||
gotRecents(recents)
|
gotRecents(recents)
|
||||||
}
|
}
|
||||||
@ -111,10 +116,14 @@ class RecentsFragment(context: Context, attributeSet: AttributeSet) : MyViewPage
|
|||||||
}
|
}
|
||||||
|
|
||||||
override fun onSearchClosed() {
|
override fun onSearchClosed() {
|
||||||
|
(recents_list.adapter as? RecentCallsAdapter)?.updateItems(allRecentCalls)
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onSearchQueryChanged(text: String) {
|
override fun onSearchQueryChanged(text: String) {
|
||||||
|
val recentCalls = allRecentCalls.filter {
|
||||||
|
it.name.contains(text, true) || it.doesContainPhoneNumber(text)
|
||||||
|
}.toMutableList() as ArrayList<RecentCall>
|
||||||
|
|
||||||
|
(recents_list.adapter as? RecentCallsAdapter)?.updateItems(recentCalls, text)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,15 @@
|
|||||||
package com.simplemobiletools.dialer.models
|
package com.simplemobiletools.dialer.models
|
||||||
|
|
||||||
|
import android.telephony.PhoneNumberUtils
|
||||||
|
import com.simplemobiletools.commons.extensions.normalizePhoneNumber
|
||||||
|
|
||||||
data class RecentCall(var id: Int, var phoneNumber: String, var name: String, var photoUri: String, var startTS: Int, var duration: Int, var type: Int,
|
data class RecentCall(var id: Int, var phoneNumber: String, var name: String, var photoUri: String, var startTS: Int, var duration: Int, var type: Int,
|
||||||
var neighbourIDs: ArrayList<Int>, val simID: Int)
|
var neighbourIDs: ArrayList<Int>, val simID: Int) {
|
||||||
|
fun doesContainPhoneNumber(text: String): Boolean {
|
||||||
|
val normalizedText = text.normalizePhoneNumber()
|
||||||
|
return PhoneNumberUtils.compare(phoneNumber.normalizePhoneNumber(), normalizedText) ||
|
||||||
|
phoneNumber.contains(text) ||
|
||||||
|
phoneNumber.normalizePhoneNumber().contains(normalizedText) ||
|
||||||
|
phoneNumber.contains(normalizedText)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user