GithubHelp home page GithubHelp logo

simistern / extension-cli Goto Github PK

View Code? Open in Web Editor NEW

This project forked from mobilefirstllc/extension-cli

0.0 1.0 0.0 11.03 MB

Command line tool for building browser extensions for chromium based browsers.

Home Page: https://oss.mobilefirst.me/extension-cli

License: MIT License

JavaScript 99.61% CSS 0.39%

extension-cli's Introduction

Extension CLI

npm travis Maintainability Last commit

Extension CLI is a command-line application that facilitates chromium∗-based extension development by providing a systematic way to build, test and document extension projects. It handles the project setup and builds and lets you focus on the extension you are creating.


Features

  • 🖥️   Javascript Bundling — Compiles, bundles and minifies javascript files (supports ES6 syntax)

  • 🎨   CSS Bundling — Compiles, bundles, and minifies CSS and SASS files

  • 🔧   Linting — lint JavaScript using ESLint

  • 📦   ZIP Generation — Generates a .zip file for uploading to extension marketplace (Chrome Web Store etc.)

  • 📝   Document Source Code — Generates code documentation using JSDoc

  • ⚗️   Unit Testing — Sets up a unit testing environment with mocha, chai, sinon-chrome, and js-dom

  • ⚔️   Cross-Browser Compatibility - create extensions for Chrome, Edge, Firefox or Opera.

feature image

Getting Started

Create new extension project
npx extension-cli
Add to an existing project
npm install extension-cli

Commands Reference

Command Description
xt-build Run builds; env flags: -e prod and -e dev
xt-test Run unit tests
xt-docs Generate docs
xt-sync Update project config files to match the latest defaults supplied by this CLI
xt-clean Remove automatically generated files

Read the Docs

 
   User Guide →

CLI Developer Guide

If you are interested in extending this project or forking see this guide →


Motivation

After developing multiple browser extensions, it became clear that there were several steps in the development process that stayed the same between every project.

Instead of setting up these tasks individually for each project, it made more sense to combine everything in a utility tool that could be shared between projects.

This approach helps with creating a common, consistent development approach between multiple projects, reduces time to get started, and makes it easier to update build tools and scripts across multiple projects as many npm packages inevitably need to be updated (frequently!).


Issues & Feature Requests: Submit on Github

Maker: Mobile First   Twitter Follow

License: MIT

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.