UNPKG

@cuba-platform/front-generator

Version:
89 lines 3.65 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); const cli_options_1 = require("../../../common/cli-options"); exports.options = cli_options_1.polymerElementOptionsConfig; const generation_1 = require("../../../common/generation"); const params_1 = require("./params"); exports.params = params_1.entityEditParams; const path = require("path"); const utils_1 = require("../../../common/utils"); const fields_1 = require("../common/fields"); class EntityEditGenerator extends generation_1.BaseGenerator { constructor(args, options) { super(args, options); this.sourceRoot(path.join(__dirname, 'template')); } // noinspection JSUnusedGlobalSymbols prompting() { return __awaiter(this, void 0, void 0, function* () { yield this._promptOrParse(); }); } // noinspection JSUnusedGlobalSymbols writing() { this.log(`Generating to ${this.destinationPath()}`); if (!this.answers) { throw new Error('Answers not provided'); } this.model = entityEditAnswersToModel(this.answers, this.options.dirShift); this.fs.copyTpl(this.templatePath('entity-edit.html'), this.destinationPath(this.model.componentName + '.html'), this.model); } end() { this.log(`Entity edit has been successfully generated into ${this.destinationRoot()}`); } _getParams() { return params_1.entityEditParams; } _getAvailableOptions() { return cli_options_1.polymerElementOptionsConfig; } } exports.generator = EntityEditGenerator; exports.composeEditFields = (entity, view) => { if (entity == null || view == null) { return { fields: [], imports: [] }; } const attributes = view.allProperties.reduce((attrArr, prop) => { const attr = entity.attributes.find(ea => ea.name === prop.name); if (attr) { attrArr.push(attr); } return attrArr; }, []); const models = attributes.map(attr => fields_1.getFieldModel(attr)); const fields = models.map(m => fields_1.getFieldHtml(m)); // const imports: string[] = models.reduce((importsCollector:string[], model) => { // const deps = fieldDependencies[model.type]; // if (deps) { // deps.forEach(dep => { // if (importsCollector.indexOf(dep) < 0) { // importsCollector.push(dep); // } // }) // } // return importsCollector; // }, []); return { fields, imports: [] }; }; function entityEditAnswersToModel(answers, dirShift) { const { fields, imports } = exports.composeEditFields(answers.entity, answers.editView); return { fields, imports, componentName: answers.editComponentName, className: utils_1.elementNameToClass(answers.editComponentName), relDirShift: dirShift || '', view: answers.editView, entity: answers.entity, }; } exports.entityEditAnswersToModel = entityEditAnswersToModel; //# sourceMappingURL=index.js.map