GSI - Employe Self Service Mobile
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

136 lines
6.7 KiB

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.command = void 0;
const fs = require("fs");
const path = require("path");
const { marked } = require("marked");
const TerminalRenderer = require("marked-terminal");
const checkMinRequiredVersion_1 = require("../checkMinRequiredVersion");
const command_1 = require("../command");
const config_1 = require("../config");
const error_1 = require("../error");
const prompt_1 = require("../prompt");
const logger_1 = require("../logger");
const npmDependencies = require("../init/features/functions/npm-dependencies");
marked.setOptions({
renderer: new TerminalRenderer(),
});
const TEMPLATE_ROOT = path.resolve(__dirname, "../../templates/extensions/");
const FUNCTIONS_ROOT = path.resolve(__dirname, "../../templates/init/functions/");
function readCommonTemplates() {
return {
extSpecTemplate: fs.readFileSync(path.join(TEMPLATE_ROOT, "extension.yaml"), "utf8"),
preinstallTemplate: fs.readFileSync(path.join(TEMPLATE_ROOT, "PREINSTALL.md"), "utf8"),
postinstallTemplate: fs.readFileSync(path.join(TEMPLATE_ROOT, "POSTINSTALL.md"), "utf8"),
changelogTemplate: fs.readFileSync(path.join(TEMPLATE_ROOT, "CHANGELOG.md"), "utf8"),
};
}
exports.command = new command_1.Command("ext:dev:init")
.description("initialize files for writing an extension in the current directory")
.before(checkMinRequiredVersion_1.checkMinRequiredVersion, "extDevMinVersion")
.action(async (options) => {
const cwd = options.cwd || process.cwd();
const config = new config_1.Config({}, { projectDir: cwd, cwd: cwd });
try {
const lang = await (0, prompt_1.promptOnce)({
type: "list",
name: "language",
message: "In which language do you want to write the Cloud Functions for your extension?",
default: "javascript",
choices: [
{
name: "JavaScript",
value: "javascript",
},
{
name: "TypeScript",
value: "typescript",
},
],
});
switch (lang) {
case "javascript": {
await javascriptSelected(config);
break;
}
case "typescript": {
await typescriptSelected(config);
break;
}
default: {
throw new error_1.FirebaseError(`${lang} is not supported.`);
}
}
await npmDependencies.askInstallDependencies({}, config);
const welcome = fs.readFileSync(path.join(TEMPLATE_ROOT, lang, "WELCOME.md"), "utf8");
return logger_1.logger.info("\n" + marked(welcome));
}
catch (err) {
if (!(err instanceof error_1.FirebaseError)) {
throw new error_1.FirebaseError(`Error occurred when initializing files for new extension: ${err.message}`, {
original: err,
});
}
throw err;
}
});
async function typescriptSelected(config) {
const packageLintingTemplate = fs.readFileSync(path.join(TEMPLATE_ROOT, "typescript", "package.lint.json"), "utf8");
const packageNoLintingTemplate = fs.readFileSync(path.join(TEMPLATE_ROOT, "typescript", "package.nolint.json"), "utf8");
const tsconfigTemplate = fs.readFileSync(path.join(TEMPLATE_ROOT, "typescript", "tsconfig.json"), "utf8");
const tsconfigDevTemplate = fs.readFileSync(path.join(TEMPLATE_ROOT, "typescript", "tsconfig.dev.json"), "utf8");
const indexTemplate = fs.readFileSync(path.join(TEMPLATE_ROOT, "typescript", "index.ts"), "utf8");
const gitignoreTemplate = fs.readFileSync(path.join(TEMPLATE_ROOT, "typescript", "_gitignore"), "utf8");
const eslintTemplate = fs.readFileSync(path.join(FUNCTIONS_ROOT, "typescript", "_eslintrc"), "utf8");
const lint = await (0, prompt_1.promptOnce)({
name: "lint",
type: "confirm",
message: "Do you want to use ESLint to catch probable bugs and enforce style?",
default: true,
});
const templates = readCommonTemplates();
await config.askWriteProjectFile("extension.yaml", templates.extSpecTemplate);
await config.askWriteProjectFile("PREINSTALL.md", templates.preinstallTemplate);
await config.askWriteProjectFile("POSTINSTALL.md", templates.postinstallTemplate);
await config.askWriteProjectFile("CHANGELOG.md", templates.changelogTemplate);
await config.askWriteProjectFile("functions/src/index.ts", indexTemplate);
if (lint) {
await config.askWriteProjectFile("functions/package.json", packageLintingTemplate);
await config.askWriteProjectFile("functions/.eslintrc.js", eslintTemplate);
}
else {
await config.askWriteProjectFile("functions/package.json", packageNoLintingTemplate);
}
await config.askWriteProjectFile("functions/tsconfig.json", tsconfigTemplate);
if (lint) {
await config.askWriteProjectFile("functions/tsconfig.dev.json", tsconfigDevTemplate);
}
await config.askWriteProjectFile("functions/.gitignore", gitignoreTemplate);
}
async function javascriptSelected(config) {
const indexTemplate = fs.readFileSync(path.join(TEMPLATE_ROOT, "javascript", "index.js"), "utf8");
const packageLintingTemplate = fs.readFileSync(path.join(TEMPLATE_ROOT, "javascript", "package.lint.json"), "utf8");
const packageNoLintingTemplate = fs.readFileSync(path.join(TEMPLATE_ROOT, "javascript", "package.nolint.json"), "utf8");
const gitignoreTemplate = fs.readFileSync(path.join(TEMPLATE_ROOT, "javascript", "_gitignore"), "utf8");
const eslintTemplate = fs.readFileSync(path.join(FUNCTIONS_ROOT, "javascript", "_eslintrc"), "utf8");
const lint = await (0, prompt_1.promptOnce)({
name: "lint",
type: "confirm",
message: "Do you want to use ESLint to catch probable bugs and enforce style?",
default: false,
});
const templates = readCommonTemplates();
await config.askWriteProjectFile("extension.yaml", templates.extSpecTemplate);
await config.askWriteProjectFile("PREINSTALL.md", templates.preinstallTemplate);
await config.askWriteProjectFile("POSTINSTALL.md", templates.postinstallTemplate);
await config.askWriteProjectFile("CHANGELOG.md", templates.changelogTemplate);
await config.askWriteProjectFile("functions/index.js", indexTemplate);
if (lint) {
await config.askWriteProjectFile("functions/package.json", packageLintingTemplate);
await config.askWriteProjectFile("functions/.eslintrc.js", eslintTemplate);
}
else {
await config.askWriteProjectFile("functions/package.json", packageNoLintingTemplate);
}
await config.askWriteProjectFile("functions/.gitignore", gitignoreTemplate);
}