Skip to content

FAQs

create is very early stage. It is just barely past proof-of-concept stage.

Right now, it’s being developed as an MVP to generalize the internals of create-typescript-app. Soon it will be more stable and these docs will be updated.

Consumption

How do I use create?

If you want to create or update a repository, see CLI for running the create command.

If you want to build your own template, see Templating Engine > About.

How do I remove part of a template?

Go ahead and change your repository! After you create a repository, you can customize it however you see fit.

If you’d like to keep a repository updated with a template, you can customize your tooling with a configuration file. See Configuration > Blocks for how to add or remove pieces of tooling.

What else can create do?

Soon, there will be higher-level scaffolding utilities that will allow packages such as create-typescript-app to:

  • Generate full documentation websites to describe their Blocks and Presets
  • Manage and keep updated sample repositories for their presets
  • Migrate repositories from external tools and/or older Preset or Template versions

See JoshuaKGoldberg/create-typescript-app#1181 📝 Documentation: Long-term project vision for more history.

Ecosystem Comparisons

create is targeting being a fully complete solution for defining creating, migrating, and/or updating repositories to use flexible templates. Those templates are defined in a feature-by-feature (“Block”) basis and with configurable “Presets” using create APIs. create templates go beyond just file system copying with network requests, shell commands, and versioned migrations.

Other ecosystem tools exist for part of that feature set. None target the full feature set of create.

In general, create’s approach is differentiated from previous projects by:

  • Producing outputs -including files and more- in a generalized format (Direct Creations)
  • Allowing sub-templates that can be individually swapped individually and add to each other (Blocks)

create-next-app, create-react-app, create-typescript-app, etc

create is an engine that allows you to define repository templates. It itself is not a repository template; it instead provides APIs that you can use to build your own repository template.

In other words, create is a lower-level primitive that can be used to create higher-level create-*-app templates.

Cookiecutter

Cookiecutter is a library and CLI app for generating projects from templates. It allows taking in directories written as Jinja templates and running pre- and post-generation hooks.

create has several key differences from what Cookiecutter supports:

  • Cookiecutter is a wrapper around a Jinja file templates; create allows for full JavaScript logic to generate contents based on provided options
  • Cookiecutter always operates at the scale of one template; create provides more granular APIs for areas of features (Blocks and Presets)
  • Cookiecutter supports file changes; create additionally supports network calls and arbitrary shell scripts as outputs

Cookiecutter is also written in Python and is installed using tools in the Python ecosystem. create is written in TypeScript and is set up to work in the web ecosystem.

copier

Copier is a library and CLI app for generating projects from templates. It takes in a local path or Git URL and dynamically replaces values in text files.

create has several key additions on top of what Copier supports:

  • Copier is a wrapper around a straightforward file templates; create allows for dynamic logic for generating contents based on provided options
  • Copier only supports file templates; create allows for sending network requests and running shell scripts
  • Copier always operates at the scale of one template; create provides more granular APIs for areas of features (Blocks and Presets)

Copier is also written in Python and is installed using tools in the Python ecosystem. create is written in TypeScript and is set up to work in the web ecosystem.

degit

degit is a tool that makes copies Git of repositories. It allows for straightforward initialization of files, along with support for post-creation actions.

create has several key additions on top of what degit supports:

  • degit is a wrapper around a straightforward git clone; create allows for dynamic logic for generating contents based on provided options
  • degit only supports limited post-clone actions; create allows for sending network requests and running shell scripts
  • degit always operates at the scale of a full repository; create provides more granular APIs for areas of features (Blocks and Presets)

GitHub Template Repositories

GitHub Template Repositories are a GitHub feature allowing making a new repository as a clone of another. Created repositories appear on github.com with a generated from … notice.

create will include treating sources as templates, and additionally adds features:

  • Template Repositories are a wrapper around a straightforward git clone; create allows for changing generated file contents based on provided options
  • Template Repositories don’t support post-clone actions; create allows for sending network requests and running shell scripts
  • Template Repositories always operate at the scale of a full repository; create provides more granular APIs for areas of features (Blocks and Presets)

Hygen

Hygen is web ecosystem tool for defining generators to automate common file system tasks. It encourages building your own generators that include templates built with the EJS embedded JavaScript templating engine. Hygen templates can have conditional rendering, embedded JavaScript, and injected shell scripts.

create takes a different architectural approach than Hygen:

  • Hygen templates are imperative descriptions of files and frontmatter; create groups areas into blocks
  • Hygen templates heavily build on EJS and do not have type-safe options; create has options explicitly defined with Zod schemas
  • create Blocks describe their own outputs and additions to other Blocks, allowing them to be individually toggled

Plop

Plop is web ecosystem tool for defining repository templates. Like create, it allows defining templates for generated files.

create has several key differences from Plop:

  • Plop is built around an imperative “actions” API for adding files, as opposed to create’s managing of outputs
  • Plop only supports file creation, not other actions such as setting repository GitHub systems
  • Plop is built on the popular Inquirer.js and Handlebars libraries, rather than create’s more type-safe Zod schema options

In other words, create is a more broadly scoped project for full repository generation, whereas Plop is more finely targeted to applying Handlebars templates.

projen

projen is web ecosystem tool for defining repository templates. It is similar to create in that it is a flexible underlying engine that allows developers define and manage project configurations through code.

create has several large differences from projen:

  • create is a generalized, tooling-agnostic generator engine that can also keep repositories updated over time
  • projen generally targets tighter integration and management with created projects, including being used in its package scripts
More details on create differing from projen
  • Ecosystem targets:
    • create only includes packages in JavaScript/TypeScript; it only targets support for the web ecosystem.
    • projen includes packages in Go, Java, JavaScript/TypeScript, and Python; it can be generally used for those ecosystems.
  • Integration with generated repositories:
    • create does not add any tooling to generated repositories; it prioritizes inferring options from existing repositories on demand.
    • projen is used in generated repositories and integrates with the repository’s tasks.
  • Integration with ecosystem tooling:
    • create does not hardcode types of tasks or the tools used for them.
    • projen bundles its own understanding of ecosystem tools such as package managers and linters, and provides APIs for projects to choose from its preferred tools.
  • Low-level code design principles:
    • create uses lean functions. Output file structures are defined with raw objects and strings.
    • projen leans into classes in its architecture. It heavily uses jsii and defines output files with classes.

Yeoman

Yeoman is a much older tool in the web ecosystem for templating. Its architecture and APIs generally work with older, now-outdated JavaScript practices:

  • Project generators must extend yeoman-generator’s Generator and define methods that are dynamically discovered and called at runtime
  • System interactions such as installing dependencies and writing files are done by imperatively calling Yeoman APIs, as opposed to producing outputs that are managed by create
  • Persistent options are provided in a raw .yo-rc.json JSON file rather than type-safe schema definitions

Yeoman has not been actively maintained in several years.

Template Development

This Blocks system is a lot of work. Is there a more straightforward system?

Not yet, but there will be. Soon, less-heavyweight engines will be available to make authoring straightforward Templates easier. See create#76 🚀 Feature: Switch to a pluggable templating engine system.

Why can’t we define Args for Blocks in Presets?

In other words, you might be wondering why the API doesn’t allow something like this:

export const presetExample = base.createPreset({
blocks: [
myBlock({
someArg: "...",
}),
],
});

This is because Blocks shouldn’t need to be configured. Users should be able to turn them off and on at will without any configuration.

Passing Args to a Block in a Preset means users will have no way to override or remove those Args.

Why do some testers allow take and others the individual system pieces?

It depends on what APIs the entities under test conceptually use.

EntityMockWhy
BasestakeBases should go through Inputs to interact with the system.
BlocksNeitherBlocks should be synchronous and take any input values from their Base Options.
InputsBothInputs receive system pieces, and can also take other Inputs.
PresetsSystemHigh-level users of Presets should not care about low-level implementation details of Inputs.
Made with 💝 in Boston by Josh Goldberg.