Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

create-banner

fengyuanchen2.4kMIT2.0.0TypeScript support: included

Create a banner from a package.json file.

create, banner, banner-generator, package, package.json

readme

create-banner

Build Status Coverage Status Downloads Version

Create a banner from a package.json file.

Main files

/
├── index.js         (CommonJS, default)
├── index.esm.js     (ECMAScript Module)
└── index.d.ts       (TypeScript Declaration File)

Install

npm install --save-dev create-banner

Usage

Syntax

createBanner(options);
  • Arguments:
    • options (optional):
      • Type: Object
      • The options for creating banner.
  • Returns:
    • Type: string
    • Return the created banner.

Examples

import createBanner from 'create-banner';

createBanner();
/*!
 * create-banner v1.0.0
 * https://github.com/fengyuanchen/create-banner
 *
 * Copyright 2018 Chen Fengyuan
 * Released under the MIT license
 *
 * Date: 2018-05-19T09:18:34.739Z
 */

createBanner({ case: 'camelCase', template: 'simple' });
/*!
 * createBanner v1.0.0
 * Copyright 2018 Chen Fengyuan
 * Released under the MIT license
 */

createBanner({ case: 'Title Case', template: 'inline' });
/*! Create Banner v1.0.0 | (c) 2018 Chen Fengyuan | MIT */

Options

case

  • Type: String
  • Default: ''
  • Options:
    • 'camel-case' (camelCase)
    • 'capital-case' (Capital Case)
    • 'constant-case' (CONSTANT_CASE)
    • 'dot-case' (dot.case)
    • 'header-case' (Header-Case)
    • 'no-case' (no-case)
    • 'param-case' (param-case)
    • 'pascal-case' (PascalCase)
    • 'path-case' (path/case)
    • 'sentence-case' (Sentence case)
    • 'snake-case' (snake_case)
    • All the case functions supported by the change-case package.

The case of the package name in the banner. Not to change the package name case by default.

data

  • Type: Object
  • Default:

    {
      date: new Date().toISOString(),
      year: new Date().getFullYear(),
    }

The extra data for creating banner, will be merged into package data.

createBanner({
  data: {
    name: 'Library.js',
    year: '2018-present',
  },
});

pkg

  • Type: Object
  • Default: undefined

The package data for creating banner. If it is undefined, will read from the closest package.json file by default using the read-pkg-up package.

template

  • Type: String
  • Default: 'normal'
  • Options:

    • 'normal':

      /*!
       * @name v@version
       * @homepage
       *
       * Copyright @year @author.name
       * Released under the @license license
       *
       * Date: @date
       */
    • 'simple':

      /*!
       * @name v@version
       * Copyright @year @author.name
       * Released under the @license license
       */
    • 'inline':

      /*! @name v@version | (c) @year @author.name | @license */
    • Other values will be used directly as a custom template.

The template for creating banner. Property using a dot path is supported by the dot-prop package.

Example for custom template:

createBanner({
  template: `/*!
 * @name v@version
 * @license (c) @author.name
 */
`,
});
/*!
 * create-banner v1.0.0
 * MIT (c) Chen Fengyuan
 */

Versioning

Maintained under the Semantic Versioning guidelines.

License

MIT © Chen Fengyuan

changelog

Changelog

2.0.0 (Feb 12, 2021)

  • Release as a stable version.

2.0.0-beta (Jan 16, 2021)

  • Update TypeScript Declaration File.

2.0.0-alpha (Jan 7, 2021)

  • Refactor in TypeScript.
  • Improve the available options.
  • Add a TypeScript Declaration File.
  • Upgrade the builtin dependencies.

1.0.0 (May 20, 2018)

  • Change the default value of the case option from 'param-case' to ''.
  • Change the template option to support more template types.
  • Remove the lite and liteTemplate options.

0.1.0 (May 19, 2018)

  • Support 6 options: case, data, pkg, template, lite and liteTemplate.