mirror of
https://github.com/angular/angular-cli.git
synced 2025-05-21 14:02:43 +08:00
111 lines
3.6 KiB
TypeScript
111 lines
3.6 KiB
TypeScript
import {NodeHost} from '../../lib/ast-tools';
|
|
import { oneLine } from 'common-tags';
|
|
import {getAppFromConfig} from '../../utilities/app-utils';
|
|
|
|
const path = require('path');
|
|
const fs = require('fs');
|
|
const chalk = require('chalk');
|
|
const dynamicPathParser = require('../../utilities/dynamic-path-parser');
|
|
const Blueprint = require('../../ember-cli/lib/models/blueprint');
|
|
const stringUtils = require('ember-cli-string-utils');
|
|
const astUtils = require('../../utilities/ast-utils');
|
|
const getFiles = Blueprint.prototype.files;
|
|
|
|
export default Blueprint.extend({
|
|
description: '',
|
|
|
|
availableOptions: [
|
|
{ name: 'flat', type: Boolean },
|
|
{ name: 'spec', type: Boolean },
|
|
{ name: 'module', type: String, aliases: ['m'] }
|
|
],
|
|
|
|
beforeInstall: function(options: any) {
|
|
const appConfig = getAppFromConfig(this.project.ngConfig.apps, this.options.app);
|
|
if (options.module) {
|
|
// Resolve path to module
|
|
const modulePath = options.module.endsWith('.ts') ? options.module : `${options.module}.ts`;
|
|
const parsedPath = dynamicPathParser(this.project, modulePath, appConfig);
|
|
this.pathToModule = path.join(this.project.root, parsedPath.dir, parsedPath.base);
|
|
|
|
if (!fs.existsSync(this.pathToModule)) {
|
|
throw 'Module specified does not exist';
|
|
}
|
|
}
|
|
},
|
|
|
|
normalizeEntityName: function (entityName: string) {
|
|
const appConfig = getAppFromConfig(this.project.ngConfig.apps, this.options.app);
|
|
const parsedPath = dynamicPathParser(this.project, entityName, appConfig);
|
|
|
|
this.dynamicPath = parsedPath;
|
|
return parsedPath.name;
|
|
},
|
|
|
|
locals: function (options: any) {
|
|
options.flat = options.flat !== undefined ?
|
|
options.flat :
|
|
this.project.ngConfigObj.get('defaults.guard.flat');
|
|
|
|
options.spec = options.spec !== undefined ?
|
|
options.spec :
|
|
this.project.ngConfigObj.get('defaults.guard.spec');
|
|
|
|
return {
|
|
dynamicPath: this.dynamicPath.dir,
|
|
flat: options.flat
|
|
};
|
|
},
|
|
|
|
files: function() {
|
|
let fileList = getFiles.call(this) as Array<string>;
|
|
|
|
if (this.options && !this.options.spec) {
|
|
fileList = fileList.filter(p => p.indexOf('__name__.guard.spec.ts') < 0);
|
|
}
|
|
|
|
return fileList;
|
|
},
|
|
|
|
fileMapTokens: function (options: any) {
|
|
// Return custom template variables here.
|
|
return {
|
|
__path__: () => {
|
|
let dir = this.dynamicPath.dir;
|
|
if (!options.locals.flat) {
|
|
dir += path.sep + options.dasherizedModuleName;
|
|
}
|
|
this.generatePath = dir;
|
|
return dir;
|
|
}
|
|
};
|
|
},
|
|
|
|
afterInstall(options: any) {
|
|
const returns: Array<any> = [];
|
|
|
|
if (!this.pathToModule) {
|
|
const warningMessage = oneLine`
|
|
Guard is generated but not provided,
|
|
it must be provided to be used
|
|
`;
|
|
this._writeStatusToUI(chalk.yellow, 'WARNING', warningMessage);
|
|
} else {
|
|
const className = stringUtils.classify(`${options.entity.name}Guard`);
|
|
const fileName = stringUtils.dasherize(`${options.entity.name}.guard`);
|
|
const fullGeneratePath = path.join(this.project.root, this.generatePath);
|
|
const moduleDir = path.parse(this.pathToModule).dir;
|
|
const relativeDir = path.relative(moduleDir, fullGeneratePath);
|
|
const importPath = relativeDir ? `./${relativeDir}/${fileName}` : `./${fileName}`;
|
|
returns.push(
|
|
astUtils.addProviderToModule(this.pathToModule, className, importPath)
|
|
.then((change: any) => change.apply(NodeHost)));
|
|
this._writeStatusToUI(chalk.yellow,
|
|
'update',
|
|
path.relative(this.project.root, this.pathToModule));
|
|
}
|
|
|
|
return Promise.all(returns);
|
|
}
|
|
});
|