Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ragingwind/generator-chrome-extension
Scaffold out a Chrome extension
https://github.com/ragingwind/generator-chrome-extension
Last synced: 3 days ago
JSON representation
Scaffold out a Chrome extension
- Host: GitHub
- URL: https://github.com/ragingwind/generator-chrome-extension
- Owner: ragingwind
- License: mit
- Created: 2013-01-27T02:11:08.000Z (almost 12 years ago)
- Default Branch: main
- Last Pushed: 2022-04-05T13:13:09.000Z (almost 3 years ago)
- Last Synced: 2025-01-09T19:37:53.108Z (10 days ago)
- Language: JavaScript
- Homepage: http://yeoman.io
- Size: 339 KB
- Stars: 2,626
- Watchers: 58
- Forks: 222
- Open Issues: 16
-
Metadata Files:
- Readme: readme.md
- Contributing: contributing.md
- License: license
Awesome Lists containing this project
- awesome-rainmana - ragingwind/generator-chrome-extension - Scaffold out a Chrome extension (JavaScript)
README
# Chrome Extension generator [![Build Status](https://secure.travis-ci.org/yeoman/generator-chrome-extension.svg?branch=master)](http://travis-ci.org/yeoman/generator-chrome-extension)
Maintainer: [Jimmy Moon](https://github.com/ragingwind)
> Chrome Extension generator that creates everything you need to get started with extension development. You can choose Browser UI(Browser,Page Action, Omnibox) type and select into permissions what you need.
## Getting Started
```sh
# Please make sure that `yo`, `gulp` and `bower` was installed on your system using this command:
npm install --global yo gulp-cli bower# Install the generator:
npm install -g generator-chrome-extension# Make a new directory, and `cd` get into it:
mkdir my-new-chrome-extension && cd $_# Generate a new project
yo chrome-extension# Transform updated source written by ES2015 (default option)
gulp babel# or Using watch to update source continuously
gulp watch# Make a production version extension
gulp build
```## Test Chrome Extension
To test, go to: chrome://extensions, enable Developer mode and load app as an unpacked extension.
Need more information about Chrome Extension? Please visit [Google Chrome Extension Development](http://developer.chrome.com/extensions/devguide.html)
## Generators
Available generators:
* [chrome-extension](#app) (aka [chrome-extension:app](#app))
### App
Sets up a new Chrome Extension, generating all the boilerplate you need to get started.
```bash
yo chrome-extension
```## gulp tasks
### Babel
The generator supports ES 2015 syntax through babel transforming. You may have a source files in `script.babel` if your project has been generated without `--no-babel` options. While developing, When those of source has been changed, `gulp babel` should be run before test and run a extension on Chrome.
```sh
gulp babel
```If you would like to have a continuous transforming by babel you can use `watch` task
### Watch
Watch task helps you reduce your efforts during development extensions. If the task detects your changes of source files, re-compile your sources automatically or Livereload([chromereload.js](https://github.com/yeoman/generator-chrome-extension/blob/master/app/templates/scripts/chromereload.js)) reloads your extension. If you would like to know more about Live-reload and preview of Yeoman? Please see [Getting started with Yeoman and generator-webapp](http://youtu.be/zBt2g9ekiug?t=3m51s) for your understanding.
```bash
gulp watch
```You need to load/reload extension after starting `gulp watch` for Live-reload to work.
For content scripts you need to refresh pages where it is used.
### Build and Package
It will build your app as a result you can have a distribution version of the app in `dist`. Run this command to build your Chrome Extension app.
```bash
gulp build
```You can also distribute your project with compressed file using the Chrome Developer Dashboard at Chrome Web Store. This command will compress your app built by `gulp build` command.
```bash
gulp package
```## Options
* `--no-babel`
If you wouldn't use [Babel](https://babeljs.io/) ES2015 transpiler.
* `--skip-install`
Skips the automatic execution of `bower` and `npm` after
scaffolding has finished.* `--test-framework=[framework]`
Defaults to `mocha`. Can be switched for
another supported testing framework like `jasmine`.* `--sass`
Add support for [Sass](http://sass-lang.com/libsass).
* `--all-permissions`
All of permissions of chrome extension will be shown.
### ES2015 and babel
ES2015 is the `default option` in the generator that means you can use es2015 now for developing the Chrome extensions. However, at this moment, you need to execute `babel` task of gulp to compile to test and run your extension on Chrome, because [ES2015 is not full functionality on Chrome as yet](http://kangax.github.io/compat-table/es6/).
The sources written by es2015 is located at `scripts.babel` and runnable sources will be at `script` after compiling by `gulp babel`. May you don't want to use babel and ES2015 use `--no-babel` option when scaffolding a new project.
```sh
yo chrome-extension --no-babel
```### Sass
This generator supports `sass` through `--sass` options and generate `scss` boilerplate files at `styles.scss` that those of `scss` files will be compiled to `styles` via `gulp style` task. To do this, `libsass` is featured in the generator. Please see [this](https://github.com/yeoman/generator-gulp-webapp#libsass) for further information.
```sh
yo chrome-extension --sass
```### All of Permissions for Chrome Extension
Need to add more permissions for chrome extension? You can get all list of permissions using `--all-permissions` option when scaffolding a new project.
```sh
yo chrome-extension --all-permissions
```## Contribute
See the [contributing docs](https://github.com/yeoman/yeoman/blob/master/contributing.md)
## License
[BSD license](http://opensource.org/licenses/bsd-license.php)