diff --git a/src/background.js b/src/background.js index a965285..617b278 100644 --- a/src/background.js +++ b/src/background.js @@ -45,9 +45,24 @@ const updateCache = async (token, oldLevel, newLevel) => { // Turn the array of levels into a comma separated list var levelURLString = levelArray.join(",") - // API endpoint + response data buffers + // Data buffers + var vocabulary = new Set(); + var kanji = new Set(); + + // If the old level is less than the new level add the old data to the new data + if(oldLevel < newLevel) + { + await chrome.storage.local.get(["vocabulary", "kanji"], (data) => { + if(data.vocabulary !== undefined && data.kanji !== undefined) + { + data.vocabulary.forEach(vocabulary.add, vocabulary) + data.kanji.forEach(kanji.add, kanji) + } + }) + } + + // API endpoint var url = "https://api.wanikani.com/v2/subjects?types=vocabulary&levels=" + levelURLString - var vocabulary = [] // WaniKani only sends 1000 elements in one response and then provides us with a link to the // next "page" of the data. We need to loop until the next page is null @@ -59,14 +74,14 @@ const updateCache = async (token, oldLevel, newLevel) => { break for(let i in response.data) - vocabulary.push(response.data[i].data.characters) + vocabulary.add(response.data[i].data.characters) url = response.pages.next_url } while(url !== null) // Extract Kanji as well var url = "https://api.wanikani.com/v2/subjects?types=kanji&levels=" + levelURLString - var kanji = [] + var kanji = new Set() do { @@ -75,24 +90,15 @@ const updateCache = async (token, oldLevel, newLevel) => { break for(let i in response.data) - kanji.push(response.data[i].data.characters) + kanji.add(response.data[i].data.characters) url = response.pages.next_url } while(url !== null) - - // If the old level is less than the new level add the old data to the new data - if(oldLevel < newLevel) - { - await chrome.storage.local.get(["vocabulary", "kanji"], (data) => { - vocabulary.concat(data.vocabulary) - kanji.concat(data.kanji) - }) - } // Cache the data chrome.storage.local.set({ - "vocabulary": vocabulary, - "kanji": kanji, + "vocabulary": [...vocabulary], + "kanji": [...kanji], "level": newLevel }) }