highcharts
Version:
JavaScript charting framework
13 lines • 11.3 kB
JavaScript
!/**
* Highcharts Gantt JS v12.5.0 (2026-01-12)
* @module highcharts/modules/grid-axis
* @requires highcharts
*
* GridAxis
*
* (c) 2016-2026 Highsoft AS
* Author: Lars A. V. Cabrera
*
* A commercial license may be required depending on use.
* See www.highcharts.com/license
*/function(t,i){"object"==typeof exports&&"object"==typeof module?module.exports=i(t._Highcharts,t._Highcharts.Axis):"function"==typeof define&&define.amd?define("highcharts/modules/grid-axis",["highcharts/highcharts"],function(t){return i(t,t.Axis)}):"object"==typeof exports?exports["highcharts/modules/grid-axis"]=i(t._Highcharts,t._Highcharts.Axis):t.Highcharts=i(t.Highcharts,t.Highcharts.Axis)}("u"<typeof window?this:window,(t,i)=>(()=>{"use strict";var e,s,r={532:t=>{t.exports=i},944:i=>{i.exports=t}},o={};function n(t){var i=o[t];if(void 0!==i)return i.exports;var e=o[t]={exports:{}};return r[t](e,e.exports,n),e.exports}n.n=t=>{var i=t&&t.__esModule?()=>t.default:()=>t;return n.d(i,{a:i}),i},n.d=(t,i)=>{for(var e in i)n.o(i,e)&&!n.o(t,e)&&Object.defineProperty(t,e,{enumerable:!0,get:i[e]})},n.o=(t,i)=>Object.prototype.hasOwnProperty.call(t,i);var h={};n.d(h,{default:()=>D});var l=n(944),a=n.n(l),d=n(532),c=n.n(d);let{dateFormats:g}=a(),{addEvent:f,defined:p,erase:u,find:m,isArray:x,isNumber:k,merge:b,pick:P,timeUnits:y,wrap:w}=a();function L(t){return a().isObject(t,!0)}function B(t,i){let e={width:0,height:0};if(i.forEach(function(i){let s=t[i],r=0,o=0,n;L(s)&&(r=(n=L(s.label)?s.label:{}).getBBox?n.getBBox().height:0,n.textStr&&!k(n.textPxLength)&&(n.textPxLength=n.getBBox().width),o=k(n.textPxLength)?Math.round(n.textPxLength):0,n.textStr&&(o=Math.round(n.getBBox().width)),e.height=Math.max(r,e.height),e.width=Math.max(o,e.width))}),"treegrid"===this.type&&this.treeGrid&&this.treeGrid.mapOfPosToGridNode){let t=this.treeGrid.mapOfPosToGridNode[-1].height||0;e.width+=this.options.labels.indentation*(t-1)}return e}function v(t){let{grid:i}=this,e=3===this.side;if(e||t.apply(this),!i?.isColumn){let t=i?.columns||[];e&&(t=t.slice().reverse()),t.forEach(t=>{t.getOffset()})}e&&t.apply(this)}function O(t){if(!0===(this.options.grid||{}).enabled){let{axisTitle:i,height:e,horiz:r,left:o,offset:n,opposite:h,options:l,top:a,width:d}=this,c=this.tickSize(),g=i?.getBBox().width,f=l.title.x,p=l.title.y,u=P(l.title.margin,r?5:10),m=i?this.chart.renderer.fontMetrics(i).f:0,x=(r?a+e:o)+(r?1:-1)*(h?-1:1)*(c?c[0]/2:0)+(this.side===s.bottom?m:0);t.titlePosition.x=r?o-(g||0)/2-u+f:x+(h?d:0)+n+f,t.titlePosition.y=r?x-(h?e:0)+(h?m:-m)/2+n+p:a-u+p}}function T(){let t,{chart:i,options:{grid:e={}},userOptions:s}=this;if(e.enabled&&((t=this.options).labels.align=P(t.labels.align,"center"),this.categories||(t.showLastLabel=!1),this.labelRotation=0,t.labels.rotation=0,t.minTickInterval=1),e.columns){let t=this.grid.columns=[],r=this.grid.columnIndex=0;for(;++r<e.columns.length;){let o=b(s,e.columns[r],{isInternal:!0,linkedTo:0,scrollbar:{enabled:!1}},{grid:{columns:void 0}}),n=new(c())(this.chart,o,"yAxis");n.grid.isColumn=!0,n.grid.columnIndex=r,u(i.axes,n),u(i[this.coll]||[],n),t.push(n)}}}function M(){let{axisTitle:t,grid:i,options:e}=this;if(!0===(e.grid||{}).enabled){let r=this.min||0,o=this.max||0,n=this.ticks[this.tickPositions[0]];if(t&&!this.chart.styledMode&&n?.slotWidth&&!this.options.title.style.width&&t.css({width:`${n.slotWidth}px`}),this.maxLabelDimensions=this.getMaxLabelDimensions(this.ticks,this.tickPositions),this.rightWall&&this.rightWall.destroy(),this.grid?.isOuterAxis()&&this.axisLine){let t=e.lineWidth;if(t){let i=this.getLinePath(t),n=i[0],h=i[1],l=(this.tickSize("tick")||[1])[0]*(this.side===s.top||this.side===s.left?-1:1);if("M"===n[0]&&"L"===h[0]&&(this.horiz?(n[2]+=l,h[2]+=l):(n[1]+=l,h[1]+=l)),!this.horiz&&this.chart.marginRight){let t=["L",this.left,n[2]||0],i=[n,t],s=["L",this.chart.chartWidth-this.chart.marginRight,this.toPixels(o+this.tickmarkOffset)],l=[["M",h[1]||0,this.toPixels(o+this.tickmarkOffset)],s];this.grid.upperBorder||r%1==0||(this.grid.upperBorder=this.grid.renderBorder(i)),this.grid.upperBorder&&(this.grid.upperBorder.attr({stroke:e.lineColor,"stroke-width":e.lineWidth}),this.grid.upperBorder.animate({d:i})),this.grid.lowerBorder||o%1==0||(this.grid.lowerBorder=this.grid.renderBorder(l)),this.grid.lowerBorder&&(this.grid.lowerBorder.attr({stroke:e.lineColor,"stroke-width":e.lineWidth}),this.grid.lowerBorder.animate({d:l}))}this.grid.axisLineExtra?(this.grid.axisLineExtra.attr({stroke:e.lineColor,"stroke-width":e.lineWidth}),this.grid.axisLineExtra.animate({d:i})):this.grid.axisLineExtra=this.grid.renderBorder(i),this.axisLine[this.showAxis?"show":"hide"]()}}if((i?.columns||[]).forEach(t=>t.render()),!this.horiz&&this.chart.hasRendered&&(this.scrollbar||this.linkedParent?.scrollbar)&&this.tickPositions.length){let t,i,e=this.tickmarkOffset,s=this.tickPositions[this.tickPositions.length-1],n=this.tickPositions[0];for(;(t=this.hiddenLabels.pop())&&t.element;)t.show();for(;(i=this.hiddenMarks.pop())&&i.element;)i.show();(t=this.ticks[n].label)&&(r-n>e?this.hiddenLabels.push(t.hide()):t.show()),(t=this.ticks[s].label)&&(s-o>e?this.hiddenLabels.push(t.hide()):t.show());let h=this.ticks[s].mark;h&&s-o<e&&s-o>0&&this.ticks[s].isLast&&this.hiddenMarks.push(h.hide())}}}function W(){let t=this.tickPositions?.info,i=this.options,e=i.grid||{},s=this.userOptions.labels||{};e.enabled&&(this.horiz?(this.series.forEach(t=>{t.options.pointRange=0}),t&&i.dateTimeLabelFormats&&i.labels&&!p(s.align)&&(!1===i.dateTimeLabelFormats[t.unitName].range||t.count>1)&&(i.labels.align="left",p(s.x)||(i.labels.x=3))):"treegrid"!==this.type&&this.grid&&this.grid.columns&&(this.minPointOffset=this.tickInterval))}function S(t){let i,e=this.options,s=t.userOptions,r=e&&L(e.grid)?e.grid:{};!0===r.enabled&&(i=b(!0,{className:"highcharts-grid-axis "+(s.className||""),dateTimeLabelFormats:{hour:{list:["%[HM]","%[H]"]},day:{list:["%[AeB]","%[aeb]","%[E]"]},week:{list:["Week %W","W%W"]},month:{list:["%[B]","%[b]","%o"]}},grid:{borderWidth:1},labels:{padding:2,style:{fontSize:"0.9em"}},margin:0,title:{text:null,reserveSpace:!1,rotation:0,style:{textOverflow:"ellipsis"}},units:[["millisecond",[1,10,100]],["second",[1,10]],["minute",[1,5,15]],["hour",[1,6]],["day",[1]],["week",[1]],["month",[1]],["year",null]]},s),"xAxis"===this.coll&&(p(s.linkedTo)&&!p(s.tickPixelInterval)&&(i.tickPixelInterval=350),!(!p(s.tickPixelInterval)&&p(s.linkedTo))||p(s.tickPositioner)||p(s.tickInterval)||p(s.units)||(i.tickPositioner=function(t,e){let s=this.linkedParent?.tickPositions?.info;if(s){let r=i.units||[],o,n=1,h="year";for(let t=0;t<r.length;t++){let i=r[t];if(i&&i[0]===s.unitName){o=t;break}}let l=k(o)&&r[o+1];if(l){h=l[0]||"year";let t=l[1];n=t?.[0]||1}else"year"===s.unitName&&(n=10*s.count);let a=y[h];return this.tickInterval=a*n,this.chart.time.getTimeTicks({unitRange:a,count:n,unitName:h},t,e,this.options.startOfWeek)}})),b(!0,this.options,i),this.horiz&&(e.minPadding=P(s.minPadding,0),e.maxPadding=P(s.maxPadding,0)),k(e.grid.borderWidth)&&(e.tickWidth=e.lineWidth=r.borderWidth))}function A(t){let i=t.userOptions,e=i?.grid||{},s=e.columns;e.enabled&&s&&b(!0,this.options,s[0])}function z(){(this.grid.columns||[]).forEach(t=>t.setScale())}function E(t){let{horiz:i,maxLabelDimensions:e,options:{grid:s={}}}=this;if(s.enabled&&e){let r=2*this.options.labels.distance,o=i?s.cellHeight||r+e.height:r+e.width;x(t.tickSize)?t.tickSize[0]=o:t.tickSize=[o,0]}}function I(){this.axes.forEach(t=>{(t.grid?.columns||[]).forEach(t=>{t.setAxisSize(),t.setAxisTranslation()})})}function C(t){let{grid:i}=this;(i.columns||[]).forEach(i=>i.destroy(t.keepEvents)),i.columns=void 0}function H(t){let i=t.userOptions||{},e=i.grid||{};e.enabled&&p(e.borderColor)&&(i.tickColor=i.lineColor=e.borderColor),this.grid||(this.grid=new R(this)),this.hiddenLabels=[],this.hiddenMarks=[]}function G(t){let i=this.label,e=this.axis,r=e.reversed,o=e.chart,n=e.options.grid||{},h=e.options.labels,l=h.align,a=s[e.side],d=t.tickmarkOffset,c=e.tickPositions,g=this.pos-d,f=k(c[t.index+1])?c[t.index+1]-d:(e.max||0)+d,p=e.tickSize("tick"),u=p?p[0]:0,m=p?p[1]/2:0;if(!0===n.enabled){let s,n,d,c;if("top"===a?n=(s=e.top+e.offset)-u:"bottom"===a?s=(n=o.chartHeight-e.bottom+e.offset)+u:(s=e.top+e.len-(e.translate(r?f:g)||0),n=e.top+e.len-(e.translate(r?g:f)||0)),"right"===a?c=(d=o.chartWidth-e.right+e.offset)+u:"left"===a?d=(c=e.left+e.offset)-u:(d=Math.round(e.left+(e.translate(r?f:g)||0))-m,c=Math.min(Math.round(e.left+(e.translate(r?g:f)||0))-m,e.left+e.len)),this.slotWidth=c-d,t.pos.x="left"===l?d:"right"===l?c:d+(c-d)/2,t.pos.y=n+(s-n)/2,i){let e=o.renderer.fontMetrics(i),s=i.getBBox().height;if(h.useHTML)t.pos.y+=e.b+-(s/2);else{let i=Math.round(s/e.h);t.pos.y+=(e.b-(e.h-e.f))/2+-((i-1)*e.h/2)}}t.pos.x+=e.horiz&&h.x||0}}function N(t){let{axis:i,value:e}=t;if(i.options.grid?.enabled){let s,r=i.tickPositions,o=(i.linkedParent||i).series[0],n=e===r[0],h=e===r[r.length-1],l=o&&m(o.options.data,function(t){return t[i.isXAxis?"x":"y"]===e});l&&o.is("gantt")&&(s=b(l),a().seriesTypes.gantt.prototype.pointClass.setGanttPointAliases(s,i.chart)),t.isFirst=n,t.isLast=h,t.point=s}}function j(){let t=this.options,i=t.grid||{},e=this.categories,s=this.tickPositions,r=s[0],o=s[1],n=s[s.length-1],h=s[s.length-2],l=this.linkedParent?.min,a=this.linkedParent?.max,d=l||this.min,c=a||this.max,g=this.tickInterval,f=k(d)&&d>=r+g&&d<o,p=k(d)&&r<d&&r+g>d,u=k(c)&&n>c&&n-g<c,m=k(c)&&c<=n-g&&c>h;!0===i.enabled&&!e&&(this.isXAxis||this.isLinked)&&((p||f)&&!t.startOnTick&&(s[0]=d),(u||m)&&!t.endOnTick&&(s[s.length-1]=c))}function F(t){var i;let{options:{grid:e={}}}=this;return!0===e.enabled&&this.categories?this.tickInterval:t.apply(this,(i=arguments,Array.prototype.slice.call(i,1)))}(e=s||(s={}))[e.top=0]="top",e[e.right=1]="right",e[e.bottom=2]="bottom",e[e.left=3]="left";class R{constructor(t){this.axis=t}isOuterAxis(){let t=this.axis,i=t.chart,e=t.grid.columnIndex,s=t.linkedParent?.grid.columns||t.grid.columns||[],r=e?t.linkedParent:t,o=-1,n=0;return 3===t.side&&!i.inverted&&s.length?!t.linkedParent:((i[t.coll]||[]).forEach((i,e)=>{i.side!==t.side||i.options.isInternal||(n=e,i===r&&(o=e))}),n===o&&(!k(e)||s.length===e))}renderBorder(t){let i=this.axis,e=i.chart.renderer,s=i.options,r=e.path(t).addClass("highcharts-axis-line").add(i.axisGroup);return e.styledMode||r.attr({stroke:s.lineColor,"stroke-width":s.lineWidth,zIndex:7}),r}}g.E=function(t){return this.dateFormat("%a",t,!0).charAt(0)},g.W=function(t){let i=this.toParts(t),e=(i[7]+6)%7,s=i.slice(0);s[2]=i[2]-e+3;let r=this.toParts(this.makeTime(s[0],0,1));return 4!==r[7]&&(i[1]=0,i[2]=1+(11-r[7])%7),(1+Math.floor((this.makeTime(s[0],s[1],s[2])-this.makeTime(r[0],r[1],r[2]))/6048e5)).toString()};let _=a();({compose:function(t,i,e){return t.keepProps.includes("grid")||(t.keepProps.push("grid"),t.prototype.getMaxLabelDimensions=B,w(t.prototype,"unsquish",F),w(t.prototype,"getOffset",v),f(t,"init",H),f(t,"afterGetTitlePosition",O),f(t,"afterInit",T),f(t,"afterRender",M),f(t,"afterSetAxisTranslation",W),f(t,"afterSetOptions",S),f(t,"afterSetOptions",A),f(t,"afterSetScale",z),f(t,"afterTickSize",E),f(t,"trimTicks",j),f(t,"destroy",C),f(i,"afterSetChartSize",I),f(e,"afterGetLabelPosition",G),f(e,"labelFormat",N)),t}}).compose(_.Axis,_.Chart,_.Tick);let D=a();return h.default})());