UNPKG

sdkscript

Version:

Set up a modern Cosmos app by running one command ⚛️

119 lines 4.31 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.getPackageLicAndAccessInfo = exports.getQuestionsAndAnswers = exports.cloneRepo = exports.getTemplateFolder = void 0; const shell = __importStar(require("shelljs")); const prompt_1 = require("./prompt"); const path_1 = require("path"); const mkdirp_1 = require("mkdirp"); const os_1 = require("os"); const fs = __importStar(require("fs")); const dargs = require('dargs'); const getTemplateFolder = async (argv) => { let folderName = 'templates'; // get example info if (argv.examples || argv.example || argv.ex) { folderName = 'examples'; const example = argv.examples || argv.example || argv.ex; if (typeof example === 'string') { argv.template = example; } } // get boilerplate info if (argv.boilerplates || argv.boilerplate) { folderName = 'boilerplates'; const boilerplate = argv.boilerplates || argv.boilerplate; if (typeof boilerplate === 'string') { argv.template = boilerplate; } } return folderName; }; exports.getTemplateFolder = getTemplateFolder; const cloneRepo = (argv, repo, name) => { const tempname = Math.random().toString(36).slice(2, 7); const dir = (0, path_1.join)(argv.tmpdir || (0, os_1.tmpdir)(), tempname); (0, mkdirp_1.sync)(dir); shell.cd(dir); shell.exec(`git clone --depth 1 ${repo} ${name}`); return dir; }; exports.cloneRepo = cloneRepo; const getQuestionsAndAnswers = async (argv, name, folderName) => { const path = (0, path_1.join)(folderName, argv.template, '.questions.json'); if (fs.existsSync(path)) { const questions = JSON.parse(fs.readFileSync(path, 'utf-8')); const fullname = shell .exec('git config --global user.name', { silent: true }) .trim(); const email = shell .exec('git config --global user.email', { silent: true }) .trim(); // @__USERNAME__/__MODULENAME__ // __PACKAGE_IDENTIFIER__ const args = dargs({ _: [], ...argv, __QUESTIONS_EXIST_: true, __MODULENAME__: name, __USERFULLNAME__: fullname, __USEREMAIL__: email, }, { allowCamelCase: true }); const results = await (0, prompt_1.prompt)(questions, args); return results; } else { return {}; } }; exports.getQuestionsAndAnswers = getQuestionsAndAnswers; const getPackageLicAndAccessInfo = async (results) => { let scopedResults; const license = await (0, prompt_1.prompt)([ { name: '__LICENSE__', message: 'Which license?', choices: ['MIT', 'closed'], type: 'list', required: true, }, ], []); if (results.__ACCESS__ === 'public') { scopedResults = await (0, prompt_1.prompt)([ { type: 'confirm', name: 'scoped', message: 'use npm scopes?', required: true, }, ], []); } return { license, scopedResults }; }; exports.getPackageLicAndAccessInfo = getPackageLicAndAccessInfo; //# sourceMappingURL=utils.js.map