UNPKG

react-static

Version:

A progressive static site generator for React

344 lines (268 loc) 30.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _fsExtra = _interopRequireDefault(require("fs-extra")); var _chalk = _interopRequireDefault(require("chalk")); var _path = _interopRequireDefault(require("path")); var _gitPromise = _interopRequireDefault(require("git-promise")); var _child_process = require("child_process"); var _inquirer = _interopRequireDefault(require("inquirer")); var _inquirerAutocompletePrompt = _interopRequireDefault(require("inquirer-autocomplete-prompt")); var _matchSorter = _interopRequireDefault(require("match-sorter")); var _downloadGitRepo = _interopRequireDefault(require("download-git-repo")); var _util = require("util"); var _utils = require("../utils"); // _inquirer["default"].registerPrompt('autocomplete', _inquirerAutocompletePrompt["default"]); var typeLocal = 'Local Directory...'; var typeGit = 'GIT Repository...'; var typeExample = 'React Static Example'; var templatesDir = _path["default"].resolve(__dirname, '../../templates'); var templates = _fsExtra["default"].readdirSync(templatesDir).filter(function (d) { return !d.startsWith('.') && !d.startsWith('README'); }); var _default = /*#__PURE__*/function () { var _create = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2(_ref) { var name, template, isCLI, isYarn, exampleChoices, templateType, answers, dest, _answers, _yield$inquirer$promp, localDirectory, _yield$inquirer$promp2, githubRepoName, getGitHubRepo; return _regenerator["default"].wrap(function _callee2$(_context2) { while (1) { switch (_context2.prev = _context2.next) { case 0: name = _ref.name, template = _ref.template, isCLI = _ref.isCLI; isYarn = shouldUseYarn(); console.log(''); exampleChoices = [].concat((0, _toConsumableArray2["default"])(templates), [typeLocal, typeGit]); templateType = typeExample; // prompt if --name argument is not passed from CLI // warning: since name will be set as a function by commander by default // unless it's assigned as an argument from the CLI, we can't simply just // check for its existence. if it has not been set by the CLI, we properly // set it to null for later conditional checks. if (!(isCLI && !name)) { _context2.next = 10; break; } _context2.next = 8; return _inquirer["default"].prompt({ type: 'input', name: 'name', message: 'What should we name this project?', "default": 'my-static-site' }); case 8: answers = _context2.sent; name = answers.name; case 10: if (name) { _context2.next = 12; break; } throw new Error('A project name is required. Please use options.name to define one.'); case 12: dest = _path["default"].resolve(process.cwd(), name); if (!_fsExtra["default"].existsSync(dest)) { _context2.next = 15; break; } throw new Error("Could not create project. Directory already exists at ".concat(dest, "!")); case 15: if (!(isCLI && !template)) { _context2.next = 20; break; } _context2.next = 18; return _inquirer["default"].prompt({ type: 'autocomplete', name: 'template', message: 'Select a template below...', source: function () { var _source = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(answersSoFar, input) { return _regenerator["default"].wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: return _context.abrupt("return", !input ? exampleChoices : (0, _matchSorter["default"])(exampleChoices, input)); case 1: case "end": return _context.stop(); } } }, _callee); })); function source(_x2, _x3) { return _source.apply(this, arguments); } return source; }() }); case 18: _answers = _context2.sent; template = _answers.template; case 20: if (template) { _context2.next = 22; break; } throw new Error('A project template is required. Please use options.template to define one.'); case 22: (0, _utils.time)(_chalk["default"].green("[\u2713] Project \"".concat(name, "\" created"))); console.log('Creating new react-static project...'); if (!(template === typeLocal)) { _context2.next = 31; break; } templateType = typeLocal; _context2.next = 28; return _inquirer["default"].prompt([{ type: 'input', name: 'localDirectory', message: "Enter an local directory's absolute location (~/Desktop/my-template)" }]); case 28: _yield$inquirer$promp = _context2.sent; localDirectory = _yield$inquirer$promp.localDirectory; template = localDirectory; case 31: if (!(template === typeGit)) { _context2.next = 38; break; } templateType = typeGit; _context2.next = 35; return _inquirer["default"].prompt([{ type: 'input', name: 'githubRepoName', message: 'Enter a repository URL from GitHub, BitBucket, GitLab, or any other public repo. (https://github.com/ownerName/repoName.git)' }]); case 35: _yield$inquirer$promp2 = _context2.sent; githubRepoName = _yield$inquirer$promp2.githubRepoName; template = githubRepoName; case 38: console.log(''); // GIT repositories if (!(templateType === typeGit)) { _context2.next = 67; break; } if (!(template.startsWith('https://') || template.startsWith('git@'))) { _context2.next = 53; break; } _context2.prev = 41; console.log(_chalk["default"].green("Cloning Git template: ".concat(template))); _context2.next = 45; return (0, _gitPromise["default"])("clone --recursive ".concat(template, " ").concat(dest)); case 45: _context2.next = 51; break; case 47: _context2.prev = 47; _context2.t0 = _context2["catch"](41); console.log(_chalk["default"].red("Cloning Git template: ".concat(template, " failed!"))); throw _context2.t0; case 51: _context2.next = 65; break; case 53: if (!template.startsWith('http://')) { _context2.next = 65; break; } // use download-git-repo to fetch remote repository getGitHubRepo = (0, _util.promisify)(_downloadGitRepo["default"]); _context2.prev = 55; console.log(_chalk["default"].green("Cloning Git template: ".concat(template))); _context2.next = 59; return getGitHubRepo(template, dest); case 59: _context2.next = 65; break; case 61: _context2.prev = 61; _context2.t1 = _context2["catch"](55); console.log(_chalk["default"].red("Cloning Git template: ".concat(template, " failed!"))); throw _context2.t1; case 65: _context2.next = 90; break; case 67: if (!(templateType === typeExample)) { _context2.next = 80; break; } // React Static templates console.log(_chalk["default"].green("Using React Static template: ".concat(template))); _context2.prev = 69; _context2.next = 72; return _fsExtra["default"].copy(_path["default"].resolve(templatesDir, template), _path["default"].resolve(process.cwd(), dest)); case 72: _context2.next = 78; break; case 74: _context2.prev = 74; _context2.t2 = _context2["catch"](69); console.log(_chalk["default"].red("Copying React Static template: ".concat(template, " failed!"))); throw _context2.t2; case 78: _context2.next = 90; break; case 80: _context2.prev = 80; console.log(_chalk["default"].green("Using template from directory: ".concat(template))); _context2.next = 84; return _fsExtra["default"].copy(_path["default"].resolve(process.cwd(), template), dest); case 84: _context2.next = 90; break; case 86: _context2.prev = 86; _context2.t3 = _context2["catch"](80); console.log(_chalk["default"].red("Copying the template from directory: ".concat(template, " failed!"))); throw _context2.t3; case 90: if (!(!_fsExtra["default"].pathExistsSync(_path["default"].join(dest, '.gitignore')) && _fsExtra["default"].pathExistsSync(_path["default"].join(dest, 'gitignore')))) { _context2.next = 93; break; } _context2.next = 93; return _fsExtra["default"].move(_path["default"].join(dest, 'gitignore'), _path["default"].join(dest, '.gitignore')); case 93: if (_fsExtra["default"].pathExistsSync(_path["default"].join(dest, 'gitignore'))) { _fsExtra["default"].removeSync(_path["default"].join(dest, 'gitignore')); } if (isCLI) { console.log("Installing dependencies with: ".concat(isYarn ? _chalk["default"].hex(_utils.ChalkColor.yarn)('Yarn') : _chalk["default"].hex(_utils.ChalkColor.npm)('NPM'), "...")); // We install react-static separately to ensure we always have the latest stable release (0, _child_process.execSync)("cd \"".concat(name, "\" && ").concat(isYarn ? 'yarn' : 'npm install')); console.log(''); } (0, _utils.timeEnd)(_chalk["default"].green("[\u2713] Project \"".concat(name, "\" created"))); console.log("\n ".concat(_chalk["default"].green('To get started:'), "\n\n cd \"").concat(name, "\" ").concat(!isCLI ? "&& ".concat(isYarn ? _chalk["default"].hex(_utils.ChalkColor.yarn)('yarn') : _chalk["default"].hex(_utils.ChalkColor.npm)('npm install')) : '', "\n\n ").concat(isYarn ? _chalk["default"].hex(_utils.ChalkColor.yarn)('yarn') : _chalk["default"].hex(_utils.ChalkColor.npm)('npm run'), " start ").concat(_chalk["default"].green('- Start the development server'), "\n ").concat(isYarn ? _chalk["default"].hex(_utils.ChalkColor.yarn)('yarn') : _chalk["default"].hex(_utils.ChalkColor.npm)('npm run'), " build ").concat(_chalk["default"].green('- Build for production'), "\n ").concat(isYarn ? _chalk["default"].hex(_utils.ChalkColor.yarn)('yarn') : _chalk["default"].hex(_utils.ChalkColor.npm)('npm run'), " serve ").concat(_chalk["default"].green('- Test a production build locally'), "\n ")); case 97: case "end": return _context2.stop(); } } }, _callee2, null, [[41, 47], [55, 61], [69, 74], [80, 86]]); })); function create(_x) { return _create.apply(this, arguments); } return create; }(); exports["default"] = _default; function shouldUseYarn() { try { (0, _child_process.execSync)('yarnpkg --version', { stdio: 'ignore' }); return true; } catch (e) { return false; } } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/commands/create.js"],"names":["inquirer","registerPrompt","autoCompletePrompt","typeLocal","typeGit","typeExample","templatesDir","path","resolve","__dirname","templates","fs","readdirSync","filter","d","startsWith","name","template","isCLI","isYarn","shouldUseYarn","console","log","exampleChoices","templateType","prompt","type","message","answers","Error","dest","process","cwd","existsSync","source","answersSoFar","input","chalk","green","localDirectory","githubRepoName","red","getGitHubRepo","downloadGitRepo","copy","pathExistsSync","join","move","removeSync","hex","ChalkColor","yarn","npm","create","stdio","e"],"mappings":"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","sourcesContent":["import fs from 'fs-extra'\nimport chalk from 'chalk'\nimport path from 'path'\nimport git from 'git-promise'\nimport { execSync } from 'child_process'\nimport inquirer from 'inquirer'\nimport autoCompletePrompt from 'inquirer-autocomplete-prompt'\nimport matchSorter from 'match-sorter'\nimport downloadGitRepo from 'download-git-repo'\nimport { promisify } from 'util'\n//\nimport { ChalkColor, time, timeEnd } from '../utils'\n\ninquirer.registerPrompt('autocomplete', autoCompletePrompt)\n\nconst typeLocal = 'Local Directory...'\nconst typeGit = 'GIT Repository...'\nconst typeExample = 'React Static Example'\n\nconst templatesDir = path.resolve(__dirname, '../../templates')\n\nconst templates = fs\n  .readdirSync(templatesDir)\n  .filter(d => !d.startsWith('.') && !d.startsWith('README'))\n\nexport default (async function create({ name, template, isCLI }) {\n  const isYarn = shouldUseYarn()\n\n  console.log('')\n\n  const exampleChoices = [...templates, typeLocal, typeGit]\n\n  let templateType = typeExample\n\n  // prompt if --name argument is not passed from CLI\n  // warning: since name will be set as a function by commander by default\n  //   unless it's assigned as an argument from the CLI, we can't simply just\n  //   check for its existence. if it has not been set by the CLI, we properly\n  //   set it to null for later conditional checks.\n  if (isCLI && !name) {\n    const answers = await inquirer.prompt({\n      type: 'input',\n      name: 'name',\n      message: 'What should we name this project?',\n      default: 'my-static-site',\n    })\n    name = answers.name\n  }\n\n  if (!name) {\n    throw new Error(\n      'A project name is required. Please use options.name to define one.'\n    )\n  }\n\n  const dest = path.resolve(process.cwd(), name)\n\n  if (fs.existsSync(dest)) {\n    throw new Error(\n      `Could not create project. Directory already exists at ${dest}!`\n    )\n  }\n\n  if (isCLI && !template) {\n    const answers = await inquirer.prompt({\n      type: 'autocomplete',\n      name: 'template',\n      message: 'Select a template below...',\n      source: async (answersSoFar, input) =>\n        !input ? exampleChoices : matchSorter(exampleChoices, input),\n    })\n    template = answers.template\n  }\n\n  if (!template) {\n    throw new Error(\n      'A project template is required. Please use options.template to define one.'\n    )\n  }\n\n  time(chalk.green(`[\\u2713] Project \"${name}\" created`))\n  console.log('Creating new react-static project...')\n\n  if (template === typeLocal) {\n    templateType = typeLocal\n    const { localDirectory } = await inquirer.prompt([\n      {\n        type: 'input',\n        name: 'localDirectory',\n        message: `Enter an local directory's absolute location (~/Desktop/my-template)`,\n      },\n    ])\n    template = localDirectory\n  }\n\n  if (template === typeGit) {\n    templateType = typeGit\n    const { githubRepoName } = await inquirer.prompt([\n      {\n        type: 'input',\n        name: 'githubRepoName',\n        message:\n          'Enter a repository URL from GitHub, BitBucket, GitLab, or any other public repo. (https://github.com/ownerName/repoName.git)',\n      },\n    ])\n    template = githubRepoName\n  }\n\n  console.log('')\n\n  // GIT repositories\n  if (templateType === typeGit) {\n    if (template.startsWith('https://') || template.startsWith('git@')) {\n      try {\n        console.log(chalk.green(`Cloning Git template: ${template}`))\n        await git(`clone --recursive ${template} ${dest}`)\n      } catch (err) {\n        console.log(chalk.red(`Cloning Git template: ${template} failed!`))\n        throw err\n      }\n    } else if (template.startsWith('http://')) {\n      // use download-git-repo to fetch remote repository\n      const getGitHubRepo = promisify(downloadGitRepo)\n      try {\n        console.log(chalk.green(`Cloning Git template: ${template}`))\n        await getGitHubRepo(template, dest)\n      } catch (err) {\n        console.log(chalk.red(`Cloning Git template: ${template} failed!`))\n        throw err\n      }\n    }\n  } else if (templateType === typeExample) {\n    // React Static templates\n    console.log(chalk.green(`Using React Static template: ${template}`))\n    try {\n      await fs.copy(\n        path.resolve(templatesDir, template),\n        path.resolve(process.cwd(), dest)\n      )\n    } catch (err) {\n      console.log(\n        chalk.red(`Copying React Static template: ${template} failed!`)\n      )\n      throw err\n    }\n  } else {\n    // Local templates\n    try {\n      console.log(chalk.green(`Using template from directory: ${template}`))\n      await fs.copy(path.resolve(process.cwd(), template), dest)\n    } catch (err) {\n      console.log(\n        chalk.red(`Copying the template from directory: ${template} failed!`)\n      )\n      throw err\n    }\n  }\n\n  // Since npm packaging will clobber .gitignore files\n  // We need to rename the gitignore file to .gitignore\n  // See: https://github.com/npm/npm/issues/1862\n\n  if (\n    !fs.pathExistsSync(path.join(dest, '.gitignore')) &&\n    fs.pathExistsSync(path.join(dest, 'gitignore'))\n  ) {\n    await fs.move(path.join(dest, 'gitignore'), path.join(dest, '.gitignore'))\n  }\n  if (fs.pathExistsSync(path.join(dest, 'gitignore'))) {\n    fs.removeSync(path.join(dest, 'gitignore'))\n  }\n\n  if (isCLI) {\n    console.log(\n      `Installing dependencies with: ${\n        isYarn\n          ? chalk.hex(ChalkColor.yarn)('Yarn')\n          : chalk.hex(ChalkColor.npm)('NPM')\n      }...`\n    )\n    // We install react-static separately to ensure we always have the latest stable release\n    execSync(`cd \"${name}\" && ${isYarn ? 'yarn' : 'npm install'}`)\n    console.log('')\n  }\n\n  timeEnd(chalk.green(`[\\u2713] Project \"${name}\" created`))\n\n  console.log(`\n  ${chalk.green('To get started:')}\n\n    cd \"${name}\" ${\n    !isCLI\n      ? `&& ${\n          isYarn\n            ? chalk.hex(ChalkColor.yarn)('yarn')\n            : chalk.hex(ChalkColor.npm)('npm install')\n        }`\n      : ''\n  }\n\n    ${\n      isYarn\n        ? chalk.hex(ChalkColor.yarn)('yarn')\n        : chalk.hex(ChalkColor.npm)('npm run')\n    } start ${chalk.green('- Start the development server')}\n    ${\n      isYarn\n        ? chalk.hex(ChalkColor.yarn)('yarn')\n        : chalk.hex(ChalkColor.npm)('npm run')\n    } build ${chalk.green('- Build for production')}\n    ${\n      isYarn\n        ? chalk.hex(ChalkColor.yarn)('yarn')\n        : chalk.hex(ChalkColor.npm)('npm run')\n    } serve ${chalk.green('- Test a production build locally')}\n  `)\n})\n\nfunction shouldUseYarn() {\n  try {\n    execSync('yarnpkg --version', { stdio: 'ignore' })\n    return true\n  } catch (e) {\n    return false\n  }\n}\n"]}