Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

create-whatever

Package Overview
Dependencies
Maintainers
1
Versions
25
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

create-whatever

create 'create-' app

  • 4.0.4
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
10
increased by66.67%
Maintainers
1
Weekly downloads
 
Created
Source

create-whatever

npm-badge workflow-badge

The smartest create- app template generator.

screencast

Why?

  • Built-in License chooser No need to care about license things.
  • Template engine Just put files with template strings and we will do the rest.
  • Highly customizable Can change caveat text, and add extra cli options.

How

Create create-greet package in four steps.

1. Generate template

yarn create whatever create-greet --template typescript

or if you use npm, then run npx create-whatever create-greet

2. Edit templates

cd create-greet and edit files inside templates/default.

TypeScript

Run yarn build or npm run build to transpile TypeScript into JavaScript.

3. Publish package to npm

Run yarn publish or npm publish to publish your create- app to npm.

4. PROFIT!!!

Template

Edit files inside templates/default. File names, directory names, and text files will be processed through Handlebars template engine to replace all template strings with respective value.

  • {{name}} package name
  • {{description}} package description
  • {{author}} author name
  • {{email}} author email
  • {{contact}} author name formatted with {{name}} <{{email}}> if email given, otherwise {{name}}
  • {{license}} package license (e.g. MIT)
  • {{year}} current year (e.g. 2020)

Helper functions

upper

Output text in UPPERCASE.

In the case of name is create-react-app, {{upper name}} becomes CREATE-REACT-APP.

lower

Output text in lowercase.

In the case of name is CREATE-REACT-APP, {{lower name}} becomes create-react-app.

camel

Output text in camelCase.

In the case of name is create-react-app, {{camel name}} becomes createReactApp.

capital

Output text in CapitalCase.

In the case of name is create-react-app, {{capital name}} becomes CreateReactApp, and {{capital name space=true}} becomes Create React App.

snake

Output text in snake_case.

In the case of name is CreateReactApp, {{snake name}} becomes create_react_app.

kebab

Output text in kebab-case.

In the case of name is CreateReactApp, {{kebab name}} becomes create-react-app.

Config

You can find the app config in src/cli.ts.

import {create} from 'create-whatever';

create('create-greet', templateRoot, {
  caveat: `Your app has been created successfuly!`,
  extra: {
    language: {
      type: 'input',
      describe: 'greeting language',
      default: 'en',
      prompt: 'if-no-arg',
    },
  },
});

templateRoot set to path.resolve(__dirname, '../templates'). You can change it to whereever you want.

caveat

string | undefined

This message will be shown after the generation process.

extra

object | undefined

Extra options passed to the app. These options will be accessible as a cli option, interactive question, and template string. In this case, --language cli option and {{language}} template string will be available.

You can find all possible options in yargs-interactive documentation.

Contribution

PRs are always welcome!

Keywords

FAQs

Package last updated on 09 Oct 2019

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc