diff options
| author | toasted-nutbread <toasted-nutbread@users.noreply.github.com> | 2020-03-07 21:41:45 -0500 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-03-07 21:41:45 -0500 | 
| commit | b8eb5e6016834cc751c973239e1e4604fe9799ee (patch) | |
| tree | 34001835d0efa086a32e50fc8fb70fee4b7f4795 | |
| parent | 4b0dfa92aaa9e088c2f59edb3adcb89f0b3c1053 (diff) | |
| parent | ba64f34df19d446cbe5b8ec2e367d4f6a4d1061f (diff) | |
Merge pull request #397 from toasted-nutbread/clipboard-monitor-refactor2
Clipboard monitor refactor
| -rw-r--r-- | ext/bg/js/api.js | 4 | ||||
| -rw-r--r-- | ext/bg/js/backend.js | 6 | ||||
| -rw-r--r-- | ext/bg/js/clipboard-monitor.js | 48 | ||||
| -rw-r--r-- | ext/bg/js/search.js | 9 | 
4 files changed, 30 insertions, 37 deletions
| diff --git a/ext/bg/js/api.js b/ext/bg/js/api.js index 0c244ffa..93e43a7d 100644 --- a/ext/bg/js/api.js +++ b/ext/bg/js/api.js @@ -25,10 +25,6 @@ function apiAudioGetUrl(definition, source, optionsContext) {      return _apiInvoke('audioGetUrl', {definition, source, optionsContext});  } -function apiClipboardGet() { -    return _apiInvoke('clipboardGet'); -} -  function _apiInvoke(action, params={}) {      const data = {action, params};      return new Promise((resolve, reject) => { diff --git a/ext/bg/js/backend.js b/ext/bg/js/backend.js index 4595dbb3..04bf240d 100644 --- a/ext/bg/js/backend.js +++ b/ext/bg/js/backend.js @@ -30,7 +30,7 @@ class Backend {          this.translator = new Translator();          this.anki = new AnkiNull();          this.mecab = new Mecab(); -        this.clipboardMonitor = new ClipboardMonitor(); +        this.clipboardMonitor = new ClipboardMonitor({getClipboard: this._onApiClipboardGet.bind(this)});          this.options = null;          this.optionsSchema = null;          this.defaultAnkiFieldTemplates = null; @@ -117,7 +117,7 @@ class Backend {              chrome.tabs.create({url: chrome.runtime.getURL('/bg/guide.html')});          } -        this.clipboardMonitor.onClipboardText = this._onClipboardText.bind(this); +        this.clipboardMonitor.on('change', this._onClipboardText.bind(this));          this._sendMessageAllTabs('backendPrepared');          const callback = () => this.checkLastError(chrome.runtime.lastError); @@ -155,7 +155,7 @@ class Backend {          }      } -    _onClipboardText(text) { +    _onClipboardText({text}) {          this._onCommandSearch({mode: 'popup', query: text});      } diff --git a/ext/bg/js/clipboard-monitor.js b/ext/bg/js/clipboard-monitor.js index c2f41385..a6d73c79 100644 --- a/ext/bg/js/clipboard-monitor.js +++ b/ext/bg/js/clipboard-monitor.js @@ -16,66 +16,64 @@   * along with this program.  If not, see <https://www.gnu.org/licenses/>.   */ -/*global apiClipboardGet, jpIsStringPartiallyJapanese*/ +/*global jpIsStringPartiallyJapanese*/ -class ClipboardMonitor { -    constructor() { -        this.timerId = null; -        this.timerToken = null; -        this.interval = 250; -        this.previousText = null; -    } - -    onClipboardText(_text) { -        throw new Error('Override me'); +class ClipboardMonitor extends EventDispatcher { +    constructor({getClipboard}) { +        super(); +        this._timerId = null; +        this._timerToken = null; +        this._interval = 250; +        this._previousText = null; +        this._getClipboard = getClipboard;      }      start() {          this.stop();          // The token below is used as a unique identifier to ensure that a new clipboard monitor -        // hasn't been started during the await call. The check below the await apiClipboardGet() +        // hasn't been started during the await call. The check below the await this._getClipboard()          // call will exit early if the reference has changed.          const token = {};          const intervalCallback = async () => { -            this.timerId = null; +            this._timerId = null;              let text = null;              try { -                text = await apiClipboardGet(); +                text = await this._getClipboard();              } catch (e) {                  // NOP              } -            if (this.timerToken !== token) { return; } +            if (this._timerToken !== token) { return; }              if (                  typeof text === 'string' &&                  (text = text.trim()).length > 0 && -                text !== this.previousText +                text !== this._previousText              ) { -                this.previousText = text; +                this._previousText = text;                  if (jpIsStringPartiallyJapanese(text)) { -                    this.onClipboardText(text); +                    this.trigger('change', {text});                  }              } -            this.timerId = setTimeout(intervalCallback, this.interval); +            this._timerId = setTimeout(intervalCallback, this._interval);          }; -        this.timerToken = token; +        this._timerToken = token;          intervalCallback();      }      stop() { -        this.timerToken = null; -        if (this.timerId !== null) { -            clearTimeout(this.timerId); -            this.timerId = null; +        this._timerToken = null; +        if (this._timerId !== null) { +            clearTimeout(this._timerId); +            this._timerId = null;          }      }      setPreviousText(text) { -        this.previousText = text; +        this._previousText = text;      }  } diff --git a/ext/bg/js/search.js b/ext/bg/js/search.js index f3cba7ae..f9481ea2 100644 --- a/ext/bg/js/search.js +++ b/ext/bg/js/search.js @@ -16,7 +16,7 @@   * along with this program.  If not, see <https://www.gnu.org/licenses/>.   */ -/*global apiOptionsSet, apiTermsFind, Display, QueryParser, ClipboardMonitor*/ +/*global apiOptionsSet, apiTermsFind, apiClipboardGet, Display, QueryParser, ClipboardMonitor*/  class DisplaySearch extends Display {      constructor() { @@ -38,7 +38,7 @@ class DisplaySearch extends Display {          this.introVisible = true;          this.introAnimationTimer = null; -        this.clipboardMonitor = new ClipboardMonitor(); +        this.clipboardMonitor = new ClipboardMonitor({getClipboard: apiClipboardGet});          this._onKeyDownIgnoreKeys = new Map([              ['ANY_MOD', new Set([ @@ -102,8 +102,7 @@ class DisplaySearch extends Display {              this.wanakanaEnable.addEventListener('change', this.onWanakanaEnableChange.bind(this));              window.addEventListener('popstate', this.onPopState.bind(this));              window.addEventListener('copy', this.onCopy.bind(this)); - -            this.clipboardMonitor.onClipboardText = this.onExternalSearchUpdate.bind(this); +            this.clipboardMonitor.on('change', this.onExternalSearchUpdate.bind(this));              this.updateSearchButton();          } catch (e) { @@ -198,7 +197,7 @@ class DisplaySearch extends Display {          this.clipboardMonitor.setPreviousText(document.getSelection().toString().trim());      } -    onExternalSearchUpdate(text) { +    onExternalSearchUpdate({text}) {          this.setQuery(text);          const url = new URL(window.location.href);          url.searchParams.set('query', text); |