@genome-spy/app 0.43.1 → 0.43.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1691,11 +1691,21 @@ void main() {
1691
1691
  * All rights reserved.
1692
1692
  *
1693
1693
  * BSD-3-Clause License: https://github.com/vega/vega-lite/blob/master/LICENSE
1694
- */const pN="locus",gN="index";var mN=5;function bN(e){const t=e.type;return!e.bins&&(t===es||t===pl||t===gl)}function iE(e){return _t(e)&&![dr,gN,pN].includes(e)}function aE(e){return e||{warn:(t,...n)=>console.warn(t,...n)}}var yN=zf(["set","modified","clear","type","scheme","schemeExtent","schemeCount","domain","domainMin","domainMid","domainMax","domainRaw","domainImplicit","nice","zero","bins","range","rangeStep","round","reverse","interpolate","interpolateGamma","zoom","fp64","name"]);function oE(e,t,n){n=aE(n);for(const r in e)if(!yN[r]){if(r==="padding"&&iE(t.type))continue;Kt(t[r])?t[r](e[r]):n.warn("Unsupported scale property: "+r)}CN(t,e,_N(t,e,AN(t,e,n)))}function vN(e,t){const n=wN(e),r=ke(n);if(!r)throw new Error("Unknown scale type: "+n);const i=r();return!e.domain&&_t(i.type)&&(e.domain=[0,0]),oE(e,i,t),i}function wN(e){var t=e.type,n="",r;return t===dr?dr+"-"+es:(xN(e)&&(r=e.rawDomain?e.rawDomain.length:e.domain?e.domain.length+ +(e.domainMid!=null):0,n=r===2?dr+"-":r===3?ts+"-":""),(n+t||es).toLowerCase())}function xN(e){const t=e.type;return _t(t)&&t!==Kx&&t!==Jx&&(e.scheme||e.range&&e.range.length&&e.range.every(Me))}function AN(e,t,n){if(!e.domain)return 0;n=aE(n);var r=EN(e,t.domainRaw,n);if(r>-1)return r;var i=t.domain,a=e.type,o=t.zero||t.zero===void 0&&bN(e),s,c;return i?(iE(a)&&t.padding&&i[0]!==Un(i)&&(i=SN(a,i,t.range,t.padding,t.exponent,t.constant)),(o||t.domainMin!=null||t.domainMax!=null||t.domainMid!=null)&&(s=(i=i.slice()).length-1||1,o&&(i[0]>0&&(i[0]=0),i[s]<0&&(i[s]=0)),t.domainMin!=null&&(i[0]=t.domainMin),t.domainMax!=null&&(i[s]=t.domainMax),t.domainMid!=null&&(c=t.domainMid,(c<i[0]||c>i[s])&&n.warn("Scale domainMid exceeds domain min or max.",c),i.splice(s,0,c))),e.domain(sE(a,i,n)),a===Yg&&e.unknown(t.domainImplicit?gg:void 0),t.nice&&e.nice&&e.nice(t.nice!==!0&&nE(e,t.nice)||null),i.length):0}function EN(e,t,n){return t?(e.domain(sE(e.type,t,n)),t.length):-1}function SN(e,t,n,r,i,a){var o=Math.abs(Un(n)-n[0]),s=o/(o-2*r),c=e===Ti?uv(t,null,s):e===gl?Ap(t,null,s,.5):e===pl?Ap(t,null,s,i||1):e===Ah?vI(t,null,s,a||1):xp(t,null,s);return t=t.slice(),t[0]=c[0],t[t.length-1]=c[1],t}function sE(e,t,n){if(o3(e)){var r=Math.abs(t.reduce(function(i,a){return i+(a<0?-1:a>0?1:0)},0));r!==t.length&&n.warn("Log scale domain includes zero: "+Nf(t))}return t}function _N(e,t,n){let r=t.bins;if(r&&!Qt(r)){const i=(r.start==null||r.stop==null)&&e.domain(),a=r.start==null?i[0]:r.start,o=r.stop==null?Un(i):r.stop,s=r.step;s||it("Scale bins parameter missing step property."),r=mi(a,o+s,s)}return r?e.bins=r:e.bins&&delete e.bins,e.type===Qg&&(r?!t.domain&&!t.domainRaw&&(e.domain(r),n=r.length):e.bins=e.domain()),n}function CN(e,t,n){var r=e.type,i=t.round||!1,a=t.range;if(t.rangeStep!=null)a=kN(r,t,n);else if(t.scheme&&(a=TN(r,t,n),Kt(a))){if(e.interpolator)return e.interpolator(a);it(`Scale type ${r} does not support interpolating color schemes.`)}if(a&&Sh(r))return e.interpolator(_h(Gm(a,t.reverse),t.interpolate,t.interpolateGamma));a&&t.interpolate&&e.interpolate?e.interpolate(s3(t.interpolate,t.interpolateGamma)):Kt(e.round)?e.round(i):Kt(e.rangeRound)&&e.interpolate(i?hl:Ci),a&&e.range(Gm(a,t.reverse))}function kN(e,t,n){e!==n3&&e!==Zg&&it("Only band and point scales support rangeStep.");var r=(t.paddingOuter!=null?t.paddingOuter:t.padding)||0,i=e===Zg?1:(t.paddingInner!=null?t.paddingInner:t.padding)||0;return[0,t.rangeStep*qg(n,i,r)]}function TN(e,t,n){var r=t.schemeExtent,i,a;return Qt(t.scheme)?a=_h(t.scheme,t.interpolate,t.interpolateGamma):(i=t.scheme.toLowerCase(),a=Kg(i),a||it(`Unrecognized scheme name: ${t.scheme}`)),n=e===t3?n+1:e===Qg?n-1:e===Wg||e===e3?+t.schemeCount||mN:n,Sh(e)?cE(a,r,t.reverse):Kt(a)?HB(cE(a,r),n):e===Yg?a:a.slice(0,n)}function cE(e,t,n){return Kt(e)&&(t||n)?$B(e,Gm(t||[0,1],n)):e}function Gm(e,t){return t?e.slice().reverse():e}const Vm=pt(",d");function IN(e){return e.chrom+":"+Vm(Math.floor(e.pos+1))}function lE(e){return!ft(e)&&"chrom"in e?IN(e):""+e}function RN(e,t){return e.chrom+":"+Vm(Math.floor(e.pos+1))+"-"+(e.chrom!=t.chrom?t.chrom+":":"")+Vm(Math.ceil(t.pos))}const DN="https://genomespy.app/data/genomes/";class BN{constructor(t){if(this.config=t,!this.config.contigs&&typeof this.config.name!="string")throw new Error("No name has been defined for the genome assembly!");this.chromosomes=[],this.cumulativeChromPositions=new Map,this.chromosomesByName=new Map,this.startByIndex=[],this.totalSize=0,this.config.contigs&&this.setChromSizes(this.config.contigs)}get name(){return this.config.name}async load(t){if(!this.config.contigs){this.config.baseUrl?this.baseUrl=/^http(s)?/.test(this.config.baseUrl)?this.config.baseUrl:t+"/"+this.config.baseUrl:this.baseUrl=DN;try{this.setChromSizes(FN(await Zc({baseURL:this.baseUrl}).load(`${this.config.name}/${this.name}.chrom.sizes`)))}catch(n){throw new Error(`Could not load chrom sizes: ${n.message}`)}}}hasChrPrefix(){return this.chromosomes.some(t=>t.name.startsWith("chr"))}setChromSizes(t){let n=0;this.startByIndex=[0];for(let r=0;r<t.length;r++){this.startByIndex.push(n);const i=t[r].size,a={...t[r],continuousStart:n,continuousEnd:n+i,continuousInterval:[n,n+i],index:r,number:r+1,odd:!(r&1)};this.chromosomes.push(a);const o=a.name.replace(/^chr/i,"");for(const s of["chr"+o,"CHR"+o,"Chr"+o,a.number,""+a.number,o,a.name])this.cumulativeChromPositions.set(s,n),this.chromosomesByName.set(s,a);n+=a.size}this.totalSize=n}getExtent(){return[0,this.totalSize]}toContinuous(t,n){let r=this.cumulativeChromPositions.get(t);if(r===void 0)throw new Error("Unknown chromosome/contig: "+t);return r+ +n}toChromosome(t){if(t>this.totalSize)return;t=Math.floor(t);const n=Pr(this.startByIndex,t)-1;if(n>0&&n<=this.chromosomes.length)return this.chromosomes[n-1]}toChromosomal(t){const n=this.toChromosome(t);if(n)return{chrom:n.name,pos:Math.floor(t)-n.continuousStart}}getChromosome(t){return this.chromosomesByName.get(t)}formatInterval(t){return RN(...this.toChromosomalInterval(t))}toChromosomalInterval(t){const n=this.toChromosomal(t[0]+.5),r=this.toChromosomal(t[1]-.5);return r.pos+=1,[n,r]}toContinuousInterval(t){var i;let[n,r]=t;return r||(r=n),[this.toContinuous(n.chrom,n.pos??0),this.toContinuous(r.chrom,r.pos??((i=this.chromosomesByName.get(r.chrom))==null?void 0:i.size))]}toDiscreteChromosomeIntervals(t){const n=t[0],r=t[1],i=[];if(n.chrom===r.chrom)i.push({chrom:n.chrom,startPos:n.pos,endPos:r.pos});else{const a=this.chromosomes.findIndex(s=>s.name===n.chrom),o=this.chromosomes.findIndex(s=>s.name===r.chrom);i.push({chrom:n.chrom,startPos:n.pos,endPos:this.chromosomes[a].size});for(let s=a+1;s<o;s++)i.push({chrom:this.chromosomes[s].name,startPos:0,endPos:this.chromosomes[s].size});i.push({chrom:r.chrom,startPos:0,endPos:r.pos})}return i}continuousToDiscreteChromosomeIntervals(t){return this.toDiscreteChromosomeIntervals([this.toChromosomal(t[0]),this.toChromosomal(t[1])])}parseInterval(t){const n=t.match(/^(chr[0-9A-Z]+)(?::([0-9,]+)(?:-(?:(chr[0-9A-Z]+):)?([0-9,]+))?)?$/);if(n){const r=n[1];if(n.slice(2).every(s=>s===void 0)){const s=this.getChromosome(r);return s?[s.continuousStart,s.continuousEnd]:void 0}const i=n[3]||r,a=parseInt(n[2].replace(/,/g,"")),o=n[4]!==void 0?parseInt(n[4].replace(/,/g,"")):a;return[this.toContinuous(r,a-1),this.toContinuous(i,o)]}}}function FN(e){return NI(e).filter(t=>/^chr[0-9A-Z]+$/.test(t[0])).map(([t,n])=>({name:t,size:parseInt(n)}))}function td(e){return Xt(e)&&"chrom"in e}function PN(e){return e.every(td)}class Ml extends Array{constructor(){super(),this.type=void 0}extend(t){return this}extendAll(t){if(t instanceof Ml&&t.type!=this.type)throw new Error(`Cannot combine different types of domains: ${this.type} and ${t.type}`);for(const n of t)this.extend(n);return this}extendAllWithAccessor(t,n){for(const r of t)this.extend(n(r));return this}}class jm extends Ml{constructor(){super(),this.type="quantitative"}extend(t){return t==null||Number.isNaN(t)?this:(t=+t,this.length?t<this[0]?this[0]=t:t>this[1]&&(this[1]=t):(this.push(t),this.push(t)),this)}}class uE extends Ml{constructor(){super(),this.type="ordinal",this.uniqueValues=new Set}extend(t){return t==null||Number.isNaN(t)?this:(this.uniqueValues.has(t)||(this.uniqueValues.add(t),this.push(t)),this)}}class fE extends uE{constructor(){super(),this.type="nominal"}}class MN extends Ml{constructor(t){super();let n=0;for(let r=1;r<t.length;r++)n+=Math.sign(t[r]-t[r-1]);if(Math.abs(n)!=t.length-1)throw new Error("Piecewise domain must be strictly increasing or decreasing: "+JSON.stringify(t));t.forEach(r=>this.push(r))}extend(t){if(this.includes(t))return this;throw new Error("Piecewise domains are immutable and cannot be unioned!")}}const hE={quantitative:jm,index:jm,locus:jm,nominal:fE,ordinal:uE};function dE(e,t){if(e=="quantitative"&&ON(t)){const n=new MN(t);return n.type=e,n}else if(hE[e]){const n=new hE[e];return n.type=e,t&&n.extendAll(t),n}throw new Error("Unknown type: "+e)}function ON(e){return e&&e.length>0&&e.length!=2&&e.every(t=>typeof t=="number")}function LN(e){return((e*=2)<=1?e*e:--e*(2-e)+1)/2}function NN(e){return--e*e*e+1}function zN(e){return((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2}function UN(e){return(Math.pow(2,-10*e)-.0009765625)*1.0009775171065494}function $N(e){return 1-UN(e)}function HN(e,t,n){return e*Math.pow(t/e,n)}ke("index",Hm,["continuous"]),ke("locus",aN,["continuous"]),ke("null",Ch,[]);const pE="quantitative",qm="ordinal",Wm="nominal",gE="locus",GN="index";class VN{constructor(t){Z(this,Dr);Z(this,Z0);Z(this,fc);Z(this,oi);Z(this,lf);Z(this,Q0);Z(this,V2);Z(this,uf);Z(this,ai,void 0);Z(this,uc,new Set);Z(this,Ot,void 0);this.channel=t,this.members=[],this.type=null,this.name=void 0}addEventListener(t,n){if(t!="domain")throw new Error("Unsupported event type: "+t);F(this,uc).add(n)}removeEventListener(t,n){if(t!="domain")throw new Error("Unsupported event type: "+t);F(this,uc).delete(n)}pushUnitView(t,n){var o;const r=Jg(t,n),i=r.type,a=(o=r==null?void 0:r.scale)==null?void 0:o.name;if(a){if(this.name!==void 0&&a!=this.name)throw new Error(`Shared scales have conflicting names: "${a}" vs. "${this.name}"!`);this.name=a}if(!this.type)this.type=i;else if(i!==this.type&&!xl(n))throw new Error(`Can not use shared scale for different data types: ${this.type} vs. ${i}. Use "resolve: independent" for channel ${this.channel}`);this.members.push({view:t,channel:n})}isExplicitDomain(){return!!this.getConfiguredDomain()}isDomainInitialized(){const t=F(this,Ot);if(!t)return!1;const n=t.domain();return _t(t.type)?n.length>2||n.length==2&&(n[0]!==0||n[1]!==0):n.length>0}getScaleProps(){return ds(this,"scaleProps",()=>{const t=J(this,Z0,VT).call(this);if(t===null||t.type=="null")return{type:"null"};const n={...J(this,Q0,jT).call(this,this.type),...t};n.type||(n.type=jN(this.channel,this.type));const r=J(this,fc,yp).call(this);return r&&r.length>0?n.domain=r:Vn(n.type)&&(n.domain=new fE),!n.domain&&n.domainMid!==void 0&&(n.domain=[n.domainMin??0,n.domainMax??1]),this.channel=="y"&&Vn(n.type)&&n.reverse==null&&(n.reverse=!0),n.range&&n.scheme&&delete n.scheme,!("zoom"in n)&&["index","locus"].includes(n.type)&&(n.zoom=!0),qN(n,this.channel),n})}getConfiguredDomain(){return J(this,uf,ev).call(this,t=>xl(t.channel)?void 0:t.view.getConfiguredDomain(t.channel))}getDataDomain(){return J(this,uf,ev).call(this,t=>xl(t.channel)?void 0:t.view.extractDataDomain(t.channel))}reconfigure(){if(F(this,Ot)&&F(this,Ot).type!="null"){const t=this.isDomainInitialized(),n=F(this,Ot).domain();NA(this,"scaleProps");const r=this.getScaleProps();if(oE(r,F(this,Ot)),_t(F(this,Ot).type)&&le(this,ai,J(this,lf,J2).call(this)),!t){J(this,Dr,ya).call(this);return}const i=F(this,Ot).domain();th(i,n)||(this.isZoomable()?F(this,Ot).domain(n):J(this,oi,Ho).call(this)?(F(this,Ot).domain(n),this.zoomTo(i,500)):J(this,Dr,ya).call(this))}}getScale(){if(F(this,Ot))return F(this,Ot);const t=this.getScaleProps(),n=vN(t);return le(this,Ot,n),oN(n)&&n.genome(this.getGenome()),_t(n.type)&&le(this,ai,J(this,lf,J2).call(this)),n}getDomain(){return this.getScale().domain()}getComplexDomain(){var t;return((t=this.getGenome())==null?void 0:t.toChromosomalInterval(this.getDomain()))??this.getDomain()}isZoomed(){return J(this,oi,Ho).call(this)&&th(J(this,fc,yp).call(this),this.getDomain())}isZoomable(){return J(this,oi,Ho).call(this)&&!!this.getScaleProps().zoom}zoom(t,n,r){if(!J(this,oi,Ho).call(this))return!1;const i=this.getScale(),a=i.domain();let o=[...a],s=i.invert(n);switch(this.getScaleProps().reverse&&(r=-r),"align"in i&&(s+=i.align()),i.type){case"linear":case"index":case"locus":o=mI(o,r||0),o=xp(o,s,t);break;case"log":o=bI(o,r||0),o=uv(o,s,t);break;case"pow":case"sqrt":{const c=i;o=yI(o,r||0,c.exponent()),o=Ap(o,s,t,c.exponent());break}default:throw new Error("Zooming is not implemented for: "+i.type)}return F(this,ai)&&(o=wI(o,F(this,ai)[0],F(this,ai)[1])),[0,1].some(c=>o[c]!=a[c])?(i.domain(o),J(this,Dr,ya).call(this),!0):!1}async zoomTo(t,n=!1){var s;if(kc(n)&&(n=n?700:0),!J(this,oi,Ho).call(this))throw new Error("Not a zoomable scale!");const r=this.fromComplexInterval(t),i=(s=this.members[0])==null?void 0:s.view.context.animator,a=this.getScale(),o=a.domain();if(n>0&&o.length==2){const c=o[1]-o[0],l=o[0]+c/2,u=r[1]-r[0],f=r[0]+u/2;await i.transition({duration:n,easingFunction:zN,onUpdate:h=>{const d=HN(c,u,h),p=(c-d)/(c-u),g=p*f+(1-p)*l;a.domain([g-d/2,g+d/2]),J(this,Dr,ya).call(this)}}),a.domain(r),J(this,Dr,ya).call(this)}else a.domain(r),i==null||i.requestRender(),J(this,Dr,ya).call(this)}resetZoom(){if(!J(this,oi,Ho).call(this))throw new Error("Not a zoomable scale!");const t=this.getDomain(),n=J(this,fc,yp).call(this);return[0,1].some(r=>n[r]!=t[r])?(F(this,Ot).domain(n),J(this,Dr,ya).call(this),!0):!1}getZoomLevel(){return this.isZoomable()?Lf(F(this,ai))/Lf(this.getScale().domain()):1}getGenome(){var n;if(this.type!=="locus")return;const t=(n=this.members[0].view.context.genomeStore)==null?void 0:n.getGenome();if(!t)throw new Error("No genome has been defined!");return t}invertToComplex(t){const n=this.getScale();if("invert"in n){const r=n.invert(t);return this.toComplex(r)}else throw new Error("The scale does not support inverting!")}toComplex(t){const n=this.getGenome();return n?n.toChromosomal(t):t}fromComplex(t){return td(t)?this.getGenome().toContinuous(t.chrom,t.pos):t}fromComplexInterval(t){return this.type==="locus"&&PN(t)?this.getGenome().toContinuousInterval(t):t}}ai=new WeakMap,uc=new WeakMap,Ot=new WeakMap,Dr=new WeakSet,ya=function(){for(const t of F(this,uc).values())t({type:"domain",scaleResolution:this})},Z0=new WeakSet,VT=function(){return ds(this,"mergedScaleProps",()=>{const t=this.members.map(n=>Jg(n.view,n.channel).scale).filter(n=>n!==void 0);return ed(t,"scale",["domain"])})},fc=new WeakSet,yp=function(){return this.getConfiguredDomain()??(this.type==gE?this.getGenome().getExtent():this.getDataDomain())},oi=new WeakSet,Ho=function(){const t=this.getScale().type;return _t(t)},lf=new WeakSet,J2=function(){const t=this.getScaleProps(),n=t.zoom;if(WN(n)&&Qt(n.extent))return this.fromComplexInterval(n.extent);if(n)return t.type=="locus"?this.getGenome().getExtent():F(this,Ot).domain()},Q0=new WeakSet,jT=function(t){const n=this.channel,r={};return this.isExplicitDomain()&&(r.zero=!1),wl(n)?r.nice=!this.isExplicitDomain():Ha(n)?r.scheme=t==Wm?"tableau10":t==qm?"blues":"viridis":Th(n)?r.range=n=="shape"?["circle","square","triangle-up","cross","diamond"]:[]:n=="size"?r.range=[0,400]:n=="angle"&&(r.range=[0,360]),r},V2=new WeakSet,uee=function(){return this.members.map(t=>t.view.getPathString()).join(", ")},uf=new WeakSet,ev=function(t){const n=this.members.filter(r=>!r.view.getLayoutAncestors().some(i=>!i.options.contributesToScaleDomain)).map(t).filter(r=>!!r);if(n.length)return n.reduce((r,i)=>r.extendAll(i))};function jN(e,t){if(t==GN||t==gE){if(h3(e))return t;throw new Error(`${e} does not support ${t} data type. Only positional channels do.`)}const n={x:["band","band","linear"],y:["band","band","linear"],size:[void 0,"point","linear"],opacity:[void 0,"point","linear"],fillOpacity:[void 0,"point","linear"],strokeOpacity:[void 0,"point","linear"],color:["ordinal","ordinal","linear"],fill:["ordinal","ordinal","linear"],stroke:["ordinal","ordinal","linear"],strokeWidth:[void 0,void 0,"linear"],shape:["ordinal","ordinal",void 0],dx:[void 0,void 0,"null"],dy:[void 0,void 0,"null"],angle:[void 0,void 0,"linear"]},i=["sample"].includes(e)?"null":n[e]?n[e][[Wm,qm,pE].indexOf(t)]:t==pE?"linear":"ordinal";if(i===void 0)throw new Error(`Channel "${e}" is not compatible with "${t}" data type. Use of a proper scale may be needed.`);return i}function qN(e,t){wl(t)&&e.type!=="ordinal"&&(e.range=[0,1]),t=="opacity"&&_t(e.type)&&(e.clamp=!0)}function WN(e){return Xt(e)}function Ym(e){const t=new Set;function n(r){for(const i of Object.values(r.resolutions.scale))t.add(i)}for(const r of Lt(e)){r.visit(n);for(const i of r.getDataAncestors()){if(!i.options.contributesToScaleDomain)break;n(i)}}t.forEach(r=>r.reconfigure())}function Zm(...e){for(const t of e)if(t!==void 0)return t}class YN{constructor(t){this.channel=t,this.members=[]}get scaleResolution(){var t;return(t=xn(this.members))==null?void 0:t.view.getScaleResolution(this.channel)}pushUnitView(t,n){const r=t.getScaleResolution(this.channel);if(!r)throw new Error("Cannot find a scale resolution!");if(this.scaleResolution&&r!==this.scaleResolution)throw new Error("Shared axes must have a shared scale!");this.members.push({view:t,channel:n})}getAxisProps(){return ds(this,"axisProps",()=>{const t=this.members.map(n=>{const r=n.view.mark.encoding[n.channel];return"axis"in r&&r.axis});return t.length>0&&t.some(n=>n===null)?null:ed(t.filter(n=>n!==void 0),"axis",["title"])})}getTitle(){const t=a=>{var s;const o=Jg(a.view,a.channel);if(!jn(o))return{member:a,explicitTitle:Zm("axis"in o?(s=o.axis)==null?void 0:s.title:void 0,o.title),implicitTitle:Zm(Ur(o)?o.field:void 0,kh(o)?o.expr:void 0)}},n=this.members.map(t),r=n.filter(a=>{var o;if(xl(a.member.channel)&&!a.explicitTitle){const s=$a(a.member.channel);return((o=n.find(c=>c.member.view==a.member.view&&c.member.channel==s))==null?void 0:o.explicitTitle)===void 0}return!0}),i=new Set(r.map(a=>Zm(a.explicitTitle,a.implicitTitle)).filter(Me));return i.size?[...i].join(", "):null}}const ZN={point:RL,rect:EL,rule:PL,link:UL,text:WL};class mt extends Yn{constructor(t,n,r,i,a,o){super(t,n,r,i,a,o),this.spec=t;const s=ZN[this.getMarkType()];if(s)this.mark=new s(this);else throw new Error(`No such mark: ${this.getMarkType()}`);this.resolve(),this.needsAxes={x:!0,y:!0}}render(t,n,r={}){super.render(t,n,r),this.isConfiguredVisible()&&(t.pushView(this,n),t.renderMark(this.mark,r),t.popView(this))}getMarkType(){return typeof this.spec.mark=="object"?this.spec.mark.type:this.spec.mark}resolve(t){t||(this.resolve("scale"),this.resolve("axis"));const n=this.mark.encoding;for(const[r,i]of Object.entries(n)){if(!rn(i))continue;const a=$a(i.resolutionChannel??r);if(!Ri(a)||t=="axis"&&!wl(a))continue;let o=this;for(;(o.getConfiguredOrDefaultResolution(a,t)=="forced"||o.dataParent instanceof Yn&&["shared","excluded","forced"].includes(o.dataParent.getConfiguredOrDefaultResolution(a,t)))&&o.getConfiguredOrDefaultResolution(a,t)!="excluded";)o=o.dataParent;t=="axis"&&wl(r)&&h3(a)?(o.resolutions[t][a]||(o.resolutions[t][a]=new YN(a)),o.resolutions[t][a].pushUnitView(this,r)):t=="scale"&&Ri(r)&&(o.resolutions[t][a]||(o.resolutions[t][a]=new VN(a)),o.resolutions[t][a].pushUnitView(this,r))}}getAccessor(t){return this._cache("accessor/"+t,()=>{const n=this.mark.encoding;if(n&&n[t])return this.context.accessorFactory.createAccessor(n[t])})}getFacetAccessor(t){const n=this.getAccessor("sample");return n||super.getFacetAccessor(this)}getCollector(){return this.context.dataFlow.findCollectorByKey(this)}_validateDomainQuery(t){if(xl(t))throw new Error(`getDomain(${t}), must only be called for primary channels!`);const n=this.mark.encoding[t];if(!rn(n))throw new Error("The channel has no scale, cannot get domain!");return n}getConfiguredDomain(t){const n=this._validateDomainQuery(t),r=n&&n.scale&&n.scale.domain;if(r){const i=this.getScaleResolution(n.resolutionChannel??t);return dE(n.type??"nominal",i.fromComplexInterval(r))}}extractDataDomain(t){const r=this._validateDomainQuery(t).type??"nominal",i=s=>{let c;const l=this.mark.encoding[s];if(l){const u=this.context.accessorFactory.createAccessor(l);if(u)if(c=dE(r),u.constant)c.extend(u({}));else{const f=this.getCollector();f!=null&&f.completed&&f.visitData(h=>c.extend(u(h)))}}return c};let a=i(t);const o=em[t];if(o){const s=i(o);s&&a.extendAll(s)}return a}getZoomLevel(){const t=n=>{var r;return((r=this.getScaleResolution(n))==null?void 0:r.getZoomLevel())??1};return ns.map(t).reduce((n,r)=>n*r,1)}propagateInteractionEvent(t){this.handleInteractionEvent(void 0,t,!0),t.target=this,!t.stopped&&this.handleInteractionEvent(void 0,t,!1)}getDefaultResolution(t,n){return t=="x"?"shared":"independent"}}function*Qm(e,t=[]){for(const[n,r]of e.entries())if(r instanceof Map)for(const i of Qm(r,[...t,n]))yield i;else yield[[...t,n],r]}class Ol extends at{get behavior(){return zm}constructor(t){super(),this.params=t??{type:"collect"},this.observers=[],this.facetBatches=void 0,this._init()}_init(){this._data=[],this.facetBatches=new gi([],JSON.stringify),this.facetBatches.set(void 0,this._data)}reset(){super.reset(),this._init()}handle(t){this._data.push(t)}beginBatch(t){TL(t)&&(this._data=[],this.facetBatches.set(Lt(t.facetId),this._data))}complete(){var i,a;const t=(i=this.params)==null?void 0:i.sort,n=t?fv(t.field,t.order):void 0,r=o=>{n&&o.sort(n)};if((a=this.params.groupby)!=null&&a.length){if(this.facetBatches.size>1)throw new Error("TODO: Support faceted data!");const o=this.params.groupby.map(c=>Oe(c)),s=o.length>1?Rc(this._data,...o):QN(this._data,o[0]);this.facetBatches.clear();for(const[c,l]of Qm(s))this.facetBatches.set(c,l)}for(const o of this.facetBatches.values())r(o);if(this.children.length)for(const[o,s]of this.facetBatches.entries()){if(o){const c={type:"facet",facetId:o};for(const l of this.children)l.beginBatch(c)}for(const c of s)this._propagate(c)}super.complete();for(const o of this.observers)o(this)}getData(){switch(this._checkStatus(),this.facetBatches.size){case 0:return[];case 1:return[...this.facetBatches.values()][0];default:{const t=this.facetBatches;return{[Symbol.iterator]:function*(){for(const r of t.values())for(let i=0;i<r.length;i++)yield r[i]}}}}}visitData(t){this._checkStatus();for(const n of this.facetBatches.values())for(let r=0;r<n.length;r++)t(n[r])}getItemCount(){let t=0;for(const n of this.facetBatches.values())t+=n.length;return t}_checkStatus(){if(!this.completed)throw new Error("Data propagation is not completed! No data are available.")}}function QN(e,t){const n=new Map;for(let r=0,i=e.length;r<i;r++){const a=e[r],o=t(a);let s=n.get(o);s||(s=[],n.set(o,s)),s.push(a)}return n}class Ll{constructor(){this.ids=[],this.values=[],this.length=0}clear(){this.length=0}push(t,n){let r=this.length++;for(;r>0;){const i=r-1>>1,a=this.values[i];if(n>=a)break;this.ids[r]=this.ids[i],this.values[r]=a,r=i}this.ids[r]=t,this.values[r]=n}pop(){if(this.length===0)return;const t=this.ids[0];if(this.length--,this.length>0){const n=this.ids[0]=this.ids[this.length],r=this.values[0]=this.values[this.length],i=this.length>>1;let a=0;for(;a<i;){let o=(a<<1)+1;const s=o+1;let c=this.ids[o],l=this.values[o];const u=this.values[s];if(s<this.length&&u<l&&(o=s,c=this.ids[s],l=u),l>=r)break;this.ids[a]=c,this.values[a]=l,a=o}this.ids[a]=n,this.values[a]=r}return t}peek(){if(this.length!==0)return this.ids[0]}peekValue(){if(this.length!==0)return this.values[0]}shrink(){this.ids.length=this.values.length=this.length}}class XN extends at{get behavior(){return mr}constructor(t){super(),this.params=t,this.startAccessor=Oe(t.start),this.endAccessor=Oe(t.end),this.chromAccessor=t.chrom?Oe(t.chrom):n=>{},this.weightAccessor=t.weight?Oe(t.weight):n=>1,this.as={coverage:t.as||"coverage",start:t.asStart||t.start,end:t.asEnd||t.end,chrom:t.asChrom||t.chrom},this.createSegment=new Function("start","end","coverage","chrom","return {"+Object.entries(this.as).filter(([n,r])=>r).map(([n,r])=>`${JSON.stringify(r)}: ${n}`).join(", ")+"};"),this.ends=new Ll}reset(){super.reset(),this.initialize()}initialize(){const t=this.as.coverage,n=this.as.end,r=this.as.chrom,i=this.startAccessor,a=this.endAccessor,o=this.chromAccessor,s=this.weightAccessor;let c,l,u,f=0,h;const d=this.ends;d.clear();const p=(b,y,w)=>{if(b==y)return;let A=!1;c&&(c[t]===w?(c[n]=y,A=!0):c[t]!=0&&this._propagate(c)),A||(c=this.createSegment(b,y,w,u))},g=()=>{let b;for(;(b=d.peekValue())!==void 0;)p(h,b,f),h=b,f-=d.pop();h=void 0,c&&(this._propagate(c),c=void 0)};this.handle=b=>{const y=i(b);let w;for(;(w=d.peekValue())!==void 0&&w<y;)p(h,w,f),h=w,f-=d.pop();if(r){let x=o(b);x!==l&&(g(),u=x,l=u)}h!==void 0&&p(h,y,f),h=y;const A=s(b);f+=A,d.push(A,a(b))},this.complete=()=>{g(),super.complete()}}}function KN(e,t,n=0,r=e.length){const i=new Ll,a=r-n;let o;for(o=0;o<t&&o<a;o++)i.push(o,e[n+o]);for(;o<a;o++){const l=e[n+o];l>=i.peekValue()&&(i.push(o,l),i.pop())}const s=[];let c;for(;(c=i.pop())!==void 0;)s.push(n+c);return s.reverse()}class JN{constructor(t,n=-1/0,r=1/0){this.maxSize=t,this.lowerLimit=n,this.upperLimit=r;const i=this.maxSize*2+1;this.lowerLimits=new Float64Array(i),this.upperLimits=new Float64Array(i),this.lowerChildren=new Int32Array(i),this.upperChildren=new Int32Array(i),this.reset()}reset(){this.lowerLimits.fill(0),this.upperLimits.fill(0),this.lowerChildren.fill(0),this.upperChildren.fill(0),this.n=1,this.lowerLimits[0]=this.lowerLimit,this.upperLimits[0]=this.upperLimit}_findSlot(t,n,r=0){if(t>=this.lowerLimits[r]&&n<=this.upperLimits[r]){const i=this.lowerChildren[r];if(i){const a=this._findSlot(t,n,i);return a>=0?a:this._findSlot(t,n,this.upperChildren[r])}else return r}else return-1}reserve(t,n){if(n-t<=0)throw new Error("Cannot reserve an empty or negative-size slot!");if(this.n+1>this.lowerLimits.length)return!1;const r=this._findSlot(t,n);if(r<0)return!1;const i=this.n++,a=this.n++;return this.lowerLimits[i]=this.lowerLimits[r],this.upperLimits[i]=t,this.lowerLimits[a]=n,this.upperLimits[a]=this.upperLimits[r],this.lowerChildren[r]=i,this.upperChildren[r]=a,!0}}class ez extends at{get behavior(){return zm}constructor(t,n){if(super(),this.params=t,this._data=[],this.channel=t.channel??"x",!["x","y"].includes(this.channel))throw new Error("Invalid channel: "+this.channel);this.posAccessor=Oe(this.params.pos),this.posBisector=Uf(this.posAccessor),this.scoreAccessor=Oe(this.params.score),this.widthAccessor=Oe(this.params.width),this.laneAccessor=this.params.lane?Oe(this.params.lane):i=>0,this.padding=this.params.padding??0,this.reservationMaps=new Map,this.resolution=n.getScaleResolution(this.channel);const r=()=>this._filterAndPropagate();this.schedule=()=>n.context.animator.requestTransition(r),this.resolution.addEventListener("domain",i=>this.schedule()),n._addBroadcastHandler("layoutComputed",()=>this.schedule())}complete(){const t=this.posAccessor;this._data.sort((n,r)=>t(n)-t(r)),this._scores=this._data.map(this.scoreAccessor);for(const n of new Set(this._data.map(this.laneAccessor)))this.reservationMaps.set(n,new JN(200));this.schedule(),super.complete()}_filterAndPropagate(){var o;super.reset();const t=this.resolution.getScale(),n=(o=this.resolution.members[0].view.coords)==null?void 0:o[this.channel=="x"?"width":"height"];if(!n)return;for(const s of this.reservationMaps.values())s.reset();const r=t.domain(),i=70,a=KN(this._scores,i,this.posBisector.left(this._data,r[0]),this.posBisector.right(this._data,r[1]));for(const s of a){const c=this._data[s],l=t(this.posAccessor(c))*n,u=this.widthAccessor(c)/2+this.padding;this.reservationMaps.get(this.laneAccessor(c)).reserve(l-u,l+u)&&this._propagate(c)}super.complete()}reset(){super.reset(),this._data=[],this.groups=new Map}handle(t){this._data.push(t)}}class tz extends at{constructor(t){super(),this.params=t,this.predicate=void 0}initialize(){this.predicate=ch(this.params.expr,this.getGlobalObject())}handle(t){this.predicate(t)&&this._propagate(t)}}class nz extends at{get behavior(){return mr}constructor(t){super();const n=t.index;if(t.fields){const r=Lt(t.fields).map(a=>Oe(a)),i=Lt(t.as||t.fields);if(r.length!==i.length)throw new Error(`Lengths of "fields" (${r.length}), and "as" (${i.length}) do not match!`);this.handle=a=>{const o=r.map((c,l)=>c(a)??[]),s=o[0].length;for(let c=0;c<s;c++){const l=Object.assign({},a);for(let u=0;u<r.length;u++)l[i[u]]=c<o[u].length?o[u][c]:null;n&&(l[n]=c),this._propagate(l)}}}else this.handle=r=>{for(let i=0;i<r.length;i++){const a=Object.assign({},r[i]);n&&(a[n]=i),this._propagate(a)}}}}const rz="0".charCodeAt(0);function*iz(e,t=","){const n=t.charCodeAt(0);let r=0;for(let i=0;i<e.length;i++){const a=e.charCodeAt(i);a==n?(yield r,r=0):r=r*10+a-rz}yield r}class az extends at{get behavior(){return mr}constructor(t){super();const n=Oe(t.exons??"exons"),r=Oe(t.start??"start"),[i,a]=t.as||["exonStart","exonEnd"];this.handle=o=>{let s=r(o),c=s,l=!0;const u=n(o);for(const f of iz(u)){if(l)c=s+f;else{s=c+f;const h=Object.assign({},o);h[i]=c,h[a]=s,this._propagate(h)}l=!l}}}}class oz extends at{get behavior(){return mr}constructor(t){super();const n=Lt(t.field).map(a=>Oe(a)),r=Lt(t.separator),i=Lt(t.as||t.field);if(n.length!==r.length||n.length!==i.length)throw new Error(`Lengths of "separator" (${r.length}), "fields" (${n.length}), and "as" (${i.length}) do not match!`);this.handle=a=>{if(n.some(c=>!c(a)))return;const o=n.map((c,l)=>c(a).split(r[l]));sz(o,a);const s=o[0].length;for(let c=0;c<s;c++){const l=Object.assign({},a);for(let u=0;u<n.length;u++)l[i[u]]=o[u][c];this._propagate(l)}}}}function sz(e,t){const n=e.map(r=>r.length);if(!n.every(r=>r==n[0]))throw new Error("Mismatching number of elements in the fields to be split: "+JSON.stringify(t))}class cz extends at{get behavior(){return Li}constructor(t){super(),this.params=t,this.as=t.as,this.fn=void 0}initialize(){this.fn=ch(this.params.expr,this.getGlobalObject())}handle(t){t[this.as]=this.fn(t),this._propagate(t)}}class mE extends at{get behavior(){return Li}constructor(t,n){super();const r=t.channel??"x";if(!["x","y"].includes(r))throw new Error("Invalid channel: "+r);const i=n.getScaleResolution(r).getGenome();if(!i)throw new Error("LinearizeGenomicCoordinate transform requires a locus scale!");const a=Oe(t.chrom),o=Lt(t.pos).map(p=>Oe(p)),s=Lt(t.as);if(o.length!=s.length)throw new Error('The number of "pos" and "as" elements must be equal!');const c=Lt(t.offset);let l;if(c.length==0)l=new Array(o.length).fill(0);else if(c.length==1)l=new Array(o.length).fill(c[0]);else if(c.length==o.length)l=c;else throw new Error(`Invalid "offset" parameter: ${JSON.stringify(t.offset)}!`);const u=new Function("datum","chromOffset","posAccessors",s.map((p,g)=>`datum[${JSON.stringify(p)}] = chromOffset + +posAccessors[${g}](datum) - ${l[g]};`).join(`
1694
+ */const pN="locus",gN="index";var mN=5;function bN(e){const t=e.type;return!e.bins&&(t===es||t===pl||t===gl)}function iE(e){return _t(e)&&![dr,gN,pN].includes(e)}function aE(e){return e||{warn:(t,...n)=>console.warn(t,...n)}}var yN=zf(["set","modified","clear","type","scheme","schemeExtent","schemeCount","domain","domainMin","domainMid","domainMax","domainRaw","domainImplicit","nice","zero","bins","range","rangeStep","round","reverse","interpolate","interpolateGamma","zoom","fp64","name"]);function oE(e,t,n){n=aE(n);for(const r in e)if(!yN[r]){if(r==="padding"&&iE(t.type))continue;Kt(t[r])?t[r](e[r]):n.warn("Unsupported scale property: "+r)}CN(t,e,_N(t,e,AN(t,e,n)))}function vN(e,t){const n=wN(e),r=ke(n);if(!r)throw new Error("Unknown scale type: "+n);const i=r();return!e.domain&&_t(i.type)&&(e.domain=[0,0]),oE(e,i,t),i}function wN(e){var t=e.type,n="",r;return t===dr?dr+"-"+es:(xN(e)&&(r=e.rawDomain?e.rawDomain.length:e.domain?e.domain.length+ +(e.domainMid!=null):0,n=r===2?dr+"-":r===3?ts+"-":""),(n+t||es).toLowerCase())}function xN(e){const t=e.type;return _t(t)&&t!==Kx&&t!==Jx&&(e.scheme||e.range&&e.range.length&&e.range.every(Me))}function AN(e,t,n){if(!e.domain)return 0;n=aE(n);var r=EN(e,t.domainRaw,n);if(r>-1)return r;var i=t.domain,a=e.type,o=t.zero||t.zero===void 0&&bN(e),s,c;return i?(iE(a)&&t.padding&&i[0]!==Un(i)&&(i=SN(a,i,t.range,t.padding,t.exponent,t.constant)),(o||t.domainMin!=null||t.domainMax!=null||t.domainMid!=null)&&(s=(i=i.slice()).length-1||1,o&&(i[0]>0&&(i[0]=0),i[s]<0&&(i[s]=0)),t.domainMin!=null&&(i[0]=t.domainMin),t.domainMax!=null&&(i[s]=t.domainMax),t.domainMid!=null&&(c=t.domainMid,(c<i[0]||c>i[s])&&n.warn("Scale domainMid exceeds domain min or max.",c),i.splice(s,0,c))),e.domain(sE(a,i,n)),a===Yg&&e.unknown(t.domainImplicit?gg:void 0),t.nice&&e.nice&&e.nice(t.nice!==!0&&nE(e,t.nice)||null),i.length):0}function EN(e,t,n){return t?(e.domain(sE(e.type,t,n)),t.length):-1}function SN(e,t,n,r,i,a){var o=Math.abs(Un(n)-n[0]),s=o/(o-2*r),c=e===Ti?uv(t,null,s):e===gl?Ap(t,null,s,.5):e===pl?Ap(t,null,s,i||1):e===Ah?vI(t,null,s,a||1):xp(t,null,s);return t=t.slice(),t[0]=c[0],t[t.length-1]=c[1],t}function sE(e,t,n){if(o3(e)){var r=Math.abs(t.reduce(function(i,a){return i+(a<0?-1:a>0?1:0)},0));r!==t.length&&n.warn("Log scale domain includes zero: "+Nf(t))}return t}function _N(e,t,n){let r=t.bins;if(r&&!Qt(r)){const i=(r.start==null||r.stop==null)&&e.domain(),a=r.start==null?i[0]:r.start,o=r.stop==null?Un(i):r.stop,s=r.step;s||it("Scale bins parameter missing step property."),r=mi(a,o+s,s)}return r?e.bins=r:e.bins&&delete e.bins,e.type===Qg&&(r?!t.domain&&!t.domainRaw&&(e.domain(r),n=r.length):e.bins=e.domain()),n}function CN(e,t,n){var r=e.type,i=t.round||!1,a=t.range;if(t.rangeStep!=null)a=kN(r,t,n);else if(t.scheme&&(a=TN(r,t,n),Kt(a))){if(e.interpolator)return e.interpolator(a);it(`Scale type ${r} does not support interpolating color schemes.`)}if(a&&Sh(r))return e.interpolator(_h(Gm(a,t.reverse),t.interpolate,t.interpolateGamma));a&&t.interpolate&&e.interpolate?e.interpolate(s3(t.interpolate,t.interpolateGamma)):Kt(e.round)?e.round(i):Kt(e.rangeRound)&&e.interpolate(i?hl:Ci),a&&e.range(Gm(a,t.reverse))}function kN(e,t,n){e!==n3&&e!==Zg&&it("Only band and point scales support rangeStep.");var r=(t.paddingOuter!=null?t.paddingOuter:t.padding)||0,i=e===Zg?1:(t.paddingInner!=null?t.paddingInner:t.padding)||0;return[0,t.rangeStep*qg(n,i,r)]}function TN(e,t,n){var r=t.schemeExtent,i,a;return Qt(t.scheme)?a=_h(t.scheme,t.interpolate,t.interpolateGamma):(i=t.scheme.toLowerCase(),a=Kg(i),a||it(`Unrecognized scheme name: ${t.scheme}`)),n=e===t3?n+1:e===Qg?n-1:e===Wg||e===e3?+t.schemeCount||mN:n,Sh(e)?cE(a,r,t.reverse):Kt(a)?HB(cE(a,r),n):e===Yg?a:a.slice(0,n)}function cE(e,t,n){return Kt(e)&&(t||n)?$B(e,Gm(t||[0,1],n)):e}function Gm(e,t){return t?e.slice().reverse():e}const Vm=pt(",d");function IN(e){return e.chrom+":"+Vm(Math.floor(e.pos+1))}function lE(e){return!ft(e)&&"chrom"in e?IN(e):""+e}function RN(e,t){return e.chrom+":"+Vm(Math.floor(e.pos+1))+"-"+(e.chrom!=t.chrom?t.chrom+":":"")+Vm(Math.ceil(t.pos))}const DN="https://genomespy.app/data/genomes/";class BN{constructor(t){if(this.config=t,!this.config.contigs&&typeof this.config.name!="string")throw new Error("No name has been defined for the genome assembly!");this.chromosomes=[],this.cumulativeChromPositions=new Map,this.chromosomesByName=new Map,this.startByIndex=[],this.totalSize=0,this.config.contigs&&this.setChromSizes(this.config.contigs)}get name(){return this.config.name}async load(t){if(!this.config.contigs){this.config.baseUrl?this.baseUrl=/^http(s)?/.test(this.config.baseUrl)?this.config.baseUrl:t+"/"+this.config.baseUrl:this.baseUrl=DN;try{this.setChromSizes(FN(await Zc({baseURL:this.baseUrl}).load(`${this.config.name}/${this.name}.chrom.sizes`)))}catch(n){throw new Error(`Could not load chrom sizes: ${n.message}`)}}}hasChrPrefix(){return this.chromosomes.some(t=>t.name.startsWith("chr"))}setChromSizes(t){let n=0;this.startByIndex=[0];for(let r=0;r<t.length;r++){this.startByIndex.push(n);const i=t[r].size,a={...t[r],continuousStart:n,continuousEnd:n+i,continuousInterval:[n,n+i],index:r,number:r+1,odd:!(r&1)};this.chromosomes.push(a);const o=a.name.replace(/^chr/i,"");for(const s of["chr"+o,"CHR"+o,"Chr"+o,a.number,""+a.number,o,a.name])this.cumulativeChromPositions.set(s,n),this.chromosomesByName.set(s,a);n+=a.size}this.totalSize=n}getExtent(){return[0,this.totalSize]}toContinuous(t,n){let r=this.cumulativeChromPositions.get(t);if(r===void 0)throw new Error("Unknown chromosome/contig: "+t);return r+ +n}toChromosome(t){if(t>this.totalSize)return;t=Math.floor(t);const n=Pr(this.startByIndex,t)-1;if(n>0&&n<=this.chromosomes.length)return this.chromosomes[n-1]}toChromosomal(t){const n=this.toChromosome(t);if(n)return{chrom:n.name,pos:Math.floor(t)-n.continuousStart}}getChromosome(t){return this.chromosomesByName.get(t)}formatInterval(t){return RN(...this.toChromosomalInterval(t))}toChromosomalInterval(t){const n=this.toChromosomal(t[0]+.5),r=this.toChromosomal(t[1]-.5);return r.pos+=1,[n,r]}toContinuousInterval(t){var i;let[n,r]=t;return r||(r=n),[this.toContinuous(n.chrom,n.pos??0),this.toContinuous(r.chrom,r.pos??((i=this.chromosomesByName.get(r.chrom))==null?void 0:i.size))]}toDiscreteChromosomeIntervals(t){const n=t[0],r=t[1],i=[];if(n.chrom===r.chrom)i.push({chrom:n.chrom,startPos:n.pos,endPos:r.pos});else{const a=this.chromosomes.findIndex(s=>s.name===n.chrom),o=this.chromosomes.findIndex(s=>s.name===r.chrom);i.push({chrom:n.chrom,startPos:n.pos,endPos:this.chromosomes[a].size});for(let s=a+1;s<o;s++)i.push({chrom:this.chromosomes[s].name,startPos:0,endPos:this.chromosomes[s].size});i.push({chrom:r.chrom,startPos:0,endPos:r.pos})}return i}continuousToDiscreteChromosomeIntervals(t){return this.toDiscreteChromosomeIntervals([this.toChromosomal(t[0]),this.toChromosomal(t[1])])}parseInterval(t){const n=t.match(/^(chr[0-9A-Z]+)(?::([0-9,]+)(?:-(?:(chr[0-9A-Z]+):)?([0-9,]+))?)?$/);if(n){const r=n[1];if(n.slice(2).every(s=>s===void 0)){const s=this.getChromosome(r);return s?[s.continuousStart,s.continuousEnd]:void 0}const i=n[3]||r,a=parseInt(n[2].replace(/,/g,"")),o=n[4]!==void 0?parseInt(n[4].replace(/,/g,"")):a;return[this.toContinuous(r,a-1),this.toContinuous(i,o)]}}}function FN(e){return NI(e).filter(t=>/^chr[0-9A-Z]+$/.test(t[0])).map(([t,n])=>({name:t,size:parseInt(n)}))}function td(e){return Xt(e)&&"chrom"in e}function PN(e){return e.every(td)}class Ml extends Array{constructor(){super(),this.type=void 0}extend(t){return this}extendAll(t){if(t instanceof Ml&&t.type!=this.type)throw new Error(`Cannot combine different types of domains: ${this.type} and ${t.type}`);for(const n of t)this.extend(n);return this}extendAllWithAccessor(t,n){for(const r of t)this.extend(n(r));return this}}class jm extends Ml{constructor(){super(),this.type="quantitative"}extend(t){return t==null||Number.isNaN(t)?this:(t=+t,this.length?t<this[0]?this[0]=t:t>this[1]&&(this[1]=t):(this.push(t),this.push(t)),this)}}class uE extends Ml{constructor(){super(),this.type="ordinal",this.uniqueValues=new Set}extend(t){return t==null||Number.isNaN(t)?this:(this.uniqueValues.has(t)||(this.uniqueValues.add(t),this.push(t)),this)}}class fE extends uE{constructor(){super(),this.type="nominal"}}class MN extends Ml{constructor(t){super();let n=0;for(let r=1;r<t.length;r++)n+=Math.sign(t[r]-t[r-1]);if(Math.abs(n)!=t.length-1)throw new Error("Piecewise domain must be strictly increasing or decreasing: "+JSON.stringify(t));t.forEach(r=>this.push(r))}extend(t){if(this.includes(t))return this;throw new Error("Piecewise domains are immutable and cannot be unioned!")}}const hE={quantitative:jm,index:jm,locus:jm,nominal:fE,ordinal:uE};function dE(e,t){if(e=="quantitative"&&ON(t)){const n=new MN(t);return n.type=e,n}else if(hE[e]){const n=new hE[e];return n.type=e,t&&n.extendAll(t),n}throw new Error("Unknown type: "+e)}function ON(e){return e&&e.length>0&&e.length!=2&&e.every(t=>typeof t=="number")}function LN(e){return((e*=2)<=1?e*e:--e*(2-e)+1)/2}function NN(e){return--e*e*e+1}function zN(e){return((e*=2)<=1?e*e*e:(e-=2)*e*e+2)/2}function UN(e){return(Math.pow(2,-10*e)-.0009765625)*1.0009775171065494}function $N(e){return 1-UN(e)}function HN(e,t,n){return e*Math.pow(t/e,n)}ke("index",Hm,["continuous"]),ke("locus",aN,["continuous"]),ke("null",Ch,[]);const pE="quantitative",qm="ordinal",Wm="nominal",gE="locus",GN="index";class VN{constructor(t){Z(this,Dr);Z(this,Z0);Z(this,fc);Z(this,oi);Z(this,lf);Z(this,Q0);Z(this,V2);Z(this,uf);Z(this,ai,void 0);Z(this,uc,new Set);Z(this,Ot,void 0);this.channel=t,this.members=[],this.type=null,this.name=void 0}addEventListener(t,n){if(t!="domain")throw new Error("Unsupported event type: "+t);F(this,uc).add(n)}removeEventListener(t,n){if(t!="domain")throw new Error("Unsupported event type: "+t);F(this,uc).delete(n)}pushUnitView(t,n){var o;const r=Jg(t,n),i=r.type,a=(o=r==null?void 0:r.scale)==null?void 0:o.name;if(a){if(this.name!==void 0&&a!=this.name)throw new Error(`Shared scales have conflicting names: "${a}" vs. "${this.name}"!`);this.name=a}if(!this.type)this.type=i;else if(i!==this.type&&!xl(n))throw new Error(`Can not use shared scale for different data types: ${this.type} vs. ${i}. Use "resolve: independent" for channel ${this.channel}`);this.members.push({view:t,channel:n})}isExplicitDomain(){return!!this.getConfiguredDomain()}isDomainInitialized(){const t=F(this,Ot);if(!t)return!1;const n=t.domain();return _t(t.type)?n.length>2||n.length==2&&(n[0]!==0||n[1]!==0):n.length>0}getScaleProps(){return ds(this,"scaleProps",()=>{const t=J(this,Z0,VT).call(this);if(t===null||t.type=="null")return{type:"null"};const n={...J(this,Q0,jT).call(this,this.type),...t};n.type||(n.type=jN(this.channel,this.type));const r=J(this,fc,yp).call(this);return r&&r.length>0?n.domain=r:Vn(n.type)&&(n.domain=new fE),!n.domain&&n.domainMid!==void 0&&(n.domain=[n.domainMin??0,n.domainMax??1]),this.channel=="y"&&Vn(n.type)&&n.reverse==null&&(n.reverse=!0),n.range&&n.scheme&&delete n.scheme,!("zoom"in n)&&["index","locus"].includes(n.type)&&(n.zoom=!0),qN(n,this.channel),n})}getConfiguredDomain(){return J(this,uf,ev).call(this,t=>xl(t.channel)?void 0:t.view.getConfiguredDomain(t.channel))}getDataDomain(){return J(this,uf,ev).call(this,t=>xl(t.channel)?void 0:t.view.extractDataDomain(t.channel))}reconfigure(){if(F(this,Ot)&&F(this,Ot).type!="null"){const t=this.isDomainInitialized(),n=F(this,Ot).domain();NA(this,"scaleProps");const r=this.getScaleProps();if(oE(r,F(this,Ot)),_t(F(this,Ot).type)&&le(this,ai,J(this,lf,J2).call(this)),!t){J(this,Dr,ya).call(this);return}const i=F(this,Ot).domain();th(i,n)||(this.isZoomable()?F(this,Ot).domain(n):J(this,oi,Ho).call(this)?(F(this,Ot).domain(n),this.zoomTo(i,500)):J(this,Dr,ya).call(this))}}getScale(){if(F(this,Ot))return F(this,Ot);const t=this.getScaleProps(),n=vN(t);return le(this,Ot,n),oN(n)&&n.genome(this.getGenome()),_t(n.type)&&le(this,ai,J(this,lf,J2).call(this)),n}getDomain(){return this.getScale().domain()}getComplexDomain(){var t;return((t=this.getGenome())==null?void 0:t.toChromosomalInterval(this.getDomain()))??this.getDomain()}isZoomed(){return J(this,oi,Ho).call(this)&&th(J(this,fc,yp).call(this),this.getDomain())}isZoomable(){return J(this,oi,Ho).call(this)&&!!this.getScaleProps().zoom}zoom(t,n,r){if(!J(this,oi,Ho).call(this))return!1;const i=this.getScale(),a=i.domain();let o=[...a],s=i.invert(n);switch(this.getScaleProps().reverse&&(r=-r),"align"in i&&(s+=i.align()),i.type){case"linear":case"index":case"locus":o=mI(o,r||0),o=xp(o,s,t);break;case"log":o=bI(o,r||0),o=uv(o,s,t);break;case"pow":case"sqrt":{const c=i;o=yI(o,r||0,c.exponent()),o=Ap(o,s,t,c.exponent());break}default:throw new Error("Zooming is not implemented for: "+i.type)}return F(this,ai)&&(o=wI(o,F(this,ai)[0],F(this,ai)[1])),[0,1].some(c=>o[c]!=a[c])?(i.domain(o),J(this,Dr,ya).call(this),!0):!1}async zoomTo(t,n=!1){var s;if(kc(n)&&(n=n?700:0),!J(this,oi,Ho).call(this))throw new Error("Not a zoomable scale!");const r=this.fromComplexInterval(t),i=(s=this.members[0])==null?void 0:s.view.context.animator,a=this.getScale(),o=a.domain();if(n>0&&o.length==2){const c=o[1]-o[0],l=o[0]+c/2,u=r[1]-r[0],f=r[0]+u/2;await i.transition({duration:n,easingFunction:zN,onUpdate:h=>{const d=HN(c,u,h),p=(c-d)/(c-u),g=p*f+(1-p)*l;a.domain([g-d/2,g+d/2]),J(this,Dr,ya).call(this)}}),a.domain(r),J(this,Dr,ya).call(this)}else a.domain(r),i==null||i.requestRender(),J(this,Dr,ya).call(this)}resetZoom(){if(!J(this,oi,Ho).call(this))throw new Error("Not a zoomable scale!");const t=this.getDomain(),n=J(this,fc,yp).call(this);return[0,1].some(r=>n[r]!=t[r])?(F(this,Ot).domain(n),J(this,Dr,ya).call(this),!0):!1}getZoomLevel(){return this.isZoomable()?Lf(F(this,ai))/Lf(this.getScale().domain()):1}getGenome(){var n;if(this.type!=="locus")return;const t=(n=this.members[0].view.context.genomeStore)==null?void 0:n.getGenome();if(!t)throw new Error("No genome has been defined!");return t}invertToComplex(t){const n=this.getScale();if("invert"in n){const r=n.invert(t);return this.toComplex(r)}else throw new Error("The scale does not support inverting!")}toComplex(t){const n=this.getGenome();return n?n.toChromosomal(t):t}fromComplex(t){return td(t)?this.getGenome().toContinuous(t.chrom,t.pos):t}fromComplexInterval(t){return this.type==="locus"&&PN(t)?this.getGenome().toContinuousInterval(t):t}}ai=new WeakMap,uc=new WeakMap,Ot=new WeakMap,Dr=new WeakSet,ya=function(){for(const t of F(this,uc).values())t({type:"domain",scaleResolution:this})},Z0=new WeakSet,VT=function(){return ds(this,"mergedScaleProps",()=>{const t=this.members.map(n=>Jg(n.view,n.channel).scale).filter(n=>n!==void 0);return ed(t,"scale",["domain"])})},fc=new WeakSet,yp=function(){return this.getConfiguredDomain()??(this.type==gE?this.getGenome().getExtent():this.getDataDomain())},oi=new WeakSet,Ho=function(){const t=this.getScale().type;return _t(t)},lf=new WeakSet,J2=function(){const t=this.getScaleProps(),n=t.zoom;if(WN(n)&&Qt(n.extent))return this.fromComplexInterval(n.extent);if(n)return t.type=="locus"?this.getGenome().getExtent():F(this,Ot).domain()},Q0=new WeakSet,jT=function(t){const n=this.channel,r={};return this.isExplicitDomain()&&(r.zero=!1),wl(n)?r.nice=!this.isExplicitDomain():Ha(n)?r.scheme=t==Wm?"tableau10":t==qm?"blues":"viridis":Th(n)?r.range=n=="shape"?["circle","square","triangle-up","cross","diamond"]:[]:n=="size"?r.range=[0,400]:n=="angle"&&(r.range=[0,360]),r},V2=new WeakSet,uee=function(){return this.members.map(t=>t.view.getPathString()).join(", ")},uf=new WeakSet,ev=function(t){const n=this.members.filter(r=>!r.view.getLayoutAncestors().some(i=>!i.options.contributesToScaleDomain)).map(t).filter(r=>!!r);if(n.length)return n.reduce((r,i)=>r.extendAll(i))};function jN(e,t){if(t==GN||t==gE){if(h3(e))return t;throw new Error(`${e} does not support ${t} data type. Only positional channels do.`)}const n={x:["band","band","linear"],y:["band","band","linear"],size:[void 0,"point","linear"],opacity:[void 0,"point","linear"],fillOpacity:[void 0,"point","linear"],strokeOpacity:[void 0,"point","linear"],color:["ordinal","ordinal","linear"],fill:["ordinal","ordinal","linear"],stroke:["ordinal","ordinal","linear"],strokeWidth:[void 0,void 0,"linear"],shape:["ordinal","ordinal",void 0],dx:[void 0,void 0,"null"],dy:[void 0,void 0,"null"],angle:[void 0,void 0,"linear"]},i=["sample"].includes(e)?"null":n[e]?n[e][[Wm,qm,pE].indexOf(t)]:t==pE?"linear":"ordinal";if(i===void 0)throw new Error(`Channel "${e}" is not compatible with "${t}" data type. Use of a proper scale may be needed.`);return i}function qN(e,t){wl(t)&&e.type!=="ordinal"&&(e.range=[0,1]),t=="opacity"&&_t(e.type)&&(e.clamp=!0)}function WN(e){return Xt(e)}function Ym(e){const t=new Set;function n(r){for(const i of Object.values(r.resolutions.scale))t.add(i)}for(const r of Lt(e)){r.visit(n);for(const i of r.getDataAncestors()){if(!i.options.contributesToScaleDomain)break;n(i)}}t.forEach(r=>r.reconfigure())}function Zm(...e){for(const t of e)if(t!==void 0)return t}class YN{constructor(t){this.channel=t,this.members=[]}get scaleResolution(){var t;return(t=xn(this.members))==null?void 0:t.view.getScaleResolution(this.channel)}pushUnitView(t,n){const r=t.getScaleResolution(this.channel);if(!r)throw new Error("Cannot find a scale resolution!");if(this.scaleResolution&&r!==this.scaleResolution)throw new Error("Shared axes must have a shared scale!");this.members.push({view:t,channel:n})}getAxisProps(){return ds(this,"axisProps",()=>{const t=this.members.map(n=>{const r=n.view.mark.encoding[n.channel];return"axis"in r&&r.axis});return t.length>0&&t.some(n=>n===null)?null:ed(t.filter(n=>n!==void 0),"axis",["title"])})}getTitle(){const t=a=>{var s;const o=Jg(a.view,a.channel);if(!jn(o))return{member:a,explicitTitle:Zm("axis"in o?(s=o.axis)==null?void 0:s.title:void 0,o.title),implicitTitle:Zm(Ur(o)?o.field:void 0,kh(o)?o.expr:void 0)}},n=this.members.map(t),r=n.filter(a=>{var o;if(xl(a.member.channel)&&!a.explicitTitle){const s=$a(a.member.channel);return((o=n.find(c=>c.member.view==a.member.view&&c.member.channel==s))==null?void 0:o.explicitTitle)===void 0}return!0}),i=new Set(r.map(a=>Zm(a.explicitTitle,a.implicitTitle)).filter(Me));return i.size?[...i].join(", "):null}}const ZN={point:RL,rect:EL,rule:PL,link:UL,text:WL};class mt extends Yn{constructor(t,n,r,i,a,o){super(t,n,r,i,a,o),this.spec=t;const s=ZN[this.getMarkType()];if(s)this.mark=new s(this);else throw new Error(`No such mark: ${this.getMarkType()}`);this.resolve(),this.needsAxes={x:!0,y:!0}}render(t,n,r={}){super.render(t,n,r),this.isConfiguredVisible()&&(t.pushView(this,n),t.renderMark(this.mark,r),t.popView(this))}getMarkType(){return typeof this.spec.mark=="object"?this.spec.mark.type:this.spec.mark}resolve(t){t||(this.resolve("scale"),this.resolve("axis"));const n=this.mark.encoding;for(const[r,i]of Object.entries(n)){if(!rn(i))continue;const a=$a(i.resolutionChannel??r);if(!Ri(a)||t=="axis"&&!wl(a))continue;let o=this;for(;(o.getConfiguredOrDefaultResolution(a,t)=="forced"||o.dataParent instanceof Yn&&["shared","excluded","forced"].includes(o.dataParent.getConfiguredOrDefaultResolution(a,t)))&&o.getConfiguredOrDefaultResolution(a,t)!="excluded";)o=o.dataParent;t=="axis"&&wl(r)&&h3(a)?(o.resolutions[t][a]||(o.resolutions[t][a]=new YN(a)),o.resolutions[t][a].pushUnitView(this,r)):t=="scale"&&Ri(r)&&(o.resolutions[t][a]||(o.resolutions[t][a]=new VN(a)),o.resolutions[t][a].pushUnitView(this,r))}}getAccessor(t){return this._cache("accessor/"+t,()=>{const n=this.mark.encoding;if(n&&n[t])return this.context.accessorFactory.createAccessor(n[t])})}getFacetAccessor(t){const n=this.getAccessor("sample");return n||super.getFacetAccessor(this)}getCollector(){return this.context.dataFlow.findCollectorByKey(this)}_validateDomainQuery(t){if(xl(t))throw new Error(`getDomain(${t}), must only be called for primary channels!`);const n=this.mark.encoding[t];if(!rn(n))throw new Error("The channel has no scale, cannot get domain!");return n}getConfiguredDomain(t){const n=this._validateDomainQuery(t),r=n&&n.scale&&n.scale.domain;if(r){const i=this.getScaleResolution(n.resolutionChannel??t);return dE(n.type??"nominal",i.fromComplexInterval(r))}}extractDataDomain(t){const r=this._validateDomainQuery(t).type??"nominal",i=s=>{let c;const l=this.mark.encoding[s];if(l){const u=this.context.accessorFactory.createAccessor(l);if(u)if(c=dE(r),u.constant)c.extend(u({}));else{const f=this.getCollector();f!=null&&f.completed&&f.visitData(h=>c.extend(u(h)))}}return c};let a=i(t);const o=em[t];if(o){const s=i(o);s&&a.extendAll(s)}return a}getZoomLevel(){const t=n=>{var r;return((r=this.getScaleResolution(n))==null?void 0:r.getZoomLevel())??1};return ns.map(t).reduce((n,r)=>n*r,1)}propagateInteractionEvent(t){this.handleInteractionEvent(void 0,t,!0),t.target=this,!t.stopped&&this.handleInteractionEvent(void 0,t,!1)}getDefaultResolution(t,n){return t=="x"?"shared":"independent"}}function*Qm(e,t=[]){for(const[n,r]of e.entries())if(r instanceof Map)for(const i of Qm(r,[...t,n]))yield i;else yield[[...t,n],r]}class Ol extends at{get behavior(){return zm}constructor(t){super(),this.params=t??{type:"collect"},this.observers=[],this.facetBatches=void 0,this._init()}_init(){this._data=[],this.facetBatches=new gi([],JSON.stringify),this.facetBatches.set(void 0,this._data)}reset(){super.reset(),this._init()}handle(t){this._data.push(t)}beginBatch(t){TL(t)&&(this._data=[],this.facetBatches.set(Lt(t.facetId),this._data))}complete(){var i,a;const t=(i=this.params)==null?void 0:i.sort,n=t?fv(t.field,t.order):void 0,r=o=>{n&&o.sort(n)};if((a=this.params.groupby)!=null&&a.length){if(this.facetBatches.size>1)throw new Error("TODO: Support faceted data!");const o=this.params.groupby.map(c=>Oe(c)),s=o.length>1?Rc(this._data,...o):QN(this._data,o[0]);this.facetBatches.clear();for(const[c,l]of Qm(s))this.facetBatches.set(c,l)}for(const o of this.facetBatches.values())r(o);if(this.children.length)for(const[o,s]of this.facetBatches.entries()){if(o){const c={type:"facet",facetId:o};for(const l of this.children)l.beginBatch(c)}for(const c of s)this._propagate(c)}super.complete();for(const o of this.observers)o(this)}getData(){switch(this._checkStatus(),this.facetBatches.size){case 0:return[];case 1:return[...this.facetBatches.values()][0];default:{const t=this.facetBatches;return{[Symbol.iterator]:function*(){for(const r of t.values())for(let i=0;i<r.length;i++)yield r[i]}}}}}visitData(t){this._checkStatus();for(const n of this.facetBatches.values())for(let r=0;r<n.length;r++)t(n[r])}getItemCount(){let t=0;for(const n of this.facetBatches.values())t+=n.length;return t}_checkStatus(){if(!this.completed)throw new Error("Data propagation is not completed! No data are available.")}}function QN(e,t){const n=new Map;for(let r=0,i=e.length;r<i;r++){const a=e[r],o=t(a);let s=n.get(o);s||(s=[],n.set(o,s)),s.push(a)}return n}class Ll{constructor(){this.ids=[],this.values=[],this.length=0}clear(){this.length=0}push(t,n){let r=this.length++;for(;r>0;){const i=r-1>>1,a=this.values[i];if(n>=a)break;this.ids[r]=this.ids[i],this.values[r]=a,r=i}this.ids[r]=t,this.values[r]=n}pop(){if(this.length===0)return;const t=this.ids[0];if(this.length--,this.length>0){const n=this.ids[0]=this.ids[this.length],r=this.values[0]=this.values[this.length],i=this.length>>1;let a=0;for(;a<i;){let o=(a<<1)+1;const s=o+1;let c=this.ids[o],l=this.values[o];const u=this.values[s];if(s<this.length&&u<l&&(o=s,c=this.ids[s],l=u),l>=r)break;this.ids[a]=c,this.values[a]=l,a=o}this.ids[a]=n,this.values[a]=r}return t}peek(){if(this.length!==0)return this.ids[0]}peekValue(){if(this.length!==0)return this.values[0]}shrink(){this.ids.length=this.values.length=this.length}}class XN extends at{get behavior(){return mr}constructor(t){super(),this.params=t,this.startAccessor=Oe(t.start),this.endAccessor=Oe(t.end),this.chromAccessor=t.chrom?Oe(t.chrom):n=>{},this.weightAccessor=t.weight?Oe(t.weight):n=>1,this.as={coverage:t.as||"coverage",start:t.asStart||t.start,end:t.asEnd||t.end,chrom:t.asChrom||t.chrom},this.createSegment=new Function("start","end","coverage","chrom","return {"+Object.entries(this.as).filter(([n,r])=>r).map(([n,r])=>`${JSON.stringify(r)}: ${n}`).join(", ")+"};"),this.ends=new Ll}reset(){super.reset(),this.initialize()}initialize(){const t=this.as.coverage,n=this.as.end,r=this.as.chrom,i=this.startAccessor,a=this.endAccessor,o=this.chromAccessor,s=this.weightAccessor;let c,l,u,f=0,h;const d=this.ends;d.clear();const p=(b,y,w)=>{if(b==y)return;let A=!1;c&&(c[t]===w?(c[n]=y,A=!0):c[t]!=0&&this._propagate(c)),A||(c=this.createSegment(b,y,w,u))},g=()=>{let b=0;for(;(b=d.peekValue())!==void 0;)p(h,b,f),h=b,f-=d.pop();h=void 0,c&&(this._propagate(c),c=void 0)};this.handle=b=>{const y=i(b);let w=0;for(;(w=d.peekValue())!==void 0&&w<y;)p(h,w,f),h=w,f-=d.pop();if(r){let x=o(b);x!==l&&(g(),u=x,l=u)}h!==void 0&&p(h,y,f),h=y;const A=s(b);f+=A,d.push(A,a(b))},this.complete=()=>{g(),super.complete()},this.beginBatch=b=>{g(),l=void 0,super.beginBatch(b)}}}function KN(e,t,n=0,r=e.length){const i=new Ll,a=r-n;let o;for(o=0;o<t&&o<a;o++)i.push(o,e[n+o]);for(;o<a;o++){const l=e[n+o];l>=i.peekValue()&&(i.push(o,l),i.pop())}const s=[];let c;for(;(c=i.pop())!==void 0;)s.push(n+c);return s.reverse()}class JN{constructor(t,n=-1/0,r=1/0){this.maxSize=t,this.lowerLimit=n,this.upperLimit=r;const i=this.maxSize*2+1;this.lowerLimits=new Float64Array(i),this.upperLimits=new Float64Array(i),this.lowerChildren=new Int32Array(i),this.upperChildren=new Int32Array(i),this.reset()}reset(){this.lowerLimits.fill(0),this.upperLimits.fill(0),this.lowerChildren.fill(0),this.upperChildren.fill(0),this.n=1,this.lowerLimits[0]=this.lowerLimit,this.upperLimits[0]=this.upperLimit}_findSlot(t,n,r=0){if(t>=this.lowerLimits[r]&&n<=this.upperLimits[r]){const i=this.lowerChildren[r];if(i){const a=this._findSlot(t,n,i);return a>=0?a:this._findSlot(t,n,this.upperChildren[r])}else return r}else return-1}reserve(t,n){if(n-t<=0)throw new Error("Cannot reserve an empty or negative-size slot!");if(this.n+1>this.lowerLimits.length)return!1;const r=this._findSlot(t,n);if(r<0)return!1;const i=this.n++,a=this.n++;return this.lowerLimits[i]=this.lowerLimits[r],this.upperLimits[i]=t,this.lowerLimits[a]=n,this.upperLimits[a]=this.upperLimits[r],this.lowerChildren[r]=i,this.upperChildren[r]=a,!0}}class ez extends at{get behavior(){return zm}constructor(t,n){if(super(),this.params=t,this._data=[],this.channel=t.channel??"x",!["x","y"].includes(this.channel))throw new Error("Invalid channel: "+this.channel);this.posAccessor=Oe(this.params.pos),this.posBisector=Uf(this.posAccessor),this.scoreAccessor=Oe(this.params.score),this.widthAccessor=Oe(this.params.width),this.laneAccessor=this.params.lane?Oe(this.params.lane):i=>0,this.padding=this.params.padding??0,this.reservationMaps=new Map,this.resolution=n.getScaleResolution(this.channel);const r=()=>this._filterAndPropagate();this.schedule=()=>n.context.animator.requestTransition(r),this.resolution.addEventListener("domain",i=>this.schedule()),n._addBroadcastHandler("layoutComputed",()=>this.schedule())}complete(){const t=this.posAccessor;this._data.sort((n,r)=>t(n)-t(r)),this._scores=this._data.map(this.scoreAccessor);for(const n of new Set(this._data.map(this.laneAccessor)))this.reservationMaps.set(n,new JN(200));this.schedule(),super.complete()}_filterAndPropagate(){var o;super.reset();const t=this.resolution.getScale(),n=(o=this.resolution.members[0].view.coords)==null?void 0:o[this.channel=="x"?"width":"height"];if(!n)return;for(const s of this.reservationMaps.values())s.reset();const r=t.domain(),i=70,a=KN(this._scores,i,this.posBisector.left(this._data,r[0]),this.posBisector.right(this._data,r[1]));for(const s of a){const c=this._data[s],l=t(this.posAccessor(c))*n,u=this.widthAccessor(c)/2+this.padding;this.reservationMaps.get(this.laneAccessor(c)).reserve(l-u,l+u)&&this._propagate(c)}super.complete()}reset(){super.reset(),this._data=[],this.groups=new Map}handle(t){this._data.push(t)}}class tz extends at{constructor(t){super(),this.params=t,this.predicate=void 0}initialize(){this.predicate=ch(this.params.expr,this.getGlobalObject())}handle(t){this.predicate(t)&&this._propagate(t)}}class nz extends at{get behavior(){return mr}constructor(t){super();const n=t.index;if(t.fields){const r=Lt(t.fields).map(a=>Oe(a)),i=Lt(t.as||t.fields);if(r.length!==i.length)throw new Error(`Lengths of "fields" (${r.length}), and "as" (${i.length}) do not match!`);this.handle=a=>{const o=r.map((c,l)=>c(a)??[]),s=o[0].length;for(let c=0;c<s;c++){const l=Object.assign({},a);for(let u=0;u<r.length;u++)l[i[u]]=c<o[u].length?o[u][c]:null;n&&(l[n]=c),this._propagate(l)}}}else this.handle=r=>{for(let i=0;i<r.length;i++){const a=Object.assign({},r[i]);n&&(a[n]=i),this._propagate(a)}}}}const rz="0".charCodeAt(0);function*iz(e,t=","){const n=t.charCodeAt(0);let r=0;for(let i=0;i<e.length;i++){const a=e.charCodeAt(i);a==n?(yield r,r=0):r=r*10+a-rz}yield r}class az extends at{get behavior(){return mr}constructor(t){super();const n=Oe(t.exons??"exons"),r=Oe(t.start??"start"),[i,a]=t.as||["exonStart","exonEnd"];this.handle=o=>{let s=r(o),c=s,l=!0;const u=n(o);for(const f of iz(u)){if(l)c=s+f;else{s=c+f;const h=Object.assign({},o);h[i]=c,h[a]=s,this._propagate(h)}l=!l}}}}class oz extends at{get behavior(){return mr}constructor(t){super();const n=Lt(t.field).map(a=>Oe(a)),r=Lt(t.separator),i=Lt(t.as||t.field);if(n.length!==r.length||n.length!==i.length)throw new Error(`Lengths of "separator" (${r.length}), "fields" (${n.length}), and "as" (${i.length}) do not match!`);this.handle=a=>{if(n.some(c=>!c(a)))return;const o=n.map((c,l)=>c(a).split(r[l]));sz(o,a);const s=o[0].length;for(let c=0;c<s;c++){const l=Object.assign({},a);for(let u=0;u<n.length;u++)l[i[u]]=o[u][c];this._propagate(l)}}}}function sz(e,t){const n=e.map(r=>r.length);if(!n.every(r=>r==n[0]))throw new Error("Mismatching number of elements in the fields to be split: "+JSON.stringify(t))}class cz extends at{get behavior(){return Li}constructor(t){super(),this.params=t,this.as=t.as,this.fn=void 0}initialize(){this.fn=ch(this.params.expr,this.getGlobalObject())}handle(t){t[this.as]=this.fn(t),this._propagate(t)}}class mE extends at{get behavior(){return Li}constructor(t,n){super();const r=t.channel??"x";if(!["x","y"].includes(r))throw new Error("Invalid channel: "+r);const i=n.getScaleResolution(r).getGenome();if(!i)throw new Error("LinearizeGenomicCoordinate transform requires a locus scale!");const a=Oe(t.chrom),o=Lt(t.pos).map(p=>Oe(p)),s=Lt(t.as);if(o.length!=s.length)throw new Error('The number of "pos" and "as" elements must be equal!');const c=Lt(t.offset);let l;if(c.length==0)l=new Array(o.length).fill(0);else if(c.length==1)l=new Array(o.length).fill(c[0]);else if(c.length==o.length)l=c;else throw new Error(`Invalid "offset" parameter: ${JSON.stringify(t.offset)}!`);const u=new Function("datum","chromOffset","posAccessors",s.map((p,g)=>`datum[${JSON.stringify(p)}] = chromOffset + +posAccessors[${g}](datum) - ${l[g]};`).join(`
1695
1695
  `));let f,h=0;const d=p=>{if(p!==f){if(h=i.cumulativeChromPositions.get(p),h===void 0)throw new Error("Unknown chromosome/contig: "+p);f=p}return h};this.handle=p=>{u(p,d(a(p)),o),this._propagate(p)}}}const bE={pages:["Lato-Regular.png"],chars:[{id:87,width:53,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:43.491,chnl:15,x:0,y:0,page:0},{id:124,width:17,height:50,xoffset:0,yoffset:-32.193000000000005,xadvance:10.521,chnl:15,x:0,y:42,page:0},{id:40,width:20,height:49,xoffset:0,yoffset:-32.571000000000005,xadvance:11.214,chnl:15,x:0,y:94,page:0},{id:41,width:19,height:49,xoffset:0,yoffset:-32.571000000000005,xadvance:11.214,chnl:15,x:0,y:145,page:0},{id:36,width:32,height:49,xoffset:0,yoffset:-34.419000000000004,xadvance:24.360000000000003,chnl:15,x:0,y:196,page:0},{id:125,width:21,height:48,xoffset:0,yoffset:-32.193000000000005,xadvance:12.642000000000001,chnl:15,x:0,y:247,page:0},{id:91,width:22,height:48,xoffset:0,yoffset:-32.193000000000005,xadvance:12.852,chnl:15,x:0,y:297,page:0},{id:93,width:19,height:48,xoffset:0,yoffset:-32.193000000000005,xadvance:12.852,chnl:15,x:0,y:347,page:0},{id:123,width:21,height:48,xoffset:0,yoffset:-32.193000000000005,xadvance:12.642000000000001,chnl:15,x:0,y:397,page:0},{id:106,width:19,height:48,xoffset:0,yoffset:-30.639000000000003,xadvance:10.08,chnl:15,x:0,y:447,page:0},{id:81,width:43,height:47,xoffset:0,yoffset:-30.429000000000002,xadvance:33.621,chnl:15,x:21,y:447,page:0},{id:77,width:45,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:38.997,chnl:15,x:66,y:447,page:0},{id:64,width:43,height:44,xoffset:0,yoffset:-28.539,xadvance:35.133,chnl:15,x:23,y:397,page:0},{id:92,width:28,height:43,xoffset:0,yoffset:-30.933000000000003,xadvance:18.984,chnl:15,x:68,y:397,page:0},{id:47,width:28,height:43,xoffset:0,yoffset:-30.933000000000003,xadvance:18.984,chnl:15,x:98,y:397,page:0},{id:109,width:42,height:32,xoffset:0,yoffset:-21.609,xadvance:34.545,chnl:15,x:113,y:447,page:0},{id:119,width:42,height:31,xoffset:0,yoffset:-21.315,xadvance:32.991,chnl:15,x:157,y:447,page:0},{id:42,width:25,height:42,xoffset:0,yoffset:-31.626,xadvance:17.85,chnl:15,x:128,y:397,page:0},{id:37,width:42,height:41,xoffset:0,yoffset:-30.387,xadvance:33.663000000000004,chnl:15,x:155,y:397,page:0},{id:79,width:42,height:41,xoffset:0,yoffset:-30.429000000000002,xadvance:33.621,chnl:15,x:199,y:397,page:0},{id:102,width:24,height:41,xoffset:0,yoffset:-30.534000000000002,xadvance:14.721,chnl:15,x:243,y:397,page:0},{id:100,width:31,height:41,xoffset:0,yoffset:-30.933000000000003,xadvance:23.520000000000003,chnl:15,x:269,y:397,page:0},{id:98,width:32,height:41,xoffset:0,yoffset:-30.933000000000003,xadvance:23.520000000000003,chnl:15,x:302,y:397,page:0},{id:56,width:32,height:41,xoffset:0,yoffset:-30.429000000000002,xadvance:24.360000000000003,chnl:15,x:336,y:397,page:0},{id:38,width:40,height:41,xoffset:0,yoffset:-30.429000000000002,xadvance:29.904000000000003,chnl:15,x:370,y:397,page:0},{id:108,width:17,height:41,xoffset:0,yoffset:-30.933000000000003,xadvance:9.912,chnl:15,x:412,y:397,page:0},{id:107,width:31,height:41,xoffset:0,yoffset:-30.933000000000003,xadvance:21.336000000000002,chnl:15,x:431,y:397,page:0},{id:48,width:33,height:41,xoffset:0,yoffset:-30.429000000000002,xadvance:24.360000000000003,chnl:15,x:464,y:397,page:0},{id:71,width:38,height:41,xoffset:0,yoffset:-30.429000000000002,xadvance:30.681,chnl:15,x:21,y:347,page:0},{id:83,width:31,height:41,xoffset:0,yoffset:-30.429000000000002,xadvance:22.785,chnl:15,x:61,y:347,page:0},{id:63,width:27,height:41,xoffset:0,yoffset:-30.429000000000002,xadvance:18.795,chnl:15,x:94,y:347,page:0},{id:105,width:18,height:41,xoffset:0,yoffset:-30.639000000000003,xadvance:10.08,chnl:15,x:123,y:347,page:0},{id:51,width:32,height:41,xoffset:0,yoffset:-30.429000000000002,xadvance:24.360000000000003,chnl:15,x:143,y:347,page:0},{id:104,width:31,height:41,xoffset:0,yoffset:-30.933000000000003,xadvance:23.436,chnl:15,x:177,y:347,page:0},{id:67,width:37,height:41,xoffset:0,yoffset:-30.429000000000002,xadvance:28.056,chnl:15,x:210,y:347,page:0},{id:88,width:37,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:27.258000000000003,chnl:15,x:249,y:347,page:0},{id:68,width:40,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:31.941000000000003,chnl:15,x:288,y:347,page:0},{id:70,width:32,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:23.751,chnl:15,x:330,y:347,page:0},{id:34,width:23,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:15.561000000000002,chnl:15,x:364,y:347,page:0},{id:72,width:38,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:32.067,chnl:15,x:389,y:347,page:0},{id:73,width:18,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:11.760000000000002,chnl:15,x:429,y:347,page:0},{id:74,width:24,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:17.745,chnl:15,x:449,y:347,page:0},{id:75,width:38,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:27.825000000000003,chnl:15,x:24,y:297,page:0},{id:76,width:31,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:21.567,chnl:15,x:475,y:347,page:0},{id:66,width:35,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:27.153000000000002,chnl:15,x:64,y:297,page:0},{id:78,width:38,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:32.067,chnl:15,x:101,y:297,page:0},{id:33,width:18,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:11.298,chnl:15,x:141,y:297,page:0},{id:80,width:34,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:25.221,chnl:15,x:161,y:297,page:0},{id:65,width:38,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:28.434,chnl:15,x:197,y:297,page:0},{id:82,width:36,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:26.313000000000002,chnl:15,x:237,y:297,page:0},{id:35,width:33,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:24.360000000000003,chnl:15,x:275,y:297,page:0},{id:84,width:34,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:24.801000000000002,chnl:15,x:310,y:297,page:0},{id:85,width:37,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:30.891000000000002,chnl:15,x:346,y:297,page:0},{id:86,width:38,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:28.434,chnl:15,x:385,y:297,page:0},{id:39,width:16,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:8.568000000000001,chnl:15,x:425,y:297,page:0},{id:69,width:32,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:24.255000000000003,chnl:15,x:443,y:297,page:0},{id:89,width:36,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:26.208000000000002,chnl:15,x:23,y:247,page:0},{id:90,width:34,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:25.284000000000002,chnl:15,x:477,y:297,page:0},{id:49,width:31,height:40,xoffset:0,yoffset:-30.156000000000002,xadvance:24.360000000000003,chnl:15,x:61,y:247,page:0},{id:50,width:32,height:40,xoffset:0,yoffset:-30.429000000000002,xadvance:24.360000000000003,chnl:15,x:94,y:247,page:0},{id:57,width:32,height:40,xoffset:0,yoffset:-30.429000000000002,xadvance:24.360000000000003,chnl:15,x:128,y:247,page:0},{id:94,width:32,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:24.360000000000003,chnl:15,x:162,y:247,page:0},{id:96,width:21,height:40,xoffset:0,yoffset:-30.429000000000002,xadvance:16.8,chnl:15,x:196,y:247,page:0},{id:55,width:33,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:24.360000000000003,chnl:15,x:219,y:247,page:0},{id:54,width:33,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:24.360000000000003,chnl:15,x:254,y:247,page:0},{id:53,width:32,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:24.360000000000003,chnl:15,x:289,y:247,page:0},{id:52,width:33,height:40,xoffset:0,yoffset:-30.093000000000004,xadvance:24.360000000000003,chnl:15,x:323,y:247,page:0},{id:103,width:31,height:39,xoffset:0,yoffset:-21.630000000000003,xadvance:21.84,chnl:15,x:358,y:247,page:0},{id:112,width:32,height:39,xoffset:0,yoffset:-21.651,xadvance:23.541,chnl:15,x:391,y:247,page:0},{id:113,width:31,height:39,xoffset:0,yoffset:-21.651,xadvance:23.520000000000003,chnl:15,x:425,y:247,page:0},{id:116,width:25,height:39,xoffset:0,yoffset:-28.182000000000002,xadvance:15.057,chnl:15,x:458,y:247,page:0},{id:121,width:31,height:38,xoffset:0,yoffset:-21.273,xadvance:21.651,chnl:15,x:34,y:196,page:0},{id:59,width:18,height:36,xoffset:0,yoffset:-20.706,xadvance:10.983,chnl:15,x:485,y:247,page:0},{id:43,width:32,height:34,xoffset:0,yoffset:-24.486,xadvance:24.360000000000003,chnl:15,x:67,y:196,page:0},{id:60,width:30,height:33,xoffset:0,yoffset:-23.331000000000003,xadvance:24.360000000000003,chnl:15,x:101,y:196,page:0},{id:62,width:31,height:33,xoffset:0,yoffset:-23.331000000000003,xadvance:24.360000000000003,chnl:15,x:133,y:196,page:0},{id:117,width:30,height:32,xoffset:0,yoffset:-21.273,xadvance:23.415000000000003,chnl:15,x:166,y:196,page:0},{id:99,width:29,height:32,xoffset:0,yoffset:-21.609,xadvance:20.055,chnl:15,x:198,y:196,page:0},{id:110,width:31,height:32,xoffset:0,yoffset:-21.609,xadvance:23.436,chnl:15,x:229,y:196,page:0},{id:111,width:32,height:32,xoffset:0,yoffset:-21.609,xadvance:23.814,chnl:15,x:262,y:196,page:0},{id:126,width:32,height:26,xoffset:0,yoffset:-16.128,xadvance:24.360000000000003,chnl:15,x:201,y:447,page:0},{id:101,width:31,height:32,xoffset:0,yoffset:-21.609,xadvance:22.176000000000002,chnl:15,x:296,y:196,page:0},{id:114,width:25,height:32,xoffset:0,yoffset:-21.651,xadvance:15.288,chnl:15,x:329,y:196,page:0},{id:115,width:27,height:32,xoffset:0,yoffset:-21.609,xadvance:18.186,chnl:15,x:356,y:196,page:0},{id:97,width:28,height:32,xoffset:0,yoffset:-21.651,xadvance:20.874000000000002,chnl:15,x:385,y:196,page:0},{id:118,width:31,height:31,xoffset:0,yoffset:-21.273,xadvance:21.672,chnl:15,x:415,y:196,page:0},{id:61,width:31,height:29,xoffset:0,yoffset:-19.089000000000002,xadvance:24.360000000000003,chnl:15,x:448,y:196,page:0},{id:120,width:30,height:31,xoffset:0,yoffset:-21.273,xadvance:20.916,chnl:15,x:21,y:145,page:0},{id:58,width:18,height:31,xoffset:0,yoffset:-20.706,xadvance:10.5,chnl:15,x:53,y:145,page:0},{id:122,width:28,height:31,xoffset:0,yoffset:-21.273,xadvance:18.984,chnl:15,x:73,y:145,page:0},{id:95,width:28,height:16,xoffset:0,yoffset:0,xadvance:19.278000000000002,chnl:15,x:235,y:447,page:0},{id:45,width:23,height:24,xoffset:0,yoffset:-14.175,xadvance:15.603000000000002,chnl:15,x:481,y:196,page:0},{id:44,width:17,height:21,xoffset:0,yoffset:-4.956,xadvance:9.534,chnl:15,x:103,y:145,page:0},{id:46,width:18,height:15,xoffset:0,yoffset:-4.956,xadvance:9.912,chnl:15,x:0,y:497,page:0},{id:32,width:0,height:0,xoffset:0,yoffset:0,xadvance:10.752,chnl:15,x:20,y:497,page:0}],info:{face:"Lato Regular",size:42,bold:0,italic:0,charset:[" ","!",'"',"#","$","%","&","'","(",")","*","+",",","-",".","/","0","1","2","3","4","5","6","7","8","9",":",";","<","=",">","?","@","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z","[","\\","]","^","_","`","a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z","{","|","}","~"],unicode:1,stretchH:100,smooth:1,aa:1,padding:[0,0,0,0],spacing:[2,2]},common:{lineHeight:50.400000000000006,base:41.454,scaleW:512,scaleH:512,pages:1,packed:0,alphaChnl:0,redChnl:0,greenChnl:0,blueChnl:0},kernings:[]};class lz extends at{get behavior(){return Li}constructor(t){super();const n=Om(bE),r=Oe(t.field),i=t.as,a=t.fontSize;this.handle=o=>{const s=r(o);s!==void 0?o[i]=n.measureWidth(s,a):o[i]=0,this._propagate(o)}}}const uz=65536;class fz extends at{get behavior(){return Li}constructor(t){super(),this.params=t}reset(){super.reset(),this.initialize()}initialize(){const t=this.params,n=t.as||"lane",r=ft(t.spacing)?t.spacing:1,i=Oe(t.start),a=Oe(t.end);if(!t.preference!=!t.preferredOrder)throw new Error('Must specify both "preference" and "preferredOrder"');if(t.preference){const o=new Float64Array(uz),s=Oe(t.preference),c=t.preferredOrder;let l=1/0;this.handle=u=>{const f=i(u);f<l&&o.fill(-1/0),l=f;const h=c.indexOf(s(u));let d=-1;if(h>=0&&o[h]<f)d=h;else{const p=i(u);for(d=0;d<o.length&&!(o[d]<p);d++);if(d>=o.length)throw new Error("Out of lanes!")}o[d]=a(u)+r,u[n]=d,this._propagate(u)}}else{const o=new Ll,s=new Ll;let c=-1/0,l=0;this.handle=u=>{const f=i(u);for(;o.length&&(o.peekValue()<=f||f<c);){const d=o.pop();s.push(d,d)}c=f;let h=s.pop();h===void 0&&(h=l++),u[n]=h,this._propagate(u),o.push(h,a(u)+r)}}}}class hz extends at{get behavior(){return mr}constructor(t){if(super(),t.as&&t.as.length!=t.fields.length)throw new Error('"fields" and "as" have unequal lengths!');const n=t.fields.map(i=>Oe(i)),r=t.as?t.as:n.map(Vo);this.handle=i=>{const a={};for(let o=0;o<n.length;o++)a[r[o]]=n[o](i);this._propagate(a)}}}class dz extends at{get behavior(){return Li}constructor(t){super();const n=new RegExp(t.regex),r=typeof t.as=="string"?[t.as]:t.as,i=Oe(t.field);this.handle=a=>{const o=i(a);if(Me(o)){const s=o.match(n);if(s){if(s.length-1!=r.length)throw new Error('The number of RegEx groups and the length of "as" do not match!');for(let c=0;c<r.length;c++)a[r[c]]=s[c+1]}else if(t.skipInvalidInput)for(let c=0;c<r.length;c++)a[r[c]]=void 0;else throw new Error(`"${o}" does not match the given regex: ${n.toString()}`)}else if(!t.skipInvalidInput)throw new Error(`Trying to match a non-string field. Encountered type: ${typeof o}, field content: "${o}".`);this._propagate(a)}}}class pz extends at{get behavior(){return mr}constructor(t){super();const n=Lt(t.columnRegex).map(h=>new RegExp(h)),r=Lt(t.asValue);if(n.length!=r.length)throw new Error('Lengths of "columnRegex" and "as" are not equal!');const i=t.skipRegex?new RegExp(t.skipRegex):void 0,a=t.asKey||"sample";let o,s,c;const l=h=>{var b;const d=Object.keys(h);for(const y of n)if(!d.some(w=>y.test(w)))throw new Error(`No columns matching the regex ${y.toString()} found in the data!`);const p=new Map;for(const[y,w]of n.entries())for(const A of d){const x=(b=w.exec(A))==null?void 0:b[1];if(x!==void 0){let C=p.get(x);C||(C=[],p.set(x,C)),C[y]=A}}o=[...p.entries()],s=d.filter(y=>!n.some(w=>w.test(y))&&!(i&&i.test(y)));const g=[...s.map(y=>JSON.stringify(y)+": datum["+JSON.stringify(y)+"]"),JSON.stringify(a)+": sampleId",...r.map((y,w)=>JSON.stringify(y)+`: datum[attrs[${w}]]`)];c=new Function("datum","sampleId","attrs",`return {
1696
1696
  `+g.join(`,
1697
1697
  `)+`
1698
- };`)},u=h=>{o||l(h);for(let d=0;d<o.length;d++){const[p,g]=o[d],b=c(h,p,g);this._propagate(b)}},f=h=>{l(h),u(h),this.handle=u};this.handle=f,this.beginBatch=h=>{qA(h)&&(this.handle=f),super.beginBatch(h)}}}class gz extends at{get behavior(){return Li}constructor(t){super(),this.params=t,this.buffer=[]}reset(){this.buffer=[]}handle(t){this.buffer.push(t)}complete(){const t=this.params,n=t.as||["y0","y1"],r=t.sort?fv(t.sort.field,t.sort.order):void 0,i=t.field?Oe(t.field):()=>1,a=t.groupby.map(u=>Oe(u)),o=JI(this.buffer,u=>a.map(f=>f(u)).join()).map(u=>u[1]);let s=u=>!0;if(t.baseField){const u=Oe(t.baseField);s=f=>u(f)!==null}let c,l;switch(t.offset){case"normalize":c=(u,f)=>u/f,l=(u,f)=>Gf(u,f);break;case"center":c=(u,f)=>u-f/2,l=(u,f)=>Gf(u,f);break;case"information":{const u=Math.log2(t.cardinality??4);c=(f,h)=>f/h,l=(f,h)=>{const p=Gf(f,w=>+!s(w)),g=Gf(f,h),b=g-p;let y=0;for(let w=0;w<f.length;w++){const A=f[w];if(s(A)){const x=h(A)/b;y-=x*Math.log2(x)}}return b/(u-(y+0))*(b/g)}}break;default:c=(u,f)=>u,l=(u,f)=>1}for(const u of o){r&&u.sort(r);const f=l(u,i);let h=0;for(const d of u){const p=h+i(d);s(d)&&(d[n[0]]=c(h,f),d[n[1]]=c(p,f),this._propagate(d),h=p)}}super.complete()}}class mz extends at{get behavior(){return mr}constructor(t){super();const n=Oe(t.field??"sequence"),[r,i]=t.as??["pos","sequence"];this.handle=a=>{const o=Object.assign({},a,{[i]:"",[r]:0}),s=n(a);for(let c=0;c<s.length;c++){const l=Object.assign({},o);l[r]=c,l[i]=s.charAt(c),this._propagate(l)}}}}class bz extends at{get behavior(){return mr}constructor(t){super(),this.params=t,this.buffer=[]}reset(){this.buffer=[]}handle(t){this.buffer.push(t)}complete(){const n=this.params.groupby,r=n.map(a=>Oe(a)),i=Rc(this.buffer,...r);for(const[a,o]of Qm(i)){const s={count:o.length};for(let c=0;c<n.length;c++)s[n[c]]=a[c];this._propagate(s)}super.complete()}}const yz="_uniqueId",yE=1e4,vE=[null];class wE extends at{get behavior(){return Li}constructor(t){super(),this.params=t,this.as=t.as??yz,this._blocks=[],this._usedBlocks=0,this._id=-1}initialize(){}reset(){super.reset(),this._usedBlocks=0,this._id=-1}handle(t){t[this.as]=this._nextId(),this._propagate(t)}_nextId(){return++this._id%yE==0&&(this._id=this._getBlock()*yE),this._id}_getBlock(){return this._usedBlocks<this._blocks.length?this._blocks[this._usedBlocks++]:this._reserveBlock()}_reserveBlock(){const t=vE.length;return vE[t]=this,this._blocks.push(t),this._usedBlocks++,t}}const xE={aggregate:bz,collect:Ol,coverage:XN,filterScoredLabels:ez,filter:tz,flatten:nz,flattenCompressedExons:az,flattenDelimited:oz,flattenSequence:mz,formula:cz,identifier:wE,linearizeGenomicCoordinate:mE,measureText:lz,pileup:fz,project:hz,regexExtract:dz,regexFold:pz,sample:WA,stack:gz};function vz(e,t){const n=xE[e.type];if(n)return new n(e,t);throw new Error("Unknown transform: "+e.type)}function AE(e){if(!_E(e)&&!SE(e))return;const t={...e.format};if(t.type??(t.type=SE(e)&&wz(e.url)),t.parse??(t.parse="auto"),!t.type)throw new Error("Format for the data source was not defined and it could not be inferred: "+JSON.stringify(e));return t}function wz(e){var t;if(Array.isArray(e)&&(e=e[0]),e)return(t=e.match(/\.(csv|tsv|json)/))==null?void 0:t[1]}const EE=e=>typeof e!="object"?xz:Az,xz=e=>({data:e}),Az=e=>e;function SE(e){return"url"in e}class ms extends at{get identifier(){}handle(t){throw new Error("Source does not handle incoming data!")}async load(){}}function _E(e){return"values"in e}class Ez extends ms{constructor(t,n){var r;if(super(),this.params=t,typeof t.values=="string"&&!((r=t==null?void 0:t.format)!=null&&r.type))throw new Error("Data format type (csv, dsv, ...) must be specified if a string is provided!")}loadSynchronously(){const t=this.params.values;let n=[],r=i=>i;if(Array.isArray(t))t.length>0&&(n=t,r=EE(t[0]));else if(typeof t=="object")n=[t];else if(typeof t=="string")n=dw(t,AE(this.params));else throw new Error('"values" in data configuration is not an array, object, or a string!');this.reset(),this.beginBatch({type:"file"});for(const i of n)this._propagate(r(i));this.complete()}async load(){this.loadSynchronously()}}function Sz(e){return"url"in e}class _z extends ms{constructor(t,n){super(),this.params=t,this.baseUrl=n==null?void 0:n.getBaseUrl()}get identifier(){return JSON.stringify({params:this.params,baseUrl:this.baseUrl})}async load(){const t=this.params.url,n=Array.isArray(t)?t:[t],r=async a=>Zc({baseURL:this.baseUrl}).load(a).catch(o=>{throw new Error(`Cannot fetch: ${this.baseUrl}${a}: ${o.message}`)}),i=(a,o)=>{try{const s=dw(a,AE(this.params));this.beginBatch({type:"file",url:o});for(const c of s)this._propagate(c)}catch(s){throw new Error(`Cannot parse: ${o}: ${s.message}`)}};this.reset(),await Promise.all(n.map(a=>r(a).then(i))),this.complete()}}function Cz(e){return"sequence"in e}class kz extends ms{constructor(t,n){if(super(),this.sequence=t.sequence,!("start"in this.sequence))throw new Error("'start' is missing from sequence parameters!");if(!("stop"in this.sequence))throw new Error("'stop' is missing from sequence parameters!")}loadSynchronously(){const t=this.sequence.as||"data",n=this.sequence.step||1,r=this.sequence.stop;this.reset(),this.beginBatch({type:"file"});for(let i=this.sequence.start;i<r;i+=n)this._propagate({[t]:i});this.complete()}async load(){this.loadSynchronously()}}class Xm extends ms{constructor(n,r){super();zn(this,"initializedPromise",Promise.resolve());if(this.view=n,r){if(r!=="x"&&r!=="y")throw new Error(`Invalid channel specified for the lazy data source: ${r}. Must be either "x" or "y"`)}else throw new Error('No channel has been specified for the lazy data source. Must be either "x" or "y".');if(this.channel=r,this.scaleResolution=this.view.getScaleResolution(r),!this.scaleResolution){const a=[`The lazy data source cannot find a resolved scale for channel "${r}".`];throw this.view instanceof mt||a.push('Make sure the view has a "shared" scale resolution as it is not a unit view.'),new Error(a.join(" "))}const i=()=>{this.view.isVisible()&&this.onDomainChanged(this.scaleResolution.getDomain(),this.scaleResolution.getComplexDomain())};this.scaleResolution.addEventListener("domain",i),this.view.context.addBroadcastListener("layoutComputed",i)}getAxisLength(){const n=this.scaleResolution.members.map(r=>{var i;return(i=r.view.coords)==null?void 0:i[this.channel==="x"?"width":"height"]}).filter(r=>r>0);return n.length?n.reduce((r,i)=>Math.min(r,i),1e4):0}get genome(){return this.scaleResolution.getGenome()}async onDomainChanged(n,r){}setLoadingStatus(n){this.view.context.setDataLoadingStatus(this.view,n)}requestRender(){this.view.context.animator.requestRender()}async load(){this.reset(),this.complete()}publishData(n){this.reset(),this.beginBatch({type:"file"});for(const r of n)for(const i of r)this._propagate(i);this.complete(),Ym(this.view),this.requestRender()}}class Tz extends Xm{constructor(n,r){const i={axis:{},...n};super(r,i.channel);zn(this,"ticks",[]);this.params=n}async onDomainChanged(){const n=this.scaleResolution.getScale(),r=this.params.axis,i=this.getAxisLength(),a=l=>25+60*pg(100,700,l),o=ft(r.tickCount)?r.tickCount:Math.round(i/a(i)),s=nE(n,o,r.tickMinStep),c=r.values?rE(n,r.values,s):sN(n,s);if(!th(c,this.ticks)){this.ticks=c;const l=lN(n,o,r.format);this.publishData([c.map(u=>({value:u,label:l(u)}))])}}}class Iz extends Xm{constructor(t,n){super(n,t.channel)}async load(){this.publishData([this.genome.chromosomes])}}function Xa(e,t){return!t||/^(data:|([A-Za-z]+:)?\/\/)/.test(e)||e.startsWith("/")?e:(t.endsWith("/")||(t+="/"),t+e)}function bs(e,t,n=!0){let r,i=o=>{};return function(...s){return new Promise((c,l)=>{const u=()=>{clearTimeout(r),i=f=>{},c(e(...s))};n&&i("debounced"),clearTimeout(r),i=l,r=window.setTimeout(u,t)})}}class Nl extends Xm{constructor(){super(...arguments);Z(this,hc,new AbortController);Z(this,ff,[0,0]);zn(this,"params")}setupDebouncing(n){n.debounce>0&&(n.debounceMode=="domain"?this.onDomainChanged=bs(this.onDomainChanged.bind(this),n.debounce,!1):n.debounceMode=="window"&&(this.loadInterval=bs(this.loadInterval.bind(this),n.debounce,!1)))}async onDomainChanged(n){var a;const r=((a=this.params)==null?void 0:a.windowSize)??-1;if(n[1]-n[0]>r)return;const i=this.quantizeInterval(n,r);this.checkAndUpdateLastInterval(i)&&(await this.initializedPromise,this.loadInterval(i))}async loadInterval(n){}async discretizeAndLoad(n,r){F(this,hc).abort(),this.setLoadingStatus(!0),le(this,hc,new AbortController);const i=F(this,hc).signal,a=this.genome.continuousToDiscreteChromosomeIntervals(n);try{const o=await Promise.all(a.map(async s=>r(s,i)));if(!i.aborted)return this.setLoadingStatus(!1),o}catch(o){if(!i.aborted)throw this.setLoadingStatus(!1),o}}quantizeInterval(n,r){return[Math.max(Math.floor(n[0]/r-1)*r,0),Math.min(Math.ceil(n[1]/r+1)*r,this.genome.totalSize)]}checkAndUpdateLastInterval(n){return th(F(this,ff),n)?!1:(le(this,ff,n),!0)}}hc=new WeakMap,ff=new WeakMap;class Rz extends Nl{constructor(t,n){const r={channel:"x",windowSize:7e3,debounce:200,debounceMode:"window",...t};if(super(n,r.channel),this.params=r,!this.params.url)throw new Error("No URL provided for IndexedFastaSource");this.setupDebouncing(this.params),this.initializedPromise=new Promise(i=>{Promise.all([Promise.resolve().then(()=>d6),Promise.resolve().then(()=>UY),Promise.resolve().then(()=>hu)]).then(([{Buffer:a},{IndexedFasta:o},{RemoteFile:s}])=>{typeof window<"u"&&(window.Buffer??(window.Buffer=a));const c=l=>new s(Xa(l,this.view.getBaseUrl()));this.fasta=new o({fasta:c(this.params.url),fai:c(this.params.indexUrl??this.params.url+".fai")}),i()})})}async loadInterval(t){const n=await this.discretizeAndLoad(t,async(r,i)=>this.fasta.getSequence(r.chrom,r.startPos,r.endPos,{signal:i}).then(a=>({chrom:r.chrom,start:r.startPos,sequence:a})));n&&this.publishData([n])}}class Dz extends Nl{constructor(n,r){const i={pixelsPerBin:2,channel:"x",debounce:200,debounceMode:"window",...n};super(r,i.channel);Z(this,dc,[]);Z(this,pc,void 0);if(this.params=i,!this.params.url)throw new Error("No URL provided for BigWigSource");this.setupDebouncing(this.params),this.initializedPromise=new Promise(a=>{Promise.all([Promise.resolve().then(()=>fk),Promise.resolve().then(()=>hu)]).then(([{BigWig:o},{RemoteFile:s}])=>{le(this,pc,new o({filehandle:new s(Xa(this.params.url,this.view.getBaseUrl()))})),F(this,pc).getHeader().then(c=>{le(this,dc,c.zoomLevels.map(l=>l.reductionLevel).reverse()),F(this,dc).push(1),a()})})})}async onDomainChanged(n){await this.initializedPromise;const r=this.getAxisLength()||700,i=Bz(n,r,F(this,dc)),a=Math.max(i*r,5e3),o=this.quantizeInterval(n,a);this.checkAndUpdateLastInterval(o)&&this.loadInterval(o,i)}async loadInterval(n,r){const i=.5/r/this.params.pixelsPerBin,a=await this.discretizeAndLoad(n,(o,s)=>F(this,pc).getFeatures(o.chrom,o.startPos,o.endPos,{scale:i,signal:s}).then(c=>c.map(l=>({chrom:o.chrom,start:l.start,end:l.end,score:l.score}))));a&&this.publishData(a)}}dc=new WeakMap,pc=new WeakMap;function Bz(e,t,n){const r=(e[1]-e[0])/t;return n.find(i=>i<r)??n.at(-1)}class Fz extends Nl{constructor(n,r){const i={channel:"x",windowSize:1e6,debounce:200,debounceMode:"window",...n};super(r,i.channel);zn(this,"parser");zn(this,"bbi");zn(this,"parseLine");if(this.params=i,!this.params.url)throw new Error("No URL provided for BigBedSource");this.setupDebouncing(this.params),this.initializedPromise=new Promise(a=>{Promise.all([Promise.resolve().then(()=>MK),Promise.resolve().then(()=>fk),Promise.resolve().then(()=>hu)]).then(([o,{BigBed:s},{RemoteFile:c}])=>{const l=o.default;this.bbi=new s({filehandle:new c(Xa(this.params.url,this.view.getBaseUrl()))}),this.bbi.getHeader().then(async u=>{this.parser=new l({autoSql:u.autoSql});try{const f=Pz(this.parser);this.parseLine=(h,d)=>f(h,d.start,d.end,d.rest)}catch{this.parseLine=(h,d)=>this.parser.parseLine(`${h} ${d.start} ${d.end} ${d.rest}`)}a()})})})}async loadInterval(n){const r=await this.discretizeAndLoad(n,async(i,a)=>this.bbi.getFeatures(i.chrom,i.startPos,i.endPos,{signal:a}).then(o=>o.map(s=>this.parseLine(i.chrom,s))));r&&this.publishData(r)}}function Pz(e){const t=e.autoSql.fields.filter(g=>g.type).slice(3);let n=0,r="",i=0,a={};const o=" ",s=o.charCodeAt(0),c="0".charCodeAt(0),l="-".charCodeAt(0);function u(){let g=r.indexOf(o,n);g<0&&(g=i);const b=r.substring(n,g);return n=g+1,b}function f(){let g=0,b=r.charCodeAt(n),y=1;b===l&&(y=-1,n++,b=r.charCodeAt(n));do{if(b===s){n++;break}g=g*10+b-c,b=r.charCodeAt(++n)}while(n<i);return g*y}const h=t.map(g=>{const{name:b,type:y}=g;if(["ubyte","int","uint"].includes(y))return()=>{a[b]=f()};if(g.isNumeric)return()=>{a[b]=Number(u())};if(["char","string","lstring"].includes(y))return()=>{a[b]=u()};throw new Error("Unsupported type: "+y)});function d(g){r=g,i=g.length,n=0}function p(g,b,y,w){d(w),a={chrom:g,chromStart:b,chromEnd:y};for(let A=0,x=h.length;A<x;A++)h[A]();return a}return p}class Mz extends Nl{constructor(n,r){const i={channel:"x",windowSize:2e4,debounce:200,debounceMode:"domain",...n};super(r,i.channel);Z(this,Mo,void 0);zn(this,"chrPrefixFixer",n=>n);if(this.params=i,!this.params.url)throw new Error("No URL provided for BamSource");this.setupDebouncing(this.params),this.initializedPromise=new Promise(a=>{Promise.all([Promise.resolve().then(()=>tJ),Promise.resolve().then(()=>hu)]).then(([{BamFile:o},{RemoteFile:s}])=>{const c=l=>new s(Xa(l,this.view.getBaseUrl()));le(this,Mo,new o({bamFilehandle:c(this.params.url),baiFilehandle:c(this.params.indexUrl??this.params.url+".bai")})),F(this,Mo).getHeader().then(l=>{var h,d;const u=this.genome.hasChrPrefix(),f=(d=(h=F(this,Mo).indexToChr)==null?void 0:h[0])==null?void 0:d.refName.startsWith("chr");u&&!f?this.chrPrefixFixer=p=>p.replace("chr",""):!u&&f&&(this.chrPrefixFixer=p=>"chr"+p),a()})})})}async loadInterval(n){const r=await this.discretizeAndLoad(n,async(i,a)=>F(this,Mo).getRecordsForRange(this.chrPrefixFixer(i.chrom),i.startPos,i.endPos,{signal:a}).then(o=>o.map(s=>({chrom:i.chrom,start:s.get("start"),end:s.get("end"),name:s.get("name"),MD:s.get("MD"),cigar:s.get("cigar"),mapq:s.get("mq"),strand:s.get("strand")===1?"+":"-"}))));r&&this.publishData(r)}}Mo=new WeakMap;class Oz extends Nl{constructor(n,r){const i={channel:"x",windowSize:3e6,debounce:200,debounceMode:"domain",...n};super(r,i.channel);Z(this,hf,void 0);if(this.params=i,!this.params.url)throw new Error("No URL provided for TabixSource");this.setupDebouncing(this.params),this.initializedPromise=new Promise(a=>{Promise.all([Promise.resolve().then(()=>d6),Promise.resolve().then(()=>fJ),Promise.resolve().then(()=>hu)]).then(([{Buffer:o},{TabixIndexedFile:s},{RemoteFile:c}])=>{typeof window<"u"&&(window.Buffer??(window.Buffer=o));const l=u=>new c(Xa(u,this.view.getBaseUrl()));le(this,hf,new s({filehandle:l(this.params.url),tbiFilehandle:l(this.params.indexUrl??this.params.url+".tbi")})),a()})})}async loadInterval(n){const r=await this.discretizeAndLoad(n,async(i,a)=>{const o=[];return await F(this,hf).getLines(i.chrom,i.startPos,i.endPos,{lineCallback:s=>{o.push(s)},signal:a}),this._parseFeatures(o)});r&&this.publishData(r)}_parseFeatures(n){return[]}}hf=new WeakMap;class Lz extends Oz{constructor(n,r){super(n,r);Z(this,df,void 0);Promise.resolve().then(()=>ZJ).then(i=>{le(this,df,i.default)})}_parseFeatures(n){var i;return(i=F(this,df))==null?void 0:i.parseStringSync(n.join(`
1698
+ };`)},u=h=>{o||l(h);for(let d=0;d<o.length;d++){const[p,g]=o[d],b=c(h,p,g);this._propagate(b)}},f=h=>{l(h),u(h),this.handle=u};this.handle=f,this.beginBatch=h=>{qA(h)&&(this.handle=f),super.beginBatch(h)}}}class gz extends at{get behavior(){return Li}constructor(t){super(),this.params=t,this.buffer=[]}reset(){this.buffer=[]}handle(t){this.buffer.push(t)}complete(){const t=this.params,n=t.as||["y0","y1"],r=t.sort?fv(t.sort.field,t.sort.order):void 0,i=t.field?Oe(t.field):()=>1,a=t.groupby.map(u=>Oe(u)),o=JI(this.buffer,u=>a.map(f=>f(u)).join()).map(u=>u[1]);let s=u=>!0;if(t.baseField){const u=Oe(t.baseField);s=f=>u(f)!==null}let c,l;switch(t.offset){case"normalize":c=(u,f)=>u/f,l=(u,f)=>Gf(u,f);break;case"center":c=(u,f)=>u-f/2,l=(u,f)=>Gf(u,f);break;case"information":{const u=Math.log2(t.cardinality??4);c=(f,h)=>f/h,l=(f,h)=>{const p=Gf(f,w=>+!s(w)),g=Gf(f,h),b=g-p;let y=0;for(let w=0;w<f.length;w++){const A=f[w];if(s(A)){const x=h(A)/b;y-=x*Math.log2(x)}}return b/(u-(y+0))*(b/g)}}break;default:c=(u,f)=>u,l=(u,f)=>1}for(const u of o){r&&u.sort(r);const f=l(u,i);let h=0;for(const d of u){const p=h+i(d);s(d)&&(d[n[0]]=c(h,f),d[n[1]]=c(p,f),this._propagate(d),h=p)}}super.complete()}}class mz extends at{get behavior(){return mr}constructor(t){super();const n=Oe(t.field??"sequence"),[r,i]=t.as??["pos","sequence"];this.handle=a=>{const o=Object.assign({},a,{[i]:"",[r]:0}),s=n(a);for(let c=0;c<s.length;c++){const l=Object.assign({},o);l[r]=c,l[i]=s.charAt(c),this._propagate(l)}}}}class bz extends at{get behavior(){return mr}constructor(t){super(),this.params=t,this.buffer=[]}reset(){this.buffer=[]}handle(t){this.buffer.push(t)}complete(){const n=this.params.groupby,r=n.map(a=>Oe(a)),i=Rc(this.buffer,...r);for(const[a,o]of Qm(i)){const s={count:o.length};for(let c=0;c<n.length;c++)s[n[c]]=a[c];this._propagate(s)}super.complete()}}const yz="_uniqueId",yE=1e4,vE=[null];class wE extends at{get behavior(){return Li}constructor(t){super(),this.params=t,this.as=t.as??yz,this._blocks=[],this._usedBlocks=0,this._id=-1}initialize(){}reset(){super.reset(),this._usedBlocks=0,this._id=-1}handle(t){t[this.as]=this._nextId(),this._propagate(t)}_nextId(){return++this._id%yE==0&&(this._id=this._getBlock()*yE),this._id}_getBlock(){return this._usedBlocks<this._blocks.length?this._blocks[this._usedBlocks++]:this._reserveBlock()}_reserveBlock(){const t=vE.length;return vE[t]=this,this._blocks.push(t),this._usedBlocks++,t}}const xE={aggregate:bz,collect:Ol,coverage:XN,filterScoredLabels:ez,filter:tz,flatten:nz,flattenCompressedExons:az,flattenDelimited:oz,flattenSequence:mz,formula:cz,identifier:wE,linearizeGenomicCoordinate:mE,measureText:lz,pileup:fz,project:hz,regexExtract:dz,regexFold:pz,sample:WA,stack:gz};function vz(e,t){const n=xE[e.type];if(n)return new n(e,t);throw new Error("Unknown transform: "+e.type)}function AE(e){if(!_E(e)&&!SE(e))return;const t={...e.format};if(t.type??(t.type=SE(e)&&wz(e.url)),t.parse??(t.parse="auto"),!t.type)throw new Error("Format for the data source was not defined and it could not be inferred: "+JSON.stringify(e));return t}function wz(e){var t;if(Array.isArray(e)&&(e=e[0]),e)return(t=e.match(/\.(csv|tsv|json)/))==null?void 0:t[1]}const EE=e=>typeof e!="object"?xz:Az,xz=e=>({data:e}),Az=e=>e;function SE(e){return"url"in e}class ms extends at{get identifier(){}handle(t){throw new Error("Source does not handle incoming data!")}async load(){}}function _E(e){return"values"in e}class Ez extends ms{constructor(t,n){var r;if(super(),this.params=t,typeof t.values=="string"&&!((r=t==null?void 0:t.format)!=null&&r.type))throw new Error("Data format type (csv, dsv, ...) must be specified if a string is provided!")}loadSynchronously(){const t=this.params.values;let n=[],r=i=>i;if(Array.isArray(t))t.length>0&&(n=t,r=EE(t[0]));else if(typeof t=="object")n=[t];else if(typeof t=="string")n=dw(t,AE(this.params));else throw new Error('"values" in data configuration is not an array, object, or a string!');this.reset(),this.beginBatch({type:"file"});for(const i of n)this._propagate(r(i));this.complete()}async load(){this.loadSynchronously()}}function Sz(e){return"url"in e}class _z extends ms{constructor(t,n){super(),this.params=t,this.baseUrl=n==null?void 0:n.getBaseUrl()}get identifier(){return JSON.stringify({params:this.params,baseUrl:this.baseUrl})}async load(){const t=this.params.url,n=Array.isArray(t)?t:[t],r=async a=>Zc({baseURL:this.baseUrl}).load(a).catch(o=>{throw new Error(`Cannot fetch: ${this.baseUrl}${a}: ${o.message}`)}),i=(a,o)=>{try{const s=dw(a,AE(this.params));this.beginBatch({type:"file",url:o});for(const c of s)this._propagate(c)}catch(s){throw new Error(`Cannot parse: ${o}: ${s.message}`)}};this.reset(),await Promise.all(n.map(a=>r(a).then(i))),this.complete()}}function Cz(e){return"sequence"in e}class kz extends ms{constructor(t,n){if(super(),this.sequence=t.sequence,!("start"in this.sequence))throw new Error("'start' is missing from sequence parameters!");if(!("stop"in this.sequence))throw new Error("'stop' is missing from sequence parameters!")}loadSynchronously(){const t=this.sequence.as||"data",n=this.sequence.step||1,r=this.sequence.stop;this.reset(),this.beginBatch({type:"file"});for(let i=this.sequence.start;i<r;i+=n)this._propagate({[t]:i});this.complete()}async load(){this.loadSynchronously()}}class Xm extends ms{constructor(n,r){super();zn(this,"initializedPromise",Promise.resolve());if(this.view=n,r){if(r!=="x"&&r!=="y")throw new Error(`Invalid channel specified for the lazy data source: ${r}. Must be either "x" or "y"`)}else throw new Error('No channel has been specified for the lazy data source. Must be either "x" or "y".');if(this.channel=r,this.scaleResolution=this.view.getScaleResolution(r),!this.scaleResolution){const a=[`The lazy data source cannot find a resolved scale for channel "${r}".`];throw this.view instanceof mt||a.push('Make sure the view has a "shared" scale resolution as it is not a unit view.'),new Error(a.join(" "))}const i=()=>{this.view.isVisible()&&this.onDomainChanged(this.scaleResolution.getDomain(),this.scaleResolution.getComplexDomain())};this.scaleResolution.addEventListener("domain",i),this.view.context.addBroadcastListener("layoutComputed",i)}getAxisLength(){const n=this.scaleResolution.members.map(r=>{var i;return(i=r.view.coords)==null?void 0:i[this.channel==="x"?"width":"height"]}).filter(r=>r>0);return n.length?n.reduce((r,i)=>Math.min(r,i),1e4):0}get genome(){return this.scaleResolution.getGenome()}async onDomainChanged(n,r){}setLoadingStatus(n){this.view.context.setDataLoadingStatus(this.view,n)}requestRender(){this.view.context.animator.requestRender()}async load(){this.reset(),this.complete()}publishData(n){this.reset(),this.beginBatch({type:"file"});for(const r of n)for(const i of r)this._propagate(i);this.complete(),Ym(this.view),this.requestRender()}}class Tz extends Xm{constructor(n,r){const i={axis:{},...n};super(r,i.channel);zn(this,"ticks",[]);this.params=n}async onDomainChanged(){const n=this.scaleResolution.getScale(),r=this.params.axis,i=this.getAxisLength(),a=l=>25+60*pg(100,700,l),o=ft(r.tickCount)?r.tickCount:Math.round(i/a(i)),s=nE(n,o,r.tickMinStep),c=r.values?rE(n,r.values,s):sN(n,s);if(!th(c,this.ticks)){this.ticks=c;const l=lN(n,o,r.format);this.publishData([c.map(u=>({value:u,label:l(u)}))])}}}class Iz extends Xm{constructor(t,n){super(n,t.channel)}async load(){this.publishData([this.genome.chromosomes])}}function Xa(e,t){return!t||/^(data:|([A-Za-z]+:)?\/\/)/.test(e)||e.startsWith("/")?e:(t.endsWith("/")||(t+="/"),t+e)}function bs(e,t,n=!0){let r,i=o=>{};return function(...s){return new Promise((c,l)=>{const u=()=>{clearTimeout(r),i=f=>{},c(e(...s))};n&&i("debounced"),clearTimeout(r),i=l,r=window.setTimeout(u,t)})}}class Nl extends Xm{constructor(){super(...arguments);Z(this,hc,new AbortController);Z(this,ff,[0,0]);zn(this,"params")}setupDebouncing(n){n.debounce>0&&(n.debounceMode=="domain"?this.onDomainChanged=bs(this.onDomainChanged.bind(this),n.debounce,!1):n.debounceMode=="window"&&(this.loadInterval=bs(this.loadInterval.bind(this),n.debounce,!1)))}async onDomainChanged(n){var a;const r=((a=this.params)==null?void 0:a.windowSize)??-1;if(n[1]-n[0]>r)return;const i=this.quantizeInterval(n,r);this.checkAndUpdateLastInterval(i)&&(await this.initializedPromise,this.loadInterval(i))}async loadInterval(n){}async discretizeAndLoad(n,r){F(this,hc).abort(),this.setLoadingStatus(!0),le(this,hc,new AbortController);const i=F(this,hc).signal,a=this.genome.continuousToDiscreteChromosomeIntervals(n);try{const o=await Promise.all(a.map(async s=>r(s,i)));if(!i.aborted)return this.setLoadingStatus(!1),o}catch(o){if(!i.aborted)throw this.setLoadingStatus(!1),o}}quantizeInterval(n,r){return[Math.max(Math.floor(n[0]/r-1)*r,0),Math.min(Math.ceil(n[1]/r+1)*r,this.genome.totalSize)]}checkAndUpdateLastInterval(n){return th(F(this,ff),n)?!1:(le(this,ff,n),!0)}}hc=new WeakMap,ff=new WeakMap;class Rz extends Nl{constructor(t,n){const r={channel:"x",windowSize:7e3,debounce:200,debounceMode:"window",...t};if(super(n,r.channel),this.params=r,!this.params.url)throw new Error("No URL provided for IndexedFastaSource");this.setupDebouncing(this.params),this.initializedPromise=new Promise(i=>{Promise.all([Promise.resolve().then(()=>d6),Promise.resolve().then(()=>UY),Promise.resolve().then(()=>hu)]).then(([{Buffer:a},{IndexedFasta:o},{RemoteFile:s}])=>{typeof window<"u"&&(window.Buffer??(window.Buffer=a));const c=l=>new s(Xa(l,this.view.getBaseUrl()));this.fasta=new o({fasta:c(this.params.url),fai:c(this.params.indexUrl??this.params.url+".fai")}),i()})})}async loadInterval(t){const n=await this.discretizeAndLoad(t,async(r,i)=>this.fasta.getSequence(r.chrom,r.startPos,r.endPos,{signal:i}).then(a=>({chrom:r.chrom,start:r.startPos,sequence:a})));n&&this.publishData([n])}}class Dz extends Nl{constructor(n,r){const i={pixelsPerBin:2,channel:"x",debounce:200,debounceMode:"window",...n};super(r,i.channel);Z(this,dc,[]);Z(this,pc,void 0);if(this.params=i,!this.params.url)throw new Error("No URL provided for BigWigSource");this.setupDebouncing(this.params),this.initializedPromise=new Promise(a=>{Promise.all([Promise.resolve().then(()=>fk),Promise.resolve().then(()=>hu)]).then(([{BigWig:o},{RemoteFile:s}])=>{le(this,pc,new o({filehandle:new s(Xa(this.params.url,this.view.getBaseUrl()))})),F(this,pc).getHeader().then(c=>{le(this,dc,c.zoomLevels.map(l=>l.reductionLevel).reverse()),F(this,dc).push(1),a()})})})}async onDomainChanged(n){await this.initializedPromise;const r=this.getAxisLength()||700,i=Bz(n,r,F(this,dc)),a=Math.max(i*r,5e3),o=this.quantizeInterval(n,a);this.checkAndUpdateLastInterval(o)&&this.loadInterval(o,i)}async loadInterval(n,r){const i=.5/r/this.params.pixelsPerBin,a=await this.discretizeAndLoad(n,(o,s)=>F(this,pc).getFeatures(o.chrom,o.startPos,o.endPos,{scale:i,signal:s}).then(c=>c.map(l=>({chrom:o.chrom,start:l.start,end:l.end,score:l.score}))));a&&this.publishData(a)}}dc=new WeakMap,pc=new WeakMap;function Bz(e,t,n){const r=(e[1]-e[0])/t;return n.find(i=>i<r)??n.at(-1)}class Fz extends Nl{constructor(n,r){const i={channel:"x",windowSize:1e6,debounce:200,debounceMode:"window",...n};super(r,i.channel);zn(this,"parser");zn(this,"bbi");zn(this,"parseLine");if(this.params=i,!this.params.url)throw new Error("No URL provided for BigBedSource");this.setupDebouncing(this.params),this.initializedPromise=new Promise(a=>{Promise.all([Promise.resolve().then(()=>MK),Promise.resolve().then(()=>fk),Promise.resolve().then(()=>hu)]).then(([o,{BigBed:s},{RemoteFile:c}])=>{const l=o.default;this.bbi=new s({filehandle:new c(Xa(this.params.url,this.view.getBaseUrl()))}),this.bbi.getHeader().then(async u=>{this.parser=new l({autoSql:u.autoSql});try{const f=Pz(this.parser);this.parseLine=(h,d)=>f(h,d.start,d.end,d.rest)}catch{this.parseLine=(h,d)=>this.parser.parseLine(`${h} ${d.start} ${d.end} ${d.rest}`)}a()})})})}async loadInterval(n){const r=await this.discretizeAndLoad(n,async(i,a)=>this.bbi.getFeatures(i.chrom,i.startPos,i.endPos,{signal:a}).then(o=>o.map(s=>this.parseLine(i.chrom,s))));r&&this.publishData(r)}}function Pz(e){const t=e.autoSql.fields.filter(y=>y.type).slice(3);let n=0,r="",i=0,a={};const o=" ",s=o.charCodeAt(0),c="0".charCodeAt(0),l="-".charCodeAt(0);function u(){let y=r.indexOf(o,n);y<0&&(y=i);const w=r.substring(n,y);return n=y+1,w}function f(){let y=0,w=r.charCodeAt(n),A=1;w===l&&(A=-1,n++,w=r.charCodeAt(n));do{if(w===s){n++;break}y=y*10+w-c,w=r.charCodeAt(++n)}while(n<i);return y*A}const h=t.map(y=>{const{name:w,type:A}=y;if(["ubyte","int","uint"].includes(A))return()=>{a[w]=f()};if(y.isNumeric)return()=>{a[w]=Number(u())};if(["char","string","lstring"].includes(A))return()=>{a[w]=u()};throw new Error("Unsupported type: "+A)}),d=t.map(y=>`"${y.name}": ${y.isNumeric?"0":"emptyString"}`),p=new Function(`
1699
+ const emptyString = "";
1700
+ return function makeTemplate(chrom, chromStart, chromEnd) {
1701
+ return {
1702
+ chrom,
1703
+ chromStart,
1704
+ chromEnd,
1705
+ ${d.join(`,
1706
+ `)}
1707
+ }
1708
+ };`)();function g(y){r=y,i=y.length,n=0}function b(y,w,A,x){g(x),a=p(y,w,A);for(let C=0,_=h.length;C<_;C++)h[C]();return a}return b}class Mz extends Nl{constructor(n,r){const i={channel:"x",windowSize:2e4,debounce:200,debounceMode:"domain",...n};super(r,i.channel);Z(this,Mo,void 0);zn(this,"chrPrefixFixer",n=>n);if(this.params=i,!this.params.url)throw new Error("No URL provided for BamSource");this.setupDebouncing(this.params),this.initializedPromise=new Promise(a=>{Promise.all([Promise.resolve().then(()=>tJ),Promise.resolve().then(()=>hu)]).then(([{BamFile:o},{RemoteFile:s}])=>{const c=l=>new s(Xa(l,this.view.getBaseUrl()));le(this,Mo,new o({bamFilehandle:c(this.params.url),baiFilehandle:c(this.params.indexUrl??this.params.url+".bai")})),F(this,Mo).getHeader().then(l=>{var h,d;const u=this.genome.hasChrPrefix(),f=(d=(h=F(this,Mo).indexToChr)==null?void 0:h[0])==null?void 0:d.refName.startsWith("chr");u&&!f?this.chrPrefixFixer=p=>p.replace("chr",""):!u&&f&&(this.chrPrefixFixer=p=>"chr"+p),a()})})})}async loadInterval(n){const r=await this.discretizeAndLoad(n,async(i,a)=>F(this,Mo).getRecordsForRange(this.chrPrefixFixer(i.chrom),i.startPos,i.endPos,{signal:a}).then(o=>o.map(s=>({chrom:i.chrom,start:s.get("start"),end:s.get("end"),name:s.get("name"),MD:s.get("MD"),cigar:s.get("cigar"),mapq:s.get("mq"),strand:s.get("strand")===1?"+":"-"}))));r&&this.publishData(r)}}Mo=new WeakMap;class Oz extends Nl{constructor(n,r){const i={channel:"x",windowSize:3e6,debounce:200,debounceMode:"domain",...n};super(r,i.channel);Z(this,hf,void 0);if(this.params=i,!this.params.url)throw new Error("No URL provided for TabixSource");this.setupDebouncing(this.params),this.initializedPromise=new Promise(a=>{Promise.all([Promise.resolve().then(()=>d6),Promise.resolve().then(()=>fJ),Promise.resolve().then(()=>hu)]).then(([{Buffer:o},{TabixIndexedFile:s},{RemoteFile:c}])=>{typeof window<"u"&&(window.Buffer??(window.Buffer=o));const l=u=>new c(Xa(u,this.view.getBaseUrl()));le(this,hf,new s({filehandle:l(this.params.url),tbiFilehandle:l(this.params.indexUrl??this.params.url+".tbi")})),a()})})}async loadInterval(n){const r=await this.discretizeAndLoad(n,async(i,a)=>{const o=[];return await F(this,hf).getLines(i.chrom,i.startPos,i.endPos,{lineCallback:s=>{o.push(s)},signal:a}),this._parseFeatures(o)});r&&this.publishData(r)}_parseFeatures(n){return[]}}hf=new WeakMap;class Lz extends Oz{constructor(n,r){super(n,r);Z(this,df,void 0);Promise.resolve().then(()=>ZJ).then(i=>{le(this,df,i.default)})}_parseFeatures(n){var i;return(i=F(this,df))==null?void 0:i.parseStringSync(n.join(`
1699
1709
  `),{parseSequences:!1})}}df=new WeakMap;function CE(e,t){if(_E(e))return new Ez(e,t);if(Sz(e))return new _z(e,t);if(Cz(e))return new kz(e,t);if(Nz(e))return qz(e.lazy,t);throw new Error("Cannot figure out the data source type: "+JSON.stringify(e))}function Nz(e){return"lazy"in e}function zz(e){return(e==null?void 0:e.type)=="axisTicks"}function Uz(e){return(e==null?void 0:e.type)=="axisGenome"}function $z(e){return(e==null?void 0:e.type)=="indexedFasta"}function Hz(e){return(e==null?void 0:e.type)=="bigwig"}function Gz(e){return(e==null?void 0:e.type)=="bigbed"}function Vz(e){return(e==null?void 0:e.type)=="bam"}function jz(e){return(e==null?void 0:e.type)=="gff3"}function qz(e,t){if(zz(e))return new Tz(e,t);if(Uz(e))return new Iz(e,t);if($z(e))return new Rz(e,t);if(Hz(e))return new Dz(e,t);if(Gz(e))return new Fz(e,t);if(Vz(e))return new Mz(e,t);if(jz(e))return new Lz(e,t);throw new Error("Cannot figure out the data source type: "+JSON.stringify(e))}function Wz(e){const t=Object.keys(e).filter(r=>typeof r=="string"),n=new Function("source","return { "+t.map(r=>JSON.stringify(r)).map(r=>`${r}: source[${r}]`).join(`,
1700
1710
  `)+" };");return n.properties=t,n}class nd extends at{get behavior(){return mr}constructor(){super();const t=n=>{const r=Wz(n);this.handle=i=>this._propagate(r(i)),this.handle(n)};this.handle=t,this.beginBatch=n=>{qA(n)&&(this.handle=t),super.beginBatch(n)}}}function Yz(e){return"name"in e}class kE extends ms{constructor(n,r,i){super();Z(this,pf,void 0);this.provider=i,this.params=n}get identifier(){return this.params.name}updateDynamicData(n){le(this,pf,n),this.loadSynchronously()}loadSynchronously(){const n=F(this,pf)??this.provider(this.params.name)??[];let r=i=>i;if(Array.isArray(n))n.length>0&&(r=EE(n[0]));else throw new Error(`Named data "${this.params.name}" is not an array!`);this.reset(),this.beginBatch({type:"file"});for(const i of n)this._propagate(r(i));this.complete()}async load(){this.loadSynchronously()}}pf=new WeakMap;class TE{constructor(){this._dataSourcesByHost=new Map,this._collectorsByHost=new Map,this._observers=new Map}get dataSources(){return[...new Set(this._dataSourcesByHost.values()).values()]}get collectors(){return[...this._collectorsByHost.values()]}addObserver(t,n){let r=this._observers.get(n);r||(r=[],this._observers.set(n,r)),r.push(t)}_relayObserverCallback(t,n){const r=this._observers.get(n);if(r)for(const i of r)i(t)}addDataSource(t,n){this._dataSourcesByHost.set(n,t)}findDataSourceByKey(t){return this._dataSourcesByHost.get(t)}findNamedDataSource(t){let n,r=[];for(const[i,a]of this._dataSourcesByHost.entries())if(a instanceof kE&&t==a.identifier){if(n&&n!==a)throw new Error(`Found multiple instances of named data: ${t}. Data flow optimization is broken (it's a bug).`);n=a,r.push(i)}if(n)return{dataSource:n,hosts:r}}addCollector(t,n){this._collectorsByHost.set(n,t),t.observers.push(r=>this._relayObserverCallback(r,n))}findCollectorByKey(t){return this._collectorsByHost.get(t)}initialize(){for(const t of this.dataSources)t.visit(n=>n.initialize())}}function IE(e,t){const n=new Map,r=[];for(const i of e)n.set(i,{ref:i,children:[]});for(const i of n.values()){const a=n.get(t(i.ref));a?a.children.push(i):r.push(i)}return r}function RE(e,t,n){var i,a;const r=(i=t.preOrder)==null?void 0:i.call(t,e);if(r)return r;for(const o of n(e)){const s=RE(o,t,n);if(s==="stop")return s}return(a=t.postOrder)==null?void 0:a.call(t,e)}function DE(e,t){return RE(e,t,n=>n.children)}function BE(e,t){const n=[];let r;const i=t??new TE,a=[];function o(f,h=()=>{}){if(!r)throw h()||new Error("Cannot append data flow node, no parent exist!");return r.addChild(f),r=f,f}function s(f,h){return o(f,()=>new Error(`Cannot append a transform because no (inherited) data are available! ${h?JSON.stringify(h):""}`))}function c(f,h){for(const d of f){let p;try{p=vz(d,h)}catch(g){throw console.warn(g),new Error(`Cannot initialize "${d.type}" transform: ${g}`)}p.behavior&Li&&s(new nd),s(p)}}const l=f=>{if(n.push(r),f.spec.data){const h=Yz(f.spec.data)?new kE(f.spec.data,f,f.context.getNamedDataFromProvider):CE(f.spec.data,f);r=h,i.addDataSource(h,f)}if(f.spec.transform&&c(f.spec.transform,f),f instanceof mt){if(!r)throw new Error(`A unit view (${f.getPathString()}) has no (inherited) data source`);const h=Zz(f);if(h){a.push(h.rewrite);for(const p of h.transforms)s(p)}f.mark.isPickingParticipant()&&(s(new nd),s(new wE({type:"identifier"})));const d=new Ol({type:"collect",groupby:f.getFacetFields(),sort:Qz(f,h==null?void 0:h.rewrittenEncoding)});o(d),i.addCollector(d,f)}},u=IE(e.getDescendants(),f=>f.dataParent);for(const f of u)DE(f,{preOrder:h=>l(h.ref),postOrder:()=>{r=n.pop()}});return a.forEach(f=>f()),i}function Zz(e){var a;const t=[],n={},r=[];for(const[o,s]of Object.entries(e.getEncoding())){const c=o;wl(c)&&f3(s)&&r.push({channel:c,chromPosDef:s})}const i=Rc(r,o=>$a(o.channel),o=>o.chromPosDef.chrom);for(const[o,s]of i.entries())for(const[c,l]of s.entries()){const u=[],f=[],h=[];for(const{channel:d,chromPosDef:p}of l){const g=w=>w.replace(/[^A-Za-z0-9_]/g,""),b=["_linearized_",g(p.chrom),"_",g(p.pos)].join(""),y={...((a=e.spec.encoding)==null?void 0:a[d])??e.getEncoding()[d]??{},field:b};delete y.chrom,delete y.pos,!y.type&&p.type&&(y.type=p.type),n[d]=y,u.push(p.pos),h.push(p.offset??0),f.push(b)}t.push(new nd),t.push(new mE({type:"linearizeGenomicCoordinate",channel:o,chrom:c,pos:u,offset:h,as:f},e))}return t.length?{transforms:t,rewrittenEncoding:n,rewrite:()=>{e.spec.encoding={...e.spec.encoding,...n},NA(e.mark,"encoding")}}:void 0}function Qz(e,t){var r;const n={...e.getEncoding(),...t}.x;if(rn(n)&&(r=e.getScaleResolution("x"))!=null&&r.isZoomable()){if(Ur(n))return"buildIndex"in n&&n.buildIndex?{field:n.field}:null;if(!vl(n)){if(kh(n))throw new Error("A zoomable x channel must be mapped to a field.")}}}function Xz(e,...t){let n=e;for(const a of t)n.addChild(a),n=a;let r;n instanceof Ol?r=n:(r=new Ol,n.addChild(r));let i;return e instanceof ms?i=async()=>(await e.load(),r.getData()):i=async()=>{throw new Error("The root node is not derived from DataSource!")},{dataSource:e,collector:r,loadAndCollect:i}}function FE(e,t=void 0){if(e.parent!==t)return!1;for(const n of e.children)if(!FE(n,e))return!1;return!0}function Km(e,t=!1){if(e.behavior&zm&&(t=!0),e instanceof nd)if(t)t=!1;else{const n=e.children[0];e.excise(),n&&Km(n,t);return}e.behavior&mr&&(t=!1);for(let n=0,r=e.children.length;n<r;n++)Km(e.children[n],t||r>1)}function Kz(e){const t=[...e._dataSourcesByHost.entries()],n=new Map;for(const r of t){const i=r[1];i.identifier&&!n.has(i.identifier)&&n.set(i.identifier,i)}e._dataSourcesByHost.clear();for(let[r,i]of t){const a=n.get(i.identifier);a&&(a.adoptChildrenOf(i),i=a),e.addDataSource(i,r)}}function Jz(e){if(Km(e),!FE(e))throw new Error("Encountered a bug! There's a problem in the data flow structure.")}function eU(e){for(const t of e.dataSources)Jz(t);Kz(e)}function PE(e){const t=new Set;e.visit(n=>{for(const r of Object.values(n.resolutions.scale)){const i=r.name;if(i&&t.has(i))throw new Error(`The same scale name "${i}" occurs in multiple scale resolutions!`);t.add(i)}})}function tU(e){for(const t of ns){const n=e.getScaleResolution(t);n&&!n.name&&n.isZoomable()&&(n.name=`${t}_at_root`)}}function nU(e){const t=[];return e.visit(n=>{if(n instanceof mt){const r=n.getEncoding();for(const[i,a]of Object.entries(r))Ur(a)&&"type"in a&&t.push({view:n,channel:i,field:a.field,type:a.type});return KA}}),t}async function rU(e,t,n){var o;if(!e.import.url)throw new Error("Cannot import, not an import spec: "+JSON.stringify(e));const r=Zc({baseURL:t}),i=e.import.url,a=JSON.parse(await r.load(i).catch(s=>{throw new Error(`Could not load imported view spec: ${i}
1701
1711
  Reason: ${s.message}`)}));if(n.isViewSpec(a))return a.baseUrl=(o=i.match(/^[^?#]*\//))==null?void 0:o[0],a;throw new Error(`The imported spec "${i}" is not a view spec: ${JSON.stringify(e)}`)}function ME(e){const t=[];return e.visit(n=>{t.push(n)}),new Set([...eR(t,n=>n.length,n=>n.name)].filter(([n,r])=>r==1&&n!==void 0).map(([n,r])=>n))}const iU=e=>!/^(layer|concat)\d+$/.test(e);function aU(e){const t=e.getSize().addPadding(e.getOverhang()),n=r=>r.grow>0?void 0:r.px;return{width:n(t.width),height:n(t.height)}}function Vr(e){return()=>e}const ar=class ar{static create(t,n,r,i){return new ar(Vr(t),Vr(n),Vr(r),Vr(i))}_offset(t,n){const r=this["_"+t];if(n===0)return r;switch(typeof n){case"number":return()=>r()+n;case"function":return()=>r()+n();default:throw new Error("Not a number of function")}}_passThrough(t){return this._offset(t,0)}constructor(t,n,r,i){this._x=t,this._y=n,this._width=r,this._height=i}get x(){return this._x()}get y(){return this._y()}get width(){return this._width()}get height(){return this._height()}get x2(){return this._x()+this._width()}get y2(){return this._y()+this._height()}equals(t){return t?this===t||this.x===t.x&&this.y===t.y&&this.width===t.width&&this.height===t.height:!1}modify(t){if(!Object.keys(t).length)return this;const n=r=>{const i=t[r];return typeof i=="number"?Vr(i):typeof i=="function"?i:this._passThrough(r)};return new ar(n("x"),n("y"),n("width"),n("height"))}translate(t,n){return t===0&&n===0?this:new ar(this._offset("x",t),this._offset("y",n),this._passThrough("width"),this._passThrough("height"))}translateBy(t){return this.translate(t.x,t.y)}expand(t,n=1){return t.left==0&&t.top==0&&t.right==0&&t.bottom==0?this:new ar(t.left?this._offset("x",-t.left*n):this._passThrough("x"),t.top?this._offset("y",-t.top*n):this._passThrough("y"),t.width?this._offset("width",t.width*n):this._passThrough("width"),t.height?this._offset("height",t.height*n):this._passThrough("height"))}shrink(t){return this.expand(t,-1)}intersect(t){return this===t||t==null?this:new ar(()=>Math.max(this.x,t.x),()=>Math.max(this.y,t.y),()=>Math.min(this.x2,t.x2)-Math.max(this.x,t.x),()=>Math.min(this.y2,t.y2)-Math.max(this.y,t.y))}union(t){return this===t||t==null?this:new ar(()=>Math.min(this.x,t.x),()=>Math.min(this.y,t.y),()=>Math.max(this.x2,t.x2)-Math.min(this.x,t.x),()=>Math.max(this.y2,t.y2)-Math.min(this.y,t.y))}isDefined(){return this.width>=0&&this.height>=0}flatten(){return new ar(Vr(this.x),Vr(this.y),Vr(this.width),Vr(this.height))}containsPoint(t,n){return t>=this.x&&t<this.x2&&n>=this.y&&n<this.y2}normalizePoint(t,n){return{x:(t-this.x)/this.width,y:(n-this.y)/this.height}}toString(){return`Rectangle: x: ${this.x}, y: ${this.y}, width: ${this.width}, height: ${this.height}`}toRoundedString(){return`Rectangle: x: ${Math.round(this.x)}, y: ${Math.round(this.y)}, width: ${Math.round(this.width)}, height: ${Math.round(this.height)}`}};zn(ar,"ZERO",ar.create(0,0,0,0));let Zn=ar;class OE{constructor(t){this.globalOptions=t}pushView(t,n){}popView(t){}renderMark(t,n){}}class LE extends OE{constructor(t,n){super(t),this.webGLHelper=n,this.buffer=[],this.coords=void 0,this.views=new Set}pushView(t,n){this.views.add(t),this.coords=n}renderMark(t,n){if(this.globalOptions.picking&&!t.isPickingParticipant())return;const r=t.render(n);r&&this.buffer.push({mark:t,callback:r,coords:this.coords,clipRect:n.clipRect})}render(){if(this.batch||this._buildBatch(),this.batch.length==0)return;const t=this.webGLHelper.gl,n=this.globalOptions.picking;t.bindFramebuffer(t.FRAMEBUFFER,n?this.webGLHelper._pickingBufferInfo.framebuffer:null),this.webGLHelper.clearAll();for(const r of this.views)r.onBeforeRender();for(const r of this.batch)r();n&&t.bindFramebuffer(t.FRAMEBUFFER,null)}_buildBatch(){this.batch=[];let t=!0,n=!0;const r=o=>()=>{t&&o()},i=o=>()=>{t&&n&&o()},a=Rc(this.buffer.reverse(),o=>o.mark);for(const[o,s]of[...a.entries()].reverse()){if(!o.isReady())continue;this.batch.push(()=>{t=o.unitView.getEffectiveOpacity()>0}),this.batch.push(...o.prepareRender(this.globalOptions).map(l=>r(l)));let c;for(const l of s){const u=l.coords;u.equals(c)||this.batch.push(r(()=>{n=o.setViewport(u,l.clipRect)})),this.batch.push(i(l.callback)),c=l.coords}}}}class oU extends OE{constructor(...t){super({}),this.contexts=t}pushView(t,n){for(const r of this.contexts)r.pushView(t,n)}popView(t){for(const n of this.contexts)n.popView(t)}renderMark(t,n){for(const r of this.contexts)r.renderMark(t,n)}}class sU{constructor(t,n){this.point=t,this.uiEvent=n,this.stopped=!1,this.target=void 0}stopPropagation(){this.stopped=!0}get type(){return this.uiEvent.type}}class cU{constructor(t,n){this.x=t,this.y=n}equals(t){return t?t===this||t.x===this.x&&t.y===this.y:!1}}const lU=e=>new Promise(t=>setTimeout(t,e));function rd(e){const t=e.requestAnimationFrame||window.requestAnimationFrame,n=e.signal,r=()=>new Promise((i,a)=>{if(n!=null&&n.aborted)return a("aborted");const o=performance.now(),s=o+(e.duration||1e3),c=typeof e.from=="number"?e.from:0,l=typeof e.to=="number"?e.to:1,u=e.easingFunction||(g=>g),f=g=>(g-o)/(s-o),h=g=>g*(l-c)+c,d=g=>Math.max(0,Math.min(1,g)),p=g=>{n!=null&&n.aborted?a("aborted"):(e.onUpdate(h(u(d(f(g))))),g<s?t(p):(e.onUpdate(h(u(1))),i()))};t(p)});return e.delay?n!=null&&n.aborted?Promise.reject("aborted"):lU(e.delay).then(r):r()}class uU{constructor(t){this._renderCallback=t,this._renderRequested=!1,this._warn=!1,this.transitions=[]}requestTransition(t){this.cancelTransition(t),this.transitions.push(t),this.requestRender()}cancelTransition(t){const n=this.transitions.indexOf(t);n>=0&&this.transitions.splice(n,1)}requestRender(){this._renderRequested?this._warn&&console.warn("Render already requested!"):(this._renderRequested=!0,window.requestAnimationFrame(t=>{this._renderRequested=!1;const n=this.transitions;this.transitions=[];let r;for(;r=n.shift();)r(t);this._renderCallback(t)}))}transition(t){return rd({requestAnimationFrame:n=>this.requestTransition(n),...t})}}class fU{constructor(t){this.genomes=new Map,this.baseUrl=t}async initialize(t){const n=new BN(t);return this.genomes.set(n.name,n),Promise.all([...this.genomes.values()].map(r=>r.load(this.baseUrl)))}getGenome(t){if(!this.genomes.size)throw new Error("No genomes have been configured!");if(t){const n=this.genomes.get(t);if(!n)throw new Error(`No genome with the name ${t} has been configured!`);return n}else{if(this.genomes.size>1)throw new Error("Cannot pick a default genome! More than one have been configured!");return this.genomes.values().next().value}}}const hU="",dU={thin:100,light:300,regular:400,normal:400,medium:500,bold:700,black:900};class pU{constructor(t){this._webGLHelper=t,this.fontRepository="https://raw.githubusercontent.com/etiennepinchon/aframe-fonts/master/fonts/",this._fonts=new gi([],JSON.stringify),this._metadataPromises=new Map,this._fontPromises=new Map,this._promises=[],this._defaultFontEntry={metrics:Om(bE),texture:t?this._createTextureNow(hU):void 0}}async waitUntilReady(){await Promise.all(this._promises)}getFont(t,n="normal",r="regular"){if(Me(r)&&(r=dU[r.toLowerCase()],!r))throw new Error("Unknown font weight: "+r);const i={family:t,style:n,weight:r};let a=this._fonts.get(i);return a||(a={metrics:void 0,texture:void 0},this._fonts.set(i,a),this._promises.push(this._loadFontEntry(a,i))),a}async _loadFontEntry(t,n){try{const r=await this._loadMetadata(n.family),i=mU(r,n),a=this.fontRepository+NE(n.family)+"/"+i.replace(/\.\w+/,""),o=this._createTexture(a+".png"),s=this._loadFont(a+".json");t.texture=await o,t.metrics=await s}catch(r){console.log("Cannot load font. Using default.",r),t.metrics=this._defaultFontEntry.metrics,t.texture=this._defaultFontEntry.texture}}_loadFont(t){let n=this._fontPromises.get(t);return n||(n=fetch(t).then(r=>{if(!r.ok)throw new Error("Could not load font: "+r.status);return r}).then(r=>r.json()).then(r=>Om(r)),this._fontPromises.set(t,n)),n}_loadMetadata(t){const n=NE(t);let r=this._metadataPromises.get(n);return r||(r=fetch(this.fontRepository+n+"/METADATA.pb").then(i=>{if(!i.ok)throw new Error("Could not load font metadata: "+i.status);return i}).then(i=>i.text()).then(i=>gU(i)).catch(i=>{console.warn(i)}),this._metadataPromises.set(n,r)),r}getDefaultFont(){return this._defaultFontEntry}_createTexture(t){const n=this._webGLHelper.gl;return new Promise((r,i)=>{kl(n,{src:t,min:n.LINEAR},(a,o,s)=>{a?i(a):r(o)})})}_createTextureNow(t){const n=this._webGLHelper.gl;let r;const i=new Promise((a,o)=>{r=kl(n,{src:t,min:n.LINEAR},(s,c,l)=>{s?o(s):a(c)})});return this._promises.push(i),r}}function NE(e){return e.toLowerCase().replaceAll(/[^\w]/g,"")}function gU(e){const t=e.split(`
@@ -2932,7 +2942,7 @@ svg:not(:root).svg-inline--fa, svg:not(:host).svg-inline--fa {
2932
2942
  />
2933
2943
  ${Zj([123],()=>this._getSearchHelp())}
2934
2944
  </div>
2935
- `}}customElements.define("genome-spy-search-field",Qj);function Xj(e,t){return new Promise(n=>{let r=0;const i=700/e.length+30;function a(){t.value=e.substring(0,r),r>=e.length?setTimeout(n,500):(r++,setTimeout(a,Math.random()*i*2))}a()})}function Y_(e){let t;return e.visit(n=>{for(const r of["x","y"]){const i=n.resolutions.scale[r];if(i&&i.type=="locus"&&i.isZoomable())return t=i,Qa}}),t}const Z_="data:image/svg+xml,%3csvg%20viewBox='0%200%2032%2032'%20xmlns='http://www.w3.org/2000/svg'%20fill-rule='evenodd'%20clip-rule='evenodd'%20stroke-linecap='round'%20stroke-linejoin='round'%20stroke-miterlimit='1.5'%3e%3cpath%20d='M4.7%2021.2s.4%202.3%201.3%203.6C7%2026%209.8%2028%209.8%2028s3.4-2.6%206.4-8.5c0%200%201%20.1%201.9-.4.9-.6.8-.4%201-1.2%200%200%202.9.5%206.6%200%202.1-.3%204.3-1%206.2-2.5%200%200-1.1-1.7-2.5-5.1-.5-1.3-2-1.8-4.6-4.6l-8.2%208.6-11.9%206.9z'%20fill-opacity='.1'/%3e%3cpath%20d='M12.7%2014.8s-4-1.8-12%202.7c0%200%201%203.7%202.5%205.3%201.4%201.5%202.3%203.6%204.6%204.6%200%200%204.7-3%206.9-9.2l3-2s4.7%202.8%2012.6-1.6c0%200-.6-3.3-3-6-2.6-3-3.8-4.7-3.8-4.7s-4.1%202.3-7.5%209.3l-3.3%201.6z'%20fill='%237fbbdd'/%3e%3cpath%20d='M12.4%2015.5c-.7-.5-2.4-.8-4.4-.4-2%20.4-4%201.3-4.8%201.8-.5.3-1.2%201-1.2%201.4%200%20.7.3%201.8.8%202.4.3.3.7.5%201.4.6.8%200%202.5-1.4%203.5-2%201-.6%201.6-.8%202.7-1.2l-2.9%202.4c-1.3%201.2-2.2%201.5-2.4%202.3%200%20.5%200%201.4.5%201.8.4.5.6.8%201.6.8.6%200%201%200%202.6-1.5.9-.9%202.3-3%202.7-3.7.6-1.1%201-2.2.7-3-.2-1-.4-1.4-.8-1.7zM17.4%2014.2c-.3-.5-.9-1.2-.2-2.5l1.9-3c.5-.8%202-2.3%202.6-2.6.6-.4%201.5-.6%202-.2.6.4%201%201%201.3%201.5.4.6.7%201.3.2%202-.7%201-1.6.9-2.8%201.7-1.2.8-1.9%201.2-2.5%201.9l3.8-1.8c1.3-.6%202.7-1.1%203.4-.7.8.5.8.7%201%201.4.3%201-.2%201.9-.8%202.4-.5.6-1.5.9-2.6%201.2-1.4.4-4.5%201-5.8.5-1.3-.5-1.3-1.4-1.5-1.8z'%20fill='%23fff'/%3e%3cpath%20d='M12.7%2014.8s-4-1.8-12%202.7c0%200%201%203.7%202.5%205.3%201.4%201.5%202.3%203.6%204.6%204.6%200%200%204.7-3%206.9-9.2l3-2s4.7%202.8%2012.6-1.6c0%200-.6-3.3-3-6-2.6-3-3.8-4.7-3.8-4.7s-4.1%202.3-7.5%209.3l-3.3%201.6z'%20fill='none'%20stroke='%23000'%20stroke-width='.5'/%3e%3cpath%20d='M12.4%2014.9s2.1-2%203-2c1.1%200%202.3%202.7%202.3%203.5%200%20.8-2.1%202.4-3.1%202.3%200%200%200-1.2-.7-2.6-.8-1.3-1.5-1.2-1.5-1.2z'%20fill='%237fbbdd'/%3e%3cpath%20d='M13.8%2015.3c.9.8.6%202%201.4%201.8%201-.2%201.4-.8%201.3-1.5%200-.7%200-.8-.4-1.6-.3-.7-1-1.1-2-.5-.7.5-1.4%201.3-1.4%201.3s.2-.3%201.1.5z'%20fill='%23fff'/%3e%3cpath%20d='M12.4%2014.9s2.1-2%203-2c1.1%200%202.3%202.7%202.3%203.5%200%20.8-2.1%202.4-3.1%202.3%200%200%200-1.2-.7-2.6-.8-1.3-1.5-1.2-1.5-1.2z'%20fill='none'%20stroke='%23000'%20stroke-width='.5'/%3e%3c/svg%3e",Q_={name:"@genome-spy/app",description:"GenomeSpy-based visualization tool for multiple patient samples",author:{name:"Kari Lavikka",email:"kari.lavikka@helsinki.fi"},contributors:[],license:"MIT",version:"0.43.1",main:"dist/index.js",type:"module",files:["dist/"],repository:{type:"git",url:"github:genome-spy/genome-spy",directory:"packages/app"},scripts:{dev:"node dev-server.mjs",build:"vite build","test:tsc":"tsc -p tsconfig.json --noEmit",prepublishOnly:"npm run build"},dependencies:{"@floating-ui/dom":"^0.5.0","@fortawesome/fontawesome-free":"^6.4.2","@fortawesome/fontawesome-svg-core":"^6.4.2","@fortawesome/free-solid-svg-icons":"^6.4.2","@genome-spy/core":"^0.43.1","@reduxjs/toolkit":"^1.8.4",idb:"^7.1.1",lit:"^3.1.0","lz-string":"^1.4.4",mapsort:"^1.0.5","redux-batched-actions":"^0.5.0","redux-undo":"^1.0.1",snarkdown:"^2.0.0"},gitHead:"e47791753d5467ab83b5ef073976eb2f2484000b"};/**
2945
+ `}}customElements.define("genome-spy-search-field",Qj);function Xj(e,t){return new Promise(n=>{let r=0;const i=700/e.length+30;function a(){t.value=e.substring(0,r),r>=e.length?setTimeout(n,500):(r++,setTimeout(a,Math.random()*i*2))}a()})}function Y_(e){let t;return e.visit(n=>{for(const r of["x","y"]){const i=n.resolutions.scale[r];if(i&&i.type=="locus"&&i.isZoomable())return t=i,Qa}}),t}const Z_="data:image/svg+xml,%3csvg%20viewBox='0%200%2032%2032'%20xmlns='http://www.w3.org/2000/svg'%20fill-rule='evenodd'%20clip-rule='evenodd'%20stroke-linecap='round'%20stroke-linejoin='round'%20stroke-miterlimit='1.5'%3e%3cpath%20d='M4.7%2021.2s.4%202.3%201.3%203.6C7%2026%209.8%2028%209.8%2028s3.4-2.6%206.4-8.5c0%200%201%20.1%201.9-.4.9-.6.8-.4%201-1.2%200%200%202.9.5%206.6%200%202.1-.3%204.3-1%206.2-2.5%200%200-1.1-1.7-2.5-5.1-.5-1.3-2-1.8-4.6-4.6l-8.2%208.6-11.9%206.9z'%20fill-opacity='.1'/%3e%3cpath%20d='M12.7%2014.8s-4-1.8-12%202.7c0%200%201%203.7%202.5%205.3%201.4%201.5%202.3%203.6%204.6%204.6%200%200%204.7-3%206.9-9.2l3-2s4.7%202.8%2012.6-1.6c0%200-.6-3.3-3-6-2.6-3-3.8-4.7-3.8-4.7s-4.1%202.3-7.5%209.3l-3.3%201.6z'%20fill='%237fbbdd'/%3e%3cpath%20d='M12.4%2015.5c-.7-.5-2.4-.8-4.4-.4-2%20.4-4%201.3-4.8%201.8-.5.3-1.2%201-1.2%201.4%200%20.7.3%201.8.8%202.4.3.3.7.5%201.4.6.8%200%202.5-1.4%203.5-2%201-.6%201.6-.8%202.7-1.2l-2.9%202.4c-1.3%201.2-2.2%201.5-2.4%202.3%200%20.5%200%201.4.5%201.8.4.5.6.8%201.6.8.6%200%201%200%202.6-1.5.9-.9%202.3-3%202.7-3.7.6-1.1%201-2.2.7-3-.2-1-.4-1.4-.8-1.7zM17.4%2014.2c-.3-.5-.9-1.2-.2-2.5l1.9-3c.5-.8%202-2.3%202.6-2.6.6-.4%201.5-.6%202-.2.6.4%201%201%201.3%201.5.4.6.7%201.3.2%202-.7%201-1.6.9-2.8%201.7-1.2.8-1.9%201.2-2.5%201.9l3.8-1.8c1.3-.6%202.7-1.1%203.4-.7.8.5.8.7%201%201.4.3%201-.2%201.9-.8%202.4-.5.6-1.5.9-2.6%201.2-1.4.4-4.5%201-5.8.5-1.3-.5-1.3-1.4-1.5-1.8z'%20fill='%23fff'/%3e%3cpath%20d='M12.7%2014.8s-4-1.8-12%202.7c0%200%201%203.7%202.5%205.3%201.4%201.5%202.3%203.6%204.6%204.6%200%200%204.7-3%206.9-9.2l3-2s4.7%202.8%2012.6-1.6c0%200-.6-3.3-3-6-2.6-3-3.8-4.7-3.8-4.7s-4.1%202.3-7.5%209.3l-3.3%201.6z'%20fill='none'%20stroke='%23000'%20stroke-width='.5'/%3e%3cpath%20d='M12.4%2014.9s2.1-2%203-2c1.1%200%202.3%202.7%202.3%203.5%200%20.8-2.1%202.4-3.1%202.3%200%200%200-1.2-.7-2.6-.8-1.3-1.5-1.2-1.5-1.2z'%20fill='%237fbbdd'/%3e%3cpath%20d='M13.8%2015.3c.9.8.6%202%201.4%201.8%201-.2%201.4-.8%201.3-1.5%200-.7%200-.8-.4-1.6-.3-.7-1-1.1-2-.5-.7.5-1.4%201.3-1.4%201.3s.2-.3%201.1.5z'%20fill='%23fff'/%3e%3cpath%20d='M12.4%2014.9s2.1-2%203-2c1.1%200%202.3%202.7%202.3%203.5%200%20.8-2.1%202.4-3.1%202.3%200%200%200-1.2-.7-2.6-.8-1.3-1.5-1.2-1.5-1.2z'%20fill='none'%20stroke='%23000'%20stroke-width='.5'/%3e%3c/svg%3e",Q_={name:"@genome-spy/app",description:"GenomeSpy-based visualization tool for multiple patient samples",author:{name:"Kari Lavikka",email:"kari.lavikka@helsinki.fi"},contributors:[],license:"MIT",version:"0.43.2",main:"dist/index.js",type:"module",files:["dist/"],repository:{type:"git",url:"github:genome-spy/genome-spy",directory:"packages/app"},scripts:{dev:"node dev-server.mjs",build:"vite build","test:tsc":"tsc -p tsconfig.json --noEmit",prepublishOnly:"npm run build"},dependencies:{"@floating-ui/dom":"^0.5.0","@fortawesome/fontawesome-free":"^6.4.2","@fortawesome/fontawesome-svg-core":"^6.4.2","@fortawesome/free-solid-svg-icons":"^6.4.2","@genome-spy/core":"^0.43.2","@reduxjs/toolkit":"^1.8.4",idb:"^7.1.1",lit:"^3.1.0","lz-string":"^1.4.4",mapsort:"^1.0.5","redux-batched-actions":"^0.5.0","redux-undo":"^1.0.1",snarkdown:"^2.0.0"},gitHead:"12ff70326672ed7ca34ef081c01fc25f19cf1ede"};/**
2936
2946
  * @license
2937
2947
  * Copyright 2020 Google LLC
2938
2948
  * SPDX-License-Identifier: BSD-3-Clause
@@ -3246,7 +3256,7 @@ ${n}</textarea
3246
3256
  `:ue}
3247
3257
  ${this._getToolButtons()}
3248
3258
  </nav>
3249
- `}}customElements.define("genome-spy-toolbar",bq);class yq{constructor(t){this.storeHelper=t,this._reducers={},this.actionInfoSources=[],this._reducer=void 0,t.addReducer("provenance",(n,r)=>this._reducer?this._reducer(n,r):n??{})}addReducer(t,n){this._reducers[t]=n;const r=a=>Object.keys(this._reducers).some(o=>Me(o)&&a.type.startsWith(o)),i=(a,o)=>r(o)?o:a??null;this._reducer=ej(V1({...this._reducers,lastAction:i}),{ignoreInitialState:!0,filter:r}),this.storeHelper.dispatch({type:"@@redux/REPLACE"+Math.random().toString(36).substring(7).split("").join(".")})}get _storeState(){return this.storeHelper.store.getState()}get _provenanceState(){return this._storeState.provenance}isEnabled(){return!!this.getPresentState()}getPresentState(){return this._provenanceState.present}addActionInfoSource(t){this.actionInfoSources.push(t)}getActionInfo(t){for(const n of this.actionInfoSources){const r=n(t);if(r)return r}}dispatchBookmark(t){this.storeHelper.dispatch([...this.isUndoable()?[lo.jumpToPast(0)]:[],...t])}isRedoable(){return this.isEnabled()&&this._provenanceState.future.length>0}redo(){this.storeHelper.dispatch(lo.redo())}isUndoable(){return this.isEnabled()&&this._provenanceState.past.length>0}undo(){this.storeHelper.dispatch(lo.undo())}isAtInitialState(){return!this.isUndoable()}isEmpty(){const t=this._provenanceState;return!this.isEnabled()||t.past.length+t.future.length<=0}activateState(t){const n=this.getCurrentIndex();t<n?this.storeHelper.dispatch(lo.jumpToPast(t)):t>n&&this.storeHelper.dispatch(lo.jumpToFuture(t-n-1))}getCurrentIndex(){var t;return(t=this._provenanceState.past)==null?void 0:t.length}getActionHistory(){const t=this._provenanceState;return t.present&&[...t.past,t.present].map(n=>n.lastAction)}getFullActionHistory(){const t=this._provenanceState;return[...t.past,t.present,...t.future].map(n=>n.lastAction)}getBookmarkableActionHistory(){var t;return(t=this.getActionHistory())==null?void 0:t.slice(1)}}function*vq(e,t=n=>+n){const n=e.length,r=new Ll,i=new Array(n).fill(0);for(const[o,s]of e.entries())s.length&&r.push(o,t(s[0]));let a=0;for(;(a=r.pop())!==void 0;){const o=e[a];let s=i[a];if(yield o[s++],s<o.length){const l=t(o[s]);r.push(a,l),i[a]=s}}}const wq="sampleCount";class xq extends at{constructor(n,r){super();Z(this,Cf);Z(this,_f,!0);this.view=r;const i=r.context.animator;if(this.provenance=Aq(r),!this.provenance)throw new Error("No SampleView was found!");this.provenance.storeHelper.subscribe(a=>{F(this,Cf,sv)&&(F(this,_f)&&(le(this,_f,!1),this.reset(),this.complete()),i.requestTransition(()=>{this.reset(),this._mergeAndPropagate(ab(a)),this.complete()}))}),this.contextObject=void 0}initialize(){this.contextObject=Object.create(super.getGlobalObject());const n=this.view.getEncoding().x;if(Ur(n))this.xAccessor=Oe(n.field);else throw new Error("Sample summarization requires a FieldDef. This is not a FieldDef: "+JSON.stringify(n))}handle(n){}getGlobalObject(){return this.contextObject}_getCollector(){if(this.parent instanceof Ol)return this.parent;throw new Error("MergeFacetsTransform must be a direct child of a Collector")}complete(){F(this,Cf,sv)&&(this._mergeAndPropagate(this.provenance.getPresentState()[Cs]),super.complete())}_mergeAndPropagate(n){const r=[...sb(n.rootGroup)].filter(i=>t_(xn(i)));for(const[i,a]of r.entries()){const o=xn(a);if(t_(o)){this.contextObject[wq]=o.samples.length,this.beginBatch({type:"facet",facetId:[i]});const s=o.samples,c=this._getCollector(),l=vq(s.map(u=>c.facetBatches.get([u])??[]),this.xAccessor);for(const u of l)this._propagate(u)}}this._updateScales()}setParent(n){super.setParent(n)}_updateScales(){const n=new Set;this.view.visit(r=>{if(r instanceof mt&&r.mark.encoding.y){const i=r.getScaleResolution("y");i&&n.add(i)}});for(const r of n)r.reconfigure()}}_f=new WeakMap,Cf=new WeakSet,sv=function(){return this.view.isConfiguredVisible()};function Aq(e){for(const t of e.getLayoutAncestors())if(t instanceof xb)return t.provenance}var Eq="BATCHING_REDUCER.BATCH";function Sq(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:Eq;return{type:t,meta:{batch:!0},payload:e}}function _q(e){return function t(n,r){return r&&r.meta&&r.meta.batch?r.payload.reduce(t,n):e(n,r)}}class Cq{constructor(t){this._reducers=t??{},this.store=fV({reducer:{}}),this._listeners=new Set,this.store.subscribe(()=>{const n=this.store.getState();for(const r of this._listeners)r(n)})}get state(){return this.store.getState()}addReducer(t,n){this._reducers[t]=n,this.store.replaceReducer(_q(V1(this._reducers)))}subscribe(t){this._listeners.add(t)}unsubscribe(t){this._listeners.delete(t)}dispatch(t){Array.isArray(t)?this.store.dispatch(Sq(t)):this.store.dispatch(t)}getDispatcher(){return t=>this.dispatch(t)}}class kq extends G_{constructor(t){super(),this.bookmarks=t,this.names=t.map(n=>n.name)}async getNames(){return this.names}async get(t){return this.bookmarks.find(n=>n.name==t)}}xE.mergeFacets=xq;class u6{constructor(t,n,r={}){const i=this;this.config=n,this.storeHelper=new Cq,this.storeHelper.addReducer("viewSettings",Ts.reducer),this.provenance=new yq(this.storeHelper),this._initializationListeners=[],this.toolbarRef=q_(),this.appContainer=t,this._configureContainer(),this.localBookmarkDatabase=typeof n.specId=="string"?new Gj(n.specId):void 0,this.globalBookmarkDatabase=void 0,Vt($`<div class="genome-spy-app">
3259
+ `}}customElements.define("genome-spy-toolbar",bq);class yq{constructor(t){this.storeHelper=t,this._reducers={},this.actionInfoSources=[],this._reducer=void 0,t.addReducer("provenance",(n,r)=>this._reducer?this._reducer(n,r):n??{})}addReducer(t,n){this._reducers[t]=n;const r=a=>Object.keys(this._reducers).some(o=>Me(o)&&a.type.startsWith(o)),i=(a,o)=>r(o)?o:a??null;this._reducer=ej(V1({...this._reducers,lastAction:i}),{ignoreInitialState:!0,filter:r}),this.storeHelper.dispatch({type:"@@redux/REPLACE"+Math.random().toString(36).substring(7).split("").join(".")})}get _storeState(){return this.storeHelper.store.getState()}get _provenanceState(){return this._storeState.provenance}isEnabled(){return!!this.getPresentState()}getPresentState(){return this._provenanceState.present}addActionInfoSource(t){this.actionInfoSources.push(t)}getActionInfo(t){for(const n of this.actionInfoSources){const r=n(t);if(r)return r}}dispatchBookmark(t){this.storeHelper.dispatch([...this.isUndoable()?[lo.jumpToPast(0)]:[],...t])}isRedoable(){return this.isEnabled()&&this._provenanceState.future.length>0}redo(){this.storeHelper.dispatch(lo.redo())}isUndoable(){return this.isEnabled()&&this._provenanceState.past.length>0}undo(){this.storeHelper.dispatch(lo.undo())}isAtInitialState(){return!this.isUndoable()}isEmpty(){const t=this._provenanceState;return!this.isEnabled()||t.past.length+t.future.length<=0}activateState(t){const n=this.getCurrentIndex();t<n?this.storeHelper.dispatch(lo.jumpToPast(t)):t>n&&this.storeHelper.dispatch(lo.jumpToFuture(t-n-1))}getCurrentIndex(){var t;return(t=this._provenanceState.past)==null?void 0:t.length}getActionHistory(){const t=this._provenanceState;return t.present&&[...t.past,t.present].map(n=>n.lastAction)}getFullActionHistory(){const t=this._provenanceState;return[...t.past,t.present,...t.future].map(n=>n.lastAction)}getBookmarkableActionHistory(){var t;return(t=this.getActionHistory())==null?void 0:t.slice(1)}}function vq(e,t,n=r=>+r){const r=e.length,i=new Ll,a=new Array(r).fill(0);for(const[s,c]of e.entries())c.length&&i.push(s,n(c[0]));let o=0;for(;(o=i.pop())!==void 0;){const s=e[o];let c=a[o];const l=s[c++];if(t(l),c<s.length){const u=n(s[c]);i.push(o,u),a[o]=c}}}const wq="sampleCount";class xq extends at{constructor(n,r){super();Z(this,Cf);Z(this,_f,!0);this.view=r;const i=r.context.animator;if(this.provenance=Aq(r),!this.provenance)throw new Error("No SampleView was found!");this.provenance.storeHelper.subscribe(a=>{F(this,Cf,sv)&&(F(this,_f)&&(le(this,_f,!1),this.reset(),this.complete()),i.requestTransition(()=>{this.reset(),this._mergeAndPropagate(ab(a)),this.complete()}))}),this.contextObject=void 0}initialize(){this.contextObject=Object.create(super.getGlobalObject());const n=this.view.getEncoding().x;if(Ur(n))this.xAccessor=Oe(n.field);else throw new Error("Sample summarization requires a FieldDef. This is not a FieldDef: "+JSON.stringify(n))}handle(n){}getGlobalObject(){return this.contextObject}_getCollector(){if(this.parent instanceof Ol)return this.parent;throw new Error("MergeFacetsTransform must be a direct child of a Collector")}complete(){F(this,Cf,sv)&&(this._mergeAndPropagate(this.provenance.getPresentState()[Cs]),super.complete())}_mergeAndPropagate(n){const r=[...sb(n.rootGroup)].filter(i=>t_(xn(i)));for(const[i,a]of r.entries()){const o=xn(a);if(t_(o)){this.contextObject[wq]=o.samples.length,this.beginBatch({type:"facet",facetId:[i]});const s=o.samples,c=this._getCollector();vq(s.map(l=>c.facetBatches.get([l])??[]),l=>this._propagate(l),this.xAccessor)}}this._updateScales()}setParent(n){super.setParent(n)}_updateScales(){const n=new Set;this.view.visit(r=>{if(r instanceof mt&&r.mark.encoding.y){const i=r.getScaleResolution("y");i&&n.add(i)}});for(const r of n)r.reconfigure()}}_f=new WeakMap,Cf=new WeakSet,sv=function(){return this.view.isConfiguredVisible()};function Aq(e){for(const t of e.getLayoutAncestors())if(t instanceof xb)return t.provenance}var Eq="BATCHING_REDUCER.BATCH";function Sq(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:Eq;return{type:t,meta:{batch:!0},payload:e}}function _q(e){return function t(n,r){return r&&r.meta&&r.meta.batch?r.payload.reduce(t,n):e(n,r)}}class Cq{constructor(t){this._reducers=t??{},this.store=fV({reducer:{}}),this._listeners=new Set,this.store.subscribe(()=>{const n=this.store.getState();for(const r of this._listeners)r(n)})}get state(){return this.store.getState()}addReducer(t,n){this._reducers[t]=n,this.store.replaceReducer(_q(V1(this._reducers)))}subscribe(t){this._listeners.add(t)}unsubscribe(t){this._listeners.delete(t)}dispatch(t){Array.isArray(t)?this.store.dispatch(Sq(t)):this.store.dispatch(t)}getDispatcher(){return t=>this.dispatch(t)}}class kq extends G_{constructor(t){super(),this.bookmarks=t,this.names=t.map(n=>n.name)}async getNames(){return this.names}async get(t){return this.bookmarks.find(n=>n.name==t)}}xE.mergeFacets=xq;class u6{constructor(t,n,r={}){const i=this;this.config=n,this.storeHelper=new Cq,this.storeHelper.addReducer("viewSettings",Ts.reducer),this.provenance=new yq(this.storeHelper),this._initializationListeners=[],this.toolbarRef=q_(),this.appContainer=t,this._configureContainer(),this.localBookmarkDatabase=typeof n.specId=="string"?new Gj(n.specId):void 0,this.globalBookmarkDatabase=void 0,Vt($`<div class="genome-spy-app">
3250
3260
  <genome-spy-toolbar
3251
3261
  ${W_(i.toolbarRef)}
3252
3262
  .app=${i}