0.1.1 • Published 5 years ago

generator-smild v0.1.1

Weekly downloads
2
License
MIT
Repository
github
Last release
5 years ago

generator-smild NPM version

An opinionated generator to build JavaScript projects

Transitioning from code to running code is not always easy in JavaScript. Over the years this process has become simpler thanks to projects like browserify, Webpack and ParcelJS but still some configuration caveats must be addressed to have a fully functioning solution. This project aims to give you a simpler way to configure your application in an opinionated way that can be tested and built with a single command.

Installation

First, install Yeoman and generator-smild using npm (we assume you have pre-installed node.js).

npm install -g yo generator-smild

Then generate your project:

yo smild

A guided setup is shown where three different paths are available.

Bundle setup

Mainly for frontend applications, this setup runs ParcelJS with the proper Typescript config to package source files and assets of your app that can be distributed to your users.

Features

  • Typescript support built-in
  • All ParcelJS features: HMR, bundle splitting, source maps, etc
  • React-hot-loader support
  • Parcel static plugin: simply place all of your static assets under a static directory and it will be copied to the build folder

Commands

npm start

This starts Parcel in watch mode and spawns a dev server (default port 1234) to access your frontend.

npm run build

Used to build your app in production mode with minify turned on and files revisioning enabled.

Server setup

Use this setup for running a NodeJS server app.

Features

  • Typescript built-in support
  • Live reload using Nodemon
  • Source maps support

Commands

npm start

Your main file is ran with live reload enabled.

npm run build

Source files are transpiled with tsc and put in the build folder.

Lib setup

This setup transpiles your Typescript codebase making it available for publishing on NPM.

Commands

npm start

Launches Typescript compiler in watch mode.

npm run build

The same as the command above without watch.

Common configuration

Regardless of the project type some additional useful commands will be configured for testing and linking local packages. There are two test runners available: jest or mocha.

npm test

Executes the matching unit test using the selected test runner.

npm run test-watch

The same as the command above but using watch mode to re run the test on file changes.

npm run coverage

Executes the matching unit test producing a coverage report.

npm run link [package-name]

Alias for yalc add package-name.

npm run rm-link [package-name]

Alias for yalc remove package-name.

npm run push

Alias for yalc push.

For a detailed explanation of yalc usage please visit the project homepage.

Common questions

After a build configuration has been created, how can I change some parameters without a manual intervention?

Just re run the generator! You will be prompted with the old inputs given, change the one you need.

License

MIT © Mattia Franchetto