Code Monkey home page Code Monkey logo

emulsify-cli's Introduction

Emulsify Design System npm

emulsify-cli

Command line interface for Emulsify.

Installation

This project is deployed to npm. In order to use this CLI, install it as a global dependency:

npm install -g @emulsify/cli

Usage

For more information on how to use emulsify-cli, please see the usage documentation.

Development

Emulsify-cli is developed using TypeScript. You can find all of the source files in the src directory, which is organized in the following manner:

  • src/index.ts - uses Commander to compose the CLI.
  • src/handlers - contains all functions that handle CLI commands, such as emulsify init.
  • src/lib - general definitions and logging tools.
  • src/schemas - contains JSON-Schema files that describe project, system, and variant configuration. These schema files are used to generate TypeScript types.
  • src/scripts - holds utility scripts for the project.
  • src/types - type modules live here, auto-generated ones are prefixed with an underscore (_).
  • src/util - contains utility functions that are used in handlers to do various things, such as caching systems.

Setup

  • Install the version of node as specified in this project's .nvmrc file. If you are using nvm, simply run nvm use.
  • Clone this repository into a directory of your choosing.
  • In the directory, run npm install.
  • Build the project: npm run build, or watch: npm run watch.
  • To test the CLI, run: npm link.

Scripts

  • npm run build: builds the project based on the configuration in tsconfig.dist.json.
  • npm run build-schema-types: Compiles the json-schema definitions within this project into ts types.
  • npm run watch: watches the codebase, and re-compiles every time a change is made.
  • npm run format: uses prettier to format all ts files within the codebase.
  • npm run lint: uses eslint to lint the codebase.
  • npm run test: runs Jest on the codebase. You can specify a path to a single test, and add any flags supported by Jest's CLI.
  • npm run type: uses typescript to check all type signatures.
  • npm run twatch: runs Jest without coverage, in verbose and watch mode. This is useful for running a single test during active development.

Deployment

This project is automatically built and deployed to NPM via a GitHub Actions workflow. In order to deploy changes merged into the develop branch, simply merge develop into main, and call it a day.

Contributors

Patrick
Patrick Coffey
Brian
Brian Lewis
Jeff
Jeff Tomlinson
Callin
Callin Mullaney
Randy
Randy Oest
mikeethedude/
mikeethedude
Andrii
Andrii Shutov
Ryan
Ryan Hagerty
Jim
Jim Vomero
Caleb
Caleb Tucker-Raymond
Igor
Igor R. Plity

emulsify-cli's People

Contributors

patrickocoffeyo avatar modulesunraveled avatar jefftomlinson avatar amazingrando avatar dependabot[bot] avatar callinmullaney avatar mikeethedude avatar fertant avatar njim avatar calebtr-metro avatar karldivad avatar iryston avatar ryanhagerty avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.