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
JavaScript
;
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;