-
Notifications
You must be signed in to change notification settings - Fork 200
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Search results with statistics #2061
base: develop
Are you sure you want to change the base?
Changes from 37 commits
5a0d132
8376a93
1b1195f
8f12d36
856333a
15f6d79
c799b52
2fd5daf
1813f7b
429825f
42fa539
07e674c
210ca69
2966e8b
1764f3b
3f1a7c6
68bd008
fd39490
d899246
92c32dd
faea5de
7217619
61333bb
2bc8c70
1401604
5b0b478
f10c554
7995ad1
e3b2f61
267621e
4c49984
46c8592
97aaa48
4ee12de
b3751c8
d0bdd5a
8be3724
478e418
b530111
7b84629
f923084
ceb74e5
e5478f9
20c0e44
d7fa48a
abdd0de
f987dd2
46589d5
61a8530
48aa5a9
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -26,6 +26,8 @@ import net.bible.android.control.page.window.ActiveWindowPageManagerProvider | |
import net.bible.android.control.versification.Scripture | ||
import net.bible.android.view.activity.search.Search | ||
import net.bible.android.view.activity.search.SearchIndex | ||
import net.bible.service.common.CommonUtils.limitTextLength | ||
import net.bible.service.sword.SwordContentFacade.getPlainText | ||
import net.bible.service.sword.SwordContentFacade.readOsisFragment | ||
import net.bible.service.sword.SwordContentFacade.search | ||
import net.bible.service.sword.SwordDocumentFacade | ||
|
@@ -55,6 +57,7 @@ class SearchControl @Inject constructor( | |
) | ||
{ | ||
private val isSearchShowingScripture = true | ||
var isStrongsSearch: Boolean = false | ||
|
||
enum class SearchBibleSection { | ||
OT, NT, CURRENT_BOOK, ALL | ||
|
@@ -98,11 +101,33 @@ class SearchControl @Inject constructor( | |
"-" | ||
} | ||
|
||
fun decorateSearchString(searchString: String, searchType: SearchType, bibleSection: SearchBibleSection, currentBookName: String?): String { | ||
val cleanSearchString = cleanSearchString(searchString) | ||
fun decorateSearchString(searchString: String, searchType: SearchType, bibleSection: SearchBibleSection, currentBookName: String?, | ||
includeAllEndings: Boolean=false, fuzzySearchAccuracy: Double? = null, proximityWords: Int? = null, | ||
strongs: Char? = null): String { | ||
var cleanSearchString = cleanSearchString(searchString) | ||
isStrongsSearch = strongs != null | ||
if (includeAllEndings || isStrongsSearch || fuzzySearchAccuracy != null) { | ||
var newSearchString = "" | ||
val wordArray: List<String> = cleanSearchString.split(" ") | ||
for (it in wordArray) { | ||
var decoratedWord = it | ||
if (includeAllEndings) decoratedWord += "* " | ||
if (isStrongsSearch) decoratedWord = "strong:$strongs$decoratedWord " | ||
if (fuzzySearchAccuracy != null) { | ||
val fuzzySearchAccuracyAdjusted = if (fuzzySearchAccuracy.equals(1.0)) 0.99 else fuzzySearchAccuracy | ||
decoratedWord += "~%.2f ".format(fuzzySearchAccuracyAdjusted) | ||
} | ||
newSearchString += decoratedWord | ||
} | ||
cleanSearchString = newSearchString.trim() | ||
} | ||
|
||
if (proximityWords != null) { | ||
cleanSearchString = "\"$cleanSearchString\"~$proximityWords" | ||
} | ||
|
||
// add search type (all/any/phrase) to search string | ||
var decorated: String = searchType.decorate(cleanSearchString) | ||
var decorated = searchType.decorate(cleanSearchString) | ||
originalSearchString = decorated | ||
|
||
// add bible section limitation to search text | ||
|
@@ -142,6 +167,26 @@ class SearchControl @Inject constructor( | |
return searchResults | ||
} | ||
|
||
fun getSearchResultVerseText(key: Key?): String { | ||
agrogers marked this conversation as resolved.
Show resolved
Hide resolved
|
||
// There is similar functionality in BookmarkControl | ||
// This is much slower than 'getSearchResultVerseElement'. Why? In the old version this was VERY fast. | ||
var verseText = "" | ||
try { | ||
val doc = activeWindowPageManagerProvider.activeWindowPageManager.currentPage.currentDocument | ||
val cat = doc!!.bookCategory | ||
verseText = if (cat == BookCategory.BIBLE || cat == BookCategory.COMMENTARY) { | ||
getPlainText(doc, key) | ||
} else { | ||
val bible = activeWindowPageManagerProvider.activeWindowPageManager.currentBible.currentDocument!! | ||
getPlainText(bible, key) | ||
} | ||
verseText = limitTextLength(verseText)!! | ||
} catch (e: Exception) { | ||
Log.e(TAG, "Error getting verse text", e) | ||
} | ||
return verseText | ||
} | ||
|
||
fun getSearchResultVerseElement(key: Key?): Element { | ||
// There is similar functionality in BookmarkControl | ||
var xmlVerse:Element? = null | ||
|
@@ -232,7 +277,7 @@ class SearchControl @Inject constructor( | |
const val TARGET_DOCUMENT = "TargetDocument" | ||
private const val STRONG_COLON_STRING = LuceneIndex.FIELD_STRONG + ":" | ||
private const val STRONG_COLON_STRING_PLACE_HOLDER = LuceneIndex.FIELD_STRONG + "COLON" | ||
const val MAX_SEARCH_RESULTS = 1000 | ||
const val MAX_SEARCH_RESULTS = 10000 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Quite a lot? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I dont think we need to limit it at all. The most hits i got was about 4000 for some common words. The search itself is very fast. Even big searches in its current form were acceptable (but slow) for me. The complete search results are valuable now because of the stats. My suggestions it make it very large. |
||
private const val TAG = "SearchControl" | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -324,16 +324,43 @@ class GridChoosePassageBook : CustomTitlebarActivityBase(R.menu.choose_passage_b | |
private val HISTORY_COLOR = Color.rgb(0xFE, 0xCC, 0x9B) | ||
private val WISDOM_COLOR = Color.rgb(0x99, 0xFF, 0x99) | ||
private val MAJOR_PROPHETS_COLOR = Color.rgb(0xFF, 0x99, 0xFF) | ||
private val MINOR_PROPHETS_COLOR = Color.rgb(0xFF, 0xFE, 0xCD) | ||
private val MINOR_PROPHETS_COLOR = Color.rgb(0xE6, 0xE5, 0xB8) | ||
private val GOSPEL_COLOR = Color.rgb(0xFF, 0x97, 0x03) | ||
private val ACTS_COLOR = Color.rgb(0x00, 0x99, 0xFF) | ||
private val PAULINE_COLOR = Color.rgb(0xFF, 0xFF, 0x31) | ||
private val PAULINE_COLOR = Color.rgb(0xF5, 0xf5, 0x21) | ||
private val GENERAL_EPISTLES_COLOR = Color.rgb(0x67, 0xCC, 0x66) // changed 99 to CC to make a little clearer on dark background | ||
private val REVELATION_COLOR = Color.rgb(0xFE, 0x33, 0xFF) | ||
private val OTHER_COLOR = ACTS_COLOR | ||
|
||
public const val BOOK_GRID_FLOW_PREFS = "book_grid_ltr" | ||
public const val BOOK_GRID_FLOW_PREFS_GROUP_BY_CATEGORY = "book_grid_group_by_category" | ||
private const val TAG = "GridChoosePassageBook" | ||
|
||
fun getBookTextColor(bookNo: Int): Int { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why here? Not used in GridChoosePassageBook activity. Perhaps need to move all these color-related code somewhere else, if they are used in multiple places. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I cant recall what i did here. But yes, they are now used in two places and i have other places i would like to use them as well. I think i wrote some functions to get what i wanted and added them somewhere. And i seem to recall not knowing where the best place to put them would be. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think you have moved this and i have incorporated that change. |
||
// colour and grouping taken from http://en.wikipedia.org/wiki/Books_of_the_Bible | ||
return when { | ||
bookNo <= BibleBook.DEUT.ordinal -> // Pentateuch - books of Moses | ||
PENTATEUCH_COLOR | ||
bookNo <= BibleBook.ESTH.ordinal -> // History | ||
HISTORY_COLOR | ||
bookNo <= BibleBook.SONG.ordinal -> // Wisdom | ||
WISDOM_COLOR | ||
bookNo <= BibleBook.DAN.ordinal -> // Major prophets | ||
MAJOR_PROPHETS_COLOR | ||
bookNo <= BibleBook.MAL.ordinal -> // Minor prophets | ||
MINOR_PROPHETS_COLOR | ||
bookNo <= BibleBook.JOHN.ordinal -> // Gospels | ||
GOSPEL_COLOR | ||
bookNo <= BibleBook.ACTS.ordinal -> // Acts | ||
ACTS_COLOR | ||
bookNo <= BibleBook.PHLM.ordinal -> // Pauline epistles | ||
PAULINE_COLOR | ||
bookNo <= BibleBook.JUDE.ordinal -> // General epistles | ||
GENERAL_EPISTLES_COLOR | ||
bookNo <= BibleBook.JUDE.ordinal -> // Revelation | ||
REVELATION_COLOR | ||
else -> OTHER_COLOR | ||
} | ||
} | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Isn't this temporary (2 search results activities)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe. I don't understand much about the manifest :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I mean, we have now SearchResults, and MySearchResults. I think SearchResults is deprecated by MySearchResults. End result should be that we remove old SearchResults and rename MySearchResults -> SearchResults.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am sure i had answered this somewhere else. Yes, MySearchResults is a duplicate. The old one could be removed.