diff options
| author | siikamiika <siikamiika@users.noreply.github.com> | 2019-08-01 02:20:09 +0300 | 
|---|---|---|
| committer | siikamiika <siikamiika@users.noreply.github.com> | 2019-08-01 02:20:09 +0300 | 
| commit | b8df9896e643c772253749a335b2abf0daa7a282 (patch) | |
| tree | f4bd8f3e5dbbd7e50426d3ba5f31311b830d651e /ext/fg/js | |
| parent | 7cfcfb3bf34bb128dc4f5a47e7846fe4cc4c8c81 (diff) | |
allow looking up terms from within terms
resolves #167, resolves #139, resolves #75, resolves #151
Diffstat (limited to 'ext/fg/js')
| -rw-r--r-- | ext/fg/js/float.js | 35 | 
1 files changed, 35 insertions, 0 deletions
| diff --git a/ext/fg/js/float.js b/ext/fg/js/float.js index 1deb61a9..65ed89a1 100644 --- a/ext/fg/js/float.js +++ b/ext/fg/js/float.js @@ -123,6 +123,41 @@ class DisplayFloat extends Display {              parent.appendChild(this.styleNode);          }      } + +    async onTermLookup(e) { +        try { +            e.preventDefault(); + +            const clickedElement = $(e.target); +            const textSource = docRangeFromPoint({x: e.clientX, y: e.clientY}); +            textSource.setEndOffset(this.options.scanning.length); + +            const {definitions, length} = await apiTermsFind(textSource.text()); +            if (definitions.length === 0) { +                return false; +            } + +            textSource.setEndOffset(length); + +            const sentence = docSentenceExtract(textSource, this.options.anki.sentenceExt); + +            const context = { +                source: { +                    definitions: this.definitions, +                    index: Display.entryIndexFind(clickedElement) +                } +            }; + +            if (this.context) { +                context.sentence = sentence; +                context.url = this.context.url; +            } + +            this.termsShow(definitions, this.options, context); +        } catch (e) { +            this.onError(e); +        } +    }  }  window.yomichan_display = new DisplayFloat(); |