Jo
is a simple and scalable code generator that works. Built for developers by developers with ❤️.
- 🏗️ JavaScript as a template language — do what you want with any other packages in your templates;
- 🎨 Hooks for any state — format, validate, whatever with your templates;
- 🚀 Support templates as npm-package — share templates between teams and projects;
- 🎩 Support brace expansion as known from sh/bash;
- 💪 Command templates etending and overriding.
$ npm i -D jo-cli
Add to templates
directory first templates via folder component
and populate command config.
templates/component/.joconfig.js
const { pascalCase } = require('change-case');
module.exports = {
title: 'React Component',
default: 'js',
path: ({ options }, filename) => (options.directory ? `./src/components/${filename}` : './src/components'),
description: 'Create React component in different technologies.',
options: {
directory: {
type: 'boolean',
short: 'd',
description: 'create component as directory',
},
module: {
type: 'string',
short: 'm',
description: 'Sub module',
parse: pascalCase,
},
},
hooks: {
preFileName: (_, filename) => pascalCase(filename),
},
};
Add template files with name to extension matching.
templates/component/js.js
module.exports.template = ({ directory }, fileName) =>
`import React from 'react';
export const ${fileName} = props => <div>${directory ? 'in direcotory' : 'one file'}</div>;`;
templates/component/css.js
module.exports.template = (_, fileName) => `.${fileName} {}`;
$ jo component tabs.{js,css} menu -d
Wait for magic! 🐰
src
└── components
├── Menu
│ └── Menu.js
└── Tabs
├── Tabs.css
└── Tabs.js
$ jo -h
Usage: jo [options] [command]
Options:
-V, --version output the version number
-h, --help display help for command
Commands:
component [options] Create React component in different technologies.
help [command] display help for command
$ jo component -h
Usage: jo component [options]
Create React component in different technologies.
Options:
-f, --force override existing files
-d, --directory create component as directory
-h, --help display help for command
Add .joconfig.js
to your project root directory.
module.exports = {
templates: [
'react-jo-templates', // name of package with templates
'bem-jo-templates',
'blog-jo-templates',
'path/to/your/templates', // templates by default
],
logMode: 'silent', // verbose, short — verbose by default
};
templates/component/test.js.js
module.exports.path = ({ options, path, extension }, fileName) =>
options.directory ? `${path}/${fileName}.test/${options.module}.${extension}` : `${path}/${fileName}.${extension}`;
module.exports.template = (_, fileName) => `
test('${fileName}');
`;
$ jo component menu.test.js -d -m base
src
└── components
└── Menu
└── Menu.test
└── Base.test.js
Calls before the filename will be created. Use it to customize naming with your team guides.
const { pascalCase } = require('change-case');
module.exports = {
//...
hooks: {
preFileName: (_, filename) => pascalCase(filename),
},
};
Calls before the file content will be saved. Use it to format or any other magic.
const prettier = require('prettier');
module.exports = {
//...
hooks: {
preFileSave: (_, content) => prettier.format(content),
},
};
You can base your command on any other. Override command config, add or override templates for any file exetensions.
module.exports = {
extends: 'react-jo-templates/templates/react',
description: 'Styled React components',
};