create-astro 0.7.1 → 0.8.0-next.0

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/LICENSE ADDED
@@ -0,0 +1,34 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2021 Fred K. Schott
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
22
+
23
+
24
+ """
25
+ This license applies to parts of the `packages/create-astro` and `packages/astro` subdirectories originating from the https://github.com/sveltejs/kit repository:
26
+
27
+ Copyright (c) 2020 [these people](https://github.com/sveltejs/kit/graphs/contributors)
28
+
29
+ Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
30
+
31
+ The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
32
+
33
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
34
+ """
package/dist/config.js CHANGED
@@ -1,24 +1,23 @@
1
- const createConfig = ({ renderers }) => {
1
+ const createConfig = ({ integrations }) => {
2
+ if (integrations.length === 0) {
3
+ return `import { defineConfig } from 'astro/config';
4
+ // https://astro.build/config
5
+ export default defineConfig({});
6
+ `;
7
+ }
8
+ const rendererImports = integrations.map((r) => ` import ${r.id} from '${r.packageName}';`);
9
+ const rendererIntegrations = integrations.map((r) => ` ${r.id}(),`);
2
10
  return [
3
- `export default {
4
- // projectRoot: '.', // Where to resolve all URLs relative to. Useful if you have a monorepo project.
5
- // pages: './src/pages', // Path to Astro components, pages, and data
6
- // dist: './dist', // When running \`astro build\`, path to final static output
7
- // public: './public', // A folder of static files Astro will copy to the root. Useful for favicons, images, and other files that don\u2019t need processing.
8
- buildOptions: {
9
- // site: 'http://example.com', // Your public domain, e.g.: https://my-site.dev/. Used to generate sitemaps and canonical URLs.
10
- sitemap: true, // Generate sitemap (set to "false" to disable)
11
- },
12
- devOptions: {
13
- // hostname: 'localhost', // The hostname to run the dev server on.
14
- // port: 3000, // The port to run the dev server on.
15
- },`,
16
- ` renderers: ${JSON.stringify(renderers, void 0, 2).split("\n").map((ln, i) => i !== 0 ? ` ${ln}` : ln).join("\n")},`,
17
- `};
18
- `
11
+ `import { defineConfig } from 'astro/config';`,
12
+ ...rendererImports,
13
+ `// https://astro.build/config`,
14
+ `export default defineConfig({`,
15
+ ` integrations: [`,
16
+ ...rendererIntegrations,
17
+ ` ]`,
18
+ `});`
19
19
  ].join("\n");
20
20
  };
21
21
  export {
22
22
  createConfig
23
23
  };
24
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2NvbmZpZy50cyJdLAogICJtYXBwaW5ncyI6ICJBQUFPLE1BQU0sZUFBZSxDQUFDLEVBQUUsZ0JBQXlDO0FBQ3ZFLFNBQU87QUFBQSxJQUNOO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsSUFhQSxnQkFBZ0IsS0FBSyxVQUFVLFdBQVcsUUFBVyxHQUNuRCxNQUFNLE1BQ04sSUFBSSxDQUFDLElBQUksTUFBTyxNQUFNLElBQUksS0FBSyxPQUFPLElBQ3RDLEtBQUs7QUFBQSxJQUNQO0FBQUE7QUFBQSxJQUVDLEtBQUs7QUFBQTsiLAogICJuYW1lcyI6IFtdCn0K
@@ -1,5 +1,5 @@
1
1
  const COUNTER_COMPONENTS = {
2
- "@astrojs/renderer-preact": {
2
+ preact: {
3
3
  filename: `src/components/PreactCounter.jsx`,
4
4
  content: `import { useState } from 'preact/hooks';
5
5
 
@@ -18,7 +18,7 @@ export default function PreactCounter() {
18
18
  }
19
19
  `
20
20
  },
21
- "@astrojs/renderer-react": {
21
+ react: {
22
22
  filename: `src/components/ReactCounter.jsx`,
23
23
  content: `import { useState } from 'react';
24
24
 
@@ -37,7 +37,7 @@ export default function ReactCounter() {
37
37
  }
38
38
  `
39
39
  },
40
- "@astrojs/renderer-solid": {
40
+ solid: {
41
41
  filename: `src/components/SolidCounter.jsx`,
42
42
  content: `import { createSignal } from "solid-js";
43
43
 
@@ -56,7 +56,7 @@ export default function SolidCounter() {
56
56
  }
57
57
  `
58
58
  },
59
- "@astrojs/renderer-svelte": {
59
+ svelte: {
60
60
  filename: `src/components/SvelteCounter.svelte`,
61
61
  content: `<script>
62
62
  let count = 0;
@@ -77,7 +77,7 @@ export default function SolidCounter() {
77
77
  </div>
78
78
  `
79
79
  },
80
- "@astrojs/renderer-vue": {
80
+ vue: {
81
81
  filename: `src/components/VueCounter.vue`,
82
82
  content: `<template>
83
83
  <div id="vue" class="counter">
@@ -109,27 +109,26 @@ export default {
109
109
  const FRAMEWORKS = [
110
110
  {
111
111
  title: "Preact",
112
- value: "@astrojs/renderer-preact"
112
+ value: { id: "preact", packageName: "@astrojs/preact" }
113
113
  },
114
114
  {
115
115
  title: "React",
116
- value: "@astrojs/renderer-react"
116
+ value: { id: "react", packageName: "@astrojs/react" }
117
117
  },
118
118
  {
119
- title: "Solid",
120
- value: "@astrojs/renderer-solid"
119
+ title: "Solid.js",
120
+ value: { id: "solid", packageName: "@astrojs/solid-js" }
121
121
  },
122
122
  {
123
123
  title: "Svelte",
124
- value: "@astrojs/renderer-svelte"
124
+ value: { id: "svelte", packageName: "@astrojs/svelte" }
125
125
  },
126
126
  {
127
127
  title: "Vue",
128
- value: "@astrojs/renderer-vue"
128
+ value: { id: "vue", packageName: "@astrojs/vue" }
129
129
  }
130
130
  ];
131
131
  export {
132
132
  COUNTER_COMPONENTS,
133
133
  FRAMEWORKS
134
134
  };
135
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2ZyYW1ld29ya3MudHMiXSwKICAibWFwcGluZ3MiOiAiQUFBTyxNQUFNLHFCQUFxQjtBQUFBLEVBQ2pDLDRCQUE0QjtBQUFBLElBQzNCLFVBQVU7QUFBQSxJQUNWLFNBQVM7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBaUJWLDJCQUEyQjtBQUFBLElBQzFCLFVBQVU7QUFBQSxJQUNWLFNBQVM7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBaUJWLDJCQUEyQjtBQUFBLElBQzFCLFVBQVU7QUFBQSxJQUNWLFNBQVM7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBaUJWLDRCQUE0QjtBQUFBLElBQzNCLFVBQVU7QUFBQSxJQUNWLFNBQVM7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQW1CVix5QkFBeUI7QUFBQSxJQUN4QixVQUFVO0FBQUEsSUFDVixTQUFTO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQTRCSixNQUFNLGFBQWE7QUFBQSxFQUN6QjtBQUFBLElBQ0MsT0FBTztBQUFBLElBQ1AsT0FBTztBQUFBO0FBQUEsRUFFUjtBQUFBLElBQ0MsT0FBTztBQUFBLElBQ1AsT0FBTztBQUFBO0FBQUEsRUFFUjtBQUFBLElBQ0MsT0FBTztBQUFBLElBQ1AsT0FBTztBQUFBO0FBQUEsRUFFUjtBQUFBLElBQ0MsT0FBTztBQUFBLElBQ1AsT0FBTztBQUFBO0FBQUEsRUFFUjtBQUFBLElBQ0MsT0FBTztBQUFBLElBQ1AsT0FBTztBQUFBO0FBQUE7IiwKICAibmFtZXMiOiBbXQp9Cg==
package/dist/index.js CHANGED
@@ -21,12 +21,13 @@ import fetch from "node-fetch";
21
21
  import prompts from "prompts";
22
22
  import degit from "degit";
23
23
  import yargs from "yargs-parser";
24
+ import ora from "ora";
24
25
  import { FRAMEWORKS, COUNTER_COMPONENTS } from "./frameworks.js";
25
26
  import { TEMPLATES } from "./templates.js";
26
27
  import { createConfig } from "./config.js";
27
28
  import { logger, defaultLogLevel } from "./logger.js";
28
29
  const cleanArgv = process.argv.filter((arg) => arg !== "--");
29
- const args = yargs(cleanArgv, { array: ["renderers"] });
30
+ const args = yargs(cleanArgv);
30
31
  prompts.override(args);
31
32
  function mkdirp(dir) {
32
33
  try {
@@ -45,8 +46,8 @@ async function main() {
45
46
  ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
46
47
  console.log(`If you encounter a problem, visit ${cyan("https://github.com/withastro/astro/issues")} to search or file a new issue.
47
48
  `);
48
- console.log(`${green(`>`)} ${gray(`Prepare for liftoff.`)}`);
49
- console.log(`${green(`>`)} ${gray(`Gathering mission details...`)}`);
49
+ let spinner = ora({ color: "green", text: "Prepare for liftoff." });
50
+ spinner.succeed();
50
51
  const cwd = args["_"][2] || ".";
51
52
  if (fs.existsSync(cwd)) {
52
53
  if (fs.readdirSync(cwd).length > 0) {
@@ -88,30 +89,23 @@ ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
88
89
  verbose: defaultLogLevel === "debug" ? true : false
89
90
  });
90
91
  const selectedTemplate = TEMPLATES.find((template) => template.value === options.template);
91
- let renderers = [];
92
- if ((selectedTemplate == null ? void 0 : selectedTemplate.renderers) === true) {
92
+ let integrations = [];
93
+ if ((selectedTemplate == null ? void 0 : selectedTemplate.integrations) === true) {
93
94
  const result = await prompts([
94
95
  {
95
96
  type: "multiselect",
96
- name: "renderers",
97
+ name: "integrations",
97
98
  message: "Which frameworks would you like to use?",
98
99
  choices: FRAMEWORKS
99
100
  }
100
101
  ]);
101
- renderers = result.renderers;
102
- } else if ((selectedTemplate == null ? void 0 : selectedTemplate.renderers) && Array.isArray(selectedTemplate.renderers) && selectedTemplate.renderers.length) {
103
- renderers = selectedTemplate.renderers;
104
- const titles = renderers.map((renderer) => {
105
- var _a;
106
- return (_a = FRAMEWORKS.find((item) => item.value === renderer)) == null ? void 0 : _a.title;
107
- }).join(", ");
108
- console.log(`${green(`\u2714`)} ${bold(`Using template's default renderers`)} ${gray("\u203A")} ${titles}`);
102
+ integrations = result.integrations;
109
103
  }
104
+ spinner = ora({ color: "green", text: "Copying project files..." }).start();
110
105
  try {
111
106
  emitter.on("info", (info) => {
112
107
  logger.debug(info.message);
113
108
  });
114
- console.log(`${green(`>`)} ${gray(`Copying project files...`)}`);
115
109
  await emitter.clone(cwd);
116
110
  } catch (err) {
117
111
  logger.debug(err);
@@ -124,10 +118,10 @@ ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
124
118
  console.log(yellow("This seems to be an issue with degit. Please check if you have 'git' installed on your system, and install it if you don't have (https://git-scm.com)."));
125
119
  console.log(yellow("If you do have 'git' installed, please run this command with the --verbose flag and file a new issue with the command output here: https://github.com/withastro/astro/issues"));
126
120
  }
121
+ spinner.fail();
127
122
  process.exit(1);
128
123
  }
129
124
  await Promise.all(POSTPROCESS_FILES.map(async (file) => {
130
- var _a;
131
125
  const fileLoc = path.resolve(path.join(cwd, file));
132
126
  switch (file) {
133
127
  case "CHANGELOG.md": {
@@ -137,17 +131,26 @@ ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
137
131
  break;
138
132
  }
139
133
  case "astro.config.mjs": {
140
- if ((selectedTemplate == null ? void 0 : selectedTemplate.renderers) !== true) {
134
+ if ((selectedTemplate == null ? void 0 : selectedTemplate.integrations) !== true) {
141
135
  break;
142
136
  }
143
- await fs.promises.writeFile(fileLoc, createConfig({ renderers }));
137
+ await fs.promises.writeFile(fileLoc, createConfig({ integrations }));
144
138
  break;
145
139
  }
146
140
  case "package.json": {
147
141
  const packageJSON = JSON.parse(await fs.promises.readFile(fileLoc, "utf8"));
148
142
  delete packageJSON.snowpack;
149
- const rendererEntries = await Promise.all(["astro", ...renderers].map((renderer) => fetch(`https://registry.npmjs.org/${renderer}/latest`).then((res) => res.json()).then((res) => [renderer, `^${res["version"]}`])));
150
- packageJSON.devDependencies = __spreadValues(__spreadValues({}, (_a = packageJSON.devDependencies) != null ? _a : {}), Object.fromEntries(rendererEntries));
143
+ const integrationEntries = (await Promise.all(integrations.map((integration) => fetch(`https://registry.npmjs.org/${integration.packageName}/latest`).then((res) => res.json()).then((res) => {
144
+ let dependencies = [[res["name"], `^${res["version"]}`]];
145
+ if (res["peerDependencies"]) {
146
+ for (const peer in res["peerDependencies"]) {
147
+ dependencies.push([peer, res["peerDependencies"][peer]]);
148
+ }
149
+ }
150
+ return dependencies;
151
+ })))).flat(1);
152
+ packageJSON.devDependencies = __spreadValues(__spreadValues({}, packageJSON.devDependencies ?? {}), Object.fromEntries(integrationEntries));
153
+ packageJSON.devDependencies = Object.fromEntries(Object.entries(packageJSON.devDependencies).sort((a, b) => a[0].localeCompare(b[0])));
151
154
  await fs.promises.writeFile(fileLoc, JSON.stringify(packageJSON, void 0, 2));
152
155
  break;
153
156
  }
@@ -156,8 +159,8 @@ ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
156
159
  if ((selectedTemplate == null ? void 0 : selectedTemplate.value) === "starter") {
157
160
  let importStatements = [];
158
161
  let components = [];
159
- await Promise.all(renderers.map(async (renderer) => {
160
- const component = COUNTER_COMPONENTS[renderer];
162
+ await Promise.all(integrations.map(async (integration) => {
163
+ const component = COUNTER_COMPONENTS[integration.id];
161
164
  const componentName = path.basename(component.filename, path.extname(component.filename));
162
165
  const absFileLoc = path.resolve(cwd, component.filename);
163
166
  importStatements.push(`import ${componentName} from '${component.filename.replace(/^src/, "..")}';`);
@@ -173,6 +176,7 @@ ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
173
176
  });
174
177
  await fs.promises.writeFile(pageFileLoc, newContent);
175
178
  }
179
+ spinner.succeed();
176
180
  console.log(bold(green("\u2714") + " Done!"));
177
181
  console.log("\nNext steps:");
178
182
  let i = 1;
@@ -193,4 +197,3 @@ export {
193
197
  main,
194
198
  mkdirp
195
199
  };
196
- //# sourceMappingURL=data:application/json;base64,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
package/dist/logger.js CHANGED
@@ -63,9 +63,8 @@ const levels = {
63
63
  silent: 90
64
64
  };
65
65
  function log(opts = {}, level, type, ...args) {
66
- var _a, _b;
67
- const logLevel = (_a = opts.level) != null ? _a : defaultLogOptions.level;
68
- const dest = (_b = opts.dest) != null ? _b : defaultLogOptions.dest;
66
+ const logLevel = opts.level ?? defaultLogOptions.level;
67
+ const dest = opts.dest ?? defaultLogOptions.dest;
69
68
  const event = {
70
69
  type,
71
70
  level,
@@ -107,4 +106,3 @@ export {
107
106
  logger,
108
107
  warn
109
108
  };
110
- //# sourceMappingURL=data:application/json;base64,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
package/dist/templates.js CHANGED
@@ -2,35 +2,25 @@ const TEMPLATES = [
2
2
  {
3
3
  title: "Starter Kit (Generic)",
4
4
  value: "starter",
5
- renderers: true
5
+ integrations: true
6
6
  },
7
7
  {
8
8
  title: "Blog",
9
- value: "blog",
10
- renderers: ["@astrojs/renderer-preact"]
9
+ value: "blog"
11
10
  },
12
11
  {
13
12
  title: "Documentation",
14
- value: "docs",
15
- renderers: ["@astrojs/renderer-preact"]
13
+ value: "docs"
16
14
  },
17
15
  {
18
16
  title: "Portfolio",
19
- value: "portfolio",
20
- renderers: ["@astrojs/renderer-preact"]
21
- },
22
- {
23
- title: "Portfolio Svelte",
24
- value: "portfolio-svelte",
25
- renderers: ["@astrojs/renderer-svelte"]
17
+ value: "portfolio"
26
18
  },
27
19
  {
28
20
  title: "Minimal",
29
- value: "minimal",
30
- renderers: []
21
+ value: "minimal"
31
22
  }
32
23
  ];
33
24
  export {
34
25
  TEMPLATES
35
26
  };
36
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL3RlbXBsYXRlcy50cyJdLAogICJtYXBwaW5ncyI6ICJBQUFPLE1BQU0sWUFBWTtBQUFBLEVBQ3hCO0FBQUEsSUFDQyxPQUFPO0FBQUEsSUFDUCxPQUFPO0FBQUEsSUFDUCxXQUFXO0FBQUE7QUFBQSxFQUVaO0FBQUEsSUFDQyxPQUFPO0FBQUEsSUFDUCxPQUFPO0FBQUEsSUFDUCxXQUFXLENBQUM7QUFBQTtBQUFBLEVBRWI7QUFBQSxJQUNDLE9BQU87QUFBQSxJQUNQLE9BQU87QUFBQSxJQUNQLFdBQVcsQ0FBQztBQUFBO0FBQUEsRUFFYjtBQUFBLElBQ0MsT0FBTztBQUFBLElBQ1AsT0FBTztBQUFBLElBQ1AsV0FBVyxDQUFDO0FBQUE7QUFBQSxFQUViO0FBQUEsSUFDQyxPQUFPO0FBQUEsSUFDUCxPQUFPO0FBQUEsSUFDUCxXQUFXLENBQUM7QUFBQTtBQUFBLEVBRWI7QUFBQSxJQUNDLE9BQU87QUFBQSxJQUNQLE9BQU87QUFBQSxJQUNQLFdBQVc7QUFBQTtBQUFBOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -1,3 +1,4 @@
1
- export declare const createConfig: ({ renderers }: {
2
- renderers: string[];
1
+ import type { Integration } from './frameworks';
2
+ export declare const createConfig: ({ integrations }: {
3
+ integrations: Integration[];
3
4
  }) => string;
@@ -1,26 +1,30 @@
1
1
  export declare const COUNTER_COMPONENTS: {
2
- '@astrojs/renderer-preact': {
2
+ preact: {
3
3
  filename: string;
4
4
  content: string;
5
5
  };
6
- '@astrojs/renderer-react': {
6
+ react: {
7
7
  filename: string;
8
8
  content: string;
9
9
  };
10
- '@astrojs/renderer-solid': {
10
+ solid: {
11
11
  filename: string;
12
12
  content: string;
13
13
  };
14
- '@astrojs/renderer-svelte': {
14
+ svelte: {
15
15
  filename: string;
16
16
  content: string;
17
17
  };
18
- '@astrojs/renderer-vue': {
18
+ vue: {
19
19
  filename: string;
20
20
  content: string;
21
21
  };
22
22
  };
23
+ export interface Integration {
24
+ id: string;
25
+ packageName: string;
26
+ }
23
27
  export declare const FRAMEWORKS: {
24
28
  title: string;
25
- value: string;
29
+ value: Integration;
26
30
  }[];
@@ -1,9 +1,9 @@
1
1
  export declare const TEMPLATES: ({
2
2
  title: string;
3
3
  value: string;
4
- renderers: boolean;
4
+ integrations: boolean;
5
5
  } | {
6
6
  title: string;
7
7
  value: string;
8
- renderers: string[];
8
+ integrations?: undefined;
9
9
  })[];
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "create-astro",
3
- "version": "0.7.1",
3
+ "version": "0.8.0-next.0",
4
4
  "type": "module",
5
5
  "author": "withastro",
6
6
  "license": "MIT",
@@ -17,30 +17,32 @@
17
17
  "bin": {
18
18
  "create-astro": "./create-astro.mjs"
19
19
  },
20
- "scripts": {
21
- "build": "astro-scripts build \"src/**/*.ts\" && tsc",
22
- "dev": "astro-scripts dev \"src/**/*.ts\"",
23
- "prepare": "yarn build",
24
- "test": "rm -rf test/fixtures && mkdir test/fixtures && node --unhandled-rejections=strict test/create-astro.test.js"
25
- },
26
20
  "files": [
27
21
  "dist",
28
22
  "create-astro.js"
29
23
  ],
30
24
  "dependencies": {
31
- "@types/degit": "^2.8.2",
32
- "@types/node-fetch": "^3.0.0",
33
- "@types/prompts": "^2.0.12",
25
+ "@types/degit": "^2.8.3",
26
+ "@types/prompts": "^2.0.14",
34
27
  "degit": "^2.8.4",
35
- "kleur": "^4.1.1",
36
- "node-fetch": "^3.0.0",
37
- "prompts": "^2.4.1",
38
- "yargs-parser": "^21.0.0"
28
+ "kleur": "^4.1.4",
29
+ "node-fetch": "^3.2.3",
30
+ "ora": "^6.1.0",
31
+ "prompts": "^2.4.2",
32
+ "yargs-parser": "^21.0.1"
39
33
  },
40
34
  "devDependencies": {
41
- "uvu": "^0.5.1"
35
+ "@types/yargs-parser": "^21.0.0",
36
+ "astro-scripts": "0.0.2",
37
+ "uvu": "^0.5.3"
42
38
  },
43
39
  "engines": {
44
40
  "node": "^14.15.0 || >=16.0.0"
45
- }
46
- }
41
+ },
42
+ "scripts": {
43
+ "build": "astro-scripts build \"src/**/*.ts\" && tsc",
44
+ "dev": "astro-scripts dev \"src/**/*.ts\"",
45
+ "test": "rm -rf test/fixtures && mkdir test/fixtures && node --unhandled-rejections=strict test/create-astro.test.js"
46
+ },
47
+ "readme": "# create-astro\n\n## Scaffolding for Astro projects\n\n**With NPM:**\n\n```bash\nnpm init astro\n```\n\n**With Yarn:**\n\n```bash\nyarn create astro\n```\n\n`create-astro` automatically runs in _interactive_ mode, but you can also specify your project name and template with command line arguments.\n\n```bash\n# npm 6.x\nnpm init astro my-astro-project --template starter\n\n# npm 7+, extra double-dash is needed:\nnpm init astro my-astro-project -- --template starter\n\n# yarn\nyarn create astro my-astro-project --template starter\n```\n[Check out the full list][examples] of example starter templates, available on GitHub.\n\nYou can also use any GitHub repo as a template:\n\n```bash\nnpm init astro my-astro-project -- --template cassidoo/shopify-react-astro\n```\n\n### CLI Flags\n\nMay be provided in place of prompts\n\n| Name | Description |\n|:-------------|:----------------------------------------------------|\n| `--template` | Specify the template name ([list][examples]) |\n| `--commit` | Specify a specific Git commit or branch to use from this repo (by default, `main` branch of this repo will be used) |\n\n### Debugging\n\nTo debug `create-astro`, you can use the `--verbose` flag which will log the output of degit and some more information about the command, this can be useful when you encounter an error and want to report it.\n\n```bash\n# npm 6.x\nnpm init astro my-astro-project --verbose\n\n# npm 7+, extra double-dash is needed:\nnpm init astro my-astro-project -- --verbose\n\n# yarn\nyarn create astro my-astro-project --verbose\n```\n\n[examples]: https://github.com/withastro/astro/tree/main/examples\n"
48
+ }