diff options
| author | Alex Yatskov <alex@foosoft.net> | 2019-09-02 11:47:14 -0700 | 
|---|---|---|
| committer | Alex Yatskov <alex@foosoft.net> | 2019-09-02 11:47:14 -0700 | 
| commit | 5347da528bd07166b4686f45440d80a77f4888a3 (patch) | |
| tree | 08bbfd0c859327ee9a08ca86afd222a222ced62b /ext/mixed/js | |
| parent | da981c0b911dc5a697246006089b266fddba84a7 (diff) | |
| parent | 4ac55da7dd5354e6c3495f04583352d0d863b7b6 (diff) | |
Merge branch 'master' into testing
Diffstat (limited to 'ext/mixed/js')
| -rw-r--r-- | ext/mixed/js/display.js | 22 | ||||
| -rw-r--r-- | ext/mixed/js/extension.js | 53 | 
2 files changed, 67 insertions, 8 deletions
| diff --git a/ext/mixed/js/display.js b/ext/mixed/js/display.js index a2707bd0..ebf56897 100644 --- a/ext/mixed/js/display.js +++ b/ext/mixed/js/display.js @@ -80,20 +80,26 @@ class Display {              const {docRangeFromPoint, docSentenceExtract} = this.dependencies;              const clickedElement = $(e.target); -            const textSource = docRangeFromPoint({x: e.clientX, y: e.clientY}); +            const textSource = docRangeFromPoint({x: e.clientX, y: e.clientY}, this.options);              if (textSource === null) {                  return false;              } -            textSource.setEndOffset(this.options.scanning.length); -            const {definitions, length} = await apiTermsFind(textSource.text()); -            if (definitions.length === 0) { -                return false; -            } +            let definitions, length, sentence; +            try { +                textSource.setEndOffset(this.options.scanning.length); -            textSource.setEndOffset(length); +                ({definitions, length} = await apiTermsFind(textSource.text())); +                if (definitions.length === 0) { +                    return false; +                } -            const sentence = docSentenceExtract(textSource, this.options.anki.sentenceExt); +                textSource.setEndOffset(length); + +                sentence = docSentenceExtract(textSource, this.options.anki.sentenceExt); +            } finally { +                textSource.cleanup(); +            }              const context = {                  source: { diff --git a/ext/mixed/js/extension.js b/ext/mixed/js/extension.js new file mode 100644 index 00000000..d7085e5b --- /dev/null +++ b/ext/mixed/js/extension.js @@ -0,0 +1,53 @@ +/* + * Copyright (C) 2019  Alex Yatskov <alex@foosoft.net> + * Author: Alex Yatskov <alex@foosoft.net> + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program.  If not, see <http://www.gnu.org/licenses/>. + */ + + +function toIterable(value) { +    if (typeof Symbol !== 'undefined' && typeof value[Symbol.iterator] !== 'undefined') { +        return value; +    } + +    const array = JSON.parse(JSON.stringify(value)); +    return Array.isArray(array) ? array : []; +} + +function extensionHasChrome() { +    try { +        return typeof chrome === 'object' && chrome !== null; +    } catch (e) { +        return false; +    } +} + +function extensionHasBrowser() { +    try { +        return typeof browser === 'object' && browser !== null; +    } catch (e) { +        return false; +    } +} + +const EXTENSION_IS_BROWSER_EDGE = ( +    extensionHasBrowser() && +    (!extensionHasChrome() || (typeof chrome.runtime === 'undefined' && typeof browser.runtime !== 'undefined')) +); + +if (EXTENSION_IS_BROWSER_EDGE) { +    // Edge does not have chrome defined. +    chrome = browser; +} |