use set instead of arrays
This commit is contained in:
parent
eb71b38045
commit
77fb392e80
|
@ -45,9 +45,24 @@ const updateCache = async (token, oldLevel, newLevel) => {
|
||||||
// Turn the array of levels into a comma separated list
|
// Turn the array of levels into a comma separated list
|
||||||
var levelURLString = levelArray.join(",")
|
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 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
|
// 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
|
// 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
|
break
|
||||||
|
|
||||||
for(let i in response.data)
|
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
|
url = response.pages.next_url
|
||||||
} while(url !== null)
|
} while(url !== null)
|
||||||
|
|
||||||
// Extract Kanji as well
|
// Extract Kanji as well
|
||||||
var url = "https://api.wanikani.com/v2/subjects?types=kanji&levels=" + levelURLString
|
var url = "https://api.wanikani.com/v2/subjects?types=kanji&levels=" + levelURLString
|
||||||
var kanji = []
|
var kanji = new Set()
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
|
@ -75,24 +90,15 @@ const updateCache = async (token, oldLevel, newLevel) => {
|
||||||
break
|
break
|
||||||
|
|
||||||
for(let i in response.data)
|
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
|
url = response.pages.next_url
|
||||||
} while(url !== null)
|
} 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
|
// Cache the data
|
||||||
chrome.storage.local.set({
|
chrome.storage.local.set({
|
||||||
"vocabulary": vocabulary,
|
"vocabulary": [...vocabulary],
|
||||||
"kanji": kanji,
|
"kanji": [...kanji],
|
||||||
"level": newLevel
|
"level": newLevel
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue