create-astro 0.7.1 → 0.9.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/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 {
@@ -37,6 +38,9 @@ function mkdirp(dir) {
37
38
  throw e;
38
39
  }
39
40
  }
41
+ function isEmpty(dirPath) {
42
+ return !fs.existsSync(dirPath) || fs.readdirSync(dirPath).length === 0;
43
+ }
40
44
  const { version } = JSON.parse(fs.readFileSync(new URL("../package.json", import.meta.url), "utf-8"));
41
45
  const POSTPROCESS_FILES = ["package.json", "astro.config.mjs", "CHANGELOG.md"];
42
46
  async function main() {
@@ -45,24 +49,38 @@ async function main() {
45
49
  ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
46
50
  console.log(`If you encounter a problem, visit ${cyan("https://github.com/withastro/astro/issues")} to search or file a new issue.
47
51
  `);
48
- console.log(`${green(`>`)} ${gray(`Prepare for liftoff.`)}`);
49
- console.log(`${green(`>`)} ${gray(`Gathering mission details...`)}`);
50
- const cwd = args["_"][2] || ".";
51
- if (fs.existsSync(cwd)) {
52
- if (fs.readdirSync(cwd).length > 0) {
53
- const response = await prompts({
54
- type: "confirm",
55
- name: "forceOverwrite",
56
- message: "Directory not empty. Continue [force overwrite]?",
57
- initial: false
58
- });
59
- if (!response.forceOverwrite) {
60
- process.exit(1);
61
- }
62
- mkdirp(cwd);
52
+ let spinner = ora({ color: "green", text: "Prepare for liftoff." });
53
+ spinner.succeed();
54
+ let cwd = args["_"][2];
55
+ if (cwd && isEmpty(cwd)) {
56
+ let acknowledgeProjectDir = ora({
57
+ color: "green",
58
+ text: `Using ${bold(cwd)} as project directory.`
59
+ });
60
+ acknowledgeProjectDir.succeed();
61
+ }
62
+ if (!cwd || !isEmpty(cwd)) {
63
+ const notEmptyMsg = (dirPath) => `"${bold(dirPath)}" is not empty. Please clear contents or choose a different path.`;
64
+ if (!isEmpty(cwd)) {
65
+ let rejectProjectDir = ora({ color: "red", text: notEmptyMsg(cwd) });
66
+ rejectProjectDir.fail();
63
67
  }
64
- } else {
65
- mkdirp(cwd);
68
+ const dirResponse = await prompts({
69
+ type: "text",
70
+ name: "directory",
71
+ message: "Where would you like to create your app?",
72
+ initial: "./my-astro-site",
73
+ validate(value) {
74
+ if (!isEmpty(value)) {
75
+ return notEmptyMsg(value);
76
+ }
77
+ return true;
78
+ }
79
+ });
80
+ cwd = dirResponse.directory;
81
+ }
82
+ if (!cwd) {
83
+ process.exit(1);
66
84
  }
67
85
  const options = await prompts([
68
86
  {
@@ -88,30 +106,23 @@ ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
88
106
  verbose: defaultLogLevel === "debug" ? true : false
89
107
  });
90
108
  const selectedTemplate = TEMPLATES.find((template) => template.value === options.template);
91
- let renderers = [];
92
- if ((selectedTemplate == null ? void 0 : selectedTemplate.renderers) === true) {
109
+ let integrations = [];
110
+ if ((selectedTemplate == null ? void 0 : selectedTemplate.integrations) === true) {
93
111
  const result = await prompts([
94
112
  {
95
113
  type: "multiselect",
96
- name: "renderers",
114
+ name: "integrations",
97
115
  message: "Which frameworks would you like to use?",
98
116
  choices: FRAMEWORKS
99
117
  }
100
118
  ]);
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}`);
119
+ integrations = result.integrations;
109
120
  }
121
+ spinner = ora({ color: "green", text: "Copying project files..." }).start();
110
122
  try {
111
123
  emitter.on("info", (info) => {
112
124
  logger.debug(info.message);
113
125
  });
114
- console.log(`${green(`>`)} ${gray(`Copying project files...`)}`);
115
126
  await emitter.clone(cwd);
116
127
  } catch (err) {
117
128
  logger.debug(err);
@@ -124,10 +135,10 @@ ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
124
135
  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
136
  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
137
  }
138
+ spinner.fail();
127
139
  process.exit(1);
128
140
  }
129
141
  await Promise.all(POSTPROCESS_FILES.map(async (file) => {
130
- var _a;
131
142
  const fileLoc = path.resolve(path.join(cwd, file));
132
143
  switch (file) {
133
144
  case "CHANGELOG.md": {
@@ -137,17 +148,26 @@ ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
137
148
  break;
138
149
  }
139
150
  case "astro.config.mjs": {
140
- if ((selectedTemplate == null ? void 0 : selectedTemplate.renderers) !== true) {
151
+ if ((selectedTemplate == null ? void 0 : selectedTemplate.integrations) !== true) {
141
152
  break;
142
153
  }
143
- await fs.promises.writeFile(fileLoc, createConfig({ renderers }));
154
+ await fs.promises.writeFile(fileLoc, createConfig({ integrations }));
144
155
  break;
145
156
  }
146
157
  case "package.json": {
147
158
  const packageJSON = JSON.parse(await fs.promises.readFile(fileLoc, "utf8"));
148
159
  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));
160
+ const integrationEntries = (await Promise.all(integrations.map((integration) => fetch(`https://registry.npmjs.org/${integration.packageName}/latest`).then((res) => res.json()).then((res) => {
161
+ let dependencies = [[res["name"], `^${res["version"]}`]];
162
+ if (res["peerDependencies"]) {
163
+ for (const peer in res["peerDependencies"]) {
164
+ dependencies.push([peer, res["peerDependencies"][peer]]);
165
+ }
166
+ }
167
+ return dependencies;
168
+ })))).flat(1);
169
+ packageJSON.devDependencies = __spreadValues(__spreadValues({}, packageJSON.devDependencies ?? {}), Object.fromEntries(integrationEntries));
170
+ packageJSON.devDependencies = Object.fromEntries(Object.entries(packageJSON.devDependencies).sort((a, b) => a[0].localeCompare(b[0])));
151
171
  await fs.promises.writeFile(fileLoc, JSON.stringify(packageJSON, void 0, 2));
152
172
  break;
153
173
  }
@@ -156,8 +176,8 @@ ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
156
176
  if ((selectedTemplate == null ? void 0 : selectedTemplate.value) === "starter") {
157
177
  let importStatements = [];
158
178
  let components = [];
159
- await Promise.all(renderers.map(async (renderer) => {
160
- const component = COUNTER_COMPONENTS[renderer];
179
+ await Promise.all(integrations.map(async (integration) => {
180
+ const component = COUNTER_COMPONENTS[integration.id];
161
181
  const componentName = path.basename(component.filename, path.extname(component.filename));
162
182
  const absFileLoc = path.resolve(cwd, component.filename);
163
183
  importStatements.push(`import ${componentName} from '${component.filename.replace(/^src/, "..")}';`);
@@ -173,6 +193,7 @@ ${bold("Welcome to Astro!")} ${gray(`(create-astro v${version})`)}`);
173
193
  });
174
194
  await fs.promises.writeFile(pageFileLoc, newContent);
175
195
  }
196
+ spinner.succeed();
176
197
  console.log(bold(green("\u2714") + " Done!"));
177
198
  console.log("\nNext steps:");
178
199
  let i = 1;
@@ -193,4 +214,3 @@ export {
193
214
  main,
194
215
  mkdirp
195
216
  };
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,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2xvZ2dlci50cyJdLAogICJtYXBwaW5ncyI6ICJBQUFBO0FBQ0E7QUFDQTtBQU1BLDJCQUFtQztBQUNsQyxRQUFNLGdCQUFnQjtBQUN0QixNQUFJLFFBQVEsSUFBSSxNQUFNO0FBQ3JCLFVBQU0sa0JBQWtCLFFBQVEsSUFBSSxLQUFLLE1BQU0sS0FBSyxHQUFHLFFBQVEsTUFBTTtBQUdyRSxRQUFJLGdCQUFnQixTQUFTO0FBQUcsYUFBTztBQUFBO0FBQ2xDLGFBQU87QUFBQTtBQUNOLFdBQU87QUFBQTtBQUdmLE1BQU0sS0FBSyxJQUFJLEtBQUssZUFBZSxtQkFBbUI7QUFBQSxFQUNyRCxNQUFNO0FBQUEsRUFDTixRQUFRO0FBQUE7QUFHRixNQUFNLHdCQUF3QixJQUFJLFNBQVM7QUFBQSxFQUNqRCxZQUFZO0FBQUEsRUFDWixNQUFNLE9BQW1CLEdBQUcsVUFBVTtBQUNyQyxRQUFJLE9BQXNCLFFBQVE7QUFDbEMsUUFBSSxPQUFPLE1BQU0sU0FBUyxPQUFPO0FBQVUsYUFBTyxRQUFRO0FBRTFELFNBQUssTUFBTSxJQUFJLEdBQUcsT0FBTyxJQUFJLFVBQVU7QUFFdkMsUUFBSSxPQUFPLE1BQU07QUFDakIsUUFBSSxNQUFNO0FBQ1QsY0FBUSxNQUFNO0FBQUEsYUFDUjtBQUNKLGlCQUFPLEtBQUssS0FBSztBQUNqQjtBQUFBLGFBQ0k7QUFDSixpQkFBTyxLQUFLLE9BQU87QUFDbkI7QUFBQSxhQUNJO0FBQ0osaUJBQU8sS0FBSyxJQUFJO0FBQ2hCO0FBQUE7QUFHRixXQUFLLE1BQU0sSUFBSTtBQUFBO0FBR2hCLFNBQUssTUFBTSxXQUFXLEdBQUcsTUFBTTtBQUMvQixTQUFLLE1BQU07QUFFWDtBQUFBO0FBQUE7QUFXSyxJQUFJO0FBQ1gsSUFBSSxRQUFRLEtBQUssU0FBUyxjQUFjO0FBQ3ZDLG9CQUFrQjtBQUFBLFdBQ1IsUUFBUSxLQUFLLFNBQVMsYUFBYTtBQUM3QyxvQkFBa0I7QUFBQSxPQUNaO0FBQ04sb0JBQWtCO0FBQUE7QUFRWixNQUFNLG9CQUEwQztBQUFBLEVBQ3RELE1BQU07QUFBQSxFQUNOLE9BQU87QUFBQTtBQVVELE1BQU0sU0FBc0M7QUFBQSxFQUNsRCxPQUFPO0FBQUEsRUFDUCxNQUFNO0FBQUEsRUFDTixNQUFNO0FBQUEsRUFDTixPQUFPO0FBQUEsRUFDUCxRQUFRO0FBQUE7QUFJRixhQUFhLE9BQW1CLElBQUksT0FBb0IsU0FBd0IsTUFBa0I7QUFsR3pHO0FBbUdDLFFBQU0sV0FBVyxXQUFLLFVBQUwsWUFBYyxrQkFBa0I7QUFDakQsUUFBTSxPQUFPLFdBQUssU0FBTCxZQUFhLGtCQUFrQjtBQUM1QyxRQUFNLFFBQW9CO0FBQUEsSUFDekI7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0EsU0FBUztBQUFBO0FBSVYsTUFBSSxPQUFPLFlBQVksT0FBTyxRQUFRO0FBQ3JDO0FBQUE7QUFHRCxPQUFLLE1BQU07QUFBQTtBQUlMLGVBQWUsTUFBa0IsU0FBd0IsVUFBc0I7QUFDckYsU0FBTyxJQUFJLE1BQU0sU0FBUyxNQUFNLEdBQUc7QUFBQTtBQUk3QixjQUFjLE1BQWtCLFNBQXdCLFVBQXNCO0FBQ3BGLFNBQU8sSUFBSSxNQUFNLFFBQVEsTUFBTSxHQUFHO0FBQUE7QUFJNUIsY0FBYyxNQUFrQixTQUF3QixVQUFzQjtBQUNwRixTQUFPLElBQUksTUFBTSxRQUFRLE1BQU0sR0FBRztBQUFBO0FBSTVCLGVBQWUsTUFBa0IsU0FBd0IsVUFBc0I7QUFDckYsU0FBTyxJQUFJLE1BQU0sU0FBUyxNQUFNLEdBQUc7QUFBQTtBQUk3QixNQUFNLFNBQVM7QUFBQSxFQUNyQixPQUFPLE1BQU0sS0FBSyxNQUFNLG1CQUFtQjtBQUFBLEVBQzNDLE1BQU0sS0FBSyxLQUFLLE1BQU0sbUJBQW1CO0FBQUEsRUFDekMsTUFBTSxLQUFLLEtBQUssTUFBTSxtQkFBbUI7QUFBQSxFQUN6QyxPQUFPLE1BQU0sS0FBSyxNQUFNLG1CQUFtQjtBQUFBOyIsCiAgIm5hbWVzIjogW10KfQo=
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.9.0",
4
4
  "type": "module",
5
5
  "author": "withastro",
6
6
  "license": "MIT",
@@ -19,26 +19,32 @@
19
19
  },
20
20
  "scripts": {
21
21
  "build": "astro-scripts build \"src/**/*.ts\" && tsc",
22
+ "build:ci": "astro-scripts build \"src/**/*.ts\"",
22
23
  "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"
24
+ "test": "mocha --exit --timeout 20000"
25
25
  },
26
26
  "files": [
27
27
  "dist",
28
28
  "create-astro.js"
29
29
  ],
30
30
  "dependencies": {
31
- "@types/degit": "^2.8.2",
32
- "@types/node-fetch": "^3.0.0",
33
- "@types/prompts": "^2.0.12",
31
+ "@types/degit": "^2.8.3",
32
+ "@types/prompts": "^2.0.14",
34
33
  "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"
34
+ "kleur": "^4.1.4",
35
+ "node-fetch": "^3.2.3",
36
+ "ora": "^6.1.0",
37
+ "prompts": "^2.4.2",
38
+ "yargs-parser": "^21.0.1"
39
39
  },
40
40
  "devDependencies": {
41
- "uvu": "^0.5.1"
41
+ "@types/chai": "^4.3.1",
42
+ "@types/mocha": "^9.1.0",
43
+ "@types/yargs-parser": "^21.0.0",
44
+ "astro-scripts": "workspace:*",
45
+ "chai": "^4.3.6",
46
+ "mocha": "^9.2.2",
47
+ "uvu": "^0.5.3"
42
48
  },
43
49
  "engines": {
44
50
  "node": "^14.15.0 || >=16.0.0"