Skip to content

Commit

Permalink
Rebase with shutterstock/rickshaw (#1)
Browse files Browse the repository at this point in the history
* Makes hover detail arrow rendering more reliable

Uses the 'CSS triangle' trick to render the left and right arrows on the
hover detail item, rather than using a glyph (whose rendering might
change depending on the font used).

The technique is described here:

http://appendto.com/blog/2013/03/pure-css-triangles-explained/

* Improves hover detail placement when space is tight

The layout error for hover detail elements is now checked for both
left and right alignment.  Then the alignment with the least error is
used.

* Add test case for Legend

* Make Rickshaw.Graph.Legend a real class

This makes it possible to extend the legend to add custom styling
or interactivity. This commit should not change behavior or options.

* Allow Legend subclasses to override the className

* Extract legend rendering into render function that can be called multiple times

* Return rendered line from addLine

* tweak area renderer to play nicely with multi renderer; fixes shutterstock#335; closes shutterstock#336

* update built libs

* Update README.md

* excise Rickshaw.Graph.Unstacker and allow for consumers to pre-stack if they like; fixes shutterstock#333

* Add series configured class name to all scatterplot points

* throw an error if provided element isn't an element

* Added Rickshaw.Graph.Minimap class. The minimap will render exactly what the main graph renders, but will not pay attention to its "window" extents and  thus will always show the whole data set.

* refactor Minimap and rename to Rickshaw.Graph.RangeSlider.Preview; closes shutterstock#273

* add data attributes on axis ticks; closes shutterstock#347

* Update README.md

* tell jshint to warn about leaking globals

* be smarter about rounding months and years; closes shutterstock#344

* Update README.md

* allow specifying custom x and y scales; closes shutterstock#346

* Respect series classes in legend renderer (to allow the color of the swatch to be controlled by css

* invoke stroke factory in renderer parent class; closes shutterstock#337; closes shutterstock#338

* update built libs

* support sending slide callbacks for range sliders; fixes shutterstock#363

* render annotations after adding each one

* make sure to initialize the preview graphs' renderers to match parents for range slider previews; closes shutterstock#364

* fire range slider events with extents in tact

* Rickshaw.Graph.RangeSlider.Preview supports millisecond zooming

Changed the domainScale interpolate function to d3.interpolateNumber
(vs. d3.interpolateRound) so that the RangeSlider Preview Window could
zoom into millisecond levels of precision (before it would only allow a
window of 1 second)

* Fix shutterstock#377: Ensure multi renderer consults it's sub renderers about how they perceive their domain

* Configure range slider from graph, so that width changes affect the slider width too.

* Fix typo

* Ensure Graph creates a copy of the x/yScale before modifying it

x/yScale is coming from the configuration dictionary which may be
referenced by the Graph creator, or shared with other Graphs. We need to
ensure we copy the scale so that our mutations do not change the object
given to us.

* Prevent slider from cutting of series.

This fixes the following bug:

I have 4 series,

[
  [{0, 1}, {1, 1}],
  [{1, 1}, {2, 1}],
  [{2, 1}, {3, 1}],
  [{3, 1}, {4, 1}]
]

I use a slider to select the x-range (2.5, 4)

This means stackedData ends up being

[ [], [], [], [[3,4], [1, 1]] ]

At this point, reading stackedData[0][0] produces undefined, even though
there is data that belongs to the range.

* Recentered detail dot. explicitly set box-sizing.

* refined margin-top

* make jQuery dependent bits compatible with jQuery.noConflict(); fixes shutterstock#396

* Rescope stroke style attribute on y-axis

In mbostock/d3 issue #1016, the scope of the `tick` class on a svg y-axis
element changed to include the entire g object (line and text), not just the
line. The Rickshaw CSS for `.y_ticks .tick` was created in the early commits, and
sets the style to be a 2px width semitransparent stroke.

Due to the change in scoping of the style class, the stroke element applies to
both the line and the text element, creating a shadow on the y-axis text labels.

By changing the scope of the stroke stanza from `.y_ticks .tick` to `.y_ticks
.tick line`, the stroke now applies only to the line, and not to the text
element, this removing the stroke shadow on the text label.

* Extend Range Slider to accept multiple graphs

Extend to allow array of graphs, and handle logic based on if the graph element
is singular or plural.

Also add examples/shared_slider.html as a demo of new functionality

Similar to pullr equest shutterstock#169 (bozdoz)

* Make jQuery known as the global symbol instead of $

To make it actually compile again.

* Define $ variable in correct scope

* Allow for developers to customise hook into jQUI slider events

* Switch back to tabs

* Add start and end scripts to allow use of UMD by Rickshaw

* Allow empty data arrays in series.

* Find correct domain even if the first series in stack is empty.

This can easily happen when series of different length are drawn and the RangeSlider is used to restrict the graph to a range where one of the series is empty.

* Removed trailing comma in example

* provide a supported interface for toggling stacking

* support resizing preview range sliders; closes shutterstock#375; closes shutterstock#417; closes shutterstock#382

* add x magnitude scale and improve barWidth calculation for bars renderer

* use preview range slider in multi renderer example

* refactor lineplot to work with multi renderer; closes shutterstock#413; closes shutterstock#414

* update built libs

* Update README.md

* Add README.md note about $super and minification; closes shutterstock#52

* Only update graph once when toggling a series, not once per series.

* Remove duplicate graph update in smoother.

* Update copyright year

Fix outdated copyright year (update to 2014)
The copyright year was out of date. Copyright notices must reflect the current year. This commit updates the listed year to 2014.

see: http://www.copyright.gov/circs/circ01.pdf for more info

* Better documentation around stacked and unstacked rendering.

* Update example_04.html

* Added method to remove HoverDetail's mouse listeners.

* Show units when displaying minutes.

When time is being displayed in minutes there is no indication of units.

* Update README.md

Per the actual source, one can pass an int to color() and select the nth color from a palette. I simply added this fact to the documentation.

* transform either stroke or color properties on highlight

* override which key to fetch legend swatch color from

* Remove error if no jQuery.

Uncaught ReferenceError: jQuery is not defined at line rickshaw.js:1985(anonymous function)

* Add default value for `renderer`

As much as I understand, `renderer` defaults to `line`. Adding that in the README

* Add homepage, repository and issues links in package.json.

* update built libs

* fixing local time ticks

* Fix typo

* Make calculating interval in bar chart consistent. Fixes shutterstock#461

Sorting object's keys returned to guarantee consistency when iterating over. Keys order in `for .. in` loop is not specified and browsers behave differently here. This results with different invterval value being calculated for different browsers. See last but one section here: http://www.ecma-international.org/ecma-262/5.1/#sec-12.6.4.

* HoverDetail should default to being inactive.

* Add Rickshaw.Graph.Dragzoom

* center x_axis on bar chart

* Rename with .append at the end

* Rename with .prepend at the end

* use prepend/append files for UMD support

prevents downstream issues from cropping up due to invalid JavaScript files.

* RangeSlider: Resize when original graph changes width

* bower ready, with d3 dependency

* fix for 29 Feb

* fixing license warning

* added travis

* upgrade dependancies

* requiring minimally node4 to run tests

jsdom works either with node <0.12 or with node >4 so this means you can install the package at node <4
but you wont be able to run the tests

* add coverage

* Multi-chart slider and colors for individual bars

RangeSlider now works with multiple charts and a single slider, by using an array with the graph variables:

var slider_three = new Rickshaw.Graph.RangeSlider({
    element: document.querySelector('#slider-range'),
    graph: [graph_one, graph_two, graph_three]
});

The bar chart renderer now looks for a proposed color for each individual bar, it will default to the chart-specific color if no color is declared:

var data = [{
  data: [{ 
    x: -1893456000, y: 29389330}, { 
    x: -1577923200, y: 33125803}, { 
    x: -1262304000, y: 37857633, color:'#06f'}, { 
    x: -946771200, y: 41665901, color:'#0cf'}
  ],
    color: 'shutterstock#222'
  }]

* created an example with multiple graphs

* multiple graphs with RangeSlider works

* revert RangeSlider now works with multiple charts and a single slider, by using an array with the graph variables:

632d1fb

* formatting and adding back $ to be able to build

* building css

* Version 1.6.0-rc.0

* Correct check for undefined variable

The code was comparing the result of `typeof` with a variable named `undefined`.

As typeof returns a string it should compare to `'undefined'`

* added example bar chart

* keeping the shared_slider example

* Running `make watchjs` watches src folder

* using npm run watch instead of makefile

* added lint to package.json

* consolodating code to avoid duplication

* Version 1.6.0

* upgraded dependancies
* support for node 4
* support for npm run watch while developing
* RangeSlider can accept multiple graphs

* fixed stacked area chart hover detail bug in firefox

* Fixes issue with negative values between 0 and -1

Probably due to a typo, numbers between 0 and -1 were not formatted as expected.

* Create a locally scoped copy of the loop-index var to prevent accessing out-of-bound index in the onConfigure callback

* added tests for hover detail

* added test for HoverDetail _removeListeners for shutterstock#477

* added tests for palette

* added test for number formatting

* added tests for annotate

* updated coveralls badge link

* Since JS doesn't have block scopes, only function scopes. So, in order to capture
a loop-index variable for the later `onConfigure` function callback, we create an
IIFE

* added test for onConfigure for shutterstock#568 shutterstock#579 shutterstock#306 shutterstock#324 shutterstock#320

added resize in the series example to manually demo onConfigure

* travis relies on built files

* added test for DragZoom initialize error for shutterstock#512

and updated test to use jsdom and lint

* including DragZoom in build

* building if needed before running tests

the tests run on the built code, rather than source code.
building if needed helps ensure the test is running against changes and
so that travis can run on prs

* added tests for mouse events on dragzoom

* added example for dragzoom

* added Rickshaw.version fixes shutterstock#538 fixes shutterstock#224

* running make after version to have updated version in dist

* 1.6.1

* based on series graph

* angular example fixes shutterstock#374 and for shutterstock#477

* example of updating data via angular controller

* instead of deap watch overwriting series data

and adding method setSeries to update data fixes shutterstock#407

* linking to angular-rickshaw directive

* Add ToC, Install section to README

This pull request adds a Table of Contents using `doctoc`, adds an npm-script to easily run it, and adds an install section to the README that more accurately reflects how to use the package. I also moved dependencies up to the Install section, as this is probably where it belongs.

* Edit CONTRIBUTING

Right now, the Contributing file has nothing about READMEs. While shutterstock#588 has been opened to talk about labels, I thought it would be good to have something in the CONTRIBUTING file about labels and issues, in general. This adds that, and should not be too controversial. In particular, I want to field possible labels from those submitting issues. This should cut down on internal time making labels that do not make sense.

* Adding link

* Adding the Contributor Covenant Code of Conduct

* Update License year

Closes shutterstock#589

* Commiting package.lock file

* 1.6.2

* update bower spec for build tools:
* specify js file extension for main property
* pull in rickshaw.css

* 1.6.3

* added test for setSeries

* chore: updated fields in the package.json

        - Check that nothing drastic happened in the `package.json`.
- We've added " JavaScript toolkit for creating interactive real-time graphs" as the description in the `package.json`. We got this from the GitHub repo description.
- Check the `package.json` keywords. We added these from your GitHub topics: "charts", "d3", "graph", "javascript", "rickshaw", "svg".
- Check that the bugs field in the package.json is OK. It doesn't match what we'd expect, which would be https://github.com/shutterstock/rickshaw/issues
- We expected the repository url in the `package.json` to be https://github.com/shutterstock/rickshaw, and it wasn't. Is this intentional?
- If there are more contributors, add them to the Contributors field in the `package.json`.

* fixes shutterstock#604 seperate build into minification and development

* build before test, fail PR on dist change

* Update Table of Contents

* 1.6.4

* Fix positioning of hoverdetail in chrome when zooming

This commit changes the calculation of the current mouse position to use
`MouseEvent.clientX/Y` (mouse position in relation to the viewport) and
`Element.getBoundingClientRect()` (element position in relation to the
viewport).

`event.layerX/Y` is non-standard and seems to return different values
than we are expecting if there is zooming involved in Chrome.

Demo, zoom in and hover the square:
https://jsfiddle.net/6gnpL75j/

An earlier commit reverted the order of layer vs offset and fixed a
positioning bug in Firefox while introducing this new one in Chrome:
shutterstock@c81f037
I looked around for that Firefox positioning bug in v1.6.0 which I found
in: http://code.shutterstock.com/rickshaw/examples/extensions.html
With this PR, both Chrome and Firefox show labels in the correct spot.

More information:
https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/clientX
https://developer.mozilla.org/en-US/docs/Web/API/Element/getBoundingClientRect
https://developer.mozilla.org/en-US/docs/Web/API/UIEvent/layerX

Chromium issue:
https://bugs.chromium.org/p/chromium/issues/detail?id=323518

* wrap style access to prevent unnecessary reflow

* whitespace

* 1.6.5

* fix: check undefined for series opacity

* test: add test for opacity settings for scatterplot renderer

* Update links

* 1.6.6

* not including package-lock since all deps are dev deps

* Add auto height and width to detail.css

* Bump express from 3.3.5 to 4.17.1 in /examples/socket.io

Bumps [express](https://github.com/expressjs/express) from 3.3.5 to 4.17.1.
- [Release notes](https://github.com/expressjs/express/releases)
- [Changelog](https://github.com/expressjs/express/blob/master/History.md)
- [Commits](expressjs/express@3.3.5...4.17.1)

Signed-off-by: dependabot[bot] <[email protected]>

* Bump clean-css from 3.4.28 to 4.2.1

Bumps [clean-css](https://github.com/jakubpawlowicz/clean-css) from 3.4.28 to 4.2.1.
- [Release notes](https://github.com/jakubpawlowicz/clean-css/releases)
- [Changelog](https://github.com/jakubpawlowicz/clean-css/blob/master/History.md)
- [Commits](clean-css/clean-css@v3.4.28...v4.2.1)

Signed-off-by: dependabot[bot] <[email protected]>

* add editorconfig

* clean-css was split into clean-css-cli

* add example of highlight transform for shutterstock#489

* Update Rickshaw.Graph.Axis.Y.js

This change allows the user to select the axis color when creating the axis.
It is useful when creating axis dynamically (adding series with different scales on run time).

* correct formatBase1024KMGTP (shutterstock#620)

* correct formatBase1024KMGTP and support negatives values

fixes shutterstock#601

* fix indentation

* 1.7.0

* check-in screenshots

* npm ignore docs tests etc

* 1.7.1

* remove local copy of vendor/d3 (shutterstock#613)

Removed the local git syncd copy of d3.js since it is already a dependency in
both the package.json and bower.json

Updated examples to use the copy from node_modules to maintain consistency with
the unit tests

* docs: Fix typo (shutterstock#630)

Co-authored-by: Christopher Chambers <[email protected]>
Co-authored-by: Robert Buchholz <[email protected]>
Co-authored-by: David Chester <[email protected]>
Co-authored-by: David Chester <[email protected]>
Co-authored-by: Martin Häcker <[email protected]>
Co-authored-by: Mark Derbecker <[email protected]>
Co-authored-by: deldrid1 <[email protected]>
Co-authored-by: Noah Gibbs <[email protected]>
Co-authored-by: Martin Olsson <[email protected]>
Co-authored-by: arunv <[email protected]>
Co-authored-by: Luke Mawbey <[email protected]>
Co-authored-by: Katie McLaughlin <[email protected]>
Co-authored-by: Callum Jones <[email protected]>
Co-authored-by: Fernando Jorge Mota <[email protected]>
Co-authored-by: Shane Reustle <[email protected]>
Co-authored-by: msand <[email protected]>
Co-authored-by: Joshua Goldberg <[email protected]>
Co-authored-by: Matthew Ginnard <[email protected]>
Co-authored-by: Nicolas Racine <[email protected]>
Co-authored-by: André Tavares <[email protected]>
Co-authored-by: Brennan Ashton <[email protected]>
Co-authored-by: hamx0r <[email protected]>
Co-authored-by: Alexander Johansson <[email protected]>
Co-authored-by: GermanBluefox <[email protected]>
Co-authored-by: Gagan Awhad <[email protected]>
Co-authored-by: Eirik S. Morland <[email protected]>
Co-authored-by: Vivek Kushwaha <[email protected]>
Co-authored-by: Sebastian Wallin <[email protected]>
Co-authored-by: Michal Ostruszka <[email protected]>
Co-authored-by: Michelle Bu <[email protected]>
Co-authored-by: Stuart Nelson <[email protected]>
Co-authored-by: Mathieu Chataigner <[email protected]>
Co-authored-by: Mike Atlas <[email protected]>
Co-authored-by: Pablo Reyes <[email protected]>
Co-authored-by: funvit <[email protected]>
Co-authored-by: Wil Moore III <[email protected]>
Co-authored-by: cjthompson <[email protected]>
Co-authored-by: Jay <[email protected]>
Co-authored-by: cesine <[email protected]>
Co-authored-by: cesine <[email protected]>
Co-authored-by: Thomas Lackemann <[email protected]>
Co-authored-by: Jay Patel <[email protected]>
Co-authored-by: Benjamin J DeLong <[email protected]>
Co-authored-by: Mathias Rangel Wulff <[email protected]>
Co-authored-by: Doa Jafri <[email protected]>
Co-authored-by: Robert Tod <[email protected]>
Co-authored-by: Tamas Goga <[email protected]>
Co-authored-by: Mokeponi <[email protected]>
Co-authored-by: bhashit parikh <[email protected]>
Co-authored-by: Richard Littauer <[email protected]>
Co-authored-by: Conan Tzou <[email protected]>
Co-authored-by: Roland Schilter <[email protected]>
Co-authored-by: Jack Q <[email protected]>
Co-authored-by: Diego Zilioti <[email protected]>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: ftortega <[email protected]>
Co-authored-by: Julien Francoz <[email protected]>
Co-authored-by: Sebastian Murphy <[email protected]>
Co-authored-by: Tim Gates <[email protected]>
  • Loading branch information
Show file tree
Hide file tree
Showing 151 changed files with 13,508 additions and 1,078 deletions.
8 changes: 8 additions & 0 deletions .editorconfig
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
root = true

[*]
indent_style = tab
end_of_line = lf
charset = utf-8
trim_trailing_whitespace = true
insert_final_newline = true
11 changes: 9 additions & 2 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,5 +1,12 @@
*.log
*swp
yarn-error.log
yarn.lock
package-lock.json

# Dependency directories
node_modules
rickshaw.css
rickshaw.js
vendor

# Coverage directory used by tools like istanbul
coverage
7 changes: 7 additions & 0 deletions .jshintignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
node_modules/
**/vendor/
**/*[.-]min.js
src/js/Rickshaw.Class.js
src/js/Rickshaw.Compat.ClassList.js
src/helpers/endUMD.js
src/helpers/startUMD.js
11 changes: 11 additions & 0 deletions .jshintrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
{
"funcscope": true,
"lastsemic": true,
"loopfunc": true,
"eqnull": true,
"expr": true,
"undef": true,
"browser": true,
"node": true,
"predef": ["Rickshaw", "d3", "jQuery", "console", "io"]
}
26 changes: 26 additions & 0 deletions .npmignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
*.log
*swp
yarn-error.log
yarn.lock
package-lock.json

# Dependency directories
node_modules

# Coverage directory used by tools like istanbul
coverage

# Docs
examples
tutorial
tests

# Development files
.editorconfig
.jshintignore
.jshintrc
.rock.yml
.travis.yml
Makefile
CODE_OF_CONDUCT.md
CONTRIBUTING.md
4 changes: 4 additions & 0 deletions .rock.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
runtime: node4
build: npm install && make clean && make
run: rock --runtime=python27 run python -m SimpleHTTPServer
test: npm test
17 changes: 17 additions & 0 deletions .travis.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
language: node_js
node_js:
- "4"
- "12"

env:
global:
- FAIL_IF_DIST_MESSAGE="These files are autogenerated. Please don't include changes to these files in your PR "

before_script:
- npm run build

after_script:
- npm run coverage
- npm run coveralls
- echo "Testing for changed dist files."
- DIST_CHANGED=`git diff --name-only HEAD $TRAVIS_BRANCH | egrep 'rickshaw(\.min)?\.(js|css)'`; [[ ! -z "$DIST_CHANGED" ]] && printf "\n\n" && echo -e "\033[31m$FAIL_IF_DIST_MESSAGE $DIST_CHANGED" && exit 1
75 changes: 75 additions & 0 deletions CODE_OF_CONDUCT.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
# Contributor Covenant Code of Conduct

## Our Pledge

In the interest of fostering an open and welcoming environment, we as
contributors and maintainers pledge to making participation in our project and
our community a harassment-free experience for everyone, regardless of age, body
size, disability, ethnicity, gender identity and expression, level of experience,
nationality, personal appearance, race, religion, or sexual identity and
orientation.

## Our Standards

Examples of behavior that contributes to creating a positive environment
include:

* Using welcoming and inclusive language
* Being respectful of differing viewpoints and experiences
* Gracefully accepting constructive criticism
* Focusing on what is best for the community
* Showing empathy towards other community members

Examples of unacceptable behavior by participants include:

* The use of sexualized language or imagery and unwelcome sexual attention or
advances
* Trolling, insulting/derogatory comments, and personal or political attacks
* Public or private harassment
* Publishing others' private information, such as a physical or electronic
address, without explicit permission
* Other conduct which could reasonably be considered inappropriate in a
professional setting

## Our Responsibilities

Project maintainers are responsible for clarifying the standards of acceptable
behavior and are expected to take appropriate and fair corrective action in
response to any instances of unacceptable behavior.

Project maintainers have the right and responsibility to remove, edit, or
reject comments, commits, code, wiki edits, issues, and other contributions
that are not aligned to this Code of Conduct, or to ban temporarily or
permanently any contributor for other behaviors that they deem inappropriate,
threatening, offensive, or harmful.

## Scope

This Code of Conduct applies both within project spaces and in public spaces
when an individual is representing the project or its community. Examples of
representing a project or community include using an official project e-mail
address, posting via an official social media account, or acting as an appointed
representative at an online or offline event. Representation of a project may be
further defined and clarified by project maintainers.

## Enforcement

Instances of abusive, harassing, or otherwise unacceptable behavior may be
reported by contacting the project team at
[email protected]. All
complaints will be reviewed and investigated and will result in a response that
is deemed necessary and appropriate to the circumstances. The project team is
obligated to maintain confidentiality with regard to the reporter of an incident.
Further details of specific enforcement policies may be posted separately.

Project maintainers who do not follow or enforce the Code of Conduct in good
faith may face temporary or permanent repercussions as determined by other
members of the project's leadership.

## Attribution

This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
available at [http://contributor-covenant.org/version/1/4][version]

[homepage]: http://contributor-covenant.org
[version]: http://contributor-covenant.org/version/1/4/
25 changes: 25 additions & 0 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
# Contribute to Rickshaw

Thanks for contributing!

## Issues

We're currently overhauling how we do issues. Before we have a template in place and relevant labels, it would be great if you made your issue concise, clear, and to the point. If you have labels that you would suggest we add, please add this line with suggested labels at the bottom of the issue:

`Suggested labels: example, another-example-label`

If you'd like to weigh in on labels, check out [this issue](https://github.com/shutterstock/rickshaw/issues/588).

## Pull requests are always welcome!

Please follow a few guidelines:

- Please don't include updated versions of `rickshaw.js` and `rickshaw.min.js`. Just changes to the source files will suffice.
- Add a unit test or two to cover the proposed changes
- Please run the tests and make sure tests are all passing before submitting your pull request
- Do as the Romans do and stick with existing whitespace and formatting conventions (i.e., tabs instead of spaces, etc)
- Consider adding a simple example under examples/ that demonstrates any new functionality

## Code of Conduct

All interactions with Shutterstock follow the [Contributor Covenant Code of Conduct](CODE_OF_CONDUCT.md).
7 changes: 7 additions & 0 deletions LICENSE
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
Copyright (C) 2011-2017 by Shutterstock Images, LLC

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
43 changes: 39 additions & 4 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -3,37 +3,56 @@ NODE_MODULES=$(NODE_PREFIX)/node_modules

CSS_MIN=$(NODE_MODULES)/.bin/cleancss
JS_MIN=$(NODE_MODULES)/.bin/uglifyjs
JS_HINT=$(NODE_MODULES)/.bin/jshint
D3=$(NODE_MODULES)/d3
JSDOM=$(NODE_MODULES)/jsdom
NODEUNIT=$(NODE_MODULES)/nodeunit

CSS_FILES=\
src/css/detail.css\
src/css/graph.css\
src/css/legend.css\

JS_FILES=\
src/helpers/startUMD.js.prepend\
src/js/Rickshaw.js\
src/js/Rickshaw.Class.js\
src/js/Rickshaw.Compat.ClassList.js\
src/js/Rickshaw.Graph.js\
src/js/Rickshaw.Fixtures.Color.js\
src/js/Rickshaw.Fixtures.RandomData.js\
src/js/Rickshaw.Fixtures.Time.js\
src/js/Rickshaw.Fixtures.Time.Local.js\
src/js/Rickshaw.Fixtures.Number.js\
src/js/Rickshaw.Color.Palette.js\
src/js/Rickshaw.Graph.Ajax.js\
src/js/Rickshaw.Graph.Annotate.js\
src/js/Rickshaw.Graph.Axis.Time.js\
src/js/Rickshaw.Graph.Axis.X.js\
src/js/Rickshaw.Graph.Axis.Y.js\
src/js/Rickshaw.Graph.Axis.Y.Scaled.js\
src/js/Rickshaw.Graph.Behavior.Series.Highlight.js\
src/js/Rickshaw.Graph.Behavior.Series.Order.js\
src/js/Rickshaw.Graph.Behavior.Series.Toggle.js\
src/js/Rickshaw.Graph.DragZoom.js\
src/js/Rickshaw.Graph.HoverDetail.js\
src/js/Rickshaw.Graph.JSONP.js\
src/js/Rickshaw.Graph.Legend.js\
src/js/Rickshaw.Graph.RangeSlider.js\
src/js/Rickshaw.Graph.RangeSlider.Preview.js\
src/js/Rickshaw.Graph.Renderer.js\
src/js/Rickshaw.Graph.Renderer.Line.js\
src/js/Rickshaw.Graph.Renderer.Stack.js\
src/js/Rickshaw.Graph.Renderer.Bar.js\
src/js/Rickshaw.Graph.Renderer.Area.js\
src/js/Rickshaw.Graph.Renderer.ScatterPlot.js\
src/js/Rickshaw.Graph.Renderer.Multi.js\
src/js/Rickshaw.Graph.Renderer.LinePlot.js\
src/js/Rickshaw.Graph.Smoother.js\
src/js/Rickshaw.Graph.Unstacker.js\
src/js/Rickshaw.Graph.Socketio.js\
src/js/Rickshaw.Series.js\
src/js/Rickshaw.Series.FixedDuration.js\
src/helpers/endUMD.js.append\

.PHONY: clean build

Expand All @@ -42,20 +61,36 @@ build: rickshaw.min.css rickshaw.min.js
clean:
rm -rf rickshaw.css rickshaw.js rickshaw.min.*

test: $(D3) $(JSDOM) $(NODEUNIT)
npm test

$(JS_HINT):
npm install jshint

$(CSS_MIN):
npm install clean-css

$(JS_MIN):
npm install uglify-js

rickshaw.css:
$(D3):
npm install d3

$(JSDOM):
npm install jsdom

$(NODEUNIT):
npm install nodeunit

rickshaw.css: $(CSS_FILES)
cat $(CSS_FILES) > rickshaw.css

rickshaw.js:
rickshaw.js: $(JS_FILES) $(JS_HINT)
$(JS_HINT) src/js
cat $(JS_FILES) > rickshaw.js

rickshaw.min.css: $(CSS_MIN) rickshaw.css
$(CSS_MIN) rickshaw.css > rickshaw.min.css

rickshaw.min.js: $(JS_MIN) rickshaw.js
$(JS_MIN) rickshaw.js > rickshaw.min.js
$(JS_MIN) --reserved-names "\$$super" rickshaw.js > rickshaw.min.js
Loading

0 comments on commit dc1ff2e

Please sign in to comment.