Browse Source

Have _loadPacks return the fetched packs

pull/58/head
Kévin Cocchi 2 years ago
parent
commit
5c8c72e341
No known key found for this signature in database GPG Key ID: E3F3FFBE2818518D
  1. 29
      web/src/index.js

29
web/src/index.js

@ -152,9 +152,16 @@ class App extends Component {
this._loadPacks(true) this._loadPacks(true)
} }
async populateStickersByID(allPacks) {
const allStickers = allPacks.map(({ stickers }) => stickers).flat()
allStickers.forEach((sticker) => {
this.stickersByID.set(sticker.id, sticker)
})
}
_loadPacks(disableCache = false) { _loadPacks(disableCache = false) {
const cache = disableCache ? "no-cache" : undefined const cache = disableCache ? "no-cache" : undefined
fetch(INDEX, { cache }).then(async indexRes => {
return fetch(INDEX, { cache }).then(async indexRes => {
if (indexRes.status >= 400) { if (indexRes.status >= 400) {
this.setState({ this.setState({
loading: false, loading: false,
@ -163,25 +170,25 @@ class App extends Component {
return return
} }
const indexData = await indexRes.json() const indexData = await indexRes.json()
const packNames = indexData.packs ?? []
HOMESERVER_URL = indexData.homeserver_url || HOMESERVER_URL HOMESERVER_URL = indexData.homeserver_url || HOMESERVER_URL
// TODO only load pack metadata when scrolled into view? // TODO only load pack metadata when scrolled into view?
for (const packFile of indexData.packs) {
const fetchedPacks = await Promise.all(packNames.map(async packFile => {
let packRes let packRes
if (packFile.startsWith("https://") || packFile.startsWith("http://")) { if (packFile.startsWith("https://") || packFile.startsWith("http://")) {
packRes = await fetch(packFile, { cache }) packRes = await fetch(packFile, { cache })
} else { } else {
packRes = await fetch(`${PACKS_BASE_URL}/${packFile}`, { cache }) packRes = await fetch(`${PACKS_BASE_URL}/${packFile}`, { cache })
} }
const packData = await packRes.json()
for (const sticker of packData.stickers) {
this.stickersByID.set(sticker.id, sticker)
}
this.setState({
packs: [...this.state.packs, packData],
loading: false,
})
}
return await packRes.json()
}))
this.setState({
packs: fetchedPacks,
loading: false,
})
this.populateStickersByID(fetchedPacks)
this.updateFrequentlyUsed() this.updateFrequentlyUsed()
return fetchedPacks
}, error => this.setState({ loading: false, error })) }, error => this.setState({ loading: false, error }))
} }

Loading…
Cancel
Save