pasta-templates v0.1.0
Pasta š
Pasta allows developers to scaffold applications, or files based on their templates (souces) š
Status
The project is not ready yet. Some of the functionalities are still missing
- Use local configuartions files to drive- transformations
- srcand- destfile paths
- initial script
 
- Imporve logging
- Imporve error handling and test coverage
- Imporve cli usage
Crazy eary adopters
If you feel really brave and you want to use it, type
npm install -g pasta-templates
then type pasta to see the options:
usage: pasta [options] [command]
commands:
  new <name> <srcFolder or gitRepo> [destFolder] - create a scaffold project. Default destination folder path ./<name>
  create <template> <name> - create a set of files based on specific templates
  help - Display the available options
global options:
  -v, --verbose   show debug information
  -q, --quiet     only output critical errorsCommands
pasta new
This pasta new command creates a new project based on a folder or, more likely, an existing git repo.
For instance pasta new memory https://github.com/albertodotcom/react-template.git will:
- create a new project in the ./memoryfolder by cloning the specified github repo;
- apply a trasformation to every file content using memory as appName. See the transformation section;
- execute npm install && git init && git add --all && git commit -m "Create scaffold project"
pasta create
The pasta create command uses templates to create a whole lot of things.
For now your current repo needs to have the following structure
...
templates
āāā create
    āāā component
        āāā files...By default the src and the dest folders are:
src => ./templates/create/templateType/
dest => ./src/templateTypes/note that dest folder is plural
With this structure in place you can type pasta create component Pesto and pasta will:
1. copy all the files from ./templates/create/component/ folder to ./src/components/
2. replace the files that have the template keyword with Pesto
3. transform the file content of every file using the process described at point 2 and 3 of the transformation section
Customization
It is possible to add a custom src or dest folder by creating a .pesto.json in the ./template folder.
.pasta.json
{
  "create": {
    "component": {
      "from": "./test/assets/create/component/",
      "to": "./src/containers/{componentName}"
    }
  }
}Trasformations
both new and create commands are meant to perform file trasformations.
There are 2 types of transformations:
1. change file name, using the template keyword in the filename itself.
For example assuming you have a templates folder like the following one:
...
templates
āāā create
    āāā component
        āāā template-test.js
        āāā template.js
...if you type pasta create component Button, you will get
...
src
āāā components
    āāā Button-test.js
    āāā Button.js
templates
āāā create
    āāā component
        āāā template-test.js
        āāā template.js
...- comment replacement, using a comment in the line above the line you would like transform with this format
||| nameInTheTemplate -> componentName
For example if you have a react component in your templates/create/component folder like the following
// ||| MyComponentName -> componentName
class MyComponentName extends React.Component {
  ...
}
// ||| MyComponentName -> componentName
export default MyComponentName;when you run pasta create component Button, pasta will replace MyComponentName with Button
class Button extends React.Component {
  ...
}
export default Button;I am still thinking about another type of transformation. Why? I would like to leave every template in a working state, so you can have linting on the file and test it.