create-cloudflare 0.0.0-e3990bbf → 0.0.0-e39a45ffa
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/README.md +2 -53
- package/dist/cli.js +74425 -54522
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +51 -28
- package/templates/analog/c3.ts +111 -0
- package/templates/analog/snippets/devBindingsModule.ts +7 -0
- package/templates/analog/templates/env.d.ts +13 -0
- package/templates/analog/templates/src/dev-bindings.ts +18 -0
- package/templates/analog/templates/wrangler.jsonc +5 -0
- package/templates/angular/c3.ts +9 -0
- package/templates/angular/pages/c3.ts +135 -0
- package/templates/angular/pages/templates/src/server.ts +15 -0
- package/templates/angular/pages/templates/tools/copy-files.mjs +15 -0
- package/templates/angular/pages/templates/wrangler.jsonc +5 -0
- package/templates/angular/workers/c3.ts +131 -0
- package/templates/angular/workers/templates/src/server.ts +15 -0
- package/templates/angular/workers/templates/wrangler.jsonc +12 -0
- package/templates/astro/c3.ts +9 -0
- package/templates/astro/pages/c3.ts +99 -0
- package/templates/astro/pages/templates/js/wrangler.jsonc +8 -0
- package/templates/astro/pages/templates/ts/src/env.d.ts +5 -0
- package/templates/astro/pages/templates/ts/worker-configuration.d.ts +4 -0
- package/templates/astro/pages/templates/ts/wrangler.jsonc +8 -0
- package/templates/astro/workers/c3.ts +98 -0
- package/templates/astro/workers/templates/js/public/.assetsignore +2 -0
- package/templates/astro/workers/templates/js/wrangler.jsonc +16 -0
- package/templates/astro/workers/templates/ts/public/.assetsignore +2 -0
- package/templates/astro/workers/templates/ts/src/env.d.ts +5 -0
- package/templates/astro/workers/templates/ts/wrangler.jsonc +16 -0
- package/templates/common/c3.ts +23 -0
- package/templates/common/js/.editorconfig +0 -1
- package/templates/common/js/__dot__gitignore +172 -0
- package/templates/common/js/package.json +2 -1
- package/templates/common/js/wrangler.jsonc +8 -0
- package/templates/common/ts/.editorconfig +0 -1
- package/templates/common/ts/__dot__gitignore +172 -0
- package/templates/common/ts/package.json +5 -4
- package/templates/common/ts/src/ab-test.ts +2 -2
- package/templates/common/ts/src/index.ts +5 -2
- package/templates/common/ts/src/proxy.ts +2 -2
- package/templates/common/ts/src/redirect.ts +2 -2
- package/templates/common/ts/tsconfig.json +34 -95
- package/templates/common/ts/wrangler.jsonc +8 -0
- package/templates/docusaurus/c3.ts +9 -0
- package/templates/docusaurus/pages/c3.ts +32 -0
- package/templates/docusaurus/workers/c3.ts +34 -0
- package/templates/docusaurus/workers/templates/wrangler.jsonc +10 -0
- package/templates/gatsby/c3.ts +9 -0
- package/templates/gatsby/pages/c3.ts +52 -0
- package/templates/gatsby/workers/c3.ts +54 -0
- package/templates/gatsby/workers/templates/wrangler.jsonc +10 -0
- package/templates/hello-world/c3.ts +37 -0
- package/templates/hello-world/js/.editorconfig +0 -1
- package/templates/hello-world/js/__dot__gitignore +172 -0
- package/templates/hello-world/js/package.json +6 -2
- package/templates/hello-world/js/test/index.spec.js +20 -0
- package/templates/hello-world/js/vitest.config.js +11 -0
- package/templates/hello-world/js/wrangler.jsonc +8 -0
- package/templates/hello-world/py/.python-version +1 -0
- package/templates/hello-world/py/README.md +23 -0
- package/templates/hello-world/py/__dot__gitignore +68 -0
- package/templates/hello-world/py/package.json +13 -0
- package/templates/hello-world/py/pyproject.toml +9 -0
- package/templates/hello-world/py/src/entry.py +5 -0
- package/templates/hello-world/py/uv.lock +22 -0
- package/templates/hello-world/py/wrangler.jsonc +9 -0
- package/templates/hello-world/ts/.editorconfig +0 -1
- package/templates/hello-world/ts/__dot__gitignore +172 -0
- package/templates/hello-world/ts/package.json +8 -4
- package/templates/hello-world/ts/src/index.ts +5 -19
- package/templates/hello-world/ts/test/env.d.ts +3 -0
- package/templates/hello-world/ts/test/index.spec.ts +24 -0
- package/templates/hello-world/ts/test/tsconfig.json +8 -0
- package/templates/hello-world/ts/tsconfig.json +37 -96
- package/templates/hello-world/ts/vitest.config.mts +11 -0
- package/templates/hello-world/ts/wrangler.jsonc +8 -0
- package/templates/hello-world-assets-only/c3.ts +16 -0
- package/templates/hello-world-assets-only/templates/package.json +13 -0
- package/templates/hello-world-assets-only/templates/public/index.html +12 -0
- package/templates/hello-world-assets-only/templates/wrangler.jsonc +11 -0
- package/templates/hello-world-durable-object/c3.ts +24 -0
- package/templates/hello-world-durable-object/js/.editorconfig +12 -0
- package/templates/hello-world-durable-object/js/.prettierrc +6 -0
- package/templates/hello-world-durable-object/js/__dot__gitignore +172 -0
- package/templates/hello-world-durable-object/js/package.json +13 -0
- package/templates/hello-world-durable-object/js/src/index.js +70 -0
- package/templates/hello-world-durable-object/js/wrangler.jsonc +24 -0
- package/templates/hello-world-durable-object/py/.python-version +1 -0
- package/templates/hello-world-durable-object/py/README.md +23 -0
- package/templates/hello-world-durable-object/py/__dot__gitignore +68 -0
- package/templates/hello-world-durable-object/py/package.json +13 -0
- package/templates/hello-world-durable-object/py/pyproject.toml +9 -0
- package/templates/hello-world-durable-object/py/src/entry.py +66 -0
- package/templates/hello-world-durable-object/py/uv.lock +22 -0
- package/templates/hello-world-durable-object/py/wrangler.jsonc +27 -0
- package/templates/hello-world-durable-object/ts/.editorconfig +12 -0
- package/templates/hello-world-durable-object/ts/.prettierrc +6 -0
- package/templates/hello-world-durable-object/ts/__dot__gitignore +172 -0
- package/templates/hello-world-durable-object/ts/package.json +15 -0
- package/templates/hello-world-durable-object/ts/src/index.ts +66 -0
- package/templates/hello-world-durable-object/ts/tsconfig.json +40 -0
- package/templates/hello-world-durable-object/ts/wrangler.jsonc +24 -0
- package/templates/hello-world-durable-object-with-assets/c3.ts +26 -0
- package/templates/hello-world-durable-object-with-assets/js/.editorconfig +12 -0
- package/templates/hello-world-durable-object-with-assets/js/.prettierrc +6 -0
- package/templates/hello-world-durable-object-with-assets/js/__dot__gitignore +172 -0
- package/templates/hello-world-durable-object-with-assets/js/package.json +13 -0
- package/templates/hello-world-durable-object-with-assets/js/public/index.html +20 -0
- package/templates/hello-world-durable-object-with-assets/js/src/index.js +70 -0
- package/templates/hello-world-durable-object-with-assets/js/wrangler.jsonc +28 -0
- package/templates/hello-world-durable-object-with-assets/py/.python-version +1 -0
- package/templates/hello-world-durable-object-with-assets/py/README.md +23 -0
- package/templates/hello-world-durable-object-with-assets/py/__dot__gitignore +68 -0
- package/templates/hello-world-durable-object-with-assets/py/package.json +13 -0
- package/templates/hello-world-durable-object-with-assets/py/public/index.html +20 -0
- package/templates/hello-world-durable-object-with-assets/py/pyproject.toml +9 -0
- package/templates/hello-world-durable-object-with-assets/py/src/entry.py +66 -0
- package/templates/hello-world-durable-object-with-assets/py/uv.lock +22 -0
- package/templates/hello-world-durable-object-with-assets/py/wrangler.jsonc +31 -0
- package/templates/hello-world-durable-object-with-assets/ts/.editorconfig +12 -0
- package/templates/hello-world-durable-object-with-assets/ts/.prettierrc +6 -0
- package/templates/hello-world-durable-object-with-assets/ts/__dot__gitignore +172 -0
- package/templates/hello-world-durable-object-with-assets/ts/package.json +15 -0
- package/templates/hello-world-durable-object-with-assets/ts/public/index.html +20 -0
- package/templates/hello-world-durable-object-with-assets/ts/src/index.ts +67 -0
- package/templates/hello-world-durable-object-with-assets/ts/tsconfig.json +40 -0
- package/templates/hello-world-durable-object-with-assets/ts/wrangler.jsonc +28 -0
- package/templates/hello-world-with-assets/c3.ts +25 -0
- package/templates/hello-world-with-assets/js/.editorconfig +12 -0
- package/templates/hello-world-with-assets/js/.prettierrc +6 -0
- package/templates/hello-world-with-assets/js/__dot__gitignore +172 -0
- package/templates/hello-world-with-assets/js/package.json +16 -0
- package/templates/hello-world-with-assets/js/public/index.html +32 -0
- package/templates/hello-world-with-assets/js/src/index.js +23 -0
- package/templates/hello-world-with-assets/js/test/index.spec.js +41 -0
- package/templates/hello-world-with-assets/js/vitest.config.js +11 -0
- package/templates/hello-world-with-assets/js/wrangler.jsonc +16 -0
- package/templates/hello-world-with-assets/py/.python-version +1 -0
- package/templates/hello-world-with-assets/py/README.md +23 -0
- package/templates/hello-world-with-assets/py/__dot__gitignore +68 -0
- package/templates/hello-world-with-assets/py/package.json +13 -0
- package/templates/hello-world-with-assets/py/public/index.html +32 -0
- package/templates/hello-world-with-assets/py/pyproject.toml +9 -0
- package/templates/hello-world-with-assets/py/src/entry.py +11 -0
- package/templates/hello-world-with-assets/py/uv.lock +22 -0
- package/templates/hello-world-with-assets/py/wrangler.jsonc +15 -0
- package/templates/hello-world-with-assets/ts/.editorconfig +12 -0
- package/templates/hello-world-with-assets/ts/.prettierrc +6 -0
- package/templates/hello-world-with-assets/ts/__dot__gitignore +172 -0
- package/templates/hello-world-with-assets/ts/package.json +18 -0
- package/templates/hello-world-with-assets/ts/public/index.html +32 -0
- package/templates/hello-world-with-assets/ts/src/index.ts +26 -0
- package/templates/hello-world-with-assets/ts/test/env.d.ts +3 -0
- package/templates/hello-world-with-assets/ts/test/index.spec.ts +41 -0
- package/templates/hello-world-with-assets/ts/test/tsconfig.json +8 -0
- package/templates/hello-world-with-assets/ts/tsconfig.json +42 -0
- package/templates/hello-world-with-assets/ts/vitest.config.mts +11 -0
- package/templates/hello-world-with-assets/ts/wrangler.jsonc +15 -0
- package/templates/hono/c3.ts +9 -0
- package/templates/hono/pages/c3.ts +47 -0
- package/templates/hono/pages/templates/src/index.tsx +12 -0
- package/templates/hono/pages/templates/wrangler.jsonc +8 -0
- package/templates/hono/workers/c3.ts +44 -0
- package/templates/hono/workers/templates/public/index.html +19 -0
- package/templates/hono/workers/templates/src/index.ts +9 -0
- package/templates/hono/workers/templates/wrangler.jsonc +9 -0
- package/templates/next/c3.ts +9 -0
- package/templates/next/pages/README.md +67 -0
- package/templates/next/pages/app/js/app/api/hello/route.js +21 -0
- package/templates/next/pages/app/js/app/not-found.js +58 -0
- package/templates/next/pages/app/ts/app/api/hello/route.ts +21 -0
- package/templates/next/pages/app/ts/app/not-found.tsx +58 -0
- package/templates/next/pages/c3.ts +221 -0
- package/templates/next/pages/pages/js/pages/api/hello.js +23 -0
- package/templates/next/pages/pages/ts/pages/api/hello.ts +24 -0
- package/templates/next/pages/wrangler.jsonc +8 -0
- package/templates/next/workers/c3.ts +71 -0
- package/templates/next/workers/templates/.dev.vars +2 -0
- package/templates/next/workers/templates/__dot__gitignore +39 -0
- package/templates/next/workers/templates/open-next.config.ts +9 -0
- package/templates/next/workers/templates/wrangler.jsonc +13 -0
- package/templates/nuxt/c3.ts +9 -0
- package/templates/nuxt/pages/c3.ts +123 -0
- package/templates/nuxt/pages/templates/env.d.ts +14 -0
- package/templates/nuxt/pages/templates/wrangler.jsonc +5 -0
- package/templates/nuxt/workers/c3.ts +122 -0
- package/templates/nuxt/workers/templates/env.d.ts +14 -0
- package/templates/nuxt/workers/templates/wrangler.jsonc +12 -0
- package/templates/openapi/c3.ts +14 -0
- package/templates/openapi/ts/README.md +3 -3
- package/templates/openapi/ts/__dot__gitignore +172 -0
- package/templates/openapi/ts/package.json +10 -6
- package/templates/openapi/ts/src/endpoints/taskCreate.ts +27 -17
- package/templates/openapi/ts/src/endpoints/taskDelete.ts +21 -20
- package/templates/openapi/ts/src/endpoints/taskFetch.ts +31 -24
- package/templates/openapi/ts/src/endpoints/taskList.ts +28 -25
- package/templates/openapi/ts/src/index.ts +18 -21
- package/templates/openapi/ts/src/types.ts +12 -8
- package/templates/openapi/ts/tsconfig.json +18 -21
- package/templates/openapi/ts/wrangler.jsonc +8 -0
- package/templates/pre-existing/c3.ts +106 -0
- package/templates/pre-existing/js/.editorconfig +12 -0
- package/templates/pre-existing/js/.prettierrc +6 -0
- package/templates/pre-existing/js/__dot__gitignore +172 -0
- package/templates/pre-existing/js/package.json +13 -0
- package/templates/queues/c3.ts +32 -0
- package/templates/queues/js/.editorconfig +0 -1
- package/templates/queues/js/__dot__gitignore +172 -0
- package/templates/queues/js/package.json +2 -1
- package/templates/queues/js/wrangler.jsonc +21 -0
- package/templates/queues/ts/.editorconfig +0 -1
- package/templates/queues/ts/__dot__gitignore +172 -0
- package/templates/queues/ts/package.json +5 -4
- package/templates/queues/ts/src/index.ts +6 -8
- package/templates/queues/ts/tsconfig.json +34 -95
- package/templates/queues/ts/wrangler.jsonc +21 -0
- package/templates/qwik/c3.ts +9 -0
- package/templates/qwik/pages/c3.ts +151 -0
- package/templates/qwik/pages/snippets/getPlatformProxy.ts +6 -0
- package/templates/qwik/pages/templates/worker-configuration.d.ts +4 -0
- package/templates/qwik/pages/templates/wrangler.jsonc +8 -0
- package/templates/qwik/workers/c3.ts +153 -0
- package/templates/qwik/workers/snippets/getPlatformProxy.ts +6 -0
- package/templates/qwik/workers/templates/public/.assetsignore +4 -0
- package/templates/qwik/workers/templates/worker-configuration.d.ts +4 -0
- package/templates/qwik/workers/templates/wrangler.jsonc +16 -0
- package/templates/react/c3.ts +9 -0
- package/templates/react/pages/c3.ts +65 -0
- package/templates/react/pages/templates/wrangler.jsonc +5 -0
- package/templates/react/workers/c3.ts +183 -0
- package/templates/react/workers/js/src/App.css +45 -0
- package/templates/react/workers/js/src/App.jsx +58 -0
- package/templates/react/workers/js/src/assets/Cloudflare_Logo.svg +53 -0
- package/templates/react/workers/js/worker/index.js +13 -0
- package/templates/react/workers/js/wrangler.jsonc +9 -0
- package/templates/react/workers/ts/src/App.css +45 -0
- package/templates/react/workers/ts/src/App.tsx +58 -0
- package/templates/react/workers/ts/src/assets/Cloudflare_Logo.svg +51 -0
- package/templates/react/workers/ts/tsconfig.worker.json +8 -0
- package/templates/react/workers/ts/worker/index.ts +12 -0
- package/templates/react/workers/ts/wrangler.jsonc +9 -0
- package/templates/react-router/c3.ts +41 -0
- package/templates/remix/c3.ts +10 -0
- package/templates/remix/pages/c3.ts +70 -0
- package/templates/remix/pages/templates/worker-configuration.d.ts +4 -0
- package/templates/remix/pages/templates/wrangler.jsonc +5 -0
- package/templates/remix/workers/c3.ts +53 -0
- package/templates/remix/workers/templates/public/.assetsignore +0 -0
- package/templates/remix/workers/templates/worker-configuration.d.ts +4 -0
- package/templates/remix/workers/templates/wrangler.toml +11 -0
- package/templates/scheduled/c3.ts +22 -0
- package/templates/scheduled/js/.editorconfig +0 -1
- package/templates/scheduled/js/__dot__gitignore +172 -0
- package/templates/scheduled/js/package.json +3 -2
- package/templates/scheduled/js/src/index.js +9 -2
- package/templates/scheduled/js/wrangler.jsonc +13 -0
- package/templates/scheduled/ts/.editorconfig +0 -1
- package/templates/scheduled/ts/__dot__gitignore +172 -0
- package/templates/scheduled/ts/package.json +5 -4
- package/templates/scheduled/ts/src/index.ts +15 -25
- package/templates/scheduled/ts/tsconfig.json +34 -95
- package/templates/scheduled/ts/wrangler.jsonc +13 -0
- package/templates/solid/c3.ts +88 -0
- package/templates/solid/templates/wrangler.jsonc +8 -0
- package/templates/svelte/c3.ts +9 -0
- package/templates/svelte/pages/c3.ts +160 -0
- package/templates/svelte/pages/templates/wrangler.jsonc +5 -0
- package/templates/svelte/workers/c3.ts +129 -0
- package/templates/svelte/workers/templates/static/.assetsignore +2 -0
- package/templates/svelte/workers/templates/wrangler.jsonc +12 -0
- package/templates/vue/c3.ts +9 -0
- package/templates/vue/pages/c3.ts +33 -0
- package/templates/vue/pages/templates/wrangler.jsonc +5 -0
- package/templates/vue/workers/c3.ts +98 -0
- package/templates/vue/workers/js/server/index.js +13 -0
- package/templates/vue/workers/js/src/App.vue +107 -0
- package/templates/vue/workers/js/src/components/HelloWorld.vue +47 -0
- package/templates/vue/workers/js/vite.config.js +21 -0
- package/templates/vue/workers/js/wrangler.jsonc +11 -0
- package/templates/vue/workers/ts/server/index.ts +12 -0
- package/templates/vue/workers/ts/src/App.vue +107 -0
- package/templates/vue/workers/ts/src/components/HelloWorld.vue +44 -0
- package/templates/vue/workers/ts/tsconfig.worker.json +8 -0
- package/templates/vue/workers/ts/vite.config.ts +21 -0
- package/templates/vue/workers/ts/wrangler.jsonc +11 -0
- package/templates-experimental/solid/c3.ts +94 -0
- package/templates-experimental/solid/templates/wrangler.jsonc +15 -0
- package/dist/angular/templates/src/main.server.ts +0 -35
- package/dist/angular/templates/tools/bundle.mjs +0 -77
- package/dist/angular/templates/tools/copy-client-files.mjs +0 -4
- package/dist/angular/templates/tools/copy-worker-files.mjs +0 -10
- package/dist/angular/templates/tools/paths.mjs +0 -9
- package/dist/angular/templates/tsconfig.server.json +0 -5
- package/templates/chatgptPlugin/ts/.assets/example.png +0 -0
- package/templates/chatgptPlugin/ts/README.md +0 -25
- package/templates/chatgptPlugin/ts/package.json +0 -16
- package/templates/chatgptPlugin/ts/src/index.ts +0 -33
- package/templates/chatgptPlugin/ts/src/search.ts +0 -59
- package/templates/chatgptPlugin/ts/wrangler.toml +0 -3
- package/templates/common/js/wrangler.toml +0 -51
- package/templates/common/ts/worker-configuration.d.ts +0 -16
- package/templates/common/ts/wrangler.toml +0 -51
- package/templates/hello-world/js/wrangler.toml +0 -51
- package/templates/hello-world/ts/wrangler.toml +0 -51
- package/templates/openapi/ts/wrangler.toml +0 -3
- package/templates/queues/js/wrangler.toml +0 -19
- package/templates/queues/ts/wrangler.toml +0 -19
- package/templates/scheduled/js/wrangler.toml +0 -9
- package/templates/scheduled/ts/wrangler.toml +0 -9
- /package/{dist/angular → templates/angular/pages}/templates/src/_routes.json +0 -0
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { logRaw, updateStatus } from "@cloudflare/cli";
|
|
2
|
+
import { blue, brandColor, dim } from "@cloudflare/cli/colors";
|
|
3
|
+
import { runFrameworkGenerator } from "frameworks/index";
|
|
4
|
+
import { transformFile } from "helpers/codemod";
|
|
5
|
+
import { usesTypescript } from "helpers/files";
|
|
6
|
+
import { detectPackageManager } from "helpers/packageManagers";
|
|
7
|
+
import { installPackages } from "helpers/packages";
|
|
8
|
+
import * as recast from "recast";
|
|
9
|
+
import type { TemplateConfig } from "../../../src/templates";
|
|
10
|
+
import type { C3Context, PackageJson } from "types";
|
|
11
|
+
|
|
12
|
+
const { npm } = detectPackageManager();
|
|
13
|
+
|
|
14
|
+
const generate = async (ctx: C3Context) => {
|
|
15
|
+
await runFrameworkGenerator(ctx, ["create", ctx.project.name]);
|
|
16
|
+
|
|
17
|
+
logRaw("");
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
const configure = async (ctx: C3Context) => {
|
|
21
|
+
// Install the adapter
|
|
22
|
+
const pkg = `@sveltejs/adapter-cloudflare`;
|
|
23
|
+
await installPackages([pkg], {
|
|
24
|
+
dev: true,
|
|
25
|
+
startText: "Adding the Cloudflare adapter",
|
|
26
|
+
doneText: `${brandColor(`installed`)} ${dim(pkg)}`,
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
updateSvelteConfig();
|
|
30
|
+
updateTypeDefinitions(ctx);
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
const updateSvelteConfig = () => {
|
|
34
|
+
// All we need to do is change the import statement in svelte.config.js
|
|
35
|
+
updateStatus(`Changing adapter in ${blue("svelte.config.js")}`);
|
|
36
|
+
|
|
37
|
+
transformFile("svelte.config.js", {
|
|
38
|
+
visitImportDeclaration: function (n) {
|
|
39
|
+
// importSource is the `x` in `import y from "x"`
|
|
40
|
+
const importSource = n.value.source;
|
|
41
|
+
if (importSource.value === "@sveltejs/adapter-auto") {
|
|
42
|
+
importSource.value = "@sveltejs/adapter-cloudflare";
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
// stop traversing this node
|
|
46
|
+
return false;
|
|
47
|
+
},
|
|
48
|
+
});
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
const updateTypeDefinitions = (ctx: C3Context) => {
|
|
52
|
+
if (!usesTypescript(ctx)) {
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
updateStatus(`Updating global type definitions in ${blue("app.d.ts")}`);
|
|
57
|
+
|
|
58
|
+
const b = recast.types.builders;
|
|
59
|
+
|
|
60
|
+
transformFile("src/app.d.ts", {
|
|
61
|
+
visitTSModuleDeclaration(n) {
|
|
62
|
+
if (n.value.id.name === "App" && n.node.body) {
|
|
63
|
+
const moduleBlock = n.node
|
|
64
|
+
.body as recast.types.namedTypes.TSModuleBlock;
|
|
65
|
+
|
|
66
|
+
const platformInterface = b.tsInterfaceDeclaration(
|
|
67
|
+
b.identifier("Platform"),
|
|
68
|
+
b.tsInterfaceBody([
|
|
69
|
+
b.tsPropertySignature(
|
|
70
|
+
b.identifier("env"),
|
|
71
|
+
b.tsTypeAnnotation(b.tsTypeReference(b.identifier("Env"))),
|
|
72
|
+
),
|
|
73
|
+
b.tsPropertySignature(
|
|
74
|
+
b.identifier("cf"),
|
|
75
|
+
b.tsTypeAnnotation(
|
|
76
|
+
b.tsTypeReference(b.identifier("CfProperties")),
|
|
77
|
+
),
|
|
78
|
+
),
|
|
79
|
+
b.tsPropertySignature(
|
|
80
|
+
b.identifier("ctx"),
|
|
81
|
+
b.tsTypeAnnotation(
|
|
82
|
+
b.tsTypeReference(b.identifier("ExecutionContext")),
|
|
83
|
+
),
|
|
84
|
+
),
|
|
85
|
+
]),
|
|
86
|
+
);
|
|
87
|
+
|
|
88
|
+
moduleBlock.body.unshift(platformInterface);
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
this.traverse(n);
|
|
92
|
+
},
|
|
93
|
+
});
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
const typesPath = "./src/worker-configuration.d.ts";
|
|
97
|
+
const config: TemplateConfig = {
|
|
98
|
+
configVersion: 1,
|
|
99
|
+
id: "svelte",
|
|
100
|
+
frameworkCli: "sv",
|
|
101
|
+
displayName: "SvelteKit",
|
|
102
|
+
platform: "workers",
|
|
103
|
+
copyFiles: {
|
|
104
|
+
path: "./templates",
|
|
105
|
+
},
|
|
106
|
+
path: "templates/svelte/workers",
|
|
107
|
+
generate,
|
|
108
|
+
configure,
|
|
109
|
+
transformPackageJson: async (original: PackageJson, ctx: C3Context) => {
|
|
110
|
+
let scripts: Record<string, string> = {
|
|
111
|
+
preview: `${npm} run build && wrangler dev`,
|
|
112
|
+
deploy: `${npm} run build && wrangler deploy`,
|
|
113
|
+
};
|
|
114
|
+
|
|
115
|
+
if (usesTypescript(ctx)) {
|
|
116
|
+
scripts = {
|
|
117
|
+
...scripts,
|
|
118
|
+
"cf-typegen": `wrangler types ${typesPath}`,
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
return { scripts };
|
|
123
|
+
},
|
|
124
|
+
devScript: "dev",
|
|
125
|
+
deployScript: "deploy",
|
|
126
|
+
previewScript: "preview",
|
|
127
|
+
typesPath,
|
|
128
|
+
};
|
|
129
|
+
export default config;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import pages from "./pages/c3";
|
|
2
|
+
import workers from "./workers/c3";
|
|
3
|
+
import type { MultiPlatformTemplateConfig } from "../../src/templates";
|
|
4
|
+
|
|
5
|
+
const config: MultiPlatformTemplateConfig = {
|
|
6
|
+
displayName: "Vue",
|
|
7
|
+
platformVariants: { pages, workers },
|
|
8
|
+
};
|
|
9
|
+
export default config;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { runFrameworkGenerator } from "frameworks/index";
|
|
2
|
+
import { detectPackageManager } from "helpers/packageManagers";
|
|
3
|
+
import type { TemplateConfig } from "../../../src/templates";
|
|
4
|
+
import type { C3Context } from "types";
|
|
5
|
+
|
|
6
|
+
const { npm } = detectPackageManager();
|
|
7
|
+
|
|
8
|
+
const generate = async (ctx: C3Context) => {
|
|
9
|
+
await runFrameworkGenerator(ctx, [ctx.project.name]);
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
const config: TemplateConfig = {
|
|
13
|
+
configVersion: 1,
|
|
14
|
+
id: "vue",
|
|
15
|
+
frameworkCli: "create-vue",
|
|
16
|
+
displayName: "Vue",
|
|
17
|
+
platform: "pages",
|
|
18
|
+
hidden: true,
|
|
19
|
+
path: "templates/vue/pages",
|
|
20
|
+
copyFiles: { path: "./templates" },
|
|
21
|
+
generate,
|
|
22
|
+
transformPackageJson: async () => ({
|
|
23
|
+
scripts: {
|
|
24
|
+
deploy: `${npm} run build && wrangler pages deploy`,
|
|
25
|
+
preview: `${npm} run build && wrangler pages dev`,
|
|
26
|
+
"cf-typegen": `wrangler types`,
|
|
27
|
+
},
|
|
28
|
+
}),
|
|
29
|
+
devScript: "dev",
|
|
30
|
+
deployScript: "deploy",
|
|
31
|
+
previewScript: "preview",
|
|
32
|
+
};
|
|
33
|
+
export default config;
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { logRaw } from "@cloudflare/cli";
|
|
2
|
+
import { brandColor, dim } from "@cloudflare/cli/colors";
|
|
3
|
+
import { inputPrompt, spinner } from "@cloudflare/cli/interactive";
|
|
4
|
+
import { runFrameworkGenerator } from "frameworks/index";
|
|
5
|
+
import { readJSON, usesTypescript, writeJSON } from "helpers/files";
|
|
6
|
+
import { detectPackageManager } from "helpers/packageManagers";
|
|
7
|
+
import { installPackages } from "helpers/packages";
|
|
8
|
+
import type { TemplateConfig } from "../../../src/templates";
|
|
9
|
+
import type { C3Context } from "types";
|
|
10
|
+
|
|
11
|
+
const { npm } = detectPackageManager();
|
|
12
|
+
|
|
13
|
+
const generate = async (ctx: C3Context) => {
|
|
14
|
+
const lang =
|
|
15
|
+
ctx.args.lang ??
|
|
16
|
+
(await inputPrompt({
|
|
17
|
+
type: "select",
|
|
18
|
+
question: "Would you like to use TypeScript?",
|
|
19
|
+
label: "Language",
|
|
20
|
+
options: [
|
|
21
|
+
{ label: "TypeScript", value: "ts" },
|
|
22
|
+
{ label: "JavaScript", value: "js" },
|
|
23
|
+
],
|
|
24
|
+
}));
|
|
25
|
+
await runFrameworkGenerator(ctx, [
|
|
26
|
+
ctx.project.name,
|
|
27
|
+
"--router",
|
|
28
|
+
lang === "ts" ? "--ts" : "",
|
|
29
|
+
]);
|
|
30
|
+
logRaw("");
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
const configure = async (ctx: C3Context) => {
|
|
34
|
+
await installPackages(["@cloudflare/vite-plugin"], {
|
|
35
|
+
dev: true,
|
|
36
|
+
startText: "Installing the Cloudflare Vite plugin",
|
|
37
|
+
doneText: `${brandColor(`installed`)} ${dim("@cloudflare/vite-plugin")}`,
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
if (usesTypescript(ctx)) {
|
|
41
|
+
updateTsconfigJson();
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
function updateTsconfigJson() {
|
|
46
|
+
const s = spinner();
|
|
47
|
+
s.start(`Updating tsconfig.json config`);
|
|
48
|
+
// Add a reference to the extra tsconfig.worker.json file.
|
|
49
|
+
// ```
|
|
50
|
+
// "references": [ ..., { path: "./tsconfig.worker.json" } ]
|
|
51
|
+
// ```
|
|
52
|
+
const tsconfig = readJSON("tsconfig.json") as { references: object[] };
|
|
53
|
+
if (tsconfig && typeof tsconfig === "object") {
|
|
54
|
+
tsconfig.references ??= [];
|
|
55
|
+
tsconfig.references.push({ path: "./tsconfig.worker.json" });
|
|
56
|
+
}
|
|
57
|
+
writeJSON("tsconfig.json", tsconfig);
|
|
58
|
+
s.stop(`${brandColor(`updated`)} ${dim(`\`tsconfig.json\``)}`);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
const config: TemplateConfig = {
|
|
62
|
+
configVersion: 1,
|
|
63
|
+
id: "vue",
|
|
64
|
+
frameworkCli: "create-vue",
|
|
65
|
+
platform: "workers",
|
|
66
|
+
displayName: "Vue",
|
|
67
|
+
path: "templates/vue/workers",
|
|
68
|
+
copyFiles: {
|
|
69
|
+
async selectVariant(ctx) {
|
|
70
|
+
// Note: this `selectVariant` function should not be needed
|
|
71
|
+
// this is just a quick workaround until
|
|
72
|
+
// https://github.com/cloudflare/workers-sdk/issues/7495
|
|
73
|
+
// is resolved
|
|
74
|
+
return usesTypescript(ctx) ? "ts" : "js";
|
|
75
|
+
},
|
|
76
|
+
variants: {
|
|
77
|
+
ts: {
|
|
78
|
+
path: "./ts",
|
|
79
|
+
},
|
|
80
|
+
js: {
|
|
81
|
+
path: "./js",
|
|
82
|
+
},
|
|
83
|
+
},
|
|
84
|
+
},
|
|
85
|
+
configure,
|
|
86
|
+
generate,
|
|
87
|
+
transformPackageJson: async (_, ctx) => ({
|
|
88
|
+
scripts: {
|
|
89
|
+
deploy: `${npm} run build && wrangler deploy`,
|
|
90
|
+
preview: `${npm} run build && wrangler dev`,
|
|
91
|
+
...(usesTypescript(ctx) && { "cf-typegen": `wrangler types` }),
|
|
92
|
+
},
|
|
93
|
+
}),
|
|
94
|
+
devScript: "dev",
|
|
95
|
+
deployScript: "deploy",
|
|
96
|
+
previewScript: "preview",
|
|
97
|
+
};
|
|
98
|
+
export default config;
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { RouterLink, RouterView } from 'vue-router'
|
|
3
|
+
import HelloWorld from './components/HelloWorld.vue'
|
|
4
|
+
import { ref } from 'vue'
|
|
5
|
+
|
|
6
|
+
const name = ref('Unknown')
|
|
7
|
+
|
|
8
|
+
const getName = async () => {
|
|
9
|
+
const res = await fetch('/api/')
|
|
10
|
+
const data = await res.json()
|
|
11
|
+
name.value = data.name
|
|
12
|
+
}
|
|
13
|
+
</script>
|
|
14
|
+
|
|
15
|
+
<template>
|
|
16
|
+
<header>
|
|
17
|
+
<img alt="Vue logo" class="logo" src="@/assets/logo.svg" width="125" height="125" />
|
|
18
|
+
|
|
19
|
+
<div class="wrapper">
|
|
20
|
+
<HelloWorld msg="You did it!" />
|
|
21
|
+
<button class="green" @click="getName" aria-label="get name">
|
|
22
|
+
Name from API is: {{ name }}
|
|
23
|
+
</button>
|
|
24
|
+
<p>Edit <code>server/index.js</code> to change what the API gets</p>
|
|
25
|
+
<nav>
|
|
26
|
+
<RouterLink to="/">Home</RouterLink>
|
|
27
|
+
<RouterLink to="/about">About</RouterLink>
|
|
28
|
+
</nav>
|
|
29
|
+
</div>
|
|
30
|
+
</header>
|
|
31
|
+
|
|
32
|
+
<RouterView />
|
|
33
|
+
</template>
|
|
34
|
+
|
|
35
|
+
<style scoped>
|
|
36
|
+
header {
|
|
37
|
+
line-height: 1.5;
|
|
38
|
+
max-height: 100vh;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.logo {
|
|
42
|
+
display: block;
|
|
43
|
+
margin: 0 auto 2rem;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
nav {
|
|
47
|
+
width: 100%;
|
|
48
|
+
font-size: 12px;
|
|
49
|
+
text-align: center;
|
|
50
|
+
margin-top: 2rem;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
nav a.router-link-exact-active {
|
|
54
|
+
color: var(--color-text);
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
nav a.router-link-exact-active:hover {
|
|
58
|
+
background-color: transparent;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
nav a {
|
|
62
|
+
display: inline-block;
|
|
63
|
+
padding: 0 1rem;
|
|
64
|
+
border-left: 1px solid var(--color-border);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
nav a:first-of-type {
|
|
68
|
+
border: 0;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
button {
|
|
72
|
+
background-color: hsla(160, 100%, 37%, 1);
|
|
73
|
+
color: var(--color-background);
|
|
74
|
+
border: 0;
|
|
75
|
+
padding: 0.5rem 1rem;
|
|
76
|
+
border-radius: 0.25rem;
|
|
77
|
+
cursor: pointer;
|
|
78
|
+
margin: 1rem 0 0.5rem 0;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
@media (min-width: 1024px) {
|
|
82
|
+
header {
|
|
83
|
+
display: flex;
|
|
84
|
+
place-items: center;
|
|
85
|
+
padding-right: calc(var(--section-gap) / 2);
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
.logo {
|
|
89
|
+
margin: 0 2rem 0 0;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
header .wrapper {
|
|
93
|
+
display: flex;
|
|
94
|
+
place-items: flex-start;
|
|
95
|
+
flex-wrap: wrap;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
nav {
|
|
99
|
+
text-align: left;
|
|
100
|
+
margin-left: -1rem;
|
|
101
|
+
font-size: 1rem;
|
|
102
|
+
|
|
103
|
+
padding: 1rem 0;
|
|
104
|
+
margin-top: 1rem;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
</style>
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
defineProps({
|
|
3
|
+
msg: {
|
|
4
|
+
type: String,
|
|
5
|
+
required: true,
|
|
6
|
+
},
|
|
7
|
+
})
|
|
8
|
+
</script>
|
|
9
|
+
|
|
10
|
+
<template>
|
|
11
|
+
<div class="greetings">
|
|
12
|
+
<h1 class="green">{{ msg }}</h1>
|
|
13
|
+
<h3>
|
|
14
|
+
You’ve successfully created a project with
|
|
15
|
+
<a href="https://vite.dev/" target="_blank" rel="noopener">Vite</a> +
|
|
16
|
+
<a href="https://vuejs.org/" target="_blank" rel="noopener">Vue 3</a> +
|
|
17
|
+
<a href="https://developers.cloudflare.com/workers/" target="_blank" rel="noopener"
|
|
18
|
+
>Cloudflare Workers</a
|
|
19
|
+
>. What's next?
|
|
20
|
+
</h3>
|
|
21
|
+
</div>
|
|
22
|
+
</template>
|
|
23
|
+
|
|
24
|
+
<style scoped>
|
|
25
|
+
h1 {
|
|
26
|
+
font-weight: 500;
|
|
27
|
+
font-size: 2.6rem;
|
|
28
|
+
position: relative;
|
|
29
|
+
top: -10px;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
h3 {
|
|
33
|
+
font-size: 1.2rem;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
.greetings h1,
|
|
37
|
+
.greetings h3 {
|
|
38
|
+
text-align: center;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
@media (min-width: 1024px) {
|
|
42
|
+
.greetings h1,
|
|
43
|
+
.greetings h3 {
|
|
44
|
+
text-align: left;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
</style>
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { fileURLToPath, URL } from 'node:url'
|
|
2
|
+
|
|
3
|
+
import { defineConfig } from 'vite'
|
|
4
|
+
import vue from '@vitejs/plugin-vue'
|
|
5
|
+
import vueDevTools from 'vite-plugin-vue-devtools'
|
|
6
|
+
|
|
7
|
+
import { cloudflare } from "@cloudflare/vite-plugin"
|
|
8
|
+
|
|
9
|
+
// https://vite.dev/config/
|
|
10
|
+
export default defineConfig({
|
|
11
|
+
plugins: [
|
|
12
|
+
vue(),
|
|
13
|
+
vueDevTools(),
|
|
14
|
+
cloudflare()
|
|
15
|
+
],
|
|
16
|
+
resolve: {
|
|
17
|
+
alias: {
|
|
18
|
+
'@': fileURLToPath(new URL('./src', import.meta.url))
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
})
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export default {
|
|
2
|
+
fetch(request) {
|
|
3
|
+
const url = new URL(request.url);
|
|
4
|
+
|
|
5
|
+
if (url.pathname.startsWith("/api/")) {
|
|
6
|
+
return Response.json({
|
|
7
|
+
name: "Cloudflare",
|
|
8
|
+
});
|
|
9
|
+
}
|
|
10
|
+
return new Response(null, { status: 404 });
|
|
11
|
+
},
|
|
12
|
+
} satisfies ExportedHandler<Env>;
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
import { RouterLink, RouterView } from 'vue-router'
|
|
3
|
+
import HelloWorld from './components/HelloWorld.vue'
|
|
4
|
+
import { ref } from 'vue'
|
|
5
|
+
|
|
6
|
+
const name = ref('Unknown')
|
|
7
|
+
|
|
8
|
+
const getName = async () => {
|
|
9
|
+
const res = await fetch('/api/')
|
|
10
|
+
const data = await res.json()
|
|
11
|
+
name.value = data.name
|
|
12
|
+
}
|
|
13
|
+
</script>
|
|
14
|
+
|
|
15
|
+
<template>
|
|
16
|
+
<header>
|
|
17
|
+
<img alt="Vue logo" class="logo" src="@/assets/logo.svg" width="125" height="125" />
|
|
18
|
+
|
|
19
|
+
<div class="wrapper">
|
|
20
|
+
<HelloWorld msg="You did it!" />
|
|
21
|
+
<button class="green" @click="getName" aria-label="get name">
|
|
22
|
+
Name from API is: {{ name }}
|
|
23
|
+
</button>
|
|
24
|
+
<p>Edit <code>server/index.ts</code> to change what the API gets</p>
|
|
25
|
+
<nav>
|
|
26
|
+
<RouterLink to="/">Home</RouterLink>
|
|
27
|
+
<RouterLink to="/about">About</RouterLink>
|
|
28
|
+
</nav>
|
|
29
|
+
</div>
|
|
30
|
+
</header>
|
|
31
|
+
|
|
32
|
+
<RouterView />
|
|
33
|
+
</template>
|
|
34
|
+
|
|
35
|
+
<style scoped>
|
|
36
|
+
header {
|
|
37
|
+
line-height: 1.5;
|
|
38
|
+
max-height: 100vh;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.logo {
|
|
42
|
+
display: block;
|
|
43
|
+
margin: 0 auto 2rem;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
nav {
|
|
47
|
+
width: 100%;
|
|
48
|
+
font-size: 12px;
|
|
49
|
+
text-align: center;
|
|
50
|
+
margin-top: 2rem;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
nav a.router-link-exact-active {
|
|
54
|
+
color: var(--color-text);
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
nav a.router-link-exact-active:hover {
|
|
58
|
+
background-color: transparent;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
nav a {
|
|
62
|
+
display: inline-block;
|
|
63
|
+
padding: 0 1rem;
|
|
64
|
+
border-left: 1px solid var(--color-border);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
nav a:first-of-type {
|
|
68
|
+
border: 0;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
button {
|
|
72
|
+
background-color: hsla(160, 100%, 37%, 1);
|
|
73
|
+
color: var(--color-background);
|
|
74
|
+
border: 0;
|
|
75
|
+
padding: 0.5rem 1rem;
|
|
76
|
+
border-radius: 0.25rem;
|
|
77
|
+
cursor: pointer;
|
|
78
|
+
margin: 1rem 0 0.5rem 0;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
@media (min-width: 1024px) {
|
|
82
|
+
header {
|
|
83
|
+
display: flex;
|
|
84
|
+
place-items: center;
|
|
85
|
+
padding-right: calc(var(--section-gap) / 2);
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
.logo {
|
|
89
|
+
margin: 0 2rem 0 0;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
header .wrapper {
|
|
93
|
+
display: flex;
|
|
94
|
+
place-items: flex-start;
|
|
95
|
+
flex-wrap: wrap;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
nav {
|
|
99
|
+
text-align: left;
|
|
100
|
+
margin-left: -1rem;
|
|
101
|
+
font-size: 1rem;
|
|
102
|
+
|
|
103
|
+
padding: 1rem 0;
|
|
104
|
+
margin-top: 1rem;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
</style>
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
defineProps<{
|
|
3
|
+
msg: string
|
|
4
|
+
}>()
|
|
5
|
+
</script>
|
|
6
|
+
|
|
7
|
+
<template>
|
|
8
|
+
<div class="greetings">
|
|
9
|
+
<h1 class="green">{{ msg }}</h1>
|
|
10
|
+
<h3>
|
|
11
|
+
You’ve successfully created a project with
|
|
12
|
+
<a href="https://vite.dev/" target="_blank" rel="noopener">Vite</a> +
|
|
13
|
+
<a href="https://vuejs.org/" target="_blank" rel="noopener">Vue 3</a> +
|
|
14
|
+
<a href="https://developers.cloudflare.com/workers/" target="_blank" rel="noopener"
|
|
15
|
+
>Cloudflare Workers</a
|
|
16
|
+
>. What's next?
|
|
17
|
+
</h3>
|
|
18
|
+
</div>
|
|
19
|
+
</template>
|
|
20
|
+
|
|
21
|
+
<style scoped>
|
|
22
|
+
h1 {
|
|
23
|
+
font-weight: 500;
|
|
24
|
+
font-size: 2.6rem;
|
|
25
|
+
position: relative;
|
|
26
|
+
top: -10px;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
h3 {
|
|
30
|
+
font-size: 1.2rem;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
.greetings h1,
|
|
34
|
+
.greetings h3 {
|
|
35
|
+
text-align: center;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
@media (min-width: 1024px) {
|
|
39
|
+
.greetings h1,
|
|
40
|
+
.greetings h3 {
|
|
41
|
+
text-align: left;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
</style>
|