Skip to content
forked from abraham/nutmeg

Build, test, and publish vanilla Web Components with a little spice

License

Notifications You must be signed in to change notification settings

pearlbea/nutmeg-cli

 
 

Repository files navigation

Nutmeg

Build, test, and publish vanilla Web Components with a little spice

Version Status macOS Build Status Linux Build Status Windows Build Status Dependency Status

🚧 Nutmeg is in active development and it's APIs are still in flux.

Nutmeg icon

Nutmeg logo

👌 Overview

Nutmeg is here to help you build, test, and publish Web Components in minutes.

By default you get the following:

  • Custom Elements v1
  • Shadow DOM v1
  • TypeScript
  • lit-html
  • Webpack
  • Karma test runner with headless browser launchers
  • Git
  • MIT license
  • Web Component best practices

📌 Install

Installing is simple via NPM.

npm install --global @nutmeg/cli

Or with Yarn

yarn global add @nutmeg/cli

Note: If it's available, Yarn will be used by default for installing dependencies.

🌱 Build

Once Nutmeg is installed you can generate a new Web Component with nutmeg new <element-name> [property:type...].

nutmeg new hello-world name:string

This will create a hello-world directory, stub out a base Web Component class HelloWorld that extends the Nutmeg Seed base class, and install the default dependencies.

🏡 Properties

Properties must be valid TypeScript types. For example string, boolean, number, string[], Element.

nutmeg new grilled-cheese quantity:number pickles:boolean cheese:string[]

Properties are the public API of your Web Component and external code can set/get them.

export class GrilledCheese extends Seed {
  @Property() public bread: string;
  @Property() public cheese: string[];
  @Property() public pickles: boolean;
  @Property() public quantity: number;
  ...
}

The @Property() decorator provides some nice features out of the box. There are two kinds of properties.

  • Primitive: boolean, string, and number.
  • Complex: any types that are not primitive.

✍️ Automatic rendering

Any properties decorated with @Property will automatically render when set.

📟 Primitive properties are reflected to the DOM

  • boolean: grilledCheese.pickle = true; => <grilled-cheese pickle></grilled-cheese>
  • number: grilledCheese.quantity = 5; => <grilled-cheese count="5"></grilled-cheese>
  • string: grilledCheese.bread = 'sourdough'; => <grilled-cheese bread="sourdough"></grilled-cheese>

📱 One-time complex property loading from attributes

On instantiation of a Web Component a one-time loading and JSON parsing happens of complex properties. In the following example cheese has the type of string[]. When connected the component will have the attribute removed and the value set as a property after JSON.parse.

The following example:

<grilled-cheese cheese="[\"sharp cheddar\"]"></grilled-cheese>

Yields:

grilledCheese.cheese.includes('sharp cheddar') === true;
<grilled-cheese></grilled-cheese>

🍽️ Serve

You can now serve the component for development on http://localhost:8080 by running:

npm run serve

With serve running you can make edits to the component and see the changes take effect automatically without manually refreshing.

🔬 Test

Running the tests from within hello-world.

npm run test

🔭 Continuous Integration

Components are generated with AppVeyor, CircleCI, and TravisCI pre-configured to run tests on Windows, macOS, and Linux respectively.

🗞️ Publish

Publishing to NPM is easy but make sure you are logged in first with npm login. Be sure to fill out package.json values like author and update the name in readme.md if you change it.

npm publish

📇 Dependencies

Once published, it's recommended that you set up Renovate to keep your dependencies current. Nutmeg has already setup a default renovate config for you, you just have to install the free GitHub app.

😎 Best practices

Out of the box many of the Google Web Fundamentals Custom Element Best Practices are handled automatically.

🔍 Example

Example Web Component built using nutmeg new hello-world name:string.

👔 License

Nutmeg is released under an MIT license.

About

Build, test, and publish vanilla Web Components with a little spice

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 82.9%
  • JavaScript 11.0%
  • HTML 6.1%