jbrowse-plugin-msaview 2.4.4 → 2.5.0

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.
Files changed (180) hide show
  1. package/dist/AddHighlightModel/GenomeMouseoverHighlight.js +2 -2
  2. package/dist/AddHighlightModel/HighlightComponents.js +0 -1
  3. package/dist/AddHighlightModel/MsaToGenomeHighlight.js +5 -3
  4. package/dist/AddHighlightModel/index.js +2 -2
  5. package/dist/AddHighlightModel/util.d.ts +1 -6
  6. package/dist/AddHighlightModel/util.js +1 -7
  7. package/dist/BgzipFastaMsaAdapter/BgzipFastaMsaAdapter.js +0 -1
  8. package/dist/BgzipFastaMsaAdapter/configSchema.js +0 -1
  9. package/dist/BgzipFastaMsaAdapter/index.js +0 -1
  10. package/dist/LaunchMsaView/components/LaunchMsaViewDialog.js +0 -1
  11. package/dist/LaunchMsaView/components/LaunchPanelContent.js +0 -1
  12. package/dist/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.js +0 -1
  13. package/dist/LaunchMsaView/components/ManualMSALoader/fetchGeneList.js +0 -1
  14. package/dist/LaunchMsaView/components/ManualMSALoader/launchView.js +0 -1
  15. package/dist/LaunchMsaView/components/NCBIBlastQuery/CachedBlastResults.js +0 -1
  16. package/dist/LaunchMsaView/components/NCBIBlastQuery/MsaAlgorithmSelect.js +0 -1
  17. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.js +0 -1
  18. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.js +0 -1
  19. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastMethodSelector.js +0 -1
  20. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastPanel.js +0 -1
  21. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastRIDPanel.js +0 -1
  22. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBISettingsDialog.js +0 -1
  23. package/dist/LaunchMsaView/components/NCBIBlastQuery/blastLaunchView.js +0 -1
  24. package/dist/LaunchMsaView/components/NCBIBlastQuery/consts.js +0 -1
  25. package/dist/LaunchMsaView/components/NCBIBlastQuery/useCachedBlastResults.js +0 -1
  26. package/dist/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.js +0 -1
  27. package/dist/LaunchMsaView/components/PreLoadedMSA/fetchMSAData.js +0 -1
  28. package/dist/LaunchMsaView/components/PreLoadedMSA/preCalculatedLaunchView.js +0 -1
  29. package/dist/LaunchMsaView/components/PreLoadedMSA/types.js +0 -1
  30. package/dist/LaunchMsaView/components/SubmitCancelActions.js +0 -1
  31. package/dist/LaunchMsaView/components/TabPanel.js +1 -2
  32. package/dist/LaunchMsaView/components/TranscriptSelector.js +0 -1
  33. package/dist/LaunchMsaView/components/calculateProteinSequence.js +0 -1
  34. package/dist/LaunchMsaView/components/fetchSeq.js +0 -1
  35. package/dist/LaunchMsaView/components/types.js +0 -1
  36. package/dist/LaunchMsaView/components/useFeatureSequence.js +0 -1
  37. package/dist/LaunchMsaView/components/useSWRFeatureSequence.js +0 -1
  38. package/dist/LaunchMsaView/components/useTranscriptSelection.js +0 -1
  39. package/dist/LaunchMsaView/components/util.js +0 -1
  40. package/dist/LaunchMsaView/index.js +0 -1
  41. package/dist/LaunchMsaView/util.js +1 -2
  42. package/dist/LaunchMsaViewExtensionPoint/index.js +0 -1
  43. package/dist/MsaViewPanel/afterCreateAutoruns.d.ts +8 -1
  44. package/dist/MsaViewPanel/afterCreateAutoruns.js +25 -21
  45. package/dist/MsaViewPanel/blosum62.js +0 -1
  46. package/dist/MsaViewPanel/components/ConnectStructureDialog.js +0 -1
  47. package/dist/MsaViewPanel/components/ErrorBoundary.d.ts +1 -1
  48. package/dist/MsaViewPanel/components/ErrorBoundary.js +0 -1
  49. package/dist/MsaViewPanel/components/LoadingBLAST.js +0 -1
  50. package/dist/MsaViewPanel/components/MsaViewPanel.js +0 -1
  51. package/dist/MsaViewPanel/components/RIDLink.js +0 -1
  52. package/dist/MsaViewPanel/doLaunchBlast.js +0 -1
  53. package/dist/MsaViewPanel/genomeToMSA.d.ts +0 -6
  54. package/dist/MsaViewPanel/genomeToMSA.js +8 -30
  55. package/dist/MsaViewPanel/genomeToMSA.test.js +0 -1
  56. package/dist/MsaViewPanel/index.js +0 -1
  57. package/dist/MsaViewPanel/model.d.ts +143 -514
  58. package/dist/MsaViewPanel/model.js +18 -61
  59. package/dist/MsaViewPanel/msaCoordToGenomeCoord.js +5 -22
  60. package/dist/MsaViewPanel/msaCoordToGenomeCoord.test.js +0 -1
  61. package/dist/MsaViewPanel/msaDataStore.js +0 -1
  62. package/dist/MsaViewPanel/pairwiseAlignment.js +2 -10
  63. package/dist/MsaViewPanel/pairwiseAlignment.test.js +0 -1
  64. package/dist/MsaViewPanel/structureConnection.d.ts +0 -6
  65. package/dist/MsaViewPanel/structureConnection.js +0 -17
  66. package/dist/MsaViewPanel/structureConnection.test.js +1 -52
  67. package/dist/MsaViewPanel/syncGenomeHoverToMsaColumn.test.d.ts +1 -0
  68. package/dist/MsaViewPanel/syncGenomeHoverToMsaColumn.test.js +92 -0
  69. package/dist/MsaViewPanel/types.js +0 -1
  70. package/dist/MsaViewPanel/util.d.ts +1 -3
  71. package/dist/MsaViewPanel/util.js +1 -3
  72. package/dist/components/ExternalLink.js +0 -1
  73. package/dist/components/ReadOnlyTextField2.js +0 -1
  74. package/dist/components/TextField2.js +0 -1
  75. package/dist/index.js +0 -1
  76. package/dist/jbrowse-plugin-msaview.umd.production.min.js +40 -40
  77. package/dist/jbrowse-plugin-msaview.umd.production.min.js.map +4 -4
  78. package/dist/utils/blastCache.js +2 -5
  79. package/dist/utils/fetch.js +0 -1
  80. package/dist/utils/msa.js +9 -9
  81. package/dist/utils/ncbiBlast.js +5 -6
  82. package/dist/utils/swrConfig.js +0 -1
  83. package/dist/utils/taxonomyNames.js +0 -1
  84. package/dist/utils/types.js +0 -1
  85. package/dist/version.d.ts +1 -1
  86. package/dist/version.js +1 -2
  87. package/package.json +11 -11
  88. package/src/AddHighlightModel/GenomeMouseoverHighlight.tsx +4 -1
  89. package/src/AddHighlightModel/MsaToGenomeHighlight.tsx +5 -8
  90. package/src/AddHighlightModel/index.tsx +4 -1
  91. package/src/AddHighlightModel/util.ts +1 -10
  92. package/src/LaunchMsaView/components/TabPanel.tsx +1 -1
  93. package/src/LaunchMsaView/util.ts +1 -3
  94. package/src/MsaViewPanel/afterCreateAutoruns.ts +24 -21
  95. package/src/MsaViewPanel/genomeToMSA.ts +10 -29
  96. package/src/MsaViewPanel/model.ts +21 -66
  97. package/src/MsaViewPanel/msaCoordToGenomeCoord.ts +5 -21
  98. package/src/MsaViewPanel/pairwiseAlignment.ts +2 -7
  99. package/src/MsaViewPanel/structureConnection.test.ts +1 -61
  100. package/src/MsaViewPanel/structureConnection.ts +0 -22
  101. package/src/MsaViewPanel/syncGenomeHoverToMsaColumn.test.ts +112 -0
  102. package/src/MsaViewPanel/util.ts +3 -7
  103. package/src/utils/blastCache.ts +2 -4
  104. package/src/utils/msa.ts +10 -8
  105. package/src/utils/ncbiBlast.ts +5 -6
  106. package/src/version.ts +1 -1
  107. package/dist/AddHighlightModel/GenomeMouseoverHighlight.js.map +0 -1
  108. package/dist/AddHighlightModel/HighlightComponents.js.map +0 -1
  109. package/dist/AddHighlightModel/MsaToGenomeHighlight.js.map +0 -1
  110. package/dist/AddHighlightModel/index.js.map +0 -1
  111. package/dist/AddHighlightModel/util.js.map +0 -1
  112. package/dist/BgzipFastaMsaAdapter/BgzipFastaMsaAdapter.js.map +0 -1
  113. package/dist/BgzipFastaMsaAdapter/configSchema.js.map +0 -1
  114. package/dist/BgzipFastaMsaAdapter/index.js.map +0 -1
  115. package/dist/LaunchMsaView/components/LaunchMsaViewDialog.js.map +0 -1
  116. package/dist/LaunchMsaView/components/LaunchPanelContent.js.map +0 -1
  117. package/dist/LaunchMsaView/components/ManualMSALoader/ManualMSALoader.js.map +0 -1
  118. package/dist/LaunchMsaView/components/ManualMSALoader/fetchGeneList.js.map +0 -1
  119. package/dist/LaunchMsaView/components/ManualMSALoader/launchView.js.map +0 -1
  120. package/dist/LaunchMsaView/components/NCBIBlastQuery/CachedBlastResults.js.map +0 -1
  121. package/dist/LaunchMsaView/components/NCBIBlastQuery/MsaAlgorithmSelect.js.map +0 -1
  122. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastAutomaticPanel.js.map +0 -1
  123. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastManualPanel.js.map +0 -1
  124. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastMethodSelector.js.map +0 -1
  125. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastPanel.js.map +0 -1
  126. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBIBlastRIDPanel.js.map +0 -1
  127. package/dist/LaunchMsaView/components/NCBIBlastQuery/NCBISettingsDialog.js.map +0 -1
  128. package/dist/LaunchMsaView/components/NCBIBlastQuery/blastLaunchView.js.map +0 -1
  129. package/dist/LaunchMsaView/components/NCBIBlastQuery/consts.js.map +0 -1
  130. package/dist/LaunchMsaView/components/NCBIBlastQuery/useCachedBlastResults.js.map +0 -1
  131. package/dist/LaunchMsaView/components/PreLoadedMSA/PreLoadedMSADataPanel.js.map +0 -1
  132. package/dist/LaunchMsaView/components/PreLoadedMSA/fetchMSAData.js.map +0 -1
  133. package/dist/LaunchMsaView/components/PreLoadedMSA/preCalculatedLaunchView.js.map +0 -1
  134. package/dist/LaunchMsaView/components/PreLoadedMSA/types.js.map +0 -1
  135. package/dist/LaunchMsaView/components/SubmitCancelActions.js.map +0 -1
  136. package/dist/LaunchMsaView/components/TabPanel.js.map +0 -1
  137. package/dist/LaunchMsaView/components/TranscriptSelector.js.map +0 -1
  138. package/dist/LaunchMsaView/components/calculateProteinSequence.js.map +0 -1
  139. package/dist/LaunchMsaView/components/fetchSeq.js.map +0 -1
  140. package/dist/LaunchMsaView/components/types.js.map +0 -1
  141. package/dist/LaunchMsaView/components/useFeatureSequence.js.map +0 -1
  142. package/dist/LaunchMsaView/components/useSWRFeatureSequence.js.map +0 -1
  143. package/dist/LaunchMsaView/components/useTranscriptSelection.js.map +0 -1
  144. package/dist/LaunchMsaView/components/util.js.map +0 -1
  145. package/dist/LaunchMsaView/index.js.map +0 -1
  146. package/dist/LaunchMsaView/util.js.map +0 -1
  147. package/dist/LaunchMsaViewExtensionPoint/index.js.map +0 -1
  148. package/dist/MsaViewPanel/afterCreateAutoruns.js.map +0 -1
  149. package/dist/MsaViewPanel/blosum62.js.map +0 -1
  150. package/dist/MsaViewPanel/components/ConnectStructureDialog.js.map +0 -1
  151. package/dist/MsaViewPanel/components/ErrorBoundary.js.map +0 -1
  152. package/dist/MsaViewPanel/components/LoadingBLAST.js.map +0 -1
  153. package/dist/MsaViewPanel/components/MsaViewPanel.js.map +0 -1
  154. package/dist/MsaViewPanel/components/RIDLink.js.map +0 -1
  155. package/dist/MsaViewPanel/doLaunchBlast.js.map +0 -1
  156. package/dist/MsaViewPanel/genomeToMSA.js.map +0 -1
  157. package/dist/MsaViewPanel/genomeToMSA.test.js.map +0 -1
  158. package/dist/MsaViewPanel/index.js.map +0 -1
  159. package/dist/MsaViewPanel/model.js.map +0 -1
  160. package/dist/MsaViewPanel/msaCoordToGenomeCoord.js.map +0 -1
  161. package/dist/MsaViewPanel/msaCoordToGenomeCoord.test.js.map +0 -1
  162. package/dist/MsaViewPanel/msaDataStore.js.map +0 -1
  163. package/dist/MsaViewPanel/pairwiseAlignment.js.map +0 -1
  164. package/dist/MsaViewPanel/pairwiseAlignment.test.js.map +0 -1
  165. package/dist/MsaViewPanel/structureConnection.js.map +0 -1
  166. package/dist/MsaViewPanel/structureConnection.test.js.map +0 -1
  167. package/dist/MsaViewPanel/types.js.map +0 -1
  168. package/dist/MsaViewPanel/util.js.map +0 -1
  169. package/dist/components/ExternalLink.js.map +0 -1
  170. package/dist/components/ReadOnlyTextField2.js.map +0 -1
  171. package/dist/components/TextField2.js.map +0 -1
  172. package/dist/index.js.map +0 -1
  173. package/dist/utils/blastCache.js.map +0 -1
  174. package/dist/utils/fetch.js.map +0 -1
  175. package/dist/utils/msa.js.map +0 -1
  176. package/dist/utils/ncbiBlast.js.map +0 -1
  177. package/dist/utils/swrConfig.js.map +0 -1
  178. package/dist/utils/taxonomyNames.js.map +0 -1
  179. package/dist/utils/types.js.map +0 -1
  180. package/dist/version.js.map +0 -1
@@ -1,13 +1,11 @@
1
- "use strict";var JBrowsePluginMsaView=(()=>{var AQ=Object.create;var Rs=Object.defineProperty;var uQ=Object.getOwnPropertyDescriptor;var fQ=Object.getOwnPropertyNames;var mQ=Object.getPrototypeOf,dQ=Object.prototype.hasOwnProperty;var g=(e,t)=>()=>(e&&(t=e(e=0)),t);var G=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),We=(e,t)=>{for(var r in t)Rs(e,r,{get:t[r],enumerable:!0})},dd=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of fQ(t))!dQ.call(e,o)&&o!==r&&Rs(e,o,{get:()=>t[o],enumerable:!(n=uQ(t,o))||n.enumerable});return e};var f=(e,t,r)=>(r=e!=null?AQ(mQ(e)):{},dd(t||!e||!e.__esModule?Rs(r,"default",{value:e,enumerable:!0}):r,e)),gQ=e=>dd(Rs({},"__esModule",{value:!0}),e);var pd=G((_N,gd)=>{gd.exports=JBrowseExports["@jbrowse/core/Plugin"]});var po=G((kN,hd)=>{hd.exports=JBrowseExports["@jbrowse/core/configuration"]});var ge=G((DN,Cd)=>{Cd.exports=JBrowseExports["@jbrowse/core/util"]});var kt=G((NN,Ed)=>{Ed.exports=JBrowseExports["mobx-state-tree"]});var xd=G((LN,Id)=>{Id.exports=JBrowseExports["@mui/material/utils"]});var _,W=g(()=>{"use client";_=f(xd(),1)});var F=G((RN,yd)=>{yd.exports=JBrowseExports["react/jsx-runtime"]});var b=G((GN,Bd)=>{Bd.exports=JBrowseExports.react});var O=G((UN,Sd)=>{Sd.exports=JBrowseExports["mobx-react"]});var Be=G((HN,Qd)=>{Qd.exports=JBrowseExports["tss-react/mui"]});var Pl=G((tL,Pd)=>{Pd.exports=JBrowseExports["@jbrowse/core/pluggableElementTypes"]});var Ud=G((nL,Gd)=>{Gd.exports=JBrowseExports["@jbrowse/core/data_adapters/BaseAdapter"]});function vi(e,t){if(typeof t!="function"&&t!==null)throw new TypeError("Class extends value "+String(t)+" is not a constructor or null");Gl(e,t);function r(){this.constructor=e}e.prototype=t===null?Object.create(t):(r.prototype=t.prototype,new r)}function Ul(e){var t=typeof Symbol=="function"&&Symbol.iterator,r=t&&e[t],n=0;if(r)return r.call(e);if(e&&typeof e.length=="number")return{next:function(){return e&&n>=e.length&&(e=void 0),{value:e&&e[n++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function ho(e,t){var r=typeof Symbol=="function"&&e[Symbol.iterator];if(!r)return e;var n=r.call(e),o,i=[],s;try{for(;(t===void 0||t-- >0)&&!(o=n.next()).done;)i.push(o.value)}catch(a){s={error:a}}finally{try{o&&!o.done&&(r=n.return)&&r.call(n)}finally{if(s)throw s.error}}return i}function Co(e,t,r){if(r||arguments.length===2)for(var n=0,o=t.length,i;n<o;n++)(i||!(n in t))&&(i||(i=Array.prototype.slice.call(t,0,n)),i[n]=t[n]);return e.concat(i||Array.prototype.slice.call(t))}var Gl,Ti=g(()=>{Gl=function(e,t){return Gl=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(r,n){r.__proto__=n}||function(r,n){for(var o in n)Object.prototype.hasOwnProperty.call(n,o)&&(r[o]=n[o])},Gl(e,t)}});function wr(e){return typeof e=="function"}var Us=g(()=>{});function Hs(e){var t=function(n){Error.call(n),n.stack=new Error().stack},r=e(t);return r.prototype=Object.create(Error.prototype),r.prototype.constructor=r,r}var Hl=g(()=>{});var js,Hd=g(()=>{Hl();js=Hs(function(e){return function(r){e(this),this.message=r?r.length+` errors occurred during unsubscription:
2
- `+r.map(function(n,o){return o+1+") "+n.toString()}).join(`
3
- `):"",this.name="UnsubscriptionError",this.errors=r}})});function jl(e,t){if(e){var r=e.indexOf(t);0<=r&&e.splice(r,1)}}var jd=g(()=>{});function Jd(e){return e instanceof qs||e&&"closed"in e&&wr(e.remove)&&wr(e.add)&&wr(e.unsubscribe)}function qd(e){wr(e)?e():e.unsubscribe()}var qs,dL,Vd=g(()=>{Ti();Us();Hd();jd();qs=(function(){function e(t){this.initialTeardown=t,this.closed=!1,this._parentage=null,this._finalizers=null}return e.prototype.unsubscribe=function(){var t,r,n,o,i;if(!this.closed){this.closed=!0;var s=this._parentage;if(s)if(this._parentage=null,Array.isArray(s))try{for(var a=Ul(s),c=a.next();!c.done;c=a.next()){var l=c.value;l.remove(this)}}catch(C){t={error:C}}finally{try{c&&!c.done&&(r=a.return)&&r.call(a)}finally{if(t)throw t.error}}else s.remove(this);var A=this.initialTeardown;if(wr(A))try{A()}catch(C){i=C instanceof js?C.errors:[C]}var u=this._finalizers;if(u){this._finalizers=null;try{for(var m=Ul(u),d=m.next();!d.done;d=m.next()){var p=d.value;try{qd(p)}catch(C){i=i??[],C instanceof js?i=Co(Co([],ho(i)),ho(C.errors)):i.push(C)}}}catch(C){n={error:C}}finally{try{d&&!d.done&&(o=m.return)&&o.call(m)}finally{if(n)throw n.error}}}if(i)throw new js(i)}},e.prototype.add=function(t){var r;if(t&&t!==this)if(this.closed)qd(t);else{if(t instanceof e){if(t.closed||t._hasParent(this))return;t._addParent(this)}(this._finalizers=(r=this._finalizers)!==null&&r!==void 0?r:[]).push(t)}},e.prototype._hasParent=function(t){var r=this._parentage;return r===t||Array.isArray(r)&&r.includes(t)},e.prototype._addParent=function(t){var r=this._parentage;this._parentage=Array.isArray(r)?(r.push(t),r):r?[r,t]:t},e.prototype._removeParent=function(t){var r=this._parentage;r===t?this._parentage=null:Array.isArray(r)&&jl(r,t)},e.prototype.remove=function(t){var r=this._finalizers;r&&jl(r,t),t instanceof e&&t._removeParent(this)},e.EMPTY=(function(){var t=new e;return t.closed=!0,t})(),e})(),dL=qs.EMPTY});var an,Js=g(()=>{an={onUnhandledError:null,onStoppedNotification:null,Promise:void 0,useDeprecatedSynchronousErrorHandling:!1,useDeprecatedNextContext:!1}});var Eo,ql=g(()=>{Ti();Eo={setTimeout:function(e,t){for(var r=[],n=2;n<arguments.length;n++)r[n-2]=arguments[n];var o=Eo.delegate;return o?.setTimeout?o.setTimeout.apply(o,Co([e,t],ho(r))):setTimeout.apply(void 0,Co([e,t],ho(r)))},clearTimeout:function(e){var t=Eo.delegate;return(t?.clearTimeout||clearTimeout)(e)},delegate:void 0}});function Yd(e){Eo.setTimeout(function(){var t=an.onUnhandledError;if(t)t(e);else throw e})}var Wd=g(()=>{Js();ql()});function Jl(){}var zd=g(()=>{});function Kd(e){return Vl("E",void 0,e)}function Xd(e){return Vl("N",e,void 0)}function Vl(e,t,r){return{kind:e,value:t,error:r}}var $d,Zd=g(()=>{$d=(function(){return Vl("C",void 0,void 0)})()});function eg(e){an.useDeprecatedSynchronousErrorHandling&&Yl&&(Yl.errorThrown=!0,Yl.error=e)}var Yl,tg=g(()=>{Js();Yl=null});function Wl(e,t){return xQ.call(e,t)}function Vs(e){an.useDeprecatedSynchronousErrorHandling?eg(e):Yd(e)}function wQ(e){throw e}function zl(e,t){var r=an.onStoppedNotification;r&&Eo.setTimeout(function(){return r(e,t)})}var $l,xQ,yQ,Kl,bQ,Xl=g(()=>{Ti();Us();Vd();Js();Wd();zd();Zd();ql();tg();$l=(function(e){vi(t,e);function t(r){var n=e.call(this)||this;return n.isStopped=!1,r?(n.destination=r,Jd(r)&&r.add(n)):n.destination=bQ,n}return t.create=function(r,n,o){return new Kl(r,n,o)},t.prototype.next=function(r){this.isStopped?zl(Xd(r),this):this._next(r)},t.prototype.error=function(r){this.isStopped?zl(Kd(r),this):(this.isStopped=!0,this._error(r))},t.prototype.complete=function(){this.isStopped?zl($d,this):(this.isStopped=!0,this._complete())},t.prototype.unsubscribe=function(){this.closed||(this.isStopped=!0,e.prototype.unsubscribe.call(this),this.destination=null)},t.prototype._next=function(r){this.destination.next(r)},t.prototype._error=function(r){try{this.destination.error(r)}finally{this.unsubscribe()}},t.prototype._complete=function(){try{this.destination.complete()}finally{this.unsubscribe()}},t})(qs),xQ=Function.prototype.bind;yQ=(function(){function e(t){this.partialObserver=t}return e.prototype.next=function(t){var r=this.partialObserver;if(r.next)try{r.next(t)}catch(n){Vs(n)}},e.prototype.error=function(t){var r=this.partialObserver;if(r.error)try{r.error(t)}catch(n){Vs(n)}else Vs(t)},e.prototype.complete=function(){var t=this.partialObserver;if(t.complete)try{t.complete()}catch(r){Vs(r)}},e})(),Kl=(function(e){vi(t,e);function t(r,n,o){var i=e.call(this)||this,s;if(wr(r)||!r)s={next:r??void 0,error:n??void 0,complete:o??void 0};else{var a;i&&an.useDeprecatedNextContext?(a=Object.create(r),a.unsubscribe=function(){return i.unsubscribe()},s={next:r.next&&Wl(r.next,a),error:r.error&&Wl(r.error,a),complete:r.complete&&Wl(r.complete,a)}):s=r}return i.destination=new yQ(s),i}return t})($l);bQ={closed:!0,next:Jl,error:wQ,complete:Jl}});function BQ(e){return wr(e?.lift)}function Ys(e){return function(t){if(BQ(t))return t.lift(function(r){try{return e(r,this)}catch(n){this.error(n)}});throw new TypeError("Unable to lift unknown Observable type")}}var Zl=g(()=>{Us()});function rg(e,t,r,n,o){return new SQ(e,t,r,n,o)}var SQ,ng=g(()=>{Ti();Xl();SQ=(function(e){vi(t,e);function t(r,n,o,i,s,a){var c=e.call(this,r)||this;return c.onFinalize=s,c.shouldUnsubscribe=a,c._next=n?function(l){try{n(l)}catch(A){r.error(A)}}:e.prototype._next,c._error=i?function(l){try{i(l)}catch(A){r.error(A)}finally{this.unsubscribe()}}:e.prototype._error,c._complete=o?function(){try{o()}catch(l){r.error(l)}finally{this.unsubscribe()}}:e.prototype._complete,c}return t.prototype.unsubscribe=function(){var r;if(!this.shouldUnsubscribe||this.shouldUnsubscribe()){var n=this.closed;e.prototype.unsubscribe.call(this),!n&&((r=this.onFinalize)===null||r===void 0||r.call(this))}},t})($l)});var og,ig=g(()=>{Hl();og=Hs(function(e){return function(){e(this),this.name="EmptyError",this.message="no elements in sequence"}})});function eA(e,t){var r=typeof t=="object";return new Promise(function(n,o){var i=new Kl({next:function(s){n(s),i.unsubscribe()},error:o,complete:function(){r?n(t.defaultValue):o(new og)}});e.subscribe(i)})}var sg=g(()=>{ig();Xl()});var ag=g(()=>{});function cg(e,t,r,n,o){return function(i,s){var a=r,c=t,l=0;i.subscribe(rg(s,function(A){var u=l++;c=a?e(c,A,u):(a=!0,A),n&&s.next(c)},o&&(function(){a&&s.next(c),s.complete()})))}}var lg=g(()=>{ng()});function Ag(e,t){return Ys(cg(e,t,arguments.length>=2,!1,!0))}var ug=g(()=>{lg();Zl()});function tA(){return Ys(function(e,t){Ag(QQ,[])(e).subscribe(t)})}var QQ,fg=g(()=>{ug();Zl();QQ=function(e,t){return e.push(t),e}});var mg=g(()=>{sg();ag();fg()});var pg={};We(pg,{default:()=>Ws});var dg,gg,Ws,hg=g(()=>{"use strict";dg=f(po()),gg=f(Ud());mg();Ws=class extends gg.BaseAdapter{async configurePre(){let t=this.getSubAdapter;if(t)return(await t({...(0,dg.readConfObject)(this.config),type:"BgzipFastaAdapter"})).dataAdapter;throw new Error("no get subadapter")}configure(){return this.configureP??=this.configurePre().catch(t=>{throw this.configureP=void 0,t}),this.configureP}async getMSARefs(){return this.refNamesP??=this.configure().then(t=>t.getRefNames()).catch(t=>{throw this.refNamesP=void 0,t}),this.refNamesP}getMsaRegex(){return new RegExp(this.getConf("msaRegex"))}refNameToMsaId(t){return t.split(this.getMsaRegex())[0]}async getMSAList(){let t=await this.getMSARefs();return[...new Set(t.map(n=>this.refNameToMsaId(n)))]}async getMSA(t){let r=await this.configure(),o=(await r.getRefNames()).filter(i=>this.refNameToMsaId(i)===t);return eA(r.getFeaturesInMultipleRegions(o.map(i=>({refName:i,start:0,end:1e9,assemblyName:""}))).pipe(tA()))}}});var ye=G((lF,xg)=>{xg.exports=JBrowseExports["@jbrowse/core/ui"]});var D=G((AF,yg)=>{yg.exports=JBrowseExports["@mui/material"]});var Fg=G(Lg=>{"use strict";var xo=b();function RQ(e,t){return e===t&&(e!==0||1/e===1/t)||e!==e&&t!==t}var PQ=typeof Object.is=="function"?Object.is:RQ,OQ=xo.useState,GQ=xo.useEffect,UQ=xo.useLayoutEffect,HQ=xo.useDebugValue;function jQ(e,t){var r=t(),n=OQ({inst:{value:r,getSnapshot:t}}),o=n[0].inst,i=n[1];return UQ(function(){o.value=r,o.getSnapshot=t,sA(o)&&i({inst:o})},[e,r,t]),GQ(function(){return sA(o)&&i({inst:o}),e(function(){sA(o)&&i({inst:o})})},[e]),HQ(r),r}function sA(e){var t=e.getSnapshot;e=e.value;try{var r=t();return!PQ(e,r)}catch{return!0}}function qQ(e,t){return t()}var JQ=typeof window>"u"||typeof window.document>"u"||typeof window.document.createElement>"u"?qQ:jQ;Lg.useSyncExternalStore=xo.useSyncExternalStore!==void 0?xo.useSyncExternalStore:JQ});var Pg=G((wF,Rg)=>{"use strict";Rg.exports=Fg()});var Ap,ga,wA=g(()=>{"use client";W();Ap=f(F(),1),ga=(0,_.createSvgIcon)((0,Ap.jsx)("path",{d:"M19.14 12.94c.04-.3.06-.61.06-.94 0-.32-.02-.64-.07-.94l2.03-1.58c.18-.14.23-.41.12-.61l-1.92-3.32c-.12-.22-.37-.29-.59-.22l-2.39.96c-.5-.38-1.03-.7-1.62-.94l-.36-2.54c-.04-.24-.24-.41-.48-.41h-3.84c-.24 0-.43.17-.47.41l-.36 2.54c-.59.24-1.13.57-1.62.94l-2.39-.96c-.22-.08-.47 0-.59.22L2.74 8.87c-.12.21-.08.47.12.61l2.03 1.58c-.05.3-.09.63-.09.94s.02.64.07.94l-2.03 1.58c-.18.14-.23.41-.12.61l1.92 3.32c.12.22.37.29.59.22l2.39-.96c.5.38 1.03.7 1.62.94l.36 2.54c.05.24.24.41.48.41h3.84c.24 0 .44-.17.47-.41l.36-2.54c.59-.24 1.13-.56 1.62-.94l2.39.96c.22.08.47 0 .59-.22l1.92-3.32c.12-.22.07-.47-.12-.61zM12 15.6c-1.98 0-3.6-1.62-3.6-3.6s1.62-3.6 3.6-3.6 3.6 1.62 3.6 3.6-1.62 3.6-3.6 3.6"}),"Settings")});var up,pa,bA=g(()=>{"use client";W();up=f(F(),1),pa=(0,_.createSvgIcon)((0,up.jsx)("path",{d:"M16.59 8.59 12 13.17 7.41 8.59 6 10l6 6 6-6z"}),"ExpandMore")});function dM(){return gp||(gp=[IDBDatabase,IDBObjectStore,IDBIndex,IDBCursor,IDBTransaction])}function gM(){return pp||(pp=[IDBCursor.prototype.advance,IDBCursor.prototype.continue,IDBCursor.prototype.continuePrimaryKey])}function pM(e){let t=new Promise((r,n)=>{let o=()=>{e.removeEventListener("success",i),e.removeEventListener("error",s)},i=()=>{r(Ln(e.result)),o()},s=()=>{n(e.error),o()};e.addEventListener("success",i),e.addEventListener("error",s)});return Ca.set(t,e),t}function hM(e){if(vA.has(e))return;let t=new Promise((r,n)=>{let o=()=>{e.removeEventListener("complete",i),e.removeEventListener("error",s),e.removeEventListener("abort",s)},i=()=>{r(),o()},s=()=>{n(e.error||new DOMException("AbortError","AbortError")),o()};e.addEventListener("complete",i),e.addEventListener("error",s),e.addEventListener("abort",s)});vA.set(e,t)}function Ip(e){TA=e(TA)}function CM(e){return gM().includes(e)?function(...t){return e.apply(_A(this),t),Ln(this.request)}:function(...t){return Ln(e.apply(_A(this),t))}}function EM(e){return typeof e=="function"?CM(e):(e instanceof IDBTransaction&&hM(e),MA(e,dM())?new Proxy(e,TA):e)}function Ln(e){if(e instanceof IDBRequest)return pM(e);if(SA.has(e))return SA.get(e);let t=EM(e);return t!==e&&(SA.set(e,t),Ca.set(t,e)),t}function Fn(e,t,{blocked:r,upgrade:n,blocking:o,terminated:i}={}){let s=indexedDB.open(e,t),a=Ln(s);return n&&s.addEventListener("upgradeneeded",c=>{n(Ln(s.result),c.oldVersion,c.newVersion,Ln(s.transaction),c)}),r&&s.addEventListener("blocked",c=>r(c.oldVersion,c.newVersion,c)),a.then(c=>{i&&c.addEventListener("close",()=>i()),o&&c.addEventListener("versionchange",l=>o(l.oldVersion,l.newVersion,l))}).catch(()=>{}),a}function hp(e,t){if(!(e instanceof IDBDatabase&&!(t in e)&&typeof t=="string"))return;if(QA.get(t))return QA.get(t);let r=t.replace(/FromIndex$/,""),n=t!==r,o=xM.includes(r);if(!(r in(n?IDBIndex:IDBObjectStore).prototype)||!(o||IM.includes(r)))return;let i=async function(s,...a){let c=this.transaction(s,o?"readwrite":"readonly"),l=c.store;return n&&(l=l.index(a.shift())),(await Promise.all([l[r](...a),o&&c.done]))[0]};return QA.set(t,i),i}async function*bM(...e){let t=this;if(t instanceof IDBCursor||(t=await t.openCursor(...e)),!t)return;t=t;let r=new Proxy(t,wM);for(xp.set(r,t),Ca.set(r,_A(t));t;)yield r,t=await(kA.get(r)||t.continue()),kA.delete(r)}function Ep(e,t){return t===Symbol.asyncIterator&&MA(e,[IDBIndex,IDBObjectStore,IDBCursor])||t==="iterate"&&MA(e,[IDBIndex,IDBObjectStore])}var MA,gp,pp,vA,SA,Ca,TA,_A,IM,xM,QA,yM,Cp,kA,xp,wM,Li=g(()=>{MA=(e,t)=>t.some(r=>e instanceof r);vA=new WeakMap,SA=new WeakMap,Ca=new WeakMap;TA={get(e,t,r){if(e instanceof IDBTransaction){if(t==="done")return vA.get(e);if(t==="store")return r.objectStoreNames[1]?void 0:r.objectStore(r.objectStoreNames[0])}return Ln(e[t])},set(e,t,r){return e[t]=r,!0},has(e,t){return e instanceof IDBTransaction&&(t==="done"||t==="store")?!0:t in e}};_A=e=>Ca.get(e);IM=["get","getKey","getAll","getAllKeys","count"],xM=["put","add","delete","clear"],QA=new Map;Ip(e=>({...e,get:(t,r,n)=>hp(t,r)||e.get(t,r,n),has:(t,r)=>!!hp(t,r)||e.has(t,r)}));yM=["continue","continuePrimaryKey","advance"],Cp={},kA=new WeakMap,xp=new WeakMap,wM={get(e,t){if(!yM.includes(t))return e[t];let r=Cp[t];return r||(r=Cp[t]=function(...n){kA.set(this,xp.get(this)[t](...n))}),r}};Ip(e=>({...e,get(t,r,n){return Ep(t,r)?bM:e.get(t,r,n)},has(t,r){return Ep(t,r)||e.has(t,r)}}))});var Pp,ya,NA=g(()=>{"use client";W();Pp=f(F(),1),ya=(0,_.createSvgIcon)((0,Pp.jsx)("path",{d:"M19 19H5V5h7V3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2v-7h-2zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3z"}),"OpenInNew")});function Rn(e){let{children:t,...r}=e;return LA.default.createElement(Op.Link,{...r,target:"_blank",rel:"noreferrer"},t," ",LA.default.createElement(ya,{fontSize:"small"}))}var LA,Op,wa=g(()=>{"use strict";LA=f(b());NA();Op=f(D())});var Kp=g(()=>{});var Xp=g(()=>{Kp()});function OM(e){try{let s=H.__wbindgen_add_to_stack_pointer(-16),a=HA(e,H.__wbindgen_export2),c=Ma;H.decompress_all(s,a,c);var t=$e().getInt32(s+0,!0),r=$e().getInt32(s+4,!0),n=$e().getInt32(s+8,!0),o=$e().getInt32(s+12,!0);if(o)throw jA(n);var i=GA(t,r).slice();return H.__wbindgen_export(t,r*1,1),i}finally{H.__wbindgen_add_to_stack_pointer(16)}}function GM(e){try{let o=H.__wbindgen_add_to_stack_pointer(-16),i=HA(e,H.__wbindgen_export2),s=Ma;H.decompress_block(o,i,s);var t=$e().getInt32(o+0,!0),r=$e().getInt32(o+4,!0),n=$e().getInt32(o+8,!0);if(n)throw jA(r);return vo.__wrap(t)}finally{H.__wbindgen_add_to_stack_pointer(16)}}function UM(e,t,r,n,o){try{let c=H.__wbindgen_add_to_stack_pointer(-16),l=HA(e,H.__wbindgen_export2),A=Ma;H.decompress_chunk_slice(c,l,A,t,r,n,o);var i=$e().getInt32(c+0,!0),s=$e().getInt32(c+4,!0),a=$e().getInt32(c+8,!0);if(a)throw jA(s);return Mo.__wrap(i)}finally{H.__wbindgen_add_to_stack_pointer(16)}}function HM(e,t){let r=Error(nh(e,t));return qM(r)}function jM(e,t){throw new Error(nh(e,t))}function qM(e){Ri===Ur.length&&Ur.push(Ur.length+1);let t=Ri;return Ri=Ur[t],Ur[t]=e,t}function JM(e){e<1028||(Ur[e]=Ri,Ri=e)}function th(e,t){return e=e>>>0,VM().subarray(e/8,e/8+t)}function GA(e,t){return e=e>>>0,UA().subarray(e/1,e/1+t)}function $e(){return(Qo===null||Qo.buffer.detached===!0||Qo.buffer.detached===void 0&&Qo.buffer!==H.memory.buffer)&&(Qo=new DataView(H.memory.buffer)),Qo}function VM(){return(Ba===null||Ba.byteLength===0)&&(Ba=new Float64Array(H.memory.buffer)),Ba}function nh(e,t){return zM(e>>>0,t)}function UA(){return(Sa===null||Sa.byteLength===0)&&(Sa=new Uint8Array(H.memory.buffer)),Sa}function YM(e){return Ur[e]}function HA(e,t){let r=t(e.length*1,1)>>>0;return UA().set(e,r/1),Ma=e.length,r}function jA(e){let t=YM(e);return JM(e),t}function zM(e,t){return OA+=t,OA>=WM&&(Qa=new TextDecoder("utf-8",{ignoreBOM:!0,fatal:!0}),Qa.decode(),OA=t),Qa.decode(UA().subarray(e,e+t))}function $M(e){H=e}var Pn,rh,Mo,vo,Zp,eh,Qo,Ba,Sa,Ur,Ri,Qa,WM,OA,Ma,H,oh=g(()=>{Pn={};Pn.d=(e,t)=>{for(var r in t)Pn.o(t,r)&&!Pn.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})};Pn.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t);Pn.r=e=>{typeof Symbol<"u"&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};rh={};Pn.r(rh);Pn.d(rh,{ChunkSliceResult:()=>Mo,DecompressResult:()=>vo,__wbg_Error_bce6d499ff0a4aff:()=>HM,__wbg___wbindgen_throw_9c31b086c2b26051:()=>jM,__wbg_set_wasm:()=>$M,decompress_all:()=>OM,decompress_block:()=>GM,decompress_chunk_slice:()=>UM});Mo=class e{static __wrap(t){let r=Object.create(e.prototype);return r.__wbg_ptr=t,Zp.register(r,r.__wbg_ptr,r),r}__destroy_into_raw(){let t=this.__wbg_ptr;return this.__wbg_ptr=0,Zp.unregister(this),t}free(){let t=this.__destroy_into_raw();H.__wbg_chunksliceresult_free(t,0)}take_buffer(){try{let o=H.__wbindgen_add_to_stack_pointer(-16);H.chunksliceresult_take_buffer(o,this.__wbg_ptr);var t=$e().getInt32(o+0,!0),r=$e().getInt32(o+4,!0),n=GA(t,r).slice();return H.__wbindgen_export(t,r*1,1),n}finally{H.__wbindgen_add_to_stack_pointer(16)}}take_cpositions(){try{let o=H.__wbindgen_add_to_stack_pointer(-16);H.chunksliceresult_take_cpositions(o,this.__wbg_ptr);var t=$e().getInt32(o+0,!0),r=$e().getInt32(o+4,!0),n=th(t,r).slice();return H.__wbindgen_export(t,r*8,8),n}finally{H.__wbindgen_add_to_stack_pointer(16)}}take_dpositions(){try{let o=H.__wbindgen_add_to_stack_pointer(-16);H.chunksliceresult_take_dpositions(o,this.__wbg_ptr);var t=$e().getInt32(o+0,!0),r=$e().getInt32(o+4,!0),n=th(t,r).slice();return H.__wbindgen_export(t,r*8,8),n}finally{H.__wbindgen_add_to_stack_pointer(16)}}};Symbol.dispose&&(Mo.prototype[Symbol.dispose]=Mo.prototype.free);vo=class e{static __wrap(t){let r=Object.create(e.prototype);return r.__wbg_ptr=t,eh.register(r,r.__wbg_ptr,r),r}__destroy_into_raw(){let t=this.__wbg_ptr;return this.__wbg_ptr=0,eh.unregister(this),t}free(){let t=this.__destroy_into_raw();H.__wbg_decompressresult_free(t,0)}get bytes_read(){return H.decompressresult_bytes_read(this.__wbg_ptr)>>>0}take_data(){try{let o=H.__wbindgen_add_to_stack_pointer(-16);H.decompressresult_take_data(o,this.__wbg_ptr);var t=$e().getInt32(o+0,!0),r=$e().getInt32(o+4,!0),n=GA(t,r).slice();return H.__wbindgen_export(t,r*1,1),n}finally{H.__wbindgen_add_to_stack_pointer(16)}}};Symbol.dispose&&(vo.prototype[Symbol.dispose]=vo.prototype.free);Zp=typeof FinalizationRegistry>"u"?{register:()=>{},unregister:()=>{}}:new FinalizationRegistry(e=>H.__wbg_chunksliceresult_free(e,1)),eh=typeof FinalizationRegistry>"u"?{register:()=>{},unregister:()=>{}}:new FinalizationRegistry(e=>H.__wbg_decompressresult_free(e,1));Qo=null;Ba=null;Sa=null;Ur=new Array(1024).fill(void 0);Ur.push(void 0,null,!0,!1);Ri=Ur.length;Qa=new TextDecoder("utf-8",{ignoreBOM:!0,fatal:!0});Qa.decode();WM=2146435072,OA=0;Ma=0});var qA=g(()=>{oh()});var ih=g(()=>{});var ah=g(()=>{Xp();qA();ih()});var ch=g(()=>{ah();qA()});function JA(){let e=(0,To.useRef)(null),[t,r]=(0,To.useState)({width:void 0,height:void 0});return(0,To.useEffect)(()=>{if(!e.current)return;let n=typeof window<"u"&&"ResizeObserver"in window?window.ResizeObserver:void 0;if(!n)return;let o=new n(i=>{r({width:i[0].contentRect.width,height:i[0].contentRect.height})});return o.observe(e.current),()=>{o.disconnect()}},[]),[e,t]}var To,lh=g(()=>{To=f(b(),1)});var uh=G((O3,Ah)=>{Ah.exports=JBrowseExports["react-dom"]});var mh=G((G3,fh)=>{fh.exports=JBrowseExports["react-dom/client"]});function dh(e){let t="",r=!1;for(let n=0,o=e.length;n<o;n++){let i=e[n];i==="<"?r=!0:i===">"?r=!1:r||(t+=i)}return t}var VA=g(()=>{});var gh=g(()=>{});var ph=g(()=>{});var hh=g(()=>{});function va(e){return typeof e=="object"&&e!==null&&"uri"in e&&!!e.uri}var KM,YA=g(()=>{KM=f(kt(),1);hh()});var Hr=G((V3,Ch)=>{Ch.exports=JBrowseExports.mobx});var XM,Eh=g(()=>{XM=f(Hr(),1)});var Ih=g(()=>{});var xh=g(()=>{});var _o,Ta,WA,zA,ZM,Pi,_a,yh=g(()=>{_o={METHOD:"method",PROPERTY:"property"},Ta=class{constructor(t,r){this.inst=t,this.args=r}},WA=class extends Ta{constructor(t,r){super(t,r),this.type=_o.METHOD}execute(t){t[this.inst](...this.args)}},zA=class extends Ta{constructor(t,r){super(t,r),this.type=_o.PROPERTY}execute(t){t[this.inst]=this.args[0]}},ZM={[_o.METHOD]:WA,[_o.PROPERTY]:zA},Pi=class{constructor(t,r,n){return new ZM[t](r,n)}};Pi.METHOD=_o.METHOD;Pi.PROPERTY=_o.PROPERTY;_a=Pi});var wh,Sr,ka,$A=g(()=>{yh();wh=Object.freeze({METHODS:["addHitRegion","arc","arcTo","beginPath","bezierCurveTo","clearHitRegions","clearRect","clip","closePath","drawFocusIfNeeded","drawImage","ellipse","fill","fillRect","fillText","lineTo","moveTo","putImageData","quadraticCurveTo","rect","removeHitRegion","resetTransform","restore","rotate","save","scale","scrollPathIntoView","setLineDash","setTransform","stroke","strokeRect","strokeText","transform","translate"],PROPERTIES:["direction","fillStyle","filter","font","globalAlpha","globalCompositeOperation","imageSmoothingEnabled","imageSmoothingQuality","lineCap","lineDashOffset","lineJoin","lineWidth","miterLimit","shadowBlur","shadowColor","shadowOffsetX","shadowOffsetY","strokeStyle","textAlign","textBaseline"]}),Sr=Object.freeze({sequence:Symbol.for("sequence"),push:Symbol.for("push"),fromJSON:Symbol.for("fromJSON")}),ka=class{constructor(t=null){this[Sr.sequence]=[],t&&this[Sr.fromJSON](t)}[Sr.fromJSON](t={sequence:[]}){t.sequence.forEach(({type:r,inst:n,args:o})=>{this[Sr.push](r,n,o)})}[Sr.push](t,r,n){this[Sr.sequence].push(new _a(t,r,n))}execute(t){t.save(),this[Sr.sequence].forEach(r=>r.execute(t)),t.restore()}toJSON(){return{sequence:this[Sr.sequence]}}};wh.METHODS.forEach(e=>{Object.defineProperty(ka.prototype,e,{value:function(...r){this[Sr.push](_a.METHOD,e,r)},writable:!1,enumerable:!0,configurable:!1})});wh.PROPERTIES.forEach(e=>{Object.defineProperty(ka.prototype,e,{get(){throw`Invalid canvas sequencer interaction, cannot get ${e}.`},set(t){this[Sr.push](_a.PROPERTY,e,[t])},enumerable:!0,configurable:!1})})});var e5,Bh=g(()=>{$A();e5=Object.freeze({sequence:Symbol.for("sequence"),push:Symbol.for("push")})});var Sh=g(()=>{Bh();$A()});var Mh=G((s5,Qh)=>{Qh.exports=!1});var e2,vh=g(()=>{Sh();e2=f(Mh(),1)});var t2,r2,Th=g(()=>{t2=f(F(),1),r2=f(b(),1)});var _h=g(()=>{});var u5,f5,m5,d5,kh=g(()=>{u5=new Uint8Array([99,124,119,123,242,107,111,197,48,1,103,43,254,215,171,118,202,130,201,125,250,89,71,240,173,212,162,175,156,164,114,192,183,253,147,38,54,63,247,204,52,165,229,241,113,216,49,21,4,199,35,195,24,150,5,154,7,18,128,226,235,39,178,117,9,131,44,26,27,110,90,160,82,59,214,179,41,227,47,132,83,209,0,237,32,252,177,91,106,203,190,57,74,76,88,207,208,239,170,251,67,77,51,133,69,249,2,127,80,60,159,168,81,163,64,143,146,157,56,245,188,182,218,33,16,255,243,210,205,12,19,236,95,151,68,23,196,167,126,61,100,93,25,115,96,129,79,220,34,42,144,136,70,238,184,20,222,94,11,219,224,50,58,10,73,6,36,92,194,211,172,98,145,149,228,121,231,200,55,109,141,213,78,169,108,86,244,234,101,122,174,8,186,120,37,46,28,166,180,198,232,221,116,31,75,189,139,138,112,62,181,102,72,3,246,14,97,53,87,185,134,193,29,158,225,248,152,17,105,217,142,148,155,30,135,233,206,85,40,223,140,161,137,13,191,230,66,104,65,153,45,15,176,84,187,22]),f5=new Uint8Array([82,9,106,213,48,54,165,56,191,64,163,158,129,243,215,251,124,227,57,130,155,47,255,135,52,142,67,68,196,222,233,203,84,123,148,50,166,194,35,61,238,76,149,11,66,250,195,78,8,46,161,102,40,217,36,178,118,91,162,73,109,139,209,37,114,248,246,100,134,104,152,22,212,164,92,204,93,101,182,146,108,112,72,80,253,237,185,218,94,21,70,87,167,141,157,132,144,216,171,0,140,188,211,10,247,228,88,5,184,179,69,6,208,44,30,143,202,63,15,2,193,175,189,3,1,19,138,107,58,145,17,65,79,103,220,234,151,242,207,206,240,180,230,115,150,172,116,34,231,173,53,133,226,249,55,232,28,117,223,110,71,241,26,113,29,41,197,137,111,183,98,14,170,24,190,27,252,86,62,75,198,210,121,32,154,219,192,254,120,205,90,244,31,221,168,51,136,7,199,49,177,18,16,89,39,128,236,95,96,81,127,169,25,181,74,13,45,229,122,159,147,201,156,239,160,224,59,77,174,42,245,176,200,235,187,60,131,83,153,97,23,43,4,126,186,119,214,38,225,105,20,99,85,33,12,125]),m5=new Uint8Array([1,2,4,8,16,32,64,128,27,54]),d5=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298])});var Dh=g(()=>{});var Nh=g(()=>{});var Lh=g(()=>{Li()});var Da,Fh=g(()=>{Da=f(kt(),1)});function XA(e,t=10){let r=String(e),n=0;for(let o=0,i=r.length;o<i;o++)n+=i2[r.charCodeAt(o)]??s2;return n*t}function ZA(e){let t=0;if(e.length===0)return t;for(let r=0;r<e.length;r++){let n=e.charCodeAt(r);t=(t<<5)-t+n,t|=0}return t}function a2(e){let{uri:t,baseUri:r=""}=e,n;try{n=new URL(t,r).href}catch{n=t}return n}function eu(e){return zt(e)?va(e)?a2(e):JSON.stringify(e):String(e)}function Rh(e){let t=/(^|[\s\n]|<[A-Za-z]*\/?>)((?:https?|ftp):\/\/[-A-Z0-9+\u0026\u2019@#/%?=()~_|!:,.;]*[-A-Z0-9+\u0026@#/%=~()_|])/gi;return e.replaceAll(t,`$1<a href='$2' target="_blank">$2</a>`)}function Ph(e,t){let{padding:r=30,minWidth:n=80,fontSize:o=12,maxWidth:i=1e3,stripHTML:s=!1}=t||{};return tu(e.map(a=>eu(a)).map(a=>s?dh(a):a).map(a=>XA(a,o)).map(a=>Math.min(Math.max(a+r,n),i)))}function tu(e,t=Number.NEGATIVE_INFINITY){let r=t;for(let n of e)r=Math.max(n,r);return r}function zt(e){return typeof e=="object"&&e!==null}var KA,ko,n2,o2,M5,v5,T5,_5,i2,s2,fn=g(()=>{KA=f(b(),1);ch();ko=f(kt(),1),n2=f(uh(),1),o2=f(mh(),1);VA();YA();YA();Eh();Ih();xh();VA();vh();Th();_h();kh();Dh();Nh();gh();ph();Fh();Lh();M5=180/Math.PI,v5=Math.PI/180,T5=/electron/i.test(typeof navigator<"u"?navigator.userAgent:""),_5=typeof jest>"u"?typeof window<"u"&&window.requestIdleCallback?window.requestIdleCallback:e=>setTimeout(()=>{e()},1):e=>{e()},i2=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,.2796875,.2765625,.3546875,.5546875,.5546875,.8890625,.665625,.190625,.3328125,.3328125,.3890625,.5828125,.2765625,.3328125,.2765625,.3015625,.5546875,.5546875,.5546875,.5546875,.5546875,.5546875,.5546875,.5546875,.5546875,.5546875,.2765625,.2765625,.584375,.5828125,.584375,.5546875,1.0140625,.665625,.665625,.721875,.721875,.665625,.609375,.7765625,.721875,.2765625,.5,.665625,.5546875,.8328125,.721875,.7765625,.665625,.7765625,.721875,.665625,.609375,.721875,.665625,.94375,.665625,.665625,.609375,.2765625,.3546875,.2765625,.4765625,.5546875,.3328125,.5546875,.5546875,.5,.5546875,.5546875,.2765625,.5546875,.5546875,.221875,.240625,.5,.221875,.8328125,.5546875,.5546875,.5546875,.5546875,.3328125,.5,.2765625,.5546875,.5,.721875,.5,.5,.5,.3546875,.259375,.353125,.5890625],s2=.5279276315789471});var Zh=G((QP,Xh)=>{Xh.exports=JBrowseExports["@jbrowse/core/pluggableElementTypes/ViewType"]});var t0,r0,No,cu=g(()=>{t0=f(F(),1),r0=f(b(),1),No=class extends r0.Component{constructor(t){super(t),this.state={error:void 0}}componentDidCatch(t,r){console.error("ErrorBoundary caught an error:",t,r),this.setState({error:t})}render(){return this.state.error?(0,t0.jsx)(this.props.FallbackComponent,{error:this.state.error}):this.props.children}}});var ft,lu,n0,o0,i0=g(()=>{ft=f(b(),1),lu=f(O(),1),n0=(0,lu.observer)(function({model:e}){let{resizeHandleWidth:t}=e,[r,n]=(0,ft.useState)(!1),o=(0,ft.useRef)(!1),i=(0,ft.useRef)(0);return(0,ft.useEffect)(()=>{function s(c){c.preventDefault();let l=c.clientX;if(i.current===0)i.current=c.clientX;else{let A=l-i.current;A&&(o.current||(o.current=!0,window.requestAnimationFrame(()=>{e.setTreeAreaWidth(e.treeAreaWidth+A),o.current=!1,i.current=c.clientX})))}}function a(){i.current=0,r&&n(!1)}return r?(document.addEventListener("mousemove",s,!0),document.addEventListener("mouseup",a,!0),()=>{document.removeEventListener("mousemove",s,!0),document.removeEventListener("mouseup",a,!0)}):()=>{}},[r,e]),ft.default.createElement("div",null,ft.default.createElement("div",{onMouseDown:()=>{n(!0)},style:{cursor:"ew-resize",height:"100%",width:t,background:"rgba(200,200,200)",position:"relative"}}))}),o0=(0,lu.observer)(function({model:e}){let{resizeHandleWidth:t}=e,[r,n]=(0,ft.useState)(!1),o=(0,ft.useRef)(!1),i=(0,ft.useRef)(0);return(0,ft.useEffect)(()=>{function s(c){c.preventDefault();let l=c.clientY;if(i.current===0)i.current=c.clientY;else{let A=l-i.current;A&&(o.current||(o.current=!0,window.requestAnimationFrame(()=>{e.setHeight(e.height+A),o.current=!1,i.current=c.clientY})))}}function a(){i.current=0,r&&n(!1)}return r?(document.addEventListener("mousemove",s,!0),document.addEventListener("mouseup",a,!0),()=>{document.removeEventListener("mousemove",s,!0),document.removeEventListener("mouseup",a,!0)}):()=>{}},[r,e]),ft.default.createElement("div",null,ft.default.createElement("div",{onMouseDown:()=>{n(!0)},style:{cursor:"ns-resize",width:"100%",height:t,background:"rgba(200,200,200)",position:"relative"}}))})});var s0,a0,c0=g(()=>{"use client";W();s0=f(F(),1),a0=(0,_.createSvgIcon)((0,s0.jsx)("path",{d:"m7 10 5 5 5-5z"}),"ArrowDropDown")});function Lo({ref:e,onScrollX:t,onScrollY:r}){let n=(0,mr.useRef)(!1),o=(0,mr.useRef)(0),i=(0,mr.useRef)(0),s=(0,mr.useRef)(0),a=(0,mr.useRef)(0),[c,l]=(0,mr.useState)(!1);(0,mr.useEffect)(()=>{let m=e.current;if(!m)return;function d(p){t&&(o.current+=p.deltaX),r&&(i.current+=p.deltaY),n.current||(n.current=!0,requestAnimationFrame(()=>{t&&(t(-o.current),o.current=0),r&&(r(-i.current),i.current=0),n.current=!1})),p.preventDefault(),p.stopPropagation()}return m.addEventListener("wheel",d,{passive:!1}),()=>{m.removeEventListener("wheel",d)}},[e,t,r]),(0,mr.useEffect)(()=>{if(!c)return;function m(p){p.preventDefault();let C=p.clientX-s.current,y=p.clientY-a.current;(C&&t||y&&r)&&(n.current||(n.current=!0,requestAnimationFrame(()=>{t?.(C),r?.(y),n.current=!1,s.current=p.clientX,a.current=p.clientY})))}function d(){s.current=0,a.current=0,l(!1)}return window.addEventListener("mousemove",m,!0),window.addEventListener("mouseup",d,!0),()=>{window.removeEventListener("mousemove",m,!0),window.removeEventListener("mouseup",d,!0)}},[c,t,r]);function A(m){let d=m.target;d.draggable||d.dataset.resizer||m.button===0&&(s.current=m.clientX,a.current=m.clientY,l(!0))}function u(m){m.preventDefault(),l(!1)}return{onMouseDown:A,onMouseUp:u}}var mr,Ra=g(()=>{mr=f(b(),1)});function Ui(e){let t=navigator.clipboard;if(t?.writeText){t.writeText(e).catch(n=>{console.error("Failed to copy to clipboard:",n)});return}let r=document.createElement("textarea");r.value=e,r.style.position="fixed",r.style.opacity="0",document.body.append(r),r.select(),document.execCommand("copy"),r.remove()}var Au=g(()=>{});var f0={};We(f0,{default:()=>g2});var jr,l0,On,A0,u0,m2,d2,g2,m0=g(()=>{jr=f(b(),1),l0=f(ye(),1),On=f(D(),1),A0=f(O(),1),u0=f(Be(),1);Au();m2=(0,u0.makeStyles)()(e=>({textArea:{padding:e.spacing(2),overflow:"auto",background:"#ddd",wordBreak:"break-word"}})),d2=(0,A0.observer)(function({model:e,onClose:t}){let[r,n]=(0,jr.useState)("Copy to clipboard"),{classes:o}=m2();return jr.default.createElement(l0.Dialog,{open:!0,onClose:t,fullWidth:!0,maxWidth:"lg",title:`Track info - ${e.name}`},jr.default.createElement(On.DialogContent,null,jr.default.createElement(On.Button,{variant:"contained",color:"primary",onClick:()=>{Ui(e.data),n("Copied!"),setTimeout(()=>{n("Copy to clipboard")},300)}},r),jr.default.createElement("pre",{className:o.textArea},e.data)),jr.default.createElement(On.DialogActions,null,jr.default.createElement(On.Button,{variant:"contained",onClick:t,color:"secondary"},"Close")))}),g2=d2});var ke,Gn,uu,d0,p2,h2,C2,E2,g0,p0=g(()=>{ke=f(b(),1);c0();Gn=f(D(),1),uu=f(O(),1),d0=f(Be(),1);Ra();p2=(0,ke.lazy)(()=>Promise.resolve().then(()=>(m0(),f0))),h2=(0,d0.makeStyles)()({button:{padding:0}}),C2=(0,uu.observer)(function({model:t,track:r}){let[n,o]=(0,ke.useState)(),{drawLabels:i,rowHeight:s,treeAreaWidth:a}=t,{model:{name:c,height:l}}=r,{classes:A}=h2(),u=Math.max(8,s-8);return ke.default.createElement("div",{style:{width:a,height:l,flexShrink:0,textAlign:"right",fontSize:u}},i?c:""," ",ke.default.createElement(Gn.IconButton,{className:A.button,style:{width:u,height:u},onClick:m=>{o(m.currentTarget)}},ke.default.createElement(a0,null)),n?ke.default.createElement(Gn.Menu,{anchorEl:n,transitionDuration:0,open:!0,onClose:()=>{o(void 0)}},ke.default.createElement(Gn.MenuItem,{dense:!0,onClick:()=>{t.toggleTrack(r.model.id),o(void 0)}},"Close"),ke.default.createElement(Gn.MenuItem,{dense:!0,onClick:()=>{t.queueDialog(m=>[p2,{onClose:m,model:r.model}]),o(void 0)}},"Get info")):null)}),E2=(0,uu.observer)(function({model:e,track:t}){let{resizeHandleWidth:r,colWidth:n,scrollX:o,numColumns:i}=e,{model:{height:s,error:a}}=t,c=(0,ke.useRef)(null),l=(0,ke.useCallback)(A=>{e.doScrollX(A)},[e]);return Lo({ref:c,onScrollX:l}),ke.default.createElement("div",{key:t.id,style:{display:"flex",height:s}},ke.default.createElement(C2,{model:e,track:t}),ke.default.createElement("div",{style:{width:r,flexShrink:0}}),ke.default.createElement("div",{ref:c,onMouseMove:A=>{if(!c.current)return;let{left:u}=c.current.getBoundingClientRect(),m=A.clientX-u-o,d=Math.floor(m/n);d>=0&&d<i?e.setMousePos(d,void 0):e.setMousePos(void 0,void 0)},onMouseLeave:()=>{e.setMousePos(void 0,void 0)}},a?ke.default.createElement("div",{style:{color:"red",fontSize:10}},`${a}`):ke.default.createElement(t.ReactComponent,{model:e,track:t})))}),g0=E2});var Qr,h0,C0,I2,E0,I0=g(()=>{Qr=f(b(),1),h0=f(ge(),1),C0=f(O(),1),I2=(0,C0.observer)(({model:e})=>{let{msaAreaHeight:t,scrollY:r,totalHeight:n}=e,[o,i]=(0,Qr.useState)(!1),s=(0,Qr.useRef)(!1),[a,c]=(0,Qr.useState)(),l="rgba(66, 119, 127, 0.3)",A=t/n,u=-r,m=u+t,d=u*A,p=m*A;return(0,Qr.useEffect)(()=>{function C(I){a!==void 0&&(s.current||(s.current=!0,window.requestAnimationFrame(()=>{e.setScrollY((0,h0.clamp)(a.scrollY-(I.clientY-a.clientY)/A,-n,0)),s.current=!1})))}function y(){c(void 0)}if(a!==void 0)return document.addEventListener("mousemove",C),document.addEventListener("mouseup",y),()=>{document.removeEventListener("mousemove",C),document.removeEventListener("mousemove",y)}},[e,A,n,a]),Qr.default.createElement("div",{style:{position:"relative",width:20,height:t,borderLeft:"1px solid #555",borderTop:"1px solid #555",boxSizing:"border-box"}},Qr.default.createElement("div",{style:{position:"absolute",top:Math.max(0,d),left:0,background:o?"rgba(66,119,127,0.6)":l,cursor:"pointer",boxSizing:"border-box",width:20,height:Math.max(p-d,20),zIndex:100},onMouseOver:()=>{i(!0)},onMouseOut:()=>{i(!1)},onMouseDown:C=>{c({clientY:C.clientY,scrollY:e.scrollY})}}))}),E0=I2});var x0,y0,w0=g(()=>{"use client";W();x0=f(F(),1),y0=(0,_.createSvgIcon)((0,x0.jsx)("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m1 17h-2v-2h2zm2.07-7.75-.9.92C13.45 12.9 13 13.5 13 15h-2v-.5c0-1.1.45-2.1 1.17-2.83l1.24-1.26c.37-.36.59-.86.59-1.41 0-1.1-.9-2-2-2s-2 .9-2 2H8c0-2.21 1.79-4 4-4s4 1.79 4 4c0 .88-.36 1.68-.93 2.25"}),"Help")});var b0,B0,S0=g(()=>{"use client";W();b0=f(F(),1),B0=(0,_.createSvgIcon)((0,b0.jsx)("path",{d:"M10 6 8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z"}),"ChevronRight")});var Q0,M0,v0=g(()=>{"use client";W();Q0=f(F(),1),M0=(0,_.createSvgIcon)((0,Q0.jsx)("path",{d:"M11 18h2v-2h-2zm1-16C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8m0-14c-2.21 0-4 1.79-4 4h2c0-1.1.9-2 2-2s2 .9 2 2c0 2-3 1.75-3 5h2c0-2.25 3-2.5 3-5 0-2.21-1.79-4-4-4"}),"HelpOutline")});var T0,Pa,fu=g(()=>{"use client";W();T0=f(F(),1),Pa=(0,_.createSvgIcon)((0,T0.jsx)("path",{d:"M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"}),"Close")});var _0,k0,D0=g(()=>{"use client";W();_0=f(F(),1),k0=(0,_.createSvgIcon)((0,_0.jsx)("path",{d:"M17.65 6.35C16.2 4.9 14.21 4 12 4c-4.42 0-7.99 3.58-7.99 8s3.57 8 7.99 8c3.73 0 6.84-2.55 7.73-6h-2.08c-.82 2.33-3.04 4-5.65 4-3.31 0-6-2.69-6-6s2.69-6 6-6c1.66 0 3.14.69 4.22 1.78L13 11h7V4z"}),"Refresh")});var N0,L0,F0=g(()=>{"use client";W();N0=f(F(),1),L0=(0,_.createSvgIcon)((0,N0.jsx)("path",{d:"M15.73 3H8.27L3 8.27v7.46L8.27 21h7.46L21 15.73V8.27zM12 17.3c-.72 0-1.3-.58-1.3-1.3s.58-1.3 1.3-1.3 1.3.58 1.3 1.3-.58 1.3-1.3 1.3m1-4.3h-2V7h2z"}),"Report")});function y2(e){if(e.sheet)return e.sheet;for(var t=0;t<document.styleSheets.length;t++)if(document.styleSheets[t].ownerNode===e)return document.styleSheets[t]}function w2(e){var t=document.createElement("style");return t.setAttribute("data-emotion",e.key),e.nonce!==void 0&&t.setAttribute("nonce",e.nonce),t.appendChild(document.createTextNode("")),t.setAttribute("data-s",""),t}var x2,R0,P0=g(()=>{x2=!1;R0=(function(){function e(r){var n=this;this._insertTag=function(o){var i;n.tags.length===0?n.insertionPoint?i=n.insertionPoint.nextSibling:n.prepend?i=n.container.firstChild:i=n.before:i=n.tags[n.tags.length-1].nextSibling,n.container.insertBefore(o,i),n.tags.push(o)},this.isSpeedy=r.speedy===void 0?!x2:r.speedy,this.tags=[],this.ctr=0,this.nonce=r.nonce,this.key=r.key,this.container=r.container,this.prepend=r.prepend,this.insertionPoint=r.insertionPoint,this.before=null}var t=e.prototype;return t.hydrate=function(n){n.forEach(this._insertTag)},t.insert=function(n){this.ctr%(this.isSpeedy?65e3:1)===0&&this._insertTag(w2(this));var o=this.tags[this.tags.length-1];if(this.isSpeedy){var i=y2(o);try{i.insertRule(n,i.cssRules.length)}catch{}}else o.appendChild(document.createTextNode(n));this.ctr++},t.flush=function(){this.tags.forEach(function(n){var o;return(o=n.parentNode)==null?void 0:o.removeChild(n)}),this.tags=[],this.ctr=0},e})()});var it,Hi,K,Oa,Fo,Ro,O0,Ga,G0,Ua=g(()=>{it="-ms-",Hi="-moz-",K="-webkit-",Oa="comm",Fo="rule",Ro="decl",O0="@import",Ga="@keyframes",G0="@layer"});function j0(e,t){return De(e,0)^45?(((t<<2^De(e,0))<<2^De(e,1))<<2^De(e,2))<<2^De(e,3):0}function Ha(e){return e.trim()}function mu(e,t){return(e=t.exec(e))?e[0]:e}function Y(e,t,r){return e.replace(t,r)}function ji(e,t){return e.indexOf(t)}function De(e,t){return e.charCodeAt(t)|0}function mn(e,t,r){return e.slice(t,r)}function gt(e){return e.length}function Po(e){return e.length}function Oo(e,t){return t.push(e),e}function du(e,t){return e.map(t).join("")}var U0,Un,H0,Go=g(()=>{U0=Math.abs,Un=String.fromCharCode,H0=Object.assign});function qi(e,t,r,n,o,i,s){return{value:e,root:t,parent:r,type:n,props:o,children:i,line:ja,column:Uo,length:s,return:""}}function qo(e,t){return H0(qi("",null,null,"",null,null,0),e,{length:-e.length},t)}function J0(){return Oe}function V0(){return Oe=pt>0?De(jo,--pt):0,Uo--,Oe===10&&(Uo=1,ja--),Oe}function ht(){return Oe=pt<q0?De(jo,pt++):0,Uo++,Oe===10&&(Uo=1,ja++),Oe}function $t(){return De(jo,pt)}function Ji(){return pt}function Jo(e,t){return mn(jo,e,t)}function Ho(e){switch(e){case 0:case 9:case 10:case 13:case 32:return 5;case 33:case 43:case 44:case 47:case 62:case 64:case 126:case 59:case 123:case 125:return 4;case 58:return 3;case 34:case 39:case 40:case 91:return 2;case 41:case 93:return 1}return 0}function qa(e){return ja=Uo=1,q0=gt(jo=e),pt=0,[]}function Ja(e){return jo="",e}function Vo(e){return Ha(Jo(pt-1,gu(e===91?e+2:e===40?e+1:e)))}function Y0(e){for(;(Oe=$t())&&Oe<33;)ht();return Ho(e)>2||Ho(Oe)>3?"":" "}function W0(e,t){for(;--t&&ht()&&!(Oe<48||Oe>102||Oe>57&&Oe<65||Oe>70&&Oe<97););return Jo(e,Ji()+(t<6&&$t()==32&&ht()==32))}function gu(e){for(;ht();)switch(Oe){case e:return pt;case 34:case 39:e!==34&&e!==39&&gu(Oe);break;case 40:e===41&&gu(e);break;case 92:ht();break}return pt}function z0(e,t){for(;ht()&&e+Oe!==57;)if(e+Oe===84&&$t()===47)break;return"/*"+Jo(t,pt-1)+"*"+Un(e===47?e:ht())}function $0(e){for(;!Ho($t());)ht();return Jo(e,pt)}var ja,Uo,q0,pt,Oe,jo,pu=g(()=>{Go();ja=1,Uo=1,q0=0,pt=0,Oe=0,jo=""});function Z0(e){return Ja(Va("",null,null,null,[""],e=qa(e),0,[0],e))}function Va(e,t,r,n,o,i,s,a,c){for(var l=0,A=0,u=s,m=0,d=0,p=0,C=1,y=1,I=1,h=0,x="",S=o,M=i,B=n,Q=x;y;)switch(p=h,h=ht()){case 40:if(p!=108&&De(Q,u-1)==58){ji(Q+=Y(Vo(h),"&","&\f"),"&\f")!=-1&&(I=-1);break}case 34:case 39:case 91:Q+=Vo(h);break;case 9:case 10:case 13:case 32:Q+=Y0(p);break;case 92:Q+=W0(Ji()-1,7);continue;case 47:switch($t()){case 42:case 47:Oo(b2(z0(ht(),Ji()),t,r),c);break;default:Q+="/"}break;case 123*C:a[l++]=gt(Q)*I;case 125*C:case 59:case 0:switch(h){case 0:case 125:y=0;case 59+A:I==-1&&(Q=Y(Q,/\f/g,"")),d>0&&gt(Q)-u&&Oo(d>32?X0(Q+";",n,r,u-1):X0(Y(Q," ","")+";",n,r,u-2),c);break;case 59:Q+=";";default:if(Oo(B=K0(Q,t,r,l,A,o,a,x,S=[],M=[],u),i),h===123)if(A===0)Va(Q,t,B,B,S,i,u,a,M);else switch(m===99&&De(Q,3)===110?100:m){case 100:case 108:case 109:case 115:Va(e,B,B,n&&Oo(K0(e,B,B,0,0,o,a,x,o,S=[],u),M),o,M,u,a,n?S:M);break;default:Va(Q,B,B,B,[""],M,0,a,M)}}l=A=d=0,C=I=1,x=Q="",u=s;break;case 58:u=1+gt(Q),d=p;default:if(C<1){if(h==123)--C;else if(h==125&&C++==0&&V0()==125)continue}switch(Q+=Un(h),h*C){case 38:I=A>0?1:(Q+="\f",-1);break;case 44:a[l++]=(gt(Q)-1)*I,I=1;break;case 64:$t()===45&&(Q+=Vo(ht())),m=$t(),A=u=gt(x=Q+=$0(Ji())),h++;break;case 45:p===45&&gt(Q)==2&&(C=0)}}return i}function K0(e,t,r,n,o,i,s,a,c,l,A){for(var u=o-1,m=o===0?i:[""],d=Po(m),p=0,C=0,y=0;p<n;++p)for(var I=0,h=mn(e,u+1,u=U0(C=s[p])),x=e;I<d;++I)(x=Ha(C>0?m[I]+" "+h:Y(h,/&\f/g,m[I])))&&(c[y++]=x);return qi(e,t,r,o===0?Fo:a,c,l,A)}function b2(e,t,r){return qi(e,t,r,Oa,Un(J0()),mn(e,2,-2),0)}function X0(e,t,r,n){return qi(e,t,r,Ro,mn(e,0,n),mn(e,n+1,-1),n)}var eC=g(()=>{Ua();Go();pu()});var tC=g(()=>{});function Hn(e,t){for(var r="",n=Po(e),o=0;o<n;o++)r+=t(e[o],o,e,t)||"";return r}function rC(e,t,r,n){switch(e.type){case G0:if(e.children.length)break;case O0:case Ro:return e.return=e.return||e.value;case Oa:return"";case Ga:return e.return=e.value+"{"+Hn(e.children,n)+"}";case Fo:e.value=e.props.join(",")}return gt(r=Hn(e.children,n))?e.return=e.value+"{"+r+"}":""}var nC=g(()=>{Ua();Go()});function oC(e){var t=Po(e);return function(r,n,o,i){for(var s="",a=0;a<t;a++)s+=e[a](r,n,o,i)||"";return s}}function iC(e){return function(t){t.root||(t=t.return)&&e(t)}}var sC=g(()=>{Go()});var aC=g(()=>{Ua();Go();eC();tC();pu();nC();sC()});var Ya=g(()=>{});function cC(e){var t=Object.create(null);return function(r){return t[r]===void 0&&(t[r]=e(r)),t[r]}}var hu=g(()=>{});function AC(e,t){switch(j0(e,t)){case 5103:return K+"print-"+e+e;case 5737:case 4201:case 3177:case 3433:case 1641:case 4457:case 2921:case 5572:case 6356:case 5844:case 3191:case 6645:case 3005:case 6391:case 5879:case 5623:case 6135:case 4599:case 4855:case 4215:case 6389:case 5109:case 5365:case 5621:case 3829:return K+e+e;case 5349:case 4246:case 4810:case 6968:case 2756:return K+e+Hi+e+it+e+e;case 6828:case 4268:return K+e+it+e+e;case 6165:return K+e+it+"flex-"+e+e;case 5187:return K+e+Y(e,/(\w+).+(:[^]+)/,K+"box-$1$2"+it+"flex-$1$2")+e;case 5443:return K+e+it+"flex-item-"+Y(e,/flex-|-self/,"")+e;case 4675:return K+e+it+"flex-line-pack"+Y(e,/align-content|flex-|-self/,"")+e;case 5548:return K+e+it+Y(e,"shrink","negative")+e;case 5292:return K+e+it+Y(e,"basis","preferred-size")+e;case 6060:return K+"box-"+Y(e,"-grow","")+K+e+it+Y(e,"grow","positive")+e;case 4554:return K+Y(e,/([^-])(transform)/g,"$1"+K+"$2")+e;case 6187:return Y(Y(Y(e,/(zoom-|grab)/,K+"$1"),/(image-set)/,K+"$1"),e,"")+e;case 5495:case 3959:return Y(e,/(image-set\([^]*)/,K+"$1$`$1");case 4968:return Y(Y(e,/(.+:)(flex-)?(.*)/,K+"box-pack:$3"+it+"flex-pack:$3"),/s.+-b[^;]+/,"justify")+K+e+e;case 4095:case 3583:case 4068:case 2532:return Y(e,/(.+)-inline(.+)/,K+"$1$2")+e;case 8116:case 7059:case 5753:case 5535:case 5445:case 5701:case 4933:case 4677:case 5533:case 5789:case 5021:case 4765:if(gt(e)-1-t>6)switch(De(e,t+1)){case 109:if(De(e,t+4)!==45)break;case 102:return Y(e,/(.+:)(.+)-([^]+)/,"$1"+K+"$2-$3$1"+Hi+(De(e,t+3)==108?"$3":"$2-$3"))+e;case 115:return~ji(e,"stretch")?AC(Y(e,"stretch","fill-available"),t)+e:e}break;case 4949:if(De(e,t+1)!==115)break;case 6444:switch(De(e,gt(e)-3-(~ji(e,"!important")&&10))){case 107:return Y(e,":",":"+K)+e;case 101:return Y(e,/(.+:)([^;!]+)(;|!.+)?/,"$1"+K+(De(e,14)===45?"inline-":"")+"box$3$1"+K+"$2$3$1"+it+"$2box$3")+e}break;case 5936:switch(De(e,t+11)){case 114:return K+e+it+Y(e,/[svh]\w+-[tblr]{2}/,"tb")+e;case 108:return K+e+it+Y(e,/[svh]\w+-[tblr]{2}/,"tb-rl")+e;case 45:return K+e+it+Y(e,/[svh]\w+-[tblr]{2}/,"lr")+e}return K+e+it+e+e}return e}var B2,S2,Q2,lC,M2,v2,T2,_2,uC,Cu=g(()=>{P0();aC();Ya();hu();B2=function(t,r,n){for(var o=0,i=0;o=i,i=$t(),o===38&&i===12&&(r[n]=1),!Ho(i);)ht();return Jo(t,pt)},S2=function(t,r){var n=-1,o=44;do switch(Ho(o)){case 0:o===38&&$t()===12&&(r[n]=1),t[n]+=B2(pt-1,r,n);break;case 2:t[n]+=Vo(o);break;case 4:if(o===44){t[++n]=$t()===58?"&\f":"",r[n]=t[n].length;break}default:t[n]+=Un(o)}while(o=ht());return t},Q2=function(t,r){return Ja(S2(qa(t),r))},lC=new WeakMap,M2=function(t){if(!(t.type!=="rule"||!t.parent||t.length<1)){for(var r=t.value,n=t.parent,o=t.column===n.column&&t.line===n.line;n.type!=="rule";)if(n=n.parent,!n)return;if(!(t.props.length===1&&r.charCodeAt(0)!==58&&!lC.get(n))&&!o){lC.set(t,!0);for(var i=[],s=Q2(r,i),a=n.props,c=0,l=0;c<s.length;c++)for(var A=0;A<a.length;A++,l++)t.props[l]=i[c]?s[c].replace(/&\f/g,a[A]):a[A]+" "+s[c]}}},v2=function(t){if(t.type==="decl"){var r=t.value;r.charCodeAt(0)===108&&r.charCodeAt(2)===98&&(t.return="",t.value="")}};T2=function(t,r,n,o){if(t.length>-1&&!t.return)switch(t.type){case Ro:t.return=AC(t.value,t.length);break;case Ga:return Hn([qo(t,{value:Y(t.value,"@","@"+K)})],o);case Fo:if(t.length)return du(t.props,function(i){switch(mu(i,/(::plac\w+|:read-\w+)/)){case":read-only":case":read-write":return Hn([qo(t,{props:[Y(i,/:(read-\w+)/,":"+Hi+"$1")]})],o);case"::placeholder":return Hn([qo(t,{props:[Y(i,/:(plac\w+)/,":"+K+"input-$1")]}),qo(t,{props:[Y(i,/:(plac\w+)/,":"+Hi+"$1")]}),qo(t,{props:[Y(i,/:(plac\w+)/,it+"input-$1")]})],o)}return""})}},_2=[T2],uC=function(t){var r=t.key;if(r==="css"){var n=document.querySelectorAll("style[data-emotion]:not([data-s])");Array.prototype.forEach.call(n,function(C){var y=C.getAttribute("data-emotion");y.indexOf(" ")!==-1&&(document.head.appendChild(C),C.setAttribute("data-s",""))})}var o=t.stylisPlugins||_2,i={},s,a=[];s=t.container||document.head,Array.prototype.forEach.call(document.querySelectorAll('style[data-emotion^="'+r+' "]'),function(C){for(var y=C.getAttribute("data-emotion").split(" "),I=1;I<y.length;I++)i[y[I]]=!0;a.push(C)});var c,l=[M2,v2];{var A,u=[rC,iC(function(C){A.insert(C)})],m=oC(l.concat(o,u)),d=function(y){return Hn(Z0(y),m)};c=function(y,I,h,x){A=h,d(y?y+"{"+I.styles+"}":I.styles),x&&(p.inserted[I.name]=!0)}}var p={key:r,sheet:new R0({key:r,container:s,nonce:t.nonce,speedy:t.speedy,prepend:t.prepend,insertionPoint:t.insertionPoint}),nonce:t.nonce,inserted:i,registered:{},insert:c};return p.sheet.hydrate(a),p}});var Eu=g(()=>{});var mC=G(oe=>{"use strict";var Ke=typeof Symbol=="function"&&Symbol.for,Iu=Ke?Symbol.for("react.element"):60103,xu=Ke?Symbol.for("react.portal"):60106,Wa=Ke?Symbol.for("react.fragment"):60107,za=Ke?Symbol.for("react.strict_mode"):60108,$a=Ke?Symbol.for("react.profiler"):60114,Ka=Ke?Symbol.for("react.provider"):60109,Xa=Ke?Symbol.for("react.context"):60110,yu=Ke?Symbol.for("react.async_mode"):60111,Za=Ke?Symbol.for("react.concurrent_mode"):60111,ec=Ke?Symbol.for("react.forward_ref"):60112,tc=Ke?Symbol.for("react.suspense"):60113,k2=Ke?Symbol.for("react.suspense_list"):60120,rc=Ke?Symbol.for("react.memo"):60115,nc=Ke?Symbol.for("react.lazy"):60116,D2=Ke?Symbol.for("react.block"):60121,N2=Ke?Symbol.for("react.fundamental"):60117,L2=Ke?Symbol.for("react.responder"):60118,F2=Ke?Symbol.for("react.scope"):60119;function Lt(e){if(typeof e=="object"&&e!==null){var t=e.$$typeof;switch(t){case Iu:switch(e=e.type,e){case yu:case Za:case Wa:case $a:case za:case tc:return e;default:switch(e=e&&e.$$typeof,e){case Xa:case ec:case nc:case rc:case Ka:return e;default:return t}}case xu:return t}}}function fC(e){return Lt(e)===Za}oe.AsyncMode=yu;oe.ConcurrentMode=Za;oe.ContextConsumer=Xa;oe.ContextProvider=Ka;oe.Element=Iu;oe.ForwardRef=ec;oe.Fragment=Wa;oe.Lazy=nc;oe.Memo=rc;oe.Portal=xu;oe.Profiler=$a;oe.StrictMode=za;oe.Suspense=tc;oe.isAsyncMode=function(e){return fC(e)||Lt(e)===yu};oe.isConcurrentMode=fC;oe.isContextConsumer=function(e){return Lt(e)===Xa};oe.isContextProvider=function(e){return Lt(e)===Ka};oe.isElement=function(e){return typeof e=="object"&&e!==null&&e.$$typeof===Iu};oe.isForwardRef=function(e){return Lt(e)===ec};oe.isFragment=function(e){return Lt(e)===Wa};oe.isLazy=function(e){return Lt(e)===nc};oe.isMemo=function(e){return Lt(e)===rc};oe.isPortal=function(e){return Lt(e)===xu};oe.isProfiler=function(e){return Lt(e)===$a};oe.isStrictMode=function(e){return Lt(e)===za};oe.isSuspense=function(e){return Lt(e)===tc};oe.isValidElementType=function(e){return typeof e=="string"||typeof e=="function"||e===Wa||e===Za||e===$a||e===za||e===tc||e===k2||typeof e=="object"&&e!==null&&(e.$$typeof===nc||e.$$typeof===rc||e.$$typeof===Ka||e.$$typeof===Xa||e.$$typeof===ec||e.$$typeof===N2||e.$$typeof===L2||e.$$typeof===F2||e.$$typeof===D2)};oe.typeOf=Lt});var gC=G((T4,dC)=>{"use strict";dC.exports=mC()});var yC=G((_4,xC)=>{"use strict";var wu=gC(),R2={childContextTypes:!0,contextType:!0,contextTypes:!0,defaultProps:!0,displayName:!0,getDefaultProps:!0,getDerivedStateFromError:!0,getDerivedStateFromProps:!0,mixins:!0,propTypes:!0,type:!0},P2={name:!0,length:!0,prototype:!0,caller:!0,callee:!0,arguments:!0,arity:!0},O2={$$typeof:!0,render:!0,defaultProps:!0,displayName:!0,propTypes:!0},EC={$$typeof:!0,compare:!0,defaultProps:!0,displayName:!0,propTypes:!0,type:!0},bu={};bu[wu.ForwardRef]=O2;bu[wu.Memo]=EC;function pC(e){return wu.isMemo(e)?EC:bu[e.$$typeof]||R2}var G2=Object.defineProperty,U2=Object.getOwnPropertyNames,hC=Object.getOwnPropertySymbols,H2=Object.getOwnPropertyDescriptor,j2=Object.getPrototypeOf,CC=Object.prototype;function IC(e,t,r){if(typeof t!="string"){if(CC){var n=j2(t);n&&n!==CC&&IC(e,n,r)}var o=U2(t);hC&&(o=o.concat(hC(t)));for(var i=pC(e),s=pC(t),a=0;a<o.length;++a){var c=o[a];if(!P2[c]&&!(r&&r[c])&&!(s&&s[c])&&!(i&&i[c])){var l=H2(t,c);try{G2(e,c,l)}catch{}}}}return e}xC.exports=IC});function Vi(e,t,r){var n="";return r.split(" ").forEach(function(o){e[o]!==void 0?t.push(e[o]+";"):o&&(n+=o+" ")}),n}var q2,oc,Yi,ic=g(()=>{q2=!0;oc=function(t,r,n){var o=t.key+"-"+r.name;(n===!1||q2===!1)&&t.registered[o]===void 0&&(t.registered[o]=r.styles)},Yi=function(t,r,n){oc(t,r,n);var o=t.key+"-"+r.name;if(t.inserted[r.name]===void 0){var i=r;do t.insert(r===i?"."+o:"",i,t.sheet,!0),i=i.next;while(i!==void 0)}}});function wC(e){for(var t=0,r,n=0,o=e.length;o>=4;++n,o-=4)r=e.charCodeAt(n)&255|(e.charCodeAt(++n)&255)<<8|(e.charCodeAt(++n)&255)<<16|(e.charCodeAt(++n)&255)<<24,r=(r&65535)*1540483477+((r>>>16)*59797<<16),r^=r>>>24,t=(r&65535)*1540483477+((r>>>16)*59797<<16)^(t&65535)*1540483477+((t>>>16)*59797<<16);switch(o){case 3:t^=(e.charCodeAt(n+2)&255)<<16;case 2:t^=(e.charCodeAt(n+1)&255)<<8;case 1:t^=e.charCodeAt(n)&255,t=(t&65535)*1540483477+((t>>>16)*59797<<16)}return t^=t>>>13,t=(t&65535)*1540483477+((t>>>16)*59797<<16),((t^t>>>15)>>>0).toString(36)}var bC=g(()=>{});var BC,SC=g(()=>{BC={animationIterationCount:1,aspectRatio:1,borderImageOutset:1,borderImageSlice:1,borderImageWidth:1,boxFlex:1,boxFlexGroup:1,boxOrdinalGroup:1,columnCount:1,columns:1,flex:1,flexGrow:1,flexPositive:1,flexShrink:1,flexNegative:1,flexOrder:1,gridRow:1,gridRowEnd:1,gridRowSpan:1,gridRowStart:1,gridColumn:1,gridColumnEnd:1,gridColumnSpan:1,gridColumnStart:1,msGridRow:1,msGridRowSpan:1,msGridColumn:1,msGridColumnSpan:1,fontWeight:1,lineHeight:1,opacity:1,order:1,orphans:1,scale:1,tabSize:1,widows:1,zIndex:1,zoom:1,WebkitLineClamp:1,fillOpacity:1,floodOpacity:1,stopOpacity:1,strokeDasharray:1,strokeDashoffset:1,strokeMiterlimit:1,strokeOpacity:1,strokeWidth:1}});function Wi(e,t,r){if(r==null)return"";var n=r;if(n.__emotion_styles!==void 0)return n;switch(typeof r){case"boolean":return"";case"object":{var o=r;if(o.anim===1)return Mr={name:o.name,styles:o.styles,next:Mr},o.name;var i=r;if(i.styles!==void 0){var s=i.next;if(s!==void 0)for(;s!==void 0;)Mr={name:s.name,styles:s.styles,next:Mr},s=s.next;var a=i.styles+";";return a}return z2(e,t,r)}case"function":{if(e!==void 0){var c=Mr,l=r(e);return Mr=c,Wi(e,t,l)}break}}var A=r;if(t==null)return A;var u=t[A];return u!==void 0?u:A}function z2(e,t,r){var n="";if(Array.isArray(r))for(var o=0;o<r.length;o++)n+=Wi(e,t,r[o])+";";else for(var i in r){var s=r[i];if(typeof s!="object"){var a=s;t!=null&&t[a]!==void 0?n+=i+"{"+t[a]+"}":QC(a)&&(n+=Bu(i)+":"+MC(i,a)+";")}else{if(i==="NO_COMPONENT_SELECTOR"&&J2)throw new Error(W2);if(Array.isArray(s)&&typeof s[0]=="string"&&(t==null||t[s[0]]===void 0))for(var c=0;c<s.length;c++)QC(s[c])&&(n+=Bu(i)+":"+MC(i,s[c])+";");else{var l=Wi(e,t,s);switch(i){case"animation":case"animationName":{n+=Bu(i)+":"+l+";";break}default:n+=i+"{"+l+"}"}}}}return n}function Yo(e,t,r){if(e.length===1&&typeof e[0]=="object"&&e[0]!==null&&e[0].styles!==void 0)return e[0];var n=!0,o="";Mr=void 0;var i=e[0];if(i==null||i.raw===void 0)n=!1,o+=Wi(r,t,i);else{var s=i;o+=s[0]}for(var a=1;a<e.length;a++)if(o+=Wi(r,t,e[a]),n){var c=i;o+=c[a]}vC.lastIndex=0;for(var l="",A;(A=vC.exec(o))!==null;)l+="-"+A[1];var u=wC(o)+l;return{name:u,styles:o,next:Mr}}var J2,V2,Y2,TC,QC,Bu,MC,W2,vC,Mr,sc=g(()=>{bC();SC();hu();J2=!1,V2=/[A-Z]|^ms/g,Y2=/_EMO_([^_]+?)_([^]*?)_EMO_/g,TC=function(t){return t.charCodeAt(1)===45},QC=function(t){return t!=null&&typeof t!="boolean"},Bu=cC(function(e){return TC(e)?e:e.replace(V2,"-$&").toLowerCase()}),MC=function(t,r){switch(t){case"animation":case"animationName":if(typeof r=="string")return r.replace(Y2,function(n,o,i){return Mr={name:o,styles:i,next:Mr},o})}return BC[t]!==1&&!TC(t)&&typeof r=="number"&&r!==0?r+"px":r},W2="Component selectors can only be used in conjunction with @emotion/babel-plugin, the swc Emotion plugin, or another Emotion-aware compiler transform.";vC=/label:\s*([^\s;{]+)\s*(;|$)/g});var ac,$2,K2,Su,Qu=g(()=>{ac=f(b()),$2=function(t){return t()},K2=ac.useInsertionEffect?ac.useInsertionEffect:!1,Su=K2||$2});var Kt,zi,_C,vu,X2,Tu,_u,ku,cc,Mu,kC,Z2,ev,DC,Du=g(()=>{Kt=f(b()),zi=f(b());Cu();Eu();Ya();ic();sc();Qu();_C=!1,vu=Kt.createContext(typeof HTMLElement<"u"?uC({key:"css"}):null),X2=vu.Provider,Tu=function(){return(0,zi.useContext)(vu)},_u=function(t){return(0,zi.forwardRef)(function(r,n){var o=(0,zi.useContext)(vu);return t(r,o,n)})},ku=Kt.createContext({}),cc={}.hasOwnProperty,Mu="__EMOTION_TYPE_PLEASE_DO_NOT_USE__",kC=function(t,r){var n={};for(var o in r)cc.call(r,o)&&(n[o]=r[o]);return n[Mu]=t,n},Z2=function(t){var r=t.cache,n=t.serialized,o=t.isStringTag;return oc(r,n,o),Su(function(){return Yi(r,n,o)}),null},ev=_u(function(e,t,r){var n=e.css;typeof n=="string"&&t.registered[n]!==void 0&&(n=t.registered[n]);var o=e[Mu],i=[n],s="";typeof e.className=="string"?s=Vi(t.registered,i,e.className):e.className!=null&&(s=e.className+" ");var a=Yo(i,void 0,Kt.useContext(ku));s+=t.key+"-"+a.name;var c={};for(var l in e)cc.call(e,l)&&l!=="css"&&l!==Mu&&!_C&&(c[l]=e[l]);return c.className=s,r&&(c.ref=r),Kt.createElement(Kt.Fragment,null,Kt.createElement(Z2,{cache:t,serialized:a,isStringTag:typeof o=="string"}),Kt.createElement(o,c))}),DC=ev});function tv(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];return Yo(t)}function Nu(){var e=tv.apply(void 0,arguments),t="animation-"+e.name;return{name:t,styles:"@keyframes "+t+"{"+e.styles+"}",anim:1,toString:function(){return"_EMO_"+this.name+"_"+this.styles+"_EMO_"}}}var Wo,sO,NC,Lu=g(()=>{Du();Du();Wo=f(b());ic();Qu();sc();Cu();Eu();Ya();sO=f(yC()),NC=function(t,r){var n=arguments;if(r==null||!cc.call(r,"css"))return Wo.createElement.apply(void 0,n);var o=n.length,i=new Array(o);i[0]=DC,i[1]=kC(t,r);for(var s=2;s<o;s++)i[s]=n[s];return Wo.createElement.apply(null,i)};(function(e){var t;t||(t=e.JSX||(e.JSX={}))})(NC||(NC={}))});var Fu=G((lO,LC)=>{LC.exports=JBrowseExports["@mui/material/styles"]});var zo,Ru=g(()=>{zo=e=>{let t=e.length,r=0,n="";for(;r<t;r++){let o=e[r];if(o==null)continue;let i;switch(typeof o){case"boolean":break;case"object":{if(Array.isArray(o))i=zo(o);else{let s=o;i="";for(let a in s)s[a]&&a&&(i&&(i+=" "),i+=a)}break}default:i=o}i&&(n&&(n+=" "),n+=i)}return n}});function FC(e){return e instanceof Object&&!("styles"in e)&&!("length"in e)&&!("__emotion_styles"in e)}var RC=g(()=>{});function GC(e){let{useCache:t}=e;function r(){let n=t(),{css:o,cx:i}=(0,OC.useMemo)(()=>rv({cache:n}),[n]);return{css:o,cx:i}}return{useCssAndCx:r}}var OC,rv,PC,UC=g(()=>{OC=f(b(),1);sc();ic();Ru();RC();({createCssAndCx:rv}=(()=>{function e(r,n,o){let i=[],s=Vi(r,i,o);return i.length<2?o:s+n(i)}function t(r){let{cache:n}=r,o=(...s)=>{let a=Yo(s,n.registered);Yi(n,a,!1);let c=`${n.key}-${a.name}`;e:{let l=s[0];if(!FC(l))break e;PC.saveClassNameCSSObjectMapping(n,c,l)}return c};return{css:o,cx:(...s)=>{let a=zo(s),c=PC.fixClassName(n,a,o);return e(n.registered,o,c)}}}return{createCssAndCx:t}})());PC=(()=>{let e=new WeakMap;return{saveClassNameCSSObjectMapping:(t,r,n)=>{let o=e.get(t);o===void 0&&(o=new Map,e.set(t,o)),o.set(r,n)},fixClassName:(()=>{function t(r){let n=!1;return r.map(([o,i])=>{if(i===void 0)return o;let s;if(n)s={"&&":i};else{s=o;for(let a in i)if(a.startsWith("@media")){n=!0;break}}return s})}return(r,n,o)=>{if(!n.includes(" "))return n;let i=e.get(r);return zo(t(n.split(" ").map(s=>[s,i?.get(s)])).map(s=>typeof s=="string"?s:o(s)))}})()}})()});function HC(e,t,r){if(!(t instanceof Object))return e;let n=Object.keys(t);if(n.length===0)return e;let o={};for(let i of Object.keys(e))o[i]=r(e[i],t[i]);for(let i of n){if(i in e)continue;let s=t[i];typeof s=="string"&&(o[i]=s)}return o}var jC=g(()=>{});function qC(e){if(!(e instanceof Object)||typeof e=="function")return e;let t=[];for(let r in e){let n=e[r],o=typeof n;if(!(o==="string"||o==="number"&&!isNaN(n)||o==="boolean"||n===void 0||n===null))return e;t.push(`${r}:${o}_${n}`)}return`xSqLiJdLMd9s${t.join("|")}`}var JC=g(()=>{});function VC(e){let{useTheme:t}=e,{useCssAndCx:r}=GC({useCache:nv});function n(){return function(o){let i=typeof o=="function"?o:()=>o;return function(a,c){let l=t(),{css:A,cx:u}=r(),m=(0,Pu.useMemo)(()=>{let y=i(l),I={};for(let h of Object.keys(y)){let x=y[h];I[h]=A(x)}return I},[A,l]),d=c?.props.classes,p=qC(d);return{classes:(0,Pu.useMemo)(()=>d?HC(m,d,u):m,[m,p,u]),theme:l,css:A,cx:u}}}}return{makeStyles:n}}var Pu,nv,YC=g(()=>{"use client";Pu=f(b(),1);Lu();UC();jC();JC();nv=Tu});var WC,ee,zC=g(()=>{WC=f(Fu(),1);YC();({makeStyles:ee}=VC({useTheme:WC.useTheme}))});var $C=g(()=>{zC()});function lc(...e){return zo(e)}var Ct=g(()=>{"use client";Lu();$C();Ru()});function Ou({children:e}){let{classes:t}=ov();return(0,KC.jsx)("div",{className:t.bg,children:e})}var KC,ov,XC=g(()=>{KC=f(F(),1);Ct();ov=ee()(e=>({bg:{padding:4,margin:4,overflow:"auto",maxHeight:200,background:e.palette.mode==="dark"?"#833":"#f88",border:`1px solid ${e.palette.divider}`}}))});var eE=G(Gu=>{var ZC="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".split("");Gu.encode=function(e){if(0<=e&&e<ZC.length)return ZC[e];throw new TypeError("Must be between 0 and 63: "+e)};Gu.decode=function(e){var t=65,r=90,n=97,o=122,i=48,s=57,a=43,c=47,l=26,A=52;return t<=e&&e<=r?e-t:n<=e&&e<=o?e-n+l:i<=e&&e<=s?e-i+A:e==a?62:e==c?63:-1}});var ju=G(Hu=>{var tE=eE(),Uu=5,rE=1<<Uu,nE=rE-1,oE=rE;function iv(e){return e<0?(-e<<1)+1:(e<<1)+0}function sv(e){var t=(e&1)===1,r=e>>1;return t?-r:r}Hu.encode=function(t){var r="",n,o=iv(t);do n=o&nE,o>>>=Uu,o>0&&(n|=oE),r+=tE.encode(n);while(o>0);return r};Hu.decode=function(t,r,n){var o=t.length,i=0,s=0,a,c;do{if(r>=o)throw new Error("Expected more digits in base 64 VLQ value.");if(c=tE.decode(t.charCodeAt(r++)),c===-1)throw new Error("Invalid base64 digit: "+t.charAt(r-1));a=!!(c&oE),c&=nE,i=i+(c<<s),s+=Uu}while(a);n.value=sv(i),n.rest=r}});var Ko=G(Xe=>{function av(e,t,r){if(t in e)return e[t];if(arguments.length===3)return r;throw new Error('"'+t+'" is a required argument.')}Xe.getArg=av;var iE=/^(?:([\w+\-.]+):)?\/\/(?:(\w+:\w+)@)?([\w.-]*)(?::(\d+))?(.*)$/,cv=/^data:.+\,.+$/;function $i(e){var t=e.match(iE);return t?{scheme:t[1],auth:t[2],host:t[3],port:t[4],path:t[5]}:null}Xe.urlParse=$i;function $o(e){var t="";return e.scheme&&(t+=e.scheme+":"),t+="//",e.auth&&(t+=e.auth+"@"),e.host&&(t+=e.host),e.port&&(t+=":"+e.port),e.path&&(t+=e.path),t}Xe.urlGenerate=$o;var lv=32;function Av(e){var t=[];return function(r){for(var n=0;n<t.length;n++)if(t[n].input===r){var o=t[0];return t[0]=t[n],t[n]=o,t[0].result}var i=e(r);return t.unshift({input:r,result:i}),t.length>lv&&t.pop(),i}}var qu=Av(function(t){var r=t,n=$i(t);if(n){if(!n.path)return t;r=n.path}for(var o=Xe.isAbsolute(r),i=[],s=0,a=0;;)if(s=a,a=r.indexOf("/",s),a===-1){i.push(r.slice(s));break}else for(i.push(r.slice(s,a));a<r.length&&r[a]==="/";)a++;for(var c,l=0,a=i.length-1;a>=0;a--)c=i[a],c==="."?i.splice(a,1):c===".."?l++:l>0&&(c===""?(i.splice(a+1,l),l=0):(i.splice(a,2),l--));return r=i.join("/"),r===""&&(r=o?"/":"."),n?(n.path=r,$o(n)):r});Xe.normalize=qu;function sE(e,t){e===""&&(e="."),t===""&&(t=".");var r=$i(t),n=$i(e);if(n&&(e=n.path||"/"),r&&!r.scheme)return n&&(r.scheme=n.scheme),$o(r);if(r||t.match(cv))return t;if(n&&!n.host&&!n.path)return n.host=t,$o(n);var o=t.charAt(0)==="/"?t:qu(e.replace(/\/+$/,"")+"/"+t);return n?(n.path=o,$o(n)):o}Xe.join=sE;Xe.isAbsolute=function(e){return e.charAt(0)==="/"||iE.test(e)};function uv(e,t){e===""&&(e="."),e=e.replace(/\/$/,"");for(var r=0;t.indexOf(e+"/")!==0;){var n=e.lastIndexOf("/");if(n<0||(e=e.slice(0,n),e.match(/^([^\/]+:\/)?\/*$/)))return t;++r}return Array(r+1).join("../")+t.substr(e.length+1)}Xe.relative=uv;var aE=(function(){var e=Object.create(null);return!("__proto__"in e)})();function cE(e){return e}function fv(e){return lE(e)?"$"+e:e}Xe.toSetString=aE?cE:fv;function mv(e){return lE(e)?e.slice(1):e}Xe.fromSetString=aE?cE:mv;function lE(e){if(!e)return!1;var t=e.length;if(t<9||e.charCodeAt(t-1)!==95||e.charCodeAt(t-2)!==95||e.charCodeAt(t-3)!==111||e.charCodeAt(t-4)!==116||e.charCodeAt(t-5)!==111||e.charCodeAt(t-6)!==114||e.charCodeAt(t-7)!==112||e.charCodeAt(t-8)!==95||e.charCodeAt(t-9)!==95)return!1;for(var r=t-10;r>=0;r--)if(e.charCodeAt(r)!==36)return!1;return!0}function dv(e,t,r){var n=qr(e.source,t.source);return n!==0||(n=e.originalLine-t.originalLine,n!==0)||(n=e.originalColumn-t.originalColumn,n!==0||r)||(n=e.generatedColumn-t.generatedColumn,n!==0)||(n=e.generatedLine-t.generatedLine,n!==0)?n:qr(e.name,t.name)}Xe.compareByOriginalPositions=dv;function gv(e,t,r){var n;return n=e.originalLine-t.originalLine,n!==0||(n=e.originalColumn-t.originalColumn,n!==0||r)||(n=e.generatedColumn-t.generatedColumn,n!==0)||(n=e.generatedLine-t.generatedLine,n!==0)?n:qr(e.name,t.name)}Xe.compareByOriginalPositionsNoSource=gv;function pv(e,t,r){var n=e.generatedLine-t.generatedLine;return n!==0||(n=e.generatedColumn-t.generatedColumn,n!==0||r)||(n=qr(e.source,t.source),n!==0)||(n=e.originalLine-t.originalLine,n!==0)||(n=e.originalColumn-t.originalColumn,n!==0)?n:qr(e.name,t.name)}Xe.compareByGeneratedPositionsDeflated=pv;function hv(e,t,r){var n=e.generatedColumn-t.generatedColumn;return n!==0||r||(n=qr(e.source,t.source),n!==0)||(n=e.originalLine-t.originalLine,n!==0)||(n=e.originalColumn-t.originalColumn,n!==0)?n:qr(e.name,t.name)}Xe.compareByGeneratedPositionsDeflatedNoLine=hv;function qr(e,t){return e===t?0:e===null?1:t===null?-1:e>t?1:-1}function Cv(e,t){var r=e.generatedLine-t.generatedLine;return r!==0||(r=e.generatedColumn-t.generatedColumn,r!==0)||(r=qr(e.source,t.source),r!==0)||(r=e.originalLine-t.originalLine,r!==0)||(r=e.originalColumn-t.originalColumn,r!==0)?r:qr(e.name,t.name)}Xe.compareByGeneratedPositionsInflated=Cv;function Ev(e){return JSON.parse(e.replace(/^\)]}'[^\n]*\n/,""))}Xe.parseSourceMapInput=Ev;function Iv(e,t,r){if(t=t||"",e&&(e[e.length-1]!=="/"&&t[0]!=="/"&&(e+="/"),t=e+t),r){var n=$i(r);if(!n)throw new Error("sourceMapURL could not be parsed");if(n.path){var o=n.path.lastIndexOf("/");o>=0&&(n.path=n.path.substring(0,o+1))}t=sE($o(n),t)}return qu(t)}Xe.computeSourceURL=Iv});var Yu=G(AE=>{var Ju=Ko(),Vu=Object.prototype.hasOwnProperty,jn=typeof Map<"u";function Jr(){this._array=[],this._set=jn?new Map:Object.create(null)}Jr.fromArray=function(t,r){for(var n=new Jr,o=0,i=t.length;o<i;o++)n.add(t[o],r);return n};Jr.prototype.size=function(){return jn?this._set.size:Object.getOwnPropertyNames(this._set).length};Jr.prototype.add=function(t,r){var n=jn?t:Ju.toSetString(t),o=jn?this.has(t):Vu.call(this._set,n),i=this._array.length;(!o||r)&&this._array.push(t),o||(jn?this._set.set(t,i):this._set[n]=i)};Jr.prototype.has=function(t){if(jn)return this._set.has(t);var r=Ju.toSetString(t);return Vu.call(this._set,r)};Jr.prototype.indexOf=function(t){if(jn){var r=this._set.get(t);if(r>=0)return r}else{var n=Ju.toSetString(t);if(Vu.call(this._set,n))return this._set[n]}throw new Error('"'+t+'" is not in the set.')};Jr.prototype.at=function(t){if(t>=0&&t<this._array.length)return this._array[t];throw new Error("No element indexed by "+t)};Jr.prototype.toArray=function(){return this._array.slice()};AE.ArraySet=Jr});var mE=G(fE=>{var uE=Ko();function xv(e,t){var r=e.generatedLine,n=t.generatedLine,o=e.generatedColumn,i=t.generatedColumn;return n>r||n==r&&i>=o||uE.compareByGeneratedPositionsInflated(e,t)<=0}function Ac(){this._array=[],this._sorted=!0,this._last={generatedLine:-1,generatedColumn:0}}Ac.prototype.unsortedForEach=function(t,r){this._array.forEach(t,r)};Ac.prototype.add=function(t){xv(this._last,t)?(this._last=t,this._array.push(t)):(this._sorted=!1,this._array.push(t))};Ac.prototype.toArray=function(){return this._sorted||(this._array.sort(uE.compareByGeneratedPositionsInflated),this._sorted=!0),this._array};fE.MappingList=Ac});var Wu=G(dE=>{var Ki=ju(),Ne=Ko(),uc=Yu().ArraySet,yv=mE().MappingList;function Xt(e){e||(e={}),this._file=Ne.getArg(e,"file",null),this._sourceRoot=Ne.getArg(e,"sourceRoot",null),this._skipValidation=Ne.getArg(e,"skipValidation",!1),this._ignoreInvalidMapping=Ne.getArg(e,"ignoreInvalidMapping",!1),this._sources=new uc,this._names=new uc,this._mappings=new yv,this._sourcesContents=null}Xt.prototype._version=3;Xt.fromSourceMap=function(t,r){var n=t.sourceRoot,o=new Xt(Object.assign(r||{},{file:t.file,sourceRoot:n}));return t.eachMapping(function(i){var s={generated:{line:i.generatedLine,column:i.generatedColumn}};i.source!=null&&(s.source=i.source,n!=null&&(s.source=Ne.relative(n,s.source)),s.original={line:i.originalLine,column:i.originalColumn},i.name!=null&&(s.name=i.name)),o.addMapping(s)}),t.sources.forEach(function(i){var s=i;n!==null&&(s=Ne.relative(n,i)),o._sources.has(s)||o._sources.add(s);var a=t.sourceContentFor(i);a!=null&&o.setSourceContent(i,a)}),o};Xt.prototype.addMapping=function(t){var r=Ne.getArg(t,"generated"),n=Ne.getArg(t,"original",null),o=Ne.getArg(t,"source",null),i=Ne.getArg(t,"name",null);!this._skipValidation&&this._validateMapping(r,n,o,i)===!1||(o!=null&&(o=String(o),this._sources.has(o)||this._sources.add(o)),i!=null&&(i=String(i),this._names.has(i)||this._names.add(i)),this._mappings.add({generatedLine:r.line,generatedColumn:r.column,originalLine:n!=null&&n.line,originalColumn:n!=null&&n.column,source:o,name:i}))};Xt.prototype.setSourceContent=function(t,r){var n=t;this._sourceRoot!=null&&(n=Ne.relative(this._sourceRoot,n)),r!=null?(this._sourcesContents||(this._sourcesContents=Object.create(null)),this._sourcesContents[Ne.toSetString(n)]=r):this._sourcesContents&&(delete this._sourcesContents[Ne.toSetString(n)],Object.keys(this._sourcesContents).length===0&&(this._sourcesContents=null))};Xt.prototype.applySourceMap=function(t,r,n){var o=r;if(r==null){if(t.file==null)throw new Error(`SourceMapGenerator.prototype.applySourceMap requires either an explicit source file, or the source map's "file" property. Both were omitted.`);o=t.file}var i=this._sourceRoot;i!=null&&(o=Ne.relative(i,o));var s=new uc,a=new uc;this._mappings.unsortedForEach(function(c){if(c.source===o&&c.originalLine!=null){var l=t.originalPositionFor({line:c.originalLine,column:c.originalColumn});l.source!=null&&(c.source=l.source,n!=null&&(c.source=Ne.join(n,c.source)),i!=null&&(c.source=Ne.relative(i,c.source)),c.originalLine=l.line,c.originalColumn=l.column,l.name!=null&&(c.name=l.name))}var A=c.source;A!=null&&!s.has(A)&&s.add(A);var u=c.name;u!=null&&!a.has(u)&&a.add(u)},this),this._sources=s,this._names=a,t.sources.forEach(function(c){var l=t.sourceContentFor(c);l!=null&&(n!=null&&(c=Ne.join(n,c)),i!=null&&(c=Ne.relative(i,c)),this.setSourceContent(c,l))},this)};Xt.prototype._validateMapping=function(t,r,n,o){if(r&&typeof r.line!="number"&&typeof r.column!="number"){var i="original.line and original.column are not numbers -- you probably meant to omit the original mapping entirely and only map the generated position. If so, pass null for the original mapping instead of an object with empty or null values.";if(this._ignoreInvalidMapping)return typeof console<"u"&&console.warn&&console.warn(i),!1;throw new Error(i)}if(!(t&&"line"in t&&"column"in t&&t.line>0&&t.column>=0&&!r&&!n&&!o)){if(t&&"line"in t&&"column"in t&&r&&"line"in r&&"column"in r&&t.line>0&&t.column>=0&&r.line>0&&r.column>=0&&n)return;var i="Invalid mapping: "+JSON.stringify({generated:t,source:n,original:r,name:o});if(this._ignoreInvalidMapping)return typeof console<"u"&&console.warn&&console.warn(i),!1;throw new Error(i)}};Xt.prototype._serializeMappings=function(){for(var t=0,r=1,n=0,o=0,i=0,s=0,a="",c,l,A,u,m=this._mappings.toArray(),d=0,p=m.length;d<p;d++){if(l=m[d],c="",l.generatedLine!==r)for(t=0;l.generatedLine!==r;)c+=";",r++;else if(d>0){if(!Ne.compareByGeneratedPositionsInflated(l,m[d-1]))continue;c+=","}c+=Ki.encode(l.generatedColumn-t),t=l.generatedColumn,l.source!=null&&(u=this._sources.indexOf(l.source),c+=Ki.encode(u-s),s=u,c+=Ki.encode(l.originalLine-1-o),o=l.originalLine-1,c+=Ki.encode(l.originalColumn-n),n=l.originalColumn,l.name!=null&&(A=this._names.indexOf(l.name),c+=Ki.encode(A-i),i=A)),a+=c}return a};Xt.prototype._generateSourcesContent=function(t,r){return t.map(function(n){if(!this._sourcesContents)return null;r!=null&&(n=Ne.relative(r,n));var o=Ne.toSetString(n);return Object.prototype.hasOwnProperty.call(this._sourcesContents,o)?this._sourcesContents[o]:null},this)};Xt.prototype.toJSON=function(){var t={version:this._version,sources:this._sources.toArray(),names:this._names.toArray(),mappings:this._serializeMappings()};return this._file!=null&&(t.file=this._file),this._sourceRoot!=null&&(t.sourceRoot=this._sourceRoot),this._sourcesContents&&(t.sourcesContent=this._generateSourcesContent(t.sources,t.sourceRoot)),t};Xt.prototype.toString=function(){return JSON.stringify(this.toJSON())};dE.SourceMapGenerator=Xt});var gE=G(qn=>{qn.GREATEST_LOWER_BOUND=1;qn.LEAST_UPPER_BOUND=2;function zu(e,t,r,n,o,i){var s=Math.floor((t-e)/2)+e,a=o(r,n[s],!0);return a===0?s:a>0?t-s>1?zu(s,t,r,n,o,i):i==qn.LEAST_UPPER_BOUND?t<n.length?t:-1:s:s-e>1?zu(e,s,r,n,o,i):i==qn.LEAST_UPPER_BOUND?s:e<0?-1:e}qn.search=function(t,r,n,o){if(r.length===0)return-1;var i=zu(-1,r.length,t,r,n,o||qn.GREATEST_LOWER_BOUND);if(i<0)return-1;for(;i-1>=0&&n(r[i],r[i-1],!0)===0;)--i;return i}});var CE=G(hE=>{function wv(e){function t(o,i,s){var a=o[i];o[i]=o[s],o[s]=a}function r(o,i){return Math.round(o+Math.random()*(i-o))}function n(o,i,s,a){if(s<a){var c=r(s,a),l=s-1;t(o,c,a);for(var A=o[a],u=s;u<a;u++)i(o[u],A,!1)<=0&&(l+=1,t(o,l,u));t(o,l+1,u);var m=l+1;n(o,i,s,m-1),n(o,i,m+1,a)}}return n}function bv(e){let t=wv.toString();return new Function(`return ${t}`)()(e)}var pE=new WeakMap;hE.quickSort=function(e,t,r=0){let n=pE.get(t);n===void 0&&(n=bv(t),pE.set(t,n)),n(e,t,r,e.length-1)}});var xE=G(fc=>{var N=Ko(),Ku=gE(),Xo=Yu().ArraySet,Bv=ju(),Xi=CE().quickSort;function pe(e,t){var r=e;return typeof e=="string"&&(r=N.parseSourceMapInput(e)),r.sections!=null?new dr(r,t):new st(r,t)}pe.fromSourceMap=function(e,t){return st.fromSourceMap(e,t)};pe.prototype._version=3;pe.prototype.__generatedMappings=null;Object.defineProperty(pe.prototype,"_generatedMappings",{configurable:!0,enumerable:!0,get:function(){return this.__generatedMappings||this._parseMappings(this._mappings,this.sourceRoot),this.__generatedMappings}});pe.prototype.__originalMappings=null;Object.defineProperty(pe.prototype,"_originalMappings",{configurable:!0,enumerable:!0,get:function(){return this.__originalMappings||this._parseMappings(this._mappings,this.sourceRoot),this.__originalMappings}});pe.prototype._charIsMappingSeparator=function(t,r){var n=t.charAt(r);return n===";"||n===","};pe.prototype._parseMappings=function(t,r){throw new Error("Subclasses must implement _parseMappings")};pe.GENERATED_ORDER=1;pe.ORIGINAL_ORDER=2;pe.GREATEST_LOWER_BOUND=1;pe.LEAST_UPPER_BOUND=2;pe.prototype.eachMapping=function(t,r,n){var o=r||null,i=n||pe.GENERATED_ORDER,s;switch(i){case pe.GENERATED_ORDER:s=this._generatedMappings;break;case pe.ORIGINAL_ORDER:s=this._originalMappings;break;default:throw new Error("Unknown order of iteration.")}for(var a=this.sourceRoot,c=t.bind(o),l=this._names,A=this._sources,u=this._sourceMapURL,m=0,d=s.length;m<d;m++){var p=s[m],C=p.source===null?null:A.at(p.source);C!==null&&(C=N.computeSourceURL(a,C,u)),c({source:C,generatedLine:p.generatedLine,generatedColumn:p.generatedColumn,originalLine:p.originalLine,originalColumn:p.originalColumn,name:p.name===null?null:l.at(p.name)})}};pe.prototype.allGeneratedPositionsFor=function(t){var r=N.getArg(t,"line"),n={source:N.getArg(t,"source"),originalLine:r,originalColumn:N.getArg(t,"column",0)};if(n.source=this._findSourceIndex(n.source),n.source<0)return[];var o=[],i=this._findMapping(n,this._originalMappings,"originalLine","originalColumn",N.compareByOriginalPositions,Ku.LEAST_UPPER_BOUND);if(i>=0){var s=this._originalMappings[i];if(t.column===void 0)for(var a=s.originalLine;s&&s.originalLine===a;)o.push({line:N.getArg(s,"generatedLine",null),column:N.getArg(s,"generatedColumn",null),lastColumn:N.getArg(s,"lastGeneratedColumn",null)}),s=this._originalMappings[++i];else for(var c=s.originalColumn;s&&s.originalLine===r&&s.originalColumn==c;)o.push({line:N.getArg(s,"generatedLine",null),column:N.getArg(s,"generatedColumn",null),lastColumn:N.getArg(s,"lastGeneratedColumn",null)}),s=this._originalMappings[++i]}return o};fc.SourceMapConsumer=pe;function st(e,t){var r=e;typeof e=="string"&&(r=N.parseSourceMapInput(e));var n=N.getArg(r,"version"),o=N.getArg(r,"sources"),i=N.getArg(r,"names",[]),s=N.getArg(r,"sourceRoot",null),a=N.getArg(r,"sourcesContent",null),c=N.getArg(r,"mappings"),l=N.getArg(r,"file",null);if(n!=this._version)throw new Error("Unsupported version: "+n);s&&(s=N.normalize(s)),o=o.map(String).map(N.normalize).map(function(A){return s&&N.isAbsolute(s)&&N.isAbsolute(A)?N.relative(s,A):A}),this._names=Xo.fromArray(i.map(String),!0),this._sources=Xo.fromArray(o,!0),this._absoluteSources=this._sources.toArray().map(function(A){return N.computeSourceURL(s,A,t)}),this.sourceRoot=s,this.sourcesContent=a,this._mappings=c,this._sourceMapURL=t,this.file=l}st.prototype=Object.create(pe.prototype);st.prototype.consumer=pe;st.prototype._findSourceIndex=function(e){var t=e;if(this.sourceRoot!=null&&(t=N.relative(this.sourceRoot,t)),this._sources.has(t))return this._sources.indexOf(t);var r;for(r=0;r<this._absoluteSources.length;++r)if(this._absoluteSources[r]==e)return r;return-1};st.fromSourceMap=function(t,r){var n=Object.create(st.prototype),o=n._names=Xo.fromArray(t._names.toArray(),!0),i=n._sources=Xo.fromArray(t._sources.toArray(),!0);n.sourceRoot=t._sourceRoot,n.sourcesContent=t._generateSourcesContent(n._sources.toArray(),n.sourceRoot),n.file=t._file,n._sourceMapURL=r,n._absoluteSources=n._sources.toArray().map(function(d){return N.computeSourceURL(n.sourceRoot,d,r)});for(var s=t._mappings.toArray().slice(),a=n.__generatedMappings=[],c=n.__originalMappings=[],l=0,A=s.length;l<A;l++){var u=s[l],m=new IE;m.generatedLine=u.generatedLine,m.generatedColumn=u.generatedColumn,u.source&&(m.source=i.indexOf(u.source),m.originalLine=u.originalLine,m.originalColumn=u.originalColumn,u.name&&(m.name=o.indexOf(u.name)),c.push(m)),a.push(m)}return Xi(n.__originalMappings,N.compareByOriginalPositions),n};st.prototype._version=3;Object.defineProperty(st.prototype,"sources",{get:function(){return this._absoluteSources.slice()}});function IE(){this.generatedLine=0,this.generatedColumn=0,this.source=null,this.originalLine=null,this.originalColumn=null,this.name=null}var $u=N.compareByGeneratedPositionsDeflatedNoLine;function EE(e,t){let r=e.length,n=e.length-t;if(!(n<=1))if(n==2){let o=e[t],i=e[t+1];$u(o,i)>0&&(e[t]=i,e[t+1]=o)}else if(n<20)for(let o=t;o<r;o++)for(let i=o;i>t;i--){let s=e[i-1],a=e[i];if($u(s,a)<=0)break;e[i-1]=a,e[i]=s}else Xi(e,$u,t)}st.prototype._parseMappings=function(t,r){var n=1,o=0,i=0,s=0,a=0,c=0,l=t.length,A=0,u={},m={},d=[],p=[],C,y,I,h,x;let S=0;for(;A<l;)if(t.charAt(A)===";")n++,A++,o=0,EE(p,S),S=p.length;else if(t.charAt(A)===",")A++;else{for(C=new IE,C.generatedLine=n,h=A;h<l&&!this._charIsMappingSeparator(t,h);h++);for(y=t.slice(A,h),I=[];A<h;)Bv.decode(t,A,m),x=m.value,A=m.rest,I.push(x);if(I.length===2)throw new Error("Found a source, but no line and column");if(I.length===3)throw new Error("Found a source and line, but no column");if(C.generatedColumn=o+I[0],o=C.generatedColumn,I.length>1&&(C.source=a+I[1],a+=I[1],C.originalLine=i+I[2],i=C.originalLine,C.originalLine+=1,C.originalColumn=s+I[3],s=C.originalColumn,I.length>4&&(C.name=c+I[4],c+=I[4])),p.push(C),typeof C.originalLine=="number"){let B=C.source;for(;d.length<=B;)d.push(null);d[B]===null&&(d[B]=[]),d[B].push(C)}}EE(p,S),this.__generatedMappings=p;for(var M=0;M<d.length;M++)d[M]!=null&&Xi(d[M],N.compareByOriginalPositionsNoSource);this.__originalMappings=[].concat(...d)};st.prototype._findMapping=function(t,r,n,o,i,s){if(t[n]<=0)throw new TypeError("Line must be greater than or equal to 1, got "+t[n]);if(t[o]<0)throw new TypeError("Column must be greater than or equal to 0, got "+t[o]);return Ku.search(t,r,i,s)};st.prototype.computeColumnSpans=function(){for(var t=0;t<this._generatedMappings.length;++t){var r=this._generatedMappings[t];if(t+1<this._generatedMappings.length){var n=this._generatedMappings[t+1];if(r.generatedLine===n.generatedLine){r.lastGeneratedColumn=n.generatedColumn-1;continue}}r.lastGeneratedColumn=1/0}};st.prototype.originalPositionFor=function(t){var r={generatedLine:N.getArg(t,"line"),generatedColumn:N.getArg(t,"column")},n=this._findMapping(r,this._generatedMappings,"generatedLine","generatedColumn",N.compareByGeneratedPositionsDeflated,N.getArg(t,"bias",pe.GREATEST_LOWER_BOUND));if(n>=0){var o=this._generatedMappings[n];if(o.generatedLine===r.generatedLine){var i=N.getArg(o,"source",null);i!==null&&(i=this._sources.at(i),i=N.computeSourceURL(this.sourceRoot,i,this._sourceMapURL));var s=N.getArg(o,"name",null);return s!==null&&(s=this._names.at(s)),{source:i,line:N.getArg(o,"originalLine",null),column:N.getArg(o,"originalColumn",null),name:s}}}return{source:null,line:null,column:null,name:null}};st.prototype.hasContentsOfAllSources=function(){return this.sourcesContent?this.sourcesContent.length>=this._sources.size()&&!this.sourcesContent.some(function(t){return t==null}):!1};st.prototype.sourceContentFor=function(t,r){if(!this.sourcesContent)return null;var n=this._findSourceIndex(t);if(n>=0)return this.sourcesContent[n];var o=t;this.sourceRoot!=null&&(o=N.relative(this.sourceRoot,o));var i;if(this.sourceRoot!=null&&(i=N.urlParse(this.sourceRoot))){var s=o.replace(/^file:\/\//,"");if(i.scheme=="file"&&this._sources.has(s))return this.sourcesContent[this._sources.indexOf(s)];if((!i.path||i.path=="/")&&this._sources.has("/"+o))return this.sourcesContent[this._sources.indexOf("/"+o)]}if(r)return null;throw new Error('"'+o+'" is not in the SourceMap.')};st.prototype.generatedPositionFor=function(t){var r=N.getArg(t,"source");if(r=this._findSourceIndex(r),r<0)return{line:null,column:null,lastColumn:null};var n={source:r,originalLine:N.getArg(t,"line"),originalColumn:N.getArg(t,"column")},o=this._findMapping(n,this._originalMappings,"originalLine","originalColumn",N.compareByOriginalPositions,N.getArg(t,"bias",pe.GREATEST_LOWER_BOUND));if(o>=0){var i=this._originalMappings[o];if(i.source===n.source)return{line:N.getArg(i,"generatedLine",null),column:N.getArg(i,"generatedColumn",null),lastColumn:N.getArg(i,"lastGeneratedColumn",null)}}return{line:null,column:null,lastColumn:null}};fc.BasicSourceMapConsumer=st;function dr(e,t){var r=e;typeof e=="string"&&(r=N.parseSourceMapInput(e));var n=N.getArg(r,"version"),o=N.getArg(r,"sections");if(n!=this._version)throw new Error("Unsupported version: "+n);this._sources=new Xo,this._names=new Xo;var i={line:-1,column:0};this._sections=o.map(function(s){if(s.url)throw new Error("Support for url field in sections not implemented.");var a=N.getArg(s,"offset"),c=N.getArg(a,"line"),l=N.getArg(a,"column");if(c<i.line||c===i.line&&l<i.column)throw new Error("Section offsets must be ordered and non-overlapping.");return i=a,{generatedOffset:{generatedLine:c+1,generatedColumn:l+1},consumer:new pe(N.getArg(s,"map"),t)}})}dr.prototype=Object.create(pe.prototype);dr.prototype.constructor=pe;dr.prototype._version=3;Object.defineProperty(dr.prototype,"sources",{get:function(){for(var e=[],t=0;t<this._sections.length;t++)for(var r=0;r<this._sections[t].consumer.sources.length;r++)e.push(this._sections[t].consumer.sources[r]);return e}});dr.prototype.originalPositionFor=function(t){var r={generatedLine:N.getArg(t,"line"),generatedColumn:N.getArg(t,"column")},n=Ku.search(r,this._sections,function(i,s){var a=i.generatedLine-s.generatedOffset.generatedLine;return a||i.generatedColumn-s.generatedOffset.generatedColumn}),o=this._sections[n];return o?o.consumer.originalPositionFor({line:r.generatedLine-(o.generatedOffset.generatedLine-1),column:r.generatedColumn-(o.generatedOffset.generatedLine===r.generatedLine?o.generatedOffset.generatedColumn-1:0),bias:t.bias}):{source:null,line:null,column:null,name:null}};dr.prototype.hasContentsOfAllSources=function(){return this._sections.every(function(t){return t.consumer.hasContentsOfAllSources()})};dr.prototype.sourceContentFor=function(t,r){for(var n=0;n<this._sections.length;n++){var o=this._sections[n],i=o.consumer.sourceContentFor(t,!0);if(i||i==="")return i}if(r)return null;throw new Error('"'+t+'" is not in the SourceMap.')};dr.prototype.generatedPositionFor=function(t){for(var r=0;r<this._sections.length;r++){var n=this._sections[r];if(n.consumer._findSourceIndex(N.getArg(t,"source"))!==-1){var o=n.consumer.generatedPositionFor(t);if(o){var i={line:o.line+(n.generatedOffset.generatedLine-1),column:o.column+(n.generatedOffset.generatedLine===o.line?n.generatedOffset.generatedColumn-1:0)};return i}}}return{line:null,column:null}};dr.prototype._parseMappings=function(t,r){this.__generatedMappings=[],this.__originalMappings=[];for(var n=0;n<this._sections.length;n++)for(var o=this._sections[n],i=o.consumer._generatedMappings,s=0;s<i.length;s++){var a=i[s],c=o.consumer._sources.at(a.source);c!==null&&(c=N.computeSourceURL(o.consumer.sourceRoot,c,this._sourceMapURL)),this._sources.add(c),c=this._sources.indexOf(c);var l=null;a.name&&(l=o.consumer._names.at(a.name),this._names.add(l),l=this._names.indexOf(l));var A={source:c,generatedLine:a.generatedLine+(o.generatedOffset.generatedLine-1),generatedColumn:a.generatedColumn+(o.generatedOffset.generatedLine===a.generatedLine?o.generatedOffset.generatedColumn-1:0),originalLine:a.originalLine,originalColumn:a.originalColumn,name:l};this.__generatedMappings.push(A),typeof A.originalLine=="number"&&this.__originalMappings.push(A)}Xi(this.__generatedMappings,N.compareByGeneratedPositionsDeflated),Xi(this.__originalMappings,N.compareByOriginalPositions)};fc.IndexedSourceMapConsumer=dr});var wE=G(yE=>{var Sv=Wu().SourceMapGenerator,mc=Ko(),Qv=/(\r?\n)/,Mv=10,Zo="$$$isSourceNode$$$";function Ft(e,t,r,n,o){this.children=[],this.sourceContents={},this.line=e??null,this.column=t??null,this.source=r??null,this.name=o??null,this[Zo]=!0,n!=null&&this.add(n)}Ft.fromStringWithSourceMap=function(t,r,n){var o=new Ft,i=t.split(Qv),s=0,a=function(){var m=p(),d=p()||"";return m+d;function p(){return s<i.length?i[s++]:void 0}},c=1,l=0,A=null;return r.eachMapping(function(m){if(A!==null)if(c<m.generatedLine)u(A,a()),c++,l=0;else{var d=i[s]||"",p=d.substr(0,m.generatedColumn-l);i[s]=d.substr(m.generatedColumn-l),l=m.generatedColumn,u(A,p),A=m;return}for(;c<m.generatedLine;)o.add(a()),c++;if(l<m.generatedColumn){var d=i[s]||"";o.add(d.substr(0,m.generatedColumn)),i[s]=d.substr(m.generatedColumn),l=m.generatedColumn}A=m},this),s<i.length&&(A&&u(A,a()),o.add(i.splice(s).join(""))),r.sources.forEach(function(m){var d=r.sourceContentFor(m);d!=null&&(n!=null&&(m=mc.join(n,m)),o.setSourceContent(m,d))}),o;function u(m,d){if(m===null||m.source===void 0)o.add(d);else{var p=n?mc.join(n,m.source):m.source;o.add(new Ft(m.originalLine,m.originalColumn,p,d,m.name))}}};Ft.prototype.add=function(t){if(Array.isArray(t))t.forEach(function(r){this.add(r)},this);else if(t[Zo]||typeof t=="string")t&&this.children.push(t);else throw new TypeError("Expected a SourceNode, string, or an array of SourceNodes and strings. Got "+t);return this};Ft.prototype.prepend=function(t){if(Array.isArray(t))for(var r=t.length-1;r>=0;r--)this.prepend(t[r]);else if(t[Zo]||typeof t=="string")this.children.unshift(t);else throw new TypeError("Expected a SourceNode, string, or an array of SourceNodes and strings. Got "+t);return this};Ft.prototype.walk=function(t){for(var r,n=0,o=this.children.length;n<o;n++)r=this.children[n],r[Zo]?r.walk(t):r!==""&&t(r,{source:this.source,line:this.line,column:this.column,name:this.name})};Ft.prototype.join=function(t){var r,n,o=this.children.length;if(o>0){for(r=[],n=0;n<o-1;n++)r.push(this.children[n]),r.push(t);r.push(this.children[n]),this.children=r}return this};Ft.prototype.replaceRight=function(t,r){var n=this.children[this.children.length-1];return n[Zo]?n.replaceRight(t,r):typeof n=="string"?this.children[this.children.length-1]=n.replace(t,r):this.children.push("".replace(t,r)),this};Ft.prototype.setSourceContent=function(t,r){this.sourceContents[mc.toSetString(t)]=r};Ft.prototype.walkSourceContents=function(t){for(var r=0,n=this.children.length;r<n;r++)this.children[r][Zo]&&this.children[r].walkSourceContents(t);for(var o=Object.keys(this.sourceContents),r=0,n=o.length;r<n;r++)t(mc.fromSetString(o[r]),this.sourceContents[o[r]])};Ft.prototype.toString=function(){var t="";return this.walk(function(r){t+=r}),t};Ft.prototype.toStringWithSourceMap=function(t){var r={code:"",line:1,column:0},n=new Sv(t),o=!1,i=null,s=null,a=null,c=null;return this.walk(function(l,A){r.code+=l,A.source!==null&&A.line!==null&&A.column!==null?((i!==A.source||s!==A.line||a!==A.column||c!==A.name)&&n.addMapping({source:A.source,original:{line:A.line,column:A.column},generated:{line:r.line,column:r.column},name:A.name}),i=A.source,s=A.line,a=A.column,c=A.name,o=!0):o&&(n.addMapping({generated:{line:r.line,column:r.column}}),i=null,o=!1);for(var u=0,m=l.length;u<m;u++)l.charCodeAt(u)===Mv?(r.line++,r.column=0,u+1===m?(i=null,o=!1):o&&n.addMapping({source:A.source,original:{line:A.line,column:A.column},generated:{line:r.line,column:r.column},name:A.name})):r.column++}),this.walkSourceContents(function(l,A){n.setSourceContent(l,A)}),{code:r.code,map:n}};yE.SourceNode=Ft});var bE=G(dc=>{dc.SourceMapGenerator=Wu().SourceMapGenerator;dc.SourceMapConsumer=xE().SourceMapConsumer;dc.SourceNode=wE().SourceNode});function pc(e){let{children:t,...r}=e;return(0,gc.jsxs)(BE.Link,{...r,target:"_blank",rel:"noopener noreferrer",children:[t," ",(0,gc.jsx)(ya,{fontSize:"small"})]})}var gc,BE,SE=g(()=>{gc=f(F(),1);NA();BE=f(D(),1)});function Xu({text:e,extra:t}){let{classes:r}=vv(),n=t?`supporting data: ${JSON.stringify(t,null,2)}`:"",o=[e,n].filter(Boolean).join(`
1
+ "use strict";var JBrowsePluginMsaView=(()=>{var MQ=Object.create;var Vs=Object.defineProperty;var vQ=Object.getOwnPropertyDescriptor;var TQ=Object.getOwnPropertyNames;var _Q=Object.getPrototypeOf,kQ=Object.prototype.hasOwnProperty;var g=(e,t)=>()=>(e&&(t=e(e=0)),t);var U=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Ye=(e,t)=>{for(var r in t)Vs(e,r,{get:t[r],enumerable:!0})},Sd=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of TQ(t))!kQ.call(e,o)&&o!==r&&Vs(e,o,{get:()=>t[o],enumerable:!(n=vQ(t,o))||n.enumerable});return e};var f=(e,t,r)=>(r=e!=null?MQ(_Q(e)):{},Sd(t||!e||!e.__esModule?Vs(r,"default",{value:e,enumerable:!0}):r,e)),DQ=e=>Sd(Vs({},"__esModule",{value:!0}),e);var Md=U((eL,Qd)=>{Qd.exports=JBrowseExports["@jbrowse/core/Plugin"]});var Eo=U((tL,vd)=>{vd.exports=JBrowseExports["@jbrowse/core/configuration"]});var Ce=U((rL,Td)=>{Td.exports=JBrowseExports["@jbrowse/core/util"]});var _t=U((nL,_d)=>{_d.exports=JBrowseExports["mobx-state-tree"]});var Dd=U((oL,kd)=>{kd.exports=JBrowseExports["@mui/material/utils"]});var _,W=g(()=>{"use client";_=f(Dd(),1)});var R=U((sL,Nd)=>{Nd.exports=JBrowseExports["react/jsx-runtime"]});var w=U((lL,Rd)=>{Rd.exports=JBrowseExports.react});var G=U((AL,Pd)=>{Pd.exports=JBrowseExports["mobx-react"]});var Se=U((uL,Od)=>{Od.exports=JBrowseExports["tss-react/mui"]});var Ul=U((gL,Hd)=>{Hd.exports=JBrowseExports["@jbrowse/core/pluggableElementTypes"]});var Gr=U((hL,qd)=>{qd.exports=JBrowseExports.mobx});var we=U((CL,Jd)=>{Jd.exports=JBrowseExports["@jbrowse/core/ui"]});var Vd,Yd,Io,Hl=g(()=>{Vd=f(R(),1),Yd=f(w(),1),Io=class extends Yd.Component{constructor(t){super(t),this.state={error:void 0}}componentDidCatch(t,r){console.error("ErrorBoundary caught an error:",t,r),this.setState({error:t})}render(){return this.state.error?(0,Vd.jsx)(this.props.FallbackComponent,{error:this.state.error}):this.props.children}}});var k=U((IL,Wd)=>{Wd.exports=JBrowseExports["@mui/material"]});var lt,jl,zd,$d,Kd=g(()=>{lt=f(w(),1),jl=f(G(),1),zd=(0,jl.observer)(function({model:e}){let{resizeHandleWidth:t}=e,[r,n]=(0,lt.useState)(!1),o=(0,lt.useRef)(!1),i=(0,lt.useRef)(0);return(0,lt.useEffect)(()=>{function s(c){c.preventDefault();let l=c.clientX;if(i.current===0)i.current=c.clientX;else{let A=l-i.current;A&&(o.current||(o.current=!0,window.requestAnimationFrame(()=>{e.setTreeAreaWidth(e.treeAreaWidth+A),o.current=!1,i.current=c.clientX})))}}function a(){i.current=0,r&&n(!1)}return r?(document.addEventListener("mousemove",s,!0),document.addEventListener("mouseup",a,!0),()=>{document.removeEventListener("mousemove",s,!0),document.removeEventListener("mouseup",a,!0)}):()=>{}},[r,e]),lt.default.createElement("div",null,lt.default.createElement("div",{onMouseDown:()=>{n(!0)},style:{cursor:"ew-resize",height:"100%",width:t,background:"rgba(200,200,200)",position:"relative"}}))}),$d=(0,jl.observer)(function({model:e}){let{resizeHandleWidth:t}=e,[r,n]=(0,lt.useState)(!1),o=(0,lt.useRef)(!1),i=(0,lt.useRef)(0);return(0,lt.useEffect)(()=>{function s(c){c.preventDefault();let l=c.clientY;if(i.current===0)i.current=c.clientY;else{let A=l-i.current;A&&(o.current||(o.current=!0,window.requestAnimationFrame(()=>{e.setHeight(e.height+A),o.current=!1,i.current=c.clientY})))}}function a(){i.current=0,r&&n(!1)}return r?(document.addEventListener("mousemove",s,!0),document.addEventListener("mouseup",a,!0),()=>{document.removeEventListener("mousemove",s,!0),document.removeEventListener("mouseup",a,!0)}):()=>{}},[r,e]),lt.default.createElement("div",null,lt.default.createElement("div",{onMouseDown:()=>{n(!0)},style:{cursor:"ns-resize",width:"100%",height:t,background:"rgba(200,200,200)",position:"relative"}}))})});var Xd,Zd,eg=g(()=>{"use client";W();Xd=f(R(),1),Zd=(0,_.createSvgIcon)((0,Xd.jsx)("path",{d:"m7 10 5 5 5-5z"}),"ArrowDropDown")});function xo({ref:e,onScrollX:t,onScrollY:r}){let n=(0,ir.useRef)(!1),o=(0,ir.useRef)(0),i=(0,ir.useRef)(0),s=(0,ir.useRef)(0),a=(0,ir.useRef)(0),[c,l]=(0,ir.useState)(!1);(0,ir.useEffect)(()=>{let m=e.current;if(!m)return;function d(p){t&&(o.current+=p.deltaX),r&&(i.current+=p.deltaY),n.current||(n.current=!0,requestAnimationFrame(()=>{t&&(t(-o.current),o.current=0),r&&(r(-i.current),i.current=0),n.current=!1})),p.preventDefault(),p.stopPropagation()}return m.addEventListener("wheel",d,{passive:!1}),()=>{m.removeEventListener("wheel",d)}},[e,t,r]),(0,ir.useEffect)(()=>{if(!c)return;function m(p){p.preventDefault();let E=p.clientX-s.current,x=p.clientY-a.current;(E&&t||x&&r)&&(n.current||(n.current=!0,requestAnimationFrame(()=>{t?.(E),r?.(x),n.current=!1,s.current=p.clientX,a.current=p.clientY})))}function d(){s.current=0,a.current=0,l(!1)}return window.addEventListener("mousemove",m,!0),window.addEventListener("mouseup",d,!0),()=>{window.removeEventListener("mousemove",m,!0),window.removeEventListener("mouseup",d,!0)}},[c,t,r]);function A(m){let d=m.target;d.draggable||d.dataset.resizer||m.button===0&&(s.current=m.clientX,a.current=m.clientY,l(!0))}function u(m){m.preventDefault(),l(!1)}return{onMouseDown:A,onMouseUp:u}}var ir,zs=g(()=>{ir=f(w(),1)});function ki(e){let t=navigator.clipboard;if(t?.writeText){t.writeText(e).catch(n=>{console.error("Failed to copy to clipboard:",n)});return}let r=document.createElement("textarea");r.value=e,r.style.position="fixed",r.style.opacity="0",document.body.append(r),r.select(),document.execCommand("copy"),r.remove()}var ql=g(()=>{});var og={};Ye(og,{default:()=>FQ});var Ur,tg,Nn,rg,ng,NQ,LQ,FQ,ig=g(()=>{Ur=f(w(),1),tg=f(we(),1),Nn=f(k(),1),rg=f(G(),1),ng=f(Se(),1);ql();NQ=(0,ng.makeStyles)()(e=>({textArea:{padding:e.spacing(2),overflow:"auto",background:"#ddd",wordBreak:"break-word"}})),LQ=(0,rg.observer)(function({model:e,onClose:t}){let[r,n]=(0,Ur.useState)("Copy to clipboard"),{classes:o}=NQ();return Ur.default.createElement(tg.Dialog,{open:!0,onClose:t,fullWidth:!0,maxWidth:"lg",title:`Track info - ${e.name}`},Ur.default.createElement(Nn.DialogContent,null,Ur.default.createElement(Nn.Button,{variant:"contained",color:"primary",onClick:()=>{ki(e.data),n("Copied!"),setTimeout(()=>{n("Copy to clipboard")},300)}},r),Ur.default.createElement("pre",{className:o.textArea},e.data)),Ur.default.createElement(Nn.DialogActions,null,Ur.default.createElement(Nn.Button,{variant:"contained",onClick:t,color:"secondary"},"Close")))}),FQ=LQ});var Pe,Ln,Jl,sg,RQ,PQ,OQ,GQ,ag,cg=g(()=>{Pe=f(w(),1);eg();Ln=f(k(),1),Jl=f(G(),1),sg=f(Se(),1);zs();RQ=(0,Pe.lazy)(()=>Promise.resolve().then(()=>(ig(),og))),PQ=(0,sg.makeStyles)()({button:{padding:0}}),OQ=(0,Jl.observer)(function({model:t,track:r}){let[n,o]=(0,Pe.useState)(),{drawLabels:i,rowHeight:s,treeAreaWidth:a}=t,{model:{name:c,height:l}}=r,{classes:A}=PQ(),u=Math.max(8,s-8);return Pe.default.createElement("div",{style:{width:a,height:l,flexShrink:0,textAlign:"right",fontSize:u}},i?c:""," ",Pe.default.createElement(Ln.IconButton,{className:A.button,style:{width:u,height:u},onClick:m=>{o(m.currentTarget)}},Pe.default.createElement(Zd,null)),n?Pe.default.createElement(Ln.Menu,{anchorEl:n,transitionDuration:0,open:!0,onClose:()=>{o(void 0)}},Pe.default.createElement(Ln.MenuItem,{dense:!0,onClick:()=>{t.toggleTrack(r.model.id),o(void 0)}},"Close"),Pe.default.createElement(Ln.MenuItem,{dense:!0,onClick:()=>{t.queueDialog(m=>[RQ,{onClose:m,model:r.model}]),o(void 0)}},"Get info")):null)}),GQ=(0,Jl.observer)(function({model:e,track:t}){let{resizeHandleWidth:r,colWidth:n,scrollX:o,numColumns:i}=e,{model:{height:s}}=t,a=(0,Pe.useRef)(null),c=(0,Pe.useCallback)(l=>{e.doScrollX(l)},[e]);return xo({ref:a,onScrollX:c}),Pe.default.createElement("div",{style:{display:"flex",height:s}},Pe.default.createElement(OQ,{model:e,track:t}),Pe.default.createElement("div",{style:{width:r,flexShrink:0}}),Pe.default.createElement("div",{ref:a,onMouseMove:l=>{if(!a.current)return;let{left:A}=a.current.getBoundingClientRect(),u=l.clientX-A-o,m=Math.floor(u/n);m>=0&&m<i?e.setMousePos(m,void 0):e.setMousePos(void 0,void 0)},onMouseLeave:()=>{e.setMousePos(void 0,void 0)}},Pe.default.createElement(t.ReactComponent,{model:e,track:t})))}),ag=GQ});function $s(e,t){let r=(0,yo.useRef)(!1),[n,o]=(0,yo.useState)();return(0,yo.useEffect)(()=>{if(n!==void 0){let a=function(l){r.current||(r.current=!0,requestAnimationFrame(()=>{let A=e==="x"?l.clientX:l.clientY;t(A-i,s),r.current=!1}))},c=function(){o(void 0)},{client:i,startScroll:s}=n;return document.addEventListener("mousemove",a),document.addEventListener("mouseup",c),()=>{document.removeEventListener("mousemove",a),document.removeEventListener("mouseup",c)}}},[e,t,n]),{dragging:n!==void 0,startDrag:(i,s)=>{o({client:e==="x"?i.clientX:i.clientY,startScroll:s})}}}var yo,Vl=g(()=>{yo=f(w(),1)});var Fn,lg,Ag,UQ,ug,fg=g(()=>{Fn=f(w(),1),lg=f(Ce(),1),Ag=f(G(),1);Vl();UQ=(0,Ag.observer)(({model:e})=>{let{msaAreaHeight:t,scrollY:r,totalHeight:n}=e,[o,i]=(0,Fn.useState)(!1),s="rgba(66, 119, 127, 0.3)",a=t/n,c=-r,l=c+t,A=c*a,u=l*a,{startDrag:m}=$s("y",(0,Fn.useCallback)((d,p)=>{e.setScrollY((0,lg.clamp)(p-d/a,-n,0))},[e,a,n]));return Fn.default.createElement("div",{style:{position:"relative",width:20,height:t,borderLeft:"1px solid #555",borderTop:"1px solid #555",boxSizing:"border-box"}},Fn.default.createElement("div",{style:{position:"absolute",top:Math.max(0,A),left:0,background:o?"rgba(66,119,127,0.6)":s,cursor:"pointer",boxSizing:"border-box",width:20,height:Math.max(u-A,20),zIndex:100},onMouseOver:()=>{i(!0)},onMouseOut:()=>{i(!1)},onMouseDown:d=>{m(d,e.scrollY)}}))}),ug=UQ});function Yl(){let e=(0,bo.useRef)(null),[t,r]=(0,bo.useState)({width:void 0,height:void 0});return(0,bo.useEffect)(()=>{if(!e.current)return;let n=typeof window<"u"&&"ResizeObserver"in window?window.ResizeObserver:void 0;if(!n)return;let o=new n(i=>{r({width:i[0].contentRect.width,height:i[0].contentRect.height})});return o.observe(e.current),()=>{o.disconnect()}},[]),[e,t]}var bo,mg=g(()=>{bo=f(w(),1)});var dg,gg,pg=g(()=>{"use client";W();dg=f(R(),1),gg=(0,_.createSvgIcon)((0,dg.jsx)("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m1 17h-2v-2h2zm2.07-7.75-.9.92C13.45 12.9 13 13.5 13 15h-2v-.5c0-1.1.45-2.1 1.17-2.83l1.24-1.26c.37-.36.59-.86.59-1.41 0-1.1-.9-2-2-2s-2 .9-2 2H8c0-2.21 1.79-4 4-4s4 1.79 4 4c0 .88-.36 1.68-.93 2.25"}),"Help")});var hg,Cg,Eg=g(()=>{"use client";W();hg=f(R(),1),Cg=(0,_.createSvgIcon)((0,hg.jsx)("path",{d:"M10 6 8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z"}),"ChevronRight")});var Ig,xg,yg=g(()=>{"use client";W();Ig=f(R(),1),xg=(0,_.createSvgIcon)((0,Ig.jsx)("path",{d:"M11 18h2v-2h-2zm1-16C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8m0-14c-2.21 0-4 1.79-4 4h2c0-1.1.9-2 2-2s2 .9 2 2c0 2-3 1.75-3 5h2c0-2.25 3-2.5 3-5 0-2.21-1.79-4-4-4"}),"HelpOutline")});var bg,Ks,Wl=g(()=>{"use client";W();bg=f(R(),1),Ks=(0,_.createSvgIcon)((0,bg.jsx)("path",{d:"M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"}),"Close")});var wg,Bg,Sg=g(()=>{"use client";W();wg=f(R(),1),Bg=(0,_.createSvgIcon)((0,wg.jsx)("path",{d:"M17.65 6.35C16.2 4.9 14.21 4 12 4c-4.42 0-7.99 3.58-7.99 8s3.57 8 7.99 8c3.73 0 6.84-2.55 7.73-6h-2.08c-.82 2.33-3.04 4-5.65 4-3.31 0-6-2.69-6-6s2.69-6 6-6c1.66 0 3.14.69 4.22 1.78L13 11h7V4z"}),"Refresh")});var Qg,Mg,vg=g(()=>{"use client";W();Qg=f(R(),1),Mg=(0,_.createSvgIcon)((0,Qg.jsx)("path",{d:"M15.73 3H8.27L3 8.27v7.46L8.27 21h7.46L21 15.73V8.27zM12 17.3c-.72 0-1.3-.58-1.3-1.3s.58-1.3 1.3-1.3 1.3.58 1.3 1.3-.58 1.3-1.3 1.3m1-4.3h-2V7h2z"}),"Report")});function jQ(e){if(e.sheet)return e.sheet;for(var t=0;t<document.styleSheets.length;t++)if(document.styleSheets[t].ownerNode===e)return document.styleSheets[t]}function qQ(e){var t=document.createElement("style");return t.setAttribute("data-emotion",e.key),e.nonce!==void 0&&t.setAttribute("nonce",e.nonce),t.appendChild(document.createTextNode("")),t.setAttribute("data-s",""),t}var HQ,Tg,_g=g(()=>{HQ=!1;Tg=(function(){function e(r){var n=this;this._insertTag=function(o){var i;n.tags.length===0?n.insertionPoint?i=n.insertionPoint.nextSibling:n.prepend?i=n.container.firstChild:i=n.before:i=n.tags[n.tags.length-1].nextSibling,n.container.insertBefore(o,i),n.tags.push(o)},this.isSpeedy=r.speedy===void 0?!HQ:r.speedy,this.tags=[],this.ctr=0,this.nonce=r.nonce,this.key=r.key,this.container=r.container,this.prepend=r.prepend,this.insertionPoint=r.insertionPoint,this.before=null}var t=e.prototype;return t.hydrate=function(n){n.forEach(this._insertTag)},t.insert=function(n){this.ctr%(this.isSpeedy?65e3:1)===0&&this._insertTag(qQ(this));var o=this.tags[this.tags.length-1];if(this.isSpeedy){var i=jQ(o);try{i.insertRule(n,i.cssRules.length)}catch{}}else o.appendChild(document.createTextNode(n));this.ctr++},t.flush=function(){this.tags.forEach(function(n){var o;return(o=n.parentNode)==null?void 0:o.removeChild(n)}),this.tags=[],this.ctr=0},e})()});var nt,Di,X,Xs,wo,Bo,kg,Zs,Dg,ea=g(()=>{nt="-ms-",Di="-moz-",X="-webkit-",Xs="comm",wo="rule",Bo="decl",kg="@import",Zs="@keyframes",Dg="@layer"});function Fg(e,t){return Ne(e,0)^45?(((t<<2^Ne(e,0))<<2^Ne(e,1))<<2^Ne(e,2))<<2^Ne(e,3):0}function ta(e){return e.trim()}function zl(e,t){return(e=t.exec(e))?e[0]:e}function Y(e,t,r){return e.replace(t,r)}function Ni(e,t){return e.indexOf(t)}function Ne(e,t){return e.charCodeAt(t)|0}function an(e,t,r){return e.slice(t,r)}function pt(e){return e.length}function So(e){return e.length}function Qo(e,t){return t.push(e),e}function $l(e,t){return e.map(t).join("")}var Ng,Rn,Lg,Mo=g(()=>{Ng=Math.abs,Rn=String.fromCharCode,Lg=Object.assign});function Li(e,t,r,n,o,i,s){return{value:e,root:t,parent:r,type:n,props:o,children:i,line:ra,column:vo,length:s,return:""}}function ko(e,t){return Lg(Li("",null,null,"",null,null,0),e,{length:-e.length},t)}function Pg(){return Oe}function Og(){return Oe=ht>0?Ne(_o,--ht):0,vo--,Oe===10&&(vo=1,ra--),Oe}function Ct(){return Oe=ht<Rg?Ne(_o,ht++):0,vo++,Oe===10&&(vo=1,ra++),Oe}function jt(){return Ne(_o,ht)}function Fi(){return ht}function Do(e,t){return an(_o,e,t)}function To(e){switch(e){case 0:case 9:case 10:case 13:case 32:return 5;case 33:case 43:case 44:case 47:case 62:case 64:case 126:case 59:case 123:case 125:return 4;case 58:return 3;case 34:case 39:case 40:case 91:return 2;case 41:case 93:return 1}return 0}function na(e){return ra=vo=1,Rg=pt(_o=e),ht=0,[]}function oa(e){return _o="",e}function No(e){return ta(Do(ht-1,Kl(e===91?e+2:e===40?e+1:e)))}function Gg(e){for(;(Oe=jt())&&Oe<33;)Ct();return To(e)>2||To(Oe)>3?"":" "}function Ug(e,t){for(;--t&&Ct()&&!(Oe<48||Oe>102||Oe>57&&Oe<65||Oe>70&&Oe<97););return Do(e,Fi()+(t<6&&jt()==32&&Ct()==32))}function Kl(e){for(;Ct();)switch(Oe){case e:return ht;case 34:case 39:e!==34&&e!==39&&Kl(Oe);break;case 40:e===41&&Kl(e);break;case 92:Ct();break}return ht}function Hg(e,t){for(;Ct()&&e+Oe!==57;)if(e+Oe===84&&jt()===47)break;return"/*"+Do(t,ht-1)+"*"+Rn(e===47?e:Ct())}function jg(e){for(;!To(jt());)Ct();return Do(e,ht)}var ra,vo,Rg,ht,Oe,_o,Xl=g(()=>{Mo();ra=1,vo=1,Rg=0,ht=0,Oe=0,_o=""});function Vg(e){return oa(ia("",null,null,null,[""],e=na(e),0,[0],e))}function ia(e,t,r,n,o,i,s,a,c){for(var l=0,A=0,u=s,m=0,d=0,p=0,E=1,x=1,I=1,h=0,y="",Q=o,M=i,B=n,v=y;x;)switch(p=h,h=Ct()){case 40:if(p!=108&&Ne(v,u-1)==58){Ni(v+=Y(No(h),"&","&\f"),"&\f")!=-1&&(I=-1);break}case 34:case 39:case 91:v+=No(h);break;case 9:case 10:case 13:case 32:v+=Gg(p);break;case 92:v+=Ug(Fi()-1,7);continue;case 47:switch(jt()){case 42:case 47:Qo(JQ(Hg(Ct(),Fi()),t,r),c);break;default:v+="/"}break;case 123*E:a[l++]=pt(v)*I;case 125*E:case 59:case 0:switch(h){case 0:case 125:x=0;case 59+A:I==-1&&(v=Y(v,/\f/g,"")),d>0&&pt(v)-u&&Qo(d>32?Jg(v+";",n,r,u-1):Jg(Y(v," ","")+";",n,r,u-2),c);break;case 59:v+=";";default:if(Qo(B=qg(v,t,r,l,A,o,a,y,Q=[],M=[],u),i),h===123)if(A===0)ia(v,t,B,B,Q,i,u,a,M);else switch(m===99&&Ne(v,3)===110?100:m){case 100:case 108:case 109:case 115:ia(e,B,B,n&&Qo(qg(e,B,B,0,0,o,a,y,o,Q=[],u),M),o,M,u,a,n?Q:M);break;default:ia(v,B,B,B,[""],M,0,a,M)}}l=A=d=0,E=I=1,y=v="",u=s;break;case 58:u=1+pt(v),d=p;default:if(E<1){if(h==123)--E;else if(h==125&&E++==0&&Og()==125)continue}switch(v+=Rn(h),h*E){case 38:I=A>0?1:(v+="\f",-1);break;case 44:a[l++]=(pt(v)-1)*I,I=1;break;case 64:jt()===45&&(v+=No(Ct())),m=jt(),A=u=pt(y=v+=jg(Fi())),h++;break;case 45:p===45&&pt(v)==2&&(E=0)}}return i}function qg(e,t,r,n,o,i,s,a,c,l,A){for(var u=o-1,m=o===0?i:[""],d=So(m),p=0,E=0,x=0;p<n;++p)for(var I=0,h=an(e,u+1,u=Ng(E=s[p])),y=e;I<d;++I)(y=ta(E>0?m[I]+" "+h:Y(h,/&\f/g,m[I])))&&(c[x++]=y);return Li(e,t,r,o===0?wo:a,c,l,A)}function JQ(e,t,r){return Li(e,t,r,Xs,Rn(Pg()),an(e,2,-2),0)}function Jg(e,t,r,n){return Li(e,t,r,Bo,an(e,0,n),an(e,n+1,-1),n)}var Yg=g(()=>{ea();Mo();Xl()});var Wg=g(()=>{});function Pn(e,t){for(var r="",n=So(e),o=0;o<n;o++)r+=t(e[o],o,e,t)||"";return r}function zg(e,t,r,n){switch(e.type){case Dg:if(e.children.length)break;case kg:case Bo:return e.return=e.return||e.value;case Xs:return"";case Zs:return e.return=e.value+"{"+Pn(e.children,n)+"}";case wo:e.value=e.props.join(",")}return pt(r=Pn(e.children,n))?e.return=e.value+"{"+r+"}":""}var $g=g(()=>{ea();Mo()});function Kg(e){var t=So(e);return function(r,n,o,i){for(var s="",a=0;a<t;a++)s+=e[a](r,n,o,i)||"";return s}}function Xg(e){return function(t){t.root||(t=t.return)&&e(t)}}var Zg=g(()=>{Mo()});var ep=g(()=>{ea();Mo();Yg();Wg();Xl();$g();Zg()});var sa=g(()=>{});function tp(e){var t=Object.create(null);return function(r){return t[r]===void 0&&(t[r]=e(r)),t[r]}}var Zl=g(()=>{});function np(e,t){switch(Fg(e,t)){case 5103:return X+"print-"+e+e;case 5737:case 4201:case 3177:case 3433:case 1641:case 4457:case 2921:case 5572:case 6356:case 5844:case 3191:case 6645:case 3005:case 6391:case 5879:case 5623:case 6135:case 4599:case 4855:case 4215:case 6389:case 5109:case 5365:case 5621:case 3829:return X+e+e;case 5349:case 4246:case 4810:case 6968:case 2756:return X+e+Di+e+nt+e+e;case 6828:case 4268:return X+e+nt+e+e;case 6165:return X+e+nt+"flex-"+e+e;case 5187:return X+e+Y(e,/(\w+).+(:[^]+)/,X+"box-$1$2"+nt+"flex-$1$2")+e;case 5443:return X+e+nt+"flex-item-"+Y(e,/flex-|-self/,"")+e;case 4675:return X+e+nt+"flex-line-pack"+Y(e,/align-content|flex-|-self/,"")+e;case 5548:return X+e+nt+Y(e,"shrink","negative")+e;case 5292:return X+e+nt+Y(e,"basis","preferred-size")+e;case 6060:return X+"box-"+Y(e,"-grow","")+X+e+nt+Y(e,"grow","positive")+e;case 4554:return X+Y(e,/([^-])(transform)/g,"$1"+X+"$2")+e;case 6187:return Y(Y(Y(e,/(zoom-|grab)/,X+"$1"),/(image-set)/,X+"$1"),e,"")+e;case 5495:case 3959:return Y(e,/(image-set\([^]*)/,X+"$1$`$1");case 4968:return Y(Y(e,/(.+:)(flex-)?(.*)/,X+"box-pack:$3"+nt+"flex-pack:$3"),/s.+-b[^;]+/,"justify")+X+e+e;case 4095:case 3583:case 4068:case 2532:return Y(e,/(.+)-inline(.+)/,X+"$1$2")+e;case 8116:case 7059:case 5753:case 5535:case 5445:case 5701:case 4933:case 4677:case 5533:case 5789:case 5021:case 4765:if(pt(e)-1-t>6)switch(Ne(e,t+1)){case 109:if(Ne(e,t+4)!==45)break;case 102:return Y(e,/(.+:)(.+)-([^]+)/,"$1"+X+"$2-$3$1"+Di+(Ne(e,t+3)==108?"$3":"$2-$3"))+e;case 115:return~Ni(e,"stretch")?np(Y(e,"stretch","fill-available"),t)+e:e}break;case 4949:if(Ne(e,t+1)!==115)break;case 6444:switch(Ne(e,pt(e)-3-(~Ni(e,"!important")&&10))){case 107:return Y(e,":",":"+X)+e;case 101:return Y(e,/(.+:)([^;!]+)(;|!.+)?/,"$1"+X+(Ne(e,14)===45?"inline-":"")+"box$3$1"+X+"$2$3$1"+nt+"$2box$3")+e}break;case 5936:switch(Ne(e,t+11)){case 114:return X+e+nt+Y(e,/[svh]\w+-[tblr]{2}/,"tb")+e;case 108:return X+e+nt+Y(e,/[svh]\w+-[tblr]{2}/,"tb-rl")+e;case 45:return X+e+nt+Y(e,/[svh]\w+-[tblr]{2}/,"lr")+e}return X+e+nt+e+e}return e}var VQ,YQ,WQ,rp,zQ,$Q,KQ,XQ,op,eA=g(()=>{_g();ep();sa();Zl();VQ=function(t,r,n){for(var o=0,i=0;o=i,i=jt(),o===38&&i===12&&(r[n]=1),!To(i);)Ct();return Do(t,ht)},YQ=function(t,r){var n=-1,o=44;do switch(To(o)){case 0:o===38&&jt()===12&&(r[n]=1),t[n]+=VQ(ht-1,r,n);break;case 2:t[n]+=No(o);break;case 4:if(o===44){t[++n]=jt()===58?"&\f":"",r[n]=t[n].length;break}default:t[n]+=Rn(o)}while(o=Ct());return t},WQ=function(t,r){return oa(YQ(na(t),r))},rp=new WeakMap,zQ=function(t){if(!(t.type!=="rule"||!t.parent||t.length<1)){for(var r=t.value,n=t.parent,o=t.column===n.column&&t.line===n.line;n.type!=="rule";)if(n=n.parent,!n)return;if(!(t.props.length===1&&r.charCodeAt(0)!==58&&!rp.get(n))&&!o){rp.set(t,!0);for(var i=[],s=WQ(r,i),a=n.props,c=0,l=0;c<s.length;c++)for(var A=0;A<a.length;A++,l++)t.props[l]=i[c]?s[c].replace(/&\f/g,a[A]):a[A]+" "+s[c]}}},$Q=function(t){if(t.type==="decl"){var r=t.value;r.charCodeAt(0)===108&&r.charCodeAt(2)===98&&(t.return="",t.value="")}};KQ=function(t,r,n,o){if(t.length>-1&&!t.return)switch(t.type){case Bo:t.return=np(t.value,t.length);break;case Zs:return Pn([ko(t,{value:Y(t.value,"@","@"+X)})],o);case wo:if(t.length)return $l(t.props,function(i){switch(zl(i,/(::plac\w+|:read-\w+)/)){case":read-only":case":read-write":return Pn([ko(t,{props:[Y(i,/:(read-\w+)/,":"+Di+"$1")]})],o);case"::placeholder":return Pn([ko(t,{props:[Y(i,/:(plac\w+)/,":"+X+"input-$1")]}),ko(t,{props:[Y(i,/:(plac\w+)/,":"+Di+"$1")]}),ko(t,{props:[Y(i,/:(plac\w+)/,nt+"input-$1")]})],o)}return""})}},XQ=[KQ],op=function(t){var r=t.key;if(r==="css"){var n=document.querySelectorAll("style[data-emotion]:not([data-s])");Array.prototype.forEach.call(n,function(E){var x=E.getAttribute("data-emotion");x.indexOf(" ")!==-1&&(document.head.appendChild(E),E.setAttribute("data-s",""))})}var o=t.stylisPlugins||XQ,i={},s,a=[];s=t.container||document.head,Array.prototype.forEach.call(document.querySelectorAll('style[data-emotion^="'+r+' "]'),function(E){for(var x=E.getAttribute("data-emotion").split(" "),I=1;I<x.length;I++)i[x[I]]=!0;a.push(E)});var c,l=[zQ,$Q];{var A,u=[zg,Xg(function(E){A.insert(E)})],m=Kg(l.concat(o,u)),d=function(x){return Pn(Vg(x),m)};c=function(x,I,h,y){A=h,d(x?x+"{"+I.styles+"}":I.styles),y&&(p.inserted[I.name]=!0)}}var p={key:r,sheet:new Tg({key:r,container:s,nonce:t.nonce,speedy:t.speedy,prepend:t.prepend,insertionPoint:t.insertionPoint}),nonce:t.nonce,inserted:i,registered:{},insert:c};return p.sheet.hydrate(a),p}});var tA=g(()=>{});var sp=U(ie=>{"use strict";var We=typeof Symbol=="function"&&Symbol.for,rA=We?Symbol.for("react.element"):60103,nA=We?Symbol.for("react.portal"):60106,aa=We?Symbol.for("react.fragment"):60107,ca=We?Symbol.for("react.strict_mode"):60108,la=We?Symbol.for("react.profiler"):60114,Aa=We?Symbol.for("react.provider"):60109,ua=We?Symbol.for("react.context"):60110,oA=We?Symbol.for("react.async_mode"):60111,fa=We?Symbol.for("react.concurrent_mode"):60111,ma=We?Symbol.for("react.forward_ref"):60112,da=We?Symbol.for("react.suspense"):60113,ZQ=We?Symbol.for("react.suspense_list"):60120,ga=We?Symbol.for("react.memo"):60115,pa=We?Symbol.for("react.lazy"):60116,eM=We?Symbol.for("react.block"):60121,tM=We?Symbol.for("react.fundamental"):60117,rM=We?Symbol.for("react.responder"):60118,nM=We?Symbol.for("react.scope"):60119;function kt(e){if(typeof e=="object"&&e!==null){var t=e.$$typeof;switch(t){case rA:switch(e=e.type,e){case oA:case fa:case aa:case la:case ca:case da:return e;default:switch(e=e&&e.$$typeof,e){case ua:case ma:case pa:case ga:case Aa:return e;default:return t}}case nA:return t}}}function ip(e){return kt(e)===fa}ie.AsyncMode=oA;ie.ConcurrentMode=fa;ie.ContextConsumer=ua;ie.ContextProvider=Aa;ie.Element=rA;ie.ForwardRef=ma;ie.Fragment=aa;ie.Lazy=pa;ie.Memo=ga;ie.Portal=nA;ie.Profiler=la;ie.StrictMode=ca;ie.Suspense=da;ie.isAsyncMode=function(e){return ip(e)||kt(e)===oA};ie.isConcurrentMode=ip;ie.isContextConsumer=function(e){return kt(e)===ua};ie.isContextProvider=function(e){return kt(e)===Aa};ie.isElement=function(e){return typeof e=="object"&&e!==null&&e.$$typeof===rA};ie.isForwardRef=function(e){return kt(e)===ma};ie.isFragment=function(e){return kt(e)===aa};ie.isLazy=function(e){return kt(e)===pa};ie.isMemo=function(e){return kt(e)===ga};ie.isPortal=function(e){return kt(e)===nA};ie.isProfiler=function(e){return kt(e)===la};ie.isStrictMode=function(e){return kt(e)===ca};ie.isSuspense=function(e){return kt(e)===da};ie.isValidElementType=function(e){return typeof e=="string"||typeof e=="function"||e===aa||e===fa||e===la||e===ca||e===da||e===ZQ||typeof e=="object"&&e!==null&&(e.$$typeof===pa||e.$$typeof===ga||e.$$typeof===Aa||e.$$typeof===ua||e.$$typeof===ma||e.$$typeof===tM||e.$$typeof===rM||e.$$typeof===nM||e.$$typeof===eM)};ie.typeOf=kt});var cp=U((wF,ap)=>{"use strict";ap.exports=sp()});var gp=U((BF,dp)=>{"use strict";var iA=cp(),oM={childContextTypes:!0,contextType:!0,contextTypes:!0,defaultProps:!0,displayName:!0,getDefaultProps:!0,getDerivedStateFromError:!0,getDerivedStateFromProps:!0,mixins:!0,propTypes:!0,type:!0},iM={name:!0,length:!0,prototype:!0,caller:!0,callee:!0,arguments:!0,arity:!0},sM={$$typeof:!0,render:!0,defaultProps:!0,displayName:!0,propTypes:!0},fp={$$typeof:!0,compare:!0,defaultProps:!0,displayName:!0,propTypes:!0,type:!0},sA={};sA[iA.ForwardRef]=sM;sA[iA.Memo]=fp;function lp(e){return iA.isMemo(e)?fp:sA[e.$$typeof]||oM}var aM=Object.defineProperty,cM=Object.getOwnPropertyNames,Ap=Object.getOwnPropertySymbols,lM=Object.getOwnPropertyDescriptor,AM=Object.getPrototypeOf,up=Object.prototype;function mp(e,t,r){if(typeof t!="string"){if(up){var n=AM(t);n&&n!==up&&mp(e,n,r)}var o=cM(t);Ap&&(o=o.concat(Ap(t)));for(var i=lp(e),s=lp(t),a=0;a<o.length;++a){var c=o[a];if(!iM[c]&&!(r&&r[c])&&!(s&&s[c])&&!(i&&i[c])){var l=lM(t,c);try{aM(e,c,l)}catch{}}}}return e}dp.exports=mp});function Ri(e,t,r){var n="";return r.split(" ").forEach(function(o){e[o]!==void 0?t.push(e[o]+";"):o&&(n+=o+" ")}),n}var uM,ha,Pi,Ca=g(()=>{uM=!0;ha=function(t,r,n){var o=t.key+"-"+r.name;(n===!1||uM===!1)&&t.registered[o]===void 0&&(t.registered[o]=r.styles)},Pi=function(t,r,n){ha(t,r,n);var o=t.key+"-"+r.name;if(t.inserted[r.name]===void 0){var i=r;do t.insert(r===i?"."+o:"",i,t.sheet,!0),i=i.next;while(i!==void 0)}}});function pp(e){for(var t=0,r,n=0,o=e.length;o>=4;++n,o-=4)r=e.charCodeAt(n)&255|(e.charCodeAt(++n)&255)<<8|(e.charCodeAt(++n)&255)<<16|(e.charCodeAt(++n)&255)<<24,r=(r&65535)*1540483477+((r>>>16)*59797<<16),r^=r>>>24,t=(r&65535)*1540483477+((r>>>16)*59797<<16)^(t&65535)*1540483477+((t>>>16)*59797<<16);switch(o){case 3:t^=(e.charCodeAt(n+2)&255)<<16;case 2:t^=(e.charCodeAt(n+1)&255)<<8;case 1:t^=e.charCodeAt(n)&255,t=(t&65535)*1540483477+((t>>>16)*59797<<16)}return t^=t>>>13,t=(t&65535)*1540483477+((t>>>16)*59797<<16),((t^t>>>15)>>>0).toString(36)}var hp=g(()=>{});var Cp,Ep=g(()=>{Cp={animationIterationCount:1,aspectRatio:1,borderImageOutset:1,borderImageSlice:1,borderImageWidth:1,boxFlex:1,boxFlexGroup:1,boxOrdinalGroup:1,columnCount:1,columns:1,flex:1,flexGrow:1,flexPositive:1,flexShrink:1,flexNegative:1,flexOrder:1,gridRow:1,gridRowEnd:1,gridRowSpan:1,gridRowStart:1,gridColumn:1,gridColumnEnd:1,gridColumnSpan:1,gridColumnStart:1,msGridRow:1,msGridRowSpan:1,msGridColumn:1,msGridColumnSpan:1,fontWeight:1,lineHeight:1,opacity:1,order:1,orphans:1,scale:1,tabSize:1,widows:1,zIndex:1,zoom:1,WebkitLineClamp:1,fillOpacity:1,floodOpacity:1,stopOpacity:1,strokeDasharray:1,strokeDashoffset:1,strokeMiterlimit:1,strokeOpacity:1,strokeWidth:1}});function Oi(e,t,r){if(r==null)return"";var n=r;if(n.__emotion_styles!==void 0)return n;switch(typeof r){case"boolean":return"";case"object":{var o=r;if(o.anim===1)return wr={name:o.name,styles:o.styles,next:wr},o.name;var i=r;if(i.styles!==void 0){var s=i.next;if(s!==void 0)for(;s!==void 0;)wr={name:s.name,styles:s.styles,next:wr},s=s.next;var a=i.styles+";";return a}return pM(e,t,r)}case"function":{if(e!==void 0){var c=wr,l=r(e);return wr=c,Oi(e,t,l)}break}}var A=r;if(t==null)return A;var u=t[A];return u!==void 0?u:A}function pM(e,t,r){var n="";if(Array.isArray(r))for(var o=0;o<r.length;o++)n+=Oi(e,t,r[o])+";";else for(var i in r){var s=r[i];if(typeof s!="object"){var a=s;t!=null&&t[a]!==void 0?n+=i+"{"+t[a]+"}":Ip(a)&&(n+=aA(i)+":"+xp(i,a)+";")}else{if(i==="NO_COMPONENT_SELECTOR"&&fM)throw new Error(gM);if(Array.isArray(s)&&typeof s[0]=="string"&&(t==null||t[s[0]]===void 0))for(var c=0;c<s.length;c++)Ip(s[c])&&(n+=aA(i)+":"+xp(i,s[c])+";");else{var l=Oi(e,t,s);switch(i){case"animation":case"animationName":{n+=aA(i)+":"+l+";";break}default:n+=i+"{"+l+"}"}}}}return n}function Lo(e,t,r){if(e.length===1&&typeof e[0]=="object"&&e[0]!==null&&e[0].styles!==void 0)return e[0];var n=!0,o="";wr=void 0;var i=e[0];if(i==null||i.raw===void 0)n=!1,o+=Oi(r,t,i);else{var s=i;o+=s[0]}for(var a=1;a<e.length;a++)if(o+=Oi(r,t,e[a]),n){var c=i;o+=c[a]}yp.lastIndex=0;for(var l="",A;(A=yp.exec(o))!==null;)l+="-"+A[1];var u=pp(o)+l;return{name:u,styles:o,next:wr}}var fM,mM,dM,bp,Ip,aA,xp,gM,yp,wr,Ea=g(()=>{hp();Ep();Zl();fM=!1,mM=/[A-Z]|^ms/g,dM=/_EMO_([^_]+?)_([^]*?)_EMO_/g,bp=function(t){return t.charCodeAt(1)===45},Ip=function(t){return t!=null&&typeof t!="boolean"},aA=tp(function(e){return bp(e)?e:e.replace(mM,"-$&").toLowerCase()}),xp=function(t,r){switch(t){case"animation":case"animationName":if(typeof r=="string")return r.replace(dM,function(n,o,i){return wr={name:o,styles:i,next:wr},o})}return Cp[t]!==1&&!bp(t)&&typeof r=="number"&&r!==0?r+"px":r},gM="Component selectors can only be used in conjunction with @emotion/babel-plugin, the swc Emotion plugin, or another Emotion-aware compiler transform.";yp=/label:\s*([^\s;{]+)\s*(;|$)/g});var Ia,hM,CM,cA,lA=g(()=>{Ia=f(w()),hM=function(t){return t()},CM=Ia.useInsertionEffect?Ia.useInsertionEffect:!1,cA=CM||hM});var qt,Gi,wp,uA,EM,fA,mA,dA,xa,AA,Bp,IM,xM,Sp,gA=g(()=>{qt=f(w()),Gi=f(w());eA();tA();sa();Ca();Ea();lA();wp=!1,uA=qt.createContext(typeof HTMLElement<"u"?op({key:"css"}):null),EM=uA.Provider,fA=function(){return(0,Gi.useContext)(uA)},mA=function(t){return(0,Gi.forwardRef)(function(r,n){var o=(0,Gi.useContext)(uA);return t(r,o,n)})},dA=qt.createContext({}),xa={}.hasOwnProperty,AA="__EMOTION_TYPE_PLEASE_DO_NOT_USE__",Bp=function(t,r){var n={};for(var o in r)xa.call(r,o)&&(n[o]=r[o]);return n[AA]=t,n},IM=function(t){var r=t.cache,n=t.serialized,o=t.isStringTag;return ha(r,n,o),cA(function(){return Pi(r,n,o)}),null},xM=mA(function(e,t,r){var n=e.css;typeof n=="string"&&t.registered[n]!==void 0&&(n=t.registered[n]);var o=e[AA],i=[n],s="";typeof e.className=="string"?s=Ri(t.registered,i,e.className):e.className!=null&&(s=e.className+" ");var a=Lo(i,void 0,qt.useContext(dA));s+=t.key+"-"+a.name;var c={};for(var l in e)xa.call(e,l)&&l!=="css"&&l!==AA&&!wp&&(c[l]=e[l]);return c.className=s,r&&(c.ref=r),qt.createElement(qt.Fragment,null,qt.createElement(IM,{cache:t,serialized:a,isStringTag:typeof o=="string"}),qt.createElement(o,c))}),Sp=xM});function yM(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];return Lo(t)}function pA(){var e=yM.apply(void 0,arguments),t="animation-"+e.name;return{name:t,styles:"@keyframes "+t+"{"+e.styles+"}",anim:1,toString:function(){return"_EMO_"+this.name+"_"+this.styles+"_EMO_"}}}var Fo,eR,Qp,hA=g(()=>{gA();gA();Fo=f(w());Ca();lA();Ea();eA();tA();sa();eR=f(gp()),Qp=function(t,r){var n=arguments;if(r==null||!xa.call(r,"css"))return Fo.createElement.apply(void 0,n);var o=n.length,i=new Array(o);i[0]=Sp,i[1]=Bp(t,r);for(var s=2;s<o;s++)i[s]=n[s];return Fo.createElement.apply(null,i)};(function(e){var t;t||(t=e.JSX||(e.JSX={}))})(Qp||(Qp={}))});var CA=U((nR,Mp)=>{Mp.exports=JBrowseExports["@mui/material/styles"]});var Ro,EA=g(()=>{Ro=e=>{let t=e.length,r=0,n="";for(;r<t;r++){let o=e[r];if(o==null)continue;let i;switch(typeof o){case"boolean":break;case"object":{if(Array.isArray(o))i=Ro(o);else{let s=o;i="";for(let a in s)s[a]&&a&&(i&&(i+=" "),i+=a)}break}default:i=o}i&&(n&&(n+=" "),n+=i)}return n}});function vp(e){return e instanceof Object&&!("styles"in e)&&!("length"in e)&&!("__emotion_styles"in e)}var Tp=g(()=>{});function Dp(e){let{useCache:t}=e;function r(){let n=t(),{css:o,cx:i}=(0,kp.useMemo)(()=>bM({cache:n}),[n]);return{css:o,cx:i}}return{useCssAndCx:r}}var kp,bM,_p,Np=g(()=>{kp=f(w(),1);Ea();Ca();EA();Tp();({createCssAndCx:bM}=(()=>{function e(r,n,o){let i=[],s=Ri(r,i,o);return i.length<2?o:s+n(i)}function t(r){let{cache:n}=r,o=(...s)=>{let a=Lo(s,n.registered);Pi(n,a,!1);let c=`${n.key}-${a.name}`;e:{let l=s[0];if(!vp(l))break e;_p.saveClassNameCSSObjectMapping(n,c,l)}return c};return{css:o,cx:(...s)=>{let a=Ro(s),c=_p.fixClassName(n,a,o);return e(n.registered,o,c)}}}return{createCssAndCx:t}})());_p=(()=>{let e=new WeakMap;return{saveClassNameCSSObjectMapping:(t,r,n)=>{let o=e.get(t);o===void 0&&(o=new Map,e.set(t,o)),o.set(r,n)},fixClassName:(()=>{function t(r){let n=!1;return r.map(([o,i])=>{if(i===void 0)return o;let s;if(n)s={"&&":i};else{s=o;for(let a in i)if(a.startsWith("@media")){n=!0;break}}return s})}return(r,n,o)=>{if(!n.includes(" "))return n;let i=e.get(r);return Ro(t(n.split(" ").map(s=>[s,i?.get(s)])).map(s=>typeof s=="string"?s:o(s)))}})()}})()});function Lp(e,t,r){if(!(t instanceof Object))return e;let n=Object.keys(t);if(n.length===0)return e;let o={};for(let i of Object.keys(e))o[i]=r(e[i],t[i]);for(let i of n){if(i in e)continue;let s=t[i];typeof s=="string"&&(o[i]=s)}return o}var Fp=g(()=>{});function Rp(e){if(!(e instanceof Object)||typeof e=="function")return e;let t=[];for(let r in e){let n=e[r],o=typeof n;if(!(o==="string"||o==="number"&&!isNaN(n)||o==="boolean"||n===void 0||n===null))return e;t.push(`${r}:${o}_${n}`)}return`xSqLiJdLMd9s${t.join("|")}`}var Pp=g(()=>{});function Op(e){let{useTheme:t}=e,{useCssAndCx:r}=Dp({useCache:wM});function n(){return function(o){let i=typeof o=="function"?o:()=>o;return function(a,c){let l=t(),{css:A,cx:u}=r(),m=(0,IA.useMemo)(()=>{let x=i(l),I={};for(let h of Object.keys(x)){let y=x[h];I[h]=A(y)}return I},[A,l]),d=c?.props.classes,p=Rp(d);return{classes:(0,IA.useMemo)(()=>d?Lp(m,d,u):m,[m,p,u]),theme:l,css:A,cx:u}}}}return{makeStyles:n}}var IA,wM,Gp=g(()=>{"use client";IA=f(w(),1);hA();Np();Fp();Pp();wM=fA});var Up,te,Hp=g(()=>{Up=f(CA(),1);Gp();({makeStyles:te}=Op({useTheme:Up.useTheme}))});var jp=g(()=>{Hp()});function ya(...e){return Ro(e)}var Et=g(()=>{"use client";hA();jp();EA()});function xA({children:e}){let{classes:t}=BM();return(0,qp.jsx)("div",{className:t.bg,children:e})}var qp,BM,Jp=g(()=>{qp=f(R(),1);Et();BM=te()(e=>({bg:{padding:4,margin:4,overflow:"auto",maxHeight:200,background:e.palette.mode==="dark"?"#833":"#f88",border:`1px solid ${e.palette.divider}`}}))});var Yp=U(yA=>{var Vp="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".split("");yA.encode=function(e){if(0<=e&&e<Vp.length)return Vp[e];throw new TypeError("Must be between 0 and 63: "+e)};yA.decode=function(e){var t=65,r=90,n=97,o=122,i=48,s=57,a=43,c=47,l=26,A=52;return t<=e&&e<=r?e-t:n<=e&&e<=o?e-n+l:i<=e&&e<=s?e-i+A:e==a?62:e==c?63:-1}});var BA=U(wA=>{var Wp=Yp(),bA=5,zp=1<<bA,$p=zp-1,Kp=zp;function SM(e){return e<0?(-e<<1)+1:(e<<1)+0}function QM(e){var t=(e&1)===1,r=e>>1;return t?-r:r}wA.encode=function(t){var r="",n,o=SM(t);do n=o&$p,o>>>=bA,o>0&&(n|=Kp),r+=Wp.encode(n);while(o>0);return r};wA.decode=function(t,r,n){var o=t.length,i=0,s=0,a,c;do{if(r>=o)throw new Error("Expected more digits in base 64 VLQ value.");if(c=Wp.decode(t.charCodeAt(r++)),c===-1)throw new Error("Invalid base64 digit: "+t.charAt(r-1));a=!!(c&Kp),c&=$p,i=i+(c<<s),s+=bA}while(a);n.value=QM(i),n.rest=r}});var Oo=U(ze=>{function MM(e,t,r){if(t in e)return e[t];if(arguments.length===3)return r;throw new Error('"'+t+'" is a required argument.')}ze.getArg=MM;var Xp=/^(?:([\w+\-.]+):)?\/\/(?:(\w+:\w+)@)?([\w.-]*)(?::(\d+))?(.*)$/,vM=/^data:.+\,.+$/;function Ui(e){var t=e.match(Xp);return t?{scheme:t[1],auth:t[2],host:t[3],port:t[4],path:t[5]}:null}ze.urlParse=Ui;function Po(e){var t="";return e.scheme&&(t+=e.scheme+":"),t+="//",e.auth&&(t+=e.auth+"@"),e.host&&(t+=e.host),e.port&&(t+=":"+e.port),e.path&&(t+=e.path),t}ze.urlGenerate=Po;var TM=32;function _M(e){var t=[];return function(r){for(var n=0;n<t.length;n++)if(t[n].input===r){var o=t[0];return t[0]=t[n],t[n]=o,t[0].result}var i=e(r);return t.unshift({input:r,result:i}),t.length>TM&&t.pop(),i}}var SA=_M(function(t){var r=t,n=Ui(t);if(n){if(!n.path)return t;r=n.path}for(var o=ze.isAbsolute(r),i=[],s=0,a=0;;)if(s=a,a=r.indexOf("/",s),a===-1){i.push(r.slice(s));break}else for(i.push(r.slice(s,a));a<r.length&&r[a]==="/";)a++;for(var c,l=0,a=i.length-1;a>=0;a--)c=i[a],c==="."?i.splice(a,1):c===".."?l++:l>0&&(c===""?(i.splice(a+1,l),l=0):(i.splice(a,2),l--));return r=i.join("/"),r===""&&(r=o?"/":"."),n?(n.path=r,Po(n)):r});ze.normalize=SA;function Zp(e,t){e===""&&(e="."),t===""&&(t=".");var r=Ui(t),n=Ui(e);if(n&&(e=n.path||"/"),r&&!r.scheme)return n&&(r.scheme=n.scheme),Po(r);if(r||t.match(vM))return t;if(n&&!n.host&&!n.path)return n.host=t,Po(n);var o=t.charAt(0)==="/"?t:SA(e.replace(/\/+$/,"")+"/"+t);return n?(n.path=o,Po(n)):o}ze.join=Zp;ze.isAbsolute=function(e){return e.charAt(0)==="/"||Xp.test(e)};function kM(e,t){e===""&&(e="."),e=e.replace(/\/$/,"");for(var r=0;t.indexOf(e+"/")!==0;){var n=e.lastIndexOf("/");if(n<0||(e=e.slice(0,n),e.match(/^([^\/]+:\/)?\/*$/)))return t;++r}return Array(r+1).join("../")+t.substr(e.length+1)}ze.relative=kM;var eh=(function(){var e=Object.create(null);return!("__proto__"in e)})();function th(e){return e}function DM(e){return rh(e)?"$"+e:e}ze.toSetString=eh?th:DM;function NM(e){return rh(e)?e.slice(1):e}ze.fromSetString=eh?th:NM;function rh(e){if(!e)return!1;var t=e.length;if(t<9||e.charCodeAt(t-1)!==95||e.charCodeAt(t-2)!==95||e.charCodeAt(t-3)!==111||e.charCodeAt(t-4)!==116||e.charCodeAt(t-5)!==111||e.charCodeAt(t-6)!==114||e.charCodeAt(t-7)!==112||e.charCodeAt(t-8)!==95||e.charCodeAt(t-9)!==95)return!1;for(var r=t-10;r>=0;r--)if(e.charCodeAt(r)!==36)return!1;return!0}function LM(e,t,r){var n=Hr(e.source,t.source);return n!==0||(n=e.originalLine-t.originalLine,n!==0)||(n=e.originalColumn-t.originalColumn,n!==0||r)||(n=e.generatedColumn-t.generatedColumn,n!==0)||(n=e.generatedLine-t.generatedLine,n!==0)?n:Hr(e.name,t.name)}ze.compareByOriginalPositions=LM;function FM(e,t,r){var n;return n=e.originalLine-t.originalLine,n!==0||(n=e.originalColumn-t.originalColumn,n!==0||r)||(n=e.generatedColumn-t.generatedColumn,n!==0)||(n=e.generatedLine-t.generatedLine,n!==0)?n:Hr(e.name,t.name)}ze.compareByOriginalPositionsNoSource=FM;function RM(e,t,r){var n=e.generatedLine-t.generatedLine;return n!==0||(n=e.generatedColumn-t.generatedColumn,n!==0||r)||(n=Hr(e.source,t.source),n!==0)||(n=e.originalLine-t.originalLine,n!==0)||(n=e.originalColumn-t.originalColumn,n!==0)?n:Hr(e.name,t.name)}ze.compareByGeneratedPositionsDeflated=RM;function PM(e,t,r){var n=e.generatedColumn-t.generatedColumn;return n!==0||r||(n=Hr(e.source,t.source),n!==0)||(n=e.originalLine-t.originalLine,n!==0)||(n=e.originalColumn-t.originalColumn,n!==0)?n:Hr(e.name,t.name)}ze.compareByGeneratedPositionsDeflatedNoLine=PM;function Hr(e,t){return e===t?0:e===null?1:t===null?-1:e>t?1:-1}function OM(e,t){var r=e.generatedLine-t.generatedLine;return r!==0||(r=e.generatedColumn-t.generatedColumn,r!==0)||(r=Hr(e.source,t.source),r!==0)||(r=e.originalLine-t.originalLine,r!==0)||(r=e.originalColumn-t.originalColumn,r!==0)?r:Hr(e.name,t.name)}ze.compareByGeneratedPositionsInflated=OM;function GM(e){return JSON.parse(e.replace(/^\)]}'[^\n]*\n/,""))}ze.parseSourceMapInput=GM;function UM(e,t,r){if(t=t||"",e&&(e[e.length-1]!=="/"&&t[0]!=="/"&&(e+="/"),t=e+t),r){var n=Ui(r);if(!n)throw new Error("sourceMapURL could not be parsed");if(n.path){var o=n.path.lastIndexOf("/");o>=0&&(n.path=n.path.substring(0,o+1))}t=Zp(Po(n),t)}return SA(t)}ze.computeSourceURL=UM});var vA=U(nh=>{var QA=Oo(),MA=Object.prototype.hasOwnProperty,On=typeof Map<"u";function jr(){this._array=[],this._set=On?new Map:Object.create(null)}jr.fromArray=function(t,r){for(var n=new jr,o=0,i=t.length;o<i;o++)n.add(t[o],r);return n};jr.prototype.size=function(){return On?this._set.size:Object.getOwnPropertyNames(this._set).length};jr.prototype.add=function(t,r){var n=On?t:QA.toSetString(t),o=On?this.has(t):MA.call(this._set,n),i=this._array.length;(!o||r)&&this._array.push(t),o||(On?this._set.set(t,i):this._set[n]=i)};jr.prototype.has=function(t){if(On)return this._set.has(t);var r=QA.toSetString(t);return MA.call(this._set,r)};jr.prototype.indexOf=function(t){if(On){var r=this._set.get(t);if(r>=0)return r}else{var n=QA.toSetString(t);if(MA.call(this._set,n))return this._set[n]}throw new Error('"'+t+'" is not in the set.')};jr.prototype.at=function(t){if(t>=0&&t<this._array.length)return this._array[t];throw new Error("No element indexed by "+t)};jr.prototype.toArray=function(){return this._array.slice()};nh.ArraySet=jr});var sh=U(ih=>{var oh=Oo();function HM(e,t){var r=e.generatedLine,n=t.generatedLine,o=e.generatedColumn,i=t.generatedColumn;return n>r||n==r&&i>=o||oh.compareByGeneratedPositionsInflated(e,t)<=0}function ba(){this._array=[],this._sorted=!0,this._last={generatedLine:-1,generatedColumn:0}}ba.prototype.unsortedForEach=function(t,r){this._array.forEach(t,r)};ba.prototype.add=function(t){HM(this._last,t)?(this._last=t,this._array.push(t)):(this._sorted=!1,this._array.push(t))};ba.prototype.toArray=function(){return this._sorted||(this._array.sort(oh.compareByGeneratedPositionsInflated),this._sorted=!0),this._array};ih.MappingList=ba});var TA=U(ah=>{var Hi=BA(),Le=Oo(),wa=vA().ArraySet,jM=sh().MappingList;function Jt(e){e||(e={}),this._file=Le.getArg(e,"file",null),this._sourceRoot=Le.getArg(e,"sourceRoot",null),this._skipValidation=Le.getArg(e,"skipValidation",!1),this._ignoreInvalidMapping=Le.getArg(e,"ignoreInvalidMapping",!1),this._sources=new wa,this._names=new wa,this._mappings=new jM,this._sourcesContents=null}Jt.prototype._version=3;Jt.fromSourceMap=function(t,r){var n=t.sourceRoot,o=new Jt(Object.assign(r||{},{file:t.file,sourceRoot:n}));return t.eachMapping(function(i){var s={generated:{line:i.generatedLine,column:i.generatedColumn}};i.source!=null&&(s.source=i.source,n!=null&&(s.source=Le.relative(n,s.source)),s.original={line:i.originalLine,column:i.originalColumn},i.name!=null&&(s.name=i.name)),o.addMapping(s)}),t.sources.forEach(function(i){var s=i;n!==null&&(s=Le.relative(n,i)),o._sources.has(s)||o._sources.add(s);var a=t.sourceContentFor(i);a!=null&&o.setSourceContent(i,a)}),o};Jt.prototype.addMapping=function(t){var r=Le.getArg(t,"generated"),n=Le.getArg(t,"original",null),o=Le.getArg(t,"source",null),i=Le.getArg(t,"name",null);!this._skipValidation&&this._validateMapping(r,n,o,i)===!1||(o!=null&&(o=String(o),this._sources.has(o)||this._sources.add(o)),i!=null&&(i=String(i),this._names.has(i)||this._names.add(i)),this._mappings.add({generatedLine:r.line,generatedColumn:r.column,originalLine:n!=null&&n.line,originalColumn:n!=null&&n.column,source:o,name:i}))};Jt.prototype.setSourceContent=function(t,r){var n=t;this._sourceRoot!=null&&(n=Le.relative(this._sourceRoot,n)),r!=null?(this._sourcesContents||(this._sourcesContents=Object.create(null)),this._sourcesContents[Le.toSetString(n)]=r):this._sourcesContents&&(delete this._sourcesContents[Le.toSetString(n)],Object.keys(this._sourcesContents).length===0&&(this._sourcesContents=null))};Jt.prototype.applySourceMap=function(t,r,n){var o=r;if(r==null){if(t.file==null)throw new Error(`SourceMapGenerator.prototype.applySourceMap requires either an explicit source file, or the source map's "file" property. Both were omitted.`);o=t.file}var i=this._sourceRoot;i!=null&&(o=Le.relative(i,o));var s=new wa,a=new wa;this._mappings.unsortedForEach(function(c){if(c.source===o&&c.originalLine!=null){var l=t.originalPositionFor({line:c.originalLine,column:c.originalColumn});l.source!=null&&(c.source=l.source,n!=null&&(c.source=Le.join(n,c.source)),i!=null&&(c.source=Le.relative(i,c.source)),c.originalLine=l.line,c.originalColumn=l.column,l.name!=null&&(c.name=l.name))}var A=c.source;A!=null&&!s.has(A)&&s.add(A);var u=c.name;u!=null&&!a.has(u)&&a.add(u)},this),this._sources=s,this._names=a,t.sources.forEach(function(c){var l=t.sourceContentFor(c);l!=null&&(n!=null&&(c=Le.join(n,c)),i!=null&&(c=Le.relative(i,c)),this.setSourceContent(c,l))},this)};Jt.prototype._validateMapping=function(t,r,n,o){if(r&&typeof r.line!="number"&&typeof r.column!="number"){var i="original.line and original.column are not numbers -- you probably meant to omit the original mapping entirely and only map the generated position. If so, pass null for the original mapping instead of an object with empty or null values.";if(this._ignoreInvalidMapping)return typeof console<"u"&&console.warn&&console.warn(i),!1;throw new Error(i)}if(!(t&&"line"in t&&"column"in t&&t.line>0&&t.column>=0&&!r&&!n&&!o)){if(t&&"line"in t&&"column"in t&&r&&"line"in r&&"column"in r&&t.line>0&&t.column>=0&&r.line>0&&r.column>=0&&n)return;var i="Invalid mapping: "+JSON.stringify({generated:t,source:n,original:r,name:o});if(this._ignoreInvalidMapping)return typeof console<"u"&&console.warn&&console.warn(i),!1;throw new Error(i)}};Jt.prototype._serializeMappings=function(){for(var t=0,r=1,n=0,o=0,i=0,s=0,a="",c,l,A,u,m=this._mappings.toArray(),d=0,p=m.length;d<p;d++){if(l=m[d],c="",l.generatedLine!==r)for(t=0;l.generatedLine!==r;)c+=";",r++;else if(d>0){if(!Le.compareByGeneratedPositionsInflated(l,m[d-1]))continue;c+=","}c+=Hi.encode(l.generatedColumn-t),t=l.generatedColumn,l.source!=null&&(u=this._sources.indexOf(l.source),c+=Hi.encode(u-s),s=u,c+=Hi.encode(l.originalLine-1-o),o=l.originalLine-1,c+=Hi.encode(l.originalColumn-n),n=l.originalColumn,l.name!=null&&(A=this._names.indexOf(l.name),c+=Hi.encode(A-i),i=A)),a+=c}return a};Jt.prototype._generateSourcesContent=function(t,r){return t.map(function(n){if(!this._sourcesContents)return null;r!=null&&(n=Le.relative(r,n));var o=Le.toSetString(n);return Object.prototype.hasOwnProperty.call(this._sourcesContents,o)?this._sourcesContents[o]:null},this)};Jt.prototype.toJSON=function(){var t={version:this._version,sources:this._sources.toArray(),names:this._names.toArray(),mappings:this._serializeMappings()};return this._file!=null&&(t.file=this._file),this._sourceRoot!=null&&(t.sourceRoot=this._sourceRoot),this._sourcesContents&&(t.sourcesContent=this._generateSourcesContent(t.sources,t.sourceRoot)),t};Jt.prototype.toString=function(){return JSON.stringify(this.toJSON())};ah.SourceMapGenerator=Jt});var ch=U(Gn=>{Gn.GREATEST_LOWER_BOUND=1;Gn.LEAST_UPPER_BOUND=2;function _A(e,t,r,n,o,i){var s=Math.floor((t-e)/2)+e,a=o(r,n[s],!0);return a===0?s:a>0?t-s>1?_A(s,t,r,n,o,i):i==Gn.LEAST_UPPER_BOUND?t<n.length?t:-1:s:s-e>1?_A(e,s,r,n,o,i):i==Gn.LEAST_UPPER_BOUND?s:e<0?-1:e}Gn.search=function(t,r,n,o){if(r.length===0)return-1;var i=_A(-1,r.length,t,r,n,o||Gn.GREATEST_LOWER_BOUND);if(i<0)return-1;for(;i-1>=0&&n(r[i],r[i-1],!0)===0;)--i;return i}});var uh=U(Ah=>{function qM(e){function t(o,i,s){var a=o[i];o[i]=o[s],o[s]=a}function r(o,i){return Math.round(o+Math.random()*(i-o))}function n(o,i,s,a){if(s<a){var c=r(s,a),l=s-1;t(o,c,a);for(var A=o[a],u=s;u<a;u++)i(o[u],A,!1)<=0&&(l+=1,t(o,l,u));t(o,l+1,u);var m=l+1;n(o,i,s,m-1),n(o,i,m+1,a)}}return n}function JM(e){let t=qM.toString();return new Function(`return ${t}`)()(e)}var lh=new WeakMap;Ah.quickSort=function(e,t,r=0){let n=lh.get(t);n===void 0&&(n=JM(t),lh.set(t,n)),n(e,t,r,e.length-1)}});var dh=U(Ba=>{var D=Oo(),DA=ch(),Go=vA().ArraySet,VM=BA(),ji=uh().quickSort;function Ee(e,t){var r=e;return typeof e=="string"&&(r=D.parseSourceMapInput(e)),r.sections!=null?new sr(r,t):new ot(r,t)}Ee.fromSourceMap=function(e,t){return ot.fromSourceMap(e,t)};Ee.prototype._version=3;Ee.prototype.__generatedMappings=null;Object.defineProperty(Ee.prototype,"_generatedMappings",{configurable:!0,enumerable:!0,get:function(){return this.__generatedMappings||this._parseMappings(this._mappings,this.sourceRoot),this.__generatedMappings}});Ee.prototype.__originalMappings=null;Object.defineProperty(Ee.prototype,"_originalMappings",{configurable:!0,enumerable:!0,get:function(){return this.__originalMappings||this._parseMappings(this._mappings,this.sourceRoot),this.__originalMappings}});Ee.prototype._charIsMappingSeparator=function(t,r){var n=t.charAt(r);return n===";"||n===","};Ee.prototype._parseMappings=function(t,r){throw new Error("Subclasses must implement _parseMappings")};Ee.GENERATED_ORDER=1;Ee.ORIGINAL_ORDER=2;Ee.GREATEST_LOWER_BOUND=1;Ee.LEAST_UPPER_BOUND=2;Ee.prototype.eachMapping=function(t,r,n){var o=r||null,i=n||Ee.GENERATED_ORDER,s;switch(i){case Ee.GENERATED_ORDER:s=this._generatedMappings;break;case Ee.ORIGINAL_ORDER:s=this._originalMappings;break;default:throw new Error("Unknown order of iteration.")}for(var a=this.sourceRoot,c=t.bind(o),l=this._names,A=this._sources,u=this._sourceMapURL,m=0,d=s.length;m<d;m++){var p=s[m],E=p.source===null?null:A.at(p.source);E!==null&&(E=D.computeSourceURL(a,E,u)),c({source:E,generatedLine:p.generatedLine,generatedColumn:p.generatedColumn,originalLine:p.originalLine,originalColumn:p.originalColumn,name:p.name===null?null:l.at(p.name)})}};Ee.prototype.allGeneratedPositionsFor=function(t){var r=D.getArg(t,"line"),n={source:D.getArg(t,"source"),originalLine:r,originalColumn:D.getArg(t,"column",0)};if(n.source=this._findSourceIndex(n.source),n.source<0)return[];var o=[],i=this._findMapping(n,this._originalMappings,"originalLine","originalColumn",D.compareByOriginalPositions,DA.LEAST_UPPER_BOUND);if(i>=0){var s=this._originalMappings[i];if(t.column===void 0)for(var a=s.originalLine;s&&s.originalLine===a;)o.push({line:D.getArg(s,"generatedLine",null),column:D.getArg(s,"generatedColumn",null),lastColumn:D.getArg(s,"lastGeneratedColumn",null)}),s=this._originalMappings[++i];else for(var c=s.originalColumn;s&&s.originalLine===r&&s.originalColumn==c;)o.push({line:D.getArg(s,"generatedLine",null),column:D.getArg(s,"generatedColumn",null),lastColumn:D.getArg(s,"lastGeneratedColumn",null)}),s=this._originalMappings[++i]}return o};Ba.SourceMapConsumer=Ee;function ot(e,t){var r=e;typeof e=="string"&&(r=D.parseSourceMapInput(e));var n=D.getArg(r,"version"),o=D.getArg(r,"sources"),i=D.getArg(r,"names",[]),s=D.getArg(r,"sourceRoot",null),a=D.getArg(r,"sourcesContent",null),c=D.getArg(r,"mappings"),l=D.getArg(r,"file",null);if(n!=this._version)throw new Error("Unsupported version: "+n);s&&(s=D.normalize(s)),o=o.map(String).map(D.normalize).map(function(A){return s&&D.isAbsolute(s)&&D.isAbsolute(A)?D.relative(s,A):A}),this._names=Go.fromArray(i.map(String),!0),this._sources=Go.fromArray(o,!0),this._absoluteSources=this._sources.toArray().map(function(A){return D.computeSourceURL(s,A,t)}),this.sourceRoot=s,this.sourcesContent=a,this._mappings=c,this._sourceMapURL=t,this.file=l}ot.prototype=Object.create(Ee.prototype);ot.prototype.consumer=Ee;ot.prototype._findSourceIndex=function(e){var t=e;if(this.sourceRoot!=null&&(t=D.relative(this.sourceRoot,t)),this._sources.has(t))return this._sources.indexOf(t);var r;for(r=0;r<this._absoluteSources.length;++r)if(this._absoluteSources[r]==e)return r;return-1};ot.fromSourceMap=function(t,r){var n=Object.create(ot.prototype),o=n._names=Go.fromArray(t._names.toArray(),!0),i=n._sources=Go.fromArray(t._sources.toArray(),!0);n.sourceRoot=t._sourceRoot,n.sourcesContent=t._generateSourcesContent(n._sources.toArray(),n.sourceRoot),n.file=t._file,n._sourceMapURL=r,n._absoluteSources=n._sources.toArray().map(function(d){return D.computeSourceURL(n.sourceRoot,d,r)});for(var s=t._mappings.toArray().slice(),a=n.__generatedMappings=[],c=n.__originalMappings=[],l=0,A=s.length;l<A;l++){var u=s[l],m=new mh;m.generatedLine=u.generatedLine,m.generatedColumn=u.generatedColumn,u.source&&(m.source=i.indexOf(u.source),m.originalLine=u.originalLine,m.originalColumn=u.originalColumn,u.name&&(m.name=o.indexOf(u.name)),c.push(m)),a.push(m)}return ji(n.__originalMappings,D.compareByOriginalPositions),n};ot.prototype._version=3;Object.defineProperty(ot.prototype,"sources",{get:function(){return this._absoluteSources.slice()}});function mh(){this.generatedLine=0,this.generatedColumn=0,this.source=null,this.originalLine=null,this.originalColumn=null,this.name=null}var kA=D.compareByGeneratedPositionsDeflatedNoLine;function fh(e,t){let r=e.length,n=e.length-t;if(!(n<=1))if(n==2){let o=e[t],i=e[t+1];kA(o,i)>0&&(e[t]=i,e[t+1]=o)}else if(n<20)for(let o=t;o<r;o++)for(let i=o;i>t;i--){let s=e[i-1],a=e[i];if(kA(s,a)<=0)break;e[i-1]=a,e[i]=s}else ji(e,kA,t)}ot.prototype._parseMappings=function(t,r){var n=1,o=0,i=0,s=0,a=0,c=0,l=t.length,A=0,u={},m={},d=[],p=[],E,x,I,h,y;let Q=0;for(;A<l;)if(t.charAt(A)===";")n++,A++,o=0,fh(p,Q),Q=p.length;else if(t.charAt(A)===",")A++;else{for(E=new mh,E.generatedLine=n,h=A;h<l&&!this._charIsMappingSeparator(t,h);h++);for(x=t.slice(A,h),I=[];A<h;)VM.decode(t,A,m),y=m.value,A=m.rest,I.push(y);if(I.length===2)throw new Error("Found a source, but no line and column");if(I.length===3)throw new Error("Found a source and line, but no column");if(E.generatedColumn=o+I[0],o=E.generatedColumn,I.length>1&&(E.source=a+I[1],a+=I[1],E.originalLine=i+I[2],i=E.originalLine,E.originalLine+=1,E.originalColumn=s+I[3],s=E.originalColumn,I.length>4&&(E.name=c+I[4],c+=I[4])),p.push(E),typeof E.originalLine=="number"){let B=E.source;for(;d.length<=B;)d.push(null);d[B]===null&&(d[B]=[]),d[B].push(E)}}fh(p,Q),this.__generatedMappings=p;for(var M=0;M<d.length;M++)d[M]!=null&&ji(d[M],D.compareByOriginalPositionsNoSource);this.__originalMappings=[].concat(...d)};ot.prototype._findMapping=function(t,r,n,o,i,s){if(t[n]<=0)throw new TypeError("Line must be greater than or equal to 1, got "+t[n]);if(t[o]<0)throw new TypeError("Column must be greater than or equal to 0, got "+t[o]);return DA.search(t,r,i,s)};ot.prototype.computeColumnSpans=function(){for(var t=0;t<this._generatedMappings.length;++t){var r=this._generatedMappings[t];if(t+1<this._generatedMappings.length){var n=this._generatedMappings[t+1];if(r.generatedLine===n.generatedLine){r.lastGeneratedColumn=n.generatedColumn-1;continue}}r.lastGeneratedColumn=1/0}};ot.prototype.originalPositionFor=function(t){var r={generatedLine:D.getArg(t,"line"),generatedColumn:D.getArg(t,"column")},n=this._findMapping(r,this._generatedMappings,"generatedLine","generatedColumn",D.compareByGeneratedPositionsDeflated,D.getArg(t,"bias",Ee.GREATEST_LOWER_BOUND));if(n>=0){var o=this._generatedMappings[n];if(o.generatedLine===r.generatedLine){var i=D.getArg(o,"source",null);i!==null&&(i=this._sources.at(i),i=D.computeSourceURL(this.sourceRoot,i,this._sourceMapURL));var s=D.getArg(o,"name",null);return s!==null&&(s=this._names.at(s)),{source:i,line:D.getArg(o,"originalLine",null),column:D.getArg(o,"originalColumn",null),name:s}}}return{source:null,line:null,column:null,name:null}};ot.prototype.hasContentsOfAllSources=function(){return this.sourcesContent?this.sourcesContent.length>=this._sources.size()&&!this.sourcesContent.some(function(t){return t==null}):!1};ot.prototype.sourceContentFor=function(t,r){if(!this.sourcesContent)return null;var n=this._findSourceIndex(t);if(n>=0)return this.sourcesContent[n];var o=t;this.sourceRoot!=null&&(o=D.relative(this.sourceRoot,o));var i;if(this.sourceRoot!=null&&(i=D.urlParse(this.sourceRoot))){var s=o.replace(/^file:\/\//,"");if(i.scheme=="file"&&this._sources.has(s))return this.sourcesContent[this._sources.indexOf(s)];if((!i.path||i.path=="/")&&this._sources.has("/"+o))return this.sourcesContent[this._sources.indexOf("/"+o)]}if(r)return null;throw new Error('"'+o+'" is not in the SourceMap.')};ot.prototype.generatedPositionFor=function(t){var r=D.getArg(t,"source");if(r=this._findSourceIndex(r),r<0)return{line:null,column:null,lastColumn:null};var n={source:r,originalLine:D.getArg(t,"line"),originalColumn:D.getArg(t,"column")},o=this._findMapping(n,this._originalMappings,"originalLine","originalColumn",D.compareByOriginalPositions,D.getArg(t,"bias",Ee.GREATEST_LOWER_BOUND));if(o>=0){var i=this._originalMappings[o];if(i.source===n.source)return{line:D.getArg(i,"generatedLine",null),column:D.getArg(i,"generatedColumn",null),lastColumn:D.getArg(i,"lastGeneratedColumn",null)}}return{line:null,column:null,lastColumn:null}};Ba.BasicSourceMapConsumer=ot;function sr(e,t){var r=e;typeof e=="string"&&(r=D.parseSourceMapInput(e));var n=D.getArg(r,"version"),o=D.getArg(r,"sections");if(n!=this._version)throw new Error("Unsupported version: "+n);this._sources=new Go,this._names=new Go;var i={line:-1,column:0};this._sections=o.map(function(s){if(s.url)throw new Error("Support for url field in sections not implemented.");var a=D.getArg(s,"offset"),c=D.getArg(a,"line"),l=D.getArg(a,"column");if(c<i.line||c===i.line&&l<i.column)throw new Error("Section offsets must be ordered and non-overlapping.");return i=a,{generatedOffset:{generatedLine:c+1,generatedColumn:l+1},consumer:new Ee(D.getArg(s,"map"),t)}})}sr.prototype=Object.create(Ee.prototype);sr.prototype.constructor=Ee;sr.prototype._version=3;Object.defineProperty(sr.prototype,"sources",{get:function(){for(var e=[],t=0;t<this._sections.length;t++)for(var r=0;r<this._sections[t].consumer.sources.length;r++)e.push(this._sections[t].consumer.sources[r]);return e}});sr.prototype.originalPositionFor=function(t){var r={generatedLine:D.getArg(t,"line"),generatedColumn:D.getArg(t,"column")},n=DA.search(r,this._sections,function(i,s){var a=i.generatedLine-s.generatedOffset.generatedLine;return a||i.generatedColumn-s.generatedOffset.generatedColumn}),o=this._sections[n];return o?o.consumer.originalPositionFor({line:r.generatedLine-(o.generatedOffset.generatedLine-1),column:r.generatedColumn-(o.generatedOffset.generatedLine===r.generatedLine?o.generatedOffset.generatedColumn-1:0),bias:t.bias}):{source:null,line:null,column:null,name:null}};sr.prototype.hasContentsOfAllSources=function(){return this._sections.every(function(t){return t.consumer.hasContentsOfAllSources()})};sr.prototype.sourceContentFor=function(t,r){for(var n=0;n<this._sections.length;n++){var o=this._sections[n],i=o.consumer.sourceContentFor(t,!0);if(i||i==="")return i}if(r)return null;throw new Error('"'+t+'" is not in the SourceMap.')};sr.prototype.generatedPositionFor=function(t){for(var r=0;r<this._sections.length;r++){var n=this._sections[r];if(n.consumer._findSourceIndex(D.getArg(t,"source"))!==-1){var o=n.consumer.generatedPositionFor(t);if(o){var i={line:o.line+(n.generatedOffset.generatedLine-1),column:o.column+(n.generatedOffset.generatedLine===o.line?n.generatedOffset.generatedColumn-1:0)};return i}}}return{line:null,column:null}};sr.prototype._parseMappings=function(t,r){this.__generatedMappings=[],this.__originalMappings=[];for(var n=0;n<this._sections.length;n++)for(var o=this._sections[n],i=o.consumer._generatedMappings,s=0;s<i.length;s++){var a=i[s],c=o.consumer._sources.at(a.source);c!==null&&(c=D.computeSourceURL(o.consumer.sourceRoot,c,this._sourceMapURL)),this._sources.add(c),c=this._sources.indexOf(c);var l=null;a.name&&(l=o.consumer._names.at(a.name),this._names.add(l),l=this._names.indexOf(l));var A={source:c,generatedLine:a.generatedLine+(o.generatedOffset.generatedLine-1),generatedColumn:a.generatedColumn+(o.generatedOffset.generatedLine===a.generatedLine?o.generatedOffset.generatedColumn-1:0),originalLine:a.originalLine,originalColumn:a.originalColumn,name:l};this.__generatedMappings.push(A),typeof A.originalLine=="number"&&this.__originalMappings.push(A)}ji(this.__generatedMappings,D.compareByGeneratedPositionsDeflated),ji(this.__originalMappings,D.compareByOriginalPositions)};Ba.IndexedSourceMapConsumer=sr});var ph=U(gh=>{var YM=TA().SourceMapGenerator,Sa=Oo(),WM=/(\r?\n)/,zM=10,Uo="$$$isSourceNode$$$";function Dt(e,t,r,n,o){this.children=[],this.sourceContents={},this.line=e??null,this.column=t??null,this.source=r??null,this.name=o??null,this[Uo]=!0,n!=null&&this.add(n)}Dt.fromStringWithSourceMap=function(t,r,n){var o=new Dt,i=t.split(WM),s=0,a=function(){var m=p(),d=p()||"";return m+d;function p(){return s<i.length?i[s++]:void 0}},c=1,l=0,A=null;return r.eachMapping(function(m){if(A!==null)if(c<m.generatedLine)u(A,a()),c++,l=0;else{var d=i[s]||"",p=d.substr(0,m.generatedColumn-l);i[s]=d.substr(m.generatedColumn-l),l=m.generatedColumn,u(A,p),A=m;return}for(;c<m.generatedLine;)o.add(a()),c++;if(l<m.generatedColumn){var d=i[s]||"";o.add(d.substr(0,m.generatedColumn)),i[s]=d.substr(m.generatedColumn),l=m.generatedColumn}A=m},this),s<i.length&&(A&&u(A,a()),o.add(i.splice(s).join(""))),r.sources.forEach(function(m){var d=r.sourceContentFor(m);d!=null&&(n!=null&&(m=Sa.join(n,m)),o.setSourceContent(m,d))}),o;function u(m,d){if(m===null||m.source===void 0)o.add(d);else{var p=n?Sa.join(n,m.source):m.source;o.add(new Dt(m.originalLine,m.originalColumn,p,d,m.name))}}};Dt.prototype.add=function(t){if(Array.isArray(t))t.forEach(function(r){this.add(r)},this);else if(t[Uo]||typeof t=="string")t&&this.children.push(t);else throw new TypeError("Expected a SourceNode, string, or an array of SourceNodes and strings. Got "+t);return this};Dt.prototype.prepend=function(t){if(Array.isArray(t))for(var r=t.length-1;r>=0;r--)this.prepend(t[r]);else if(t[Uo]||typeof t=="string")this.children.unshift(t);else throw new TypeError("Expected a SourceNode, string, or an array of SourceNodes and strings. Got "+t);return this};Dt.prototype.walk=function(t){for(var r,n=0,o=this.children.length;n<o;n++)r=this.children[n],r[Uo]?r.walk(t):r!==""&&t(r,{source:this.source,line:this.line,column:this.column,name:this.name})};Dt.prototype.join=function(t){var r,n,o=this.children.length;if(o>0){for(r=[],n=0;n<o-1;n++)r.push(this.children[n]),r.push(t);r.push(this.children[n]),this.children=r}return this};Dt.prototype.replaceRight=function(t,r){var n=this.children[this.children.length-1];return n[Uo]?n.replaceRight(t,r):typeof n=="string"?this.children[this.children.length-1]=n.replace(t,r):this.children.push("".replace(t,r)),this};Dt.prototype.setSourceContent=function(t,r){this.sourceContents[Sa.toSetString(t)]=r};Dt.prototype.walkSourceContents=function(t){for(var r=0,n=this.children.length;r<n;r++)this.children[r][Uo]&&this.children[r].walkSourceContents(t);for(var o=Object.keys(this.sourceContents),r=0,n=o.length;r<n;r++)t(Sa.fromSetString(o[r]),this.sourceContents[o[r]])};Dt.prototype.toString=function(){var t="";return this.walk(function(r){t+=r}),t};Dt.prototype.toStringWithSourceMap=function(t){var r={code:"",line:1,column:0},n=new YM(t),o=!1,i=null,s=null,a=null,c=null;return this.walk(function(l,A){r.code+=l,A.source!==null&&A.line!==null&&A.column!==null?((i!==A.source||s!==A.line||a!==A.column||c!==A.name)&&n.addMapping({source:A.source,original:{line:A.line,column:A.column},generated:{line:r.line,column:r.column},name:A.name}),i=A.source,s=A.line,a=A.column,c=A.name,o=!0):o&&(n.addMapping({generated:{line:r.line,column:r.column}}),i=null,o=!1);for(var u=0,m=l.length;u<m;u++)l.charCodeAt(u)===zM?(r.line++,r.column=0,u+1===m?(i=null,o=!1):o&&n.addMapping({source:A.source,original:{line:A.line,column:A.column},generated:{line:r.line,column:r.column},name:A.name})):r.column++}),this.walkSourceContents(function(l,A){n.setSourceContent(l,A)}),{code:r.code,map:n}};gh.SourceNode=Dt});var hh=U(Qa=>{Qa.SourceMapGenerator=TA().SourceMapGenerator;Qa.SourceMapConsumer=dh().SourceMapConsumer;Qa.SourceNode=ph().SourceNode});var Ch,Ma,NA=g(()=>{"use client";W();Ch=f(R(),1),Ma=(0,_.createSvgIcon)((0,Ch.jsx)("path",{d:"M19 19H5V5h7V3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2v-7h-2zM14 3v2h3.59l-9.83 9.83 1.41 1.41L19 6.41V10h2V3z"}),"OpenInNew")});function Ta(e){let{children:t,...r}=e;return(0,va.jsxs)(Eh.Link,{...r,target:"_blank",rel:"noopener noreferrer",children:[t," ",(0,va.jsx)(Ma,{fontSize:"small"})]})}var va,Eh,Ih=g(()=>{va=f(R(),1);NA();Eh=f(k(),1)});function LA({text:e,extra:t}){let{classes:r}=$M(),n=t?`supporting data: ${JSON.stringify(t,null,2)}`:"",o=[e,n].filter(Boolean).join(`
4
2
  `),i=encodeURIComponent(`I got this error from JBrowse, here is the stack trace:
5
3
 
6
4
  \`\`\`
7
5
  ${e}
8
6
  \`\`\`
9
7
  ${n}
10
- `),s=`https://github.com/GMOD/jbrowse-components/issues/new?labels=bug&title=JBrowse+issue&body=${i}`,a=`mailto:${QE}?subject=JBrowse%202%20error&body=${i}`;return(0,Vr.jsxs)(Vr.Fragment,{children:[(0,Vr.jsxs)(hc.Typography,{children:["Post a new issue at"," ",(0,Vr.jsx)(pc,{href:s,children:"GitHub"})," or send an email to ",(0,Vr.jsx)(pc,{href:a,children:QE})]}),(0,Vr.jsx)("pre",{className:r.pre,children:o})]})}var Vr,hc,QE,vv,ME=g(()=>{Vr=f(F(),1),hc=f(D(),1);SE();Ct();QE="jbrowse2@berkeley.edu",vv=ee()(e=>({pre:{background:(0,hc.alpha)(e.palette.error.main,.2),border:`1px solid ${e.palette.divider}`,overflow:"auto",margin:20,maxHeight:300}}))});function Zu({message:e,children:t,variant:r="body2",...n}){let{classes:o}=Tv();return(0,vE.jsx)(TE.Typography,{className:lc(o.dots,n.className),...n,variant:r,children:e||"Loading"})}var vE,TE,Tv,_E=g(()=>{vE=f(F(),1),TE=f(D(),1);Ct();Tv=ee()({dots:{"&::after":{display:"inline-block",content:'""',width:"1em",textAlign:"left",animation:`${Nu`
8
+ `),s=`https://github.com/GMOD/jbrowse-components/issues/new?labels=bug&title=JBrowse+issue&body=${i}`,a=`mailto:${xh}?subject=JBrowse%202%20error&body=${i}`;return(0,qr.jsxs)(qr.Fragment,{children:[(0,qr.jsxs)(_a.Typography,{children:["Post a new issue at"," ",(0,qr.jsx)(Ta,{href:s,children:"GitHub"})," or send an email to ",(0,qr.jsx)(Ta,{href:a,children:xh})]}),(0,qr.jsx)("pre",{className:r.pre,children:o})]})}var qr,_a,xh,$M,yh=g(()=>{qr=f(R(),1),_a=f(k(),1);Ih();Et();xh="jbrowse2@berkeley.edu",$M=te()(e=>({pre:{background:(0,_a.alpha)(e.palette.error.main,.2),border:`1px solid ${e.palette.divider}`,overflow:"auto",margin:20,maxHeight:300}}))});function FA({message:e,children:t,variant:r="body2",...n}){let{classes:o}=KM();return(0,bh.jsx)(wh.Typography,{className:ya(o.dots,n.className),...n,variant:r,children:e||"Loading"})}var bh,wh,KM,Bh=g(()=>{bh=f(R(),1),wh=f(k(),1);Et();KM=te()({dots:{"&::after":{display:"inline-block",content:'""',width:"1em",textAlign:"left",animation:`${pA`
11
9
  0% {
12
10
  content: '';
13
11
  }
@@ -20,16 +18,18 @@ ${n}
20
18
  75% {
21
19
  content: '...';
22
20
  }
23
- `} 1.2s infinite ease-in-out`}}})});var DE=G((XO,kE)=>{kE.exports=function(){var e=document.getSelection();if(!e.rangeCount)return function(){};for(var t=document.activeElement,r=[],n=0;n<e.rangeCount;n++)r.push(e.getRangeAt(n));switch(t.tagName.toUpperCase()){case"INPUT":case"TEXTAREA":t.blur();break;default:t=null;break}return e.removeAllRanges(),function(){e.type==="Caret"&&e.removeAllRanges(),e.rangeCount||r.forEach(function(o){e.addRange(o)}),t&&t.focus()}}});var FE=G((ZO,LE)=>{"use strict";var _v=DE(),NE={"text/plain":"Text","text/html":"Url",default:"Text"},kv="Copy to clipboard: #{key}, Enter";function Dv(e){var t=(/mac os x/i.test(navigator.userAgent)?"\u2318":"Ctrl")+"+C";return e.replace(/#{\s*key\s*}/g,t)}function Nv(e,t){var r,n,o,i,s,a,c=!1;t||(t={}),r=t.debug||!1;try{o=_v(),i=document.createRange(),s=document.getSelection(),a=document.createElement("span"),a.textContent=e,a.ariaHidden="true",a.style.all="unset",a.style.position="fixed",a.style.top=0,a.style.clip="rect(0, 0, 0, 0)",a.style.whiteSpace="pre",a.style.webkitUserSelect="text",a.style.MozUserSelect="text",a.style.msUserSelect="text",a.style.userSelect="text",a.addEventListener("copy",function(A){if(A.stopPropagation(),t.format)if(A.preventDefault(),typeof A.clipboardData>"u"){r&&console.warn("unable to use e.clipboardData"),r&&console.warn("trying IE specific stuff"),window.clipboardData.clearData();var u=NE[t.format]||NE.default;window.clipboardData.setData(u,e)}else A.clipboardData.clearData(),A.clipboardData.setData(t.format,e);t.onCopy&&(A.preventDefault(),t.onCopy(A.clipboardData))}),document.body.appendChild(a),i.selectNodeContents(a),s.addRange(i);var l=document.execCommand("copy");if(!l)throw new Error("copy command was unsuccessful");c=!0}catch(A){r&&console.error("unable to copy using execCommand: ",A),r&&console.warn("trying IE specific stuff");try{window.clipboardData.setData(t.format||"text",e),t.onCopy&&t.onCopy(window.clipboardData),c=!0}catch(u){r&&console.error("unable to copy using clipboardData: ",u),r&&console.error("falling back to prompt"),n=Dv("message"in t?t.message:kv),window.prompt(n,e)}}finally{s&&(typeof s.removeRange=="function"?s.removeRange(i):s.removeAllRanges()),a&&document.body.removeChild(a),o()}return c}LE.exports=Nv});var UE={};We(UE,{default:()=>GE});async function OE(e){let t=await fetch(e);if(!t.ok)throw new Error(`HTTP ${t.status} fetching ${e}: ${await t.text()}`);return t.text()}async function Lv(e){return JSON.parse(await OE(e))}async function Pv(e){if(ef[e])return ef[e];let t=new URL(e).search,r=await OE(e),n=Fv.exec(r)?.[1]??"",o=await Lv(new URL(n,e).href+t),i=new PE.SourceMapConsumer(o);return ef[e]=i,i}async function Ov(e){let t=[];for(let r of e.split(`
24
- `)){let n=Rv.exec(r);if(!n){t.push(r);continue}let o=n[2],s=(await Pv(o)).originalPositionFor({line:+n[3],column:+n[4]});if(!s.source||!s.line||!s.column){t.push(r);continue}t.push(`${s.source}:${s.line}:${s.column+1} (${n[1].trim()})`)}return t.join(`
25
- `)}function Gv(e,t){return e.startsWith("Error:")?e.slice(`${t}`.length):e}function Uv(e){return typeof e=="object"&&e!==null&&"stack"in e?`${e.stack}`:""}function GE({error:e,onClose:t,extra:r}){let[n,o]=(0,ei.useState)(),[i,s]=(0,ei.useState)(),[a,c]=(0,ei.useState)(!1),l=e?`${e}`:"",A=Gv(Uv(e),l);(0,ei.useEffect)(()=>{(async()=>{try{o(await Ov(A))}catch(d){console.error(d),o(A),s(d)}})()},[A]);let u=window.JBrowseSession?.version,m=[i?"Error loading source map, showing raw stack trace below:":"",l.length>RE?`${l.slice(0,RE)}...`:l,n||"No stack trace available",u?`JBrowse ${u}`:""].filter(Boolean).join(`
26
- `);return(0,Zt.jsxs)(Rt.Dialog,{open:!0,onClose:t,maxWidth:"xl",children:[(0,Zt.jsxs)(Rt.DialogTitle,{children:["Stack trace",(0,Zt.jsx)(Rt.IconButton,{onClick:t,sx:{position:"absolute",right:8,top:8},children:(0,Zt.jsx)(Pa,{})})]}),(0,Zt.jsx)(Rt.DialogContent,{children:n===void 0?(0,Zt.jsx)(Zu,{variant:"h6"}):(0,Zt.jsx)(Xu,{text:m,extra:r})}),(0,Zt.jsxs)(Rt.DialogActions,{children:[(0,Zt.jsx)(Rt.Button,{variant:"contained",color:"secondary",onClick:async()=>{let{default:d}=await Promise.resolve().then(()=>f(FE(),1));d(m),c(!0),setTimeout(()=>{c(!1)},1e3)},children:a?"Copied!":"Copy stack trace to clipboard"}),(0,Zt.jsx)(Rt.Button,{variant:"contained",color:"primary",onClick:t,children:"Close"})]})]})}var Zt,ei,Rt,PE,ef,Fv,Rv,RE,HE=g(()=>{Zt=f(F(),1),ei=f(b(),1);fu();Rt=f(D(),1),PE=f(bE(),1);ME();_E();ef={},Fv=/\/\/# sourceMappingURL=(.*)/,Rv=/(.*)((?:https?|file):\/\/.*):(\d+):(\d+)/;RE=1e4});function jv(e){let t="",r="is not assignable",n=e.indexOf(r);if(n!==-1){let o=e.slice(0,n+r.length),i=/.*at path "(.*)" snapshot `(.*)` is not assignable/m.exec(o);i&&(e=`Failed to load element at ${i[1]}...Failed element had snapshot`,t=i[2]);let s=/.*snapshot `(.*)` is not assignable/.exec(o);s&&(e="Failed to load element...Failed element had snapshot",t=s[1])}return t}function qv({error:e,onReset:t}){let{classes:r}=jE(),[n,o]=(0,ri.useState)(!1);return(0,vt.jsxs)("div",{className:r.iconFloat,children:[typeof e=="object"&&e&&"stack"in e?(0,vt.jsx)(ti.Tooltip,{title:"Get stack trace",children:(0,vt.jsx)(ti.IconButton,{onClick:()=>{o(!0)},color:"primary",children:(0,vt.jsx)(L0,{})})}):null,t?(0,vt.jsx)(ti.Tooltip,{title:"Retry",children:(0,vt.jsx)(ti.IconButton,{onClick:t,color:"primary",children:(0,vt.jsx)(k0,{})})}):null,n?(0,vt.jsx)(ri.Suspense,{fallback:null,children:(0,vt.jsx)(Hv,{error:e,onClose:()=>{o(!1)}})}):null]})}function Jv({error:e,onReset:t}){let{classes:r}=jE(),n=`${e}`,o=n.indexOf("expected an instance of"),i=o!==-1?n.slice(0,o):n,s=jv(n);return(0,vt.jsxs)(Ou,{children:[i.slice(0,1e4),(0,vt.jsx)(qv,{error:e,onReset:t}),s?(0,vt.jsx)("pre",{className:r.bg,children:JSON.stringify(JSON.parse(s),null,2)}):null]})}var vt,ri,ti,Hv,jE,qE,JE=g(()=>{vt=f(F(),1),ri=f(b(),1);D0();F0();ti=f(D(),1);XC();Ct();Hv=(0,ri.lazy)(()=>Promise.resolve().then(()=>(HE(),UE))),jE=ee()(e=>({bg:{background:e.palette.divider,border:"1px solid black",margin:20},iconFloat:{float:"right",marginLeft:100}}));qE=Jv});var YE=G((c8,VE)=>{"use strict";var Vv=/["'&<>]/;VE.exports=Yv;function Yv(e){var t=""+e,r=Vv.exec(t);if(!r)return t;var n,o="",i=0,s=0;for(i=r.index;i<t.length;i++){switch(t.charCodeAt(i)){case 34:n="&quot;";break;case 38:n="&amp;";break;case 39:n="&#39;";break;case 60:n="&lt;";break;case 62:n="&gt;";break;default:continue}s!==i&&(o+=t.substring(s,i)),s=i+1,o+=n}return s!==i?o+t.substring(s,i):o}});function WE(e,t){(t==null||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r<t;r++)n[r]=e[r];return n}function Wv(e){if(Array.isArray(e))return e}function zv(e,t){var r=e==null?null:typeof Symbol<"u"&&e[Symbol.iterator]||e["@@iterator"];if(r!=null){var n,o,i,s,a=[],c=!0,l=!1;try{if(i=(r=r.call(e)).next,t!==0)for(;!(c=(n=i.call(r)).done)&&(a.push(n.value),a.length!==t);c=!0);}catch(A){l=!0,o=A}finally{try{if(!c&&r.return!=null&&(s=r.return(),Object(s)!==s))return}finally{if(l)throw o}}return a}}function $v(){throw new TypeError(`Invalid attempt to destructure non-iterable instance.
27
- In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function Kv(e,t){return Wv(e)||zv(e,t)||Xv(e,t)||$v()}function Xv(e,t){if(e){if(typeof e=="string")return WE(e,t);var r={}.toString.call(e).slice(8,-1);return r==="Object"&&e.constructor&&(r=e.constructor.name),r==="Map"||r==="Set"?Array.from(e):r==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?WE(e,t):void 0}}function Ge(e){return function(t){t instanceof RegExp&&(t.lastIndex=0);for(var r=arguments.length,n=new Array(r>1?r-1:0),o=1;o<r;o++)n[o-1]=arguments[o];return af(e,t,n)}}function aT(e){return function(){for(var t=arguments.length,r=new Array(t),n=0;n<t;n++)r[n]=arguments[n];return cf(e,r)}}function U(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:es;if(zE&&zE(e,null),!Et(t))return e;let n=t.length;for(;n--;){let o=t[n];if(typeof o=="string"){let i=r(o);i!==o&&(Zv(t)||(t[n]=i),o=i)}e[o]=!0}return e}function cT(e){for(let t=0;t<e.length;t++)Te(e,t)||(e[t]=null);return e}function Tt(e){let t=ai(null);for(let n of aI(e)){var r=Kv(n,2);let o=r[0],i=r[1];Te(e,o)&&(Et(i)?t[o]=cT(i):i&&typeof i=="object"&&i.constructor===Object?t[o]=Tt(i):t[o]=i)}return t}function lT(e){switch(typeof e){case"string":return e;case"number":return iT(e);case"boolean":return sT(e);case"bigint":return ZE?ZE(e):"0";case"symbol":return eI?eI(e):"Symbol()";case"undefined":return Zi(e);case"function":case"object":{if(e===null)return Zi(e);let t=e,r=Jn(t,"toString");if(typeof r=="function"){let n=r(t);return typeof n=="string"?n:Zi(n)}return Zi(e)}default:return Zi(e)}}function Jn(e,t){for(;e!==null;){let n=tT(e,t);if(n){if(n.get)return Ge(n.get);if(typeof n.value=="function")return Ge(n.value)}e=eT(e)}function r(){return null}return r}function AT(e){try{return at(e,""),!0}catch{return!1}}function lI(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:yT(),t=P=>lI(P);if(t.version="3.4.5",t.removed=[],!e||!e.document||e.document.nodeType!==si.document||!e.Element)return t.isSupported=!1,t;let r=e.document,n=r,o=n.currentScript,i=e.DocumentFragment,s=e.HTMLTemplateElement,a=e.Node,c=e.Element,l=e.NodeFilter,A=e.NamedNodeMap,u=A===void 0?e.NamedNodeMap||e.MozNamedAttrMap:A,m=e.HTMLFormElement,d=e.DOMParser,p=e.trustedTypes,C=c.prototype,y=Jn(C,"cloneNode"),I=Jn(C,"remove"),h=Jn(C,"nextSibling"),x=Jn(C,"childNodes"),S=Jn(C,"parentNode"),M=a&&a.prototype?Jn(a.prototype,"nodeType"):null;if(typeof s=="function"){let P=r.createElement("template");P.content&&P.content.ownerDocument&&(r=P.content.ownerDocument)}let B,Q="",L=r,T=L.implementation,re=L.createNodeIterator,k=L.createDocumentFragment,j=L.getElementsByTagName,J=n.importNode,R=sI();t.isSupported=typeof aI=="function"&&typeof S=="function"&&T&&T.createHTMLDocument!==void 0;let ie=mT,_t=dT,qt=gT,Sn=pT,vs=hT,Zr=CT,Ts=ET,en=xT,Ir=iI,be=null,Ao=U({},[...tI,...rf,...nf,...of,...rI]),ve=null,xr=U({},[...nI,...sf,...oI,...Ec]),se=Object.seal(ai(null,{tagNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},attributeNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},allowCustomizedBuiltInElements:{writable:!0,configurable:!1,enumerable:!0,value:!1}})),Qn=null,Mn=null,nr=Object.seal(ai(null,{tagCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},attributeCheck:{writable:!0,configurable:!1,enumerable:!0,value:null}})),_s=!0,bi=!0,tn=!1,Bi=!0,Fr=!1,$=!0,ne=!1,me=!1,de=!1,tt=!1,rt=!1,xe=!1,St=!0,rn=!1,nn="user-content-",uo=!0,on=!1,Ue={},Fe=null,vn=U({},["annotation-xml","audio","colgroup","desc","foreignobject","head","iframe","math","mi","mn","mo","ms","mtext","noembed","noframes","noscript","plaintext","script","style","svg","template","thead","title","video","xmp"]),ks=null,fo=U({},["audio","video","img","source","image","track"]),bl=null,td=U({},["alt","class","for","id","label","name","pattern","placeholder","role","summary","title","value","style","xmlns"]),Ds="http://www.w3.org/1998/Math/MathML",Ns="http://www.w3.org/2000/svg",yr="http://www.w3.org/1999/xhtml",mo=yr,Bl=!1,Sl=null,nQ=U({},[Ds,Ns,yr],tf),Ql=U({},["mi","mo","mn","ms","mtext"]),Ml=U({},["annotation-xml"]),oQ=U({},["title","style","font","a","script"]),Si=null,iQ=["application/xhtml+xml","text/html"],sQ="text/html",He=null,go=null,aQ=r.createElement("form"),rd=function(E){return E instanceof RegExp||E instanceof Function},vl=function(){let E=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};if(go&&go===E)return;(!E||typeof E!="object")&&(E={}),E=Tt(E),Si=iQ.indexOf(E.PARSER_MEDIA_TYPE)===-1?sQ:E.PARSER_MEDIA_TYPE,He=Si==="application/xhtml+xml"?tf:es,be=Te(E,"ALLOWED_TAGS")&&Et(E.ALLOWED_TAGS)?U({},E.ALLOWED_TAGS,He):Ao,ve=Te(E,"ALLOWED_ATTR")&&Et(E.ALLOWED_ATTR)?U({},E.ALLOWED_ATTR,He):xr,Sl=Te(E,"ALLOWED_NAMESPACES")&&Et(E.ALLOWED_NAMESPACES)?U({},E.ALLOWED_NAMESPACES,tf):nQ,bl=Te(E,"ADD_URI_SAFE_ATTR")&&Et(E.ADD_URI_SAFE_ATTR)?U(Tt(td),E.ADD_URI_SAFE_ATTR,He):td,ks=Te(E,"ADD_DATA_URI_TAGS")&&Et(E.ADD_DATA_URI_TAGS)?U(Tt(fo),E.ADD_DATA_URI_TAGS,He):fo,Fe=Te(E,"FORBID_CONTENTS")&&Et(E.FORBID_CONTENTS)?U({},E.FORBID_CONTENTS,He):vn,Qn=Te(E,"FORBID_TAGS")&&Et(E.FORBID_TAGS)?U({},E.FORBID_TAGS,He):Tt({}),Mn=Te(E,"FORBID_ATTR")&&Et(E.FORBID_ATTR)?U({},E.FORBID_ATTR,He):Tt({}),Ue=Te(E,"USE_PROFILES")?E.USE_PROFILES&&typeof E.USE_PROFILES=="object"?Tt(E.USE_PROFILES):E.USE_PROFILES:!1,_s=E.ALLOW_ARIA_ATTR!==!1,bi=E.ALLOW_DATA_ATTR!==!1,tn=E.ALLOW_UNKNOWN_PROTOCOLS||!1,Bi=E.ALLOW_SELF_CLOSE_IN_ATTR!==!1,Fr=E.SAFE_FOR_TEMPLATES||!1,$=E.SAFE_FOR_XML!==!1,ne=E.WHOLE_DOCUMENT||!1,tt=E.RETURN_DOM||!1,rt=E.RETURN_DOM_FRAGMENT||!1,xe=E.RETURN_TRUSTED_TYPE||!1,de=E.FORCE_BODY||!1,St=E.SANITIZE_DOM!==!1,rn=E.SANITIZE_NAMED_PROPS||!1,uo=E.KEEP_CONTENT!==!1,on=E.IN_PLACE||!1,Ir=AT(E.ALLOWED_URI_REGEXP)?E.ALLOWED_URI_REGEXP:iI,mo=typeof E.NAMESPACE=="string"?E.NAMESPACE:yr,Ql=Te(E,"MATHML_TEXT_INTEGRATION_POINTS")&&E.MATHML_TEXT_INTEGRATION_POINTS&&typeof E.MATHML_TEXT_INTEGRATION_POINTS=="object"?Tt(E.MATHML_TEXT_INTEGRATION_POINTS):U({},["mi","mo","mn","ms","mtext"]),Ml=Te(E,"HTML_INTEGRATION_POINTS")&&E.HTML_INTEGRATION_POINTS&&typeof E.HTML_INTEGRATION_POINTS=="object"?Tt(E.HTML_INTEGRATION_POINTS):U({},["annotation-xml"]);let w=Te(E,"CUSTOM_ELEMENT_HANDLING")&&E.CUSTOM_ELEMENT_HANDLING&&typeof E.CUSTOM_ELEMENT_HANDLING=="object"?Tt(E.CUSTOM_ELEMENT_HANDLING):ai(null);if(se=ai(null),Te(w,"tagNameCheck")&&rd(w.tagNameCheck)&&(se.tagNameCheck=w.tagNameCheck),Te(w,"attributeNameCheck")&&rd(w.attributeNameCheck)&&(se.attributeNameCheck=w.attributeNameCheck),Te(w,"allowCustomizedBuiltInElements")&&typeof w.allowCustomizedBuiltInElements=="boolean"&&(se.allowCustomizedBuiltInElements=w.allowCustomizedBuiltInElements),Fr&&(bi=!1),rt&&(tt=!0),Ue&&(be=U({},rI),ve=ai(null),Ue.html===!0&&(U(be,tI),U(ve,nI)),Ue.svg===!0&&(U(be,rf),U(ve,sf),U(ve,Ec)),Ue.svgFilters===!0&&(U(be,nf),U(ve,sf),U(ve,Ec)),Ue.mathMl===!0&&(U(be,of),U(ve,oI),U(ve,Ec))),nr.tagCheck=null,nr.attributeCheck=null,Te(E,"ADD_TAGS")&&(typeof E.ADD_TAGS=="function"?nr.tagCheck=E.ADD_TAGS:Et(E.ADD_TAGS)&&(be===Ao&&(be=Tt(be)),U(be,E.ADD_TAGS,He))),Te(E,"ADD_ATTR")&&(typeof E.ADD_ATTR=="function"?nr.attributeCheck=E.ADD_ATTR:Et(E.ADD_ATTR)&&(ve===xr&&(ve=Tt(ve)),U(ve,E.ADD_ATTR,He))),Te(E,"ADD_URI_SAFE_ATTR")&&Et(E.ADD_URI_SAFE_ATTR)&&U(bl,E.ADD_URI_SAFE_ATTR,He),Te(E,"FORBID_CONTENTS")&&Et(E.FORBID_CONTENTS)&&(Fe===vn&&(Fe=Tt(Fe)),U(Fe,E.FORBID_CONTENTS,He)),Te(E,"ADD_FORBID_CONTENTS")&&Et(E.ADD_FORBID_CONTENTS)&&(Fe===vn&&(Fe=Tt(Fe)),U(Fe,E.ADD_FORBID_CONTENTS,He)),uo&&(be["#text"]=!0),ne&&U(be,["html","head","body"]),be.table&&(U(be,["tbody"]),delete Qn.tbody),E.TRUSTED_TYPES_POLICY){if(typeof E.TRUSTED_TYPES_POLICY.createHTML!="function")throw Cc('TRUSTED_TYPES_POLICY configuration option must provide a "createHTML" hook.');if(typeof E.TRUSTED_TYPES_POLICY.createScriptURL!="function")throw Cc('TRUSTED_TYPES_POLICY configuration option must provide a "createScriptURL" hook.');B=E.TRUSTED_TYPES_POLICY,Q=B.createHTML("")}else B===void 0&&(B=wT(p,o)),B!==null&&typeof Q=="string"&&(Q=B.createHTML(""));It&&It(E),go=E},nd=U({},[...rf,...nf,...uT]),od=U({},[...of,...fT]),cQ=function(E){let w=S(E);(!w||!w.tagName)&&(w={namespaceURI:mo,tagName:"template"});let v=es(E.tagName),V=es(w.tagName);return Sl[E.namespaceURI]?E.namespaceURI===Ns?w.namespaceURI===yr?v==="svg":w.namespaceURI===Ds?v==="svg"&&(V==="annotation-xml"||Ql[V]):!!nd[v]:E.namespaceURI===Ds?w.namespaceURI===yr?v==="math":w.namespaceURI===Ns?v==="math"&&Ml[V]:!!od[v]:E.namespaceURI===yr?w.namespaceURI===Ns&&!Ml[V]||w.namespaceURI===Ds&&!Ql[V]?!1:!od[v]&&(oQ[v]||!nd[v]):!!(Si==="application/xhtml+xml"&&Sl[E.namespaceURI]):!1},or=function(E){oi(t.removed,{element:E});try{S(E).removeChild(E)}catch{I(E)}},Tn=function(E,w){try{oi(t.removed,{attribute:w.getAttributeNode(E),from:w})}catch{oi(t.removed,{attribute:null,from:w})}if(w.removeAttribute(E),E==="is")if(tt||rt)try{or(w)}catch{}else try{w.setAttribute(E,"")}catch{}},id=function(E){let w=null,v=null;if(de)E="<remove></remove>"+E;else{let Pe=KE(E,/^[\r\n\t ]+/);v=Pe&&Pe[0]}Si==="application/xhtml+xml"&&mo===yr&&(E='<html xmlns="http://www.w3.org/1999/xhtml"><head></head><body>'+E+"</body></html>");let V=B?B.createHTML(E):E;if(mo===yr)try{w=new d().parseFromString(V,Si)}catch{}if(!w||!w.documentElement){w=T.createDocument(mo,"template",null);try{w.documentElement.innerHTML=Bl?Q:V}catch{}}let Re=w.body||w.documentElement;return E&&v&&Re.insertBefore(r.createTextNode(v),Re.childNodes[0]||null),mo===yr?j.call(w,ne?"html":"body")[0]:ne?w.documentElement:Re},sd=function(E){return re.call(E.ownerDocument||E,E,l.SHOW_ELEMENT|l.SHOW_COMMENT|l.SHOW_TEXT|l.SHOW_PROCESSING_INSTRUCTION|l.SHOW_CDATA_SECTION,null)},ad=function(E){E.normalize();let w=re.call(E.ownerDocument||E,E,l.SHOW_TEXT|l.SHOW_COMMENT|l.SHOW_CDATA_SECTION|l.SHOW_PROCESSING_INSTRUCTION,null),v=w.nextNode();for(;v;){let V=v.data;ni([ie,_t,qt],Re=>{V=ii(V,Re," ")}),v.data=V,v=w.nextNode()}},Tl=function(E){return E instanceof m&&(typeof E.nodeName!="string"||typeof E.textContent!="string"||typeof E.removeChild!="function"||!(E.attributes instanceof u)||typeof E.removeAttribute!="function"||typeof E.setAttribute!="function"||typeof E.namespaceURI!="string"||typeof E.insertBefore!="function"||typeof E.hasChildNodes!="function")},Ls=function(E){if(!M||typeof E!="object"||E===null)return!1;try{return typeof M(E)=="number"}catch{return!1}};function Rr(P,E,w){ni(P,v=>{v.call(t,E,w,go)})}let cd=function(E){let w=null;if(Rr(R.beforeSanitizeElements,E,null),Tl(E))return or(E),!0;let v=He(E.nodeName);if(Rr(R.uponSanitizeElement,E,{tagName:v,allowedTags:be}),$&&E.hasChildNodes()&&!Ls(E.firstElementChild)&&at(/<[/\w!]/g,E.innerHTML)&&at(/<[/\w!]/g,E.textContent)||$&&E.namespaceURI===yr&&v==="style"&&Ls(E.firstElementChild)||E.nodeType===si.progressingInstruction||$&&E.nodeType===si.comment&&at(/<[/\w]/g,E.data))return or(E),!0;if(Qn[v]||!(nr.tagCheck instanceof Function&&nr.tagCheck(v))&&!be[v]){if(!Qn[v]&&Ad(v)&&(se.tagNameCheck instanceof RegExp&&at(se.tagNameCheck,v)||se.tagNameCheck instanceof Function&&se.tagNameCheck(v)))return!1;if(uo&&!Fe[v]){let V=S(E)||E.parentNode,Re=x(E)||E.childNodes;if(Re&&V){let Pe=Re.length;for(let Qt=Pe-1;Qt>=0;--Qt){let sn=y(Re[Qt],!0);V.insertBefore(sn,h(E))}}}return or(E),!0}return E instanceof c&&!cQ(E)||(v==="noscript"||v==="noembed"||v==="noframes")&&at(/<\/no(script|embed|frames)/i,E.innerHTML)?(or(E),!0):(Fr&&E.nodeType===si.text&&(w=E.textContent,ni([ie,_t,qt],V=>{w=ii(w,V," ")}),E.textContent!==w&&(oi(t.removed,{element:E.cloneNode()}),E.textContent=w)),Rr(R.afterSanitizeElements,E,null),!1)},ld=function(E,w,v){if(Mn[w]||St&&(w==="id"||w==="name")&&(v in r||v in aQ))return!1;let V=ve[w]||nr.attributeCheck instanceof Function&&nr.attributeCheck(w,E);if(!(bi&&!Mn[w]&&at(Sn,w))){if(!(_s&&at(vs,w))){if(!V||Mn[w]){if(!(Ad(E)&&(se.tagNameCheck instanceof RegExp&&at(se.tagNameCheck,E)||se.tagNameCheck instanceof Function&&se.tagNameCheck(E))&&(se.attributeNameCheck instanceof RegExp&&at(se.attributeNameCheck,w)||se.attributeNameCheck instanceof Function&&se.attributeNameCheck(w,E))||w==="is"&&se.allowCustomizedBuiltInElements&&(se.tagNameCheck instanceof RegExp&&at(se.tagNameCheck,v)||se.tagNameCheck instanceof Function&&se.tagNameCheck(v))))return!1}else if(!bl[w]){if(!at(Ir,ii(v,Ts,""))){if(!((w==="src"||w==="xlink:href"||w==="href")&&E!=="script"&&XE(v,"data:")===0&&ks[E])){if(!(tn&&!at(Zr,ii(v,Ts,"")))){if(v)return!1}}}}}}return!0},lQ=U({},["annotation-xml","color-profile","font-face","font-face-format","font-face-name","font-face-src","font-face-uri","missing-glyph"]),Ad=function(E){return!lQ[es(E)]&&at(en,E)},ud=function(E){Rr(R.beforeSanitizeAttributes,E,null);let w=E.attributes;if(!w||Tl(E))return;let v={attrName:"",attrValue:"",keepAttr:!0,allowedAttributes:ve,forceKeepAttr:void 0},V=w.length;for(;V--;){let Re=w[V],Pe=Re.name,Qt=Re.namespaceURI,sn=Re.value,Pr=He(Pe),kl=sn,Ye=Pe==="value"?kl:oT(kl);if(v.attrName=Pr,v.attrValue=Ye,v.keepAttr=!0,v.forceKeepAttr=void 0,Rr(R.uponSanitizeAttribute,E,v),Ye=v.attrValue,rn&&(Pr==="id"||Pr==="name")&&XE(Ye,nn)!==0&&(Tn(Pe,E),Ye=nn+Ye),$&&at(/((--!?|])>)|<\/(style|script|title|xmp|textarea|noscript|iframe|noembed|noframes)/i,Ye)){Tn(Pe,E);continue}if(Pr==="attributename"&&KE(Ye,"href")){Tn(Pe,E);continue}if(v.forceKeepAttr)continue;if(!v.keepAttr){Tn(Pe,E);continue}if(!Bi&&at(/\/>/i,Ye)){Tn(Pe,E);continue}Fr&&ni([ie,_t,qt],md=>{Ye=ii(Ye,md," ")});let fd=He(E.nodeName);if(!ld(fd,Pr,Ye)){Tn(Pe,E);continue}if(B&&typeof p=="object"&&typeof p.getAttributeType=="function"&&!Qt)switch(p.getAttributeType(fd,Pr)){case"TrustedHTML":{Ye=B.createHTML(Ye);break}case"TrustedScriptURL":{Ye=B.createScriptURL(Ye);break}}if(Ye!==kl)try{Qt?E.setAttributeNS(Qt,Pe,Ye):E.setAttribute(Pe,Ye),Tl(E)?or(E):$E(t.removed)}catch{Tn(Pe,E)}}Rr(R.afterSanitizeAttributes,E,null)},_l=function(E){let w=null,v=sd(E);for(Rr(R.beforeSanitizeShadowDOM,E,null);w=v.nextNode();)Rr(R.uponSanitizeShadowNode,w,null),cd(w),ud(w),w.content instanceof i&&_l(w.content);Rr(R.afterSanitizeShadowDOM,E,null)},Fs=function(E){if(E.nodeType===si.element&&E.shadowRoot instanceof i){let V=E.shadowRoot;Fs(V),_l(V)}let w=E.childNodes;if(!w)return;let v=[];ni(w,V=>{oi(v,V)});for(let V of v)Fs(V)};return t.sanitize=function(P){let E=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},w=null,v=null,V=null,Re=null;if(Bl=!P,Bl&&(P="<!-->"),typeof P!="string"&&!Ls(P)&&(P=lT(P),typeof P!="string"))throw Cc("dirty is not a string, aborting");if(!t.isSupported)return P;if(me||vl(E),t.removed=[],typeof P=="string"&&(on=!1),on){let sn=P.nodeName;if(typeof sn=="string"){let Pr=He(sn);if(!be[Pr]||Qn[Pr])throw Cc("root node is forbidden and cannot be sanitized in-place")}Fs(P)}else if(Ls(P))w=id("<!---->"),v=w.ownerDocument.importNode(P,!0),v.nodeType===si.element&&v.nodeName==="BODY"||v.nodeName==="HTML"?w=v:w.appendChild(v),Fs(v);else{if(!tt&&!Fr&&!ne&&P.indexOf("<")===-1)return B&&xe?B.createHTML(P):P;if(w=id(P),!w)return tt?null:xe?Q:""}w&&de&&or(w.firstChild);let Pe=sd(on?P:w);for(;V=Pe.nextNode();)cd(V),ud(V),V.content instanceof i&&_l(V.content);if(on)return Fr&&ad(P),P;if(tt){if(Fr&&ad(w),rt)for(Re=k.call(w.ownerDocument);w.firstChild;)Re.appendChild(w.firstChild);else Re=w;return(ve.shadowroot||ve.shadowrootmode)&&(Re=J.call(n,Re,!0)),Re}let Qt=ne?w.outerHTML:w.innerHTML;return ne&&be["!doctype"]&&w.ownerDocument&&w.ownerDocument.doctype&&w.ownerDocument.doctype.name&&at(IT,w.ownerDocument.doctype.name)&&(Qt="<!DOCTYPE "+w.ownerDocument.doctype.name+`>
28
- `+Qt),Fr&&ni([ie,_t,qt],sn=>{Qt=ii(Qt,sn," ")}),B&&xe?B.createHTML(Qt):Qt},t.setConfig=function(){let P=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};vl(P),me=!0},t.clearConfig=function(){go=null,me=!1},t.isValidAttribute=function(P,E,w){go||vl({});let v=He(P),V=He(E);return ld(v,V,w)},t.addHook=function(P,E){typeof E=="function"&&oi(R[P],E)},t.removeHook=function(P,E){if(E!==void 0){let w=rT(R[P],E);return w===-1?void 0:nT(R[P],w,1)[0]}return $E(R[P])},t.removeHooks=function(P){R[P]=[]},t.removeAllHooks=function(){R=sI()},t}var aI,zE,Zv,eT,tT,It,er,ai,cI,af,cf,ni,rT,$E,oi,nT,Et,es,tf,KE,ii,XE,oT,iT,sT,ZE,eI,Te,Zi,at,Cc,tI,rf,nf,uT,of,fT,rI,nI,sf,oI,Ec,mT,dT,gT,pT,hT,iI,CT,ET,IT,xT,si,yT,wT,sI,AI,uI=g(()=>{aI=Object.entries,zE=Object.setPrototypeOf,Zv=Object.isFrozen,eT=Object.getPrototypeOf,tT=Object.getOwnPropertyDescriptor,It=Object.freeze,er=Object.seal,ai=Object.create,cI=typeof Reflect<"u"&&Reflect,af=cI.apply,cf=cI.construct;It||(It=function(t){return t});er||(er=function(t){return t});af||(af=function(t,r){for(var n=arguments.length,o=new Array(n>2?n-2:0),i=2;i<n;i++)o[i-2]=arguments[i];return t.apply(r,o)});cf||(cf=function(t){for(var r=arguments.length,n=new Array(r>1?r-1:0),o=1;o<r;o++)n[o-1]=arguments[o];return new t(...n)});ni=Ge(Array.prototype.forEach),rT=Ge(Array.prototype.lastIndexOf),$E=Ge(Array.prototype.pop),oi=Ge(Array.prototype.push),nT=Ge(Array.prototype.splice),Et=Array.isArray,es=Ge(String.prototype.toLowerCase),tf=Ge(String.prototype.toString),KE=Ge(String.prototype.match),ii=Ge(String.prototype.replace),XE=Ge(String.prototype.indexOf),oT=Ge(String.prototype.trim),iT=Ge(Number.prototype.toString),sT=Ge(Boolean.prototype.toString),ZE=typeof BigInt>"u"?null:Ge(BigInt.prototype.toString),eI=typeof Symbol>"u"?null:Ge(Symbol.prototype.toString),Te=Ge(Object.prototype.hasOwnProperty),Zi=Ge(Object.prototype.toString),at=Ge(RegExp.prototype.test),Cc=aT(TypeError);tI=It(["a","abbr","acronym","address","area","article","aside","audio","b","bdi","bdo","big","blink","blockquote","body","br","button","canvas","caption","center","cite","code","col","colgroup","content","data","datalist","dd","decorator","del","details","dfn","dialog","dir","div","dl","dt","element","em","fieldset","figcaption","figure","font","footer","form","h1","h2","h3","h4","h5","h6","head","header","hgroup","hr","html","i","img","input","ins","kbd","label","legend","li","main","map","mark","marquee","menu","menuitem","meter","nav","nobr","ol","optgroup","option","output","p","picture","pre","progress","q","rp","rt","ruby","s","samp","search","section","select","shadow","slot","small","source","spacer","span","strike","strong","style","sub","summary","sup","table","tbody","td","template","textarea","tfoot","th","thead","time","tr","track","tt","u","ul","var","video","wbr"]),rf=It(["svg","a","altglyph","altglyphdef","altglyphitem","animatecolor","animatemotion","animatetransform","circle","clippath","defs","desc","ellipse","enterkeyhint","exportparts","filter","font","g","glyph","glyphref","hkern","image","inputmode","line","lineargradient","marker","mask","metadata","mpath","part","path","pattern","polygon","polyline","radialgradient","rect","stop","style","switch","symbol","text","textpath","title","tref","tspan","view","vkern"]),nf=It(["feBlend","feColorMatrix","feComponentTransfer","feComposite","feConvolveMatrix","feDiffuseLighting","feDisplacementMap","feDistantLight","feDropShadow","feFlood","feFuncA","feFuncB","feFuncG","feFuncR","feGaussianBlur","feImage","feMerge","feMergeNode","feMorphology","feOffset","fePointLight","feSpecularLighting","feSpotLight","feTile","feTurbulence"]),uT=It(["animate","color-profile","cursor","discard","font-face","font-face-format","font-face-name","font-face-src","font-face-uri","foreignobject","hatch","hatchpath","mesh","meshgradient","meshpatch","meshrow","missing-glyph","script","set","solidcolor","unknown","use"]),of=It(["math","menclose","merror","mfenced","mfrac","mglyph","mi","mlabeledtr","mmultiscripts","mn","mo","mover","mpadded","mphantom","mroot","mrow","ms","mspace","msqrt","mstyle","msub","msup","msubsup","mtable","mtd","mtext","mtr","munder","munderover","mprescripts"]),fT=It(["maction","maligngroup","malignmark","mlongdiv","mscarries","mscarry","msgroup","mstack","msline","msrow","semantics","annotation","annotation-xml","mprescripts","none"]),rI=It(["#text"]),nI=It(["accept","action","align","alt","autocapitalize","autocomplete","autopictureinpicture","autoplay","background","bgcolor","border","capture","cellpadding","cellspacing","checked","cite","class","clear","color","cols","colspan","command","commandfor","controls","controlslist","coords","crossorigin","datetime","decoding","default","dir","disabled","disablepictureinpicture","disableremoteplayback","download","draggable","enctype","enterkeyhint","exportparts","face","for","headers","height","hidden","high","href","hreflang","id","inert","inputmode","integrity","ismap","kind","label","lang","list","loading","loop","low","max","maxlength","media","method","min","minlength","multiple","muted","name","nonce","noshade","novalidate","nowrap","open","optimum","part","pattern","placeholder","playsinline","popover","popovertarget","popovertargetaction","poster","preload","pubdate","radiogroup","readonly","rel","required","rev","reversed","role","rows","rowspan","spellcheck","scope","selected","shape","size","sizes","slot","span","srclang","start","src","srcset","step","style","summary","tabindex","title","translate","type","usemap","valign","value","width","wrap","xmlns"]),sf=It(["accent-height","accumulate","additive","alignment-baseline","amplitude","ascent","attributename","attributetype","azimuth","basefrequency","baseline-shift","begin","bias","by","class","clip","clippathunits","clip-path","clip-rule","color","color-interpolation","color-interpolation-filters","color-profile","color-rendering","cx","cy","d","dx","dy","diffuseconstant","direction","display","divisor","dur","edgemode","elevation","end","exponent","fill","fill-opacity","fill-rule","filter","filterunits","flood-color","flood-opacity","font-family","font-size","font-size-adjust","font-stretch","font-style","font-variant","font-weight","fx","fy","g1","g2","glyph-name","glyphref","gradientunits","gradienttransform","height","href","id","image-rendering","in","in2","intercept","k","k1","k2","k3","k4","kerning","keypoints","keysplines","keytimes","lang","lengthadjust","letter-spacing","kernelmatrix","kernelunitlength","lighting-color","local","marker-end","marker-mid","marker-start","markerheight","markerunits","markerwidth","maskcontentunits","maskunits","max","mask","mask-type","media","method","mode","min","name","numoctaves","offset","operator","opacity","order","orient","orientation","origin","overflow","paint-order","path","pathlength","patterncontentunits","patterntransform","patternunits","points","preservealpha","preserveaspectratio","primitiveunits","r","rx","ry","radius","refx","refy","repeatcount","repeatdur","restart","result","rotate","scale","seed","shape-rendering","slope","specularconstant","specularexponent","spreadmethod","startoffset","stddeviation","stitchtiles","stop-color","stop-opacity","stroke-dasharray","stroke-dashoffset","stroke-linecap","stroke-linejoin","stroke-miterlimit","stroke-opacity","stroke","stroke-width","style","surfacescale","systemlanguage","tabindex","tablevalues","targetx","targety","transform","transform-origin","text-anchor","text-decoration","text-rendering","textlength","type","u1","u2","unicode","values","viewbox","visibility","version","vert-adv-y","vert-origin-x","vert-origin-y","width","word-spacing","wrap","writing-mode","xchannelselector","ychannelselector","x","x1","x2","xmlns","y","y1","y2","z","zoomandpan"]),oI=It(["accent","accentunder","align","bevelled","close","columnalign","columnlines","columnspacing","columnspan","denomalign","depth","dir","display","displaystyle","encoding","fence","frame","height","href","id","largeop","length","linethickness","lquote","lspace","mathbackground","mathcolor","mathsize","mathvariant","maxsize","minsize","movablelimits","notation","numalign","open","rowalign","rowlines","rowspacing","rowspan","rspace","rquote","scriptlevel","scriptminsize","scriptsizemultiplier","selection","separator","separators","stretchy","subscriptshift","supscriptshift","symmetric","voffset","width","xmlns"]),Ec=It(["xlink:href","xml:id","xlink:title","xml:space","xmlns:xlink"]),mT=er(/{{[\w\W]*|^[\w\W]*}}/g),dT=er(/<%[\w\W]*|^[\w\W]*%>/g),gT=er(/\${[\w\W]*/g),pT=er(/^data-[\-\w.\u00B7-\uFFFF]+$/),hT=er(/^aria-[\-\w]+$/),iI=er(/^(?:(?:(?:f|ht)tps?|mailto|tel|callto|sms|cid|xmpp|matrix):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i),CT=er(/^(?:\w+script|data):/i),ET=er(/[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205F\u3000]/g),IT=er(/^html$/i),xT=er(/^[a-z][.\w]*(-[.\w]+)+$/i),si={element:1,text:3,progressingInstruction:7,comment:8,document:9},yT=function(){return typeof window>"u"?null:window},wT=function(t,r){if(typeof t!="object"||typeof t.createPolicy!="function")return null;let n=null,o="data-tt-policy-suffix";r&&r.hasAttribute(o)&&(n=r.getAttribute(o));let i="dompurify"+(n?"#"+n:"");try{return t.createPolicy(i,{createHTML(s){return s},createScriptURL(s){return s}})}catch{return console.warn("TrustedTypes policy "+i+" could not be created."),null}},sI=function(){return{afterSanitizeAttributes:[],afterSanitizeElements:[],afterSanitizeShadowDOM:[],beforeSanitizeAttributes:[],beforeSanitizeElements:[],beforeSanitizeShadowDOM:[],uponSanitizeAttribute:[],uponSanitizeElement:[],uponSanitizeShadowNode:[]}};AI=lI()});var dI={};We(dI,{default:()=>mI});function mI({value:e,className:t}){let r=(0,Ic.useRef)(null);return(0,Ic.useLayoutEffect)(()=>{let n=r.current;if(n)for(let o of n.querySelectorAll("a"))o.setAttribute("rel","noopener noreferrer"),o.setAttribute("target","_blank")},[e]),(0,fI.jsx)("span",{ref:r,className:t,dangerouslySetInnerHTML:{__html:AI.sanitize(e)}})}var fI,Ic,gI=g(()=>{fI=f(F(),1),Ic=f(b(),1);uI()});function QT(e){return ST.test(e)}function MT(e){return e.includes("<")||e.includes("://")}function vT({value:e,className:t}){let r=(0,dn.useRef)(null);return(0,dn.useLayoutEffect)(()=>{let n=r.current;if(n)try{n.setHTML(e);for(let o of n.querySelectorAll("a"))o.setAttribute("rel","noopener noreferrer"),o.setAttribute("target","_blank")}catch(o){console.error(o)}},[e]),(0,Vn.jsx)("span",{ref:r,className:t})}function gn({html:e,className:t}){let r=`${e}`;if(!MT(r))return(0,Vn.jsx)("span",{className:t,children:r});let n=Rh(r),o=QT(n)?n:(0,pI.default)(n);return typeof Element<"u"&&Element.prototype.setHTML?(0,Vn.jsx)(vT,{value:o,className:t}):(0,Vn.jsx)(dn.Suspense,{fallback:(0,Vn.jsx)("span",{className:t}),children:(0,Vn.jsx)(BT,{value:o,className:t})})}var Vn,dn,pI,bT,BT,ST,lf=g(()=>{Vn=f(F(),1),dn=f(b(),1),pI=f(YE(),1);fn();bT=["a","b","br","code","div","em","h1","h2","h3","h4","h5","h6","i","img","li","p","pre","span","small","strong","table","tbody","sup","sub","td","tfoot","th","thead","tr","u","ul"],BT=(0,dn.lazy)(()=>Promise.resolve().then(()=>(gI(),dI))),ST=new RegExp(bT.map(e=>String.raw`<${e}\b[^>]*>`).join("|"),"i")});function TT({error:e}){let{classes:t}=EI();return(0,Pt.jsx)("div",{className:t.errorBox,children:(0,Pt.jsx)(qE,{error:e})})}var Pt,hI,mt,CI,EI,_T,II,xI=g(()=>{Pt=f(F(),1),hI=f(b(),1);fu();mt=f(D(),1),CI=f(O(),1);cu();JE();lf();Ct();EI=ee()(e=>({closeButton:{position:"absolute",right:e.spacing(1),top:e.spacing(1),color:e.palette.grey[500]},errorBox:{width:800,margin:40}}));_T=(0,CI.observer)(function(t){let{classes:r}=EI(),{titleNode:n,...o}=t,{title:i,header:s,children:a,onClose:c}=o,l=(0,mt.useTheme)();return(0,Pt.jsx)(mt.Dialog,{...o,children:(0,Pt.jsxs)(mt.ScopedCssBaseline,{children:[(0,hI.isValidElement)(s)?s:(0,Pt.jsxs)(mt.DialogTitle,{children:[n||(0,Pt.jsx)(gn,{html:i||""}),c?(0,Pt.jsx)(mt.IconButton,{className:r.closeButton,onClick:A=>{c(A,"backdropClick")},children:(0,Pt.jsx)(Pa,{})}):null]}),(0,Pt.jsx)(mt.Divider,{}),(0,Pt.jsx)(No,{FallbackComponent:TT,children:(0,Pt.jsx)(mt.ThemeProvider,{theme:(0,mt.createTheme)(l,{components:{MuiInputBase:{styleOverrides:{input:{boxSizing:"content-box!important"}}}}}),children:a})})]})})}),II=_T});function Af({onClose:e,helpText:t,label:r}){return(0,Yn.jsx)(II,{open:!0,onClose:e,title:"Help",titleNode:r?(0,Yn.jsxs)(Yn.Fragment,{children:["Help: ",r]}):void 0,onClick:n=>{n.stopPropagation()},onMouseDown:n=>{n.stopPropagation()},children:(0,Yn.jsx)(yI.DialogContent,{children:t})})}var Yn,yI,wI=g(()=>{Yn=f(F(),1),yI=f(D(),1);xI()});function uf({helpText:e,label:t}){let[r,n]=(0,xc.useState)(!1);return(0,Yr.jsxs)(Yr.Fragment,{children:[(0,Yr.jsx)(bI.IconButton,{size:"small",onClick:o=>{o.stopPropagation(),n(!0)},style:{marginLeft:4,padding:4},children:(0,Yr.jsx)(M0,{fontSize:"small"})}),r?(0,Yr.jsxs)(xc.Suspense,{fallback:null,children:[(0,Yr.jsx)(Af,{helpText:e,label:t,onClose:o=>{o.stopPropagation(),n(!1)}})," "]}):null]})}var Yr,xc,bI,BI=g(()=>{Yr=f(F(),1),xc=f(b(),1);v0();bI=f(D(),1);wI()});var SI,QI,MI,kT,vI,TI=g(()=>{SI=f(F(),1),QI=f(b(),1),MI=f(D(),1),kT=QI.forwardRef(function(t,r){return(0,SI.jsx)(MI.Menu,{...t,ref:r,style:{pointerEvents:"none",...t.style},slotProps:{...t.slotProps,paper:{style:{pointerEvents:"auto"}}}})}),vI=kT});var _I,kI,DI=g(()=>{"use client";W();_I=f(F(),1),kI=(0,_.createSvgIcon)((0,_I.jsx)("path",{d:"m10 17 5-5-5-5z"}),"ArrowRight")});var NI,LI,FI=g(()=>{"use client";W();NI=f(F(),1),LI=(0,_.createSvgIcon)((0,NI.jsx)("path",{d:"M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2m-9 14-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8z"}),"CheckBox")});var RI,PI,OI=g(()=>{"use client";W();RI=f(F(),1),PI=(0,_.createSvgIcon)((0,RI.jsx)("path",{d:"M19 5v14H5V5zm0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2"}),"CheckBoxOutlineBlank")});var GI,UI,HI=g(()=>{"use client";W();GI=f(F(),1),UI=(0,_.createSvgIcon)((0,GI.jsx)("path",{d:"M12 7c-2.76 0-5 2.24-5 5s2.24 5 5 5 5-2.24 5-5-2.24-5-5-5m0-5C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8"}),"RadioButtonChecked")});var jI,qI,JI=g(()=>{"use client";W();jI=f(F(),1),qI=(0,_.createSvgIcon)((0,jI.jsx)("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8"}),"RadioButtonUnchecked")});function VI(e){let{classes:t}=DT(),{type:r}=e,n,o;"checked"in e&&({checked:n,disabled:o}=e);let i;switch(r){case"subMenu":{i=(0,pn.jsx)(kI,{color:"action"});break}case"checkbox":{n?i=(0,pn.jsx)(LI,{color:o?"inherit":void 0}):i=(0,pn.jsx)(PI,{color:"action"});break}case"radio":{n?i=(0,pn.jsx)(UI,{color:o?"inherit":void 0}):i=(0,pn.jsx)(qI,{color:"action"});break}}return(0,pn.jsx)("div",{className:t.menuItemEndDecoration,children:i})}var pn,yc,DT,YI=g(()=>{pn=f(F(),1);DI();FI();OI();HI();JI();yc=f(D(),1);Ct();DT=ee()({menuItemEndDecoration:{padding:0,margin:0,height:16}})});function WI(e){if(typeof e=="string")return e.toLowerCase().replace(/\s+/g,"_")}function NT({title:e,Icon:t,inset:r,menuItems:n,onMenuItemClick:o,closeAfterItemClick:i,onCloseRoot:s,isOpen:a,onOpen:c,onClose:l}){let[A,u]=(0,ff.useState)(null),m=WI(e);return(0,ce.jsxs)(ce.Fragment,{children:[(0,ce.jsxs)(xt.MenuItem,{ref:u,"data-testid":m?`cascading-submenu-${m}`:void 0,onMouseOver:c,onFocus:c,onClick:c,children:[t?(0,ce.jsx)(xt.ListItemIcon,{children:(0,ce.jsx)(t,{})}):null,(0,ce.jsx)(xt.ListItemText,{primary:e,inset:r}),(0,ce.jsx)(B0,{})]}),(0,ce.jsx)(vI,{open:a,anchorEl:A,onClose:l,anchorOrigin:{vertical:"top",horizontal:"right"},transformOrigin:{vertical:"top",horizontal:"left"},children:(0,ce.jsx)(zI,{closeAfterItemClick:i,onMenuItemClick:o,menuItems:n,onCloseRoot:s})})]})}function zI({onMenuItemClick:e,closeAfterItemClick:t,menuItems:r,onCloseRoot:n}){let[o,i]=(0,ff.useState)(),s=()=>{i(void 0)},a=r.some(A=>"icon"in A&&A.icon),c=r.some(A=>(A.type==="checkbox"||A.type==="radio")&&"helpText"in A&&A.helpText),l=r.toSorted((A,u)=>(u.priority||0)-(A.priority||0));return(0,ce.jsx)(ce.Fragment,{children:l.map((A,u)=>{if("subMenu"in A)return(0,ce.jsx)(NT,{title:A.label,Icon:A.icon,inset:a&&!A.icon,onMenuItemClick:e,menuItems:A.subMenu,closeAfterItemClick:t,onCloseRoot:n,isOpen:o===u,onOpen:()=>{i(u)},onClose:s},`subMenu-${A.label}-${u}`);if(A.type==="divider")return(0,ce.jsx)(xt.Divider,{component:"li"},`divider-${u}`);if(A.type==="subHeader")return(0,ce.jsx)(xt.ListSubheader,{children:A.label},`subHeader-${A.label}-${u}`);let m=A,d=m.helpText,p=m.type==="checkbox"||m.type==="radio",C=WI(m.label);return(0,ce.jsxs)(xt.MenuItem,{"data-testid":C?`cascading-menuitem-${C}`:void 0,disabled:!!m.disabled,onClick:y=>{t&&n(),e(y,m.onClick)},onMouseOver:s,children:[m.icon?(0,ce.jsx)(xt.ListItemIcon,{children:(0,ce.jsx)(m.icon,{})}):null,(0,ce.jsx)(xt.ListItemText,{primary:m.label,secondary:m.subLabel,inset:a&&!m.icon}),(0,ce.jsx)("div",{style:{flexGrow:1,minWidth:10}}),p?(0,ce.jsx)(VI,{type:m.type,checked:m.checked,disabled:m.disabled}):null,d?(0,ce.jsx)(uf,{helpText:d,label:m.label}):p&&c?(0,ce.jsx)("div",{style:{marginLeft:4,padding:4,width:28,height:28}}):null]},`${m.label}-${u}`)})})}function mf({onMenuItemClick:e,closeAfterItemClick:t=!0,menuItems:r,open:n,onClose:o,anchorEl:i,anchorOrigin:s,transformOrigin:a,anchorReference:c,anchorPosition:l,slotProps:A,marginThreshold:u,style:m}){let d=Array.isArray(r)?r:r();return(0,ce.jsx)(xt.Menu,{anchorEl:i,open:n,onClose:o,anchorOrigin:s,transformOrigin:a,anchorReference:c,anchorPosition:l,slotProps:A,marginThreshold:u??void 0,style:m,children:(0,ce.jsx)(zI,{menuItems:d,closeAfterItemClick:t,onMenuItemClick:e,onCloseRoot:o})})}var ce,ff,xt,$I=g(()=>{ce=f(F(),1),ff=f(b(),1);S0();xt=f(D(),1);BI();TI();YI()});function LT({children:e,menuItems:t,closeAfterItemClick:r=!0,stopPropagation:n,disabled:o,setOpen:i,ButtonComponent:s=KI.IconButton,onClick:a,anchorOrigin:c,transformOrigin:l,marginThreshold:A,...u}){let[m,d]=(0,wc.useState)(null),p=!!m;(0,wc.useEffect)(()=>{i?.(p)},[p,i]);let C=o??(Array.isArray(t)&&t.length===0);return(0,Wn.jsxs)(Wn.Fragment,{children:[(0,Wn.jsx)(s,{onClick:y=>{n&&y.stopPropagation(),d(y.currentTarget),a?.(y)},...u,disabled:C,children:e}),p?(0,Wn.jsx)(mf,{open:p,onClose:()=>{d(null)},anchorEl:m,anchorOrigin:c,transformOrigin:l,marginThreshold:A,menuItems:t,closeAfterItemClick:r,onMenuItemClick:(y,I)=>{I()}}):null]})}var Wn,wc,KI,vr,ci=g(()=>{Wn=f(F(),1),wc=f(b(),1),KI=f(D(),1);$I();vr=LT});var XI,ZI,ex=g(()=>{"use client";W();XI=f(F(),1),ZI=(0,_.createSvgIcon)((0,XI.jsx)("path",{d:"M12 2C6.49 2 2 6.49 2 12s4.49 10 10 10c1.38 0 2.5-1.12 2.5-2.5 0-.61-.23-1.2-.64-1.67-.08-.1-.13-.21-.13-.33 0-.28.22-.5.5-.5H16c3.31 0 6-2.69 6-6 0-4.96-4.49-9-10-9m5.5 11c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5m-3-4c-.83 0-1.5-.67-1.5-1.5S13.67 6 14.5 6s1.5.67 1.5 1.5S15.33 9 14.5 9M5 11.5c0-.83.67-1.5 1.5-1.5s1.5.67 1.5 1.5S7.33 13 6.5 13 5 12.33 5 11.5m6-4c0 .83-.67 1.5-1.5 1.5S8 8.33 8 7.5 8.67 6 9.5 6s1.5.67 1.5 1.5"}),"Palette")});var FT,li,tx=g(()=>{FT={50:"#ffebee",100:"#ffcdd2",200:"#ef9a9a",300:"#e57373",400:"#ef5350",500:"#f44336",600:"#e53935",700:"#d32f2f",800:"#c62828",900:"#b71c1c",A100:"#ff8a80",A200:"#ff5252",A400:"#ff1744",A700:"#d50000"},li=FT});var RT,ts,rx=g(()=>{RT={50:"#e3f2fd",100:"#bbdefb",200:"#90caf9",300:"#64b5f6",400:"#42a5f5",500:"#2196f3",600:"#1e88e5",700:"#1976d2",800:"#1565c0",900:"#0d47a1",A100:"#82b1ff",A200:"#448aff",A400:"#2979ff",A700:"#2962ff"},ts=RT});var PT,rs,nx=g(()=>{PT={50:"#e8f5e9",100:"#c8e6c9",200:"#a5d6a7",300:"#81c784",400:"#66bb6a",500:"#4caf50",600:"#43a047",700:"#388e3c",800:"#2e7d32",900:"#1b5e20",A100:"#b9f6ca",A200:"#69f0ae",A400:"#00e676",A700:"#00c853"},rs=PT});var OT,ns,ox=g(()=>{OT={50:"#fff3e0",100:"#ffe0b2",200:"#ffcc80",300:"#ffb74d",400:"#ffa726",500:"#ff9800",600:"#fb8c00",700:"#f57c00",800:"#ef6c00",900:"#e65100",A100:"#ffd180",A200:"#ffab40",A400:"#ff9100",A700:"#ff6d00"},ns=OT});var GT,hn,ix=g(()=>{GT={50:"#fafafa",100:"#f5f5f5",200:"#eeeeee",300:"#e0e0e0",400:"#bdbdbd",500:"#9e9e9e",600:"#757575",700:"#616161",800:"#424242",900:"#212121",A100:"#f5f5f5",A200:"#eeeeee",A400:"#bdbdbd",A700:"#616161"},hn=GT});var df=g(()=>{tx();rx();nx();ox();ix()});var UT,Wr,Ze,tr,mx,sx,gf,HT,bc,dx,gx,ax,cx,lx,os,jT,qT,JT,VT,Cf,Ax,YT,pf,hf,ux,Ef,yt,fx,Bc,Sc=g(()=>{UT={grad:.9,turn:360,rad:360/(2*Math.PI)},Wr=function(e){return typeof e=="string"?e.length>0:typeof e=="number"},Ze=function(e,t,r){return t===void 0&&(t=0),r===void 0&&(r=Math.pow(10,t)),Math.round(r*e)/r+0},tr=function(e,t,r){return t===void 0&&(t=0),r===void 0&&(r=1),e>r?r:e>t?e:t},mx=function(e){return(e=isFinite(e)?e%360:0)>0?e:e+360},sx=function(e){return{r:tr(e.r,0,255),g:tr(e.g,0,255),b:tr(e.b,0,255),a:tr(e.a)}},gf=function(e){return{r:Ze(e.r),g:Ze(e.g),b:Ze(e.b),a:Ze(e.a,3)}},HT=/^#([0-9a-f]{3,8})$/i,bc=function(e){var t=e.toString(16);return t.length<2?"0"+t:t},dx=function(e){var t=e.r,r=e.g,n=e.b,o=e.a,i=Math.max(t,r,n),s=i-Math.min(t,r,n),a=s?i===t?(r-n)/s:i===r?2+(n-t)/s:4+(t-r)/s:0;return{h:60*(a<0?a+6:a),s:i?s/i*100:0,v:i/255*100,a:o}},gx=function(e){var t=e.h,r=e.s,n=e.v,o=e.a;t=t/360*6,r/=100,n/=100;var i=Math.floor(t),s=n*(1-r),a=n*(1-(t-i)*r),c=n*(1-(1-t+i)*r),l=i%6;return{r:255*[n,a,s,s,c,n][l],g:255*[c,n,n,a,s,s][l],b:255*[s,s,c,n,n,a][l],a:o}},ax=function(e){return{h:mx(e.h),s:tr(e.s,0,100),l:tr(e.l,0,100),a:tr(e.a)}},cx=function(e){return{h:Ze(e.h),s:Ze(e.s),l:Ze(e.l),a:Ze(e.a,3)}},lx=function(e){return gx((r=(t=e).s,{h:t.h,s:(r*=((n=t.l)<50?n:100-n)/100)>0?2*r/(n+r)*100:0,v:n+r,a:t.a}));var t,r,n},os=function(e){return{h:(t=dx(e)).h,s:(o=(200-(r=t.s))*(n=t.v)/100)>0&&o<200?r*n/100/(o<=100?o:200-o)*100:0,l:o/2,a:t.a};var t,r,n,o},jT=/^hsla?\(\s*([+-]?\d*\.?\d+)(deg|rad|grad|turn)?\s*,\s*([+-]?\d*\.?\d+)%\s*,\s*([+-]?\d*\.?\d+)%\s*(?:,\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i,qT=/^hsla?\(\s*([+-]?\d*\.?\d+)(deg|rad|grad|turn)?\s+([+-]?\d*\.?\d+)%\s+([+-]?\d*\.?\d+)%\s*(?:\/\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i,JT=/^rgba?\(\s*([+-]?\d*\.?\d+)(%)?\s*,\s*([+-]?\d*\.?\d+)(%)?\s*,\s*([+-]?\d*\.?\d+)(%)?\s*(?:,\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i,VT=/^rgba?\(\s*([+-]?\d*\.?\d+)(%)?\s+([+-]?\d*\.?\d+)(%)?\s+([+-]?\d*\.?\d+)(%)?\s*(?:\/\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i,Cf={string:[[function(e){var t=HT.exec(e);return t?(e=t[1]).length<=4?{r:parseInt(e[0]+e[0],16),g:parseInt(e[1]+e[1],16),b:parseInt(e[2]+e[2],16),a:e.length===4?Ze(parseInt(e[3]+e[3],16)/255,2):1}:e.length===6||e.length===8?{r:parseInt(e.substr(0,2),16),g:parseInt(e.substr(2,2),16),b:parseInt(e.substr(4,2),16),a:e.length===8?Ze(parseInt(e.substr(6,2),16)/255,2):1}:null:null},"hex"],[function(e){var t=JT.exec(e)||VT.exec(e);return t?t[2]!==t[4]||t[4]!==t[6]?null:sx({r:Number(t[1])/(t[2]?100/255:1),g:Number(t[3])/(t[4]?100/255:1),b:Number(t[5])/(t[6]?100/255:1),a:t[7]===void 0?1:Number(t[7])/(t[8]?100:1)}):null},"rgb"],[function(e){var t=jT.exec(e)||qT.exec(e);if(!t)return null;var r,n,o=ax({h:(r=t[1],n=t[2],n===void 0&&(n="deg"),Number(r)*(UT[n]||1)),s:Number(t[3]),l:Number(t[4]),a:t[5]===void 0?1:Number(t[5])/(t[6]?100:1)});return lx(o)},"hsl"]],object:[[function(e){var t=e.r,r=e.g,n=e.b,o=e.a,i=o===void 0?1:o;return Wr(t)&&Wr(r)&&Wr(n)?sx({r:Number(t),g:Number(r),b:Number(n),a:Number(i)}):null},"rgb"],[function(e){var t=e.h,r=e.s,n=e.l,o=e.a,i=o===void 0?1:o;if(!Wr(t)||!Wr(r)||!Wr(n))return null;var s=ax({h:Number(t),s:Number(r),l:Number(n),a:Number(i)});return lx(s)},"hsl"],[function(e){var t=e.h,r=e.s,n=e.v,o=e.a,i=o===void 0?1:o;if(!Wr(t)||!Wr(r)||!Wr(n))return null;var s=(function(a){return{h:mx(a.h),s:tr(a.s,0,100),v:tr(a.v,0,100),a:tr(a.a)}})({h:Number(t),s:Number(r),v:Number(n),a:Number(i)});return gx(s)},"hsv"]]},Ax=function(e,t){for(var r=0;r<t.length;r++){var n=t[r][0](e);if(n)return[n,t[r][1]]}return[null,void 0]},YT=function(e){return typeof e=="string"?Ax(e.trim(),Cf.string):typeof e=="object"&&e!==null?Ax(e,Cf.object):[null,void 0]},pf=function(e,t){var r=os(e);return{h:r.h,s:tr(r.s+100*t,0,100),l:r.l,a:r.a}},hf=function(e){return(299*e.r+587*e.g+114*e.b)/1e3/255},ux=function(e,t){var r=os(e);return{h:r.h,s:r.s,l:tr(r.l+100*t,0,100),a:r.a}},Ef=(function(){function e(t){this.parsed=YT(t)[0],this.rgba=this.parsed||{r:0,g:0,b:0,a:1}}return e.prototype.isValid=function(){return this.parsed!==null},e.prototype.brightness=function(){return Ze(hf(this.rgba),2)},e.prototype.isDark=function(){return hf(this.rgba)<.5},e.prototype.isLight=function(){return hf(this.rgba)>=.5},e.prototype.toHex=function(){return t=gf(this.rgba),r=t.r,n=t.g,o=t.b,s=(i=t.a)<1?bc(Ze(255*i)):"","#"+bc(r)+bc(n)+bc(o)+s;var t,r,n,o,i,s},e.prototype.toRgb=function(){return gf(this.rgba)},e.prototype.toRgbString=function(){return t=gf(this.rgba),r=t.r,n=t.g,o=t.b,(i=t.a)<1?"rgba("+r+", "+n+", "+o+", "+i+")":"rgb("+r+", "+n+", "+o+")";var t,r,n,o,i},e.prototype.toHsl=function(){return cx(os(this.rgba))},e.prototype.toHslString=function(){return t=cx(os(this.rgba)),r=t.h,n=t.s,o=t.l,(i=t.a)<1?"hsla("+r+", "+n+"%, "+o+"%, "+i+")":"hsl("+r+", "+n+"%, "+o+"%)";var t,r,n,o,i},e.prototype.toHsv=function(){return t=dx(this.rgba),{h:Ze(t.h),s:Ze(t.s),v:Ze(t.v),a:Ze(t.a,3)};var t},e.prototype.invert=function(){return yt({r:255-(t=this.rgba).r,g:255-t.g,b:255-t.b,a:t.a});var t},e.prototype.saturate=function(t){return t===void 0&&(t=.1),yt(pf(this.rgba,t))},e.prototype.desaturate=function(t){return t===void 0&&(t=.1),yt(pf(this.rgba,-t))},e.prototype.grayscale=function(){return yt(pf(this.rgba,-1))},e.prototype.lighten=function(t){return t===void 0&&(t=.1),yt(ux(this.rgba,t))},e.prototype.darken=function(t){return t===void 0&&(t=.1),yt(ux(this.rgba,-t))},e.prototype.rotate=function(t){return t===void 0&&(t=15),this.hue(this.hue()+t)},e.prototype.alpha=function(t){return typeof t=="number"?yt({r:(r=this.rgba).r,g:r.g,b:r.b,a:t}):Ze(this.rgba.a,3);var r},e.prototype.hue=function(t){var r=os(this.rgba);return typeof t=="number"?yt({h:t,s:r.s,l:r.l,a:r.a}):Ze(r.h)},e.prototype.isEqual=function(t){return this.toHex()===yt(t).toHex()},e})(),yt=function(e){return e instanceof Ef?e:new Ef(e)},fx=[],Bc=function(e){e.forEach(function(t){fx.indexOf(t)<0&&(t(Ef,Cf),fx.push(t))})}});function Qc(e,t){var r={white:"#ffffff",bisque:"#ffe4c4",blue:"#0000ff",cadetblue:"#5f9ea0",chartreuse:"#7fff00",chocolate:"#d2691e",coral:"#ff7f50",antiquewhite:"#faebd7",aqua:"#00ffff",azure:"#f0ffff",whitesmoke:"#f5f5f5",papayawhip:"#ffefd5",plum:"#dda0dd",blanchedalmond:"#ffebcd",black:"#000000",gold:"#ffd700",goldenrod:"#daa520",gainsboro:"#dcdcdc",cornsilk:"#fff8dc",cornflowerblue:"#6495ed",burlywood:"#deb887",aquamarine:"#7fffd4",beige:"#f5f5dc",crimson:"#dc143c",cyan:"#00ffff",darkblue:"#00008b",darkcyan:"#008b8b",darkgoldenrod:"#b8860b",darkkhaki:"#bdb76b",darkgray:"#a9a9a9",darkgreen:"#006400",darkgrey:"#a9a9a9",peachpuff:"#ffdab9",darkmagenta:"#8b008b",darkred:"#8b0000",darkorchid:"#9932cc",darkorange:"#ff8c00",darkslateblue:"#483d8b",gray:"#808080",darkslategray:"#2f4f4f",darkslategrey:"#2f4f4f",deeppink:"#ff1493",deepskyblue:"#00bfff",wheat:"#f5deb3",firebrick:"#b22222",floralwhite:"#fffaf0",ghostwhite:"#f8f8ff",darkviolet:"#9400d3",magenta:"#ff00ff",green:"#008000",dodgerblue:"#1e90ff",grey:"#808080",honeydew:"#f0fff0",hotpink:"#ff69b4",blueviolet:"#8a2be2",forestgreen:"#228b22",lawngreen:"#7cfc00",indianred:"#cd5c5c",indigo:"#4b0082",fuchsia:"#ff00ff",brown:"#a52a2a",maroon:"#800000",mediumblue:"#0000cd",lightcoral:"#f08080",darkturquoise:"#00ced1",lightcyan:"#e0ffff",ivory:"#fffff0",lightyellow:"#ffffe0",lightsalmon:"#ffa07a",lightseagreen:"#20b2aa",linen:"#faf0e6",mediumaquamarine:"#66cdaa",lemonchiffon:"#fffacd",lime:"#00ff00",khaki:"#f0e68c",mediumseagreen:"#3cb371",limegreen:"#32cd32",mediumspringgreen:"#00fa9a",lightskyblue:"#87cefa",lightblue:"#add8e6",midnightblue:"#191970",lightpink:"#ffb6c1",mistyrose:"#ffe4e1",moccasin:"#ffe4b5",mintcream:"#f5fffa",lightslategray:"#778899",lightslategrey:"#778899",navajowhite:"#ffdead",navy:"#000080",mediumvioletred:"#c71585",powderblue:"#b0e0e6",palegoldenrod:"#eee8aa",oldlace:"#fdf5e6",paleturquoise:"#afeeee",mediumturquoise:"#48d1cc",mediumorchid:"#ba55d3",rebeccapurple:"#663399",lightsteelblue:"#b0c4de",mediumslateblue:"#7b68ee",thistle:"#d8bfd8",tan:"#d2b48c",orchid:"#da70d6",mediumpurple:"#9370db",purple:"#800080",pink:"#ffc0cb",skyblue:"#87ceeb",springgreen:"#00ff7f",palegreen:"#98fb98",red:"#ff0000",yellow:"#ffff00",slateblue:"#6a5acd",lavenderblush:"#fff0f5",peru:"#cd853f",palevioletred:"#db7093",violet:"#ee82ee",teal:"#008080",slategray:"#708090",slategrey:"#708090",aliceblue:"#f0f8ff",darkseagreen:"#8fbc8f",darkolivegreen:"#556b2f",greenyellow:"#adff2f",seagreen:"#2e8b57",seashell:"#fff5ee",tomato:"#ff6347",silver:"#c0c0c0",sienna:"#a0522d",lavender:"#e6e6fa",lightgreen:"#90ee90",orange:"#ffa500",orangered:"#ff4500",steelblue:"#4682b4",royalblue:"#4169e1",turquoise:"#40e0d0",yellowgreen:"#9acd32",salmon:"#fa8072",saddlebrown:"#8b4513",sandybrown:"#f4a460",rosybrown:"#bc8f8f",darksalmon:"#e9967a",lightgoldenrodyellow:"#fafad2",snow:"#fffafa",lightgrey:"#d3d3d3",lightgray:"#d3d3d3",dimgray:"#696969",dimgrey:"#696969",olivedrab:"#6b8e23",olive:"#808000"},n={};for(var o in r)n[r[o]]=o;var i={};e.prototype.toName=function(s){if(!(this.rgba.a||this.rgba.r||this.rgba.g||this.rgba.b))return"transparent";var a,c,l=n[this.toHex()];if(l)return l;if(s?.closest){var A=this.toRgb(),u=1/0,m="black";if(!i.length)for(var d in r)i[d]=new e(r[d]).toRgb();for(var p in r){var C=(a=A,c=i[p],Math.pow(a.r-c.r,2)+Math.pow(a.g-c.g,2)+Math.pow(a.b-c.b,2));C<u&&(u=C,m=p)}return m}},t.string.push([function(s){var a=s.toLowerCase(),c=a==="transparent"?"#0000":r[a];return c?new e(c).toRgb():null},"name"])}var If=g(()=>{});function Mc(e,t){return Object.fromEntries(Object.entries(e).map(t))}function zn(e,t){return Mc(e,([r,n])=>[r,t.palette.getContrastText(yt(n).toHex())])}function xf(e,t){if(e.length===0)return t;let r=[],n=0;for(let o of e)o>n&&r.push(t.slice(n,o)),n=o+1;return n<t.length&&r.push(t.slice(n)),r.join("")}function yf(e){return e.end-e.start}function is(e){return e==="-"||e==="."}var Cn=g(()=>{Sc();If();Bc([Qc])});var WT,Ai,vc=g(()=>{df();Sc();If();Cn();Bc([Qc]);WT={none:{},clustal:{G:"orange",P:"orange",S:"orange",T:"orange",H:"red",K:"red",R:"red",F:"blue",W:"blue",Y:"blue",I:"green",L:"green",M:"green",V:"green"},lesk:{G:"orange",A:"orange",S:"orange",T:"orange",C:"green",V:"green",I:"green",L:"green",P:"green",F:"green",Y:"green",M:"green",W:"green",N:"magenta",Q:"magenta",H:"magenta",D:"red",E:"red",K:"blue",R:"blue"},maeditor:{A:"lightgreen",G:"lightgreen",C:"green",D:"darkgreen",E:"darkgreen",N:"darkgreen",Q:"darkgreen",I:"blue",L:"blue",M:"blue",V:"blue",F:"#c8a2c8",W:"#c8a2c8",Y:"#c8a2c8",H:"darkblue",K:"orange",R:"orange",P:"pink",S:"red",T:"red"},percent_identity_dynamic:{},flower:{A:"#b18a51",C:"#ff5701",D:"#01a578",E:"#2da0a1",F:"#fa559d",G:"#b1c23c",H:"#0194f9",I:"#f27663",K:"#7fc3d7",L:"#df6e75",M:"#fe9daf",N:"#0bcec6",P:"#4fa32a",Q:"#7295ae",R:"#83bff1",S:"#b4bd9b",T:"#d2b576",V:"#fd997b",W:"#ff2ded",Y:"#c96ecf"},rainbow_dna:{A:"#3737f5",C:"#37f537",G:"#f5f537",T:"#f53737",U:"#f53737"},clustalx_protein:{A:"#197fe5",C:"#e57f7f",D:"#cc4ccc",E:"#cc4ccc",F:"#197fe5",G:"#e5994c",H:"#19b2b2",I:"#197fe5",K:"#e53319",L:"#197fe5",M:"#197fe5",N:"#19cc19",P:"#cccc00",Q:"#19cc19",R:"#e53319",S:"#19cc19",T:"#19cc19",V:"#197fe5",W:"#197fe5",Y:"#19b2b2"},clustalx_protein_dynamic:{},clustalx_dna:{A:"#e53319",C:"#197fe5",G:"#e5994c",T:"#19cc19",U:"#19cc19"},jbrowse_dna:{A:rs[500],C:ts[500],G:ns[500],T:li[500],U:li[500]},jalview_buried:{A:"#00a35c",R:"#00fc03",N:"#00eb14",D:"#00eb14",C:"#0000ff",Q:"#00f10e",E:"#00f10e",G:"#009d62",H:"#00d52a",I:"#0054ab",L:"#007b84",K:"#00ff00",M:"#009768",F:"#008778",P:"#00e01f",S:"#00d52a",T:"#00db24",W:"#00a857",Y:"#00e619",V:"#005fa0",B:"#00eb14",X:"#00b649",Z:"#00f10e"},jalview_hydrophobicity:{A:"#ad0052",R:"#0000ff",N:"#0c00f3",D:"#0c00f3",C:"#c2003d",Q:"#0c00f3",E:"#0c00f3",G:"#6a0095",H:"#1500ea",I:"#ff0000",L:"#ea0015",K:"#0000ff",M:"#b0004f",F:"#cb0034",P:"#4600b9",S:"#5e00a1",T:"#61009e",W:"#5b00a4",Y:"#4f00b0",V:"#f60009",B:"#0c00f3",X:"#680097",Z:"#0c00f3"},jalview_prophelix:{A:"#e718e7",R:"#6f906f",N:"#1be41b",D:"#778877",C:"#23dc23",Q:"#926d92",E:"#ff00ff",G:"#00ff00",H:"#758a75",I:"#8a758a",L:"#ae51ae",K:"#a05fa0",M:"#ef10ef",F:"#986798",P:"#00ff00",S:"#36c936",T:"#47b847",W:"#8a758a",Y:"#21de21",V:"#857a85",B:"#49b649",X:"#758a75",Z:"#c936c9"},jalview_propstrand:{A:"#5858a7",R:"#6b6b94",N:"#64649b",D:"#2121de",C:"#9d9d62",Q:"#8c8c73",E:"#0000ff",G:"#4949b6",H:"#60609f",I:"#ecec13",L:"#b2b24d",K:"#4747b8",M:"#82827d",F:"#c2c23d",P:"#2323dc",S:"#4949b6",T:"#9d9d62",W:"#c0c03f",Y:"#d3d32c",V:"#ffff00",B:"#4343bc",X:"#797986",Z:"#4747b8"},jalview_propturn:{A:"#2cd3d3",R:"#708f8f",N:"#ff0000",D:"#e81717",C:"#a85757",Q:"#3fc0c0",E:"#778888",G:"#ff0000",H:"#708f8f",I:"#00ffff",L:"#1ce3e3",K:"#7e8181",M:"#1ee1e1",F:"#1ee1e1",P:"#f60909",S:"#e11e1e",T:"#738c8c",W:"#738c8c",Y:"#9d6262",V:"#07f8f8",B:"#f30c0c",X:"#7c8383",Z:"#5ba4a4"},jalview_taylor:{A:"#ccff00",R:"#0000ff",N:"#cc00ff",D:"#ff0000",C:"#ffff00",Q:"#ff00cc",E:"#ff0066",G:"#ff9900",H:"#0066ff",I:"#66ff00",L:"#33ff00",K:"#6600ff",M:"#00ff00",F:"#00ff66",P:"#ffcc00",S:"#ff3300",T:"#ff6600",W:"#00ccff",Y:"#00ffcc",V:"#99ff00"},jalview_zappo:{A:"#ffafaf",R:"#6464ff",N:"#00ff00",D:"#ff0000",C:"#ffff00",Q:"#00ff00",E:"#ff0000",G:"#ff00ff",H:"#6464ff",I:"#ffafaf",L:"#ffafaf",K:"#6464ff",M:"#ffafaf",F:"#ffc800",P:"#ff00ff",S:"#00ff00",T:"#00ff00",W:"#ffc800",Y:"#ffc800",V:"#ffafaf"},cinema:{H:"blue",K:"blue",R:"blue",D:"red",E:"red",S:"green",T:"green",N:"green",Q:"green",A:"white",V:"white",L:"white",I:"white",M:"white",F:"magenta",W:"magenta",Y:"magenta",P:"brown",G:"brown",C:"yellow",B:"gray",Z:"gray",X:"gray","-":"gray",".":"gray"}},Ai=Mc(WT,([e,t])=>[e,Mc(t,([r,n])=>[r,yt(n).toHex()])])});var wf,px,zT,hx,Cx=g(()=>{wf=f(b(),1);ci();ex();px=f(O(),1);vc();zT=(0,px.observer)(function({model:e}){let{colorSchemeName:t}=e;return wf.default.createElement(vr,{closeAfterItemClick:!0,anchorOrigin:{vertical:"bottom",horizontal:"left"},transformOrigin:{vertical:"top",horizontal:"left"},menuItems:Object.keys(Ai).map(r=>({label:r,type:"radio",checked:t===r,onClick:()=>{e.setColorSchemeName(r)}}))},wf.default.createElement(ZI,null))}),hx=zT});var Ex,Ix,xx=g(()=>{"use client";W();Ex=f(F(),1),Ix=(0,_.createSvgIcon)((0,Ex.jsx)("path",{d:"M19 3h-4.18C14.4 1.84 13.3 1 12 1s-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2m-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1m2 14H7v-2h7zm3-4H7v-2h10zm0-4H7V7h10z"}),"Assignment")});var yx,ss,bf=g(()=>{"use client";W();yx=f(F(),1),ss=(0,_.createSvgIcon)((0,yx.jsx)("path",{d:"M20 6h-8l-2-2H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2m0 12H4V8h16z"}),"FolderOpen")});var Bf,wx,bx=g(()=>{"use client";W();Bf=f(F(),1),wx=(0,_.createSvgIcon)([(0,Bf.jsx)("circle",{cx:"12",cy:"12",r:"3.2"},"0"),(0,Bf.jsx)("path",{d:"M9 2 7.17 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2h-3.17L15 2zm3 15c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5"},"1")],"PhotoCamera")});var Bx,Sx,Qx=g(()=>{"use client";W();Bx=f(F(),1),Sx=(0,_.createSvgIcon)((0,Bx.jsx)("path",{d:"M4.25 5.61C6.27 8.2 10 13 10 13v6c0 .55.45 1 1 1h2c.55 0 1-.45 1-1v-6s3.72-4.8 5.74-7.39c.51-.66.04-1.61-.79-1.61H5.04c-.83 0-1.3.95-.79 1.61"}),"FilterAlt")});var Mx,vx,Tx=g(()=>{"use client";W();Mx=f(F(),1),vx=(0,_.createSvgIcon)((0,Mx.jsx)("path",{d:"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14"}),"Search")});var _x,kx,Dx=g(()=>{"use client";W();_x=f(F(),1),kx=(0,_.createSvgIcon)((0,_x.jsx)("path",{d:"M3 18h6v-2H3zM3 6v2h18V6zm0 7h12v-2H3z"}),"Sort")});var Nx,Lx,Fx=g(()=>{"use client";W();Nx=f(F(),1),Lx=(0,_.createSvgIcon)((0,Nx.jsx)("path",{d:"M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5M12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5m0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3"}),"Visibility")});function Rx(e){return Sf[Math.min(e,Sf.length-1)]}var Sf,Qf,Mf=g(()=>{Sf=[["#F8766D"],["#F8766D","#00BFC4"],["#F8766D","#00BA38","#619CFF"],["#F8766D","#7CAE00","#00BFC4","#C77CFF"],["#F8766D","#A3A500","#00BF7D","#00B0F6","#E76BF3"],["#F8766D","#B79F00","#00BA38","#00BFC4","#619CFF","#F564E3"],["#F8766D","#C49A00","#53B400","#00C094","#00B6EB","#A58AFF","#FB61D7"],["#F8766D","#CD9600","#7CAE00","#00BE67","#00BFC4","#00A9FF","#C77CFF","#FF61CC"]];Qf=Sf});var Ox={};We(Ox,{default:()=>ZT});var ue,Px,as,Tc,$T,KT,XT,ZT,Gx=g(()=>{ue=f(b(),1),Px=f(ye(),1),as=f(D(),1),Tc=f(O(),1);Mf();$T=(0,Tc.observer)(function({model:e}){let{featureFilters:t}=e;return ue.default.createElement("div",null,ue.default.createElement(as.Button,{onClick:()=>{for(let r of t.keys())e.setFilter(r,!0)}},"Toggle all on"),ue.default.createElement(as.Button,{onClick:()=>{for(let r of t.keys())e.setFilter(r,!1)}},"Toggle all off"))}),KT=(0,Tc.observer)(function({model:e}){let{tidyInterProAnnotationTypes:t,featureFilters:r}=e,n=[...t.values()],o=Rx(n.length-1);return ue.default.createElement(ue.default.Fragment,null,ue.default.createElement($T,{model:e}),ue.default.createElement("table",null,ue.default.createElement("thead",null,ue.default.createElement("tr",null,ue.default.createElement("td",null),ue.default.createElement("td",null,"accession"),ue.default.createElement("td",null,"name"),ue.default.createElement("td",null,"description"))),ue.default.createElement("tbody",null,n.map(({accession:i,name:s,description:a},c)=>ue.default.createElement("tr",{key:i},ue.default.createElement("td",null,ue.default.createElement("input",{type:"checkbox",checked:r.get(i)??!1,onChange:()=>{e.setFilter(i,!e.featureFilters.get(i))}})),ue.default.createElement("td",null,i),ue.default.createElement("td",null,s),ue.default.createElement("td",null,a),ue.default.createElement("td",null,ue.default.createElement("div",{style:{width:20,height:20,background:o[c]||"black"}})))))))}),XT=(0,Tc.observer)(function({onClose:e,model:t}){return ue.default.createElement(Px.Dialog,{onClose:()=>{e()},open:!0,title:"Feature filters",maxWidth:"xl"},ue.default.createElement(as.DialogContent,null,ue.default.createElement(KT,{model:t})))}),ZT=XT});async function Ux(e,t){let r=await fetch(e,t);if(!r.ok)throw new Error(`HTTP ${r.status} fetching ${e} ${await r.text()}`);return r}async function vf(e,t){return(await Ux(e,t)).text()}async function _c(e,t){return(await Ux(e,t)).json()}function Hx(e){return new Promise(t=>setTimeout(t,e))}var Tf=g(()=>{});var Jx={};We(Jx,{default:()=>t_});var he,jx,_f,Se,qx,e_,t_,Vx=g(()=>{he=f(b(),1),jx=f(ye(),1),_f=f(ge(),1),Se=f(D(),1),qx=f(O(),1);Tf();e_=(0,qx.observer)(function({handleClose:e,model:t}){let[r,n]=(0,he.useState)(),[o,i]=(0,he.useState)("file"),[s,a]=(0,he.useState)("");return he.default.createElement(jx.Dialog,{maxWidth:"xl",title:"Open protein domains from file",onClose:()=>{e()},open:!0},he.default.createElement(Se.DialogContent,null,he.default.createElement("div",null,he.default.createElement(Se.Typography,null,"Open a JSON file of InterProScan results that you run remotely on EBI servers or locally"),he.default.createElement("div",{style:{display:"flex",margin:30}},he.default.createElement(Se.FormControl,{component:"fieldset"},he.default.createElement(Se.RadioGroup,{value:o,onChange:c=>{i(c.target.value)}},he.default.createElement(Se.FormControlLabel,{value:"url",control:he.default.createElement(Se.Radio,null),label:"URL"}),he.default.createElement(Se.FormControlLabel,{value:"file",control:he.default.createElement(Se.Radio,null),label:"File"}))),o==="url"?he.default.createElement("div",null,he.default.createElement(Se.Typography,null,"Open a InterProScan JSON file remote URL"),he.default.createElement(Se.TextField,{label:"URL",value:s,onChange:c=>{a(c.target.value)}})):null,o==="file"?he.default.createElement("div",{style:{paddingTop:20}},he.default.createElement(Se.Typography,null,"Open a InterProScan JSON file file from your local drive"),he.default.createElement(Se.Button,{variant:"outlined",component:"label"},"Choose File",he.default.createElement("input",{type:"file",hidden:!0,onChange:({target:c})=>{let l=c.files?.[0];l&&n(l)}}))):null))),he.default.createElement(Se.DialogActions,null,he.default.createElement(Se.Button,{variant:"contained",color:"primary",onClick:()=>{(async()=>{try{let c=r?JSON.parse(await r.text()):await _c(s);t.setInterProAnnotations(Object.fromEntries(c.results.map(l=>[l.xref[0].id,l]))),t.setShowDomains(!0),(0,_f.getSession)(t).notify("Loaded interproscan results","success")}catch(c){console.error(c),(0,_f.getSession)(t).notifyError(`${c}`,c)}finally{t.setStatus()}})(),e()}},"Open results")))}),t_=e_});async function r_({seq:e,onProgress:t,onJobId:r,programs:n,model:o}){let i=await vf(`${Df}/iprscan5/run`,{method:"POST",body:new URLSearchParams({email:"colin.diesh@gmail.com",sequence:e,programs:n.join(",")})});r?.(i),await o_({jobId:i,onProgress:t}),await i_({jobId:i,model:o})}function n_(e){return _c(`${Df}/iprscan5/result/${e}/json`)}async function o_({onProgress:e,jobId:t}){let r=`${Df}/iprscan5/status/${t}`;try{for(;;){for(let o=0;o<10;o++)await Hx(1e3),e({msg:`Checking status ${10-o}`,url:r});let n=await vf(r);if(n.includes("FINISHED"))break;if(n.includes("FAILURE"))throw new Error(`Failed to run: jobId ${t}`)}}finally{e()}}async function Yx({algorithm:e,seq:t,programs:r,onJobId:n,onProgress:o,model:i}){try{if(o({msg:`Launching ${e} MSA`}),e==="interproscan")await r_({seq:t,onJobId:n,onProgress:o,programs:r,model:i});else throw new Error("unknown algorithm")}finally{o()}}async function i_({jobId:e,model:t}){try{t.setStatus({msg:`Downloading results of ${e} (for larger sequences this can be slow, click status to download and upload in the manual tab)`,url:`https://www.ebi.ac.uk/Tools/services/rest/iprscan5/result/${e}/json`});let r=await n_(e);t.setInterProAnnotations(Object.fromEntries(r.results.map(n=>[n.xref[0].id,n]))),t.setShowDomains(!0),(0,kf.getSession)(t).notify(`Loaded interproscan ${e} results`,"success")}catch(r){console.error(r),(0,kf.getSession)(t).notifyError(`${r}`,r)}finally{t.setStatus()}}var kf,Df,Wx=g(()=>{kf=f(ge(),1);Tf();Df="https://www.ebi.ac.uk/Tools/services/rest"});var Xx={};We(Xx,{default:()=>a_});var Qe,zx,$x,Ot,Kx,s_,a_,Zx=g(()=>{Qe=f(b(),1),zx=f(ye(),1),$x=f(ge(),1),Ot=f(D(),1),Kx=f(O(),1);Wx();s_=(0,Kx.observer)(function({handleClose:e,model:t}){let[r,n]=(0,Qe.useState)([{name:"NCBIfam",description:"NCBI RefSeq FAMs including TIGRFAMs",category:"Families, domains, sites & repeats",checked:!0},{name:"SFLD",description:"Structure function linkage database",category:"Families, domains, sites & repeats",checked:!0},{name:"Phobius",checked:!0,description:"A combined transmembrane topology and signal peptide predictor",category:"Other sequence features"},{name:"SignalP",checked:!0,category:"Other sequence features"},{name:"SignalP_EUK",category:"Other category",checked:!0},{name:"SignalP_GRAM_POSITIVE",category:"Other category",checked:!0},{name:"SignalP_GRAM_NEGATIVE",checked:!0,category:"Other category"},{name:"SuperFamily",category:"Structural domains",checked:!0},{name:"Panther",category:"Families, domains, sites & repeats",checked:!0},{name:"Gene3d",category:"Structural domains",checked:!0},{name:"HAMAP",category:"Families, domains, sites & repeats",checked:!0},{name:"PrositeProfiles",category:"Families, domains, sites & repeats",checked:!0},{name:"PrositePatterns",category:"Families, domains, sites & repeats",checked:!0},{name:"Coils",category:"Other sequence features",checked:!0},{name:"SMART",category:"Families, domains, sites & repeats",checked:!0},{name:"CDD",description:"Conserved Domains Database",category:"Families, domains, sites & repeats",checked:!0},{name:"PRINTS",category:"Families, domains, sites & repeats",checked:!0},{name:"PfamA",category:"Families, domains, sites & repeats",checked:!0},{name:"MobiDBLite",checked:!0,category:"Other sequence features"},{name:"PIRSF",checked:!0,category:"Other category"},{name:"TMHMM",checked:!0,category:"Other sequence features"},{name:"AntiFam",checked:!0,category:"Other category"},{name:"FunFam",checked:!0,category:"Other category"},{name:"PIRSR",checked:!0,category:"Families, domains, sites & repeats"}]),o=r.filter(a=>a.checked).map(a=>a.name),[i,s]=(0,Qe.useState)(!1);return Qe.default.createElement(zx.Dialog,{maxWidth:"xl",title:"Query InterProScan API for domains",onClose:()=>{e()},open:!0},Qe.default.createElement(Ot.DialogContent,null,Qe.default.createElement(Ot.Typography,null,"This will run InterProScan via the InterProScan API on all rows of the current MSA"),Qe.default.createElement(Ot.Button,{onClick:()=>{s(!i)}},i?"Hide":"Show"," advanced options"),i?Qe.default.createElement("div",null,Qe.default.createElement(Ot.Typography,null,"Select algorithms for InterProScan to run"),Qe.default.createElement("div",null,Qe.default.createElement(Ot.Button,{variant:"contained",color:"secondary",onClick:()=>{n(r.map(a=>({...a,checked:!1})))}},"Select none"),Qe.default.createElement(Ot.Button,{variant:"contained",color:"primary",onClick:()=>{n(r.map(a=>({...a,checked:!0})))}},"Select all")),Qe.default.createElement("table",null,Qe.default.createElement("tbody",null,r.toSorted((a,c)=>a.category.localeCompare(c.category)).map(({name:a,checked:c,category:l})=>Qe.default.createElement("tr",{key:a},Qe.default.createElement("td",null,Qe.default.createElement("input",{type:"checkbox",key:a,checked:c,onChange:()=>{n(r.map(A=>A.name===a?{...A,checked:!A.checked}:A))}})),Qe.default.createElement("td",null,a),Qe.default.createElement("td",null,l)))))):null),Qe.default.createElement(Ot.DialogActions,null,Qe.default.createElement(Ot.Button,{variant:"contained",color:"secondary",onClick:()=>{e()}},"Cancel"),Qe.default.createElement(Ot.Button,{variant:"contained",color:"primary",onClick:()=>{(async()=>{try{let{rows:a}=t;if(a.length>140)throw new Error("Too many sequences, please run InterProScan offline");await Yx({algorithm:"interproscan",programs:o,seq:a.map(c=>[c[0],c[1].replaceAll("-","")]).filter(c=>!!c[1]).map(c=>`>${c[0]}
29
- ${c[1]}`).join(`
30
- `),onProgress:c=>{t.setStatus(c)},model:t})}catch(a){console.error(a),(0,$x.getSession)(t).notifyError(`${a}`,a)}finally{t.setStatus()}})(),e()}},"Send sequences to InterProScan")))}),a_=s_});function ey({model:e}){let{showDomains:t,actuallyShowDomains:r,subFeatureRows:n,noDomains:o}=e;return[{label:"Open domains...",icon:ss,onClick:()=>{e.queueDialog(i=>[l_,{handleClose:i,model:e}])}},{label:"Query InterProScan for domains...",icon:vx,onClick:()=>{e.queueDialog(i=>[A_,{handleClose:i,model:e}])}},{label:`Show domains${o?" (no domains loaded)":""}`,disabled:o,icon:Lx,checked:r?t:!1,type:"checkbox",onClick:()=>{e.setShowDomains(!t)}},{label:`Use sub-row layout${o?" (no domains loaded)":""}`,disabled:o,checked:r?n:!1,icon:kx,type:"checkbox",onClick:()=>{e.setSubFeatureRows(!n)}},{label:`Filter domains${o?" (no domains loaded)":""}`,icon:Sx,disabled:o,onClick:()=>{e.queueDialog(i=>[c_,{onClose:i,model:e}])}}]}var kc,c_,l_,A_,ty=g(()=>{kc=f(b(),1);Qx();bf();Tx();Dx();Fx();c_=(0,kc.lazy)(()=>Promise.resolve().then(()=>(Gx(),Ox))),l_=(0,kc.lazy)(()=>Promise.resolve().then(()=>(Vx(),Jx))),A_=(0,kc.lazy)(()=>Promise.resolve().then(()=>(Zx(),Xx)))});var iy=G((zG,oy)=>{"use strict";var u_=function(t){return f_(t)&&!m_(t)};function f_(e){return!!e&&typeof e=="object"}function m_(e){var t=Object.prototype.toString.call(e);return t==="[object RegExp]"||t==="[object Date]"||p_(e)}var d_=typeof Symbol=="function"&&Symbol.for,g_=d_?Symbol.for("react.element"):60103;function p_(e){return e.$$typeof===g_}function h_(e){return Array.isArray(e)?[]:{}}function cs(e,t){return t.clone!==!1&&t.isMergeableObject(e)?ui(h_(e),e,t):e}function C_(e,t,r){return e.concat(t).map(function(n){return cs(n,r)})}function E_(e,t){if(!t.customMerge)return ui;var r=t.customMerge(e);return typeof r=="function"?r:ui}function I_(e){return Object.getOwnPropertySymbols?Object.getOwnPropertySymbols(e).filter(function(t){return Object.propertyIsEnumerable.call(e,t)}):[]}function ry(e){return Object.keys(e).concat(I_(e))}function ny(e,t){try{return t in e}catch{return!1}}function x_(e,t){return ny(e,t)&&!(Object.hasOwnProperty.call(e,t)&&Object.propertyIsEnumerable.call(e,t))}function y_(e,t,r){var n={};return r.isMergeableObject(e)&&ry(e).forEach(function(o){n[o]=cs(e[o],r)}),ry(t).forEach(function(o){x_(e,o)||(ny(e,o)&&r.isMergeableObject(t[o])?n[o]=E_(o,r)(e[o],t[o],r):n[o]=cs(t[o],r))}),n}function ui(e,t,r){r=r||{},r.arrayMerge=r.arrayMerge||C_,r.isMergeableObject=r.isMergeableObject||u_,r.cloneUnlessOtherwiseSpecified=cs;var n=Array.isArray(t),o=Array.isArray(e),i=n===o;return i?n?r.arrayMerge(e,t,r):y_(e,t,r):cs(t,r)}ui.all=function(t,r){if(!Array.isArray(t))throw new Error("first argument should be an array");return t.reduce(function(n,o){return ui(n,o,r)},{})};var w_=ui;oy.exports=w_});function cy(){return{palette:{...Dc,mode:void 0},components:{MuiLink:{styleOverrides:{root:({theme:e})=>({color:e.palette.tertiary.main})}}}}}function P_(){return{...cy(),name:"Default (from config)"}}function O_(){return{...cy(),name:"Light (stock)"}}function G_(){return{name:"Dark (stock)",palette:{...Dc,mode:"dark"},components:{MuiAppBar:{defaultProps:{enableColorOnDark:!0},styleOverrides:{root:({theme:e})=>e.palette.primary.main}}}}}function U_(){return{name:"Dark (minimal)",palette:{...Dc,mode:"dark",primary:{main:hn[700]},secondary:{main:hn[800]},tertiary:Me.palette.augmentColor({color:{main:hn[900]}})}}}function H_(){return{name:"Light (minimal)",palette:{...Dc,primary:{main:hn[900]},secondary:{main:hn[800]},tertiary:Me.palette.augmentColor({color:{main:hn[900]}})}}}var ay,b_,Me,B_,S_,Q_,sy,KG,M_,v_,T_,__,k_,D_,N_,L_,F_,R_,Dc,XG,ly=g(()=>{ay=f(D(),1);df();b_=f(iy(),1),Me=(0,ay.createTheme)(),B_=Me.palette.augmentColor({color:{main:"#0D233F"}}),S_=Me.palette.augmentColor({color:{main:"#721E63"}}),Q_=Me.palette.augmentColor({color:{main:"#135560"}}),sy=Me.palette.augmentColor({color:{main:"#FFB11D"}}),KG=Me.palette.augmentColor({color:{main:"#aaa"}}),M_={A:Me.palette.augmentColor({color:rs}),C:Me.palette.augmentColor({color:ts}),G:Me.palette.augmentColor({color:ns}),T:Me.palette.augmentColor({color:li})},v_=[null,Me.palette.augmentColor({color:{main:"#FF8080"}}),Me.palette.augmentColor({color:{main:"#80FF80"}}),Me.palette.augmentColor({color:{main:"#8080FF"}}),Me.palette.augmentColor({color:{main:"#8080FF"}}),Me.palette.augmentColor({color:{main:"#80FF80"}}),Me.palette.augmentColor({color:{main:"#FF8080"}})],T_=[null,Me.palette.augmentColor({color:{main:"#8f8f8f"}}),Me.palette.augmentColor({color:{main:"#adadad"}}),Me.palette.augmentColor({color:{main:"#d8d8d8"}}),Me.palette.augmentColor({color:{main:"#d8d8d8"}}),Me.palette.augmentColor({color:{main:"#adadad"}}),Me.palette.augmentColor({color:{main:"#8f8f8f"}})],__="#e22",k_="#3e3",D_="#800080",N_="#808080",L_="#f00",F_="#00f",R_="#97b8c9",Dc={primary:B_,secondary:S_,tertiary:Q_,quaternary:sy,highlight:sy,stopCodon:__,startCodon:k_,insertion:D_,deletion:N_,softclip:F_,hardclip:L_,bases:M_,frames:T_,framesCDS:v_,skip:R_};XG={default:P_(),lightStock:O_(),lightMinimal:H_(),darkMinimal:U_(),darkStock:G_()}});var Ay=g(()=>{});var uy=g(()=>{});var Nf=g(()=>{ly();lf();Ay();uy()});function En({value:e}){let{classes:t}=j_(),r=/^https?:\/\//.exec(`${e}`);return(0,Nc.jsx)("div",{className:t.fieldValue,children:(0,fy.isValidElement)(e)?e:r?(0,Nc.jsx)(my.Link,{href:`${e}`,children:`${e}`}):(0,Nc.jsx)(gn,{html:zt(e)?JSON.stringify(e):String(e)})})}var Nc,fy,my,j_,Lc=g(()=>{Nc=f(F(),1),fy=f(b(),1),my=f(D(),1);Nf();fn();Ct();j_=ee()(e=>({fieldValue:{wordBreak:"break-word",maxHeight:300,fontSize:12,padding:e.spacing(.5),overflow:"auto"}}))});function Tr({description:e,name:t,width:r,prefix:n=[]}){let{classes:o}=q_(),i=[...n,t].join(".");return e?(0,Fc.jsx)(dy.Tooltip,{title:e,placement:"left",children:(0,Fc.jsx)("div",{className:lc(o.fieldDescription,o.fieldName),children:i})}):(0,Fc.jsx)("div",{className:o.fieldName,style:{width:r},children:i})}var Fc,dy,q_,ls=g(()=>{Fc=f(F(),1),dy=f(D(),1);Ct();q_=ee()(e=>({fieldDescription:{"&:hover":{background:e.palette.mode==="dark"?"#e65100":"yellow"}},fieldName:{wordBreak:"break-all",minWidth:90,borderBottom:"1px solid #0003",fontSize:12,background:e.palette.action.disabledBackground,marginRight:e.spacing(1),padding:e.spacing(.5)}}))});function Ff({name:e,value:t,description:r,formatter:n,prefix:o=[]}){let{classes:i}=J_(),[s,a]=(0,gy.useState)(!1),c=t.length>Lf,l=c&&!s?t.slice(0,Lf):t;return t.length===1?zt(t[0])?(0,wt.jsx)(_r,{formatter:n,attributes:t[0],prefix:[...o,e]}):(0,wt.jsxs)("div",{className:i.field,children:[(0,wt.jsx)(Tr,{prefix:o,description:r,name:e}),(0,wt.jsx)(En,{value:n?n(t[0],e):t[0]})]}):t.every(A=>zt(A))?(0,wt.jsx)(wt.Fragment,{children:t.map((A,u)=>(0,wt.jsx)(_r,{formatter:n,attributes:A,prefix:[...o,`${e}-${u}`]},`${JSON.stringify(A)}-${u}`))}):(0,wt.jsxs)("div",{className:i.field,children:[(0,wt.jsx)(Tr,{prefix:o,description:r,name:e}),l.map((A,u)=>(0,wt.jsx)("div",{className:i.fieldSubvalue,children:(0,wt.jsx)(En,{value:n?n(A,e):A})},`${JSON.stringify(A)}-${u}`)),c?(0,wt.jsx)("button",{type:"button",onClick:()=>{a(A=>!A)},children:s?"Show less":`Showing ${Lf} of ${t.length}. Show all...`}):null]})}var wt,gy,Lf,J_,py=g(()=>{wt=f(F(),1),gy=f(b(),1);Rc();Lc();ls();fn();Ct();Lf=100,J_=ee()(e=>({field:{display:"flex",flexWrap:"wrap"},fieldSubvalue:{wordBreak:"break-word",maxHeight:300,padding:e.spacing(.5),border:`1px solid ${e.palette.action.selected}`,boxSizing:"border-box",overflow:"auto"}}))});var Cy=G((C6,hy)=>{hy.exports=JBrowseExports["@mui/x-data-grid"]});function Rf({children:e,style:t}){let{classes:r}=V_();return(0,Ey.jsx)("div",{className:r.flexContainer,style:t,children:e})}var Ey,V_,Iy=g(()=>{Ey=f(F(),1);Ct();V_=ee()({flexContainer:{display:"flex",flexDirection:"column"}})});function Pf({value:e,prefix:t,name:r}){let{classes:n}=Y_(),[o,i]=(0,xy.useState)(!1),s=Object.keys(e[0]).sort(),a=new Set(s),c=Object.entries(e).map(([u,m])=>{let{id:d,...p}=m;return{id:u,identifier:d,...p}});for(let u of e)for(let m of Object.keys(u))a.add(m);let l;a.has("id")?(a.delete("id"),l=["identifier",...a]):l=[...a];let A=l.map(u=>Ph(c.map(m=>m[u])));return a.size<s.length+5?(0,gr.jsxs)("div",{className:n.margin,children:[(0,gr.jsx)(Tr,{prefix:t,name:r}),(0,gr.jsx)(fi.FormControlLabel,{control:(0,gr.jsx)(fi.Checkbox,{checked:o,onChange:u=>{i(u.target.checked)}}),label:(0,gr.jsx)(fi.Typography,{variant:"body2",children:"Show options"})}),(0,gr.jsx)(Rf,{children:(0,gr.jsx)(yy.DataGrid,{disableRowSelectionOnClick:!0,rows:c,rowHeight:20,columnHeaderHeight:35,hideFooter:c.length<25,showToolbar:o,columns:l.map((u,m)=>({field:u,width:A[m],renderCell:({value:d})=>(0,gr.jsx)("div",{className:n.cell,children:(0,gr.jsx)(gn,{html:eu(d||"")})})}))})})]}):null}var gr,xy,fi,yy,Y_,wy=g(()=>{gr=f(F(),1),xy=f(b(),1),fi=f(D(),1),yy=f(Cy(),1);ls();Iy();Nf();fn();Ct();Y_=ee()(e=>({margin:{marginBottom:e.spacing(4)},cell:{whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"}}))});function Of({name:e,value:t,description:r,prefix:n,width:o,formatter:i}){let{classes:s}=W_();return t!=null?(0,As.jsxs)("div",{className:s.field,children:[(0,As.jsx)(Tr,{prefix:n,description:r,name:e,width:o}),(0,As.jsx)(En,{value:i?i(t,e):t})]}):null}var As,W_,by=g(()=>{As=f(F(),1);Lc();ls();Ct();W_=ee()({field:{display:"flex",flexWrap:"wrap"}})});function Gf({value:e,prefix:t,name:r}){let{classes:n}=z_(),{uri:o,baseUri:i=""}=e,s;try{s=new URL(o,i).href}catch{s=o}return(0,us.jsxs)("div",{className:n.field,children:[(0,us.jsx)(Tr,{prefix:t,name:r}),(0,us.jsx)(En,{value:s})]})}var us,z_,By=g(()=>{us=f(F(),1);Lc();ls();Ct();z_=ee()({field:{display:"flex",flexWrap:"wrap"}})});function Sy(e,t){return Math.ceil(tu(e.map(r=>XA([...t,r[0]].join("."),12))))+10}function Qy(e,t={}){let r=t;for(let n of e)zt(r)&&(r=r[n]);return typeof r=="string"?r:zt(r)&&typeof r.Description=="string"?r.Description:void 0}var My=g(()=>{fn()});function _r(e){let{attributes:t,omit:r=[],omitSingleLevel:n=[],descriptions:o,formatter:i,hideUris:s,prefix:a=[]}=e,c=new Set([...r,...K_,...n]),{__jbrowsefmt:l,...A}=t,u=Object.entries({...A,...l}).filter(([d,p])=>p!=null&&!c.has(d)),m=Sy(u,a);return(0,zr.jsx)(zr.Fragment,{children:u.map(([d,p])=>{let C=Qy([...a,d],o);if(Array.isArray(p))return p.length>1&&p.every(y=>zt(y))?(0,zr.jsx)(Pf,{name:d,prefix:a,value:p},d):(0,zr.jsx)(Ff,{name:d,value:p,formatter:i,description:C,prefix:a},d);if(zt(p)){let{omitSingleLevel:y,...I}=e;return va(p)?s?null:(0,zr.jsx)(Gf,{name:d,prefix:a,value:p},d):(0,zr.jsx)(_r,{...I,formatter:i,attributes:p,descriptions:o,prefix:[...a,d]},d)}else return(0,zr.jsx)(Of,{name:d,formatter:i,value:p,description:C,prefix:a,width:Math.min(m,$_)},d)})})}var zr,$_,K_,Rc=g(()=>{zr=f(F(),1);py();wy();by();By();My();fn();$_=170,K_=["__jbrowsefmt","length","position","subfeatures","uniqueId","exonFrames","parentId","thickStart","thickEnd","_lineHash"]});function Kn({children:e,title:t,defaultExpanded:r=!0}){let{classes:n}=X_();return(0,$n.jsxs)(In.Accordion,{defaultExpanded:r,children:[(0,$n.jsx)(In.AccordionSummary,{expandIcon:(0,$n.jsx)(pa,{className:n.icon}),children:(0,$n.jsx)(In.Typography,{variant:"button",children:t})}),(0,$n.jsx)(In.AccordionDetails,{className:n.expansionPanelDetails,children:e})]})}var $n,In,X_,Uf=g(()=>{$n=f(F(),1);bA();In=f(D(),1);Ct();X_=ee()(e=>({expansionPanelDetails:{display:"block",padding:e.spacing(1)},icon:{color:e.palette.tertiary.contrastText||"#fff"}}))});function dt({checked:e,label:t,disabled:r,onChange:n}){return Pc.default.createElement("div",null,Pc.default.createElement(Oc.FormControlLabel,{control:Pc.default.createElement(Oc.Checkbox,{disabled:r,checked:e,onChange:n}),label:t}))}var Pc,Oc,Gc=g(()=>{Pc=f(b(),1),Oc=f(D(),1)});function fs({str:e}){let{classes:t}=Z_(),[r,n]=(0,pr.useState)(!1),[o,i]=(0,pr.useState)(!1),[s,a]=(0,pr.useState)(!1),c=A=>A.replaceAll("-","").replaceAll(".",""),l=e.map(([A,u])=>[A,o?u:c(u)]).filter(A=>s?!0:!!A[1]).map(([A,u])=>`>${A}
31
- ${o?u:c(u)}`).join(`
32
- `);return pr.default.createElement(pr.default.Fragment,null,pr.default.createElement(Uc.Button,{color:"primary",variant:"contained",onClick:()=>{Ui(l),n(!0),setTimeout(()=>{n(!1)},500)}},r?"Copied!":"Copy to clipboard"),pr.default.createElement(dt,{label:"Show gaps",checked:o,onChange:()=>{i(!o)}}),pr.default.createElement(dt,{label:"Show empty",checked:s,onChange:()=>{a(!s)}}),pr.default.createElement(Uc.TextField,{variant:"outlined",multiline:!0,className:t.dialogContent,minRows:5,maxRows:10,fullWidth:!0,value:l,slotProps:{input:{readOnly:!0,className:t.textAreaFont}}}))}var pr,Uc,vy,Z_,Hf=g(()=>{pr=f(b(),1),Uc=f(D(),1),vy=f(Be(),1);Gc();Au();Z_=(0,vy.makeStyles)()({textAreaFont:{fontFamily:"Courier New",wordWrap:"break-word"},dialogContent:{background:"lightgrey",margin:4,minWidth:"80em"}})});var Dy={};We(Dy,{default:()=>tk});var mi,Ty,_y,ky,ek,tk,Ny=g(()=>{mi=f(b(),1);Rc();Uf();Ty=f(ye(),1),_y=f(D(),1),ky=f(O(),1);Hf();ek=(0,ky.observer)(function({model:e,onClose:t}){let{header:r}=e;return mi.default.createElement(Ty.Dialog,{onClose:()=>{t()},open:!0,title:"Metadata",maxWidth:"xl"},mi.default.createElement(_y.DialogContent,null,mi.default.createElement(_r,{attributes:r}),mi.default.createElement(Kn,{title:"sequence"},mi.default.createElement(fs,{str:e.rows}))))}),tk=ek});var Fy={};We(Fy,{default:()=>Ly});function Ly({model:e,onClose:t}){let[r,n]=(0,we.useState)(!0),[o,i]=(0,we.useState)(!0),[s,a]=(0,we.useState)("viewport"),[c,l]=(0,we.useState)(),A=(0,Ce.useTheme)(),{totalWidth:u,totalHeight:m,treeAreaWidth:d,turnedOnTracks:p}=e,C=p.length>0,y=u+d,I=m,h=s==="entire"&&(y>1e4||I>1e4);return we.default.createElement(Hc.Dialog,{onClose:()=>{t()},open:!0,title:"Export SVG"},we.default.createElement(Ce.DialogContent,null,c?we.default.createElement(Hc.ErrorMessage,{error:c}):null,we.default.createElement(Ce.Typography,null,"Settings:"),we.default.createElement(dt,{label:"Include minimap?",disabled:s==="entire",checked:r,onChange:()=>{n(!r)}}),C?we.default.createElement(dt,{label:"Include tracks?",checked:o,onChange:()=>{i(!o)}}):null,we.default.createElement("div",null,we.default.createElement(Ce.FormControl,null,we.default.createElement(Ce.FormLabel,null,"Export type"),we.default.createElement(Ce.RadioGroup,{value:s,onChange:x=>{a(x.target.value)}},we.default.createElement(Ce.FormControlLabel,{value:"entire",control:we.default.createElement(Ce.Radio,null),label:"Entire MSA"}),we.default.createElement(Ce.FormControlLabel,{value:"viewport",control:we.default.createElement(Ce.Radio,null),label:"Current viewport only"})))),h?we.default.createElement(Ce.Alert,{severity:"warning",style:{marginTop:8}},"The entire MSA is very large (",Math.round(y),"x",Math.round(I)," pixels). Export may be slow or fail."):null),we.default.createElement(Ce.DialogActions,null,we.default.createElement(Ce.Button,{variant:"contained",color:"primary",onClick:()=>{(async()=>{try{await e.exportSVG({theme:A,includeMinimap:s==="entire"?!1:r,includeTracks:C&&o,exportType:s}),t()}catch(x){console.error(x),l(x)}})()}},"Submit"),we.default.createElement(Ce.Button,{variant:"contained",color:"secondary",onClick:()=>{t()}},"Cancel")))}var we,Hc,Ce,Ry=g(()=>{we=f(b(),1),Hc=f(ye(),1),Ce=f(D(),1);Gc()});var Hy={};We(Hy,{default:()=>sk});var z,Oy,et,ms,Gy,Uy,Py,rk,nk,ok,ik,sk,jy=g(()=>{z=f(b(),1),Oy=f(ye(),1),et=f(D(),1),ms=f(O(),1),Gy=f(Be(),1);vc();Gc();Uy=(0,Gy.makeStyles)()(e=>({field:{margin:e.spacing(4)},flex:{display:"flex"},minw:{width:"80em"}})),Py=(e=0)=>+e.toFixed(1),rk=(0,ms.observer)(function({model:e}){return z.default.createElement(z.default.Fragment,null,z.default.createElement(nk,{model:e}),z.default.createElement(ok,{model:e}))}),nk=(0,ms.observer)(function({model:t}){let{drawTree:r,drawLabels:n,drawNodeBubbles:o,labelsAlignRight:i,showBranchLen:s}=t;return z.default.createElement("div",null,z.default.createElement("h1",null,"Tree options"),z.default.createElement(dt,{checked:s,label:"Show branch length?",onChange:()=>{t.setShowBranchLen(!s)}}),z.default.createElement(dt,{checked:o,label:"Draw clickable bubbles on tree branches?",onChange:()=>{t.setDrawNodeBubbles(!o)}}),z.default.createElement(dt,{checked:r,label:"Show tree?",onChange:()=>{t.setDrawTree(!r)}}),z.default.createElement(dt,{checked:i,label:"Tree labels align right?",onChange:()=>{t.setLabelsAlignRight(!i)}}),z.default.createElement(dt,{checked:n,label:"Draw labels",onChange:()=>{t.setDrawLabels(!n)}}))}),ok=(0,ms.observer)(function({model:t}){let{classes:r}=Uy(),{bgColor:n,colWidth:o,allowedGappyness:i,drawMsaLetters:s,colorSchemeName:a,hideGaps:c,rowHeight:l}=t;return z.default.createElement("div",null,z.default.createElement("h1",null,"MSA options"),z.default.createElement(dt,{checked:s,label:"Draw letters",onChange:()=>{t.setDrawMsaLetters(!s)}}),z.default.createElement(dt,{checked:n,label:"Color letters instead of background of tiles",onChange:()=>{t.setBgColor(!n)}}),z.default.createElement(dt,{checked:c,label:"Enable hiding gappy columns?",onChange:()=>{t.setHideGaps(!c)}}),c?z.default.createElement("div",{className:r.flex},z.default.createElement(et.Typography,null,"Hide columns w/ >",i,"% gaps"),z.default.createElement(et.Slider,{className:r.field,min:1,max:100,value:i,onChange:(A,u)=>{t.setAllowedGappyness(u)}})):null,z.default.createElement("div",{className:r.flex},z.default.createElement(et.Typography,null,"Column width (",Py(o),"px)"),z.default.createElement(et.Slider,{className:r.field,min:1,max:50,value:o,onChange:(A,u)=>{t.setColWidth(u)}})),z.default.createElement("div",{className:r.flex},z.default.createElement(et.Typography,null,"Row height (",Py(l),"px)"),z.default.createElement(et.Slider,{className:r.field,min:1,max:50,value:l,onChange:(A,u)=>{t.setRowHeight(u)}})),z.default.createElement(et.TextField,{select:!0,label:"Color scheme",value:a,onChange:A=>{t.setColorSchemeName(A.target.value)}},Object.keys(Ai).map(A=>z.default.createElement(et.MenuItem,{key:A,value:A},A))))}),ik=(0,ms.observer)(function({model:e,onClose:t}){let{classes:r}=Uy();return z.default.createElement(Oy.Dialog,{open:!0,title:"Settings",maxWidth:"xl",onClose:()=>{t()}},z.default.createElement(et.DialogContent,{className:r.minw},z.default.createElement(rk,{model:e}),z.default.createElement(et.DialogActions,null,z.default.createElement(et.Button,{variant:"contained",color:"primary",onClick:()=>{t()}},"Submit"))))}),sk=ik});var Xn,qy,ak,ck,lk,Ak,Jy,Vy=g(()=>{Xn=f(b(),1);ci();xx();bf();bx();wA();qy=f(O(),1);ty();ak=(0,Xn.lazy)(()=>Promise.resolve().then(()=>(Ny(),Dy))),ck=(0,Xn.lazy)(()=>Promise.resolve().then(()=>(Ry(),Fy))),lk=(0,Xn.lazy)(()=>Promise.resolve().then(()=>(jy(),Hy))),Ak=(0,qy.observer)(({model:e})=>Xn.default.createElement(vr,{menuItems:[{label:"Return to import form",icon:ss,onClick:()=>{e.reset()}},{label:"Metadata",icon:Ix,onClick:()=>{e.queueDialog(t=>[ak,{model:e,onClose:t}])}},{label:"More settings",icon:ga,onClick:()=>{e.queueDialog(t=>[lk,{model:e,onClose:t}])}},{label:"Domain settings",type:"subMenu",subMenu:ey({model:e})},{label:"Export SVG",icon:wx,onClick:()=>{e.queueDialog(t=>[ck,{onClose:t,model:e}])}}],anchorOrigin:{vertical:"bottom",horizontal:"left"},transformOrigin:{vertical:"top",horizontal:"left"}},Xn.default.createElement(ss,null))),Jy=Ak});var jc,qc,Yy,uk,Wy,zy=g(()=>{jc=f(b(),1),qc=f(D(),1),Yy=f(O(),1),uk=(0,Yy.observer)(function({model:t}){let{hideGaps:r,allowedGappyness:n}=t;return r?jc.default.createElement("div",{style:{display:"flex",alignItems:"center",gap:8}},jc.default.createElement(qc.Typography,{style:{whiteSpace:"nowrap"}},"Hide columns w/ >",n,"% gaps"),jc.default.createElement(qc.Slider,{style:{width:100},min:1,max:100,value:n,onChange:(o,i)=>{t.setAllowedGappyness(i)}})):null}),Wy=uk});var $y,Ky,Xy,Zy,fk,mk,ew,tw=g(()=>{$y=f(b(),1),Ky=f(D(),1),Xy=f(O(),1),Zy=f(Be(),1),fk=(0,Zy.makeStyles)()({margin:{margin:"auto",marginLeft:10}}),mk=(0,Xy.observer)(function({model:e}){let{mouseOverRowName:t,mouseCol:r}=e,{classes:n}=fk();return t&&r!==void 0?$y.default.createElement(Ky.Typography,{className:n.margin},t,":",e.visibleColToSeqPosOneBased(t,r)," (",e.visibleColToRowLetter(t,r),")"):null}),ew=mk});var Jc,rw,nw,ow,iw,dk,gk,sw,aw=g(()=>{Jc=f(b(),1),rw=f(ye(),1),nw=f(D(),1),ow=f(O(),1),iw=f(Be(),1),dk=(0,iw.makeStyles)()({margin:{margin:"auto",marginLeft:10}}),gk=(0,ow.observer)(({model:e})=>{let{status:t}=e,{classes:r}=dk();return t?Jc.default.createElement(nw.Typography,{className:r.margin},Jc.default.createElement(rw.LoadingEllipses,{message:t.msg,component:"span"})," ",t.url?Jc.default.createElement("a",{href:t.url,target:"_blank",rel:"noreferrer"},"(status)"):null):null}),sw=gk});var cw,lw,Aw=g(()=>{"use client";W();cw=f(F(),1),lw=(0,_.createSvgIcon)((0,cw.jsx)("path",{d:"M3 17v2h6v-2zM3 5v2h10V5zm10 16v-2h8v-2h-8v-2h-2v6zM7 9v2H3v2h4v2h2V9zm14 4v-2H11v2zm-6-4h2V7h4V5h-4V3h-2z"}),"Tune")});var jf,uw,pk,fw,mw=g(()=>{jf=f(b(),1);ci();Aw();uw=f(O(),1),pk=(0,uw.observer)(function({model:e}){let{drawMsaLetters:t,hideGaps:r,bgColor:n}=e;return jf.default.createElement(vr,{closeAfterItemClick:!1,anchorOrigin:{vertical:"bottom",horizontal:"left"},transformOrigin:{vertical:"top",horizontal:"left"},menuItems:[{label:"Draw letters",type:"checkbox",checked:t,onClick:()=>{e.setDrawMsaLetters(!t)}},{label:"Color letters instead of background of tiles",type:"checkbox",checked:!n,onClick:()=>{e.setBgColor(!n)}},{label:"Enable hiding gappy columns?",type:"checkbox",checked:r,onClick:()=>{e.setHideGaps(!r)}}]},jf.default.createElement(lw,null))}),fw=pk});var qf,Vc,dw,hk,gw,pw=g(()=>{qf=f(b(),1),Vc=f(D(),1),dw=f(O(),1),hk=(0,dw.observer)(function({model:e}){let{currentAlignment:t,alignmentNames:r}=e;return r.length>0?qf.default.createElement(Vc.TextField,{select:!0,variant:"outlined",value:t,size:"small",onChange:n=>{e.setCurrentAlignment(+n.target.value),e.setScrollX(0),e.setScrollY(0)}},r.map((n,o)=>qf.default.createElement(Vc.MenuItem,{key:`${n}-${o}`,value:o},n))):null}),gw=hk});var hw,Cw,Ew=g(()=>{"use client";W();hw=f(F(),1),Cw=(0,_.createSvgIcon)((0,hw.jsx)("path",{d:"M22 11V3h-7v3H9V3H2v8h7V8h2v10h4v3h7v-8h-7v3h-2V8h2v3z"}),"AccountTree")});var Jf,Iw,Ck,xw,yw=g(()=>{Jf=f(b(),1);ci();Ew();Iw=f(O(),1),Ck=(0,Iw.observer)(function({model:e}){let{drawTree:t,showBranchLen:r,labelsAlignRight:n,drawNodeBubbles:o,drawLabels:i,rows:s}=e;return Jf.default.createElement(vr,{closeAfterItemClick:!1,anchorOrigin:{vertical:"bottom",horizontal:"left"},transformOrigin:{vertical:"top",horizontal:"left"},menuItems:[{label:"Show branch length",type:"checkbox",checked:r,onClick:()=>{e.setShowBranchLen(!r)}},{label:"Show tree",type:"checkbox",checked:t,onClick:()=>{e.setDrawTree(!t)}},{label:"Draw clickable bubbles on tree branches",type:"checkbox",checked:o,onClick:()=>{e.setDrawNodeBubbles(!o)}},{label:"Tree labels align right",type:"checkbox",checked:n,onClick:()=>{e.setLabelsAlignRight(!n)}},{label:"Draw labels",type:"checkbox",checked:i,onClick:()=>{e.setDrawLabels(!i)}},...s.length>=2?[{label:"Advanced",type:"subMenu",subMenu:[{label:"Calculate neighbor joining tree (BLOSUM62)",onClick:()=>{try{e.calculateNeighborJoiningTreeFromMSA()}catch(a){console.error("Failed to calculate NJ tree:",a),e.setError(a)}}}]}]:[]]},Jf.default.createElement(Cw,null))}),xw=Ck});var Vf,ww,bw=g(()=>{"use client";W();Vf=f(F(),1),ww=(0,_.createSvgIcon)([(0,Vf.jsx)("path",{d:"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14"},"0"),(0,Vf.jsx)("path",{d:"M12 10h-2v2H9v-2H7V9h2V7h1v2h2z"},"1")],"ZoomIn")});var Bw,Sw,Qw=g(()=>{"use client";W();Bw=f(F(),1),Sw=(0,_.createSvgIcon)((0,Bw.jsx)("path",{d:"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14M7 9h5v1H7z"}),"ZoomOut")});var Zn,Yf,Mw,Ek,vw,Tw=g(()=>{Zn=f(b(),1);bw();Qw();Yf=f(D(),1),Mw=f(O(),1),Ek=(0,Mw.observer)(function({model:t}){return Zn.default.createElement(Zn.default.Fragment,null,Zn.default.createElement(Yf.IconButton,{onClick:()=>{t.zoomIn()}},Zn.default.createElement(ww,null)),Zn.default.createElement(Yf.IconButton,{onClick:()=>{t.zoomOut()}},Zn.default.createElement(Sw,null)))}),vw=Ek});var _w,kw,Dw=g(()=>{"use client";W();_w=f(F(),1),kw=(0,_.createSvgIcon)((0,_w.jsx)("path",{d:"M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2m0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2m0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2"}),"MoreVert")});var Nw,Lw,Fw=g(()=>{"use client";W();Nw=f(F(),1),Lw=(0,_.createSvgIcon)((0,Nw.jsx)("path",{d:"M12 5V2L8 6l4 4V7c3.31 0 6 2.69 6 6 0 2.97-2.17 5.43-5 5.91v2.02c3.95-.49 7-3.85 7-7.93 0-4.42-3.58-8-8-8m-6 8c0-1.65.67-3.15 1.76-4.24L6.34 7.34C4.9 8.79 4 10.79 4 13c0 4.08 3.05 7.44 7 7.93v-2.02c-2.83-.48-5-2.94-5-5.91"}),"RestartAlt")});var Wf,Rw,Ik,Pw,Ow=g(()=>{Wf=f(b(),1);ci();Dw();Fw();Rw=f(O(),1),Ik=(0,Rw.observer)(function({model:e}){return Wf.default.createElement(vr,{menuItems:[{label:"Fit both vertically/horizontally",onClick:()=>{e.fit()}},{label:"Fit vertically",onClick:()=>{e.fitVertically()}},{label:"Fit horizontally",onClick:()=>{e.fitHorizontally()}},{label:"Reset zoom to default",icon:Lw,onClick:()=>{e.resetZoom()}}]},Wf.default.createElement(kw,null))}),Pw=Ik});var Gw,Uw=g(()=>{Gw="5.0.16"});var qw={};We(qw,{default:()=>jw});function jw({onClose:e}){return Je.default.createElement(Hw.Dialog,{open:!0,title:"About",onClose:()=>{e()}},Je.default.createElement(bt.DialogContent,null,Je.default.createElement(bt.Typography,null,"MSAView ",Gw," (",Je.default.createElement(bt.Link,{href:"https://github.com/gmod/react-msaview"},"Github"),")"),Je.default.createElement("ul",null,Je.default.createElement("li",null,Je.default.createElement(bt.Typography,null,"We use some color schemes from the"," ",Je.default.createElement(bt.Link,{href:"https://github.com/biotite-dev/biotite"},"biotite")," ","project, and their license is reproduced"," ",Je.default.createElement(bt.Link,{href:"https://github.com/biotite-dev/biotite/blob/master/LICENSE.rst"},"here"))),Je.default.createElement("li",null,Je.default.createElement(bt.Typography,null,"See this page for some information on jalview colorings"," ",Je.default.createElement(bt.Link,{href:"https://www.jalview.org/help/html/colourSchemes/"},"here"))),Je.default.createElement("li",null,Je.default.createElement(bt.Typography,null,"See this page for some info on the clustal, cinema, maeditor, and lesk color schemes"," ",Je.default.createElement(bt.Link,{href:"http://www.bioinformatics.nl/~berndb/aacolour.html"},"here"))),Je.default.createElement("li",null,Je.default.createElement(bt.Typography,null,"See this paper about the flower color scheme"," ",Je.default.createElement(bt.Link,{href:"https://www.ncbi.nlm.nih.gov/pmc/articles/PMC7245768/"},"here"))))))}var Je,Hw,bt,Jw=g(()=>{Je=f(b(),1),Hw=f(ye(),1),bt=f(D(),1);Uw()});function wk(){return Le.default.createElement("div",{style:{flex:1}})}var Le,Vw,Yw,xk,yk,Ww,zw=g(()=>{Le=f(b(),1);lh();w0();Vw=f(D(),1),Yw=f(O(),1);Cx();Vy();zy();tw();aw();mw();pw();yw();Tw();Ow();xk=(0,Le.lazy)(()=>Promise.resolve().then(()=>(Jw(),qw))),yk=(0,Yw.observer)(function({model:e}){let[t,{height:r}]=JA();return(0,Le.useEffect)(()=>{e.setHeaderHeight(r||0)},[e,r]),Le.default.createElement("div",{ref:t,style:{display:"flex"}},Le.default.createElement(Jy,{model:e}),Le.default.createElement(hx,{model:e}),Le.default.createElement(xw,{model:e}),Le.default.createElement(fw,{model:e}),Le.default.createElement(vw,{model:e}),Le.default.createElement(Pw,{model:e}),Le.default.createElement(Wy,{model:e}),Le.default.createElement("div",{style:{paddingLeft:20,margin:"auto"}},Le.default.createElement(gw,{model:e})),Le.default.createElement(ew,{model:e}),Le.default.createElement(wk,null),Le.default.createElement(sw,{model:e}),Le.default.createElement(Vw.IconButton,{onClick:()=>{e.queueDialog(n=>[xk,{onClose:n}])}},Le.default.createElement(y0,null)))});Ww=yk});var Gt,$w,bk,Kw,Xw=g(()=>{Gt=f(b(),1),$w=f(O(),1),bk=(0,$w.observer)(function({model:e}){let[t,r]=(0,Gt.useState)(),[n,o]=(0,Gt.useState)(!1),i=(0,Gt.useRef)(!1),{scrollX:s,msaAreaWidth:a,minimapHeight:c,colWidth:l,numColumns:A}=e,u=a/A/l,m=-s,d=m+a,p=m*u,C=d*u,y="rgba(66, 119, 127, 0.3)",I=Math.max(C-p,20);(0,Gt.useEffect)(()=>{function S(B){t!==void 0&&(i.current||(i.current=!0,window.requestAnimationFrame(()=>{e.setScrollX(t.scrollX-(B.clientX-t.clientX)/u),i.current=!1})))}function M(){r(void 0)}if(t!==void 0)return document.addEventListener("mousemove",S),document.addEventListener("mouseup",M),()=>{document.removeEventListener("mousemove",S),document.removeEventListener("mousemove",M)}},[e,u,t]);let h=12,x=c-h;return Gt.default.createElement("div",{style:{position:"relative",height:c,width:"100%"}},Gt.default.createElement("div",{style:{height:h,boxSizing:"border-box",border:"1px solid #555"}}),Gt.default.createElement("div",{style:{position:"absolute",top:0,left:Math.max(0,p),background:n?"rgba(66,119,127,0.6)":y,cursor:"pointer",height:h,width:I,zIndex:100},onMouseOver:()=>{o(!0)},onMouseOut:()=>{o(!1)},onMouseDown:S=>{r({clientX:S.clientX,scrollX:e.scrollX})}}),Gt.default.createElement("svg",{height:x,style:{width:"100%"}},Gt.default.createElement("polygon",{fill:y,points:[[p+I,0],[p,0],[0,x],[a,x]].toString()})))}),Kw=bk});function zf(){return Yc.default.createElement("div",{style:{position:"absolute",left:"50%",top:"50%"}},Yc.default.createElement(Wc.CircularProgress,null),Yc.default.createElement(Wc.Typography,null,"Loading..."))}var Yc,Wc,Zw=g(()=>{Yc=f(b(),1),Wc=f(D(),1)});function zc({model:e,offsetX:t,offsetY:r,ctx:n,highResScaleFactorOverride:o,blockSizeYOverride:i}){let{leaves:s,blockSize:a,rowHeight:c,highResScaleFactor:l,showDomains:A}=e;if(A){let u=o||l,m=i||a;n.resetTransform(),n.scale(u,u),n.translate(-t,c/2-r);let d=Math.max(0,Math.floor((r-c)/c)),p=Math.max(0,Math.ceil((r+m+c)/c)),C=s.slice(d,p);Bk({model:e,ctx:n,visibleLeaves:C})}}function Bk({model:e,ctx:t,visibleLeaves:r}){let{subFeatureRows:n,colWidth:o,rowHeight:i,fillPalette:s,strokePalette:a,tidyFilteredGatheredInterProAnnotations:c}=e;for(let l=0,A=r.length;l<A;l++){let u=r[l],{x:m,data:{name:d}}=u,p=m,C=c[d];if(C)for(let y=0,I=C.length;y<I;y++){let{start:h,end:x,accession:S}=C[y],M=e.seqPosToVisibleCol(d,h-1),B=e.seqPosToVisibleCol(d,x);if(M===void 0||B===void 0)continue;let Q=M*o;t.fillStyle=s[S],t.strokeStyle=a[S];let L=n?4:i,T=p-i+(n?y*L:0),re=o*(B-M);t.fillRect(Q,T,re,L),t.strokeRect(Q,T,re,L)}}}var $f=g(()=>{});function $c({model:e,offsetX:t,offsetY:r,contrastScheme:n,ctx:o,theme:i,highResScaleFactorOverride:s,blockSizeXOverride:a,blockSizeYOverride:c}){let{colWidth:l,blockSize:A,rowHeight:u,fontSize:m,highResScaleFactor:d,actuallyShowDomains:p,leaves:C,bgColor:y}=e,I=s||d,h=a||A,x=c||A;o.resetTransform(),o.scale(I,I),o.translate(-t,u/2-r),o.textAlign="center",o.font=o.font.replace(/\d+px/,`${y?"":"bold "}${m}px`);let S=Math.max(0,Math.floor((r-u)/u)),M=Math.max(0,Math.ceil((r+x+u)/u)),B=Math.max(0,Math.floor(t/l)),Q=Math.max(0,Math.ceil((t+h)/l)),L=C.slice(S,M);p||Sk({model:e,ctx:o,theme:i,offsetX:t,xStart:B,xEnd:Q,visibleLeaves:L}),Qk({model:e,ctx:o,offsetX:t,contrastScheme:n,xStart:B,xEnd:Q,visibleLeaves:L}),Mk({model:e,ctx:o,xStart:B,xEnd:Q,visibleLeaves:L}),o.resetTransform()}function Sk({model:e,offsetX:t,ctx:r,visibleLeaves:n,theme:o,xStart:i,xEnd:s}){let{bgColor:a,colorSchemeName:c,colorScheme:l,columns:A,colWidth:u,rowHeight:m,relativeTo:d}=e,p=d?A[d]?.slice(i,s):null,C=c==="clustalx_protein_dynamic",y=c==="percent_identity_dynamic",I=t-t%u;for(let h=0,x=n.length;h<x;h++){let S=n[h],{data:{name:M}}=S,B=S.x,Q=A[M]?.slice(i,s);if(Q)for(let L=0,T=Q.length;L<T;L++){let re=Q[L],k=p&&M!==d&&re===p[L],j=C?e.colClustalX[i+L][re]:y?(()=>{let J=e.colConsensus[i+L];return re===J.letter?J.color:void 0})():l[re.toUpperCase()];if(a||C||y){let J=k?o.palette.action.hover:j||o.palette.background.default;r.fillStyle=J,r.fillRect(L*u+I,B-m,u,m)}}}}function Qk({model:e,offsetX:t,contrastScheme:r,ctx:n,visibleLeaves:o,xStart:i,xEnd:s}){let{bgColor:a,actuallyShowDomains:c,showMsaLetters:l,colorScheme:A,columns:u,colWidth:m,rowHeight:d,relativeTo:p}=e,C=p?u[p]?.slice(i,s):null;if(l){let y=t-t%m,I=m/2,h=d/4;for(let x=0,S=o.length;x<S;x++){let M=o[x],{data:{name:B}}=M,Q=M.x-h,L=u[B]?.slice(i,s);if(L)for(let T=0,re=L.length;T<re;T++){let k=L[T],J=C&&B!==p&&k===C[T]?".":k,R=A[k.toUpperCase()],ie=r[k.toUpperCase()]||"black";n.fillStyle=c?"black":a?ie:R||"black",n.fillText(J,T*m+y+I,Q)}}}}function Mk({model:e,ctx:t,visibleLeaves:r,xStart:n,xEnd:o}){let{bgColor:i,hideGapsEffective:s}=e;s&&(t.lineWidth=1,t.strokeStyle="#f0f",eb({visibleLeaves:r,xStart:n,ctx:t,model:e,xEnd:o,offset:0}),t.strokeStyle=i?"#fff":"#000",eb({visibleLeaves:r,xStart:n,ctx:t,model:e,xEnd:o,offset:-1}))}function eb({model:e,ctx:t,visibleLeaves:r,xStart:n,xEnd:o,offset:i}){let{colWidth:a,rowHeight:c,insertionPositions:l}=e;for(let A of r){let{name:u}=A.data,m=l.get(u);if(m){let d=A.x;for(let{pos:p}of m)if(p>=n&&p<o){let C=p*a,y=d-c,I=d;t.beginPath(),t.moveTo(C+i,y+i);let h=y,x=!0;for(;h<I;){let S=Math.min(h+2,I),M=x?C+1:C-1;t.lineTo(M+i,S+i),h=S,x=!x}t.stroke()}}}}var Kf=g(()=>{});var Ut,tb,rb,nb,ob,vk,ib,sb=g(()=>{Ut=f(b(),1),tb=f(ye(),1),rb=f(D(),1),nb=f(Hr(),1),ob=f(O(),1);$f();Kf();Cn();vk=(0,ob.observer)(function({model:e,offsetX:t,offsetY:r}){let{colWidth:n,rowHeight:o,scrollY:i,scrollX:s,colorScheme:a,blockSize:c,mouseClickCol:l,mouseClickRow:A,highResScaleFactor:u}=e,m=(0,rb.useTheme)(),d=(0,Ut.useMemo)(()=>zn(a,m),[a,m]),p=(0,Ut.useRef)(null);(0,Ut.useEffect)(()=>{let h=p.current?.getContext("2d");if(h)return(0,nb.autorun)(()=>{h.resetTransform(),h.clearRect(0,0,c*u,c*u),e.actuallyShowDomains&&zc({ctx:h,offsetX:t,offsetY:r,model:e}),$c({ctx:h,theme:m,offsetX:t,offsetY:r,contrastScheme:d,model:e})})},[e,t,r,m,c,u,d]);let[C,y]=(0,Ut.useState)(),{hoveredInsertion:I}=e;return Ut.default.createElement(Ut.default.Fragment,null,Ut.default.createElement("canvas",{ref:p,onMouseMove:h=>{if(!p.current)return;y({x:h.clientX,y:h.clientY});let{left:x,top:S}=p.current.getBoundingClientRect(),M=h.clientX-x+t,B=h.clientY-S+r,Q=Math.floor(M/n),L=Math.floor(B/o);Q>=0&&Q<e.numColumns&&L>=0&&L<e.numRows?e.setMousePos(Q,L):e.setMousePos(void 0,void 0)},onClick:h=>{if(!p.current)return;let{left:x,top:S}=p.current.getBoundingClientRect(),M=h.clientX-x+t,B=h.clientY-S+r,Q=Math.floor(M/n),L=Math.floor(B/o);Q===l&&L===A?e.setMouseClickPos(void 0,void 0):e.setMouseClickPos(Q,L)},onMouseLeave:()=>{e.setMousePos(),y(void 0)},width:c*u,height:c*u,style:{position:"absolute",top:i+r,left:s+t,width:c,height:c}}),I&&C?Ut.default.createElement(tb.BaseTooltip,{clientPoint:{x:C.x,y:C.y+15}},"Insertion (",I.letters.length,e.sequenceType==="amino"?"aa":"bp","):"," ",I.letters.length>20?`${I.letters.slice(0,20)}...`:I.letters):null)}),ib=vk});var $r,ab,Tk,cb,lb=g(()=>{$r=f(b(),1),ab=f(O(),1);Zw();sb();Ra();Tk=(0,ab.observer)(function({model:e}){let{MSA:t,verticalScrollbarWidth:r,msaFilehandle:n,height:o,msaAreaWidth:i,blocks2d:s}=e,a=(0,$r.useRef)(null),c=(0,$r.useCallback)(m=>{e.doScrollX(m)},[e]),l=(0,$r.useCallback)(m=>{e.doScrollY(m)},[e]),{onMouseDown:A,onMouseUp:u}=Lo({ref:a,onScrollX:c,onScrollY:l});return $r.default.createElement("div",{ref:a,onMouseDown:A,onMouseUp:u,onMouseLeave:m=>{m.preventDefault()},style:{position:"relative",height:o,width:i-r,overflow:"hidden"}},!t&&!n?null:t?s.map(([m,d])=>$r.default.createElement(ib,{key:`${m}_${d}`,model:e,offsetX:m,offsetY:d})):$r.default.createElement(zf,null))}),cb=Tk});function ub({ctx:e,model:t}){let{mouseCol:r,colWidth:n,msaAreaWidth:o,verticalScrollbarWidth:i,height:s,rowHeight:a,scrollX:c,scrollY:l,mouseRow:A,mouseClickRow:u,mouseClickCol:m,relativeTo:d,rowNamesSet:p,hoveredTreeNode:C,highlightedColumns:y}=t,I=o-i;if(e.resetTransform(),e.clearRect(0,0,I,s),d){let h=p.get(d);h!==void 0&&(e.fillStyle=_k,e.fillRect(0,h*a+l,I,a))}if(C){e.fillStyle=kk;for(let h of C.descendantNames){let x=p.get(h);x!==void 0&&e.fillRect(0,x*a+l,I,a)}}if(y?.length){e.fillStyle=Xf;for(let h of y)e.fillRect(h*n+c,0,n,s)}r!==void 0&&(e.fillStyle=Ab,e.fillRect(r*n+c,0,n,s)),A!==void 0&&(e.fillStyle=Ab,e.fillRect(0,A*a+l,I,a)),m!==void 0&&(e.fillStyle=Xf,e.fillRect(m*n+c,0,n,s)),u!==void 0&&(e.fillStyle=Xf,e.fillRect(0,u*a+l,I,a))}var Ab,Xf,_k,kk,fb=g(()=>{Ab="rgba(0,0,0,0.15)",Xf="rgba(128,128,0,0.2)",_k="rgba(0,128,255,0.3)",kk="rgba(255,165,0,0.15)"});var di,mb,db,gb,Dk,pb,hb=g(()=>{di=f(b(),1),mb=f(kt(),1),db=f(Hr(),1),gb=f(O(),1);fb();Dk=(0,gb.observer)(function({model:e}){let t=(0,di.useRef)(null),{height:r,msaAreaWidth:n,verticalScrollbarWidth:o}=e,i=n-o;return(0,di.useEffect)(()=>{let s=t.current?.getContext("2d");return s?(0,db.autorun)(()=>{(0,mb.isAlive)(e)&&ub({ctx:s,model:e})}):void 0},[e]),di.default.createElement("canvas",{ref:t,id:"mouseover",width:i,height:r,style:{position:"absolute",top:0,left:0,width:i,height:r,zIndex:1e3,pointerEvents:"none"}})}),pb=Dk});var Kc,Cb,Nk,Eb,Ib=g(()=>{Kc=f(b(),1),Cb=f(O(),1);lb();hb();Nk=(0,Cb.observer)(function({model:e}){return Kc.default.createElement("div",{style:{position:"relative"}},Kc.default.createElement(cb,{model:e}),Kc.default.createElement(pb,{model:e}))}),Eb=Nk});var ds,xb=g(()=>{ds=class{constructor(){this.ids=[],this.values=[],this.length=0}clear(){this.length=0}push(t,r){let n=this.length++;for(;n>0;){let o=n-1>>1,i=this.values[o];if(r>=i)break;this.ids[n]=this.ids[o],this.values[n]=i,n=o}this.ids[n]=t,this.values[n]=r}pop(){if(this.length===0)return;let t=this.ids,r=this.values,n=t[0],o=--this.length;if(o>0){let i=t[o],s=r[o],a=0,c=o>>1;for(;a<c;){let l=(a<<1)+1,A=l+1,u=l+(+(A<o)&+(r[A]<r[l]));if(r[u]>=s)break;t[a]=t[u],r[a]=r[u],a=u}t[a]=i,r[a]=s}return n}peek(){return this.length>0?this.ids[0]:void 0}peekValue(){return this.length>0?this.values[0]:void 0}shrink(){this.ids.length=this.values.length=this.length}}});function wb(e,t){let r=0,n=t.length-1;for(;r<n;){let o=r+n>>1;t[o]>e?n=o:r=o+1}return t[r]}function Lk(e,t,r,n,o,i){let s=[n,o];for(;s.length;){let a=s.pop()||0,c=s.pop()||0;if(a-c<=i&&Math.floor(c/i)>=Math.floor(a/i))continue;let l=e[c],A=e[c+a>>1],u=e[a],m=l>A!=l>u?l:A<l!=A<u?A:u,d=c-1,p=a+1;for(;;){do d++;while(e[d]<m);do p--;while(e[p]>m);if(d>=p)break;Fk(e,t,r,d,p)}s.push(c,p,p+1,a)}}function Fk(e,t,r,n,o){let i=e[n];e[n]=e[o],e[o]=i;let s=4*n,a=4*o,c=t[s],l=t[s+1],A=t[s+2],u=t[s+3];t[s]=t[a],t[s+1]=t[a+1],t[s+2]=t[a+2],t[s+3]=t[a+3],t[a]=c,t[a+1]=l,t[a+2]=A,t[a+3]=u;let m=r[n];r[n]=r[o],r[o]=m}function Rk(e,t){let r=e^t,n=65535^r,o=65535^(e|t),i=e&(t^65535),s=r|n>>1,a=r>>1^r,c=o>>1^n&i>>1^o,l=r&o>>1^i>>1^i;r=s,n=a,o=c,i=l,s=r&r>>2^n&n>>2,a=r&n>>2^n&(r^n)>>2,c^=r&o>>2^n&i>>2,l^=n&o>>2^(r^n)&i>>2,r=s,n=a,o=c,i=l,s=r&r>>4^n&n>>4,a=r&n>>4^n&(r^n)>>4,c^=r&o>>4^n&i>>4,l^=n&o>>4^(r^n)&i>>4,r=s,n=a,o=c,i=l,c^=r&o>>8^n&i>>8,l^=n&o>>8^(r^n)&i>>8,r=c^c>>1,n=l^l>>1;let A=e^t,u=n|65535^(A|r);return A=(A|A<<8)&16711935,A=(A|A<<4)&252645135,A=(A|A<<2)&858993459,A=(A|A<<1)&1431655765,u=(u|u<<8)&16711935,u=(u|u<<4)&252645135,u=(u|u<<2)&858993459,u=(u|u<<1)&1431655765,(u<<1|A)>>>0}var yb,Zf,gs,bb=g(()=>{xb();yb=[Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],Zf=3,gs=class e{static from(t,r=0){if(r%8!==0)throw new Error("byteOffset must be 8-byte aligned.");if(!t||t.byteLength===void 0||t.buffer)throw new Error("Data must be an instance of ArrayBuffer or SharedArrayBuffer.");let[n,o]=new Uint8Array(t,r+0,2);if(n!==251)throw new Error("Data does not appear to be in a Flatbush format.");let i=o>>4;if(i!==Zf)throw new Error(`Got v${i} data when expected v${Zf}.`);let s=yb[o&15];if(!s)throw new Error("Unrecognized array type.");let[a]=new Uint16Array(t,r+2,1),[c]=new Uint32Array(t,r+4,1);return new e(c,a,s,void 0,t,r)}constructor(t,r=16,n=Float64Array,o=ArrayBuffer,i,s=0){if(t===void 0)throw new Error("Missing required argument: numItems.");if(isNaN(t)||t<=0)throw new Error(`Unexpected numItems value: ${t}.`);this.numItems=+t,this.nodeSize=Math.min(Math.max(+r,2),65535),this.byteOffset=s;let a=t,c=a;this._levelBounds=[a*4];do a=Math.ceil(a/this.nodeSize),c+=a,this._levelBounds.push(c*4);while(a!==1);this.ArrayType=n,this.IndexArrayType=c<16384?Uint16Array:Uint32Array;let l=yb.indexOf(n),A=c*4*n.BYTES_PER_ELEMENT;if(l<0)throw new Error(`Unexpected typed array class: ${n}.`);if(i)this.data=i,this._boxes=new n(i,s+8,c*4),this._indices=new this.IndexArrayType(i,s+8+A,c),this._pos=c*4,this.minX=this._boxes[this._pos-4],this.minY=this._boxes[this._pos-3],this.maxX=this._boxes[this._pos-2],this.maxY=this._boxes[this._pos-1];else{let u=this.data=new o(8+A+c*this.IndexArrayType.BYTES_PER_ELEMENT);this._boxes=new n(u,8,c*4),this._indices=new this.IndexArrayType(u,8+A,c),this._pos=0,this.minX=1/0,this.minY=1/0,this.maxX=-1/0,this.maxY=-1/0,new Uint8Array(u,0,2).set([251,(Zf<<4)+l]),new Uint16Array(u,2,1)[0]=r,new Uint32Array(u,4,1)[0]=t}this._queue=new ds}add(t,r,n=t,o=r){let i=this._pos>>2,s=this._boxes;return this._indices[i]=i,s[this._pos++]=t,s[this._pos++]=r,s[this._pos++]=n,s[this._pos++]=o,t<this.minX&&(this.minX=t),r<this.minY&&(this.minY=r),n>this.maxX&&(this.maxX=n),o>this.maxY&&(this.maxY=o),i}finish(){if(this._pos>>2!==this.numItems)throw new Error(`Added ${this._pos>>2} items when expected ${this.numItems}.`);let t=this._boxes;if(this.numItems<=this.nodeSize){t[this._pos++]=this.minX,t[this._pos++]=this.minY,t[this._pos++]=this.maxX,t[this._pos++]=this.maxY;return}let r=this.maxX-this.minX||1,n=this.maxY-this.minY||1,o=new Uint32Array(this.numItems),i=65535;for(let s=0,a=0;s<this.numItems;s++){let c=t[a++],l=t[a++],A=t[a++],u=t[a++],m=Math.floor(i*((c+A)/2-this.minX)/r),d=Math.floor(i*((l+u)/2-this.minY)/n);o[s]=Rk(m,d)}Lk(o,t,this._indices,0,this.numItems-1,this.nodeSize);for(let s=0,a=0;s<this._levelBounds.length-1;s++){let c=this._levelBounds[s];for(;a<c;){let l=a,A=t[a++],u=t[a++],m=t[a++],d=t[a++];for(let p=1;p<this.nodeSize&&a<c;p++)A=Math.min(A,t[a++]),u=Math.min(u,t[a++]),m=Math.max(m,t[a++]),d=Math.max(d,t[a++]);this._indices[this._pos>>2]=l,t[this._pos++]=A,t[this._pos++]=u,t[this._pos++]=m,t[this._pos++]=d}}}search(t,r,n,o,i){if(this._pos!==this._boxes.length)throw new Error("Data not yet indexed - call index.finish().");let s=this._boxes.length-4,a=[],c=[];for(;s!==void 0;){let l=Math.min(s+this.nodeSize*4,wb(s,this._levelBounds));for(let A=s;A<l;A+=4){let u=this._boxes[A];if(n<u)continue;let m=this._boxes[A+1];if(o<m)continue;let d=this._boxes[A+2];if(t>d)continue;let p=this._boxes[A+3];if(r>p)continue;let C=this._indices[A>>2]|0;s>=this.numItems*4?a.push(C):(i===void 0||i(C,u,m,d,p))&&c.push(C)}s=a.pop()}return c}neighbors(t,r,n=1/0,o=1/0,i){if(this._pos!==this._boxes.length)throw new Error("Data not yet indexed - call index.finish().");let s=this._boxes.length-4,a=this._queue,c=[],l=o*o;e:for(;s!==void 0;){let A=Math.min(s+this.nodeSize*4,wb(s,this._levelBounds));for(let u=s;u<A;u+=4){let m=this._indices[u>>2]|0,d=this._boxes[u],p=this._boxes[u+1],C=this._boxes[u+2],y=this._boxes[u+3],I=t<d?d-t:t>C?t-C:0,h=r<p?p-r:r>y?r-y:0,x=I*I+h*h;x>l||(s>=this.numItems*4?a.push(m<<1,x):(i===void 0||i(m))&&a.push((m<<1)+1,x))}for(;a.length&&a.peek()&1;)if(a.peekValue()>l||(c.push(a.pop()>>1),c.length===n))break e;s=a.length?a.pop()>>1:void 0}return a.clear(),c}}});var ps,gi,Bb,Pk,Sb,Qb=g(()=>{ps=f(b(),1),gi=f(D(),1),Bb=f(O(),1),Pk=(0,Bb.observer)(function({node:e,model:t,onClose:r}){return ps.default.createElement(gi.Menu,{anchorReference:"anchorPosition",anchorPosition:{left:e.x,top:e.y},transitionDuration:0,keepMounted:!0,open:!!e,onClose:r},ps.default.createElement(gi.MenuItem,{dense:!0,disabled:!0},e.name),ps.default.createElement(gi.MenuItem,{dense:!0,onClick:()=>{t.toggleCollapsed(e.id),r()}},t.collapsed.includes(e.id)?"Expand this node":"Collapse this node"),ps.default.createElement(gi.MenuItem,{dense:!0,onClick:()=>{t.showOnly===e.id?t.setShowOnly(void 0):t.setShowOnly(e.id),r()}},t.showOnly===e.id?"Disable show only this node":"Show only this node"))}),Sb=Pk});var _b={};We(_b,{default:()=>Gk});var kr,Mb,vb,Tb,Ok,Gk,kb=g(()=>{kr=f(b(),1);Rc();Uf();Mb=f(ye(),1),vb=f(D(),1),Tb=f(O(),1);Hf();Ok=(0,Tb.observer)(function({info:e,model:t,nodeName:r,onClose:n}){let{treeMetadata:o,rows:i}=t,s=o[r],a=i.find(c=>c[0]===r);return kr.default.createElement(Mb.Dialog,{onClose:()=>{n()},open:!0,title:"Tree node info",maxWidth:"xl"},kr.default.createElement(vb.DialogContent,null,kr.default.createElement(Kn,{title:"Attributes"},kr.default.createElement(_r,{attributes:{nodeName:r,...e}})),kr.default.createElement(Kn,{title:"Sequence"},a?kr.default.createElement(fs,{str:[a]}):kr.default.createElement("div",null,"Sequence not found")),s?kr.default.createElement(Kn,{title:"Extra metadata"},kr.default.createElement(_r,{attributes:s})):null))}),Gk=Ok});var Kr,xn,Db,Uk,Hk,Nb,Lb=g(()=>{Kr=f(b(),1),xn=f(D(),1),Db=f(O(),1),Uk=(0,Kr.lazy)(()=>Promise.resolve().then(()=>(kb(),_b))),Hk=(0,Db.observer)(function({node:e,onClose:t,model:r}){let{collapsed:n}=r,{name:o,id:i}=e,s=n.includes(i);return Kr.default.createElement(xn.Menu,{anchorReference:"anchorPosition",anchorPosition:{top:e.y,left:e.x},transitionDuration:0,keepMounted:!0,open:!!e,onClose:t},Kr.default.createElement(xn.MenuItem,{dense:!0,disabled:!0},o),Kr.default.createElement(xn.MenuItem,{dense:!0,onClick:()=>{r.queueDialog(a=>[Uk,{info:r.getRowData(o),model:r,nodeName:o,onClose:a}]),t()}},"More info..."),Kr.default.createElement(xn.MenuItem,{dense:!0,onClick:()=>{r.toggleCollapsed(i),t()}},s?"Show node":"Hide node"),Kr.default.createElement(xn.MenuItem,{dense:!0,onClick:()=>{r.drawRelativeTo(e.name),t()}},"Indicate differences from this row"),r.relativeTo?Kr.default.createElement(xn.MenuItem,{dense:!0,onClick:()=>{r.drawRelativeTo(void 0),t()}},"Clear reference row"):null)}),Nb=Hk});function Fb(e){let t=0;if(e.children)for(let r of e.children){let n=Fb(r)+1;n>t&&(t=n)}return e.height=t,t}function Rb(e,t,r,n){let o=t(e),i={data:e,children:null,parent:r,depth:n,height:0};return o?.length&&(i.children=o.map(s=>Rb(s,t,i,n+1))),i}function Pb(e,t){let r=Rb(e,t,null,0);return Fb(r),r}function Ob(e,t){function r(n){let o=t(n.data);if(n.children)for(let i of n.children)o+=r(i);return n.value=o,o}return r(e),e}function Gb(e,t){function r(n){if(n.children){n.children.sort(t);for(let o of n.children)r(o)}}return r(e),e}function hs(e,t){if(t(e))return e;if(e.children)for(let r of e.children){let n=hs(r,t);if(n)return n}}function Cs(e){let t=[];function r(n){if(n.children)for(let o of n.children)r(o);else t.push(n)}return r(e),t}function Ub(e){let t=[];function r(n){if(t.push(n),n.children)for(let o of n.children)r(o)}return r(e),t}function Xc(e){let t=[];function r(n){if(n.children)for(let o of n.children)t.push({source:n,target:o}),r(o)}return r(e),t}function Hb(e,t,r){let n=Cs(e),o=n.length,i=t/o;for(let l=0;l<o;l++)n[l].x=(l+.5)*i;function s(l){if(!l.children)return;for(let u of l.children)s(u);let A=0;for(let u of l.children)A+=u.x;l.x=A/l.children.length}s(e);let a=e.height;function c(l,A){if(l.y=a===0?r:A/a*r,l.children)for(let u of l.children)c(u,A+1)}c(e,0)}function jb(e){e.children&&(e._children=e.children,e.children=null)}function em(e){return(e.data.length||0)+(e.children?e.children.reduce((t,r)=>Math.max(t,em(r)),0):0)}function tm(e,t,r){if(e.len=(t+=Math.max(e.data.length||0,0))*r,e.children)for(let n of e.children)tm(n,t,r)}var rm=g(()=>{});function Es(e){if(e.depthToLeaf!==void 0)return e.depthToLeaf;if(!e.children||e.children.length===0)e.depthToLeaf=0;else{let t=0;for(let r of e.children)t=Math.max(t,1+Es(r));e.depthToLeaf=t}return e.depthToLeaf}function tl(e){let t=e.len||0;if(e.children)for(let r of e.children)t=Math.max(t,tl(r));return t}function el(e,t,r,n){if(t)return e.len;let o=Es(e);return(n-o)/n*r}function jk({offsetY:e,ctx:t,model:r,theme:n,blockSizeYOverride:o}){let{hierarchy:i,showBranchLenEffective:s,blockSize:a}=r,c=o||a;t.strokeStyle=n.palette.text.primary;let l=tl(i),A=Es(i);for(let u of Xc(i)){let{source:m,target:d}=u,p=m.x,C=d.x,y=el(d,s,l,A),I=el(m,s,l,A);if(y===void 0||I===void 0)continue;let h=Math.min(p,C),x=Math.max(p,C);e+c>=h&&x>=e&&(t.beginPath(),t.moveTo(I,p),t.lineTo(I,C),t.lineTo(y,C),t.stroke())}}function qk({ctx:e,clickMap:t,offsetY:r,model:n,blockSizeYOverride:o}){let{hierarchy:i,showBranchLenEffective:s,collapsed:a,blockSize:c,marginLeft:l}=n,A=o||c,u=tl(i),m=Es(i);for(let d of Ub(i)){let p=el(d,s,u,m);if(p===void 0)continue;let{data:C}=d,y=d.x,{id:I,name:h}=C;d.height>=1&&y>r-Zc&&y<r+A+Zc&&(e.strokeStyle="black",e.fillStyle=a.includes(I)?"black":"white",e.beginPath(),e.arc(p,y,eo,0,2*Math.PI),e.fill(),e.stroke(),t?.insert({minX:p-eo+l,maxX:p-eo+nm+l,minY:y-eo,maxY:y-eo+nm,branch:!0,id:I,name:h}))}}function Jk({theme:e,model:t,offsetY:r,ctx:n,clickMap:o,blockSizeYOverride:i}){let{fontSize:s,showBranchLenEffective:a,treeMetadata:c,blockSize:l,labelsAlignRight:A,drawTree:u,treeAreaWidth:m,treeAreaWidthMinusMargin:d,marginLeft:p,leaves:C,noTree:y,hierarchy:I}=t,h=i||l,x=n.measureText("M").width;A?(n.textAlign="right",n.setLineDash([1,3])):n.textAlign="start";let S=tl(I),M=Es(I);for(let B of C){let{data:{name:Q,id:L}}=B,T=B.x,re=c[Q]?.genome||Q;if(T>r-Zc&&T<r+h+Zc){let k=T+s/4,j=0;y||(j=el(B,a,S,M)||0);let{width:J}=n.measureText(re);if(n.fillStyle=e.palette.text.primary,A){let ie=d-2;u&&!y&&(n.moveTo(j+eo+2,T),n.lineTo(ie-2-J,T),n.stroke()),n.fillText(re,ie,k),o?.insert({minX:m-J,maxX:m,minY:k-x,maxY:k,name:Q,id:L})}else{let R=y?2:j+nm;n.fillText(re,R,k),o?.insert({minX:R+p,maxX:R+J+p,minY:k-x,maxY:k,name:Q,id:L})}}}n.setLineDash([])}function rl({model:e,clickMap:t,ctx:r,offsetY:n,theme:o,highResScaleFactorOverride:i,blockSizeYOverride:s}){t?.clear();let{noTree:a,drawTree:c,drawNodeBubbles:l,highResScaleFactor:A,fontSize:u,showTreeText:m,marginLeft:d,nref:p,rowHeight:C}=e;r.resetTransform();let y=p<0?Number.NEGATIVE_INFINITY:i||A;r.scale(y,y),r.translate(d,-n);let I=r.font;r.font=I.replace(/\d+px/,`${u}px`),!a&&c&&(jk({ctx:r,offsetY:n,model:e,theme:o,blockSizeYOverride:s}),l&&qk({ctx:r,offsetY:n,clickMap:t,model:e,blockSizeYOverride:s})),m&&Jk({ctx:r,offsetY:n,model:e,clickMap:t,theme:o,blockSizeYOverride:s}),t?.finish()}var pi,Zc,eo,nm,nl=g(()=>{rm();pi=600,Zc=5,eo=2.5,nm=eo*2});var _e,qb,Jb,Vb,Yb,Vk,om,Yk,Wb,zb=g(()=>{_e=f(b(),1),qb=f(D(),1);bb();Jb=f(Hr(),1),Vb=f(O(),1),Yb=f(Be(),1);Qb();Lb();nl();Vk=(0,Yb.makeStyles)()(e=>({tooltip:{position:"fixed",pointerEvents:"none",zIndex:1e4,backgroundColor:e.palette.grey[700],color:e.palette.common.white,padding:"4px 8px",borderRadius:4,fontSize:12,whiteSpace:"nowrap",maxWidth:300,overflow:"hidden",textOverflow:"ellipsis"}})),om=class{flatbush=null;entries=[];clear(){this.flatbush=null,this.entries=[]}insert(t){this.entries.push(t)}finish(){if(this.entries.length===0){this.flatbush=null;return}else{this.flatbush=new gs(this.entries.length);for(let t of this.entries)this.flatbush.add(t.minX,t.minY,t.maxX,t.maxY);this.flatbush.finish()}}search(t){return this.flatbush?.search(t.minX,t.minY,t.maxX,t.maxY).map(r=>this.entries[r])??[]}},Yk=(0,Vb.observer)(function({model:e,offsetY:t}){let{classes:r}=Vk(),n=(0,qb.useTheme)(),o=(0,_e.useRef)(null),i=(0,_e.useRef)(new om),s=(0,_e.useRef)(null),[a,c]=(0,_e.useState)(),[l,A]=(0,_e.useState)(),[u,m]=(0,_e.useState)(),[d,p]=(0,_e.useState)(),{scrollY:C,treeAreaWidth:y,blockSize:I,highResScaleFactor:h}=e,x=y+pi,S=I,M=x*h,B=S*h,Q=(0,_e.useCallback)(k=>{e.incrementRef(),o.current=k},[e,S,x]);(0,_e.useEffect)(()=>{let k=o.current?.getContext("2d");if(k)return(0,Jb.autorun)(()=>{k.resetTransform(),k.clearRect(0,0,(y+pi)*h,I*h),rl({ctx:k,model:e,offsetY:t,clickMap:i.current,theme:n})})},[e,I,h,y,t,n]),(0,_e.useEffect)(()=>{let k=s.current?.getContext("2d");if(k&&(k.resetTransform(),k.clearRect(0,0,y+pi,I),k.translate(0,-t),u)){let{minX:j,maxX:J,minY:R,maxY:ie}=u;k.fillStyle="rgba(0,0,0,0.1)",k.fillRect(j,R,J-j,ie-R)}},[u,t,I,y]);function L(k){let j=k.nativeEvent.offsetX,J=k.nativeEvent.offsetY,[R]=i.current.search({minX:j,maxX:j+1,minY:J+t,maxY:J+1+t});return R?.branch?{...R,x:k.clientX,y:k.clientY}:void 0}function T(k){let j=k.nativeEvent.offsetX,J=k.nativeEvent.offsetY,[R]=i.current.search({minX:j,maxX:j+1,minY:J+t,maxY:J+1+t});return R&&!R.branch?{...R,x:k.clientX,y:k.clientY}:void 0}let re={width:x,height:S,top:C+t,left:0,position:"absolute"};return _e.default.createElement(_e.default.Fragment,null,a?.id?_e.default.createElement(Sb,{node:a,model:e,onClose:()=>{c(void 0)}}):null,l?.id?_e.default.createElement(Nb,{node:l,model:e,onClose:()=>{A(void 0)}}):null,_e.default.createElement("canvas",{width:M,height:B,style:re,onMouseMove:k=>{if(!o.current)return;let j=T(k),J=L(k),R=j||J;if(o.current.style.cursor=R?"pointer":"default",m(j),p(R?{name:R.name,x:k.clientX,y:k.clientY}:void 0),R){if(e.setHoveredTreeNode(R.id),j?.name){let ie=e.rowNamesSet.get(j.name);ie!==void 0&&e.setMousePos(void 0,ie)}}else e.setHoveredTreeNode(void 0),e.setMousePos(void 0,void 0)},onClick:k=>{let{clientX:j,clientY:J}=k,R=L(k);R?.id&&c({x:j,y:J,id:R.id,name:R.name});let ie=T(k);ie?.id&&A({...ie,x:j,y:J})},onMouseLeave:()=>{m(void 0),p(void 0),e.setHoveredTreeNode(void 0),e.setMousePos(void 0,void 0)},ref:Q}),_e.default.createElement("canvas",{style:{...re,pointerEvents:"none",zIndex:100},width:x,height:S,ref:s}),d?_e.default.createElement("div",{className:r.tooltip,style:{left:d.x+12,top:d.y+12}},d.name):null)}),Wb=Yk});var hr,Kb,Xb,Zb,Wk,$b,zk,eB,tB=g(()=>{hr=f(b(),1),Kb=f(kt(),1),Xb=f(Hr(),1),Zb=f(O(),1);zb();nl();Ra();Wk="rgba(0,128,255,0.3)",$b="rgba(255,165,0,0.2)",zk=(0,Zb.observer)(function({model:e}){let t=(0,hr.useRef)(null),r=(0,hr.useRef)(null),{treeWidth:n,height:o,blocksY:i,treeAreaWidth:s}=e,a=(0,hr.useCallback)(A=>{e.doScrollY(A)},[e]),{onMouseDown:c,onMouseUp:l}=Lo({ref:t,onScrollY:a});return(0,hr.useEffect)(()=>{let A=r.current?.getContext("2d");return A?(0,Xb.autorun)(()=>{if((0,Kb.isAlive)(e)){let{relativeTo:u,leaves:m,rowHeight:d,hoveredTreeNode:p,treeAreaWidth:C,height:y,scrollY:I,mouseOverRowName:h}=e;if(A.resetTransform(),A.clearRect(0,0,C,y),u){let x=m.find(S=>S.data.name===u);x&&(A.fillStyle=Wk,A.fillRect(0,x.x+I-d/2,C,d))}if(p){A.fillStyle=$b;for(let x of p.descendantNames){let S=m.find(M=>M.data.name===x);S&&A.fillRect(0,S.x+I-d/2,C,d)}}if(h&&h!==u&&!p?.descendantNames.includes(h)){let x=m.find(S=>S.data.name===h);x&&(A.fillStyle=$b,A.fillRect(0,x.x+I-d/2,C,d))}}}):void 0},[e]),hr.default.createElement("div",{ref:t,onMouseDown:c,onMouseUp:l,onMouseLeave:A=>{A.preventDefault()},style:{height:o,position:"relative",width:n+pi}},i.map(A=>hr.default.createElement(Wb,{key:A,model:e,offsetY:A})),hr.default.createElement("canvas",{ref:r,width:s,height:o,style:{position:"absolute",top:0,left:0,width:s,height:o,zIndex:1e3,pointerEvents:"none"}}))}),eB=zk});var im,rB,$k,nB,oB=g(()=>{im=f(b(),1),rB=f(O(),1);tB();$k=(0,rB.observer)(function({model:e}){let{treeAreaWidth:t}=e;return im.default.createElement("div",{style:{overflow:"hidden",flexShrink:0,width:t}},im.default.createElement(eB,{model:e}))}),nB=$k});var iB,sB,Kk,aB,cB=g(()=>{iB=f(b(),1),sB=f(O(),1),Kk=(0,sB.observer)(({model:e})=>{let{treeAreaWidth:t}=e;return iB.default.createElement("div",{style:{flexShrink:0,width:t}})}),aB=Kk});var te,to,Xk,Zk,eD,tD,rD,nD,lB,AB=g(()=>{te=f(b(),1),to=f(O(),1);i0();p0();I0();zw();Xw();Ib();oB();cB();Xk=(0,to.observer)(function({model:e}){let{showHorizontalScrollbar:t}=e;return te.default.createElement("div",{style:{display:"flex"}},te.default.createElement(aB,{model:e}),t?te.default.createElement(Kw,{model:e}):null)}),Zk=(0,to.observer)(function({model:e}){let{mouseCol:t,mouseClickCol:r,colWidth:n,scrollX:o,treeAreaWidth:i,resizeHandleWidth:s,totalTrackAreaHeight:a,msaAreaWidth:c,verticalScrollbarWidth:l}=e,A=i+s,u=c-l;return te.default.createElement("div",{style:{position:"absolute",left:A,top:0,width:u,height:a,overflow:"hidden",pointerEvents:"none"}},t!==void 0?te.default.createElement("div",{style:{position:"absolute",left:t*n+o,top:0,width:n,height:a,backgroundColor:"rgba(0,0,0,0.15)",zIndex:100}}):null,r!==void 0?te.default.createElement("div",{style:{position:"absolute",left:r*n+o,top:0,width:n,height:a,backgroundColor:"rgba(128,128,0,0.2)",zIndex:100}}):null)}),eD=(0,to.observer)(function({model:e}){let{turnedOnTracks:t}=e;return t.length===0?null:te.default.createElement("div",{style:{position:"relative"}},te.default.createElement(Zk,{model:e}),t.map(r=>te.default.createElement(g0,{key:r.model.id,model:e,track:r})))}),tD=(0,to.observer)(function({model:e}){let{showVerticalScrollbar:t}=e;return te.default.createElement("div",{style:{display:"flex"}},te.default.createElement(nB,{model:e}),te.default.createElement(n0,{model:e}),te.default.createElement(Eb,{model:e}),t?te.default.createElement(E0,{model:e}):null)}),rD=(0,to.observer)(function({model:e}){return te.default.createElement("div",{style:{position:"relative"}},te.default.createElement(Xk,{model:e}),te.default.createElement(eD,{model:e}),te.default.createElement(tD,{model:e}))}),nD=(0,to.observer)(function({model:e}){let{height:t,viewInitialized:r,DialogComponent:n,DialogProps:o}=e;return te.default.createElement("div",null,r?te.default.createElement(te.default.Fragment,null,te.default.createElement("div",{style:{height:t,overflow:"hidden"}},te.default.createElement(Ww,{model:e}),te.default.createElement(rD,{model:e})),te.default.createElement(o0,{model:e}),n?te.default.createElement(te.Suspense,{fallback:null},te.default.createElement(n,{...o})):null):null)}),lB=nD});var uB,fB,mB,dB=g(()=>{uB=`CLUSTAL O(1.2.3) multiple sequence alignment
21
+ `} 1.2s infinite ease-in-out`}}})});var Qh=U((WR,Sh)=>{Sh.exports=function(){var e=document.getSelection();if(!e.rangeCount)return function(){};for(var t=document.activeElement,r=[],n=0;n<e.rangeCount;n++)r.push(e.getRangeAt(n));switch(t.tagName.toUpperCase()){case"INPUT":case"TEXTAREA":t.blur();break;default:t=null;break}return e.removeAllRanges(),function(){e.type==="Caret"&&e.removeAllRanges(),e.rangeCount||r.forEach(function(o){e.addRange(o)}),t&&t.focus()}}});var Th=U((zR,vh)=>{"use strict";var XM=Qh(),Mh={"text/plain":"Text","text/html":"Url",default:"Text"},ZM="Copy to clipboard: #{key}, Enter";function e2(e){var t=(/mac os x/i.test(navigator.userAgent)?"\u2318":"Ctrl")+"+C";return e.replace(/#{\s*key\s*}/g,t)}function t2(e,t){var r,n,o,i,s,a,c=!1;t||(t={}),r=t.debug||!1;try{o=XM(),i=document.createRange(),s=document.getSelection(),a=document.createElement("span"),a.textContent=e,a.ariaHidden="true",a.style.all="unset",a.style.position="fixed",a.style.top=0,a.style.clip="rect(0, 0, 0, 0)",a.style.whiteSpace="pre",a.style.webkitUserSelect="text",a.style.MozUserSelect="text",a.style.msUserSelect="text",a.style.userSelect="text",a.addEventListener("copy",function(A){if(A.stopPropagation(),t.format)if(A.preventDefault(),typeof A.clipboardData>"u"){r&&console.warn("unable to use e.clipboardData"),r&&console.warn("trying IE specific stuff"),window.clipboardData.clearData();var u=Mh[t.format]||Mh.default;window.clipboardData.setData(u,e)}else A.clipboardData.clearData(),A.clipboardData.setData(t.format,e);t.onCopy&&(A.preventDefault(),t.onCopy(A.clipboardData))}),document.body.appendChild(a),i.selectNodeContents(a),s.addRange(i);var l=document.execCommand("copy");if(!l)throw new Error("copy command was unsuccessful");c=!0}catch(A){r&&console.error("unable to copy using execCommand: ",A),r&&console.warn("trying IE specific stuff");try{window.clipboardData.setData(t.format||"text",e),t.onCopy&&t.onCopy(window.clipboardData),c=!0}catch(u){r&&console.error("unable to copy using clipboardData: ",u),r&&console.error("falling back to prompt"),n=e2("message"in t?t.message:ZM),window.prompt(n,e)}}finally{s&&(typeof s.removeRange=="function"?s.removeRange(i):s.removeAllRanges()),a&&document.body.removeChild(a),o()}return c}vh.exports=t2});var Lh={};Ye(Lh,{default:()=>Nh});async function Dh(e){let t=await fetch(e);if(!t.ok)throw new Error(`HTTP ${t.status} fetching ${e}: ${await t.text()}`);return t.text()}async function r2(e){return JSON.parse(await Dh(e))}async function i2(e){if(RA[e])return RA[e];let t=new URL(e).search,r=await Dh(e),n=n2.exec(r)?.[1]??"",o=await r2(new URL(n,e).href+t),i=new kh.SourceMapConsumer(o);return RA[e]=i,i}async function s2(e){let t=[];for(let r of e.split(`
22
+ `)){let n=o2.exec(r);if(!n){t.push(r);continue}let o=n[2],s=(await i2(o)).originalPositionFor({line:+n[3],column:+n[4]});if(!s.source||!s.line||!s.column){t.push(r);continue}t.push(`${s.source}:${s.line}:${s.column+1} (${n[1].trim()})`)}return t.join(`
23
+ `)}function a2(e,t){return e.startsWith("Error:")?e.slice(`${t}`.length):e}function c2(e){return typeof e=="object"&&e!==null&&"stack"in e?`${e.stack}`:""}function Nh({error:e,onClose:t,extra:r}){let[n,o]=(0,Ho.useState)(),[i,s]=(0,Ho.useState)(),[a,c]=(0,Ho.useState)(!1),l=e?`${e}`:"",A=a2(c2(e),l);(0,Ho.useEffect)(()=>{(async()=>{try{o(await s2(A))}catch(d){console.error(d),o(A),s(d)}})()},[A]);let u=window.JBrowseSession?.version,m=[i?"Error loading source map, showing raw stack trace below:":"",l.length>_h?`${l.slice(0,_h)}...`:l,n||"No stack trace available",u?`JBrowse ${u}`:""].filter(Boolean).join(`
24
+ `);return(0,Vt.jsxs)(Nt.Dialog,{open:!0,onClose:t,maxWidth:"xl",children:[(0,Vt.jsxs)(Nt.DialogTitle,{children:["Stack trace",(0,Vt.jsx)(Nt.IconButton,{onClick:t,sx:{position:"absolute",right:8,top:8},children:(0,Vt.jsx)(Ks,{})})]}),(0,Vt.jsx)(Nt.DialogContent,{children:n===void 0?(0,Vt.jsx)(FA,{variant:"h6"}):(0,Vt.jsx)(LA,{text:m,extra:r})}),(0,Vt.jsxs)(Nt.DialogActions,{children:[(0,Vt.jsx)(Nt.Button,{variant:"contained",color:"secondary",onClick:async()=>{let{default:d}=await Promise.resolve().then(()=>f(Th(),1));d(m),c(!0),setTimeout(()=>{c(!1)},1e3)},children:a?"Copied!":"Copy stack trace to clipboard"}),(0,Vt.jsx)(Nt.Button,{variant:"contained",color:"primary",onClick:t,children:"Close"})]})]})}var Vt,Ho,Nt,kh,RA,n2,o2,_h,Fh=g(()=>{Vt=f(R(),1),Ho=f(w(),1);Wl();Nt=f(k(),1),kh=f(hh(),1);yh();Bh();RA={},n2=/\/\/# sourceMappingURL=(.*)/,o2=/(.*)((?:https?|file):\/\/.*):(\d+):(\d+)/;_h=1e4});function A2(e){let t="",r="is not assignable",n=e.indexOf(r);if(n!==-1){let o=e.slice(0,n+r.length),i=/.*at path "(.*)" snapshot `(.*)` is not assignable/m.exec(o);i&&(e=`Failed to load element at ${i[1]}...Failed element had snapshot`,t=i[2]);let s=/.*snapshot `(.*)` is not assignable/.exec(o);s&&(e="Failed to load element...Failed element had snapshot",t=s[1])}return t}function u2({error:e,onReset:t}){let{classes:r}=Rh(),[n,o]=(0,qo.useState)(!1);return(0,Mt.jsxs)("div",{className:r.iconFloat,children:[typeof e=="object"&&e&&"stack"in e?(0,Mt.jsx)(jo.Tooltip,{title:"Get stack trace",children:(0,Mt.jsx)(jo.IconButton,{onClick:()=>{o(!0)},color:"primary",children:(0,Mt.jsx)(Mg,{})})}):null,t?(0,Mt.jsx)(jo.Tooltip,{title:"Retry",children:(0,Mt.jsx)(jo.IconButton,{onClick:t,color:"primary",children:(0,Mt.jsx)(Bg,{})})}):null,n?(0,Mt.jsx)(qo.Suspense,{fallback:null,children:(0,Mt.jsx)(l2,{error:e,onClose:()=>{o(!1)}})}):null]})}function f2({error:e,onReset:t}){let{classes:r}=Rh(),n=`${e}`,o=n.indexOf("expected an instance of"),i=o!==-1?n.slice(0,o):n,s=A2(n);return(0,Mt.jsxs)(xA,{children:[i.slice(0,1e4),(0,Mt.jsx)(u2,{error:e,onReset:t}),s?(0,Mt.jsx)("pre",{className:r.bg,children:JSON.stringify(JSON.parse(s),null,2)}):null]})}var Mt,qo,jo,l2,Rh,Ph,Oh=g(()=>{Mt=f(R(),1),qo=f(w(),1);Sg();vg();jo=f(k(),1);Jp();Et();l2=(0,qo.lazy)(()=>Promise.resolve().then(()=>(Fh(),Lh))),Rh=te()(e=>({bg:{background:e.palette.divider,border:"1px solid black",margin:20},iconFloat:{float:"right",marginLeft:100}}));Ph=f2});var Uh=U((o3,Gh)=>{"use strict";var m2=/["'&<>]/;Gh.exports=d2;function d2(e){var t=""+e,r=m2.exec(t);if(!r)return t;var n,o="",i=0,s=0;for(i=r.index;i<t.length;i++){switch(t.charCodeAt(i)){case 34:n="&quot;";break;case 38:n="&amp;";break;case 39:n="&#39;";break;case 60:n="&lt;";break;case 62:n="&gt;";break;default:continue}s!==i&&(o+=t.substring(s,i)),s=i+1,o+=n}return s!==i?o+t.substring(s,i):o}});var Hh=g(()=>{});var jh=g(()=>{Hh()});function g2(e){try{let s=j.__wbindgen_add_to_stack_pointer(-16),a=UA(e,j.__wbindgen_export2),c=La;j.decompress_all(s,a,c);var t=$e().getInt32(s+0,!0),r=$e().getInt32(s+4,!0),n=$e().getInt32(s+8,!0),o=$e().getInt32(s+12,!0);if(o)throw HA(n);var i=OA(t,r).slice();return j.__wbindgen_export(t,r*1,1),i}finally{j.__wbindgen_add_to_stack_pointer(16)}}function p2(e){try{let o=j.__wbindgen_add_to_stack_pointer(-16),i=UA(e,j.__wbindgen_export2),s=La;j.decompress_block(o,i,s);var t=$e().getInt32(o+0,!0),r=$e().getInt32(o+4,!0),n=$e().getInt32(o+8,!0);if(n)throw HA(r);return Yo.__wrap(t)}finally{j.__wbindgen_add_to_stack_pointer(16)}}function h2(e,t,r,n,o){try{let c=j.__wbindgen_add_to_stack_pointer(-16),l=UA(e,j.__wbindgen_export2),A=La;j.decompress_chunk_slice(c,l,A,t,r,n,o);var i=$e().getInt32(c+0,!0),s=$e().getInt32(c+4,!0),a=$e().getInt32(c+8,!0);if(a)throw HA(s);return Vo.__wrap(i)}finally{j.__wbindgen_add_to_stack_pointer(16)}}function C2(e,t){let r=Error(Wh(e,t));return I2(r)}function E2(e,t){throw new Error(Wh(e,t))}function I2(e){qi===Jr.length&&Jr.push(Jr.length+1);let t=qi;return qi=Jr[t],Jr[t]=e,t}function x2(e){e<1028||(Jr[e]=qi,qi=e)}function Vh(e,t){return e=e>>>0,y2().subarray(e/8,e/8+t)}function OA(e,t){return e=e>>>0,GA().subarray(e/1,e/1+t)}function $e(){return(Jo===null||Jo.buffer.detached===!0||Jo.buffer.detached===void 0&&Jo.buffer!==j.memory.buffer)&&(Jo=new DataView(j.memory.buffer)),Jo}function y2(){return(ka===null||ka.byteLength===0)&&(ka=new Float64Array(j.memory.buffer)),ka}function Wh(e,t){return B2(e>>>0,t)}function GA(){return(Da===null||Da.byteLength===0)&&(Da=new Uint8Array(j.memory.buffer)),Da}function b2(e){return Jr[e]}function UA(e,t){let r=t(e.length*1,1)>>>0;return GA().set(e,r/1),La=e.length,r}function HA(e){let t=b2(e);return x2(e),t}function B2(e,t){return PA+=t,PA>=w2&&(Na=new TextDecoder("utf-8",{ignoreBOM:!0,fatal:!0}),Na.decode(),PA=t),Na.decode(GA().subarray(e,e+t))}function S2(e){j=e}var Un,Yh,Vo,Yo,qh,Jh,Jo,ka,Da,Jr,qi,Na,w2,PA,La,j,zh=g(()=>{Un={};Un.d=(e,t)=>{for(var r in t)Un.o(t,r)&&!Un.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})};Un.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t);Un.r=e=>{typeof Symbol<"u"&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};Yh={};Un.r(Yh);Un.d(Yh,{ChunkSliceResult:()=>Vo,DecompressResult:()=>Yo,__wbg_Error_ef53bc310eb298a0:()=>C2,__wbg___wbindgen_throw_1506f2235d1bdba0:()=>E2,__wbg_set_wasm:()=>S2,decompress_all:()=>g2,decompress_block:()=>p2,decompress_chunk_slice:()=>h2});Vo=class e{static __wrap(t){let r=Object.create(e.prototype);return r.__wbg_ptr=t,qh.register(r,r.__wbg_ptr,r),r}__destroy_into_raw(){let t=this.__wbg_ptr;return this.__wbg_ptr=0,qh.unregister(this),t}free(){let t=this.__destroy_into_raw();j.__wbg_chunksliceresult_free(t,0)}take_buffer(){try{let o=j.__wbindgen_add_to_stack_pointer(-16);j.chunksliceresult_take_buffer(o,this.__wbg_ptr);var t=$e().getInt32(o+0,!0),r=$e().getInt32(o+4,!0),n=OA(t,r).slice();return j.__wbindgen_export(t,r*1,1),n}finally{j.__wbindgen_add_to_stack_pointer(16)}}take_cpositions(){try{let o=j.__wbindgen_add_to_stack_pointer(-16);j.chunksliceresult_take_cpositions(o,this.__wbg_ptr);var t=$e().getInt32(o+0,!0),r=$e().getInt32(o+4,!0),n=Vh(t,r).slice();return j.__wbindgen_export(t,r*8,8),n}finally{j.__wbindgen_add_to_stack_pointer(16)}}take_dpositions(){try{let o=j.__wbindgen_add_to_stack_pointer(-16);j.chunksliceresult_take_dpositions(o,this.__wbg_ptr);var t=$e().getInt32(o+0,!0),r=$e().getInt32(o+4,!0),n=Vh(t,r).slice();return j.__wbindgen_export(t,r*8,8),n}finally{j.__wbindgen_add_to_stack_pointer(16)}}};Symbol.dispose&&(Vo.prototype[Symbol.dispose]=Vo.prototype.free);Yo=class e{static __wrap(t){let r=Object.create(e.prototype);return r.__wbg_ptr=t,Jh.register(r,r.__wbg_ptr,r),r}__destroy_into_raw(){let t=this.__wbg_ptr;return this.__wbg_ptr=0,Jh.unregister(this),t}free(){let t=this.__destroy_into_raw();j.__wbg_decompressresult_free(t,0)}get bytes_read(){return j.decompressresult_bytes_read(this.__wbg_ptr)>>>0}take_data(){try{let o=j.__wbindgen_add_to_stack_pointer(-16);j.decompressresult_take_data(o,this.__wbg_ptr);var t=$e().getInt32(o+0,!0),r=$e().getInt32(o+4,!0),n=OA(t,r).slice();return j.__wbindgen_export(t,r*1,1),n}finally{j.__wbindgen_add_to_stack_pointer(16)}}};Symbol.dispose&&(Yo.prototype[Symbol.dispose]=Yo.prototype.free);qh=typeof FinalizationRegistry>"u"?{register:()=>{},unregister:()=>{}}:new FinalizationRegistry(e=>j.__wbg_chunksliceresult_free(e,1)),Jh=typeof FinalizationRegistry>"u"?{register:()=>{},unregister:()=>{}}:new FinalizationRegistry(e=>j.__wbg_decompressresult_free(e,1));Jo=null;ka=null;Da=null;Jr=new Array(1024).fill(void 0);Jr.push(void 0,null,!0,!1);qi=Jr.length;Na=new TextDecoder("utf-8",{ignoreBOM:!0,fatal:!0});Na.decode();w2=2146435072,PA=0;La=0});var jA=g(()=>{zh()});var $h=g(()=>{});var Xh=g(()=>{jh();jA();$h()});var Zh=g(()=>{Xh();jA()});var t0=U((S3,e0)=>{e0.exports=JBrowseExports["react-dom"]});var n0=U((Q3,r0)=>{r0.exports=JBrowseExports["react-dom/client"]});function o0(e){let t="",r=!1;for(let n=0,o=e.length;n<o;n++){let i=e[n];i==="<"?r=!0:i===">"?r=!1:r||(t+=i)}return t}var qA=g(()=>{});var i0=g(()=>{});var s0=g(()=>{});var a0=g(()=>{});function Fa(e){return typeof e=="object"&&e!==null&&"uri"in e&&!!e.uri}var Q2,JA=g(()=>{Q2=f(_t(),1);a0()});var M2,c0=g(()=>{M2=f(Gr(),1)});var l0=g(()=>{});var A0=g(()=>{});var Wo,Ra,VA,YA,v2,Ji,Pa,u0=g(()=>{Wo={METHOD:"method",PROPERTY:"property"},Ra=class{constructor(t,r){this.inst=t,this.args=r}},VA=class extends Ra{constructor(t,r){super(t,r),this.type=Wo.METHOD}execute(t){t[this.inst](...this.args)}},YA=class extends Ra{constructor(t,r){super(t,r),this.type=Wo.PROPERTY}execute(t){t[this.inst]=this.args[0]}},v2={[Wo.METHOD]:VA,[Wo.PROPERTY]:YA},Ji=class{constructor(t,r,n){return new v2[t](r,n)}};Ji.METHOD=Wo.METHOD;Ji.PROPERTY=Wo.PROPERTY;Pa=Ji});var f0,Br,Oa,WA=g(()=>{u0();f0=Object.freeze({METHODS:["addHitRegion","arc","arcTo","beginPath","bezierCurveTo","clearHitRegions","clearRect","clip","closePath","drawFocusIfNeeded","drawImage","ellipse","fill","fillRect","fillText","lineTo","moveTo","putImageData","quadraticCurveTo","rect","removeHitRegion","resetTransform","restore","rotate","save","scale","scrollPathIntoView","setLineDash","setTransform","stroke","strokeRect","strokeText","transform","translate"],PROPERTIES:["direction","fillStyle","filter","font","globalAlpha","globalCompositeOperation","imageSmoothingEnabled","imageSmoothingQuality","lineCap","lineDashOffset","lineJoin","lineWidth","miterLimit","shadowBlur","shadowColor","shadowOffsetX","shadowOffsetY","strokeStyle","textAlign","textBaseline"]}),Br=Object.freeze({sequence:Symbol.for("sequence"),push:Symbol.for("push"),fromJSON:Symbol.for("fromJSON")}),Oa=class{constructor(t=null){this[Br.sequence]=[],t&&this[Br.fromJSON](t)}[Br.fromJSON](t={sequence:[]}){t.sequence.forEach(({type:r,inst:n,args:o})=>{this[Br.push](r,n,o)})}[Br.push](t,r,n){this[Br.sequence].push(new Pa(t,r,n))}execute(t){t.save(),this[Br.sequence].forEach(r=>r.execute(t)),t.restore()}toJSON(){return{sequence:this[Br.sequence]}}};f0.METHODS.forEach(e=>{Object.defineProperty(Oa.prototype,e,{value:function(...r){this[Br.push](Pa.METHOD,e,r)},writable:!1,enumerable:!0,configurable:!1})});f0.PROPERTIES.forEach(e=>{Object.defineProperty(Oa.prototype,e,{get(){throw`Invalid canvas sequencer interaction, cannot get ${e}.`},set(t){this[Br.push](Pa.PROPERTY,e,[t])},enumerable:!0,configurable:!1})})});var G3,d0=g(()=>{WA();G3=Object.freeze({sequence:Symbol.for("sequence"),push:Symbol.for("push")})});var g0=g(()=>{d0();WA()});var h0=U((V3,p0)=>{p0.exports=!1});var T2,C0=g(()=>{g0();T2=f(h0(),1)});var _2,k2,E0=g(()=>{_2=f(R(),1),k2=f(w(),1)});var I0=g(()=>{});var K3,X3,Z3,e5,x0=g(()=>{K3=new Uint8Array([99,124,119,123,242,107,111,197,48,1,103,43,254,215,171,118,202,130,201,125,250,89,71,240,173,212,162,175,156,164,114,192,183,253,147,38,54,63,247,204,52,165,229,241,113,216,49,21,4,199,35,195,24,150,5,154,7,18,128,226,235,39,178,117,9,131,44,26,27,110,90,160,82,59,214,179,41,227,47,132,83,209,0,237,32,252,177,91,106,203,190,57,74,76,88,207,208,239,170,251,67,77,51,133,69,249,2,127,80,60,159,168,81,163,64,143,146,157,56,245,188,182,218,33,16,255,243,210,205,12,19,236,95,151,68,23,196,167,126,61,100,93,25,115,96,129,79,220,34,42,144,136,70,238,184,20,222,94,11,219,224,50,58,10,73,6,36,92,194,211,172,98,145,149,228,121,231,200,55,109,141,213,78,169,108,86,244,234,101,122,174,8,186,120,37,46,28,166,180,198,232,221,116,31,75,189,139,138,112,62,181,102,72,3,246,14,97,53,87,185,134,193,29,158,225,248,152,17,105,217,142,148,155,30,135,233,206,85,40,223,140,161,137,13,191,230,66,104,65,153,45,15,176,84,187,22]),X3=new Uint8Array([82,9,106,213,48,54,165,56,191,64,163,158,129,243,215,251,124,227,57,130,155,47,255,135,52,142,67,68,196,222,233,203,84,123,148,50,166,194,35,61,238,76,149,11,66,250,195,78,8,46,161,102,40,217,36,178,118,91,162,73,109,139,209,37,114,248,246,100,134,104,152,22,212,164,92,204,93,101,182,146,108,112,72,80,253,237,185,218,94,21,70,87,167,141,157,132,144,216,171,0,140,188,211,10,247,228,88,5,184,179,69,6,208,44,30,143,202,63,15,2,193,175,189,3,1,19,138,107,58,145,17,65,79,103,220,234,151,242,207,206,240,180,230,115,150,172,116,34,231,173,53,133,226,249,55,232,28,117,223,110,71,241,26,113,29,41,197,137,111,183,98,14,170,24,190,27,252,86,62,75,198,210,121,32,154,219,192,254,120,205,90,244,31,221,168,51,136,7,199,49,177,18,16,89,39,128,236,95,96,81,127,169,25,181,74,13,45,229,122,159,147,201,156,239,160,224,59,77,174,42,245,176,200,235,187,60,131,83,153,97,23,43,4,126,186,119,214,38,225,105,20,99,85,33,12,125]),Z3=new Uint8Array([1,2,4,8,16,32,64,128,27,54]),e5=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298])});function Vi(e,t){if(typeof t!="function"&&t!==null)throw new TypeError("Class extends value "+String(t)+" is not a constructor or null");zA(e,t);function r(){this.constructor=e}e.prototype=t===null?Object.create(t):(r.prototype=t.prototype,new r)}function $A(e){var t=typeof Symbol=="function"&&Symbol.iterator,r=t&&e[t],n=0;if(r)return r.call(e);if(e&&typeof e.length=="number")return{next:function(){return e&&n>=e.length&&(e=void 0),{value:e&&e[n++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}function zo(e,t){var r=typeof Symbol=="function"&&e[Symbol.iterator];if(!r)return e;var n=r.call(e),o,i=[],s;try{for(;(t===void 0||t-- >0)&&!(o=n.next()).done;)i.push(o.value)}catch(a){s={error:a}}finally{try{o&&!o.done&&(r=n.return)&&r.call(n)}finally{if(s)throw s.error}}return i}function $o(e,t,r){if(r||arguments.length===2)for(var n=0,o=t.length,i;n<o;n++)(i||!(n in t))&&(i||(i=Array.prototype.slice.call(t,0,n)),i[n]=t[n]);return e.concat(i||Array.prototype.slice.call(t))}var zA,Yi=g(()=>{zA=function(e,t){return zA=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(r,n){r.__proto__=n}||function(r,n){for(var o in n)Object.prototype.hasOwnProperty.call(n,o)&&(r[o]=n[o])},zA(e,t)}});function Sr(e){return typeof e=="function"}var Ga=g(()=>{});function Ua(e){var t=function(n){Error.call(n),n.stack=new Error().stack},r=e(t);return r.prototype=Object.create(Error.prototype),r.prototype.constructor=r,r}var KA=g(()=>{});var Ha,y0=g(()=>{KA();Ha=Ua(function(e){return function(r){e(this),this.message=r?r.length+` errors occurred during unsubscription:
25
+ `+r.map(function(n,o){return o+1+") "+n.toString()}).join(`
26
+ `):"",this.name="UnsubscriptionError",this.errors=r}})});function XA(e,t){if(e){var r=e.indexOf(t);0<=r&&e.splice(r,1)}}var b0=g(()=>{});function B0(e){return e instanceof ja||e&&"closed"in e&&Sr(e.remove)&&Sr(e.add)&&Sr(e.unsubscribe)}function w0(e){Sr(e)?e():e.unsubscribe()}var ja,f5,S0=g(()=>{Yi();Ga();y0();b0();ja=(function(){function e(t){this.initialTeardown=t,this.closed=!1,this._parentage=null,this._finalizers=null}return e.prototype.unsubscribe=function(){var t,r,n,o,i;if(!this.closed){this.closed=!0;var s=this._parentage;if(s)if(this._parentage=null,Array.isArray(s))try{for(var a=$A(s),c=a.next();!c.done;c=a.next()){var l=c.value;l.remove(this)}}catch(E){t={error:E}}finally{try{c&&!c.done&&(r=a.return)&&r.call(a)}finally{if(t)throw t.error}}else s.remove(this);var A=this.initialTeardown;if(Sr(A))try{A()}catch(E){i=E instanceof Ha?E.errors:[E]}var u=this._finalizers;if(u){this._finalizers=null;try{for(var m=$A(u),d=m.next();!d.done;d=m.next()){var p=d.value;try{w0(p)}catch(E){i=i??[],E instanceof Ha?i=$o($o([],zo(i)),zo(E.errors)):i.push(E)}}}catch(E){n={error:E}}finally{try{d&&!d.done&&(o=m.return)&&o.call(m)}finally{if(n)throw n.error}}}if(i)throw new Ha(i)}},e.prototype.add=function(t){var r;if(t&&t!==this)if(this.closed)w0(t);else{if(t instanceof e){if(t.closed||t._hasParent(this))return;t._addParent(this)}(this._finalizers=(r=this._finalizers)!==null&&r!==void 0?r:[]).push(t)}},e.prototype._hasParent=function(t){var r=this._parentage;return r===t||Array.isArray(r)&&r.includes(t)},e.prototype._addParent=function(t){var r=this._parentage;this._parentage=Array.isArray(r)?(r.push(t),r):r?[r,t]:t},e.prototype._removeParent=function(t){var r=this._parentage;r===t?this._parentage=null:Array.isArray(r)&&XA(r,t)},e.prototype.remove=function(t){var r=this._finalizers;r&&XA(r,t),t instanceof e&&t._removeParent(this)},e.EMPTY=(function(){var t=new e;return t.closed=!0,t})(),e})(),f5=ja.EMPTY});var cn,qa=g(()=>{cn={onUnhandledError:null,onStoppedNotification:null,Promise:void 0,useDeprecatedSynchronousErrorHandling:!1,useDeprecatedNextContext:!1}});var Ko,ZA=g(()=>{Yi();Ko={setTimeout:function(e,t){for(var r=[],n=2;n<arguments.length;n++)r[n-2]=arguments[n];var o=Ko.delegate;return o?.setTimeout?o.setTimeout.apply(o,$o([e,t],zo(r))):setTimeout.apply(void 0,$o([e,t],zo(r)))},clearTimeout:function(e){var t=Ko.delegate;return(t?.clearTimeout||clearTimeout)(e)},delegate:void 0}});function Q0(e){Ko.setTimeout(function(){var t=cn.onUnhandledError;if(t)t(e);else throw e})}var M0=g(()=>{qa();ZA()});function eu(){}var v0=g(()=>{});function _0(e){return tu("E",void 0,e)}function k0(e){return tu("N",e,void 0)}function tu(e,t,r){return{kind:e,value:t,error:r}}var T0,D0=g(()=>{T0=(function(){return tu("C",void 0,void 0)})()});function N0(e){cn.useDeprecatedSynchronousErrorHandling&&ru&&(ru.errorThrown=!0,ru.error=e)}var ru,L0=g(()=>{qa();ru=null});function nu(e,t){return D2.call(e,t)}function Ja(e){cn.useDeprecatedSynchronousErrorHandling?N0(e):Q0(e)}function L2(e){throw e}function ou(e,t){var r=cn.onStoppedNotification;r&&Ko.setTimeout(function(){return r(e,t)})}var iu,D2,N2,su,F2,au=g(()=>{Yi();Ga();S0();qa();M0();v0();D0();ZA();L0();iu=(function(e){Vi(t,e);function t(r){var n=e.call(this)||this;return n.isStopped=!1,r?(n.destination=r,B0(r)&&r.add(n)):n.destination=F2,n}return t.create=function(r,n,o){return new su(r,n,o)},t.prototype.next=function(r){this.isStopped?ou(k0(r),this):this._next(r)},t.prototype.error=function(r){this.isStopped?ou(_0(r),this):(this.isStopped=!0,this._error(r))},t.prototype.complete=function(){this.isStopped?ou(T0,this):(this.isStopped=!0,this._complete())},t.prototype.unsubscribe=function(){this.closed||(this.isStopped=!0,e.prototype.unsubscribe.call(this),this.destination=null)},t.prototype._next=function(r){this.destination.next(r)},t.prototype._error=function(r){try{this.destination.error(r)}finally{this.unsubscribe()}},t.prototype._complete=function(){try{this.destination.complete()}finally{this.unsubscribe()}},t})(ja),D2=Function.prototype.bind;N2=(function(){function e(t){this.partialObserver=t}return e.prototype.next=function(t){var r=this.partialObserver;if(r.next)try{r.next(t)}catch(n){Ja(n)}},e.prototype.error=function(t){var r=this.partialObserver;if(r.error)try{r.error(t)}catch(n){Ja(n)}else Ja(t)},e.prototype.complete=function(){var t=this.partialObserver;if(t.complete)try{t.complete()}catch(r){Ja(r)}},e})(),su=(function(e){Vi(t,e);function t(r,n,o){var i=e.call(this)||this,s;if(Sr(r)||!r)s={next:r??void 0,error:n??void 0,complete:o??void 0};else{var a;i&&cn.useDeprecatedNextContext?(a=Object.create(r),a.unsubscribe=function(){return i.unsubscribe()},s={next:r.next&&nu(r.next,a),error:r.error&&nu(r.error,a),complete:r.complete&&nu(r.complete,a)}):s=r}return i.destination=new N2(s),i}return t})(iu);F2={closed:!0,next:eu,error:L2,complete:eu}});function R2(e){return Sr(e?.lift)}function Va(e){return function(t){if(R2(t))return t.lift(function(r){try{return e(r,this)}catch(n){this.error(n)}});throw new TypeError("Unable to lift unknown Observable type")}}var cu=g(()=>{Ga()});function F0(e,t,r,n,o){return new P2(e,t,r,n,o)}var P2,R0=g(()=>{Yi();au();P2=(function(e){Vi(t,e);function t(r,n,o,i,s,a){var c=e.call(this,r)||this;return c.onFinalize=s,c.shouldUnsubscribe=a,c._next=n?function(l){try{n(l)}catch(A){r.error(A)}}:e.prototype._next,c._error=i?function(l){try{i(l)}catch(A){r.error(A)}finally{this.unsubscribe()}}:e.prototype._error,c._complete=o?function(){try{o()}catch(l){r.error(l)}finally{this.unsubscribe()}}:e.prototype._complete,c}return t.prototype.unsubscribe=function(){var r;if(!this.shouldUnsubscribe||this.shouldUnsubscribe()){var n=this.closed;e.prototype.unsubscribe.call(this),!n&&((r=this.onFinalize)===null||r===void 0||r.call(this))}},t})(iu)});var P0,O0=g(()=>{KA();P0=Ua(function(e){return function(){e(this),this.name="EmptyError",this.message="no elements in sequence"}})});function lu(e,t){var r=typeof t=="object";return new Promise(function(n,o){var i=new su({next:function(s){n(s),i.unsubscribe()},error:o,complete:function(){r?n(t.defaultValue):o(new P0)}});e.subscribe(i)})}var G0=g(()=>{O0();au()});var U0=g(()=>{});function H0(e,t,r,n,o){return function(i,s){var a=r,c=t,l=0;i.subscribe(F0(s,function(A){var u=l++;c=a?e(c,A,u):(a=!0,A),n&&s.next(c)},o&&(function(){a&&s.next(c),s.complete()})))}}var j0=g(()=>{R0()});function q0(e,t){return Va(H0(e,t,arguments.length>=2,!1,!0))}var J0=g(()=>{j0();cu()});function Au(){return Va(function(e,t){q0(O2,[])(e).subscribe(t)})}var O2,V0=g(()=>{J0();cu();O2=function(e,t){return e.push(t),e}});var Y0=g(()=>{G0();U0();V0()});var W0=g(()=>{});var z0=g(()=>{});function G2(){return $0||($0=[IDBDatabase,IDBObjectStore,IDBIndex,IDBCursor,IDBTransaction])}function U2(){return K0||(K0=[IDBCursor.prototype.advance,IDBCursor.prototype.continue,IDBCursor.prototype.continuePrimaryKey])}function H2(e){let t=new Promise((r,n)=>{let o=()=>{e.removeEventListener("success",i),e.removeEventListener("error",s)},i=()=>{r(Hn(e.result)),o()},s=()=>{n(e.error),o()};e.addEventListener("success",i),e.addEventListener("error",s)});return Ya.set(t,e),t}function j2(e){if(du.has(e))return;let t=new Promise((r,n)=>{let o=()=>{e.removeEventListener("complete",i),e.removeEventListener("error",s),e.removeEventListener("abort",s)},i=()=>{r(),o()},s=()=>{n(e.error||new DOMException("AbortError","AbortError")),o()};e.addEventListener("complete",i),e.addEventListener("error",s),e.addEventListener("abort",s)});du.set(e,t)}function tC(e){gu=e(gu)}function q2(e){return U2().includes(e)?function(...t){return e.apply(pu(this),t),Hn(this.request)}:function(...t){return Hn(e.apply(pu(this),t))}}function J2(e){return typeof e=="function"?q2(e):(e instanceof IDBTransaction&&j2(e),mu(e,G2())?new Proxy(e,gu):e)}function Hn(e){if(e instanceof IDBRequest)return H2(e);if(uu.has(e))return uu.get(e);let t=J2(e);return t!==e&&(uu.set(e,t),Ya.set(t,e)),t}function jn(e,t,{blocked:r,upgrade:n,blocking:o,terminated:i}={}){let s=indexedDB.open(e,t),a=Hn(s);return n&&s.addEventListener("upgradeneeded",c=>{n(Hn(s.result),c.oldVersion,c.newVersion,Hn(s.transaction),c)}),r&&s.addEventListener("blocked",c=>r(c.oldVersion,c.newVersion,c)),a.then(c=>{i&&c.addEventListener("close",()=>i()),o&&c.addEventListener("versionchange",l=>o(l.oldVersion,l.newVersion,l))}).catch(()=>{}),a}function X0(e,t){if(!(e instanceof IDBDatabase&&!(t in e)&&typeof t=="string"))return;if(fu.get(t))return fu.get(t);let r=t.replace(/FromIndex$/,""),n=t!==r,o=Y2.includes(r);if(!(r in(n?IDBIndex:IDBObjectStore).prototype)||!(o||V2.includes(r)))return;let i=async function(s,...a){let c=this.transaction(s,o?"readwrite":"readonly"),l=c.store;return n&&(l=l.index(a.shift())),(await Promise.all([l[r](...a),o&&c.done]))[0]};return fu.set(t,i),i}async function*$2(...e){let t=this;if(t instanceof IDBCursor||(t=await t.openCursor(...e)),!t)return;t=t;let r=new Proxy(t,z2);for(rC.set(r,t),Ya.set(r,pu(t));t;)yield r,t=await(hu.get(r)||t.continue()),hu.delete(r)}function eC(e,t){return t===Symbol.asyncIterator&&mu(e,[IDBIndex,IDBObjectStore,IDBCursor])||t==="iterate"&&mu(e,[IDBIndex,IDBObjectStore])}var mu,$0,K0,du,uu,Ya,gu,pu,V2,Y2,fu,W2,Z0,hu,rC,z2,Wi=g(()=>{mu=(e,t)=>t.some(r=>e instanceof r);du=new WeakMap,uu=new WeakMap,Ya=new WeakMap;gu={get(e,t,r){if(e instanceof IDBTransaction){if(t==="done")return du.get(e);if(t==="store")return r.objectStoreNames[1]?void 0:r.objectStore(r.objectStoreNames[0])}return Hn(e[t])},set(e,t,r){return e[t]=r,!0},has(e,t){return e instanceof IDBTransaction&&(t==="done"||t==="store")?!0:t in e}};pu=e=>Ya.get(e);V2=["get","getKey","getAll","getAllKeys","count"],Y2=["put","add","delete","clear"],fu=new Map;tC(e=>({...e,get:(t,r,n)=>X0(t,r)||e.get(t,r,n),has:(t,r)=>!!X0(t,r)||e.has(t,r)}));W2=["continue","continuePrimaryKey","advance"],Z0={},hu=new WeakMap,rC=new WeakMap,z2={get(e,t){if(!W2.includes(t))return e[t];let r=Z0[t];return r||(r=Z0[t]=function(...n){hu.set(this,rC.get(this)[t](...n))}),r}};tC(e=>({...e,get(t,r,n){return eC(t,r)?$2:e.get(t,r,n)},has(t,r){return eC(t,r)||e.has(t,r)}}))});var nC=g(()=>{Wi()});var Wa,oC=g(()=>{Wa=f(_t(),1)});function Eu(e,t=10){let r=String(e),n=0;for(let o=0,i=r.length;o<i;o++)n+=Z2[r.charCodeAt(o)]??ev;return n*t}function Iu(e){let t=0;if(e.length===0)return t;for(let r=0;r<e.length;r++){let n=e.charCodeAt(r);t=(t<<5)-t+n,t|=0}return t}function tv(e){let{uri:t,baseUri:r=""}=e,n;try{n=new URL(t,r).href}catch{n=t}return n}function xu(e){return Yt(e)?Fa(e)?tv(e):JSON.stringify(e):String(e)}function iC(e){let t=/(^|[\s\n]|<[A-Za-z]*\/?>)((?:https?|ftp):\/\/[-A-Z0-9+\u0026\u2019@#/%?=()~_|!:,.;]*[-A-Z0-9+\u0026@#/%=~()_|])/gi;return e.replaceAll(t,`$1<a href='$2' target="_blank">$2</a>`)}function sC(e,t){let{padding:r=30,minWidth:n=80,fontSize:o=12,maxWidth:i=1e3,stripHTML:s=!1}=t||{};return yu(e.map(a=>xu(a)).map(a=>s?o0(a):a).map(a=>Eu(a,o)).map(a=>Math.min(Math.max(a+r,n),i)))}function yu(e,t=Number.NEGATIVE_INFINITY){let r=t;for(let n of e)r=Math.max(n,r);return r}function Yt(e){return typeof e=="object"&&e!==null}var Cu,Xo,K2,X2,gP,pP,hP,CP,Z2,ev,ln=g(()=>{Cu=f(w(),1);Zh();Xo=f(_t(),1),K2=f(t0(),1),X2=f(n0(),1);qA();JA();JA();c0();l0();A0();qA();C0();E0();I0();x0();W0();z0();i0();s0();oC();nC();gP=180/Math.PI,pP=Math.PI/180,hP=/electron/i.test(typeof navigator<"u"?navigator.userAgent:""),CP=typeof jest>"u"?typeof window<"u"&&window.requestIdleCallback?window.requestIdleCallback:e=>setTimeout(()=>{e()},1):e=>{e()},Z2=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,.2796875,.2765625,.3546875,.5546875,.5546875,.8890625,.665625,.190625,.3328125,.3328125,.3890625,.5828125,.2765625,.3328125,.2765625,.3015625,.5546875,.5546875,.5546875,.5546875,.5546875,.5546875,.5546875,.5546875,.5546875,.5546875,.2765625,.2765625,.584375,.5828125,.584375,.5546875,1.0140625,.665625,.665625,.721875,.721875,.665625,.609375,.7765625,.721875,.2765625,.5,.665625,.5546875,.8328125,.721875,.7765625,.665625,.7765625,.721875,.665625,.609375,.721875,.665625,.94375,.665625,.665625,.609375,.2765625,.3546875,.2765625,.4765625,.5546875,.3328125,.5546875,.5546875,.5,.5546875,.5546875,.2765625,.5546875,.5546875,.221875,.240625,.5,.221875,.8328125,.5546875,.5546875,.5546875,.5546875,.3328125,.5,.2765625,.5546875,.5,.721875,.5,.5,.5,.3546875,.259375,.353125,.5890625],ev=.5279276315789471});function aC(e,t){(t==null||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r<t;r++)n[r]=e[r];return n}function rv(e){if(Array.isArray(e))return e}function nv(e,t){var r=e==null?null:typeof Symbol<"u"&&e[Symbol.iterator]||e["@@iterator"];if(r!=null){var n,o,i,s,a=[],c=!0,l=!1;try{if(i=(r=r.call(e)).next,t!==0)for(;!(c=(n=i.call(r)).done)&&(a.push(n.value),a.length!==t);c=!0);}catch(A){l=!0,o=A}finally{try{if(!c&&r.return!=null&&(s=r.return(),Object(s)!==s))return}finally{if(l)throw o}}return a}}function ov(){throw new TypeError(`Invalid attempt to destructure non-iterable instance.
27
+ In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function iv(e,t){return rv(e)||nv(e,t)||sv(e,t)||ov()}function sv(e,t){if(e){if(typeof e=="string")return aC(e,t);var r={}.toString.call(e).slice(8,-1);return r==="Object"&&e.constructor&&(r=e.constructor.name),r==="Map"||r==="Set"?Array.from(e):r==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?aC(e,t):void 0}}function Ge(e){return function(t){t instanceof RegExp&&(t.lastIndex=0);for(var r=arguments.length,n=new Array(r>1?r-1:0),o=1;o<r;o++)n[o-1]=arguments[o];return Mu(e,t,n)}}function gv(e){return function(){for(var t=arguments.length,r=new Array(t),n=0;n<t;n++)r[n]=arguments[n];return vu(e,r)}}function H(e,t){let r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:Ki;if(cC&&cC(e,null),!It(t))return e;let n=t.length;for(;n--;){let o=t[n];if(typeof o=="string"){let i=r(o);i!==o&&(av(t)||(t[n]=i),o=i)}e[o]=!0}return e}function pv(e){for(let t=0;t<e.length;t++)_e(e,t)||(e[t]=null);return e}function At(e){let t=ri(null);for(let n of IC(e)){var r=iv(n,2);let o=r[0],i=r[1];_e(e,o)&&(It(i)?t[o]=pv(i):i&&typeof i=="object"&&i.constructor===Object?t[o]=At(i):t[o]=i)}return t}function hv(e){switch(typeof e){case"string":return e;case"number":return mv(e);case"boolean":return dv(e);case"bigint":return fC?fC(e):"0";case"symbol":return mC?mC(e):"Symbol()";case"undefined":return zi(e);case"function":case"object":{if(e===null)return zi(e);let t=e,r=Mr(t,"toString");if(typeof r=="function"){let n=r(t);return typeof n=="string"?n:zi(n)}return zi(e)}default:return zi(e)}}function Mr(e,t){for(;e!==null;){let n=lv(e,t);if(n){if(n.get)return Ge(n.get);if(typeof n.value=="function")return Ge(n.value)}e=cv(e)}function r(){return null}return r}function Cv(e){try{return it(e,""),!0}catch{return!1}}function yC(){let e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:Tv(),t=F=>yC(F);if(t.version="3.4.7",t.removed=[],!e||!e.document||e.document.nodeType!==Qr.document||!e.Element)return t.isSupported=!1,t;let r=e.document,n=r,o=n.currentScript;e.DocumentFragment;let i=e.HTMLTemplateElement,s=e.Node,a=e.Element,c=e.NodeFilter,l=e.NamedNodeMap;l===void 0&&(e.NamedNodeMap||e.MozNamedAttrMap),e.HTMLFormElement;let A=e.DOMParser,u=e.trustedTypes,m=a.prototype,d=Mr(m,"cloneNode"),p=Mr(m,"remove"),E=Mr(m,"nextSibling"),x=Mr(m,"childNodes"),I=Mr(m,"parentNode"),h=Mr(m,"shadowRoot"),y=Mr(m,"attributes"),Q=s&&s.prototype?Mr(s.prototype,"nodeType"):null,M=s&&s.prototype?Mr(s.prototype,"nodeName"):null;if(typeof i=="function"){let F=r.createElement("template");F.content&&F.content.ownerDocument&&(r=F.content.ownerDocument)}let B,v="",P=r,N=P.implementation,$=P.createNodeIterator,S=P.createDocumentFragment,L=P.getElementsByTagName,J=n.importNode,O=EC();t.isSupported=typeof IC=="function"&&typeof I=="function"&&N&&N.createHTMLDocument!==void 0;let Te=xv,Tt=yv,Ut=bv,Qn=wv,Rs=Bv,en=Sv,Ps=Qv,tn=vv,xr=CC,ue=null,Mn=H({},[...dC,...wu,...Bu,...Su,...gC]),de=null,tr=H({},[...pC,...Qu,...hC,...za]),se=Object.seal(ri(null,{tagNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},attributeNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},allowCustomizedBuiltInElements:{writable:!0,configurable:!1,enumerable:!0,value:!1}})),vn=null,Tn=null,rr=Object.seal(ri(null,{tagCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},attributeCheck:{writable:!0,configurable:!1,enumerable:!0,value:null}})),Os=!0,Mi=!0,rn=!1,vi=!0,Pr=!1,K=!0,oe=!1,ge=!1,pe=!1,tt=!1,rt=!1,be=!1,Qt=!0,nn=!1,on="user-content-",mo=!0,sn=!1,Ue={},Re=null,_n=H({},["annotation-xml","audio","colgroup","desc","foreignobject","head","iframe","math","mi","mn","mo","ms","mtext","noembed","noframes","noscript","plaintext","script","style","svg","template","thead","title","video","xmp"]),Gs=null,go=H({},["audio","video","img","source","image","track"]),Nl=null,md=H({},["alt","class","for","id","label","name","pattern","placeholder","role","summary","title","value","style","xmlns"]),Us="http://www.w3.org/1998/Math/MathML",Hs="http://www.w3.org/2000/svg",yr="http://www.w3.org/1999/xhtml",po=yr,Ll=!1,Fl=null,xQ=H({},[Us,Hs,yr],bu),Rl=H({},["mi","mo","mn","ms","mtext"]),Pl=H({},["annotation-xml"]),yQ=H({},["title","style","font","a","script"]),Ti=null,bQ=["application/xhtml+xml","text/html"],wQ="text/html",De=null,ho=null,BQ=r.createElement("form"),dd=function(C){return C instanceof RegExp||C instanceof Function},Ol=function(){let C=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};if(ho&&ho===C)return;(!C||typeof C!="object")&&(C={}),C=At(C),Ti=bQ.indexOf(C.PARSER_MEDIA_TYPE)===-1?wQ:C.PARSER_MEDIA_TYPE,De=Ti==="application/xhtml+xml"?bu:Ki,ue=_e(C,"ALLOWED_TAGS")&&It(C.ALLOWED_TAGS)?H({},C.ALLOWED_TAGS,De):Mn,de=_e(C,"ALLOWED_ATTR")&&It(C.ALLOWED_ATTR)?H({},C.ALLOWED_ATTR,De):tr,Fl=_e(C,"ALLOWED_NAMESPACES")&&It(C.ALLOWED_NAMESPACES)?H({},C.ALLOWED_NAMESPACES,bu):xQ,Nl=_e(C,"ADD_URI_SAFE_ATTR")&&It(C.ADD_URI_SAFE_ATTR)?H(At(md),C.ADD_URI_SAFE_ATTR,De):md,Gs=_e(C,"ADD_DATA_URI_TAGS")&&It(C.ADD_DATA_URI_TAGS)?H(At(go),C.ADD_DATA_URI_TAGS,De):go,Re=_e(C,"FORBID_CONTENTS")&&It(C.FORBID_CONTENTS)?H({},C.FORBID_CONTENTS,De):_n,vn=_e(C,"FORBID_TAGS")&&It(C.FORBID_TAGS)?H({},C.FORBID_TAGS,De):At({}),Tn=_e(C,"FORBID_ATTR")&&It(C.FORBID_ATTR)?H({},C.FORBID_ATTR,De):At({}),Ue=_e(C,"USE_PROFILES")?C.USE_PROFILES&&typeof C.USE_PROFILES=="object"?At(C.USE_PROFILES):C.USE_PROFILES:!1,Os=C.ALLOW_ARIA_ATTR!==!1,Mi=C.ALLOW_DATA_ATTR!==!1,rn=C.ALLOW_UNKNOWN_PROTOCOLS||!1,vi=C.ALLOW_SELF_CLOSE_IN_ATTR!==!1,Pr=C.SAFE_FOR_TEMPLATES||!1,K=C.SAFE_FOR_XML!==!1,oe=C.WHOLE_DOCUMENT||!1,tt=C.RETURN_DOM||!1,rt=C.RETURN_DOM_FRAGMENT||!1,be=C.RETURN_TRUSTED_TYPE||!1,pe=C.FORCE_BODY||!1,Qt=C.SANITIZE_DOM!==!1,nn=C.SANITIZE_NAMED_PROPS||!1,mo=C.KEEP_CONTENT!==!1,sn=C.IN_PLACE||!1,xr=Cv(C.ALLOWED_URI_REGEXP)?C.ALLOWED_URI_REGEXP:CC,po=typeof C.NAMESPACE=="string"?C.NAMESPACE:yr,Rl=_e(C,"MATHML_TEXT_INTEGRATION_POINTS")&&C.MATHML_TEXT_INTEGRATION_POINTS&&typeof C.MATHML_TEXT_INTEGRATION_POINTS=="object"?At(C.MATHML_TEXT_INTEGRATION_POINTS):H({},["mi","mo","mn","ms","mtext"]),Pl=_e(C,"HTML_INTEGRATION_POINTS")&&C.HTML_INTEGRATION_POINTS&&typeof C.HTML_INTEGRATION_POINTS=="object"?At(C.HTML_INTEGRATION_POINTS):H({},["annotation-xml"]);let b=_e(C,"CUSTOM_ELEMENT_HANDLING")&&C.CUSTOM_ELEMENT_HANDLING&&typeof C.CUSTOM_ELEMENT_HANDLING=="object"?At(C.CUSTOM_ELEMENT_HANDLING):ri(null);if(se=ri(null),_e(b,"tagNameCheck")&&dd(b.tagNameCheck)&&(se.tagNameCheck=b.tagNameCheck),_e(b,"attributeNameCheck")&&dd(b.attributeNameCheck)&&(se.attributeNameCheck=b.attributeNameCheck),_e(b,"allowCustomizedBuiltInElements")&&typeof b.allowCustomizedBuiltInElements=="boolean"&&(se.allowCustomizedBuiltInElements=b.allowCustomizedBuiltInElements),Pr&&(Mi=!1),rt&&(tt=!0),Ue&&(ue=H({},gC),de=ri(null),Ue.html===!0&&(H(ue,dC),H(de,pC)),Ue.svg===!0&&(H(ue,wu),H(de,Qu),H(de,za)),Ue.svgFilters===!0&&(H(ue,Bu),H(de,Qu),H(de,za)),Ue.mathMl===!0&&(H(ue,Su),H(de,hC),H(de,za))),rr.tagCheck=null,rr.attributeCheck=null,_e(C,"ADD_TAGS")&&(typeof C.ADD_TAGS=="function"?rr.tagCheck=C.ADD_TAGS:It(C.ADD_TAGS)&&(ue===Mn&&(ue=At(ue)),H(ue,C.ADD_TAGS,De))),_e(C,"ADD_ATTR")&&(typeof C.ADD_ATTR=="function"?rr.attributeCheck=C.ADD_ATTR:It(C.ADD_ATTR)&&(de===tr&&(de=At(de)),H(de,C.ADD_ATTR,De))),_e(C,"ADD_URI_SAFE_ATTR")&&It(C.ADD_URI_SAFE_ATTR)&&H(Nl,C.ADD_URI_SAFE_ATTR,De),_e(C,"FORBID_CONTENTS")&&It(C.FORBID_CONTENTS)&&(Re===_n&&(Re=At(Re)),H(Re,C.FORBID_CONTENTS,De)),_e(C,"ADD_FORBID_CONTENTS")&&It(C.ADD_FORBID_CONTENTS)&&(Re===_n&&(Re=At(Re)),H(Re,C.ADD_FORBID_CONTENTS,De)),mo&&(ue["#text"]=!0),oe&&H(ue,["html","head","body"]),ue.table&&(H(ue,["tbody"]),delete vn.tbody),C.TRUSTED_TYPES_POLICY){if(typeof C.TRUSTED_TYPES_POLICY.createHTML!="function")throw $i('TRUSTED_TYPES_POLICY configuration option must provide a "createHTML" hook.');if(typeof C.TRUSTED_TYPES_POLICY.createScriptURL!="function")throw $i('TRUSTED_TYPES_POLICY configuration option must provide a "createScriptURL" hook.');B=C.TRUSTED_TYPES_POLICY,v=B.createHTML("")}else B===void 0&&(B=_v(u,o)),B!==null&&typeof v=="string"&&(v=B.createHTML(""));(O.uponSanitizeElement.length>0||O.uponSanitizeAttribute.length>0)&&ue===Mn&&(ue=At(ue)),O.uponSanitizeAttribute.length>0&&de===tr&&(de=At(de)),xt&&xt(C),ho=C},gd=H({},[...wu,...Bu,...Ev]),pd=H({},[...Su,...Iv]),SQ=function(C){let b=I(C);(!b||!b.tagName)&&(b={namespaceURI:po,tagName:"template"});let T=Ki(C.tagName),ee=Ki(b.tagName);return Fl[C.namespaceURI]?C.namespaceURI===Hs?b.namespaceURI===yr?T==="svg":b.namespaceURI===Us?T==="svg"&&(ee==="annotation-xml"||Rl[ee]):!!gd[T]:C.namespaceURI===Us?b.namespaceURI===yr?T==="math":b.namespaceURI===Hs?T==="math"&&Pl[ee]:!!pd[T]:C.namespaceURI===yr?b.namespaceURI===Hs&&!Pl[ee]||b.namespaceURI===Us&&!Rl[ee]?!1:!pd[T]&&(yQ[T]||!gd[T]):!!(Ti==="application/xhtml+xml"&&Fl[C.namespaceURI]):!1},nr=function(C){ei(t.removed,{element:C});try{I(C).removeChild(C)}catch{p(C)}},kn=function(C,b){try{ei(t.removed,{attribute:b.getAttributeNode(C),from:b})}catch{ei(t.removed,{attribute:null,from:b})}if(b.removeAttribute(C),C==="is")if(tt||rt)try{nr(b)}catch{}else try{b.setAttribute(C,"")}catch{}},hd=function(C){let b=null,T=null;if(pe)C="<remove></remove>"+C;else{let he=AC(C,/^[\r\n\t ]+/);T=he&&he[0]}Ti==="application/xhtml+xml"&&po===yr&&(C='<html xmlns="http://www.w3.org/1999/xhtml"><head></head><body>'+C+"</body></html>");let ee=B?B.createHTML(C):C;if(po===yr)try{b=new A().parseFromString(ee,Ti)}catch{}if(!b||!b.documentElement){b=N.createDocument(po,"template",null);try{b.documentElement.innerHTML=Ll?v:ee}catch{}}let V=b.body||b.documentElement;return C&&T&&V.insertBefore(r.createTextNode(T),V.childNodes[0]||null),po===yr?L.call(b,oe?"html":"body")[0]:oe?b.documentElement:V},Cd=function(C){return $.call(C.ownerDocument||C,C,c.SHOW_ELEMENT|c.SHOW_COMMENT|c.SHOW_TEXT|c.SHOW_PROCESSING_INSTRUCTION|c.SHOW_CDATA_SECTION,null)},Ed=function(C){C.normalize();let b=$.call(C.ownerDocument||C,C,c.SHOW_TEXT|c.SHOW_COMMENT|c.SHOW_CDATA_SECTION|c.SHOW_PROCESSING_INSTRUCTION,null),T=b.nextNode();for(;T;){let ee=T.data;Zo([Te,Tt,Ut],V=>{ee=ti(ee,V," ")}),T.data=ee,T=b.nextNode()}},js=function(C){let b=M?M(C):null;return typeof b!="string"||De(b)!=="form"?!1:typeof C.nodeName!="string"||typeof C.textContent!="string"||typeof C.removeChild!="function"||C.attributes!==y(C)||typeof C.removeAttribute!="function"||typeof C.setAttribute!="function"||typeof C.namespaceURI!="string"||typeof C.insertBefore!="function"||typeof C.hasChildNodes!="function"||C.nodeType!==Q(C)||C.childNodes!==x(C)},_i=function(C){if(!Q||typeof C!="object"||C===null)return!1;try{return Q(C)===Qr.documentFragment}catch{return!1}},qs=function(C){if(!Q||typeof C!="object"||C===null)return!1;try{return typeof Q(C)=="number"}catch{return!1}};function Or(F,C,b){Zo(F,T=>{T.call(t,C,b,ho)})}let Id=function(C){let b=null;if(Or(O.beforeSanitizeElements,C,null),js(C))return nr(C),!0;let T=De(C.nodeName);if(Or(O.uponSanitizeElement,C,{tagName:T,allowedTags:ue}),K&&C.hasChildNodes()&&!qs(C.firstElementChild)&&it(/<[/\w!]/g,C.innerHTML)&&it(/<[/\w!]/g,C.textContent)||K&&C.namespaceURI===yr&&T==="style"&&qs(C.firstElementChild)||C.nodeType===Qr.progressingInstruction||K&&C.nodeType===Qr.comment&&it(/<[/\w]/g,C.data))return nr(C),!0;if(vn[T]||!(rr.tagCheck instanceof Function&&rr.tagCheck(T))&&!ue[T]){if(!vn[T]&&yd(T)&&(se.tagNameCheck instanceof RegExp&&it(se.tagNameCheck,T)||se.tagNameCheck instanceof Function&&se.tagNameCheck(T)))return!1;if(mo&&!Re[T]){let V=I(C),he=x(C);if(he&&V){let Ht=he.length;for(let br=Ht-1;br>=0;--br){let or=d(he[br],!0);V.insertBefore(or,E(C))}}}return nr(C),!0}return(Q?Q(C):C.nodeType)===Qr.element&&!SQ(C)||(T==="noscript"||T==="noembed"||T==="noframes")&&it(/<\/no(script|embed|frames)/i,C.innerHTML)?(nr(C),!0):(Pr&&C.nodeType===Qr.text&&(b=C.textContent,Zo([Te,Tt,Ut],V=>{b=ti(b,V," ")}),C.textContent!==b&&(ei(t.removed,{element:C.cloneNode()}),C.textContent=b)),Or(O.afterSanitizeElements,C,null),!1)},xd=function(C,b,T){if(Tn[b]||Qt&&(b==="id"||b==="name")&&(T in r||T in BQ))return!1;let ee=de[b]||rr.attributeCheck instanceof Function&&rr.attributeCheck(b,C);if(!(Mi&&!Tn[b]&&it(Qn,b))){if(!(Os&&it(Rs,b))){if(!ee||Tn[b]){if(!(yd(C)&&(se.tagNameCheck instanceof RegExp&&it(se.tagNameCheck,C)||se.tagNameCheck instanceof Function&&se.tagNameCheck(C))&&(se.attributeNameCheck instanceof RegExp&&it(se.attributeNameCheck,b)||se.attributeNameCheck instanceof Function&&se.attributeNameCheck(b,C))||b==="is"&&se.allowCustomizedBuiltInElements&&(se.tagNameCheck instanceof RegExp&&it(se.tagNameCheck,T)||se.tagNameCheck instanceof Function&&se.tagNameCheck(T))))return!1}else if(!Nl[b]){if(!it(xr,ti(T,Ps,""))){if(!((b==="src"||b==="xlink:href"||b==="href")&&C!=="script"&&uC(T,"data:")===0&&Gs[C])){if(!(rn&&!it(en,ti(T,Ps,"")))){if(T)return!1}}}}}}return!0},QQ=H({},["annotation-xml","color-profile","font-face","font-face-format","font-face-name","font-face-src","font-face-uri","missing-glyph"]),yd=function(C){return!QQ[Ki(C)]&&it(tn,C)},bd=function(C){Or(O.beforeSanitizeAttributes,C,null);let b=C.attributes;if(!b||js(C))return;let T={attrName:"",attrValue:"",keepAttr:!0,allowedAttributes:de,forceKeepAttr:void 0},ee=b.length;for(;ee--;){let V=b[ee],he=V.name,Ht=V.namespaceURI,br=V.value,or=De(he),Gl=br,Ve=he==="value"?Gl:fv(Gl);if(T.attrName=or,T.attrValue=Ve,T.keepAttr=!0,T.forceKeepAttr=void 0,Or(O.uponSanitizeAttribute,C,T),Ve=T.attrValue,nn&&(or==="id"||or==="name")&&uC(Ve,on)!==0&&(kn(he,C),Ve=on+Ve),K&&it(/((--!?|])>)|<\/(style|script|title|xmp|textarea|noscript|iframe|noembed|noframes)/i,Ve)){kn(he,C);continue}if(or==="attributename"&&AC(Ve,"href")){kn(he,C);continue}if(T.forceKeepAttr)continue;if(!T.keepAttr){kn(he,C);continue}if(!vi&&it(/\/>/i,Ve)){kn(he,C);continue}Pr&&Zo([Te,Tt,Ut],Bd=>{Ve=ti(Ve,Bd," ")});let wd=De(C.nodeName);if(!xd(wd,or,Ve)){kn(he,C);continue}if(B&&typeof u=="object"&&typeof u.getAttributeType=="function"&&!Ht)switch(u.getAttributeType(wd,or)){case"TrustedHTML":{Ve=B.createHTML(Ve);break}case"TrustedScriptURL":{Ve=B.createScriptURL(Ve);break}}if(Ve!==Gl)try{Ht?C.setAttributeNS(Ht,he,Ve):C.setAttribute(he,Ve),js(C)?nr(C):lC(t.removed)}catch{kn(he,C)}}Or(O.afterSanitizeAttributes,C,null)},Js=function(C){let b=null,T=Cd(C);for(Or(O.beforeSanitizeShadowDOM,C,null);b=T.nextNode();)if(Or(O.uponSanitizeShadowNode,b,null),Id(b),bd(b),_i(b.content)&&Js(b.content),(Q?Q(b):b.nodeType)===Qr.element){let V=h?h(b):b.shadowRoot;_i(V)&&(Co(V),Js(V))}Or(O.afterSanitizeShadowDOM,C,null)},Co=function(C){let b=Q?Q(C):C.nodeType;if(b===Qr.element){let V=h?h(C):C.shadowRoot;_i(V)&&(Co(V),Js(V))}let T=x?x(C):C.childNodes;if(!T)return;let ee=[];Zo(T,V=>{ei(ee,V)});for(let V of ee)Co(V);if(b===Qr.element){let V=M?M(C):null;if(typeof V=="string"&&De(V)==="template"){let he=C.content;_i(he)&&Co(he)}}};return t.sanitize=function(F){let C=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},b=null,T=null,ee=null,V=null;if(Ll=!F,Ll&&(F="<!-->"),typeof F!="string"&&!qs(F)&&(F=hv(F),typeof F!="string"))throw $i("dirty is not a string, aborting");if(!t.isSupported)return F;if(ge||Ol(C),t.removed=[],typeof F=="string"&&(sn=!1),sn){let br=M?M(F):F.nodeName;if(typeof br=="string"){let or=De(br);if(!ue[or]||vn[or])throw $i("root node is forbidden and cannot be sanitized in-place")}if(js(F))throw $i("root node is clobbered and cannot be sanitized in-place");Co(F)}else if(qs(F))b=hd("<!---->"),T=b.ownerDocument.importNode(F,!0),T.nodeType===Qr.element&&T.nodeName==="BODY"||T.nodeName==="HTML"?b=T:b.appendChild(T),Co(T);else{if(!tt&&!Pr&&!oe&&F.indexOf("<")===-1)return B&&be?B.createHTML(F):F;if(b=hd(F),!b)return tt?null:be?v:""}b&&pe&&nr(b.firstChild);let he=Cd(sn?F:b);for(;ee=he.nextNode();)Id(ee),bd(ee),_i(ee.content)&&Js(ee.content);if(sn)return Pr&&Ed(F),F;if(tt){if(Pr&&Ed(b),rt)for(V=S.call(b.ownerDocument);b.firstChild;)V.appendChild(b.firstChild);else V=b;return(de.shadowroot||de.shadowrootmode)&&(V=J.call(n,V,!0)),V}let Ht=oe?b.outerHTML:b.innerHTML;return oe&&ue["!doctype"]&&b.ownerDocument&&b.ownerDocument.doctype&&b.ownerDocument.doctype.name&&it(Mv,b.ownerDocument.doctype.name)&&(Ht="<!DOCTYPE "+b.ownerDocument.doctype.name+`>
28
+ `+Ht),Pr&&Zo([Te,Tt,Ut],br=>{Ht=ti(Ht,br," ")}),B&&be?B.createHTML(Ht):Ht},t.setConfig=function(){let F=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};Ol(F),ge=!0},t.clearConfig=function(){ho=null,ge=!1},t.isValidAttribute=function(F,C,b){ho||Ol({});let T=De(F),ee=De(C);return xd(T,ee,b)},t.addHook=function(F,C){typeof C=="function"&&ei(O[F],C)},t.removeHook=function(F,C){if(C!==void 0){let b=Av(O[F],C);return b===-1?void 0:uv(O[F],b,1)[0]}return lC(O[F])},t.removeHooks=function(F){O[F]=[]},t.removeAllHooks=function(){O=EC()},t}var IC,cC,av,cv,lv,xt,Wt,ri,xC,Mu,vu,Zo,Av,lC,ei,uv,It,Ki,bu,AC,ti,uC,fv,mv,dv,fC,mC,_e,zi,it,$i,dC,wu,Bu,Ev,Su,Iv,gC,pC,Qu,hC,za,xv,yv,bv,wv,Bv,CC,Sv,Qv,Mv,vv,Qr,Tv,_v,EC,bC,wC=g(()=>{IC=Object.entries,cC=Object.setPrototypeOf,av=Object.isFrozen,cv=Object.getPrototypeOf,lv=Object.getOwnPropertyDescriptor,xt=Object.freeze,Wt=Object.seal,ri=Object.create,xC=typeof Reflect<"u"&&Reflect,Mu=xC.apply,vu=xC.construct;xt||(xt=function(t){return t});Wt||(Wt=function(t){return t});Mu||(Mu=function(t,r){for(var n=arguments.length,o=new Array(n>2?n-2:0),i=2;i<n;i++)o[i-2]=arguments[i];return t.apply(r,o)});vu||(vu=function(t){for(var r=arguments.length,n=new Array(r>1?r-1:0),o=1;o<r;o++)n[o-1]=arguments[o];return new t(...n)});Zo=Ge(Array.prototype.forEach),Av=Ge(Array.prototype.lastIndexOf),lC=Ge(Array.prototype.pop),ei=Ge(Array.prototype.push),uv=Ge(Array.prototype.splice),It=Array.isArray,Ki=Ge(String.prototype.toLowerCase),bu=Ge(String.prototype.toString),AC=Ge(String.prototype.match),ti=Ge(String.prototype.replace),uC=Ge(String.prototype.indexOf),fv=Ge(String.prototype.trim),mv=Ge(Number.prototype.toString),dv=Ge(Boolean.prototype.toString),fC=typeof BigInt>"u"?null:Ge(BigInt.prototype.toString),mC=typeof Symbol>"u"?null:Ge(Symbol.prototype.toString),_e=Ge(Object.prototype.hasOwnProperty),zi=Ge(Object.prototype.toString),it=Ge(RegExp.prototype.test),$i=gv(TypeError);dC=xt(["a","abbr","acronym","address","area","article","aside","audio","b","bdi","bdo","big","blink","blockquote","body","br","button","canvas","caption","center","cite","code","col","colgroup","content","data","datalist","dd","decorator","del","details","dfn","dialog","dir","div","dl","dt","element","em","fieldset","figcaption","figure","font","footer","form","h1","h2","h3","h4","h5","h6","head","header","hgroup","hr","html","i","img","input","ins","kbd","label","legend","li","main","map","mark","marquee","menu","menuitem","meter","nav","nobr","ol","optgroup","option","output","p","picture","pre","progress","q","rp","rt","ruby","s","samp","search","section","select","shadow","slot","small","source","spacer","span","strike","strong","style","sub","summary","sup","table","tbody","td","template","textarea","tfoot","th","thead","time","tr","track","tt","u","ul","var","video","wbr"]),wu=xt(["svg","a","altglyph","altglyphdef","altglyphitem","animatecolor","animatemotion","animatetransform","circle","clippath","defs","desc","ellipse","enterkeyhint","exportparts","filter","font","g","glyph","glyphref","hkern","image","inputmode","line","lineargradient","marker","mask","metadata","mpath","part","path","pattern","polygon","polyline","radialgradient","rect","stop","style","switch","symbol","text","textpath","title","tref","tspan","view","vkern"]),Bu=xt(["feBlend","feColorMatrix","feComponentTransfer","feComposite","feConvolveMatrix","feDiffuseLighting","feDisplacementMap","feDistantLight","feDropShadow","feFlood","feFuncA","feFuncB","feFuncG","feFuncR","feGaussianBlur","feImage","feMerge","feMergeNode","feMorphology","feOffset","fePointLight","feSpecularLighting","feSpotLight","feTile","feTurbulence"]),Ev=xt(["animate","color-profile","cursor","discard","font-face","font-face-format","font-face-name","font-face-src","font-face-uri","foreignobject","hatch","hatchpath","mesh","meshgradient","meshpatch","meshrow","missing-glyph","script","set","solidcolor","unknown","use"]),Su=xt(["math","menclose","merror","mfenced","mfrac","mglyph","mi","mlabeledtr","mmultiscripts","mn","mo","mover","mpadded","mphantom","mroot","mrow","ms","mspace","msqrt","mstyle","msub","msup","msubsup","mtable","mtd","mtext","mtr","munder","munderover","mprescripts"]),Iv=xt(["maction","maligngroup","malignmark","mlongdiv","mscarries","mscarry","msgroup","mstack","msline","msrow","semantics","annotation","annotation-xml","mprescripts","none"]),gC=xt(["#text"]),pC=xt(["accept","action","align","alt","autocapitalize","autocomplete","autopictureinpicture","autoplay","background","bgcolor","border","capture","cellpadding","cellspacing","checked","cite","class","clear","color","cols","colspan","command","commandfor","controls","controlslist","coords","crossorigin","datetime","decoding","default","dir","disabled","disablepictureinpicture","disableremoteplayback","download","draggable","enctype","enterkeyhint","exportparts","face","for","headers","height","hidden","high","href","hreflang","id","inert","inputmode","integrity","ismap","kind","label","lang","list","loading","loop","low","max","maxlength","media","method","min","minlength","multiple","muted","name","nonce","noshade","novalidate","nowrap","open","optimum","part","pattern","placeholder","playsinline","popover","popovertarget","popovertargetaction","poster","preload","pubdate","radiogroup","readonly","rel","required","rev","reversed","role","rows","rowspan","spellcheck","scope","selected","shape","size","sizes","slot","span","srclang","start","src","srcset","step","style","summary","tabindex","title","translate","type","usemap","valign","value","width","wrap","xmlns"]),Qu=xt(["accent-height","accumulate","additive","alignment-baseline","amplitude","ascent","attributename","attributetype","azimuth","basefrequency","baseline-shift","begin","bias","by","class","clip","clippathunits","clip-path","clip-rule","color","color-interpolation","color-interpolation-filters","color-profile","color-rendering","cx","cy","d","dx","dy","diffuseconstant","direction","display","divisor","dur","edgemode","elevation","end","exponent","fill","fill-opacity","fill-rule","filter","filterunits","flood-color","flood-opacity","font-family","font-size","font-size-adjust","font-stretch","font-style","font-variant","font-weight","fx","fy","g1","g2","glyph-name","glyphref","gradientunits","gradienttransform","height","href","id","image-rendering","in","in2","intercept","k","k1","k2","k3","k4","kerning","keypoints","keysplines","keytimes","lang","lengthadjust","letter-spacing","kernelmatrix","kernelunitlength","lighting-color","local","marker-end","marker-mid","marker-start","markerheight","markerunits","markerwidth","maskcontentunits","maskunits","max","mask","mask-type","media","method","mode","min","name","numoctaves","offset","operator","opacity","order","orient","orientation","origin","overflow","paint-order","path","pathlength","patterncontentunits","patterntransform","patternunits","points","preservealpha","preserveaspectratio","primitiveunits","r","rx","ry","radius","refx","refy","repeatcount","repeatdur","restart","result","rotate","scale","seed","shape-rendering","slope","specularconstant","specularexponent","spreadmethod","startoffset","stddeviation","stitchtiles","stop-color","stop-opacity","stroke-dasharray","stroke-dashoffset","stroke-linecap","stroke-linejoin","stroke-miterlimit","stroke-opacity","stroke","stroke-width","style","surfacescale","systemlanguage","tabindex","tablevalues","targetx","targety","transform","transform-origin","text-anchor","text-decoration","text-rendering","textlength","type","u1","u2","unicode","values","viewbox","visibility","version","vert-adv-y","vert-origin-x","vert-origin-y","width","word-spacing","wrap","writing-mode","xchannelselector","ychannelselector","x","x1","x2","xmlns","y","y1","y2","z","zoomandpan"]),hC=xt(["accent","accentunder","align","bevelled","close","columnalign","columnlines","columnspacing","columnspan","denomalign","depth","dir","display","displaystyle","encoding","fence","frame","height","href","id","largeop","length","linethickness","lquote","lspace","mathbackground","mathcolor","mathsize","mathvariant","maxsize","minsize","movablelimits","notation","numalign","open","rowalign","rowlines","rowspacing","rowspan","rspace","rquote","scriptlevel","scriptminsize","scriptsizemultiplier","selection","separator","separators","stretchy","subscriptshift","supscriptshift","symmetric","voffset","width","xmlns"]),za=xt(["xlink:href","xml:id","xlink:title","xml:space","xmlns:xlink"]),xv=Wt(/{{[\w\W]*|^[\w\W]*}}/g),yv=Wt(/<%[\w\W]*|^[\w\W]*%>/g),bv=Wt(/\${[\w\W]*/g),wv=Wt(/^data-[\-\w.\u00B7-\uFFFF]+$/),Bv=Wt(/^aria-[\-\w]+$/),CC=Wt(/^(?:(?:(?:f|ht)tps?|mailto|tel|callto|sms|cid|xmpp|matrix):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i),Sv=Wt(/^(?:\w+script|data):/i),Qv=Wt(/[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205F\u3000]/g),Mv=Wt(/^html$/i),vv=Wt(/^[a-z][.\w]*(-[.\w]+)+$/i),Qr={element:1,attribute:2,text:3,cdataSection:4,entityReference:5,entityNode:6,progressingInstruction:7,comment:8,document:9,documentType:10,documentFragment:11,notation:12},Tv=function(){return typeof window>"u"?null:window},_v=function(t,r){if(typeof t!="object"||typeof t.createPolicy!="function")return null;let n=null,o="data-tt-policy-suffix";r&&r.hasAttribute(o)&&(n=r.getAttribute(o));let i="dompurify"+(n?"#"+n:"");try{return t.createPolicy(i,{createHTML(s){return s},createScriptURL(s){return s}})}catch{return console.warn("TrustedTypes policy "+i+" could not be created."),null}},EC=function(){return{afterSanitizeAttributes:[],afterSanitizeElements:[],afterSanitizeShadowDOM:[],beforeSanitizeAttributes:[],beforeSanitizeElements:[],beforeSanitizeShadowDOM:[],uponSanitizeAttribute:[],uponSanitizeElement:[],uponSanitizeShadowNode:[]}};bC=yC()});var QC={};Ye(QC,{default:()=>SC});function SC({value:e,className:t}){let r=(0,$a.useRef)(null);return(0,$a.useLayoutEffect)(()=>{let n=r.current;if(n)for(let o of n.querySelectorAll("a"))o.setAttribute("rel","noopener noreferrer"),o.setAttribute("target","_blank")},[e]),(0,BC.jsx)("span",{ref:r,className:t,dangerouslySetInnerHTML:{__html:bC.sanitize(e)}})}var BC,$a,MC=g(()=>{BC=f(R(),1),$a=f(w(),1);wC()});function Lv(e){return Nv.test(e)}function Fv(e){return e.includes("<")||e.includes("://")}function Rv({value:e,className:t}){let r=(0,An.useRef)(null);return(0,An.useLayoutEffect)(()=>{let n=r.current;if(n)try{n.setHTML(e);for(let o of n.querySelectorAll("a"))o.setAttribute("rel","noopener noreferrer"),o.setAttribute("target","_blank")}catch(o){console.error(o)}},[e]),(0,qn.jsx)("span",{ref:r,className:t})}function un({html:e,className:t}){let r=`${e}`;if(!Fv(r))return(0,qn.jsx)("span",{className:t,children:r});let n=iC(r),o=Lv(n)?n:(0,vC.default)(n);return typeof Element<"u"&&Element.prototype.setHTML?(0,qn.jsx)(Rv,{value:o,className:t}):(0,qn.jsx)(An.Suspense,{fallback:(0,qn.jsx)("span",{className:t}),children:(0,qn.jsx)(Dv,{value:o,className:t})})}var qn,An,vC,kv,Dv,Nv,Tu=g(()=>{qn=f(R(),1),An=f(w(),1),vC=f(Uh(),1);ln();kv=["a","b","br","code","div","em","h1","h2","h3","h4","h5","h6","i","img","li","mark","p","pre","span","small","strong","table","tbody","sup","sub","td","tfoot","th","thead","tr","u","ul"],Dv=(0,An.lazy)(()=>Promise.resolve().then(()=>(MC(),QC))),Nv=new RegExp(kv.map(e=>String.raw`<${e}\b[^>]*>`).join("|"),"i")});function Pv({error:e}){let{classes:t}=kC();return(0,Lt.jsx)("div",{className:t.errorBox,children:(0,Lt.jsx)(Ph,{error:e})})}var Lt,TC,ut,_C,kC,Ov,DC,NC=g(()=>{Lt=f(R(),1),TC=f(w(),1);Wl();ut=f(k(),1),_C=f(G(),1);Hl();Oh();Tu();Et();kC=te()(e=>({closeButton:{position:"absolute",right:e.spacing(1),top:e.spacing(1),color:e.palette.grey[500]},errorBox:{width:800,margin:40}}));Ov=(0,_C.observer)(function(t){let{classes:r}=kC(),{titleNode:n,...o}=t,{title:i,header:s,children:a,onClose:c}=o,l=(0,ut.useTheme)();return(0,Lt.jsx)(ut.Dialog,{...o,children:(0,Lt.jsxs)(ut.ScopedCssBaseline,{children:[(0,TC.isValidElement)(s)?s:(0,Lt.jsxs)(ut.DialogTitle,{children:[n||(0,Lt.jsx)(un,{html:i||""}),c?(0,Lt.jsx)(ut.IconButton,{className:r.closeButton,onClick:A=>{c(A,"backdropClick")},children:(0,Lt.jsx)(Ks,{})}):null]}),(0,Lt.jsx)(ut.Divider,{}),(0,Lt.jsx)(Io,{FallbackComponent:Pv,children:(0,Lt.jsx)(ut.ThemeProvider,{theme:(0,ut.createTheme)(l,{components:{MuiInputBase:{styleOverrides:{input:{boxSizing:"content-box!important"}}}}}),children:a})})]})})}),DC=Ov});function _u({onClose:e,helpText:t,label:r}){return(0,Jn.jsx)(DC,{open:!0,onClose:e,title:"Help",titleNode:r?(0,Jn.jsxs)(Jn.Fragment,{children:["Help: ",r]}):void 0,onClick:n=>{n.stopPropagation()},onMouseDown:n=>{n.stopPropagation()},children:(0,Jn.jsx)(LC.DialogContent,{children:t})})}var Jn,LC,FC=g(()=>{Jn=f(R(),1),LC=f(k(),1);NC()});function ku({helpText:e,label:t}){let[r,n]=(0,Ka.useState)(!1);return(0,Vr.jsxs)(Vr.Fragment,{children:[(0,Vr.jsx)(RC.IconButton,{size:"small",onClick:o=>{o.stopPropagation(),n(!0)},style:{marginLeft:4,padding:4},children:(0,Vr.jsx)(xg,{fontSize:"small"})}),r?(0,Vr.jsxs)(Ka.Suspense,{fallback:null,children:[(0,Vr.jsx)(_u,{helpText:e,label:t,onClose:o=>{o.stopPropagation(),n(!1)}})," "]}):null]})}var Vr,Ka,RC,PC=g(()=>{Vr=f(R(),1),Ka=f(w(),1);yg();RC=f(k(),1);FC()});var OC,GC,UC,Gv,HC,jC=g(()=>{OC=f(R(),1),GC=f(w(),1),UC=f(k(),1),Gv=GC.forwardRef(function(t,r){return(0,OC.jsx)(UC.Menu,{...t,ref:r,style:{pointerEvents:"none",...t.style},slotProps:{...t.slotProps,paper:{style:{pointerEvents:"auto"}}}})}),HC=Gv});var qC,JC,VC=g(()=>{"use client";W();qC=f(R(),1),JC=(0,_.createSvgIcon)((0,qC.jsx)("path",{d:"m10 17 5-5-5-5z"}),"ArrowRight")});var YC,WC,zC=g(()=>{"use client";W();YC=f(R(),1),WC=(0,_.createSvgIcon)((0,YC.jsx)("path",{d:"M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2m-9 14-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8z"}),"CheckBox")});var $C,KC,XC=g(()=>{"use client";W();$C=f(R(),1),KC=(0,_.createSvgIcon)((0,$C.jsx)("path",{d:"M19 5v14H5V5zm0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2"}),"CheckBoxOutlineBlank")});var ZC,eE,tE=g(()=>{"use client";W();ZC=f(R(),1),eE=(0,_.createSvgIcon)((0,ZC.jsx)("path",{d:"M12 7c-2.76 0-5 2.24-5 5s2.24 5 5 5 5-2.24 5-5-2.24-5-5-5m0-5C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8"}),"RadioButtonChecked")});var rE,nE,oE=g(()=>{"use client";W();rE=f(R(),1),nE=(0,_.createSvgIcon)((0,rE.jsx)("path",{d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8"}),"RadioButtonUnchecked")});function iE(e){let{classes:t}=Uv(),{type:r}=e,n,o;"checked"in e&&({checked:n,disabled:o}=e);let i;switch(r){case"subMenu":{i=(0,fn.jsx)(JC,{color:"action"});break}case"checkbox":{n?i=(0,fn.jsx)(WC,{color:o?"inherit":void 0}):i=(0,fn.jsx)(KC,{color:"action"});break}case"radio":{n?i=(0,fn.jsx)(eE,{color:o?"inherit":void 0}):i=(0,fn.jsx)(nE,{color:"action"});break}}return(0,fn.jsx)("div",{className:t.menuItemEndDecoration,children:i})}var fn,Xa,Uv,sE=g(()=>{fn=f(R(),1);VC();zC();XC();tE();oE();Xa=f(k(),1);Et();Uv=te()({menuItemEndDecoration:{padding:0,margin:0,height:16}})});function aE(e){if(typeof e=="string")return e.toLowerCase().replace(/\s+/g,"_")}function Hv({title:e,Icon:t,inset:r,menuItems:n,onMenuItemClick:o,closeAfterItemClick:i,onCloseRoot:s,isOpen:a,onOpen:c,onClose:l}){let[A,u]=(0,Du.useState)(null),m=aE(e);return(0,ae.jsxs)(ae.Fragment,{children:[(0,ae.jsxs)(yt.MenuItem,{ref:u,"data-testid":m?`cascading-submenu-${m}`:void 0,onMouseOver:c,onFocus:c,onClick:c,children:[t?(0,ae.jsx)(yt.ListItemIcon,{children:(0,ae.jsx)(t,{})}):null,(0,ae.jsx)(yt.ListItemText,{primary:e,inset:r}),(0,ae.jsx)(Cg,{})]}),(0,ae.jsx)(HC,{open:a,anchorEl:A,onClose:l,anchorOrigin:{vertical:"top",horizontal:"right"},transformOrigin:{vertical:"top",horizontal:"left"},children:(0,ae.jsx)(cE,{closeAfterItemClick:i,onMenuItemClick:o,menuItems:n,onCloseRoot:s})})]})}function cE({onMenuItemClick:e,closeAfterItemClick:t,menuItems:r,onCloseRoot:n}){let[o,i]=(0,Du.useState)(),s=()=>{i(void 0)},a=r.some(A=>"icon"in A&&A.icon),c=r.some(A=>(A.type==="checkbox"||A.type==="radio")&&"helpText"in A&&A.helpText),l=r.toSorted((A,u)=>(u.priority||0)-(A.priority||0));return(0,ae.jsx)(ae.Fragment,{children:l.map((A,u)=>{if("subMenu"in A)return(0,ae.jsx)(Hv,{title:A.label,Icon:A.icon,inset:a&&!A.icon,onMenuItemClick:e,menuItems:A.subMenu,closeAfterItemClick:t,onCloseRoot:n,isOpen:o===u,onOpen:()=>{i(u)},onClose:s},`subMenu-${A.label}-${u}`);if(A.type==="divider")return(0,ae.jsx)(yt.Divider,{component:"li"},`divider-${u}`);if(A.type==="subHeader")return(0,ae.jsx)(yt.ListSubheader,{children:A.label},`subHeader-${A.label}-${u}`);let m=A,d=m.helpText,p=m.type==="checkbox"||m.type==="radio",E=aE(m.label);return(0,ae.jsxs)(yt.MenuItem,{"data-testid":E?`cascading-menuitem-${E}`:void 0,disabled:!!m.disabled,onClick:x=>{t&&n(),e(x,m.onClick)},onMouseOver:s,children:[m.icon?(0,ae.jsx)(yt.ListItemIcon,{children:(0,ae.jsx)(m.icon,{})}):null,(0,ae.jsx)(yt.ListItemText,{primary:m.label,secondary:m.subLabel,inset:a&&!m.icon}),(0,ae.jsx)("div",{style:{flexGrow:1,minWidth:10}}),p?(0,ae.jsx)(iE,{type:m.type,checked:m.checked,disabled:m.disabled}):null,d?(0,ae.jsx)(ku,{helpText:d,label:m.label}):p&&c?(0,ae.jsx)("div",{style:{marginLeft:4,padding:4,width:28,height:28}}):null]},`${m.label}-${u}`)})})}function Nu({onMenuItemClick:e,closeAfterItemClick:t=!0,menuItems:r,open:n,onClose:o,anchorEl:i,anchorOrigin:s,transformOrigin:a,anchorReference:c,anchorPosition:l,slotProps:A,marginThreshold:u,style:m}){let d=Array.isArray(r)?r:r();return(0,ae.jsx)(yt.Menu,{anchorEl:i,open:n,onClose:o,anchorOrigin:s,transformOrigin:a,anchorReference:c,anchorPosition:l,slotProps:A,marginThreshold:u??void 0,style:m,children:(0,ae.jsx)(cE,{menuItems:d,closeAfterItemClick:t,onMenuItemClick:e,onCloseRoot:o})})}var ae,Du,yt,lE=g(()=>{ae=f(R(),1),Du=f(w(),1);Eg();yt=f(k(),1);PC();jC();sE()});function jv({children:e,menuItems:t,closeAfterItemClick:r=!0,stopPropagation:n,disabled:o,setOpen:i,ButtonComponent:s=AE.IconButton,onClick:a,anchorOrigin:c,transformOrigin:l,marginThreshold:A,...u}){let[m,d]=(0,Za.useState)(null),p=!!m;(0,Za.useEffect)(()=>{i?.(p)},[p,i]);let E=o??(Array.isArray(t)&&t.length===0);return(0,Vn.jsxs)(Vn.Fragment,{children:[(0,Vn.jsx)(s,{onClick:x=>{n&&x.stopPropagation(),d(x.currentTarget),a?.(x)},...u,disabled:E,children:e}),p?(0,Vn.jsx)(Nu,{open:p,onClose:()=>{d(null)},anchorEl:m,anchorOrigin:c,transformOrigin:l,marginThreshold:A,menuItems:t,closeAfterItemClick:r,onMenuItemClick:(x,I)=>{I()}}):null]})}var Vn,Za,AE,vr,ni=g(()=>{Vn=f(R(),1),Za=f(w(),1),AE=f(k(),1);lE();vr=jv});var uE,fE,mE=g(()=>{"use client";W();uE=f(R(),1),fE=(0,_.createSvgIcon)((0,uE.jsx)("path",{d:"M12 2C6.49 2 2 6.49 2 12s4.49 10 10 10c1.38 0 2.5-1.12 2.5-2.5 0-.61-.23-1.2-.64-1.67-.08-.1-.13-.21-.13-.33 0-.28.22-.5.5-.5H16c3.31 0 6-2.69 6-6 0-4.96-4.49-9-10-9m5.5 11c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5m-3-4c-.83 0-1.5-.67-1.5-1.5S13.67 6 14.5 6s1.5.67 1.5 1.5S15.33 9 14.5 9M5 11.5c0-.83.67-1.5 1.5-1.5s1.5.67 1.5 1.5S7.33 13 6.5 13 5 12.33 5 11.5m6-4c0 .83-.67 1.5-1.5 1.5S8 8.33 8 7.5 8.67 6 9.5 6s1.5.67 1.5 1.5"}),"Palette")});var qv,oi,dE=g(()=>{qv={50:"#ffebee",100:"#ffcdd2",200:"#ef9a9a",300:"#e57373",400:"#ef5350",500:"#f44336",600:"#e53935",700:"#d32f2f",800:"#c62828",900:"#b71c1c",A100:"#ff8a80",A200:"#ff5252",A400:"#ff1744",A700:"#d50000"},oi=qv});var Jv,Xi,gE=g(()=>{Jv={50:"#e3f2fd",100:"#bbdefb",200:"#90caf9",300:"#64b5f6",400:"#42a5f5",500:"#2196f3",600:"#1e88e5",700:"#1976d2",800:"#1565c0",900:"#0d47a1",A100:"#82b1ff",A200:"#448aff",A400:"#2979ff",A700:"#2962ff"},Xi=Jv});var Vv,Zi,pE=g(()=>{Vv={50:"#e8f5e9",100:"#c8e6c9",200:"#a5d6a7",300:"#81c784",400:"#66bb6a",500:"#4caf50",600:"#43a047",700:"#388e3c",800:"#2e7d32",900:"#1b5e20",A100:"#b9f6ca",A200:"#69f0ae",A400:"#00e676",A700:"#00c853"},Zi=Vv});var Yv,es,hE=g(()=>{Yv={50:"#fff3e0",100:"#ffe0b2",200:"#ffcc80",300:"#ffb74d",400:"#ffa726",500:"#ff9800",600:"#fb8c00",700:"#f57c00",800:"#ef6c00",900:"#e65100",A100:"#ffd180",A200:"#ffab40",A400:"#ff9100",A700:"#ff6d00"},es=Yv});var Wv,mn,CE=g(()=>{Wv={50:"#fafafa",100:"#f5f5f5",200:"#eeeeee",300:"#e0e0e0",400:"#bdbdbd",500:"#9e9e9e",600:"#757575",700:"#616161",800:"#424242",900:"#212121",A100:"#f5f5f5",A200:"#eeeeee",A400:"#bdbdbd",A700:"#616161"},mn=Wv});var Lu=g(()=>{dE();gE();pE();hE();CE()});var zv,Yr,Ke,zt,SE,EE,Fu,$v,ec,QE,ME,IE,xE,yE,ts,Kv,Xv,Zv,eT,Ou,bE,tT,Ru,Pu,wE,Gu,bt,BE,tc,rc=g(()=>{zv={grad:.9,turn:360,rad:360/(2*Math.PI)},Yr=function(e){return typeof e=="string"?e.length>0:typeof e=="number"},Ke=function(e,t,r){return t===void 0&&(t=0),r===void 0&&(r=Math.pow(10,t)),Math.round(r*e)/r+0},zt=function(e,t,r){return t===void 0&&(t=0),r===void 0&&(r=1),e>r?r:e>t?e:t},SE=function(e){return(e=isFinite(e)?e%360:0)>0?e:e+360},EE=function(e){return{r:zt(e.r,0,255),g:zt(e.g,0,255),b:zt(e.b,0,255),a:zt(e.a)}},Fu=function(e){return{r:Ke(e.r),g:Ke(e.g),b:Ke(e.b),a:Ke(e.a,3)}},$v=/^#([0-9a-f]{3,8})$/i,ec=function(e){var t=e.toString(16);return t.length<2?"0"+t:t},QE=function(e){var t=e.r,r=e.g,n=e.b,o=e.a,i=Math.max(t,r,n),s=i-Math.min(t,r,n),a=s?i===t?(r-n)/s:i===r?2+(n-t)/s:4+(t-r)/s:0;return{h:60*(a<0?a+6:a),s:i?s/i*100:0,v:i/255*100,a:o}},ME=function(e){var t=e.h,r=e.s,n=e.v,o=e.a;t=t/360*6,r/=100,n/=100;var i=Math.floor(t),s=n*(1-r),a=n*(1-(t-i)*r),c=n*(1-(1-t+i)*r),l=i%6;return{r:255*[n,a,s,s,c,n][l],g:255*[c,n,n,a,s,s][l],b:255*[s,s,c,n,n,a][l],a:o}},IE=function(e){return{h:SE(e.h),s:zt(e.s,0,100),l:zt(e.l,0,100),a:zt(e.a)}},xE=function(e){return{h:Ke(e.h),s:Ke(e.s),l:Ke(e.l),a:Ke(e.a,3)}},yE=function(e){return ME((r=(t=e).s,{h:t.h,s:(r*=((n=t.l)<50?n:100-n)/100)>0?2*r/(n+r)*100:0,v:n+r,a:t.a}));var t,r,n},ts=function(e){return{h:(t=QE(e)).h,s:(o=(200-(r=t.s))*(n=t.v)/100)>0&&o<200?r*n/100/(o<=100?o:200-o)*100:0,l:o/2,a:t.a};var t,r,n,o},Kv=/^hsla?\(\s*([+-]?\d*\.?\d+)(deg|rad|grad|turn)?\s*,\s*([+-]?\d*\.?\d+)%\s*,\s*([+-]?\d*\.?\d+)%\s*(?:,\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i,Xv=/^hsla?\(\s*([+-]?\d*\.?\d+)(deg|rad|grad|turn)?\s+([+-]?\d*\.?\d+)%\s+([+-]?\d*\.?\d+)%\s*(?:\/\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i,Zv=/^rgba?\(\s*([+-]?\d*\.?\d+)(%)?\s*,\s*([+-]?\d*\.?\d+)(%)?\s*,\s*([+-]?\d*\.?\d+)(%)?\s*(?:,\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i,eT=/^rgba?\(\s*([+-]?\d*\.?\d+)(%)?\s+([+-]?\d*\.?\d+)(%)?\s+([+-]?\d*\.?\d+)(%)?\s*(?:\/\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i,Ou={string:[[function(e){var t=$v.exec(e);return t?(e=t[1]).length<=4?{r:parseInt(e[0]+e[0],16),g:parseInt(e[1]+e[1],16),b:parseInt(e[2]+e[2],16),a:e.length===4?Ke(parseInt(e[3]+e[3],16)/255,2):1}:e.length===6||e.length===8?{r:parseInt(e.substr(0,2),16),g:parseInt(e.substr(2,2),16),b:parseInt(e.substr(4,2),16),a:e.length===8?Ke(parseInt(e.substr(6,2),16)/255,2):1}:null:null},"hex"],[function(e){var t=Zv.exec(e)||eT.exec(e);return t?t[2]!==t[4]||t[4]!==t[6]?null:EE({r:Number(t[1])/(t[2]?100/255:1),g:Number(t[3])/(t[4]?100/255:1),b:Number(t[5])/(t[6]?100/255:1),a:t[7]===void 0?1:Number(t[7])/(t[8]?100:1)}):null},"rgb"],[function(e){var t=Kv.exec(e)||Xv.exec(e);if(!t)return null;var r,n,o=IE({h:(r=t[1],n=t[2],n===void 0&&(n="deg"),Number(r)*(zv[n]||1)),s:Number(t[3]),l:Number(t[4]),a:t[5]===void 0?1:Number(t[5])/(t[6]?100:1)});return yE(o)},"hsl"]],object:[[function(e){var t=e.r,r=e.g,n=e.b,o=e.a,i=o===void 0?1:o;return Yr(t)&&Yr(r)&&Yr(n)?EE({r:Number(t),g:Number(r),b:Number(n),a:Number(i)}):null},"rgb"],[function(e){var t=e.h,r=e.s,n=e.l,o=e.a,i=o===void 0?1:o;if(!Yr(t)||!Yr(r)||!Yr(n))return null;var s=IE({h:Number(t),s:Number(r),l:Number(n),a:Number(i)});return yE(s)},"hsl"],[function(e){var t=e.h,r=e.s,n=e.v,o=e.a,i=o===void 0?1:o;if(!Yr(t)||!Yr(r)||!Yr(n))return null;var s=(function(a){return{h:SE(a.h),s:zt(a.s,0,100),v:zt(a.v,0,100),a:zt(a.a)}})({h:Number(t),s:Number(r),v:Number(n),a:Number(i)});return ME(s)},"hsv"]]},bE=function(e,t){for(var r=0;r<t.length;r++){var n=t[r][0](e);if(n)return[n,t[r][1]]}return[null,void 0]},tT=function(e){return typeof e=="string"?bE(e.trim(),Ou.string):typeof e=="object"&&e!==null?bE(e,Ou.object):[null,void 0]},Ru=function(e,t){var r=ts(e);return{h:r.h,s:zt(r.s+100*t,0,100),l:r.l,a:r.a}},Pu=function(e){return(299*e.r+587*e.g+114*e.b)/1e3/255},wE=function(e,t){var r=ts(e);return{h:r.h,s:r.s,l:zt(r.l+100*t,0,100),a:r.a}},Gu=(function(){function e(t){this.parsed=tT(t)[0],this.rgba=this.parsed||{r:0,g:0,b:0,a:1}}return e.prototype.isValid=function(){return this.parsed!==null},e.prototype.brightness=function(){return Ke(Pu(this.rgba),2)},e.prototype.isDark=function(){return Pu(this.rgba)<.5},e.prototype.isLight=function(){return Pu(this.rgba)>=.5},e.prototype.toHex=function(){return t=Fu(this.rgba),r=t.r,n=t.g,o=t.b,s=(i=t.a)<1?ec(Ke(255*i)):"","#"+ec(r)+ec(n)+ec(o)+s;var t,r,n,o,i,s},e.prototype.toRgb=function(){return Fu(this.rgba)},e.prototype.toRgbString=function(){return t=Fu(this.rgba),r=t.r,n=t.g,o=t.b,(i=t.a)<1?"rgba("+r+", "+n+", "+o+", "+i+")":"rgb("+r+", "+n+", "+o+")";var t,r,n,o,i},e.prototype.toHsl=function(){return xE(ts(this.rgba))},e.prototype.toHslString=function(){return t=xE(ts(this.rgba)),r=t.h,n=t.s,o=t.l,(i=t.a)<1?"hsla("+r+", "+n+"%, "+o+"%, "+i+")":"hsl("+r+", "+n+"%, "+o+"%)";var t,r,n,o,i},e.prototype.toHsv=function(){return t=QE(this.rgba),{h:Ke(t.h),s:Ke(t.s),v:Ke(t.v),a:Ke(t.a,3)};var t},e.prototype.invert=function(){return bt({r:255-(t=this.rgba).r,g:255-t.g,b:255-t.b,a:t.a});var t},e.prototype.saturate=function(t){return t===void 0&&(t=.1),bt(Ru(this.rgba,t))},e.prototype.desaturate=function(t){return t===void 0&&(t=.1),bt(Ru(this.rgba,-t))},e.prototype.grayscale=function(){return bt(Ru(this.rgba,-1))},e.prototype.lighten=function(t){return t===void 0&&(t=.1),bt(wE(this.rgba,t))},e.prototype.darken=function(t){return t===void 0&&(t=.1),bt(wE(this.rgba,-t))},e.prototype.rotate=function(t){return t===void 0&&(t=15),this.hue(this.hue()+t)},e.prototype.alpha=function(t){return typeof t=="number"?bt({r:(r=this.rgba).r,g:r.g,b:r.b,a:t}):Ke(this.rgba.a,3);var r},e.prototype.hue=function(t){var r=ts(this.rgba);return typeof t=="number"?bt({h:t,s:r.s,l:r.l,a:r.a}):Ke(r.h)},e.prototype.isEqual=function(t){return this.toHex()===bt(t).toHex()},e})(),bt=function(e){return e instanceof Gu?e:new Gu(e)},BE=[],tc=function(e){e.forEach(function(t){BE.indexOf(t)<0&&(t(Gu,Ou),BE.push(t))})}});function nc(e,t){var r={white:"#ffffff",bisque:"#ffe4c4",blue:"#0000ff",cadetblue:"#5f9ea0",chartreuse:"#7fff00",chocolate:"#d2691e",coral:"#ff7f50",antiquewhite:"#faebd7",aqua:"#00ffff",azure:"#f0ffff",whitesmoke:"#f5f5f5",papayawhip:"#ffefd5",plum:"#dda0dd",blanchedalmond:"#ffebcd",black:"#000000",gold:"#ffd700",goldenrod:"#daa520",gainsboro:"#dcdcdc",cornsilk:"#fff8dc",cornflowerblue:"#6495ed",burlywood:"#deb887",aquamarine:"#7fffd4",beige:"#f5f5dc",crimson:"#dc143c",cyan:"#00ffff",darkblue:"#00008b",darkcyan:"#008b8b",darkgoldenrod:"#b8860b",darkkhaki:"#bdb76b",darkgray:"#a9a9a9",darkgreen:"#006400",darkgrey:"#a9a9a9",peachpuff:"#ffdab9",darkmagenta:"#8b008b",darkred:"#8b0000",darkorchid:"#9932cc",darkorange:"#ff8c00",darkslateblue:"#483d8b",gray:"#808080",darkslategray:"#2f4f4f",darkslategrey:"#2f4f4f",deeppink:"#ff1493",deepskyblue:"#00bfff",wheat:"#f5deb3",firebrick:"#b22222",floralwhite:"#fffaf0",ghostwhite:"#f8f8ff",darkviolet:"#9400d3",magenta:"#ff00ff",green:"#008000",dodgerblue:"#1e90ff",grey:"#808080",honeydew:"#f0fff0",hotpink:"#ff69b4",blueviolet:"#8a2be2",forestgreen:"#228b22",lawngreen:"#7cfc00",indianred:"#cd5c5c",indigo:"#4b0082",fuchsia:"#ff00ff",brown:"#a52a2a",maroon:"#800000",mediumblue:"#0000cd",lightcoral:"#f08080",darkturquoise:"#00ced1",lightcyan:"#e0ffff",ivory:"#fffff0",lightyellow:"#ffffe0",lightsalmon:"#ffa07a",lightseagreen:"#20b2aa",linen:"#faf0e6",mediumaquamarine:"#66cdaa",lemonchiffon:"#fffacd",lime:"#00ff00",khaki:"#f0e68c",mediumseagreen:"#3cb371",limegreen:"#32cd32",mediumspringgreen:"#00fa9a",lightskyblue:"#87cefa",lightblue:"#add8e6",midnightblue:"#191970",lightpink:"#ffb6c1",mistyrose:"#ffe4e1",moccasin:"#ffe4b5",mintcream:"#f5fffa",lightslategray:"#778899",lightslategrey:"#778899",navajowhite:"#ffdead",navy:"#000080",mediumvioletred:"#c71585",powderblue:"#b0e0e6",palegoldenrod:"#eee8aa",oldlace:"#fdf5e6",paleturquoise:"#afeeee",mediumturquoise:"#48d1cc",mediumorchid:"#ba55d3",rebeccapurple:"#663399",lightsteelblue:"#b0c4de",mediumslateblue:"#7b68ee",thistle:"#d8bfd8",tan:"#d2b48c",orchid:"#da70d6",mediumpurple:"#9370db",purple:"#800080",pink:"#ffc0cb",skyblue:"#87ceeb",springgreen:"#00ff7f",palegreen:"#98fb98",red:"#ff0000",yellow:"#ffff00",slateblue:"#6a5acd",lavenderblush:"#fff0f5",peru:"#cd853f",palevioletred:"#db7093",violet:"#ee82ee",teal:"#008080",slategray:"#708090",slategrey:"#708090",aliceblue:"#f0f8ff",darkseagreen:"#8fbc8f",darkolivegreen:"#556b2f",greenyellow:"#adff2f",seagreen:"#2e8b57",seashell:"#fff5ee",tomato:"#ff6347",silver:"#c0c0c0",sienna:"#a0522d",lavender:"#e6e6fa",lightgreen:"#90ee90",orange:"#ffa500",orangered:"#ff4500",steelblue:"#4682b4",royalblue:"#4169e1",turquoise:"#40e0d0",yellowgreen:"#9acd32",salmon:"#fa8072",saddlebrown:"#8b4513",sandybrown:"#f4a460",rosybrown:"#bc8f8f",darksalmon:"#e9967a",lightgoldenrodyellow:"#fafad2",snow:"#fffafa",lightgrey:"#d3d3d3",lightgray:"#d3d3d3",dimgray:"#696969",dimgrey:"#696969",olivedrab:"#6b8e23",olive:"#808000"},n={};for(var o in r)n[r[o]]=o;var i={};e.prototype.toName=function(s){if(!(this.rgba.a||this.rgba.r||this.rgba.g||this.rgba.b))return"transparent";var a,c,l=n[this.toHex()];if(l)return l;if(s?.closest){var A=this.toRgb(),u=1/0,m="black";if(!i.length)for(var d in r)i[d]=new e(r[d]).toRgb();for(var p in r){var E=(a=A,c=i[p],Math.pow(a.r-c.r,2)+Math.pow(a.g-c.g,2)+Math.pow(a.b-c.b,2));E<u&&(u=E,m=p)}return m}},t.string.push([function(s){var a=s.toLowerCase(),c=a==="transparent"?"#0000":r[a];return c?new e(c).toRgb():null},"name"])}var Uu=g(()=>{});function oc(e,t){return Object.fromEntries(Object.entries(e).map(t))}function rs(e,t){return oc(e,([r,n])=>[r,t.palette.getContrastText(bt(n).toHex())])}function Hu(e,t){if(e.length===0)return t;let r=[],n=0;for(let o of e)o>n&&r.push(t.slice(n,o)),n=o+1;return n<t.length&&r.push(t.slice(n)),r.join("")}function ju(e){return e.end-e.start}function ns(e){return e==="-"||e==="."}var Yn=g(()=>{rc();Uu();tc([nc])});var rT,ii,ic=g(()=>{Lu();rc();Uu();Yn();tc([nc]);rT={none:{},clustal:{G:"orange",P:"orange",S:"orange",T:"orange",H:"red",K:"red",R:"red",F:"blue",W:"blue",Y:"blue",I:"green",L:"green",M:"green",V:"green"},lesk:{G:"orange",A:"orange",S:"orange",T:"orange",C:"green",V:"green",I:"green",L:"green",P:"green",F:"green",Y:"green",M:"green",W:"green",N:"magenta",Q:"magenta",H:"magenta",D:"red",E:"red",K:"blue",R:"blue"},maeditor:{A:"lightgreen",G:"lightgreen",C:"green",D:"darkgreen",E:"darkgreen",N:"darkgreen",Q:"darkgreen",I:"blue",L:"blue",M:"blue",V:"blue",F:"#c8a2c8",W:"#c8a2c8",Y:"#c8a2c8",H:"darkblue",K:"orange",R:"orange",P:"pink",S:"red",T:"red"},percent_identity_dynamic:{},flower:{A:"#b18a51",C:"#ff5701",D:"#01a578",E:"#2da0a1",F:"#fa559d",G:"#b1c23c",H:"#0194f9",I:"#f27663",K:"#7fc3d7",L:"#df6e75",M:"#fe9daf",N:"#0bcec6",P:"#4fa32a",Q:"#7295ae",R:"#83bff1",S:"#b4bd9b",T:"#d2b576",V:"#fd997b",W:"#ff2ded",Y:"#c96ecf"},rainbow_dna:{A:"#3737f5",C:"#37f537",G:"#f5f537",T:"#f53737",U:"#f53737"},clustalx_protein:{A:"#197fe5",C:"#e57f7f",D:"#cc4ccc",E:"#cc4ccc",F:"#197fe5",G:"#e5994c",H:"#19b2b2",I:"#197fe5",K:"#e53319",L:"#197fe5",M:"#197fe5",N:"#19cc19",P:"#cccc00",Q:"#19cc19",R:"#e53319",S:"#19cc19",T:"#19cc19",V:"#197fe5",W:"#197fe5",Y:"#19b2b2"},clustalx_protein_dynamic:{},clustalx_dna:{A:"#e53319",C:"#197fe5",G:"#e5994c",T:"#19cc19",U:"#19cc19"},jbrowse_dna:{A:Zi[500],C:Xi[500],G:es[500],T:oi[500],U:oi[500]},jalview_buried:{A:"#00a35c",R:"#00fc03",N:"#00eb14",D:"#00eb14",C:"#0000ff",Q:"#00f10e",E:"#00f10e",G:"#009d62",H:"#00d52a",I:"#0054ab",L:"#007b84",K:"#00ff00",M:"#009768",F:"#008778",P:"#00e01f",S:"#00d52a",T:"#00db24",W:"#00a857",Y:"#00e619",V:"#005fa0",B:"#00eb14",X:"#00b649",Z:"#00f10e"},jalview_hydrophobicity:{A:"#ad0052",R:"#0000ff",N:"#0c00f3",D:"#0c00f3",C:"#c2003d",Q:"#0c00f3",E:"#0c00f3",G:"#6a0095",H:"#1500ea",I:"#ff0000",L:"#ea0015",K:"#0000ff",M:"#b0004f",F:"#cb0034",P:"#4600b9",S:"#5e00a1",T:"#61009e",W:"#5b00a4",Y:"#4f00b0",V:"#f60009",B:"#0c00f3",X:"#680097",Z:"#0c00f3"},jalview_prophelix:{A:"#e718e7",R:"#6f906f",N:"#1be41b",D:"#778877",C:"#23dc23",Q:"#926d92",E:"#ff00ff",G:"#00ff00",H:"#758a75",I:"#8a758a",L:"#ae51ae",K:"#a05fa0",M:"#ef10ef",F:"#986798",P:"#00ff00",S:"#36c936",T:"#47b847",W:"#8a758a",Y:"#21de21",V:"#857a85",B:"#49b649",X:"#758a75",Z:"#c936c9"},jalview_propstrand:{A:"#5858a7",R:"#6b6b94",N:"#64649b",D:"#2121de",C:"#9d9d62",Q:"#8c8c73",E:"#0000ff",G:"#4949b6",H:"#60609f",I:"#ecec13",L:"#b2b24d",K:"#4747b8",M:"#82827d",F:"#c2c23d",P:"#2323dc",S:"#4949b6",T:"#9d9d62",W:"#c0c03f",Y:"#d3d32c",V:"#ffff00",B:"#4343bc",X:"#797986",Z:"#4747b8"},jalview_propturn:{A:"#2cd3d3",R:"#708f8f",N:"#ff0000",D:"#e81717",C:"#a85757",Q:"#3fc0c0",E:"#778888",G:"#ff0000",H:"#708f8f",I:"#00ffff",L:"#1ce3e3",K:"#7e8181",M:"#1ee1e1",F:"#1ee1e1",P:"#f60909",S:"#e11e1e",T:"#738c8c",W:"#738c8c",Y:"#9d6262",V:"#07f8f8",B:"#f30c0c",X:"#7c8383",Z:"#5ba4a4"},jalview_taylor:{A:"#ccff00",R:"#0000ff",N:"#cc00ff",D:"#ff0000",C:"#ffff00",Q:"#ff00cc",E:"#ff0066",G:"#ff9900",H:"#0066ff",I:"#66ff00",L:"#33ff00",K:"#6600ff",M:"#00ff00",F:"#00ff66",P:"#ffcc00",S:"#ff3300",T:"#ff6600",W:"#00ccff",Y:"#00ffcc",V:"#99ff00"},jalview_zappo:{A:"#ffafaf",R:"#6464ff",N:"#00ff00",D:"#ff0000",C:"#ffff00",Q:"#00ff00",E:"#ff0000",G:"#ff00ff",H:"#6464ff",I:"#ffafaf",L:"#ffafaf",K:"#6464ff",M:"#ffafaf",F:"#ffc800",P:"#ff00ff",S:"#00ff00",T:"#00ff00",W:"#ffc800",Y:"#ffc800",V:"#ffafaf"},cinema:{H:"blue",K:"blue",R:"blue",D:"red",E:"red",S:"green",T:"green",N:"green",Q:"green",A:"white",V:"white",L:"white",I:"white",M:"white",F:"magenta",W:"magenta",Y:"magenta",P:"brown",G:"brown",C:"yellow",B:"gray",Z:"gray",X:"gray","-":"gray",".":"gray"}},ii=oc(rT,([e,t])=>[e,oc(t,([r,n])=>[r,bt(n).toHex()])])});var qu,vE,nT,TE,_E=g(()=>{qu=f(w(),1);ni();mE();vE=f(G(),1);ic();nT=(0,vE.observer)(function({model:e}){let{colorSchemeName:t}=e;return qu.default.createElement(vr,{closeAfterItemClick:!0,anchorOrigin:{vertical:"bottom",horizontal:"left"},transformOrigin:{vertical:"top",horizontal:"left"},menuItems:Object.keys(ii).map(r=>({label:r,type:"radio",checked:t===r,onClick:()=>{e.setColorSchemeName(r)}}))},qu.default.createElement(fE,null))}),TE=nT});var kE,DE,NE=g(()=>{"use client";W();kE=f(R(),1),DE=(0,_.createSvgIcon)((0,kE.jsx)("path",{d:"M19 3h-4.18C14.4 1.84 13.3 1 12 1s-2.4.84-2.82 2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2m-7 0c.55 0 1 .45 1 1s-.45 1-1 1-1-.45-1-1 .45-1 1-1m2 14H7v-2h7zm3-4H7v-2h10zm0-4H7V7h10z"}),"Assignment")});var LE,os,Ju=g(()=>{"use client";W();LE=f(R(),1),os=(0,_.createSvgIcon)((0,LE.jsx)("path",{d:"M20 6h-8l-2-2H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2m0 12H4V8h16z"}),"FolderOpen")});var Vu,FE,RE=g(()=>{"use client";W();Vu=f(R(),1),FE=(0,_.createSvgIcon)([(0,Vu.jsx)("circle",{cx:"12",cy:"12",r:"3.2"},"0"),(0,Vu.jsx)("path",{d:"M9 2 7.17 4H4c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2h-3.17L15 2zm3 15c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5"},"1")],"PhotoCamera")});var PE,sc,Yu=g(()=>{"use client";W();PE=f(R(),1),sc=(0,_.createSvgIcon)((0,PE.jsx)("path",{d:"M19.14 12.94c.04-.3.06-.61.06-.94 0-.32-.02-.64-.07-.94l2.03-1.58c.18-.14.23-.41.12-.61l-1.92-3.32c-.12-.22-.37-.29-.59-.22l-2.39.96c-.5-.38-1.03-.7-1.62-.94l-.36-2.54c-.04-.24-.24-.41-.48-.41h-3.84c-.24 0-.43.17-.47.41l-.36 2.54c-.59.24-1.13.57-1.62.94l-2.39-.96c-.22-.08-.47 0-.59.22L2.74 8.87c-.12.21-.08.47.12.61l2.03 1.58c-.05.3-.09.63-.09.94s.02.64.07.94l-2.03 1.58c-.18.14-.23.41-.12.61l1.92 3.32c.12.22.37.29.59.22l2.39-.96c.5.38 1.03.7 1.62.94l.36 2.54c.05.24.24.41.48.41h3.84c.24 0 .44-.17.47-.41l.36-2.54c.59-.24 1.13-.56 1.62-.94l2.39.96c.22.08.47 0 .59-.22l1.92-3.32c.12-.22.07-.47-.12-.61zM12 15.6c-1.98 0-3.6-1.62-3.6-3.6s1.62-3.6 3.6-3.6 3.6 1.62 3.6 3.6-1.62 3.6-3.6 3.6"}),"Settings")});var OE,GE,UE=g(()=>{"use client";W();OE=f(R(),1),GE=(0,_.createSvgIcon)((0,OE.jsx)("path",{d:"M4.25 5.61C6.27 8.2 10 13 10 13v6c0 .55.45 1 1 1h2c.55 0 1-.45 1-1v-6s3.72-4.8 5.74-7.39c.51-.66.04-1.61-.79-1.61H5.04c-.83 0-1.3.95-.79 1.61"}),"FilterAlt")});var HE,jE,qE=g(()=>{"use client";W();HE=f(R(),1),jE=(0,_.createSvgIcon)((0,HE.jsx)("path",{d:"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14"}),"Search")});var JE,VE,YE=g(()=>{"use client";W();JE=f(R(),1),VE=(0,_.createSvgIcon)((0,JE.jsx)("path",{d:"M3 18h6v-2H3zM3 6v2h18V6zm0 7h12v-2H3z"}),"Sort")});var WE,zE,$E=g(()=>{"use client";W();WE=f(R(),1),zE=(0,_.createSvgIcon)((0,WE.jsx)("path",{d:"M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5M12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5m0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3"}),"Visibility")});function KE(e){return Wu[Math.min(e,Wu.length-1)]}var Wu,zu,$u=g(()=>{Wu=[["#F8766D"],["#F8766D","#00BFC4"],["#F8766D","#00BA38","#619CFF"],["#F8766D","#7CAE00","#00BFC4","#C77CFF"],["#F8766D","#A3A500","#00BF7D","#00B0F6","#E76BF3"],["#F8766D","#B79F00","#00BA38","#00BFC4","#619CFF","#F564E3"],["#F8766D","#C49A00","#53B400","#00C094","#00B6EB","#A58AFF","#FB61D7"],["#F8766D","#CD9600","#7CAE00","#00BE67","#00BFC4","#00A9FF","#C77CFF","#FF61CC"]];zu=Wu});var ZE={};Ye(ZE,{default:()=>aT});var fe,XE,is,ac,oT,iT,sT,aT,eI=g(()=>{fe=f(w(),1),XE=f(we(),1),is=f(k(),1),ac=f(G(),1);$u();oT=(0,ac.observer)(function({model:e}){let{featureFilters:t}=e;return fe.default.createElement("div",null,fe.default.createElement(is.Button,{onClick:()=>{for(let r of t.keys())e.setFilter(r,!0)}},"Toggle all on"),fe.default.createElement(is.Button,{onClick:()=>{for(let r of t.keys())e.setFilter(r,!1)}},"Toggle all off"))}),iT=(0,ac.observer)(function({model:e}){let{tidyInterProAnnotationTypes:t,featureFilters:r}=e,n=[...t.values()],o=KE(n.length-1);return fe.default.createElement(fe.default.Fragment,null,fe.default.createElement(oT,{model:e}),fe.default.createElement("table",null,fe.default.createElement("thead",null,fe.default.createElement("tr",null,fe.default.createElement("td",null),fe.default.createElement("td",null,"accession"),fe.default.createElement("td",null,"name"),fe.default.createElement("td",null,"description"))),fe.default.createElement("tbody",null,n.map(({accession:i,name:s,description:a},c)=>fe.default.createElement("tr",{key:i},fe.default.createElement("td",null,fe.default.createElement("input",{type:"checkbox",checked:r.get(i)??!1,onChange:()=>{e.setFilter(i,!e.featureFilters.get(i))}})),fe.default.createElement("td",null,i),fe.default.createElement("td",null,s),fe.default.createElement("td",null,a),fe.default.createElement("td",null,fe.default.createElement("div",{style:{width:20,height:20,background:o[c]||"black"}})))))))}),sT=(0,ac.observer)(function({onClose:e,model:t}){return fe.default.createElement(XE.Dialog,{onClose:()=>{e()},open:!0,title:"Feature filters",maxWidth:"xl"},fe.default.createElement(is.DialogContent,null,fe.default.createElement(iT,{model:t})))}),aT=sT});async function tI(e,t){let r=await fetch(e,t);if(!r.ok)throw new Error(`HTTP ${r.status} fetching ${e} ${await r.text()}`);return r}async function Ku(e,t){return(await tI(e,t)).text()}async function cc(e,t){return(await tI(e,t)).json()}function rI(e,t){return new Promise((r,n)=>{if(t?.aborted)n(new DOMException("Aborted","AbortError"));else{let o=setTimeout(r,e);t?.addEventListener("abort",()=>{clearTimeout(o),n(new DOMException("Aborted","AbortError"))})}})}function Xu(e){return e instanceof DOMException&&e.name==="AbortError"}var Zu=g(()=>{});var iI={};Ye(iI,{default:()=>lT});var Ie,nI,ef,Qe,oI,cT,lT,sI=g(()=>{Ie=f(w(),1),nI=f(we(),1),ef=f(Ce(),1),Qe=f(k(),1),oI=f(G(),1);Zu();cT=(0,oI.observer)(function({handleClose:e,model:t}){let[r,n]=(0,Ie.useState)(),[o,i]=(0,Ie.useState)("file"),[s,a]=(0,Ie.useState)("");return Ie.default.createElement(nI.Dialog,{maxWidth:"xl",title:"Open protein domains from file",onClose:()=>{e()},open:!0},Ie.default.createElement(Qe.DialogContent,null,Ie.default.createElement("div",null,Ie.default.createElement(Qe.Typography,null,"Open a JSON file of InterProScan results that you run remotely on EBI servers or locally"),Ie.default.createElement("div",{style:{display:"flex",margin:30}},Ie.default.createElement(Qe.FormControl,{component:"fieldset"},Ie.default.createElement(Qe.RadioGroup,{value:o,onChange:c=>{i(c.target.value)}},Ie.default.createElement(Qe.FormControlLabel,{value:"url",control:Ie.default.createElement(Qe.Radio,null),label:"URL"}),Ie.default.createElement(Qe.FormControlLabel,{value:"file",control:Ie.default.createElement(Qe.Radio,null),label:"File"}))),o==="url"?Ie.default.createElement("div",null,Ie.default.createElement(Qe.Typography,null,"Open a InterProScan JSON file remote URL"),Ie.default.createElement(Qe.TextField,{label:"URL",value:s,onChange:c=>{a(c.target.value)}})):null,o==="file"?Ie.default.createElement("div",{style:{paddingTop:20}},Ie.default.createElement(Qe.Typography,null,"Open a InterProScan JSON file file from your local drive"),Ie.default.createElement(Qe.Button,{variant:"outlined",component:"label"},"Choose File",Ie.default.createElement("input",{type:"file",hidden:!0,onChange:({target:c})=>{let l=c.files?.[0];l&&n(l)}}))):null))),Ie.default.createElement(Qe.DialogActions,null,Ie.default.createElement(Qe.Button,{variant:"contained",color:"primary",onClick:()=>{(async()=>{try{let c=r?JSON.parse(await r.text()):await cc(s);t.setInterProAnnotations(Object.fromEntries(c.results.map(l=>[l.xref[0].id,l]))),t.setShowDomains(!0),(0,ef.getSession)(t).notify("Loaded interproscan results","success")}catch(c){console.error(c),(0,ef.getSession)(t).notifyError(`${c}`,c)}finally{t.setStatus()}})(),e()}},"Open results")))}),lT=cT});async function AT({seq:e,onProgress:t,onJobId:r,programs:n,model:o,signal:i}){let s=await Ku(`${tf}/iprscan5/run`,{method:"POST",body:new URLSearchParams({email:"colin.diesh@gmail.com",sequence:e,programs:n.join(",")}),signal:i});r?.(s),await fT({jobId:s,onProgress:t,signal:i}),await mT({jobId:s,model:o,onProgress:t,signal:i})}function uT(e,t){return cc(`${tf}/iprscan5/result/${e}/json`,{signal:t})}async function fT({onProgress:e,jobId:t,signal:r}){let n=`${tf}/iprscan5/status/${t}`;try{for(;;){for(let i=0;i<10;i++)await rI(1e3,r),e({msg:`Checking status ${10-i}`,url:n});let o=await Ku(n,{signal:r});if(o.includes("FINISHED"))break;if(o.includes("FAILURE"))throw new Error(`Failed to run: jobId ${t}`)}}finally{e()}}async function aI({algorithm:e,seq:t,programs:r,onJobId:n,onProgress:o,model:i,signal:s}){try{if(o({msg:`Launching ${e} MSA`}),e==="interproscan")await AT({seq:t,onJobId:n,onProgress:o,programs:r,model:i,signal:s});else throw new Error("unknown algorithm")}catch(a){if(Xu(a))(0,ss.getSession)(i).notify("Cancelled InterProScan query","info");else throw a}finally{o()}}async function mT({jobId:e,model:t,onProgress:r,signal:n}){try{r({msg:`Downloading results of ${e} (for larger sequences this can be slow, click status to download and upload in the manual tab)`,url:`https://www.ebi.ac.uk/Tools/services/rest/iprscan5/result/${e}/json`});let o=await uT(e,n);t.setInterProAnnotations(Object.fromEntries(o.results.map(i=>[i.xref[0].id,i]))),t.setShowDomains(!0),(0,ss.getSession)(t).notify(`Loaded interproscan ${e} results`,"success")}catch(o){Xu(o)?(0,ss.getSession)(t).notify("Cancelled InterProScan query","info"):(console.error(o),(0,ss.getSession)(t).notifyError(`${o}`,o))}finally{r()}}var ss,tf,cI=g(()=>{ss=f(Ce(),1);Zu();tf="https://www.ebi.ac.uk/Tools/services/rest"});var fI={};Ye(fI,{default:()=>gT});var Me,lI,AI,Ft,uI,dT,gT,mI=g(()=>{Me=f(w(),1),lI=f(we(),1),AI=f(Ce(),1),Ft=f(k(),1),uI=f(G(),1);cI();dT=(0,uI.observer)(function({handleClose:e,model:t}){let[r,n]=(0,Me.useState)([{name:"NCBIfam",description:"NCBI RefSeq FAMs including TIGRFAMs",category:"Families, domains, sites & repeats",checked:!0},{name:"SFLD",description:"Structure function linkage database",category:"Families, domains, sites & repeats",checked:!0},{name:"Phobius",checked:!0,description:"A combined transmembrane topology and signal peptide predictor",category:"Other sequence features"},{name:"SignalP",checked:!0,category:"Other sequence features"},{name:"SignalP_EUK",category:"Other category",checked:!0},{name:"SignalP_GRAM_POSITIVE",category:"Other category",checked:!0},{name:"SignalP_GRAM_NEGATIVE",checked:!0,category:"Other category"},{name:"SuperFamily",category:"Structural domains",checked:!0},{name:"Panther",category:"Families, domains, sites & repeats",checked:!0},{name:"Gene3d",category:"Structural domains",checked:!0},{name:"HAMAP",category:"Families, domains, sites & repeats",checked:!0},{name:"PrositeProfiles",category:"Families, domains, sites & repeats",checked:!0},{name:"PrositePatterns",category:"Families, domains, sites & repeats",checked:!0},{name:"Coils",category:"Other sequence features",checked:!0},{name:"SMART",category:"Families, domains, sites & repeats",checked:!0},{name:"CDD",description:"Conserved Domains Database",category:"Families, domains, sites & repeats",checked:!0},{name:"PRINTS",category:"Families, domains, sites & repeats",checked:!0},{name:"PfamA",category:"Families, domains, sites & repeats",checked:!0},{name:"MobiDBLite",checked:!0,category:"Other sequence features"},{name:"PIRSF",checked:!0,category:"Other category"},{name:"TMHMM",checked:!0,category:"Other sequence features"},{name:"AntiFam",checked:!0,category:"Other category"},{name:"FunFam",checked:!0,category:"Other category"},{name:"PIRSR",checked:!0,category:"Families, domains, sites & repeats"}]),o=r.filter(a=>a.checked).map(a=>a.name),[i,s]=(0,Me.useState)(!1);return Me.default.createElement(lI.Dialog,{maxWidth:"xl",title:"Query InterProScan API for domains",onClose:()=>{e()},open:!0},Me.default.createElement(Ft.DialogContent,null,Me.default.createElement(Ft.Typography,null,"This will run InterProScan via the InterProScan API on all rows of the current MSA"),Me.default.createElement(Ft.Button,{onClick:()=>{s(!i)}},i?"Hide":"Show"," advanced options"),i?Me.default.createElement("div",null,Me.default.createElement(Ft.Typography,null,"Select algorithms for InterProScan to run"),Me.default.createElement("div",null,Me.default.createElement(Ft.Button,{variant:"contained",color:"secondary",onClick:()=>{n(r.map(a=>({...a,checked:!1})))}},"Select none"),Me.default.createElement(Ft.Button,{variant:"contained",color:"primary",onClick:()=>{n(r.map(a=>({...a,checked:!0})))}},"Select all")),Me.default.createElement("table",null,Me.default.createElement("tbody",null,r.toSorted((a,c)=>a.category.localeCompare(c.category)).map(({name:a,checked:c,category:l})=>Me.default.createElement("tr",{key:a},Me.default.createElement("td",null,Me.default.createElement("input",{type:"checkbox",key:a,checked:c,onChange:()=>{n(r.map(A=>A.name===a?{...A,checked:!A.checked}:A))}})),Me.default.createElement("td",null,a),Me.default.createElement("td",null,l)))))):null),Me.default.createElement(Ft.DialogActions,null,Me.default.createElement(Ft.Button,{variant:"contained",color:"secondary",onClick:()=>{e()}},"Cancel"),Me.default.createElement(Ft.Button,{variant:"contained",color:"primary",onClick:()=>{let a=new AbortController;(async()=>{try{let{rows:c}=t;if(c.length>140)throw new Error("Too many sequences, please run InterProScan offline");await aI({algorithm:"interproscan",programs:o,seq:c.map(l=>[l[0],l[1].replaceAll("-","")]).filter(l=>!!l[1]).map(l=>`>${l[0]}
29
+ ${l[1]}`).join(`
30
+ `),onProgress:l=>{t.setStatus(l?{...l,onCancel:()=>{a.abort()}}:void 0)},model:t,signal:a.signal})}catch(c){console.error(c),(0,AI.getSession)(t).notifyError(`${c}`,c)}finally{t.setStatus()}})(),e()}},"Send sequences to InterProScan")))}),gT=dT});function dI({model:e}){let{showDomains:t,actuallyShowDomains:r,subFeatureRows:n,noDomains:o}=e;return[{label:"Open domains...",icon:os,onClick:()=>{e.queueDialog(i=>[hT,{handleClose:i,model:e}])}},{label:"Query InterProScan for domains...",icon:jE,onClick:()=>{e.queueDialog(i=>[CT,{handleClose:i,model:e}])}},{label:`Show domains${o?" (no domains loaded)":""}`,disabled:o,icon:zE,checked:r?t:!1,type:"checkbox",onClick:()=>{e.setShowDomains(!t)}},{label:`Use sub-row layout${o?" (no domains loaded)":""}`,disabled:o,checked:r?n:!1,icon:VE,type:"checkbox",onClick:()=>{e.setSubFeatureRows(!n)}},{label:`Filter domains${o?" (no domains loaded)":""}`,icon:GE,disabled:o,onClick:()=>{e.queueDialog(i=>[pT,{onClose:i,model:e}])}}]}var lc,pT,hT,CT,gI=g(()=>{lc=f(w(),1);UE();Ju();qE();YE();$E();pT=(0,lc.lazy)(()=>Promise.resolve().then(()=>(eI(),ZE))),hT=(0,lc.lazy)(()=>Promise.resolve().then(()=>(sI(),iI))),CT=(0,lc.lazy)(()=>Promise.resolve().then(()=>(mI(),fI)))});var EI=U((bO,CI)=>{"use strict";var ET=function(t){return IT(t)&&!xT(t)};function IT(e){return!!e&&typeof e=="object"}function xT(e){var t=Object.prototype.toString.call(e);return t==="[object RegExp]"||t==="[object Date]"||wT(e)}var yT=typeof Symbol=="function"&&Symbol.for,bT=yT?Symbol.for("react.element"):60103;function wT(e){return e.$$typeof===bT}function BT(e){return Array.isArray(e)?[]:{}}function as(e,t){return t.clone!==!1&&t.isMergeableObject(e)?si(BT(e),e,t):e}function ST(e,t,r){return e.concat(t).map(function(n){return as(n,r)})}function QT(e,t){if(!t.customMerge)return si;var r=t.customMerge(e);return typeof r=="function"?r:si}function MT(e){return Object.getOwnPropertySymbols?Object.getOwnPropertySymbols(e).filter(function(t){return Object.propertyIsEnumerable.call(e,t)}):[]}function pI(e){return Object.keys(e).concat(MT(e))}function hI(e,t){try{return t in e}catch{return!1}}function vT(e,t){return hI(e,t)&&!(Object.hasOwnProperty.call(e,t)&&Object.propertyIsEnumerable.call(e,t))}function TT(e,t,r){var n={};return r.isMergeableObject(e)&&pI(e).forEach(function(o){n[o]=as(e[o],r)}),pI(t).forEach(function(o){vT(e,o)||(hI(e,o)&&r.isMergeableObject(t[o])?n[o]=QT(o,r)(e[o],t[o],r):n[o]=as(t[o],r))}),n}function si(e,t,r){r=r||{},r.arrayMerge=r.arrayMerge||ST,r.isMergeableObject=r.isMergeableObject||ET,r.cloneUnlessOtherwiseSpecified=as;var n=Array.isArray(t),o=Array.isArray(e),i=n===o;return i?n?r.arrayMerge(e,t,r):TT(e,t,r):as(t,r)}si.all=function(t,r){if(!Array.isArray(t))throw new Error("first argument should be an array");return t.reduce(function(n,o){return si(n,o,r)},{})};var _T=si;CI.exports=_T});function yI(){return{palette:{...Ac,mode:void 0},components:{MuiLink:{styleOverrides:{root:({theme:e})=>({color:e.palette.tertiary.main})}}}}}function VT(){return{...yI(),name:"Default (from config)"}}function YT(){return{...yI(),name:"Light (stock)"}}function WT(){return{name:"Dark (stock)",palette:{...Ac,mode:"dark"},components:{MuiAppBar:{defaultProps:{enableColorOnDark:!0},styleOverrides:{root:({theme:e})=>e.palette.primary.main}}}}}function zT(){return{name:"Dark (minimal)",palette:{...Ac,mode:"dark",primary:{main:mn[700]},secondary:{main:mn[800]},tertiary:ve.palette.augmentColor({color:{main:mn[900]}})}}}function $T(){return{name:"Light (minimal)",palette:{...Ac,primary:{main:mn[900]},secondary:{main:mn[800]},tertiary:ve.palette.augmentColor({color:{main:mn[900]}})}}}var xI,kT,ve,DT,NT,LT,II,BO,FT,RT,PT,OT,GT,UT,HT,jT,qT,JT,Ac,SO,bI=g(()=>{xI=f(k(),1);Lu();kT=f(EI(),1),ve=(0,xI.createTheme)(),DT=ve.palette.augmentColor({color:{main:"#0D233F"}}),NT=ve.palette.augmentColor({color:{main:"#721E63"}}),LT=ve.palette.augmentColor({color:{main:"#135560"}}),II=ve.palette.augmentColor({color:{main:"#FFB11D"}}),BO=ve.palette.augmentColor({color:{main:"#aaa"}}),FT={A:ve.palette.augmentColor({color:Zi}),C:ve.palette.augmentColor({color:Xi}),G:ve.palette.augmentColor({color:es}),T:ve.palette.augmentColor({color:oi})},RT=[null,ve.palette.augmentColor({color:{main:"#FF8080"}}),ve.palette.augmentColor({color:{main:"#80FF80"}}),ve.palette.augmentColor({color:{main:"#8080FF"}}),ve.palette.augmentColor({color:{main:"#8080FF"}}),ve.palette.augmentColor({color:{main:"#80FF80"}}),ve.palette.augmentColor({color:{main:"#FF8080"}})],PT=[null,ve.palette.augmentColor({color:{main:"#8f8f8f"}}),ve.palette.augmentColor({color:{main:"#adadad"}}),ve.palette.augmentColor({color:{main:"#d8d8d8"}}),ve.palette.augmentColor({color:{main:"#d8d8d8"}}),ve.palette.augmentColor({color:{main:"#adadad"}}),ve.palette.augmentColor({color:{main:"#8f8f8f"}})],OT="#e22",GT="#3e3",UT="#800080",HT="#808080",jT="#f00",qT="#00f",JT="#97b8c9",Ac={primary:DT,secondary:NT,tertiary:LT,quaternary:II,highlight:II,stopCodon:OT,startCodon:GT,insertion:UT,deletion:HT,softclip:qT,hardclip:jT,bases:FT,frames:PT,framesCDS:RT,skip:JT};SO={default:VT(),lightStock:YT(),lightMinimal:$T(),darkMinimal:zT(),darkStock:WT()}});var wI=g(()=>{});var BI=g(()=>{});var rf=g(()=>{bI();Tu();wI();BI()});function dn({value:e}){let{classes:t}=KT(),r=/^https?:\/\//.exec(`${e}`);return(0,uc.jsx)("div",{className:t.fieldValue,children:(0,SI.isValidElement)(e)?e:r?(0,uc.jsx)(QI.Link,{href:`${e}`,children:`${e}`}):(0,uc.jsx)(un,{html:Yt(e)?JSON.stringify(e):String(e)})})}var uc,SI,QI,KT,fc=g(()=>{uc=f(R(),1),SI=f(w(),1),QI=f(k(),1);rf();ln();Et();KT=te()(e=>({fieldValue:{wordBreak:"break-word",maxHeight:300,fontSize:12,padding:e.spacing(.5),overflow:"auto"}}))});function Tr({description:e,name:t,width:r,prefix:n=[]}){let{classes:o}=XT(),i=[...n,t].join(".");return e?(0,mc.jsx)(MI.Tooltip,{title:e,placement:"left",children:(0,mc.jsx)("div",{className:ya(o.fieldDescription,o.fieldName),children:i})}):(0,mc.jsx)("div",{className:o.fieldName,style:{width:r},children:i})}var mc,MI,XT,cs=g(()=>{mc=f(R(),1),MI=f(k(),1);Et();XT=te()(e=>({fieldDescription:{"&:hover":{background:e.palette.mode==="dark"?"#e65100":"yellow"}},fieldName:{wordBreak:"break-all",minWidth:90,borderBottom:"1px solid #0003",fontSize:12,background:e.palette.action.disabledBackground,marginRight:e.spacing(1),padding:e.spacing(.5)}}))});function of({name:e,value:t,description:r,formatter:n,prefix:o=[]}){let{classes:i}=ZT(),[s,a]=(0,vI.useState)(!1),c=t.length>nf,l=c&&!s?t.slice(0,nf):t;return t.length===1?Yt(t[0])?(0,wt.jsx)(_r,{formatter:n,attributes:t[0],prefix:[...o,e]}):(0,wt.jsxs)("div",{className:i.field,children:[(0,wt.jsx)(Tr,{prefix:o,description:r,name:e}),(0,wt.jsx)(dn,{value:n?n(t[0],e):t[0]})]}):t.every(A=>Yt(A))?(0,wt.jsx)(wt.Fragment,{children:t.map((A,u)=>(0,wt.jsx)(_r,{formatter:n,attributes:A,prefix:[...o,`${e}-${u}`]},`${JSON.stringify(A)}-${u}`))}):(0,wt.jsxs)("div",{className:i.field,children:[(0,wt.jsx)(Tr,{prefix:o,description:r,name:e}),l.map((A,u)=>(0,wt.jsx)("div",{className:i.fieldSubvalue,children:(0,wt.jsx)(dn,{value:n?n(A,e):A})},`${JSON.stringify(A)}-${u}`)),c?(0,wt.jsx)("button",{type:"button",onClick:()=>{a(A=>!A)},children:s?"Show less":`Showing ${nf} of ${t.length}. Show all...`}):null]})}var wt,vI,nf,ZT,TI=g(()=>{wt=f(R(),1),vI=f(w(),1);dc();fc();cs();ln();Et();nf=100,ZT=te()(e=>({field:{display:"flex",flexWrap:"wrap"},fieldSubvalue:{wordBreak:"break-word",maxHeight:300,padding:e.spacing(.5),border:`1px solid ${e.palette.action.selected}`,boxSizing:"border-box",overflow:"auto"}}))});var kI=U((VO,_I)=>{_I.exports=JBrowseExports["@mui/x-data-grid"]});function sf({children:e,style:t}){let{classes:r}=e_();return(0,DI.jsx)("div",{className:r.flexContainer,style:t,children:e})}var DI,e_,NI=g(()=>{DI=f(R(),1);Et();e_=te()({flexContainer:{display:"flex",flexDirection:"column"}})});function af({value:e,prefix:t,name:r}){let{classes:n}=t_(),[o,i]=(0,LI.useState)(!1),s=Object.keys(e[0]).sort(),a=new Set(s),c=Object.entries(e).map(([u,m])=>{let{id:d,...p}=m;return{id:u,identifier:d,...p}});for(let u of e)for(let m of Object.keys(u))a.add(m);let l;a.has("id")?(a.delete("id"),l=["identifier",...a]):l=[...a];let A=l.map(u=>sC(c.map(m=>m[u])));return a.size<s.length+5?(0,ar.jsxs)("div",{className:n.margin,children:[(0,ar.jsx)(Tr,{prefix:t,name:r}),(0,ar.jsx)(ai.FormControlLabel,{control:(0,ar.jsx)(ai.Checkbox,{checked:o,onChange:u=>{i(u.target.checked)}}),label:(0,ar.jsx)(ai.Typography,{variant:"body2",children:"Show options"})}),(0,ar.jsx)(sf,{children:(0,ar.jsx)(FI.DataGrid,{disableRowSelectionOnClick:!0,rows:c,rowHeight:20,columnHeaderHeight:35,hideFooter:c.length<25,showToolbar:o,columns:l.map((u,m)=>({field:u,width:A[m],renderCell:({value:d})=>(0,ar.jsx)("div",{className:n.cell,children:(0,ar.jsx)(un,{html:xu(d||"")})})}))})})]}):null}var ar,LI,ai,FI,t_,RI=g(()=>{ar=f(R(),1),LI=f(w(),1),ai=f(k(),1),FI=f(kI(),1);cs();NI();rf();ln();Et();t_=te()(e=>({margin:{marginBottom:e.spacing(4)},cell:{whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"}}))});function cf({name:e,value:t,description:r,prefix:n,width:o,formatter:i}){let{classes:s}=r_();return t!=null?(0,ls.jsxs)("div",{className:s.field,children:[(0,ls.jsx)(Tr,{prefix:n,description:r,name:e,width:o}),(0,ls.jsx)(dn,{value:i?i(t,e):t})]}):null}var ls,r_,PI=g(()=>{ls=f(R(),1);fc();cs();Et();r_=te()({field:{display:"flex",flexWrap:"wrap"}})});function lf({value:e,prefix:t,name:r}){let{classes:n}=n_(),{uri:o,baseUri:i=""}=e,s;try{s=new URL(o,i).href}catch{s=o}return(0,As.jsxs)("div",{className:n.field,children:[(0,As.jsx)(Tr,{prefix:t,name:r}),(0,As.jsx)(dn,{value:s})]})}var As,n_,OI=g(()=>{As=f(R(),1);fc();cs();Et();n_=te()({field:{display:"flex",flexWrap:"wrap"}})});function GI(e,t){return Math.ceil(yu(e.map(r=>Eu([...t,r[0]].join("."),12))))+10}function UI(e,t={}){let r=t;for(let n of e)Yt(r)&&(r=r[n]);return typeof r=="string"?r:Yt(r)&&typeof r.Description=="string"?r.Description:void 0}var HI=g(()=>{ln()});function _r(e){let{attributes:t,omit:r=[],omitSingleLevel:n=[],descriptions:o,formatter:i,hideUris:s,prefix:a=[]}=e,c=new Set([...r,...i_,...n]),{__jbrowsefmt:l,...A}=t,u=Object.entries({...A,...l}).filter(([d,p])=>p!=null&&!c.has(d)),m=GI(u,a);return(0,Wr.jsx)(Wr.Fragment,{children:u.map(([d,p])=>{let E=UI([...a,d],o);if(Array.isArray(p))return p.length>1&&p.every(x=>Yt(x))?(0,Wr.jsx)(af,{name:d,prefix:a,value:p},d):(0,Wr.jsx)(of,{name:d,value:p,formatter:i,description:E,prefix:a},d);if(Yt(p)){let{omitSingleLevel:x,...I}=e;return Fa(p)?s?null:(0,Wr.jsx)(lf,{name:d,prefix:a,value:p},d):(0,Wr.jsx)(_r,{...I,formatter:i,attributes:p,descriptions:o,prefix:[...a,d]},d)}else return(0,Wr.jsx)(cf,{name:d,formatter:i,value:p,description:E,prefix:a,width:Math.min(m,o_)},d)})})}var Wr,o_,i_,dc=g(()=>{Wr=f(R(),1);TI();RI();PI();OI();HI();ln();o_=170,i_=["__jbrowsefmt","length","position","subfeatures","uniqueId","exonFrames","parentId","thickStart","thickEnd","_lineHash"]});var jI,gc,Af=g(()=>{"use client";W();jI=f(R(),1),gc=(0,_.createSvgIcon)((0,jI.jsx)("path",{d:"M16.59 8.59 12 13.17 7.41 8.59 6 10l6 6 6-6z"}),"ExpandMore")});function zn({children:e,title:t,defaultExpanded:r=!0}){let{classes:n}=s_();return(0,Wn.jsxs)(gn.Accordion,{defaultExpanded:r,children:[(0,Wn.jsx)(gn.AccordionSummary,{expandIcon:(0,Wn.jsx)(gc,{className:n.icon}),children:(0,Wn.jsx)(gn.Typography,{variant:"button",children:t})}),(0,Wn.jsx)(gn.AccordionDetails,{className:n.expansionPanelDetails,children:e})]})}var Wn,gn,s_,uf=g(()=>{Wn=f(R(),1);Af();gn=f(k(),1);Et();s_=te()(e=>({expansionPanelDetails:{display:"block",padding:e.spacing(1)},icon:{color:e.palette.tertiary.contrastText||"#fff"}}))});function ft({checked:e,label:t,disabled:r,onChange:n}){return pc.default.createElement("div",null,pc.default.createElement(hc.FormControlLabel,{control:pc.default.createElement(hc.Checkbox,{disabled:r,checked:e,onChange:n}),label:t}))}var pc,hc,Cc=g(()=>{pc=f(w(),1),hc=f(k(),1)});function us({str:e}){let{classes:t}=a_(),[r,n]=(0,cr.useState)(!1),[o,i]=(0,cr.useState)(!1),[s,a]=(0,cr.useState)(!1),c=A=>A.replaceAll("-","").replaceAll(".",""),l=e.map(([A,u])=>[A,o?u:c(u)]).filter(([,A])=>s||!!A).map(([A,u])=>`>${A}
31
+ ${u}`).join(`
32
+ `);return cr.default.createElement(cr.default.Fragment,null,cr.default.createElement(Ec.Button,{color:"primary",variant:"contained",onClick:()=>{ki(l),n(!0),setTimeout(()=>{n(!1)},500)}},r?"Copied!":"Copy to clipboard"),cr.default.createElement(ft,{label:"Show gaps",checked:o,onChange:()=>{i(!o)}}),cr.default.createElement(ft,{label:"Show empty",checked:s,onChange:()=>{a(!s)}}),cr.default.createElement(Ec.TextField,{variant:"outlined",multiline:!0,className:t.dialogContent,minRows:5,maxRows:10,fullWidth:!0,value:l,slotProps:{input:{readOnly:!0,className:t.textAreaFont}}}))}var cr,Ec,qI,a_,ff=g(()=>{cr=f(w(),1),Ec=f(k(),1),qI=f(Se(),1);Cc();ql();a_=(0,qI.makeStyles)()({textAreaFont:{fontFamily:"Courier New",wordWrap:"break-word"},dialogContent:{background:"lightgrey",margin:4,minWidth:"80em"}})});var WI={};Ye(WI,{default:()=>l_});var ci,JI,VI,YI,c_,l_,zI=g(()=>{ci=f(w(),1);dc();uf();JI=f(we(),1),VI=f(k(),1),YI=f(G(),1);ff();c_=(0,YI.observer)(function({model:e,onClose:t}){let{header:r}=e;return ci.default.createElement(JI.Dialog,{onClose:()=>{t()},open:!0,title:"Metadata",maxWidth:"xl"},ci.default.createElement(VI.DialogContent,null,ci.default.createElement(_r,{attributes:r}),ci.default.createElement(zn,{title:"sequence"},ci.default.createElement(us,{str:e.rows}))))}),l_=c_});var KI={};Ye(KI,{default:()=>$I});function $I({model:e,onClose:t}){let[r,n]=(0,Be.useState)(!0),[o,i]=(0,Be.useState)(!0),[s,a]=(0,Be.useState)("viewport"),[c,l]=(0,Be.useState)(),A=(0,xe.useTheme)(),{totalWidth:u,totalHeight:m,treeAreaWidth:d,turnedOnTracks:p}=e,E=p.length>0,x=u+d,I=m,h=s==="entire"&&(x>1e4||I>1e4);return Be.default.createElement(Ic.Dialog,{onClose:()=>{t()},open:!0,title:"Export SVG"},Be.default.createElement(xe.DialogContent,null,c?Be.default.createElement(Ic.ErrorMessage,{error:c}):null,Be.default.createElement(xe.Typography,null,"Settings:"),Be.default.createElement(ft,{label:"Include minimap?",disabled:s==="entire",checked:r,onChange:()=>{n(!r)}}),E?Be.default.createElement(ft,{label:"Include tracks?",checked:o,onChange:()=>{i(!o)}}):null,Be.default.createElement("div",null,Be.default.createElement(xe.FormControl,null,Be.default.createElement(xe.FormLabel,null,"Export type"),Be.default.createElement(xe.RadioGroup,{value:s,onChange:y=>{a(y.target.value)}},Be.default.createElement(xe.FormControlLabel,{value:"entire",control:Be.default.createElement(xe.Radio,null),label:"Entire MSA"}),Be.default.createElement(xe.FormControlLabel,{value:"viewport",control:Be.default.createElement(xe.Radio,null),label:"Current viewport only"})))),h?Be.default.createElement(xe.Alert,{severity:"warning",style:{marginTop:8}},"The entire MSA is very large (",Math.round(x),"x",Math.round(I)," pixels). Export may be slow or fail."):null),Be.default.createElement(xe.DialogActions,null,Be.default.createElement(xe.Button,{variant:"contained",color:"primary",onClick:()=>{(async()=>{try{await e.exportSVG({theme:A,includeMinimap:s==="entire"?!1:r,includeTracks:E&&o,exportType:s}),t()}catch(y){console.error(y),l(y)}})()}},"Submit"),Be.default.createElement(xe.Button,{variant:"contained",color:"secondary",onClick:()=>{t()}},"Cancel")))}var Be,Ic,xe,XI=g(()=>{Be=f(w(),1),Ic=f(we(),1),xe=f(k(),1);Cc()});var nx={};Ye(nx,{default:()=>d_});var z,ex,Xe,fs,tx,rx,ZI,A_,u_,f_,m_,d_,ox=g(()=>{z=f(w(),1),ex=f(we(),1),Xe=f(k(),1),fs=f(G(),1),tx=f(Se(),1);ic();Cc();rx=(0,tx.makeStyles)()(e=>({field:{margin:e.spacing(4)},flex:{display:"flex"},minw:{width:"80em"}})),ZI=(e=0)=>+e.toFixed(1),A_=(0,fs.observer)(function({model:e}){return z.default.createElement(z.default.Fragment,null,z.default.createElement(u_,{model:e}),z.default.createElement(f_,{model:e}))}),u_=(0,fs.observer)(function({model:t}){let{drawTree:r,drawLabels:n,drawNodeBubbles:o,labelsAlignRight:i,showBranchLen:s}=t;return z.default.createElement("div",null,z.default.createElement("h1",null,"Tree options"),z.default.createElement(ft,{checked:s,label:"Show branch length?",onChange:()=>{t.setShowBranchLen(!s)}}),z.default.createElement(ft,{checked:o,label:"Draw clickable bubbles on tree branches?",onChange:()=>{t.setDrawNodeBubbles(!o)}}),z.default.createElement(ft,{checked:r,label:"Show tree?",onChange:()=>{t.setDrawTree(!r)}}),z.default.createElement(ft,{checked:i,label:"Tree labels align right?",onChange:()=>{t.setLabelsAlignRight(!i)}}),z.default.createElement(ft,{checked:n,label:"Draw labels",onChange:()=>{t.setDrawLabels(!n)}}))}),f_=(0,fs.observer)(function({model:t}){let{classes:r}=rx(),{bgColor:n,colWidth:o,allowedGappyness:i,drawMsaLetters:s,colorSchemeName:a,hideGaps:c,rowHeight:l}=t;return z.default.createElement("div",null,z.default.createElement("h1",null,"MSA options"),z.default.createElement(ft,{checked:s,label:"Draw letters",onChange:()=>{t.setDrawMsaLetters(!s)}}),z.default.createElement(ft,{checked:n,label:"Color letters instead of background of tiles",onChange:()=>{t.setBgColor(!n)}}),z.default.createElement(ft,{checked:c,label:"Enable hiding gappy columns?",onChange:()=>{t.setHideGaps(!c)}}),c?z.default.createElement("div",{className:r.flex},z.default.createElement(Xe.Typography,null,"Hide columns w/ >",i,"% gaps"),z.default.createElement(Xe.Slider,{className:r.field,min:1,max:100,value:i,onChange:(A,u)=>{t.setAllowedGappyness(u)}})):null,z.default.createElement("div",{className:r.flex},z.default.createElement(Xe.Typography,null,"Column width (",ZI(o),"px)"),z.default.createElement(Xe.Slider,{className:r.field,min:1,max:50,value:o,onChange:(A,u)=>{t.setColWidth(u)}})),z.default.createElement("div",{className:r.flex},z.default.createElement(Xe.Typography,null,"Row height (",ZI(l),"px)"),z.default.createElement(Xe.Slider,{className:r.field,min:1,max:50,value:l,onChange:(A,u)=>{t.setRowHeight(u)}})),z.default.createElement(Xe.TextField,{select:!0,label:"Color scheme",value:a,onChange:A=>{t.setColorSchemeName(A.target.value)}},Object.keys(ii).map(A=>z.default.createElement(Xe.MenuItem,{key:A,value:A},A))))}),m_=(0,fs.observer)(function({model:e,onClose:t}){let{classes:r}=rx();return z.default.createElement(ex.Dialog,{open:!0,title:"Settings",maxWidth:"xl",onClose:()=>{t()}},z.default.createElement(Xe.DialogContent,{className:r.minw},z.default.createElement(A_,{model:e}),z.default.createElement(Xe.DialogActions,null,z.default.createElement(Xe.Button,{variant:"contained",color:"primary",onClick:()=>{t()}},"Submit"))))}),d_=m_});var $n,ix,g_,p_,h_,C_,sx,ax=g(()=>{$n=f(w(),1);ni();NE();Ju();RE();Yu();ix=f(G(),1);gI();g_=(0,$n.lazy)(()=>Promise.resolve().then(()=>(zI(),WI))),p_=(0,$n.lazy)(()=>Promise.resolve().then(()=>(XI(),KI))),h_=(0,$n.lazy)(()=>Promise.resolve().then(()=>(ox(),nx))),C_=(0,ix.observer)(({model:e})=>$n.default.createElement(vr,{menuItems:[{label:"Return to import form",icon:os,onClick:()=>{e.reset()}},{label:"Metadata",icon:DE,onClick:()=>{e.queueDialog(t=>[g_,{model:e,onClose:t}])}},{label:"More settings",icon:sc,onClick:()=>{e.queueDialog(t=>[h_,{model:e,onClose:t}])}},{label:"Domain settings",type:"subMenu",subMenu:dI({model:e})},{label:"Export SVG",icon:FE,onClick:()=>{e.queueDialog(t=>[p_,{onClose:t,model:e}])}}],anchorOrigin:{vertical:"bottom",horizontal:"left"},transformOrigin:{vertical:"top",horizontal:"left"}},$n.default.createElement(os,null))),sx=C_});var xc,yc,cx,E_,lx,Ax=g(()=>{xc=f(w(),1),yc=f(k(),1),cx=f(G(),1),E_=(0,cx.observer)(function({model:t}){let{hideGaps:r,allowedGappyness:n}=t;return r?xc.default.createElement("div",{style:{display:"flex",alignItems:"center",gap:8}},xc.default.createElement(yc.Typography,{style:{whiteSpace:"nowrap"}},"Hide columns w/ >",n,"% gaps"),xc.default.createElement(yc.Slider,{style:{width:100},min:1,max:100,value:n,onChange:(o,i)=>{t.setAllowedGappyness(i)}})):null}),lx=E_});var ux,fx,mx,dx,I_,x_,gx,px=g(()=>{ux=f(w(),1),fx=f(k(),1),mx=f(G(),1),dx=f(Se(),1),I_=(0,dx.makeStyles)()({margin:{margin:"auto",marginLeft:10}}),x_=(0,mx.observer)(function({model:e}){let{mouseOverRowName:t,mouseCol:r}=e,{classes:n}=I_();return t&&r!==void 0?ux.default.createElement(fx.Typography,{className:n.margin},t,":",e.visibleColToSeqPosOneBased(t,r)," (",e.visibleColToRowLetter(t,r),")"):null}),gx=x_});var ms,hx,bc,Cx,Ex,y_,b_,Ix,xx=g(()=>{ms=f(w(),1),hx=f(we(),1),bc=f(k(),1),Cx=f(G(),1),Ex=f(Se(),1),y_=(0,Ex.makeStyles)()({margin:{margin:"auto",marginLeft:10}}),b_=(0,Cx.observer)(({model:e})=>{let{status:t}=e,{classes:r}=y_();return t?ms.default.createElement(bc.Typography,{className:r.margin},ms.default.createElement(hx.LoadingEllipses,{message:t.msg,component:"span"})," ",t.url?ms.default.createElement("a",{href:t.url,target:"_blank",rel:"noreferrer"},"(status)"):null," ",t.onCancel?ms.default.createElement(bc.Button,{size:"small",onClick:()=>t.onCancel?.()},"Cancel"):null):null}),Ix=b_});var yx,bx,wx=g(()=>{"use client";W();yx=f(R(),1),bx=(0,_.createSvgIcon)((0,yx.jsx)("path",{d:"M3 17v2h6v-2zM3 5v2h10V5zm10 16v-2h8v-2h-8v-2h-2v6zM7 9v2H3v2h4v2h2V9zm14 4v-2H11v2zm-6-4h2V7h4V5h-4V3h-2z"}),"Tune")});function Bx(e){let{drawMsaLetters:t,hideGaps:r,bgColor:n}=e;return[{label:"Draw letters",type:"checkbox",checked:t,onClick:()=>{e.setDrawMsaLetters(!t)}},{label:"Color letters instead of background of tiles",type:"checkbox",checked:!n,onClick:()=>{e.setBgColor(!n)}},{label:"Enable hiding gappy columns?",type:"checkbox",checked:r,onClick:()=>{e.setHideGaps(!r)}}]}function Sx(e){let{drawTree:t,showBranchLen:r,labelsAlignRight:n,drawNodeBubbles:o,drawLabels:i}=e;return[{label:"Show branch length",type:"checkbox",checked:r,onClick:()=>{e.setShowBranchLen(!r)}},{label:"Show tree",type:"checkbox",checked:t,onClick:()=>{e.setDrawTree(!t)}},{label:"Draw clickable bubbles on tree branches",type:"checkbox",checked:o,onClick:()=>{e.setDrawNodeBubbles(!o)}},{label:"Tree labels align right",type:"checkbox",checked:n,onClick:()=>{e.setLabelsAlignRight(!n)}},{label:"Draw labels",type:"checkbox",checked:i,onClick:()=>{e.setDrawLabels(!i)}}]}var mf=g(()=>{});var df,Qx,w_,Mx,vx=g(()=>{df=f(w(),1);ni();wx();Qx=f(G(),1);mf();w_=(0,Qx.observer)(function({model:e}){return df.default.createElement(vr,{closeAfterItemClick:!1,anchorOrigin:{vertical:"bottom",horizontal:"left"},transformOrigin:{vertical:"top",horizontal:"left"},menuItems:Bx(e)},df.default.createElement(bx,null))}),Mx=w_});var gf,wc,Tx,B_,_x,kx=g(()=>{gf=f(w(),1),wc=f(k(),1),Tx=f(G(),1),B_=(0,Tx.observer)(function({model:e}){let{currentAlignment:t,alignmentNames:r}=e;return r.length>0?gf.default.createElement(wc.TextField,{select:!0,variant:"outlined",value:t,size:"small",onChange:n=>{e.setCurrentAlignment(+n.target.value),e.setScrollX(0),e.setScrollY(0)}},r.map((n,o)=>gf.default.createElement(wc.MenuItem,{key:`${n}-${o}`,value:o},n))):null}),_x=B_});var Dx,Nx,Lx=g(()=>{"use client";W();Dx=f(R(),1),Nx=(0,_.createSvgIcon)((0,Dx.jsx)("path",{d:"M22 11V3h-7v3H9V3H2v8h7V8h2v10h4v3h7v-8h-7v3h-2V8h2v3z"}),"AccountTree")});var pf,Fx,S_,Rx,Px=g(()=>{pf=f(w(),1);ni();Lx();Fx=f(G(),1);mf();S_=(0,Fx.observer)(function({model:e}){let{rows:t}=e;return pf.default.createElement(vr,{closeAfterItemClick:!1,anchorOrigin:{vertical:"bottom",horizontal:"left"},transformOrigin:{vertical:"top",horizontal:"left"},menuItems:[...Sx(e),...t.length>=2?[{label:"Advanced",type:"subMenu",subMenu:[{label:"Calculate neighbor joining tree (BLOSUM62)",onClick:()=>{try{e.calculateNeighborJoiningTreeFromMSA()}catch(r){console.error("Failed to calculate NJ tree:",r),e.setError(r)}}}]}]:[]]},pf.default.createElement(Nx,null))}),Rx=S_});var hf,Ox,Gx=g(()=>{"use client";W();hf=f(R(),1),Ox=(0,_.createSvgIcon)([(0,hf.jsx)("path",{d:"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14"},"0"),(0,hf.jsx)("path",{d:"M12 10h-2v2H9v-2H7V9h2V7h1v2h2z"},"1")],"ZoomIn")});var Ux,Hx,jx=g(()=>{"use client";W();Ux=f(R(),1),Hx=(0,_.createSvgIcon)((0,Ux.jsx)("path",{d:"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14M7 9h5v1H7z"}),"ZoomOut")});var Kn,Cf,qx,Q_,Jx,Vx=g(()=>{Kn=f(w(),1);Gx();jx();Cf=f(k(),1),qx=f(G(),1),Q_=(0,qx.observer)(function({model:t}){return Kn.default.createElement(Kn.default.Fragment,null,Kn.default.createElement(Cf.IconButton,{onClick:()=>{t.zoomIn()}},Kn.default.createElement(Ox,null)),Kn.default.createElement(Cf.IconButton,{onClick:()=>{t.zoomOut()}},Kn.default.createElement(Hx,null)))}),Jx=Q_});var Yx,Wx,zx=g(()=>{"use client";W();Yx=f(R(),1),Wx=(0,_.createSvgIcon)((0,Yx.jsx)("path",{d:"M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2m0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2m0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2"}),"MoreVert")});var $x,Kx,Xx=g(()=>{"use client";W();$x=f(R(),1),Kx=(0,_.createSvgIcon)((0,$x.jsx)("path",{d:"M12 5V2L8 6l4 4V7c3.31 0 6 2.69 6 6 0 2.97-2.17 5.43-5 5.91v2.02c3.95-.49 7-3.85 7-7.93 0-4.42-3.58-8-8-8m-6 8c0-1.65.67-3.15 1.76-4.24L6.34 7.34C4.9 8.79 4 10.79 4 13c0 4.08 3.05 7.44 7 7.93v-2.02c-2.83-.48-5-2.94-5-5.91"}),"RestartAlt")});var Ef,Zx,M_,ey,ty=g(()=>{Ef=f(w(),1);ni();zx();Xx();Zx=f(G(),1),M_=(0,Zx.observer)(function({model:e}){return Ef.default.createElement(vr,{menuItems:[{label:"Fit both vertically/horizontally",onClick:()=>{e.fit()}},{label:"Fit vertically",onClick:()=>{e.fitVertically()}},{label:"Fit horizontally",onClick:()=>{e.fitHorizontally()}},{label:"Reset zoom to default",icon:Kx,onClick:()=>{e.resetZoom()}}]},Ef.default.createElement(Wx,null))}),ey=M_});var ry,ny=g(()=>{ry="5.1.1"});var sy={};Ye(sy,{default:()=>iy});function iy({onClose:e}){return He.default.createElement(oy.Dialog,{open:!0,title:"About",onClose:()=>{e()}},He.default.createElement(Bt.DialogContent,null,He.default.createElement(Bt.Typography,null,"MSAView ",ry," (",He.default.createElement(Bt.Link,{href:"https://github.com/gmod/react-msaview"},"Github"),")"),He.default.createElement("ul",null,He.default.createElement("li",null,He.default.createElement(Bt.Typography,null,"We use some color schemes from the"," ",He.default.createElement(Bt.Link,{href:"https://github.com/biotite-dev/biotite"},"biotite")," ","project, and their license is reproduced"," ",He.default.createElement(Bt.Link,{href:"https://github.com/biotite-dev/biotite/blob/master/LICENSE.rst"},"here"))),He.default.createElement("li",null,He.default.createElement(Bt.Typography,null,"See this page for some information on jalview colorings"," ",He.default.createElement(Bt.Link,{href:"https://www.jalview.org/help/html/colourSchemes/"},"here"))),He.default.createElement("li",null,He.default.createElement(Bt.Typography,null,"See this page for some info on the clustal, cinema, maeditor, and lesk color schemes"," ",He.default.createElement(Bt.Link,{href:"http://www.bioinformatics.nl/~berndb/aacolour.html"},"here"))),He.default.createElement("li",null,He.default.createElement(Bt.Typography,null,"See this paper about the flower color scheme"," ",He.default.createElement(Bt.Link,{href:"https://www.ncbi.nlm.nih.gov/pmc/articles/PMC7245768/"},"here"))))))}var He,oy,Bt,ay=g(()=>{He=f(w(),1),oy=f(we(),1),Bt=f(k(),1);ny()});function __(){return Fe.default.createElement("div",{style:{flex:1}})}var Fe,cy,ly,v_,T_,Ay,uy=g(()=>{Fe=f(w(),1);mg();pg();cy=f(k(),1),ly=f(G(),1);_E();ax();Ax();px();xx();vx();kx();Px();Vx();ty();v_=(0,Fe.lazy)(()=>Promise.resolve().then(()=>(ay(),sy))),T_=(0,ly.observer)(function({model:e}){let[t,{height:r}]=Yl();return(0,Fe.useEffect)(()=>{e.setHeaderHeight(r||0)},[e,r]),Fe.default.createElement("div",{ref:t,style:{display:"flex"}},Fe.default.createElement(sx,{model:e}),Fe.default.createElement(TE,{model:e}),Fe.default.createElement(Rx,{model:e}),Fe.default.createElement(Mx,{model:e}),Fe.default.createElement(Jx,{model:e}),Fe.default.createElement(ey,{model:e}),Fe.default.createElement(lx,{model:e}),Fe.default.createElement("div",{style:{paddingLeft:20,margin:"auto"}},Fe.default.createElement(_x,{model:e})),Fe.default.createElement(gx,{model:e}),Fe.default.createElement(__,null),Fe.default.createElement(Ix,{model:e}),Fe.default.createElement(cy.IconButton,{onClick:()=>{e.queueDialog(n=>[v_,{onClose:n}])}},Fe.default.createElement(gg,null)))});Ay=T_});var kr,fy,k_,my,dy=g(()=>{kr=f(w(),1),fy=f(G(),1);Vl();k_=(0,fy.observer)(function({model:e}){let[t,r]=(0,kr.useState)(!1),{scrollX:n,msaAreaWidth:o,minimapHeight:i,colWidth:s,numColumns:a}=e,c=o/a/s,l=-n,A=l+o,u=l*c,m=A*c,d="rgba(66, 119, 127, 0.3)",p=Math.max(m-u,20),{startDrag:E}=$s("x",(0,kr.useCallback)((h,y)=>{e.setScrollX(y-h/c)},[e,c])),x=12,I=i-x;return kr.default.createElement("div",{style:{position:"relative",height:i,width:"100%"}},kr.default.createElement("div",{style:{height:x,boxSizing:"border-box",border:"1px solid #555"}}),kr.default.createElement("div",{style:{position:"absolute",top:0,left:Math.max(0,u),background:t?"rgba(66,119,127,0.6)":d,cursor:"pointer",height:x,width:p,zIndex:100},onMouseOver:()=>{r(!0)},onMouseOut:()=>{r(!1)},onMouseDown:h=>{E(h,e.scrollX)}}),kr.default.createElement("svg",{height:I,style:{width:"100%"}},kr.default.createElement("polygon",{fill:d,points:[[u+p,0],[u,0],[0,I],[o,I]].toString()})))}),my=k_});function If(){return Bc.default.createElement("div",{style:{position:"absolute",left:"50%",top:"50%"}},Bc.default.createElement(Sc.CircularProgress,null),Bc.default.createElement(Sc.Typography,null,"Loading..."))}var Bc,Sc,gy=g(()=>{Bc=f(w(),1),Sc=f(k(),1)});function Qc({model:e,offsetX:t,offsetY:r,ctx:n,highResScaleFactorOverride:o,blockSizeYOverride:i}){let{leaves:s,blockSize:a,rowHeight:c,highResScaleFactor:l,showDomains:A}=e;if(A){let u=o||l,m=i||a;n.resetTransform(),n.scale(u,u),n.translate(-t,c/2-r);let d=Math.max(0,Math.floor((r-c)/c)),p=Math.max(0,Math.ceil((r+m+c)/c)),E=s.slice(d,p);D_({model:e,ctx:n,visibleLeaves:E})}}function D_({model:e,ctx:t,visibleLeaves:r}){let{subFeatureRows:n,colWidth:o,rowHeight:i,fillPalette:s,strokePalette:a,tidyFilteredGatheredInterProAnnotations:c}=e;for(let l=0,A=r.length;l<A;l++){let u=r[l],{x:m,data:{name:d}}=u,p=m,E=c[d];if(E)for(let x=0,I=E.length;x<I;x++){let{start:h,end:y,accession:Q}=E[x],M=e.seqPosToVisibleCol(d,h-1),B=e.seqPosToVisibleCol(d,y);if(M===void 0||B===void 0)continue;let v=M*o;t.fillStyle=s[Q],t.strokeStyle=a[Q];let P=n?4:i,N=p-i+(n?x*P:0),$=o*(B-M);t.fillRect(v,N,$,P),t.strokeRect(v,N,$,P)}}}var xf=g(()=>{});function Mc({model:e,offsetX:t,offsetY:r,contrastScheme:n,ctx:o,theme:i,highResScaleFactorOverride:s,blockSizeXOverride:a,blockSizeYOverride:c}){let{colWidth:l,blockSize:A,rowHeight:u,fontSize:m,highResScaleFactor:d,actuallyShowDomains:p,leaves:E,bgColor:x}=e,I=s||d,h=a||A,y=c||A;o.resetTransform(),o.scale(I,I),o.translate(-t,u/2-r),o.textAlign="center",o.font=o.font.replace(/(?:bold )?\d+px/,`${x?"":"bold "}${m}px`);let Q=Math.max(0,Math.floor((r-u)/u)),M=Math.max(0,Math.ceil((r+y+u)/u)),B=Math.max(0,Math.floor(t/l)),v=Math.max(0,Math.ceil((t+h)/l)),P=E.slice(Q,M);p||N_({model:e,ctx:o,theme:i,offsetX:t,xStart:B,xEnd:v,visibleLeaves:P}),L_({model:e,ctx:o,offsetX:t,contrastScheme:n,xStart:B,xEnd:v,visibleLeaves:P}),F_({model:e,ctx:o,xStart:B,xEnd:v,visibleLeaves:P}),o.resetTransform()}function N_({model:e,offsetX:t,ctx:r,visibleLeaves:n,theme:o,xStart:i,xEnd:s}){let{bgColor:a,colorSchemeName:c,colorScheme:l,columns:A,colWidth:u,rowHeight:m,relativeTo:d}=e,p=d?A[d]?.slice(i,s):null,E=c==="clustalx_protein_dynamic",x=c==="percent_identity_dynamic",I=t-t%u;for(let h=0,y=n.length;h<y;h++){let Q=n[h],{data:{name:M}}=Q,B=Q.x,v=A[M]?.slice(i,s);if(v)for(let P=0,N=v.length;P<N;P++){let $=v[P],S=p&&M!==d&&$===p[P],L;if(E)L=e.colClustalX[i+P][$];else if(x){let J=e.colConsensus[i+P];L=$===J.letter?J.color:void 0}else L=l[$.toUpperCase()];if(a||E||x){let J=S?o.palette.action.hover:L||o.palette.background.default;r.fillStyle=J,r.fillRect(P*u+I,B-m,u,m)}}}}function L_({model:e,offsetX:t,contrastScheme:r,ctx:n,visibleLeaves:o,xStart:i,xEnd:s}){let{bgColor:a,actuallyShowDomains:c,showMsaLetters:l,colorScheme:A,columns:u,colWidth:m,rowHeight:d,relativeTo:p}=e,E=p?u[p]?.slice(i,s):null;if(l){let x=t-t%m,I=m/2,h=d/4;for(let y=0,Q=o.length;y<Q;y++){let M=o[y],{data:{name:B}}=M,v=M.x-h,P=u[B]?.slice(i,s);if(P)for(let N=0,$=P.length;N<$;N++){let S=P[N],J=E&&B!==p&&S===E[N]?".":S,O=A[S.toUpperCase()],Te=r[S.toUpperCase()]||"black";n.fillStyle=c?"black":a?Te:O||"black",n.fillText(J,N*m+x+I,v)}}}}function F_({model:e,ctx:t,visibleLeaves:r,xStart:n,xEnd:o}){let{bgColor:i,hideGapsEffective:s}=e;s&&(t.lineWidth=1,t.strokeStyle="#f0f",py({visibleLeaves:r,xStart:n,ctx:t,model:e,xEnd:o,offset:0}),t.strokeStyle=i?"#fff":"#000",py({visibleLeaves:r,xStart:n,ctx:t,model:e,xEnd:o,offset:-1}))}function py({model:e,ctx:t,visibleLeaves:r,xStart:n,xEnd:o,offset:i}){let{colWidth:a,rowHeight:c,insertionPositions:l}=e;for(let A of r){let{name:u}=A.data,m=l.get(u);if(m){let d=A.x;for(let{pos:p}of m)if(p>=n&&p<o){let E=p*a,x=d-c,I=d;t.beginPath(),t.moveTo(E+i,x+i);let h=x,y=!0;for(;h<I;){let Q=Math.min(h+2,I),M=y?E+1:E-1;t.lineTo(M+i,Q+i),h=Q,y=!y}t.stroke()}}}}var yf=g(()=>{});function vc(e){let t=(0,Cy.useTheme)(),r=(0,hy.useMemo)(()=>rs(e,t),[e,t]);return{theme:t,contrastScheme:r}}var hy,Cy,bf=g(()=>{hy=f(w(),1),Cy=f(k(),1);Yn()});function Ey(e,t,r,n,o,i){let{left:s,top:a}=t.getBoundingClientRect();return{col:Math.floor((e.clientX-s+r)/o),row:Math.floor((e.clientY-a+n)/i)}}var lr,Iy,xy,yy,R_,by,wy=g(()=>{lr=f(w(),1),Iy=f(we(),1),xy=f(Gr(),1),yy=f(G(),1);xf();yf();bf();R_=(0,yy.observer)(function({model:e,offsetX:t,offsetY:r}){let{colWidth:n,rowHeight:o,scrollY:i,scrollX:s,colorScheme:a,blockSize:c,mouseClickCol:l,mouseClickRow:A,highResScaleFactor:u}=e,{theme:m,contrastScheme:d}=vc(a),p=(0,lr.useRef)(null);(0,lr.useEffect)(()=>{let h=p.current?.getContext("2d");if(h)return(0,xy.autorun)(()=>{h.resetTransform(),h.clearRect(0,0,c*u,c*u),e.actuallyShowDomains&&Qc({ctx:h,offsetX:t,offsetY:r,model:e}),Mc({ctx:h,theme:m,offsetX:t,offsetY:r,contrastScheme:d,model:e})})},[e,t,r,m,c,u,d]);let[E,x]=(0,lr.useState)(),{hoveredInsertion:I}=e;return lr.default.createElement(lr.default.Fragment,null,lr.default.createElement("canvas",{ref:p,onMouseMove:h=>{if(p.current){x({x:h.clientX,y:h.clientY});let{col:y,row:Q}=Ey(h,p.current,t,r,n,o);y>=0&&y<e.numColumns&&Q>=0&&Q<e.numRows?e.setMousePos(y,Q):e.setMousePos(void 0,void 0)}},onClick:h=>{if(p.current){let{col:y,row:Q}=Ey(h,p.current,t,r,n,o);y===l&&Q===A?e.setMouseClickPos(void 0,void 0):e.setMouseClickPos(y,Q)}},onMouseLeave:()=>{e.setMousePos(),x(void 0)},width:c*u,height:c*u,style:{position:"absolute",top:i+r,left:s+t,width:c,height:c}}),I&&E?lr.default.createElement(Iy.BaseTooltip,{clientPoint:{x:E.x,y:E.y+15}},"Insertion (",I.letters.length,e.sequenceType==="amino"?"aa":"bp","):"," ",I.letters.length>20?`${I.letters.slice(0,20)}...`:I.letters):null)}),by=R_});var zr,By,P_,Sy,Qy=g(()=>{zr=f(w(),1),By=f(G(),1);gy();wy();zs();P_=(0,By.observer)(function({model:e}){let{MSA:t,verticalScrollbarWidth:r,msaFilehandle:n,height:o,msaAreaWidth:i,blocks2d:s}=e,a=(0,zr.useRef)(null),c=(0,zr.useCallback)(m=>{e.doScrollX(m)},[e]),l=(0,zr.useCallback)(m=>{e.doScrollY(m)},[e]),{onMouseDown:A,onMouseUp:u}=xo({ref:a,onScrollX:c,onScrollY:l});return zr.default.createElement("div",{ref:a,onMouseDown:A,onMouseUp:u,onMouseLeave:m=>{m.preventDefault()},style:{position:"relative",height:o,width:i-r,overflow:"hidden"}},!t&&!n?null:t?s.map(([m,d])=>zr.default.createElement(by,{key:`${m}_${d}`,model:e,offsetX:m,offsetY:d})):zr.default.createElement(If,null))}),Sy=P_});function vy({ctx:e,model:t}){let{mouseCol:r,colWidth:n,msaAreaWidth:o,verticalScrollbarWidth:i,height:s,rowHeight:a,scrollX:c,scrollY:l,mouseRow:A,mouseClickRow:u,mouseClickCol:m,relativeTo:d,rowNamesSet:p,hoveredTreeNode:E,highlightedColumns:x}=t,I=o-i;if(e.resetTransform(),e.clearRect(0,0,I,s),d){let h=p.get(d);h!==void 0&&(e.fillStyle=O_,e.fillRect(0,h*a+l,I,a))}if(E){e.fillStyle=G_;for(let h of E.descendantNames){let y=p.get(h);y!==void 0&&e.fillRect(0,y*a+l,I,a)}}if(x?.length){e.fillStyle=wf;for(let h of x)e.fillRect(h*n+c,0,n,s)}r!==void 0&&(e.fillStyle=My,e.fillRect(r*n+c,0,n,s)),A!==void 0&&(e.fillStyle=My,e.fillRect(0,A*a+l,I,a)),m!==void 0&&(e.fillStyle=wf,e.fillRect(m*n+c,0,n,s)),u!==void 0&&(e.fillStyle=wf,e.fillRect(0,u*a+l,I,a))}var My,wf,O_,G_,Ty=g(()=>{My="rgba(0,0,0,0.15)",wf="rgba(128,128,0,0.2)",O_="rgba(0,128,255,0.3)",G_="rgba(255,165,0,0.15)"});var li,_y,ky,Dy,U_,Ny,Ly=g(()=>{li=f(w(),1),_y=f(_t(),1),ky=f(Gr(),1),Dy=f(G(),1);Ty();U_=(0,Dy.observer)(function({model:e}){let t=(0,li.useRef)(null),{height:r,msaAreaWidth:n,verticalScrollbarWidth:o}=e,i=n-o;return(0,li.useEffect)(()=>{let s=t.current?.getContext("2d");return s?(0,ky.autorun)(()=>{(0,_y.isAlive)(e)&&vy({ctx:s,model:e})}):void 0},[e]),li.default.createElement("canvas",{ref:t,id:"mouseover",width:i,height:r,style:{position:"absolute",top:0,left:0,width:i,height:r,zIndex:1e3,pointerEvents:"none"}})}),Ny=U_});var Tc,Fy,H_,Ry,Py=g(()=>{Tc=f(w(),1),Fy=f(G(),1);Qy();Ly();H_=(0,Fy.observer)(function({model:e}){return Tc.default.createElement("div",{style:{position:"relative"}},Tc.default.createElement(Sy,{model:e}),Tc.default.createElement(Ny,{model:e}))}),Ry=H_});var ds,Oy=g(()=>{ds=class{constructor(){this.ids=[],this.values=[],this.length=0}clear(){this.length=0}push(t,r){let n=this.length++;for(;n>0;){let o=n-1>>1,i=this.values[o];if(r>=i)break;this.ids[n]=this.ids[o],this.values[n]=i,n=o}this.ids[n]=t,this.values[n]=r}pop(){if(this.length===0)return;let t=this.ids,r=this.values,n=t[0],o=--this.length;if(o>0){let i=t[o],s=r[o],a=0,c=o>>1;for(;a<c;){let l=(a<<1)+1,A=l+1,u=l+(+(A<o)&+(r[A]<r[l]));if(r[u]>=s)break;t[a]=t[u],r[a]=r[u],a=u}t[a]=i,r[a]=s}return n}peek(){return this.length>0?this.ids[0]:void 0}peekValue(){return this.length>0?this.values[0]:void 0}shrink(){this.ids.length=this.values.length=this.length}}});function Uy(e,t){let r=0,n=t.length-1;for(;r<n;){let o=r+n>>1;t[o]>e?n=o:r=o+1}return t[r]}function j_(e,t,r,n,o,i){let s=[n,o];for(;s.length;){let a=s.pop()||0,c=s.pop()||0;if(a-c<=i&&Math.floor(c/i)>=Math.floor(a/i))continue;let l=e[c],A=e[c+a>>1],u=e[a],m=l>A!=l>u?l:A<l!=A<u?A:u,d=c-1,p=a+1;for(;;){do d++;while(e[d]<m);do p--;while(e[p]>m);if(d>=p)break;q_(e,t,r,d,p)}s.push(c,p,p+1,a)}}function q_(e,t,r,n,o){let i=e[n];e[n]=e[o],e[o]=i;let s=4*n,a=4*o,c=t[s],l=t[s+1],A=t[s+2],u=t[s+3];t[s]=t[a],t[s+1]=t[a+1],t[s+2]=t[a+2],t[s+3]=t[a+3],t[a]=c,t[a+1]=l,t[a+2]=A,t[a+3]=u;let m=r[n];r[n]=r[o],r[o]=m}function J_(e,t){let r=e^t,n=65535^r,o=65535^(e|t),i=e&(t^65535),s=r|n>>1,a=r>>1^r,c=o>>1^n&i>>1^o,l=r&o>>1^i>>1^i;r=s,n=a,o=c,i=l,s=r&r>>2^n&n>>2,a=r&n>>2^n&(r^n)>>2,c^=r&o>>2^n&i>>2,l^=n&o>>2^(r^n)&i>>2,r=s,n=a,o=c,i=l,s=r&r>>4^n&n>>4,a=r&n>>4^n&(r^n)>>4,c^=r&o>>4^n&i>>4,l^=n&o>>4^(r^n)&i>>4,r=s,n=a,o=c,i=l,c^=r&o>>8^n&i>>8,l^=n&o>>8^(r^n)&i>>8,r=c^c>>1,n=l^l>>1;let A=e^t,u=n|65535^(A|r);return A=(A|A<<8)&16711935,A=(A|A<<4)&252645135,A=(A|A<<2)&858993459,A=(A|A<<1)&1431655765,u=(u|u<<8)&16711935,u=(u|u<<4)&252645135,u=(u|u<<2)&858993459,u=(u|u<<1)&1431655765,(u<<1|A)>>>0}var Gy,Bf,gs,Hy=g(()=>{Oy();Gy=[Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array],Bf=3,gs=class e{static from(t,r=0){if(r%8!==0)throw new Error("byteOffset must be 8-byte aligned.");if(!t||t.byteLength===void 0||t.buffer)throw new Error("Data must be an instance of ArrayBuffer or SharedArrayBuffer.");let[n,o]=new Uint8Array(t,r+0,2);if(n!==251)throw new Error("Data does not appear to be in a Flatbush format.");let i=o>>4;if(i!==Bf)throw new Error(`Got v${i} data when expected v${Bf}.`);let s=Gy[o&15];if(!s)throw new Error("Unrecognized array type.");let[a]=new Uint16Array(t,r+2,1),[c]=new Uint32Array(t,r+4,1);return new e(c,a,s,void 0,t,r)}constructor(t,r=16,n=Float64Array,o=ArrayBuffer,i,s=0){if(t===void 0)throw new Error("Missing required argument: numItems.");if(isNaN(t)||t<=0)throw new Error(`Unexpected numItems value: ${t}.`);this.numItems=+t,this.nodeSize=Math.min(Math.max(+r,2),65535),this.byteOffset=s;let a=t,c=a;this._levelBounds=[a*4];do a=Math.ceil(a/this.nodeSize),c+=a,this._levelBounds.push(c*4);while(a!==1);this.ArrayType=n,this.IndexArrayType=c<16384?Uint16Array:Uint32Array;let l=Gy.indexOf(n),A=c*4*n.BYTES_PER_ELEMENT;if(l<0)throw new Error(`Unexpected typed array class: ${n}.`);if(i)this.data=i,this._boxes=new n(i,s+8,c*4),this._indices=new this.IndexArrayType(i,s+8+A,c),this._pos=c*4,this.minX=this._boxes[this._pos-4],this.minY=this._boxes[this._pos-3],this.maxX=this._boxes[this._pos-2],this.maxY=this._boxes[this._pos-1];else{let u=this.data=new o(8+A+c*this.IndexArrayType.BYTES_PER_ELEMENT);this._boxes=new n(u,8,c*4),this._indices=new this.IndexArrayType(u,8+A,c),this._pos=0,this.minX=1/0,this.minY=1/0,this.maxX=-1/0,this.maxY=-1/0,new Uint8Array(u,0,2).set([251,(Bf<<4)+l]),new Uint16Array(u,2,1)[0]=r,new Uint32Array(u,4,1)[0]=t}this._queue=new ds}add(t,r,n=t,o=r){let i=this._pos>>2,s=this._boxes;return this._indices[i]=i,s[this._pos++]=t,s[this._pos++]=r,s[this._pos++]=n,s[this._pos++]=o,t<this.minX&&(this.minX=t),r<this.minY&&(this.minY=r),n>this.maxX&&(this.maxX=n),o>this.maxY&&(this.maxY=o),i}finish(){if(this._pos>>2!==this.numItems)throw new Error(`Added ${this._pos>>2} items when expected ${this.numItems}.`);let t=this._boxes;if(this.numItems<=this.nodeSize){t[this._pos++]=this.minX,t[this._pos++]=this.minY,t[this._pos++]=this.maxX,t[this._pos++]=this.maxY;return}let r=this.maxX-this.minX||1,n=this.maxY-this.minY||1,o=new Uint32Array(this.numItems),i=65535;for(let s=0,a=0;s<this.numItems;s++){let c=t[a++],l=t[a++],A=t[a++],u=t[a++],m=Math.floor(i*((c+A)/2-this.minX)/r),d=Math.floor(i*((l+u)/2-this.minY)/n);o[s]=J_(m,d)}j_(o,t,this._indices,0,this.numItems-1,this.nodeSize);for(let s=0,a=0;s<this._levelBounds.length-1;s++){let c=this._levelBounds[s];for(;a<c;){let l=a,A=t[a++],u=t[a++],m=t[a++],d=t[a++];for(let p=1;p<this.nodeSize&&a<c;p++)A=Math.min(A,t[a++]),u=Math.min(u,t[a++]),m=Math.max(m,t[a++]),d=Math.max(d,t[a++]);this._indices[this._pos>>2]=l,t[this._pos++]=A,t[this._pos++]=u,t[this._pos++]=m,t[this._pos++]=d}}}search(t,r,n,o,i){if(this._pos!==this._boxes.length)throw new Error("Data not yet indexed - call index.finish().");let s=this._boxes.length-4,a=[],c=[];for(;s!==void 0;){let l=Math.min(s+this.nodeSize*4,Uy(s,this._levelBounds));for(let A=s;A<l;A+=4){let u=this._boxes[A];if(n<u)continue;let m=this._boxes[A+1];if(o<m)continue;let d=this._boxes[A+2];if(t>d)continue;let p=this._boxes[A+3];if(r>p)continue;let E=this._indices[A>>2]|0;s>=this.numItems*4?a.push(E):(i===void 0||i(E,u,m,d,p))&&c.push(E)}s=a.pop()}return c}neighbors(t,r,n=1/0,o=1/0,i){if(this._pos!==this._boxes.length)throw new Error("Data not yet indexed - call index.finish().");let s=this._boxes.length-4,a=this._queue,c=[],l=o*o;e:for(;s!==void 0;){let A=Math.min(s+this.nodeSize*4,Uy(s,this._levelBounds));for(let u=s;u<A;u+=4){let m=this._indices[u>>2]|0,d=this._boxes[u],p=this._boxes[u+1],E=this._boxes[u+2],x=this._boxes[u+3],I=t<d?d-t:t>E?t-E:0,h=r<p?p-r:r>x?r-x:0,y=I*I+h*h;y>l||(s>=this.numItems*4?a.push(m<<1,y):(i===void 0||i(m))&&a.push((m<<1)+1,y))}for(;a.length&&a.peek()&1;)if(a.peekValue()>l||(c.push(a.pop()>>1),c.length===n))break e;s=a.length?a.pop()>>1:void 0}return a.clear(),c}}});var ps,Ai,jy,V_,qy,Jy=g(()=>{ps=f(w(),1),Ai=f(k(),1),jy=f(G(),1),V_=(0,jy.observer)(function({node:e,model:t,onClose:r}){return ps.default.createElement(Ai.Menu,{anchorReference:"anchorPosition",anchorPosition:{left:e.x,top:e.y},transitionDuration:0,keepMounted:!0,open:!!e,onClose:r},ps.default.createElement(Ai.MenuItem,{dense:!0,disabled:!0},e.name),ps.default.createElement(Ai.MenuItem,{dense:!0,onClick:()=>{t.toggleCollapsed(e.id),r()}},t.collapsed.includes(e.id)?"Expand this node":"Collapse this node"),ps.default.createElement(Ai.MenuItem,{dense:!0,onClick:()=>{t.showOnly===e.id?t.setShowOnly(void 0):t.setShowOnly(e.id),r()}},t.showOnly===e.id?"Disable show only this node":"Show only this node"))}),qy=V_});var zy={};Ye(zy,{default:()=>W_});var Dr,Vy,Yy,Wy,Y_,W_,$y=g(()=>{Dr=f(w(),1);dc();uf();Vy=f(we(),1),Yy=f(k(),1),Wy=f(G(),1);ff();Y_=(0,Wy.observer)(function({info:e,model:t,nodeName:r,onClose:n}){let{treeMetadata:o,rows:i}=t,s=o[r],a=i.find(c=>c[0]===r);return Dr.default.createElement(Vy.Dialog,{onClose:()=>{n()},open:!0,title:"Tree node info",maxWidth:"xl"},Dr.default.createElement(Yy.DialogContent,null,Dr.default.createElement(zn,{title:"Attributes"},Dr.default.createElement(_r,{attributes:{nodeName:r,...e}})),Dr.default.createElement(zn,{title:"Sequence"},a?Dr.default.createElement(us,{str:[a]}):Dr.default.createElement("div",null,"Sequence not found")),s?Dr.default.createElement(zn,{title:"Extra metadata"},Dr.default.createElement(_r,{attributes:s})):null))}),W_=Y_});var $r,pn,Ky,z_,$_,Xy,Zy=g(()=>{$r=f(w(),1),pn=f(k(),1),Ky=f(G(),1),z_=(0,$r.lazy)(()=>Promise.resolve().then(()=>($y(),zy))),$_=(0,Ky.observer)(function({node:e,onClose:t,model:r}){let{collapsed:n}=r,{name:o,id:i}=e,s=n.includes(i);return $r.default.createElement(pn.Menu,{anchorReference:"anchorPosition",anchorPosition:{top:e.y,left:e.x},transitionDuration:0,keepMounted:!0,open:!!e,onClose:t},$r.default.createElement(pn.MenuItem,{dense:!0,disabled:!0},o),$r.default.createElement(pn.MenuItem,{dense:!0,onClick:()=>{r.queueDialog(a=>[z_,{info:r.getRowData(o),model:r,nodeName:o,onClose:a}]),t()}},"More info..."),$r.default.createElement(pn.MenuItem,{dense:!0,onClick:()=>{r.toggleCollapsed(i),t()}},s?"Show node":"Hide node"),$r.default.createElement(pn.MenuItem,{dense:!0,onClick:()=>{r.drawRelativeTo(e.name),t()}},"Indicate differences from this row"),r.relativeTo?$r.default.createElement(pn.MenuItem,{dense:!0,onClick:()=>{r.drawRelativeTo(void 0),t()}},"Clear reference row"):null)}),Xy=$_});function eb(e){let t=0;if(e.children)for(let r of e.children){let n=eb(r)+1;n>t&&(t=n)}return e.height=t,t}function tb(e,t,r,n){let o=t(e),i={data:e,children:null,parent:r,depth:n,height:0};return o?.length&&(i.children=o.map(s=>tb(s,t,i,n+1))),i}function rb(e,t){let r=tb(e,t,null,0);return eb(r),r}function nb(e,t){function r(n){let o=t(n.data);if(n.children)for(let i of n.children)o+=r(i);return n.value=o,o}return r(e),e}function ob(e,t){function r(n){if(n.children){n.children.sort(t);for(let o of n.children)r(o)}}return r(e),e}function hs(e,t){if(t(e))return e;if(e.children)for(let r of e.children){let n=hs(r,t);if(n)return n}}function Cs(e){let t=[];function r(n){if(n.children)for(let o of n.children)r(o);else t.push(n)}return r(e),t}function ib(e){let t=[];function r(n){if(t.push(n),n.children)for(let o of n.children)r(o)}return r(e),t}function _c(e){let t=[];function r(n){if(n.children)for(let o of n.children)t.push({source:n,target:o}),r(o)}return r(e),t}function sb(e,t,r){let n=Cs(e),o=n.length,i=t/o;for(let l=0;l<o;l++)n[l].x=(l+.5)*i;function s(l){if(!l.children)return;for(let u of l.children)s(u);let A=0;for(let u of l.children)A+=u.x;l.x=A/l.children.length}s(e);let a=e.height;function c(l,A){if(l.y=a===0?r:A/a*r,l.children)for(let u of l.children)c(u,A+1)}c(e,0)}function ab(e){e.children&&(e._children=e.children,e.children=null)}function Es(e){if(e.depthToLeaf===void 0){let t=0;if(e.children)for(let r of e.children)t=Math.max(t,1+Es(r));e.depthToLeaf=t}return e.depthToLeaf}function Sf(e){let t=e.len||0;if(e.children)for(let r of e.children)t=Math.max(t,Sf(r));return t}function Qf(e){return(e.data.length||0)+(e.children?e.children.reduce((t,r)=>Math.max(t,Qf(r)),0):0)}function Mf(e,t,r){if(e.len=(t+=Math.max(e.data.length||0,0))*r,e.children)for(let n of e.children)Mf(n,t,r)}var vf=g(()=>{});function Dc(e,t,r,n){if(t)return e.len;let o=Es(e);return(n-o)/n*r}function K_({offsetY:e,ctx:t,model:r,theme:n,maxBranchLen:o,maxDepthToLeaf:i,blockSizeYOverride:s}){let{hierarchy:a,showBranchLenEffective:c,blockSize:l}=r,A=s||l;t.strokeStyle=n.palette.text.primary;for(let u of _c(a)){let{source:m,target:d}=u,p=m.x,E=d.x,x=Dc(d,c,o,i),I=Dc(m,c,o,i);if(x===void 0||I===void 0)continue;let h=Math.min(p,E),y=Math.max(p,E);e+A>=h&&y>=e&&(t.beginPath(),t.moveTo(I,p),t.lineTo(I,E),t.lineTo(x,E),t.stroke())}}function X_({ctx:e,clickMap:t,offsetY:r,model:n,maxBranchLen:o,maxDepthToLeaf:i,blockSizeYOverride:s}){let{hierarchy:a,showBranchLenEffective:c,collapsed:l,blockSize:A,marginLeft:u}=n,m=s||A;for(let d of ib(a)){let p=Dc(d,c,o,i);if(p===void 0)continue;let{data:E}=d,x=d.x,{id:I,name:h}=E;d.height>=1&&x>r-kc&&x<r+m+kc&&(e.strokeStyle="black",e.fillStyle=l.includes(I)?"black":"white",e.beginPath(),e.arc(p,x,Xn,0,2*Math.PI),e.fill(),e.stroke(),t?.insert({minX:p-Xn+u,maxX:p-Xn+Tf+u,minY:x-Xn,maxY:x-Xn+Tf,branch:!0,id:I,name:h}))}}function Z_({theme:e,model:t,offsetY:r,ctx:n,clickMap:o,maxBranchLen:i,maxDepthToLeaf:s,blockSizeYOverride:a}){let{fontSize:c,showBranchLenEffective:l,treeMetadata:A,blockSize:u,labelsAlignRight:m,drawTree:d,treeAreaWidth:p,treeAreaWidthMinusMargin:E,marginLeft:x,leaves:I,noTree:h}=t,y=a||u,Q=n.measureText("M").width;m?(n.textAlign="right",n.setLineDash([1,3])):n.textAlign="start";for(let M of I){let{data:{name:B,id:v}}=M,P=M.x,N=A[B]?.genome||B;if(P>r-kc&&P<r+y+kc){let $=P+c/4,S=0;h||(S=Dc(M,l,i,s)||0);let{width:L}=n.measureText(N);if(n.fillStyle=e.palette.text.primary,m){let O=E-2;d&&!h&&(n.moveTo(S+Xn+2,P),n.lineTo(O-2-L,P),n.stroke()),n.fillText(N,O,$),o?.insert({minX:p-L,maxX:p,minY:$-Q,maxY:$,name:B,id:v})}else{let J=h?2:S+Tf;n.fillText(N,J,$),o?.insert({minX:J+x,maxX:J+L+x,minY:$-Q,maxY:$,name:B,id:v})}}}n.setLineDash([])}function Nc({model:e,clickMap:t,ctx:r,offsetY:n,theme:o,highResScaleFactorOverride:i,blockSizeYOverride:s}){t?.clear();let{noTree:a,drawTree:c,drawNodeBubbles:l,highResScaleFactor:A,fontSize:u,showTreeText:m,marginLeft:d,nref:p,rowHeight:E}=e;r.resetTransform();let x=p<0?Number.NEGATIVE_INFINITY:i||A;r.scale(x,x),r.translate(d,-n);let I=r.font;r.font=I.replace(/\d+px/,`${u}px`);let{maxBranchLength:h,maxDepthToLeaf:y}=e;!a&&c&&(K_({ctx:r,offsetY:n,model:e,theme:o,maxBranchLen:h,maxDepthToLeaf:y,blockSizeYOverride:s}),l&&X_({ctx:r,offsetY:n,clickMap:t,model:e,maxBranchLen:h,maxDepthToLeaf:y,blockSizeYOverride:s})),m&&Z_({ctx:r,offsetY:n,model:e,clickMap:t,theme:o,maxBranchLen:h,maxDepthToLeaf:y,blockSizeYOverride:s}),t?.finish()}var ui,kc,Xn,Tf,Lc=g(()=>{vf();ui=600,kc=5,Xn=2.5,Tf=Xn*2});var ke,cb,lb,Ab,ub,ek,_f,tk,fb,mb=g(()=>{ke=f(w(),1),cb=f(k(),1);Hy();lb=f(Gr(),1),Ab=f(G(),1),ub=f(Se(),1);Jy();Zy();Lc();ek=(0,ub.makeStyles)()(e=>({tooltip:{position:"fixed",pointerEvents:"none",zIndex:1e4,backgroundColor:e.palette.grey[700],color:e.palette.common.white,padding:"4px 8px",borderRadius:4,fontSize:12,whiteSpace:"nowrap",maxWidth:300,overflow:"hidden",textOverflow:"ellipsis"}})),_f=class{flatbush=null;entries=[];clear(){this.flatbush=null,this.entries=[]}insert(t){this.entries.push(t)}finish(){if(this.entries.length===0){this.flatbush=null;return}else{this.flatbush=new gs(this.entries.length);for(let t of this.entries)this.flatbush.add(t.minX,t.minY,t.maxX,t.maxY);this.flatbush.finish()}}search(t){return this.flatbush?.search(t.minX,t.minY,t.maxX,t.maxY).map(r=>this.entries[r])??[]}},tk=(0,Ab.observer)(function({model:e,offsetY:t}){let{classes:r}=ek(),n=(0,cb.useTheme)(),o=(0,ke.useRef)(null),i=(0,ke.useRef)(new _f),s=(0,ke.useRef)(null),[a,c]=(0,ke.useState)(),[l,A]=(0,ke.useState)(),[u,m]=(0,ke.useState)(),[d,p]=(0,ke.useState)(),{scrollY:E,treeAreaWidth:x,blockSize:I,highResScaleFactor:h}=e,y=x+ui,Q=I,M=y*h,B=Q*h,v=(0,ke.useCallback)(S=>{e.incrementRef(),o.current=S},[e,Q,y]);(0,ke.useEffect)(()=>{let S=o.current?.getContext("2d");if(S)return(0,lb.autorun)(()=>{S.resetTransform(),S.clearRect(0,0,(x+ui)*h,I*h),Nc({ctx:S,model:e,offsetY:t,clickMap:i.current,theme:n})})},[e,I,h,x,t,n]),(0,ke.useEffect)(()=>{let S=s.current?.getContext("2d");if(S&&(S.resetTransform(),S.clearRect(0,0,x+ui,I),S.translate(0,-t),u)){let{minX:L,maxX:J,minY:O,maxY:Te}=u;S.fillStyle="rgba(0,0,0,0.1)",S.fillRect(L,O,J-L,Te-O)}},[u,t,I,x]);function P(S){let L=S.nativeEvent.offsetX,J=S.nativeEvent.offsetY,[O]=i.current.search({minX:L,maxX:L+1,minY:J+t,maxY:J+1+t});return O?.branch?{...O,x:S.clientX,y:S.clientY}:void 0}function N(S){let L=S.nativeEvent.offsetX,J=S.nativeEvent.offsetY,[O]=i.current.search({minX:L,maxX:L+1,minY:J+t,maxY:J+1+t});return O&&!O.branch?{...O,x:S.clientX,y:S.clientY}:void 0}let $={width:y,height:Q,top:E+t,left:0,position:"absolute"};return ke.default.createElement(ke.default.Fragment,null,a?.id?ke.default.createElement(qy,{node:a,model:e,onClose:()=>{c(void 0)}}):null,l?.id?ke.default.createElement(Xy,{node:l,model:e,onClose:()=>{A(void 0)}}):null,ke.default.createElement("canvas",{width:M,height:B,style:$,onMouseMove:S=>{if(!o.current)return;let L=N(S),J=P(S),O=L||J;if(o.current.style.cursor=O?"pointer":"default",m(L),p(O?{name:O.name,x:S.clientX,y:S.clientY}:void 0),O){if(e.setHoveredTreeNode(O.id),L?.name){let Te=e.rowNamesSet.get(L.name);Te!==void 0&&e.setMousePos(void 0,Te)}}else e.setHoveredTreeNode(void 0),e.setMousePos(void 0,void 0)},onClick:S=>{let{clientX:L,clientY:J}=S,O=P(S);O?.id&&c({x:L,y:J,id:O.id,name:O.name});let Te=N(S);Te?.id&&A({...Te,x:L,y:J})},onMouseLeave:()=>{m(void 0),p(void 0),e.setHoveredTreeNode(void 0),e.setMousePos(void 0,void 0)},ref:v}),ke.default.createElement("canvas",{style:{...$,pointerEvents:"none",zIndex:100},width:y,height:Q,ref:s}),d?ke.default.createElement("div",{className:r.tooltip,style:{left:d.x+12,top:d.y+12}},d.name):null)}),fb=tk});var Ar,gb,pb,hb,rk,db,nk,Cb,Eb=g(()=>{Ar=f(w(),1),gb=f(_t(),1),pb=f(Gr(),1),hb=f(G(),1);mb();Lc();zs();rk="rgba(0,128,255,0.3)",db="rgba(255,165,0,0.2)",nk=(0,hb.observer)(function({model:e}){let t=(0,Ar.useRef)(null),r=(0,Ar.useRef)(null),{treeWidth:n,height:o,blocksY:i,treeAreaWidth:s}=e,a=(0,Ar.useCallback)(A=>{e.doScrollY(A)},[e]),{onMouseDown:c,onMouseUp:l}=xo({ref:t,onScrollY:a});return(0,Ar.useEffect)(()=>{let A=r.current?.getContext("2d");return A?(0,pb.autorun)(()=>{if((0,gb.isAlive)(e)){let{relativeTo:u,leaves:m,rowHeight:d,hoveredTreeNode:p,treeAreaWidth:E,height:x,scrollY:I,mouseOverRowName:h}=e;A.resetTransform(),A.clearRect(0,0,E,x);let y=new Map(m.map(M=>[M.data.name,M])),Q=M=>{let B=y.get(M);B&&A.fillRect(0,B.x+I-d/2,E,d)};if(u&&(A.fillStyle=rk,Q(u)),p){A.fillStyle=db;for(let M of p.descendantNames)Q(M)}h&&h!==u&&!p?.descendantNames.includes(h)&&(A.fillStyle=db,Q(h))}}):void 0},[e]),Ar.default.createElement("div",{ref:t,onMouseDown:c,onMouseUp:l,onMouseLeave:A=>{A.preventDefault()},style:{height:o,position:"relative",width:n+ui}},i.map(A=>Ar.default.createElement(fb,{key:A,model:e,offsetY:A})),Ar.default.createElement("canvas",{ref:r,width:s,height:o,style:{position:"absolute",top:0,left:0,width:s,height:o,zIndex:1e3,pointerEvents:"none"}}))}),Cb=nk});var kf,Ib,ok,xb,yb=g(()=>{kf=f(w(),1),Ib=f(G(),1);Eb();ok=(0,Ib.observer)(function({model:e}){let{treeAreaWidth:t}=e;return kf.default.createElement("div",{style:{overflow:"hidden",flexShrink:0,width:t}},kf.default.createElement(Cb,{model:e}))}),xb=ok});var bb,wb,ik,Bb,Sb=g(()=>{bb=f(w(),1),wb=f(G(),1),ik=(0,wb.observer)(({model:e})=>{let{treeAreaWidth:t}=e;return bb.default.createElement("div",{style:{flexShrink:0,width:t}})}),Bb=ik});var re,Zn,sk,ak,ck,lk,Ak,uk,Qb,Mb=g(()=>{re=f(w(),1),Zn=f(G(),1);Kd();cg();fg();uy();dy();Py();yb();Sb();sk=(0,Zn.observer)(function({model:e}){let{showHorizontalScrollbar:t}=e;return re.default.createElement("div",{style:{display:"flex"}},re.default.createElement(Bb,{model:e}),t?re.default.createElement(my,{model:e}):null)}),ak=(0,Zn.observer)(function({model:e}){let{mouseCol:t,mouseClickCol:r,colWidth:n,scrollX:o,treeAreaWidth:i,resizeHandleWidth:s,totalTrackAreaHeight:a,msaAreaWidth:c,verticalScrollbarWidth:l}=e,A=i+s,u=c-l;return re.default.createElement("div",{style:{position:"absolute",left:A,top:0,width:u,height:a,overflow:"hidden",pointerEvents:"none"}},t!==void 0?re.default.createElement("div",{style:{position:"absolute",left:t*n+o,top:0,width:n,height:a,backgroundColor:"rgba(0,0,0,0.15)",zIndex:100}}):null,r!==void 0?re.default.createElement("div",{style:{position:"absolute",left:r*n+o,top:0,width:n,height:a,backgroundColor:"rgba(128,128,0,0.2)",zIndex:100}}):null)}),ck=(0,Zn.observer)(function({model:e}){let{turnedOnTracks:t}=e;return t.length===0?null:re.default.createElement("div",{style:{position:"relative"}},re.default.createElement(ak,{model:e}),t.map(r=>re.default.createElement(ag,{key:r.model.id,model:e,track:r})))}),lk=(0,Zn.observer)(function({model:e}){let{showVerticalScrollbar:t}=e;return re.default.createElement("div",{style:{display:"flex"}},re.default.createElement(xb,{model:e}),re.default.createElement(zd,{model:e}),re.default.createElement(Ry,{model:e}),t?re.default.createElement(ug,{model:e}):null)}),Ak=(0,Zn.observer)(function({model:e}){return re.default.createElement("div",{style:{position:"relative"}},re.default.createElement(sk,{model:e}),re.default.createElement(ck,{model:e}),re.default.createElement(lk,{model:e}))}),uk=(0,Zn.observer)(function({model:e}){let{height:t,viewInitialized:r,DialogComponent:n,DialogProps:o}=e;return re.default.createElement("div",null,r?re.default.createElement(re.default.Fragment,null,re.default.createElement("div",{style:{height:t,overflow:"hidden"}},re.default.createElement(Ay,{model:e}),re.default.createElement(Ak,{model:e})),re.default.createElement($d,{model:e}),n?re.default.createElement(re.Suspense,{fallback:null},re.default.createElement(n,{...o})):null):null)}),Qb=uk});var vb,Tb,_b,kb=g(()=>{vb=`CLUSTAL O(1.2.3) multiple sequence alignment
33
33
  UniProt/Swiss-Prot|P26898|IL2RA_SHEEP MEPSLLMWRFFVFIVVPGCVTEACHDDPPSLRNA----------MFKVLRYE----VGTM
34
34
  UniProt/Swiss-Prot|P01590|IL2RA_MOUSE MEPRLLMLGFLSLTIVPSCRAELCLYDPPEVPNA----------TFKALSYK----NGTI
35
35
  UniProt/Swiss-Prot|P41690|IL2RA_FELCA MEPSLLLWGILTFVVVHGHVTELCDENPPDIQHA----------TFKALTYK----TGTM
@@ -42,7 +42,7 @@ UniProt/Swiss-Prot|Q8BZM1|GLMN_MOUSE PLPLRSLLFLQLPLLGVGLNP----------------
42
42
  UniProt/Swiss-Prot|P36835|IL2_CAPHI -----------LLGVGLNPKFLTP------------------------------------
43
43
  UniProt/Swiss-Prot|Q7JFM4|IL2_AOTVO MLKPPLPLRSLLFLQLPLLGVGLNPKFLTPSGNEDIGGKPGTGGDFFLTSTPAGTLDVST
44
44
  UniProt/Swiss-Prot|Q29416|IL2_CANFA --------------LFLQLSLLG-------------------------------------
45
- `,fB=`CLUSTAL O(1.2.4) multiple sequence alignment
45
+ `,Tb=`CLUSTAL O(1.2.4) multiple sequence alignment
46
46
 
47
47
 
48
48
  sp|P69905|HBA_HUMAN MVLSPADKTNVKAAWGKVGAHAGEYGAEALERMFLSFPTTKTYFPHFDLSHGSAQVKGHG 60
@@ -58,34 +58,23 @@ sp|P13786|HBAZ_CAPHI SKVVAAVGDAVKSIDNVTSALSKLSELHAYVLRVDPVNFKFLSHCLLVTLASHF
58
58
  sp|P69905|HBA_HUMAN AVHASLDKFLASVSTVLTSKYR 142
59
59
  sp|P01942|HBA_MOUSE AVHASLDKFLASVSTVLTSKYR 142
60
60
  sp|P13786|HBAZ_CAPHI DAHAAWDKFLSIVSGVLTEKYR 142
61
- .**: ****: ** ***.***`,mB="(((UniProt/Swiss-Prot|P26898|IL2RA_SHEEP:0.24036,(UniProt/Swiss-Prot|P41690|IL2RA_FELCA:0.17737,(UniProt/Swiss-Prot|P01589|IL2RA_HUMAN:0.03906,UniProt/Swiss-Prot|Q5MNY4|IL2RA_MACMU:0.03787):0.13033):0.04964):0.02189,UniProt/Swiss-Prot|P01590|IL2RA_MOUSE:0.23072):0.06814,(((UniProt/Swiss-Prot|Q95118|IL2RG_BOVIN:0.09600,UniProt/Swiss-Prot|P40321|IL2RG_CANFA:0.09845):0.25333,UniProt/Swiss-Prot|Q29416|IL2_CANFA:-0.35055):0.10231,(UniProt/Swiss-Prot|P26896|IL2RB_RAT:0.33631,UniProt/Swiss-Prot|Q7JFM4|IL2_AOTVO:-0.33631):0.10166):0.01607,(UniProt/Swiss-Prot|Q8BZM1|GLMN_MOUSE:0.32378,UniProt/Swiss-Prot|P36835|IL2_CAPHI:-0.32378):0.09999)"});async function ol(e,t,r,n){e.setError(void 0),t&&e.setMSAFilehandle(t),r&&e.setTreeFilehandle(r),n&&e.setGFFFilehandle(n)}var sm=g(()=>{});function Dr({onClick:e,model:t,children:r}){return Bt.default.createElement("li",null,Bt.default.createElement(il.Link,{onClick:n=>{t.setError(void 0),n.preventDefault(),e()},href:"#"},Bt.default.createElement(il.Typography,{component:"span"},r)))}var Bt,il,gB,yn,oD,pB,hB=g(()=>{Bt=f(b(),1),il=f(D(),1),gB=f(O(),1);dB();sm();yn="https://jbrowse.org/genomes/multiple_sequence_alignments",oD=(0,gB.observer)(function({model:e}){function t({msa:r,tree:n,gff:o}){(async()=>{try{await ol(e,r?{uri:r,locationType:"UriLocation"}:void 0,n?{uri:n,locationType:"UriLocation"}:void 0,o?{uri:o,locationType:"UriLocation"}:void 0)}catch(i){console.error(i),e.setError(i)}})()}return Bt.default.createElement("ul",null,Bt.default.createElement(Dr,{model:e,onClick:()=>{t({tree:"https://jbrowse.org/genomes/newicktrees/sarscov2phylo.pub.ft.nh"})}},"230k COVID-19 samples (tree only)"),Bt.default.createElement(Dr,{model:e,onClick:()=>{e.setData({msa:uB,tree:mB})}},"Small protein MSA+tree"),Bt.default.createElement(Dr,{model:e,onClick:()=>{e.setData({msa:fB})}},"Small MSA only"),Bt.default.createElement(Dr,{model:e,onClick:()=>{t({msa:`${yn}/pfam-cov2.stock`})}},"PFAM SARS-CoV2 multi-stockholm"),Bt.default.createElement(Dr,{model:e,onClick:()=>{t({msa:`${yn}/pfam-cov2.stock`,gff:`${yn}/pfam-cov2-domains.gff`})}},"PFAM SARS-CoV2 multi-stockholm w/ domains loaded"),Bt.default.createElement(Dr,{model:e,onClick:()=>{t({msa:`${yn}/Lysine.stock`})}},"Lysine stockholm file"),Bt.default.createElement(Dr,{model:e,onClick:()=>{t({msa:`${yn}/PF01601_full.txt`})}},"PF01601 stockholm file (SARS-CoV2 spike protein)"),Bt.default.createElement(Dr,{model:e,onClick:()=>{t({msa:`${yn}/europe_covid.fa`})}},"Europe COVID full genomes (LR883044.1 and 199 other sequences)"),Bt.default.createElement(Dr,{model:e,onClick:()=>{t({msa:`${yn}/rhv_test-only.aligned_with_mafft_auto.fa`,tree:`${yn}/rhv_test-only.aligned_with_mafft_auto.nh`})}},"MAFFT+VeryFastTree(17.9k samples)"),Bt.default.createElement(Dr,{model:e,onClick:()=>{t({msa:"https://jbrowse.org/demos/ttc39a.mfa"})}},"Human BLAST results mfa"))}),pB=oD});var fe,hi,Cr,CB,iD,EB,IB=g(()=>{fe=f(b(),1),hi=f(ye(),1),Cr=f(D(),1),CB=f(O(),1);hB();sm();iD=(0,CB.observer)(function({model:e}){let[t,r]=(0,fe.useState)(),[n,o]=(0,fe.useState)(),[i,s]=(0,fe.useState)(),{error:a}=e;return fe.default.createElement(Cr.Container,null,fe.default.createElement("div",{style:{width:"50%"}},a?fe.default.createElement(hi.ErrorMessage,{error:a}):null,fe.default.createElement(Cr.Typography,null,"Open an MSA file (stockholm or clustal format) and/or a tree file (newick format)."),fe.default.createElement(Cr.Typography,{color:"error"},"Note: you can open up just an MSA or just a tree, both are not required. Some MSA files e.g. stockholm format have an embedded tree also and this is fine, and opening a separate tree file is not required.")),fe.default.createElement("div",{style:{display:"flex",justifyContent:"center",alignItems:"center",gap:40}},fe.default.createElement("div",null,fe.default.createElement("div",null,fe.default.createElement(Cr.Typography,null,"MSA file or URL"),fe.default.createElement(hi.FileSelector,{location:t,setLocation:r})),fe.default.createElement("div",null,fe.default.createElement(Cr.Typography,null,"Tree file or URL"),fe.default.createElement(hi.FileSelector,{location:n,setLocation:o})),fe.default.createElement("div",null,fe.default.createElement(Cr.Typography,null,"InterProScan GFF file or URL (optional)"),fe.default.createElement(hi.FileSelector,{location:i,setLocation:s}))),fe.default.createElement("div",null,fe.default.createElement(Cr.Button,{onClick:()=>{(async()=>{try{await ol(e,t,n,i)}catch(c){console.error(c),e.setError(c)}})()},variant:"contained",color:"primary",disabled:!t&&!n},"Open")),fe.default.createElement("div",null,fe.default.createElement(Cr.Typography,null,"Examples"),fe.default.createElement(pB,{model:e}))))}),EB=iD});function xB(){return ct.default.createElement("div",{style:{display:"flex",alignItems:"center",gap:12,padding:20}},ct.default.createElement("svg",{width:"24",height:"24",viewBox:"0 0 24 24",xmlns:"http://www.w3.org/2000/svg"},ct.default.createElement("style",null,"@keyframes spinner { to { transform: rotate(360deg); } }"),ct.default.createElement("circle",{cx:"12",cy:"12",r:"10",stroke:"#ccc",strokeWidth:"3",fill:"none"}),ct.default.createElement("path",{d:"M12 2a10 10 0 0 1 10 10",stroke:"#1976d2",strokeWidth:"3",fill:"none",strokeLinecap:"round",style:{animation:"spinner 1s linear infinite",transformOrigin:"center"}})),ct.default.createElement(sl.Typography,{variant:"h6"},"Loading..."))}var ct,yB,sl,am,sD,aD,al,cm=g(()=>{ct=f(b(),1),yB=f(ye(),1);cu();sl=f(D(),1),am=f(O(),1);AB();IB();sD=(0,am.observer)(function({model:e,error:t}){return ct.default.createElement("div",null,ct.default.createElement(yB.ErrorMessage,{error:t}),ct.default.createElement(sl.Button,{variant:"contained",color:"primary",onClick:()=>{e.reset()}},"Return to import form"))}),aD=(0,am.observer)(function({model:e}){let{isLoading:t,dataInitialized:r,msaFilehandle:n,treeFilehandle:o}=e,i=!!(n||o);return ct.default.createElement("div",null,ct.default.createElement(No,{FallbackComponent:s=>ct.default.createElement(sD,{model:e,error:s.error})},r?t?ct.default.createElement(xB,null):ct.default.createElement(lB,{model:e}):i||t?ct.default.createElement(xB,null):ct.default.createElement(EB,{model:e})))}),al=aD});var bB=G((cH,wB)=>{wB.exports=JBrowseExports["@jbrowse/core/ui/theme"]});var SB=G((lH,BB)=>{BB.exports=JBrowseExports["@jbrowse/core/util/io"]});var MB=G((AH,QB)=>{QB.exports=JBrowseExports["@jbrowse/core/util/types/mst"]});var vB=g(()=>{});function Ci(e,t="node",r=0){let n=`${t}-${r}`;return{...e,id:n,name:e.name||n,children:e.children?.map((o,i)=>Ci(o,`${n}-${i}`,r+1))||[]}}var lm=g(()=>{});var Ht,Ei=g(()=>{Ht=class{getTree(){return{id:"root",name:"root",noTree:!0,children:this.getNames().map(t=>({id:t,children:[],name:t}))}}getRowData(t){}getStructures(){return{}}getHeader(){return{}}get alignmentNames(){return[]}get seqConsensus(){}get secondaryStructureConsensus(){}get tracks(){return[]}}});function Ii(e){return e>=cD&&e<=lD}var TB,_B,cD,lD,kB,DB,wn,Am=g(()=>{Ei();TB=65,_B=90,cD=97,lD=122,kB=45,DB=46;wn=class extends Ht{MSA;orderedNames;constructor(t){super();let r=[],n=[];for(let o of t.split(">")){if(!/\S/.test(o))continue;let i=o.indexOf(`
61
+ .**: ****: ** ***.***`,_b="(((UniProt/Swiss-Prot|P26898|IL2RA_SHEEP:0.24036,(UniProt/Swiss-Prot|P41690|IL2RA_FELCA:0.17737,(UniProt/Swiss-Prot|P01589|IL2RA_HUMAN:0.03906,UniProt/Swiss-Prot|Q5MNY4|IL2RA_MACMU:0.03787):0.13033):0.04964):0.02189,UniProt/Swiss-Prot|P01590|IL2RA_MOUSE:0.23072):0.06814,(((UniProt/Swiss-Prot|Q95118|IL2RG_BOVIN:0.09600,UniProt/Swiss-Prot|P40321|IL2RG_CANFA:0.09845):0.25333,UniProt/Swiss-Prot|Q29416|IL2_CANFA:-0.35055):0.10231,(UniProt/Swiss-Prot|P26896|IL2RB_RAT:0.33631,UniProt/Swiss-Prot|Q7JFM4|IL2_AOTVO:-0.33631):0.10166):0.01607,(UniProt/Swiss-Prot|Q8BZM1|GLMN_MOUSE:0.32378,UniProt/Swiss-Prot|P36835|IL2_CAPHI:-0.32378):0.09999)"});async function Fc(e,t,r,n){e.setError(void 0),t&&e.setMSAFilehandle(t),r&&e.setTreeFilehandle(r),n&&e.setGFFFilehandle(n)}var Df=g(()=>{});function Nr({onClick:e,model:t,children:r}){return St.default.createElement("li",null,St.default.createElement(Rc.Link,{onClick:n=>{t.setError(void 0),n.preventDefault(),e()},href:"#"},St.default.createElement(Rc.Typography,{component:"span"},r)))}var St,Rc,Db,hn,fk,Nb,Lb=g(()=>{St=f(w(),1),Rc=f(k(),1),Db=f(G(),1);kb();Df();hn="https://jbrowse.org/genomes/multiple_sequence_alignments",fk=(0,Db.observer)(function({model:e}){function t({msa:r,tree:n,gff:o}){(async()=>{try{await Fc(e,r?{uri:r,locationType:"UriLocation"}:void 0,n?{uri:n,locationType:"UriLocation"}:void 0,o?{uri:o,locationType:"UriLocation"}:void 0)}catch(i){console.error(i),e.setError(i)}})()}return St.default.createElement("ul",null,St.default.createElement(Nr,{model:e,onClick:()=>{t({tree:"https://jbrowse.org/genomes/newicktrees/sarscov2phylo.pub.ft.nh"})}},"230k COVID-19 samples (tree only)"),St.default.createElement(Nr,{model:e,onClick:()=>{e.setData({msa:vb,tree:_b})}},"Small protein MSA+tree"),St.default.createElement(Nr,{model:e,onClick:()=>{e.setData({msa:Tb})}},"Small MSA only"),St.default.createElement(Nr,{model:e,onClick:()=>{t({msa:`${hn}/pfam-cov2.stock`})}},"PFAM SARS-CoV2 multi-stockholm"),St.default.createElement(Nr,{model:e,onClick:()=>{t({msa:`${hn}/pfam-cov2.stock`,gff:`${hn}/pfam-cov2-domains.gff`})}},"PFAM SARS-CoV2 multi-stockholm w/ domains loaded"),St.default.createElement(Nr,{model:e,onClick:()=>{t({msa:`${hn}/Lysine.stock`})}},"Lysine stockholm file"),St.default.createElement(Nr,{model:e,onClick:()=>{t({msa:`${hn}/PF01601_full.txt`})}},"PF01601 stockholm file (SARS-CoV2 spike protein)"),St.default.createElement(Nr,{model:e,onClick:()=>{t({msa:`${hn}/europe_covid.fa`})}},"Europe COVID full genomes (LR883044.1 and 199 other sequences)"),St.default.createElement(Nr,{model:e,onClick:()=>{t({msa:`${hn}/rhv_test-only.aligned_with_mafft_auto.fa`,tree:`${hn}/rhv_test-only.aligned_with_mafft_auto.nh`})}},"MAFFT+VeryFastTree(17.9k samples)"),St.default.createElement(Nr,{model:e,onClick:()=>{t({msa:"https://jbrowse.org/demos/ttc39a.mfa"})}},"Human BLAST results mfa"))}),Nb=fk});var me,fi,ur,Fb,mk,Rb,Pb=g(()=>{me=f(w(),1),fi=f(we(),1),ur=f(k(),1),Fb=f(G(),1);Lb();Df();mk=(0,Fb.observer)(function({model:e}){let[t,r]=(0,me.useState)(),[n,o]=(0,me.useState)(),[i,s]=(0,me.useState)(),{error:a}=e;return me.default.createElement(ur.Container,null,me.default.createElement("div",{style:{width:"50%"}},a?me.default.createElement(fi.ErrorMessage,{error:a}):null,me.default.createElement(ur.Typography,null,"Open an MSA file (stockholm or clustal format) and/or a tree file (newick format)."),me.default.createElement(ur.Typography,{color:"error"},"Note: you can open up just an MSA or just a tree, both are not required. Some MSA files e.g. stockholm format have an embedded tree also and this is fine, and opening a separate tree file is not required.")),me.default.createElement("div",{style:{display:"flex",justifyContent:"center",alignItems:"center",gap:40}},me.default.createElement("div",null,me.default.createElement("div",null,me.default.createElement(ur.Typography,null,"MSA file or URL"),me.default.createElement(fi.FileSelector,{location:t,setLocation:r})),me.default.createElement("div",null,me.default.createElement(ur.Typography,null,"Tree file or URL"),me.default.createElement(fi.FileSelector,{location:n,setLocation:o})),me.default.createElement("div",null,me.default.createElement(ur.Typography,null,"InterProScan GFF file or URL (optional)"),me.default.createElement(fi.FileSelector,{location:i,setLocation:s}))),me.default.createElement("div",null,me.default.createElement(ur.Button,{onClick:()=>{(async()=>{try{await Fc(e,t,n,i)}catch(c){console.error(c),e.setError(c)}})()},variant:"contained",color:"primary",disabled:!t&&!n},"Open")),me.default.createElement("div",null,me.default.createElement(ur.Typography,null,"Examples"),me.default.createElement(Nb,{model:e}))))}),Rb=mk});function Ob(){return st.default.createElement("div",{style:{display:"flex",alignItems:"center",gap:12,padding:20}},st.default.createElement("svg",{width:"24",height:"24",viewBox:"0 0 24 24",xmlns:"http://www.w3.org/2000/svg"},st.default.createElement("style",null,"@keyframes spinner { to { transform: rotate(360deg); } }"),st.default.createElement("circle",{cx:"12",cy:"12",r:"10",stroke:"#ccc",strokeWidth:"3",fill:"none"}),st.default.createElement("path",{d:"M12 2a10 10 0 0 1 10 10",stroke:"#1976d2",strokeWidth:"3",fill:"none",strokeLinecap:"round",style:{animation:"spinner 1s linear infinite",transformOrigin:"center"}})),st.default.createElement(Pc.Typography,{variant:"h6"},"Loading..."))}var st,Gb,Pc,Nf,dk,gk,Oc,Lf=g(()=>{st=f(w(),1),Gb=f(we(),1);Hl();Pc=f(k(),1),Nf=f(G(),1);Mb();Pb();dk=(0,Nf.observer)(function({model:e,error:t}){return st.default.createElement("div",null,st.default.createElement(Gb.ErrorMessage,{error:t}),st.default.createElement(Pc.Button,{variant:"contained",color:"primary",onClick:()=>{e.reset()}},"Return to import form"))}),gk=(0,Nf.observer)(function({model:e}){let{isLoading:t,dataInitialized:r,msaFilehandle:n,treeFilehandle:o}=e,i=!!(n||o);return st.default.createElement("div",null,st.default.createElement(Io,{FallbackComponent:s=>st.default.createElement(dk,{model:e,error:s.error})},r?t?st.default.createElement(Ob,null):st.default.createElement(Qb,{model:e}):i||t?st.default.createElement(Ob,null):st.default.createElement(Rb,{model:e})))}),Oc=gk});var Hb=U((q6,Ub)=>{Ub.exports=JBrowseExports["@jbrowse/core/ui/theme"]});var qb=U((J6,jb)=>{jb.exports=JBrowseExports["@jbrowse/core/util/io"]});var Vb=U((V6,Jb)=>{Jb.exports=JBrowseExports["@jbrowse/core/util/types/mst"]});var Yb=g(()=>{});function mi(e,t="node",r=0){let n=`${t}-${r}`;return{...e,id:n,name:e.name||n,children:e.children?.map((o,i)=>mi(o,`${n}-${i}`,r+1))||[]}}var Ff=g(()=>{});var Rt,di=g(()=>{Rt=class{getTree(){return{id:"root",name:"root",noTree:!0,children:this.getNames().map(t=>({id:t,children:[],name:t}))}}getRowData(t){}getStructures(){return{}}getHeader(){return{}}get alignmentNames(){return[]}get seqConsensus(){}get secondaryStructureConsensus(){}get tracks(){return[]}}});function gi(e){return e>=pk&&e<=hk}var Wb,zb,pk,hk,$b,Kb,Cn,Rf=g(()=>{di();Wb=65,zb=90,pk=97,hk=122,$b=45,Kb=46;Cn=class extends Rt{MSA;orderedNames;constructor(t){super();let r=[],n=[];for(let o of t.split(">")){if(!/\S/.test(o))continue;let i=o.indexOf(`
62
62
  `);if(i===-1)continue;let s=o.slice(0,i),a=s.indexOf(" "),c=a===-1?s:s.slice(0,a);c&&(r.push(o.slice(i+1).replaceAll(/\s/g,"")),n.push(c))}this.orderedNames=n,this.MSA={seqdata:this.expandA3M(r,n)}}static sniff(t){if(!t.startsWith(">"))return!1;let r=[];for(let s of t.split(">")){if(!/\S/.test(s))continue;let a=s.indexOf(`
63
- `);if(a===-1)continue;let c=s.slice(a+1).replaceAll(/\s/g,"");c&&r.push(c)}if(r.length<2)return!1;let n=!1,o=-1,i=!0;for(let s of r){let a=0;for(let c=0;c<s.length;c++){let l=s.charCodeAt(c);Ii(l)?n=!0:(l>=TB&&l<=_B||l===kB)&&a++}o===-1?o=a:a!==o&&(i=!1)}return n&&i}expandA3M(t,r){let n=r.length;if(n===0)return{};let o=[],i=[];for(let l=0;l<n;l++){let A=t[l],u=[],m=[],d=0;for(;d<A.length;){let p=A.charCodeAt(d);if(p>=TB&&p<=_B||p===kB){u.push(A[d]);let C="",y=d+1;for(;y<A.length;){let I=A.charCodeAt(y);if(Ii(I)||I===DB)C+=A[y],y++;else break}m.push(C),d=y}else if(p===DB)d++;else if(Ii(p)){let C="";for(;d<A.length&&Ii(A.charCodeAt(d));)C+=A[d],d++;u.push(""),m.push(C)}else d++}o.push(u),i.push(m)}let s=Math.max(...o.map(l=>l.length),0),a=new Array(s).fill(0);for(let l=0;l<n;l++){let A=i[l];for(let u=0;u<A.length;u++){let m=0;for(let d of A[u])Ii(d.charCodeAt(0))&&m++;m>a[u]&&(a[u]=m)}}let c={};for(let l=0;l<n;l++){let A=o[l],u=i[l],m=[];for(let d=0;d<s;d++){let p=a[d];if(d<A.length){let C=A[d],y=u[d]||"";m.push(C||"-");let I="";for(let x of y)Ii(x.charCodeAt(0))&&(I+=x.toUpperCase());m.push(I);let h=p-I.length;h>0&&m.push(".".repeat(h))}else m.push("-"),p>0&&m.push(".".repeat(p))}c[r[l]]=m.join("")}return c}getMSA(){return this.MSA}getNames(){return this.orderedNames}getRow(t){return this.MSA.seqdata[t]||""}getWidth(){let t=Object.keys(this.MSA.seqdata)[0];return t?this.getRow(t).length:0}}});function AD(e){let t=/\(?(\d+(\.\d+)+)\)?/.exec(e);return t&&t.length>1?t[1]:""}function LB(e){let t=["CLUSTAL","PROBCONS","MUSCLE","MSAPROBS","Kalign"];t.some(n=>e.startsWith(n))||console.warn(`${e} is not a known CLUSTAL header: ${t.join(",")}, proceeding but could indicate an issue`);let r=AD(e);return{info:e,version:r}}function cl(e){let t=e.next();for(;!t.done&&t.value.trim()==="";)t=e.next();return t.value}function uD(e){let t=e.split(/\s+/),r=e.slice(t[0].length),n=t[0].length+r.indexOf(t[1]),o=n+t[1].length;return[n,o]}function NB(e){let t=cl(e),r=[],n="";if(!t)return;for(;t;)t.startsWith(" ")?n=t:r.push(t),t=e.next().value;let[o,i]=uD(r[0]),a=r.map(u=>u.split(/\s+/)).map(u=>u[0]),c=r.map(u=>u.slice(o,i)),l=n.slice(o,i),A=c[0].length-l.length;return A&&(l+=" ".repeat(A)),{ids:a,seqs:c,consensus:l}}function FB(e){let t,r=NB(e);if(r!==void 0)for(;t=NB(e);){for(let n=0;n<t.seqs.length;n++)r.seqs[n]+=t.seqs[n];r.consensus+=t.consensus}return r}var um=g(()=>{});var RB=g(()=>{um()});function fD(e){let t=cl(e);if(!t)throw new Error("Empty file received");let r=LB(t),n=FB(e);if(n===void 0)throw new Error("No blocks parsed");let o=n.seqs.map((s,a)=>({id:n.ids[a],seq:s})),{consensus:i}=n;if(i.length!==o[0].seq.length)throw new Error(`Consensus length != sequence length. Con ${i.length} seq ${o[0].seq.length}`);return{consensus:i,alns:o,header:r}}function PB(e){let t=e.split(`
64
- `)[Symbol.iterator]();return fD(t)}var OB=g(()=>{RB();um()});var ro,fm=g(()=>{OB();Ei();ro=class extends Ht{MSA;constructor(t){super(),this.MSA=PB(t)}getMSA(){return this.MSA}getRow(t){return this.MSA.alns.find(r=>r.id===t)?.seq||""}getWidth(){return this.MSA.alns[0].seq.length}getHeader(){return this.MSA.header}getNames(){return this.MSA.alns.map(t=>t.id)}get seqConsensus(){return this.MSA.consensus}}});function GB(e){let t=e.split(`
65
- `).map(i=>i.trim()).filter(i=>!!i),r=[],n=[];for(let i of t)if(i.startsWith("SEQ"))r.push(i);else{if(i.startsWith("DATA"))continue;if(i.startsWith("//"))break;n.push(i)}let o=r.map(i=>{let[,s,a,c,l,A,u,m,d]=i.split(" ");return{species:s,protein:a,chr:c,start:+l,end:+A,strand:+u,geneId:m,unknown:d,seq:""}});for(let i of n)for(let s=0;s<r.length;s++)o[s].seq+=i[s];return o}function ll(e){let t=e.split(`
66
- `).map(i=>i.trim()).filter(i=>!!i),r=[],n="";for(let i of t)if(i.startsWith("SEQ"))r.push(i);else{if(i.startsWith("DATA"))continue;if(i.startsWith("//"))break;n=i}let o=r.map(i=>{let[,s,a,c,l,A,u,m,d]=i.split(" ");return{species:s,protein:a,chr:c,start:+l,end:+A,strand:+u,geneId:m,unknown:d}});return{tree:n,seqs:o}}var mm=g(()=>{});var no,dm=g(()=>{mm();Ei();no=class extends Ht{MSA;constructor(t){super(),this.MSA=GB(t)}getMSA(){return this.MSA}getRow(t){return this.MSA.find(r=>r.protein===t)?.seq||""}getWidth(){return this.MSA[0].seq.length}getHeader(){return""}getNames(){return this.MSA.map(t=>t.protein)}}});var oo,gm=g(()=>{Ei();oo=class extends Ht{MSA;constructor(t){super();let r={},n={};for(let o of t.split(">")){if(!/\S/.test(o))continue;let i=o.indexOf(`
67
- `);if(i===-1)continue;let s=o.slice(0,i),a=s.indexOf(" "),c=a===-1?s:s.slice(0,a);c&&(r[c]=o.slice(i+1).replaceAll(/\s/g,""),c.includes(":")&&(n[c.replaceAll(":","_")]=c))}this.MSA={seqdata:r,colonNormalized:n}}getMSA(){return this.MSA}getNames(){return Object.keys(this.MSA.seqdata)}getRow(t){return this.MSA.seqdata[t]??this.MSA.seqdata[this.MSA.colonNormalized[t]??""]??""}getWidth(){let t=Object.keys(this.MSA.seqdata)[0];return this.getRow(t).length}}});function io(e){let t=[],r=[],n=e.replace(/'((?:[^']|'')*)'/g,(s,a)=>{let c=r.length;return r.push(a.replaceAll("''","'")),`__Q${c}__`}),o={},i=n.split(/\s*(;|\(|\)|,|:)\s*/);for(let s=0;s<i.length;s++){let c=i[s].replace(/^__Q(\d+)__$/,(A,u)=>r[Number(u)]),l={};switch(c){case"(":o.children=[l],t.push(o),o=l;break;case",":t.at(-1)?.children.push(l),o=l;break;case")":o=t.pop();break;case":":break;default:{let A=i[s-1];A===")"||A==="("||A===","?o.name=c:A===":"&&(o.length=Number.parseFloat(c))}}}return o}var pm=g(()=>{});function xi(){return{gf:{},gc:{},gs:{},gr:{},seqname:[],seqdata:{}}}function Is(e){return UB.test(e)}function HB(e,t){let r=t??{},n=[],o=null,i=e.split(`
68
- `);for(let s of i){let a;if(UB.test(s))o=xi();else if(mD.test(s))o&&n.push(o),o=null;else if(a=dD.exec(s)){if(!o){if(r.strict)throw new Error("No format header: # STOCKHOLM 1.0");o=xi()}let c=a[1];o.gf[c]||(o.gf[c]=[]),o.gf[c].push(a[2])}else if(a=gD.exec(s)){if(!o){if(r.strict)throw new Error("No format header: # STOCKHOLM 1.0");o=xi()}let c=a[1];o.gc[c]||(o.gc[c]=""),o.gc[c]+=a[2]}else if(a=pD.exec(s)){if(!o){if(r.strict)throw new Error("No format header: # STOCKHOLM 1.0");o=xi()}let c=a[1],l=a[2],A=a[3];o.gs[l]||(o.gs[l]={}),o.gs[l][c]||(o.gs[l][c]=[]),o.gs[l][c].push(A)}else if(a=hD.exec(s)){if(!o){if(r.strict)throw new Error("No format header: # STOCKHOLM 1.0");o=xi()}let c=a[1],l=a[2],A=a[3];o.gr[l]||(o.gr[l]={}),o.gr[l][c]||(o.gr[l][c]=""),o.gr[l][c]+=A}else if(a=CD.exec(s)){if(!o){if(r.strict)throw new Error("No format header: # STOCKHOLM 1.0");o=xi()}let c=a[1],l=a[2];o.seqdata[c]||(o.seqdata[c]="",o.seqname.push(c)),o.seqdata[c]+=l}else if(ED.test(s)&&r.strict)throw new Error("Malformed line")}return o&&n.push(o),n}var UB,mD,dD,gD,pD,hD,CD,ED,hm=g(()=>{UB=/^# STOCKHOLM 1.0/,mD=/^\/\/\s*$/,dD=/^#=GF\s+(\S+)\s+(.*?)\s*$/,gD=/^#=GC\s+(\S+)\s+(.*?)\s*$/,pD=/^#=GS\s+(\S+)\s+(\S+)\s+(.*?)\s*$/,hD=/^#=GR\s+(\S+)\s+(\S+)\s+(.*?)\s*$/,CD=/^\s*(\S+)\s+(\S+)\s*$/,ED=/\S/});var so,Cm=g(()=>{pm();hm();lm();Ei();hm();so=class extends Ht{data;MSA;constructor(t,r){super();let n=HB(t);this.data=n,this.MSA=n[r]}getMSA(){return this.MSA}getRow(t){return this.MSA.seqdata[t]||""}getWidth(){let t=Object.keys(this.MSA.seqdata)[0];return this.getRow(t).length}get alignmentNames(){return this.data.map((t,r)=>t.gf.DE?.[0]??`Alignment ${r+1}`)}getHeader(){let t=this.MSA.gs.AC??{},r=this.MSA.gs.DR??{};return{General:this.MSA.gf,Accessions:Object.fromEntries(Object.entries(t).map(([n,o])=>[n,o[0]])),Dbxref:Object.fromEntries(Object.entries(r).map(([n,o])=>[n,o.join("; ")]))}}getRowData(t){return{name:t,accession:this.MSA.gs.AC?.[t]?.[0],dbxref:this.MSA.gs.DR?.[t]?.join("; ")}}getNames(){return Object.keys(this.MSA.seqdata)}getStructures(){let t=/PDB; +(\S+) +(\S); ([0-9]+)-([0-9]+)/,r=this.MSA.gs.DR??{},n={};for(let[o,i]of Object.entries(r))for(let s of i){let a=t.exec(s);a&&(n[o]??=[]).push({pdb:a[1].toLowerCase(),chain:a[2],startPos:+a[3],endPos:+a[4]})}return n}getTree(){let t=this.MSA.gf.NH?.[0];return t?Ci(io(t)):super.getTree()}get seqConsensus(){return this.MSA.gc.seq_cons}get secondaryStructureConsensus(){return this.MSA.gc.SS_cons}get tracks(){return[{id:"seqConsensus",name:"Sequence consensus",data:this.seqConsensus,customColorScheme:{}},{id:"secondaryStruct",name:"Secondary-structure",data:this.secondaryStructureConsensus,customColorScheme:{">":"pink","<":"lightblue"}}]}}});function Em(e,t=0){return Is(e)?new so(e,t):wn.sniff(e)?new wn(e):e.startsWith(">")?new oo(e):e.startsWith("SEQ")?new no(e):new ro(e)}var jB=g(()=>{Am();fm();dm();gm();Cm();mm();pm();Am();fm();dm();gm();Cm()});function ID(e){return e?Object.fromEntries(e.split(";").map(t=>t.trim()).filter(t=>!!t).map(t=>t.split("=")).map(([t,r])=>[t?.trim()??"",r?decodeURIComponent(r).trim().split(",").join(" "):void 0]).filter(([t])=>t!=="")):{}}function Al(e){return e?e.split(`
69
- `).map(t=>t.trim()).filter(t=>!!t&&!t.startsWith("#")).map(t=>{let r=t.split(" "),[n,o,i,s,a,c,l,A]=r,u=r[8];return{seq_id:n??"",source:o??"",type:i??"",start:Number(s)||0,end:Number(a)||0,score:Number(c)||0,strand:l??".",phase:A??".",...ID(u)}}):[]}var qB=g(()=>{});function ul(e){let t=new Map;for(let n of e){let o=t.get(n.seq_id);o?o.push(n):t.set(n.seq_id,[n])}let r={};for(let[n,o]of t){let i=new Map,s=new Map;for(let c of o){let l=c.Name||c.ID||`${c.source}_${c.start}_${c.end}`,A=c.signature_desc||c.Name||l,u=c.Ontology_term||c.description||c.Note||A;s.has(l)||s.set(l,{name:A,description:u,accession:l});let m=i.get(l);m?m.push({start:c.start,end:c.end}):i.set(l,[{start:c.start,end:c.end}])}let a=[];for(let[c,l]of i){let A=s.get(c);a.push({signature:{entry:A},locations:l})}r[n]={matches:a,xref:[{id:n}]}}return r}var JB=g(()=>{});var VB=g(()=>{});var YB=g(()=>{qB();JB();VB()});var WB=g(()=>{vB();lm();jB();YB()});function zB({mapHeight:e,blockSize:t,viewportY:r,viewportHeight:n}){let o=Math.max(0,Math.min(r,e*t-n)),i=Math.floor(o/t),s=Math.floor((o+n-1)/t),a=[];for(let c=i;c<=s;c++)a.push(c*t);return a}function $B({mapWidth:e,blockSize:t,viewportX:r,viewportWidth:n}){let o=Math.max(0,Math.min(r,e-n)),i=Math.floor(o/t),s=Math.floor((o+n-1)/t),a=[];for(let c=i;c<=s;c++)a.push(c*t);return a}var KB=g(()=>{});function Im({ctx:e,conservation:t,colWidth:r,trackHeight:n,offsetX:o,blockSize:i}){let s=Math.max(0,Math.floor(o/r)),a=Math.max(0,Math.ceil((o+i)/r));e.fillStyle="gray";for(let c=s;c<a&&c<t.length;c++){let A=t[c]*n,u=c*r;e.fillRect(u,n-A,r,A)}}function xm({ctx:e,data:t,colorScheme:r,contrastScheme:n,bgColor:o,colWidth:i,rowHeight:s,offsetX:a,blockSize:c}){let l=Math.max(0,Math.floor(a/i)),A=Math.max(0,Math.ceil((a+c)/i)),u=t?.slice(l,A);for(let m=0;u&&m<u.length;m++){let d=u[m],p=r[d.toUpperCase()];if(o){let C=m*i+a-a%i;e.fillStyle=p||"white",e.fillRect(C,0,i,s),s>=10&&i>=s/2&&(e.fillStyle=n[d.toUpperCase()]||"black",e.fillText(d,C+i/2,s/2+1))}}}function bD({model:e,ctx:t,offsetX:r,offsetY:n,trackHeight:o,blockSizeXOverride:i,highResScaleFactorOverride:s}){let{blockSize:a,colWidth:c,highResScaleFactor:l,conservation:A}=e,u=i??a,m=s??l;t.resetTransform(),t.scale(m,m),t.translate(-r,n),Im({ctx:t,conservation:A,colWidth:c,trackHeight:o,offsetX:r,blockSize:u}),t.resetTransform()}function BD({model:e,ctx:t,track:r,offsetX:n,offsetY:o,contrastScheme:i,blockSizeXOverride:s,highResScaleFactorOverride:a}){let{blockSize:c,bgColor:l,colorScheme:A,colWidth:u,fontSize:m,rowHeight:d,highResScaleFactor:p}=e,{customColorScheme:C,data:y}=r.model,I=C??A,h=s??c,x=a??p;t.resetTransform(),t.scale(x,x),t.translate(-n,o),t.textAlign="center",t.font=t.font.replace(/\d+px/,`${m}px`),xm({ctx:t,data:y,colorScheme:I,contrastScheme:i,bgColor:l,colWidth:u,rowHeight:d,offsetX:n,blockSize:h}),t.resetTransform()}function XB({model:e,ctx:t,offsetX:r,contrastScheme:n,blockSizeXOverride:o,highResScaleFactorOverride:i}){let{turnedOnTracks:s}=e,a=0;for(let c of s){let l=c.model.height;c.model.id==="conservation"?bD({model:e,ctx:t,offsetX:r,offsetY:a,trackHeight:l,blockSizeXOverride:o,highResScaleFactorOverride:i}):BD({model:e,ctx:t,track:c,offsetX:r,offsetY:a,contrastScheme:n,blockSizeXOverride:o,highResScaleFactorOverride:i}),a+=l}}var fl=g(()=>{});var Xr,ZB,ym,SD,QD,eS,tS=g(()=>{Xr=f(b(),1),ZB=f(ye(),1),ym=f(O(),1);fl();SD=(0,ym.observer)(function({model:e,offsetX:t,trackHeight:r}){let{blockSize:n,scrollX:o,colWidth:i,highResScaleFactor:s,conservation:a}=e,c=(0,Xr.useRef)(null);return(0,Xr.useEffect)(()=>{if(!c.current)return;let l=c.current.getContext("2d");l&&(l.resetTransform(),l.scale(s,s),l.clearRect(0,0,n,r),l.translate(-t,0),Im({ctx:l,conservation:a,colWidth:i,trackHeight:r,offsetX:t,blockSize:n}))},[n,i,r,t,s,a]),Xr.default.createElement("canvas",{ref:c,height:r*s,width:n*s,style:{position:"absolute",left:o+t,width:n,height:r}})}),QD=(0,ym.observer)(function({model:e,track:t}){let{blocksX:r,msaAreaWidth:n}=e,o=t.model.height;return Xr.default.createElement("div",{style:{position:"relative",height:o,width:n,overflow:"hidden"}},r.map(i=>Xr.default.createElement(SD,{key:i,model:e,offsetX:i,trackHeight:o})),Xr.default.createElement(ZB.ResizeHandle,{onDrag:i=>(e.setConservationTrackHeight(Math.max(10,e.conservationTrackHeight+i)),i),style:{position:"absolute",bottom:0,left:0,height:4,width:"100%",zIndex:1,background:"rgba(200,200,200,0.5)"}}))}),eS=QD});var Nr,rS,wm,MD,vD,nS,oS=g(()=>{Nr=f(b(),1),rS=f(D(),1),wm=f(O(),1);Cn();fl();MD=(0,wm.observer)(function({track:e,model:t,offsetX:r}){let{blockSize:n,scrollX:o,bgColor:i,colorScheme:s,colWidth:a,fontSize:c,rowHeight:l,highResScaleFactor:A}=t,{model:{customColorScheme:u,data:m}}=e,d=u||s,p=(0,rS.useTheme)(),C=(0,Nr.useRef)(null),y=(0,Nr.useMemo)(()=>zn(d,p),[d,p]);return(0,Nr.useEffect)(()=>{if(!C.current)return;let I=C.current.getContext("2d");I&&(I.resetTransform(),I.scale(A,A),I.clearRect(0,0,n,l),I.translate(-r,0),I.textAlign="center",I.font=I.font.replace(/\d+px/,`${c}px`),xm({ctx:I,data:m,colorScheme:d,contrastScheme:y,bgColor:i,colWidth:a,rowHeight:l,offsetX:r,blockSize:n}))},[c,i,n,a,l,r,y,d,A,m]),Nr.default.createElement("canvas",{ref:C,height:l*A,width:n*A,style:{position:"absolute",left:o+r,width:n,height:l}})}),vD=(0,wm.observer)(function({track:e,model:t}){let{blocksX:r,msaAreaWidth:n,rowHeight:o}=t;return e.model.data?Nr.default.createElement("div",{style:{position:"relative",height:o,width:n,overflow:"hidden"}},r.map(i=>Nr.default.createElement(MD,{key:i,track:e,model:t,offsetX:i}))):null}),nS=vD});var ml,dl=g(()=>{ml="maeditor"});function iS(e){let t=Math.min(e.length-1,Qf.length-1),r=Qf[t];return Object.fromEntries(e.map((n,o)=>[n,r[o]]))}var sS=g(()=>{Mf()});function aS(e){let t=new Map(e.map(n=>[n.id,{id:`${n.id}`,name:`${n.id}`,parent:n.parent!==void 0?`${n.parent}`:void 0,children:[]}])),r;for(let n of e){let o=t.get(n.id),i=n.parent!==void 0?t.get(n.parent):void 0;i?i.children.push(o):r??=o}return r}var cS=g(()=>{});function lS(e,t){bm||(bm=document.createElement("canvas"));let r=bm.getContext("2d");if(!r)throw new Error("no canvas context");return r.font=r.font.replace(/\d+px/,`${t}px`),r.measureText(e).width}var bm,AS=g(()=>{});function uS(){return Lr.types.model({tree:Lr.types.maybe(Lr.types.string),msa:Lr.types.maybe(Lr.types.string),treeMetadata:Lr.types.maybe(Lr.types.string),gff:Lr.types.maybe(Lr.types.string)}).actions(e=>({setTree(t){e.tree=t},setMSA(t){e.msa=t},setTreeMetadata(t){e.treeMetadata=t},setGFF(t){e.gff=t}})).postProcessSnapshot(e=>{let{tree:t,msa:r,treeMetadata:n,gff:o}=e,i=5e4;return{tree:t&&t.length>i?void 0:t,msa:r&&r.length>i?void 0:r,treeMetadata:n&&n.length>i?void 0:n,gff:o&&o.length>i?void 0:o}})}var Lr,fS=g(()=>{Lr=f(kt(),1)});function dS(){return mS.types.model("DialogQueueSessionMixin",{}).volatile(()=>({queueOfDialogs:[]})).views(e=>({get DialogComponent(){return e.queueOfDialogs[0]?.[0]},get DialogProps(){return e.queueOfDialogs[0]?.[1]}})).actions(e=>({removeActiveDialog(){e.queueOfDialogs=e.queueOfDialogs.slice(1)},queueDialog(t){let[r,n]=t(()=>{this.removeActiveDialog()});e.queueOfDialogs=[...e.queueOfDialogs,[r,n]]}}))}var mS,gS=g(()=>{mS=f(kt(),1)});function hS(){return pS.types.model({bgColor:!0,colorSchemeName:ml}).actions(e=>({setColorSchemeName(t){e.colorSchemeName=t},setBgColor(t){e.bgColor=t}}))}var pS,CS=g(()=>{pS=f(kt(),1);dl()});function ES(){return yi.types.model({drawLabels:!0,labelsAlignRight:!1,treeAreaWidth:yi.types.optional(yi.types.number,400),treeWidth:yi.types.optional(yi.types.number,300),showBranchLen:!0,drawTree:!0,drawNodeBubbles:!0}).actions(e=>({setTreeAreaWidth(t){e.treeAreaWidth=Math.round(t)},setTreeWidth(t){e.treeWidth=Math.round(t)},setLabelsAlignRight(t){e.labelsAlignRight=t},setDrawTree(t){e.drawTree=t},setShowBranchLen(t){e.showBranchLen=t},setDrawNodeBubbles(t){e.drawNodeBubbles=t},setDrawLabels(t){e.drawLabels=t}}))}var yi,IS=g(()=>{yi=f(kt(),1);dl()});function Dm(e,t){return xS.get(e.toUpperCase())?.get(t.toUpperCase())??-4}function _D(e,t){if(e.length!==t.length)throw new Error("Sequences must have the same length (aligned)");let r=0,n=0,o=0,i=0;for(let l=0;l<e.length;l++){let A=e[l],u=t[l];if(A==="-"&&u==="-")continue;if(A==="-"||u==="-"){n++;continue}let m=Dm(A,u);o+=m,i+=Math.max(Dm(A,A),Dm(u,u)),A.toUpperCase()===u.toUpperCase()?r++:n++}if(r+n===0||i<=0)return 1;let a=o/i,c=Math.max(.01,Math.min(1,a));return-Math.log(c)}function kD(e){let t=e.length,r=[];for(let n=0;n<t;n++){r[n]=[];for(let o=0;o<t;o++)n===o?r[n][o]=0:o<n?r[n][o]=r[o][n]:r[n][o]=_D(e[n][1],e[o][1])}return r}function DD(e,t){let r=e.length;if(r<2)return{name:t[0]};if(r===2){let a=e[0][1];return{left:{name:t[0]},right:{name:t[1]},leftLength:a/2,rightLength:a/2}}let n=[];for(let a=0;a<r;a++)n[a]=[...e[a]];let o=t.map(a=>({name:a})),i=r;for(;i>2;){let a=[];for(let x=0;x<o.length;x++)o[x]!==void 0&&a.push(x);let c=new Map;for(let x of a){let S=0;for(let M of a)x!==M&&(S+=n[x][M]);c.set(x,S)}let l=1/0,A=-1,u=-1;for(let x=0;x<a.length;x++)for(let S=x+1;S<a.length;S++){let M=a[x],B=a[S],Q=(i-2)*n[M][B]-c.get(M)-c.get(B);Q<l&&(l=Q,A=M,u=B)}let m=n[A][u],d=c.get(A),p=c.get(u),C,y;i>2?(C=m/2+(d-p)/(2*(i-2)),y=m-C):(C=m/2,y=m/2),C=Math.max(0,C),y=Math.max(0,y);let I={left:o[A],right:o[u],leftLength:C,rightLength:y},h=A;for(let x of a)if(x!==A&&x!==u){let S=(n[A][x]+n[u][x]-m)/2;n[h][x]=Math.max(0,S),n[x][h]=Math.max(0,S)}o[u]=void 0,o[h]=I,i--}let s=[];for(let a=0;a<o.length;a++)o[a]!==void 0&&s.push(a);if(s.length===2){let a=s[0],c=s[1],l=n[a][c];return{left:o[a],right:o[c],leftLength:l/2,rightLength:l/2}}return o[s[0]]}function Nm(e,t){let r;if(e.name!==void 0&&!e.left&&!e.right)r=`'${e.name.replaceAll("'","''")}'`;else{let n=e.left?Nm(e.left,e.leftLength):"",o=e.right?Nm(e.right,e.rightLength):"";r=`(${n},${o})`}return t!==void 0&&(r+=`:${t.toFixed(6)}`),r}function yS(e){if(e.length<2)throw new Error("Need at least 2 sequences to build a tree");let t=e.map(o=>o[0]),r=kD(e),n=DD(r,t);return Nm(n)+";"}var gl,TD,xS,wS=g(()=>{gl="ARNDCQEGHILKMFPSTWYVBZX*",TD=[[4,-1,-2,-2,0,-1,-1,0,-2,-1,-1,-1,-1,-2,-1,1,0,-3,-2,0,-2,-1,0,-4],[-1,5,0,-2,-3,1,0,-2,0,-3,-2,2,-1,-3,-2,-1,-1,-3,-2,-3,-1,0,-1,-4],[-2,0,6,1,-3,0,0,0,1,-3,-3,0,-2,-3,-2,1,0,-4,-2,-3,3,0,-1,-4],[-2,-2,1,6,-3,0,2,-1,-1,-3,-4,-1,-3,-3,-1,0,-1,-4,-3,-3,4,1,-1,-4],[0,-3,-3,-3,9,-3,-4,-3,-3,-1,-1,-3,-1,-2,-3,-1,-1,-2,-2,-1,-3,-3,-2,-4],[-1,1,0,0,-3,5,2,-2,0,-3,-2,1,0,-3,-1,0,-1,-2,-1,-2,0,3,-1,-4],[-1,0,0,2,-4,2,5,-2,0,-3,-3,1,-2,-3,-1,0,-1,-3,-2,-2,1,4,-1,-4],[0,-2,0,-1,-3,-2,-2,6,-2,-4,-4,-2,-3,-3,-2,0,-2,-2,-3,-3,-1,-2,-1,-4],[-2,0,1,-1,-3,0,0,-2,8,-3,-3,-1,-2,-1,-2,-1,-2,-2,2,-3,0,0,-1,-4],[-1,-3,-3,-3,-1,-3,-3,-4,-3,4,2,-3,1,0,-3,-2,-1,-3,-1,3,-3,-3,-1,-4],[-1,-2,-3,-4,-1,-2,-3,-4,-3,2,4,-2,2,0,-3,-2,-1,-2,-1,1,-4,-3,-1,-4],[-1,2,0,-1,-3,1,1,-2,-1,-3,-2,5,-1,-3,-1,0,-1,-3,-2,-2,0,1,-1,-4],[-1,-1,-2,-3,-1,0,-2,-3,-2,1,2,-1,5,0,-2,-1,-1,-1,-1,1,-3,-1,-1,-4],[-2,-3,-3,-3,-2,-3,-3,-3,-1,0,0,-3,0,6,-4,-2,-2,1,3,-1,-3,-3,-1,-4],[-1,-2,-2,-1,-3,-1,-1,-2,-2,-3,-3,-1,-2,-4,7,-1,-1,-4,-3,-2,-2,-1,-2,-4],[1,-1,1,0,-1,0,0,0,-1,-2,-2,0,-1,-2,-1,4,1,-3,-2,-2,0,0,0,-4],[0,-1,0,-1,-1,-1,-1,-2,-2,-1,-1,-1,-1,-2,-1,1,5,-2,-2,0,-1,-1,0,-4],[-3,-3,-4,-4,-2,-2,-3,-2,-2,-3,-2,-3,-1,1,-4,-3,-2,11,2,-3,-4,-3,-2,-4],[-2,-2,-2,-3,-2,-1,-2,-3,2,-1,-1,-2,-1,3,-3,-2,-2,2,7,-1,-3,-2,-1,-4],[0,-3,-3,-3,-1,-2,-2,-3,-3,3,1,-2,1,-1,-2,-2,0,-3,-1,4,-3,-2,-1,-4],[-2,-1,3,4,-3,0,1,-1,0,-3,-4,0,-3,-3,-2,0,-1,-4,-3,-3,4,1,-1,-4],[-1,0,0,1,-3,3,4,-2,0,-3,-3,1,-1,-3,-1,0,-1,-3,-2,-2,1,4,-1,-4],[0,-1,-1,-1,-2,-1,-1,-1,-1,-1,-1,-1,-1,-1,-2,0,0,-2,-1,-1,-1,-1,-1,-4],[-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,1]],xS=new Map;for(let e=0;e<gl.length;e++){let t=new Map;for(let r=0;r<gl.length;r++)t.set(gl[r],TD[e][r]);xS.set(gl[e],t)}});function Lm(e){let t=[],r=0;for(;r<e.length&&(r=e.indexOf("{",r),r!==-1);){let n=1,o=r+1;for(r++;r<e.length&&n>0;)e[r]==="{"?n++:e[r]==="}"&&n--,r++;n===0&&t.push(e.slice(o,r-1).trim())}return t}function LD(e,t){let r=e.indexOf("{",t);if(r===-1)return;let n=1,o=r+1;for(;o<e.length&&n>0;)e[o]==="{"?n++:e[o]==="}"&&n--,o++;return n===0?e.slice(r+1,o-1).trim():void 0}function bS(e){let t=e.replace(/\s+/g," ").replace(/\s*{\s*/g,"{").replace(/\s*}\s*/g,"}").replace(/\s*,\s*/g,",").replace(/\s*::\s*=\s*/g,"::=").replace(/^.*?::=/,""),r=FD(t),n=Object.fromEntries(Lm(r.fdict).flatMap(o=>{let i=RD(o);return i?[[i.id,ND[i.name]||i.name]]:[]}));return Lm(r.nodes).flatMap(o=>{let i=PD(o);if(!i)return[];let{features:s=[],...a}=i;return[{...a,...Object.fromEntries(s.map(c=>[n[c.featureid],c.value]))}]})}function FD(e){let t={},r=e.trim();r.startsWith("{")&&r.endsWith("}")&&(r=r.slice(1,-1).trim());let n=0;for(;n<r.length;){for(;n<r.length&&/\s/.test(r[n]);)n++;if(n>=r.length)break;let o=n;for(;n<r.length&&/\w/.test(r[n]);)n++;if(n>=r.length||r[n]!==" "&&r[n]!=="{"){n=r.indexOf(",",n),n=n===-1?r.length:n+1;continue}let i=r.slice(o,n).trim();for(;n<r.length&&/\s/.test(r[n]);)n++;if(n>=r.length||r[n]!=="{"){n=r.indexOf(",",n),n=n===-1?r.length:n+1;continue}let s=1,a=n+1;for(n++;n<r.length&&s>0;)r[n]==="{"?s++:r[n]==="}"&&s--,n++;s===0&&(t[i]=r.slice(a,n-1).trim()),n=r.indexOf(",",n),n=n===-1?r.length:n+1}return t}function RD(e){let t=/id\s+(\d+)/.exec(e),r=/name\s+"((?:[^"\\]|\\.)*)"/s.exec(e);return!t||!r?null:{id:parseInt(t[1],10),name:r[1].replace(/\\"/g,'"').replace(/\\\\/g,"\\")}}function PD(e){let t=/id\s+(\d+)/.exec(e);if(!t)return null;let r=/parent\s+(\d+)/.exec(e),n=e.indexOf("features"),o=n!==-1?LD(e,n):void 0;return{id:parseInt(t[1],10),...r?{parent:parseInt(r[1],10)}:{},features:o?Lm(o).flatMap(i=>{let s=OD(i);return s?[s]:[]}):[]}}function OD(e){let t=/featureid\s+(\d+)/.exec(e),r=/value\s+"((?:[^"\\]|\\.)*)"/s.exec(e);return!t||!r?null:{featureid:parseInt(t[1],10),value:r[1].replace(/\\"/g,'"').replace(/\\\\/g,"\\")}}var ND,BS=g(()=>{ND={$NODE_COLLAPSED:"collapsed",$NODE_COLOR:"color",$LABEL_BG_COLOR:"color","seq-id":"seqId","seq-title":"seqTitle","align-index":"alignIndex","accession-nbr":"accessionNbr","blast-name":"blastName","common-name":"commonName","leaf-count":"leafCount"}});function Fm(e,t){let r=0,n=0,o=0,i=e.length;for(;n<i&&e[n]===o;)n++,o++;for(;r<t;)for(r++,o++;n<i&&e[n]===o;)n++,o++;return o}function SS(e,t){let r=0,n=e.length-1;for(;r<=n;){let i=Math.floor((r+n)/2);if(e[i]===t)return;e[i]<t?r=i+1:n=i-1}return t-r}function GD({seq:e,blanks:t,visibleCol:r}){let n=Fm(t,r),o=e.length;if(n<o&&is(e[n]))return;let i=0;for(let s=0;s<n&&s<o;s++)is(e[s])||i++;return n<o?i:void 0}function QS({rowName:e,visibleCol:t,rowMap:r,blanks:n}){let o=r.get(e);return o!==void 0?GD({seq:o,visibleCol:t,blanks:n}):void 0}var MS=g(()=>{Cn()});function vS({row:e,seqPos:t}){let r=0,n=0;for(;n<e.length;){if(!is(e[n])){if(r===t)return n;r++}n++}return t===0?0:n}var TS=g(()=>{Cn()});function _S(e,t){let r=URL.createObjectURL(e),n=document.createElement("a");n.href=r,n.download=t,n.click(),setTimeout(()=>{URL.revokeObjectURL(r)},4e4)}var kS=g(()=>{});var ao,DS,UD,NS,LS=g(()=>{ao=f(b(),1),DS=f(O(),1),UD=(0,DS.observer)(({model:e})=>{let{scrollX:t,msaAreaWidth:r,minimapHeight:n,colWidth:o,numColumns:i}=e,s=12,a=n-12,c=r/i/o,l=-t,A=l+r,u=l*c,m=A*c,d="rgb(66, 119, 127)",p=.3;return ao.default.createElement(ao.default.Fragment,null,ao.default.createElement("rect",{x:0,y:0,width:r,height:s,stroke:"#555",fill:"none"}),ao.default.createElement("rect",{x:Math.max(0,u),y:0,width:m-u,height:s,fill:d,fillOpacity:p,stroke:"#555"}),ao.default.createElement("g",{transform:`translate(0 ${s})`},ao.default.createElement("polygon",{fill:d,fillOpacity:p,points:[[m,0],[u,0],[0,a],[r,a]].toString()})))}),NS=UD});var PS={};We(PS,{Context:()=>Om});function FS(e){return!e||typeof e=="string"?e:e+""}function Er(e,t){let r=Object.keys(t);for(let n of r)e=e.replace(new RegExp("\\{"+n+"\\}","gi"),t[n]);return e}function Rm(e){if(!e)throw new Error("cannot create a random attribute name for an undefined object");let t="ABCDEFGHIJKLMNOPQRSTUVWXTZabcdefghiklmnopqrstuvwxyz",r="";do{r="";for(let n=0;n<12;n++)r+=t[Math.floor(Math.random()*t.length)]}while(e[r]);return r}function HD(e,t=10){let r={},n=e.split(",");for(let o=0;o<n.length;o+=2){let i="&"+n[o+1]+";",s=parseInt(n[o],t);r[i]="&#"+s+";"}return r["\\xa0"]="&#160;",r}function jD(e){let t={left:"start",right:"end",center:"middle",start:"start",end:"end"};return t[e]||t.start}function qD(e){let t={alphabetic:"alphabetic",hanging:"hanging",top:"text-before-edge",bottom:"text-after-edge",middle:"central"};return t[e]||t.alphabetic}var RS,xs,ys,Pm,Om,OS=g(()=>{RS=HD("50,nbsp,51,iexcl,52,cent,53,pound,54,curren,55,yen,56,brvbar,57,sect,58,uml,59,copy,5a,ordf,5b,laquo,5c,not,5d,shy,5e,reg,5f,macr,5g,deg,5h,plusmn,5i,sup2,5j,sup3,5k,acute,5l,micro,5m,para,5n,middot,5o,cedil,5p,sup1,5q,ordm,5r,raquo,5s,frac14,5t,frac12,5u,frac34,5v,iquest,60,Agrave,61,Aacute,62,Acirc,63,Atilde,64,Auml,65,Aring,66,AElig,67,Ccedil,68,Egrave,69,Eacute,6a,Ecirc,6b,Euml,6c,Igrave,6d,Iacute,6e,Icirc,6f,Iuml,6g,ETH,6h,Ntilde,6i,Ograve,6j,Oacute,6k,Ocirc,6l,Otilde,6m,Ouml,6n,times,6o,Oslash,6p,Ugrave,6q,Uacute,6r,Ucirc,6s,Uuml,6t,Yacute,6u,THORN,6v,szlig,70,agrave,71,aacute,72,acirc,73,atilde,74,auml,75,aring,76,aelig,77,ccedil,78,egrave,79,eacute,7a,ecirc,7b,euml,7c,igrave,7d,iacute,7e,icirc,7f,iuml,7g,eth,7h,ntilde,7i,ograve,7j,oacute,7k,ocirc,7l,otilde,7m,ouml,7n,divide,7o,oslash,7p,ugrave,7q,uacute,7r,ucirc,7s,uuml,7t,yacute,7u,thorn,7v,yuml,ci,fnof,sh,Alpha,si,Beta,sj,Gamma,sk,Delta,sl,Epsilon,sm,Zeta,sn,Eta,so,Theta,sp,Iota,sq,Kappa,sr,Lambda,ss,Mu,st,Nu,su,Xi,sv,Omicron,t0,Pi,t1,Rho,t3,Sigma,t4,Tau,t5,Upsilon,t6,Phi,t7,Chi,t8,Psi,t9,Omega,th,alpha,ti,beta,tj,gamma,tk,delta,tl,epsilon,tm,zeta,tn,eta,to,theta,tp,iota,tq,kappa,tr,lambda,ts,mu,tt,nu,tu,xi,tv,omicron,u0,pi,u1,rho,u2,sigmaf,u3,sigma,u4,tau,u5,upsilon,u6,phi,u7,chi,u8,psi,u9,omega,uh,thetasym,ui,upsih,um,piv,812,bull,816,hellip,81i,prime,81j,Prime,81u,oline,824,frasl,88o,weierp,88h,image,88s,real,892,trade,89l,alefsym,8cg,larr,8ch,uarr,8ci,rarr,8cj,darr,8ck,harr,8dl,crarr,8eg,lArr,8eh,uArr,8ei,rArr,8ej,dArr,8ek,hArr,8g0,forall,8g2,part,8g3,exist,8g5,empty,8g7,nabla,8g8,isin,8g9,notin,8gb,ni,8gf,prod,8gh,sum,8gi,minus,8gn,lowast,8gq,radic,8gt,prop,8gu,infin,8h0,ang,8h7,and,8h8,or,8h9,cap,8ha,cup,8hb,int,8hk,there4,8hs,sim,8i5,cong,8i8,asymp,8j0,ne,8j1,equiv,8j4,le,8j5,ge,8k2,sub,8k3,sup,8k4,nsub,8k6,sube,8k7,supe,8kl,oplus,8kn,otimes,8l5,perp,8m5,sdot,8o8,lceil,8o9,rceil,8oa,lfloor,8ob,rfloor,8p9,lang,8pa,rang,9ea,loz,9j0,spades,9j3,clubs,9j5,hearts,9j6,diams,ai,OElig,aj,oelig,b0,Scaron,b1,scaron,bo,Yuml,m6,circ,ms,tilde,802,ensp,803,emsp,809,thinsp,80c,zwnj,80d,zwj,80e,lrm,80f,rlm,80j,ndash,80k,mdash,80o,lsquo,80p,rsquo,80q,sbquo,80s,ldquo,80t,rdquo,80u,bdquo,810,dagger,811,Dagger,81g,permil,81p,lsaquo,81q,rsaquo,85c,euro",32),xs={strokeStyle:{svgAttr:"stroke",canvas:"#000000",svg:"none",apply:"stroke"},fillStyle:{svgAttr:"fill",canvas:"#000000",svg:null,apply:"fill"},lineCap:{svgAttr:"stroke-linecap",canvas:"butt",svg:"butt",apply:"stroke"},lineJoin:{svgAttr:"stroke-linejoin",canvas:"miter",svg:"miter",apply:"stroke"},miterLimit:{svgAttr:"stroke-miterlimit",canvas:10,svg:4,apply:"stroke"},lineWidth:{svgAttr:"stroke-width",canvas:1,svg:1,apply:"stroke"},globalAlpha:{svgAttr:"opacity",canvas:1,svg:1,apply:"fill stroke"},font:{canvas:"10px sans-serif"},shadowColor:{canvas:"#000000"},shadowOffsetX:{canvas:0},shadowOffsetY:{canvas:0},shadowBlur:{canvas:0},textAlign:{canvas:"start"},textBaseline:{canvas:"alphabetic"},lineDash:{svgAttr:"stroke-dasharray",canvas:[],svg:null,apply:"stroke"}},ys=class{__root;__ctx;constructor(t,r){this.__root=t,this.__ctx=r}addColorStop(t,r){let n=this.__ctx.__createElement("stop");if(n.setAttribute("offset",String(t)),FS(r).includes("rgba")){let i=/rgba\(\s*(\d*\.?\d+)\s*,\s*(\d*\.?\d+)\s*,\s*(\d*\.?\d+)\s*,\s*(\d?\.?\d*)\s*\)/gi.exec(r);i&&(n.setAttribute("stop-color",Er("rgb({r},{g},{b})",{r:i[1],g:i[2],b:i[3]})),n.setAttribute("stop-opacity",i[4]))}else n.setAttribute("stop-color",FS(r));this.__root.appendChild(n)}},Pm=class{__root;__ctx;constructor(t,r){this.__root=t,this.__ctx=r}},Om=class{width;height;enableMirroring;canvas;__document;__ctx;__canvas;__root;__ids;__defs;__currentElement;__styleStack;__groupStack;__currentDefaultPath;__currentPosition;__transformMatrix;__transformMatrixStack;__currentElementsToStyle;__options;__id;__fontUnderline;__fontHref;strokeStyle;fillStyle;lineCap;lineJoin;miterLimit;lineWidth;globalAlpha;font;shadowColor;shadowOffsetX;shadowOffsetY;shadowBlur;textAlign;textBaseline;lineDash;constructor(t,r){let n={width:500,height:500,enableMirroring:!1},o;typeof t=="number"&&r!==void 0?o={...n,width:t,height:r}:t&&typeof t=="object"?o=t:o=n,this.width=o.width||n.width,this.height=o.height||n.height,this.enableMirroring=o.enableMirroring!==void 0?o.enableMirroring:n.enableMirroring,this.canvas=this,this.__document=o.document||document,o.ctx?this.__ctx=o.ctx:(this.__canvas=this.__document.createElement("canvas"),this.__ctx=this.__canvas.getContext("2d")),this.__setDefaultStyles(),this.__styleStack=[this.__getStyleState()],this.__groupStack=[],this.__root=this.__document.createElementNS("http://www.w3.org/2000/svg","svg"),this.__root.setAttribute("version","1.1"),this.__root.setAttribute("xmlns","http://www.w3.org/2000/svg"),this.__root.setAttributeNS("http://www.w3.org/2000/xmlns/","xmlns:xlink","http://www.w3.org/1999/xlink"),this.__root.setAttribute("width",String(this.width)),this.__root.setAttribute("height",String(this.height)),this.__ids={},this.__defs=this.__document.createElementNS("http://www.w3.org/2000/svg","defs"),this.__root.appendChild(this.__defs),this.__currentElement=this.__document.createElementNS("http://www.w3.org/2000/svg","g"),this.__root.appendChild(this.__currentElement),this.__currentDefaultPath="",this.__currentPosition={},this.__transformMatrix=new DOMMatrix,this.resetTransform(),this.__options=o,this.__id=Math.random().toString(16).substring(2,8)}__createElement(t,r={},n){let o=this.__document.createElementNS("http://www.w3.org/2000/svg",t);n&&(o.setAttribute("fill","none"),o.setAttribute("stroke","none"));for(let i of Object.keys(r))o.setAttribute(i,r[i]);return o}__setDefaultStyles(){for(let t of Object.keys(xs))this[t]=xs[t].canvas}__applyStyleState(t){for(let r of Object.keys(t))this[r]=t[r]}__getStyleState(){let t={};for(let r of Object.keys(xs))t[r]=this[r];return t}__applyTransformation(t,r){let{a:n,b:o,c:i,d:s,e:a,f:c}=r||this.getTransform();t.setAttribute("transform",`matrix(${n} ${o} ${i} ${s} ${a} ${c})`)}__applyStyleToCurrentElement(t){let r=this.__currentElement,n=this.__currentElementsToStyle;if(n){r.setAttribute(t,""),r=n.element;for(let i of n.children)i.setAttribute(t,"")}let o=Object.keys(xs);for(let i of o){let s=xs[i],a=this[i];if(s.apply){if(a instanceof Pm){if(a.__ctx)for(let c of Array.from(a.__ctx.__defs.childNodes)){let l=c.getAttribute("id");l&&(this.__ids[l]=l,this.__defs.appendChild(c))}r.setAttribute(s.apply,Er("url(#{id})",{id:a.__root.getAttribute("id")}))}else if(a instanceof ys)r.setAttribute(s.apply,Er("url(#{id})",{id:a.__root.getAttribute("id")}));else if(s.apply.includes(t)&&s.svg!==a)if((s.svgAttr==="stroke"||s.svgAttr==="fill")&&a&&a.includes("rgba")){let l=/rgba\(\s*(\d*\.?\d+)\s*,\s*(\d*\.?\d+)\s*,\s*(\d*\.?\d+)\s*,\s*(\d?\.?\d*)\s*\)/gi.exec(a);if(l){r.setAttribute(s.svgAttr,Er("rgb({r},{g},{b})",{r:l[1],g:l[2],b:l[3]}));let A=Number(l[4]),u=this.globalAlpha;u!=null&&(A*=u),r.setAttribute(s.svgAttr+"-opacity",String(A))}}else{let c=s.svgAttr,l=a;if(i==="globalAlpha"){if(c=t+"-"+s.svgAttr,r.getAttribute(c))continue}else if(i==="lineWidth"){let A=this.__getTransformScale();l=a*Math.max(A.x,A.y)}r.setAttribute(c,l)}}}}__closestGroupOrSvg(t){return t=t||this.__currentElement,t.nodeName==="g"||t.nodeName==="svg"?t:this.__closestGroupOrSvg(t.parentNode)}getSerializedSvg(t){let r=new XMLSerializer().serializeToString(this.__root);if(/xmlns="http:\/\/www\.w3\.org\/2000\/svg".+xmlns="http:\/\/www\.w3\.org\/2000\/svg/gi.test(r)&&(r=r.replace('xmlns="http://www.w3.org/2000/svg','xmlns:xlink="http://www.w3.org/1999/xlink')),t)for(let o of Object.keys(RS)){let i=new RegExp(o,"gi");i.test(r)&&(r=r.replace(i,RS[o]))}return r}getSvg(){return this.__root}save(){let t=this.__createElement("g"),r=this.__closestGroupOrSvg();this.__groupStack.push(r),r.appendChild(t),this.__currentElement=t;let n=this.__getStyleState();this.__styleStack.push(n),this.__transformMatrixStack||(this.__transformMatrixStack=[]),this.__transformMatrixStack.push(this.getTransform())}restore(){this.__currentElement=this.__groupStack.pop(),this.__currentElementsToStyle=void 0,this.__currentElement||(this.__currentElement=this.__root.childNodes[1]);let t=this.__styleStack.pop();this.__applyStyleState(t),this.__transformMatrixStack&&this.__transformMatrixStack.length>0&&this.setTransform(this.__transformMatrixStack.pop())}beginPath(){this.__currentDefaultPath="",this.__currentPosition={};let t=this.__createElement("path",{},!0);this.__closestGroupOrSvg().appendChild(t),this.__currentElement=t}__applyCurrentDefaultPath(){let t=this.__currentElement;t.nodeName==="path"&&t.setAttribute("d",this.__currentDefaultPath)}__addPathCommand(t){this.__currentDefaultPath+=" ",this.__currentDefaultPath+=t}moveTo(t,r){this.__currentElement.nodeName!=="path"&&this.beginPath(),this.__currentPosition={x:t,y:r},this.__addPathCommand(Er("M {x} {y}",{x:this.__matrixTransform(t,r).x,y:this.__matrixTransform(t,r).y}))}closePath(){this.__currentDefaultPath&&this.__addPathCommand("Z")}lineTo(t,r){this.__currentPosition={x:t,y:r},this.__currentDefaultPath.includes("M")?this.__addPathCommand(Er("L {x} {y}",{x:this.__matrixTransform(t,r).x,y:this.__matrixTransform(t,r).y})):this.__addPathCommand(Er("M {x} {y}",{x:this.__matrixTransform(t,r).x,y:this.__matrixTransform(t,r).y}))}bezierCurveTo(t,r,n,o,i,s){this.__currentPosition={x:i,y:s},this.__addPathCommand(Er("C {cp1x} {cp1y} {cp2x} {cp2y} {x} {y}",{cp1x:this.__matrixTransform(t,r).x,cp1y:this.__matrixTransform(t,r).y,cp2x:this.__matrixTransform(n,o).x,cp2y:this.__matrixTransform(n,o).y,x:this.__matrixTransform(i,s).x,y:this.__matrixTransform(i,s).y}))}quadraticCurveTo(t,r,n,o){this.__currentPosition={x:n,y:o},this.__addPathCommand(Er("Q {cpx} {cpy} {x} {y}",{cpx:this.__matrixTransform(t,r).x,cpy:this.__matrixTransform(t,r).y,x:this.__matrixTransform(n,o).x,y:this.__matrixTransform(n,o).y}))}stroke(){this.__currentElement.nodeName==="path"&&this.__currentElement.setAttribute("paint-order","fill stroke markers"),this.__applyCurrentDefaultPath(),this.__applyStyleToCurrentElement("stroke")}fill(){this.__currentElement.nodeName==="path"&&this.__currentElement.setAttribute("paint-order","stroke fill markers"),this.__applyCurrentDefaultPath(),this.__applyStyleToCurrentElement("fill")}rect(t,r,n,o){this.__currentElement.nodeName!=="path"&&this.beginPath(),this.moveTo(t,r),this.lineTo(t+n,r),this.lineTo(t+n,r+o),this.lineTo(t,r+o),this.lineTo(t,r),this.closePath()}__clearCanvas(){let t=this.__root.childNodes[1];this.__root.removeChild(t),this.__currentElement=this.__document.createElementNS("http://www.w3.org/2000/svg","g"),this.__root.appendChild(this.__currentElement),this.__groupStack=[]}fillRect(t,r,n,o){let{a:i,b:s,c:a,d:c,e:l,f:A}=this.getTransform();JSON.stringify([i,s,a,c,l,A])===JSON.stringify([1,0,0,1,0,0])&&t===0&&r===0&&n===this.width&&o===this.height&&this.__clearCanvas();let u=this.__createElement("rect",{x:t,y:r,width:n,height:o},!0);this.__closestGroupOrSvg().appendChild(u),this.__currentElement=u,this.__applyTransformation(u),this.__applyStyleToCurrentElement("fill")}strokeRect(t,r,n,o){let i=this.__createElement("rect",{x:t,y:r,width:n,height:o},!0);this.__closestGroupOrSvg().appendChild(i),this.__currentElement=i,this.__applyTransformation(i),this.__applyStyleToCurrentElement("stroke")}clearRect(t,r,n,o){let{a:i,b:s,c:a,d:c,e:l,f:A}=this.getTransform();if(JSON.stringify([i,s,a,c,l,A])===JSON.stringify([1,0,0,1,0,0])&&t===0&&r===0&&n===this.width&&o===this.height){this.__clearCanvas();return}let u=this.__createElement("rect",{x:t,y:r,width:n,height:o,fill:"#FFFFFF"},!0);this.__applyTransformation(u),this.__closestGroupOrSvg().appendChild(u)}createLinearGradient(t,r,n,o){let i=this.__createElement("linearGradient",{id:Rm(this.__ids),x1:t+"px",x2:n+"px",y1:r+"px",y2:o+"px",gradientUnits:"userSpaceOnUse"});return this.__defs.appendChild(i),new ys(i,this)}createRadialGradient(t,r,n,o,i,s){let a=this.__createElement("radialGradient",{id:Rm(this.__ids),cx:o+"px",cy:i+"px",r:s+"px",fx:t+"px",fy:r+"px",gradientUnits:"userSpaceOnUse"});return this.__defs.appendChild(a),new ys(a,this)}__applyText(t,r,n,o){let i=document.createElement("span");i.setAttribute("style","font:"+this.font);let s=i.style,a=this.__closestGroupOrSvg(),c=this.__createElement("text",{"font-family":s.fontFamily,"font-size":s.fontSize,"font-style":s.fontStyle,"font-weight":s.fontWeight,"text-decoration":this.__fontUnderline,x:r,y:n,"text-anchor":jD(this.textAlign),"dominant-baseline":qD(this.textBaseline)},!0);c.appendChild(this.__document.createTextNode(t)),this.__currentElement=c,this.__applyTransformation(c),this.__applyStyleToCurrentElement(o);let l=c;if(this.__fontHref){let A=this.__createElement("a");A.setAttributeNS("http://www.w3.org/1999/xlink","xlink:href",this.__fontHref),A.appendChild(c),l=A}a.appendChild(l)}fillText(t,r,n){this.__applyText(t,r,n,"fill")}strokeText(t,r,n){this.__applyText(t,r,n,"stroke")}measureText(t){return this.__ctx.font=this.font,this.__ctx.measureText(t)}arc(t,r,n,o,i,s){if(o===i)return;o=o%(2*Math.PI),i=i%(2*Math.PI),o===i&&(i=(i+2*Math.PI-.001*(s?-1:1))%(2*Math.PI));let a=t+n*Math.cos(i),c=r+n*Math.sin(i),l=t+n*Math.cos(o),A=r+n*Math.sin(o),u=s?0:1,m=0,d=i-o;d<0&&(d+=2*Math.PI),s?m=d>Math.PI?0:1:m=d>Math.PI?1:0;let p=Math.hypot(this.__transformMatrix.a,this.__transformMatrix.b),C=Math.hypot(this.__transformMatrix.c,this.__transformMatrix.d);this.lineTo(l,A),this.__addPathCommand(Er("A {rx} {ry} {xAxisRotation} {largeArcFlag} {sweepFlag} {endX} {endY}",{rx:n*p,ry:n*C,xAxisRotation:0,largeArcFlag:m,sweepFlag:u,endX:this.__matrixTransform(a,c).x,endY:this.__matrixTransform(a,c).y})),this.__currentPosition={x:a,y:c}}clip(){let t=this.__closestGroupOrSvg(),r=this.__createElement("clipPath"),n=Rm(this.__ids),o=this.__createElement("g");this.__applyCurrentDefaultPath(),t.removeChild(this.__currentElement),r.setAttribute("id",n),r.appendChild(this.__currentElement),this.__defs.appendChild(r),t.setAttribute("clip-path",Er("url(#{id})",{id:n})),t.appendChild(o),this.__currentElement=o}setLineDash(t){t&&t.length>0?this.lineDash=t.join(","):this.lineDash=null}setTransform(t,r,n,o,i,s){t instanceof DOMMatrix?this.__transformMatrix=new DOMMatrix([t.a,t.b,t.c,t.d,t.e,t.f]):this.__transformMatrix=new DOMMatrix([t,r,n,o,i,s])}getTransform(){let{a:t,b:r,c:n,d:o,e:i,f:s}=this.__transformMatrix;return new DOMMatrix([t,r,n,o,i,s])}resetTransform(){this.setTransform(1,0,0,1,0,0)}scale(t,r){if(r===void 0&&(r=t),isNaN(t)||isNaN(r)||!isFinite(t)||!isFinite(r))return;let n=this.getTransform().scale(t,r);this.setTransform(n)}rotate(t){let r=this.getTransform().multiply(new DOMMatrix([Math.cos(t),Math.sin(t),-Math.sin(t),Math.cos(t),0,0]));this.setTransform(r)}translate(t,r){let n=this.getTransform().translate(t,r);this.setTransform(n)}transform(t,r,n,o,i,s){let a=this.getTransform().multiply(new DOMMatrix([t,r,n,o,i,s]));this.setTransform(a)}__matrixTransform(t,r){return new DOMPoint(t,r).matrixTransform(this.__transformMatrix)}__getTransformScale(){return{x:Math.hypot(this.__transformMatrix.a,this.__transformMatrix.b),y:Math.hypot(this.__transformMatrix.c,this.__transformMatrix.d)}}__getTransformRotation(){return Math.atan2(this.__transformMatrix.b,this.__transformMatrix.a)}drawFocusRing(){}createImageData(){}putImageData(){}globalCompositeOperation(){}drawImage(){}createPattern(){return null}}});var jS={};We(jS,{renderToSvg:()=>JD});async function JD(e,t){await(0,HS.when)(()=>!!e.dataInitialized);let{width:r,height:n,scrollX:o,scrollY:i,totalTrackAreaHeight:s}=e,{exportType:a,theme:c,includeMinimap:l,includeTracks:A}=t,u=A?s:0;if(a==="entire")return GS({width:e.totalWidth+e.treeAreaWidth,height:e.totalHeight+u,contentHeight:e.totalHeight,trackHeight:u,theme:c,model:e,offsetY:0,offsetX:0,includeMinimap:l,includeTracks:A});if(a==="viewport")return GS({width:r,height:n+(l?e.minimapHeight:0)+u,contentHeight:n,trackHeight:u,theme:c,model:e,offsetY:-i,offsetX:-o,includeMinimap:l,includeTracks:A});throw new Error("unknown export type")}async function GS({width:e,height:t,contentHeight:r,trackHeight:n,offsetX:o,offsetY:i,theme:s,model:a,includeMinimap:c,includeTracks:l}){let{Context:A}=await Promise.resolve().then(()=>(OS(),PS)),u=c?WD:$D;return(0,US.renderToStaticMarkup)(le.default.createElement(zD,{width:e,height:t},le.default.createElement(u,{model:a},l&&n>0?le.default.createElement(YD,{Context:A,model:a,theme:s,offsetX:o,width:e,trackHeight:n}):null,le.default.createElement("g",{transform:n>0?`translate(0 ${n})`:void 0},le.default.createElement(VD,{Context:A,model:a,theme:s,offsetX:o,offsetY:i,width:e,contentHeight:r})))))}function VD({model:e,theme:t,width:r,contentHeight:n,offsetX:o,offsetY:i,Context:s}){let{treeAreaWidth:a,colorScheme:c,id:l}=e,A=`tree-${l}`,u=`msa-${l}`,m=zn(c,t),d=new s(r,n),p=new s(r,n);zc({ctx:p,offsetX:o,offsetY:i,model:e,blockSizeYOverride:n,highResScaleFactorOverride:1});let C=r-a;return rl({model:e,offsetY:i,ctx:d,theme:t,blockSizeYOverride:n,highResScaleFactorOverride:1}),$c({model:e,theme:t,offsetY:i,offsetX:o,contrastScheme:m,ctx:p,blockSizeXOverride:C,blockSizeYOverride:n,highResScaleFactorOverride:1}),le.default.createElement(le.default.Fragment,null,le.default.createElement("defs",null,le.default.createElement("clipPath",{id:A},le.default.createElement("rect",{x:0,y:0,width:a,height:n}))),le.default.createElement("defs",null,le.default.createElement("clipPath",{id:u},le.default.createElement("rect",{x:0,y:0,width:C,height:n}))),le.default.createElement("g",{clipPath:`url(#${A})`,dangerouslySetInnerHTML:{__html:d.getSvg().innerHTML}}),le.default.createElement("g",{clipPath:`url(#${u})`,transform:`translate(${a} 0)`,dangerouslySetInnerHTML:{__html:p.getSvg().innerHTML}}))}function YD({model:e,theme:t,width:r,trackHeight:n,offsetX:o,Context:i}){let{treeAreaWidth:s,colorScheme:a,id:c}=e,l=`tracks-${c}`,A=zn(a,t),u=r-s,m=new i(u,n);return XB({model:e,ctx:m,offsetX:o,contrastScheme:A,blockSizeXOverride:u,highResScaleFactorOverride:1}),le.default.createElement("g",{transform:`translate(${s} 0)`},le.default.createElement("defs",null,le.default.createElement("clipPath",{id:l},le.default.createElement("rect",{x:0,y:0,width:u,height:n}))),le.default.createElement("g",{clipPath:`url(#${l})`,dangerouslySetInnerHTML:{__html:m.getSvg().innerHTML}}))}function WD({model:e,children:t}){let{minimapHeight:r,treeAreaWidth:n}=e;return le.default.createElement(le.default.Fragment,null,le.default.createElement("g",{transform:`translate(${n} 0)`},le.default.createElement(NS,{model:e})),le.default.createElement("g",{transform:`translate(0 ${r})`},t))}function zD({width:e,height:t,children:r}){return le.default.createElement("svg",{width:e,height:t,xmlns:"http://www.w3.org/2000/svg",xmlnsXlink:"http://www.w3.org/1999/xlink",viewBox:[0,0,e,t].toString()},r)}function $D({children:e}){return e}var le,US,HS,qS=g(()=>{le=f(b(),1),US=f(ge(),1),HS=f(Hr(),1);LS();$f();Kf();fl();nl();Cn()});function KD(){return X.types.compose(dS(),ES(),hS(),X.types.model("MsaView",{id:co.ElementId,showDomains:!1,hideGaps:!0,allowedGappyness:100,subFeatureRows:!1,type:X.types.literal("MsaView"),drawMsaLetters:!0,height:X.types.optional(X.types.number,550),rowHeight:16,scrollY:0,scrollX:0,colWidth:12,treeFilehandle:X.types.maybe(co.FileLocation),msaFilehandle:X.types.maybe(co.FileLocation),treeMetadataFilehandle:X.types.maybe(co.FileLocation),gffFilehandle:X.types.maybe(co.FileLocation),currentAlignment:0,collapsed:X.types.array(X.types.string),showOnly:X.types.maybe(X.types.string),turnedOffTracks:X.types.map(X.types.boolean),data:X.types.optional(uS(),{tree:"",msa:"",treeMetadata:""}),featureFilters:X.types.map(X.types.boolean),relativeTo:X.types.maybe(X.types.string)})).volatile(()=>({headerHeight:0,status:void 0,highResScaleFactor:2,loadingMSA:!1,loadingTree:!1,volatileWidth:void 0,resizeHandleWidth:5,blockSize:500,mouseRow:void 0,mouseCol:void 0,mouseClickRow:void 0,mouseClickCol:void 0,hoveredTreeNode:void 0,highlightedColumns:void 0,nref:0,minimapHeight:56,conservationTrackHeight:40,marginLeft:20,error:void 0,interProAnnotations:void 0})).actions(e=>({drawRelativeTo(t){e.relativeTo=t},setHideGaps(t){e.hideGaps=t},setAllowedGappyness(t){e.allowedGappyness=t},setLoadingMSA(t){e.loadingMSA=t},setLoadingTree(t){e.loadingTree=t},setWidth(t){e.volatileWidth=t},setHeight(t){e.height=t},setError(t){e.error=t},setMousePos(t,r){e.mouseCol=t,e.mouseRow=r},setHoveredTreeNode(t){if(!t){e.hoveredTreeNode=void 0;return}let r=hs(e.hierarchy,o=>o.data.id===t);if(!r){e.hoveredTreeNode=void 0;return}let n=Cs(r).map(o=>o.data.name);e.hoveredTreeNode={nodeId:t,descendantNames:n}},setHighlightedColumns(t){e.highlightedColumns=t},setShowDomains(t){e.showDomains=t},setSubFeatureRows(t){e.subFeatureRows=t},setMouseClickPos(t,r){e.mouseClickCol=t,e.mouseClickRow=r},setRowHeight(t){e.rowHeight=t},setColWidth(t){e.colWidth=t},setScrollY(t){e.scrollY=t},setCurrentAlignment(t){e.currentAlignment=t},toggleCollapsed(t){e.collapsed.includes(t)?e.collapsed.remove(t):e.collapsed.push(t)},setShowOnly(t){e.showOnly=t},setData(t){e.data=(0,X.cast)(t)},setMSAFilehandle(t){e.msaFilehandle=t},setTreeFilehandle(t){e.treeFilehandle=t},setGFFFilehandle(t){e.gffFilehandle=t},setMSA(t){e.data.setMSA(t)},setTree(t){e.data.setTree(t)},setTreeMetadata(t){e.data.setTreeMetadata(t)}})).views(e=>({get hideGapsEffective(){return e.hideGaps&&(e.collapsed.length>0||e.allowedGappyness<100)},get realAllowedGappyness(){return this.hideGapsEffective?e.allowedGappyness:100},get actuallyShowDomains(){return e.showDomains&&!!e.interProAnnotations},get viewInitialized(){return e.volatileWidth!==void 0},get width(){if(e.volatileWidth===void 0)throw new Error("not initialized");return e.volatileWidth}})).views(e=>({extraViewMenuItems(){return[]},get colorScheme(){return Ai[e.colorSchemeName]},get header(){return this.MSA?.getHeader()||{}},get alignmentNames(){return this.MSA?.alignmentNames||[]},get noTree(){return!!this.tree.noTree},get noDomains(){return!e.interProAnnotations},menuItems(){return[]},get treeMetadata(){return e.data.treeMetadata?JSON.parse(e.data.treeMetadata):{}},get MSA(){let t=e.data.msa;return t?Em(t,e.currentAlignment):null},get numColumns(){return(this.MSA?.getWidth()||0)-this.blanks.length},get tree(){let t=e.data.tree;return t?Ci(t.startsWith("BioTreeContainer")?aS(bS(t)):io(t.startsWith("SEQ")?ll(t).tree:t)):this.MSA?.getTree()||{noTree:!0,children:[],id:"empty",name:"empty"}},get rowNames(){return this.leaves.map(t=>t.data.name)},get mouseOverRowName(){let{mouseRow:t}=e;return t===void 0?void 0:this.rowNames[t]},get hoveredInsertion(){let{mouseCol:t,mouseRow:r}=e;if(t===void 0||r===void 0)return;let n=this.rowNames[r];if(!n)return;let o=this.insertionPositions.get(n);if(!o)return;let i=o.find(s=>s.pos===t);if(i)return{rowName:n,col:t,letters:i.letters}},get root(){let t=Pb(this.tree,r=>r.children);if(Ob(t,r=>r.children.length>0?0:1),Gb(t,(r,n)=>(r.data.length??1)-(n.data.length??1)),e.showOnly){let r=hs(t,n=>n.data.id===e.showOnly);r&&(t=r)}for(let r of e.collapsed){let n=hs(t,o=>o.data.id===r);n&&(n.children?jb(n):n.parent?.children&&(n.parent.children=n.parent.children.filter(o=>o.data.id!==r)))}return t},get msaAreaWidth(){return e.width-e.treeAreaWidth},get treeAreaWidthMinusMargin(){return e.treeAreaWidth-e.marginLeft},get blanks(){let{hideGapsEffective:t,realAllowedGappyness:r}=e;if(!t)return[];let n=this.leaves.map(l=>this.MSA?.getRow(l.data.name)).filter(Ve.notEmpty);if(n.length===0)return[];let o=n[0].length,i=n.length,s=Math.ceil(r/100*i),a=new Uint16Array(o);for(let l=0;l<i;l++){let A=n[l];for(let u=0;u<o;u++)A.charCodeAt(u)-45>>>0<=1&&a[u]++}let c=[];for(let l=0;l<o;l++)a[l]>=s&&c.push(l);return c},get blanksSet(){return new Set(this.blanks)},get insertionPositions(){let{hideGapsEffective:t}=e,{blanks:r,rows:n}=this,o=r.length;if(o===0||!t)return new Map;let i=new Map;for(let[s,a]of n){let c=[],l=0,A=0,u=-1,m=[],d=a.length;for(let p=0;p<d;p++)A<o&&r[A]===p?(a.charCodeAt(p)-45>>>0<=1||(u===l?m.push(a[p]):(m.length>0&&c.push({pos:u,letters:m.join("")}),u=l,m=[a[p]])),A++):l++;m.length>0&&c.push({pos:u,letters:m.join("")}),c.length>0&&i.set(s,c)}return i},get rows(){let t=this.MSA;return this.leaves.map(r=>[r.data.name,t?.getRow(r.data.name)]).filter(r=>!!r[1])},get numRows(){return this.rows.length},get rowMap(){return new Map(this.rows)},get columns(){return Object.fromEntries(this.rows.map((t,r)=>[t[0],this.columns2d[r]]))},get columns2d(){let{hideGapsEffective:t}=e;return this.rows.map(r=>r[1]).map(r=>t?xf(this.blanks,r):r)},get fontSize(){return Math.min(Math.max(6,e.rowHeight-3),18)},get colStats(){let t=[],r=this.columns2d;for(let n of r)for(let o=0;o<n.length;o++){let i=t[o]||{},s=n[o];i[s]||(i[s]=0),i[s]++,t[o]=i}return t},get colStatsSums(){return this.colStats.map(t=>(0,Ve.sum)(Object.values(t)))},get sequenceType(){let t=new Set;for(let s of this.colStats)for(let a of Object.keys(s)){let c=a.toUpperCase();c!=="-"&&c!=="."&&t.add(c)}let r=new Set(["A","C","G","T","N"]),n=new Set(["A","C","G","U","N"]),o=[...t].every(s=>r.has(s)),i=[...t].every(s=>n.has(s));return o&&!t.has("U")?"dna":i&&!t.has("T")?"rna":"amino"},get colConsensus(){let{colStats:t,colStatsSums:r}=this;return t.map((n,o)=>{let i=r[o],s=0,a="";for(let l in n){let A=n[l];A>s&&l!=="-"&&l!=="."&&(s=A,a=l)}let c=s/i;return{letter:a,color:c>.4?`hsl(240, 30%, ${100*Math.max(1-c/3,.3)}%)`:void 0}})},get colClustalX(){let{colStats:t,colStatsSums:r}=this;return t.map((n,o)=>{let i=r[o],s={},a=n.W??0,c=n.L??0,l=n.V??0,A=n.I??0,u=n.M??0,m=n.A??0,d=n.F??0,p=n.C??0,C=n.H??0,y=n.P??0,I=n.R??0,h=n.K??0,x=n.Q??0,S=n.E??0,M=n.D??0,B=n.T??0,Q=n.S??0,L=n.G??0,T=n.Y??0,re=n.N??0,k=a+c+l+A+u+m+d+p+C+y+T,j=h+I,J=x+S,R=S+M,ie=B+Q;return k/i>.6&&(s.W="rgb(128,179,230)",s.L="rgb(128,179,230)",s.V="rgb(128,179,230)",s.A="rgb(128,179,230)",s.I="rgb(128,179,230)",s.M="rgb(128,179,230)",s.F="rgb(128,179,230)",s.C="rgb(128,179,230)"),(j/i>.6||h/i>.8||I/i>.8||x/i>.8)&&(s.K="#d88",s.R="#d88"),(j/i>.6||J/i>.5||S/i>.8||x/i>.8||M/i>.8)&&(s.E="rgb(192, 72, 192)"),(j/i>.6||R/i>.5||h/i>.8||I/i>.8||x/i>.8)&&(s.D="rgb(204, 77, 204)"),(re/i>.5||T/i>.85)&&(s.N="#8f8"),(j/i>.6||J/i>.6||x/i>.85||S/i>.85||h/i>.85||I/i>.85)&&(s.Q="#8f8"),(k/i>.6||ie/i>.5||Q/i>.85||B/i>.85)&&(s.S="rgb(26,204,26)",s.T="rgb(26,204,26)"),p/i>.85&&(s.C="rgb(240, 128, 128)"),L/i>0&&(s.G="rgb(240, 144, 72)"),y/i>0&&(s.P="rgb(204, 204, 0)"),(k/i>.6||a/i>.85||T/i>.85||m/i>.85||p/i>.85||y/i>.85||x/i>.85||d/i>.85||C/i>.85||A/i>.85||c/i>.85||u/i>.85||l/i>.85)&&(s.H="rgb(26, 179, 179)",s.Y="rgb(26, 179, 179)"),s})},get conservation(){let{colStats:t,colStatsSums:r,sequenceType:n}=this,i=Math.log2(n==="amino"?20:4);return t.map((s,a)=>{let c=r[a];if(!c)return 0;let l=(s["-"]||0)+(s["."]||0),A=c-l;if(A===0)return 0;let u={};for(let C of Object.keys(s)){if(C==="-"||C===".")continue;let y=C.toUpperCase();u[y]=(u[y]||0)+s[C]}let m=0;for(let C of Object.keys(u)){let y=u[C]/A;y>0&&(m-=y*Math.log2(y))}let d=l/c;return Math.max(0,1-m/i)*(1-d)})},get hierarchy(){let t=this.root;return Hb(t,this.totalHeight,e.treeWidth),t.data.length=0,tm(t,0,e.treeWidth/em(t)),t},get totalHeight(){return Cs(this.root).length*e.rowHeight},get leaves(){return Cs(this.hierarchy)},get allBranchesLength0(){return Xc(this.hierarchy).every(t=>!t.source.data.length)},get showBranchLenEffective(){return this.allBranchesLength0?!1:e.showBranchLen}})).views(e=>({get totalWidth(){return e.numColumns*e.colWidth}})).views(e=>({get dataInitialized(){return(e.data.msa||e.data.tree)&&!e.error},get blocksX(){return $B({viewportWidth:e.msaAreaWidth,viewportX:-e.scrollX,blockSize:e.blockSize,mapWidth:e.totalWidth})},get blocksY(){return zB({viewportHeight:e.height,viewportY:-e.scrollY,blockSize:e.blockSize,mapHeight:e.totalHeight})}})).views(e=>({get blocks2d(){return e.blocksY.flatMap(t=>e.blocksX.map(r=>[r,t]))},get isLoading(){return e.loadingMSA||e.loadingTree},get maxScrollX(){return Math.min(-e.totalWidth+(e.msaAreaWidth-100),0)},get showMsaLetters(){return e.drawMsaLetters&&e.rowHeight>=5&&e.colWidth>e.rowHeight/2},get showTreeText(){return e.drawLabels&&e.rowHeight>=5}})).actions(e=>({setDrawMsaLetters(t){e.drawMsaLetters=t},calculateNeighborJoiningTreeFromMSA(){if(e.rows.length<2)throw new Error("Need at least 2 sequences to build a tree");let t=yS(e.rows);e.setTree(t)},resetZoom(){e.setColWidth(12),e.setRowHeight(16)},zoomOutHorizontal(){e.colWidth=Math.max(1,Math.floor(e.colWidth*.75)),e.scrollX=(0,Ve.clamp)(e.scrollX,e.maxScrollX,0)},zoomInHorizontal(){e.colWidth=Math.ceil(e.colWidth*1.5),e.scrollX=(0,Ve.clamp)(e.scrollX,e.maxScrollX,0)},zoomInVertical(){e.rowHeight=Math.ceil(e.rowHeight*1.5)},zoomOutVertical(){e.rowHeight=Math.max(1.5,Math.floor(e.rowHeight*.75))},zoomIn(){(0,jt.transaction)(()=>{e.colWidth=Math.ceil(e.colWidth*1.5),e.rowHeight=Math.ceil(e.rowHeight*1.5),e.scrollX=(0,Ve.clamp)(e.scrollX,e.maxScrollX,0)})},zoomOut(){(0,jt.transaction)(()=>{e.colWidth=Math.max(1,Math.floor(e.colWidth*.75)),e.rowHeight=Math.max(1.5,Math.floor(e.rowHeight*.75)),e.scrollX=(0,Ve.clamp)(e.scrollX,e.maxScrollX,0)})},doScrollY(t){e.scrollY=(0,Ve.clamp)(e.scrollY+t,-e.totalHeight+10,0)},setInterProAnnotations(t){e.interProAnnotations=t},applyGFFText(t){let r=Al(t),n=ul(r);e.interProAnnotations=n,e.setShowDomains(!0)},doScrollX(t){this.setScrollX(e.scrollX+t)},setScrollX(t){e.scrollX=(0,Ve.clamp)(t,e.maxScrollX,0)},toggleTrack(t){e.turnedOffTracks.has(t)?e.turnedOffTracks.delete(t):e.turnedOffTracks.set(t,!0)},setStatus(t){e.status=t}})).views(e=>({get labelsWidth(){let{rowHeight:t,leaves:r,treeMetadata:n,fontSize:o}=e;return t<=5?0:r.reduce((i,s)=>Math.max(i,lS(n[s.data.name]?.genome||s.data.name,o)),0)},get secondaryStructureConsensus(){return e.MSA?.secondaryStructureConsensus},get seqConsensus(){return e.MSA?.seqConsensus},get adapterTrackModels(){let{rowHeight:t,MSA:r,hideGapsEffective:n,blanks:o}=e;return(r?.tracks??[]).filter(s=>!!s.data).map(s=>({model:{...s,data:n&&s.data?xf(o,s.data):s.data,height:t},ReactComponent:nS}))},get tracks(){let t={model:{id:"conservation",name:"Conservation",height:e.conservationTrackHeight},ReactComponent:eS};return[...this.adapterTrackModels,t]},get turnedOnTracks(){return this.tracks.filter(t=>!e.turnedOffTracks.has(t.model.id))},get showHorizontalScrollbar(){return e.msaAreaWidth<e.totalWidth},get rowNamesSet(){return new Map(e.rowNames.map((t,r)=>[t,r]))},visibleColToRowLetter(t,r){let{rowMap:n,blanks:o}=e;return n.get(t)?.[Fm(o,r)]},visibleColToSeqPos(t,r){return QS({rowName:t,visibleCol:r,rowMap:e.rowMap,blanks:e.blanks})},visibleColToSeqPosOneBased(t,r){let n=this.visibleColToSeqPos(t,r);return n!==void 0?n+1:void 0},globalColToVisibleCol(t){let{blanks:r,hideGapsEffective:n}=e;return n?SS(r,t):t},seqPosToGlobalCol(t,r){let{rows:n}=e,o=this.rowNamesSet.get(t);return o!==void 0&&n[o]?vS({row:n[o][1],seqPos:r}):0},seqPosToVisibleCol(t,r){let n=this.seqPosToGlobalCol(t,r);return this.globalColToVisibleCol(n)}})).views(e=>({get hoveredCell(){let{mouseCol:t,mouseRow:r}=e;if(t===void 0||r===void 0)return;let n=e.rowNames[r];if(!n)return;let i=e.columns[n]?.[t],s=e.visibleColToSeqPosOneBased(n,t);return{rowName:n,col:t,base:i,seqPos:s}},get msaAreaHeight(){return e.height-(e.showHorizontalScrollbar?e.minimapHeight:0)-e.headerHeight},get totalTrackAreaHeight(){return(0,Ve.sum)(e.turnedOnTracks.map(t=>t.model.height))},get tidyInterProAnnotationTypes(){return new Map(this.tidyInterProAnnotations.map(t=>[t.accession,t]))},get tidyInterProAnnotations(){let{interProAnnotations:t}=e;return t?Object.entries(t).flatMap(([r,n])=>n.matches.flatMap(({signature:o,locations:i})=>o.entry?i.map(({start:s,end:a})=>({id:r,name:o.entry.name,accession:o.entry.accession,description:o.entry.description,start:s,end:a})):[])).toSorted((r,n)=>yf(n)-yf(r)):[]},get tidyFilteredInterProAnnotations(){return this.tidyInterProAnnotations.filter(t=>e.featureFilters.get(t.accession))},get tidyFilteredGatheredInterProAnnotations(){return(0,Ve.groupBy)(this.tidyFilteredInterProAnnotations,t=>t.id)}})).views(e=>({get showVerticalScrollbar(){return e.msaAreaHeight<e.totalHeight}})).views(e=>({get verticalScrollbarWidth(){return e.showVerticalScrollbar?20:0},get fillPalette(){return iS([...e.tidyInterProAnnotationTypes.keys()])},get strokePalette(){return Object.fromEntries(Object.entries(this.fillPalette).map(([t,r])=>[t,yt(r).darken(.1).toHex()]))},getRowData(t){return{data:e.MSA?.getRowData(t),treeMetadata:e.treeMetadata[t]}}})).actions(e=>({setHeaderHeight(t){e.headerHeight=t},setConservationTrackHeight(t){e.conservationTrackHeight=t},reset(){e.setData({tree:"",msa:""}),e.resetZoom(),e.setError(void 0),e.setScrollY(0),e.setScrollX(0),e.setCurrentAlignment(0),e.setTreeFilehandle(void 0),e.setMSAFilehandle(void 0),e.setGFFFilehandle(void 0),e.setInterProAnnotations({}),e.setShowDomains(!1)},async exportSVG(t){let{renderToSvg:r}=await Promise.resolve().then(()=>(qS(),jS)),n=await r(e,t),o=new Blob([n],{type:"image/svg+xml"});_S(o,"image.svg")},incrementRef(){e.nref++},initFilter(t){e.featureFilters.get(t)===void 0&&e.featureFilters.set(t,!0)},setFilter(t,r){e.featureFilters.set(t,r)},fit(){e.rowHeight=e.msaAreaHeight/e.numRows,e.colWidth=e.msaAreaWidth/e.numColumns,e.scrollX=0,e.scrollY=0},fitVertically(){e.rowHeight=e.msaAreaHeight/e.numRows,e.scrollY=0},fitHorizontally(){e.colWidth=e.msaAreaWidth/e.numColumns,e.scrollX=0},afterCreate(){(0,X.addDisposer)(e,(0,jt.autorun)(()=>{for(let t of e.tidyInterProAnnotationTypes.keys())this.initFilter(t)})),(0,X.addDisposer)(e,(0,jt.autorun)(async()=>{let{treeFilehandle:t}=e;if(t)try{e.setLoadingTree(!0),e.setTree(await(0,Ve.fetchAndMaybeUnzipText)((0,ws.openLocation)(t))),t.locationType==="BlobLocation"&&e.setTreeFilehandle(void 0)}catch(r){console.error(r),e.setError(r)}finally{e.setLoadingTree(!1)}})),(0,X.addDisposer)(e,(0,jt.autorun)(async()=>{let{treeMetadataFilehandle:t}=e;if(t)try{e.setTreeMetadata(await(0,Ve.fetchAndMaybeUnzipText)((0,ws.openLocation)(t)))}catch(r){console.error(r),e.setError(r)}})),(0,X.addDisposer)(e,(0,jt.autorun)(()=>{let t=e.data.gff;if(t)try{e.applyGFFText(t)}catch(r){console.error(r),e.setError(r)}})),(0,X.addDisposer)(e,(0,jt.autorun)(async()=>{let{gffFilehandle:t}=e;if(t)try{let r=await(0,Ve.fetchAndMaybeUnzipText)((0,ws.openLocation)(t));e.applyGFFText(r),t.locationType==="BlobLocation"&&e.setGFFFilehandle(void 0)}catch(r){console.error(r),e.setError(r)}})),(0,X.addDisposer)(e,(0,jt.autorun)(async()=>{let{msaFilehandle:t}=e;if(t)try{e.setLoadingMSA(!0),e.setError(void 0);let r=await(0,Ve.fetchAndMaybeUnzipText)((0,ws.openLocation)(t));(0,jt.transaction)(()=>{e.setMSA(r),t.locationType==="BlobLocation"&&e.setMSAFilehandle(void 0)})}catch(r){console.error(r),e.setError(r)}finally{e.setLoadingMSA(!1)}})),(0,X.addDisposer)(e,(0,jt.autorun)(()=>{e.colorSchemeName.includes("dynamic")&&(e.colStats,e.colStatsSums),e.columns})),(0,X.addDisposer)(e,(0,jt.autorun)(()=>{e.setTreeWidth(Math.max(50,e.treeAreaWidth-e.labelsWidth-10-e.marginLeft))}))}})).postProcessSnapshot(e=>{let t=e,{data:{tree:r,msa:n,treeMetadata:o},showDomains:i,hideGaps:s,allowedGappyness:a,subFeatureRows:c,drawMsaLetters:l,height:A,rowHeight:u,scrollY:m,scrollX:d,colWidth:p,currentAlignment:C,collapsed:y,showOnly:I,turnedOffTracks:h,featureFilters:x,relativeTo:S,bgColor:M,colorSchemeName:B,drawLabels:Q,labelsAlignRight:L,treeAreaWidth:T,treeWidth:re,showBranchLen:k,drawTree:j,drawNodeBubbles:J,...R}=t,_t=Object.fromEntries(Object.entries({showDomains:!1,hideGaps:!0,allowedGappyness:100,subFeatureRows:!1,drawMsaLetters:!0,height:550,rowHeight:16,scrollY:0,scrollX:0,colWidth:12,currentAlignment:0,bgColor:!0,colorSchemeName:ml,drawLabels:!0,labelsAlignRight:!1,treeAreaWidth:400,treeWidth:300,showBranchLen:!0,drawTree:!0,drawNodeBubbles:!0}).filter(([qt,Sn])=>t[qt]!==Sn).map(([qt])=>[qt,t[qt]]));return{...R,data:{...e.treeFilehandle?{}:{tree:r},...e.msaFilehandle?{}:{msa:n},...e.treeMetadataFilehandle?{}:{treeMetadata:o}},..._t,...y?.length?{collapsed:y}:{},...I!==void 0?{showOnly:I}:{},...h&&Object.keys(h).length>0?{turnedOffTracks:h}:{},...x&&Object.keys(x).length>0?{featureFilters:x}:{},...S!==void 0?{relativeTo:S}:{}}})}var Ve,ws,co,X,jt,pl,Hm=g(()=>{Ve=f(ge(),1),ws=f(SB(),1),co=f(MB(),1),X=f(kt(),1);Sc();jt=f(Hr(),1);WB();KB();vc();tS();oS();dl();sS();cS();rm();AS();fS();gS();CS();IS();wS();BS();MS();TS();Cn();kS();pl=KD});var jm,XD,ZD,e1=g(()=>{jm=f(b(),1),XD=f(bB(),1),ZD=f(Fu(),1);Hm();cm()});var qm=g(()=>{cm();e1();Hm()});function lN(e){let t=e;return t.type==="ProteinView"&&Array.isArray(t.structures)}function Bn(e){return e.filter(lN)}function El(e,t){if(t<0||t>=e.length)return;let r=0;for(let n=0;n<t;n++)e[n]!=="-"&&r++;if(e[t]!=="-")return r}function A1(e,t){let r=0;for(let n=0;n<e.length;n++)if(e[n]!=="-"){if(r===t)return n;r++}}var Bs=g(()=>{"use strict"});var D1={};We(D1,{default:()=>EN});var Ae,Il,T1,Ee,_1,k1,hN,CN,EN,N1=g(()=>{"use strict";Ae=f(b()),Il=f(ye()),T1=f(ge()),Ee=f(D()),_1=f(O()),k1=f(Be());Bs();hN=(0,k1.makeStyles)()(e=>({formControl:{marginBottom:e.spacing(2)}})),CN=(0,_1.observer)(function({model:t,handleClose:r}){let{classes:n}=hN(),o=(0,T1.getSession)(t),[i,s]=(0,Ae.useState)(""),[a,c]=(0,Ae.useState)(0),[l,A]=(0,Ae.useState)(t.querySeqName),[u,m]=(0,Ae.useState)(),d=Bn(o.views),C=d.find(h=>h.id===i)?.structures??[],y=t.rows.map(h=>h[0]),I=()=>{if(!i){m("Please select a protein view");return}try{t.connectToStructure(i,a,l),r()}catch(h){m(h instanceof Error?h.message:String(h))}};return Ae.default.createElement(Il.Dialog,{maxWidth:"sm",title:"Connect to Protein Structure",open:!0,onClose:r},Ae.default.createElement(Ee.DialogContent,null,d.length===0?Ae.default.createElement(Ee.Typography,{color:"textSecondary"},"No protein views are currently open. Please open a protein structure view first."):Ae.default.createElement(Ae.default.Fragment,null,Ae.default.createElement(Ee.FormControl,{fullWidth:!0,className:n.formControl},Ae.default.createElement(Ee.InputLabel,null,"Protein View"),Ae.default.createElement(Ee.Select,{value:i,label:"Protein View",onChange:h=>{s(h.target.value),c(0)}},d.map(h=>Ae.default.createElement(Ee.MenuItem,{key:h.id,value:h.id},h.displayName??`ProteinView ${h.id}`)))),C.length>1?Ae.default.createElement(Ee.FormControl,{fullWidth:!0,className:n.formControl},Ae.default.createElement(Ee.InputLabel,null,"Structure"),Ae.default.createElement(Ee.Select,{value:a,label:"Structure",onChange:h=>{c(h.target.value)}},C.map((h,x)=>Ae.default.createElement(Ee.MenuItem,{key:x,value:x},h.url??`Structure ${x+1}`)))):null,Ae.default.createElement(Ee.FormControl,{fullWidth:!0,className:n.formControl},Ae.default.createElement(Ee.InputLabel,null,"MSA Row"),Ae.default.createElement(Ee.Select,{value:l,label:"MSA Row",onChange:h=>{A(h.target.value)}},y.map(h=>Ae.default.createElement(Ee.MenuItem,{key:h,value:h},h)))),u?Ae.default.createElement(Il.ErrorMessage,{error:u}):null)),Ae.default.createElement(Ee.DialogActions,null,Ae.default.createElement(Ee.Button,{onClick:r},"Cancel"),Ae.default.createElement(Ee.Button,{onClick:I,variant:"contained",disabled:d.length===0||!i},"Connect")))}),EN=CN});var Ms,P1,xl,O1=g(()=>{"use strict";Ms=f(b()),P1=f(ye()),xl=class extends Ms.Component{constructor(t){super(t),this.state={hasError:!1,error:null}}static getDerivedStateFromError(t){return{hasError:!0,error:t}}componentDidCatch(t,r){console.error("MsaViewPanel error:",t,r.componentStack)}render(){return this.state.hasError?Ms.default.createElement("div",{style:{padding:20}},Ms.default.createElement(P1.ErrorMessage,{error:this.state.error})):this.props.children}}});function xN({baseUrl:e,rid:t}){return zm.default.createElement(G1.Typography,null,"RID ",t," (",zm.default.createElement(Rn,{href:`${e}?CMD=Get&RID=${t}`},"see status"),")")}var zm,G1,$m,U1=g(()=>{"use strict";zm=f(b()),G1=f(D());wa();$m=xN});function yN({baseUrl:e,rid:t,error:r}){return rr.default.createElement("div",null,t?rr.default.createElement($m,{rid:t,baseUrl:e}):null,rr.default.createElement(yl.ErrorMessage,{error:r}))}function wN({baseUrl:e,rid:t,progress:r}){let{classes:n}=q1();return rr.default.createElement("div",{className:n.loading},t?rr.default.createElement($m,{baseUrl:e,rid:t}):null,rr.default.createElement(Km.Typography,null,r))}var rr,yl,Km,H1,j1,q1,bN,J1,V1=g(()=>{"use strict";rr=f(b()),yl=f(ye()),Km=f(D()),H1=f(O()),j1=f(Be());U1();q1=(0,j1.makeStyles)()(e=>({margin:{padding:20},loading:{background:e.palette.background.paper}}));bN=(0,H1.observer)(function({model:t,baseUrl:r}){let{progress:n,rid:o,error:i}=t,{classes:s}=q1();return rr.default.createElement("div",{className:s.margin},rr.default.createElement(yl.LoadingEllipses,{message:"Running NCBI BLAST",variant:"h5"}),i?rr.default.createElement(yN,{baseUrl:r,rid:o,error:i}):o?rr.default.createElement(wN,{baseUrl:r,rid:o,progress:n}):rr.default.createElement(Km.Typography,null,n||"Initializing BLAST query"))}),J1=bN});var $1={};We($1,{default:()=>QN});var lo,Y1,W1,z1,BN,SN,QN,K1=g(()=>{"use strict";lo=f(b()),Y1=f(ye()),W1=f(O());qm();z1=f(Be());O1();V1();BN=(0,z1.makeStyles)()({loadingContainer:{padding:20}}),SN=(0,W1.observer)(function({model:t}){let{classes:r}=BN(),{blastParams:n,loadingStoredData:o}=t;return lo.default.createElement(xl,null,lo.default.createElement("div",null,n?lo.default.createElement(J1,{model:t,baseUrl:n.baseUrl}):o?lo.default.createElement("div",{className:r.loadingContainer},lo.default.createElement(Y1.LoadingEllipses,{message:"Loading MSA data",variant:"h6"})):lo.default.createElement(al,{model:t})))}),QN=SN});var vN={};We(vN,{default:()=>wl});var tQ=f(pd()),Zm=f(po()),rQ=f(ge()),ed=f(kt());W();var wd=f(F(),1),bd=(0,_.createSvgIcon)((0,wd.jsx)("path",{d:"M20 2H4c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2M8 20H4v-4h4zm0-6H4v-4h4zm0-6H4V4h4zm6 12h-4v-4h4zm0-6h-4v-4h4zm0-6h-4V4h4zm6 12h-4v-4h4zm0-6h-4v-4h4zm0-6h-4V4h4z"}),"GridOn");var Fd=f(b()),Rd=f(ge());var Mi=f(b()),Nd=f(O());var Dl=f(b()),vd=f(ge()),Nl=f(O());var Md=f(Be());function Ps(e){return!!e&&typeof e=="object"&&"hoverPosition"in e&&!!e.hoverPosition}var Os=(0,Md.makeStyles)()({highlight:{height:"100%",background:"rgba(255,255,0,0.2)",border:"1px solid rgba(50,50,0,0.2)",position:"absolute",zIndex:99,textAlign:"center",pointerEvents:"none",overflow:"hidden"}});var pQ=(0,Nl.observer)(function({model:e}){let{hovered:t,views:r}=(0,vd.getSession)(e);return r.some(o=>o.type==="MsaView")&&Ps(t)?Dl.default.createElement(hQ,{model:e,hovered:t}):null}),hQ=(0,Nl.observer)(function({model:e,hovered:t}){let{classes:r}=Os(),{offsetPx:n}=e,{coord:o,refName:i}=t.hoverPosition,s=e.bpToPx({refName:i,coord:o-1}),a=e.bpToPx({refName:i,coord:o});if(s&&a){let c=Math.max(Math.abs(a.offsetPx-s.offsetPx),4),l=Math.min(s.offsetPx,a.offsetPx)-n;return Dl.default.createElement("div",{className:r.highlight,style:{left:l,width:c}})}return null}),Td=pQ;var Qi=f(b()),Ll=f(ge()),Fl=f(O());function _d(e){return!!e&&typeof e=="object"&&"hoverFeature"in e&&"hoverPosition"in e&&!!e.hoverPosition}function Gs({assemblyManager:e,assemblyNames:t,refName:r}){let n=t?.[0];return n?e.get(n)?.getCanonicalRefName(r)??r:r}function kd(e){return/AF-([A-Z0-9]+)-F\d+/.exec(e)?.[1]}var CQ=(0,Fl.observer)(function({model:t}){let{views:r,hovered:n}=(0,Ll.getSession)(t),i=r.find(s=>s.type==="MsaView")?.connectedHighlights;return!Ps(n)&&i?.length?Qi.default.createElement(EQ,{model:t,highlights:Array.from(i)}):null}),EQ=(0,Fl.observer)(function({model:e,highlights:t}){let{classes:r}=Os(),{assemblyManager:n}=(0,Ll.getSession)(e),{offsetPx:o}=e;return Qi.default.createElement(Qi.default.Fragment,null,t.map((i,s)=>{let a=Gs({assemblyManager:n,assemblyNames:e.assemblyNames,refName:i.refName}),c=e.bpToPx({refName:a,coord:i.start}),l=e.bpToPx({refName:a,coord:i.end});if(c&&l){let A=Math.max(Math.abs(l.offsetPx-c.offsetPx),4),u=Math.min(c.offsetPx,l.offsetPx)-o;return Qi.default.createElement("div",{key:`${i.refName}-${i.start}-${i.end}-${s}`,className:r.highlight,style:{left:u,width:A}})}return null}))}),Dd=CQ;var IQ=(0,Nd.observer)(function({model:t}){return Mi.default.createElement(Mi.default.Fragment,null,Mi.default.createElement(Dd,{model:t}),Mi.default.createElement(Td,{model:t}))}),Ld=IQ;function Rl(e){e.addToExtensionPoint("LinearGenomeView-TracksContainerComponent",(t,{model:r})=>{let{views:n}=(0,Rd.getSession)(r);return n.some(i=>i.type==="MsaView")?[...t,Fd.default.createElement(Ld,{key:"highlight_protein_viewer_msaview",model:r})]:t})}var Cg=f(Pl());var Od=f(po());function Ol(e){let t=e.getAdapterType("BgzipFastaAdapter");return(0,Od.ConfigurationSchema)("BgzipFastaMsaAdapter",{msaRegex:{type:"string",defaultValue:"_"}},{baseConfiguration:t?.configSchema})}function rA(e){return e.addAdapterType(()=>new Cg.AdapterType({name:"BgzipFastaMsaAdapter",configSchema:Ol(e),adapterMetadata:{hiddenFromGUI:!0},getAdapterClass:()=>Promise.resolve().then(()=>(hg(),pg)).then(t=>t.default)}))}var Fa=f(ge());W();var Eg=f(F(),1),Ig=(0,_.createSvgIcon)((0,Eg.jsx)("path",{d:"M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6z"}),"Add");var Mt=f(b()),$h=f(ye()),Kh=f(ge()),Do=f(D());var Z=f(b()),yA=f(ye()),sp=f(ge()),Vt=f(D()),ap=f(O()),cp=f(Be());function wg({session:e,newViewTitle:t,view:r,feature:n,msaFilehandle:o,treeFilehandle:i,querySeqName:s,data:a}){e.addView("MsaView",{type:"MsaView",displayName:t,connectedViewId:r.id,connectedFeature:n.toJSON(),msaFilehandle:o,treeFilehandle:i,querySeqName:s,data:a})}var nA=f(b()),bg=f(D());function MQ({children:e,...t}){return nA.default.createElement("div",null,nA.default.createElement(bg.TextField,{...t},e))}var nt=MQ;var $s=f(ge());function Jt(e){return(0,$s.getContainingView)(e)}function Bg(e){return[...new Set(e.filter(t=>!!t))]}function Sg(e,t){return t.filter(r=>!!r).join(e)}function vQ(e){let r=(e.get("subfeatures")??[]).filter(n=>(n.get("type")==="mRNA"||n.get("type")==="transcript")&&n.get("subfeatures")?.some(o=>o.get("type")==="CDS"));return r.length>0?r:[e]}function zs(e){let t=(0,$s.sum)(e.get("subfeatures")?.filter(r=>r.get("type")?.toLowerCase()==="cds").map(r=>r.get("end")-r.get("start"))??[]);return{len:Math.floor(t/3),mod:t%3}}function _n(e){return e?.id()??""}function TQ(e){return e?Bg([e.id(),e.get("name"),e.get("id"),e.get("transcript_id")]):[]}function _i(e,t){return TQ(e).includes(t)}function Ks(e){return e?Sg(" ",[e.get("name"),e.get("id")]):""}function kn(e){return e?Sg(" ",[e.get("gene_name")??e.get("name"),e.get("id")?`(${e.get("id")})`:void 0]):""}function Xs(e,t){return`BLAST - ${kn(e)} - ${Ks(t)}`}function Qg(e){return vQ(e).toSorted((r,n)=>zs(n).len-zs(r).len)}function Zs(e){return e.replaceAll("*","").replaceAll("&","")}function ea(e){return Bg([e.id(),e.get("id"),e.get("name"),e.get("gene_id"),e.get("gene_name")])}var oA=f(b()),Mg=f(ye()),vg=f(D()),Tg=f(Be()),_Q=(0,Tg.makeStyles)()({dialogContent:{width:"80em"}});function ir({error:e,children:t}){let{classes:r}=_Q();return oA.default.createElement(vg.DialogContent,{className:r.dialogContent},e?oA.default.createElement(Mg.ErrorMessage,{error:e}):null,t)}var ta=f(b()),ki=f(D());function Or({onSubmit:e,onCancel:t,submitDisabled:r,submitLabel:n="Submit",cancelLabel:o="Cancel"}){return ta.default.createElement(ki.DialogActions,null,ta.default.createElement(ki.Button,{color:"primary",variant:"contained",disabled:r,onClick:()=>{e()}},n),ta.default.createElement(ki.Button,{color:"secondary",variant:"contained",onClick:()=>{t()}},o))}var sr=f(b()),Io=f(D()),Dg=f(Be());var _g=f(b()),kg=f(Be());var kQ=(0,kg.makeStyles)()({textAreaFont:{fontFamily:"Courier New"}});function iA({value:e}){let{classes:t}=kQ();return _g.default.createElement(nt,{variant:"outlined",multiline:!0,minRows:5,maxRows:10,fullWidth:!0,value:e,slotProps:{input:{readOnly:!0,classes:{input:t.textAreaFont}}}})}var DQ=(0,Dg.makeStyles)()({flex:{display:"flex"},minWidth:{minWidth:300},centered:{alignContent:"center",marginLeft:20}});function ar({feature:e,options:t,selectedId:r,selectedTranscript:n,setSelectedId:o,proteinSequence:i,validIds:s}){let{classes:a}=DQ(),[c,l]=(0,sr.useState)(!1);return sr.default.createElement(sr.default.Fragment,null,sr.default.createElement("div",{className:a.flex},sr.default.createElement(Io.TextField,{variant:"outlined",label:`Choose isoform of ${kn(e)}`,select:!0,className:a.minWidth,value:r,onChange:A=>{o(A.target.value)}},t.map(A=>{let u=s?s.some(p=>_i(A,p)):!0,{len:m,mod:d}=zs(A);return sr.default.createElement(Io.MenuItem,{value:_n(A),key:A.id(),disabled:!u},Ks(A)," (",m," aa)"," ",d?" (possible fragment)":"",s?u?" (has data)":" (no data)":"")})),sr.default.createElement("div",{className:a.centered},sr.default.createElement(Io.Button,{variant:"contained",color:"primary",onClick:()=>{l(!c)}},c?"Hide sequence":"Show sequence"))),c?sr.default.createElement(iA,{value:i?`>${Ks(n)}
70
- ${i}`:"Loading..."}):null)}var da=f(b());var cn=f(ge());function NQ(e,t){return e.map(r=>t.slice(r.start,r.end)).join("")}function LQ({cds:e,sequence:t,codonTable:r}){let n=NQ(e,t),o="";for(let i=0;i<n.length;i+=3)o+=r[n.slice(i,i+3)]??"&";return o}function FQ(e,t){return e.map(r=>({...r,start:t-r.end,end:t-r.start})).toSorted((r,n)=>r.start-n.start)}function Ng({feature:e,seq:t}){let{subfeatures:r,start:n,strand:o}=e.toJSON(),i=(0,cn.dedupe)(r?.toSorted((s,a)=>s.start-a.start).map(s=>({...s,start:s.start-n,end:s.end-n})).filter(s=>s.type==="CDS")??[],s=>`${s.start}-${s.end}`);return LQ({cds:o===-1?FQ(i,t.length):i,sequence:o===-1?(0,cn.revcom)(t):t,codonTable:(0,cn.generateCodonTable)(cn.defaultCodonTable)})}var np=f(ge());var qe=f(b(),1),xA=f(Pg(),1);var ot=f(b(),1);var ln={};We(ln,{ERROR_REVALIDATE_EVENT:()=>VQ,FOCUS_EVENT:()=>Og,MUTATE_EVENT:()=>Ug,RECONNECT_EVENT:()=>Gg});var Og=0,Gg=1,Ug=2,VQ=3;var Hg=Object.prototype.hasOwnProperty;function ra(e,t){var r,n;if(e===t)return!0;if(e&&t&&(r=e.constructor)===t.constructor){if(r===Date)return e.getTime()===t.getTime();if(r===RegExp)return e.toString()===t.toString();if(r===Array){if((n=e.length)===t.length)for(;n--&&ra(e[n],t[n]););return n===-1}if(!r||typeof e=="object"){n=0;for(r in e)if(Hg.call(e,r)&&++n&&!Hg.call(t,r)||!(r in t)||!ra(e[r],t[r]))return!1;return Object.keys(t).length===n}}return e!==e&&t!==t}var cr=new WeakMap,lr=()=>{},je=lr(),yo=Object,q=e=>e===je,Dt=e=>typeof e=="function",Ar=(e,t)=>({...e,...t}),ca=e=>Dt(e.then),aA={},na={},dA="undefined",wo=typeof window!=dA,ia=typeof document!=dA,qg=wo&&"Deno"in window,Jg=()=>wo&&typeof window.requestAnimationFrame!=dA,la=(e,t)=>{let r=cr.get(e);return[()=>!q(t)&&e.get(t)||aA,n=>{if(!q(t)){let o=e.get(t);t in na||(na[t]=o),r[5](t,Ar(o,n),o||aA)}},r[6],()=>!q(t)&&t in na?na[t]:!q(t)&&e.get(t)||aA]},AA=!0,YQ=()=>AA,[uA,fA]=wo&&window.addEventListener?[window.addEventListener.bind(window),window.removeEventListener.bind(window)]:[lr,lr],WQ=()=>{let e=ia&&document.visibilityState;return q(e)||e!=="hidden"},zQ=e=>(ia&&document.addEventListener("visibilitychange",e),uA("focus",e),()=>{ia&&document.removeEventListener("visibilitychange",e),fA("focus",e)}),$Q=e=>{let t=()=>{AA=!0,e()},r=()=>{AA=!1};return uA("online",t),uA("offline",r),()=>{fA("online",t),fA("offline",r)}},Vg={isOnline:YQ,isVisible:WQ},Yg={initFocus:zQ,initReconnect:$Q},Aa=!ot.default.useId,An=!wo||qg,gA=e=>Jg()?window.requestAnimationFrame(e):setTimeout(e,1),bo=An?ot.useEffect:ot.useLayoutEffect,cA=typeof navigator<"u"&&navigator.connection,mA=!An&&cA&&(["slow-2g","2g"].includes(cA.effectiveType)||cA.saveData),oa=new WeakMap,KQ=e=>yo.prototype.toString.call(e),lA=(e,t)=>e===`[object ${t}]`,XQ=0,sa=e=>{let t=typeof e,r=KQ(e),n=lA(r,"Date"),o=lA(r,"RegExp"),i=lA(r,"Object"),s,a;if(yo(e)===e&&!n&&!o){if(s=oa.get(e),s)return s;if(s=++XQ+"~",oa.set(e,s),Array.isArray(e)){for(s="@",a=0;a<e.length;a++)s+=sa(e[a])+",";oa.set(e,s)}if(i){s="#";let c=yo.keys(e).sort();for(;!q(a=c.pop());)q(e[a])||(s+=a+":"+sa(e[a])+",");oa.set(e,s)}}else s=n?e.toJSON():t=="symbol"?e.toString():t=="string"?JSON.stringify(e):""+e;return s},Ni=e=>{if(Dt(e))try{e=e()}catch{e=""}let t=e;return e=typeof e=="string"?e:(Array.isArray(e)?e.length:e)?sa(e):"",[e,t]},ZQ=0,Di=()=>++ZQ;async function ua(...e){let[t,r,n,o]=e,i=Ar({populateCache:!0,throwOnError:!0},typeof o=="boolean"?{revalidate:o}:o||{}),s=i.populateCache,a=i.rollbackOnError,c=i.optimisticData,l=m=>typeof a=="function"?a(m):a!==!1,A=i.throwOnError;if(Dt(r)){let m=r,d=[],p=t.keys();for(let C of p)!/^\$(inf|sub)\$/.test(C)&&m(t.get(C)._k)&&d.push(C);return Promise.all(d.map(u))}return u(r);async function u(m){let[d]=Ni(m);if(!d)return;let[p,C]=la(t,d),[y,I,h,x]=cr.get(t),S=()=>{let R=y[d];return(Dt(i.revalidate)?i.revalidate(p().data,m):i.revalidate!==!1)&&(delete h[d],delete x[d],R&&R[0])?R[0](2).then(()=>p().data):p().data};if(e.length<3)return S();let M=n,B,Q=!1,L=Di();I[d]=[L,0];let T=!q(c),re=p(),k=re.data,j=re._c,J=q(j)?k:j;if(T&&(c=Dt(c)?c(J,k):c,C({data:c,_c:J})),Dt(M))try{M=M(J)}catch(R){B=R,Q=!0}if(M&&ca(M))if(M=await M.catch(R=>{B=R,Q=!0}),L!==I[d][0]){if(Q)throw B;return M}else Q&&T&&l(B)&&(s=!0,C({data:J,_c:je}));if(s&&!Q)if(Dt(s)){let R=s(M,J);C({data:R,error:je,_c:je})}else C({data:M,error:je,_c:je});if(I[d][1]=Di(),Promise.resolve(S()).then(()=>{C({_c:je})}),Q){if(A)throw B;return}return M}}var jg=(e,t)=>{for(let r in e)e[r][0]&&e[r][0](t)},pA=(e,t)=>{if(!cr.has(e)){let r=Ar(Yg,t),n=Object.create(null),o=ua.bind(je,e),i=lr,s=Object.create(null),a=(A,u)=>{let m=s[A]||[];return s[A]=m,m.push(u),()=>m.splice(m.indexOf(u),1)},c=(A,u,m)=>{e.set(A,u);let d=s[A];if(d)for(let p of d)p(u,m)},l=()=>{if(!cr.has(e)&&(cr.set(e,[n,Object.create(null),Object.create(null),Object.create(null),o,c,a]),!An)){let A=r.initFocus(setTimeout.bind(je,jg.bind(je,n,0))),u=r.initReconnect(setTimeout.bind(je,jg.bind(je,n,1)));i=()=>{A&&A(),u&&u(),cr.delete(e)}}};return l(),[e,o,l,i]}return[e,cr.get(e)[4]]},eM=(e,t,r,n,o)=>{let i=r.errorRetryCount,s=o.retryCount,a=~~((Math.random()+.5)*(1<<(s<8?s:8)))*r.errorRetryInterval;!q(i)&&s>i||setTimeout(n,a,o)},Wg=ra,[fa,zg]=pA(new Map),ma=Ar({onLoadingSlow:lr,onSuccess:lr,onError:lr,onErrorRetry:eM,onDiscarded:lr,revalidateOnFocus:!0,revalidateOnReconnect:!0,revalidateIfStale:!0,shouldRetryOnError:!0,errorRetryInterval:mA?1e4:5e3,focusThrottleInterval:5*1e3,dedupingInterval:2*1e3,loadingTimeout:mA?5e3:3e3,compare:Wg,isPaused:()=>!1,cache:fa,mutate:zg,fallback:{}},Vg),hA=(e,t)=>{let r=Ar(e,t);if(t){let{use:n,fallback:o}=e,{use:i,fallback:s}=t;n&&i&&(r.use=n.concat(i)),o&&s&&(r.fallback=Ar(o,s))}return r},aa=(0,ot.createContext)({}),CA=e=>{let{value:t}=e,r=(0,ot.useContext)(aa),n=Dt(t),o=(0,ot.useMemo)(()=>n?t(r):t,[n,r,t]),i=(0,ot.useMemo)(()=>n?o:hA(r,o),[n,r,o]),s=o&&o.provider,a=(0,ot.useRef)(je);s&&!a.current&&(a.current=pA(s(i.cache||fa),o));let c=a.current;return c&&(i.cache=c[0],i.mutate=c[1]),bo(()=>{if(c)return c[2]&&c[2](),c[3]},[]),(0,ot.createElement)(aa.Provider,Ar(e,{value:i}))};var $g="$inf$";var Bo=f(b(),1);var Kg=wo&&window.__SWR_DEVTOOLS_USE__,tM=Kg?window.__SWR_DEVTOOLS_USE__:[],rM=()=>{Kg&&(window.__SWR_DEVTOOLS_REACT__=Bo.default)},nM=e=>Dt(e[1])?[e[0],e[1],e[2]||{}]:[e[0],null,(e[1]===null?e[2]:e[1])||{}],oM=()=>{let e=(0,Bo.useContext)(aa);return(0,Bo.useMemo)(()=>Ar(ma,e),[e])};var iM=e=>(t,r,n)=>e(t,r&&((...i)=>{let[s]=Ni(t),[,,,a]=cr.get(fa);if(s.startsWith($g))return r(...i);let c=a[s];return q(c)?r(...i):(delete a[s],c)}),n),sM=tM.concat(iM),Xg=e=>function(...r){let n=oM(),[o,i,s]=nM(r),a=hA(n,s),c=e,{use:l}=a,A=(l||[]).concat(sM);for(let u=A.length;u--;)c=A[u](c);return c(o,i||a.fetcher||null,a)},Zg=(e,t,r)=>{let n=t[e]||(t[e]=[]);return n.push(r),()=>{let o=n.indexOf(r);o>=0&&(n[o]=n[n.length-1],n.pop())}};rM();var aM=()=>{},NF=aM();var EA=qe.default.use||(e=>{switch(e.status){case"pending":throw e;case"fulfilled":return e.value;case"rejected":throw e.reason;default:throw e.status="pending",e.then(t=>{e.status="fulfilled",e.value=t},t=>{e.status="rejected",e.reason=t}),e}}),IA={dedupe:!0},ep=Promise.resolve(je),cM=()=>lr,lM=(e,t,r)=>{let{cache:n,compare:o,suspense:i,fallbackData:s,revalidateOnMount:a,revalidateIfStale:c,refreshInterval:l,refreshWhenHidden:A,refreshWhenOffline:u,keepPreviousData:m,strictServerPrefetchWarning:d}=r,[p,C,y,I]=cr.get(n),[h,x]=Ni(e),S=(0,qe.useRef)(!1),M=(0,qe.useRef)(!1),B=(0,qe.useRef)(h),Q=(0,qe.useRef)(t),L=(0,qe.useRef)(r),T=()=>L.current,re=()=>T().isVisible()&&T().isOnline(),[k,j,J,R]=la(n,h),ie=(0,qe.useRef)({}).current,_t=q(s)?q(r.fallback)?je:r.fallback[h]:s,qt=($,ne)=>{for(let me in ie){let de=me;if(de==="data"){if(!o($[de],ne[de])&&(!q($[de])||!o(ve,ne[de])))return!1}else if(ne[de]!==$[de])return!1}return!0},Sn=!S.current,vs=(0,qe.useMemo)(()=>{let $=k(),ne=R(),me=xe=>{let St=Ar(xe);return delete St._k,(()=>{if(!h||!t||T().isPaused())return!1;if(Sn&&!q(a))return a;let nn=q(_t)?St.data:_t;return i?q(nn)||c:q(nn)||c})()?{isValidating:!0,isLoading:!0,...St}:St},de=me($),tt=$===ne?de:me(ne),rt=de;return[()=>{let xe=me(k());return qt(xe,rt)?(rt.data=xe.data,rt.isLoading=xe.isLoading,rt.isValidating=xe.isValidating,rt.error=xe.error,rt):(rt=xe,xe)},()=>tt]},[n,h]),Zr=(0,xA.useSyncExternalStore)((0,qe.useCallback)($=>J(h,(ne,me)=>{qt(me,ne)||$()}),[n,h]),vs[0],vs[1]),Ts=p[h]&&p[h].length>0,en=Zr.data,Ir=q(en)?_t&&ca(_t)?EA(_t):_t:en,be=Zr.error,Ao=(0,qe.useRef)(Ir),ve=m?q(en)?q(Ao.current)?Ir:Ao.current:en:Ir,xr=h&&q(Ir),se=(0,qe.useRef)(null);!An&&(0,xA.useSyncExternalStore)(cM,()=>(se.current=!1,se),()=>(se.current=!0,se));let Qn=se.current;d&&Qn&&!i&&xr&&console.warn(`Missing pre-initiated data for serialized key "${h}" during server-side rendering. Data fetching should be initiated on the server and provided to SWR via fallback data. You can set "strictServerPrefetchWarning: false" to disable this warning.`);let Mn=!h||!t||T().isPaused()||Ts&&!q(be)?!1:Sn&&!q(a)?a:i?q(Ir)?!1:c:q(Ir)||c,nr=Sn&&Mn,_s=q(Zr.isValidating)?nr:Zr.isValidating,bi=q(Zr.isLoading)?nr:Zr.isLoading,tn=(0,qe.useCallback)(async $=>{let ne=Q.current;if(!h||!ne||M.current||T().isPaused())return!1;let me,de,tt=!0,rt=$||{},xe=!y[h]||!rt.dedupe,St=()=>Aa?!M.current&&h===B.current&&S.current:h===B.current,rn={isValidating:!1,isLoading:!1},nn=()=>{j(rn)},uo=()=>{let Ue=y[h];Ue&&Ue[1]===de&&delete y[h]},on={isValidating:!0};q(k().data)&&(on.isLoading=!0);try{if(xe&&(j(on),r.loadingTimeout&&q(k().data)&&setTimeout(()=>{tt&&St()&&T().onLoadingSlow(h,r)},r.loadingTimeout),y[h]=[ne(x),Di()]),[me,de]=y[h],me=await me,xe&&setTimeout(uo,r.dedupingInterval),!y[h]||y[h][1]!==de)return xe&&St()&&T().onDiscarded(h),!1;rn.error=je;let Ue=C[h];if(!q(Ue)&&(de<=Ue[0]||de<=Ue[1]||Ue[1]===0))return nn(),xe&&St()&&T().onDiscarded(h),!1;let Fe=k().data;rn.data=o(Fe,me)?Fe:me,xe&&St()&&T().onSuccess(me,h,r)}catch(Ue){uo();let Fe=T(),{shouldRetryOnError:vn}=Fe;Fe.isPaused()||(rn.error=Ue,xe&&St()&&(Fe.onError(Ue,h,Fe),(vn===!0||Dt(vn)&&vn(Ue))&&(!T().revalidateOnFocus||!T().revalidateOnReconnect||re())&&Fe.onErrorRetry(Ue,h,Fe,ks=>{let fo=p[h];fo&&fo[0]&&fo[0](ln.ERROR_REVALIDATE_EVENT,ks)},{retryCount:(rt.retryCount||0)+1,dedupe:!0})))}return tt=!1,nn(),!0},[h,n]),Bi=(0,qe.useCallback)((...$)=>ua(n,B.current,...$),[]);if(bo(()=>{Q.current=t,L.current=r,q(en)||(Ao.current=en)}),bo(()=>{if(!h)return;let $=tn.bind(je,IA),ne=0;T().revalidateOnFocus&&(ne=Date.now()+T().focusThrottleInterval);let de=Zg(h,p,(tt,rt={})=>{if(tt==ln.FOCUS_EVENT){let xe=Date.now();T().revalidateOnFocus&&xe>ne&&re()&&(ne=xe+T().focusThrottleInterval,$())}else if(tt==ln.RECONNECT_EVENT)T().revalidateOnReconnect&&re()&&$();else{if(tt==ln.MUTATE_EVENT)return tn();if(tt==ln.ERROR_REVALIDATE_EVENT)return tn(rt)}});return M.current=!1,B.current=h,S.current=!0,j({_k:x}),Mn&&(y[h]||(q(Ir)||An?$():gA($))),()=>{M.current=!0,de()}},[h]),bo(()=>{let $;function ne(){let de=Dt(l)?l(k().data):l;de&&$!==-1&&($=setTimeout(me,de))}function me(){!k().error&&(A||T().isVisible())&&(u||T().isOnline())?tn(IA).then(ne):ne()}return ne(),()=>{$&&(clearTimeout($),$=-1)}},[l,A,u,h]),(0,qe.useDebugValue)(ve),i){if(!Aa&&An&&xr)throw new Error("Fallback data is required when using Suspense in SSR.");xr&&(Q.current=t,L.current=r,M.current=!1);let $=I[h],ne=!q($)&&xr?Bi($):ep;if(EA(ne),!q(be)&&xr)throw be;let me=xr?tn(IA):ep;!q(ve)&&xr&&(me.status="fulfilled",me.value=!0),EA(me)}return{mutate:Bi,get data(){return ie.data=!0,ve},get error(){return ie.error=!0,be},get isValidating(){return ie.isValidating=!0,_s},get isLoading(){return ie.isLoading=!0,bi}}},LF=yo.defineProperty(CA,"defaultValue",{value:ma}),Dn=Xg(lM);var tp=f(po());async function rp({start:e,end:t,refName:r,session:n,assemblyName:o}){let{assemblyManager:i,rpcManager:s}=n,a=await i.waitForAssembly(o);if(!a)throw new Error("assembly not found");let c="getSequence";return(await s.call(c,"CoreGetFeatures",{adapterConfig:(0,tp.getConf)(a,["sequence","adapter"]),sessionId:c,regions:[{start:e,end:t,refName:a.getCanonicalRefName(r),assemblyName:o}]}))[0]?.get("seq")??""}var Nn={revalidateOnFocus:!1,revalidateOnReconnect:!1,revalidateIfStale:!1,refreshWhenHidden:!1,refreshWhenOffline:!1,shouldRetryOnError:!1};async function AM({feature:e,assemblyName:t,view:r}){let n=(0,np.getSession)(r),{start:o,end:i,refName:s}=e.toJSON();return{seq:await rp({start:o,end:i,refName:s,assemblyName:t,session:n})}}function op({view:e,feature:t}){let r=e?.assemblyNames?.[0],n=t&&r?{feature:t,assemblyName:r,view:e}:void 0,{data:o,error:i}=Dn(n?[n.feature.id(),n.assemblyName,"feature-sequence"]:null,()=>AM(n),Nn);return{sequence:o,error:i}}function ip({view:e,feature:t}){let{sequence:r,error:n}=op({view:e,feature:t});return{proteinSequence:r&&t?Ng({seq:r.seq,feature:t}):"",sequence:r,error:n}}function uM(e,t,r){if(r&&r.length>0){let n=t.find(i=>_n(i)===e),o=n&&r.some(i=>_i(n,i));if(n&&!o){let i=t.find(s=>r.some(a=>_i(s,a)));return i?_n(i):void 0}}}function br({feature:e,view:t,validIds:r}){let n=(0,da.useMemo)(()=>Qg(e),[e]),[o,i]=(0,da.useState)(()=>_n(n[0])),s=uM(o,n,r)??o,a=n.find(A=>_n(A)===s),{proteinSequence:c,error:l}=ip({view:t,feature:a});return{options:n,selectedId:s,setSelectedId:i,selectedTranscript:a,proteinSequence:c,error:l,validIds:r}}var fM=(0,cp.makeStyles)()({textAreaFont:{fontFamily:"Courier New"},inputContainer:{marginBottom:30},fileContainer:{maxWidth:500},msaInput:{marginBottom:20},queryNameInput:{marginTop:20},warningAlert:{marginTop:10}}),mM=(0,ap.observer)(function({model:t,feature:r,handleClose:n}){let o=(0,sp.getSession)(t),i=Jt(t),{classes:s}=fM(),[a,c]=(0,Z.useState)(),[l,A]=(0,Z.useState)("file"),[u,m]=(0,Z.useState)(""),[d,p]=(0,Z.useState)(""),[C,y]=(0,Z.useState)(),[I,h]=(0,Z.useState)(),[x,S]=(0,Z.useState)(""),M=br({feature:r,view:i}),{selectedTranscript:B,error:Q}=M;return Z.default.createElement(Z.default.Fragment,null,Z.default.createElement(ir,{error:a??Q},Z.default.createElement(Vt.FormControl,{component:"fieldset"},Z.default.createElement(Vt.RadioGroup,{row:!0,value:l,onChange:T=>{A(T.target.value)}},Z.default.createElement(Vt.FormControlLabel,{value:"file",control:Z.default.createElement(Vt.Radio,null),label:"Open files"}),Z.default.createElement(Vt.FormControlLabel,{value:"text",control:Z.default.createElement(Vt.Radio,null),label:"Paste text"}))),Z.default.createElement("div",{className:s.inputContainer},l==="file"?Z.default.createElement("div",{className:s.fileContainer},Z.default.createElement(yA.FileSelector,{name:"MSA File .aln (Clustal), .fa/.mfa (aligned FASTA), .stock (Stockholm), etc)",inline:!0,location:C,setLocation:y}),Z.default.createElement(yA.FileSelector,{name:"Tree file .nh (Newick) or .asn (NCBI COBALT ASN.1)",inline:!0,location:I,setLocation:h})):Z.default.createElement(Z.default.Fragment,null,Z.default.createElement(nt,{variant:"outlined",name:"MSA",multiline:!0,minRows:5,className:s.msaInput,maxRows:10,fullWidth:!0,placeholder:"Paste MSA here",value:u,onChange:T=>{m(T.target.value)}}),Z.default.createElement(nt,{variant:"outlined",name:"Tree",multiline:!0,minRows:5,maxRows:10,fullWidth:!0,placeholder:"Paste newick tree (optional)",value:d,onChange:T=>{p(T.target.value)}}))),Z.default.createElement(ar,{feature:r,...M}),Z.default.createElement(nt,{variant:"outlined",name:"MSA row name",fullWidth:!0,required:!0,className:s.queryNameInput,placeholder:"Row name in MSA that corresponds to the selected transcript",helperText:"Required: Specify the name of the row in your MSA that should be aligned with the selected transcript",value:x,onChange:T=>{S(T.target.value)}}),x.trim()?null:Z.default.createElement(Vt.Alert,{severity:"warning",className:s.warningAlert},"Without specifying the MSA row name, clicking on the MSA will not navigate to the corresponding genome position, and hovering highlights will not work.")),Z.default.createElement(Or,{submitDisabled:!B||l==="file"&&!C||l==="text"&&!u.trim(),onSubmit:()=>{try{B&&(c(void 0),wg({session:o,newViewTitle:kn(B),view:i,feature:B,querySeqName:x.trim(),...l==="file"?{msaFilehandle:C,treeFilehandle:I}:{data:{msa:u,tree:d}}}),n())}catch(T){console.error(T),c(T)}},onCancel:n}))}),lp=mM;var fr=f(b()),Wp=f(ge());wA();var zp=f(D()),$p=f(Be());var ae=f(b());bA();var Nt=f(D()),Lp=f(O()),Fp=f(Be());var ze=f(b()),Qp=f(ye());W();var fp=f(F(),1),mp=(0,_.createSvgIcon)((0,fp.jsx)("path",{d:"M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6zM19 4h-3.5l-1-1h-5l-1 1H5v2h14z"}),"Delete");var lt=f(D()),Mp=f(O()),vp=f(Be());var BA=f(ge());function ha({newViewTitle:e,view:t,feature:r,blastParams:n}){(0,BA.getSession)(t).addView("MsaView",{type:"MsaView",displayName:e,connectedViewId:t.id,connectedFeature:r.toJSON(),drawNodeBubbles:!0,colWidth:10,rowHeight:12,blastParams:n})}function dp({newViewTitle:e,view:t,cached:r}){(0,BA.getSession)(t).addView("MsaView",{type:"MsaView",displayName:e,connectedViewId:t.id,drawNodeBubbles:!0,colWidth:10,rowHeight:12,data:{msa:r.msa,tree:r.tree,treeMetadata:r.treeMetadata}})}Li();var BM="jbrowse-msaview-blast-cache",un="blast-results",SM=2;async function Ea(){return Fn(BM,SM,{upgrade(e,t){t<2&&e.objectStoreNames.contains(un)&&e.deleteObjectStore(un),e.objectStoreNames.contains(un)||e.createObjectStore(un,{keyPath:"id"})}})}function QM(e,t,r,n){return n?`${t}:${r}:${n}:${e}`:`${t}:${r}:${e}`}async function yp({proteinSequence:e,blastDatabase:t,blastProgram:r,msaAlgorithm:n,msa:o,tree:i,treeMetadata:s,rid:a,geneId:c,transcriptId:l,transcriptName:A,geneName:u}){let m=await Ea(),p={id:QM(e,t,r,l),proteinSequence:e,blastDatabase:t,blastProgram:r,msaAlgorithm:n,msa:o,tree:i,treeMetadata:s,rid:a,timestamp:Date.now(),geneId:c,transcriptId:l,transcriptName:A,geneName:u};return await m.put(un,p),p}async function wp(){return(await(await Ea()).getAll(un)).toSorted((r,n)=>n.timestamp-r.timestamp)}async function bp(e){await(await Ea()).delete(un,e)}async function Bp(){await(await Ea()).clear(un)}function Ia(e){let{data:t,error:r,mutate:n}=Dn(`cached-blast-${e.join(",")}`,async()=>(await wp()).filter(a=>a.geneId&&e.includes(a.geneId)),Nn);return{results:t??[],error:r,isLoading:!t&&!r,handleDelete:async s=>{await bp(s),await n(a=>a?.filter(c=>c.id!==s)??[],!1)},handleClearAll:async()=>{await Bp(),await n([],!1)}}}var MM=(0,vp.makeStyles)()({header:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:8},resultList:{maxHeight:300,overflow:"auto"}});function Sp(e){let t=[e.geneName,e.transcriptName!==e.geneName?e.transcriptName:void 0].filter(r=>!!r);return t.length>0?t.join(" - "):e.geneId??e.transcriptId??"Unknown"}var vM=(0,Mp.observer)(function({model:e,handleClose:t,feature:r}){let{classes:n}=MM(),o=Jt(e),[i,s]=(0,ze.useState)(),a=(0,ze.useMemo)(()=>ea(r),[r]),{results:c,error:l,isLoading:A,handleDelete:u,handleClearAll:m}=Ia(a),d=C=>{dp({view:o,cached:C,newViewTitle:`BLAST - ${Sp(C)}`}),t()},p=l??i;return p?ze.default.createElement(Qp.ErrorMessage,{error:p}):A?ze.default.createElement(lt.Typography,null,"Loading cached results..."):c.length===0?ze.default.createElement(lt.Typography,{color:"textSecondary"},"No cached BLAST results found for this gene. Run a BLAST query to cache results."):ze.default.createElement("div",null,ze.default.createElement("div",{className:n.header},ze.default.createElement(lt.Typography,{variant:"subtitle1"},"Cached BLAST Results (",c.length,")"),ze.default.createElement(lt.Button,{size:"small",color:"error",onClick:async()=>{try{s(void 0),await m()}catch(C){s(C)}}},"Clear All")),ze.default.createElement(lt.List,{dense:!0,className:n.resultList},c.map(C=>ze.default.createElement(lt.ListItem,{key:C.id,disablePadding:!0,secondaryAction:ze.default.createElement(lt.IconButton,{edge:"end",size:"small",onClick:async y=>{y.stopPropagation();try{s(void 0),await u(C.id)}catch(I){s(I)}}},ze.default.createElement(mp,{fontSize:"small"}))},ze.default.createElement(lt.ListItemButton,{onClick:()=>{d(C)}},ze.default.createElement(lt.ListItemText,{primary:`${Sp(C)} - ${C.blastDatabase}/${C.blastProgram} (${C.msaAlgorithm})`,secondary:`${new Date(C.timestamp).toLocaleString()} - Seq: ${C.proteinSequence.slice(0,30)}...`}))))))}),Tp=vM;var DA=f(b()),Np=f(D());var xa="https://blast.ncbi.nlm.nih.gov/Blast.cgi",_p=["clustalo","muscle","kalign","mafft"],kp=["nr","nr_cluster_seq"],Dp=["blastp","quick-blastp"];function Fi({value:e,onChange:t,className:r}){return DA.default.createElement(nt,{variant:"outlined",label:"MSA Algorithm",className:r,select:!0,value:e,onChange:n=>{t(n.target.value)}},_p.map(n=>DA.default.createElement(Np.MenuItem,{value:n,key:n},n)))}var TM=(0,Fp.makeStyles)()({selectField:{width:150},databaseFieldContainer:{display:"flex"},clusterSeqMessage:{marginLeft:4,alignContent:"center"},cachedResultsAccordion:{marginTop:20},infoText:{marginTop:20}}),_M=(0,Lp.observer)(function({handleClose:e,feature:t,model:r,children:n,baseUrl:o}){let{classes:i}=TM(),s=Jt(r),[a,c]=(0,ae.useState)(),[l,A]=(0,ae.useState)("nr"),[u,m]=(0,ae.useState)("clustalo"),[d,p]=(0,ae.useState)("quick-blastp"),C=(0,ae.useMemo)(()=>ea(t),[t]),{results:y,error:I}=Ia(C),h=br({feature:t,view:s}),{selectedTranscript:x,proteinSequence:S}=h,M=h.error??a??I;return ae.default.createElement(ae.default.Fragment,null,ae.default.createElement(ir,{error:M},n,ae.default.createElement(nt,{variant:"outlined",label:"BLAST database",className:i.selectField,select:!0,value:l,onChange:B=>{let Q=B.target.value;A(Q),Q==="nr_cluster_seq"&&p("blastp")}},kp.map(B=>ae.default.createElement(Nt.MenuItem,{value:B,key:B},B))),ae.default.createElement(Fi,{className:i.selectField,value:u,onChange:m}),ae.default.createElement("div",{className:i.databaseFieldContainer},ae.default.createElement(nt,{variant:"outlined",label:"BLAST program",disabled:l==="nr_cluster_seq",className:i.selectField,select:!0,value:d,onChange:B=>{p(B.target.value)}},Dp.map(B=>ae.default.createElement(Nt.MenuItem,{value:B,key:B},B))),l==="nr_cluster_seq"?ae.default.createElement(Nt.Typography,{variant:"subtitle2",className:i.clusterSeqMessage},"Can only use blastp on nr_cluster_seq"):null),ae.default.createElement(ar,{feature:t,...h}),ae.default.createElement(Nt.Typography,{className:i.infoText},"This panel will automatically submit a query to NCBI. Using blastp can take 10+ minutes to run, quick-blastp is generally a lot faster but is not available for the clustered database. After completion, all the hits will be run through a multiple sequence alignment. Note: we are not able to currently run NCBI COBALT automatically on the BLAST results, even though that is the method NCBI uses on their website. If you need a COBALT alignment, please use the manual approach of submitting BLAST yourself and downloading the resulting files"),y.length>0?ae.default.createElement(Nt.Accordion,{className:i.cachedResultsAccordion},ae.default.createElement(Nt.AccordionSummary,{expandIcon:ae.default.createElement(pa,null)},ae.default.createElement(Nt.Typography,null,"Previous BLAST Results")),ae.default.createElement(Nt.AccordionDetails,null,ae.default.createElement(Tp,{model:r,handleClose:e,feature:t}))):null),ae.default.createElement(Or,{submitDisabled:!S,onSubmit:()=>{try{x&&(c(void 0),ha({feature:x,view:s,newViewTitle:Xs(t,x),blastParams:{baseUrl:o,blastProgram:d,blastDatabase:l,msaAlgorithm:u,selectedTranscript:x,proteinSequence:S}}),e())}catch(B){console.error(B),c(B)}},onCancel:e}))}),Rp=_M;var Br=f(b()),Gp=f(ge()),So=f(D()),Up=f(O()),Hp=f(Be());wa();var kM=(0,Hp.makeStyles)()({ncbiLink:{wordBreak:"break-all",margin:30,maxWidth:600},infoText:{marginTop:20}}),DM=(0,Up.observer)(function({handleClose:e,feature:t,model:r,children:n,baseUrl:o}){let{classes:i}=kM(),s=Jt(r),a=br({feature:t,view:s}),{proteinSequence:c,error:l}=a,A=Zs(c),u=`${o}?PAGE_TYPE=BlastSearch&PAGE=Proteins&PROGRAM=blastp&QUERY=${A}`,m=`${o}?PAGE_TYPE=BlastSearch&PAGE=Proteins&PROGRAM=blastp&QUERY=${(0,Gp.shorten2)(A,10)}`;return Br.default.createElement(Br.default.Fragment,null,Br.default.createElement(ir,{error:l},n,Br.default.createElement(ar,{feature:t,...a}),c?Br.default.createElement("div",{className:i.ncbiLink},"Link to NCBI BLAST: ",Br.default.createElement(Rn,{href:u},m)):null,Br.default.createElement(So.Typography,{className:i.infoText},`Click the link above and run your BLAST query, and once you have results, click "Multiple Alignment" at the top of the results page to be redirected to COBALT, NCBI's multiple sequence aligner. Once COBALT completes, you can download an MSA (.aln file) and optionally a Newick tree (.nh) and paste the results into JBrowse`)),Br.default.createElement(So.DialogActions,null,Br.default.createElement(So.Button,{color:"primary",variant:"contained",onClick:()=>{e()}},"Close")))}),jp=DM;var Gr=f(b()),Yt=f(D());function FA({lookupMethod:e,setLookupMethod:t}){return Gr.default.createElement(Yt.FormControl,{component:"fieldset"},Gr.default.createElement(Yt.RadioGroup,{row:!0,value:e,onChange:r=>{t(r.target.value)}},Gr.default.createElement(Yt.FormControlLabel,{value:"automatic",control:Gr.default.createElement(Yt.Radio,null),label:"Automatic"}),Gr.default.createElement(Yt.FormControlLabel,{value:"rid",control:Gr.default.createElement(Yt.Radio,null),label:"Load from RID"}),Gr.default.createElement(Yt.FormControlLabel,{value:"manual",control:Gr.default.createElement(Yt.Radio,null),label:"Manual"})))}var At=f(b()),ba=f(D()),qp=f(O()),Jp=f(Be());wa();var NM=(0,Jp.makeStyles)()({marginBottom:{marginBottom:16},ridField:{width:150},infoText:{marginTop:20}}),LM=(0,qp.observer)(function({handleClose:e,feature:t,model:r,children:n,baseUrl:o}){let{classes:i}=NM(),s=Jt(r),[a,c]=(0,At.useState)(),[l,A]=(0,At.useState)(""),[u,m]=(0,At.useState)("clustalo"),d=br({feature:t,view:s}),{selectedTranscript:p,proteinSequence:C}=d,y=d.error??a,I=l.trim();return At.default.createElement(At.default.Fragment,null,At.default.createElement(ir,{error:y},n,At.default.createElement(ba.Typography,{variant:"body2",className:i.marginBottom},"Enter the RID (Request ID) from a previously submitted NCBI BLAST query. You can find the RID in the BLAST results page URL or at the top of the results page. RIDs are typically valid for 24-36 hours after submission."),At.default.createElement(nt,{variant:"outlined",label:"BLAST RID",placeholder:"e.g., ABC12345",fullWidth:!0,className:i.marginBottom,value:l,onChange:h=>{A(h.target.value)}}),I?At.default.createElement(ba.Typography,{variant:"body2",className:i.marginBottom},At.default.createElement(Rn,{href:`${o}?CMD=Get&RID=${I}`},"View BLAST results on NCBI")):null,At.default.createElement(Fi,{className:i.ridField,value:u,onChange:m}),At.default.createElement(ar,{feature:t,...d}),At.default.createElement(ba.Typography,{className:i.infoText},"This will fetch the BLAST results for the provided RID and run them through a multiple sequence alignment. The protein sequence from the selected transcript will be added as the query sequence in the MSA.")),At.default.createElement(Or,{submitDisabled:!C||!I,onSubmit:()=>{try{p&&I&&(c(void 0),ha({feature:p,view:s,newViewTitle:Xs(t,p),blastParams:{baseUrl:o,blastProgram:"blastp",blastDatabase:"nr",msaAlgorithm:u,selectedTranscript:p,proteinSequence:C,rid:I}}),e())}catch(h){console.error(h),c(h)}},onCancel:e}))}),Vp=LM;var ur=f(b()),Wt=f(D()),Yp=f(Be());var FM=(0,Yp.makeStyles)()({urlField:{minWidth:300}});function RA({handleClose:e,baseUrl:t}){let{classes:r}=FM(),[n,o]=(0,ur.useState)(t);return ur.default.createElement(Wt.Dialog,{open:!0,maxWidth:"lg",onClose:()=>{e()}},ur.default.createElement(Wt.DialogTitle,null,"BLAST Settings"),ur.default.createElement(Wt.DialogContent,null,ur.default.createElement(nt,{autoFocus:!0,margin:"dense",label:"BLAST Base URL",fullWidth:!0,variant:"outlined",value:n,className:r.urlField,onChange:i=>{o(i.target.value)}}),ur.default.createElement(Wt.Button,{variant:"contained",onClick:()=>{o(xa)}},"Reset")),ur.default.createElement(Wt.DialogActions,null,ur.default.createElement(Wt.Button,{variant:"contained",color:"secondary",onClick:()=>{e()}},"Cancel"),ur.default.createElement(Wt.Button,{color:"primary",variant:"contained",onClick:()=>{e(n)}},"Save")))}var RM=(0,$p.makeStyles)()({settingsButton:{float:"right"}}),PM={automatic:Rp,rid:Vp,manual:jp};function PA({handleClose:e,model:t,feature:r}){let[n,o]=(0,fr.useState)("automatic"),[i,s]=(0,Wp.useLocalStorage)("msa-blastRootUrl",xa),[a,c]=(0,fr.useState)(!1),{classes:l}=RM(),A=PM[n];return fr.default.createElement(fr.default.Fragment,null,fr.default.createElement(zp.IconButton,{className:l.settingsButton,size:"small",onClick:()=>{c(!0)}},fr.default.createElement(ga,null)),fr.default.createElement(A,{model:t,feature:r,handleClose:e,baseUrl:i},fr.default.createElement(FA,{lookupMethod:n,setLookupMethod:o})),a?fr.default.createElement(RA,{baseUrl:i,handleClose:u=>{u&&s(u),c(!1)}}):null)}var ut=f(b()),Oi=f(ye()),La=f(ge()),Vh=f(D()),Yh=f(O());var Wh=f(Be());fn();function ru(e,t="",r=5e3){let n=[e];for(;n.length;){let o=n.pop();for(let[i,s]of Object.entries(o)){if(t.length>r)return ZA(t);typeof s=="object"&&s!==null?n.push(s):i==="locationType"&&s==="FileHandleLocation"?t+=`${i}-BlobLocation`:i==="handleId"?t+=`blobId-fh-blob-${s}`:t+=`${i}-${s}`}}return`adp-${ZA(t)}`}function Oh(e={}){return e.type&&e.adapterId?`${e.type}-${e.adapterId}`:`${ru(e)}`}var Gh={};async function c2(e,t,r){let n=r?.type;if(!n)throw new Error(`could not determine adapter type from adapter config snapshot ${JSON.stringify(r)}`);let o=e.getAdapterType(n);if(!o)throw new Error(`unknown data adapter type ${n}`);let i=o.configSchema.create(r,{pluginManager:e}),s=nu.bind(null,e,t),a=await o.getAdapterClass();return{dataAdapter:new a(i,s,e),sessionIds:new Set([t])}}async function nu(e,t,r){let n=Oh(r);Gh[n]??=c2(e,t,r);let o=await Gh[n];return o.sessionIds.add(t),o}async function Uh(e,t){return(await nu(e,"msa",t)).dataAdapter}async function Hh({config:e,pluginManager:t}){return(await Uh(t,e)).getMSAList()}async function jh({config:e,pluginManager:t,msaId:r}){return(await Uh(t,e)).getMSA(r)}function qh({session:e,newViewTitle:t,view:r,feature:n,data:o,querySeqName:i}){e.addView("MsaView",{type:"MsaView",displayName:t,treeAreaWidth:200,querySeqName:i,treeWidth:100,drawNodeBubbles:!1,labelsAlignRight:!0,showBranchLen:!1,colWidth:10,rowHeight:12,colorSchemeName:"percent_identity_dynamic",data:o,connectedViewId:r.id,connectedFeature:n.toJSON()})}var Jh=f(po());function Na(e){return(0,Jh.readConfObject)(e,["msa","datasets"])}var l2=(0,Wh.makeStyles)()({selectedContainer:{marginTop:50}}),A2=(0,Yh.observer)(function({model:e,feature:t,handleClose:r}){let n=(0,La.getSession)(e),o=Jt(e),{classes:i}=l2(),{pluginManager:s}=(0,La.getEnv)(e),{assemblyNames:a}=o,[c,l]=(0,ut.useState)(),A=Na(n.jbrowse),[u,m]=(0,ut.useState)(A?.[0]?.datasetId),d=A?.find(L=>L.datasetId===u),{data:p,isLoading:C,error:y}=Dn(d?`${d.datasetId}-msa-list`:null,()=>Hh({config:d.adapter,pluginManager:s}),Nn),I=br({feature:t,view:o,validIds:p}),{selectedId:h,selectedTranscript:x}=I,{data:S,isLoading:M,error:B}=Dn(h&&d&&p?`${d.datasetId}-${h}-${p.length}-msa`:null,()=>jh({msaId:h,config:d.adapter,pluginManager:s}),Nn),Q=y??B??I.error??c;return ut.default.createElement(ut.default.Fragment,null,ut.default.createElement(ir,{error:Q},ut.default.createElement(nt,{select:!0,label:"Select MSA dataset",value:u,onChange:L=>{m(L.target.value)}},A?.map(L=>ut.default.createElement(Vh.MenuItem,{key:L.datasetId,value:L.datasetId},L.name))),d?ut.default.createElement("div",{className:i.selectedContainer},!C&&M?ut.default.createElement(Oi.LoadingEllipses,{variant:"h6",message:`Loading MSA for (${h})`}):null,C?ut.default.createElement(Oi.LoadingEllipses,{variant:"h6",message:`Loading available MSAs for (${d.name})`}):null,p?ut.default.createElement("div",null,ut.default.createElement(Oi.SanitizedHTML,{html:d.description}),ut.default.createElement(ar,{feature:t,...I})):null):null),ut.default.createElement(Or,{submitDisabled:!x||!S?.length,onSubmit:()=>{try{if(x&&S){let L=`${h}_${a[0]}`;qh({session:n,newViewTitle:kn(x),view:o,querySeqName:L,feature:x,data:{msa:S.map(T=>`>${T.get("refName")}
71
- ${T.get("seq")}`).join(`
72
- `)}}),r()}}catch(L){l(L)}},onCancel:r}))}),zh=A2;var ou=f(b());function Gi({children:e,value:t,index:r,...n}){return ou.default.createElement("div",{role:"tabpanel",hidden:t!==r,...n},t===r?ou.default.createElement("div",null,e):null)}function iu({handleClose:e,feature:t,model:r}){let n=(0,Kh.getSession)(r),i=!!Na(n.jbrowse)?.length,[s,a]=(0,Mt.useState)("ncbi_blast");return Mt.default.createElement($h.Dialog,{maxWidth:"xl",title:"Launch MSA view",open:!0,onClose:e},Mt.default.createElement(Do.Tabs,{value:s,onChange:(c,l)=>{a(l)}},Mt.default.createElement(Do.Tab,{label:"NCBI BLAST query",value:"ncbi_blast"}),i?Mt.default.createElement(Do.Tab,{label:"Pre-loaded MSA datasets",value:"preloaded_msa"}):null,Mt.default.createElement(Do.Tab,{label:"Manual upload",value:"manual_msa"})),Mt.default.createElement(Gi,{value:s,index:"ncbi_blast"},Mt.default.createElement(PA,{handleClose:e,feature:t,model:r})),i?Mt.default.createElement(Gi,{value:s,index:"preloaded_msa"},Mt.default.createElement(zh,{model:r,feature:t,handleClose:e})):null,Mt.default.createElement(Gi,{value:s,index:"manual_msa"},Mt.default.createElement(lp,{model:r,feature:t,handleClose:e})))}function u2(e){return e.name==="LinearBasicDisplay"}function f2(e){return e.views(t=>{let r=t.contextMenuItems;return{contextMenuItems(){let n=t.contextMenuFeature,o=(0,Fa.getContainingTrack)(t),i=n?.get("type"),s=n&&["gene","mRNA","transcript"].includes(i);return[...r(),...s?[{label:"Launch MSA view",icon:Ig,onClick:()=>{(0,Fa.getSession)(o).queueDialog(a=>[iu,{model:o,handleClose:a,feature:n}])}}]:[]]}}})}function su(e){e.addToExtensionPoint("Core-extendPluggableElement",t=>(u2(t)&&(t.stateModel=f2(t.stateModel)),t))}function au(e){e.addToExtensionPoint("LaunchView-MsaView",({session:t,data:r,msaFileLocation:n,treeFileLocation:o,connectedViewId:i,connectedFeature:s,displayName:a,colorSchemeName:c,colWidth:l,rowHeight:A,treeAreaWidth:u,treeWidth:m,drawNodeBubbles:d,labelsAlignRight:p,showBranchLen:C,querySeqName:y})=>{if(!r&&!n)throw new Error("No MSA data or file location provided when launching MSA view");t.addView("MsaView",{type:"MsaView",displayName:a,connectedViewId:i,connectedFeature:s,colorSchemeName:c,colWidth:l,rowHeight:A,treeAreaWidth:u,treeWidth:m,drawNodeBubbles:d,labelsAlignRight:p,showBranchLen:C,init:{msaData:r?.msa,treeData:r?.tree,msaUrl:n?.uri,treeUrl:o?.uri,querySeqName:y}})})}var X1=f(b()),Z1=f(Zh());var L1=f(b()),F1=f(Pl()),wi=f(ge()),Ie=f(kt());function e0(e){let t=e.strand,r=e.refName;if(t!==-1&&t!==1)throw new Error(`Invalid strand value: ${t}. Expected 1 or -1.`);if(!r)throw new Error("refName is required");let n=new Map;for(let c of e.subfeatures??[])if(c.type==="CDS"&&c.start<c.end){let l=`${c.start}-${c.end}`;n.has(l)||n.set(l,c)}let o=[...n.values()].sort((c,l)=>t*(c.start-l.start)),i={},s={},a={};if(o.length!==0){let l=(3-(o[0]?.phase??0))%3,A=-1;for(let u of o){let m=u.end-u.start;for(let d=0;d<m;d++){let p=t===1?u.start+d:u.end-1-d,C=Math.floor(l++/3);i[p]=C,C!==A?(s[C]=p,a[C]=[p],A=C):a[C].push(p)}}}return{g2p:i,p2g:s,p2gCodon:a,refName:r,strand:t}}var R1=f(Hr());qm();var Ym=f(ge());function t1(e,t){let r=e.sciname.replaceAll(" ","_");if(e.taxid&&t?.has(e.taxid)){let n=t.get(e.taxid);n.commonName&&(r=n.commonName.split(" ").map(o=>o.charAt(0).toUpperCase()+o.slice(1).toLowerCase()).join("_"))}return`${e.accession}-${r}`}function r1(e){return e.replaceAll("-","")}async function n1(e,t){let r=await fetch(e,t);if(!r.ok)throw new Error(`HTTP ${r.status} fetching ${e} ${await r.text()}`);return r}async function bn(e,t){return(await n1(e,t)).text()}async function o1(e,t){return(await n1(e,t)).json()}function hl(e){return new Promise(t=>setTimeout(t,e))}var Cl="https://www.ebi.ac.uk/Tools/services/rest",eN={clustalo:{params:{email:"colin.diesh@gmail.com"},msaResult:"aln-clustal_num",treeResult:"phylotree"},muscle:{params:{email:"colin.diesh@gmail.com",format:"clw",tree:"tree1"},msaResult:"fa",treeResult:"phylotree"},kalign:{params:{email:"colin.diesh@gmail.com",stype:"protein"},msaResult:"fa",treeResult:"phylotree"},mafft:{params:{email:"colin.diesh@gmail.com",stype:"protein"},msaResult:"fa",treeResult:"phylotree"}};async function tN({onProgress:e,jobId:t,algorithm:r}){for(;;){for(let o=0;o<10;o++)await hl(1e3),e(`Re-checking MSA status in... ${10-o}`);let n=await bn(`${Cl}/${r}/status/${t}`);if(n==="FINISHED")break;if(n.includes("FAILURE"))throw new Error(`Failed to run: jobId ${t}`)}}async function i1({algorithm:e,sequence:t,onProgress:r}){let n=eN[e];r(`Launching ${e} MSA...`);let o=await bn(`${Cl}/${e}/run`,{method:"POST",body:new URLSearchParams({...n.params,sequence:t})});return await tN({jobId:o,algorithm:e,onProgress:r}),{msa:await bn(`${Cl}/${e}/result/${o}/${n.msaResult}`),tree:await bn(`${Cl}/${e}/result/${o}/${n.treeResult}`)}}async function Jm({rid:e,baseUrl:t,onProgress:r}){r(`Checking BLAST status for RID: ${e}...`),await nN({rid:e,onProgress:r,baseUrl:t});let n=await o1(`${t}?CMD=Get&RID=${e}&FORMAT_TYPE=JSON2_S&FORMAT_OBJECT=Alignment`);return{rid:e,hits:n.BlastOutput2[0]?.report.results.search.hits??[]}}async function s1({query:e,blastDatabase:t,blastProgram:r,baseUrl:n,onProgress:o,onRid:i}){o("Submitting to NCBI BLAST...");let{rid:s}=await rN({query:e,blastDatabase:t,blastProgram:r,baseUrl:n});return i(s),Jm({rid:s,baseUrl:n,onProgress:o})}async function rN({query:e,blastProgram:t,blastDatabase:r,baseUrl:n}){let o=await bn(n,{method:"POST",body:new URLSearchParams({CMD:"Put",PROGRAM:t==="quick-blastp"?"blastp":t,DATABASE:r,QUERY:e,...r==="nr_cluster_seq"?{CLUSTERED_DB:"on",DB_TYPE:"Experimental Databases"}:{},...t==="quick-blastp"?{BLAST_PROGRAMS:"kmerBlastp"}:{}})}),i=/^ {4}RID = (.*$)/m.exec(o)?.[1],s=/^ {4}RTOE = (.*$)/m.exec(o)?.[1];if(!i)throw new Error("Failed to get RID from BLAST request");return{rid:i,rtoe:s}}async function nN({rid:e,onProgress:t,baseUrl:r}){for(;;){for(let c=0;c<20;c++)await hl(1e3),t(`Re-checking BLAST status in... ${20-c}`);let o=await bn(`${r}?CMD=Get&FORMAT_OBJECT=SearchInfo&RID=${e}`),s=/\s+Status=(\S+)/m.exec(o)?.[1],a=/\s+ThereAreHits=yes/m.test(o);if(s!=="WAITING"){if(s==="FAILED")throw new Error(`BLAST ${e} failed`);if(s==="READY"){if(a)return!0;throw new Error("No hits found")}throw new Error(`BLAST ${e} returned unexpected status: ${s??"unknown"}`)}}}Li();var oN="jbrowse-msaview-taxonomy-cache",bs="common-names",iN=2;async function a1(){return Fn(oN,iN,{upgrade(e){e.objectStoreNames.contains(bs)&&e.deleteObjectStore(bs),e.createObjectStore(bs,{keyPath:"taxid"})}})}async function sN(e){let r=(await a1()).transaction(bs,"readonly"),n=await Promise.all(e.map(o=>r.store.get(o)));return await r.done,n}async function aN(e){let r=(await a1()).transaction(bs,"readwrite");for(let n of e)await r.store.put(n);await r.done}async function c1(e){let t=new Map,r=[],n=await sN(e);for(let s=0;s<e.length;s++){let a=e[s],c=n[s];c?t.set(a,{sciname:c.sciname,commonName:c.commonName}):r.push(a)}if(r.length===0)return t;let o=100,i=[];for(let s=0;s<r.length;s+=o){let a=r.slice(s,s+o),c=a.join(",");try{let A=await(await fetch(`https://eutils.ncbi.nlm.nih.gov/entrez/eutils/efetch.fcgi?db=taxonomy&id=${c}&retmode=xml`)).text(),u=new Map,m=/<Taxon>\s*<TaxId>(\d+)<\/TaxId>/g,d;for(;(d=m.exec(A))!==null;){let p=Number(d[1]),C=d.index,y=1,I=C+d[0].length;for(;y>0&&I<A.length;){let B=A.indexOf("<Taxon>",I),Q=A.indexOf("</Taxon>",I);if(Q===-1)break;B!==-1&&B<Q?(y++,I=B+7):(y--,I=Q+8)}let h=A.slice(C,I),x=u.get(p),S=h.includes("<LineageEx>"),M=x?.includes("<LineageEx>");(!x||S&&!M)&&u.set(p,h)}for(let p of a){let C=u.get(p);if(C){let y=/<GenbankCommonName>(.*?)<\/GenbankCommonName>/.exec(C),I=/<CommonName>(.*?)<\/CommonName>/.exec(C),h=/<ScientificName>(.*?)<\/ScientificName>/.exec(C),x=y?.[1]??I?.[1],S=h?.[1]??"";t.set(p,{sciname:S,commonName:x}),i.push({taxid:p,sciname:S,commonName:x})}}}catch(l){console.error("Failed to fetch taxonomy data:",l)}}return i.length>0&&await aN(i),t}async function l1({self:e}){let{baseUrl:t,blastDatabase:r,blastProgram:n,msaAlgorithm:o,proteinSequence:i,selectedTranscript:s,rid:a}=e.blastParams,c=Zs(i),l,A;if(a){e.setRid(a);let I=await Jm({rid:a,baseUrl:t,onProgress:h=>{e.setProgress(h)}});l=I.hits,A=I.rid}else{let I=await s1({query:c,blastDatabase:r,blastProgram:n,baseUrl:t,onProgress:h=>{e.setProgress(h)},onRid:h=>{e.setRid(h)}});l=I.hits,A=I.rid}e.setProgress("Fetching species taxonomy info...");let u=l.map(I=>I.description[0]?.taxid).filter(I=>I!==void 0),m=await c1(u),d={},p=l.map(I=>{let h=I.description[0]??{accession:"unknown",id:"unknown",sciname:"unknown"},x=t1(h,m),S=r1(I.hsps[0]?.hseq??"");return d[x]=cN(h,m),`>${x}
73
- ${S}`}),C=await i1({algorithm:o,sequence:[`>QUERY
63
+ `);if(a===-1)continue;let c=s.slice(a+1).replaceAll(/\s/g,"");c&&r.push(c)}if(r.length<2)return!1;let n=!1,o=-1,i=!0;for(let s of r){let a=0;for(let c=0;c<s.length;c++){let l=s.charCodeAt(c);gi(l)?n=!0:(l>=Wb&&l<=zb||l===$b)&&a++}o===-1?o=a:a!==o&&(i=!1)}return n&&i}expandA3M(t,r){let n=r.length;if(n===0)return{};let o=[],i=[];for(let l=0;l<n;l++){let A=t[l],u=[],m=[],d=0;for(;d<A.length;){let p=A.charCodeAt(d);if(p>=Wb&&p<=zb||p===$b){u.push(A[d]);let E="",x=d+1;for(;x<A.length;){let I=A.charCodeAt(x);if(gi(I)||I===Kb)E+=A[x],x++;else break}m.push(E),d=x}else if(p===Kb)d++;else if(gi(p)){let E="";for(;d<A.length&&gi(A.charCodeAt(d));)E+=A[d],d++;u.push(""),m.push(E)}else d++}o.push(u),i.push(m)}let s=Math.max(...o.map(l=>l.length),0),a=new Array(s).fill(0);for(let l=0;l<n;l++){let A=i[l];for(let u=0;u<A.length;u++){let m=0;for(let d of A[u])gi(d.charCodeAt(0))&&m++;m>a[u]&&(a[u]=m)}}let c={};for(let l=0;l<n;l++){let A=o[l],u=i[l],m=[];for(let d=0;d<s;d++){let p=a[d];if(d<A.length){let E=A[d],x=u[d]||"";m.push(E||"-");let I="";for(let y of x)gi(y.charCodeAt(0))&&(I+=y.toUpperCase());m.push(I);let h=p-I.length;h>0&&m.push(".".repeat(h))}else m.push("-"),p>0&&m.push(".".repeat(p))}c[r[l]]=m.join("")}return c}getMSA(){return this.MSA}getNames(){return this.orderedNames}getRow(t){return this.MSA.seqdata[t]||""}getWidth(){let t=Object.keys(this.MSA.seqdata)[0];return t?this.getRow(t).length:0}}});function Ck(e){let t=/\(?(\d+(\.\d+)+)\)?/.exec(e);return t&&t.length>1?t[1]:""}function Zb(e){let t=["CLUSTAL","PROBCONS","MUSCLE","MSAPROBS","Kalign"];t.some(n=>e.startsWith(n))||console.warn(`${e} is not a known CLUSTAL header: ${t.join(",")}, proceeding but could indicate an issue`);let r=Ck(e);return{info:e,version:r}}function Gc(e){let t=e.next();for(;!t.done&&t.value.trim()==="";)t=e.next();return t.value}function Ek(e){let t=e.split(/\s+/),r=e.slice(t[0].length),n=t[0].length+r.indexOf(t[1]),o=n+t[1].length;return[n,o]}function Xb(e){let t=Gc(e),r=[],n="";if(!t)return;for(;t;)t.startsWith(" ")?n=t:r.push(t),t=e.next().value;let[o,i]=Ek(r[0]),a=r.map(u=>u.split(/\s+/)).map(u=>u[0]),c=r.map(u=>u.slice(o,i)),l=n.slice(o,i),A=c[0].length-l.length;return A&&(l+=" ".repeat(A)),{ids:a,seqs:c,consensus:l}}function ew(e){let t,r=Xb(e);if(r!==void 0)for(;t=Xb(e);){for(let n=0;n<t.seqs.length;n++)r.seqs[n]+=t.seqs[n];r.consensus+=t.consensus}return r}var Pf=g(()=>{});var tw=g(()=>{Pf()});function Ik(e){let t=Gc(e);if(!t)throw new Error("Empty file received");let r=Zb(t),n=ew(e);if(n===void 0)throw new Error("No blocks parsed");let o=n.seqs.map((s,a)=>({id:n.ids[a],seq:s})),{consensus:i}=n;if(i.length!==o[0].seq.length)throw new Error(`Consensus length != sequence length. Con ${i.length} seq ${o[0].seq.length}`);return{consensus:i,alns:o,header:r}}function rw(e){let t=e.split(`
64
+ `)[Symbol.iterator]();return Ik(t)}var nw=g(()=>{tw();Pf()});var eo,Of=g(()=>{nw();di();eo=class extends Rt{MSA;constructor(t){super(),this.MSA=rw(t)}getMSA(){return this.MSA}getRow(t){return this.MSA.alns.find(r=>r.id===t)?.seq||""}getWidth(){return this.MSA.alns[0].seq.length}getHeader(){return this.MSA.header}getNames(){return this.MSA.alns.map(t=>t.id)}get seqConsensus(){return this.MSA.consensus}}});function ow(e){let t=e.split(`
65
+ `).map(i=>i.trim()).filter(i=>!!i),r=[],n=[];for(let i of t)if(i.startsWith("SEQ"))r.push(i);else{if(i.startsWith("DATA"))continue;if(i.startsWith("//"))break;n.push(i)}let o=r.map(i=>{let[,s,a,c,l,A,u,m,d]=i.split(" ");return{species:s,protein:a,chr:c,start:+l,end:+A,strand:+u,geneId:m,unknown:d,seq:""}});for(let i of n)for(let s=0;s<r.length;s++)o[s].seq+=i[s];return o}function Uc(e){let t=e.split(`
66
+ `).map(i=>i.trim()).filter(i=>!!i),r=[],n="";for(let i of t)if(i.startsWith("SEQ"))r.push(i);else{if(i.startsWith("DATA"))continue;if(i.startsWith("//"))break;n=i}let o=r.map(i=>{let[,s,a,c,l,A,u,m,d]=i.split(" ");return{species:s,protein:a,chr:c,start:+l,end:+A,strand:+u,geneId:m,unknown:d}});return{tree:n,seqs:o}}var Gf=g(()=>{});var to,Uf=g(()=>{Gf();di();to=class extends Rt{MSA;constructor(t){super(),this.MSA=ow(t)}getMSA(){return this.MSA}getRow(t){return this.MSA.find(r=>r.protein===t)?.seq||""}getWidth(){return this.MSA[0].seq.length}getHeader(){return""}getNames(){return this.MSA.map(t=>t.protein)}}});var ro,Hf=g(()=>{di();ro=class extends Rt{MSA;constructor(t){super();let r={},n={};for(let o of t.split(">")){if(!/\S/.test(o))continue;let i=o.indexOf(`
67
+ `);if(i===-1)continue;let s=o.slice(0,i),a=s.indexOf(" "),c=a===-1?s:s.slice(0,a);c&&(r[c]=o.slice(i+1).replaceAll(/\s/g,""),c.includes(":")&&(n[c.replaceAll(":","_")]=c))}this.MSA={seqdata:r,colonNormalized:n}}getMSA(){return this.MSA}getNames(){return Object.keys(this.MSA.seqdata)}getRow(t){return this.MSA.seqdata[t]??this.MSA.seqdata[this.MSA.colonNormalized[t]??""]??""}getWidth(){let t=Object.keys(this.MSA.seqdata)[0];return this.getRow(t).length}}});function no(e){let t=[],r=[],n=e.replace(/'((?:[^']|'')*)'/g,(s,a)=>{let c=r.length;return r.push(a.replaceAll("''","'")),`__Q${c}__`}),o={},i=n.split(/\s*(;|\(|\)|,|:)\s*/);for(let s=0;s<i.length;s++){let c=i[s].replace(/^__Q(\d+)__$/,(A,u)=>r[Number(u)]),l={};switch(c){case"(":o.children=[l],t.push(o),o=l;break;case",":t.at(-1)?.children.push(l),o=l;break;case")":o=t.pop();break;case":":break;default:{let A=i[s-1];A===")"||A==="("||A===","?o.name=c:A===":"&&(o.length=Number.parseFloat(c))}}}return o}var jf=g(()=>{});function pi(){return{gf:{},gc:{},gs:{},gr:{},seqname:[],seqdata:{}}}function Is(e){return iw.test(e)}function sw(e,t){let r=t??{},n=[],o=null,i=e.split(`
68
+ `);for(let s of i){let a;if(iw.test(s))o=pi();else if(xk.test(s))o&&n.push(o),o=null;else if(a=yk.exec(s)){if(!o){if(r.strict)throw new Error("No format header: # STOCKHOLM 1.0");o=pi()}let c=a[1];o.gf[c]||(o.gf[c]=[]),o.gf[c].push(a[2])}else if(a=bk.exec(s)){if(!o){if(r.strict)throw new Error("No format header: # STOCKHOLM 1.0");o=pi()}let c=a[1];o.gc[c]||(o.gc[c]=""),o.gc[c]+=a[2]}else if(a=wk.exec(s)){if(!o){if(r.strict)throw new Error("No format header: # STOCKHOLM 1.0");o=pi()}let c=a[1],l=a[2],A=a[3];o.gs[l]||(o.gs[l]={}),o.gs[l][c]||(o.gs[l][c]=[]),o.gs[l][c].push(A)}else if(a=Bk.exec(s)){if(!o){if(r.strict)throw new Error("No format header: # STOCKHOLM 1.0");o=pi()}let c=a[1],l=a[2],A=a[3];o.gr[l]||(o.gr[l]={}),o.gr[l][c]||(o.gr[l][c]=""),o.gr[l][c]+=A}else if(a=Sk.exec(s)){if(!o){if(r.strict)throw new Error("No format header: # STOCKHOLM 1.0");o=pi()}let c=a[1],l=a[2];o.seqdata[c]||(o.seqdata[c]="",o.seqname.push(c)),o.seqdata[c]+=l}else if(Qk.test(s)&&r.strict)throw new Error("Malformed line")}return o&&n.push(o),n}var iw,xk,yk,bk,wk,Bk,Sk,Qk,qf=g(()=>{iw=/^# STOCKHOLM 1.0/,xk=/^\/\/\s*$/,yk=/^#=GF\s+(\S+)\s+(.*?)\s*$/,bk=/^#=GC\s+(\S+)\s+(.*?)\s*$/,wk=/^#=GS\s+(\S+)\s+(\S+)\s+(.*?)\s*$/,Bk=/^#=GR\s+(\S+)\s+(\S+)\s+(.*?)\s*$/,Sk=/^\s*(\S+)\s+(\S+)\s*$/,Qk=/\S/});var oo,Jf=g(()=>{jf();qf();Ff();di();qf();oo=class extends Rt{data;MSA;constructor(t,r){super();let n=sw(t);this.data=n,this.MSA=n[r]}getMSA(){return this.MSA}getRow(t){return this.MSA.seqdata[t]||""}getWidth(){let t=Object.keys(this.MSA.seqdata)[0];return this.getRow(t).length}get alignmentNames(){return this.data.map((t,r)=>t.gf.DE?.[0]??`Alignment ${r+1}`)}getHeader(){let t=this.MSA.gs.AC??{},r=this.MSA.gs.DR??{};return{General:this.MSA.gf,Accessions:Object.fromEntries(Object.entries(t).map(([n,o])=>[n,o[0]])),Dbxref:Object.fromEntries(Object.entries(r).map(([n,o])=>[n,o.join("; ")]))}}getRowData(t){return{name:t,accession:this.MSA.gs.AC?.[t]?.[0],dbxref:this.MSA.gs.DR?.[t]?.join("; ")}}getNames(){return Object.keys(this.MSA.seqdata)}getStructures(){let t=/PDB; +(\S+) +(\S); ([0-9]+)-([0-9]+)/,r=this.MSA.gs.DR??{},n={};for(let[o,i]of Object.entries(r))for(let s of i){let a=t.exec(s);a&&(n[o]??=[]).push({pdb:a[1].toLowerCase(),chain:a[2],startPos:+a[3],endPos:+a[4]})}return n}getTree(){let t=this.MSA.gf.NH?.[0];return t?mi(no(t)):super.getTree()}get seqConsensus(){return this.MSA.gc.seq_cons}get secondaryStructureConsensus(){return this.MSA.gc.SS_cons}get tracks(){return[{id:"seqConsensus",name:"Sequence consensus",data:this.seqConsensus,customColorScheme:{}},{id:"secondaryStruct",name:"Secondary-structure",data:this.secondaryStructureConsensus,customColorScheme:{">":"pink","<":"lightblue"}}]}}});function Vf(e,t=0){return Is(e)?new oo(e,t):Cn.sniff(e)?new Cn(e):e.startsWith(">")?new ro(e):e.startsWith("SEQ")?new to(e):new eo(e)}var aw=g(()=>{Rf();Of();Uf();Hf();Jf();Gf();jf();Rf();Of();Uf();Hf();Jf()});function Mk(e){return e?Object.fromEntries(e.split(";").map(t=>t.trim()).filter(t=>!!t).map(t=>t.split("=")).map(([t,r])=>[t?.trim()??"",r?decodeURIComponent(r).trim().split(",").join(" "):void 0]).filter(([t])=>t!=="")):{}}function Hc(e){return e?e.split(`
69
+ `).map(t=>t.trim()).filter(t=>!!t&&!t.startsWith("#")).map(t=>{let r=t.split(" "),[n,o,i,s,a,c,l,A]=r,u=r[8];return{seq_id:n??"",source:o??"",type:i??"",start:Number(s)||0,end:Number(a)||0,score:Number(c)||0,strand:l??".",phase:A??".",...Mk(u)}}):[]}var cw=g(()=>{});function jc(e){let t=new Map;for(let n of e){let o=t.get(n.seq_id);o?o.push(n):t.set(n.seq_id,[n])}let r={};for(let[n,o]of t){let i=new Map,s=new Map;for(let c of o){let l=c.Name||c.ID||`${c.source}_${c.start}_${c.end}`,A=c.signature_desc||c.Name||l,u=c.Ontology_term||c.description||c.Note||A;s.has(l)||s.set(l,{name:A,description:u,accession:l});let m=i.get(l);m?m.push({start:c.start,end:c.end}):i.set(l,[{start:c.start,end:c.end}])}let a=[];for(let[c,l]of i){let A=s.get(c);a.push({signature:{entry:A},locations:l})}r[n]={matches:a,xref:[{id:n}]}}return r}var lw=g(()=>{});var Aw=g(()=>{});var uw=g(()=>{cw();lw();Aw()});var fw=g(()=>{Yb();Ff();aw();uw()});function mw({mapHeight:e,blockSize:t,viewportY:r,viewportHeight:n}){let o=Math.max(0,Math.min(r,e*t-n)),i=Math.floor(o/t),s=Math.floor((o+n-1)/t),a=[];for(let c=i;c<=s;c++)a.push(c*t);return a}function dw({mapWidth:e,blockSize:t,viewportX:r,viewportWidth:n}){let o=Math.max(0,Math.min(r,e-n)),i=Math.floor(o/t),s=Math.floor((o+n-1)/t),a=[];for(let c=i;c<=s;c++)a.push(c*t);return a}var gw=g(()=>{});function Iw(e,t){let{W:r=0,L:n=0,V:o=0,I:i=0,M:s=0,A:a=0,F:c=0,C:l=0,H:A=0,P:u=0,R:m=0,K:d=0,Q:p=0,E=0,D:x=0,T:I=0,S:h=0,G:y=0,Y:Q=0,N:M=0}=e,B=r+n+o+i+s+a+c+l+A+u+Q,v=d+m,P=p+E,N=E+x,$=I+h,S=J=>J/t,L={};return S(B)>.6&&(L.W=En,L.L=En,L.V=En,L.A=En,L.I=En,L.M=En,L.F=En,L.C=En),(S(v)>.6||S(d)>.8||S(m)>.8||S(p)>.8)&&(L.K=pw,L.R=pw),(S(v)>.6||S(P)>.5||S(E)>.8||S(p)>.8||S(x)>.8)&&(L.E=kk),(S(v)>.6||S(N)>.5||S(d)>.8||S(m)>.8||S(p)>.8)&&(L.D=Dk),(S(M)>.5||S(Q)>.85)&&(L.N=hw),(S(v)>.6||S(P)>.6||S(p)>.85||S(E)>.85||S(d)>.85||S(m)>.85)&&(L.Q=hw),(S(B)>.6||S($)>.5||S(h)>.85||S(I)>.85)&&(L.S=Cw,L.T=Cw),S(l)>.85&&(L.C=Nk),y>0&&(L.G=Lk),u>0&&(L.P=Fk),(S(B)>.6||S(r)>.85||S(Q)>.85||S(a)>.85||S(l)>.85||S(u)>.85||S(p)>.85||S(c)>.85||S(A)>.85||S(i)>.85||S(n)>.85||S(s)>.85||S(o)>.85)&&(L.H=Ew,L.Y=Ew),L}var En,pw,kk,Dk,hw,Cw,Nk,Lk,Fk,Ew,xw=g(()=>{En="rgb(128,179,230)",pw="#d88",kk="rgb(192, 72, 192)",Dk="rgb(204, 77, 204)",hw="#8f8",Cw="rgb(26,204,26)",Nk="rgb(240, 128, 128)",Lk="rgb(240, 144, 72)",Fk="rgb(204, 204, 0)",Ew="rgb(26, 179, 179)"});function Yf({ctx:e,conservation:t,colWidth:r,trackHeight:n,offsetX:o,blockSize:i}){let s=Math.max(0,Math.floor(o/r)),a=Math.max(0,Math.ceil((o+i)/r));e.fillStyle="gray";for(let c=s;c<a&&c<t.length;c++){let A=t[c]*n,u=c*r;e.fillRect(u,n-A,r,A)}}function Wf({ctx:e,data:t,colorScheme:r,contrastScheme:n,bgColor:o,colWidth:i,rowHeight:s,offsetX:a,blockSize:c}){let l=Math.max(0,Math.floor(a/i)),A=Math.max(0,Math.ceil((a+c)/i)),u=t?.slice(l,A);for(let m=0;u&&m<u.length;m++){let d=u[m],p=r[d.toUpperCase()];if(o){let E=m*i+a-a%i;e.fillStyle=p||"white",e.fillRect(E,0,i,s),s>=10&&i>=s/2&&(e.fillStyle=n[d.toUpperCase()]||"black",e.fillText(d,E+i/2,s/2+1))}}}function Rk({model:e,ctx:t,offsetX:r,offsetY:n,trackHeight:o,blockSizeXOverride:i,highResScaleFactorOverride:s}){let{blockSize:a,colWidth:c,highResScaleFactor:l,conservation:A}=e,u=i??a,m=s??l;t.resetTransform(),t.scale(m,m),t.translate(-r,n),Yf({ctx:t,conservation:A,colWidth:c,trackHeight:o,offsetX:r,blockSize:u}),t.resetTransform()}function Pk({model:e,ctx:t,track:r,offsetX:n,offsetY:o,contrastScheme:i,blockSizeXOverride:s,highResScaleFactorOverride:a}){let{blockSize:c,bgColor:l,colorScheme:A,colWidth:u,fontSize:m,rowHeight:d,highResScaleFactor:p}=e,{customColorScheme:E,data:x}=r.model,I=E??A,h=s??c,y=a??p;t.resetTransform(),t.scale(y,y),t.translate(-n,o),t.textAlign="center",t.font=t.font.replace(/\d+px/,`${m}px`),Wf({ctx:t,data:x,colorScheme:I,contrastScheme:i,bgColor:l,colWidth:u,rowHeight:d,offsetX:n,blockSize:h}),t.resetTransform()}function yw({model:e,ctx:t,offsetX:r,contrastScheme:n,blockSizeXOverride:o,highResScaleFactorOverride:i}){let{turnedOnTracks:s}=e,a=0;for(let c of s){let l=c.model.height;c.model.id==="conservation"?Rk({model:e,ctx:t,offsetX:r,offsetY:a,trackHeight:l,blockSizeXOverride:o,highResScaleFactorOverride:i}):Pk({model:e,ctx:t,track:c,offsetX:r,offsetY:a,contrastScheme:n,blockSizeXOverride:o,highResScaleFactorOverride:i}),a+=l}}var qc=g(()=>{});var Kr,bw,zf,Ok,Gk,ww,Bw=g(()=>{Kr=f(w(),1),bw=f(we(),1),zf=f(G(),1);qc();Ok=(0,zf.observer)(function({model:e,offsetX:t,trackHeight:r}){let{blockSize:n,scrollX:o,colWidth:i,highResScaleFactor:s,conservation:a}=e,c=(0,Kr.useRef)(null);return(0,Kr.useEffect)(()=>{if(!c.current)return;let l=c.current.getContext("2d");l&&(l.resetTransform(),l.scale(s,s),l.clearRect(0,0,n,r),l.translate(-t,0),Yf({ctx:l,conservation:a,colWidth:i,trackHeight:r,offsetX:t,blockSize:n}))},[n,i,r,t,s,a]),Kr.default.createElement("canvas",{ref:c,height:r*s,width:n*s,style:{position:"absolute",left:o+t,width:n,height:r}})}),Gk=(0,zf.observer)(function({model:e,track:t}){let{blocksX:r,msaAreaWidth:n}=e,o=t.model.height;return Kr.default.createElement("div",{style:{position:"relative",height:o,width:n,overflow:"hidden"}},r.map(i=>Kr.default.createElement(Ok,{key:i,model:e,offsetX:i,trackHeight:o})),Kr.default.createElement(bw.ResizeHandle,{onDrag:i=>(e.setConservationTrackHeight(Math.max(10,e.conservationTrackHeight+i)),i),style:{position:"absolute",bottom:0,left:0,height:4,width:"100%",zIndex:1,background:"rgba(200,200,200,0.5)"}}))}),ww=Gk});var In,$f,Uk,Hk,Sw,Qw=g(()=>{In=f(w(),1),$f=f(G(),1);bf();qc();Uk=(0,$f.observer)(function({track:e,model:t,offsetX:r}){let{blockSize:n,scrollX:o,bgColor:i,colorScheme:s,colWidth:a,fontSize:c,rowHeight:l,highResScaleFactor:A}=t,{model:{customColorScheme:u,data:m}}=e,d=u||s,p=(0,In.useRef)(null),{contrastScheme:E}=vc(d);return(0,In.useEffect)(()=>{if(!p.current)return;let x=p.current.getContext("2d");x&&(x.resetTransform(),x.scale(A,A),x.clearRect(0,0,n,l),x.translate(-r,0),x.textAlign="center",x.font=x.font.replace(/\d+px/,`${c}px`),Wf({ctx:x,data:m,colorScheme:d,contrastScheme:E,bgColor:i,colWidth:a,rowHeight:l,offsetX:r,blockSize:n}))},[c,i,n,a,l,r,E,d,A,m]),In.default.createElement("canvas",{ref:p,height:l*A,width:n*A,style:{position:"absolute",left:o+r,width:n,height:l}})}),Hk=(0,$f.observer)(function({track:e,model:t}){let{blocksX:r,msaAreaWidth:n,rowHeight:o}=t;return e.model.data?In.default.createElement("div",{style:{position:"relative",height:o,width:n,overflow:"hidden"}},r.map(i=>In.default.createElement(Uk,{key:i,track:e,model:t,offsetX:i}))):null}),Sw=Hk});var Jc,Vc=g(()=>{Jc="maeditor"});function Mw(e){let t=Math.min(e.length-1,zu.length-1),r=zu[t];return Object.fromEntries(e.map((n,o)=>[n,r[o]]))}var vw=g(()=>{$u()});function Tw(e){let t=new Map(e.map(n=>[n.id,{id:`${n.id}`,name:`${n.id}`,parent:n.parent!==void 0?`${n.parent}`:void 0,children:[]}])),r;for(let n of e){let o=t.get(n.id),i=n.parent!==void 0?t.get(n.parent):void 0;i?i.children.push(o):r??=o}return r}var _w=g(()=>{});function kw(e,t){Kf||(Kf=document.createElement("canvas"));let r=Kf.getContext("2d");if(!r)throw new Error("no canvas context");return r.font=r.font.replace(/\d+px/,`${t}px`),r.measureText(e).width}var Kf,Dw=g(()=>{});function Nw(){return Lr.types.model({tree:Lr.types.maybe(Lr.types.string),msa:Lr.types.maybe(Lr.types.string),treeMetadata:Lr.types.maybe(Lr.types.string),gff:Lr.types.maybe(Lr.types.string)}).actions(e=>({setTree(t){e.tree=t},setMSA(t){e.msa=t},setTreeMetadata(t){e.treeMetadata=t},setGFF(t){e.gff=t}})).postProcessSnapshot(e=>{let{tree:t,msa:r,treeMetadata:n,gff:o}=e,i=5e4;return{tree:t&&t.length>i?void 0:t,msa:r&&r.length>i?void 0:r,treeMetadata:n&&n.length>i?void 0:n,gff:o&&o.length>i?void 0:o}})}var Lr,Lw=g(()=>{Lr=f(_t(),1)});function Rw(){return Fw.types.model("DialogQueueSessionMixin",{}).volatile(()=>({queueOfDialogs:[]})).views(e=>({get DialogComponent(){return e.queueOfDialogs[0]?.[0]},get DialogProps(){return e.queueOfDialogs[0]?.[1]}})).actions(e=>({removeActiveDialog(){e.queueOfDialogs=e.queueOfDialogs.slice(1)},queueDialog(t){let[r,n]=t(()=>{this.removeActiveDialog()});e.queueOfDialogs=[...e.queueOfDialogs,[r,n]]}}))}var Fw,Pw=g(()=>{Fw=f(_t(),1)});function Gw(){return Ow.types.model({bgColor:!0,colorSchemeName:Jc}).actions(e=>({setColorSchemeName(t){e.colorSchemeName=t},setBgColor(t){e.bgColor=t}}))}var Ow,Uw=g(()=>{Ow=f(_t(),1);Vc()});function Hw(){return hi.types.model({drawLabels:!0,labelsAlignRight:!1,treeAreaWidth:hi.types.optional(hi.types.number,400),treeWidth:hi.types.optional(hi.types.number,300),showBranchLen:!0,drawTree:!0,drawNodeBubbles:!0}).actions(e=>({setTreeAreaWidth(t){e.treeAreaWidth=Math.round(t)},setTreeWidth(t){e.treeWidth=Math.round(t)},setLabelsAlignRight(t){e.labelsAlignRight=t},setDrawTree(t){e.drawTree=t},setShowBranchLen(t){e.showBranchLen=t},setDrawNodeBubbles(t){e.drawNodeBubbles=t},setDrawLabels(t){e.drawLabels=t}}))}var hi,jw=g(()=>{hi=f(_t(),1);Vc()});function sm(e,t){return qw.get(e.toUpperCase())?.get(t.toUpperCase())??-4}function qk(e,t){if(e.length!==t.length)throw new Error("Sequences must have the same length (aligned)");let r=0,n=0,o=0,i=0;for(let l=0;l<e.length;l++){let A=e[l],u=t[l];if(A==="-"&&u==="-")continue;if(A==="-"||u==="-"){n++;continue}let m=sm(A,u);o+=m,i+=Math.max(sm(A,A),sm(u,u)),A.toUpperCase()===u.toUpperCase()?r++:n++}if(r+n===0||i<=0)return 1;let a=o/i,c=Math.max(.01,Math.min(1,a));return-Math.log(c)}function Jk(e){let t=e.length,r=[];for(let n=0;n<t;n++){r[n]=[];for(let o=0;o<t;o++)n===o?r[n][o]=0:o<n?r[n][o]=r[o][n]:r[n][o]=qk(e[n][1],e[o][1])}return r}function Vk(e,t){let r=e.length;if(r<2)return{name:t[0]};if(r===2){let a=e[0][1];return{left:{name:t[0]},right:{name:t[1]},leftLength:a/2,rightLength:a/2}}let n=[];for(let a=0;a<r;a++)n[a]=[...e[a]];let o=t.map(a=>({name:a})),i=r;for(;i>2;){let a=[];for(let y=0;y<o.length;y++)o[y]!==void 0&&a.push(y);let c=new Map;for(let y of a){let Q=0;for(let M of a)y!==M&&(Q+=n[y][M]);c.set(y,Q)}let l=1/0,A=-1,u=-1;for(let y=0;y<a.length;y++)for(let Q=y+1;Q<a.length;Q++){let M=a[y],B=a[Q],v=(i-2)*n[M][B]-c.get(M)-c.get(B);v<l&&(l=v,A=M,u=B)}let m=n[A][u],d=c.get(A),p=c.get(u),E,x;i>2?(E=m/2+(d-p)/(2*(i-2)),x=m-E):(E=m/2,x=m/2),E=Math.max(0,E),x=Math.max(0,x);let I={left:o[A],right:o[u],leftLength:E,rightLength:x},h=A;for(let y of a)if(y!==A&&y!==u){let Q=(n[A][y]+n[u][y]-m)/2;n[h][y]=Math.max(0,Q),n[y][h]=Math.max(0,Q)}o[u]=void 0,o[h]=I,i--}let s=[];for(let a=0;a<o.length;a++)o[a]!==void 0&&s.push(a);if(s.length===2){let a=s[0],c=s[1],l=n[a][c];return{left:o[a],right:o[c],leftLength:l/2,rightLength:l/2}}return o[s[0]]}function am(e,t){let r;if(e.name!==void 0&&!e.left&&!e.right)r=`'${e.name.replaceAll("'","''")}'`;else{let n=e.left?am(e.left,e.leftLength):"",o=e.right?am(e.right,e.rightLength):"";r=`(${n},${o})`}return t!==void 0&&(r+=`:${t.toFixed(6)}`),r}function Jw(e){if(e.length<2)throw new Error("Need at least 2 sequences to build a tree");let t=e.map(o=>o[0]),r=Jk(e),n=Vk(r,t);return am(n)+";"}var Yc,jk,qw,Vw=g(()=>{Yc="ARNDCQEGHILKMFPSTWYVBZX*",jk=[[4,-1,-2,-2,0,-1,-1,0,-2,-1,-1,-1,-1,-2,-1,1,0,-3,-2,0,-2,-1,0,-4],[-1,5,0,-2,-3,1,0,-2,0,-3,-2,2,-1,-3,-2,-1,-1,-3,-2,-3,-1,0,-1,-4],[-2,0,6,1,-3,0,0,0,1,-3,-3,0,-2,-3,-2,1,0,-4,-2,-3,3,0,-1,-4],[-2,-2,1,6,-3,0,2,-1,-1,-3,-4,-1,-3,-3,-1,0,-1,-4,-3,-3,4,1,-1,-4],[0,-3,-3,-3,9,-3,-4,-3,-3,-1,-1,-3,-1,-2,-3,-1,-1,-2,-2,-1,-3,-3,-2,-4],[-1,1,0,0,-3,5,2,-2,0,-3,-2,1,0,-3,-1,0,-1,-2,-1,-2,0,3,-1,-4],[-1,0,0,2,-4,2,5,-2,0,-3,-3,1,-2,-3,-1,0,-1,-3,-2,-2,1,4,-1,-4],[0,-2,0,-1,-3,-2,-2,6,-2,-4,-4,-2,-3,-3,-2,0,-2,-2,-3,-3,-1,-2,-1,-4],[-2,0,1,-1,-3,0,0,-2,8,-3,-3,-1,-2,-1,-2,-1,-2,-2,2,-3,0,0,-1,-4],[-1,-3,-3,-3,-1,-3,-3,-4,-3,4,2,-3,1,0,-3,-2,-1,-3,-1,3,-3,-3,-1,-4],[-1,-2,-3,-4,-1,-2,-3,-4,-3,2,4,-2,2,0,-3,-2,-1,-2,-1,1,-4,-3,-1,-4],[-1,2,0,-1,-3,1,1,-2,-1,-3,-2,5,-1,-3,-1,0,-1,-3,-2,-2,0,1,-1,-4],[-1,-1,-2,-3,-1,0,-2,-3,-2,1,2,-1,5,0,-2,-1,-1,-1,-1,1,-3,-1,-1,-4],[-2,-3,-3,-3,-2,-3,-3,-3,-1,0,0,-3,0,6,-4,-2,-2,1,3,-1,-3,-3,-1,-4],[-1,-2,-2,-1,-3,-1,-1,-2,-2,-3,-3,-1,-2,-4,7,-1,-1,-4,-3,-2,-2,-1,-2,-4],[1,-1,1,0,-1,0,0,0,-1,-2,-2,0,-1,-2,-1,4,1,-3,-2,-2,0,0,0,-4],[0,-1,0,-1,-1,-1,-1,-2,-2,-1,-1,-1,-1,-2,-1,1,5,-2,-2,0,-1,-1,0,-4],[-3,-3,-4,-4,-2,-2,-3,-2,-2,-3,-2,-3,-1,1,-4,-3,-2,11,2,-3,-4,-3,-2,-4],[-2,-2,-2,-3,-2,-1,-2,-3,2,-1,-1,-2,-1,3,-3,-2,-2,2,7,-1,-3,-2,-1,-4],[0,-3,-3,-3,-1,-2,-2,-3,-3,3,1,-2,1,-1,-2,-2,0,-3,-1,4,-3,-2,-1,-4],[-2,-1,3,4,-3,0,1,-1,0,-3,-4,0,-3,-3,-2,0,-1,-4,-3,-3,4,1,-1,-4],[-1,0,0,1,-3,3,4,-2,0,-3,-3,1,-1,-3,-1,0,-1,-3,-2,-2,1,4,-1,-4],[0,-1,-1,-1,-2,-1,-1,-1,-1,-1,-1,-1,-1,-1,-2,0,0,-2,-1,-1,-1,-1,-1,-4],[-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,-4,1]],qw=new Map;for(let e=0;e<Yc.length;e++){let t=new Map;for(let r=0;r<Yc.length;r++)t.set(Yc[r],jk[e][r]);qw.set(Yc[e],t)}});function cm(e){let t=[],r=0;for(;r<e.length&&(r=e.indexOf("{",r),r!==-1);){let n=1,o=r+1;for(r++;r<e.length&&n>0;)e[r]==="{"?n++:e[r]==="}"&&n--,r++;n===0&&t.push(e.slice(o,r-1).trim())}return t}function Wk(e,t){let r=e.indexOf("{",t);if(r===-1)return;let n=1,o=r+1;for(;o<e.length&&n>0;)e[o]==="{"?n++:e[o]==="}"&&n--,o++;return n===0?e.slice(r+1,o-1).trim():void 0}function Yw(e){let t=e.replace(/\s+/g," ").replace(/\s*{\s*/g,"{").replace(/\s*}\s*/g,"}").replace(/\s*,\s*/g,",").replace(/\s*::\s*=\s*/g,"::=").replace(/^.*?::=/,""),r=zk(t),n=Object.fromEntries(cm(r.fdict).flatMap(o=>{let i=$k(o);return i?[[i.id,Yk[i.name]||i.name]]:[]}));return cm(r.nodes).flatMap(o=>{let i=Kk(o);if(!i)return[];let{features:s=[],...a}=i;return[{...a,...Object.fromEntries(s.map(c=>[n[c.featureid],c.value]))}]})}function zk(e){let t={},r=e.trim();r.startsWith("{")&&r.endsWith("}")&&(r=r.slice(1,-1).trim());let n=0;for(;n<r.length;){for(;n<r.length&&/\s/.test(r[n]);)n++;if(n>=r.length)break;let o=n;for(;n<r.length&&/\w/.test(r[n]);)n++;if(n>=r.length||r[n]!==" "&&r[n]!=="{"){n=r.indexOf(",",n),n=n===-1?r.length:n+1;continue}let i=r.slice(o,n).trim();for(;n<r.length&&/\s/.test(r[n]);)n++;if(n>=r.length||r[n]!=="{"){n=r.indexOf(",",n),n=n===-1?r.length:n+1;continue}let s=1,a=n+1;for(n++;n<r.length&&s>0;)r[n]==="{"?s++:r[n]==="}"&&s--,n++;s===0&&(t[i]=r.slice(a,n-1).trim()),n=r.indexOf(",",n),n=n===-1?r.length:n+1}return t}function $k(e){let t=/id\s+(\d+)/.exec(e),r=/name\s+"((?:[^"\\]|\\.)*)"/s.exec(e);return!t||!r?null:{id:parseInt(t[1],10),name:r[1].replace(/\\"/g,'"').replace(/\\\\/g,"\\")}}function Kk(e){let t=/id\s+(\d+)/.exec(e);if(!t)return null;let r=/parent\s+(\d+)/.exec(e),n=e.indexOf("features"),o=n!==-1?Wk(e,n):void 0;return{id:parseInt(t[1],10),...r?{parent:parseInt(r[1],10)}:{},features:o?cm(o).flatMap(i=>{let s=Xk(i);return s?[s]:[]}):[]}}function Xk(e){let t=/featureid\s+(\d+)/.exec(e),r=/value\s+"((?:[^"\\]|\\.)*)"/s.exec(e);return!t||!r?null:{featureid:parseInt(t[1],10),value:r[1].replace(/\\"/g,'"').replace(/\\\\/g,"\\")}}var Yk,Ww=g(()=>{Yk={$NODE_COLLAPSED:"collapsed",$NODE_COLOR:"color",$LABEL_BG_COLOR:"color","seq-id":"seqId","seq-title":"seqTitle","align-index":"alignIndex","accession-nbr":"accessionNbr","blast-name":"blastName","common-name":"commonName","leaf-count":"leafCount"}});function lm(e,t){let r=0,n=0,o=0,i=e.length;for(;n<i&&e[n]===o;)n++,o++;for(;r<t;)for(r++,o++;n<i&&e[n]===o;)n++,o++;return o}function zw(e,t){let r=0,n=e.length-1;for(;r<=n;){let i=Math.floor((r+n)/2);if(e[i]===t)return;e[i]<t?r=i+1:n=i-1}return t-r}function Zk({seq:e,blanks:t,visibleCol:r}){let n=lm(t,r),o=e.length;if(n<o&&ns(e[n]))return;let i=0;for(let s=0;s<n&&s<o;s++)ns(e[s])||i++;return n<o?i:void 0}function $w({rowName:e,visibleCol:t,rowMap:r,blanks:n}){let o=r.get(e);return o!==void 0?Zk({seq:o,visibleCol:t,blanks:n}):void 0}var Kw=g(()=>{Yn()});function Xw({row:e,seqPos:t}){let r=0,n=0;for(;n<e.length;){if(!ns(e[n])){if(r===t)return n;r++}n++}return t===0?0:n}var Zw=g(()=>{Yn()});function eB(e,t){let r=URL.createObjectURL(e),n=document.createElement("a");n.href=r,n.download=t,n.click(),setTimeout(()=>{URL.revokeObjectURL(r)},4e4)}var tB=g(()=>{});var io,rB,eD,nB,oB=g(()=>{io=f(w(),1),rB=f(G(),1),eD=(0,rB.observer)(({model:e})=>{let{scrollX:t,msaAreaWidth:r,minimapHeight:n,colWidth:o,numColumns:i}=e,s=12,a=n-12,c=r/i/o,l=-t,A=l+r,u=l*c,m=A*c,d="rgb(66, 119, 127)",p=.3;return io.default.createElement(io.default.Fragment,null,io.default.createElement("rect",{x:0,y:0,width:r,height:s,stroke:"#555",fill:"none"}),io.default.createElement("rect",{x:Math.max(0,u),y:0,width:m-u,height:s,fill:d,fillOpacity:p,stroke:"#555"}),io.default.createElement("g",{transform:`translate(0 ${s})`},io.default.createElement("polygon",{fill:d,fillOpacity:p,points:[[m,0],[u,0],[0,a],[r,a]].toString()})))}),nB=eD});var aB={};Ye(aB,{Context:()=>fm});function iB(e){return!e||typeof e=="string"?e:e+""}function fr(e,t){let r=Object.keys(t);for(let n of r)e=e.replace(new RegExp("\\{"+n+"\\}","gi"),t[n]);return e}function Am(e){if(!e)throw new Error("cannot create a random attribute name for an undefined object");let t="ABCDEFGHIJKLMNOPQRSTUVWXTZabcdefghiklmnopqrstuvwxyz",r="";do{r="";for(let n=0;n<12;n++)r+=t[Math.floor(Math.random()*t.length)]}while(e[r]);return r}function tD(e,t=10){let r={},n=e.split(",");for(let o=0;o<n.length;o+=2){let i="&"+n[o+1]+";",s=parseInt(n[o],t);r[i]="&#"+s+";"}return r["\\xa0"]="&#160;",r}function rD(e){let t={left:"start",right:"end",center:"middle",start:"start",end:"end"};return t[e]||t.start}function nD(e){let t={alphabetic:"alphabetic",hanging:"hanging",top:"text-before-edge",bottom:"text-after-edge",middle:"central"};return t[e]||t.alphabetic}var sB,xs,ys,um,fm,cB=g(()=>{sB=tD("50,nbsp,51,iexcl,52,cent,53,pound,54,curren,55,yen,56,brvbar,57,sect,58,uml,59,copy,5a,ordf,5b,laquo,5c,not,5d,shy,5e,reg,5f,macr,5g,deg,5h,plusmn,5i,sup2,5j,sup3,5k,acute,5l,micro,5m,para,5n,middot,5o,cedil,5p,sup1,5q,ordm,5r,raquo,5s,frac14,5t,frac12,5u,frac34,5v,iquest,60,Agrave,61,Aacute,62,Acirc,63,Atilde,64,Auml,65,Aring,66,AElig,67,Ccedil,68,Egrave,69,Eacute,6a,Ecirc,6b,Euml,6c,Igrave,6d,Iacute,6e,Icirc,6f,Iuml,6g,ETH,6h,Ntilde,6i,Ograve,6j,Oacute,6k,Ocirc,6l,Otilde,6m,Ouml,6n,times,6o,Oslash,6p,Ugrave,6q,Uacute,6r,Ucirc,6s,Uuml,6t,Yacute,6u,THORN,6v,szlig,70,agrave,71,aacute,72,acirc,73,atilde,74,auml,75,aring,76,aelig,77,ccedil,78,egrave,79,eacute,7a,ecirc,7b,euml,7c,igrave,7d,iacute,7e,icirc,7f,iuml,7g,eth,7h,ntilde,7i,ograve,7j,oacute,7k,ocirc,7l,otilde,7m,ouml,7n,divide,7o,oslash,7p,ugrave,7q,uacute,7r,ucirc,7s,uuml,7t,yacute,7u,thorn,7v,yuml,ci,fnof,sh,Alpha,si,Beta,sj,Gamma,sk,Delta,sl,Epsilon,sm,Zeta,sn,Eta,so,Theta,sp,Iota,sq,Kappa,sr,Lambda,ss,Mu,st,Nu,su,Xi,sv,Omicron,t0,Pi,t1,Rho,t3,Sigma,t4,Tau,t5,Upsilon,t6,Phi,t7,Chi,t8,Psi,t9,Omega,th,alpha,ti,beta,tj,gamma,tk,delta,tl,epsilon,tm,zeta,tn,eta,to,theta,tp,iota,tq,kappa,tr,lambda,ts,mu,tt,nu,tu,xi,tv,omicron,u0,pi,u1,rho,u2,sigmaf,u3,sigma,u4,tau,u5,upsilon,u6,phi,u7,chi,u8,psi,u9,omega,uh,thetasym,ui,upsih,um,piv,812,bull,816,hellip,81i,prime,81j,Prime,81u,oline,824,frasl,88o,weierp,88h,image,88s,real,892,trade,89l,alefsym,8cg,larr,8ch,uarr,8ci,rarr,8cj,darr,8ck,harr,8dl,crarr,8eg,lArr,8eh,uArr,8ei,rArr,8ej,dArr,8ek,hArr,8g0,forall,8g2,part,8g3,exist,8g5,empty,8g7,nabla,8g8,isin,8g9,notin,8gb,ni,8gf,prod,8gh,sum,8gi,minus,8gn,lowast,8gq,radic,8gt,prop,8gu,infin,8h0,ang,8h7,and,8h8,or,8h9,cap,8ha,cup,8hb,int,8hk,there4,8hs,sim,8i5,cong,8i8,asymp,8j0,ne,8j1,equiv,8j4,le,8j5,ge,8k2,sub,8k3,sup,8k4,nsub,8k6,sube,8k7,supe,8kl,oplus,8kn,otimes,8l5,perp,8m5,sdot,8o8,lceil,8o9,rceil,8oa,lfloor,8ob,rfloor,8p9,lang,8pa,rang,9ea,loz,9j0,spades,9j3,clubs,9j5,hearts,9j6,diams,ai,OElig,aj,oelig,b0,Scaron,b1,scaron,bo,Yuml,m6,circ,ms,tilde,802,ensp,803,emsp,809,thinsp,80c,zwnj,80d,zwj,80e,lrm,80f,rlm,80j,ndash,80k,mdash,80o,lsquo,80p,rsquo,80q,sbquo,80s,ldquo,80t,rdquo,80u,bdquo,810,dagger,811,Dagger,81g,permil,81p,lsaquo,81q,rsaquo,85c,euro",32),xs={strokeStyle:{svgAttr:"stroke",canvas:"#000000",svg:"none",apply:"stroke"},fillStyle:{svgAttr:"fill",canvas:"#000000",svg:null,apply:"fill"},lineCap:{svgAttr:"stroke-linecap",canvas:"butt",svg:"butt",apply:"stroke"},lineJoin:{svgAttr:"stroke-linejoin",canvas:"miter",svg:"miter",apply:"stroke"},miterLimit:{svgAttr:"stroke-miterlimit",canvas:10,svg:4,apply:"stroke"},lineWidth:{svgAttr:"stroke-width",canvas:1,svg:1,apply:"stroke"},globalAlpha:{svgAttr:"opacity",canvas:1,svg:1,apply:"fill stroke"},font:{canvas:"10px sans-serif"},shadowColor:{canvas:"#000000"},shadowOffsetX:{canvas:0},shadowOffsetY:{canvas:0},shadowBlur:{canvas:0},textAlign:{canvas:"start"},textBaseline:{canvas:"alphabetic"},lineDash:{svgAttr:"stroke-dasharray",canvas:[],svg:null,apply:"stroke"}},ys=class{__root;__ctx;constructor(t,r){this.__root=t,this.__ctx=r}addColorStop(t,r){let n=this.__ctx.__createElement("stop");if(n.setAttribute("offset",String(t)),iB(r).includes("rgba")){let i=/rgba\(\s*(\d*\.?\d+)\s*,\s*(\d*\.?\d+)\s*,\s*(\d*\.?\d+)\s*,\s*(\d?\.?\d*)\s*\)/gi.exec(r);i&&(n.setAttribute("stop-color",fr("rgb({r},{g},{b})",{r:i[1],g:i[2],b:i[3]})),n.setAttribute("stop-opacity",i[4]))}else n.setAttribute("stop-color",iB(r));this.__root.appendChild(n)}},um=class{__root;__ctx;constructor(t,r){this.__root=t,this.__ctx=r}},fm=class{width;height;enableMirroring;canvas;__document;__ctx;__canvas;__root;__ids;__defs;__currentElement;__styleStack;__groupStack;__currentDefaultPath;__currentPosition;__transformMatrix;__transformMatrixStack;__currentElementsToStyle;__options;__id;__fontUnderline;__fontHref;strokeStyle;fillStyle;lineCap;lineJoin;miterLimit;lineWidth;globalAlpha;font;shadowColor;shadowOffsetX;shadowOffsetY;shadowBlur;textAlign;textBaseline;lineDash;constructor(t,r){let n={width:500,height:500,enableMirroring:!1},o;typeof t=="number"&&r!==void 0?o={...n,width:t,height:r}:t&&typeof t=="object"?o=t:o=n,this.width=o.width||n.width,this.height=o.height||n.height,this.enableMirroring=o.enableMirroring!==void 0?o.enableMirroring:n.enableMirroring,this.canvas=this,this.__document=o.document||document,o.ctx?this.__ctx=o.ctx:(this.__canvas=this.__document.createElement("canvas"),this.__ctx=this.__canvas.getContext("2d")),this.__setDefaultStyles(),this.__styleStack=[this.__getStyleState()],this.__groupStack=[],this.__root=this.__document.createElementNS("http://www.w3.org/2000/svg","svg"),this.__root.setAttribute("version","1.1"),this.__root.setAttribute("xmlns","http://www.w3.org/2000/svg"),this.__root.setAttributeNS("http://www.w3.org/2000/xmlns/","xmlns:xlink","http://www.w3.org/1999/xlink"),this.__root.setAttribute("width",String(this.width)),this.__root.setAttribute("height",String(this.height)),this.__ids={},this.__defs=this.__document.createElementNS("http://www.w3.org/2000/svg","defs"),this.__root.appendChild(this.__defs),this.__currentElement=this.__document.createElementNS("http://www.w3.org/2000/svg","g"),this.__root.appendChild(this.__currentElement),this.__currentDefaultPath="",this.__currentPosition={},this.__transformMatrix=new DOMMatrix,this.resetTransform(),this.__options=o,this.__id=Math.random().toString(16).substring(2,8)}__createElement(t,r={},n){let o=this.__document.createElementNS("http://www.w3.org/2000/svg",t);n&&(o.setAttribute("fill","none"),o.setAttribute("stroke","none"));for(let i of Object.keys(r))o.setAttribute(i,r[i]);return o}__setDefaultStyles(){for(let t of Object.keys(xs))this[t]=xs[t].canvas}__applyStyleState(t){for(let r of Object.keys(t))this[r]=t[r]}__getStyleState(){let t={};for(let r of Object.keys(xs))t[r]=this[r];return t}__applyTransformation(t,r){let{a:n,b:o,c:i,d:s,e:a,f:c}=r||this.getTransform();t.setAttribute("transform",`matrix(${n} ${o} ${i} ${s} ${a} ${c})`)}__applyStyleToCurrentElement(t){let r=this.__currentElement,n=this.__currentElementsToStyle;if(n){r.setAttribute(t,""),r=n.element;for(let i of n.children)i.setAttribute(t,"")}let o=Object.keys(xs);for(let i of o){let s=xs[i],a=this[i];if(s.apply){if(a instanceof um){if(a.__ctx)for(let c of Array.from(a.__ctx.__defs.childNodes)){let l=c.getAttribute("id");l&&(this.__ids[l]=l,this.__defs.appendChild(c))}r.setAttribute(s.apply,fr("url(#{id})",{id:a.__root.getAttribute("id")}))}else if(a instanceof ys)r.setAttribute(s.apply,fr("url(#{id})",{id:a.__root.getAttribute("id")}));else if(s.apply.includes(t)&&s.svg!==a)if((s.svgAttr==="stroke"||s.svgAttr==="fill")&&a&&a.includes("rgba")){let l=/rgba\(\s*(\d*\.?\d+)\s*,\s*(\d*\.?\d+)\s*,\s*(\d*\.?\d+)\s*,\s*(\d?\.?\d*)\s*\)/gi.exec(a);if(l){r.setAttribute(s.svgAttr,fr("rgb({r},{g},{b})",{r:l[1],g:l[2],b:l[3]}));let A=Number(l[4]),u=this.globalAlpha;u!=null&&(A*=u),r.setAttribute(s.svgAttr+"-opacity",String(A))}}else{let c=s.svgAttr,l=a;if(i==="globalAlpha"){if(c=t+"-"+s.svgAttr,r.getAttribute(c))continue}else if(i==="lineWidth"){let A=this.__getTransformScale();l=a*Math.max(A.x,A.y)}r.setAttribute(c,l)}}}}__closestGroupOrSvg(t){return t=t||this.__currentElement,t.nodeName==="g"||t.nodeName==="svg"?t:this.__closestGroupOrSvg(t.parentNode)}getSerializedSvg(t){let r=new XMLSerializer().serializeToString(this.__root);if(/xmlns="http:\/\/www\.w3\.org\/2000\/svg".+xmlns="http:\/\/www\.w3\.org\/2000\/svg/gi.test(r)&&(r=r.replace('xmlns="http://www.w3.org/2000/svg','xmlns:xlink="http://www.w3.org/1999/xlink')),t)for(let o of Object.keys(sB)){let i=new RegExp(o,"gi");i.test(r)&&(r=r.replace(i,sB[o]))}return r}getSvg(){return this.__root}save(){let t=this.__createElement("g"),r=this.__closestGroupOrSvg();this.__groupStack.push(r),r.appendChild(t),this.__currentElement=t;let n=this.__getStyleState();this.__styleStack.push(n),this.__transformMatrixStack||(this.__transformMatrixStack=[]),this.__transformMatrixStack.push(this.getTransform())}restore(){this.__currentElement=this.__groupStack.pop(),this.__currentElementsToStyle=void 0,this.__currentElement||(this.__currentElement=this.__root.childNodes[1]);let t=this.__styleStack.pop();this.__applyStyleState(t),this.__transformMatrixStack&&this.__transformMatrixStack.length>0&&this.setTransform(this.__transformMatrixStack.pop())}beginPath(){this.__currentDefaultPath="",this.__currentPosition={};let t=this.__createElement("path",{},!0);this.__closestGroupOrSvg().appendChild(t),this.__currentElement=t}__applyCurrentDefaultPath(){let t=this.__currentElement;t.nodeName==="path"&&t.setAttribute("d",this.__currentDefaultPath)}__addPathCommand(t){this.__currentDefaultPath+=" ",this.__currentDefaultPath+=t}moveTo(t,r){this.__currentElement.nodeName!=="path"&&this.beginPath(),this.__currentPosition={x:t,y:r},this.__addPathCommand(fr("M {x} {y}",{x:this.__matrixTransform(t,r).x,y:this.__matrixTransform(t,r).y}))}closePath(){this.__currentDefaultPath&&this.__addPathCommand("Z")}lineTo(t,r){this.__currentPosition={x:t,y:r},this.__currentDefaultPath.includes("M")?this.__addPathCommand(fr("L {x} {y}",{x:this.__matrixTransform(t,r).x,y:this.__matrixTransform(t,r).y})):this.__addPathCommand(fr("M {x} {y}",{x:this.__matrixTransform(t,r).x,y:this.__matrixTransform(t,r).y}))}bezierCurveTo(t,r,n,o,i,s){this.__currentPosition={x:i,y:s},this.__addPathCommand(fr("C {cp1x} {cp1y} {cp2x} {cp2y} {x} {y}",{cp1x:this.__matrixTransform(t,r).x,cp1y:this.__matrixTransform(t,r).y,cp2x:this.__matrixTransform(n,o).x,cp2y:this.__matrixTransform(n,o).y,x:this.__matrixTransform(i,s).x,y:this.__matrixTransform(i,s).y}))}quadraticCurveTo(t,r,n,o){this.__currentPosition={x:n,y:o},this.__addPathCommand(fr("Q {cpx} {cpy} {x} {y}",{cpx:this.__matrixTransform(t,r).x,cpy:this.__matrixTransform(t,r).y,x:this.__matrixTransform(n,o).x,y:this.__matrixTransform(n,o).y}))}stroke(){this.__currentElement.nodeName==="path"&&this.__currentElement.setAttribute("paint-order","fill stroke markers"),this.__applyCurrentDefaultPath(),this.__applyStyleToCurrentElement("stroke")}fill(){this.__currentElement.nodeName==="path"&&this.__currentElement.setAttribute("paint-order","stroke fill markers"),this.__applyCurrentDefaultPath(),this.__applyStyleToCurrentElement("fill")}rect(t,r,n,o){this.__currentElement.nodeName!=="path"&&this.beginPath(),this.moveTo(t,r),this.lineTo(t+n,r),this.lineTo(t+n,r+o),this.lineTo(t,r+o),this.lineTo(t,r),this.closePath()}__clearCanvas(){let t=this.__root.childNodes[1];this.__root.removeChild(t),this.__currentElement=this.__document.createElementNS("http://www.w3.org/2000/svg","g"),this.__root.appendChild(this.__currentElement),this.__groupStack=[]}fillRect(t,r,n,o){let{a:i,b:s,c:a,d:c,e:l,f:A}=this.getTransform();JSON.stringify([i,s,a,c,l,A])===JSON.stringify([1,0,0,1,0,0])&&t===0&&r===0&&n===this.width&&o===this.height&&this.__clearCanvas();let u=this.__createElement("rect",{x:t,y:r,width:n,height:o},!0);this.__closestGroupOrSvg().appendChild(u),this.__currentElement=u,this.__applyTransformation(u),this.__applyStyleToCurrentElement("fill")}strokeRect(t,r,n,o){let i=this.__createElement("rect",{x:t,y:r,width:n,height:o},!0);this.__closestGroupOrSvg().appendChild(i),this.__currentElement=i,this.__applyTransformation(i),this.__applyStyleToCurrentElement("stroke")}clearRect(t,r,n,o){let{a:i,b:s,c:a,d:c,e:l,f:A}=this.getTransform();if(JSON.stringify([i,s,a,c,l,A])===JSON.stringify([1,0,0,1,0,0])&&t===0&&r===0&&n===this.width&&o===this.height){this.__clearCanvas();return}let u=this.__createElement("rect",{x:t,y:r,width:n,height:o,fill:"#FFFFFF"},!0);this.__applyTransformation(u),this.__closestGroupOrSvg().appendChild(u)}createLinearGradient(t,r,n,o){let i=this.__createElement("linearGradient",{id:Am(this.__ids),x1:t+"px",x2:n+"px",y1:r+"px",y2:o+"px",gradientUnits:"userSpaceOnUse"});return this.__defs.appendChild(i),new ys(i,this)}createRadialGradient(t,r,n,o,i,s){let a=this.__createElement("radialGradient",{id:Am(this.__ids),cx:o+"px",cy:i+"px",r:s+"px",fx:t+"px",fy:r+"px",gradientUnits:"userSpaceOnUse"});return this.__defs.appendChild(a),new ys(a,this)}__applyText(t,r,n,o){let i=document.createElement("span");i.setAttribute("style","font:"+this.font);let s=i.style,a=this.__closestGroupOrSvg(),c=this.__createElement("text",{"font-family":s.fontFamily,"font-size":s.fontSize,"font-style":s.fontStyle,"font-weight":s.fontWeight,"text-decoration":this.__fontUnderline,x:r,y:n,"text-anchor":rD(this.textAlign),"dominant-baseline":nD(this.textBaseline)},!0);c.appendChild(this.__document.createTextNode(t)),this.__currentElement=c,this.__applyTransformation(c),this.__applyStyleToCurrentElement(o);let l=c;if(this.__fontHref){let A=this.__createElement("a");A.setAttributeNS("http://www.w3.org/1999/xlink","xlink:href",this.__fontHref),A.appendChild(c),l=A}a.appendChild(l)}fillText(t,r,n){this.__applyText(t,r,n,"fill")}strokeText(t,r,n){this.__applyText(t,r,n,"stroke")}measureText(t){return this.__ctx.font=this.font,this.__ctx.measureText(t)}arc(t,r,n,o,i,s){if(o===i)return;o=o%(2*Math.PI),i=i%(2*Math.PI),o===i&&(i=(i+2*Math.PI-.001*(s?-1:1))%(2*Math.PI));let a=t+n*Math.cos(i),c=r+n*Math.sin(i),l=t+n*Math.cos(o),A=r+n*Math.sin(o),u=s?0:1,m=0,d=i-o;d<0&&(d+=2*Math.PI),s?m=d>Math.PI?0:1:m=d>Math.PI?1:0;let p=Math.hypot(this.__transformMatrix.a,this.__transformMatrix.b),E=Math.hypot(this.__transformMatrix.c,this.__transformMatrix.d);this.lineTo(l,A),this.__addPathCommand(fr("A {rx} {ry} {xAxisRotation} {largeArcFlag} {sweepFlag} {endX} {endY}",{rx:n*p,ry:n*E,xAxisRotation:0,largeArcFlag:m,sweepFlag:u,endX:this.__matrixTransform(a,c).x,endY:this.__matrixTransform(a,c).y})),this.__currentPosition={x:a,y:c}}clip(){let t=this.__closestGroupOrSvg(),r=this.__createElement("clipPath"),n=Am(this.__ids),o=this.__createElement("g");this.__applyCurrentDefaultPath(),t.removeChild(this.__currentElement),r.setAttribute("id",n),r.appendChild(this.__currentElement),this.__defs.appendChild(r),t.setAttribute("clip-path",fr("url(#{id})",{id:n})),t.appendChild(o),this.__currentElement=o}setLineDash(t){t&&t.length>0?this.lineDash=t.join(","):this.lineDash=null}setTransform(t,r,n,o,i,s){t instanceof DOMMatrix?this.__transformMatrix=new DOMMatrix([t.a,t.b,t.c,t.d,t.e,t.f]):this.__transformMatrix=new DOMMatrix([t,r,n,o,i,s])}getTransform(){let{a:t,b:r,c:n,d:o,e:i,f:s}=this.__transformMatrix;return new DOMMatrix([t,r,n,o,i,s])}resetTransform(){this.setTransform(1,0,0,1,0,0)}scale(t,r){if(r===void 0&&(r=t),isNaN(t)||isNaN(r)||!isFinite(t)||!isFinite(r))return;let n=this.getTransform().scale(t,r);this.setTransform(n)}rotate(t){let r=this.getTransform().multiply(new DOMMatrix([Math.cos(t),Math.sin(t),-Math.sin(t),Math.cos(t),0,0]));this.setTransform(r)}translate(t,r){let n=this.getTransform().translate(t,r);this.setTransform(n)}transform(t,r,n,o,i,s){let a=this.getTransform().multiply(new DOMMatrix([t,r,n,o,i,s]));this.setTransform(a)}__matrixTransform(t,r){return new DOMPoint(t,r).matrixTransform(this.__transformMatrix)}__getTransformScale(){return{x:Math.hypot(this.__transformMatrix.a,this.__transformMatrix.b),y:Math.hypot(this.__transformMatrix.c,this.__transformMatrix.d)}}__getTransformRotation(){return Math.atan2(this.__transformMatrix.b,this.__transformMatrix.a)}drawFocusRing(){}createImageData(){}putImageData(){}globalCompositeOperation(){}drawImage(){}createPattern(){return null}}});var fB={};Ye(fB,{renderToSvg:()=>oD});async function oD(e,t){await(0,uB.when)(()=>!!e.dataInitialized);let{width:r,height:n,scrollX:o,scrollY:i,totalTrackAreaHeight:s}=e,{exportType:a,theme:c,includeMinimap:l,includeTracks:A}=t,u=A?s:0;if(a==="entire")return lB({width:e.totalWidth+e.treeAreaWidth,height:e.totalHeight+u,contentHeight:e.totalHeight,trackHeight:u,theme:c,model:e,offsetY:0,offsetX:0,includeMinimap:l,includeTracks:A});if(a==="viewport")return lB({width:r,height:n+(l?e.minimapHeight:0)+u,contentHeight:n,trackHeight:u,theme:c,model:e,offsetY:-i,offsetX:-o,includeMinimap:l,includeTracks:A});throw new Error("unknown export type")}async function lB({width:e,height:t,contentHeight:r,trackHeight:n,offsetX:o,offsetY:i,theme:s,model:a,includeMinimap:c,includeTracks:l}){let{Context:A}=await Promise.resolve().then(()=>(cB(),aB)),u=c?aD:lD;return(0,AB.renderToStaticMarkup)(ce.default.createElement(cD,{width:e,height:t},ce.default.createElement(u,{model:a},l&&n>0?ce.default.createElement(sD,{Context:A,model:a,theme:s,offsetX:o,width:e,trackHeight:n}):null,ce.default.createElement("g",{transform:n>0?`translate(0 ${n})`:void 0},ce.default.createElement(iD,{Context:A,model:a,theme:s,offsetX:o,offsetY:i,width:e,contentHeight:r})))))}function iD({model:e,theme:t,width:r,contentHeight:n,offsetX:o,offsetY:i,Context:s}){let{treeAreaWidth:a,colorScheme:c,id:l}=e,A=`tree-${l}`,u=`msa-${l}`,m=rs(c,t),d=new s(r,n),p=new s(r,n);Qc({ctx:p,offsetX:o,offsetY:i,model:e,blockSizeYOverride:n,highResScaleFactorOverride:1});let E=r-a;return Nc({model:e,offsetY:i,ctx:d,theme:t,blockSizeYOverride:n,highResScaleFactorOverride:1}),Mc({model:e,theme:t,offsetY:i,offsetX:o,contrastScheme:m,ctx:p,blockSizeXOverride:E,blockSizeYOverride:n,highResScaleFactorOverride:1}),ce.default.createElement(ce.default.Fragment,null,ce.default.createElement("defs",null,ce.default.createElement("clipPath",{id:A},ce.default.createElement("rect",{x:0,y:0,width:a,height:n}))),ce.default.createElement("defs",null,ce.default.createElement("clipPath",{id:u},ce.default.createElement("rect",{x:0,y:0,width:E,height:n}))),ce.default.createElement("g",{clipPath:`url(#${A})`,dangerouslySetInnerHTML:{__html:d.getSvg().innerHTML}}),ce.default.createElement("g",{clipPath:`url(#${u})`,transform:`translate(${a} 0)`,dangerouslySetInnerHTML:{__html:p.getSvg().innerHTML}}))}function sD({model:e,theme:t,width:r,trackHeight:n,offsetX:o,Context:i}){let{treeAreaWidth:s,colorScheme:a,id:c}=e,l=`tracks-${c}`,A=rs(a,t),u=r-s,m=new i(u,n);return yw({model:e,ctx:m,offsetX:o,contrastScheme:A,blockSizeXOverride:u,highResScaleFactorOverride:1}),ce.default.createElement("g",{transform:`translate(${s} 0)`},ce.default.createElement("defs",null,ce.default.createElement("clipPath",{id:l},ce.default.createElement("rect",{x:0,y:0,width:u,height:n}))),ce.default.createElement("g",{clipPath:`url(#${l})`,dangerouslySetInnerHTML:{__html:m.getSvg().innerHTML}}))}function aD({model:e,children:t}){let{minimapHeight:r,treeAreaWidth:n}=e;return ce.default.createElement(ce.default.Fragment,null,ce.default.createElement("g",{transform:`translate(${n} 0)`},ce.default.createElement(nB,{model:e})),ce.default.createElement("g",{transform:`translate(0 ${r})`},t))}function cD({width:e,height:t,children:r}){return ce.default.createElement("svg",{width:e,height:t,xmlns:"http://www.w3.org/2000/svg",xmlnsXlink:"http://www.w3.org/1999/xlink",viewBox:[0,0,e,t].toString()},r)}function lD({children:e}){return e}var ce,AB,uB,mB=g(()=>{ce=f(w(),1),AB=f(Ce(),1),uB=f(Gr(),1);oB();xf();yf();qc();Lc();Yn()});function AD(){return Z.types.compose(Rw(),Hw(),Gw(),Z.types.model("MsaView",{id:so.ElementId,showDomains:!1,hideGaps:!0,allowedGappyness:100,subFeatureRows:!1,type:Z.types.literal("MsaView"),drawMsaLetters:!0,height:Z.types.optional(Z.types.number,550),rowHeight:16,scrollY:0,scrollX:0,colWidth:12,treeFilehandle:Z.types.maybe(so.FileLocation),msaFilehandle:Z.types.maybe(so.FileLocation),treeMetadataFilehandle:Z.types.maybe(so.FileLocation),gffFilehandle:Z.types.maybe(so.FileLocation),currentAlignment:0,collapsed:Z.types.array(Z.types.string),showOnly:Z.types.maybe(Z.types.string),turnedOffTracks:Z.types.map(Z.types.boolean),data:Z.types.optional(Nw(),{tree:"",msa:"",treeMetadata:""}),featureFilters:Z.types.map(Z.types.boolean),relativeTo:Z.types.maybe(Z.types.string)})).volatile(()=>({headerHeight:0,status:void 0,highResScaleFactor:2,loadingMSA:!1,loadingTree:!1,volatileWidth:void 0,resizeHandleWidth:5,blockSize:500,mouseRow:void 0,mouseCol:void 0,mouseClickRow:void 0,mouseClickCol:void 0,hoveredTreeNode:void 0,highlightedColumns:void 0,nref:0,minimapHeight:56,conservationTrackHeight:40,marginLeft:20,error:void 0,interProAnnotations:void 0})).actions(e=>({drawRelativeTo(t){e.relativeTo=t},setHideGaps(t){e.hideGaps=t},setAllowedGappyness(t){e.allowedGappyness=t},setLoadingMSA(t){e.loadingMSA=t},setLoadingTree(t){e.loadingTree=t},setWidth(t){e.volatileWidth=t},setHeight(t){e.height=t},setError(t){e.error=t},setMousePos(t,r){e.mouseCol=t,e.mouseRow=r},setHoveredTreeNode(t){if(!t){e.hoveredTreeNode=void 0;return}let r=hs(e.hierarchy,o=>o.data.id===t);if(!r){e.hoveredTreeNode=void 0;return}let n=Cs(r).map(o=>o.data.name);e.hoveredTreeNode={nodeId:t,descendantNames:n}},setHighlightedColumns(t){e.highlightedColumns=t},setShowDomains(t){e.showDomains=t},setSubFeatureRows(t){e.subFeatureRows=t},setMouseClickPos(t,r){e.mouseClickCol=t,e.mouseClickRow=r},setRowHeight(t){e.rowHeight=t},setColWidth(t){e.colWidth=t},setScrollY(t){e.scrollY=t},setCurrentAlignment(t){e.currentAlignment=t},toggleCollapsed(t){e.collapsed.includes(t)?e.collapsed.remove(t):e.collapsed.push(t)},setShowOnly(t){e.showOnly=t},setData(t){e.data=(0,Z.cast)(t)},setMSAFilehandle(t){e.msaFilehandle=t},setTreeFilehandle(t){e.treeFilehandle=t},setGFFFilehandle(t){e.gffFilehandle=t},setMSA(t){e.data.setMSA(t)},setTree(t){e.data.setTree(t)},setTreeMetadata(t){e.data.setTreeMetadata(t)}})).views(e=>({get hideGapsEffective(){return e.hideGaps&&(e.collapsed.length>0||e.allowedGappyness<100)},get realAllowedGappyness(){return this.hideGapsEffective?e.allowedGappyness:100},get actuallyShowDomains(){return e.showDomains&&!!e.interProAnnotations},get viewInitialized(){return e.volatileWidth!==void 0},get width(){if(e.volatileWidth===void 0)throw new Error("not initialized");return e.volatileWidth}})).views(e=>({extraViewMenuItems(){return[]},get colorScheme(){return ii[e.colorSchemeName]},get header(){return this.MSA?.getHeader()||{}},get alignmentNames(){return this.MSA?.alignmentNames||[]},get noTree(){return!!this.tree.noTree},get noDomains(){return!e.interProAnnotations},menuItems(){return[]},get treeMetadata(){return e.data.treeMetadata?JSON.parse(e.data.treeMetadata):{}},get MSA(){let t=e.data.msa;return t?Vf(t,e.currentAlignment):null},get numColumns(){return(this.MSA?.getWidth()||0)-this.blanks.length},get tree(){let t=e.data.tree;return t?mi(t.startsWith("BioTreeContainer")?Tw(Yw(t)):no(t.startsWith("SEQ")?Uc(t).tree:t)):this.MSA?.getTree()||{noTree:!0,children:[],id:"empty",name:"empty"}},get rowNames(){return this.leaves.map(t=>t.data.name)},get mouseOverRowName(){let{mouseRow:t}=e;return t===void 0?void 0:this.rowNames[t]},get hoveredInsertion(){let{mouseCol:t,mouseRow:r}=e;if(t===void 0||r===void 0)return;let n=this.rowNames[r];if(!n)return;let o=this.insertionPositions.get(n);if(!o)return;let i=o.find(s=>s.pos===t);if(i)return{rowName:n,col:t,letters:i.letters}},get root(){let t=rb(this.tree,r=>r.children);if(nb(t,r=>r.children.length>0?0:1),ob(t,(r,n)=>(r.data.length??1)-(n.data.length??1)),e.showOnly){let r=hs(t,n=>n.data.id===e.showOnly);r&&(t=r)}for(let r of e.collapsed){let n=hs(t,o=>o.data.id===r);n&&(n.children?ab(n):n.parent?.children&&(n.parent.children=n.parent.children.filter(o=>o.data.id!==r)))}return t},get msaAreaWidth(){return e.width-e.treeAreaWidth},get treeAreaWidthMinusMargin(){return e.treeAreaWidth-e.marginLeft},get blanks(){let{hideGapsEffective:t,realAllowedGappyness:r}=e;if(!t)return[];let n=this.leaves.map(l=>this.MSA?.getRow(l.data.name)).filter(je.notEmpty);if(n.length===0)return[];let o=n[0].length,i=n.length,s=Math.ceil(r/100*i),a=new Uint16Array(o);for(let l=0;l<i;l++){let A=n[l];for(let u=0;u<o;u++)A.charCodeAt(u)-45>>>0<=1&&a[u]++}let c=[];for(let l=0;l<o;l++)a[l]>=s&&c.push(l);return c},get blanksSet(){return new Set(this.blanks)},get insertionPositions(){let{hideGapsEffective:t}=e,{blanks:r,rows:n}=this,o=r.length;if(o===0||!t)return new Map;let i=new Map;for(let[s,a]of n){let c=[],l=0,A=0,u=-1,m=[],d=a.length;for(let p=0;p<d;p++)A<o&&r[A]===p?(a.charCodeAt(p)-45>>>0<=1||(u===l?m.push(a[p]):(m.length>0&&c.push({pos:u,letters:m.join("")}),u=l,m=[a[p]])),A++):l++;m.length>0&&c.push({pos:u,letters:m.join("")}),c.length>0&&i.set(s,c)}return i},get rows(){let t=this.MSA;return this.leaves.map(r=>[r.data.name,t?.getRow(r.data.name)]).filter(r=>!!r[1])},get numRows(){return this.rows.length},get rowMap(){return new Map(this.rows)},get columns(){return Object.fromEntries(this.rows.map((t,r)=>[t[0],this.columns2d[r]]))},get columns2d(){let{hideGapsEffective:t}=e;return this.rows.map(r=>r[1]).map(r=>t?Hu(this.blanks,r):r)},get fontSize(){return Math.min(Math.max(6,e.rowHeight-3),18)},get colStats(){let t=[],r=this.columns2d;for(let n of r)for(let o=0;o<n.length;o++){let i=t[o]??={},s=n[o];i[s]=(i[s]??0)+1}return t},get colStatsSums(){return this.colStats.map(t=>(0,je.sum)(Object.values(t)))},get sequenceType(){let t=new Set;for(let s of this.colStats)for(let a of Object.keys(s)){let c=a.toUpperCase();c!=="-"&&c!=="."&&t.add(c)}let r=new Set(["A","C","G","T","N"]),n=new Set(["A","C","G","U","N"]),o=[...t].every(s=>r.has(s)),i=[...t].every(s=>n.has(s));return o&&!t.has("U")?"dna":i&&!t.has("T")?"rna":"amino"},get colConsensus(){let{colStats:t,colStatsSums:r}=this;return t.map((n,o)=>{let i=r[o],s=0,a="";for(let l in n){let A=n[l];A>s&&l!=="-"&&l!=="."&&(s=A,a=l)}let c=s/i;return{letter:a,color:c>.4?`hsl(240, 30%, ${100*Math.max(1-c/3,.3)}%)`:void 0}})},get colClustalX(){let{colStats:t,colStatsSums:r}=this;return t.map((n,o)=>Iw(n,r[o]))},get conservation(){let{colStats:t,colStatsSums:r,sequenceType:n}=this,i=Math.log2(n==="amino"?20:4);return t.map((s,a)=>{let c=r[a];if(!c)return 0;let l=(s["-"]||0)+(s["."]||0),A=c-l;if(A===0)return 0;let u={};for(let E of Object.keys(s)){if(E==="-"||E===".")continue;let x=E.toUpperCase();u[x]=(u[x]||0)+s[E]}let m=0;for(let E of Object.keys(u)){let x=u[E]/A;x>0&&(m-=x*Math.log2(x))}let d=l/c;return Math.max(0,1-m/i)*(1-d)})},get hierarchy(){let t=this.root;return sb(t,this.totalHeight,e.treeWidth),t.data.length=0,Mf(t,0,e.treeWidth/Qf(t)),t},get totalHeight(){return Cs(this.root).length*e.rowHeight},get leaves(){return Cs(this.hierarchy)},get maxBranchLength(){return Sf(this.hierarchy)},get maxDepthToLeaf(){return Es(this.hierarchy)},get allBranchesLength0(){return _c(this.hierarchy).every(t=>!t.source.data.length)},get showBranchLenEffective(){return this.allBranchesLength0?!1:e.showBranchLen}})).views(e=>({get totalWidth(){return e.numColumns*e.colWidth}})).views(e=>({get dataInitialized(){return(e.data.msa||e.data.tree)&&!e.error},get blocksX(){return dw({viewportWidth:e.msaAreaWidth,viewportX:-e.scrollX,blockSize:e.blockSize,mapWidth:e.totalWidth})},get blocksY(){return mw({viewportHeight:e.height,viewportY:-e.scrollY,blockSize:e.blockSize,mapHeight:e.totalHeight})}})).views(e=>({get blocks2d(){return e.blocksY.flatMap(t=>e.blocksX.map(r=>[r,t]))},get isLoading(){return e.loadingMSA||e.loadingTree},get maxScrollX(){return Math.min(-e.totalWidth+(e.msaAreaWidth-100),0)},get showMsaLetters(){return e.drawMsaLetters&&e.rowHeight>=5&&e.colWidth>e.rowHeight/2},get showTreeText(){return e.drawLabels&&e.rowHeight>=5}})).actions(e=>({setDrawMsaLetters(t){e.drawMsaLetters=t},calculateNeighborJoiningTreeFromMSA(){if(e.rows.length<2)throw new Error("Need at least 2 sequences to build a tree");let t=Jw(e.rows);e.setTree(t)},resetZoom(){e.setColWidth(12),e.setRowHeight(16)},zoomOutHorizontal(){e.colWidth=Math.max(1,Math.floor(e.colWidth*.75)),e.scrollX=(0,je.clamp)(e.scrollX,e.maxScrollX,0)},zoomInHorizontal(){e.colWidth=Math.ceil(e.colWidth*1.5),e.scrollX=(0,je.clamp)(e.scrollX,e.maxScrollX,0)},zoomInVertical(){e.rowHeight=Math.ceil(e.rowHeight*1.5)},zoomOutVertical(){e.rowHeight=Math.max(1.5,Math.floor(e.rowHeight*.75))},zoomIn(){(0,Pt.transaction)(()=>{e.colWidth=Math.ceil(e.colWidth*1.5),e.rowHeight=Math.ceil(e.rowHeight*1.5),e.scrollX=(0,je.clamp)(e.scrollX,e.maxScrollX,0)})},zoomOut(){(0,Pt.transaction)(()=>{e.colWidth=Math.max(1,Math.floor(e.colWidth*.75)),e.rowHeight=Math.max(1.5,Math.floor(e.rowHeight*.75)),e.scrollX=(0,je.clamp)(e.scrollX,e.maxScrollX,0)})},doScrollY(t){e.scrollY=(0,je.clamp)(e.scrollY+t,-e.totalHeight+10,0)},setInterProAnnotations(t){e.interProAnnotations=t},applyGFFText(t){let r=Hc(t),n=jc(r);e.interProAnnotations=n,e.setShowDomains(!0)},doScrollX(t){this.setScrollX(e.scrollX+t)},setScrollX(t){e.scrollX=(0,je.clamp)(t,e.maxScrollX,0)},toggleTrack(t){e.turnedOffTracks.has(t)?e.turnedOffTracks.delete(t):e.turnedOffTracks.set(t,!0)},setStatus(t){e.status=t}})).views(e=>({get labelsWidth(){let{rowHeight:t,leaves:r,treeMetadata:n,fontSize:o}=e;return t<=5?0:r.reduce((i,s)=>Math.max(i,kw(n[s.data.name]?.genome||s.data.name,o)),0)},get secondaryStructureConsensus(){return e.MSA?.secondaryStructureConsensus},get seqConsensus(){return e.MSA?.seqConsensus},get adapterTrackModels(){let{rowHeight:t,MSA:r,hideGapsEffective:n,blanks:o}=e;return(r?.tracks??[]).filter(s=>!!s.data).map(s=>({model:{...s,data:n&&s.data?Hu(o,s.data):s.data,height:t},ReactComponent:Sw}))},get tracks(){let t={model:{id:"conservation",name:"Conservation",height:e.conservationTrackHeight},ReactComponent:ww};return[...this.adapterTrackModels,t]},get turnedOnTracks(){return this.tracks.filter(t=>!e.turnedOffTracks.has(t.model.id))},get showHorizontalScrollbar(){return e.msaAreaWidth<e.totalWidth},get rowNamesSet(){return new Map(e.rowNames.map((t,r)=>[t,r]))},visibleColToRowLetter(t,r){let{rowMap:n,blanks:o}=e;return n.get(t)?.[lm(o,r)]},visibleColToSeqPos(t,r){return $w({rowName:t,visibleCol:r,rowMap:e.rowMap,blanks:e.blanks})},visibleColToSeqPosOneBased(t,r){let n=this.visibleColToSeqPos(t,r);return n!==void 0?n+1:void 0},globalColToVisibleCol(t){let{blanks:r,hideGapsEffective:n}=e;return n?zw(r,t):t},seqPosToGlobalCol(t,r){let{rows:n}=e,o=this.rowNamesSet.get(t);return o!==void 0&&n[o]?Xw({row:n[o][1],seqPos:r}):0},seqPosToVisibleCol(t,r){let n=this.seqPosToGlobalCol(t,r);return this.globalColToVisibleCol(n)}})).views(e=>({get hoveredCell(){let{mouseCol:t,mouseRow:r}=e;if(t===void 0||r===void 0)return;let n=e.rowNames[r];if(!n)return;let i=e.columns[n]?.[t],s=e.visibleColToSeqPosOneBased(n,t);return{rowName:n,col:t,base:i,seqPos:s}},get msaAreaHeight(){return e.height-(e.showHorizontalScrollbar?e.minimapHeight:0)-e.headerHeight},get totalTrackAreaHeight(){return(0,je.sum)(e.turnedOnTracks.map(t=>t.model.height))},get tidyInterProAnnotationTypes(){return new Map(this.tidyInterProAnnotations.map(t=>[t.accession,t]))},get tidyInterProAnnotations(){let{interProAnnotations:t}=e;return t?Object.entries(t).flatMap(([r,n])=>n.matches.flatMap(({signature:o,locations:i})=>o.entry?i.map(({start:s,end:a})=>({id:r,name:o.entry.name,accession:o.entry.accession,description:o.entry.description,start:s,end:a})):[])).toSorted((r,n)=>ju(n)-ju(r)):[]},get tidyFilteredInterProAnnotations(){return this.tidyInterProAnnotations.filter(t=>e.featureFilters.get(t.accession))},get tidyFilteredGatheredInterProAnnotations(){return(0,je.groupBy)(this.tidyFilteredInterProAnnotations,t=>t.id)}})).views(e=>({get showVerticalScrollbar(){return e.msaAreaHeight<e.totalHeight}})).views(e=>({get verticalScrollbarWidth(){return e.showVerticalScrollbar?20:0},get fillPalette(){return Mw([...e.tidyInterProAnnotationTypes.keys()])},get strokePalette(){return Object.fromEntries(Object.entries(this.fillPalette).map(([t,r])=>[t,bt(r).darken(.1).toHex()]))},getRowData(t){return{data:e.MSA?.getRowData(t),treeMetadata:e.treeMetadata[t]}}})).actions(e=>({setHeaderHeight(t){e.headerHeight=t},setConservationTrackHeight(t){e.conservationTrackHeight=t},reset(){e.setData({tree:"",msa:""}),e.resetZoom(),e.setError(void 0),e.setScrollY(0),e.setScrollX(0),e.setCurrentAlignment(0),e.setTreeFilehandle(void 0),e.setMSAFilehandle(void 0),e.setGFFFilehandle(void 0),e.setInterProAnnotations({}),e.setShowDomains(!1)},async exportSVG(t){let{renderToSvg:r}=await Promise.resolve().then(()=>(mB(),fB)),n=await r(e,t),o=new Blob([n],{type:"image/svg+xml"});eB(o,"image.svg")},incrementRef(){e.nref++},initFilter(t){e.featureFilters.has(t)||e.featureFilters.set(t,!0)},setFilter(t,r){e.featureFilters.set(t,r)},fit(){e.rowHeight=e.msaAreaHeight/e.numRows,e.colWidth=e.msaAreaWidth/e.numColumns,e.scrollX=0,e.scrollY=0},fitVertically(){e.rowHeight=e.msaAreaHeight/e.numRows,e.scrollY=0},fitHorizontally(){e.colWidth=e.msaAreaWidth/e.numColumns,e.scrollX=0},afterCreate(){(0,Z.addDisposer)(e,(0,Pt.autorun)(()=>{for(let t of e.tidyInterProAnnotationTypes.keys())this.initFilter(t)})),(0,Z.addDisposer)(e,(0,Pt.autorun)(async()=>{let{treeFilehandle:t}=e;if(t)try{e.setLoadingTree(!0),e.setTree(await(0,je.fetchAndMaybeUnzipText)((0,bs.openLocation)(t))),t.locationType==="BlobLocation"&&e.setTreeFilehandle(void 0)}catch(r){console.error(r),e.setError(r)}finally{e.setLoadingTree(!1)}})),(0,Z.addDisposer)(e,(0,Pt.autorun)(async()=>{let{treeMetadataFilehandle:t}=e;if(t)try{e.setTreeMetadata(await(0,je.fetchAndMaybeUnzipText)((0,bs.openLocation)(t)))}catch(r){console.error(r),e.setError(r)}})),(0,Z.addDisposer)(e,(0,Pt.autorun)(()=>{let t=e.data.gff;if(t)try{e.applyGFFText(t)}catch(r){console.error(r),e.setError(r)}})),(0,Z.addDisposer)(e,(0,Pt.autorun)(async()=>{let{gffFilehandle:t}=e;if(t)try{let r=await(0,je.fetchAndMaybeUnzipText)((0,bs.openLocation)(t));e.applyGFFText(r),t.locationType==="BlobLocation"&&e.setGFFFilehandle(void 0)}catch(r){console.error(r),e.setError(r)}})),(0,Z.addDisposer)(e,(0,Pt.autorun)(async()=>{let{msaFilehandle:t}=e;if(t)try{e.setLoadingMSA(!0),e.setError(void 0);let r=await(0,je.fetchAndMaybeUnzipText)((0,bs.openLocation)(t));(0,Pt.transaction)(()=>{e.setMSA(r),t.locationType==="BlobLocation"&&e.setMSAFilehandle(void 0)})}catch(r){console.error(r),e.setError(r)}finally{e.setLoadingMSA(!1)}})),(0,Z.addDisposer)(e,(0,Pt.autorun)(()=>{e.colorSchemeName.includes("dynamic")&&(e.colStats,e.colStatsSums),e.columns})),(0,Z.addDisposer)(e,(0,Pt.autorun)(()=>{e.setTreeWidth(Math.max(50,e.treeAreaWidth-e.labelsWidth-10-e.marginLeft))}))}})).postProcessSnapshot(e=>{let t=e,{data:{tree:r,msa:n,treeMetadata:o},showDomains:i,hideGaps:s,allowedGappyness:a,subFeatureRows:c,drawMsaLetters:l,height:A,rowHeight:u,scrollY:m,scrollX:d,colWidth:p,currentAlignment:E,collapsed:x,showOnly:I,turnedOffTracks:h,featureFilters:y,relativeTo:Q,bgColor:M,colorSchemeName:B,drawLabels:v,labelsAlignRight:P,treeAreaWidth:N,treeWidth:$,showBranchLen:S,drawTree:L,drawNodeBubbles:J,...O}=t,Tt=Object.fromEntries(Object.entries({showDomains:!1,hideGaps:!0,allowedGappyness:100,subFeatureRows:!1,drawMsaLetters:!0,height:550,rowHeight:16,scrollY:0,scrollX:0,colWidth:12,currentAlignment:0,bgColor:!0,colorSchemeName:Jc,drawLabels:!0,labelsAlignRight:!1,treeAreaWidth:400,treeWidth:300,showBranchLen:!0,drawTree:!0,drawNodeBubbles:!0}).filter(([Ut,Qn])=>t[Ut]!==Qn).map(([Ut])=>[Ut,t[Ut]]));return{...O,data:{...e.treeFilehandle?{}:{tree:r},...e.msaFilehandle?{}:{msa:n},...e.treeMetadataFilehandle?{}:{treeMetadata:o}},...Tt,...x?.length?{collapsed:x}:{},...I!==void 0?{showOnly:I}:{},...h&&Object.keys(h).length>0?{turnedOffTracks:h}:{},...y&&Object.keys(y).length>0?{featureFilters:y}:{},...Q!==void 0?{relativeTo:Q}:{}}})}var je,bs,so,Z,Pt,Wc,gm=g(()=>{je=f(Ce(),1),bs=f(qb(),1),so=f(Vb(),1),Z=f(_t(),1);rc();Pt=f(Gr(),1);fw();gw();xw();ic();Bw();Qw();Vc();vw();_w();vf();Dw();Lw();Pw();Uw();jw();Vw();Ww();Kw();Zw();Yn();tB();Wc=AD});var pm,uD,fD,bB=g(()=>{pm=f(w(),1),uD=f(Hb(),1),fD=f(CA(),1);gm();Lf()});var hm=g(()=>{Lf();bB();gm()});function vD(e){let t=e;return t.type==="ProteinView"&&Array.isArray(t.structures)}function bn(e){return e.filter(vD)}function il(e,t){if(t<0||t>=e.length)return;let r=0;for(let n=0;n<t;n++)e[n]!=="-"&&r++;if(e[t]!=="-")return r}var Qs=g(()=>{"use strict"});var cS={};Ye(cS,{default:()=>RD});var le,al,iS,ye,sS,aS,LD,FD,RD,lS=g(()=>{"use strict";le=f(w()),al=f(we()),iS=f(Ce()),ye=f(k()),sS=f(G()),aS=f(Se());Qs();LD=(0,aS.makeStyles)()(e=>({formControl:{marginBottom:e.spacing(2)}})),FD=(0,sS.observer)(function({model:t,handleClose:r}){let{classes:n}=LD(),o=(0,iS.getSession)(t),[i,s]=(0,le.useState)(""),[a,c]=(0,le.useState)(0),[l,A]=(0,le.useState)(t.querySeqName),[u,m]=(0,le.useState)(),d=bn(o.views),E=d.find(h=>h.id===i)?.structures??[],x=t.rows.map(h=>h[0]),I=()=>{if(!i){m("Please select a protein view");return}try{t.connectToStructure(i,a,l),r()}catch(h){m(h instanceof Error?h.message:String(h))}};return le.default.createElement(al.Dialog,{maxWidth:"sm",title:"Connect to Protein Structure",open:!0,onClose:r},le.default.createElement(ye.DialogContent,null,d.length===0?le.default.createElement(ye.Typography,{color:"textSecondary"},"No protein views are currently open. Please open a protein structure view first."):le.default.createElement(le.default.Fragment,null,le.default.createElement(ye.FormControl,{fullWidth:!0,className:n.formControl},le.default.createElement(ye.InputLabel,null,"Protein View"),le.default.createElement(ye.Select,{value:i,label:"Protein View",onChange:h=>{s(h.target.value),c(0)}},d.map(h=>le.default.createElement(ye.MenuItem,{key:h.id,value:h.id},h.displayName??`ProteinView ${h.id}`)))),E.length>1?le.default.createElement(ye.FormControl,{fullWidth:!0,className:n.formControl},le.default.createElement(ye.InputLabel,null,"Structure"),le.default.createElement(ye.Select,{value:a,label:"Structure",onChange:h=>{c(h.target.value)}},E.map((h,y)=>le.default.createElement(ye.MenuItem,{key:y,value:y},h.url??`Structure ${y+1}`)))):null,le.default.createElement(ye.FormControl,{fullWidth:!0,className:n.formControl},le.default.createElement(ye.InputLabel,null,"MSA Row"),le.default.createElement(ye.Select,{value:l,label:"MSA Row",onChange:h=>{A(h.target.value)}},x.map(h=>le.default.createElement(ye.MenuItem,{key:h,value:h},h)))),u?le.default.createElement(al.ErrorMessage,{error:u}):null)),le.default.createElement(ye.DialogActions,null,le.default.createElement(ye.Button,{onClick:r},"Cancel"),le.default.createElement(ye.Button,{onClick:I,variant:"contained",disabled:d.length===0||!i},"Connect")))}),RD=FD});var xS=U((sj,IS)=>{IS.exports=JBrowseExports["@jbrowse/core/data_adapters/BaseAdapter"]});var wS={};Ye(wS,{default:()=>cl});var yS,bS,cl,BS=g(()=>{"use strict";yS=f(Eo()),bS=f(xS());Y0();cl=class extends bS.BaseAdapter{async configurePre(){let t=this.getSubAdapter;if(t)return(await t({...(0,yS.readConfObject)(this.config),type:"BgzipFastaAdapter"})).dataAdapter;throw new Error("no get subadapter")}configure(){return this.configureP??=this.configurePre().catch(t=>{throw this.configureP=void 0,t}),this.configureP}async getMSARefs(){return this.refNamesP??=this.configure().then(t=>t.getRefNames()).catch(t=>{throw this.refNamesP=void 0,t}),this.refNamesP}getMsaRegex(){return new RegExp(this.getConf("msaRegex"))}refNameToMsaId(t){return t.split(this.getMsaRegex())[0]}async getMSAList(){let t=await this.getMSARefs();return[...new Set(t.map(n=>this.refNameToMsaId(n)))]}async getMSA(t){let r=await this.configure(),o=(await r.getRefNames()).filter(i=>this.refNameToMsaId(i)===t);return lu(r.getFeaturesInMultipleRegions(o.map(i=>({refName:i,start:0,end:1e9,assemblyName:""}))).pipe(Au()))}}});var OS=U(PS=>{"use strict";var xi=w();function KD(e,t){return e===t&&(e!==0||1/e===1/t)||e!==e&&t!==t}var XD=typeof Object.is=="function"?Object.is:KD,ZD=xi.useState,eN=xi.useEffect,tN=xi.useLayoutEffect,rN=xi.useDebugValue;function nN(e,t){var r=t(),n=ZD({inst:{value:r,getSnapshot:t}}),o=n[0].inst,i=n[1];return tN(function(){o.value=r,o.getSnapshot=t,Dm(o)&&i({inst:o})},[e,r,t]),eN(function(){return Dm(o)&&i({inst:o}),e(function(){Dm(o)&&i({inst:o})})},[e]),rN(r),r}function Dm(e){var t=e.getSnapshot;e=e.value;try{var r=t();return!XD(e,r)}catch{return!0}}function oN(e,t){return t()}var iN=typeof window>"u"||typeof window.document>"u"||typeof window.document.createElement>"u"?oN:nN;PS.useSyncExternalStore=xi.useSyncExternalStore!==void 0?xi.useSyncExternalStore:iN});var US=U((bj,GS)=>{"use strict";GS.exports=OS()});function uo(e){let{children:t,...r}=e;return Xm.default.createElement(M1.Link,{...r,target:"_blank",rel:"noreferrer"},t," ",Xm.default.createElement(Ma,{fontSize:"small"}))}var Xm,M1,Sl=g(()=>{"use strict";Xm=f(w());NA();M1=f(k())});var tQ=U((UJ,eQ)=>{eQ.exports=JBrowseExports["@jbrowse/core/pluggableElementTypes/ViewType"]});var Fs,rQ,_l,nQ=g(()=>{"use strict";Fs=f(w()),rQ=f(we()),_l=class extends Fs.Component{constructor(t){super(t),this.state={hasError:!1,error:null}}static getDerivedStateFromError(t){return{hasError:!0,error:t}}componentDidCatch(t,r){console.error("MsaViewPanel error:",t,r.componentStack)}render(){return this.state.hasError?Fs.default.createElement("div",{style:{padding:20}},Fs.default.createElement(rQ.ErrorMessage,{error:this.state.error})):this.props.children}}});function qN({baseUrl:e,rid:t}){return ad.default.createElement(oQ.Typography,null,"RID ",t," (",ad.default.createElement(uo,{href:`${e}?CMD=Get&RID=${t}`},"see status"),")")}var ad,oQ,cd,iQ=g(()=>{"use strict";ad=f(w()),oQ=f(k());Sl();cd=qN});function JN({baseUrl:e,rid:t,error:r}){return er.default.createElement("div",null,t?er.default.createElement(cd,{rid:t,baseUrl:e}):null,er.default.createElement(kl.ErrorMessage,{error:r}))}function VN({baseUrl:e,rid:t,progress:r}){let{classes:n}=cQ();return er.default.createElement("div",{className:n.loading},t?er.default.createElement(cd,{baseUrl:e,rid:t}):null,er.default.createElement(ld.Typography,null,r))}var er,kl,ld,sQ,aQ,cQ,YN,lQ,AQ=g(()=>{"use strict";er=f(w()),kl=f(we()),ld=f(k()),sQ=f(G()),aQ=f(Se());iQ();cQ=(0,aQ.makeStyles)()(e=>({margin:{padding:20},loading:{background:e.palette.background.paper}}));YN=(0,sQ.observer)(function({model:t,baseUrl:r}){let{progress:n,rid:o,error:i}=t,{classes:s}=cQ();return er.default.createElement("div",{className:s.margin},er.default.createElement(kl.LoadingEllipses,{message:"Running NCBI BLAST",variant:"h5"}),i?er.default.createElement(JN,{baseUrl:r,rid:o,error:i}):o?er.default.createElement(VN,{baseUrl:r,rid:o,progress:n}):er.default.createElement(ld.Typography,null,n||"Initializing BLAST query"))}),lQ=YN});var dQ={};Ye(dQ,{default:()=>$N});var fo,uQ,fQ,mQ,WN,zN,$N,gQ=g(()=>{"use strict";fo=f(w()),uQ=f(we()),fQ=f(G());hm();mQ=f(Se());nQ();AQ();WN=(0,mQ.makeStyles)()({loadingContainer:{padding:20}}),zN=(0,fQ.observer)(function({model:t}){let{classes:r}=WN(),{blastParams:n,loadingStoredData:o}=t;return fo.default.createElement(_l,null,fo.default.createElement("div",null,n?fo.default.createElement(lQ,{model:t,baseUrl:n.baseUrl}):o?fo.default.createElement("div",{className:r.loadingContainer},fo.default.createElement(uQ.LoadingEllipses,{message:"Loading MSA data",variant:"h6"})):fo.default.createElement(Oc,{model:t})))}),$N=zN});var XN={};Ye(XN,{default:()=>Dl});var EQ=f(Md()),ud=f(Eo()),IQ=f(Ce()),fd=f(_t());W();var Ld=f(R(),1),Fd=(0,_.createSvgIcon)((0,Ld.jsx)("path",{d:"M20 2H4c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V4c0-1.1-.9-2-2-2M8 20H4v-4h4zm0-6H4v-4h4zm0-6H4V4h4zm6 12h-4v-4h4zm0-6h-4v-4h4zm0-6h-4V4h4zm6 12h-4v-4h4zm0-6h-4v-4h4zm0-6h-4V4h4z"}),"GridOn");var hS=f(w()),CS=f(Ce());var vs=f(w()),gS=f(G());var bm=f(w()),fS=f(Ce()),wm=f(G());var Ud=f(Se());function Dn(e){return!!e&&typeof e=="object"&&"hoverPosition"in e&&!!e.hoverPosition}function Ys({assemblyManager:e,assemblyNames:t,refName:r}){let n=t?.[0];return n?e.get(n)?.getCanonicalRefName(r)??r:r}function Gd(e){return/AF-([A-Z0-9]+)-F\d+/.exec(e)?.[1]}var Ws=(0,Ud.makeStyles)()({highlight:{height:"100%",background:"rgba(255,255,0,0.2)",border:"1px solid rgba(50,50,0,0.2)",position:"absolute",zIndex:99,textAlign:"center",pointerEvents:"none",overflow:"hidden"}});var AS=f(w()),uS=f(Ul()),Ci=f(Ce()),Ze=f(_t());function jd(e){let t=e.strand,r=e.refName;if(t!==-1&&t!==1)throw new Error(`Invalid strand value: ${t}. Expected 1 or -1.`);if(!r)throw new Error("refName is required");let n=new Map;for(let c of e.subfeatures??[])if(c.type==="CDS"&&c.start<c.end){let l=`${c.start}-${c.end}`;n.has(l)||n.set(l,c)}let o=[...n.values()].sort((c,l)=>t*(c.start-l.start)),i={},s={},a={};if(o.length!==0){let l=(3-(o[0]?.phase??0))%3,A=-1;for(let u of o){let m=u.end-u.start;for(let d=0;d<m;d++){let p=t===1?u.start+d:u.end-1-d,E=Math.floor(l++/3);i[p]=E,E!==A?(s[E]=p,a[E]=[p],A=E):a[E].push(p)}}}return{g2p:i,p2g:s,p2gCodon:a,refName:r,strand:t}}var xm=f(Gr());hm();var Im=f(Ce());function wB(e,t){let r=e.sciname.replaceAll(" ","_");if(e.taxid&&t?.has(e.taxid)){let n=t.get(e.taxid);n.commonName&&(r=n.commonName.split(" ").map(o=>o.charAt(0).toUpperCase()+o.slice(1).toLowerCase()).join("_"))}return`${e.accession}-${r}`}function BB(e){return e.replaceAll("-","")}var $c=f(Ce());function $t(e){return(0,$c.getContainingView)(e)}function SB(e){return[...new Set(e.filter(t=>!!t))]}function QB(e,t){return t.filter(r=>!!r).join(e)}function mD(e){let r=(e.get("subfeatures")??[]).filter(n=>(n.get("type")==="mRNA"||n.get("type")==="transcript")&&n.get("subfeatures")?.some(o=>o.get("type")==="CDS"));return r.length>0?r:[e]}function zc(e){let t=(0,$c.sum)(e.get("subfeatures")?.filter(r=>r.get("type")==="CDS").map(r=>r.get("end")-r.get("start"))??[]);return{len:Math.floor(t/3),mod:t%3}}function ao(e){return e?.id()??""}function dD(e){return e?SB([e.id(),e.get("name"),e.get("id"),e.get("transcript_id")]):[]}function ws(e,t){return dD(e).includes(t)}function Kc(e){return e?QB(" ",[e.get("name"),e.get("id")]):""}function co(e){return e?QB(" ",[e.get("gene_name")??e.get("name"),e.get("id")?`(${e.get("id")})`:void 0]):""}function Xc(e,t){return`BLAST - ${co(e)} - ${Kc(t)}`}function MB(e){return mD(e).toSorted((r,n)=>zc(n).len-zc(r).len)}function Zc(e){return e.replaceAll("*","").replaceAll("&","")}function el(e){return SB([e.id(),e.get("id"),e.get("name"),e.get("gene_id"),e.get("gene_name")])}Wi();var gD="jbrowse-msaview-blast-cache",xn="blast-results",pD=2;async function tl(){return jn(gD,pD,{upgrade(e,t){t<2&&e.objectStoreNames.contains(xn)&&e.deleteObjectStore(xn),e.objectStoreNames.contains(xn)||e.createObjectStore(xn,{keyPath:"id"})}})}function hD(e,t,r,n){let o=n?`:${n}`:"";return`${t}:${r}${o}:${e}`}async function vB({proteinSequence:e,blastDatabase:t,blastProgram:r,msaAlgorithm:n,msa:o,tree:i,treeMetadata:s,rid:a,geneId:c,transcriptId:l,transcriptName:A,geneName:u}){let m=await tl(),p={id:hD(e,t,r,l),proteinSequence:e,blastDatabase:t,blastProgram:r,msaAlgorithm:n,msa:o,tree:i,treeMetadata:s,rid:a,timestamp:Date.now(),geneId:c,transcriptId:l,transcriptName:A,geneName:u};return await m.put(xn,p),p}async function TB(){return(await(await tl()).getAll(xn)).toSorted((r,n)=>n.timestamp-r.timestamp)}async function _B(e){await(await tl()).delete(xn,e)}async function kB(){await(await tl()).clear(xn)}async function DB(e,t){let r=await fetch(e,t);if(!r.ok)throw new Error(`HTTP ${r.status} fetching ${e} ${await r.text()}`);return r}async function yn(e,t){return(await DB(e,t)).text()}async function NB(e,t){return(await DB(e,t)).json()}function rl(e){return new Promise(t=>setTimeout(t,e))}var ol="https://www.ebi.ac.uk/Tools/services/rest",nl="colin.diesh@gmail.com",CD={clustalo:{params:{email:nl},msaResult:"aln-clustal_num",treeResult:"phylotree"},muscle:{params:{email:nl,format:"clw",tree:"tree1"},msaResult:"fa",treeResult:"phylotree"},kalign:{params:{email:nl,stype:"protein"},msaResult:"fa",treeResult:"phylotree"},mafft:{params:{email:nl,stype:"protein"},msaResult:"fa",treeResult:"phylotree"}};async function ED({onProgress:e,jobId:t,algorithm:r}){for(;;){let n=await yn(`${ol}/${r}/status/${t}`);if(n==="FINISHED")break;if(n.includes("FAILURE"))throw new Error(`Failed to run: jobId ${t}`);for(let o=0;o<10;o++)e(`Re-checking MSA status in... ${10-o}`),await rl(1e3)}}async function LB({algorithm:e,sequence:t,onProgress:r}){let n=CD[e];r(`Launching ${e} MSA...`);let o=await yn(`${ol}/${e}/run`,{method:"POST",body:new URLSearchParams({...n.params,sequence:t})});return await ED({jobId:o,algorithm:e,onProgress:r}),{msa:await yn(`${ol}/${e}/result/${o}/${n.msaResult}`),tree:await yn(`${ol}/${e}/result/${o}/${n.treeResult}`)}}async function Cm({rid:e,baseUrl:t,onProgress:r}){r(`Checking BLAST status for RID: ${e}...`),await xD({rid:e,onProgress:r,baseUrl:t});let n=await NB(`${t}?CMD=Get&RID=${e}&FORMAT_TYPE=JSON2_S&FORMAT_OBJECT=Alignment`);return{rid:e,hits:n.BlastOutput2[0]?.report.results.search.hits??[]}}async function FB({query:e,blastDatabase:t,blastProgram:r,baseUrl:n,onProgress:o,onRid:i}){o("Submitting to NCBI BLAST...");let{rid:s}=await ID({query:e,blastDatabase:t,blastProgram:r,baseUrl:n});return i(s),Cm({rid:s,baseUrl:n,onProgress:o})}async function ID({query:e,blastProgram:t,blastDatabase:r,baseUrl:n}){let o=await yn(n,{method:"POST",body:new URLSearchParams({CMD:"Put",PROGRAM:t==="quick-blastp"?"blastp":t,DATABASE:r,QUERY:e,...r==="nr_cluster_seq"?{CLUSTERED_DB:"on",DB_TYPE:"Experimental Databases"}:{},...t==="quick-blastp"?{BLAST_PROGRAMS:"kmerBlastp"}:{}})}),i=/^ {4}RID = (.*$)/m.exec(o)?.[1],s=/^ {4}RTOE = (.*$)/m.exec(o)?.[1];if(!i)throw new Error("Failed to get RID from BLAST request");return{rid:i,rtoe:s}}async function xD({rid:e,onProgress:t,baseUrl:r}){for(;;){let n=await yn(`${r}?CMD=Get&FORMAT_OBJECT=SearchInfo&RID=${e}`),i=/\s+Status=(\S+)/m.exec(n)?.[1],s=/\s+ThereAreHits=yes/m.test(n);if(i==="WAITING"){for(let c=0;c<20;c++)t(`Re-checking BLAST status in... ${20-c}`),await rl(1e3);continue}if(i==="FAILED")throw new Error(`BLAST ${e} failed`);if(i==="READY"){if(s)return!0;throw new Error("No hits found")}throw new Error(`BLAST ${e} returned unexpected status: ${i??"unknown"}`)}}Wi();var yD="jbrowse-msaview-taxonomy-cache",Bs="common-names",bD=2;async function RB(){return jn(yD,bD,{upgrade(e){e.objectStoreNames.contains(Bs)&&e.deleteObjectStore(Bs),e.createObjectStore(Bs,{keyPath:"taxid"})}})}async function wD(e){let r=(await RB()).transaction(Bs,"readonly"),n=await Promise.all(e.map(o=>r.store.get(o)));return await r.done,n}async function BD(e){let r=(await RB()).transaction(Bs,"readwrite");for(let n of e)await r.store.put(n);await r.done}async function PB(e){let t=new Map,r=[],n=await wD(e);for(let s=0;s<e.length;s++){let a=e[s],c=n[s];c?t.set(a,{sciname:c.sciname,commonName:c.commonName}):r.push(a)}if(r.length===0)return t;let o=100,i=[];for(let s=0;s<r.length;s+=o){let a=r.slice(s,s+o),c=a.join(",");try{let A=await(await fetch(`https://eutils.ncbi.nlm.nih.gov/entrez/eutils/efetch.fcgi?db=taxonomy&id=${c}&retmode=xml`)).text(),u=new Map,m=/<Taxon>\s*<TaxId>(\d+)<\/TaxId>/g,d;for(;(d=m.exec(A))!==null;){let p=Number(d[1]),E=d.index,x=1,I=E+d[0].length;for(;x>0&&I<A.length;){let B=A.indexOf("<Taxon>",I),v=A.indexOf("</Taxon>",I);if(v===-1)break;B!==-1&&B<v?(x++,I=B+7):(x--,I=v+8)}let h=A.slice(E,I),y=u.get(p),Q=h.includes("<LineageEx>"),M=y?.includes("<LineageEx>");(!y||Q&&!M)&&u.set(p,h)}for(let p of a){let E=u.get(p);if(E){let x=/<GenbankCommonName>(.*?)<\/GenbankCommonName>/.exec(E),I=/<CommonName>(.*?)<\/CommonName>/.exec(E),h=/<ScientificName>(.*?)<\/ScientificName>/.exec(E),y=x?.[1]??I?.[1],Q=h?.[1]??"";t.set(p,{sciname:Q,commonName:y}),i.push({taxid:p,sciname:Q,commonName:y})}}}catch(l){console.error("Failed to fetch taxonomy data:",l)}}return i.length>0&&await BD(i),t}async function OB({self:e}){let{baseUrl:t,blastDatabase:r,blastProgram:n,msaAlgorithm:o,proteinSequence:i,selectedTranscript:s,rid:a}=e.blastParams,c=Zc(i),l,A;if(a){e.setRid(a);let I=await Cm({rid:a,baseUrl:t,onProgress:h=>{e.setProgress(h)}});l=I.hits,A=I.rid}else{let I=await FB({query:c,blastDatabase:r,blastProgram:n,baseUrl:t,onProgress:h=>{e.setProgress(h)},onRid:h=>{e.setRid(h)}});l=I.hits,A=I.rid}e.setProgress("Fetching species taxonomy info...");let u=l.map(I=>I.description[0]?.taxid).filter(I=>I!==void 0),m=await PB(u),d={},p=l.map(I=>{let h=I.description[0]??{accession:"unknown",id:"unknown",sciname:"unknown"},y=wB(h,m),Q=BB(I.hsps[0]?.hseq??"");return d[y]=SD(h,m),`>${y}
70
+ ${Q}`}),E=await LB({algorithm:o,sequence:[`>QUERY
74
71
  ${c}`,...p].join(`
75
- `),onProgress:I=>{e.setProgress(I)}}),y=JSON.stringify(d);return await yp({proteinSequence:c,blastDatabase:r,blastProgram:n,msaAlgorithm:o,msa:C.msa,tree:C.tree,treeMetadata:y,rid:A,geneId:s?.get("parentId"),transcriptId:s?.id(),transcriptName:s?.get("name")??s?.get("id"),geneName:s?.get("gene_name")??s?.get("parentId")}),{...C,treeMetadata:y}}function cN(e,t){let r={},n=e.taxid?t.get(e.taxid):void 0;return n?.sciname&&(r["Scientific name"]=n.sciname),n?.commonName&&(r["Common name"]=n.commonName),e.accession&&(r.Accession=e.accession),e.id&&(r.ID=e.id),e.title&&(r.Description=e.title),r}Bs();function Ss({model:e,coord:t}){let{querySeqName:r,transcriptToMsaMap:n,mafRegion:o}=e,s=e.rows.find(c=>c[0]===r)?.[1];if(!s)return;let a=El(s,t);if(a!==void 0){if(o){let c=o.start+a;return c>=o.end?void 0:{refName:o.refName,start:c,end:c+1}}if(n){let{refName:c,p2g:l}=n,A=l[a],u=l[a+1];return A!==void 0&&u!==void 0?{refName:c,start:Math.min(A,u),end:Math.max(A,u)}:void 0}}}Li();var AN="jbrowse-msaview-data",uN=1,Qs="msa-data";async function Vm(){return Fn(AN,uN,{upgrade(e){e.objectStoreNames.contains(Qs)||e.createObjectStore(Qs,{keyPath:"id"}).createIndex("timestamp","timestamp",{unique:!1})}})}function u1(){return`msa-${Date.now()}-${Math.random().toString(36).slice(2,11)}`}async function f1(e,t){try{let r=await Vm(),n={id:e,msa:t.msa,tree:t.tree,treeMetadata:t.treeMetadata,timestamp:Date.now()};return await r.put(Qs,n),!0}catch(r){return console.warn("Failed to store MSA data:",r),!1}}async function m1(e){try{let r=await(await Vm()).get(Qs,e);return r?{msa:r.msa,tree:r.tree,treeMetadata:r.treeMetadata}:void 0}catch(t){console.warn("Failed to retrieve MSA data:",t);return}}async function d1(e=10080*60*1e3){try{let t=await Vm(),r=Date.now()-e,i=await t.transaction(Qs,"readwrite").store.index("timestamp").openCursor(IDBKeyRange.upperBound(r)),s=0;for(;i;)await i.delete(),s++,i=await i.continue();return s}catch(t){return console.warn("Failed to cleanup old MSA data:",t),0}}Bs();function g1(e){let{dataStoreId:t,rows:r}=e;t&&r.length===0&&(async()=>{try{e.setLoadingStoredData(!0);let n=await m1(t);n&&(n.msa&&e.setMSA(n.msa),n.tree&&e.setTree(n.tree))}catch(n){console.error("Failed to load MSA data from IndexedDB:",n)}finally{e.setLoadingStoredData(!1)}})()}function p1(e){let{rows:t,dataStoreId:r,isStoringData:n}=e;if(t.length>0&&!r&&!n){if(e.msaFilehandle||e.treeFilehandle)return;let o=e.data.msa,i=e.data.tree;(o||i)&&(e.setIsStoringData(!0),(async()=>{try{let s=u1();await f1(s,{msa:o,tree:i,treeMetadata:e.data.treeMetadata})&&e.setDataStoreId(s)}catch(s){console.error("Failed to store MSA data to IndexedDB:",s)}finally{e.setIsStoringData(!1)}})())}}function h1(e){e.blastParams&&(async()=>{try{e.setProgress("Submitting query"),e.setError(void 0);let t=await l1({self:e});e.setData(t),e.setBlastParams(void 0)}catch(t){e.setError(t),console.error(t)}finally{e.setProgress("")}})()}function C1(e){let{init:t}=e;t&&(async()=>{try{e.setError(void 0);let{msaData:r,msaUrl:n,treeData:o,treeUrl:i,querySeqName:s}=t;if(n){let a=kd(n);a&&(e.setUniprotId(a),e.setQuerySeqName("query"))}if(s&&e.setQuerySeqName(s),r)e.setMSA(r);else if(n){let a=await fetch(n);if(!a.ok)throw new Error(`Failed to fetch MSA: ${a.status}`);let c=await a.text();e.setMSA(c)}if(o)e.setTree(o);else if(i){let a=await fetch(i);if(!a.ok)throw new Error(`Failed to fetch tree: ${a.status}`);let c=await a.text();e.setTree(c)}e.setInit(void 0)}catch(r){e.setError(r),console.error(r)}})()}function E1(e){let{mouseCol:t,mouseClickCol:r}=e,n=t===void 0?void 0:Ss({model:e,coord:t}),o=r===void 0?void 0:Ss({model:e,coord:r});e.setConnectedHighlights([n,o].filter(i=>!!i))}function I1(e){let{mouseCol:t,connectedProteinViews:r}=e;if(r.length!==0)for(let n of r){let o=n.proteinView.structures[n.structureIdx];if(!o)continue;if(t===void 0){o.clearHighlightFromExternal?.();continue}let i=e.getSequenceByRowName(n.msaRowName);if(!i)continue;let s=El(i,t);if(s===void 0){o.clearHighlightFromExternal?.();continue}let a=n.msaToStructure[s];a===void 0?o.clearHighlightFromExternal?.():o.highlightFromExternal?.(a)}}function x1(e){let{connectedViewId:t,uniprotId:r,rows:n,connectedStructures:o}=e;if(!(!r||n.length===0))for(let i of Bn((0,Ym.getSession)(e).views))for(let s=0;s<i.structures.length;s++){let a=i.structures[s];if(!(!a||a.connectedViewId!==t||a.uniprotId!==r||o.some(l=>l.proteinViewId===i.id&&l.structureIdx===s))&&a.structureSequences?.[0])try{e.connectToStructure(i.id,s)}catch(l){console.error("Failed to auto-connect to ProteinView:",l)}}}function y1(e){let{connectedViewId:t,transcriptToMsaMap:r,querySeqName:n}=e;if(!t||!r)return;let o=new Set;for(let s of Bn((0,Ym.getSession)(e).views))for(let a of s.structures){if(a.connectedViewId!==t)continue;let c=a.hoverGenomeHighlights;if(!c||c.length===0)continue;let{g2p:l}=r;for(let A of c)for(let u=A.start;u<A.end;u++){let m=l[u];if(m!==void 0){let d=e.seqPosToGlobalCol(n,m);o.add(d)}}}let i=Array.from(o).map(s=>e.globalColToVisibleCol(s)).filter(s=>s!==void 0);e.setHighlightedColumns(i.length>0?i:void 0)}function w1(){d1().catch(e=>{console.error("Failed to cleanup old MSA data:",e)})}var b1=f(ge());function B1({model:e}){let{hovered:t}=(0,b1.getSession)(e),{querySeqName:r,transcriptToMsaMap:n,connectedView:o,mafRegion:i}=e;if(!o?.initialized||!_d(t))return;let{coord:s,refName:a}=t.hoverPosition;if(i){if(a!==i.refName||!o.assemblyNames.includes(i.assemblyName)||s<i.start||s>=i.end)return;let l=s-i.start;return e.seqPosToVisibleCol(r,l)}if(n){let{g2p:c}=n,l=c[s];if(l!==void 0)return e.seqPosToVisibleCol(r,l)}}var fN={A:{A:4,R:-1,N:-2,D:-2,C:0,Q:-1,E:-1,G:0,H:-2,I:-1,L:-1,K:-1,M:-1,F:-2,P:-1,S:1,T:0,W:-3,Y:-2,V:0,B:-2,Z:-1,X:0,"*":-4},R:{A:-1,R:5,N:0,D:-2,C:-3,Q:1,E:0,G:-2,H:0,I:-3,L:-2,K:2,M:-1,F:-3,P:-2,S:-1,T:-1,W:-3,Y:-2,V:-3,B:-1,Z:0,X:-1,"*":-4},N:{A:-2,R:0,N:6,D:1,C:-3,Q:0,E:0,G:0,H:1,I:-3,L:-3,K:0,M:-2,F:-3,P:-2,S:1,T:0,W:-4,Y:-2,V:-3,B:3,Z:0,X:-1,"*":-4},D:{A:-2,R:-2,N:1,D:6,C:-3,Q:0,E:2,G:-1,H:-1,I:-3,L:-4,K:-1,M:-3,F:-3,P:-1,S:0,T:-1,W:-4,Y:-3,V:-3,B:4,Z:1,X:-1,"*":-4},C:{A:0,R:-3,N:-3,D:-3,C:9,Q:-3,E:-4,G:-3,H:-3,I:-1,L:-1,K:-3,M:-1,F:-2,P:-3,S:-1,T:-1,W:-2,Y:-2,V:-1,B:-3,Z:-3,X:-2,"*":-4},Q:{A:-1,R:1,N:0,D:0,C:-3,Q:5,E:2,G:-2,H:0,I:-3,L:-2,K:1,M:0,F:-3,P:-1,S:0,T:-1,W:-2,Y:-1,V:-2,B:0,Z:3,X:-1,"*":-4},E:{A:-1,R:0,N:0,D:2,C:-4,Q:2,E:5,G:-2,H:0,I:-3,L:-3,K:1,M:-2,F:-3,P:-1,S:0,T:-1,W:-3,Y:-2,V:-2,B:1,Z:4,X:-1,"*":-4},G:{A:0,R:-2,N:0,D:-1,C:-3,Q:-2,E:-2,G:6,H:-2,I:-4,L:-4,K:-2,M:-3,F:-3,P:-2,S:0,T:-2,W:-2,Y:-3,V:-3,B:-1,Z:-2,X:-1,"*":-4},H:{A:-2,R:0,N:1,D:-1,C:-3,Q:0,E:0,G:-2,H:8,I:-3,L:-3,K:-1,M:-2,F:-1,P:-2,S:-1,T:-2,W:-2,Y:2,V:-3,B:0,Z:0,X:-1,"*":-4},I:{A:-1,R:-3,N:-3,D:-3,C:-1,Q:-3,E:-3,G:-4,H:-3,I:4,L:2,K:-3,M:1,F:0,P:-3,S:-2,T:-1,W:-3,Y:-1,V:3,B:-3,Z:-3,X:-1,"*":-4},L:{A:-1,R:-2,N:-3,D:-4,C:-1,Q:-2,E:-3,G:-4,H:-3,I:2,L:4,K:-2,M:2,F:0,P:-3,S:-2,T:-1,W:-2,Y:-1,V:1,B:-4,Z:-3,X:-1,"*":-4},K:{A:-1,R:2,N:0,D:-1,C:-3,Q:1,E:1,G:-2,H:-1,I:-3,L:-2,K:5,M:-1,F:-3,P:-1,S:0,T:-1,W:-3,Y:-2,V:-2,B:0,Z:1,X:-1,"*":-4},M:{A:-1,R:-1,N:-2,D:-3,C:-1,Q:0,E:-2,G:-3,H:-2,I:1,L:2,K:-1,M:5,F:0,P:-2,S:-1,T:-1,W:-1,Y:-1,V:1,B:-3,Z:-1,X:-1,"*":-4},F:{A:-2,R:-3,N:-3,D:-3,C:-2,Q:-3,E:-3,G:-3,H:-1,I:0,L:0,K:-3,M:0,F:6,P:-4,S:-2,T:-2,W:1,Y:3,V:-1,B:-3,Z:-3,X:-1,"*":-4},P:{A:-1,R:-2,N:-2,D:-1,C:-3,Q:-1,E:-1,G:-2,H:-2,I:-3,L:-3,K:-1,M:-2,F:-4,P:7,S:-1,T:-1,W:-4,Y:-3,V:-2,B:-2,Z:-1,X:-2,"*":-4},S:{A:1,R:-1,N:1,D:0,C:-1,Q:0,E:0,G:0,H:-1,I:-2,L:-2,K:0,M:-1,F:-2,P:-1,S:4,T:1,W:-3,Y:-2,V:-2,B:0,Z:0,X:0,"*":-4},T:{A:0,R:-1,N:0,D:-1,C:-1,Q:-1,E:-1,G:-2,H:-2,I:-1,L:-1,K:-1,M:-1,F:-2,P:-1,S:1,T:5,W:-2,Y:-2,V:0,B:-1,Z:-1,X:0,"*":-4},W:{A:-3,R:-3,N:-4,D:-4,C:-2,Q:-2,E:-3,G:-2,H:-2,I:-3,L:-2,K:-3,M:-1,F:1,P:-4,S:-3,T:-2,W:11,Y:2,V:-3,B:-4,Z:-3,X:-2,"*":-4},Y:{A:-2,R:-2,N:-2,D:-3,C:-2,Q:-1,E:-2,G:-3,H:2,I:-1,L:-1,K:-2,M:-1,F:3,P:-3,S:-2,T:-2,W:2,Y:7,V:-1,B:-3,Z:-2,X:-1,"*":-4},V:{A:0,R:-3,N:-3,D:-3,C:-1,Q:-2,E:-2,G:-3,H:-3,I:3,L:1,K:-2,M:1,F:-1,P:-2,S:-2,T:0,W:-3,Y:-1,V:4,B:-3,Z:-2,X:-1,"*":-4},B:{A:-2,R:-1,N:3,D:4,C:-3,Q:0,E:1,G:-1,H:0,I:-3,L:-4,K:0,M:-3,F:-3,P:-2,S:0,T:-1,W:-4,Y:-3,V:-3,B:4,Z:1,X:-1,"*":-4},Z:{A:-1,R:0,N:0,D:1,C:-3,Q:3,E:4,G:-2,H:0,I:-3,L:-3,K:1,M:-1,F:-3,P:-1,S:0,T:-1,W:-3,Y:-2,V:-2,B:1,Z:4,X:-1,"*":-4},X:{A:0,R:-1,N:-1,D:-1,C:-2,Q:-1,E:-1,G:-1,H:-1,I:-1,L:-1,K:-1,M:-1,F:-1,P:-2,S:0,T:0,W:-2,Y:-1,V:-1,B:-1,Z:-1,X:-1,"*":-4},"*":{A:-4,R:-4,N:-4,D:-4,C:-4,Q:-4,E:-4,G:-4,H:-4,I:-4,L:-4,K:-4,M:-4,F:-4,P:-4,S:-4,T:-4,W:-4,Y:-4,V:-4,B:-4,Z:-4,X:-4,"*":1}},S1=fN;function Q1(e,t){return S1[e.toUpperCase()]?.[t.toUpperCase()]??-4}var mN=-10,dN=-.5;function gN(e,t,r=mN,n=dN){let o=e.length,i=t.length,s=[],a=[],c=[];for(let h=0;h<=o;h++){s[h]=[],a[h]=[],c[h]=[];for(let x=0;x<=i;x++)s[h][x]=-1/0,a[h][x]=-1/0,c[h][x]=-1/0}s[0][0]=0;for(let h=1;h<=o;h++)a[h][0]=r+(h-1)*n;for(let h=1;h<=i;h++)c[0][h]=r+(h-1)*n;for(let h=1;h<=o;h++)for(let x=1;x<=i;x++){let S=Q1(e[h-1],t[x-1]);s[h][x]=Math.max(s[h-1][x-1],a[h-1][x-1],c[h-1][x-1])+S,a[h][x]=Math.max(s[h-1][x]+r,a[h-1][x]+n),c[h][x]=Math.max(s[h][x-1]+r,c[h][x-1]+n)}let l="",A="",u=o,m=i,d=s[o][i],p=a[o][i],C=c[o][i],y=Math.max(d,p,C),I=y===d?"M":y===p?"Ix":"Iy";for(;u>0||m>0;)if(I==="M"&&u>0&&m>0){l=e[u-1]+l,A=t[m-1]+A;let h=Q1(e[u-1],t[m-1]),x=s[u-1][m-1],S=a[u-1][m-1],M=s[u][m];M===x+h?I="M":M===S+h?I="Ix":I="Iy",u--,m--}else if(I==="Ix"&&u>0){l=e[u-1]+l,A="-"+A;let h=a[u][m],x=s[u-1][m]+r;I=h===x?"M":"Ix",u--}else if(m>0){l="-"+l,A=t[m-1]+A;let h=c[u][m],x=s[u][m-1]+r;I=h===x?"M":"Iy",m--}else break;return{alignedSeq1:l,alignedSeq2:A,score:y}}function pN(e,t){let r="";for(let n=0;n<e.length;n++){let o=e[n],i=t[n];o==="-"||i==="-"?r+=" ":o.toUpperCase()===i.toUpperCase()?r+="|":r+=" "}return r}function M1(e,t){let{alignedSeq1:r,alignedSeq2:n}=gN(e,t);return{consensus:pN(r,n),alns:[{id:"msa",seq:r},{id:"structure",seq:n}]}}function v1(e){let t=e.alns[0].seq,r=e.alns[1].seq;if(t.length!==r.length)throw new Error("Aligned sequences must have same length");let n=0,o=0,i=new Map,s=new Map;for(let a=0;a<t.length;a++){let c=t[a],l=r[a];c!=="-"&&l!=="-"?(i.set(n,o),s.set(o,n),n++,o++):c==="-"?o++:n++}return{seq1ToSeq2:i,seq2ToSeq1:s}}Bs();var IN=(0,L1.lazy)(()=>Promise.resolve().then(()=>(N1(),D1)));function Wm(){return Ie.types.compose(F1.BaseViewModel,pl(),Ie.types.model("MsaView",{connectedViewId:Ie.types.maybe(Ie.types.string),connectedFeature:Ie.types.frozen(),connectedHighlights:Ie.types.array(Ie.types.model({refName:Ie.types.string,start:Ie.types.number,end:Ie.types.number})),blastParams:Ie.types.frozen(),querySeqName:"QUERY",uniprotId:Ie.types.maybe(Ie.types.string),zoomToBaseLevel:!1,init:Ie.types.frozen(),connectedStructures:Ie.types.array(Ie.types.frozen()),dataStoreId:Ie.types.maybe(Ie.types.string),mafRegion:Ie.types.frozen()})).volatile(()=>({rid:void 0,progress:"",error:void 0,loadingStoredData:!1,isStoringData:!1})).views(e=>({getRowByName(t){return e.rows.find(r=>r[0]===t)},getSequenceByRowName(t){return e.rows.find(r=>r[0]===t)?.[1]}})).views(e=>({get transcriptToMsaMap(){return e.connectedFeature?e0(e.connectedFeature):void 0},get connectedView(){let{views:t}=(0,wi.getSession)(e);return t.find(r=>r.id===e.connectedViewId)},get connectedProteinViews(){let t=Bn((0,wi.getSession)(e).views),r=[];for(let n of e.connectedStructures){let o=t.find(i=>i.id===n.proteinViewId);o&&r.push({...n,proteinView:o})}return r}})).views(e=>({get structureHoverCol(){for(let t of e.connectedProteinViews){let n=t.proteinView.structures[t.structureIdx]?.hoverPosition?.structureSeqPos;if(n!==void 0){let o=t.structureToMsa[n];if(o!==void 0){let i=e.getSequenceByRowName(t.msaRowName);if(i){let s=A1(i,o);if(s!==void 0)return e.globalColToVisibleCol(s)}}}}}})).views(e=>({get mouseCol2(){let t=e.structureHoverCol;return t!==void 0?t:B1({model:e})}})).actions(e=>({setZoomToBaseLevel(t){e.zoomToBaseLevel=t},setError(t){e.error=t},setProgress(t){e.progress=t},setRid(t){e.rid=t},setConnectedHighlights(t){e.connectedHighlights=(0,Ie.cast)(t)},addToConnectedHighlights(t){e.connectedHighlights.push(t)},clearConnectedHighlights(){e.connectedHighlights=(0,Ie.cast)([])},setBlastParams(t){e.blastParams=t},setInit(t){e.init=t},setQuerySeqName(t){e.querySeqName=t},setUniprotId(t){e.uniprotId=t},setDataStoreId(t){e.dataStoreId=t},setMafRegion(t){e.mafRegion=t},setLoadingStoredData(t){e.loadingStoredData=t},setIsStoringData(t){e.isStoringData=t},handleMsaClick(t){let{connectedView:r,zoomToBaseLevel:n}=e,{assemblyManager:o}=(0,wi.getSession)(e),i=Ss({model:e,coord:t});if(!(!i||!r))if(n)r.navTo(i);else{let s=Gs({assemblyManager:o,assemblyNames:r.assemblyNames,refName:i.refName});r.centerAt(i.start,s)}},connectToStructure(t,r,n){let o=n??e.querySeqName,i=e.getSequenceByRowName(o);if(!i)throw new Error(`MSA row "${o}" not found`);let s=i.replaceAll("-",""),a=Bn((0,wi.getSession)(e).views).find(p=>p.id===t);if(!a)throw new Error(`ProteinView "${t}" not found`);let c=a.structures[r];if(!c)throw new Error(`Structure at index ${r} not found`);let l=c.structureSequences?.[0];if(!l)throw new Error("Structure sequence not available");let A=M1(s,l),{seq1ToSeq2:u,seq2ToSeq1:m}=v1(A),d={proteinViewId:t,structureIdx:r,msaRowName:o,msaToStructure:Object.fromEntries(u),structureToMsa:Object.fromEntries(m)};e.connectedStructures.push(d)},disconnectFromStructure(t,r){let n=e.connectedStructures.findIndex(o=>o.proteinViewId===t&&o.structureIdx===r);n!==-1&&e.connectedStructures.splice(n,1)},disconnectAllStructures(){e.connectedStructures.clear()}})).actions(e=>{let t=e.setMouseClickPos.bind(e);return{setMouseClickPos(r,n){t(r,n),r!==void 0&&e.handleMsaClick(r)}}}).views(e=>({extraViewMenuItems(){return[{label:"Zoom to base level on click?",checked:e.zoomToBaseLevel,type:"checkbox",onClick:()=>{e.setZoomToBaseLevel(!e.zoomToBaseLevel)}},{label:"Connect to protein structure...",onClick:()=>{(0,wi.getSession)(e).queueDialog(t=>[IN,{model:e,handleClose:t}])}},...e.connectedStructures.length>0?[{label:"Disconnect from protein structures",onClick:()=>{e.disconnectAllStructures()}}]:[]]}})).actions(e=>({afterCreate(){w1();for(let t of[g1,p1,h1,C1,E1,I1,x1,y1])(0,Ie.addDisposer)(e,(0,R1.autorun)(()=>{t(e)}))}}))}var MN=(0,X1.lazy)(()=>Promise.resolve().then(()=>(K1(),$1)));function Xm(e){e.addViewType(()=>new Z1.default({name:"MsaView",stateModel:Wm(),ReactComponent:MN}))}var eQ="2.4.4";var wl=class extends tQ.default{constructor(){super(...arguments);this.name="MsaViewPlugin";this.version=eQ;this.rootConfigurationSchema=r=>({msa:(0,Zm.ConfigurationSchema)("MSA",{datasets:ed.types.maybe(ed.types.array((0,Zm.ConfigurationSchema)("MSAEntry",{datasetId:{type:"string",defaultValue:""},description:{type:"string",defaultValue:""},name:{type:"string",defaultValue:""},adapter:r.pluggableConfigSchemaType("adapter")})))})})}install(r){Xm(r),su(r),au(r),Rl(r),rA(r)}configure(r){(0,rQ.isAbstractMenuManager)(r.rootModel)&&r.rootModel.appendToSubMenu(["Add"],{label:"Multiple sequence alignment view",icon:bd,onClick:n=>{n.addView("MsaView",{})}})}};return gQ(vN);})();
72
+ `),onProgress:I=>{e.setProgress(I)}}),x=JSON.stringify(d);return await vB({proteinSequence:c,blastDatabase:r,blastProgram:n,msaAlgorithm:o,msa:E.msa,tree:E.tree,treeMetadata:x,rid:A,geneId:s?.get("parentId"),transcriptId:s?.id(),transcriptName:s?.get("name")??s?.get("id"),geneName:s?.get("gene_name")??s?.get("parentId")}),{...E,treeMetadata:x}}function SD(e,t){let r={},n=e.taxid?t.get(e.taxid):void 0;return n?.sciname&&(r["Scientific name"]=n.sciname),n?.commonName&&(r["Common name"]=n.commonName),e.accession&&(r.Accession=e.accession),e.id&&(r.ID=e.id),e.title&&(r.Description=e.title),r}var GB=f(Ce());function UB({model:e}){let{hovered:t}=(0,GB.getSession)(e),{querySeqName:r,transcriptToMsaMap:n,connectedView:o,mafRegion:i}=e;if(!o?.initialized||!Dn(t))return;let{coord:s,refName:a}=t.hoverPosition;if(i)return a!==i.refName||!o.assemblyNames.includes(i.assemblyName)||s<i.start||s>=i.end?void 0:e.seqPosToVisibleCol(r,s-i.start);if(n){let c=n.g2p[s];if(c!==void 0)return e.seqPosToVisibleCol(r,c)}}Wi();var QD="jbrowse-msaview-data",MD=1,Ss="msa-data";async function Em(){return jn(QD,MD,{upgrade(e){e.objectStoreNames.contains(Ss)||e.createObjectStore(Ss,{keyPath:"id"}).createIndex("timestamp","timestamp",{unique:!1})}})}function HB(){return`msa-${Date.now()}-${Math.random().toString(36).slice(2,11)}`}async function jB(e,t){try{let r=await Em(),n={id:e,msa:t.msa,tree:t.tree,treeMetadata:t.treeMetadata,timestamp:Date.now()};return await r.put(Ss,n),!0}catch(r){return console.warn("Failed to store MSA data:",r),!1}}async function qB(e){try{let r=await(await Em()).get(Ss,e);return r?{msa:r.msa,tree:r.tree,treeMetadata:r.treeMetadata}:void 0}catch(t){console.warn("Failed to retrieve MSA data:",t);return}}async function JB(e=10080*60*1e3){try{let t=await Em(),r=Date.now()-e,i=await t.transaction(Ss,"readwrite").store.index("timestamp").openCursor(IDBKeyRange.upperBound(r)),s=0;for(;i;)await i.delete(),s++,i=await i.continue();return s}catch(t){return console.warn("Failed to cleanup old MSA data:",t),0}}Qs();function VB(e){let{dataStoreId:t,rows:r}=e;t&&r.length===0&&(async()=>{try{e.setLoadingStoredData(!0);let n=await qB(t);n&&(n.msa&&e.setMSA(n.msa),n.tree&&e.setTree(n.tree))}catch(n){console.error("Failed to load MSA data from IndexedDB:",n)}finally{e.setLoadingStoredData(!1)}})()}function YB(e){let{rows:t,dataStoreId:r,isStoringData:n}=e;if(t.length>0&&!r&&!n){if(e.msaFilehandle||e.treeFilehandle)return;let o=e.data.msa,i=e.data.tree;(o||i)&&(e.setIsStoringData(!0),(async()=>{try{let s=HB();await jB(s,{msa:o,tree:i,treeMetadata:e.data.treeMetadata})&&e.setDataStoreId(s)}catch(s){console.error("Failed to store MSA data to IndexedDB:",s)}finally{e.setIsStoringData(!1)}})())}}function WB(e){e.blastParams&&(async()=>{try{e.setProgress("Submitting query"),e.setError(void 0);let t=await OB({self:e});e.setData(t),e.setBlastParams(void 0)}catch(t){e.setError(t),console.error(t)}finally{e.setProgress("")}})()}function zB(e){let{init:t}=e;t&&(async()=>{try{e.setError(void 0);let{msaData:r,msaUrl:n,treeData:o,treeUrl:i,querySeqName:s}=t;if(n){let a=Gd(n);a&&(e.setUniprotId(a),e.setQuerySeqName("query"))}if(s&&e.setQuerySeqName(s),r)e.setMSA(r);else if(n){let a=await fetch(n);if(!a.ok)throw new Error(`Failed to fetch MSA: ${a.status}`);let c=await a.text();e.setMSA(c)}if(o)e.setTree(o);else if(i){let a=await fetch(i);if(!a.ok)throw new Error(`Failed to fetch tree: ${a.status}`);let c=await a.text();e.setTree(c)}e.setInit(void 0)}catch(r){e.setError(r),console.error(r)}})()}function $B(e){let t=!1;return()=>{let r=UB({model:e});r!==void 0?(e.setMousePos(r),t=!0):t&&(e.setMousePos(void 0),t=!1)}}function KB(e){let{mouseCol:t,connectedProteinViews:r}=e;if(r.length!==0)for(let n of r){let o=n.proteinView.structures[n.structureIdx];if(!o)continue;if(t===void 0){o.clearHighlightFromExternal?.();continue}let i=e.getSequenceByRowName(n.msaRowName);if(!i)continue;let s=il(i,t);if(s===void 0){o.clearHighlightFromExternal?.();continue}let a=n.msaToStructure[s];a===void 0?o.clearHighlightFromExternal?.():o.highlightFromExternal?.(a)}}function XB(e){let{connectedViewId:t,uniprotId:r,rows:n,connectedStructures:o}=e;if(!(!r||n.length===0))for(let i of bn((0,Im.getSession)(e).views))for(let s=0;s<i.structures.length;s++){let a=i.structures[s];if(!(!a||a.connectedViewId!==t||a.uniprotId!==r||o.some(l=>l.proteinViewId===i.id&&l.structureIdx===s))&&a.structureSequences?.[0])try{e.connectToStructure(i.id,s)}catch(l){console.error("Failed to auto-connect to ProteinView:",l)}}}function ZB(e){let{connectedViewId:t,transcriptToMsaMap:r,querySeqName:n}=e;if(!t||!r)return;let o=new Set;for(let s of bn((0,Im.getSession)(e).views))for(let a of s.structures){if(a.connectedViewId!==t)continue;let c=a.hoverGenomeHighlights;if(!c||c.length===0)continue;let{g2p:l}=r;for(let A of c)for(let u=A.start;u<A.end;u++){let m=l[u];if(m!==void 0){let d=e.seqPosToGlobalCol(n,m);o.add(d)}}}let i=Array.from(o).map(s=>e.globalColToVisibleCol(s)).filter(s=>s!==void 0);e.setHighlightedColumns(i.length>0?i:void 0)}function eS(){JB().catch(e=>{console.error("Failed to cleanup old MSA data:",e)})}Qs();function sl({model:e,coord:t}){let{querySeqName:r,transcriptToMsaMap:n,mafRegion:o}=e,i=e.rows.find(a=>a[0]===r)?.[1];if(!i)return;let s=il(i,t);if(s!==void 0){if(o){let a=o.start+s;return a<o.end?{refName:o.refName,start:a,end:a+1}:void 0}if(n){let{refName:a,p2g:c}=n,l=c[s],A=c[s+1];return l!==void 0&&A!==void 0?{refName:a,start:Math.min(l,A),end:Math.max(l,A)}:void 0}}}var TD={A:{A:4,R:-1,N:-2,D:-2,C:0,Q:-1,E:-1,G:0,H:-2,I:-1,L:-1,K:-1,M:-1,F:-2,P:-1,S:1,T:0,W:-3,Y:-2,V:0,B:-2,Z:-1,X:0,"*":-4},R:{A:-1,R:5,N:0,D:-2,C:-3,Q:1,E:0,G:-2,H:0,I:-3,L:-2,K:2,M:-1,F:-3,P:-2,S:-1,T:-1,W:-3,Y:-2,V:-3,B:-1,Z:0,X:-1,"*":-4},N:{A:-2,R:0,N:6,D:1,C:-3,Q:0,E:0,G:0,H:1,I:-3,L:-3,K:0,M:-2,F:-3,P:-2,S:1,T:0,W:-4,Y:-2,V:-3,B:3,Z:0,X:-1,"*":-4},D:{A:-2,R:-2,N:1,D:6,C:-3,Q:0,E:2,G:-1,H:-1,I:-3,L:-4,K:-1,M:-3,F:-3,P:-1,S:0,T:-1,W:-4,Y:-3,V:-3,B:4,Z:1,X:-1,"*":-4},C:{A:0,R:-3,N:-3,D:-3,C:9,Q:-3,E:-4,G:-3,H:-3,I:-1,L:-1,K:-3,M:-1,F:-2,P:-3,S:-1,T:-1,W:-2,Y:-2,V:-1,B:-3,Z:-3,X:-2,"*":-4},Q:{A:-1,R:1,N:0,D:0,C:-3,Q:5,E:2,G:-2,H:0,I:-3,L:-2,K:1,M:0,F:-3,P:-1,S:0,T:-1,W:-2,Y:-1,V:-2,B:0,Z:3,X:-1,"*":-4},E:{A:-1,R:0,N:0,D:2,C:-4,Q:2,E:5,G:-2,H:0,I:-3,L:-3,K:1,M:-2,F:-3,P:-1,S:0,T:-1,W:-3,Y:-2,V:-2,B:1,Z:4,X:-1,"*":-4},G:{A:0,R:-2,N:0,D:-1,C:-3,Q:-2,E:-2,G:6,H:-2,I:-4,L:-4,K:-2,M:-3,F:-3,P:-2,S:0,T:-2,W:-2,Y:-3,V:-3,B:-1,Z:-2,X:-1,"*":-4},H:{A:-2,R:0,N:1,D:-1,C:-3,Q:0,E:0,G:-2,H:8,I:-3,L:-3,K:-1,M:-2,F:-1,P:-2,S:-1,T:-2,W:-2,Y:2,V:-3,B:0,Z:0,X:-1,"*":-4},I:{A:-1,R:-3,N:-3,D:-3,C:-1,Q:-3,E:-3,G:-4,H:-3,I:4,L:2,K:-3,M:1,F:0,P:-3,S:-2,T:-1,W:-3,Y:-1,V:3,B:-3,Z:-3,X:-1,"*":-4},L:{A:-1,R:-2,N:-3,D:-4,C:-1,Q:-2,E:-3,G:-4,H:-3,I:2,L:4,K:-2,M:2,F:0,P:-3,S:-2,T:-1,W:-2,Y:-1,V:1,B:-4,Z:-3,X:-1,"*":-4},K:{A:-1,R:2,N:0,D:-1,C:-3,Q:1,E:1,G:-2,H:-1,I:-3,L:-2,K:5,M:-1,F:-3,P:-1,S:0,T:-1,W:-3,Y:-2,V:-2,B:0,Z:1,X:-1,"*":-4},M:{A:-1,R:-1,N:-2,D:-3,C:-1,Q:0,E:-2,G:-3,H:-2,I:1,L:2,K:-1,M:5,F:0,P:-2,S:-1,T:-1,W:-1,Y:-1,V:1,B:-3,Z:-1,X:-1,"*":-4},F:{A:-2,R:-3,N:-3,D:-3,C:-2,Q:-3,E:-3,G:-3,H:-1,I:0,L:0,K:-3,M:0,F:6,P:-4,S:-2,T:-2,W:1,Y:3,V:-1,B:-3,Z:-3,X:-1,"*":-4},P:{A:-1,R:-2,N:-2,D:-1,C:-3,Q:-1,E:-1,G:-2,H:-2,I:-3,L:-3,K:-1,M:-2,F:-4,P:7,S:-1,T:-1,W:-4,Y:-3,V:-2,B:-2,Z:-1,X:-2,"*":-4},S:{A:1,R:-1,N:1,D:0,C:-1,Q:0,E:0,G:0,H:-1,I:-2,L:-2,K:0,M:-1,F:-2,P:-1,S:4,T:1,W:-3,Y:-2,V:-2,B:0,Z:0,X:0,"*":-4},T:{A:0,R:-1,N:0,D:-1,C:-1,Q:-1,E:-1,G:-2,H:-2,I:-1,L:-1,K:-1,M:-1,F:-2,P:-1,S:1,T:5,W:-2,Y:-2,V:0,B:-1,Z:-1,X:0,"*":-4},W:{A:-3,R:-3,N:-4,D:-4,C:-2,Q:-2,E:-3,G:-2,H:-2,I:-3,L:-2,K:-3,M:-1,F:1,P:-4,S:-3,T:-2,W:11,Y:2,V:-3,B:-4,Z:-3,X:-2,"*":-4},Y:{A:-2,R:-2,N:-2,D:-3,C:-2,Q:-1,E:-2,G:-3,H:2,I:-1,L:-1,K:-2,M:-1,F:3,P:-3,S:-2,T:-2,W:2,Y:7,V:-1,B:-3,Z:-2,X:-1,"*":-4},V:{A:0,R:-3,N:-3,D:-3,C:-1,Q:-2,E:-2,G:-3,H:-3,I:3,L:1,K:-2,M:1,F:-1,P:-2,S:-2,T:0,W:-3,Y:-1,V:4,B:-3,Z:-2,X:-1,"*":-4},B:{A:-2,R:-1,N:3,D:4,C:-3,Q:0,E:1,G:-1,H:0,I:-3,L:-4,K:0,M:-3,F:-3,P:-2,S:0,T:-1,W:-4,Y:-3,V:-3,B:4,Z:1,X:-1,"*":-4},Z:{A:-1,R:0,N:0,D:1,C:-3,Q:3,E:4,G:-2,H:0,I:-3,L:-3,K:1,M:-1,F:-3,P:-1,S:0,T:-1,W:-3,Y:-2,V:-2,B:1,Z:4,X:-1,"*":-4},X:{A:0,R:-1,N:-1,D:-1,C:-2,Q:-1,E:-1,G:-1,H:-1,I:-1,L:-1,K:-1,M:-1,F:-1,P:-2,S:0,T:0,W:-2,Y:-1,V:-1,B:-1,Z:-1,X:-1,"*":-4},"*":{A:-4,R:-4,N:-4,D:-4,C:-4,Q:-4,E:-4,G:-4,H:-4,I:-4,L:-4,K:-4,M:-4,F:-4,P:-4,S:-4,T:-4,W:-4,Y:-4,V:-4,B:-4,Z:-4,X:-4,"*":1}},tS=TD;function rS(e,t){return tS[e.toUpperCase()]?.[t.toUpperCase()]??-4}var _D=-10,kD=-.5;function DD(e,t,r=_D,n=kD){let o=e.length,i=t.length,s=[],a=[],c=[];for(let h=0;h<=o;h++){s[h]=[],a[h]=[],c[h]=[];for(let y=0;y<=i;y++)s[h][y]=-1/0,a[h][y]=-1/0,c[h][y]=-1/0}s[0][0]=0;for(let h=1;h<=o;h++)a[h][0]=r+(h-1)*n;for(let h=1;h<=i;h++)c[0][h]=r+(h-1)*n;for(let h=1;h<=o;h++)for(let y=1;y<=i;y++){let Q=rS(e[h-1],t[y-1]);s[h][y]=Math.max(s[h-1][y-1],a[h-1][y-1],c[h-1][y-1])+Q,a[h][y]=Math.max(s[h-1][y]+r,a[h-1][y]+n),c[h][y]=Math.max(s[h][y-1]+r,c[h][y-1]+n)}let l="",A="",u=o,m=i,d=s[o][i],p=a[o][i],E=c[o][i],x=Math.max(d,p,E),I=x===d?"M":x===p?"Ix":"Iy";for(;u>0||m>0;)if(I==="M"&&u>0&&m>0){l=e[u-1]+l,A=t[m-1]+A;let h=rS(e[u-1],t[m-1]),y=s[u-1][m-1],Q=a[u-1][m-1],M=s[u][m];M===y+h?I="M":M===Q+h?I="Ix":I="Iy",u--,m--}else if(I==="Ix"&&u>0){l=e[u-1]+l,A="-"+A;let h=a[u][m],y=s[u-1][m]+r;I=h===y?"M":"Ix",u--}else if(m>0){l="-"+l,A=t[m-1]+A;let h=c[u][m],y=s[u][m-1]+r;I=h===y?"M":"Iy",m--}else break;return{alignedSeq1:l,alignedSeq2:A,score:x}}function ND(e,t){let r="";for(let n=0;n<e.length;n++){let o=e[n],i=t[n],s=o!=="-"&&i!=="-"&&o.toUpperCase()===i.toUpperCase();r+=s?"|":" "}return r}function nS(e,t){let{alignedSeq1:r,alignedSeq2:n}=DD(e,t);return{consensus:ND(r,n),alns:[{id:"msa",seq:r},{id:"structure",seq:n}]}}function oS(e){let t=e.alns[0].seq,r=e.alns[1].seq;if(t.length!==r.length)throw new Error("Aligned sequences must have same length");let n=0,o=0,i=new Map,s=new Map;for(let a=0;a<t.length;a++){let c=t[a],l=r[a];c!=="-"&&l!=="-"?(i.set(n,o),s.set(o,n),n++,o++):c==="-"?o++:n++}return{seq1ToSeq2:i,seq2ToSeq1:s}}Qs();var PD=(0,AS.lazy)(()=>Promise.resolve().then(()=>(lS(),cS)));function ym(){return Ze.types.compose(uS.BaseViewModel,Wc(),Ze.types.model("MsaView",{connectedViewId:Ze.types.maybe(Ze.types.string),connectedFeature:Ze.types.frozen(),blastParams:Ze.types.frozen(),querySeqName:"QUERY",uniprotId:Ze.types.maybe(Ze.types.string),zoomToBaseLevel:!1,init:Ze.types.frozen(),connectedStructures:Ze.types.array(Ze.types.frozen()),dataStoreId:Ze.types.maybe(Ze.types.string),mafRegion:Ze.types.frozen()})).volatile(()=>({rid:void 0,progress:"",error:void 0,loadingStoredData:!1,isStoringData:!1})).views(e=>({getRowByName(t){return e.rows.find(r=>r[0]===t)},getSequenceByRowName(t){return e.rows.find(r=>r[0]===t)?.[1]}})).views(e=>({get transcriptToMsaMap(){return e.connectedFeature?jd(e.connectedFeature):void 0},get connectedView(){let{views:t}=(0,Ci.getSession)(e);return t.find(r=>r.id===e.connectedViewId)},get connectedProteinViews(){let t=bn((0,Ci.getSession)(e).views),r=[];for(let n of e.connectedStructures){let o=t.find(i=>i.id===n.proteinViewId);o&&r.push({...n,proteinView:o})}return r}})).views(e=>({get connectedHighlights(){let{mouseCol:t,mouseClickCol:r}=e;return[t===void 0?void 0:sl({model:e,coord:t}),r===void 0?void 0:sl({model:e,coord:r})].filter(n=>n!==void 0)}})).actions(e=>({setZoomToBaseLevel(t){e.zoomToBaseLevel=t},setError(t){e.error=t},setProgress(t){e.progress=t},setRid(t){e.rid=t},setBlastParams(t){e.blastParams=t},setInit(t){e.init=t},setQuerySeqName(t){e.querySeqName=t},setUniprotId(t){e.uniprotId=t},setDataStoreId(t){e.dataStoreId=t},setMafRegion(t){e.mafRegion=t},setLoadingStoredData(t){e.loadingStoredData=t},setIsStoringData(t){e.isStoringData=t},handleMsaClick(t){let{connectedView:r,zoomToBaseLevel:n}=e,{assemblyManager:o}=(0,Ci.getSession)(e),i=sl({model:e,coord:t});if(!(!i||!r))if(n)r.navTo(i);else{let s=Ys({assemblyManager:o,assemblyNames:r.assemblyNames,refName:i.refName});r.centerAt(i.start,s)}},connectToStructure(t,r,n){let o=n??e.querySeqName,i=e.getSequenceByRowName(o);if(!i)throw new Error(`MSA row "${o}" not found`);let s=i.replaceAll("-",""),a=bn((0,Ci.getSession)(e).views).find(d=>d.id===t);if(!a)throw new Error(`ProteinView "${t}" not found`);let c=a.structures[r];if(!c)throw new Error(`Structure at index ${r} not found`);let l=c.structureSequences?.[0];if(!l)throw new Error("Structure sequence not available");let A=nS(s,l),{seq1ToSeq2:u}=oS(A),m={proteinViewId:t,structureIdx:r,msaRowName:o,msaToStructure:Object.fromEntries(u)};e.connectedStructures.push(m)},disconnectFromStructure(t,r){let n=e.connectedStructures.findIndex(o=>o.proteinViewId===t&&o.structureIdx===r);n!==-1&&e.connectedStructures.splice(n,1)},disconnectAllStructures(){e.connectedStructures.clear()}})).actions(e=>{let t=e.setMouseClickPos.bind(e);return{setMouseClickPos(r,n){t(r,n),r!==void 0&&e.handleMsaClick(r)}}}).views(e=>({extraViewMenuItems(){return[{label:"Zoom to base level on click?",checked:e.zoomToBaseLevel,type:"checkbox",onClick:()=>{e.setZoomToBaseLevel(!e.zoomToBaseLevel)}},{label:"Connect to protein structure...",onClick:()=>{(0,Ci.getSession)(e).queueDialog(t=>[PD,{model:e,handleClose:t}])}},...e.connectedStructures.length>0?[{label:"Disconnect from protein structures",onClick:()=>{e.disconnectAllStructures()}}]:[]]}})).actions(e=>({afterCreate(){eS();for(let t of[VB,YB,WB,zB,KB,XB,ZB])(0,Ze.addDisposer)(e,(0,xm.autorun)(()=>{t(e)}));(0,Ze.addDisposer)(e,(0,xm.autorun)($B(e)))}}))}function Ei(e){return e.type==="MsaView"}var OD=(0,wm.observer)(function({model:e}){let{hovered:t,views:r}=(0,fS.getSession)(e);return r.some(o=>Ei(o)&&o.connectedViewId===e.id)&&Dn(t)?bm.default.createElement(GD,{model:e,hovered:t}):null}),GD=(0,wm.observer)(function({model:e,hovered:t}){let{classes:r}=Ws(),{offsetPx:n}=e,{coord:o,refName:i}=t.hoverPosition,s=e.bpToPx({refName:i,coord:o-1}),a=e.bpToPx({refName:i,coord:o});if(s&&a){let c=Math.max(Math.abs(a.offsetPx-s.offsetPx),4),l=Math.min(s.offsetPx,a.offsetPx)-n;return bm.default.createElement("div",{className:r.highlight,style:{left:l,width:c}})}return null}),mS=OD;var Ms=f(w()),Bm=f(Ce()),Sm=f(G());var UD=(0,Sm.observer)(function({model:t}){let{views:r,hovered:n}=(0,Bm.getSession)(t),i=r.filter(Ei).find(s=>s.connectedViewId===t.id)?.connectedHighlights;return!Dn(n)&&i?.length?Ms.default.createElement(HD,{model:t,highlights:i}):null}),HD=(0,Sm.observer)(function({model:e,highlights:t}){let{classes:r}=Ws(),{assemblyManager:n}=(0,Bm.getSession)(e),{offsetPx:o}=e;return Ms.default.createElement(Ms.default.Fragment,null,t.map((i,s)=>{let a=Ys({assemblyManager:n,assemblyNames:e.assemblyNames,refName:i.refName}),c=e.bpToPx({refName:a,coord:i.start}),l=e.bpToPx({refName:a,coord:i.end});if(c&&l){let A=Math.max(Math.abs(l.offsetPx-c.offsetPx),4),u=Math.min(c.offsetPx,l.offsetPx)-o;return Ms.default.createElement("div",{key:`${i.refName}-${i.start}-${i.end}-${s}`,className:r.highlight,style:{left:u,width:A}})}return null}))}),dS=UD;var jD=(0,gS.observer)(function({model:t}){return vs.default.createElement(vs.default.Fragment,null,vs.default.createElement(dS,{model:t}),vs.default.createElement(mS,{model:t}))}),pS=jD;function Qm(e){e.addToExtensionPoint("LinearGenomeView-TracksContainerComponent",(t,{model:r})=>{let{views:n}=(0,CS.getSession)(r);return n.some(i=>Ei(i)&&i.connectedViewId===r.id)?[...t,hS.default.createElement(pS,{key:"highlight_protein_viewer_msaview",model:r})]:t})}var SS=f(Ul());var ES=f(Eo());function Mm(e){let t=e.getAdapterType("BgzipFastaAdapter");return(0,ES.ConfigurationSchema)("BgzipFastaMsaAdapter",{msaRegex:{type:"string",defaultValue:"_"}},{baseConfiguration:t?.configSchema})}function vm(e){return e.addAdapterType(()=>new SS.AdapterType({name:"BgzipFastaMsaAdapter",configSchema:Mm(e),adapterMetadata:{hiddenFromGUI:!0},getAdapterClass:()=>Promise.resolve().then(()=>(BS(),wS)).then(t=>t.default)}))}var Tl=f(Ce());W();var QS=f(R(),1),MS=(0,_.createSvgIcon)((0,QS.jsx)("path",{d:"M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6z"}),"Add");var vt=f(w()),X1=f(we()),Z1=f(Ce()),Qi=f(k());var ne=f(w()),zm=f(we()),l1=f(Ce()),Kt=f(k()),A1=f(G()),u1=f(Se());function vS({session:e,newViewTitle:t,view:r,feature:n,msaFilehandle:o,treeFilehandle:i,querySeqName:s,data:a}){e.addView("MsaView",{type:"MsaView",displayName:t,connectedViewId:r.id,connectedFeature:n.toJSON(),msaFilehandle:o,treeFilehandle:i,querySeqName:s,data:a})}var Tm=f(w()),TS=f(k());function qD({children:e,...t}){return Tm.default.createElement("div",null,Tm.default.createElement(TS.TextField,{...t},e))}var at=qD;var _m=f(w()),_S=f(we()),kS=f(k()),DS=f(Se()),JD=(0,DS.makeStyles)()({dialogContent:{width:"80em"}});function mr({error:e,children:t}){let{classes:r}=JD();return _m.default.createElement(kS.DialogContent,{className:r.dialogContent},e?_m.default.createElement(_S.ErrorMessage,{error:e}):null,t)}var ll=f(w()),Ts=f(k());function Xr({onSubmit:e,onCancel:t,submitDisabled:r,submitLabel:n="Submit",cancelLabel:o="Cancel"}){return ll.default.createElement(Ts.DialogActions,null,ll.default.createElement(Ts.Button,{color:"primary",variant:"contained",disabled:r,onClick:()=>{e()}},n),ll.default.createElement(Ts.Button,{color:"secondary",variant:"contained",onClick:()=>{t()}},o))}var dr=f(w()),Ii=f(k()),FS=f(Se());var NS=f(w()),LS=f(Se());var VD=(0,LS.makeStyles)()({textAreaFont:{fontFamily:"Courier New"}});function km({value:e}){let{classes:t}=VD();return NS.default.createElement(at,{variant:"outlined",multiline:!0,minRows:5,maxRows:10,fullWidth:!0,value:e,slotProps:{input:{readOnly:!0,classes:{input:t.textAreaFont}}}})}var YD=(0,FS.makeStyles)()({flex:{display:"flex"},minWidth:{minWidth:300},centered:{alignContent:"center",marginLeft:20}});function gr({feature:e,options:t,selectedId:r,selectedTranscript:n,setSelectedId:o,proteinSequence:i,validIds:s}){let{classes:a}=YD(),[c,l]=(0,dr.useState)(!1);return dr.default.createElement(dr.default.Fragment,null,dr.default.createElement("div",{className:a.flex},dr.default.createElement(Ii.TextField,{variant:"outlined",label:`Choose isoform of ${co(e)}`,select:!0,className:a.minWidth,value:r,onChange:A=>{o(A.target.value)}},t.map(A=>{let u=s?s.some(p=>ws(A,p)):!0,{len:m,mod:d}=zc(A);return dr.default.createElement(Ii.MenuItem,{value:ao(A),key:A.id(),disabled:!u},Kc(A)," (",m," aa)"," ",d?" (possible fragment)":"",s?u?" (has data)":" (no data)":"")})),dr.default.createElement("div",{className:a.centered},dr.default.createElement(Ii.Button,{variant:"contained",color:"primary",onClick:()=>{l(!c)}},c?"Hide sequence":"Show sequence"))),c?dr.default.createElement(km,{value:i?`>${Kc(n)}
73
+ ${i}`:"Loading..."}):null)}var yl=f(w());var wn=f(Ce());function WD(e,t){return e.map(r=>t.slice(r.start,r.end)).join("")}function zD({cds:e,sequence:t,codonTable:r}){let n=WD(e,t),o="";for(let i=0;i<n.length;i+=3)o+=r[n.slice(i,i+3)]??"&";return o}function $D(e,t){return e.map(r=>({...r,start:t-r.end,end:t-r.start})).toSorted((r,n)=>r.start-n.start)}function RS({feature:e,seq:t}){let{subfeatures:r,start:n,strand:o}=e.toJSON(),i=(0,wn.dedupe)(r?.toSorted((s,a)=>s.start-a.start).map(s=>({...s,start:s.start-n,end:s.end-n})).filter(s=>s.type==="CDS")??[],s=>`${s.start}-${s.end}`);return zD({cds:o===-1?$D(i,t.length):i,sequence:o===-1?(0,wn.revcom)(t):t,codonTable:(0,wn.generateCodonTable)(wn.defaultCodonTable)})}var s1=f(Ce());var Je=f(w(),1),Wm=f(US(),1);var ct=f(w(),1);var Bn={};Ye(Bn,{ERROR_REVALIDATE_EVENT:()=>sN,FOCUS_EVENT:()=>HS,MUTATE_EVENT:()=>qS,RECONNECT_EVENT:()=>jS});var HS=0,jS=1,qS=2,sN=3;var JS=Object.prototype.hasOwnProperty;function Al(e,t){var r,n;if(e===t)return!0;if(e&&t&&(r=e.constructor)===t.constructor){if(r===Date)return e.getTime()===t.getTime();if(r===RegExp)return e.toString()===t.toString();if(r===Array){if((n=e.length)===t.length)for(;n--&&Al(e[n],t[n]););return n===-1}if(!r||typeof e=="object"){n=0;for(r in e)if(JS.call(e,r)&&++n&&!JS.call(t,r)||!(r in t)||!Al(e[r],t[r]))return!1;return Object.keys(t).length===n}}return e!==e&&t!==t}var pr=new WeakMap,hr=()=>{},qe=hr(),yi=Object,q=e=>e===qe,Ot=e=>typeof e=="function",Cr=(e,t)=>({...e,...t}),pl=e=>Ot(e.then),Nm={},ul={},Um="undefined",bi=typeof window!=Um,ml=typeof document!=Um,YS=bi&&"Deno"in window,WS=()=>bi&&typeof window.requestAnimationFrame!=Um,hl=(e,t)=>{let r=pr.get(e);return[()=>!q(t)&&e.get(t)||Nm,n=>{if(!q(t)){let o=e.get(t);t in ul||(ul[t]=o),r[5](t,Cr(o,n),o||Nm)}},r[6],()=>!q(t)&&t in ul?ul[t]:!q(t)&&e.get(t)||Nm]},Rm=!0,aN=()=>Rm,[Pm,Om]=bi&&window.addEventListener?[window.addEventListener.bind(window),window.removeEventListener.bind(window)]:[hr,hr],cN=()=>{let e=ml&&document.visibilityState;return q(e)||e!=="hidden"},lN=e=>(ml&&document.addEventListener("visibilitychange",e),Pm("focus",e),()=>{ml&&document.removeEventListener("visibilitychange",e),Om("focus",e)}),AN=e=>{let t=()=>{Rm=!0,e()},r=()=>{Rm=!1};return Pm("online",t),Pm("offline",r),()=>{Om("online",t),Om("offline",r)}},zS={isOnline:aN,isVisible:cN},$S={initFocus:lN,initReconnect:AN},Cl=!ct.default.useId,Sn=!bi||YS,Hm=e=>WS()?window.requestAnimationFrame(e):setTimeout(e,1),wi=Sn?ct.useEffect:ct.useLayoutEffect,Lm=typeof navigator<"u"&&navigator.connection,Gm=!Sn&&Lm&&(["slow-2g","2g"].includes(Lm.effectiveType)||Lm.saveData),fl=new WeakMap,uN=e=>yi.prototype.toString.call(e),Fm=(e,t)=>e===`[object ${t}]`,fN=0,dl=e=>{let t=typeof e,r=uN(e),n=Fm(r,"Date"),o=Fm(r,"RegExp"),i=Fm(r,"Object"),s,a;if(yi(e)===e&&!n&&!o){if(s=fl.get(e),s)return s;if(s=++fN+"~",fl.set(e,s),Array.isArray(e)){for(s="@",a=0;a<e.length;a++)s+=dl(e[a])+",";fl.set(e,s)}if(i){s="#";let c=yi.keys(e).sort();for(;!q(a=c.pop());)q(e[a])||(s+=a+":"+dl(e[a])+",");fl.set(e,s)}}else s=n?e.toJSON():t=="symbol"?e.toString():t=="string"?JSON.stringify(e):""+e;return s},ks=e=>{if(Ot(e))try{e=e()}catch{e=""}let t=e;return e=typeof e=="string"?e:(Array.isArray(e)?e.length:e)?dl(e):"",[e,t]},mN=0,_s=()=>++mN;async function El(...e){let[t,r,n,o]=e,i=Cr({populateCache:!0,throwOnError:!0},typeof o=="boolean"?{revalidate:o}:o||{}),s=i.populateCache,a=i.rollbackOnError,c=i.optimisticData,l=m=>typeof a=="function"?a(m):a!==!1,A=i.throwOnError;if(Ot(r)){let m=r,d=[],p=t.keys();for(let E of p)!/^\$(inf|sub)\$/.test(E)&&m(t.get(E)._k)&&d.push(E);return Promise.all(d.map(u))}return u(r);async function u(m){let[d]=ks(m);if(!d)return;let[p,E]=hl(t,d),[x,I,h,y]=pr.get(t),Q=()=>{let O=x[d];return(Ot(i.revalidate)?i.revalidate(p().data,m):i.revalidate!==!1)&&(delete h[d],delete y[d],O&&O[0])?O[0](2).then(()=>p().data):p().data};if(e.length<3)return Q();let M=n,B,v=!1,P=_s();I[d]=[P,0];let N=!q(c),$=p(),S=$.data,L=$._c,J=q(L)?S:L;if(N&&(c=Ot(c)?c(J,S):c,E({data:c,_c:J})),Ot(M))try{M=M(J)}catch(O){B=O,v=!0}if(M&&pl(M))if(M=await M.catch(O=>{B=O,v=!0}),P!==I[d][0]){if(v)throw B;return M}else v&&N&&l(B)&&(s=!0,E({data:J,_c:qe}));if(s&&!v)if(Ot(s)){let O=s(M,J);E({data:O,error:qe,_c:qe})}else E({data:M,error:qe,_c:qe});if(I[d][1]=_s(),Promise.resolve(Q()).then(()=>{E({_c:qe})}),v){if(A)throw B;return}return M}}var VS=(e,t)=>{for(let r in e)e[r][0]&&e[r][0](t)},jm=(e,t)=>{if(!pr.has(e)){let r=Cr($S,t),n=Object.create(null),o=El.bind(qe,e),i=hr,s=Object.create(null),a=(A,u)=>{let m=s[A]||[];return s[A]=m,m.push(u),()=>m.splice(m.indexOf(u),1)},c=(A,u,m)=>{e.set(A,u);let d=s[A];if(d)for(let p of d)p(u,m)},l=()=>{if(!pr.has(e)&&(pr.set(e,[n,Object.create(null),Object.create(null),Object.create(null),o,c,a]),!Sn)){let A=r.initFocus(setTimeout.bind(qe,VS.bind(qe,n,0))),u=r.initReconnect(setTimeout.bind(qe,VS.bind(qe,n,1)));i=()=>{A&&A(),u&&u(),pr.delete(e)}}};return l(),[e,o,l,i]}return[e,pr.get(e)[4]]},dN=(e,t,r,n,o)=>{let i=r.errorRetryCount,s=o.retryCount,a=~~((Math.random()+.5)*(1<<(s<8?s:8)))*r.errorRetryInterval;!q(i)&&s>i||setTimeout(n,a,o)},KS=Al,[Il,XS]=jm(new Map),xl=Cr({onLoadingSlow:hr,onSuccess:hr,onError:hr,onErrorRetry:dN,onDiscarded:hr,revalidateOnFocus:!0,revalidateOnReconnect:!0,revalidateIfStale:!0,shouldRetryOnError:!0,errorRetryInterval:Gm?1e4:5e3,focusThrottleInterval:5*1e3,dedupingInterval:2*1e3,loadingTimeout:Gm?5e3:3e3,compare:KS,isPaused:()=>!1,cache:Il,mutate:XS,fallback:{}},zS),qm=(e,t)=>{let r=Cr(e,t);if(t){let{use:n,fallback:o}=e,{use:i,fallback:s}=t;n&&i&&(r.use=n.concat(i)),o&&s&&(r.fallback=Cr(o,s))}return r},gl=(0,ct.createContext)({}),Jm=e=>{let{value:t}=e,r=(0,ct.useContext)(gl),n=Ot(t),o=(0,ct.useMemo)(()=>n?t(r):t,[n,r,t]),i=(0,ct.useMemo)(()=>n?o:qm(r,o),[n,r,o]),s=o&&o.provider,a=(0,ct.useRef)(qe);s&&!a.current&&(a.current=jm(s(i.cache||Il),o));let c=a.current;return c&&(i.cache=c[0],i.mutate=c[1]),wi(()=>{if(c)return c[2]&&c[2](),c[3]},[]),(0,ct.createElement)(gl.Provider,Cr(e,{value:i}))};var ZS="$inf$";var Bi=f(w(),1);var e1=bi&&window.__SWR_DEVTOOLS_USE__,gN=e1?window.__SWR_DEVTOOLS_USE__:[],pN=()=>{e1&&(window.__SWR_DEVTOOLS_REACT__=Bi.default)},hN=e=>Ot(e[1])?[e[0],e[1],e[2]||{}]:[e[0],null,(e[1]===null?e[2]:e[1])||{}],CN=()=>{let e=(0,Bi.useContext)(gl);return(0,Bi.useMemo)(()=>Cr(xl,e),[e])};var EN=e=>(t,r,n)=>e(t,r&&((...i)=>{let[s]=ks(t),[,,,a]=pr.get(Il);if(s.startsWith(ZS))return r(...i);let c=a[s];return q(c)?r(...i):(delete a[s],c)}),n),IN=gN.concat(EN),t1=e=>function(...r){let n=CN(),[o,i,s]=hN(r),a=qm(n,s),c=e,{use:l}=a,A=(l||[]).concat(IN);for(let u=A.length;u--;)c=A[u](c);return c(o,i||a.fetcher||null,a)},r1=(e,t,r)=>{let n=t[e]||(t[e]=[]);return n.push(r),()=>{let o=n.indexOf(r);o>=0&&(n[o]=n[n.length-1],n.pop())}};pN();var xN=()=>{},Nj=xN();var Vm=Je.default.use||(e=>{switch(e.status){case"pending":throw e;case"fulfilled":return e.value;case"rejected":throw e.reason;default:throw e.status="pending",e.then(t=>{e.status="fulfilled",e.value=t},t=>{e.status="rejected",e.reason=t}),e}}),Ym={dedupe:!0},n1=Promise.resolve(qe),yN=()=>hr,bN=(e,t,r)=>{let{cache:n,compare:o,suspense:i,fallbackData:s,revalidateOnMount:a,revalidateIfStale:c,refreshInterval:l,refreshWhenHidden:A,refreshWhenOffline:u,keepPreviousData:m,strictServerPrefetchWarning:d}=r,[p,E,x,I]=pr.get(n),[h,y]=ks(e),Q=(0,Je.useRef)(!1),M=(0,Je.useRef)(!1),B=(0,Je.useRef)(h),v=(0,Je.useRef)(t),P=(0,Je.useRef)(r),N=()=>P.current,$=()=>N().isVisible()&&N().isOnline(),[S,L,J,O]=hl(n,h),Te=(0,Je.useRef)({}).current,Tt=q(s)?q(r.fallback)?qe:r.fallback[h]:s,Ut=(K,oe)=>{for(let ge in Te){let pe=ge;if(pe==="data"){if(!o(K[pe],oe[pe])&&(!q(K[pe])||!o(de,oe[pe])))return!1}else if(oe[pe]!==K[pe])return!1}return!0},Qn=!Q.current,Rs=(0,Je.useMemo)(()=>{let K=S(),oe=O(),ge=be=>{let Qt=Cr(be);return delete Qt._k,(()=>{if(!h||!t||N().isPaused())return!1;if(Qn&&!q(a))return a;let on=q(Tt)?Qt.data:Tt;return i?q(on)||c:q(on)||c})()?{isValidating:!0,isLoading:!0,...Qt}:Qt},pe=ge(K),tt=K===oe?pe:ge(oe),rt=pe;return[()=>{let be=ge(S());return Ut(be,rt)?(rt.data=be.data,rt.isLoading=be.isLoading,rt.isValidating=be.isValidating,rt.error=be.error,rt):(rt=be,be)},()=>tt]},[n,h]),en=(0,Wm.useSyncExternalStore)((0,Je.useCallback)(K=>J(h,(oe,ge)=>{Ut(ge,oe)||K()}),[n,h]),Rs[0],Rs[1]),Ps=p[h]&&p[h].length>0,tn=en.data,xr=q(tn)?Tt&&pl(Tt)?Vm(Tt):Tt:tn,ue=en.error,Mn=(0,Je.useRef)(xr),de=m?q(tn)?q(Mn.current)?xr:Mn.current:tn:xr,tr=h&&q(xr),se=(0,Je.useRef)(null);!Sn&&(0,Wm.useSyncExternalStore)(yN,()=>(se.current=!1,se),()=>(se.current=!0,se));let vn=se.current;d&&vn&&!i&&tr&&console.warn(`Missing pre-initiated data for serialized key "${h}" during server-side rendering. Data fetching should be initiated on the server and provided to SWR via fallback data. You can set "strictServerPrefetchWarning: false" to disable this warning.`);let Tn=!h||!t||N().isPaused()||Ps&&!q(ue)?!1:Qn&&!q(a)?a:i?q(xr)?!1:c:q(xr)||c,rr=Qn&&Tn,Os=q(en.isValidating)?rr:en.isValidating,Mi=q(en.isLoading)?rr:en.isLoading,rn=(0,Je.useCallback)(async K=>{let oe=v.current;if(!h||!oe||M.current||N().isPaused())return!1;let ge,pe,tt=!0,rt=K||{},be=!x[h]||!rt.dedupe,Qt=()=>Cl?!M.current&&h===B.current&&Q.current:h===B.current,nn={isValidating:!1,isLoading:!1},on=()=>{L(nn)},mo=()=>{let Ue=x[h];Ue&&Ue[1]===pe&&delete x[h]},sn={isValidating:!0};q(S().data)&&(sn.isLoading=!0);try{if(be&&(L(sn),r.loadingTimeout&&q(S().data)&&setTimeout(()=>{tt&&Qt()&&N().onLoadingSlow(h,r)},r.loadingTimeout),x[h]=[oe(y),_s()]),[ge,pe]=x[h],ge=await ge,be&&setTimeout(mo,r.dedupingInterval),!x[h]||x[h][1]!==pe)return be&&Qt()&&N().onDiscarded(h),!1;nn.error=qe;let Ue=E[h];if(!q(Ue)&&(pe<=Ue[0]||pe<=Ue[1]||Ue[1]===0))return on(),be&&Qt()&&N().onDiscarded(h),!1;let Re=S().data;nn.data=o(Re,ge)?Re:ge,be&&Qt()&&N().onSuccess(ge,h,r)}catch(Ue){mo();let Re=N(),{shouldRetryOnError:_n}=Re;Re.isPaused()||(nn.error=Ue,be&&Qt()&&(Re.onError(Ue,h,Re),(_n===!0||Ot(_n)&&_n(Ue))&&(!N().revalidateOnFocus||!N().revalidateOnReconnect||$())&&Re.onErrorRetry(Ue,h,Re,Gs=>{let go=p[h];go&&go[0]&&go[0](Bn.ERROR_REVALIDATE_EVENT,Gs)},{retryCount:(rt.retryCount||0)+1,dedupe:!0})))}return tt=!1,on(),!0},[h,n]),vi=(0,Je.useCallback)((...K)=>El(n,B.current,...K),[]);if(wi(()=>{v.current=t,P.current=r,q(tn)||(Mn.current=tn)}),wi(()=>{if(!h)return;let K=rn.bind(qe,Ym),oe=0;N().revalidateOnFocus&&(oe=Date.now()+N().focusThrottleInterval);let pe=r1(h,p,(tt,rt={})=>{if(tt==Bn.FOCUS_EVENT){let be=Date.now();N().revalidateOnFocus&&be>oe&&$()&&(oe=be+N().focusThrottleInterval,K())}else if(tt==Bn.RECONNECT_EVENT)N().revalidateOnReconnect&&$()&&K();else{if(tt==Bn.MUTATE_EVENT)return rn();if(tt==Bn.ERROR_REVALIDATE_EVENT)return rn(rt)}});return M.current=!1,B.current=h,Q.current=!0,L({_k:y}),Tn&&(x[h]||(q(xr)||Sn?K():Hm(K))),()=>{M.current=!0,pe()}},[h]),wi(()=>{let K;function oe(){let pe=Ot(l)?l(S().data):l;pe&&K!==-1&&(K=setTimeout(ge,pe))}function ge(){!S().error&&(A||N().isVisible())&&(u||N().isOnline())?rn(Ym).then(oe):oe()}return oe(),()=>{K&&(clearTimeout(K),K=-1)}},[l,A,u,h]),(0,Je.useDebugValue)(de),i){if(!Cl&&Sn&&tr)throw new Error("Fallback data is required when using Suspense in SSR.");tr&&(v.current=t,P.current=r,M.current=!1);let K=I[h],oe=!q(K)&&tr?vi(K):n1;if(Vm(oe),!q(ue)&&tr)throw ue;let ge=tr?rn(Ym):n1;!q(de)&&tr&&(ge.status="fulfilled",ge.value=!0),Vm(ge)}return{mutate:vi,get data(){return Te.data=!0,de},get error(){return Te.error=!0,ue},get isValidating(){return Te.isValidating=!0,Os},get isLoading(){return Te.isLoading=!0,Mi}}},Lj=yi.defineProperty(Jm,"defaultValue",{value:xl}),lo=t1(bN);var o1=f(Eo());async function i1({start:e,end:t,refName:r,session:n,assemblyName:o}){let{assemblyManager:i,rpcManager:s}=n,a=await i.waitForAssembly(o);if(!a)throw new Error("assembly not found");let c="getSequence";return(await s.call(c,"CoreGetFeatures",{adapterConfig:(0,o1.getConf)(a,["sequence","adapter"]),sessionId:c,regions:[{start:e,end:t,refName:a.getCanonicalRefName(r),assemblyName:o}]}))[0]?.get("seq")??""}var Ao={revalidateOnFocus:!1,revalidateOnReconnect:!1,revalidateIfStale:!1,refreshWhenHidden:!1,refreshWhenOffline:!1,shouldRetryOnError:!1};async function wN({feature:e,assemblyName:t,view:r}){let n=(0,s1.getSession)(r),{start:o,end:i,refName:s}=e.toJSON();return{seq:await i1({start:o,end:i,refName:s,assemblyName:t,session:n})}}function a1({view:e,feature:t}){let r=e?.assemblyNames?.[0],n=t&&r?{feature:t,assemblyName:r,view:e}:void 0,{data:o,error:i}=lo(n?[n.feature.id(),n.assemblyName,"feature-sequence"]:null,()=>wN(n),Ao);return{sequence:o,error:i}}function c1({view:e,feature:t}){let{sequence:r,error:n}=a1({view:e,feature:t});return{proteinSequence:r&&t?RS({seq:r.seq,feature:t}):"",sequence:r,error:n}}function BN(e,t,r){if(r&&r.length>0){let n=t.find(i=>ao(i)===e),o=n&&r.some(i=>ws(n,i));if(n&&!o){let i=t.find(s=>r.some(a=>ws(s,a)));return i?ao(i):void 0}}}function Fr({feature:e,view:t,validIds:r}){let n=(0,yl.useMemo)(()=>MB(e),[e]),[o,i]=(0,yl.useState)(()=>ao(n[0])),s=BN(o,n,r)??o,a=n.find(A=>ao(A)===s),{proteinSequence:c,error:l}=c1({view:t,feature:a});return{options:n,selectedId:s,setSelectedId:i,selectedTranscript:a,proteinSequence:c,error:l,validIds:r}}var SN=(0,u1.makeStyles)()({textAreaFont:{fontFamily:"Courier New"},inputContainer:{marginBottom:30},fileContainer:{maxWidth:500},msaInput:{marginBottom:20},queryNameInput:{marginTop:20},warningAlert:{marginTop:10}}),QN=(0,A1.observer)(function({model:t,feature:r,handleClose:n}){let o=(0,l1.getSession)(t),i=$t(t),{classes:s}=SN(),[a,c]=(0,ne.useState)(),[l,A]=(0,ne.useState)("file"),[u,m]=(0,ne.useState)(""),[d,p]=(0,ne.useState)(""),[E,x]=(0,ne.useState)(),[I,h]=(0,ne.useState)(),[y,Q]=(0,ne.useState)(""),M=Fr({feature:r,view:i}),{selectedTranscript:B,error:v}=M;return ne.default.createElement(ne.default.Fragment,null,ne.default.createElement(mr,{error:a??v},ne.default.createElement(Kt.FormControl,{component:"fieldset"},ne.default.createElement(Kt.RadioGroup,{row:!0,value:l,onChange:N=>{A(N.target.value)}},ne.default.createElement(Kt.FormControlLabel,{value:"file",control:ne.default.createElement(Kt.Radio,null),label:"Open files"}),ne.default.createElement(Kt.FormControlLabel,{value:"text",control:ne.default.createElement(Kt.Radio,null),label:"Paste text"}))),ne.default.createElement("div",{className:s.inputContainer},l==="file"?ne.default.createElement("div",{className:s.fileContainer},ne.default.createElement(zm.FileSelector,{name:"MSA File .aln (Clustal), .fa/.mfa (aligned FASTA), .stock (Stockholm), etc)",inline:!0,location:E,setLocation:x}),ne.default.createElement(zm.FileSelector,{name:"Tree file .nh (Newick) or .asn (NCBI COBALT ASN.1)",inline:!0,location:I,setLocation:h})):ne.default.createElement(ne.default.Fragment,null,ne.default.createElement(at,{variant:"outlined",name:"MSA",multiline:!0,minRows:5,className:s.msaInput,maxRows:10,fullWidth:!0,placeholder:"Paste MSA here",value:u,onChange:N=>{m(N.target.value)}}),ne.default.createElement(at,{variant:"outlined",name:"Tree",multiline:!0,minRows:5,maxRows:10,fullWidth:!0,placeholder:"Paste newick tree (optional)",value:d,onChange:N=>{p(N.target.value)}}))),ne.default.createElement(gr,{feature:r,...M}),ne.default.createElement(at,{variant:"outlined",name:"MSA row name",fullWidth:!0,required:!0,className:s.queryNameInput,placeholder:"Row name in MSA that corresponds to the selected transcript",helperText:"Required: Specify the name of the row in your MSA that should be aligned with the selected transcript",value:y,onChange:N=>{Q(N.target.value)}}),y.trim()?null:ne.default.createElement(Kt.Alert,{severity:"warning",className:s.warningAlert},"Without specifying the MSA row name, clicking on the MSA will not navigate to the corresponding genome position, and hovering highlights will not work.")),ne.default.createElement(Xr,{submitDisabled:!B||l==="file"&&!E||l==="text"&&!u.trim(),onSubmit:()=>{try{B&&(c(void 0),vS({session:o,newViewTitle:co(B),view:i,feature:B,querySeqName:y.trim(),...l==="file"?{msaFilehandle:E,treeFilehandle:I}:{data:{msa:u,tree:d}}}),n())}catch(N){console.error(N),c(N)}},onCancel:n}))}),f1=QN;var Ir=f(w()),R1=f(Ce());Yu();var P1=f(k()),O1=f(Se());var Ae=f(w());Af();var Gt=f(k()),B1=f(G()),S1=f(Se());var et=f(w()),h1=f(we());W();var m1=f(R(),1),d1=(0,_.createSvgIcon)((0,m1.jsx)("path",{d:"M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6zM19 4h-3.5l-1-1h-5l-1 1H5v2h14z"}),"Delete");var mt=f(k()),C1=f(G()),E1=f(Se());var $m=f(Ce());function bl({newViewTitle:e,view:t,feature:r,blastParams:n}){(0,$m.getSession)(t).addView("MsaView",{type:"MsaView",displayName:e,connectedViewId:t.id,connectedFeature:r.toJSON(),drawNodeBubbles:!0,colWidth:10,rowHeight:12,blastParams:n})}function g1({newViewTitle:e,view:t,cached:r}){(0,$m.getSession)(t).addView("MsaView",{type:"MsaView",displayName:e,connectedViewId:t.id,drawNodeBubbles:!0,colWidth:10,rowHeight:12,data:{msa:r.msa,tree:r.tree,treeMetadata:r.treeMetadata}})}function wl(e){let{data:t,error:r,mutate:n}=lo(`cached-blast-${e.join(",")}`,async()=>(await TB()).filter(a=>a.geneId&&e.includes(a.geneId)),Ao);return{results:t??[],error:r,isLoading:!t&&!r,handleDelete:async s=>{await _B(s),await n(a=>a?.filter(c=>c.id!==s)??[],!1)},handleClearAll:async()=>{await kB(),await n([],!1)}}}var MN=(0,E1.makeStyles)()({header:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:8},resultList:{maxHeight:300,overflow:"auto"}});function p1(e){let t=[e.geneName,e.transcriptName!==e.geneName?e.transcriptName:void 0].filter(r=>!!r);return t.length>0?t.join(" - "):e.geneId??e.transcriptId??"Unknown"}var vN=(0,C1.observer)(function({model:e,handleClose:t,feature:r}){let{classes:n}=MN(),o=$t(e),[i,s]=(0,et.useState)(),a=(0,et.useMemo)(()=>el(r),[r]),{results:c,error:l,isLoading:A,handleDelete:u,handleClearAll:m}=wl(a),d=E=>{g1({view:o,cached:E,newViewTitle:`BLAST - ${p1(E)}`}),t()},p=l??i;return p?et.default.createElement(h1.ErrorMessage,{error:p}):A?et.default.createElement(mt.Typography,null,"Loading cached results..."):c.length===0?et.default.createElement(mt.Typography,{color:"textSecondary"},"No cached BLAST results found for this gene. Run a BLAST query to cache results."):et.default.createElement("div",null,et.default.createElement("div",{className:n.header},et.default.createElement(mt.Typography,{variant:"subtitle1"},"Cached BLAST Results (",c.length,")"),et.default.createElement(mt.Button,{size:"small",color:"error",onClick:async()=>{try{s(void 0),await m()}catch(E){s(E)}}},"Clear All")),et.default.createElement(mt.List,{dense:!0,className:n.resultList},c.map(E=>et.default.createElement(mt.ListItem,{key:E.id,disablePadding:!0,secondaryAction:et.default.createElement(mt.IconButton,{edge:"end",size:"small",onClick:async x=>{x.stopPropagation();try{s(void 0),await u(E.id)}catch(I){s(I)}}},et.default.createElement(d1,{fontSize:"small"}))},et.default.createElement(mt.ListItemButton,{onClick:()=>{d(E)}},et.default.createElement(mt.ListItemText,{primary:`${p1(E)} - ${E.blastDatabase}/${E.blastProgram} (${E.msaAlgorithm})`,secondary:`${new Date(E.timestamp).toLocaleString()} - Seq: ${E.proteinSequence.slice(0,30)}...`}))))))}),I1=vN;var Km=f(w()),w1=f(k());var Bl="https://blast.ncbi.nlm.nih.gov/Blast.cgi",x1=["clustalo","muscle","kalign","mafft"],y1=["nr","nr_cluster_seq"],b1=["blastp","quick-blastp"];function Ds({value:e,onChange:t,className:r}){return Km.default.createElement(at,{variant:"outlined",label:"MSA Algorithm",className:r,select:!0,value:e,onChange:n=>{t(n.target.value)}},x1.map(n=>Km.default.createElement(w1.MenuItem,{value:n,key:n},n)))}var TN=(0,S1.makeStyles)()({selectField:{width:150},databaseFieldContainer:{display:"flex"},clusterSeqMessage:{marginLeft:4,alignContent:"center"},cachedResultsAccordion:{marginTop:20},infoText:{marginTop:20}}),_N=(0,B1.observer)(function({handleClose:e,feature:t,model:r,children:n,baseUrl:o}){let{classes:i}=TN(),s=$t(r),[a,c]=(0,Ae.useState)(),[l,A]=(0,Ae.useState)("nr"),[u,m]=(0,Ae.useState)("clustalo"),[d,p]=(0,Ae.useState)("quick-blastp"),E=(0,Ae.useMemo)(()=>el(t),[t]),{results:x,error:I}=wl(E),h=Fr({feature:t,view:s}),{selectedTranscript:y,proteinSequence:Q}=h,M=h.error??a??I;return Ae.default.createElement(Ae.default.Fragment,null,Ae.default.createElement(mr,{error:M},n,Ae.default.createElement(at,{variant:"outlined",label:"BLAST database",className:i.selectField,select:!0,value:l,onChange:B=>{let v=B.target.value;A(v),v==="nr_cluster_seq"&&p("blastp")}},y1.map(B=>Ae.default.createElement(Gt.MenuItem,{value:B,key:B},B))),Ae.default.createElement(Ds,{className:i.selectField,value:u,onChange:m}),Ae.default.createElement("div",{className:i.databaseFieldContainer},Ae.default.createElement(at,{variant:"outlined",label:"BLAST program",disabled:l==="nr_cluster_seq",className:i.selectField,select:!0,value:d,onChange:B=>{p(B.target.value)}},b1.map(B=>Ae.default.createElement(Gt.MenuItem,{value:B,key:B},B))),l==="nr_cluster_seq"?Ae.default.createElement(Gt.Typography,{variant:"subtitle2",className:i.clusterSeqMessage},"Can only use blastp on nr_cluster_seq"):null),Ae.default.createElement(gr,{feature:t,...h}),Ae.default.createElement(Gt.Typography,{className:i.infoText},"This panel will automatically submit a query to NCBI. Using blastp can take 10+ minutes to run, quick-blastp is generally a lot faster but is not available for the clustered database. After completion, all the hits will be run through a multiple sequence alignment. Note: we are not able to currently run NCBI COBALT automatically on the BLAST results, even though that is the method NCBI uses on their website. If you need a COBALT alignment, please use the manual approach of submitting BLAST yourself and downloading the resulting files"),x.length>0?Ae.default.createElement(Gt.Accordion,{className:i.cachedResultsAccordion},Ae.default.createElement(Gt.AccordionSummary,{expandIcon:Ae.default.createElement(gc,null)},Ae.default.createElement(Gt.Typography,null,"Previous BLAST Results")),Ae.default.createElement(Gt.AccordionDetails,null,Ae.default.createElement(I1,{model:r,handleClose:e,feature:t}))):null),Ae.default.createElement(Xr,{submitDisabled:!Q,onSubmit:()=>{try{y&&(c(void 0),bl({feature:y,view:s,newViewTitle:Xc(t,y),blastParams:{baseUrl:o,blastProgram:d,blastDatabase:l,msaAlgorithm:u,selectedTranscript:y,proteinSequence:Q}}),e())}catch(B){console.error(B),c(B)}},onCancel:e}))}),Q1=_N;var Rr=f(w()),v1=f(Ce()),Si=f(k()),T1=f(G()),_1=f(Se());Sl();var kN=(0,_1.makeStyles)()({ncbiLink:{wordBreak:"break-all",margin:30,maxWidth:600},infoText:{marginTop:20}}),DN=(0,T1.observer)(function({handleClose:e,feature:t,model:r,children:n,baseUrl:o}){let{classes:i}=kN(),s=$t(r),a=Fr({feature:t,view:s}),{proteinSequence:c,error:l}=a,A=Zc(c),u=`${o}?PAGE_TYPE=BlastSearch&PAGE=Proteins&PROGRAM=blastp&QUERY=${A}`,m=`${o}?PAGE_TYPE=BlastSearch&PAGE=Proteins&PROGRAM=blastp&QUERY=${(0,v1.shorten2)(A,10)}`;return Rr.default.createElement(Rr.default.Fragment,null,Rr.default.createElement(mr,{error:l},n,Rr.default.createElement(gr,{feature:t,...a}),c?Rr.default.createElement("div",{className:i.ncbiLink},"Link to NCBI BLAST: ",Rr.default.createElement(uo,{href:u},m)):null,Rr.default.createElement(Si.Typography,{className:i.infoText},`Click the link above and run your BLAST query, and once you have results, click "Multiple Alignment" at the top of the results page to be redirected to COBALT, NCBI's multiple sequence aligner. Once COBALT completes, you can download an MSA (.aln file) and optionally a Newick tree (.nh) and paste the results into JBrowse`)),Rr.default.createElement(Si.DialogActions,null,Rr.default.createElement(Si.Button,{color:"primary",variant:"contained",onClick:()=>{e()}},"Close")))}),k1=DN;var Zr=f(w()),Xt=f(k());function Zm({lookupMethod:e,setLookupMethod:t}){return Zr.default.createElement(Xt.FormControl,{component:"fieldset"},Zr.default.createElement(Xt.RadioGroup,{row:!0,value:e,onChange:r=>{t(r.target.value)}},Zr.default.createElement(Xt.FormControlLabel,{value:"automatic",control:Zr.default.createElement(Xt.Radio,null),label:"Automatic"}),Zr.default.createElement(Xt.FormControlLabel,{value:"rid",control:Zr.default.createElement(Xt.Radio,null),label:"Load from RID"}),Zr.default.createElement(Xt.FormControlLabel,{value:"manual",control:Zr.default.createElement(Xt.Radio,null),label:"Manual"})))}var dt=f(w()),Ql=f(k()),D1=f(G()),N1=f(Se());Sl();var NN=(0,N1.makeStyles)()({marginBottom:{marginBottom:16},ridField:{width:150},infoText:{marginTop:20}}),LN=(0,D1.observer)(function({handleClose:e,feature:t,model:r,children:n,baseUrl:o}){let{classes:i}=NN(),s=$t(r),[a,c]=(0,dt.useState)(),[l,A]=(0,dt.useState)(""),[u,m]=(0,dt.useState)("clustalo"),d=Fr({feature:t,view:s}),{selectedTranscript:p,proteinSequence:E}=d,x=d.error??a,I=l.trim();return dt.default.createElement(dt.default.Fragment,null,dt.default.createElement(mr,{error:x},n,dt.default.createElement(Ql.Typography,{variant:"body2",className:i.marginBottom},"Enter the RID (Request ID) from a previously submitted NCBI BLAST query. You can find the RID in the BLAST results page URL or at the top of the results page. RIDs are typically valid for 24-36 hours after submission."),dt.default.createElement(at,{variant:"outlined",label:"BLAST RID",placeholder:"e.g., ABC12345",fullWidth:!0,className:i.marginBottom,value:l,onChange:h=>{A(h.target.value)}}),I?dt.default.createElement(Ql.Typography,{variant:"body2",className:i.marginBottom},dt.default.createElement(uo,{href:`${o}?CMD=Get&RID=${I}`},"View BLAST results on NCBI")):null,dt.default.createElement(Ds,{className:i.ridField,value:u,onChange:m}),dt.default.createElement(gr,{feature:t,...d}),dt.default.createElement(Ql.Typography,{className:i.infoText},"This will fetch the BLAST results for the provided RID and run them through a multiple sequence alignment. The protein sequence from the selected transcript will be added as the query sequence in the MSA.")),dt.default.createElement(Xr,{submitDisabled:!E||!I,onSubmit:()=>{try{p&&I&&(c(void 0),bl({feature:p,view:s,newViewTitle:Xc(t,p),blastParams:{baseUrl:o,blastProgram:"blastp",blastDatabase:"nr",msaAlgorithm:u,selectedTranscript:p,proteinSequence:E,rid:I}}),e())}catch(h){console.error(h),c(h)}},onCancel:e}))}),L1=LN;var Er=f(w()),Zt=f(k()),F1=f(Se());var FN=(0,F1.makeStyles)()({urlField:{minWidth:300}});function ed({handleClose:e,baseUrl:t}){let{classes:r}=FN(),[n,o]=(0,Er.useState)(t);return Er.default.createElement(Zt.Dialog,{open:!0,maxWidth:"lg",onClose:()=>{e()}},Er.default.createElement(Zt.DialogTitle,null,"BLAST Settings"),Er.default.createElement(Zt.DialogContent,null,Er.default.createElement(at,{autoFocus:!0,margin:"dense",label:"BLAST Base URL",fullWidth:!0,variant:"outlined",value:n,className:r.urlField,onChange:i=>{o(i.target.value)}}),Er.default.createElement(Zt.Button,{variant:"contained",onClick:()=>{o(Bl)}},"Reset")),Er.default.createElement(Zt.DialogActions,null,Er.default.createElement(Zt.Button,{variant:"contained",color:"secondary",onClick:()=>{e()}},"Cancel"),Er.default.createElement(Zt.Button,{color:"primary",variant:"contained",onClick:()=>{e(n)}},"Save")))}var RN=(0,O1.makeStyles)()({settingsButton:{float:"right"}}),PN={automatic:Q1,rid:L1,manual:k1};function td({handleClose:e,model:t,feature:r}){let[n,o]=(0,Ir.useState)("automatic"),[i,s]=(0,R1.useLocalStorage)("msa-blastRootUrl",Bl),[a,c]=(0,Ir.useState)(!1),{classes:l}=RN(),A=PN[n];return Ir.default.createElement(Ir.default.Fragment,null,Ir.default.createElement(P1.IconButton,{className:l.settingsButton,size:"small",onClick:()=>{c(!0)}},Ir.default.createElement(sc,null)),Ir.default.createElement(A,{model:t,feature:r,handleClose:e,baseUrl:i},Ir.default.createElement(Zm,{lookupMethod:n,setLookupMethod:o})),a?Ir.default.createElement(ed,{baseUrl:i,handleClose:u=>{u&&s(u),c(!1)}}):null)}var gt=f(w()),Ns=f(we()),vl=f(Ce()),Y1=f(k()),W1=f(G());var z1=f(Se());ln();function rd(e,t="",r=5e3){let n=[e];for(;n.length;){let o=n.pop();for(let[i,s]of Object.entries(o)){if(t.length>r)return Iu(t);typeof s=="object"&&s!==null?n.push(s):i==="locationType"&&s==="FileHandleLocation"?t+=`${i}-BlobLocation`:i==="handleId"?t+=`blobId-fh-blob-${s}`:t+=`${i}-${s}`}}return`adp-${Iu(t)}`}function G1(e={}){return e.type&&e.adapterId?`${e.type}-${e.adapterId}`:`${rd(e)}`}var U1={};async function ON(e,t,r){let n=r?.type;if(!n)throw new Error(`could not determine adapter type from adapter config snapshot ${JSON.stringify(r)}`);let o=e.getAdapterType(n);if(!o)throw new Error(`unknown data adapter type ${n}`);let i=o.configSchema.create(r,{pluginManager:e}),s=nd.bind(null,e,t),a=await o.getAdapterClass();return{dataAdapter:new a(i,s,e),sessionIds:new Set([t])}}async function nd(e,t,r){let n=G1(r);U1[n]??=ON(e,t,r);let o=await U1[n];return o.sessionIds.add(t),o}async function H1(e,t){return(await nd(e,"msa",t)).dataAdapter}async function j1({config:e,pluginManager:t}){return(await H1(t,e)).getMSAList()}async function q1({config:e,pluginManager:t,msaId:r}){return(await H1(t,e)).getMSA(r)}function J1({session:e,newViewTitle:t,view:r,feature:n,data:o,querySeqName:i}){e.addView("MsaView",{type:"MsaView",displayName:t,treeAreaWidth:200,querySeqName:i,treeWidth:100,drawNodeBubbles:!1,labelsAlignRight:!0,showBranchLen:!1,colWidth:10,rowHeight:12,colorSchemeName:"percent_identity_dynamic",data:o,connectedViewId:r.id,connectedFeature:n.toJSON()})}var V1=f(Eo());function Ml(e){return(0,V1.readConfObject)(e,["msa","datasets"])}var GN=(0,z1.makeStyles)()({selectedContainer:{marginTop:50}}),UN=(0,W1.observer)(function({model:e,feature:t,handleClose:r}){let n=(0,vl.getSession)(e),o=$t(e),{classes:i}=GN(),{pluginManager:s}=(0,vl.getEnv)(e),{assemblyNames:a}=o,[c,l]=(0,gt.useState)(),A=Ml(n.jbrowse),[u,m]=(0,gt.useState)(A?.[0]?.datasetId),d=A?.find(P=>P.datasetId===u),{data:p,isLoading:E,error:x}=lo(d?`${d.datasetId}-msa-list`:null,()=>j1({config:d.adapter,pluginManager:s}),Ao),I=Fr({feature:t,view:o,validIds:p}),{selectedId:h,selectedTranscript:y}=I,{data:Q,isLoading:M,error:B}=lo(h&&d&&p?`${d.datasetId}-${h}-${p.length}-msa`:null,()=>q1({msaId:h,config:d.adapter,pluginManager:s}),Ao),v=x??B??I.error??c;return gt.default.createElement(gt.default.Fragment,null,gt.default.createElement(mr,{error:v},gt.default.createElement(at,{select:!0,label:"Select MSA dataset",value:u,onChange:P=>{m(P.target.value)}},A?.map(P=>gt.default.createElement(Y1.MenuItem,{key:P.datasetId,value:P.datasetId},P.name))),d?gt.default.createElement("div",{className:i.selectedContainer},!E&&M?gt.default.createElement(Ns.LoadingEllipses,{variant:"h6",message:`Loading MSA for (${h})`}):null,E?gt.default.createElement(Ns.LoadingEllipses,{variant:"h6",message:`Loading available MSAs for (${d.name})`}):null,p?gt.default.createElement("div",null,gt.default.createElement(Ns.SanitizedHTML,{html:d.description}),gt.default.createElement(gr,{feature:t,...I})):null):null),gt.default.createElement(Xr,{submitDisabled:!y||!Q?.length,onSubmit:()=>{try{if(y&&Q){let P=`${h}_${a[0]}`;J1({session:n,newViewTitle:co(y),view:o,querySeqName:P,feature:y,data:{msa:Q.map(N=>`>${N.get("refName")}
74
+ ${N.get("seq")}`).join(`
75
+ `)}}),r()}}catch(P){l(P)}},onCancel:r}))}),$1=UN;var K1=f(w());function Ls({children:e,value:t,index:r,...n}){return K1.default.createElement("div",{role:"tabpanel",hidden:t!==r,...n},t===r?e:null)}function od({handleClose:e,feature:t,model:r}){let n=(0,Z1.getSession)(r),i=!!Ml(n.jbrowse)?.length,[s,a]=(0,vt.useState)("ncbi_blast");return vt.default.createElement(X1.Dialog,{maxWidth:"xl",title:"Launch MSA view",open:!0,onClose:e},vt.default.createElement(Qi.Tabs,{value:s,onChange:(c,l)=>{a(l)}},vt.default.createElement(Qi.Tab,{label:"NCBI BLAST query",value:"ncbi_blast"}),i?vt.default.createElement(Qi.Tab,{label:"Pre-loaded MSA datasets",value:"preloaded_msa"}):null,vt.default.createElement(Qi.Tab,{label:"Manual upload",value:"manual_msa"})),vt.default.createElement(Ls,{value:s,index:"ncbi_blast"},vt.default.createElement(td,{handleClose:e,feature:t,model:r})),i?vt.default.createElement(Ls,{value:s,index:"preloaded_msa"},vt.default.createElement($1,{model:r,feature:t,handleClose:e})):null,vt.default.createElement(Ls,{value:s,index:"manual_msa"},vt.default.createElement(f1,{model:r,feature:t,handleClose:e})))}function HN(e){return e.name==="LinearBasicDisplay"}function jN(e){return e.views(t=>{let r=t.contextMenuItems;return{contextMenuItems(){let n=t.contextMenuFeature,o=(0,Tl.getContainingTrack)(t),i=n?.get("type"),s=n&&["gene","mRNA","transcript"].includes(i);return[...r(),...s?[{label:"Launch MSA view",icon:MS,onClick:()=>{(0,Tl.getSession)(o).queueDialog(a=>[od,{model:o,handleClose:a,feature:n}])}}]:[]]}}})}function id(e){e.addToExtensionPoint("Core-extendPluggableElement",t=>(HN(t)&&(t.stateModel=jN(t.stateModel)),t))}function sd(e){e.addToExtensionPoint("LaunchView-MsaView",({session:t,data:r,msaFileLocation:n,treeFileLocation:o,connectedViewId:i,connectedFeature:s,displayName:a,colorSchemeName:c,colWidth:l,rowHeight:A,treeAreaWidth:u,treeWidth:m,drawNodeBubbles:d,labelsAlignRight:p,showBranchLen:E,querySeqName:x})=>{if(!r&&!n)throw new Error("No MSA data or file location provided when launching MSA view");t.addView("MsaView",{type:"MsaView",displayName:a,connectedViewId:i,connectedFeature:s,colorSchemeName:c,colWidth:l,rowHeight:A,treeAreaWidth:u,treeWidth:m,drawNodeBubbles:d,labelsAlignRight:p,showBranchLen:E,init:{msaData:r?.msa,treeData:r?.tree,msaUrl:n?.uri,treeUrl:o?.uri,querySeqName:x}})})}var pQ=f(w()),hQ=f(tQ());var KN=(0,pQ.lazy)(()=>Promise.resolve().then(()=>(gQ(),dQ)));function Ad(e){e.addViewType(()=>new hQ.default({name:"MsaView",stateModel:ym(),ReactComponent:KN}))}var CQ="2.5.0";var Dl=class extends EQ.default{constructor(){super(...arguments);this.name="MsaViewPlugin";this.version=CQ;this.rootConfigurationSchema=r=>({msa:(0,ud.ConfigurationSchema)("MSA",{datasets:fd.types.maybe(fd.types.array((0,ud.ConfigurationSchema)("MSAEntry",{datasetId:{type:"string",defaultValue:""},description:{type:"string",defaultValue:""},name:{type:"string",defaultValue:""},adapter:r.pluggableConfigSchemaType("adapter")})))})})}install(r){Ad(r),id(r),sd(r),Qm(r),vm(r)}configure(r){(0,IQ.isAbstractMenuManager)(r.rootModel)&&r.rootModel.appendToSubMenu(["Add"],{label:"Multiple sequence alignment view",icon:Fd,onClick:n=>{n.addView("MsaView",{})}})}};return DQ(XN);})();
76
76
  /*! Bundled license information:
77
77
 
78
- use-sync-external-store/cjs/use-sync-external-store-shim.production.js:
79
- (**
80
- * @license React
81
- * use-sync-external-store-shim.production.js
82
- *
83
- * Copyright (c) Meta Platforms, Inc. and affiliates.
84
- *
85
- * This source code is licensed under the MIT license found in the
86
- * LICENSE file in the root directory of this source tree.
87
- *)
88
-
89
78
  react-is/cjs/react-is.production.min.js:
90
79
  (** @license React v16.13.1
91
80
  * react-is.production.min.js
@@ -106,6 +95,17 @@ escape-html/index.js:
106
95
  *)
107
96
 
108
97
  dompurify/dist/purify.es.mjs:
109
- (*! @license DOMPurify 3.4.5 | (c) Cure53 and other contributors | Released under the Apache license 2.0 and Mozilla Public License 2.0 | github.com/cure53/DOMPurify/blob/3.4.5/LICENSE *)
98
+ (*! @license DOMPurify 3.4.7 | (c) Cure53 and other contributors | Released under the Apache license 2.0 and Mozilla Public License 2.0 | github.com/cure53/DOMPurify/blob/3.4.7/LICENSE *)
99
+
100
+ use-sync-external-store/cjs/use-sync-external-store-shim.production.js:
101
+ (**
102
+ * @license React
103
+ * use-sync-external-store-shim.production.js
104
+ *
105
+ * Copyright (c) Meta Platforms, Inc. and affiliates.
106
+ *
107
+ * This source code is licensed under the MIT license found in the
108
+ * LICENSE file in the root directory of this source tree.
109
+ *)
110
110
  */
111
111
  //# sourceMappingURL=jbrowse-plugin-msaview.umd.production.min.js.map