diff options
author | toasted-nutbread <toasted-nutbread@users.noreply.github.com> | 2022-10-15 11:40:22 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-10-15 11:40:22 -0400 |
commit | 5e707248ce4eb595056fd9c46acaf9a0d83678c6 (patch) | |
tree | 9f63809bb08abf7111e40dce2e20faefe5b9a08c | |
parent | abb3e5d5d0a63a20933f1770e03e87e756439d35 (diff) |
Fix text selection not always working properly (#2246)
-rw-r--r-- | ext/js/language/text-scanner.js | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/ext/js/language/text-scanner.js b/ext/js/language/text-scanner.js index 826c8c5b..fcba47a4 100644 --- a/ext/js/language/text-scanner.js +++ b/ext/js/language/text-scanner.js @@ -87,6 +87,7 @@ class TextScanner extends EventDispatcher { this._canClearSelection = true; + this._textSelectionTimer = null; this._yomichanIsChangingTextSelectionNow = false; this._userHasNotSelectedAnythingManually = true; } @@ -269,7 +270,13 @@ class TextScanner extends EventDispatcher { if (this._selectText && this._userHasNotSelectedAnythingManually) { this._yomichanIsChangingTextSelectionNow = true; this._textSourceCurrent.select(); - setTimeout(() => this._yomichanIsChangingTextSelectionNow = false, 0); + if (this._textSelectionTimer !== null) { clearTimeout(this._textSelectionTimer); } + // This timeout uses a 50ms delay to ensure that the selectionchange event has time to occur. + // If the delay is 0ms, the timeout will sometimes complete before the event. + this._textSelectionTimer = setTimeout(() => { + this._yomichanIsChangingTextSelectionNow = false; + this._textSelectionTimer = null; + }, 50); this._textSourceCurrentSelected = true; } else { this._textSourceCurrentSelected = false; |