Commit 3035aaae authored by David Schnur's avatar David Schnur

Merge branch 'master' into 0.9-work

Conflicts:
	component.json
	flot.jquery.json
	jquery.flot.js
	jquery.flot.pie.js
	jquery.flot.resize.js
	lib/jquery.colorhelpers.js
	package.json
parents ea4bfb11 39bc058b
...@@ -542,7 +542,7 @@ You can see a timestamp like this ...@@ -542,7 +542,7 @@ You can see a timestamp like this
alert((new Date()).getTime()) alert((new Date()).getTime())
``` ```
There are different schools of thought when it comes to diplay of There are different schools of thought when it comes to display of
timestamps. Many will want the timestamps to be displayed according to timestamps. Many will want the timestamps to be displayed according to
a certain time zone, usually the time zone in which the data has been a certain time zone, usually the time zone in which the data has been
produced. Some want the localized experience, where the timestamps are produced. Some want the localized experience, where the timestamps are
...@@ -572,6 +572,19 @@ In Python you can get it with something like: ...@@ -572,6 +572,19 @@ In Python you can get it with something like:
```python ```python
calendar.timegm(datetime_object.timetuple()) * 1000 calendar.timegm(datetime_object.timetuple()) * 1000
``` ```
In Ruby you can get it using the `#to_i` method on the
[`Time`](http://apidock.com/ruby/Time/to_i) object. If you're using the
`active_support` gem (default for Ruby on Rails applications) `#to_i` is also
available on the `DateTime` and `ActiveSupport::TimeWithZone` objects. You
simply need to multiply the result by 1000:
```ruby
Time.now.to_i * 1000 # => 1383582043000
# ActiveSupport examples:
DateTime.now.to_i * 1000 # => 1383582043000
ActiveSupport::TimeZone.new('Asia/Shanghai').now.to_i * 1000
# => 1383582043000
```
In .NET you can get it with something like: In .NET you can get it with something like:
...@@ -1497,7 +1510,7 @@ hooks in the plugins bundled with Flot. ...@@ -1497,7 +1510,7 @@ hooks in the plugins bundled with Flot.
case a plot is overwritten by a new plot. If you're writing a case a plot is overwritten by a new plot. If you're writing a
plugin that adds extra DOM elements or event handlers, you should plugin that adds extra DOM elements or event handlers, you should
add a callback to clean up after you. Take a look at the section in add a callback to clean up after you. Take a look at the section in
PLUGINS.txt for more info. the [PLUGINS](PLUGINS.md) document for more info.
## Plugins ## ## Plugins ##
...@@ -1519,7 +1532,7 @@ from the "option" attribute of the plugin. The init function gets a ...@@ -1519,7 +1532,7 @@ from the "option" attribute of the plugin. The init function gets a
reference to the plot object created and uses this to register hooks reference to the plot object created and uses this to register hooks
and add new public methods if needed. and add new public methods if needed.
See the PLUGINS.txt file for details on how to write a plugin. As the See the [PLUGINS](PLUGINS.md) document for details on how to write a plugin. As the
above description hints, it's actually pretty easy. above description hints, it's actually pretty easy.
......
...@@ -8,9 +8,8 @@ work for us, and a faster and better response. ...@@ -8,9 +8,8 @@ work for us, and a faster and better response.
Issues are not a way to ask general questions about Flot. If you see unexpected Issues are not a way to ask general questions about Flot. If you see unexpected
behavior but are not 100% certain that it is a bug, please try posting to the behavior but are not 100% certain that it is a bug, please try posting to the
[forum](http://groups.google.com/group/flot-graphs) first, and confirm that [forum](http://groups.google.com/group/flot-graphs) first, and confirm that
what you see is really a Flot problem before creating a new issue for it. what you see is really a Flot problem before creating a new issue for it. When
reporting a bug, please include a working demonstration of the problem, if
When reporting a bug, please include a working demonstration of the problem, if
possible, or at least a clear description of the options you're using and the possible, or at least a clear description of the options you're using and the
environment (browser and version, jQuery version, other libraries) that you're environment (browser and version, jQuery version, other libraries) that you're
running under. running under.
...@@ -21,23 +20,23 @@ love to hear them! Please submit each suggestion as a separate new issue. ...@@ -21,23 +20,23 @@ love to hear them! Please submit each suggestion as a separate new issue.
If you would like to work on an existing issue, please make sure it is not If you would like to work on an existing issue, please make sure it is not
already assigned to someone else. If an issue is assigned to someone, that already assigned to someone else. If an issue is assigned to someone, that
person has already started working on it. So, pick unassigned issues to prevent person has already started working on it. So, pick unassigned issues to prevent
duplicated efforts. duplicated effort.
### Pull Requests ### ### Pull Requests ###
To make merging as easy as possible, please keep these rules in mind: To make merging as easy as possible, please keep these rules in mind:
1. Divide larger changes into a series of small, logical commits with 1. Submit new features or architectural changes to the *<version>-work*
descriptive messages. branch for the next major release. Submit bug fixes to the master branch.
2. Format your code according to the style guidelines below.
3. Submit new features or architectural changes to the <version>-work branch 2. Divide larger changes into a series of small, logical commits with
for the next major release. Submit bug fixes to the master branch. descriptive messages.
4. Rebase, if necessary, before submitting your pull request, to reduce the 3. Rebase, if necessary, before submitting your pull request, to reduce the
work we need to do to merge it. work we need to do to merge it.
4. Format your code according to the style guidelines below.
### Flot Style Guidelines ### ### Flot Style Guidelines ###
Flot follows the [jQuery Core Style Guidelines](http://docs.jquery.com/JQuery_Core_Style_Guidelines), Flot follows the [jQuery Core Style Guidelines](http://docs.jquery.com/JQuery_Core_Style_Guidelines),
...@@ -45,8 +44,8 @@ with the following updates and exceptions: ...@@ -45,8 +44,8 @@ with the following updates and exceptions:
#### Spacing #### #### Spacing ####
Do not add horizontal space around parameter lists, loop definitions, or Use four-space indents, no tabs. Do not add horizontal space around parameter
array/object indices. For example: lists, loop definitions, or array/object indices. For example:
```js ```js
for ( var i = 0; i < data.length; i++ ) { // This block is wrong! for ( var i = 0; i < data.length; i++ ) { // This block is wrong!
...@@ -64,8 +63,8 @@ array/object indices. For example: ...@@ -64,8 +63,8 @@ array/object indices. For example:
#### Comments #### #### Comments ####
Use // for all comments except the header at the top of a file or inline Use [jsDoc](http://usejsdoc.org) comments for all file and function headers.
include. Use // for all inline and block comments, regardless of length.
All // comment blocks should have an empty line above *and* below them. For All // comment blocks should have an empty line above *and* below them. For
example: example:
......
...@@ -14,11 +14,32 @@ ...@@ -14,11 +14,32 @@
### Changes ### ### Changes ###
- Added a table of contents to the API documentation. - Added a plot.destroy method as a way to free memory when emptying the plot
(patch by Brian Peiris, pull request #1064) placeholder and then re-using it for some other purpose.
(patch by Thodoris Greasidis, issue #1129, pull request #1130)
- Added a table of contents and PLUGINS link to the API documentation.
(patches by Brian Peiris, pull requests #1064 and #1127)
- Added Ruby code examples for time conversion.
(patch by Mike Połtyn, pull request #1182)
- Minor improvements to API.md and README.md.
(patches by Patrik Ragnarsson, pull requests #1085 and #1086)
- Updated inlined jQuery Resize to the latest version to fix errors.
(reported by Matthew Sabol and sloker, issues #997 ad #1081)
### Bug fixes ### ### Bug fixes ###
- Fixed an unexpected change in behavior that resulted in duplicate tick
labels when using a plugin, like flot-tickrotor, that overrode tick labels.
(patch by Mark Cote, pull request #1091)
- Fixed a regression from 0.7 where axis labels were given the wrong width,
causing them to overlap at certain scales and ignore the labelWidth option.
(patch by Benjamin Gram, pull request #1177)
- Fixed a bug where the second axis in an xaxes/yaxes array incorrectly had - Fixed a bug where the second axis in an xaxes/yaxes array incorrectly had
its 'innermost' property set to false or undefined, even if it was on the its 'innermost' property set to false or undefined, even if it was on the
other side of the plot from the first axis. This resulted in the axis bar other side of the plot from the first axis. This resulted in the axis bar
...@@ -26,6 +47,53 @@ ...@@ -26,6 +47,53 @@
when the grid had a left/right border width of zero. when the grid had a left/right border width of zero.
(reported by Teq1, fix researched by ryleyb, issue #1056) (reported by Teq1, fix researched by ryleyb, issue #1056)
- Fixed an error when using a placeholder that has no font-size property.
(patch by Craig Oldford, pull request #1135)
- Fixed a regression from 0.7 where nulls at the end of a series were ignored
for purposes of determing the range of the x-axis.
(reported by Munsifali Rashid, issue #1095)
- If a font size is provided, base the default lineHeight on that size rather
that the font size of the plot placeholder, which may be very different.
(reported by Daniel Hoffmann Bernardes, issue #1131, pull request #1199)
- Fix broken highlighting for right-aligned bars.
(reported by BeWiBu and Mihai Stanciu, issues #975 and #1093, with further
assistance by Eric Byers, pull request #1120)
- Prevent white circles from sometimes showing up inside of pie charts.
(reported by Pierre Dubois and Jack Klink, issues #1128 and #1073)
- Label formatting no longer breaks when a page contains multiple pie charts.
(reported by Brend Wanders, issue #1055)
- When using multiple axes on opposite sides of the plot, the innermost axis
coming later in the list no longer has its bar drawn incorrectly.
(reported by ryleyb, issue #1056)
- When removing series labels and redrawing the plot, the legend now updates
correctly even when using an external container.
(patch by Luis Silva, issue #1159, pull request #1160)
- The pie plugin no longer ignores the value of the left offset option.
(reported by melanker, issue #1136)
- Fixed a regression from 0.7, where extra padding was added unnecessarily to
sides of the plot where there was no last tick label.
(reported by sknob001, issue #1048, pull request #1200)
- Fixed incorrect tooltip behavior in the interacting example.
(patch by cleroux, issue #686, pull request #1074)
- Fixed an error in CSS color extraction with elements outside the DOM.
(patch by execjosh, pull request #1084)
- Fixed :not selector error when using jQuery without Sizzle.
(patch by Anthony Ryan, pull request #1180)
- Worked around a browser issue that caused bars to appear un-filled.
(reported by irbian, issue #915)
## Flot 0.8.1 ## ## Flot 0.8.1 ##
......
...@@ -107,4 +107,4 @@ examples/axes-time-zones/index.html. ...@@ -107,4 +107,4 @@ examples/axes-time-zones/index.html.
[excanvas]: http://code.google.com/p/explorercanvas/ [excanvas]: http://code.google.com/p/explorercanvas/
[flashcanvas]: http://code.google.com/p/flashcanvas/ [flashcanvas]: http://code.google.com/p/flashcanvas/
[timezone-js]: https://github.com/mde/timezone-js [timezone-js]: https://github.com/mde/timezone-js
[olson]: ftp://ftp.iana.org/tz/ [olson]: http://ftp.iana.org/time-zones
...@@ -42,20 +42,15 @@ ...@@ -42,20 +42,15 @@
} }
}); });
function showTooltip(x, y, contents) { $("<div id='tooltip'></div>").css({
$("<div id='tooltip'>" + contents + "</div>").css({
position: "absolute", position: "absolute",
display: "none", display: "none",
top: y + 5,
left: x + 5,
border: "1px solid #fdd", border: "1px solid #fdd",
padding: "2px", padding: "2px",
"background-color": "#fee", "background-color": "#fee",
opacity: 0.80 opacity: 0.80
}).appendTo("body").fadeIn(200); }).appendTo("body");
}
var previousPoint = null;
$("#placeholder").bind("plothover", function (event, pos, item) { $("#placeholder").bind("plothover", function (event, pos, item) {
if ($("#enablePosition:checked").length > 0) { if ($("#enablePosition:checked").length > 0) {
...@@ -65,20 +60,14 @@ ...@@ -65,20 +60,14 @@
if ($("#enableTooltip:checked").length > 0) { if ($("#enableTooltip:checked").length > 0) {
if (item) { if (item) {
if (previousPoint != item.dataIndex) {
previousPoint = item.dataIndex;
$("#tooltip").remove();
var x = item.datapoint[0].toFixed(2), var x = item.datapoint[0].toFixed(2),
y = item.datapoint[1].toFixed(2); y = item.datapoint[1].toFixed(2);
showTooltip(item.pageX, item.pageY, $("#tooltip").html(item.series.label + " of " + x + " = " + y)
item.series.label + " of " + x + " = " + y); .css({top: item.pageY+5, left: item.pageX+5})
} .fadeIn(200);
} else { } else {
$("#tooltip").remove(); $("#tooltip").hide();
previousPoint = null;
} }
} }
}); });
...@@ -98,7 +87,6 @@ ...@@ -98,7 +87,6 @@
</script> </script>
</head> </head>
<body> <body>
<div id="header"> <div id="header">
<h2>Interactivity</h2> <h2>Interactivity</h2>
</div> </div>
......
...@@ -775,6 +775,23 @@ Licensed under the MIT license. ...@@ -775,6 +775,23 @@ Licensed under the MIT license.
}; };
}; };
plot.shutdown = shutdown; plot.shutdown = shutdown;
plot.destroy = function () {
shutdown();
placeholder.removeData("plot").empty();
series = [];
options = null;
surface = null;
overlay = null;
eventHolder = null;
ctx = null;
octx = null;
xaxes = [];
yaxes = [];
hooks = null;
highlights = [];
plot = null;
};
plot.resize = function (width, height) { plot.resize = function (width, height) {
width = width || placeholder.width(); width = width || placeholder.width();
height = height || placeholder.height(); height = height || placeholder.height();
...@@ -860,17 +877,17 @@ Licensed under the MIT license. ...@@ -860,17 +877,17 @@ Licensed under the MIT license.
// since the rest of the code assumes that they exist. // since the rest of the code assumes that they exist.
var i, axisOptions, axisCount, var i, axisOptions, axisCount,
fontSize = placeholder.css("font-size"),
fontSizeDefault = fontSize ? +fontSize.replace("px", "") : 13,
fontDefaults = { fontDefaults = {
style: placeholder.css("font-style"), style: placeholder.css("font-style"),
size: Math.round(0.8 * (+placeholder.css("font-size").replace("px", "") || 13)), size: Math.round(0.8 * fontSizeDefault),
variant: placeholder.css("font-variant"), variant: placeholder.css("font-variant"),
weight: placeholder.css("font-weight"), weight: placeholder.css("font-weight"),
family: placeholder.css("font-family") family: placeholder.css("font-family")
}, },
markings; markings;
fontDefaults.lineHeight = fontDefaults.size * 1.15;
axisCount = options.xaxes.length || 1; axisCount = options.xaxes.length || 1;
for (i = 0; i < axisCount; ++i) { for (i = 0; i < axisCount; ++i) {
...@@ -893,15 +910,34 @@ Licensed under the MIT license. ...@@ -893,15 +910,34 @@ Licensed under the MIT license.
axisOptions = $.extend(true, {}, options.xaxis, axisOptions); axisOptions = $.extend(true, {}, options.xaxis, axisOptions);
options.xaxes[i] = axisOptions; options.xaxes[i] = axisOptions;
fontDefaults.color = axisOptions.color;
if (axisOptions.font) { if (axisOptions.font) {
axisOptions.font = $.extend({}, fontDefaults, axisOptions.font); axisOptions.font = $.extend({}, fontDefaults, axisOptions.font);
} }
if (axisOptions.tickFont || axisOptions.font) { if (axisOptions.tickFont || axisOptions.font) {
axisOptions.tickFont = $.extend({}, axisOptions.font || fontDefaults, axisOptions.tickFont); axisOptions.tickFont = $.extend({}, axisOptions.font || fontDefaults, axisOptions.tickFont);
if (!axisOptions.tickFont.color) {
axisOptions.tickFont.color = axisOptions.color;
}
if (!axisOptions.tickFont.lineHeight) {
axisOptions.tickFont.lineHeight = Math.round(axisOptions.tickFont.size * 1.15);
}
} }
if (axisOptions.label && (axisOptions.labelFont || axisOptions.font)) { if (axisOptions.label && (axisOptions.labelFont || axisOptions.font)) {
axisOptions.labelFont = $.extend({}, axisOptions.font || fontDefaults, axisOptions.labelFont); axisOptions.labelFont = $.extend({}, axisOptions.font || fontDefaults, axisOptions.labelFont);
if (!axisOptions.labelFont.color) {
axisOptions.labelFont.color = axisOptions.color;
}
if (!axisOptions.labelFont.lineHeight) {
axisOptions.labelFont.lineHeight = Math.round(axisOptions.labelFont.size * 1.15);
}
}
if (axisOptions.font) {
if (!axisOptions.font.color) {
axisOptions.font.color = axisOptions.color;
}
if (!axisOptions.font.lineHeight) {
axisOptions.font.lineHeight = Math.round(axisOptions.font.size * 1.15);
}
} }
} }
...@@ -927,15 +963,34 @@ Licensed under the MIT license. ...@@ -927,15 +963,34 @@ Licensed under the MIT license.
axisOptions = $.extend(true, {}, options.yaxis, axisOptions); axisOptions = $.extend(true, {}, options.yaxis, axisOptions);
options.yaxes[i] = axisOptions; options.yaxes[i] = axisOptions;
fontDefaults.color = axisOptions.color;
if (axisOptions.font) { if (axisOptions.font) {
axisOptions.font = $.extend({}, fontDefaults, axisOptions.font); axisOptions.font = $.extend({}, fontDefaults, axisOptions.font);
} }
if (axisOptions.tickFont || axisOptions.font) { if (axisOptions.tickFont || axisOptions.font) {
axisOptions.tickFont = $.extend({}, axisOptions.font || fontDefaults, axisOptions.tickFont); axisOptions.tickFont = $.extend({}, axisOptions.font || fontDefaults, axisOptions.tickFont);
if (!axisOptions.tickFont.color) {
axisOptions.tickFont.color = axisOptions.color;
}
if (!axisOptions.tickFont.lineHeight) {
axisOptions.tickFont.lineHeight = Math.round(axisOptions.tickFont.size * 1.15);
}
} }
if (axisOptions.label && (axisOptions.labelFont || axisOptions.font)) { if (axisOptions.label && (axisOptions.labelFont || axisOptions.font)) {
axisOptions.labelFont = $.extend({}, axisOptions.font || fontDefaults, axisOptions.labelFont); axisOptions.labelFont = $.extend({}, axisOptions.font || fontDefaults, axisOptions.labelFont);
if (!axisOptions.labelFont.color) {
axisOptions.labelFont.color = axisOptions.color;
}
if (!axisOptions.labelFont.lineHeight) {
axisOptions.labelFont.lineHeight = Math.round(axisOptions.labelFont.size * 1.15);
}
}
if (axisOptions.font) {
if (!axisOptions.font.color) {
axisOptions.font.color = axisOptions.color;
}
if (!axisOptions.font.lineHeight) {
axisOptions.font.lineHeight = Math.round(axisOptions.font.size * 1.15);
}
} }
} }
...@@ -1327,7 +1382,7 @@ Licensed under the MIT license. ...@@ -1327,7 +1382,7 @@ Licensed under the MIT license.
if (val != null) { if (val != null) {
f = format[m]; f = format[m];
// extract min/max info // extract min/max info
if (f.autoscale) { if (f.autoscale !== false) {
if (f.x) { if (f.x) {
updateAxis(s.xaxis, val, val); updateAxis(s.xaxis, val, val);
} }
...@@ -1401,11 +1456,8 @@ Licensed under the MIT license. ...@@ -1401,11 +1456,8 @@ Licensed under the MIT license.
case "right": case "right":
delta = -s.bars.barWidth; delta = -s.bars.barWidth;
break; break;
case "center":
delta = -s.bars.barWidth / 2;
break;
default: default:
throw new Error("Invalid bar alignment: " + s.bars.align); delta = -s.bars.barWidth / 2;
} }
if (s.bars.horizontal) { if (s.bars.horizontal) {
...@@ -1437,7 +1489,9 @@ Licensed under the MIT license. ...@@ -1437,7 +1489,9 @@ Licensed under the MIT license.
// from a previous plot in this container that we'll try to re-use. // from a previous plot in this container that we'll try to re-use.
placeholder.css("padding", 0) // padding messes up the positioning placeholder.css("padding", 0) // padding messes up the positioning
.children(":not(.flot-base,.flot-overlay)").remove(); .children().filter(function(){
return !$(this).hasClass("flot-overlay") && !$(this).hasClass('flot-base');
}).remove();
if (placeholder.css("position") === "static") { if (placeholder.css("position") === "static") {
placeholder.css("position", "relative"); // for positioning labels and overlay placeholder.css("position", "relative"); // for positioning labels and overlay
...@@ -1540,7 +1594,8 @@ Licensed under the MIT license. ...@@ -1540,7 +1594,8 @@ Licensed under the MIT license.
tickWidth = opts.tickWidth || opts.labelWidth || 0, tickWidth = opts.tickWidth || opts.labelWidth || 0,
tickHeight = opts.tickHeight || opts.labelHeight || 0, tickHeight = opts.tickHeight || opts.labelHeight || 0,
maxWidth = tickWidth || axis.direction === "x" ? Math.floor(surface.width / (ticks.length || 1)) : null, maxWidth = tickWidth || axis.direction === "x" ? Math.floor(surface.width / (ticks.length || 1)) : null,
layer = "flot-" + axis.direction + "-axis flot-" + axis.direction + axis.n + "-axis " + axis.direction + "Axis " + axis.direction + axis.n + "Axis", legacyStyles = axis.direction + "Axis " + axis.direction + axis.n + "Axis",
layer = "flot-" + axis.direction + "-axis flot-" + axis.direction + axis.n + "-axis " + legacyStyles,
font = opts.tickFont || "flot-tick-label tickLabel"; font = opts.tickFont || "flot-tick-label tickLabel";
for (var i = 0; i < ticks.length; ++i) { for (var i = 0; i < ticks.length; ++i) {
...@@ -1582,30 +1637,41 @@ Licensed under the MIT license. ...@@ -1582,30 +1637,41 @@ Licensed under the MIT license.
axisPosition = axisOptions.position, axisPosition = axisOptions.position,
axisMargin = options.grid.axisMargin, axisMargin = options.grid.axisMargin,
padding = options.grid.labelMargin, padding = options.grid.labelMargin,
all = axis.direction === "x" ? xaxes : yaxes, isXAxis = axis.direction === "x",
innermost; innermost = true,
outermost = true,
// Determine the margin around the axis first = true,
found = false;
var samePosition = $.grep(all, function(axis) {
return axis && axis.options.position === axisPosition && axis.reserveSpace; // Determine the axis's position in its direction and on its side
});
if ($.inArray(axis, samePosition) === samePosition.length - 1) { $.each(isXAxis ? xaxes : yaxes, function(i, a) {
axisMargin = 0; // outermost if (a && a.reserveSpace) {
if (a === axis) {
found = true;
} else if (a.options.position === axisPosition) {
if (found) {
outermost = false;
} else {
innermost = false;
}
} }
if (!found) {
first = false;
}
}
});
// Determine whether the axis is the first (innermost) on its side // The outermost axis on each side has no margin
innermost = $.inArray(axis, samePosition) === 0; if (outermost) {
axisMargin = 0;
}
// Determine the length of the tick marks // The ticks for the first axis in each direction stretch across
if (tickLength == null) { if (tickLength == null) {
if (innermost) { tickLength = first ? "full" : 5;
tickLength = "full";
} else {
tickLength = 5;
}
} }
if (!isNaN(+tickLength)) { if (!isNaN(+tickLength)) {
...@@ -1615,9 +1681,10 @@ Licensed under the MIT license. ...@@ -1615,9 +1681,10 @@ Licensed under the MIT license.
// Measure the dimensions of the axis label, if it has one // Measure the dimensions of the axis label, if it has one
if (axisOptions.label) { if (axisOptions.label) {
var layer = "flot-" + axis.direction + "-axis flot-" + axis.direction + axis.n + "-axis " + axis.direction + "Axis " + axis.direction + axis.n + "Axis", var legacyStyles = "Axis " + axis.direction + axis.n + "Axis",
layer = "flot-" + axis.direction + "-axis flot-" + axis.direction + axis.n + "-axis " + axis.direction + legacyStyles,
font = axisOptions.labelFont || "flot-axis-label axisLabels " + axis.direction + axis.n + "axisLabel", font = axisOptions.labelFont || "flot-axis-label axisLabels " + axis.direction + axis.n + "axisLabel",
angle = axis.direction === "x" ? 0 : axisOptions.position === "right" ? 90 : -90, angle = isXAxis ? 0 : axisOptions.position === "right" ? 90 : -90,
labelInfo = surface.getTextInfo(layer, axisOptions.label, font, angle); labelInfo = surface.getTextInfo(layer, axisOptions.label, font, angle);
contentWidth += labelInfo.width + axisOptions.labelPadding; contentWidth += labelInfo.width + axisOptions.labelPadding;
contentHeight += labelInfo.height + axisOptions.labelPadding; contentHeight += labelInfo.height + axisOptions.labelPadding;
...@@ -1625,7 +1692,7 @@ Licensed under the MIT license. ...@@ -1625,7 +1692,7 @@ Licensed under the MIT license.
// Compute the axis bounding box and update the plot bounds // Compute the axis bounding box and update the plot bounds
if (axis.direction === "x") { if (isXAxis) {
contentHeight += padding; contentHeight += padding;
if (axisPosition === "top") { if (axisPosition === "top") {
axis.box = { top: plotOffset.top + axisMargin, height: contentHeight }; axis.box = { top: plotOffset.top + axisMargin, height: contentHeight };
...@@ -1667,35 +1734,49 @@ Licensed under the MIT license. ...@@ -1667,35 +1734,49 @@ Licensed under the MIT license.
// possibly adjust plot offset to ensure everything stays // possibly adjust plot offset to ensure everything stays
// inside the canvas and isn't clipped off // inside the canvas and isn't clipped off
var minMargin = options.grid.minBorderMargin, var minMargin = options.grid.minBorderMargin;
margins = { x: 0, y: 0 }, i;
// check stuff from the plot (FIXME: this should just read // check stuff from the plot (FIXME: this should just read
// a value from the series, otherwise it's impossible to // a value from the series, otherwise it's impossible to
// customize) // customize)
if (minMargin == null) { if (minMargin == null) {
minMargin = 0; minMargin = 0;
for (i = 0; i < series.length; ++i) { for (var i = 0; i < series.length; ++i) {
minMargin = Math.max(minMargin, 2 * (series[i].points.radius + series[i].points.lineWidth/2)); minMargin = Math.max(minMargin, 2 * (series[i].points.radius + series[i].points.lineWidth/2));
} }
} }
margins.x = margins.y = Math.ceil(minMargin); var margins = {
left: minMargin,
right: minMargin,
top: minMargin,
bottom: minMargin
};
// check axis labels, note we don't check the actual // check axis labels, note we don't check the actual
// labels but instead use the overall width/height to not // labels but instead use the overall width/height to not
// jump as much around with replots // jump as much around with replots
$.each(allAxes(), function (_, axis) { $.each(allAxes(), function (_, axis) {
var dir = axis.direction; if (axis.reserveSpace && axis.ticks && axis.ticks.length) {
if (axis.reserveSpace) { var lastTick = axis.ticks[axis.ticks.length - 1];
margins[dir] = Math.ceil(Math.max(margins[dir], (dir === "x" ? axis.tickWidth : axis.tickHeight) / 2)); if (axis.direction === "x") {
margins.left = Math.max(margins.left, axis.tickWidth / 2);
if (lastTick.v <= axis.max) {
margins.right = Math.max(margins.right, axis.tickWidth / 2);
}
} else {
margins.bottom = Math.max(margins.bottom, axis.tickHeight / 2);
if (lastTick.v <= axis.max) {
margins.top = Math.max(margins.top, axis.tickHeight / 2);
}
}
} }
}); });
plotOffset.left = Math.max(margins.x, plotOffset.left); plotOffset.left = Math.ceil(Math.max(margins.left, plotOffset.left));
plotOffset.right = Math.max(margins.x, plotOffset.right); plotOffset.right = Math.ceil(Math.max(margins.right, plotOffset.right));
plotOffset.top = Math.max(margins.y, plotOffset.top); plotOffset.top = Math.ceil(Math.max(margins.top, plotOffset.top));
plotOffset.bottom = Math.max(margins.y, plotOffset.bottom); plotOffset.bottom = Math.ceil(Math.max(margins.bottom, plotOffset.bottom));
} }
function setupGrid() { function setupGrid() {
...@@ -2403,19 +2484,25 @@ Licensed under the MIT license. ...@@ -2403,19 +2484,25 @@ Licensed under the MIT license.
function drawAxisLabels() { function drawAxisLabels() {
$.each(allAxes(), function (_, axis) { $.each(allAxes(), function (_, axis) {
if (!axis.show || axis.ticks.length === 0) {
return;
}
var box = axis.box, var box = axis.box,
axisOptions = axis.options, axisOptions = axis.options,
layer = "flot-" + axis.direction + "-axis flot-" + axis.direction + axis.n + "-axis " + axis.direction + "Axis " + axis.direction + axis.n + "Axis", legacyStyles = axis.direction + "Axis " + axis.direction + axis.n + "Axis",
layer = "flot-" + axis.direction + "-axis flot-" + axis.direction + axis.n + "-axis " + legacyStyles,
labelFont = axisOptions.labelFont || "flot-axis-label axisLabels " + axis.direction + axis.n + "axisLabel", labelFont = axisOptions.labelFont || "flot-axis-label axisLabels " + axis.direction + axis.n + "axisLabel",
tickFont = axisOptions.tickFont || "flot-tick-label tickLabel", tickFont = axisOptions.tickFont || "flot-tick-label tickLabel",
tick, x, y, halign, valign; tick, x, y, halign, valign;
// Remove text before checking for axis.show and ticks.length;
// otherwise plugins, like flot-tickrotor, that draw their own
// tick labels will end up with both theirs and the defaults.
surface.removeText(layer); surface.removeText(layer);
if (!axis.show || axis.ticks.length === 0) {
return;
}
if (axisOptions.label) { if (axisOptions.label) {
if (axis.direction === "x") { if (axis.direction === "x") {
if (axisOptions.position === "top") { if (axisOptions.position === "top") {
...@@ -2824,7 +2911,7 @@ Licensed under the MIT license. ...@@ -2824,7 +2911,7 @@ Licensed under the MIT license.
ctx.restore(); ctx.restore();
} }
function drawBar(x, y, b, barLeft, barRight, offset, fillStyleCallback, axisx, axisy, c, horizontal, lineWidth) { function drawBar(x, y, b, barLeft, barRight, fillStyleCallback, axisx, axisy, c, horizontal, lineWidth) {
var left, right, bottom, top, var left, right, bottom, top,
drawLeft, drawRight, drawTop, drawBottom, drawLeft, drawRight, drawTop, drawBottom,
tmp; tmp;
...@@ -2899,13 +2986,8 @@ Licensed under the MIT license. ...@@ -2899,13 +2986,8 @@ Licensed under the MIT license.
// fill the bar // fill the bar
if (fillStyleCallback) { if (fillStyleCallback) {
c.beginPath();
c.moveTo(left, bottom);
c.lineTo(left, top);
c.lineTo(right, top);
c.lineTo(right, bottom);
c.fillStyle = fillStyleCallback(bottom, top); c.fillStyle = fillStyleCallback(bottom, top);
c.fill(); c.fillRect(left, top, right - left, bottom - top)
} }
// draw outline // draw outline
...@@ -2913,40 +2995,36 @@ Licensed under the MIT license. ...@@ -2913,40 +2995,36 @@ Licensed under the MIT license.
c.beginPath(); c.beginPath();
// FIXME: inline moveTo is buggy with excanvas // FIXME: inline moveTo is buggy with excanvas
c.moveTo(left, bottom + offset); c.moveTo(left, bottom);
if (drawLeft) { if (drawLeft)
c.lineTo(left, top + offset); c.lineTo(left, top);
} else { else
c.moveTo(left, top + offset); c.moveTo(left, top);
} if (drawTop)
if (drawTop) { c.lineTo(right, top);
c.lineTo(right, top + offset); else
} else { c.moveTo(right, top);
c.moveTo(right, top + offset); if (drawRight)
} c.lineTo(right, bottom);
if (drawRight) { else
c.lineTo(right, bottom + offset); c.moveTo(right, bottom);
} else { if (drawBottom)
c.moveTo(right, bottom + offset); c.lineTo(left, bottom);
} else
if (drawBottom) { c.moveTo(left, bottom);
c.lineTo(left, bottom + offset);
} else {
c.moveTo(left, bottom + offset);
}
c.stroke(); c.stroke();
} }
} }
function drawSeriesBars(series) { function drawSeriesBars(series) {
function plotBars(datapoints, barLeft, barRight, offset, fillStyleCallback, axisx, axisy) { function plotBars(datapoints, barLeft, barRight, fillStyleCallback, axisx, axisy) {
var points = datapoints.points, ps = datapoints.pointsize; var points = datapoints.points, ps = datapoints.pointsize;
for (var i = 0; i < points.length; i += ps) { for (var i = 0; i < points.length; i += ps) {
if (points[i] == null) { if (points[i] == null) {
continue; continue;
} }
drawBar(points[i], points[i + 1], points[i + 2], barLeft, barRight, offset, fillStyleCallback, axisx, axisy, ctx, series.bars.horizontal, series.bars.lineWidth); drawBar(points[i], points[i + 1], points[i + 2], barLeft, barRight, fillStyleCallback, axisx, axisy, ctx, series.bars.horizontal, series.bars.lineWidth);
} }
} }
...@@ -2966,15 +3044,12 @@ Licensed under the MIT license. ...@@ -2966,15 +3044,12 @@ Licensed under the MIT license.
case "right": case "right":
barLeft = -series.bars.barWidth; barLeft = -series.bars.barWidth;
break; break;
case "center":
barLeft = -series.bars.barWidth / 2;
break;
default: default:
throw new Error("Invalid bar alignment: " + series.bars.align); barLeft = -series.bars.barWidth / 2;
} }
var fillStyleCallback = series.bars.fill ? function (bottom, top) { return getFillStyle(series.bars, series.color, bottom, top); } : null; var fillStyleCallback = series.bars.fill ? function (bottom, top) { return getFillStyle(series.bars, series.color, bottom, top); } : null;
plotBars(series.datapoints, barLeft, barLeft + series.bars.barWidth, 0, fillStyleCallback, series.xaxis, series.yaxis); plotBars(series.datapoints, barLeft, barLeft + series.bars.barWidth, fillStyleCallback, series.xaxis, series.yaxis);
ctx.restore(); ctx.restore();
} }
...@@ -2996,7 +3071,11 @@ Licensed under the MIT license. ...@@ -2996,7 +3071,11 @@ Licensed under the MIT license.
function insertLegend() { function insertLegend() {
if (options.legend.container != null) {
$(options.legend.container).html("");
} else {
placeholder.find(".legend").remove(); placeholder.find(".legend").remove();
}
if (!options.legend.show) { if (!options.legend.show) {
return; return;
...@@ -3198,7 +3277,20 @@ Licensed under the MIT license. ...@@ -3198,7 +3277,20 @@ Licensed under the MIT license.
} }
if (s.bars.show && !item) { // no other point can be nearby if (s.bars.show && !item) { // no other point can be nearby
var barLeft = s.bars.align === "left" ? 0 : -s.bars.barWidth/2,
var barLeft, barRight;
switch (s.bars.align) {
case "left":
barLeft = 0;
break;
case "right":
barLeft = -s.bars.barWidth;
break;
default:
barLeft = -s.bars.barWidth / 2;
}
barRight = barLeft + s.bars.barWidth; barRight = barLeft + s.bars.barWidth;
for (j = 0; j < points.length; j += ps) { for (j = 0; j < points.length; j += ps) {
...@@ -3417,13 +3509,24 @@ Licensed under the MIT license. ...@@ -3417,13 +3509,24 @@ Licensed under the MIT license.
function drawBarHighlight(series, point) { function drawBarHighlight(series, point) {
var highlightColor = (typeof series.highlightColor === "string") ? series.highlightColor : $.color.parse(series.color).scale("a", 0.5).toString(), var highlightColor = (typeof series.highlightColor === "string") ? series.highlightColor : $.color.parse(series.color).scale("a", 0.5).toString(),
fillStyle = highlightColor, fillStyle = highlightColor,
barLeft = series.bars.align === "left" ? 0 : -series.bars.barWidth/2; barLeft;
switch (series.bars.align) {
case "left":
barLeft = 0;
break;
case "right":
barLeft = -series.bars.barWidth;
break;
default:
barLeft = -series.bars.barWidth / 2;
}
octx.lineWidth = series.bars.lineWidth; octx.lineWidth = series.bars.lineWidth;
octx.strokeStyle = highlightColor; octx.strokeStyle = highlightColor;
drawBar(point[0], point[1], point[2] || 0, barLeft, barLeft + series.bars.barWidth, drawBar(point[0], point[1], point[2] || 0, barLeft, barLeft + series.bars.barWidth,
0, function () { return fillStyle; }, series.xaxis, series.yaxis, octx, series.bars.horizontal, series.bars.lineWidth); function () { return fillStyle; }, series.xaxis, series.yaxis, octx, series.bars.horizontal, series.bars.lineWidth);
} }
function getColorOrGradient(spec, bottom, top, defaultColor) { function getColorOrGradient(spec, bottom, top, defaultColor) {
......
...@@ -69,6 +69,7 @@ More detail and specific examples can be found in the included HTML file. ...@@ -69,6 +69,7 @@ More detail and specific examples can be found in the included HTML file.
var canvas = null, var canvas = null,
target = null, target = null,
options = null,
maxRadius = null, maxRadius = null,
centerLeft = null, centerLeft = null,
centerTop = null, centerTop = null,
...@@ -294,15 +295,14 @@ More detail and specific examples can be found in the included HTML file. ...@@ -294,15 +295,14 @@ More detail and specific examples can be found in the included HTML file.
} else { } else {
centerLeft -= legendWidth / 2; centerLeft -= legendWidth / 2;
} }
} else {
centerLeft += options.series.pie.offset.left;
}
if (centerLeft < maxRadius) { if (centerLeft < maxRadius) {
centerLeft = maxRadius; centerLeft = maxRadius;
} else if (centerLeft > canvasWidth - maxRadius) { } else if (centerLeft > canvasWidth - maxRadius) {
centerLeft = canvasWidth - maxRadius; centerLeft = canvasWidth - maxRadius;
} }
} else {
centerLeft += options.series.pie.offset.left;
}
var slices = plot.getData(), var slices = plot.getData(),
attempts = 0; attempts = 0;
......
...@@ -76,15 +76,16 @@ ...@@ -76,15 +76,16 @@
// if it's "transparent" // if it's "transparent"
$.color.extract = function (elem, css) { $.color.extract = function (elem, css) {
var c; var c;
do { do {
c = elem.css(css).toLowerCase(); c = elem.css(css).toLowerCase();
// keep going until we find an element that has color, or // keep going until we find an element that has color, or
// we hit the body // we hit the body or root (have no parent)
if (c !== "" && c !== "transparent") { if (c !== "" && c !== "transparent") {
break; break;
} }
elem = elem.parent(); elem = elem.parent();
} while (!$.nodeName(elem.get(0), "body")); } while (elem.length && !$.nodeName(elem.get(0), "body"));
// catch Safari's way of signalling transparent // catch Safari's way of signalling transparent
if (c === "rgba(0, 0, 0, 0)") { if (c === "rgba(0, 0, 0, 0)") {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment