@cuba-platform/front-generator
Version:
CUBA Platform front-end clients generator
92 lines • 4.12 kB
JavaScript
;
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
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) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.options = exports.params = exports.generator = exports.entityEditAnswersToModel = exports.composeEditFields = void 0;
const cli_options_1 = require("../../../common/cli-options");
Object.defineProperty(exports, "options", { enumerable: true, get: function () { return cli_options_1.polymerElementOptionsConfig; } });
const base_generator_1 = require("../../../common/base-generator");
const params_1 = require("./params");
Object.defineProperty(exports, "params", { enumerable: true, get: function () { return params_1.entityEditParams; } });
const path = require("path");
const utils_1 = require("../../../common/utils");
const fields_1 = require("../common/fields");
class EntityEditGenerator extends base_generator_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;
const 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 => (0, fields_1.getFieldModel)(attr));
const fields = models.map(m => (0, 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: [] };
};
exports.composeEditFields = composeEditFields;
function entityEditAnswersToModel(answers, dirShift) {
const { fields, imports } = (0, exports.composeEditFields)(answers.entity, answers.editView);
return {
fields,
imports,
componentName: answers.editComponentName,
className: (0, utils_1.elementNameToClass)(answers.editComponentName),
relDirShift: (0, utils_1.normalizeRelativePath)(dirShift),
view: answers.editView,
entity: answers.entity,
};
}
exports.entityEditAnswersToModel = entityEditAnswersToModel;
//# sourceMappingURL=index.js.map