ÿØÿà JFIF    ÿÛ „  ( %"1!%)+...383,7(-.+  -+++--++++---+-+-----+---------------+---+-++7-----ÿÀ  ß â" ÿÄ     ÿÄ H    !1AQaq"‘¡2B±ÁÑð#R“Ò Tbr‚²á3csƒ’ÂñDS¢³$CÿÄ   ÿÄ %  !1AQa"23‘ÿÚ   ? ôÿ ¨pŸªáÿ —åYõõ\?àÒü©ŠÄï¨pŸªáÿ —åYõõ\?àÓü©ŠÄá 0Ÿªáÿ Ÿå[úƒ ú®ði~TÁbqÐ8OÕpÿ ƒOò¤Oè`–RÂáœá™êi€ßÉ< FtŸI“öÌ8úDf´°å}“¾œ6  öFá°y¥jñÇh†ˆ¢ã/ÃÐ:ªcÈ "Y¡ðÑl>ÿ ”ÏËte:qž\oäŠe÷󲍷˜HT4&ÿ ÓÐü6ö®¿øþßèô Ÿ•7Ñi’•j|“ñì>b…þS?*Óôÿ ÓÐü*h¥£ír¶ü UãS炟[AÐaè[ûª•õ&õj?†Éö+EzP—WeÒírJFt ‘BŒ†Ï‡%#tE Øz ¥OÛ«!1›üä±Í™%ºÍãö]°î(–:@<‹ŒÊö×òÆt¦ãº+‡¦%ÌÁ²h´OƒJŒtMÜ>ÀÜÊw3Y´•牋4ǍýʏTì>œú=Íwhyë,¾Ôò×õ¿ßÊa»«þˆѪQ|%6ž™A õ%:øj<>É—ÿ Å_ˆCbõ¥š±ý¯Ýƒï…¶|RëócÍf溪“t.СøTÿ *Ä¿-{†çàczůŽ_–^XþŒ±miB[X±d 1,é”zEù»& î9gœf™9Ð'.;—™i}!ôšåîqêÛ٤ёý£½ÆA–àôe"A$˝Úsäÿ ÷Û #°xŸëí(l »ý3—¥5m! rt`†0~'j2(]S¦¦kv,ÚÇ l¦øJA£Šƒ J3E8ÙiŽ:cÉžúeZ°€¯\®kÖ(79«Ž:¯X”¾³Š&¡* ….‰Ž(ÜíŸ2¥ª‡×Hi²TF¤ò[¨íÈRëÉ䢍mgÑ.Ÿ<öäS0í„ǹÁU´f#Vß;Õ–…P@3ío<ä-±»Ž.L|kªÀê›fÂ6@»eu‚|ÓaÞÆŸ…¨ááå>åŠ?cKü6ùTÍÆ”†sĤÚ;H2RÚ†õ\Ö·Ÿn'¾ ñ#ºI¤Å´%çÁ­‚â7›‹qT3Iï¨ÖÚ5I7Ë!ÅOóŸ¶øÝñØôת¦$Tcö‘[«Ö³šÒ';Aþ ¸èíg A2Z"i¸vdÄ÷.iõ®§)¿]¤À†–‡É&ä{V¶iŽ”.Ó×Õÿ û?h¬Mt–íª[ÿ Ñÿ ÌV(í}=ibÔ¡›¥¢±b Lô¥‡piη_Z<‡z§èŒ)iÖwiÇ 2hÙ3·=’d÷8éŽ1¦¸c¤µ€7›7Ø ð\á)} ¹fËí›pAÃL%âc2 í§æQz¿;T8sæ°qø)QFMð‰XŒÂ±N¢aF¨…8¯!U  Z©RÊ ÖPVÄÀÍin™Ì-GˆªÅËŠ›•zË}º±ŽÍFò¹}Uw×#ä5B¤{î}Ð<ÙD é©¤&‡ïDbàÁôMÁ." ¤‡ú*õ'VŽ|¼´Úgllº¼klz[Æüï÷Aób‡Eÿ dÑ»Xx9ÃÜ£ÁT/`¼¸vI±Ýµ·Ë‚“G³þ*Ÿû´r|*}<¨îºœ @¦mÄ’M¹”.œ«Y–|6ÏU¤jç¥ÕÞqO ˜kDÆÁ¨5ÿ š;ÐЦ¦€GÙk \ –Þ=â¼=SͧµªS°ÚÍpÜãQűÀõ¬?ÃÁ1Ñ•õZà?hóœ€ L¦l{Y*K˜Ù›zc˜–ˆâ ø+¾ ­-Ök¥%ùEÜA'}ˆ><ÊIè“bpÍ/qÞâvoX€w,\úªò6Z[XdÒæ­@Ö—€$òJí#é>'°Ú ôª˜<)4ryÙ£|óAÅn5žêŸyÒäMÝ2{"}‰–¤l÷ûWX\l¾Á¸góÉOÔ /óñB¤f¸çñ[.P˜ZsÊË*ßT܈§QN¢’¡¨§V¼(Üù*eÕ“”5T¨‹Âê¥FŒã½Dü[8'Ò¥a…Ú¶k7a *•›¼'Ò·\8¨ª\@\õ¢¦íq+DÙrmÎ…_ªæ»ŠÓœ¡¯’Ré9MÅ×D™lælffc+ŒÑ,ý™ÿ ¯þǤ=Å’Á7µ÷ÚÛ/“Ü€ñýã¼àí¾ÕÑ+ƒ,uµMâÀÄbm:ÒÎPæ{˜Gz[ƒ¯«® KHà`ߨŠéí¯P8Aq.C‰ à€kòpj´kN¶qô€…Õ,ÜNŠª-­{Zö’æû44‰sŽè‰îVíRœÕm" 6?³D9¡ÇTíÅꋇ`4«¸ÝÁô ï’ýorqКÇZ«x4Žâéþuïf¹µö[P ,Q£éaX±`PÉÍZ ¸äYúg üAx ’6Lê‚xÝÓ*äQ  Ï’¨hÍ =²,6ï#rÃ<¯–£»ƒ‹,–ê•€ aÛsñ'%Æ"®ÛüìBᝠHÚ3ß°©$“XnœÖ’î2ËTeûìxîß ¦å¿çÉ ðK§þ{‘t‚Ϋ¬jéîZ[ ”š7L¥4VÚCE×]m¤Øy”ä4-dz£œ§¸x.*ãÊÊ b÷•h:©‡¦s`BTÁRû¾g⻩‹jø sF¢àJøFl‘È•Xᓁà~*j¯ +(ÚÕ6-£¯÷GŠØy‚<Ç’.F‹Hœw(+)ÜÜâÈzÄäT§FߘãÏ;DmVœ3Àu@mÚüXÝü•3B¨òÌÁÛ<·ÃÜ z,Ì@õÅ·d2]ü8s÷IôÞ¯^Ç9¢u„~ëAŸï4«M? K]­ÅàPl@s_ p:°¬ZR”´›JC[CS.h‹ƒïËœ«Æ]–÷ó‚wR×k7X‰k›‘´ù¦=¡«‰¨¨Â')—71ó’c‡Ðúµ `é.{§p¹ój\Ž{1h{o±Ý=áUÊïGÖŒõ–-BÄm+AZX¶¡ ïHðæ¥JmÙ;…䡟ˆ¦ ° äšiÉg«$üMk5¤L“’çÊvïâï ,=f“"íἊ5ô¬x6{ɏžID0e¸vçmi'︧ºð9$ò¹÷*£’9ÿ ²TÔ…×>JV¥}Œ}$p[bÔ®*[jzS*8 ”·T›Í–ñUîƒwo$áè=LT™ç—~ô·¤ÈÚ$榍q‰„+´kFm)ž‹©i–ËqÞŠ‰à¶ü( ‚•§ •°ò·‡#5ª•µÊ﯅¡X¨šÁ*F#TXJÊ ušJVÍ&=iÄs1‚3•'fý§5Ñ<=[íÞ­ PÚ;ѱÌ_~Ä££8rÞ ²w;’hDT°>ÈG¬8Á²ÚzŽ®ò®qZcqJêäÞ-ö[ܘbň±çb“ж31²n×iƒðÕ;1¶þÉ ªX‰,ßqÏ$>•î íZ¥Z 1{ç൵+ƒÕµ¥°T$§K]á»Ûï*·¤tMI’ÂZbŽÕiÒ˜}bÓ0£ª5›¨ [5Ž^ÝœWøÂÝh° ¢OWun£¤5 a2Z.G2³YL]jåtì”ä ÁÓ‘%"©<Ôúʰsº UZvä‡ÄiÆÒM .÷V·™ø#kèýiíÌ–ª)µT[)BˆõÑ xB¾B€ÖT¨.¥~ð@VĶr#¸ü*åZNDŽH;âi ],©£öØpù(šºãö¼T.uCê•4@ÿ GÕÛ)Cx›®0ø#:ÏðFÒbR\(€€Ä®fã4Þ‰Fä¯HXƒÅ,†öEÑÔÜ]Öv²?tLÃvBY£ú6Êu5ÅAQ³1‘’¬x–HŒÐ‡ ^ ¸KwJôÖŽ5×CÚ¨vÜ«/B0$×k°=ðbÇ(Ï)w±A†Á† 11Í=èQšµ626ŒÜ/`G«µ<}—-Ö7KEHÈÉðóȤmݱû±·ø«Snmá=“䫚mݱŸ¡¶~ó·“äUóJæúòB|E LêŽy´jDÔ$G¢þÐñ7óR8ýÒ…Ç› WVe#·Ÿ p·Fx~•ݤF÷0Èÿ K¯æS<6’¡WШ; ´ÿ ¥Êø\Òuî†åÝ–VNœkÒ7oòX¨Á­Ø÷FÎÑä±g÷ÿ M~Çî=p,X´ ÝÌÚÅ‹’ÃjÖ.ØöÏñ qïQ¤ÓZE†° =6·]܈ s¸>v•Ž^Ý\wq9r‰Î\¸¡kURÒ$­*‹Nq?Þª*!sŠÆ:TU_u±T+øX¡ ®¹¡,ÄâÃBTsÜ$Ø›4m椴zÜK]’’›Pƒ @€#â˜`é¹=I‡fiV•Ôî“nRm+µFPOhÍ0B£ €+¬5c v•:P'ÒyÎ ‰V~‚Ó†ÖuókDoh$å\*ö%Ю=£«…aȼ½÷Û.-½VŒŠ¼'lyî±1¬3ó#ÞE¿ÔS¤gV£m›=§\û"—WU¤ÚǼÿ ÂnÁGŒÃ ‚õN D³õNÚíŒÕ;HôyÄÈ©P¹Ä{:?R‘Ô¨âF÷ø£bÅó® JS|‚R÷ivýáâ€Æé¡è³´IئÑT!§˜•ت‚¬â@q€wnïCWÄ@JU€ê¯m6]Ï:£âx'+ÒðXvÓ¦Úm=–´7œ $ì“B£~p%ÕŸUþ« N@¼üï~w˜ñø5®—'Ôe»¤5ã//€ž~‰Tþ›Å7•#¤× Íö pÄ$ùeåì*«ÓŠEØWEÈsßg ¦ûvžSsLpºÊW–âµEWöˬH; ™!CYõZ ÃÄf æ#1W. \uWâ\,\Çf j’<qTbên›Î[vxx£ë 'ö¨1›˜ÀM¼Pÿ H)ƒêêŒA7s,|F“ 꺸k³9Ìö*ç®;Ö!Ö$Eiž•¹ÒÚ†ýóéÝû¾ÕS®ó$’NÝäŸz¤5r¦ãÄÃD÷Üø!°ø‡Ô&@m™Ì^Ãä­d q5Lnÿ N;.6½·N|#ä"1Nƒx“ã<3('&ñßt  ~ªu”1Tb㫨9ê–›–bìd$ߣ=#ÕãÒmU¯eí$EFù5ýYô櫨æì™Ç—±ssM]·á¿0ÕåJRÓªîiƒ+O58ÖñªŠÒx" \µâá¨i’¤i —Ö ” M+M¤ë9‚‰A¦°Qõ¾ßøK~¼Ã‘g…Ö´~÷Ï[3GUœÒ½#…kàÔ®Ò”‰³·dWV‰IP‰Ú8u¹”E ÖqLj¾êÕCBš{A^Âß;–¨`¯¬ìö ˼ ×tìø.tƐm*n¨y4o&Àx¥n¦×î‡aupáÛj8¿m›è¶ã!o½;ß0y^ý×^EÑ¿ÒjzŒ­)vÚÑnÄL …^ªô× ‡—‚3k Îý­hï]içå–îÏ*÷ñþ»Ô CÒjøjÍznˆ´ ¹#b'Fô‹ ‰v¥'’à'T´ƒHýÍ%M‰ ƒ&ÆÇŒï1 ‘ –Þ ‰i¬s žR-Ÿ kЬá¬7:þ 0ŒÅÒÕ/aÙ¬ÃÝ#Úøœ ©aiVc‰. ¹¦ãµ” ›Yg¦›ÆÎýº°f³7ƒhá·¸­}&D9¡ÂsÉÙÞèŠõØàC™¨ñbFC|´Ü(ŸƒÚÒ-%»'a Ì¿)ËÇn¿úÿ ÞŽX…4ÊÅH^ôΑí@ù¹Eh¶“L8Çjù ¼ÎåVªóR©Ï5uà V4lZß®=€xÖŸ–ÑÈ ÷”¨°¾__yM1tÉ?uÆþIkÄgæ@þ[¢†°XÃJ£j·:nkÅ¢u ‘}âGzö­/IµèЬ¼48q¦F°ŽR¼=ûì{´¯RýicS ÕÛ íNtÍÙï£,w4rêì®»~x(©Uñ§#Ñ&œÕ¤>ÎåÍÓ9’Ö{9eV­[Öjâ²ãu]˜å2›qÑšÕJç0€sÄ|Êëè0튔bÁ>“{×_F`Ø©ºê:µä,v¤ðfc1±"«ÔÍän1#=· Âøv~H½ÐßA¾¿Ü€Óš]Õ; I¾÷ç‚Qi†î¹9ywÔKG˜áñ zQY—§ÃÕZ07§X‚ Áh;ÁM)iÌCH-¯T‘ë|A0{Ò½LÚ–TâÖkÜ’dÀ“rmm»”جPF³ÖcbE§T€ÒxKºû’Ó®7±²(\4ŽÃ¸Uu@j™yĵ;³µ!Á¢b.W¤=mõ´êµK k ¸K^ÜÛ#p*Ü14qkZç5ïë †°5Ï%ÍÛ<Õ¤×Ô¥ê†C Õ´¼ú$ƒÖ“”]Ù¬qÞÚ[4©ý!ûÏ—Áb쳐XµA¬â~`›Çr¸8ìùÝ䫦<>ä÷«?xs´ÇÑ /á;¹øüÊÈÙà{"@Žïzâ¬[âß‚ U_<ÇŸ½4èN˜ú61®qŠu ¦þF£»äJ_ˆÙÎ~ ÞAã–݄ϗrŠD;xTž‘ô`É«…suãO`?³à™ô Lý#Íc5öoæØ‚y´´÷«ZR§<&JÇ+éâô´€i!Àˆ0æAoàðLèÖ-2ŸõW.’t^–(KÁmHµV@xÜÇy®Ñø­â^:Ú3w· 7½¹°ñ¸â¹®:',«Mœ—n­Á+Ãbš LÈ‘ÄnRÓÅœ%¦²‰¨ùQ:¤f‚ "PÕtô¸…cæl…&˜Ú˜Ôkv‹ž+vŠ,=¢v­6—Xy*¥t£«<™:“aîϲ=¦6rO]XI¿Œ÷¤zÚ­›¶ 6÷”w\d ü~v®ˆÌk«^m<ÿ ¢‰Õ\)ùºŽ;… lîÙÅEŠ®cѾ@vnMÏ,¼“ñ•ŽBxðÃzãÇç%3ˆ"}Ù•Åî> BÉú;Ò]V+P˜F_´ßé> Øše|ï‡ÄOmFæÇ ãqÞ$/xÐx­z`ï9"œÜij‚!7.\Td…9M‡•iŽ‹¾‘50ÞŽn¥ß4ÉôO ¹*í^QêËÜÇÌ8=ާs‰'ÂëÙ«á%Pú[O †ÅP¯Vsް.‰,kc¶ ¬A9n˜XÎ-ÞšN["¹QÕ‰ƒMýÁߺXJæÍaLj¾×Ãmã¾ãÚ uñÒþåQô¦¥ /ÄUx:‚ÍÜ’ Đ©ØÝ3V¨‰ÕnÐ6ó*óúK­«…c ¯U òhsý­jóÔj#,ímŒRµ«lbïUTŒÑ8†Ä0œÏr`ð¡¬É Ї ë"À² ™ 6¥ f¶ ¢ÚoܱԷ-<Àî)†a¶ž'Ú»¨TXqØæ¶÷YÄHy˜9ÈIW­YÀuMFë ºÏ’AqÌ4·/Ú †ô'i$øä­=Ä Ý|öK×40è|È6p‘0§)o¥ctî§H+CA-“ xØ|ÐXАç l8íºð3Ø:³¤¬KX¯UÿÙ /* jqPlot 1.0.8r1250 | (c) 2009-2013 Chris Leonello | jplot.com jsDate | (c) 2010-2013 Chris Leonello */ (function (d) { d.jqplot.BarRenderer = function () { d.jqplot.LineRenderer.call(this) }; d.jqplot.BarRenderer.prototype = new d.jqplot.LineRenderer(); d.jqplot.BarRenderer.prototype.constructor = d.jqplot.BarRenderer; d.jqplot.BarRenderer.prototype.init = function (o, q) { this.barPadding = 8; this.barMargin = 10; this.barDirection = "vertical"; this.barWidth = null; this.shadowOffset = 2; this.shadowDepth = 5; this.shadowAlpha = 0.08; this.waterfall = false; this.groups = 1; this.varyBarColor = false; this.highlightMouseOver = true; this.highlightMouseDown = false; this.highlightColors = []; this.transposedData = true; this.renderer.animation = {show: false, direction: "down", speed: 3000, _supported: true}; this._type = "bar"; if (o.highlightMouseDown && o.highlightMouseOver == null) { o.highlightMouseOver = false } d.extend(true, this, o); d.extend(true, this.renderer, o); this.fill = true; if (this.barDirection === "horizontal" && this.rendererOptions.animation && this.rendererOptions.animation.direction == null) { this.renderer.animation.direction = "left" } if (this.waterfall) { this.fillToZero = false; this.disableStack = true } if (this.barDirection == "vertical") { this._primaryAxis = "_xaxis"; this._stackAxis = "y"; this.fillAxis = "y" } else { this._primaryAxis = "_yaxis"; this._stackAxis = "x"; this.fillAxis = "x" } this._highlightedPoint = null; this._plotSeriesInfo = null; this._dataColors = []; this._barPoints = []; var p = {lineJoin: "miter", lineCap: "round", fill: true, isarc: false, strokeStyle: this.color, fillStyle: this.color, closePath: this.fill}; this.renderer.shapeRenderer.init(p); var n = {lineJoin: "miter", lineCap: "round", fill: true, isarc: false, angle: this.shadowAngle, offset: this.shadowOffset, alpha: this.shadowAlpha, depth: this.shadowDepth, closePath: this.fill}; this.renderer.shadowRenderer.init(n); q.postInitHooks.addOnce(h); q.postDrawHooks.addOnce(j); q.eventListenerHooks.addOnce("jqplotMouseMove", b); q.eventListenerHooks.addOnce("jqplotMouseDown", a); q.eventListenerHooks.addOnce("jqplotMouseUp", l); q.eventListenerHooks.addOnce("jqplotClick", e); q.eventListenerHooks.addOnce("jqplotRightClick", m) }; function g(t, p, o, w) { if (this.rendererOptions.barDirection == "horizontal") { this._stackAxis = "x"; this._primaryAxis = "_yaxis" } if (this.rendererOptions.waterfall == true) { this._data = d.extend(true, [], this.data); var s = 0; var u = (!this.rendererOptions.barDirection || this.rendererOptions.barDirection === "vertical" || this.transposedData === false) ? 1 : 0; for (var q = 0; q < this.data.length; q++) { s += this.data[q][u]; if (q > 0) { this.data[q][u] += this.data[q - 1][u] } } this.data[this.data.length] = (u == 1) ? [this.data.length + 1, s] : [s, this.data.length + 1]; this._data[this._data.length] = (u == 1) ? [this._data.length + 1, s] : [s, this._data.length + 1] } if (this.rendererOptions.groups > 1) { this.breakOnNull = true; var n = this.data.length; var v = parseInt(n / this.rendererOptions.groups, 10); var r = 0; for (var q = v; q < n; q += v) { this.data.splice(q + r, 0, [null, null]); this._plotData.splice(q + r, 0, [null, null]); this._stackData.splice(q + r, 0, [null, null]); r++ } for (q = 0; q < this.data.length; q++) { if (this._primaryAxis == "_xaxis") { this.data[q][0] = q + 1; this._plotData[q][0] = q + 1; this._stackData[q][0] = q + 1 } else { this.data[q][1] = q + 1; this._plotData[q][1] = q + 1; this._stackData[q][1] = q + 1 } } } } d.jqplot.preSeriesInitHooks.push(g); d.jqplot.BarRenderer.prototype.calcSeriesNumbers = function () { var r = 0; var t = 0; var q = this[this._primaryAxis]; var p, o, u; for (var n = 0; n < q._series.length; n++) { o = q._series[n]; if (o === this) { u = n } if (o.renderer.constructor == d.jqplot.BarRenderer) { r += o.data.length; t += 1 } } return[r, t, u] }; d.jqplot.BarRenderer.prototype.setBarWidth = function () { var q; var n = 0; var o = 0; var t = this[this._primaryAxis]; var x, r, v; var w = this._plotSeriesInfo = this.renderer.calcSeriesNumbers.call(this); n = w[0]; o = w[1]; var u = t.numberTicks; var p = (u - 1) / 2; if (t.name == "xaxis" || t.name == "x2axis") { if (this._stack) { this.barWidth = (t._offsets.max - t._offsets.min) / n * o - this.barMargin } else { this.barWidth = ((t._offsets.max - t._offsets.min) / p - this.barPadding * (o - 1) - this.barMargin * 2) / o } } else { if (this._stack) { this.barWidth = (t._offsets.min - t._offsets.max) / n * o - this.barMargin } else { this.barWidth = ((t._offsets.min - t._offsets.max) / p - this.barPadding * (o - 1) - this.barMargin * 2) / o } } return[n, o] }; function f(o) { var q = []; for (var s = 0; s < o.length; s++) { var r = d.jqplot.getColorComponents(o[s]); var n = [r[0], r[1], r[2]]; var t = n[0] + n[1] + n[2]; for (var p = 0; p < 3; p++) { n[p] = (t > 570) ? n[p] * 0.8 : n[p] + 0.3 * (255 - n[p]); n[p] = parseInt(n[p], 10) } q.push("rgb(" + n[0] + "," + n[1] + "," + n[2] + ")") } return q } function i(v, u, s, t, o) { var q = v, w = v - 1, n, p, r = (o === "x") ? 0 : 1; if (q > 0) { p = t.series[w]._plotData[u][r]; if ((s * p) < 0) { n = i(w, u, s, t, o) } else { n = t.series[w].gridData[u][r] } } else { n = (r === 0) ? t.series[q]._xaxis.series_u2p(0) : t.series[q]._yaxis.series_u2p(0) } return n } d.jqplot.BarRenderer.prototype.draw = function (E, L, q, G) { var I; var A = d.extend({}, q); var w = (A.shadow != undefined) ? A.shadow : this.shadow; var O = (A.showLine != undefined) ? A.showLine : this.showLine; var F = (A.fill != undefined) ? A.fill : this.fill; var p = this.xaxis; var J = this.yaxis; var y = this._xaxis.series_u2p; var K = this._yaxis.series_u2p; var D, C; this._dataColors = []; this._barPoints = []; if (this.barWidth == null) { this.renderer.setBarWidth.call(this) } var N = this._plotSeriesInfo = this.renderer.calcSeriesNumbers.call(this); var x = N[0]; var v = N[1]; var s = N[2]; var H = []; if (this._stack) { this._barNudge = 0 } else { this._barNudge = (-Math.abs(v / 2 - 0.5) + s) * (this.barWidth + this.barPadding) } if (O) { var u = new d.jqplot.ColorGenerator(this.negativeSeriesColors); var B = new d.jqplot.ColorGenerator(this.seriesColors); var M = u.get(this.index); if (!this.useNegativeColors) { M = A.fillStyle } var t = A.fillStyle; var r; var P; var o; if (this.barDirection == "vertical") { for (var I = 0; I < L.length; I++) { if (!this._stack && this.data[I][1] == null) { continue } H = []; r = L[I][0] + this._barNudge; if (this._stack && this._prevGridData.length) { o = i(this.index, I, this._plotData[I][1], G, "y") } else { if (this.fillToZero) { o = this._yaxis.series_u2p(0) } else { if (this.waterfall && I > 0 && I < this.gridData.length - 1) { o = this.gridData[I - 1][1] } else { if (this.waterfall && I == 0 && I < this.gridData.length - 1) { if (this._yaxis.min <= 0 && this._yaxis.max >= 0) { o = this._yaxis.series_u2p(0) } else { if (this._yaxis.min > 0) { o = E.canvas.height } else { o = 0 } } } else { if (this.waterfall && I == this.gridData.length - 1) { if (this._yaxis.min <= 0 && this._yaxis.max >= 0) { o = this._yaxis.series_u2p(0) } else { if (this._yaxis.min > 0) { o = E.canvas.height } else { o = 0 } } } else { o = E.canvas.height } } } } } if ((this.fillToZero && this._plotData[I][1] < 0) || (this.waterfall && this._data[I][1] < 0)) { if (this.varyBarColor && !this._stack) { if (this.useNegativeColors) { A.fillStyle = u.next() } else { A.fillStyle = B.next() } } else { A.fillStyle = M } } else { if (this.varyBarColor && !this._stack) { A.fillStyle = B.next() } else { A.fillStyle = t } } if (!this.fillToZero || this._plotData[I][1] >= 0) { H.push([r - this.barWidth / 2, o]); H.push([r - this.barWidth / 2, L[I][1]]); H.push([r + this.barWidth / 2, L[I][1]]); H.push([r + this.barWidth / 2, o]) } else { H.push([r - this.barWidth / 2, L[I][1]]); H.push([r - this.barWidth / 2, o]); H.push([r + this.barWidth / 2, o]); H.push([r + this.barWidth / 2, L[I][1]]) } this._barPoints.push(H); if (w && !this._stack) { var z = d.extend(true, {}, A); delete z.fillStyle; this.renderer.shadowRenderer.draw(E, H, z) } var n = A.fillStyle || this.color; this._dataColors.push(n); this.renderer.shapeRenderer.draw(E, H, A) } } else { if (this.barDirection == "horizontal") { for (var I = 0; I < L.length; I++) { if (!this._stack && this.data[I][0] == null) { continue } H = []; r = L[I][1] - this._barNudge; P; if (this._stack && this._prevGridData.length) { P = i(this.index, I, this._plotData[I][0], G, "x") } else { if (this.fillToZero) { P = this._xaxis.series_u2p(0) } else { if (this.waterfall && I > 0 && I < this.gridData.length - 1) { P = this.gridData[I - 1][0] } else { if (this.waterfall && I == 0 && I < this.gridData.length - 1) { if (this._xaxis.min <= 0 && this._xaxis.max >= 0) { P = this._xaxis.series_u2p(0) } else { if (this._xaxis.min > 0) { P = 0 } else { P = 0 } } } else { if (this.waterfall && I == this.gridData.length - 1) { if (this._xaxis.min <= 0 && this._xaxis.max >= 0) { P = this._xaxis.series_u2p(0) } else { if (this._xaxis.min > 0) { P = 0 } else { P = E.canvas.width } } } else { P = 0 } } } } } if ((this.fillToZero && this._plotData[I][0] < 0) || (this.waterfall && this._data[I][0] < 0)) { if (this.varyBarColor && !this._stack) { if (this.useNegativeColors) { A.fillStyle = u.next() } else { A.fillStyle = B.next() } } else { A.fillStyle = M } } else { if (this.varyBarColor && !this._stack) { A.fillStyle = B.next() } else { A.fillStyle = t } } if (!this.fillToZero || this._plotData[I][0] >= 0) { H.push([P, r + this.barWidth / 2]); H.push([P, r - this.barWidth / 2]); H.push([L[I][0], r - this.barWidth / 2]); H.push([L[I][0], r + this.barWidth / 2]) } else { H.push([L[I][0], r + this.barWidth / 2]); H.push([L[I][0], r - this.barWidth / 2]); H.push([P, r - this.barWidth / 2]); H.push([P, r + this.barWidth / 2]) } this._barPoints.push(H); if (w && !this._stack) { var z = d.extend(true, {}, A); delete z.fillStyle; this.renderer.shadowRenderer.draw(E, H, z) } var n = A.fillStyle || this.color; this._dataColors.push(n); this.renderer.shapeRenderer.draw(E, H, A) } } } } if (this.highlightColors.length == 0) { this.highlightColors = d.jqplot.computeHighlightColors(this._dataColors) } else { if (typeof(this.highlightColors) == "string") { var N = this.highlightColors; this.highlightColors = []; for (var I = 0; I < this._dataColors.length; I++) { this.highlightColors.push(N) } } } }; d.jqplot.BarRenderer.prototype.drawShadow = function (z, G, p, B) { var D; var w = (p != undefined) ? p : {}; var t = (w.shadow != undefined) ? w.shadow : this.shadow; var I = (w.showLine != undefined) ? w.showLine : this.showLine; var A = (w.fill != undefined) ? w.fill : this.fill; var o = this.xaxis; var E = this.yaxis; var v = this._xaxis.series_u2p; var F = this._yaxis.series_u2p; var y, C, x, u, s, r; if (this._stack && this.shadow) { if (this.barWidth == null) { this.renderer.setBarWidth.call(this) } var H = this._plotSeriesInfo = this.renderer.calcSeriesNumbers.call(this); u = H[0]; s = H[1]; r = H[2]; if (this._stack) { this._barNudge = 0 } else { this._barNudge = (-Math.abs(s / 2 - 0.5) + r) * (this.barWidth + this.barPadding) } if (I) { if (this.barDirection == "vertical") { for (var D = 0; D < G.length; D++) { if (this.data[D][1] == null) { continue } C = []; var q = G[D][0] + this._barNudge; var n; if (this._stack && this._prevGridData.length) { n = i(this.index, D, this._plotData[D][1], B, "y") } else { if (this.fillToZero) { n = this._yaxis.series_u2p(0) } else { n = z.canvas.height } } C.push([q - this.barWidth / 2, n]); C.push([q - this.barWidth / 2, G[D][1]]); C.push([q + this.barWidth / 2, G[D][1]]); C.push([q + this.barWidth / 2, n]); this.renderer.shadowRenderer.draw(z, C, w) } } else { if (this.barDirection == "horizontal") { for (var D = 0; D < G.length; D++) { if (this.data[D][0] == null) { continue } C = []; var q = G[D][1] - this._barNudge; var J; if (this._stack && this._prevGridData.length) { J = i(this.index, D, this._plotData[D][0], B, "x") } else { if (this.fillToZero) { J = this._xaxis.series_u2p(0) } else { J = 0 } } C.push([J, q + this.barWidth / 2]); C.push([G[D][0], q + this.barWidth / 2]); C.push([G[D][0], q - this.barWidth / 2]); C.push([J, q - this.barWidth / 2]); this.renderer.shadowRenderer.draw(z, C, w) } } } } } }; function h(q, p, n) { for (var o = 0; o < this.series.length; o++) { if (this.series[o].renderer.constructor == d.jqplot.BarRenderer) { if (this.series[o].highlightMouseOver) { this.series[o].highlightMouseDown = false } } } } function j() { if (this.plugins.barRenderer && this.plugins.barRenderer.highlightCanvas) { this.plugins.barRenderer.highlightCanvas.resetCanvas(); this.plugins.barRenderer.highlightCanvas = null } this.plugins.barRenderer = {highlightedSeriesIndex: null}; this.plugins.barRenderer.highlightCanvas = new d.jqplot.GenericCanvas(); this.eventCanvas._elem.before(this.plugins.barRenderer.highlightCanvas.createElement(this._gridPadding, "jqplot-barRenderer-highlight-canvas", this._plotDimensions, this)); this.plugins.barRenderer.highlightCanvas.setContext(); this.eventCanvas._elem.bind("mouseleave", {plot: this}, function (n) { k(n.data.plot) }) } function c(u, t, q, p) { var o = u.series[t]; var n = u.plugins.barRenderer.highlightCanvas; n._ctx.clearRect(0, 0, n._ctx.canvas.width, n._ctx.canvas.height); o._highlightedPoint = q; u.plugins.barRenderer.highlightedSeriesIndex = t; var r = {fillStyle: o.highlightColors[q]}; o.renderer.shapeRenderer.draw(n._ctx, p, r); n = null } function k(p) { var n = p.plugins.barRenderer.highlightCanvas; n._ctx.clearRect(0, 0, n._ctx.canvas.width, n._ctx.canvas.height); for (var o = 0; o < p.series.length; o++) { p.series[o]._highlightedPoint = null } p.plugins.barRenderer.highlightedSeriesIndex = null; p.target.trigger("jqplotDataUnhighlight"); n = null } function b(r, q, u, t, s) { if (t) { var p = [t.seriesIndex, t.pointIndex, t.data]; var o = jQuery.Event("jqplotDataMouseOver"); o.pageX = r.pageX; o.pageY = r.pageY; s.target.trigger(o, p); if (s.series[p[0]].show && s.series[p[0]].highlightMouseOver && !(p[0] == s.plugins.barRenderer.highlightedSeriesIndex && p[1] == s.series[p[0]]._highlightedPoint)) { var n = jQuery.Event("jqplotDataHighlight"); n.which = r.which; n.pageX = r.pageX; n.pageY = r.pageY; s.target.trigger(n, p); c(s, t.seriesIndex, t.pointIndex, t.points) } } else { if (t == null) { k(s) } } } function a(q, p, t, s, r) { if (s) { var o = [s.seriesIndex, s.pointIndex, s.data]; if (r.series[o[0]].highlightMouseDown && !(o[0] == r.plugins.barRenderer.highlightedSeriesIndex && o[1] == r.series[o[0]]._highlightedPoint)) { var n = jQuery.Event("jqplotDataHighlight"); n.which = q.which; n.pageX = q.pageX; n.pageY = q.pageY; r.target.trigger(n, o); c(r, s.seriesIndex, s.pointIndex, s.points) } } else { if (s == null) { k(r) } } } function l(p, o, s, r, q) { var n = q.plugins.barRenderer.highlightedSeriesIndex; if (n != null && q.series[n].highlightMouseDown) { k(q) } } function e(q, p, t, s, r) { if (s) { var o = [s.seriesIndex, s.pointIndex, s.data]; var n = jQuery.Event("jqplotDataClick"); n.which = q.which; n.pageX = q.pageX; n.pageY = q.pageY; r.target.trigger(n, o) } } function m(r, q, u, t, s) { if (t) { var p = [t.seriesIndex, t.pointIndex, t.data]; var n = s.plugins.barRenderer.highlightedSeriesIndex; if (n != null && s.series[n].highlightMouseDown) { k(s) } var o = jQuery.Event("jqplotDataRightClick"); o.which = r.which; o.pageX = r.pageX; o.pageY = r.pageY; s.target.trigger(o, p) } } })(akeeba.jQuery);