UNPKG

venmjs

Version:

This is a tool ๐Ÿ”ง that can be installed in your terminal at any time โ›๏ธ it was made for beginners and even for experts, for his utilities, and for a simple creation process ๐Ÿงจ. Every web developer knows how frustrating is to deal with the creation of a ne

82 lines (57 loc) โ€ข 5.26 kB
'use strict'; function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _fsExtra = _interopRequireDefault(require("fs-extra")); var _path = _interopRequireDefault(require("path")); var logger = _interopRequireWildcard(require("../../utils/logger")); var _validate = require("../../utils/validate"); function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } var shell = require('shelljs'); /** * Deploy the webapp to netlify * @param {String} configFile - File whose content is to be read * @returns {String[]} * @returns {Promise<void>} */ var _default = /*#__PURE__*/function () { var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(templateDir) { return regeneratorRuntime.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: _context.next = 2; return (0, _validate.validateInstallation)('netlify'); case 2: _context.next = 4; return (0, _validate.validateInstallation)('git help -g'); case 4: logger.info('Deploying the client side project ๐Ÿ“ƒ'); if (templateDir !== 'client' || templateDir !== 'server') { _fsExtra["default"].copySync(_path["default"].resolve(__dirname, '../../templates/deploy/netlify.toml'), 'netlify.toml'); _fsExtra["default"].writeFileSync('netlify.toml', "[build]\n command = \"npm run build\"\n publish=\"dist\"\n base = \"\"\n # The base directory should be the path to the nested Vue project\n \n [[redirects]]\n from = \"/*\"\n to = \"/index.html\"\n status = 200"); shell.exec("wt -w 0 -d . -p \"Command Prompt\" cmd /k \"cd client && npm run build && netlify deploy --open && netlify deploy --prod && exit\";"); } else if (templateDir === 'client' || templateDir === 'server') { shell.cd('cd ..'); _fsExtra["default"].copySync(_path["default"].resolve(__dirname, '../../templates/deploy/netlify.toml'), 'netlify.toml'); _fsExtra["default"].writeFileSync('netlify.toml', "[build]\n command = \"npm run build\"\n publish=\"dist\"\n base = \"\"\n # The base directory should be the path to the nested Vue project\n \n [[redirects]]\n from = \"/*\"\n to = \"/index.html\"\n status = 200"); shell.exec('wt -w 0 -d . -p "Command Prompt" cmd /k "cd client && npm run build && netlify deploy --open && netlify deploy --prod && exit";'); } case 6: case "end": return _context.stop(); } } }, _callee); })); return function (_x) { return _ref.apply(this, arguments); }; }(); exports["default"] = _default;