d52d324df4
* remove ember-cli-valid-component-name since we no longer need it * component names no longer need to contain a hyphen * remove Husky from README since we no longer use it * update Storybook example * update JSDoc examples and fix params table header
81 lines
2.1 KiB
JavaScript
81 lines
2.1 KiB
JavaScript
'use strict';
|
|
|
|
const path = require('path');
|
|
const stringUtil = require('ember-cli-string-utils');
|
|
const pathUtil = require('ember-cli-path-utils');
|
|
const getPathOption = require('ember-cli-get-component-path-option');
|
|
const normalizeEntityName = require('ember-cli-normalize-entity-name');
|
|
|
|
module.exports = {
|
|
description: 'Generates a component.',
|
|
|
|
availableOptions: [
|
|
{
|
|
name: 'path',
|
|
type: String,
|
|
default: 'components',
|
|
aliases: [{ 'no-path': '' }],
|
|
},
|
|
],
|
|
|
|
filesPath: function() {
|
|
let filesDirectory = 'files';
|
|
|
|
return path.join(this.path, filesDirectory);
|
|
},
|
|
|
|
fileMapTokens: function() {
|
|
return {
|
|
__path__: function(options) {
|
|
if (options.pod) {
|
|
return path.join(options.podPath, options.locals.path, options.dasherizedModuleName);
|
|
} else {
|
|
return 'components';
|
|
}
|
|
},
|
|
__templatepath__: function(options) {
|
|
if (options.pod) {
|
|
return path.join(options.podPath, options.locals.path, options.dasherizedModuleName);
|
|
}
|
|
return 'templates/components';
|
|
},
|
|
__templatename__: function(options) {
|
|
if (options.pod) {
|
|
return 'template';
|
|
}
|
|
return options.dasherizedModuleName;
|
|
},
|
|
};
|
|
},
|
|
|
|
normalizeEntityName: function(entityName) {
|
|
return normalizeEntityName(entityName);
|
|
},
|
|
|
|
locals: function(options) {
|
|
let templatePath = '';
|
|
let importTemplate = '';
|
|
let contents = '';
|
|
|
|
// if we're in an addon, build import statement
|
|
if (options.project.isEmberCLIAddon() || (options.inRepoAddon && !options.inDummy)) {
|
|
if (options.pod) {
|
|
templatePath = './template';
|
|
} else {
|
|
templatePath =
|
|
pathUtil.getRelativeParentPath(options.entity.name) +
|
|
'templates/components/' +
|
|
stringUtil.dasherize(options.entity.name);
|
|
}
|
|
importTemplate = "import layout from '" + templatePath + "';\n";
|
|
contents = '\n layout';
|
|
}
|
|
|
|
return {
|
|
importTemplate: importTemplate,
|
|
contents: contents,
|
|
path: getPathOption(options),
|
|
};
|
|
},
|
|
};
|