diff options
author | toasted-nutbread <toasted-nutbread@users.noreply.github.com> | 2020-08-22 14:40:44 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-08-22 14:40:44 -0400 |
commit | 9fa0f2a56a79159227f1f42455157fe9c84132d3 (patch) | |
tree | d9a69e94a42939da1d184a3eec8f5ad03ef450ea /ext/bg | |
parent | bdb4c21a784a3b5c342bf456a8ed754d6d5e63f2 (diff) |
Move findTerms and findKanji functions into TextScanner (#747)
Diffstat (limited to 'ext/bg')
-rw-r--r-- | ext/bg/js/query-parser.js | 32 |
1 files changed, 6 insertions, 26 deletions
diff --git a/ext/bg/js/query-parser.js b/ext/bg/js/query-parser.js index 2ad88601..b0ef2d78 100644 --- a/ext/bg/js/query-parser.js +++ b/ext/bg/js/query-parser.js @@ -27,9 +27,6 @@ class QueryParser extends EventDispatcher { this._getOptionsContext = getOptionsContext; this._setSpinnerVisible = setSpinnerVisible; this._selectedParser = null; - this._scanLength = 1; - this._sentenceExtent = 1; - this._layoutAwareScan = false; this._documentUtil = documentUtil; this._parseResults = []; this._queryParser = document.querySelector('#query-parser-content'); @@ -50,19 +47,10 @@ class QueryParser extends EventDispatcher { this._queryParser.addEventListener('click', this._onClick.bind(this)); } - setOptions({selectedParser, scanLength, sentenceExtent, layoutAwareScan, termSpacing, scanning}) { + setOptions({selectedParser, termSpacing, scanning}) { if (selectedParser === null || typeof selectedParser === 'string') { this._selectedParser = selectedParser; } - if (typeof scanLength === 'number') { - this._scanLength = scanLength; - } - if (typeof sentenceExtent === 'number') { - this._sentenceExtent = sentenceExtent; - } - if (typeof layoutAwareScan === 'boolean') { - this._layoutAwareScan = layoutAwareScan; - } if (typeof termSpacing === 'boolean') { this._queryParser.dataset.termSpacing = `${termSpacing}`; } @@ -95,22 +83,14 @@ class QueryParser extends EventDispatcher { async _search(textSource, cause) { if (textSource === null) { return null; } - const scanLength = this._scanLength; - const sentenceExtent = this._sentenceExtent; - const layoutAwareScan = this._layoutAwareScan; - const searchText = this._textScanner.getTextSourceContent(textSource, scanLength, layoutAwareScan); - if (searchText.length === 0) { return null; } - const optionsContext = this._getOptionsContext(); - const {definitions, length} = await api.termsFind(searchText, {}, optionsContext); - if (definitions.length === 0) { return null; } - - const sentence = this._documentUtil.extractSentence(textSource, sentenceExtent, layoutAwareScan); + const results = await this._textScanner.findTerms(textSource, optionsContext); + if (results === null) { return null; } - textSource.setEndOffset(length, layoutAwareScan); + const {definitions, sentence, type} = results; this.trigger('searched', { - type: 'terms', + type, definitions, sentence, cause, @@ -118,7 +98,7 @@ class QueryParser extends EventDispatcher { optionsContext }); - return {definitions, type: 'terms'}; + return {definitions, type}; } _onParserChange(e) { |