Skip to content

Latest commit

 

History

History
116 lines (93 loc) · 4.35 KB

contributing.md

File metadata and controls

116 lines (93 loc) · 4.35 KB

Contributing

Suggestions and pull requests are highly encouraged! Have a look at the open issues, especially the easy ones.

Notions

  • You will need to be familiar with npm and webpack to build this extension.
  • The extension can be loaded into Chrome or Firefox manually (See notes below)
  • JSX is used to create DOM elements.
  • All the latest DOM APIs and JavaScript features are available because the extension only has to work in the latest Chrome and Firefox. 🎉
  • Each JavaScript feature lives in its own file under source/features and it's imported in source/content.ts.
  • Some GitHub pages are loaded via AJAX/PJAX, so some features use the special onAjaxedPages loader (see it as a custom "on DOM ready").
  • See what a feature looks like.
  • If you're making changes to the README, try to match the style of the content that's already there and when in doubt, take a look at our little style guide.
  • Refined GitHub tries to integrate as best as possible, so GitHub's own styleguide might come in useful.

features.add

The simplest usage of feature.add is the following. This will be run instantly on all page-loads (but not on ajax loads):

import features from '../libs/features';

function init () {
	console.log('✨');
}

features.add({
	id: 'make-github-more-refined',
	init
});

Here's an example using all of the possible feature.add options:

import React from 'dom-chef';
import select from 'select-dom';
import features from '../libs/features';

function log() {
	console.log('✨', <div className="rgh-jsx-element"/>);
}
function init(): void {
	select('.btn')!.addEventListener('click', log);
}
function deinit(): void {
	select('.btn')!.removeEventListener('load', log);
}

features.add({
	id: 'make-github-more-refined',
	include: [
		features.isUserProfile,
		features.isRepo
	],
	exclude: [
		features.isOwnUserProfile
	],
	load: features.domReady, // Wait for dom-ready
	// load: features.onAjaxedPages, // Or: Wait for dom-ready AND run on all ajaxed loads
	// load: features.onNewComments, // Or: Wait for dom-ready AND run on all ajaxed loads AND watch for new comments
	deinit, // Rarely needed
	init
});

Workflow

First clone:

git clone https://github.com/sindresorhus/refined-github
cd refined-github
npm install

When working on the extension or checking out branches, use this to have it constantly build your changes:

npm run watch # Listen for file changes and automatically rebuild

Then load or reload it into the browser to see the changes (this does not happen automatically).

Loading into the browser

Once built, load it in the browser of your choice:

Chrome Firefox
  1. Open chrome://extensions;
  2. Check the Developer mode checkbox;
  3. Click on the Load unpacked extension button;
  4. Select the folder refined-github/distribution.
  1. Open about:debugging#addons;
  2. Click on the Load Temporary Add-on button;
  3. Select the file refined-github/distribution/manifest.json.
Or you can use run this command to have Firefox automatically load and reload it through web-ext run:

npm run watch:firefox