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.
Files changed (134) hide show
  1. package/.testRun.ts +118 -0
  2. package/boilerplate-react/.eslintrc.cjs +17 -0
  3. package/boilerplate-react/.test-dev.test.ts +2 -0
  4. package/boilerplate-react/.test-prod.test.ts +2 -0
  5. package/boilerplate-react/.testCiJob.json +1 -0
  6. package/boilerplate-react/_gitignore +2 -0
  7. package/boilerplate-react/package.json +27 -0
  8. package/boilerplate-react/pages/about/code.css +6 -0
  9. package/boilerplate-react/pages/about/index.page.jsx +14 -0
  10. package/{files/js/react → boilerplate-react}/pages/index/Counter.jsx +4 -4
  11. package/{files/js/react → boilerplate-react}/pages/index/index.page.jsx +3 -4
  12. package/boilerplate-react/renderer/Link.jsx +14 -0
  13. package/boilerplate-react/renderer/PageShell.css +19 -0
  14. package/{files/js/react/renderer/PageWrapper.jsx → boilerplate-react/renderer/PageShell.jsx} +36 -21
  15. package/boilerplate-react/renderer/PropTypeValues.js +3 -0
  16. package/boilerplate-react/renderer/_default.page.client.jsx +22 -0
  17. package/boilerplate-react/renderer/_default.page.server.jsx +45 -0
  18. package/{files/js/react → boilerplate-react}/renderer/_error.page.jsx +8 -5
  19. package/boilerplate-react/renderer/logo.svg +36 -0
  20. package/boilerplate-react/renderer/usePageContext.jsx +25 -0
  21. package/boilerplate-react/server/index.js +74 -0
  22. package/boilerplate-react/server/root.js +8 -0
  23. package/boilerplate-react/vite.config.js +6 -0
  24. package/boilerplate-react-ts/.eslintrc.cjs +19 -0
  25. package/boilerplate-react-ts/.test-dev.test.ts +2 -0
  26. package/boilerplate-react-ts/.test-prod.test.ts +2 -0
  27. package/boilerplate-react-ts/.testCiJob.json +1 -0
  28. package/boilerplate-react-ts/_gitignore +2 -0
  29. package/boilerplate-react-ts/package.json +36 -0
  30. package/boilerplate-react-ts/pages/about/code.css +6 -0
  31. package/boilerplate-react-ts/pages/about/index.page.tsx +14 -0
  32. package/{files/ts/react → boilerplate-react-ts}/pages/index/Counter.tsx +4 -4
  33. package/{files/ts/react → boilerplate-react-ts}/pages/index/index.page.tsx +3 -4
  34. package/boilerplate-react-ts/renderer/Link.tsx +9 -0
  35. package/{files/ts/react/renderer/PageWrapper.tsx → boilerplate-react-ts/renderer/PageShell.tsx} +22 -28
  36. package/boilerplate-react-ts/renderer/_default.page.client.tsx +23 -0
  37. package/boilerplate-react-ts/renderer/_default.page.server.tsx +46 -0
  38. package/{files/ts/react → boilerplate-react-ts}/renderer/_error.page.tsx +4 -6
  39. package/boilerplate-react-ts/renderer/types.ts +35 -0
  40. package/boilerplate-react-ts/renderer/usePageContext.tsx +20 -0
  41. package/boilerplate-react-ts/server/index.ts +74 -0
  42. package/boilerplate-react-ts/server/root.ts +8 -0
  43. package/boilerplate-react-ts/server/tsconfig.json +9 -0
  44. package/boilerplate-react-ts/tsconfig.json +22 -0
  45. package/boilerplate-react-ts/vite.config.ts +9 -0
  46. package/boilerplate-vue/.test-dev.test.ts +2 -0
  47. package/boilerplate-vue/.test-prod.test.ts +2 -0
  48. package/boilerplate-vue/.testCiJob.json +1 -0
  49. package/boilerplate-vue/_gitignore +2 -0
  50. package/boilerplate-vue/package.json +22 -0
  51. package/boilerplate-vue/pages/about/index.page.vue +13 -0
  52. package/boilerplate-vue/pages/index/Counter.vue +8 -0
  53. package/{files/js/vue → boilerplate-vue}/pages/index/index.page.vue +1 -1
  54. package/{files/js/vue → boilerplate-vue}/renderer/Link.vue +2 -2
  55. package/{files/js/vue/renderer/PageWrapper.vue → boilerplate-vue/renderer/PageShell.vue} +1 -1
  56. package/boilerplate-vue/renderer/_default.page.client.js +15 -0
  57. package/boilerplate-vue/renderer/_default.page.server.js +54 -0
  58. package/{files/js/vue → boilerplate-vue}/renderer/_error.page.vue +2 -2
  59. package/boilerplate-vue/renderer/app.js +28 -0
  60. package/boilerplate-vue/renderer/logo.svg +36 -0
  61. package/boilerplate-vue/renderer/usePageContext.js +18 -0
  62. package/boilerplate-vue/server/index.js +74 -0
  63. package/boilerplate-vue/server/root.js +8 -0
  64. package/boilerplate-vue/vite.config.js +6 -0
  65. package/boilerplate-vue-ts/.test-dev.test.ts +2 -0
  66. package/boilerplate-vue-ts/.test-prod.test.ts +2 -0
  67. package/boilerplate-vue-ts/.testCiJob.json +1 -0
  68. package/boilerplate-vue-ts/_gitignore +2 -0
  69. package/boilerplate-vue-ts/package.json +28 -0
  70. package/boilerplate-vue-ts/pages/about/index.page.vue +13 -0
  71. package/boilerplate-vue-ts/pages/index/Counter.vue +8 -0
  72. package/{files/ts/vue → boilerplate-vue-ts}/pages/index/index.page.vue +1 -1
  73. package/{files/ts/vue → boilerplate-vue-ts}/renderer/Link.vue +2 -2
  74. package/{files/ts/vue/renderer/PageWrapper.vue → boilerplate-vue-ts/renderer/PageShell.vue} +1 -1
  75. package/boilerplate-vue-ts/renderer/_default.page.client.ts +16 -0
  76. package/boilerplate-vue-ts/renderer/_default.page.server.ts +56 -0
  77. package/{files/ts/vue → boilerplate-vue-ts}/renderer/_error.page.vue +2 -2
  78. package/boilerplate-vue-ts/renderer/app.ts +29 -0
  79. package/boilerplate-vue-ts/renderer/logo.svg +36 -0
  80. package/boilerplate-vue-ts/renderer/types.ts +38 -0
  81. package/boilerplate-vue-ts/renderer/usePageContext.ts +21 -0
  82. package/boilerplate-vue-ts/server/index.ts +74 -0
  83. package/boilerplate-vue-ts/server/root.ts +8 -0
  84. package/boilerplate-vue-ts/server/tsconfig.json +9 -0
  85. package/boilerplate-vue-ts/tsconfig.json +21 -0
  86. package/boilerplate-vue-ts/vite.config.ts +9 -0
  87. package/boilerplate-vue-ts/vue.d.ts +4 -0
  88. package/index.js +222 -0
  89. package/package.json +13 -52
  90. package/README.md +0 -30
  91. package/create-vike.js +0 -2
  92. package/dist/index.js +0 -402
  93. package/files/js/react/pages/about/index.page.jsx +0 -13
  94. package/files/js/react/renderer/Link.jsx +0 -15
  95. package/files/js/react/renderer/_default.page.client.jsx +0 -19
  96. package/files/js/react/renderer/_default.page.server.jsx +0 -47
  97. package/files/js/react/renderer/usePageContext.jsx +0 -18
  98. package/files/js/react+client-router/renderer/_default.page.client.jsx +0 -43
  99. package/files/js/react+client-router/renderer/types.js +0 -1
  100. package/files/js/vike/server/index.js +0 -40
  101. package/files/js/vue/pages/about/index.page.vue +0 -11
  102. package/files/js/vue/pages/index/Counter.vue +0 -10
  103. package/files/js/vue/renderer/_default.page.client.js +0 -12
  104. package/files/js/vue/renderer/_default.page.server.js +0 -41
  105. package/files/js/vue/renderer/app.js +0 -29
  106. package/files/js/vue/renderer/usePageContext.js +0 -18
  107. package/files/js/vue+client-router/renderer/_default.page.client.js +0 -23
  108. package/files/js/vue+client-router/renderer/app.js +0 -36
  109. package/files/js/vue+client-router/renderer/types.js +0 -1
  110. package/files/shared/.prettierrc +0 -1
  111. package/files/shared/react/pages/about/index.css +0 -4
  112. package/files/shared/vike/_gitignore +0 -121
  113. package/files/ts/react/pages/about/index.page.tsx +0 -13
  114. package/files/ts/react/renderer/Link.tsx +0 -19
  115. package/files/ts/react/renderer/_default.page.client.tsx +0 -21
  116. package/files/ts/react/renderer/_default.page.server.tsx +0 -49
  117. package/files/ts/react/renderer/types.ts +0 -11
  118. package/files/ts/react/renderer/usePageContext.tsx +0 -25
  119. package/files/ts/react+client-router/renderer/_default.page.client.tsx +0 -44
  120. package/files/ts/react+client-router/renderer/types.ts +0 -12
  121. package/files/ts/vike/server/index.ts +0 -40
  122. package/files/ts/vue/pages/about/index.page.vue +0 -11
  123. package/files/ts/vue/pages/index/Counter.vue +0 -10
  124. package/files/ts/vue/renderer/_default.page.client.ts +0 -14
  125. package/files/ts/vue/renderer/_default.page.server.ts +0 -43
  126. package/files/ts/vue/renderer/app.ts +0 -30
  127. package/files/ts/vue/renderer/types.ts +0 -10
  128. package/files/ts/vue/renderer/usePageContext.ts +0 -20
  129. package/files/ts/vue/vue.d.ts +0 -4
  130. package/files/ts/vue+client-router/renderer/_default.page.client.ts +0 -24
  131. package/files/ts/vue+client-router/renderer/app.ts +0 -37
  132. package/files/ts/vue+client-router/renderer/types.ts +0 -11
  133. /package/{files/shared/react/renderer/PageWrapper.css → boilerplate-react-ts/renderer/PageShell.css} +0 -0
  134. /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 {};
@@ -1 +0,0 @@
1
- {}
@@ -1,4 +0,0 @@
1
- h1,
2
- p {
3
- color: green;
4
- }
@@ -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,13 +0,0 @@
1
- import React from "react";
2
- import "./index.css";
3
-
4
- export { Page };
5
-
6
- function Page() {
7
- return (
8
- <>
9
- <h1>About</h1>
10
- <p>A colored page.</p>
11
- </>
12
- );
13
- }
@@ -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,11 +0,0 @@
1
- <template>
2
- <h1>About</h1>
3
- <p>A colored page.</p>
4
- </template>
5
-
6
- <style>
7
- h1,
8
- p {
9
- color: green;
10
- }
11
- </style>
@@ -1,10 +0,0 @@
1
- <template>
2
- <button type="button" @click="state.count++">
3
- Counter {{ state.count }}
4
- </button>
5
- </template>
6
-
7
- <script lang="ts" setup>
8
- import { reactive } from "vue";
9
- const state = reactive({ count: 0 });
10
- </script>
@@ -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,10 +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: any;
5
- pageProps?: PageProps;
6
- documentProps?: {
7
- title?: string;
8
- description?: string;
9
- };
10
- };
@@ -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
- }
@@ -1,4 +0,0 @@
1
- declare module "*.vue" {
2
- const Component: any;
3
- export default Component;
4
- }
@@ -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
- });