diff options
| -rw-r--r-- | README.md | 28 | ||||
| -rw-r--r-- | ext/bg/js/audio.js | 29 | 
2 files changed, 39 insertions, 18 deletions
| @@ -56,26 +56,26 @@ Please be aware that the non-English dictionaries contain fewer entries than the  primary language is not English, you may consider also importing the English version for better coverage.  *   **[JMdict](http://www.edrdg.org/enamdict/enamdict_doc.html)** (Japanese vocabulary) -    *   [jmdict_dutch.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_dutch.zip) -    *   [jmdict_english.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_english.zip) -    *   [jmdict_french.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_french.zip) -    *   [jmdict_german.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_german.zip) -    *   [jmdict_hungarian.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_hungarian.zip) -    *   [jmdict_russian.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_russian.zip) -    *   [jmdict_slovenian.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_slovenian.zip) -    *   [jmdict_spanish.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_spanish.zip) -    *   [jmdict_swedish.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_swedish.zip) +    *   [jmdict\_dutch.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_dutch.zip) +    *   [jmdict\_english.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_english.zip) +    *   [jmdict\_french.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_french.zip) +    *   [jmdict\_german.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_german.zip) +    *   [jmdict\_hungarian.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_hungarian.zip) +    *   [jmdict\_russian.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_russian.zip) +    *   [jmdict\_slovenian.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_slovenian.zip) +    *   [jmdict\_spanish.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_spanish.zip) +    *   [jmdict\_swedish.zip](https://foosoft.net/projects/yomichan/dl/dict/jmdict_swedish.zip)  *   **[JMnedict](http://www.edrdg.org/enamdict/enamdict_doc.html)** (Japanese names)      *   [jmnedict.zip](https://foosoft.net/projects/yomichan/dl/dict/jmnedict.zip)  *   **[KireiCake](https://kireicake.com/rikaicakes/)** (Japanese slang)      *   [kireicake.zip](https://foosoft.net/projects/yomichan/dl/dict/kireicake.zip)  *   **[KANJIDIC](http://nihongo.monash.edu/kanjidic2/index.html)** (Japanese Kanji) -    *   [kanjidic_english.zip](https://foosoft.net/projects/yomichan/dl/dict/kanjidic_english.zip) -    *   [kanjidic_french.zip](https://foosoft.net/projects/yomichan/dl/dict/kanjidic_french.zip) -    *   [kanjidic_portuguese.zip](https://foosoft.net/projects/yomichan/dl/dict/kanjidic_portuguese.zip) -    *   [kanjidic_spanish.zip](https://foosoft.net/projects/yomichan/dl/dict/kanjidic_spanish.zip) +    *   [kanjidic\_english.zip](https://foosoft.net/projects/yomichan/dl/dict/kanjidic_english.zip) +    *   [kanjidic\_french.zip](https://foosoft.net/projects/yomichan/dl/dict/kanjidic_french.zip) +    *   [kanjidic\_portuguese.zip](https://foosoft.net/projects/yomichan/dl/dict/kanjidic_portuguese.zip) +    *   [kanjidic\_spanish.zip](https://foosoft.net/projects/yomichan/dl/dict/kanjidic_spanish.zip)  *   **[Innocent Corpus](https://forum.koohii.com/post-168613.html#pid168613)** (Term and Kanji frequencies across 5000+ novels) -    *   [innocent_corpus.zip](https://foosoft.net/projects/yomichan/dl/dict/innocent_corpus.zip) +    *   [innocent\_corpus.zip](https://foosoft.net/projects/yomichan/dl/dict/innocent_corpus.zip)  ## Basic Usage ## diff --git a/ext/bg/js/audio.js b/ext/bg/js/audio.js index 549288f5..2e5db7cc 100644 --- a/ext/bg/js/audio.js +++ b/ext/bg/js/audio.js @@ -69,10 +69,10 @@ async function audioBuildUrl(definition, mode, cache={}) {              const dom = new DOMParser().parseFromString(response, 'text/html');              for (const row of dom.getElementsByClassName('dc-result-row')) {                  try { -                    const url = row.getElementsByClassName('ill-onebuttonplayer').item(0).getAttribute('data-url'); +                    const url = row.querySelector('audio>source[src]').getAttribute('src');                      const reading = row.getElementsByClassName('dc-vocab_kana').item(0).innerText;                      if (url && reading && (!definition.reading || definition.reading === reading)) { -                        return url; +                        return audioUrlNormalize(url, 'https://www.japanesepod101.com', '/learningcenter/reference/');                      }                  } catch (e) {                      // NOP @@ -86,7 +86,7 @@ async function audioBuildUrl(definition, mode, cache={}) {                  resolve(response);              } else {                  const xhr = new XMLHttpRequest(); -                xhr.open('GET', `http://jisho.org/search/${definition.expression}`); +                xhr.open('GET', `https://jisho.org/search/${definition.expression}`);                  xhr.addEventListener('error', () => reject('Failed to scrape audio data'));                  xhr.addEventListener('load', () => {                      cache[definition.expression] = xhr.responseText; @@ -100,7 +100,10 @@ async function audioBuildUrl(definition, mode, cache={}) {                  const dom = new DOMParser().parseFromString(response, 'text/html');                  const audio = dom.getElementById(`audio_${definition.expression}:${definition.reading}`);                  if (audio) { -                    return audio.getElementsByTagName('source').item(0).getAttribute('src'); +                    const url = audio.getElementsByTagName('source').item(0).getAttribute('src'); +                    if (url) { +                        return audioUrlNormalize(url, 'https://jisho.org', '/search/'); +                    }                  }              } catch (e) {                  // NOP @@ -112,6 +115,24 @@ async function audioBuildUrl(definition, mode, cache={}) {      }  } +function audioUrlNormalize(url, baseUrl, basePath) { +    if (url) { +        if (url[0] === '/') { +            if (url.length >= 2 && url[1] === '/') { +                // Begins with "//" +                url = baseUrl.substr(0, baseUrl.indexOf(':') + 1) + url; +            } else { +                // Begins with "/" +                url = baseUrl + url; +            } +        } else if (!/^[a-z][a-z0-9\+\-\.]*:/i.test(url)) { +            // No URI scheme => relative path +            url = baseUrl + basePath + url; +        } +    } +    return url; +} +  function audioBuildFilename(definition) {      if (definition.reading || definition.expression) {          let filename = 'yomichan'; |