-
-
Notifications
You must be signed in to change notification settings - Fork 21
/
clientEntry.js
66 lines (53 loc) · 1.52 KB
/
clientEntry.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/* global VUEPRESS_VERSION, LAST_COMMIT_HASH*/
import { createApp } from '@vuepress/core/lib/app/app.js'
import { sync } from 'vuex-router-sync';
const { app, router } = createApp(false /* isServer */)
const store = app.$options.store
if (window.__INITIAL_STATE__) {
store.replaceState(window.__INITIAL_STATE__);
}
sync(store, router);
window.__VUEPRESS_VERSION__ = {
version: VUEPRESS_VERSION,
hash: LAST_COMMIT_HASH
}
router.onReady(() => {
if (!window.__INITIAL_STATE__) {
fetchMetadata(router.currentRoute);
}
router.beforeResolve((to, from, next) => {
if (to.path === from.path) {
return next();
}
fetchMetadata(to).then(next, next);
});
app.$mount('#app')
})
function fetchMetadata(route) {
return new Promise((resolve, reject) => {
const page = findPageForPath(app.$site.pages, route.path);
if (!page) {
return resolve();
}
const metadataKey = page.metadataKey;
if (!metadataKey) {
// Ignore pages with no API metadata key
return resolve();
}
const versionedMetadataKey = `${page.version || 'next'}/${metadataKey}`;
if (store.state.metadata[versionedMetadataKey]) {
console.log('State data already available');
return resolve();
}
store.dispatch('fetchMetadata', versionedMetadataKey).then(resolve, reject);
});
}
function findPageForPath(pages, path) {
for (let i = 0; i < pages.length; i++) {
const page = pages[i]
if (page.path.toLowerCase() === path.toLowerCase()) {
return page
}
}
return null;
}