Merge pull request #299 from nagisa77/codex/improve-menu-loading-behavior

Implement menu caching
This commit is contained in:
Tim
2025-08-01 11:25:16 +08:00
committed by GitHub

View File

@@ -167,38 +167,68 @@ export default {
notificationState.unreadCount = 0 notificationState.unreadCount = 0
} }
} }
await updateCount()
watch(() => authState.loggedIn, async () => { watch(() => authState.loggedIn, async () => {
await updateCount() await updateCount()
}) })
const CAT_CACHE_KEY = 'menu-categories'
const TAG_CACHE_KEY = 'menu-tags'
const cachedCategories = localStorage.getItem(CAT_CACHE_KEY)
if (cachedCategories) {
try { try {
this.isLoadingCategory = true this.categories = JSON.parse(cachedCategories)
fetch(`${API_BASE_URL}/api/categories`).then( } catch { /* ignore */ }
res => { }
const cachedTags = localStorage.getItem(TAG_CACHE_KEY)
if (cachedTags) {
try {
this.tags = JSON.parse(cachedTags)
} catch { /* ignore */ }
}
this.isLoadingCategory = !cachedCategories
this.isLoadingTag = !cachedTags
const fetchCategories = () => {
fetch(`${API_BASE_URL}/api/categories`).then(res => {
if (res.ok) { if (res.ok) {
res.json().then(data => { res.json().then(data => {
this.categories = data.slice(0, 10) this.categories = data.slice(0, 10)
localStorage.setItem(CAT_CACHE_KEY, JSON.stringify(this.categories))
}) })
} }
this.isLoadingCategory = false this.isLoadingCategory = false
})
} }
)
} catch { /* ignore */ }
try { const fetchTags = () => {
this.isLoadingTag = true fetch(`${API_BASE_URL}/api/tags?limit=10`).then(res => {
fetch(`${API_BASE_URL}/api/tags?limit=10`).then(
res => {
if (res.ok) { if (res.ok) {
res.json().then(data => { res.json().then(data => {
this.tags = data this.tags = data
localStorage.setItem(TAG_CACHE_KEY, JSON.stringify(this.tags))
}) })
} }
this.isLoadingTag = false this.isLoadingTag = false
})
} }
)
} catch { /* ignore */ } if (cachedCategories) {
setTimeout(fetchCategories, 1500)
} else {
fetchCategories()
}
if (cachedTags) {
setTimeout(fetchTags, 1500)
} else {
fetchTags()
}
await updateCount()
}, },
methods: { methods: {
cycleTheme, cycleTheme,