create-vike 0.0.4 → 0.0.304
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.testRun.ts +118 -0
- package/boilerplate-react/.eslintrc.cjs +17 -0
- package/boilerplate-react/.test-dev.test.ts +2 -0
- package/boilerplate-react/.test-prod.test.ts +2 -0
- package/boilerplate-react/.testCiJob.json +1 -0
- package/boilerplate-react/_gitignore +2 -0
- package/boilerplate-react/package.json +27 -0
- package/boilerplate-react/pages/about/code.css +6 -0
- package/boilerplate-react/pages/about/index.page.jsx +14 -0
- package/{files/js/react → boilerplate-react}/pages/index/Counter.jsx +4 -4
- package/{files/js/react → boilerplate-react}/pages/index/index.page.jsx +3 -4
- package/boilerplate-react/renderer/Link.jsx +14 -0
- package/boilerplate-react/renderer/PageShell.css +19 -0
- package/{files/js/react/renderer/PageWrapper.jsx → boilerplate-react/renderer/PageShell.jsx} +36 -21
- package/boilerplate-react/renderer/PropTypeValues.js +3 -0
- package/boilerplate-react/renderer/_default.page.client.jsx +22 -0
- package/boilerplate-react/renderer/_default.page.server.jsx +45 -0
- package/{files/js/react → boilerplate-react}/renderer/_error.page.jsx +8 -5
- package/boilerplate-react/renderer/logo.svg +36 -0
- package/boilerplate-react/renderer/usePageContext.jsx +25 -0
- package/boilerplate-react/server/index.js +74 -0
- package/boilerplate-react/server/root.js +8 -0
- package/boilerplate-react/vite.config.js +6 -0
- package/boilerplate-react-ts/.eslintrc.cjs +19 -0
- package/boilerplate-react-ts/.test-dev.test.ts +2 -0
- package/boilerplate-react-ts/.test-prod.test.ts +2 -0
- package/boilerplate-react-ts/.testCiJob.json +1 -0
- package/boilerplate-react-ts/_gitignore +2 -0
- package/boilerplate-react-ts/package.json +36 -0
- package/boilerplate-react-ts/pages/about/code.css +6 -0
- package/boilerplate-react-ts/pages/about/index.page.tsx +14 -0
- package/{files/ts/react → boilerplate-react-ts}/pages/index/Counter.tsx +4 -4
- package/{files/ts/react → boilerplate-react-ts}/pages/index/index.page.tsx +3 -4
- package/boilerplate-react-ts/renderer/Link.tsx +9 -0
- package/{files/ts/react/renderer/PageWrapper.tsx → boilerplate-react-ts/renderer/PageShell.tsx} +22 -28
- package/boilerplate-react-ts/renderer/_default.page.client.tsx +23 -0
- package/boilerplate-react-ts/renderer/_default.page.server.tsx +46 -0
- package/{files/ts/react → boilerplate-react-ts}/renderer/_error.page.tsx +4 -6
- package/boilerplate-react-ts/renderer/types.ts +35 -0
- package/boilerplate-react-ts/renderer/usePageContext.tsx +20 -0
- package/boilerplate-react-ts/server/index.ts +74 -0
- package/boilerplate-react-ts/server/root.ts +8 -0
- package/boilerplate-react-ts/server/tsconfig.json +9 -0
- package/boilerplate-react-ts/tsconfig.json +22 -0
- package/boilerplate-react-ts/vite.config.ts +9 -0
- package/boilerplate-vue/.test-dev.test.ts +2 -0
- package/boilerplate-vue/.test-prod.test.ts +2 -0
- package/boilerplate-vue/.testCiJob.json +1 -0
- package/boilerplate-vue/_gitignore +2 -0
- package/boilerplate-vue/package.json +22 -0
- package/boilerplate-vue/pages/about/index.page.vue +13 -0
- package/boilerplate-vue/pages/index/Counter.vue +8 -0
- package/{files/js/vue → boilerplate-vue}/pages/index/index.page.vue +1 -1
- package/{files/js/vue → boilerplate-vue}/renderer/Link.vue +2 -2
- package/{files/js/vue/renderer/PageWrapper.vue → boilerplate-vue/renderer/PageShell.vue} +1 -1
- package/boilerplate-vue/renderer/_default.page.client.js +15 -0
- package/boilerplate-vue/renderer/_default.page.server.js +54 -0
- package/{files/js/vue → boilerplate-vue}/renderer/_error.page.vue +2 -2
- package/boilerplate-vue/renderer/app.js +28 -0
- package/boilerplate-vue/renderer/logo.svg +36 -0
- package/boilerplate-vue/renderer/usePageContext.js +18 -0
- package/boilerplate-vue/server/index.js +74 -0
- package/boilerplate-vue/server/root.js +8 -0
- package/boilerplate-vue/vite.config.js +6 -0
- package/boilerplate-vue-ts/.test-dev.test.ts +2 -0
- package/boilerplate-vue-ts/.test-prod.test.ts +2 -0
- package/boilerplate-vue-ts/.testCiJob.json +1 -0
- package/boilerplate-vue-ts/_gitignore +2 -0
- package/boilerplate-vue-ts/package.json +28 -0
- package/boilerplate-vue-ts/pages/about/index.page.vue +13 -0
- package/boilerplate-vue-ts/pages/index/Counter.vue +8 -0
- package/{files/ts/vue → boilerplate-vue-ts}/pages/index/index.page.vue +1 -1
- package/{files/ts/vue → boilerplate-vue-ts}/renderer/Link.vue +2 -2
- package/{files/ts/vue/renderer/PageWrapper.vue → boilerplate-vue-ts/renderer/PageShell.vue} +1 -1
- package/boilerplate-vue-ts/renderer/_default.page.client.ts +16 -0
- package/boilerplate-vue-ts/renderer/_default.page.server.ts +56 -0
- package/{files/ts/vue → boilerplate-vue-ts}/renderer/_error.page.vue +2 -2
- package/boilerplate-vue-ts/renderer/app.ts +29 -0
- package/boilerplate-vue-ts/renderer/logo.svg +36 -0
- package/boilerplate-vue-ts/renderer/types.ts +38 -0
- package/boilerplate-vue-ts/renderer/usePageContext.ts +21 -0
- package/boilerplate-vue-ts/server/index.ts +74 -0
- package/boilerplate-vue-ts/server/root.ts +8 -0
- package/boilerplate-vue-ts/server/tsconfig.json +9 -0
- package/boilerplate-vue-ts/tsconfig.json +21 -0
- package/boilerplate-vue-ts/vite.config.ts +9 -0
- package/boilerplate-vue-ts/vue.d.ts +4 -0
- package/index.js +222 -0
- package/package.json +13 -52
- package/README.md +0 -30
- package/create-vike.js +0 -2
- package/dist/index.js +0 -402
- package/files/js/react/pages/about/index.page.jsx +0 -13
- package/files/js/react/renderer/Link.jsx +0 -15
- package/files/js/react/renderer/_default.page.client.jsx +0 -19
- package/files/js/react/renderer/_default.page.server.jsx +0 -47
- package/files/js/react/renderer/usePageContext.jsx +0 -18
- package/files/js/react+client-router/renderer/_default.page.client.jsx +0 -43
- package/files/js/react+client-router/renderer/types.js +0 -1
- package/files/js/vike/server/index.js +0 -40
- package/files/js/vue/pages/about/index.page.vue +0 -11
- package/files/js/vue/pages/index/Counter.vue +0 -10
- package/files/js/vue/renderer/_default.page.client.js +0 -12
- package/files/js/vue/renderer/_default.page.server.js +0 -41
- package/files/js/vue/renderer/app.js +0 -29
- package/files/js/vue/renderer/usePageContext.js +0 -18
- package/files/js/vue+client-router/renderer/_default.page.client.js +0 -23
- package/files/js/vue+client-router/renderer/app.js +0 -36
- package/files/js/vue+client-router/renderer/types.js +0 -1
- package/files/shared/.prettierrc +0 -1
- package/files/shared/react/pages/about/index.css +0 -4
- package/files/shared/vike/_gitignore +0 -121
- package/files/ts/react/pages/about/index.page.tsx +0 -13
- package/files/ts/react/renderer/Link.tsx +0 -19
- package/files/ts/react/renderer/_default.page.client.tsx +0 -21
- package/files/ts/react/renderer/_default.page.server.tsx +0 -49
- package/files/ts/react/renderer/types.ts +0 -11
- package/files/ts/react/renderer/usePageContext.tsx +0 -25
- package/files/ts/react+client-router/renderer/_default.page.client.tsx +0 -44
- package/files/ts/react+client-router/renderer/types.ts +0 -12
- package/files/ts/vike/server/index.ts +0 -40
- package/files/ts/vue/pages/about/index.page.vue +0 -11
- package/files/ts/vue/pages/index/Counter.vue +0 -10
- package/files/ts/vue/renderer/_default.page.client.ts +0 -14
- package/files/ts/vue/renderer/_default.page.server.ts +0 -43
- package/files/ts/vue/renderer/app.ts +0 -30
- package/files/ts/vue/renderer/types.ts +0 -10
- package/files/ts/vue/renderer/usePageContext.ts +0 -20
- package/files/ts/vue/vue.d.ts +0 -4
- package/files/ts/vue+client-router/renderer/_default.page.client.ts +0 -24
- package/files/ts/vue+client-router/renderer/app.ts +0 -37
- package/files/ts/vue+client-router/renderer/types.ts +0 -11
- /package/{files/shared/react/renderer/PageWrapper.css → boilerplate-react-ts/renderer/PageShell.css} +0 -0
- /package/{files/shared/vike → boilerplate-react-ts}/renderer/logo.svg +0 -0
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { createSSRApp, h } from "vue";
|
|
2
|
-
import PageWrapper from "./PageWrapper.vue";
|
|
3
|
-
import { setPageContext } from "./usePageContext";
|
|
4
|
-
|
|
5
|
-
export { createApp };
|
|
6
|
-
|
|
7
|
-
function createApp(pageContext) {
|
|
8
|
-
const { Page, pageProps } = pageContext;
|
|
9
|
-
const PageWithLayout = {
|
|
10
|
-
render() {
|
|
11
|
-
return h(
|
|
12
|
-
PageWrapper,
|
|
13
|
-
{},
|
|
14
|
-
{
|
|
15
|
-
default() {
|
|
16
|
-
return h(Page, pageProps || {});
|
|
17
|
-
},
|
|
18
|
-
}
|
|
19
|
-
);
|
|
20
|
-
},
|
|
21
|
-
};
|
|
22
|
-
|
|
23
|
-
const app = createSSRApp(PageWithLayout);
|
|
24
|
-
|
|
25
|
-
// Make `pageContext` available from any Vue component
|
|
26
|
-
setPageContext(app, pageContext);
|
|
27
|
-
|
|
28
|
-
return app;
|
|
29
|
-
}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
// Hook `usePageContext()` to make `pageContext` available from any Vue component.
|
|
2
|
-
// See https://vite-plugin-ssr.com/pageContext-anywhere
|
|
3
|
-
|
|
4
|
-
import { inject } from "vue";
|
|
5
|
-
|
|
6
|
-
export { usePageContext };
|
|
7
|
-
export { setPageContext };
|
|
8
|
-
|
|
9
|
-
const key = Symbol();
|
|
10
|
-
|
|
11
|
-
function usePageContext() {
|
|
12
|
-
const pageContext = inject(key);
|
|
13
|
-
return pageContext;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
function setPageContext(app, pageContext) {
|
|
17
|
-
app.provide(key, pageContext);
|
|
18
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { useClientRouter } from "vite-plugin-ssr/client/router";
|
|
2
|
-
import { createApp } from "./app";
|
|
3
|
-
|
|
4
|
-
useClientRouter({
|
|
5
|
-
async render(pageContext) {
|
|
6
|
-
const app = createApp(pageContext);
|
|
7
|
-
app.mount("#app");
|
|
8
|
-
},
|
|
9
|
-
|
|
10
|
-
ensureHydration: true,
|
|
11
|
-
|
|
12
|
-
prefetchLinks: true,
|
|
13
|
-
|
|
14
|
-
onTransitionStart() {
|
|
15
|
-
// Page transition started
|
|
16
|
-
},
|
|
17
|
-
|
|
18
|
-
onTransitionEnd() {
|
|
19
|
-
// Page transition ended
|
|
20
|
-
},
|
|
21
|
-
}).hydrationPromise.then(() => {
|
|
22
|
-
// Hydration finished; page is now interactive
|
|
23
|
-
});
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
createApp as createVueApp,
|
|
3
|
-
createSSRApp,
|
|
4
|
-
defineComponent,
|
|
5
|
-
h,
|
|
6
|
-
} from "vue";
|
|
7
|
-
import PageWrapper from "./PageWrapper.vue";
|
|
8
|
-
import { setPageContext } from "./usePageContext";
|
|
9
|
-
|
|
10
|
-
export { createApp };
|
|
11
|
-
|
|
12
|
-
function createApp(pageContext) {
|
|
13
|
-
const { Page, pageProps } = pageContext;
|
|
14
|
-
const PageWithLayout = defineComponent({
|
|
15
|
-
render() {
|
|
16
|
-
return h(
|
|
17
|
-
PageWrapper,
|
|
18
|
-
{},
|
|
19
|
-
{
|
|
20
|
-
default() {
|
|
21
|
-
return h(Page, pageProps || {});
|
|
22
|
-
},
|
|
23
|
-
}
|
|
24
|
-
);
|
|
25
|
-
},
|
|
26
|
-
});
|
|
27
|
-
|
|
28
|
-
const app = pageContext.isHydration
|
|
29
|
-
? createSSRApp(PageWithLayout)
|
|
30
|
-
: createVueApp(PageWithLayout);
|
|
31
|
-
|
|
32
|
-
// Make `pageContext` available from any Vue component
|
|
33
|
-
setPageContext(app, pageContext);
|
|
34
|
-
|
|
35
|
-
return app;
|
|
36
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/files/shared/.prettierrc
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{}
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
# Logs
|
|
2
|
-
logs
|
|
3
|
-
*.log
|
|
4
|
-
npm-debug.log*
|
|
5
|
-
yarn-debug.log*
|
|
6
|
-
yarn-error.log*
|
|
7
|
-
lerna-debug.log*
|
|
8
|
-
.pnpm-debug.log*
|
|
9
|
-
|
|
10
|
-
# Diagnostic reports (https://nodejs.org/api/report.html)
|
|
11
|
-
report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json
|
|
12
|
-
|
|
13
|
-
# Runtime data
|
|
14
|
-
pids
|
|
15
|
-
*.pid
|
|
16
|
-
*.seed
|
|
17
|
-
*.pid.lock
|
|
18
|
-
|
|
19
|
-
# Directory for instrumented libs generated by jscoverage/JSCover
|
|
20
|
-
lib-cov
|
|
21
|
-
|
|
22
|
-
# Coverage directory used by tools like istanbul
|
|
23
|
-
coverage
|
|
24
|
-
*.lcov
|
|
25
|
-
|
|
26
|
-
# nyc test coverage
|
|
27
|
-
.nyc_output
|
|
28
|
-
|
|
29
|
-
# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files)
|
|
30
|
-
.grunt
|
|
31
|
-
|
|
32
|
-
# Bower dependency directory (https://bower.io/)
|
|
33
|
-
bower_components
|
|
34
|
-
|
|
35
|
-
# node-waf configuration
|
|
36
|
-
.lock-wscript
|
|
37
|
-
|
|
38
|
-
# Compiled binary addons (https://nodejs.org/api/addons.html)
|
|
39
|
-
build/Release
|
|
40
|
-
|
|
41
|
-
# Dependency directories
|
|
42
|
-
node_modules/
|
|
43
|
-
jspm_packages/
|
|
44
|
-
|
|
45
|
-
# Snowpack dependency directory (https://snowpack.dev/)
|
|
46
|
-
web_modules/
|
|
47
|
-
|
|
48
|
-
# TypeScript cache
|
|
49
|
-
*.tsbuildinfo
|
|
50
|
-
|
|
51
|
-
# Optional npm cache directory
|
|
52
|
-
.npm
|
|
53
|
-
|
|
54
|
-
# Optional eslint cache
|
|
55
|
-
.eslintcache
|
|
56
|
-
|
|
57
|
-
# Microbundle cache
|
|
58
|
-
.rpt2_cache/
|
|
59
|
-
.rts2_cache_cjs/
|
|
60
|
-
.rts2_cache_es/
|
|
61
|
-
.rts2_cache_umd/
|
|
62
|
-
|
|
63
|
-
# Optional REPL history
|
|
64
|
-
.node_repl_history
|
|
65
|
-
|
|
66
|
-
# Output of 'npm pack'
|
|
67
|
-
*.tgz
|
|
68
|
-
|
|
69
|
-
# Yarn Integrity file
|
|
70
|
-
.yarn-integrity
|
|
71
|
-
|
|
72
|
-
# dotenv environment variables file
|
|
73
|
-
.env
|
|
74
|
-
.env.test
|
|
75
|
-
.env.production
|
|
76
|
-
|
|
77
|
-
# parcel-bundler cache (https://parceljs.org/)
|
|
78
|
-
.cache
|
|
79
|
-
.parcel-cache
|
|
80
|
-
|
|
81
|
-
# Next.js build output
|
|
82
|
-
.next
|
|
83
|
-
out
|
|
84
|
-
|
|
85
|
-
# Nuxt.js build / generate output
|
|
86
|
-
.nuxt
|
|
87
|
-
dist
|
|
88
|
-
|
|
89
|
-
# Gatsby files
|
|
90
|
-
.cache/
|
|
91
|
-
# Comment in the public line in if your project uses Gatsby and not Next.js
|
|
92
|
-
# https://nextjs.org/blog/next-9-1#public-directory-support
|
|
93
|
-
# public
|
|
94
|
-
|
|
95
|
-
# vuepress build output
|
|
96
|
-
.vuepress/dist
|
|
97
|
-
|
|
98
|
-
# Serverless directories
|
|
99
|
-
.serverless/
|
|
100
|
-
|
|
101
|
-
# FuseBox cache
|
|
102
|
-
.fusebox/
|
|
103
|
-
|
|
104
|
-
# DynamoDB Local files
|
|
105
|
-
.dynamodb/
|
|
106
|
-
|
|
107
|
-
# TernJS port file
|
|
108
|
-
.tern-port
|
|
109
|
-
|
|
110
|
-
# Stores VSCode versions used for testing VSCode extensions
|
|
111
|
-
.vscode-test
|
|
112
|
-
|
|
113
|
-
# yarn v2
|
|
114
|
-
.yarn/cache
|
|
115
|
-
.yarn/unplugged
|
|
116
|
-
.yarn/build-state.yml
|
|
117
|
-
.yarn/install-state.gz
|
|
118
|
-
.pnp.*
|
|
119
|
-
|
|
120
|
-
# Local files
|
|
121
|
-
*.local
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import React from "react";
|
|
2
|
-
import { usePageContext } from "./usePageContext";
|
|
3
|
-
|
|
4
|
-
export { Link };
|
|
5
|
-
|
|
6
|
-
function Link(props: {
|
|
7
|
-
href?: string;
|
|
8
|
-
className?: string;
|
|
9
|
-
children: React.ReactNode;
|
|
10
|
-
}) {
|
|
11
|
-
const pageContext = usePageContext();
|
|
12
|
-
const className = [
|
|
13
|
-
props.className,
|
|
14
|
-
pageContext.urlPathname === props.href && "is-active",
|
|
15
|
-
]
|
|
16
|
-
.filter(Boolean)
|
|
17
|
-
.join(" ");
|
|
18
|
-
return <a {...props} className={className} />;
|
|
19
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import ReactDOM from "react-dom";
|
|
2
|
-
import React from "react";
|
|
3
|
-
import { getPage } from "vite-plugin-ssr/client";
|
|
4
|
-
import { PageWrapper } from "./PageWrapper";
|
|
5
|
-
import type { PageContext } from "./types";
|
|
6
|
-
import type { PageContextBuiltInClient } from "vite-plugin-ssr/types";
|
|
7
|
-
|
|
8
|
-
hydrate();
|
|
9
|
-
|
|
10
|
-
async function hydrate() {
|
|
11
|
-
// We do Server Routing, but we can also do Client Routing by using `useClientRouter()`
|
|
12
|
-
// instead of `getPage()`, see https://vite-plugin-ssr.com/useClientRouter
|
|
13
|
-
const pageContext = await getPage<PageContextBuiltInClient & PageContext>();
|
|
14
|
-
const { Page, pageProps } = pageContext;
|
|
15
|
-
ReactDOM.hydrate(
|
|
16
|
-
<PageWrapper pageContext={pageContext}>
|
|
17
|
-
<Page {...pageProps} />
|
|
18
|
-
</PageWrapper>,
|
|
19
|
-
document.getElementById("page-view")
|
|
20
|
-
);
|
|
21
|
-
}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import ReactDOMServer from "react-dom/server";
|
|
2
|
-
import React from "react";
|
|
3
|
-
import { PageWrapper } from "./PageWrapper";
|
|
4
|
-
import { escapeInject, dangerouslySkipEscape } from "vite-plugin-ssr";
|
|
5
|
-
import logoUrl from "./logo.svg";
|
|
6
|
-
import type { PageContext } from "./types";
|
|
7
|
-
import type { PageContextBuiltIn } from "vite-plugin-ssr/types";
|
|
8
|
-
|
|
9
|
-
export { render };
|
|
10
|
-
|
|
11
|
-
// See https://vite-plugin-ssr.com/data-fetching
|
|
12
|
-
export const passToClient = ["pageProps", "urlPathname"];
|
|
13
|
-
|
|
14
|
-
async function render(pageContext: PageContextBuiltIn & PageContext) {
|
|
15
|
-
const { Page, pageProps } = pageContext;
|
|
16
|
-
const pageHtml = ReactDOMServer.renderToString(
|
|
17
|
-
<PageWrapper pageContext={pageContext}>
|
|
18
|
-
<Page {...pageProps} />
|
|
19
|
-
</PageWrapper>
|
|
20
|
-
);
|
|
21
|
-
|
|
22
|
-
// See https://vite-plugin-ssr.com/html-head
|
|
23
|
-
const { documentProps } = pageContext;
|
|
24
|
-
const title = (documentProps && documentProps.title) || "Vite SSR app";
|
|
25
|
-
const desc =
|
|
26
|
-
(documentProps && documentProps.description) ||
|
|
27
|
-
"App using Vite + vite-plugin-ssr";
|
|
28
|
-
|
|
29
|
-
const documentHtml = escapeInject`<!DOCTYPE html>
|
|
30
|
-
<html lang="en">
|
|
31
|
-
<head>
|
|
32
|
-
<meta charset="UTF-8" />
|
|
33
|
-
<link rel="icon" href="${logoUrl}" />
|
|
34
|
-
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
35
|
-
<meta name="description" content="${desc}" />
|
|
36
|
-
<title>${title}</title>
|
|
37
|
-
</head>
|
|
38
|
-
<body>
|
|
39
|
-
<div id="page-view">${dangerouslySkipEscape(pageHtml)}</div>
|
|
40
|
-
</body>
|
|
41
|
-
</html>`;
|
|
42
|
-
|
|
43
|
-
return {
|
|
44
|
-
documentHtml,
|
|
45
|
-
pageContext: {
|
|
46
|
-
// We can add some `pageContext` here, which is useful if we want to do page redirection https://vite-plugin-ssr.com/page-redirection
|
|
47
|
-
},
|
|
48
|
-
};
|
|
49
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
export type PageProps = {};
|
|
2
|
-
// The `pageContext` that are available in both on the server-side and browser-side
|
|
3
|
-
export type PageContext = {
|
|
4
|
-
Page: (pageProps: PageProps) => React.ReactElement;
|
|
5
|
-
pageProps: PageProps;
|
|
6
|
-
urlPathname: string;
|
|
7
|
-
documentProps?: {
|
|
8
|
-
title?: string;
|
|
9
|
-
description?: string;
|
|
10
|
-
};
|
|
11
|
-
};
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
// `usePageContext` allows us to access `pageContext` in any React component.
|
|
2
|
-
// More infos: https://vite-plugin-ssr.com/pageContext-anywhere
|
|
3
|
-
|
|
4
|
-
import React, { useContext } from "react";
|
|
5
|
-
import type { PageContext } from "./types";
|
|
6
|
-
|
|
7
|
-
export { PageContextProvider };
|
|
8
|
-
export { usePageContext };
|
|
9
|
-
|
|
10
|
-
const Context = React.createContext<PageContext>(undefined as any);
|
|
11
|
-
|
|
12
|
-
function PageContextProvider({
|
|
13
|
-
pageContext,
|
|
14
|
-
children,
|
|
15
|
-
}: {
|
|
16
|
-
pageContext: PageContext;
|
|
17
|
-
children: React.ReactNode;
|
|
18
|
-
}) {
|
|
19
|
-
return <Context.Provider value={pageContext}>{children}</Context.Provider>;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
function usePageContext() {
|
|
23
|
-
const pageContext = useContext(Context);
|
|
24
|
-
return pageContext;
|
|
25
|
-
}
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
import ReactDOM from "react-dom";
|
|
2
|
-
import React from "react";
|
|
3
|
-
import { useClientRouter } from "vite-plugin-ssr/client/router";
|
|
4
|
-
import { PageWrapper } from "./PageWrapper";
|
|
5
|
-
import { PageContext } from "./types";
|
|
6
|
-
|
|
7
|
-
useClientRouter({
|
|
8
|
-
async render(pageContext: PageContext) {
|
|
9
|
-
if (pageContext.isHydration) {
|
|
10
|
-
// When we render the first page. (Since we do SSR, the first page is already
|
|
11
|
-
// rendered to HTML and we merely have to hydrate it.)
|
|
12
|
-
const { Page, pageProps } = pageContext;
|
|
13
|
-
ReactDOM.hydrate(
|
|
14
|
-
<PageWrapper pageContext={pageContext}>
|
|
15
|
-
<Page {...pageProps} />
|
|
16
|
-
</PageWrapper>,
|
|
17
|
-
document.getElementById("page-view")
|
|
18
|
-
);
|
|
19
|
-
} else {
|
|
20
|
-
// When the user navigates to a new page.
|
|
21
|
-
const { Page, pageProps } = pageContext;
|
|
22
|
-
ReactDOM.render(
|
|
23
|
-
<PageWrapper pageContext={pageContext}>
|
|
24
|
-
<Page {...pageProps} />
|
|
25
|
-
</PageWrapper>,
|
|
26
|
-
document.getElementById("page-view")
|
|
27
|
-
);
|
|
28
|
-
}
|
|
29
|
-
},
|
|
30
|
-
|
|
31
|
-
ensureHydration: true,
|
|
32
|
-
|
|
33
|
-
prefetchLinks: true,
|
|
34
|
-
|
|
35
|
-
onTransitionStart() {
|
|
36
|
-
// Page transition started
|
|
37
|
-
},
|
|
38
|
-
|
|
39
|
-
onTransitionEnd() {
|
|
40
|
-
// Page transition ended
|
|
41
|
-
},
|
|
42
|
-
}).hydrationPromise.then(() => {
|
|
43
|
-
// Hydration finished; page is now interactive
|
|
44
|
-
});
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
export type PageProps = {};
|
|
2
|
-
// The `pageContext` that are available in both on the server-side and browser-side
|
|
3
|
-
export type PageContext = {
|
|
4
|
-
Page: (pageProps: PageProps) => React.ReactElement;
|
|
5
|
-
isHydration: boolean;
|
|
6
|
-
pageProps: PageProps;
|
|
7
|
-
urlPathname: string;
|
|
8
|
-
documentProps?: {
|
|
9
|
-
title?: string;
|
|
10
|
-
description?: string;
|
|
11
|
-
};
|
|
12
|
-
};
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import express from "express";
|
|
2
|
-
import { createPageRenderer } from "vite-plugin-ssr";
|
|
3
|
-
|
|
4
|
-
const isProduction = process.env.NODE_ENV === "production";
|
|
5
|
-
const root = `${__dirname}/..`;
|
|
6
|
-
|
|
7
|
-
startServer();
|
|
8
|
-
|
|
9
|
-
async function startServer() {
|
|
10
|
-
const app = express();
|
|
11
|
-
|
|
12
|
-
let viteDevServer;
|
|
13
|
-
if (isProduction) {
|
|
14
|
-
app.use(express.static(`${root}/dist/client`));
|
|
15
|
-
} else {
|
|
16
|
-
const vite = require("vite");
|
|
17
|
-
viteDevServer = await vite.createServer({
|
|
18
|
-
root,
|
|
19
|
-
server: { middlewareMode: true },
|
|
20
|
-
});
|
|
21
|
-
app.use(viteDevServer.middlewares);
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
const renderPage = createPageRenderer({ viteDevServer, isProduction, root });
|
|
25
|
-
app.get("*", async (req, res, next) => {
|
|
26
|
-
const url = req.originalUrl;
|
|
27
|
-
const pageContextInit = {
|
|
28
|
-
url,
|
|
29
|
-
};
|
|
30
|
-
const pageContext = await renderPage(pageContextInit);
|
|
31
|
-
const { httpResponse } = pageContext;
|
|
32
|
-
if (!httpResponse) return next();
|
|
33
|
-
const { statusCode, body } = httpResponse;
|
|
34
|
-
res.status(statusCode).send(body);
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
const port = process.env.PORT || 3000;
|
|
38
|
-
app.listen(port);
|
|
39
|
-
console.log(`Server running at http://localhost:${port}`);
|
|
40
|
-
}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { getPage } from "vite-plugin-ssr/client";
|
|
2
|
-
import { createApp } from "./app";
|
|
3
|
-
import type { PageContext } from "./types";
|
|
4
|
-
import type { PageContextBuiltInClient } from "vite-plugin-ssr/types";
|
|
5
|
-
|
|
6
|
-
hydrate();
|
|
7
|
-
|
|
8
|
-
async function hydrate() {
|
|
9
|
-
// We do Server Routing, but we can also do Client Routing by using `useClientRouter()`
|
|
10
|
-
// instead of `getPage()`, see https://vite-plugin-ssr.com/useClientRouter
|
|
11
|
-
const pageContext = await getPage<PageContextBuiltInClient & PageContext>();
|
|
12
|
-
const app = createApp(pageContext);
|
|
13
|
-
app.mount("#app");
|
|
14
|
-
}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
import { renderToString } from "@vue/server-renderer";
|
|
2
|
-
import { escapeInject, dangerouslySkipEscape } from "vite-plugin-ssr";
|
|
3
|
-
import { createApp } from "./app";
|
|
4
|
-
import logoUrl from "./logo.svg";
|
|
5
|
-
import type { PageContext } from "./types";
|
|
6
|
-
import type { PageContextBuiltIn } from "vite-plugin-ssr/types";
|
|
7
|
-
|
|
8
|
-
export { render };
|
|
9
|
-
// See https://vite-plugin-ssr.com/data-fetching
|
|
10
|
-
export const passToClient = ["pageProps", "urlPathname"];
|
|
11
|
-
|
|
12
|
-
async function render(pageContext: PageContextBuiltIn & PageContext) {
|
|
13
|
-
const app = createApp(pageContext);
|
|
14
|
-
const appHtml = await renderToString(app);
|
|
15
|
-
|
|
16
|
-
// See https://vite-plugin-ssr.com/html-head
|
|
17
|
-
const { documentProps } = pageContext;
|
|
18
|
-
const title = (documentProps && documentProps.title) || "Vite SSR app";
|
|
19
|
-
const desc =
|
|
20
|
-
(documentProps && documentProps.description) ||
|
|
21
|
-
"App using Vite + vite-plugin-ssr";
|
|
22
|
-
|
|
23
|
-
const documentHtml = escapeInject`<!DOCTYPE html>
|
|
24
|
-
<html lang="en">
|
|
25
|
-
<head>
|
|
26
|
-
<meta charset="UTF-8" />
|
|
27
|
-
<link rel="icon" href="${logoUrl}" />
|
|
28
|
-
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
29
|
-
<meta name="description" content="${desc}" />
|
|
30
|
-
<title>${title}</title>
|
|
31
|
-
</head>
|
|
32
|
-
<body>
|
|
33
|
-
<div id="app">${dangerouslySkipEscape(appHtml)}</div>
|
|
34
|
-
</body>
|
|
35
|
-
</html>`;
|
|
36
|
-
|
|
37
|
-
return {
|
|
38
|
-
documentHtml,
|
|
39
|
-
pageContext: {
|
|
40
|
-
// We can add some `pageContext` here, which is useful if we want to do page redirection https://vite-plugin-ssr.com/page-redirection
|
|
41
|
-
},
|
|
42
|
-
};
|
|
43
|
-
}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import { createSSRApp, defineComponent, h } from "vue";
|
|
2
|
-
import PageWrapper from "./PageWrapper.vue";
|
|
3
|
-
import { setPageContext } from "./usePageContext";
|
|
4
|
-
import type { PageContext } from "./types";
|
|
5
|
-
|
|
6
|
-
export { createApp };
|
|
7
|
-
|
|
8
|
-
function createApp(pageContext: PageContext) {
|
|
9
|
-
const { Page, pageProps } = pageContext;
|
|
10
|
-
const PageWithLayout = defineComponent({
|
|
11
|
-
render() {
|
|
12
|
-
return h(
|
|
13
|
-
PageWrapper,
|
|
14
|
-
{},
|
|
15
|
-
{
|
|
16
|
-
default() {
|
|
17
|
-
return h(Page, pageProps || {});
|
|
18
|
-
},
|
|
19
|
-
}
|
|
20
|
-
);
|
|
21
|
-
},
|
|
22
|
-
});
|
|
23
|
-
|
|
24
|
-
const app = createSSRApp(PageWithLayout);
|
|
25
|
-
|
|
26
|
-
// Make `pageContext` available from any Vue component
|
|
27
|
-
setPageContext(app, pageContext);
|
|
28
|
-
|
|
29
|
-
return app;
|
|
30
|
-
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
// Hook `usePageContext()` to make `pageContext` available from any Vue component.
|
|
2
|
-
// See https://vite-plugin-ssr.com/pageContext-anywhere
|
|
3
|
-
|
|
4
|
-
import { inject } from "vue";
|
|
5
|
-
import type { App } from "vue";
|
|
6
|
-
import { PageContext } from "./types";
|
|
7
|
-
|
|
8
|
-
export { usePageContext };
|
|
9
|
-
export { setPageContext };
|
|
10
|
-
|
|
11
|
-
const key = Symbol();
|
|
12
|
-
|
|
13
|
-
function usePageContext() {
|
|
14
|
-
const pageContext = inject(key);
|
|
15
|
-
return pageContext;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
function setPageContext(app: App, pageContext: PageContext) {
|
|
19
|
-
app.provide(key, pageContext);
|
|
20
|
-
}
|
package/files/ts/vue/vue.d.ts
DELETED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { useClientRouter } from "vite-plugin-ssr/client/router";
|
|
2
|
-
import { createApp } from "./app";
|
|
3
|
-
import { PageContext } from "./types";
|
|
4
|
-
|
|
5
|
-
useClientRouter({
|
|
6
|
-
async render(pageContext: PageContext) {
|
|
7
|
-
const app = createApp(pageContext);
|
|
8
|
-
app.mount("#app");
|
|
9
|
-
},
|
|
10
|
-
|
|
11
|
-
ensureHydration: true,
|
|
12
|
-
|
|
13
|
-
prefetchLinks: true,
|
|
14
|
-
|
|
15
|
-
onTransitionStart() {
|
|
16
|
-
// Page transition started
|
|
17
|
-
},
|
|
18
|
-
|
|
19
|
-
onTransitionEnd() {
|
|
20
|
-
// Page transition ended
|
|
21
|
-
},
|
|
22
|
-
}).hydrationPromise.then(() => {
|
|
23
|
-
// Hydration finished; page is now interactive
|
|
24
|
-
});
|