Skip to content

Latest commit

 

History

History
138 lines (73 loc) · 4.42 KB

CONTRIBUTING.md

File metadata and controls

138 lines (73 loc) · 4.42 KB

Reporting Bugs

Each bug report MUST have a Codepen/JSFiddle recreation before any work can begin. further instructions »

Requesting Features

Please search the Issue Tracker to see if your feature has already been requested, and if so, subscribe to it. Otherwise, read these further instructions »

Contributing Features

The FullCalendar project welcomes Pull Requests for new features, but because there are so many feature requests (over 100), and because every new feature requires refinement and maintenance, each PR will be prioritized against the project's other demands and might take a while to make it to an official release.

Furthermore, each new feature should be designed as robustly as possible and be useful beyond the immediate usecase it was initially designed for. Feel free to start a ticket discussing the feature's specs before coding.

Contributing Bugfixes

In the description of your Pull Request, please include recreation steps for the bug as well as a [JSFiddle/JSBin] demo. Communicating the buggy behavior is a requirement before a merge can happen.

Contributing Locales

Please edit the original files in the packages/core/locales/ directory.

Other Ways to Contribute

Read about other ways to contribute »

Getting Set Up

You will need Git, Node and NPM installed.

Then, clone FullCalendar's git repo:

git clone --recursive git://github.com/fullcalendar/fullcalendar.git

The recursive flag will clone all submodules as well. fullcalendar-scheduler and the example projects are located within submodules.

Enter the directory and install FullCalendar's dependencies:

cd fullcalendar
npm install

NOTE: The install command will take a LONG time. We are working to fix this.

Development Workflow

After you make code changes, you'll want to compile the JS/CSS so that it can be previewed from the tests and examples. You can either manually rebuild each time you make a change:

npm run build

Or, you can run a script that automatically rebuilds whenever you save a source file:

npm run watch

If you want to clean up the generated files, run:

npm run clean

Running Test

To run the Karma tests, you must first run npm run watch. Then, in separate console, run:

npm run test

You will be given a URL to visit in your browser. When you visit this URL the tests will automatically run.

If you want to execute the tests headlessly, run:

npm run test:single

Git

Because this repo has a few git submodules, it will be very convenient to set your default git push behavior to be recursive. Do something like this:

git config --global push.recurseSubmodules on-demand

Style Guide

Please follow the Google JavaScript Style Guide as closely as possible. With the following exceptions:

if (true) {
}
else { // please put else, else if, and catch on a separate line
}

// please write one-line array literals with a one-space padding inside
var a = [ 1, 2, 3 ];

// please write one-line object literals with a one-space padding inside
var o = { a: 1, b: 2, c: 3 };

Other exceptions:

  • please ignore anything about Google Closure Compiler or the goog library
  • please do not write JSDoc comments

Notes about whitespace:

  • use tabs instead of spaces
  • separate functions with 2 blank lines
  • separate logical blocks within functions with 1 blank line

Run the command line tool to automatically check your style:

npm run lint

Before Submitting your Code

If you have edited code (including tests and translations) and would like to submit a pull request, please make sure you have done the following:

  1. Conformed to the style guide (successfully run npm run lint)

  2. Written automated tests. View the Automated Test Readme