About
RGraph is a JavaScript charts library based on
HTML5 SVG and canvas. RGraph is mature (over 15 years
old) and has a wealth of features making it an ideal
choice to use for showing charts on your website.
Download
Get the latest version of RGraph (version 6.18, 1st June 2024) from
the download page. You can read the changelog here. There's also older versions available,
minified files and links to cdnjs.com hosted libraries.
License
RGraph can be used for free under the GPL or if
that doesn't suit your situation there's an
inexpensive (£129) commercial license available.How do I find out which version of RGraph I have installed?
Posted by Al at 17:45 on Friday 10th June 2022 [link]
I have what looks like a minified version of some RGraph libraries - but how do I find out which version I'm on?
Posted by Richard at 18:05 on Friday 10th June 2022 [link]
Hmmm, that's a toughie. The release script adds a comment to the top of each file stating the version number - but minification would remove it.
Send me a copy of the script (send it to richardheyes at Googles popular webmail service (!) ) and I'll see if I can identify it.
Send me a copy of the script (send it to richardheyes at Googles popular webmail service (!) ) and I'll see if I can identify it.
Posted by Al at 20:03 on Friday 10th June 2022 [link]
It would be good to have a getVersion() function, but for now ... RGraph.bar.js reads:
RGraph=window.RGraph||{isrgraph:true,isRGraph:true,rgraph:true};RGraph.Bar=function(conf)
{var id=conf.id,canvas=document.getElementById(id),data=conf.data;this.id=id;this.canvas=canvas;this.context=this.canvas.getContext('2d');this.canvas.__object__=this;this.type='bar';this.max=0;this.stackedOrGrouped=false;this.isRGraph=true;this.isrgraph=true;this.rgraph=true;this.uid=RGraph.createUID();this.canvas.uid=this.canvas.uid?this.canvas.uid:RGraph.createUID();this.colorsParsed=false;this.original_colors=[];this.cachedBackgroundCanvas=null;this.firstDraw=true;this.properties={backgroundBarsCount:null,backgroundBarsColor1:'rgba(0,0,0,0)',backgroundBarsColor2:'rgba(0,0,0,0)',backgroundGrid:true,backgroundGridColor:'#ddd',backgroundGridLinewidth:1,backgroundGridHsize:20,backgroundGridVsize:20,backgroundGridVlines:true,backgroundGridHlines:true,backgroundGridBorder:true,backgroundGridAutofit:true,backgroundGridAutofitAlign:true,backgroundGridHlinesCount:5,backgroundGridDashed:false,backgroundGridDotted:false,backgroundImage:null,backgroundImageStretch:true,backgroundImageX:null,backgroundImageY:null,backgroundImageW:null,backgroundImageH:null,backgroundImageAlign:null,backgroundColor:null,backgroundHbars:null,marginTop:35,marginBottom:35,marginLeft:35,marginRight:35,marginInner:5,marginInnerGrouped:1,labelsIngraph:null,labelsIngraphFont:null,labelsIngraphSize:null,labelsIngraphColor:null,labelsIngraphBold:null,labelsIngraphItalic:null,labelsIngraphOffsetx:0,labelsIngraphOffsety:0,labelsAbove:false,labelsAboveDecimals:0,labelsAboveSize:null,labelsAboveColor:null,labelsAboveBold:null,labelsAboveItalic:null,labelsAboveFont:null,labelsAbovePoint:'.',labelsAboveThousand:',',labelsAboveBackground:'rgba(0,0,0,0)',labelsAboveAngle:null,labelsAboveOffset:null,labelsAboveOffsetx:0,labelsAboveOffsety:0,labelsAboveUnitsPre:'',labelsAboveUnitsPost:'',yaxis:true,yaxisLinewidth:1,yaxisColor:'black',yaxisTickmarks:true,yaxisTickmarksCount:null,yaxisTickmarksLastTop:null,yaxisTickmarksLastBottom:null,yaxisTickmarksLength:3,yaxisScale:true,yaxisScaleMin:0,yaxisScaleMax:null,yaxisScaleUnitsPre:'',yaxisScaleUnitsPost:'',yaxisScaleDecimals:0,yaxisScalePoint:'.',yaxisScaleThousand:',',yaxisScaleRound:false,yaxisScaleFormatter:null,yaxisLabelsSpecific:null,yaxisLabelsCount:5,yaxisLabelsOffsetx:0,yaxisLabelsOffsety:0,yaxisLabelsHalign:null,yaxisLabelsValign:null,yaxisLabelsFont:null,yaxisLabelsSize:null,yaxisLabelsColor:null,yaxisLabelsBold:null,yaxisLabelsItalic:null,yaxisLabelsPosition:'edge',yaxisPosition:'left',yaxisTitle:'',yaxisTitleAccessible:null,yaxisTitleBold:null,yaxisTitleSize:null,yaxisTitleFont:null,yaxisTitleColor:null,yaxisTitleItalic:null,yaxisTitlePos:null,yaxisTitleX:null,yaxisTitleY:null,yaxisTitleOffsetx:0,yaxisTitleOffsety:0,yaxisTitleHalign:null,yaxisTitleValign:null,yaxisTitleAccessible:null,xaxis:true,xaxisLinewidth:1,xaxisColor:'black',xaxisTickmarks:true,xaxisTickmarksLength:3,xaxisTickmarksLastLeft:null,xaxisTickmarksLastRight:null,xaxisTickmarksCount:null,xaxisLabels:null,xaxisLabelsSize:null,xaxisLabelsFont:null,xaxisLabelsItalic:null,xaxisLabelsBold:null,xaxisLabelsColor:null,xaxisLabelsFormattedDecimals:0,xaxisLabelsFormattedPoint:'.',xaxisLabelsFormattedThousand:',',xaxisLabelsFormattedUnitsPre:'',xaxisLabelsFormattedUnitsPost:'',xaxisLabelsOffsetx:0,xaxisLabelsOffsety:0,xaxisLabelsHalign:null,xaxisLabelsValign:null,xaxisLabelsPosition:'section',xaxisLabelsSpecificAlign:'left',xaxisPosition:'bottom',xaxisLabelsAngle:0,xaxisTitle:'',xaxisTitleBold:null,xaxisTitleSize:null,xaxisTitleFont:null,xaxisTitleColor:null,xaxisTitleItalic:null,xaxisTitlePos:null,xaxisTitleOffsetx:0,xaxisTitleOffsety:0,xaxisTitleX:null,xaxisTitleY:null,xaxisTitleHalign:null,xaxisTitleValign:null,textItalic:false,textBold:false,textColor:'black',textSize:12,textFont:'Arial, Verdana, sans-serif',textAccessible:true,textAccessibleOverflow:'visible',textAccessiblePointerevents:false,title:'',titleX:null,titleY:null,titleHalign:null,titleValign:null,titleBackground:null,titleHpos:null,titleVpos:null,titleFont:null,titleSize:null,titleColor:null,titleBold:null,titleItalic:null,titleOffsetx:0,titleOffsety:0,colorsStroke:'rgba(0,0,0,0)',colors:['red','#0f0','blue','pink','orange','cyan','black','white','green','magenta'],colorsSequential:false,colorsReverse:false,grouping:'grouped',variant:'bar',variantSketchVerticals:true,variantThreedXaxis:true,variantThreedYaxis:true,variantThreedAngle:0.1,variantThreedOffsetx:10,variantThreedOffsety:5,shadow:false,shadowColor:'#aaa',shadowOffsetx:0,shadowOffsety:0,shadowBlur:15,tooltips:null,tooltipsEffect:'slide',tooltipsCssClass:'RGraph_tooltip',tooltipsCss:null,tooltipsEvent:'onclick',tooltipsHighlight:true,tooltipsHotspotXonly:false,tooltipsFormattedThousand:',',tooltipsFormattedPoint:'.',tooltipsFormattedDecimals:0,tooltipsFormattedUnitsPre:'',tooltipsFormattedUnitsPost:'',tooltipsFormattedKeyColors:null,tooltipsFormattedKeyColorsShape:'square',tooltipsFormattedKeyLabels:[],tooltipsFormattedListType:'ul',tooltipsFormattedListItems:null,tooltipsFormattedTableHeaders:null,tooltipsFormattedTableData:null,tooltipsPointer:true,tooltipsPositionStatic:true,highlightStroke:'rgba(0,0,0,0)',highlightFill:'rgba(255,255,255,0.7)',key:null,keyBackground:'white',keyPosition:'graph',keyShadow:false,keyShadowColor:'#666',keyShadowBlur:3,keyShadowOffsetx:2,keyShadowOffsety:2,keyPositionMarginBoxed:false,keyPositionX:null,keyPositionY:null,keyInteractive:false,keyInteractiveHighlightChartStroke:'black',keyInteractiveHighlightChartFill:'rgba(255,255,255,0.7)',keyInteractiveHighlightLabel:'rgba(255,0,0,0.2)',keyHalign:'right',keyColorShape:'square',keyRounded:true,keyLinewidth:1,keyColors:null,keyLabelsColor:null,keyLabelsSize:null,keyLabelsFont:null,keyLabelsBold:null,keyLabelsItalic:null,keyLabelsOffsetx:0,keyLabelsOffsety:0,contextmenu:null,crosshairs:false,crosshairsColor:'#333',crosshairsHline:true,crosshairsVline:true,linewidth:1,annotatable:false,annotatableLinewidth:1,annotatableColor:'black',adjustable:false,adjustableOnly:null,beveled:false,errorbars:false,errorbarsColor:'black',errorbarsCapped:true,errorbarsCappedWidth:14,errorbarsLinewidth:1,combinedEffect:null,combinedEffectOptions:null,combinedEffectCallback:null,corners:'square',cornersRoundRadius:10,clearto:'rgba(0,0,0,0)'}
if(!this.canvas){alert('[BAR] No canvas support');return;}
data=RGraph.stringsToNumbers(data);for(var i=0;i<data.length;++i){if(typeof data[i]==='object'&&!RGraph.isNull(data[i])){this.stackedOrGrouped=true;}}
var linear_data=RGraph.arrayLinearize(data);for(var i=0;i<linear_data.length;++i){this['$'+i]={};}
this.data=data;this.original_data=RGraph.arrayClone(data);this.coords=[];this.coords2=[];this.coordsText=[];this.data_arr=RGraph.arrayLinearize(this.data);var properties=this.properties;this.path=RGraph.pathObjectFunction;if(RGraph.Effects&&typeof RGraph.Effects.decorate==='function'){RGraph.Effects.decorate(this);}
this.responsive=RGraph.responsive;this.set=function(name)
{var value=typeof arguments[1]==='undefined'?null:arguments[1];if(name==='bevelled'){name='beveled';}
if(arguments.length===1&&typeof arguments[0]==='object'){for(i in arguments[0]){if(typeof i==='string'){this.set(i,arguments[0][i]);}}
return this;}
properties[name]=value;return this;};this.get=function(name)
{return properties[name];};this.draw=function()
{RGraph.fireCustomEvent(this,'onbeforedraw');if(!this.canvas.__rgraph_aa_translated__){this.context.translate(0.5,0.5);this.canvas.__rgraph_aa_translated__=true;}
if(typeof properties.backgroundImage==='string'){RGraph.drawBackgroundImage(this);}
if(properties.variant==='3d'){if(properties.textAccessible){}else{this.context.setTransform(1,properties.variantThreedAngle,0,1,0.5,0.5);}}
if(!this.colorsParsed){this.parseColors();this.colorsParsed=true;}
this.marginLeft=properties.marginLeft;this.marginRight=properties.marginRight;this.marginTop=properties.marginTop;this.marginBottom=properties.marginBottom;if((properties.variant=='pyramid'||properties.variant=='dot')&&typeof properties.tooltips=='object'&&properties.tooltips&&properties.tooltips.length>0){alert('[BAR] ('+this.id+') Sorry, tooltips are not supported with dot or pyramid charts');}
this.coords=[];this.coords2=[];this.coordsText=[];this.max=0;this.grapharea=this.canvas.height-this.marginTop-this.marginBottom;this.halfgrapharea=this.grapharea/2;this.halfTextHeight=properties.textSize/2;RGraph.Background.draw(this);this.drawbars();this.drawAxes();this.drawLabels();if(properties.beveled||properties.beveled){this.drawBevel();}
if(properties.key&&properties.key.length){RGraph.drawKey(this,properties.key,properties.colors);}
if(properties.contextmenu){RGraph.showContext(this);}
if(properties.errorbars){this.drawErrorbars();}
if(properties.labelsIngraph){RGraph.drawInGraphLabels(this);}
RGraph.installEventListeners(this);if(this.firstDraw){this.firstDraw=false;RGraph.fireCustomEvent(this,'onfirstdraw');this.firstDrawFunc();}
RGraph.fireCustomEvent(this,'ondraw');return this;};this.exec=function(func)
{func(this);return this;};this.drawAxes=function()
{if(RGraph.ISSAFARI==-1){this.context.lineCap='square';}
if(properties.xaxisLabels&&properties.xaxisLabels.length){if(typeof properties.xaxisLabels==='string'){properties.xaxisLabels=RGraph.arrayPad({array:[],length:this.data.length,value:properties.xaxisLabels});}
for(var i=0;i<properties.xaxisLabels.length;++i){properties.xaxisLabels[i]=RGraph.labelSubstitution({object:this,text:properties.xaxisLabels[i],index:i,value:this.data[i],decimals:properties.xaxisLabelsFormattedDecimals||0,unitsPre:properties.xaxisLabelsFormattedUnitsPre||'',unitsPost:properties.xaxisLabelsFormattedUnitsPost||'',thousand:properties.xaxisLabelsFormattedThousand||',',point:properties.xaxisLabelsFormattedPoint||'.'});}}
RGraph.drawXAxis(this);RGraph.drawYAxis(this);};this.drawbars=function()
{this.context.lineWidth=properties.linewidth;this.context.strokeStyle=properties.colorsStroke;this.context.fillStyle=properties.colors[0];var prevX=0,prevY=0,decimals=properties.yaxisScaleDecimals;if(properties.yaxisScaleMax){this.scale2=RGraph.getScale({object:this,options:{'scale.max':properties.yaxisScaleMax,'scale.strict':properties.yaxisScaleRound?false:true,'scale.min':properties.yaxisScaleMin,'scale.thousand':properties.yaxisScaleThousand,'scale.point':properties.yaxisScalePoint,'scale.decimals':properties.yaxisScaleDecimals,'scale.labels.count':properties.yaxisLabelsCount,'scale.round':properties.yaxisScaleRound,'scale.units.pre':properties.yaxisScaleUnitsPre,'scale.units.post':properties.yaxisScaleUnitsPost,'scale.formatter':properties.yaxisScaleFormatter}});}else{var errorbars=properties.errorbars;if(typeof errorbars==='number'){var value=errorbars;properties.errorbars=[];for(var i=0;i<this.data.length;++i){if(typeof this.data[i]==='number'){properties.errorbars.push([value,null]);}else if(typeof this.data[i]==='object'&&!RGraph.isNull(this.data[i])){for(var j=0;j<this.data[i].length;++j){properties.errorbars.push([value,null]);}}}
errorbars=properties.errorbars;}
for(i=0;i<this.data.length;++i){if(typeof this.data[i]=='object'){var value=properties.grouping==='grouped'?Number(RGraph.arrayMax(this.data[i],true)):Number(RGraph.arraySum(this.data[i]));}else{var value=Number(this.data[i]);}
this.max=Math.max(Math.abs(this.max),Math.abs(value)+
Number((typeof properties.errorbars==='object'&&typeof properties.errorbars[i]==='object'&&!RGraph.isNull(properties.errorbars[i])&&typeof properties.errorbars[i][0]==='number')?properties.errorbars[i][0]:0));}
this.scale2=RGraph.getScale({object:this,options:{'scale.max':this.max,'scale.min':properties.yaxisScaleMin,'scale.thousand':properties.yaxisScaleThousand,'scale.point':properties.yaxisScalePoint,'scale.decimals':properties.yaxisScaleDecimals,'scale.labels.count':properties.yaxisLabelsCount,'scale.round':properties.yaxisScaleRound,'scale.units.pre':properties.yaxisScaleUnitsPre,'scale.units.post':properties.yaxisScaleUnitsPost,'scale.formatter':properties.yaxisScaleFormatter}});this.max=this.scale2.max;}
if(properties.adjustable&&!properties.yaxisScaleMax){this.set('yaxisScaleMax',this.scale2.max);}
if(properties.backgroundHbars&&properties.backgroundHbars.length>0){RGraph.drawBars(this);}
var variant=properties.variant;if(variant==='3d'){RGraph.draw3DAxes(this);}
var xaxispos=properties.xaxisPosition,width=(this.canvas.width-this.marginLeft-this.marginRight)/this.data.length,orig_height=height,hmargin=properties.marginInner,shadow=properties.shadow,shadowColor=properties.shadowColor,shadowBlur=properties.shadowBlur,shadowOffsetX=properties.shadowOffsetx,shadowOffsetY=properties.shadowOffsety,strokeStyle=properties.colorsStroke,colors=properties.colors,sequentialColorIndex=0
var height;for(i=0,len=this.data.length;i<len;i+=1){if(RGraph.arraySum(this.data[i])<0){var height=(RGraph.arraySum(this.data[i])+this.scale2.min)/(this.scale2.max-this.scale2.min);}else{var height=(RGraph.arraySum(this.data[i])-this.scale2.min)/(this.scale2.max-this.scale2.min);}
height*=Math.abs(this.getYCoord(this.scale2.max)-this.getYCoord(this.scale2.min));var x=(i*width)+this.marginLeft;var y=xaxispos=='center'?((this.canvas.height-this.marginTop-this.marginBottom)/2)+this.marginTop-height:this.canvas.height-height-this.marginBottom;if(xaxispos=='top'){y=this.marginTop;}
if(height<0){y+=height;height=Math.abs(height);}
if(shadow){this.context.shadowColor=shadowColor;this.context.shadowBlur=shadowBlur;this.context.shadowOffsetX=shadowOffsetX;this.context.shadowOffsetY=shadowOffsetY;}
this.context.beginPath();if(typeof this.data[i]=='number'){if(xaxispos==='bottom'&&properties.yaxisScaleMin<0){if(this.data[i]>=0){height=Math.abs(this.getYCoord(0)-this.getYCoord(this.data[i]));}else{y=this.getYCoord(0);height=Math.abs(this.getYCoord(0)-this.getYCoord(this.data[i]));}}
var barWidth=width-(2*hmargin);if(barWidth<0){alert('[RGRAPH] Warning: you have a negative bar width. This may be caused by the marginInner being too high or the width of the canvas not being sufficient.');}
this.context.strokeStyle=strokeStyle;this.context.fillStyle=colors[0];if(properties.colorsSequential){this.context.fillStyle=colors[i];}
if(variant=='sketch'){this.context.lineCap='round';var sketchOffset=3;this.context.beginPath();this.context.strokeStyle=colors[0];if(properties.colorsSequential){this.context.strokeStyle=colors[i];}
this.context.moveTo(x+hmargin+2,y+height-2);this.context.lineTo(x+hmargin-1,y-4);this.context.moveTo(x+hmargin-3,y+ -2+(this.data[i]<0?height:0));this.context.quadraticCurveTo(x+hmargin+((width-hmargin-hmargin)/4),y+0+(this.data[i]<0?height:0)+(this.data[i]>0?10:-10),x+hmargin+width+ -1-hmargin-hmargin,y+0+(this.data[i]<0?height:0));this.context.moveTo(x+hmargin+width-5-hmargin-hmargin,y-5);this.context.lineTo(x+hmargin+width-3-hmargin-hmargin,y+height-3);if(properties.variantSketchVerticals){for(var r=0.2;r<=0.8;r+=0.2){this.context.moveTo(x+hmargin+((width-hmargin-hmargin)*r),y-1);this.context.lineTo(x+hmargin+((width-hmargin-hmargin)*r),y+height+(r==0.2?1:-2));}}
this.context.stroke();}else if(variant=='bar'||variant=='3d'||variant=='glass'||variant=='bevel'){if(variant=='glass'){RGraph.roundedRect({context:this.context,x:x+hmargin,y:y,width:barWidth,height:height,radius:5,roundtl:this.data[i]>0,roundtr:this.data[i]>0,roundbl:this.data[i]<0,roundbr:this.data[i]<0});this.context.stroke();this.context.fill();}else{if(properties.corners==='round'){this.context.beginPath();this.context.lineCap='miter';this.context.lineJoin='square';this.roundedCornersRect(x+hmargin,y,barWidth,height);(x+hmargin,y,barWidth,height);this.context.stroke();this.context.fill();}else{this.context.beginPath();this.context.lineJoin='miter';this.context.lineCap='square';this.context.rect(x+hmargin,y,barWidth,height);this.context.stroke();this.context.fill();}}
if(variant=='3d'){var prevStrokeStyle=this.context.strokeStyle;var prevFillStyle=this.context.fillStyle;if(this.data[i]>=0){this.context.beginPath();this.context.moveTo(x+hmargin,y);this.context.lineTo(x+hmargin+properties.variantThreedOffsetx,y-properties.variantThreedOffsety);this.context.lineTo(x+hmargin+properties.variantThreedOffsetx+barWidth,y-properties.variantThreedOffsety);this.context.lineTo(x+hmargin+barWidth,y);this.context.closePath();this.context.stroke();this.context.fill();}
this.context.beginPath();this.context.moveTo(x+hmargin+barWidth,y);this.context.lineTo(x+hmargin+barWidth+properties.variantThreedOffsetx,this.data[i]<0&&xaxispos==='bottom'?this.getYCoord(0):(this.data[i]<0&&(y-properties.variantThreedOffsety)<(this.marginTop+this.halfgrapharea)?(this.marginTop+this.halfgrapharea):(y-properties.variantThreedOffsety)));this.context.lineTo(x+hmargin+barWidth+properties.variantThreedOffsetx,this.data[i]<0&&(y-properties.variantThreedOffsety+height)<(this.marginTop+this.getYCoord(0))?this.getYCoord(this.data[i])-properties.variantThreedOffsety:(this.data[i]>0?y-properties.variantThreedOffsety+height:Math.min(y-properties.variantThreedOffsety+height,this.canvas.height-this.marginBottom)));this.context.lineTo(x+hmargin+barWidth,y+height);this.context.closePath();this.context.stroke();this.context.fill();if(this.data[i]>0){this.context.beginPath();this.context.fillStyle='rgba(255,255,255,0.5)';this.context.moveTo(x+hmargin,y);this.context.lineTo(x+hmargin+properties.variantThreedOffsetx,y-properties.variantThreedOffsety);this.context.lineTo(x+hmargin+properties.variantThreedOffsetx+barWidth,y-properties.variantThreedOffsety);this.context.lineTo(x+hmargin+barWidth,y);this.context.lineTo(x+hmargin,y);this.context.closePath();this.context.stroke();this.context.fill();}
this.context.beginPath();this.context.fillStyle='rgba(0,0,0,0.4)';this.context.moveTo(x+hmargin+barWidth,y);this.context.lineTo(x+hmargin+barWidth+properties.variantThreedOffsetx,this.data[i]<0&&xaxispos==='bottom'?this.getYCoord(0):(this.data[i]<0&&(y-properties.variantThreedOffsety)<(this.marginTop+this.halfgrapharea)?(this.marginTop+this.halfgrapharea):y-properties.variantThreedOffsety));this.context.lineTo(x+hmargin+barWidth+properties.variantThreedOffsetx,this.data[i]<0&&(y-properties.variantThreedOffsety+height)<this.getYCoord(0)?this.getYCoord(0):this.data[i]>0?y-properties.variantThreedOffsety+height:Math.min(y-properties.variantThreedOffsety+height,this.canvas.height-this.marginBottom));this.context.lineTo(x+hmargin+barWidth,y+height);this.context.lineTo(x+hmargin+barWidth,y);this.context.closePath();this.context.stroke();this.context.fill();this.context.strokeStyle=prevStrokeStyle;this.context.fillStyle=prevFillStyle;}else if(variant=='glass'){var grad=this.context.createLinearGradient(x+hmargin,y,x+hmargin+(barWidth/2),y);grad.addColorStop(0,'rgba(255,255,255,0.9)');grad.addColorStop(1,'rgba(255,255,255,0.5)');this.context.beginPath();this.context.fillStyle=grad;this.context.rect(x+hmargin+3,y+(this.data[i]>0?3:0),(barWidth/2)-2,height-2);this.context.fill();}}else if(variant=='dot'){this.context.beginPath();this.context.strokeStyle=this.properties.colors[0];this.context.moveTo(x+(width/2),y);this.context.lineTo(x+(width/2),y+height);this.context.stroke();this.context.beginPath();this.context.fillStyle=this.properties.colors[i];this.context.arc(x+(width/2),y+(this.data[i]>0?0:height),2,0,6.28,0);this.context.fillStyle=properties.colors[0];if(properties.colorsSequential){this.context.fillStyle=colors[i];}
this.context.stroke();this.context.fill();}else{alert('[BAR] Warning! Unknown variant: '+variant);}
this.coords.push([x+hmargin,y,width-(2*hmargin),height]);if(typeof this.coords2[i]=='undefined'){this.coords2[i]=[];}
this.coords2[i].push([x+hmargin,y,width-(2*hmargin),height]);}else if(this.data[i]&&typeof this.data[i]=='object'&&properties.grouping=='stacked'){if(this.scale2.min){alert("[ERROR] Stacked Bar charts with a Y min are not supported");}
var barWidth=width-(2*hmargin);var redrawCoords=[];var startY=0;var dataset=this.data[i];if(barWidth<0){alert('[RGRAPH] Warning: you have a negative bar width. This may be caused by the marginInner being too high or the width of the canvas not being sufficient.');}
for(j=0;j<dataset.length;++j){if(xaxispos=='center'){alert("[BAR] It's pointless having the X axis position at the center on a stacked bar chart.");return;}
if(this.data[i][j]<0){alert('[BAR] Negative values are not permitted with a stacked bar chart. Try a grouped one instead.');return;}
this.context.strokeStyle=strokeStyle
this.context.fillStyle=colors[j];if(properties.colorsReverse){this.context.fillStyle=colors[this.data[i].length-j-1];}
if(properties.colorsSequential&&colors[sequentialColorIndex]){this.context.fillStyle=colors[sequentialColorIndex++];}else if(properties.colorsSequential){this.context.fillStyle=colors[sequentialColorIndex-1];}
var height=(dataset[j]/this.scale2.max)*(this.canvas.height-this.marginTop-this.marginBottom);if(xaxispos=='center'){height/=2;}
var totalHeight=(RGraph.arraySum(dataset)/this.scale2.max)*(this.canvas.height-hmargin-this.marginTop-this.marginBottom);this.coords.push([x+hmargin,y,width-(2*hmargin),height]);if(typeof this.coords2[i]=='undefined'){this.coords2[i]=[];}
this.coords2[i].push([x+hmargin,y,width-(2*hmargin),height]);if(height>0){if(j===0&&properties.corners==='round'){this.context.beginPath();this.context.lineCap='miter';this.context.lineJoin='square';this.roundedCornersRect(x+hmargin,y,width-(2*hmargin),height);this.context.stroke();this.context.fill();}else{this.path('b lj % lc % r % % % % s % f %','miter','square',x+hmargin,y,width-(2*hmargin),height,this.context.strokeStyle,this.context.fillStyle);}}
if(j==0){var startY=y;var startX=x;}
if(shadow){redrawCoords.push([x+hmargin,y,width-(2*hmargin),height,this.context.fillStyle]);}
if(variant=='3d'){var prevFillStyle=this.context.fillStyle;var prevStrokeStyle=this.context.strokeStyle;if(j==0){this.context.beginPath();this.context.moveTo(startX+hmargin,y);this.context.lineTo(startX+properties.variantThreedOffsetx+hmargin,y-properties.variantThreedOffsety);this.context.lineTo(startX+properties.variantThreedOffsetx+barWidth+hmargin,y-properties.variantThreedOffsety);this.context.lineTo(startX+barWidth+hmargin,y);this.context.closePath();this.context.fill();this.context.stroke();}
this.context.beginPath();this.context.moveTo(startX+barWidth+hmargin,y);this.context.lineTo(startX+barWidth+hmargin+properties.variantThreedOffsetx,y-properties.variantThreedOffsety);this.context.lineTo(startX+barWidth+hmargin+properties.variantThreedOffsetx,y-properties.variantThreedOffsety+height);this.context.lineTo(startX+barWidth+hmargin,y+height);this.context.closePath();this.context.fill();this.context.stroke();if(j==0){this.context.fillStyle='rgba(255,255,255,0.5)';this.context.beginPath();this.context.moveTo(startX+hmargin,y);this.context.lineTo(startX+properties.variantThreedOffsetx+hmargin,y-properties.variantThreedOffsety);this.context.lineTo(startX+properties.variantThreedOffsetx+barWidth+hmargin,y-properties.variantThreedOffsety);this.context.lineTo(startX+barWidth+hmargin,y);this.context.closePath();this.context.fill();this.context.stroke();}
this.context.fillStyle='rgba(0,0,0,0.4)';this.context.beginPath();this.context.moveTo(startX+barWidth+hmargin,y);this.context.lineTo(startX+barWidth+hmargin+properties.variantThreedOffsetx,y-properties.variantThreedOffsety);this.context.lineTo(startX+barWidth+hmargin+properties.variantThreedOffsetx,y-properties.variantThreedOffsety+height);this.context.lineTo(startX+barWidth+hmargin,y+height);this.context.closePath();this.context.fill();this.context.stroke();this.context.strokeStyle=prevStrokeStyle;this.context.fillStyle=prevFillStyle;}
y+=height;}
if(shadow){RGraph.noShadow(this);for(k=0;k<redrawCoords.length;++k){this.context.strokeStyle=strokeStyle;this.context.fillStyle=redrawCoords[k][4];this.context.strokeRect(redrawCoords[k][0],redrawCoords[k][1],redrawCoords[k][2],redrawCoords[k][3]);this.context.fillRect(redrawCoords[k][0],redrawCoords[k][1],redrawCoords[k][2],redrawCoords[k][3]);this.context.stroke();this.context.fill();}
redrawCoords=[];}}else if(this.data[i]&&typeof this.data[i]=='object'&&properties.grouping=='grouped'){var redrawCoords=[];this.context.lineWidth=properties.linewidth;for(j=0;j<this.data[i].length;++j){this.context.strokeStyle=strokeStyle;this.context.fillStyle=colors[j];if(properties.colorsSequential&&colors[sequentialColorIndex]){this.context.fillStyle=colors[sequentialColorIndex++];}else if(properties.colorsSequential){this.context.fillStyle=colors[sequentialColorIndex-1];}
var individualBarWidth=(width-(2*hmargin))/this.data[i].length;var height=((this.data[i][j]+(this.data[i][j]<0?this.scale2.min:(-1*this.scale2.min)))/(this.scale2.max-this.scale2.min))*(this.canvas.height-this.marginTop-this.marginBottom);var groupedMargin=properties.marginInnerGrouped;var startX=x+hmargin+(j*individualBarWidth);if(individualBarWidth<0){alert('[RGRAPH] Warning: you have a negative bar width. This may be caused by the marginInner being too high or the width of the canvas not being sufficient.');}
if(xaxispos=='center'){height/=2;}
if(xaxispos=='top'){var startY=this.marginTop;var height=Math.abs(height);}else if(xaxispos=='center'){var startY=this.marginTop+(this.grapharea/2)-height;}else{var startY=this.getYCoord(0);var height=Math.abs(Math.abs(this.getYCoord(this.data[i][j]))-this.getYCoord(0));if(this.data[i][j]>=0){startY-=height;}}
if(properties.corners==='round'){this.context.beginPath();this.context.lineCap='miter';this.context.lineJoin='square';this.roundedCornersRect(startX+groupedMargin,startY,individualBarWidth-(2*groupedMargin),height);this.context.stroke();this.context.fill();}else{this.context.beginPath();this.context.lineJoin='miter';this.context.lineCap='square';this.context.rect(startX+groupedMargin,startY,individualBarWidth-(2*groupedMargin),height);this.context.stroke();this.context.fill();}
y+=height;if(variant=='3d'){var prevFillStyle=this.context.fillStyle;var prevStrokeStyle=this.context.strokeStyle;var hmarginGrouped=properties.marginInnerGrouped;if(this.data[i][j]>=0){this.context.beginPath();this.context.moveTo(startX+hmarginGrouped,startY);this.context.lineTo(startX+hmarginGrouped+properties.variantThreedOffsetx,startY-properties.variantThreedOffsety);this.context.lineTo(startX+properties.variantThreedOffsetx+individualBarWidth-hmarginGrouped,startY-properties.variantThreedOffsety);this.context.lineTo(startX+individualBarWidth-hmarginGrouped,startY);this.context.closePath();this.context.fill();this.context.stroke();}
this.context.beginPath();this.context.moveTo(startX+individualBarWidth-hmarginGrouped-1,startY);this.context.lineTo(startX+individualBarWidth-hmarginGrouped+properties.variantThreedOffsetx,this.data[i][j]<0?(this.getYCoord(0)+Math.abs(height)-properties.variantThreedOffsety)-(properties.xaxisPosition==='center'?0:Math.abs(height)-this.properties.variantThreedOffsety):this.getYCoord(0)-height-properties.variantThreedOffsety);this.context.lineTo(startX+individualBarWidth-hmarginGrouped+properties.variantThreedOffsetx,this.data[i][j]<0&&(startY+height-properties.variantThreedOffsety)<this.getYCoord(0)?(this.getYCoord(0)):(startY+height-properties.variantThreedOffsety));this.context.lineTo(startX+individualBarWidth-hmarginGrouped-1,startY+height);this.context.closePath();this.context.fill();this.context.stroke();if(this.data[i][j]>=0){this.context.fillStyle='rgba(255,255,255,0.5)';this.context.beginPath();this.context.moveTo(startX+hmarginGrouped,startY);this.context.lineTo(startX+hmarginGrouped+properties.variantThreedOffsetx,startY-properties.variantThreedOffsety);this.context.lineTo(startX+properties.variantThreedOffsetx+individualBarWidth-hmarginGrouped,startY-properties.variantThreedOffsety);this.context.lineTo(startX+individualBarWidth-hmarginGrouped,startY);this.context.closePath();this.context.fill();this.context.stroke();}
this.context.fillStyle='rgba(0,0,0,0.4)';this.context.beginPath();this.context.moveTo(startX+individualBarWidth-hmarginGrouped,startY);this.context.lineTo(startX+individualBarWidth+properties.variantThreedOffsetx-hmarginGrouped,this.data[i][j]<0?(this.getYCoord(0)+Math.abs(height)-properties.variantThreedOffsety)-(properties.xaxisPosition==='center'?0:Math.abs(height)-this.properties.variantThreedOffsety):this.getYCoord(0)-height-properties.variantThreedOffsety);this.context.lineTo(startX+individualBarWidth+properties.variantThreedOffsetx-hmarginGrouped,+this.data[i][j]<0&&(startY+height-5)<this.getYCoord(0)?((height>this.properties.variantThreedOffsety)?this.getYCoord(0)+height-this.properties.variantThreedOffsety:this.getYCoord(0)):(startY+height-properties.variantThreedOffsety));this.context.lineTo(startX+individualBarWidth-hmarginGrouped,startY+height);this.context.closePath();this.context.fill();this.context.stroke();this.context.strokeStyle=prevStrokeStyle;this.context.fillStyle=prevFillStyle;}
if(height<0){height=Math.abs(height);startY=startY-height;}
this.coords.push([startX+groupedMargin,startY,individualBarWidth-(2*groupedMargin),height]);if(typeof this.coords2[i]=='undefined'){this.coords2[i]=[];}
this.coords2[i].push([startX+groupedMargin,startY,individualBarWidth-(2*groupedMargin),height]);if(properties.shadow){redrawCoords.push([startX+groupedMargin,startY,individualBarWidth-(2*groupedMargin),height,this.context.fillStyle]);}}
if(redrawCoords.length){RGraph.noShadow(this);this.context.lineWidth=properties.linewidth;this.context.beginPath();for(var j=0;j<redrawCoords.length;++j){this.context.fillStyle=redrawCoords[j][4];this.context.strokeStyle=properties.colorsStroke;this.context.fillRect(redrawCoords[j][0],redrawCoords[j][1],redrawCoords[j][2],redrawCoords[j][3]);this.context.strokeRect(redrawCoords[j][0],redrawCoords[j][1],redrawCoords[j][2],redrawCoords[j][3]);}
this.context.fill();this.context.stroke();redrawCoords=[];}}else{this.coords.push([]);}
this.context.closePath();}
if(properties.variant==='3d'&&properties.yaxisPosition==='right'){RGraph.draw3DYAxis(this);}
RGraph.noShadow(this);};this.drawLabels=function()
{this.drawAboveLabels();};this.getShape=function(e)
{var obj=arguments[1]?arguments[1]:this;var mouseXY=RGraph.getMouseXY(e),mouseX=mouseXY[0],mouseY=mouseXY[1],canvas=obj.canvas,context=obj.context,coords=obj.coords
for(var i=0,len=coords.length;i<len;i+=1){if(obj.coords[i].length==0){continue;}
var left=coords[i][0],top=coords[i][1],width=coords[i][2],height=coords[i][3];if(properties.tooltipsHotspotXonly){this.path('b r % % % %',left,this.marginTop,width,this.canvas.height-this.marginBottom);}else{var indexes=RGraph.sequentialIndexToGrouped(i,this.data);if(properties.grouping==='stacked'&&properties.corners==='round'&&indexes[1]===0){this.context.beginPath();this.roundedCornersRect(left,top,width,height);}else{this.path('b r % % % %',left,top,width,height);}}
if(this.context.isPointInPath(mouseX,mouseY)){if(properties.tooltips&&RGraph.parseTooltipText){var tooltip=RGraph.parseTooltipText(properties.tooltips,i);}
var dataset=0,idx=i
while(idx>=(typeof obj.data[dataset]==='object'&&obj.data[dataset]?obj.data[dataset].length:1)){if(typeof obj.data[dataset]==='number'){idx-=1;}else if(obj.data[dataset]){idx-=obj.data[dataset].length;}else{idx-=1;}
dataset++;}
if(typeof obj.data[dataset]=='number'){idx=0;}
return{object:this,x:left,y:top,width:width,height:height,tooltip:typeof tooltip==='string'?tooltip:null,label:properties.xaxisLabels&&typeof properties.xaxisLabels[dataset]==='string'?properties.xaxisLabels[dataset]:null,dataset:dataset,index:idx,sequentialIndex:i};}}
return null;};this.getShapeByX=function(e)
{var canvas=e.target;var mouseCoords=RGraph.getMouseXY(e);var obj=arguments[1]?arguments[1]:this;for(var i=0,len=obj.coords.length;i<len;i++){if(obj.coords[i].length==0){continue;}
var mouseX=mouseCoords[0];var mouseY=mouseCoords[1];var left=obj.coords[i][0];var top=obj.coords[i][1];var width=obj.coords[i][2];var height=obj.coords[i][3];if(mouseX>=left&&mouseX<=(left+width)){if(properties.tooltips){var tooltip=RGraph.parseTooltipText?RGraph.parseTooltipText(properties.tooltips,i):properties.tooltips[i];}
var indexes=RGraph.sequentialIndexToGrouped(i,this.data);return{object:obj,x:left,y:top,width:width,height:height,dataset:indexes[0],index:indexes[1],sequentialIndex:i,tooltip:typeof tooltip==='string'?tooltip:null};}}
return null;};this.getValue=function(arg)
{if(arg.length==2){var mouseX=arg[0];var mouseY=arg[1];}else{var mouseCoords=RGraph.getMouseXY(arg);var mouseX=mouseCoords[0];var mouseY=mouseCoords[1];}
if(mouseY<properties.marginTop||mouseY>(this.canvas.height-properties.marginBottom)||mouseX<properties.marginLeft||mouseX>(this.canvas.width-properties.marginRight)){return null;}
if(properties.xaxisPosition=='center'){var value=(((this.grapharea/2)-(mouseY-properties.marginTop))/this.grapharea)*(this.scale2.max-this.scale2.min)
value*=2;if(value>=0){value+=this.scale2.min;}else{value-=this.scale2.min;}}else if(properties.xaxisPosition=='top'){var value=((this.grapharea-(mouseY-properties.marginTop))/this.grapharea)*(this.scale2.max-this.scale2.min)
value=this.scale2.max-value;value=Math.abs(value)* -1;}else{var value=((this.grapharea-(mouseY-properties.marginTop))/this.grapharea)*(this.scale2.max-this.scale2.min)
value+=this.scale2.min;}
return value;};this.getYCoord=function(value)
{if(value>this.scale2.max){return null;}
var y,xaxispos=properties.xaxisPosition;if(xaxispos=='top'){if(value<0){value=Math.abs(value);}
y=((value-this.scale2.min)/(this.scale2.max-this.scale2.min))*this.grapharea;y=y+this.marginTop}else if(xaxispos=='center'){y=((value-this.scale2.min)/(this.scale2.max-this.scale2.min))*(this.grapharea/2);y=(this.grapharea/2)-y;y+=this.marginTop;}else{if(value<this.scale2.min){value=this.scale2.min;}
y=((value-this.scale2.min)/(this.scale2.max-this.scale2.min));y*=(this.canvas.height-this.marginTop-this.marginBottom);y=this.canvas.height-this.marginBottom-y;}
return y;};this.highlight=function(shape)
{if(typeof properties.highlightStyle==='function'){(properties.highlightStyle)(shape);}else if(typeof properties.highlightStyle==='string'&&properties.highlightStyle==='invert'){for(var i=0;i<this.coords.length;++i){if(i!==shape.sequentialIndex){this.path('b r % % % % s % f %',this.coords[i][0],this.coords[i][1],this.coords[i][2],this.coords[i][3],properties.highlightStroke,properties.highlightFill);}}}else{if(properties.grouping==='stacked'&&shape.index===0){this.context.beginPath();this.context.strokeStyle=properties.highlightStroke;this.context.fillStyle=properties.highlightFill;if(properties.corners==='round'){this.roundedCornersRect(shape.x,shape.y,shape.width,shape.height);}else{this.context.rect(shape.x,shape.y,shape.width,shape.height);}
this.context.stroke();this.context.fill();}else{RGraph.Highlight.rect(this,shape);}}};this.getObjectByXY=function(e)
{var mouseXY=RGraph.getMouseXY(e);var shape=this.getShape(e);if(properties.variant==='3d'&&!properties.textAccessible){var adjustment=properties.variantThreedAngle*mouseXY[0];mouseXY[1]-=adjustment;}
if(mouseXY[0]>=properties.marginLeft&&mouseXY[0]<=(this.canvas.width-properties.marginRight)&&mouseXY[1]>=properties.marginTop&&mouseXY[1]<=(this.canvas.height-properties.marginBottom)){return this;}};this.adjusting_mousemove=function(e)
{if(properties.adjustable&&RGraph.Registry.get('adjusting')&&RGraph.Registry.get('adjusting').uid==this.uid){var value=Number(this.getValue(e));var shape=RGraph.Registry.get('adjusting.shape')
if(shape){RGraph.Registry.set('adjusting.shape',shape);if(this.stackedOrGrouped&&properties.grouping=='grouped'){var indexes=RGraph.sequentialIndexToGrouped(shape.sequentialIndex,this.data);if(typeof this.data[indexes[0]]=='number'){this.data[indexes[0]]=Number(value);}else if(!RGraph.isNull(this.data[indexes[0]])){this.data[indexes[0]][indexes[1]]=Number(value);}}else if(typeof this.data[shape.sequentialIndex]=='number'){this.data[shape.sequentialIndex]=Number(value);}
RGraph.redrawCanvas(e.target);RGraph.fireCustomEvent(this,'onadjust');}}};this.parseColors=function()
{if(this.original_colors.length===0){this.original_colors.colors=RGraph.arrayClone(properties.colors);this.original_colors.keyColors=RGraph.arrayClone(properties.keyColors);this.original_colors.crosshairsColor=properties.crosshairsColor;this.original_colors.highlightStroke=properties.highlightStroke;this.original_colors.highlightFill=properties.highlightFill;this.original_colors.textColor=properties.textColor;this.original_colors.backgroundBarsColor1=properties.backgroundBarsColor1;this.original_colors.backgroundBarsColor2=properties.backgroundBarsColor2;this.original_colors.backgroundGridColor=properties.backgroundGridColor;this.original_colors.backgroundColor=properties.backgroundColor;this.original_colors.colorsStroke=properties.colorsStroke;this.original_colors.axesColor=properties.axesColor;}
var colors=properties.colors;if(colors){for(var i=0;i<colors.length;++i){colors[i]=this.parseSingleColorForGradient(colors[i]);}}
var colors=properties.keyColors;if(colors){for(var i=0;i<colors.length;++i){colors[i]=this.parseSingleColorForGradient(colors[i]);}}
properties.crosshairsColor=this.parseSingleColorForGradient(properties.crosshairsColor);properties.highlightStroke=this.parseSingleColorForGradient(properties.highlightStroke);properties.highlightFill=this.parseSingleColorForGradient(properties.highlightFill);properties.textColor=this.parseSingleColorForGradient(properties.textColor);properties.backgroundBarsColor1=this.parseSingleColorForGradient(properties.backgroundBarsColor1);properties.backgroundBarsColor2=this.parseSingleColorForGradient(properties.backgroundBarsColor2);properties.backgroundGridColor=this.parseSingleColorForGradient(properties.backgroundGridColor);properties.backgroundColor=this.parseSingleColorForGradient(properties.backgroundColor);properties.colorStroke=this.parseSingleColorForGradient(properties.colorStroke);properties.axesColor=this.parseSingleColorForGradient(properties.axesColor);};this.reset=function()
{};this.parseSingleColorForGradient=function(color)
{if(!color||typeof color!='string'){return color;}
if(color.match(/^gradient\((.*)\)$/i)){if(color.match(/^gradient\(({.*})\)$/i)){return RGraph.parseJSONGradient({object:this,def:RegExp.$1});}
var parts=RegExp.$1.split(':');var grad=this.context.createLinearGradient(0,this.canvas.height-properties.marginBottom,0,properties.marginTop);var diff=1/(parts.length-1);grad.addColorStop(0,RGraph.trim(parts[0]));for(var j=1,len=parts.length;j<len;++j){grad.addColorStop(j*diff,RGraph.trim(parts[j]));}}
return grad?grad:color;};this.drawBevel=function()
{var coords=this.coords,coords2=this.coords2;if(properties.grouping=='stacked'){for(var i=0;i<coords2.length;++i){if(coords2[i]&&coords2[i][0]&&coords2[i][0][0]){var x=coords2[i][0][0];var y=coords2[i][0][1];var w=coords2[i][0][2];var arr=[];for(var j=0;j<coords2[i].length;++j){arr.push(coords2[i][j][3]);}
var h=RGraph.arraySum(arr);this.context.save();this.context.strokeStyle='black';this.context.beginPath();this.context.rect(x,y,w,h);this.context.clip();this.context.shadowColor='black';this.context.shadowOffsetX=0;this.context.shadowOffsetY=0;this.context.shadowBlur=20;this.context.beginPath();this.context.rect(x-3,y-3,w+6,h+100);this.context.lineWidth=5;this.context.stroke();this.context.restore();}}}else{for(var i=0;i<coords.length;++i){if(coords[i]){var x=coords[i][0];var y=coords[i][1];var w=coords[i][2];var h=coords[i][3];var xaxispos=properties.xaxisPosition;var xaxis_ycoord=((this.canvas.height-this.marginTop-this.marginBottom)/2)+this.marginTop;this.context.save();this.context.strokeStyle='black';this.context.beginPath();this.context.rect(x,y,w,h);this.context.clip();this.context.shadowColor='black';this.context.shadowOffsetX=0;this.context.shadowOffsetY=0;this.context.shadowBlur=20;if(xaxispos=='top'||(xaxispos=='center'&&(y+h)>xaxis_ycoord)){y=y-100;h=h+100;}else{y=y;h=h+100;}
this.context.beginPath();this.context.rect(x-3,y-3,w+6,h+6);this.context.lineWidth=5;this.context.stroke();this.context.restore();}}}};this.interactiveKeyHighlight=function(index)
{var obj=this;this.coords2.forEach(function(value,idx,arr)
{if(typeof value[index]=='object'&&value[index]){var x=value[index][0]-0.5,y=value[index][1]-0.5,w=value[index][2]+1,h=value[index][3]+1;obj.context.fillStyle=properties.keyInteractiveHighlightChartFill;obj.context.strokeStyle=properties.keyInteractiveHighlightChartStroke;obj.context.lineWidth=2;obj.context.strokeRect(x,y,w,h);obj.context.fillRect(x,y,w,h);}});};this.on=function(type,func)
{if(type.substr(0,2)!=='on'){type='on'+type;}
if(typeof this[type]!=='function'){this[type]=func;}else{RGraph.addCustomEventListener(this,type,func);}
return this;};this.drawLabelsAbove=this.drawAboveLabels=function()
{var labels=properties.labelsAbove,specific=properties.labelsAboveSpecific,bold=typeof properties.labelsAboveBold==='boolean'?properties.labelsAboveBold:properties.textBold,italic=typeof properties.labelsAboveItalic==='boolean'?properties.labelsAboveItalic:properties.textItalic,color=properties.labelsAboveColor||properties.textColor,font=properties.labelsAboveFont||properties.textFont,size=typeof properties.labelsAboveSize==='number'?properties.labelsAboveSize:properties.textSize,background=properties.labelsAboveBackground,decimals=properties.labelsAboveDecimals,angle=-1*properties.labelsAboveAngle,unitsPre=properties.labelsAboveUnitsPre,unitsPost=properties.labelsAboveUnitsPost,point=properties.labelsAbovePoint,thousand=properties.labelsAboveThousand,coords=this.coords,coords2=this.coords2,data=this.data,ldata=RGraph.arrayLinearize(this.data),offsetx=properties.labelsAboveOffsetx,offsety=properties.labelsAboveOffsety,text_italic=properties.textItalic,text_bold=properties.textBold,text_color=properties.textColor,text_font=properties.textFont,text_size=properties.textSize,grouping=properties.grouping;if(typeof properties.labelsAboveOffset==='number'){offsety=properties.labelsAboveOffset;}
var textConf=RGraph.getTextConf({object:this,prefix:'labelsAbove'});RGraph.noShadow(this);this.context.fillStyle=textConf.color;if(labels&&grouping==='grouped'){for(var i=0,len=data.length,sequentialIndex=0;i<len;i+=1){if(typeof data[i]==='number'&&data[i]>=0){var angle=angle;var halign=(angle?'left':'center');var valign=angle!==0?'center':'bottom';RGraph.text({object:this,font:textConf.font,size:textConf.size,color:textConf.color,bold:textConf.bold,italic:textConf.italic,x:coords2[i][0][0]+(coords2[i][0][2]/2)+offsetx,y:coords2[i][0][1]-offsety,text:specific?(specific[sequentialIndex]||''):RGraph.numberFormat({object:this,number:Number(typeof data[i]==='object'?data[i][0]:data[i]).toFixed(decimals),unitspre:unitsPre,unitspost:unitsPost,point:point,thousand:thousand}),halign:halign,valign:valign,angle:angle,marker:false,bounding:true,'bounding.fill':background,'bounding.stroke':'rgba(0,0,0,0)',tag:'labels.above'});sequentialIndex++;}else if(typeof data[i]==='number'&&data[i]<0){var angle=angle;var halign=angle?'right':'center';var valign=angle!==0?'center':'top';RGraph.text({object:this,font:textConf.font,size:textConf.size,color:textConf.color,bold:textConf.bold,italic:textConf.italic,x:coords2[i][0][0]+(coords2[i][0][2]/2)+offsetx,y:coords2[i][0][1]+coords2[i][0][3]+offsety,text:specific?(specific[sequentialIndex]||''):RGraph.numberFormat({object:this,number:Number(typeof data[i]==='object'?data[i][0]:data[i]).toFixed(decimals),unitspre:unitsPre,unitspost:unitsPost,point:point,thousand:thousand}),halign:halign,valign:valign,angle:angle,bounding:true,'bounding.fill':background,'bounding.stroke':'rgba(0,0,0,0)',marker:false,tag:'labels.above'});sequentialIndex++;}else if(typeof data[i]==='object'){for(var j=0,len2=data[i].length;j<len2;j+=1){var angle=angle;var halign=data[i][j]<0?'right':'left';halign=angle===0?'center':halign;var valign=data[i][j]<0?'top':'bottom';valign=angle!=0?'center':valign;RGraph.text({object:this,font:textConf.font,size:textConf.size,color:textConf.color,bold:textConf.bold,italic:textConf.italic,x:coords2[i][j][0]+(coords2[i][j][2]/2)+offsetx,y:properties.xaxisPosition==='top'?coords2[i][j][1]+coords2[i][j][3]+5:coords2[i][j][1]+(data[i][j]<0?coords2[i][j][3]+offsety:-offsety),text:specific?(specific[sequentialIndex]||''):RGraph.numberFormat({object:this,number:Number(data[i][j]).toFixed(decimals),unitspre:unitsPre,unitspost:unitsPost,point:point,thousand:thousand}),halign:halign,valign:properties.xaxisPosition==='top'?'top':valign,angle:angle,bounding:true,'bounding.fill':background,'bounding.stroke':'rgba(0,0,0,0)',marker:false,tag:'labels.above'});sequentialIndex++;}}}}else if(labels&&grouping==='stacked'){for(var i=0,len=data.length,sequentialIndex=0;i<len;i+=1){if(typeof data[i]==='object'){var angle=angle;var halign=angle!=0?'left':'center';var valign=angle!=0?'center':'bottom';RGraph.text({object:this,font:textConf.font,size:textConf.size,color:textConf.color,bold:textConf.bold,italic:textConf.italic,x:coords2[i][0][0]+(coords2[i][0][2]/2)+offsetx,y:coords2[i][0][1]+(data[i][0]<0?coords2[i][0][3]:0)-offsety,text:specific?(specific[sequentialIndex]||''):RGraph.numberFormat({object:this,number:Number(RGraph.arraySum(data[i])).toFixed(decimals),unitspre:unitsPre,unitspost:unitsPost,point:point,thousand:thousand}),halign:halign,valign:valign,angle:angle,bounding:true,'bounding.fill':background,'bounding.stroke':'rgba(0,0,0,0)',marker:false,tag:'labels.above'});sequentialIndex+=data[i].length;}else{var angle=angle;var halign=angle!=0?'left':'center';var valign=angle!=0?'center':'bottom';RGraph.text({object:this,font:textConf.font,size:textConf.size,color:textConf.color,bold:textConf.bold,italic:textConf.italic,x:coords2[i][0][0]+(coords2[i][0][2]/2)+offsetx,y:coords2[i][0][1]+(data[i][0]<0?coords2[i][0][3]:0)-offsety,text:specific?(specific[sequentialIndex]||''):RGraph.numberFormat({object:this,number:Number(data[i]).toFixed(decimals),unitspre:unitsPre,unitspost:unitsPost,point:point,thousand:thousand}),halign:halign,valign:valign,angle:angle,bounding:true,'bounding.fill':background,'bounding.stroke':'rgba(0,0,0,0)',marker:false,tag:'labels.above'});sequentialIndex++;}}}};this.firstDrawFunc=function()
{};this.wave=function()
{if(this.data.length===1){this.grow(arguments[0],arguments[1]);return;}
var obj=this,opt=arguments[0]||{},labelsAbove=this.get('labelsAbove');opt.frames=opt.frames||60;opt.startFrames=[];opt.counters=[];var framesperbar=opt.frames/3,frame=-1,callback=arguments[1]||function(){},original=RGraph.arrayClone(this.original_data);this.set('labelsAbove',false);for(var i=0,len=obj.data.length;i<len;i+=1){opt.startFrames[i]=((opt.frames/2)/(obj.data.length-1))*i;if(typeof obj.data[i]==='object'&&obj.data[i]){opt.counters[i]=[];for(var j=0;j<obj.data[i].length;j++){opt.counters[i][j]=0;}}else{opt.counters[i]=0;}}
obj.draw();obj.set('yaxisScaleMax',obj.scale2.max);RGraph.clear(obj.canvas);function iterator()
{++frame;for(var i=0,len=obj.data.length;i<len;i+=1){if(frame>opt.startFrames[i]){if(typeof obj.data[i]==='number'){obj.data[i]=Math.min(Math.abs(original[i]),Math.abs(original[i]*((opt.counters[i]++)/framesperbar)));if(original[i]<0){obj.data[i]*=-1;}}else if(!RGraph.isNull(obj.data[i])){for(var j=0,len2=obj.data[i].length;j<len2;j+=1){obj.data[i][j]=Math.min(Math.abs(original[i][j]),Math.abs(original[i][j]*((opt.counters[i][j]++)/framesperbar)));if(original[i][j]<0){obj.data[i][j]*=-1;}}}}else{obj.data[i]=typeof obj.data[i]==='object'&&obj.data[i]?RGraph.arrayPad([],obj.data[i].length,0):(RGraph.isNull(obj.data[i])?null:0);}}
if(frame>=opt.frames){if(labelsAbove){obj.set('labelsAbove',true);RGraph.redraw();}
callback(obj);}else{RGraph.redrawCanvas(obj.canvas);RGraph.Effects.updateCanvas(iterator);}}
iterator();return this;};this.colorwave=this.colorWave=function()
{var obj=this,opt=arguments[0]||{};opt.frames=opt.frames||60;opt.startFrames=[];opt.counters=[],colors=obj.properties.colors;if(colors.length<=obj.data.length){obj.set('colorsSequential',true);colors=RGraph.arrayPad(colors,obj.data.length,colors[colors.length-1]);}
var framesperbar=opt.frames/2,frame=-1,callback=arguments[1]||function(){},originalColors=RGraph.arrayClone(obj.properties.colors);for(var i=0,len=originalColors.length;i<len;i+=1){opt.startFrames[i]=((opt.frames/2)/(originalColors.length-1))*i;opt.counters[i]=0;}
function iterator()
{++frame;for(var i=0,len=colors.length;i<len;i+=1){if(frame>opt.startFrames[i]&&colors[i].match(/^rgba?\(([0-9 ]+),([0-9 ]+),([0-9 ]+)(,([ 0-9.]+)?)\)/)){colors[i]='rgba({1},{2},{3},{4})'.format(RegExp.$1,RegExp.$2,RegExp.$3,(frame-opt.startFrames[i])/framesperbar);}else{colors[i]=colors[i].replace(/,[0-9. ]+\)/,',0)');}}
if(frame>=opt.frames){callback(obj);}else{RGraph.redrawCanvas(obj.canvas);RGraph.Effects.updateCanvas(iterator);}}
iterator();return this;};this.grow=function()
{var opt=arguments[0]||{},frames=opt.frames||30,frame=0,callback=arguments[1]||function(){},obj=this,labelsAbove=this.get('labelsAbove');if(RGraph.isArray(opt.data)){var ymax=0;for(var i=0;i<opt.data.length;++i){if(typeof opt.data[i]==='object'){for(var j=0;j<opt.data[i].length;++j){if(typeof opt.data[i][j]==='string'&&opt.data[i][j].match(/(\+|\-)([0-9]+)/)){if(RegExp.$1==='+'){opt.data[i][j]=this.original_data[i][j]+parseInt(RegExp.$2);}else{opt.data[i][j]=this.original_data[i][j]-parseInt(RegExp.$2);}}
ymax=Math.max(ymax,opt.data[i][j]);}}else if(typeof opt.data[i]==='string'&&opt.data[i].match(/(\+|\-)([0-9]+)/)){if(RegExp.$1==='+'){opt.data[i]=this.original_data[i]+parseInt(RegExp.$2);}else{opt.data[i]=this.original_data[i]-parseInt(RegExp.$2);}
ymax=Math.max(ymax,opt.data[i]);}else{ymax=Math.max(ymax,opt.data[i]);}}
var scale=RGraph.getScale({object:this,options:{'scale.max':ymax}});if(typeof properties.yaxisScaleMax!=='number'){this.set('yaxisScaleMax',scale.max);}}
this.set('labelsAbove',false);if(properties.yaxisScaleMax==null){var ymax=0;for(var i=0;i<this.data.length;++i){if(RGraph.isArray(this.data[i])&&properties.grouping==='stacked'){ymax=Math.max(ymax,Math.abs(RGraph.arraySum(this.data[i])));}else if(RGraph.isArray(this.data[i])&&properties.grouping==='grouped'){for(var j=0,group=[];j<this.data[i].length;j++){group.push(Math.abs(this.data[i][j]));}
ymax=Math.max(ymax,Math.abs(RGraph.arrayMax(group)));}else{ymax=Math.max(ymax,Math.abs(this.data[i]));}}
var scale=RGraph.getScale({object:this,options:{'scale.max':ymax}});this.set('yaxisScaleMax',scale.max);}
if(typeof opt.ymax==='number'){this.set('yaxisScaleMax',opt.ymax);}
var iterator=function()
{var easingMultiplier=RGraph.Effects.getEasingMultiplier(frames,frame);for(var j=0,len=obj.original_data.length;j<len;++j){if(typeof obj.data[j]==='object'&&!RGraph.isNull(obj.data[j])){for(var k=0,len2=obj.data[j].length;k<len2;++k){if(obj.firstDraw||!opt.data){obj.data[j][k]=easingMultiplier*obj.original_data[j][k];}else if(opt.data&&opt.data.length===obj.original_data.length){var diff=opt.data[j][k]-obj.original_data[j][k];obj.data[j][k]=(easingMultiplier*diff)+obj.original_data[j][k];}}}else{if(obj.firstDraw||!opt.data){obj.data[j]=easingMultiplier*obj.original_data[j];}else if(opt.data&&opt.data.length===obj.original_data.length){var diff=opt.data[j]-obj.original_data[j];obj.data[j]=(easingMultiplier*diff)+obj.original_data[j];}}}
RGraph.redrawCanvas(obj.canvas);if(frame<frames){frame+=1;RGraph.Effects.updateCanvas(iterator);}else{if(RGraph.isArray(opt.data)){var linear_data=RGraph.arrayLinearize(data);for(var i=0;i<linear_data.length;++i){if(!obj['$'+i]){obj['$'+i]={};}}}
obj.data=data;obj.original_data=RGraph.arrayClone(data);if(labelsAbove){obj.set('labelsAbove',true);RGraph.redraw();}
callback(obj);}};iterator();return this;};this.drawErrorbars=function()
{var coords=this.coords,color=properties.errorbarsColor||'black',default_halfwidth=Math.min(properties.errorbarsCappedWidth,coords[0][2])/2,x=0,errorbars=properties.errorbars,length=0;if(!properties.errorbarsCapped){properties.errorbarsCappedWidth=0;halfwidth=0;}
this.context.lineWidth=properties.errorbarsLinewidth;for(var i=0;i<coords.length;++i){var barX=coords[i][0],barY=coords[i][1],barW=coords[i][2],barH=coords[i][3];var groupedIndexes=RGraph.sequentialIndexToGrouped(i,this.data);if(typeof this.data[groupedIndexes[0]]==='object'&&!RGraph.isNull(this.data[groupedIndexes[0]])){var isGrouped=true,group=groupedIndexes[0],subgroup=groupedIndexes[1];}
color=properties.errorbarsColor||'black';if(errorbars[i]&&typeof errorbars[i][3]==='number'){this.context.lineWidth=errorbars[i][3];}
var halfwidth=(errorbars[i]&&typeof errorbars[i][4]==='number')?errorbars[i][4]/2:default_halfwidth;if(!properties.errorbarsCapped){halfwidth=0;}
if(typeof errorbars[i]==='number'){length=Math.abs(this.getYCoord(errorbars[i])-this.getYCoord(0));if(length){this.path('b % % l % % l % % l % % s %',barX+(barW/2),(typeof this.data[i]==='number'&&this.data[i]<0||(isGrouped&&this.data[group][subgroup]<0))?barY+barH:barY,barX+(barW/2),(typeof this.data[i]==='number'&&this.data[i]<0||(isGrouped&&this.data[group][subgroup]<0))?barY+barH+length:barY-length,barX+(barW/2)-halfwidth,(typeof this.data[i]==='number'&&this.data[i]<0||(isGrouped&&this.data[group][subgroup]<0))?Math.round(barY+barH+length):Math.round(barY-length),barX+(barW/2)+halfwidth,(typeof this.data[i]==='number'&&this.data[i]<0||(isGrouped&&this.data[group][subgroup]<0))?Math.round(barY+barH+length):Math.round(barY-length),color);}}else if(typeof errorbars[i]==='object'&&!RGraph.isNull(errorbars[i])){var positiveLength=Math.abs(this.getYCoord(errorbars[i][0])-this.getYCoord(0));if(typeof errorbars[i][1]==='string'){color=errorbars[i][1];}else if(typeof errorbars[i][2]==='string'){color=errorbars[i][2];}
halfwidth=typeof errorbars[i][4]==='number'?errorbars[i][4]/2:default_halfwidth;if(!properties.errorbarsCapped){halfwidth=0;}
if(!RGraph.isNull(errorbars[i][0])){this.path('b m % % l % % l % % l % % s %',barX+(barW/2),barY+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),barX+(barW/2),barY-positiveLength+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),barX+(barW/2)-halfwidth,Math.round(barY-positiveLength)+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),barX+(barW/2)+halfwidth,Math.round(barY-positiveLength)+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),color);}
if(typeof errorbars[i][1]==='number'){var negativeLength=Math.abs(this.getYCoord(errorbars[i][1])-this.getYCoord(0));this.path('b m % % l % % l % % l % % s %',barX+(barW/2),barY+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),barX+(barW/2),barY+negativeLength+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),barX+(barW/2)-halfwidth,Math.round(coords[i][1]+negativeLength)+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),barX+(barW/2)+halfwidth,Math.round(barY+negativeLength)+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),color);}}
if(errorbars[i]&&typeof errorbars[i][3]==='number'){this.context.lineWidth=properties.errorbarsLinewidth;}}};this.isAdjustable=function(shape)
{if(RGraph.isNull(properties.adjustableOnly)||!RGraph.isArray(properties.adjustableOnly)){return true;}
if(RGraph.isArray(properties.adjustableOnly)&&properties.adjustableOnly[shape.sequentialIndex]){return true;}
return false;};this.tooltipSubstitutions=function(opt)
{var indexes=RGraph.sequentialIndexToGrouped(opt.index,this.data);var values=this.data[indexes[0]];if(typeof values==='number'){values=[values];}
return{index:indexes[1],dataset:indexes[0],sequentialIndex:opt.index,value:this.data_arr[opt.index],values:values};};this.tooltipsFormattedCustom=function(specific,index)
{var label;if(this.stackedOrGrouped){label=(!RGraph.isNull(properties.tooltipsFormattedKeyLabels)&&typeof properties.tooltipsFormattedKeyLabels==='object'&&properties.tooltipsFormattedKeyLabels[index])?properties.tooltipsFormattedKeyLabels[index]:'';}else{label=(!RGraph.isNull(properties.tooltipsFormattedKeyLabels)&&typeof properties.tooltipsFormattedKeyLabels==='object'&&properties.tooltipsFormattedKeyLabels[specific.index])?properties.tooltipsFormattedKeyLabels[specific.index]:'';}
return{label:label};};this.positionTooltipStatic=function(args)
{var obj=args.object,e=args.event,tooltip=args.tooltip,index=args.index,canvasXY=RGraph.getCanvasXY(obj.canvas)
coords=this.coords[args.index];args.tooltip.style.left=(canvasXY[0]
+coords[0]
-(tooltip.offsetWidth/2)
+(coords[2]/2)
+obj.properties.tooltipsOffsetx)+'px';args.tooltip.style.top=(canvasXY[1]
+coords[1]
-tooltip.offsetHeight
-10
+obj.properties.tooltipsOffsety)+'px';if(properties.variant==='3d'){var left=coords[0];var top=coords[1];var angle=properties.variantThreedAngle;var adjustment=Math.tan(angle)*left;args.tooltip.style.top=parseInt(args.tooltip.style.top)+adjustment-5+'px';}
if(this.data_arr[index]<0){args.tooltip.style.top=parseFloat(args.tooltip.style.top)
+(coords[3]/2)
+'px';}};this.roundedCornersRect=function(x,y,width,height)
{var radius=properties.cornersRoundRadius;radius=Math.min(width/2,height/2,radius);this.context.save();this.context.translate(x,y);this.context.moveTo(width/2,0);this.context.arcTo(width,0,width,height,Math.min(height/2,radius));this.context.arcTo(width,height,0,height,0);this.context.arcTo(0,height,0,0,0);this.context.arcTo(0,0,radius,0,Math.min(height/2,radius));this.context.lineTo(width/2,0);this.context.restore();};this.install3DAxisClip=function()
{this.path('b m % % l % % l % % l % % l % % l % % c cl',this.marginLeft,this.getYCoord(0),this.marginLeft,this.canvas.height-this.marginBottom,this.canvas.width-this.marginRight,this.canvas.height-this.marginBottom,this.canvas.width-this.marginRight+this.properties.variantThreedOffsetx,this.canvas.height-this.marginBottom-this.properties.variantThreedOffsety,this.canvas.width-this.marginRight+this.properties.variantThreedOffsetx,this.getYCoord(0)-this.properties.variantThreedOffsety,this.canvas.width-this.marginRight,this.getYCoord(0));};RGraph.register(this);RGraph.parseObjectStyleConfig(this,conf.options);};RGraph.CombinedChart=function()
{this.objects=[];var objects=[];if(RGraph.isArray(arguments[0])){objects=arguments[0];}else{for(var i=0;i<arguments.length;i+=1){objects[i]=arguments[i];}}
for(var i=0;i<objects.length;++i){this.objects[i]=objects[i];this.objects[i].set({marginLeft:this.objects[0].get('marginLeft'),marginRight:this.objects[0].get('marginRight'),marginTop:this.objects[0].get('marginTop'),marginBottom:this.objects[0].get('marginBottom')});if(this.objects[i].type=='line'){var obj=this.objects[i];obj.set('marginInner',((this.objects[0].canvas.width-this.objects[0].get('marginRight')-this.objects[0].get('marginLeft'))/this.objects[0].data.length)/2);obj.set('yaxis',false);obj.set('xaxis',false);obj.set('backgroundGrid',false);obj.set('yaxisScale',false);}
if(this.objects[i].get('resizable')){var resizable_object=obj;}}
if(resizable_object){function myOnresizebeforedraw(obj)
{var marginLeft=obj.get('marginLeft');var marginRight=obj.get('marginRight');obj.set('marginInner',(obj.canvas.width-marginLeft-marginRight)/(obj.original_data[0].length*2));}
RGraph.addCustomEventListener(resizable_object,'onresizebeforedraw',myOnresizebeforedraw);}
return this;};RGraph.CombinedChart.prototype.add=function(obj)
{this.objects.push(obj);return this;};RGraph.CombinedChart.prototype.draw=function()
{if(RGraph.isArray(this.objects)){for(var i=0;i<this.objects.length;++i){if(this.objects[i].properties['combinedEffect']){var options=this.objects[i].properties['combinedEffectOptions']?eval('('+this.objects[i].properties['combinedEffectOptions']+')'):null,callback=this.objects[i].properties['combinedEffectCallback'],func=this.objects[i].properties['combinedEffect'];(this.objects[i][func])(options,callback);}else{this.objects[i].draw();}}}
return this;};RGraph.SegmentedBar=function(conf)
{this.config=conf;this.properties={};this.config.data.forEach(function(v,k,arr)
{arr[k]=RGraph.arrayPad([],v,1);});for(i in this.config.options){if(typeof i==='string'){this.properties[i]=this.config.options[i];}}
var seg=this;this.background=new RGraph.Bar({id:conf.id[0],data:RGraph.arrayPad([],conf.data.length),options:{backgroundGridHlinesCount:seg.properties.segmentsCount,colors:['rgba(0,0,0,0)'],xaxis:false,yaxis:false,yaxisLabels:false,xaxis:false,yaxis:false,yaxisScale:false}});this.foreground=new RGraph.Bar({id:conf.id[1],data:conf.data,options:{grouping:'stacked',xaxis:false,yaxis:false,backgroundGrid:false,yaxisLabelsOffsetx:-3,yaxisLabelsOffsety:20}}).on('draw',function(obj)
{var lw=seg.properties.segmentsLinewidth;var count=seg.properties.segmentsCount;for(var i=0;i<=count;++i){obj.path('cr 0 % 1000 %',obj.getYCoord(i/count*seg.foreground.scale2.max)-(lw/2),lw);}});this.foreground.set({yaxisLabelsOffsety:(this.foreground.canvas.height-this.foreground.properties.marginTop-this.foreground.properties.marginBottom)/seg.properties.segmentsCount/2});this.draw=function()
{this.background.draw();this.foreground.draw();return this;}
this.grow=function()
{this.background.draw();this.foreground.grow(arguments[0],arguments[1]);return this;}
this.wave=function()
{this.background.draw();this.foreground.wave(arguments[0],arguments[1]);return this;}
this.responsive=function(conf)
{this.foreground.responsive(conf);this.background.responsive(conf);return this;}}
RGraph=window.RGraph||{isrgraph:true,isRGraph:true,rgraph:true};RGraph.Bar=function(conf)
{var id=conf.id,canvas=document.getElementById(id),data=conf.data;this.id=id;this.canvas=canvas;this.context=this.canvas.getContext('2d');this.canvas.__object__=this;this.type='bar';this.max=0;this.stackedOrGrouped=false;this.isRGraph=true;this.isrgraph=true;this.rgraph=true;this.uid=RGraph.createUID();this.canvas.uid=this.canvas.uid?this.canvas.uid:RGraph.createUID();this.colorsParsed=false;this.original_colors=[];this.cachedBackgroundCanvas=null;this.firstDraw=true;this.properties={backgroundBarsCount:null,backgroundBarsColor1:'rgba(0,0,0,0)',backgroundBarsColor2:'rgba(0,0,0,0)',backgroundGrid:true,backgroundGridColor:'#ddd',backgroundGridLinewidth:1,backgroundGridHsize:20,backgroundGridVsize:20,backgroundGridVlines:true,backgroundGridHlines:true,backgroundGridBorder:true,backgroundGridAutofit:true,backgroundGridAutofitAlign:true,backgroundGridHlinesCount:5,backgroundGridDashed:false,backgroundGridDotted:false,backgroundImage:null,backgroundImageStretch:true,backgroundImageX:null,backgroundImageY:null,backgroundImageW:null,backgroundImageH:null,backgroundImageAlign:null,backgroundColor:null,backgroundHbars:null,marginTop:35,marginBottom:35,marginLeft:35,marginRight:35,marginInner:5,marginInnerGrouped:1,labelsIngraph:null,labelsIngraphFont:null,labelsIngraphSize:null,labelsIngraphColor:null,labelsIngraphBold:null,labelsIngraphItalic:null,labelsIngraphOffsetx:0,labelsIngraphOffsety:0,labelsAbove:false,labelsAboveDecimals:0,labelsAboveSize:null,labelsAboveColor:null,labelsAboveBold:null,labelsAboveItalic:null,labelsAboveFont:null,labelsAbovePoint:'.',labelsAboveThousand:',',labelsAboveBackground:'rgba(0,0,0,0)',labelsAboveAngle:null,labelsAboveOffset:null,labelsAboveOffsetx:0,labelsAboveOffsety:0,labelsAboveUnitsPre:'',labelsAboveUnitsPost:'',yaxis:true,yaxisLinewidth:1,yaxisColor:'black',yaxisTickmarks:true,yaxisTickmarksCount:null,yaxisTickmarksLastTop:null,yaxisTickmarksLastBottom:null,yaxisTickmarksLength:3,yaxisScale:true,yaxisScaleMin:0,yaxisScaleMax:null,yaxisScaleUnitsPre:'',yaxisScaleUnitsPost:'',yaxisScaleDecimals:0,yaxisScalePoint:'.',yaxisScaleThousand:',',yaxisScaleRound:false,yaxisScaleFormatter:null,yaxisLabelsSpecific:null,yaxisLabelsCount:5,yaxisLabelsOffsetx:0,yaxisLabelsOffsety:0,yaxisLabelsHalign:null,yaxisLabelsValign:null,yaxisLabelsFont:null,yaxisLabelsSize:null,yaxisLabelsColor:null,yaxisLabelsBold:null,yaxisLabelsItalic:null,yaxisLabelsPosition:'edge',yaxisPosition:'left',yaxisTitle:'',yaxisTitleAccessible:null,yaxisTitleBold:null,yaxisTitleSize:null,yaxisTitleFont:null,yaxisTitleColor:null,yaxisTitleItalic:null,yaxisTitlePos:null,yaxisTitleX:null,yaxisTitleY:null,yaxisTitleOffsetx:0,yaxisTitleOffsety:0,yaxisTitleHalign:null,yaxisTitleValign:null,yaxisTitleAccessible:null,xaxis:true,xaxisLinewidth:1,xaxisColor:'black',xaxisTickmarks:true,xaxisTickmarksLength:3,xaxisTickmarksLastLeft:null,xaxisTickmarksLastRight:null,xaxisTickmarksCount:null,xaxisLabels:null,xaxisLabelsSize:null,xaxisLabelsFont:null,xaxisLabelsItalic:null,xaxisLabelsBold:null,xaxisLabelsColor:null,xaxisLabelsFormattedDecimals:0,xaxisLabelsFormattedPoint:'.',xaxisLabelsFormattedThousand:',',xaxisLabelsFormattedUnitsPre:'',xaxisLabelsFormattedUnitsPost:'',xaxisLabelsOffsetx:0,xaxisLabelsOffsety:0,xaxisLabelsHalign:null,xaxisLabelsValign:null,xaxisLabelsPosition:'section',xaxisLabelsSpecificAlign:'left',xaxisPosition:'bottom',xaxisLabelsAngle:0,xaxisTitle:'',xaxisTitleBold:null,xaxisTitleSize:null,xaxisTitleFont:null,xaxisTitleColor:null,xaxisTitleItalic:null,xaxisTitlePos:null,xaxisTitleOffsetx:0,xaxisTitleOffsety:0,xaxisTitleX:null,xaxisTitleY:null,xaxisTitleHalign:null,xaxisTitleValign:null,textItalic:false,textBold:false,textColor:'black',textSize:12,textFont:'Arial, Verdana, sans-serif',textAccessible:true,textAccessibleOverflow:'visible',textAccessiblePointerevents:false,title:'',titleX:null,titleY:null,titleHalign:null,titleValign:null,titleBackground:null,titleHpos:null,titleVpos:null,titleFont:null,titleSize:null,titleColor:null,titleBold:null,titleItalic:null,titleOffsetx:0,titleOffsety:0,colorsStroke:'rgba(0,0,0,0)',colors:['red','#0f0','blue','pink','orange','cyan','black','white','green','magenta'],colorsSequential:false,colorsReverse:false,grouping:'grouped',variant:'bar',variantSketchVerticals:true,variantThreedXaxis:true,variantThreedYaxis:true,variantThreedAngle:0.1,variantThreedOffsetx:10,variantThreedOffsety:5,shadow:false,shadowColor:'#aaa',shadowOffsetx:0,shadowOffsety:0,shadowBlur:15,tooltips:null,tooltipsEffect:'slide',tooltipsCssClass:'RGraph_tooltip',tooltipsCss:null,tooltipsEvent:'onclick',tooltipsHighlight:true,tooltipsHotspotXonly:false,tooltipsFormattedThousand:',',tooltipsFormattedPoint:'.',tooltipsFormattedDecimals:0,tooltipsFormattedUnitsPre:'',tooltipsFormattedUnitsPost:'',tooltipsFormattedKeyColors:null,tooltipsFormattedKeyColorsShape:'square',tooltipsFormattedKeyLabels:[],tooltipsFormattedListType:'ul',tooltipsFormattedListItems:null,tooltipsFormattedTableHeaders:null,tooltipsFormattedTableData:null,tooltipsPointer:true,tooltipsPositionStatic:true,highlightStroke:'rgba(0,0,0,0)',highlightFill:'rgba(255,255,255,0.7)',key:null,keyBackground:'white',keyPosition:'graph',keyShadow:false,keyShadowColor:'#666',keyShadowBlur:3,keyShadowOffsetx:2,keyShadowOffsety:2,keyPositionMarginBoxed:false,keyPositionX:null,keyPositionY:null,keyInteractive:false,keyInteractiveHighlightChartStroke:'black',keyInteractiveHighlightChartFill:'rgba(255,255,255,0.7)',keyInteractiveHighlightLabel:'rgba(255,0,0,0.2)',keyHalign:'right',keyColorShape:'square',keyRounded:true,keyLinewidth:1,keyColors:null,keyLabelsColor:null,keyLabelsSize:null,keyLabelsFont:null,keyLabelsBold:null,keyLabelsItalic:null,keyLabelsOffsetx:0,keyLabelsOffsety:0,contextmenu:null,crosshairs:false,crosshairsColor:'#333',crosshairsHline:true,crosshairsVline:true,linewidth:1,annotatable:false,annotatableLinewidth:1,annotatableColor:'black',adjustable:false,adjustableOnly:null,beveled:false,errorbars:false,errorbarsColor:'black',errorbarsCapped:true,errorbarsCappedWidth:14,errorbarsLinewidth:1,combinedEffect:null,combinedEffectOptions:null,combinedEffectCallback:null,corners:'square',cornersRoundRadius:10,clearto:'rgba(0,0,0,0)'}
if(!this.canvas){alert('[BAR] No canvas support');return;}
data=RGraph.stringsToNumbers(data);for(var i=0;i<data.length;++i){if(typeof data[i]==='object'&&!RGraph.isNull(data[i])){this.stackedOrGrouped=true;}}
var linear_data=RGraph.arrayLinearize(data);for(var i=0;i<linear_data.length;++i){this['$'+i]={};}
this.data=data;this.original_data=RGraph.arrayClone(data);this.coords=[];this.coords2=[];this.coordsText=[];this.data_arr=RGraph.arrayLinearize(this.data);var properties=this.properties;this.path=RGraph.pathObjectFunction;if(RGraph.Effects&&typeof RGraph.Effects.decorate==='function'){RGraph.Effects.decorate(this);}
this.responsive=RGraph.responsive;this.set=function(name)
{var value=typeof arguments[1]==='undefined'?null:arguments[1];if(name==='bevelled'){name='beveled';}
if(arguments.length===1&&typeof arguments[0]==='object'){for(i in arguments[0]){if(typeof i==='string'){this.set(i,arguments[0][i]);}}
return this;}
properties[name]=value;return this;};this.get=function(name)
{return properties[name];};this.draw=function()
{RGraph.fireCustomEvent(this,'onbeforedraw');if(!this.canvas.__rgraph_aa_translated__){this.context.translate(0.5,0.5);this.canvas.__rgraph_aa_translated__=true;}
if(typeof properties.backgroundImage==='string'){RGraph.drawBackgroundImage(this);}
if(properties.variant==='3d'){if(properties.textAccessible){}else{this.context.setTransform(1,properties.variantThreedAngle,0,1,0.5,0.5);}}
if(!this.colorsParsed){this.parseColors();this.colorsParsed=true;}
this.marginLeft=properties.marginLeft;this.marginRight=properties.marginRight;this.marginTop=properties.marginTop;this.marginBottom=properties.marginBottom;if((properties.variant=='pyramid'||properties.variant=='dot')&&typeof properties.tooltips=='object'&&properties.tooltips&&properties.tooltips.length>0){alert('[BAR] ('+this.id+') Sorry, tooltips are not supported with dot or pyramid charts');}
this.coords=[];this.coords2=[];this.coordsText=[];this.max=0;this.grapharea=this.canvas.height-this.marginTop-this.marginBottom;this.halfgrapharea=this.grapharea/2;this.halfTextHeight=properties.textSize/2;RGraph.Background.draw(this);this.drawbars();this.drawAxes();this.drawLabels();if(properties.beveled||properties.beveled){this.drawBevel();}
if(properties.key&&properties.key.length){RGraph.drawKey(this,properties.key,properties.colors);}
if(properties.contextmenu){RGraph.showContext(this);}
if(properties.errorbars){this.drawErrorbars();}
if(properties.labelsIngraph){RGraph.drawInGraphLabels(this);}
RGraph.installEventListeners(this);if(this.firstDraw){this.firstDraw=false;RGraph.fireCustomEvent(this,'onfirstdraw');this.firstDrawFunc();}
RGraph.fireCustomEvent(this,'ondraw');return this;};this.exec=function(func)
{func(this);return this;};this.drawAxes=function()
{if(RGraph.ISSAFARI==-1){this.context.lineCap='square';}
if(properties.xaxisLabels&&properties.xaxisLabels.length){if(typeof properties.xaxisLabels==='string'){properties.xaxisLabels=RGraph.arrayPad({array:[],length:this.data.length,value:properties.xaxisLabels});}
for(var i=0;i<properties.xaxisLabels.length;++i){properties.xaxisLabels[i]=RGraph.labelSubstitution({object:this,text:properties.xaxisLabels[i],index:i,value:this.data[i],decimals:properties.xaxisLabelsFormattedDecimals||0,unitsPre:properties.xaxisLabelsFormattedUnitsPre||'',unitsPost:properties.xaxisLabelsFormattedUnitsPost||'',thousand:properties.xaxisLabelsFormattedThousand||',',point:properties.xaxisLabelsFormattedPoint||'.'});}}
RGraph.drawXAxis(this);RGraph.drawYAxis(this);};this.drawbars=function()
{this.context.lineWidth=properties.linewidth;this.context.strokeStyle=properties.colorsStroke;this.context.fillStyle=properties.colors[0];var prevX=0,prevY=0,decimals=properties.yaxisScaleDecimals;if(properties.yaxisScaleMax){this.scale2=RGraph.getScale({object:this,options:{'scale.max':properties.yaxisScaleMax,'scale.strict':properties.yaxisScaleRound?false:true,'scale.min':properties.yaxisScaleMin,'scale.thousand':properties.yaxisScaleThousand,'scale.point':properties.yaxisScalePoint,'scale.decimals':properties.yaxisScaleDecimals,'scale.labels.count':properties.yaxisLabelsCount,'scale.round':properties.yaxisScaleRound,'scale.units.pre':properties.yaxisScaleUnitsPre,'scale.units.post':properties.yaxisScaleUnitsPost,'scale.formatter':properties.yaxisScaleFormatter}});}else{var errorbars=properties.errorbars;if(typeof errorbars==='number'){var value=errorbars;properties.errorbars=[];for(var i=0;i<this.data.length;++i){if(typeof this.data[i]==='number'){properties.errorbars.push([value,null]);}else if(typeof this.data[i]==='object'&&!RGraph.isNull(this.data[i])){for(var j=0;j<this.data[i].length;++j){properties.errorbars.push([value,null]);}}}
errorbars=properties.errorbars;}
for(i=0;i<this.data.length;++i){if(typeof this.data[i]=='object'){var value=properties.grouping==='grouped'?Number(RGraph.arrayMax(this.data[i],true)):Number(RGraph.arraySum(this.data[i]));}else{var value=Number(this.data[i]);}
this.max=Math.max(Math.abs(this.max),Math.abs(value)+
Number((typeof properties.errorbars==='object'&&typeof properties.errorbars[i]==='object'&&!RGraph.isNull(properties.errorbars[i])&&typeof properties.errorbars[i][0]==='number')?properties.errorbars[i][0]:0));}
this.scale2=RGraph.getScale({object:this,options:{'scale.max':this.max,'scale.min':properties.yaxisScaleMin,'scale.thousand':properties.yaxisScaleThousand,'scale.point':properties.yaxisScalePoint,'scale.decimals':properties.yaxisScaleDecimals,'scale.labels.count':properties.yaxisLabelsCount,'scale.round':properties.yaxisScaleRound,'scale.units.pre':properties.yaxisScaleUnitsPre,'scale.units.post':properties.yaxisScaleUnitsPost,'scale.formatter':properties.yaxisScaleFormatter}});this.max=this.scale2.max;}
if(properties.adjustable&&!properties.yaxisScaleMax){this.set('yaxisScaleMax',this.scale2.max);}
if(properties.backgroundHbars&&properties.backgroundHbars.length>0){RGraph.drawBars(this);}
var variant=properties.variant;if(variant==='3d'){RGraph.draw3DAxes(this);}
var xaxispos=properties.xaxisPosition,width=(this.canvas.width-this.marginLeft-this.marginRight)/this.data.length,orig_height=height,hmargin=properties.marginInner,shadow=properties.shadow,shadowColor=properties.shadowColor,shadowBlur=properties.shadowBlur,shadowOffsetX=properties.shadowOffsetx,shadowOffsetY=properties.shadowOffsety,strokeStyle=properties.colorsStroke,colors=properties.colors,sequentialColorIndex=0
var height;for(i=0,len=this.data.length;i<len;i+=1){if(RGraph.arraySum(this.data[i])<0){var height=(RGraph.arraySum(this.data[i])+this.scale2.min)/(this.scale2.max-this.scale2.min);}else{var height=(RGraph.arraySum(this.data[i])-this.scale2.min)/(this.scale2.max-this.scale2.min);}
height*=Math.abs(this.getYCoord(this.scale2.max)-this.getYCoord(this.scale2.min));var x=(i*width)+this.marginLeft;var y=xaxispos=='center'?((this.canvas.height-this.marginTop-this.marginBottom)/2)+this.marginTop-height:this.canvas.height-height-this.marginBottom;if(xaxispos=='top'){y=this.marginTop;}
if(height<0){y+=height;height=Math.abs(height);}
if(shadow){this.context.shadowColor=shadowColor;this.context.shadowBlur=shadowBlur;this.context.shadowOffsetX=shadowOffsetX;this.context.shadowOffsetY=shadowOffsetY;}
this.context.beginPath();if(typeof this.data[i]=='number'){if(xaxispos==='bottom'&&properties.yaxisScaleMin<0){if(this.data[i]>=0){height=Math.abs(this.getYCoord(0)-this.getYCoord(this.data[i]));}else{y=this.getYCoord(0);height=Math.abs(this.getYCoord(0)-this.getYCoord(this.data[i]));}}
var barWidth=width-(2*hmargin);if(barWidth<0){alert('[RGRAPH] Warning: you have a negative bar width. This may be caused by the marginInner being too high or the width of the canvas not being sufficient.');}
this.context.strokeStyle=strokeStyle;this.context.fillStyle=colors[0];if(properties.colorsSequential){this.context.fillStyle=colors[i];}
if(variant=='sketch'){this.context.lineCap='round';var sketchOffset=3;this.context.beginPath();this.context.strokeStyle=colors[0];if(properties.colorsSequential){this.context.strokeStyle=colors[i];}
this.context.moveTo(x+hmargin+2,y+height-2);this.context.lineTo(x+hmargin-1,y-4);this.context.moveTo(x+hmargin-3,y+ -2+(this.data[i]<0?height:0));this.context.quadraticCurveTo(x+hmargin+((width-hmargin-hmargin)/4),y+0+(this.data[i]<0?height:0)+(this.data[i]>0?10:-10),x+hmargin+width+ -1-hmargin-hmargin,y+0+(this.data[i]<0?height:0));this.context.moveTo(x+hmargin+width-5-hmargin-hmargin,y-5);this.context.lineTo(x+hmargin+width-3-hmargin-hmargin,y+height-3);if(properties.variantSketchVerticals){for(var r=0.2;r<=0.8;r+=0.2){this.context.moveTo(x+hmargin+((width-hmargin-hmargin)*r),y-1);this.context.lineTo(x+hmargin+((width-hmargin-hmargin)*r),y+height+(r==0.2?1:-2));}}
this.context.stroke();}else if(variant=='bar'||variant=='3d'||variant=='glass'||variant=='bevel'){if(variant=='glass'){RGraph.roundedRect({context:this.context,x:x+hmargin,y:y,width:barWidth,height:height,radius:5,roundtl:this.data[i]>0,roundtr:this.data[i]>0,roundbl:this.data[i]<0,roundbr:this.data[i]<0});this.context.stroke();this.context.fill();}else{if(properties.corners==='round'){this.context.beginPath();this.context.lineCap='miter';this.context.lineJoin='square';this.roundedCornersRect(x+hmargin,y,barWidth,height);(x+hmargin,y,barWidth,height);this.context.stroke();this.context.fill();}else{this.context.beginPath();this.context.lineJoin='miter';this.context.lineCap='square';this.context.rect(x+hmargin,y,barWidth,height);this.context.stroke();this.context.fill();}}
if(variant=='3d'){var prevStrokeStyle=this.context.strokeStyle;var prevFillStyle=this.context.fillStyle;if(this.data[i]>=0){this.context.beginPath();this.context.moveTo(x+hmargin,y);this.context.lineTo(x+hmargin+properties.variantThreedOffsetx,y-properties.variantThreedOffsety);this.context.lineTo(x+hmargin+properties.variantThreedOffsetx+barWidth,y-properties.variantThreedOffsety);this.context.lineTo(x+hmargin+barWidth,y);this.context.closePath();this.context.stroke();this.context.fill();}
this.context.beginPath();this.context.moveTo(x+hmargin+barWidth,y);this.context.lineTo(x+hmargin+barWidth+properties.variantThreedOffsetx,this.data[i]<0&&xaxispos==='bottom'?this.getYCoord(0):(this.data[i]<0&&(y-properties.variantThreedOffsety)<(this.marginTop+this.halfgrapharea)?(this.marginTop+this.halfgrapharea):(y-properties.variantThreedOffsety)));this.context.lineTo(x+hmargin+barWidth+properties.variantThreedOffsetx,this.data[i]<0&&(y-properties.variantThreedOffsety+height)<(this.marginTop+this.getYCoord(0))?this.getYCoord(this.data[i])-properties.variantThreedOffsety:(this.data[i]>0?y-properties.variantThreedOffsety+height:Math.min(y-properties.variantThreedOffsety+height,this.canvas.height-this.marginBottom)));this.context.lineTo(x+hmargin+barWidth,y+height);this.context.closePath();this.context.stroke();this.context.fill();if(this.data[i]>0){this.context.beginPath();this.context.fillStyle='rgba(255,255,255,0.5)';this.context.moveTo(x+hmargin,y);this.context.lineTo(x+hmargin+properties.variantThreedOffsetx,y-properties.variantThreedOffsety);this.context.lineTo(x+hmargin+properties.variantThreedOffsetx+barWidth,y-properties.variantThreedOffsety);this.context.lineTo(x+hmargin+barWidth,y);this.context.lineTo(x+hmargin,y);this.context.closePath();this.context.stroke();this.context.fill();}
this.context.beginPath();this.context.fillStyle='rgba(0,0,0,0.4)';this.context.moveTo(x+hmargin+barWidth,y);this.context.lineTo(x+hmargin+barWidth+properties.variantThreedOffsetx,this.data[i]<0&&xaxispos==='bottom'?this.getYCoord(0):(this.data[i]<0&&(y-properties.variantThreedOffsety)<(this.marginTop+this.halfgrapharea)?(this.marginTop+this.halfgrapharea):y-properties.variantThreedOffsety));this.context.lineTo(x+hmargin+barWidth+properties.variantThreedOffsetx,this.data[i]<0&&(y-properties.variantThreedOffsety+height)<this.getYCoord(0)?this.getYCoord(0):this.data[i]>0?y-properties.variantThreedOffsety+height:Math.min(y-properties.variantThreedOffsety+height,this.canvas.height-this.marginBottom));this.context.lineTo(x+hmargin+barWidth,y+height);this.context.lineTo(x+hmargin+barWidth,y);this.context.closePath();this.context.stroke();this.context.fill();this.context.strokeStyle=prevStrokeStyle;this.context.fillStyle=prevFillStyle;}else if(variant=='glass'){var grad=this.context.createLinearGradient(x+hmargin,y,x+hmargin+(barWidth/2),y);grad.addColorStop(0,'rgba(255,255,255,0.9)');grad.addColorStop(1,'rgba(255,255,255,0.5)');this.context.beginPath();this.context.fillStyle=grad;this.context.rect(x+hmargin+3,y+(this.data[i]>0?3:0),(barWidth/2)-2,height-2);this.context.fill();}}else if(variant=='dot'){this.context.beginPath();this.context.strokeStyle=this.properties.colors[0];this.context.moveTo(x+(width/2),y);this.context.lineTo(x+(width/2),y+height);this.context.stroke();this.context.beginPath();this.context.fillStyle=this.properties.colors[i];this.context.arc(x+(width/2),y+(this.data[i]>0?0:height),2,0,6.28,0);this.context.fillStyle=properties.colors[0];if(properties.colorsSequential){this.context.fillStyle=colors[i];}
this.context.stroke();this.context.fill();}else{alert('[BAR] Warning! Unknown variant: '+variant);}
this.coords.push([x+hmargin,y,width-(2*hmargin),height]);if(typeof this.coords2[i]=='undefined'){this.coords2[i]=[];}
this.coords2[i].push([x+hmargin,y,width-(2*hmargin),height]);}else if(this.data[i]&&typeof this.data[i]=='object'&&properties.grouping=='stacked'){if(this.scale2.min){alert("[ERROR] Stacked Bar charts with a Y min are not supported");}
var barWidth=width-(2*hmargin);var redrawCoords=[];var startY=0;var dataset=this.data[i];if(barWidth<0){alert('[RGRAPH] Warning: you have a negative bar width. This may be caused by the marginInner being too high or the width of the canvas not being sufficient.');}
for(j=0;j<dataset.length;++j){if(xaxispos=='center'){alert("[BAR] It's pointless having the X axis position at the center on a stacked bar chart.");return;}
if(this.data[i][j]<0){alert('[BAR] Negative values are not permitted with a stacked bar chart. Try a grouped one instead.');return;}
this.context.strokeStyle=strokeStyle
this.context.fillStyle=colors[j];if(properties.colorsReverse){this.context.fillStyle=colors[this.data[i].length-j-1];}
if(properties.colorsSequential&&colors[sequentialColorIndex]){this.context.fillStyle=colors[sequentialColorIndex++];}else if(properties.colorsSequential){this.context.fillStyle=colors[sequentialColorIndex-1];}
var height=(dataset[j]/this.scale2.max)*(this.canvas.height-this.marginTop-this.marginBottom);if(xaxispos=='center'){height/=2;}
var totalHeight=(RGraph.arraySum(dataset)/this.scale2.max)*(this.canvas.height-hmargin-this.marginTop-this.marginBottom);this.coords.push([x+hmargin,y,width-(2*hmargin),height]);if(typeof this.coords2[i]=='undefined'){this.coords2[i]=[];}
this.coords2[i].push([x+hmargin,y,width-(2*hmargin),height]);if(height>0){if(j===0&&properties.corners==='round'){this.context.beginPath();this.context.lineCap='miter';this.context.lineJoin='square';this.roundedCornersRect(x+hmargin,y,width-(2*hmargin),height);this.context.stroke();this.context.fill();}else{this.path('b lj % lc % r % % % % s % f %','miter','square',x+hmargin,y,width-(2*hmargin),height,this.context.strokeStyle,this.context.fillStyle);}}
if(j==0){var startY=y;var startX=x;}
if(shadow){redrawCoords.push([x+hmargin,y,width-(2*hmargin),height,this.context.fillStyle]);}
if(variant=='3d'){var prevFillStyle=this.context.fillStyle;var prevStrokeStyle=this.context.strokeStyle;if(j==0){this.context.beginPath();this.context.moveTo(startX+hmargin,y);this.context.lineTo(startX+properties.variantThreedOffsetx+hmargin,y-properties.variantThreedOffsety);this.context.lineTo(startX+properties.variantThreedOffsetx+barWidth+hmargin,y-properties.variantThreedOffsety);this.context.lineTo(startX+barWidth+hmargin,y);this.context.closePath();this.context.fill();this.context.stroke();}
this.context.beginPath();this.context.moveTo(startX+barWidth+hmargin,y);this.context.lineTo(startX+barWidth+hmargin+properties.variantThreedOffsetx,y-properties.variantThreedOffsety);this.context.lineTo(startX+barWidth+hmargin+properties.variantThreedOffsetx,y-properties.variantThreedOffsety+height);this.context.lineTo(startX+barWidth+hmargin,y+height);this.context.closePath();this.context.fill();this.context.stroke();if(j==0){this.context.fillStyle='rgba(255,255,255,0.5)';this.context.beginPath();this.context.moveTo(startX+hmargin,y);this.context.lineTo(startX+properties.variantThreedOffsetx+hmargin,y-properties.variantThreedOffsety);this.context.lineTo(startX+properties.variantThreedOffsetx+barWidth+hmargin,y-properties.variantThreedOffsety);this.context.lineTo(startX+barWidth+hmargin,y);this.context.closePath();this.context.fill();this.context.stroke();}
this.context.fillStyle='rgba(0,0,0,0.4)';this.context.beginPath();this.context.moveTo(startX+barWidth+hmargin,y);this.context.lineTo(startX+barWidth+hmargin+properties.variantThreedOffsetx,y-properties.variantThreedOffsety);this.context.lineTo(startX+barWidth+hmargin+properties.variantThreedOffsetx,y-properties.variantThreedOffsety+height);this.context.lineTo(startX+barWidth+hmargin,y+height);this.context.closePath();this.context.fill();this.context.stroke();this.context.strokeStyle=prevStrokeStyle;this.context.fillStyle=prevFillStyle;}
y+=height;}
if(shadow){RGraph.noShadow(this);for(k=0;k<redrawCoords.length;++k){this.context.strokeStyle=strokeStyle;this.context.fillStyle=redrawCoords[k][4];this.context.strokeRect(redrawCoords[k][0],redrawCoords[k][1],redrawCoords[k][2],redrawCoords[k][3]);this.context.fillRect(redrawCoords[k][0],redrawCoords[k][1],redrawCoords[k][2],redrawCoords[k][3]);this.context.stroke();this.context.fill();}
redrawCoords=[];}}else if(this.data[i]&&typeof this.data[i]=='object'&&properties.grouping=='grouped'){var redrawCoords=[];this.context.lineWidth=properties.linewidth;for(j=0;j<this.data[i].length;++j){this.context.strokeStyle=strokeStyle;this.context.fillStyle=colors[j];if(properties.colorsSequential&&colors[sequentialColorIndex]){this.context.fillStyle=colors[sequentialColorIndex++];}else if(properties.colorsSequential){this.context.fillStyle=colors[sequentialColorIndex-1];}
var individualBarWidth=(width-(2*hmargin))/this.data[i].length;var height=((this.data[i][j]+(this.data[i][j]<0?this.scale2.min:(-1*this.scale2.min)))/(this.scale2.max-this.scale2.min))*(this.canvas.height-this.marginTop-this.marginBottom);var groupedMargin=properties.marginInnerGrouped;var startX=x+hmargin+(j*individualBarWidth);if(individualBarWidth<0){alert('[RGRAPH] Warning: you have a negative bar width. This may be caused by the marginInner being too high or the width of the canvas not being sufficient.');}
if(xaxispos=='center'){height/=2;}
if(xaxispos=='top'){var startY=this.marginTop;var height=Math.abs(height);}else if(xaxispos=='center'){var startY=this.marginTop+(this.grapharea/2)-height;}else{var startY=this.getYCoord(0);var height=Math.abs(Math.abs(this.getYCoord(this.data[i][j]))-this.getYCoord(0));if(this.data[i][j]>=0){startY-=height;}}
if(properties.corners==='round'){this.context.beginPath();this.context.lineCap='miter';this.context.lineJoin='square';this.roundedCornersRect(startX+groupedMargin,startY,individualBarWidth-(2*groupedMargin),height);this.context.stroke();this.context.fill();}else{this.context.beginPath();this.context.lineJoin='miter';this.context.lineCap='square';this.context.rect(startX+groupedMargin,startY,individualBarWidth-(2*groupedMargin),height);this.context.stroke();this.context.fill();}
y+=height;if(variant=='3d'){var prevFillStyle=this.context.fillStyle;var prevStrokeStyle=this.context.strokeStyle;var hmarginGrouped=properties.marginInnerGrouped;if(this.data[i][j]>=0){this.context.beginPath();this.context.moveTo(startX+hmarginGrouped,startY);this.context.lineTo(startX+hmarginGrouped+properties.variantThreedOffsetx,startY-properties.variantThreedOffsety);this.context.lineTo(startX+properties.variantThreedOffsetx+individualBarWidth-hmarginGrouped,startY-properties.variantThreedOffsety);this.context.lineTo(startX+individualBarWidth-hmarginGrouped,startY);this.context.closePath();this.context.fill();this.context.stroke();}
this.context.beginPath();this.context.moveTo(startX+individualBarWidth-hmarginGrouped-1,startY);this.context.lineTo(startX+individualBarWidth-hmarginGrouped+properties.variantThreedOffsetx,this.data[i][j]<0?(this.getYCoord(0)+Math.abs(height)-properties.variantThreedOffsety)-(properties.xaxisPosition==='center'?0:Math.abs(height)-this.properties.variantThreedOffsety):this.getYCoord(0)-height-properties.variantThreedOffsety);this.context.lineTo(startX+individualBarWidth-hmarginGrouped+properties.variantThreedOffsetx,this.data[i][j]<0&&(startY+height-properties.variantThreedOffsety)<this.getYCoord(0)?(this.getYCoord(0)):(startY+height-properties.variantThreedOffsety));this.context.lineTo(startX+individualBarWidth-hmarginGrouped-1,startY+height);this.context.closePath();this.context.fill();this.context.stroke();if(this.data[i][j]>=0){this.context.fillStyle='rgba(255,255,255,0.5)';this.context.beginPath();this.context.moveTo(startX+hmarginGrouped,startY);this.context.lineTo(startX+hmarginGrouped+properties.variantThreedOffsetx,startY-properties.variantThreedOffsety);this.context.lineTo(startX+properties.variantThreedOffsetx+individualBarWidth-hmarginGrouped,startY-properties.variantThreedOffsety);this.context.lineTo(startX+individualBarWidth-hmarginGrouped,startY);this.context.closePath();this.context.fill();this.context.stroke();}
this.context.fillStyle='rgba(0,0,0,0.4)';this.context.beginPath();this.context.moveTo(startX+individualBarWidth-hmarginGrouped,startY);this.context.lineTo(startX+individualBarWidth+properties.variantThreedOffsetx-hmarginGrouped,this.data[i][j]<0?(this.getYCoord(0)+Math.abs(height)-properties.variantThreedOffsety)-(properties.xaxisPosition==='center'?0:Math.abs(height)-this.properties.variantThreedOffsety):this.getYCoord(0)-height-properties.variantThreedOffsety);this.context.lineTo(startX+individualBarWidth+properties.variantThreedOffsetx-hmarginGrouped,+this.data[i][j]<0&&(startY+height-5)<this.getYCoord(0)?((height>this.properties.variantThreedOffsety)?this.getYCoord(0)+height-this.properties.variantThreedOffsety:this.getYCoord(0)):(startY+height-properties.variantThreedOffsety));this.context.lineTo(startX+individualBarWidth-hmarginGrouped,startY+height);this.context.closePath();this.context.fill();this.context.stroke();this.context.strokeStyle=prevStrokeStyle;this.context.fillStyle=prevFillStyle;}
if(height<0){height=Math.abs(height);startY=startY-height;}
this.coords.push([startX+groupedMargin,startY,individualBarWidth-(2*groupedMargin),height]);if(typeof this.coords2[i]=='undefined'){this.coords2[i]=[];}
this.coords2[i].push([startX+groupedMargin,startY,individualBarWidth-(2*groupedMargin),height]);if(properties.shadow){redrawCoords.push([startX+groupedMargin,startY,individualBarWidth-(2*groupedMargin),height,this.context.fillStyle]);}}
if(redrawCoords.length){RGraph.noShadow(this);this.context.lineWidth=properties.linewidth;this.context.beginPath();for(var j=0;j<redrawCoords.length;++j){this.context.fillStyle=redrawCoords[j][4];this.context.strokeStyle=properties.colorsStroke;this.context.fillRect(redrawCoords[j][0],redrawCoords[j][1],redrawCoords[j][2],redrawCoords[j][3]);this.context.strokeRect(redrawCoords[j][0],redrawCoords[j][1],redrawCoords[j][2],redrawCoords[j][3]);}
this.context.fill();this.context.stroke();redrawCoords=[];}}else{this.coords.push([]);}
this.context.closePath();}
if(properties.variant==='3d'&&properties.yaxisPosition==='right'){RGraph.draw3DYAxis(this);}
RGraph.noShadow(this);};this.drawLabels=function()
{this.drawAboveLabels();};this.getShape=function(e)
{var obj=arguments[1]?arguments[1]:this;var mouseXY=RGraph.getMouseXY(e),mouseX=mouseXY[0],mouseY=mouseXY[1],canvas=obj.canvas,context=obj.context,coords=obj.coords
for(var i=0,len=coords.length;i<len;i+=1){if(obj.coords[i].length==0){continue;}
var left=coords[i][0],top=coords[i][1],width=coords[i][2],height=coords[i][3];if(properties.tooltipsHotspotXonly){this.path('b r % % % %',left,this.marginTop,width,this.canvas.height-this.marginBottom);}else{var indexes=RGraph.sequentialIndexToGrouped(i,this.data);if(properties.grouping==='stacked'&&properties.corners==='round'&&indexes[1]===0){this.context.beginPath();this.roundedCornersRect(left,top,width,height);}else{this.path('b r % % % %',left,top,width,height);}}
if(this.context.isPointInPath(mouseX,mouseY)){if(properties.tooltips&&RGraph.parseTooltipText){var tooltip=RGraph.parseTooltipText(properties.tooltips,i);}
var dataset=0,idx=i
while(idx>=(typeof obj.data[dataset]==='object'&&obj.data[dataset]?obj.data[dataset].length:1)){if(typeof obj.data[dataset]==='number'){idx-=1;}else if(obj.data[dataset]){idx-=obj.data[dataset].length;}else{idx-=1;}
dataset++;}
if(typeof obj.data[dataset]=='number'){idx=0;}
return{object:this,x:left,y:top,width:width,height:height,tooltip:typeof tooltip==='string'?tooltip:null,label:properties.xaxisLabels&&typeof properties.xaxisLabels[dataset]==='string'?properties.xaxisLabels[dataset]:null,dataset:dataset,index:idx,sequentialIndex:i};}}
return null;};this.getShapeByX=function(e)
{var canvas=e.target;var mouseCoords=RGraph.getMouseXY(e);var obj=arguments[1]?arguments[1]:this;for(var i=0,len=obj.coords.length;i<len;i++){if(obj.coords[i].length==0){continue;}
var mouseX=mouseCoords[0];var mouseY=mouseCoords[1];var left=obj.coords[i][0];var top=obj.coords[i][1];var width=obj.coords[i][2];var height=obj.coords[i][3];if(mouseX>=left&&mouseX<=(left+width)){if(properties.tooltips){var tooltip=RGraph.parseTooltipText?RGraph.parseTooltipText(properties.tooltips,i):properties.tooltips[i];}
var indexes=RGraph.sequentialIndexToGrouped(i,this.data);return{object:obj,x:left,y:top,width:width,height:height,dataset:indexes[0],index:indexes[1],sequentialIndex:i,tooltip:typeof tooltip==='string'?tooltip:null};}}
return null;};this.getValue=function(arg)
{if(arg.length==2){var mouseX=arg[0];var mouseY=arg[1];}else{var mouseCoords=RGraph.getMouseXY(arg);var mouseX=mouseCoords[0];var mouseY=mouseCoords[1];}
if(mouseY<properties.marginTop||mouseY>(this.canvas.height-properties.marginBottom)||mouseX<properties.marginLeft||mouseX>(this.canvas.width-properties.marginRight)){return null;}
if(properties.xaxisPosition=='center'){var value=(((this.grapharea/2)-(mouseY-properties.marginTop))/this.grapharea)*(this.scale2.max-this.scale2.min)
value*=2;if(value>=0){value+=this.scale2.min;}else{value-=this.scale2.min;}}else if(properties.xaxisPosition=='top'){var value=((this.grapharea-(mouseY-properties.marginTop))/this.grapharea)*(this.scale2.max-this.scale2.min)
value=this.scale2.max-value;value=Math.abs(value)* -1;}else{var value=((this.grapharea-(mouseY-properties.marginTop))/this.grapharea)*(this.scale2.max-this.scale2.min)
value+=this.scale2.min;}
return value;};this.getYCoord=function(value)
{if(value>this.scale2.max){return null;}
var y,xaxispos=properties.xaxisPosition;if(xaxispos=='top'){if(value<0){value=Math.abs(value);}
y=((value-this.scale2.min)/(this.scale2.max-this.scale2.min))*this.grapharea;y=y+this.marginTop}else if(xaxispos=='center'){y=((value-this.scale2.min)/(this.scale2.max-this.scale2.min))*(this.grapharea/2);y=(this.grapharea/2)-y;y+=this.marginTop;}else{if(value<this.scale2.min){value=this.scale2.min;}
y=((value-this.scale2.min)/(this.scale2.max-this.scale2.min));y*=(this.canvas.height-this.marginTop-this.marginBottom);y=this.canvas.height-this.marginBottom-y;}
return y;};this.highlight=function(shape)
{if(typeof properties.highlightStyle==='function'){(properties.highlightStyle)(shape);}else if(typeof properties.highlightStyle==='string'&&properties.highlightStyle==='invert'){for(var i=0;i<this.coords.length;++i){if(i!==shape.sequentialIndex){this.path('b r % % % % s % f %',this.coords[i][0],this.coords[i][1],this.coords[i][2],this.coords[i][3],properties.highlightStroke,properties.highlightFill);}}}else{if(properties.grouping==='stacked'&&shape.index===0){this.context.beginPath();this.context.strokeStyle=properties.highlightStroke;this.context.fillStyle=properties.highlightFill;if(properties.corners==='round'){this.roundedCornersRect(shape.x,shape.y,shape.width,shape.height);}else{this.context.rect(shape.x,shape.y,shape.width,shape.height);}
this.context.stroke();this.context.fill();}else{RGraph.Highlight.rect(this,shape);}}};this.getObjectByXY=function(e)
{var mouseXY=RGraph.getMouseXY(e);var shape=this.getShape(e);if(properties.variant==='3d'&&!properties.textAccessible){var adjustment=properties.variantThreedAngle*mouseXY[0];mouseXY[1]-=adjustment;}
if(mouseXY[0]>=properties.marginLeft&&mouseXY[0]<=(this.canvas.width-properties.marginRight)&&mouseXY[1]>=properties.marginTop&&mouseXY[1]<=(this.canvas.height-properties.marginBottom)){return this;}};this.adjusting_mousemove=function(e)
{if(properties.adjustable&&RGraph.Registry.get('adjusting')&&RGraph.Registry.get('adjusting').uid==this.uid){var value=Number(this.getValue(e));var shape=RGraph.Registry.get('adjusting.shape')
if(shape){RGraph.Registry.set('adjusting.shape',shape);if(this.stackedOrGrouped&&properties.grouping=='grouped'){var indexes=RGraph.sequentialIndexToGrouped(shape.sequentialIndex,this.data);if(typeof this.data[indexes[0]]=='number'){this.data[indexes[0]]=Number(value);}else if(!RGraph.isNull(this.data[indexes[0]])){this.data[indexes[0]][indexes[1]]=Number(value);}}else if(typeof this.data[shape.sequentialIndex]=='number'){this.data[shape.sequentialIndex]=Number(value);}
RGraph.redrawCanvas(e.target);RGraph.fireCustomEvent(this,'onadjust');}}};this.parseColors=function()
{if(this.original_colors.length===0){this.original_colors.colors=RGraph.arrayClone(properties.colors);this.original_colors.keyColors=RGraph.arrayClone(properties.keyColors);this.original_colors.crosshairsColor=properties.crosshairsColor;this.original_colors.highlightStroke=properties.highlightStroke;this.original_colors.highlightFill=properties.highlightFill;this.original_colors.textColor=properties.textColor;this.original_colors.backgroundBarsColor1=properties.backgroundBarsColor1;this.original_colors.backgroundBarsColor2=properties.backgroundBarsColor2;this.original_colors.backgroundGridColor=properties.backgroundGridColor;this.original_colors.backgroundColor=properties.backgroundColor;this.original_colors.colorsStroke=properties.colorsStroke;this.original_colors.axesColor=properties.axesColor;}
var colors=properties.colors;if(colors){for(var i=0;i<colors.length;++i){colors[i]=this.parseSingleColorForGradient(colors[i]);}}
var colors=properties.keyColors;if(colors){for(var i=0;i<colors.length;++i){colors[i]=this.parseSingleColorForGradient(colors[i]);}}
properties.crosshairsColor=this.parseSingleColorForGradient(properties.crosshairsColor);properties.highlightStroke=this.parseSingleColorForGradient(properties.highlightStroke);properties.highlightFill=this.parseSingleColorForGradient(properties.highlightFill);properties.textColor=this.parseSingleColorForGradient(properties.textColor);properties.backgroundBarsColor1=this.parseSingleColorForGradient(properties.backgroundBarsColor1);properties.backgroundBarsColor2=this.parseSingleColorForGradient(properties.backgroundBarsColor2);properties.backgroundGridColor=this.parseSingleColorForGradient(properties.backgroundGridColor);properties.backgroundColor=this.parseSingleColorForGradient(properties.backgroundColor);properties.colorStroke=this.parseSingleColorForGradient(properties.colorStroke);properties.axesColor=this.parseSingleColorForGradient(properties.axesColor);};this.reset=function()
{};this.parseSingleColorForGradient=function(color)
{if(!color||typeof color!='string'){return color;}
if(color.match(/^gradient\((.*)\)$/i)){if(color.match(/^gradient\(({.*})\)$/i)){return RGraph.parseJSONGradient({object:this,def:RegExp.$1});}
var parts=RegExp.$1.split(':');var grad=this.context.createLinearGradient(0,this.canvas.height-properties.marginBottom,0,properties.marginTop);var diff=1/(parts.length-1);grad.addColorStop(0,RGraph.trim(parts[0]));for(var j=1,len=parts.length;j<len;++j){grad.addColorStop(j*diff,RGraph.trim(parts[j]));}}
return grad?grad:color;};this.drawBevel=function()
{var coords=this.coords,coords2=this.coords2;if(properties.grouping=='stacked'){for(var i=0;i<coords2.length;++i){if(coords2[i]&&coords2[i][0]&&coords2[i][0][0]){var x=coords2[i][0][0];var y=coords2[i][0][1];var w=coords2[i][0][2];var arr=[];for(var j=0;j<coords2[i].length;++j){arr.push(coords2[i][j][3]);}
var h=RGraph.arraySum(arr);this.context.save();this.context.strokeStyle='black';this.context.beginPath();this.context.rect(x,y,w,h);this.context.clip();this.context.shadowColor='black';this.context.shadowOffsetX=0;this.context.shadowOffsetY=0;this.context.shadowBlur=20;this.context.beginPath();this.context.rect(x-3,y-3,w+6,h+100);this.context.lineWidth=5;this.context.stroke();this.context.restore();}}}else{for(var i=0;i<coords.length;++i){if(coords[i]){var x=coords[i][0];var y=coords[i][1];var w=coords[i][2];var h=coords[i][3];var xaxispos=properties.xaxisPosition;var xaxis_ycoord=((this.canvas.height-this.marginTop-this.marginBottom)/2)+this.marginTop;this.context.save();this.context.strokeStyle='black';this.context.beginPath();this.context.rect(x,y,w,h);this.context.clip();this.context.shadowColor='black';this.context.shadowOffsetX=0;this.context.shadowOffsetY=0;this.context.shadowBlur=20;if(xaxispos=='top'||(xaxispos=='center'&&(y+h)>xaxis_ycoord)){y=y-100;h=h+100;}else{y=y;h=h+100;}
this.context.beginPath();this.context.rect(x-3,y-3,w+6,h+6);this.context.lineWidth=5;this.context.stroke();this.context.restore();}}}};this.interactiveKeyHighlight=function(index)
{var obj=this;this.coords2.forEach(function(value,idx,arr)
{if(typeof value[index]=='object'&&value[index]){var x=value[index][0]-0.5,y=value[index][1]-0.5,w=value[index][2]+1,h=value[index][3]+1;obj.context.fillStyle=properties.keyInteractiveHighlightChartFill;obj.context.strokeStyle=properties.keyInteractiveHighlightChartStroke;obj.context.lineWidth=2;obj.context.strokeRect(x,y,w,h);obj.context.fillRect(x,y,w,h);}});};this.on=function(type,func)
{if(type.substr(0,2)!=='on'){type='on'+type;}
if(typeof this[type]!=='function'){this[type]=func;}else{RGraph.addCustomEventListener(this,type,func);}
return this;};this.drawLabelsAbove=this.drawAboveLabels=function()
{var labels=properties.labelsAbove,specific=properties.labelsAboveSpecific,bold=typeof properties.labelsAboveBold==='boolean'?properties.labelsAboveBold:properties.textBold,italic=typeof properties.labelsAboveItalic==='boolean'?properties.labelsAboveItalic:properties.textItalic,color=properties.labelsAboveColor||properties.textColor,font=properties.labelsAboveFont||properties.textFont,size=typeof properties.labelsAboveSize==='number'?properties.labelsAboveSize:properties.textSize,background=properties.labelsAboveBackground,decimals=properties.labelsAboveDecimals,angle=-1*properties.labelsAboveAngle,unitsPre=properties.labelsAboveUnitsPre,unitsPost=properties.labelsAboveUnitsPost,point=properties.labelsAbovePoint,thousand=properties.labelsAboveThousand,coords=this.coords,coords2=this.coords2,data=this.data,ldata=RGraph.arrayLinearize(this.data),offsetx=properties.labelsAboveOffsetx,offsety=properties.labelsAboveOffsety,text_italic=properties.textItalic,text_bold=properties.textBold,text_color=properties.textColor,text_font=properties.textFont,text_size=properties.textSize,grouping=properties.grouping;if(typeof properties.labelsAboveOffset==='number'){offsety=properties.labelsAboveOffset;}
var textConf=RGraph.getTextConf({object:this,prefix:'labelsAbove'});RGraph.noShadow(this);this.context.fillStyle=textConf.color;if(labels&&grouping==='grouped'){for(var i=0,len=data.length,sequentialIndex=0;i<len;i+=1){if(typeof data[i]==='number'&&data[i]>=0){var angle=angle;var halign=(angle?'left':'center');var valign=angle!==0?'center':'bottom';RGraph.text({object:this,font:textConf.font,size:textConf.size,color:textConf.color,bold:textConf.bold,italic:textConf.italic,x:coords2[i][0][0]+(coords2[i][0][2]/2)+offsetx,y:coords2[i][0][1]-offsety,text:specific?(specific[sequentialIndex]||''):RGraph.numberFormat({object:this,number:Number(typeof data[i]==='object'?data[i][0]:data[i]).toFixed(decimals),unitspre:unitsPre,unitspost:unitsPost,point:point,thousand:thousand}),halign:halign,valign:valign,angle:angle,marker:false,bounding:true,'bounding.fill':background,'bounding.stroke':'rgba(0,0,0,0)',tag:'labels.above'});sequentialIndex++;}else if(typeof data[i]==='number'&&data[i]<0){var angle=angle;var halign=angle?'right':'center';var valign=angle!==0?'center':'top';RGraph.text({object:this,font:textConf.font,size:textConf.size,color:textConf.color,bold:textConf.bold,italic:textConf.italic,x:coords2[i][0][0]+(coords2[i][0][2]/2)+offsetx,y:coords2[i][0][1]+coords2[i][0][3]+offsety,text:specific?(specific[sequentialIndex]||''):RGraph.numberFormat({object:this,number:Number(typeof data[i]==='object'?data[i][0]:data[i]).toFixed(decimals),unitspre:unitsPre,unitspost:unitsPost,point:point,thousand:thousand}),halign:halign,valign:valign,angle:angle,bounding:true,'bounding.fill':background,'bounding.stroke':'rgba(0,0,0,0)',marker:false,tag:'labels.above'});sequentialIndex++;}else if(typeof data[i]==='object'){for(var j=0,len2=data[i].length;j<len2;j+=1){var angle=angle;var halign=data[i][j]<0?'right':'left';halign=angle===0?'center':halign;var valign=data[i][j]<0?'top':'bottom';valign=angle!=0?'center':valign;RGraph.text({object:this,font:textConf.font,size:textConf.size,color:textConf.color,bold:textConf.bold,italic:textConf.italic,x:coords2[i][j][0]+(coords2[i][j][2]/2)+offsetx,y:properties.xaxisPosition==='top'?coords2[i][j][1]+coords2[i][j][3]+5:coords2[i][j][1]+(data[i][j]<0?coords2[i][j][3]+offsety:-offsety),text:specific?(specific[sequentialIndex]||''):RGraph.numberFormat({object:this,number:Number(data[i][j]).toFixed(decimals),unitspre:unitsPre,unitspost:unitsPost,point:point,thousand:thousand}),halign:halign,valign:properties.xaxisPosition==='top'?'top':valign,angle:angle,bounding:true,'bounding.fill':background,'bounding.stroke':'rgba(0,0,0,0)',marker:false,tag:'labels.above'});sequentialIndex++;}}}}else if(labels&&grouping==='stacked'){for(var i=0,len=data.length,sequentialIndex=0;i<len;i+=1){if(typeof data[i]==='object'){var angle=angle;var halign=angle!=0?'left':'center';var valign=angle!=0?'center':'bottom';RGraph.text({object:this,font:textConf.font,size:textConf.size,color:textConf.color,bold:textConf.bold,italic:textConf.italic,x:coords2[i][0][0]+(coords2[i][0][2]/2)+offsetx,y:coords2[i][0][1]+(data[i][0]<0?coords2[i][0][3]:0)-offsety,text:specific?(specific[sequentialIndex]||''):RGraph.numberFormat({object:this,number:Number(RGraph.arraySum(data[i])).toFixed(decimals),unitspre:unitsPre,unitspost:unitsPost,point:point,thousand:thousand}),halign:halign,valign:valign,angle:angle,bounding:true,'bounding.fill':background,'bounding.stroke':'rgba(0,0,0,0)',marker:false,tag:'labels.above'});sequentialIndex+=data[i].length;}else{var angle=angle;var halign=angle!=0?'left':'center';var valign=angle!=0?'center':'bottom';RGraph.text({object:this,font:textConf.font,size:textConf.size,color:textConf.color,bold:textConf.bold,italic:textConf.italic,x:coords2[i][0][0]+(coords2[i][0][2]/2)+offsetx,y:coords2[i][0][1]+(data[i][0]<0?coords2[i][0][3]:0)-offsety,text:specific?(specific[sequentialIndex]||''):RGraph.numberFormat({object:this,number:Number(data[i]).toFixed(decimals),unitspre:unitsPre,unitspost:unitsPost,point:point,thousand:thousand}),halign:halign,valign:valign,angle:angle,bounding:true,'bounding.fill':background,'bounding.stroke':'rgba(0,0,0,0)',marker:false,tag:'labels.above'});sequentialIndex++;}}}};this.firstDrawFunc=function()
{};this.wave=function()
{if(this.data.length===1){this.grow(arguments[0],arguments[1]);return;}
var obj=this,opt=arguments[0]||{},labelsAbove=this.get('labelsAbove');opt.frames=opt.frames||60;opt.startFrames=[];opt.counters=[];var framesperbar=opt.frames/3,frame=-1,callback=arguments[1]||function(){},original=RGraph.arrayClone(this.original_data);this.set('labelsAbove',false);for(var i=0,len=obj.data.length;i<len;i+=1){opt.startFrames[i]=((opt.frames/2)/(obj.data.length-1))*i;if(typeof obj.data[i]==='object'&&obj.data[i]){opt.counters[i]=[];for(var j=0;j<obj.data[i].length;j++){opt.counters[i][j]=0;}}else{opt.counters[i]=0;}}
obj.draw();obj.set('yaxisScaleMax',obj.scale2.max);RGraph.clear(obj.canvas);function iterator()
{++frame;for(var i=0,len=obj.data.length;i<len;i+=1){if(frame>opt.startFrames[i]){if(typeof obj.data[i]==='number'){obj.data[i]=Math.min(Math.abs(original[i]),Math.abs(original[i]*((opt.counters[i]++)/framesperbar)));if(original[i]<0){obj.data[i]*=-1;}}else if(!RGraph.isNull(obj.data[i])){for(var j=0,len2=obj.data[i].length;j<len2;j+=1){obj.data[i][j]=Math.min(Math.abs(original[i][j]),Math.abs(original[i][j]*((opt.counters[i][j]++)/framesperbar)));if(original[i][j]<0){obj.data[i][j]*=-1;}}}}else{obj.data[i]=typeof obj.data[i]==='object'&&obj.data[i]?RGraph.arrayPad([],obj.data[i].length,0):(RGraph.isNull(obj.data[i])?null:0);}}
if(frame>=opt.frames){if(labelsAbove){obj.set('labelsAbove',true);RGraph.redraw();}
callback(obj);}else{RGraph.redrawCanvas(obj.canvas);RGraph.Effects.updateCanvas(iterator);}}
iterator();return this;};this.colorwave=this.colorWave=function()
{var obj=this,opt=arguments[0]||{};opt.frames=opt.frames||60;opt.startFrames=[];opt.counters=[],colors=obj.properties.colors;if(colors.length<=obj.data.length){obj.set('colorsSequential',true);colors=RGraph.arrayPad(colors,obj.data.length,colors[colors.length-1]);}
var framesperbar=opt.frames/2,frame=-1,callback=arguments[1]||function(){},originalColors=RGraph.arrayClone(obj.properties.colors);for(var i=0,len=originalColors.length;i<len;i+=1){opt.startFrames[i]=((opt.frames/2)/(originalColors.length-1))*i;opt.counters[i]=0;}
function iterator()
{++frame;for(var i=0,len=colors.length;i<len;i+=1){if(frame>opt.startFrames[i]&&colors[i].match(/^rgba?\(([0-9 ]+),([0-9 ]+),([0-9 ]+)(,([ 0-9.]+)?)\)/)){colors[i]='rgba({1},{2},{3},{4})'.format(RegExp.$1,RegExp.$2,RegExp.$3,(frame-opt.startFrames[i])/framesperbar);}else{colors[i]=colors[i].replace(/,[0-9. ]+\)/,',0)');}}
if(frame>=opt.frames){callback(obj);}else{RGraph.redrawCanvas(obj.canvas);RGraph.Effects.updateCanvas(iterator);}}
iterator();return this;};this.grow=function()
{var opt=arguments[0]||{},frames=opt.frames||30,frame=0,callback=arguments[1]||function(){},obj=this,labelsAbove=this.get('labelsAbove');if(RGraph.isArray(opt.data)){var ymax=0;for(var i=0;i<opt.data.length;++i){if(typeof opt.data[i]==='object'){for(var j=0;j<opt.data[i].length;++j){if(typeof opt.data[i][j]==='string'&&opt.data[i][j].match(/(\+|\-)([0-9]+)/)){if(RegExp.$1==='+'){opt.data[i][j]=this.original_data[i][j]+parseInt(RegExp.$2);}else{opt.data[i][j]=this.original_data[i][j]-parseInt(RegExp.$2);}}
ymax=Math.max(ymax,opt.data[i][j]);}}else if(typeof opt.data[i]==='string'&&opt.data[i].match(/(\+|\-)([0-9]+)/)){if(RegExp.$1==='+'){opt.data[i]=this.original_data[i]+parseInt(RegExp.$2);}else{opt.data[i]=this.original_data[i]-parseInt(RegExp.$2);}
ymax=Math.max(ymax,opt.data[i]);}else{ymax=Math.max(ymax,opt.data[i]);}}
var scale=RGraph.getScale({object:this,options:{'scale.max':ymax}});if(typeof properties.yaxisScaleMax!=='number'){this.set('yaxisScaleMax',scale.max);}}
this.set('labelsAbove',false);if(properties.yaxisScaleMax==null){var ymax=0;for(var i=0;i<this.data.length;++i){if(RGraph.isArray(this.data[i])&&properties.grouping==='stacked'){ymax=Math.max(ymax,Math.abs(RGraph.arraySum(this.data[i])));}else if(RGraph.isArray(this.data[i])&&properties.grouping==='grouped'){for(var j=0,group=[];j<this.data[i].length;j++){group.push(Math.abs(this.data[i][j]));}
ymax=Math.max(ymax,Math.abs(RGraph.arrayMax(group)));}else{ymax=Math.max(ymax,Math.abs(this.data[i]));}}
var scale=RGraph.getScale({object:this,options:{'scale.max':ymax}});this.set('yaxisScaleMax',scale.max);}
if(typeof opt.ymax==='number'){this.set('yaxisScaleMax',opt.ymax);}
var iterator=function()
{var easingMultiplier=RGraph.Effects.getEasingMultiplier(frames,frame);for(var j=0,len=obj.original_data.length;j<len;++j){if(typeof obj.data[j]==='object'&&!RGraph.isNull(obj.data[j])){for(var k=0,len2=obj.data[j].length;k<len2;++k){if(obj.firstDraw||!opt.data){obj.data[j][k]=easingMultiplier*obj.original_data[j][k];}else if(opt.data&&opt.data.length===obj.original_data.length){var diff=opt.data[j][k]-obj.original_data[j][k];obj.data[j][k]=(easingMultiplier*diff)+obj.original_data[j][k];}}}else{if(obj.firstDraw||!opt.data){obj.data[j]=easingMultiplier*obj.original_data[j];}else if(opt.data&&opt.data.length===obj.original_data.length){var diff=opt.data[j]-obj.original_data[j];obj.data[j]=(easingMultiplier*diff)+obj.original_data[j];}}}
RGraph.redrawCanvas(obj.canvas);if(frame<frames){frame+=1;RGraph.Effects.updateCanvas(iterator);}else{if(RGraph.isArray(opt.data)){var linear_data=RGraph.arrayLinearize(data);for(var i=0;i<linear_data.length;++i){if(!obj['$'+i]){obj['$'+i]={};}}}
obj.data=data;obj.original_data=RGraph.arrayClone(data);if(labelsAbove){obj.set('labelsAbove',true);RGraph.redraw();}
callback(obj);}};iterator();return this;};this.drawErrorbars=function()
{var coords=this.coords,color=properties.errorbarsColor||'black',default_halfwidth=Math.min(properties.errorbarsCappedWidth,coords[0][2])/2,x=0,errorbars=properties.errorbars,length=0;if(!properties.errorbarsCapped){properties.errorbarsCappedWidth=0;halfwidth=0;}
this.context.lineWidth=properties.errorbarsLinewidth;for(var i=0;i<coords.length;++i){var barX=coords[i][0],barY=coords[i][1],barW=coords[i][2],barH=coords[i][3];var groupedIndexes=RGraph.sequentialIndexToGrouped(i,this.data);if(typeof this.data[groupedIndexes[0]]==='object'&&!RGraph.isNull(this.data[groupedIndexes[0]])){var isGrouped=true,group=groupedIndexes[0],subgroup=groupedIndexes[1];}
color=properties.errorbarsColor||'black';if(errorbars[i]&&typeof errorbars[i][3]==='number'){this.context.lineWidth=errorbars[i][3];}
var halfwidth=(errorbars[i]&&typeof errorbars[i][4]==='number')?errorbars[i][4]/2:default_halfwidth;if(!properties.errorbarsCapped){halfwidth=0;}
if(typeof errorbars[i]==='number'){length=Math.abs(this.getYCoord(errorbars[i])-this.getYCoord(0));if(length){this.path('b % % l % % l % % l % % s %',barX+(barW/2),(typeof this.data[i]==='number'&&this.data[i]<0||(isGrouped&&this.data[group][subgroup]<0))?barY+barH:barY,barX+(barW/2),(typeof this.data[i]==='number'&&this.data[i]<0||(isGrouped&&this.data[group][subgroup]<0))?barY+barH+length:barY-length,barX+(barW/2)-halfwidth,(typeof this.data[i]==='number'&&this.data[i]<0||(isGrouped&&this.data[group][subgroup]<0))?Math.round(barY+barH+length):Math.round(barY-length),barX+(barW/2)+halfwidth,(typeof this.data[i]==='number'&&this.data[i]<0||(isGrouped&&this.data[group][subgroup]<0))?Math.round(barY+barH+length):Math.round(barY-length),color);}}else if(typeof errorbars[i]==='object'&&!RGraph.isNull(errorbars[i])){var positiveLength=Math.abs(this.getYCoord(errorbars[i][0])-this.getYCoord(0));if(typeof errorbars[i][1]==='string'){color=errorbars[i][1];}else if(typeof errorbars[i][2]==='string'){color=errorbars[i][2];}
halfwidth=typeof errorbars[i][4]==='number'?errorbars[i][4]/2:default_halfwidth;if(!properties.errorbarsCapped){halfwidth=0;}
if(!RGraph.isNull(errorbars[i][0])){this.path('b m % % l % % l % % l % % s %',barX+(barW/2),barY+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),barX+(barW/2),barY-positiveLength+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),barX+(barW/2)-halfwidth,Math.round(barY-positiveLength)+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),barX+(barW/2)+halfwidth,Math.round(barY-positiveLength)+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),color);}
if(typeof errorbars[i][1]==='number'){var negativeLength=Math.abs(this.getYCoord(errorbars[i][1])-this.getYCoord(0));this.path('b m % % l % % l % % l % % s %',barX+(barW/2),barY+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),barX+(barW/2),barY+negativeLength+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),barX+(barW/2)-halfwidth,Math.round(coords[i][1]+negativeLength)+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),barX+(barW/2)+halfwidth,Math.round(barY+negativeLength)+(this.data[i]<0?barH:0)+((isGrouped&&this.data[group][subgroup]<0)?barH:0),color);}}
if(errorbars[i]&&typeof errorbars[i][3]==='number'){this.context.lineWidth=properties.errorbarsLinewidth;}}};this.isAdjustable=function(shape)
{if(RGraph.isNull(properties.adjustableOnly)||!RGraph.isArray(properties.adjustableOnly)){return true;}
if(RGraph.isArray(properties.adjustableOnly)&&properties.adjustableOnly[shape.sequentialIndex]){return true;}
return false;};this.tooltipSubstitutions=function(opt)
{var indexes=RGraph.sequentialIndexToGrouped(opt.index,this.data);var values=this.data[indexes[0]];if(typeof values==='number'){values=[values];}
return{index:indexes[1],dataset:indexes[0],sequentialIndex:opt.index,value:this.data_arr[opt.index],values:values};};this.tooltipsFormattedCustom=function(specific,index)
{var label;if(this.stackedOrGrouped){label=(!RGraph.isNull(properties.tooltipsFormattedKeyLabels)&&typeof properties.tooltipsFormattedKeyLabels==='object'&&properties.tooltipsFormattedKeyLabels[index])?properties.tooltipsFormattedKeyLabels[index]:'';}else{label=(!RGraph.isNull(properties.tooltipsFormattedKeyLabels)&&typeof properties.tooltipsFormattedKeyLabels==='object'&&properties.tooltipsFormattedKeyLabels[specific.index])?properties.tooltipsFormattedKeyLabels[specific.index]:'';}
return{label:label};};this.positionTooltipStatic=function(args)
{var obj=args.object,e=args.event,tooltip=args.tooltip,index=args.index,canvasXY=RGraph.getCanvasXY(obj.canvas)
coords=this.coords[args.index];args.tooltip.style.left=(canvasXY[0]
+coords[0]
-(tooltip.offsetWidth/2)
+(coords[2]/2)
+obj.properties.tooltipsOffsetx)+'px';args.tooltip.style.top=(canvasXY[1]
+coords[1]
-tooltip.offsetHeight
-10
+obj.properties.tooltipsOffsety)+'px';if(properties.variant==='3d'){var left=coords[0];var top=coords[1];var angle=properties.variantThreedAngle;var adjustment=Math.tan(angle)*left;args.tooltip.style.top=parseInt(args.tooltip.style.top)+adjustment-5+'px';}
if(this.data_arr[index]<0){args.tooltip.style.top=parseFloat(args.tooltip.style.top)
+(coords[3]/2)
+'px';}};this.roundedCornersRect=function(x,y,width,height)
{var radius=properties.cornersRoundRadius;radius=Math.min(width/2,height/2,radius);this.context.save();this.context.translate(x,y);this.context.moveTo(width/2,0);this.context.arcTo(width,0,width,height,Math.min(height/2,radius));this.context.arcTo(width,height,0,height,0);this.context.arcTo(0,height,0,0,0);this.context.arcTo(0,0,radius,0,Math.min(height/2,radius));this.context.lineTo(width/2,0);this.context.restore();};this.install3DAxisClip=function()
{this.path('b m % % l % % l % % l % % l % % l % % c cl',this.marginLeft,this.getYCoord(0),this.marginLeft,this.canvas.height-this.marginBottom,this.canvas.width-this.marginRight,this.canvas.height-this.marginBottom,this.canvas.width-this.marginRight+this.properties.variantThreedOffsetx,this.canvas.height-this.marginBottom-this.properties.variantThreedOffsety,this.canvas.width-this.marginRight+this.properties.variantThreedOffsetx,this.getYCoord(0)-this.properties.variantThreedOffsety,this.canvas.width-this.marginRight,this.getYCoord(0));};RGraph.register(this);RGraph.parseObjectStyleConfig(this,conf.options);};RGraph.CombinedChart=function()
{this.objects=[];var objects=[];if(RGraph.isArray(arguments[0])){objects=arguments[0];}else{for(var i=0;i<arguments.length;i+=1){objects[i]=arguments[i];}}
for(var i=0;i<objects.length;++i){this.objects[i]=objects[i];this.objects[i].set({marginLeft:this.objects[0].get('marginLeft'),marginRight:this.objects[0].get('marginRight'),marginTop:this.objects[0].get('marginTop'),marginBottom:this.objects[0].get('marginBottom')});if(this.objects[i].type=='line'){var obj=this.objects[i];obj.set('marginInner',((this.objects[0].canvas.width-this.objects[0].get('marginRight')-this.objects[0].get('marginLeft'))/this.objects[0].data.length)/2);obj.set('yaxis',false);obj.set('xaxis',false);obj.set('backgroundGrid',false);obj.set('yaxisScale',false);}
if(this.objects[i].get('resizable')){var resizable_object=obj;}}
if(resizable_object){function myOnresizebeforedraw(obj)
{var marginLeft=obj.get('marginLeft');var marginRight=obj.get('marginRight');obj.set('marginInner',(obj.canvas.width-marginLeft-marginRight)/(obj.original_data[0].length*2));}
RGraph.addCustomEventListener(resizable_object,'onresizebeforedraw',myOnresizebeforedraw);}
return this;};RGraph.CombinedChart.prototype.add=function(obj)
{this.objects.push(obj);return this;};RGraph.CombinedChart.prototype.draw=function()
{if(RGraph.isArray(this.objects)){for(var i=0;i<this.objects.length;++i){if(this.objects[i].properties['combinedEffect']){var options=this.objects[i].properties['combinedEffectOptions']?eval('('+this.objects[i].properties['combinedEffectOptions']+')'):null,callback=this.objects[i].properties['combinedEffectCallback'],func=this.objects[i].properties['combinedEffect'];(this.objects[i][func])(options,callback);}else{this.objects[i].draw();}}}
return this;};RGraph.SegmentedBar=function(conf)
{this.config=conf;this.properties={};this.config.data.forEach(function(v,k,arr)
{arr[k]=RGraph.arrayPad([],v,1);});for(i in this.config.options){if(typeof i==='string'){this.properties[i]=this.config.options[i];}}
var seg=this;this.background=new RGraph.Bar({id:conf.id[0],data:RGraph.arrayPad([],conf.data.length),options:{backgroundGridHlinesCount:seg.properties.segmentsCount,colors:['rgba(0,0,0,0)'],xaxis:false,yaxis:false,yaxisLabels:false,xaxis:false,yaxis:false,yaxisScale:false}});this.foreground=new RGraph.Bar({id:conf.id[1],data:conf.data,options:{grouping:'stacked',xaxis:false,yaxis:false,backgroundGrid:false,yaxisLabelsOffsetx:-3,yaxisLabelsOffsety:20}}).on('draw',function(obj)
{var lw=seg.properties.segmentsLinewidth;var count=seg.properties.segmentsCount;for(var i=0;i<=count;++i){obj.path('cr 0 % 1000 %',obj.getYCoord(i/count*seg.foreground.scale2.max)-(lw/2),lw);}});this.foreground.set({yaxisLabelsOffsety:(this.foreground.canvas.height-this.foreground.properties.marginTop-this.foreground.properties.marginBottom)/seg.properties.segmentsCount/2});this.draw=function()
{this.background.draw();this.foreground.draw();return this;}
this.grow=function()
{this.background.draw();this.foreground.grow(arguments[0],arguments[1]);return this;}
this.wave=function()
{this.background.draw();this.foreground.wave(arguments[0],arguments[1]);return this;}
this.responsive=function(conf)
{this.foreground.responsive(conf);this.background.responsive(conf);return this;}}
Posted by Richard at 20:35 on Friday 10th June 2022 [link]
OK it's at least version 6.01 - because it has the "corners" properties and that was introduced in that version.
If you have the other libraries you could go through the release notes and see if the features listed there are in your copies.
For example, looking through the latest release notes:
https://www.rgraph.net/canvas/release-notes-2022.html
If you have the string labelsAboveFormatter in your Bar chart library then you have v6.06 as that property was added in that version (it's not there - so your version is not 6.06 - it must be 6.01, 6.02, 6.03, 6.04 or 6.05).
Looking for more things that are mentioned in the release notes will help you narrow it down further. You will probably need to look through other files if you have them.
If you have the other libraries you could go through the release notes and see if the features listed there are in your copies.
For example, looking through the latest release notes:
https://www.rgraph.net/canvas/release-notes-2022.html
If you have the string labelsAboveFormatter in your Bar chart library then you have v6.06 as that property was added in that version (it's not there - so your version is not 6.06 - it must be 6.01, 6.02, 6.03, 6.04 or 6.05).
Looking for more things that are mentioned in the release notes will help you narrow it down further. You will probably need to look through other files if you have them.
Posted by Richard at 19:24 on Sunday 11th September 2022 [link]
For anyone reading this in the future, the version numbers that are added to the top of each file are now added in such a way that they won't get removed by minification so you'll always be able to identity the RGraph files.
[Replies are closed]